diff --git a/cp/public/assets/js/tabler.esm.min.js b/cp/public/assets/js/tabler.esm.min.js deleted file mode 100644 index 2f4015a..0000000 --- a/cp/public/assets/js/tabler.esm.min.js +++ /dev/null @@ -1,15 +0,0 @@ -/*! -* Tabler v1.0.0-beta20 (https://tabler.io) -* @version 1.0.0-beta20 -* @link https://tabler.io -* Copyright 2018-2023 The Tabler Authors -* Copyright 2018-2023 codecalm.net Paweł Kuna -* Licensed under MIT (https://github.com/tabler/tabler/blob/master/LICENSE) -*/ -var e=new Map;function t(t){var s=e.get(t);s&&s.destroy()}function o(t){var s=e.get(t);s&&s.update()}var r=null;"undefined"==typeof window?((r=function(e){return e}).destroy=function(e){return e},r.update=function(e){return e}):((r=function(t,s){return t&&Array.prototype.forEach.call(t.length?t:[t],(function(t){return function(t){if(t&&t.nodeName&&"TEXTAREA"===t.nodeName&&!e.has(t)){var s,i=null,n=window.getComputedStyle(t),r=(s=t.value,function(){o({testForHeightReduction:""===s||!t.value.startsWith(s),restoreTextAlign:null}),s=t.value}),a=function(s){t.removeEventListener("autosize:destroy",a),t.removeEventListener("autosize:update",l),t.removeEventListener("input",r),window.removeEventListener("resize",l),Object.keys(s).forEach((function(e){return t.style[e]=s[e]})),e.delete(t)}.bind(t,{height:t.style.height,resize:t.style.resize,textAlign:t.style.textAlign,overflowY:t.style.overflowY,overflowX:t.style.overflowX,wordWrap:t.style.wordWrap});t.addEventListener("autosize:destroy",a),t.addEventListener("autosize:update",l),t.addEventListener("input",r),window.addEventListener("resize",l),t.style.overflowX="hidden",t.style.wordWrap="break-word",e.set(t,{destroy:a,update:l}),l()}function o(e){var s,r,a=e.restoreTextAlign,l=void 0===a?null:a,u=e.testForHeightReduction,c=void 0===u||u,h=n.overflowY;if(0!==t.scrollHeight&&("vertical"===n.resize?t.style.resize="none":"both"===n.resize&&(t.style.resize="horizontal"),c&&(s=function(e){for(var t=[];e&&e.parentNode&&e.parentNode instanceof Element;)e.parentNode.scrollTop&&t.push([e.parentNode,e.parentNode.scrollTop]),e=e.parentNode;return function(){return t.forEach((function(e){var t=e[0],s=e[1];t.style.scrollBehavior="auto",t.scrollTop=s,t.style.scrollBehavior=null}))}}(t),t.style.height=""),r="content-box"===n.boxSizing?t.scrollHeight-(parseFloat(n.paddingTop)+parseFloat(n.paddingBottom)):t.scrollHeight+parseFloat(n.borderTopWidth)+parseFloat(n.borderBottomWidth),"none"!==n.maxHeight&&r>parseFloat(n.maxHeight)?("hidden"===n.overflowY&&(t.style.overflow="scroll"),r=parseFloat(n.maxHeight)):"hidden"!==n.overflowY&&(t.style.overflow="hidden"),t.style.height=r+"px",l&&(t.style.textAlign=l),s&&s(),i!==r&&(t.dispatchEvent(new Event("autosize:resized",{bubbles:!0})),i=r),h!==n.overflow&&!l)){var d=n.textAlign;"hidden"===n.overflow&&(t.style.textAlign="start"===d?"end":"start"),o({restoreTextAlign:d,testForHeightReduction:!0})}}function l(){o({testForHeightReduction:!0,restoreTextAlign:null})}}(t)})),t}).destroy=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],t),e},r.update=function(e){return e&&Array.prototype.forEach.call(e.length?e:[e],o),e});var n=r,elements=document.querySelectorAll('[data-bs-toggle="autosize"]');function _objectWithoutPropertiesLoose(e,t){if(null==e)return{};var s,i,n={},r=Object.keys(e);for(i=0;i=0||(n[s]=e[s]);return n}function IMask(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return new IMask.InputMask(e,t)}elements.length&&elements.forEach((function(e){n(e)}));class ChangeDetails{constructor(e){Object.assign(this,{inserted:"",rawInserted:"",skip:!1,tailShift:0},e)}aggregate(e){return this.rawInserted+=e.rawInserted,this.skip=this.skip||e.skip,this.inserted+=e.inserted,this.tailShift+=e.tailShift,this}get offset(){return this.tailShift+this.inserted.length}}function isString(e){return"string"==typeof e||e instanceof String}IMask.ChangeDetails=ChangeDetails;const DIRECTION={NONE:"NONE",LEFT:"LEFT",FORCE_LEFT:"FORCE_LEFT",RIGHT:"RIGHT",FORCE_RIGHT:"FORCE_RIGHT"};function forceDirection(e){switch(e){case DIRECTION.LEFT:return DIRECTION.FORCE_LEFT;case DIRECTION.RIGHT:return DIRECTION.FORCE_RIGHT;default:return e}}function escapeRegExp(e){return e.replace(/([.*+?^=!:${}()|[\]\/\\])/g,"\\$1")}function normalizePrepare(e){return Array.isArray(e)?e:[e,new ChangeDetails]}function objectIncludes(e,t){if(t===e)return!0;var s,i=Array.isArray(t),n=Array.isArray(e);if(i&&n){if(t.length!=e.length)return!1;for(s=0;s0&&void 0!==arguments[0]?arguments[0]:"",t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,s=arguments.length>2?arguments[2]:void 0;this.value=e,this.from=t,this.stop=s}toString(){return this.value}extend(e){this.value+=String(e)}appendTo(e){return e.append(this.toString(),{tail:!0}).aggregate(e._appendPlaceholder())}get state(){return{value:this.value,from:this.from,stop:this.stop}}set state(e){Object.assign(this,e)}unshift(e){if(!this.value.length||null!=e&&this.from>=e)return"";const t=this.value[0];return this.value=this.value.slice(1),t}shift(){if(!this.value.length)return"";const e=this.value[this.value.length-1];return this.value=this.value.slice(0,-1),e}}class Masked{constructor(e){this._value="",this._update(Object.assign({},Masked.DEFAULTS,e)),this.isInitialized=!0}updateOptions(e){Object.keys(e).length&&this.withValueRefresh(this._update.bind(this,e))}_update(e){Object.assign(this,e)}get state(){return{_value:this.value}}set state(e){this._value=e._value}reset(){this._value=""}get value(){return this._value}set value(e){this.resolve(e)}resolve(e){return this.reset(),this.append(e,{input:!0},""),this.doCommit(),this.value}get unmaskedValue(){return this.value}set unmaskedValue(e){this.reset(),this.append(e,{},""),this.doCommit()}get typedValue(){return this.doParse(this.value)}set typedValue(e){this.value=this.doFormat(e)}get rawInputValue(){return this.extractInput(0,this.value.length,{raw:!0})}set rawInputValue(e){this.reset(),this.append(e,{raw:!0},""),this.doCommit()}get displayValue(){return this.value}get isComplete(){return!0}get isFilled(){return this.isComplete}nearestInputPos(e,t){return e}totalInputPositions(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;return Math.min(this.value.length,t-e)}extractInput(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;return this.value.slice(e,t)}extractTail(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;return new ContinuousTailDetails(this.extractInput(e,t),e)}appendTail(e){return isString(e)&&(e=new ContinuousTailDetails(String(e))),e.appendTo(this)}_appendCharRaw(e){return e?(this._value+=e,new ChangeDetails({inserted:e,rawInserted:e})):new ChangeDetails}_appendChar(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=arguments.length>2?arguments[2]:void 0;const i=this.state;let n;if([e,n]=normalizePrepare(this.doPrepare(e,t)),n=n.aggregate(this._appendCharRaw(e,t)),n.inserted){let e,r=!1!==this.doValidate(t);if(r&&null!=s){const t=this.state;!0===this.overwrite&&(e=s.state,s.unshift(this.value.length-n.tailShift));let i=this.appendTail(s);r=i.rawInserted===s.toString(),r&&i.inserted||"shift"!==this.overwrite||(this.state=t,e=s.state,s.shift(),i=this.appendTail(s),r=i.rawInserted===s.toString()),r&&i.inserted&&(this.state=t)}r||(n=new ChangeDetails,this.state=i,s&&e&&(s.state=e))}return n}_appendPlaceholder(){return new ChangeDetails}_appendEager(){return new ChangeDetails}append(e,t,s){if(!isString(e))throw new Error("value should be string");const i=new ChangeDetails,n=isString(s)?new ContinuousTailDetails(String(s)):s;null!=t&&t.tail&&(t._beforeTailState=this.state);for(let s=0;s0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;return this._value=this.value.slice(0,e)+this.value.slice(t),new ChangeDetails}withValueRefresh(e){if(this._refreshing||!this.isInitialized)return e();this._refreshing=!0;const t=this.rawInputValue,s=this.value,i=e();return this.rawInputValue=t,this.value&&this.value!==s&&0===s.indexOf(this.value)&&this.append(s.slice(this.value.length),{},""),delete this._refreshing,i}runIsolated(e){if(this._isolated||!this.isInitialized)return e(this);this._isolated=!0;const t=this.state,s=e(this);return this.state=t,delete this._isolated,s}doSkipInvalid(e){return this.skipInvalid}doPrepare(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return this.prepare?this.prepare(e,this,t):e}doValidate(e){return(!this.validate||this.validate(this.value,this,e))&&(!this.parent||this.parent.doValidate(e))}doCommit(){this.commit&&this.commit(this.value,this)}doFormat(e){return this.format?this.format(e,this):e}doParse(e){return this.parse?this.parse(e,this):e}splice(e,t,s,i){let n=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{input:!0};const r=e+t,a=this.extractTail(r),o=!0===this.eager||"remove"===this.eager;let l;o&&(i=forceDirection(i),l=this.extractInput(0,r,{raw:!0}));let u=e;const c=new ChangeDetails;if(i!==DIRECTION.NONE&&(u=this.nearestInputPos(e,t>1&&0!==e&&!o?DIRECTION.NONE:i),c.tailShift=u-e),c.aggregate(this.remove(u)),o&&i!==DIRECTION.NONE&&l===this.rawInputValue)if(i===DIRECTION.FORCE_LEFT){let e;for(;l===this.rawInputValue&&(e=this.value.length);)c.aggregate(new ChangeDetails({tailShift:-1})).aggregate(this.remove(e-1))}else i===DIRECTION.FORCE_RIGHT&&a.unshift();return c.aggregate(this.append(s,n,a))}maskEquals(e){return this.mask===e}typedValueEquals(e){const t=this.typedValue;return e===t||Masked.EMPTY_VALUES.includes(e)&&Masked.EMPTY_VALUES.includes(t)||this.doFormat(e)===this.doFormat(this.typedValue)}}function maskedClass(e){if(null==e)throw new Error("mask property should be defined");return e instanceof RegExp?IMask.MaskedRegExp:isString(e)?IMask.MaskedPattern:e instanceof Date||e===Date?IMask.MaskedDate:e instanceof Number||"number"==typeof e||e===Number?IMask.MaskedNumber:Array.isArray(e)||e===Array?IMask.MaskedDynamic:IMask.Masked&&e.prototype instanceof IMask.Masked?e:e instanceof IMask.Masked?e.constructor:e instanceof Function?IMask.MaskedFunction:(console.warn("Mask not found for mask",e),IMask.Masked)}function createMask(e){if(IMask.Masked&&e instanceof IMask.Masked)return e;const t=(e=Object.assign({},e)).mask;if(IMask.Masked&&t instanceof IMask.Masked)return t;const s=maskedClass(t);if(!s)throw new Error("Masked class is not found for provided mask, appropriate module needs to be import manually before creating mask.");return new s(e)}Masked.DEFAULTS={format:String,parse:e=>e,skipInvalid:!0},Masked.EMPTY_VALUES=[void 0,null,""],IMask.Masked=Masked,IMask.createMask=createMask;const _excluded$4=["parent","isOptional","placeholderChar","displayChar","lazy","eager"],DEFAULT_INPUT_DEFINITIONS={0:/\d/,a:/[\u0041-\u005A\u0061-\u007A\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]/,"*":/./};class PatternInputDefinition{constructor(e){const{parent:t,isOptional:s,placeholderChar:i,displayChar:n,lazy:r,eager:a}=e,o=_objectWithoutPropertiesLoose(e,_excluded$4);this.masked=createMask(o),Object.assign(this,{parent:t,isOptional:s,placeholderChar:i,displayChar:n,lazy:r,eager:a})}reset(){this.isFilled=!1,this.masked.reset()}remove(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;return 0===e&&t>=1?(this.isFilled=!1,this.masked.remove(e,t)):new ChangeDetails}get value(){return this.masked.value||(this.isFilled&&!this.isOptional?this.placeholderChar:"")}get unmaskedValue(){return this.masked.unmaskedValue}get displayValue(){return this.masked.value&&this.displayChar||this.value}get isComplete(){return Boolean(this.masked.value)||this.isOptional}_appendChar(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(this.isFilled)return new ChangeDetails;const s=this.masked.state,i=this.masked._appendChar(e,t);return i.inserted&&!1===this.doValidate(t)&&(i.inserted=i.rawInserted="",this.masked.state=s),i.inserted||this.isOptional||this.lazy||t.input||(i.inserted=this.placeholderChar),i.skip=!i.inserted&&!this.isOptional,this.isFilled=Boolean(i.inserted),i}append(){return this.masked.append(...arguments)}_appendPlaceholder(){const e=new ChangeDetails;return this.isFilled||this.isOptional||(this.isFilled=!0,e.inserted=this.placeholderChar),e}_appendEager(){return new ChangeDetails}extractTail(){return this.masked.extractTail(...arguments)}appendTail(){return this.masked.appendTail(...arguments)}extractInput(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length,s=arguments.length>2?arguments[2]:void 0;return this.masked.extractInput(e,t,s)}nearestInputPos(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:DIRECTION.NONE;const s=this.value.length,i=Math.min(Math.max(e,0),s);switch(t){case DIRECTION.LEFT:case DIRECTION.FORCE_LEFT:return this.isComplete?i:0;case DIRECTION.RIGHT:case DIRECTION.FORCE_RIGHT:return this.isComplete?i:s;default:return i}}totalInputPositions(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;return this.value.slice(e,t).length}doValidate(){return this.masked.doValidate(...arguments)&&(!this.parent||this.parent.doValidate(...arguments))}doCommit(){this.masked.doCommit()}get state(){return{masked:this.masked.state,isFilled:this.isFilled}}set state(e){this.masked.state=e.masked,this.isFilled=e.isFilled}}class PatternFixedDefinition{constructor(e){Object.assign(this,e),this._value="",this.isFixed=!0}get value(){return this._value}get unmaskedValue(){return this.isUnmasking?this.value:""}get displayValue(){return this.value}reset(){this._isRawInput=!1,this._value=""}remove(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this._value.length;return this._value=this._value.slice(0,e)+this._value.slice(t),this._value||(this._isRawInput=!1),new ChangeDetails}nearestInputPos(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:DIRECTION.NONE;const s=this._value.length;switch(t){case DIRECTION.LEFT:case DIRECTION.FORCE_LEFT:return 0;default:return s}}totalInputPositions(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this._value.length;return this._isRawInput?t-e:0}extractInput(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this._value.length;return(arguments.length>2&&void 0!==arguments[2]?arguments[2]:{}).raw&&this._isRawInput&&this._value.slice(e,t)||""}get isComplete(){return!0}get isFilled(){return Boolean(this._value)}_appendChar(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const s=new ChangeDetails;if(this.isFilled)return s;const i=!0===this.eager||"append"===this.eager,n=this.char===e&&(this.isUnmasking||t.input||t.raw)&&(!t.raw||!i)&&!t.tail;return n&&(s.rawInserted=this.char),this._value=s.inserted=this.char,this._isRawInput=n&&(t.raw||t.input),s}_appendEager(){return this._appendChar(this.char,{tail:!0})}_appendPlaceholder(){const e=new ChangeDetails;return this.isFilled||(this._value=e.inserted=this.char),e}extractTail(){return arguments.length>1&&void 0!==arguments[1]||this.value.length,new ContinuousTailDetails("")}appendTail(e){return isString(e)&&(e=new ContinuousTailDetails(String(e))),e.appendTo(this)}append(e,t,s){const i=this._appendChar(e[0],t);return null!=s&&(i.tailShift+=this.appendTail(s).tailShift),i}doCommit(){}get state(){return{_value:this._value,_isRawInput:this._isRawInput}}set state(e){Object.assign(this,e)}}const _excluded$3=["chunks"];class ChunksTailDetails{constructor(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;this.chunks=e,this.from=t}toString(){return this.chunks.map(String).join("")}extend(e){if(!String(e))return;isString(e)&&(e=new ContinuousTailDetails(String(e)));const t=this.chunks[this.chunks.length-1],s=t&&(t.stop===e.stop||null==e.stop)&&e.from===t.from+t.toString().length;if(e instanceof ContinuousTailDetails)s?t.extend(e.toString()):this.chunks.push(e);else if(e instanceof ChunksTailDetails){if(null==e.stop){let t;for(;e.chunks.length&&null==e.chunks[0].stop;)t=e.chunks.shift(),t.from+=e.from,this.extend(t)}e.toString()&&(e.stop=e.blockIndex,this.chunks.push(e))}}appendTo(e){if(!(e instanceof IMask.MaskedPattern)){return new ContinuousTailDetails(this.toString()).appendTo(e)}const t=new ChangeDetails;for(let s=0;s=0){const s=e._appendPlaceholder(r);t.aggregate(s)}a=i instanceof ChunksTailDetails&&e._blocks[r]}if(a){const s=a.appendTail(i);s.skip=!1,t.aggregate(s),e._value+=s.inserted;const n=i.toString().slice(s.rawInserted.length);n&&t.aggregate(e.append(n,{tail:!0}))}else t.aggregate(e.append(i.toString(),{tail:!0}))}return t}get state(){return{chunks:this.chunks.map((e=>e.state)),from:this.from,stop:this.stop,blockIndex:this.blockIndex}}set state(e){const{chunks:t}=e,s=_objectWithoutPropertiesLoose(e,_excluded$3);Object.assign(this,s),this.chunks=t.map((e=>{const t="chunks"in e?new ChunksTailDetails:new ContinuousTailDetails;return t.state=e,t}))}unshift(e){if(!this.chunks.length||null!=e&&this.from>=e)return"";const t=null!=e?e-this.from:e;let s=0;for(;s=this.masked._blocks.length&&(this.index=this.masked._blocks.length-1,this.offset=this.block.value.length))}_pushLeft(e){for(this.pushState(),this.bindBlock();0<=this.index;--this.index,this.offset=(null===(t=this.block)||void 0===t?void 0:t.value.length)||0){var t;if(e())return this.ok=!0}return this.ok=!1}_pushRight(e){for(this.pushState(),this.bindBlock();this.index{if(!this.block.isFixed&&this.block.value)return this.offset=this.block.nearestInputPos(this.offset,DIRECTION.FORCE_LEFT),0!==this.offset||void 0}))}pushLeftBeforeInput(){return this._pushLeft((()=>{if(!this.block.isFixed)return this.offset=this.block.nearestInputPos(this.offset,DIRECTION.LEFT),!0}))}pushLeftBeforeRequired(){return this._pushLeft((()=>{if(!(this.block.isFixed||this.block.isOptional&&!this.block.value))return this.offset=this.block.nearestInputPos(this.offset,DIRECTION.LEFT),!0}))}pushRightBeforeFilled(){return this._pushRight((()=>{if(!this.block.isFixed&&this.block.value)return this.offset=this.block.nearestInputPos(this.offset,DIRECTION.FORCE_RIGHT),this.offset!==this.block.value.length||void 0}))}pushRightBeforeInput(){return this._pushRight((()=>{if(!this.block.isFixed)return this.offset=this.block.nearestInputPos(this.offset,DIRECTION.NONE),!0}))}pushRightBeforeRequired(){return this._pushRight((()=>{if(!(this.block.isFixed||this.block.isOptional&&!this.block.value))return this.offset=this.block.nearestInputPos(this.offset,DIRECTION.NONE),!0}))}}class MaskedRegExp extends Masked{_update(e){e.mask&&(e.validate=t=>t.search(e.mask)>=0),super._update(e)}}IMask.MaskedRegExp=MaskedRegExp;const _excluded$2=["_blocks"];class MaskedPattern extends Masked{constructor(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};e.definitions=Object.assign({},DEFAULT_INPUT_DEFINITIONS,e.definitions),super(Object.assign({},MaskedPattern.DEFAULTS,e))}_update(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};e.definitions=Object.assign({},this.definitions,e.definitions),super._update(e),this._rebuildMask()}_rebuildMask(){const e=this.definitions;this._blocks=[],this._stops=[],this._maskedBlocks={};let t=this.mask;if(!t||!e)return;let s=!1,i=!1;for(let a=0;a0===e.indexOf(t)));s.sort(((e,t)=>t.length-e.length));const i=s[0];if(i){const e=createMask(Object.assign({parent:this,lazy:this.lazy,eager:this.eager,placeholderChar:this.placeholderChar,displayChar:this.displayChar,overwrite:this.overwrite},this.blocks[i]));e&&(this._blocks.push(e),this._maskedBlocks[i]||(this._maskedBlocks[i]=[]),this._maskedBlocks[i].push(this._blocks.length-1)),a+=i.length-1;continue}}let o=t[a],l=o in e;if(o===MaskedPattern.STOP_CHAR){this._stops.push(this._blocks.length);continue}if("{"===o||"}"===o){s=!s;continue}if("["===o||"]"===o){i=!i;continue}if(o===MaskedPattern.ESCAPE_CHAR){if(++a,o=t[a],!o)break;l=!1}const u=null===(n=e[o])||void 0===n||!n.mask||(null===(r=e[o])||void 0===r?void 0:r.mask.prototype)instanceof IMask.Masked?{mask:e[o]}:e[o],c=l?new PatternInputDefinition(Object.assign({parent:this,isOptional:i,lazy:this.lazy,eager:this.eager,placeholderChar:this.placeholderChar,displayChar:this.displayChar},u)):new PatternFixedDefinition({char:o,eager:this.eager,isUnmasking:s});this._blocks.push(c)}}get state(){return Object.assign({},super.state,{_blocks:this._blocks.map((e=>e.state))})}set state(e){const{_blocks:t}=e,s=_objectWithoutPropertiesLoose(e,_excluded$2);this._blocks.forEach(((e,s)=>e.state=t[s])),super.state=s}reset(){super.reset(),this._blocks.forEach((e=>e.reset()))}get isComplete(){return this._blocks.every((e=>e.isComplete))}get isFilled(){return this._blocks.every((e=>e.isFilled))}get isFixed(){return this._blocks.every((e=>e.isFixed))}get isOptional(){return this._blocks.every((e=>e.isOptional))}doCommit(){this._blocks.forEach((e=>e.doCommit())),super.doCommit()}get unmaskedValue(){return this._blocks.reduce(((e,t)=>e+t.unmaskedValue),"")}set unmaskedValue(e){super.unmaskedValue=e}get value(){return this._blocks.reduce(((e,t)=>e+t.value),"")}set value(e){super.value=e}get displayValue(){return this._blocks.reduce(((e,t)=>e+t.displayValue),"")}appendTail(e){return super.appendTail(e).aggregate(this._appendPlaceholder())}_appendEager(){var e;const t=new ChangeDetails;let s=null===(e=this._mapPosToBlock(this.value.length))||void 0===e?void 0:e.index;if(null==s)return t;this._blocks[s].isFilled&&++s;for(let e=s;e1&&void 0!==arguments[1]?arguments[1]:{};const s=this._mapPosToBlock(this.value.length),i=new ChangeDetails;if(!s)return i;for(let a=s.index;;++a){var n,r;const s=this._blocks[a];if(!s)break;const o=s._appendChar(e,Object.assign({},t,{_beforeTailState:null===(n=t._beforeTailState)||void 0===n||null===(r=n._blocks)||void 0===r?void 0:r[a]})),l=o.skip;if(i.aggregate(o),l||o.rawInserted)break}return i}extractTail(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;const s=new ChunksTailDetails;return e===t||this._forEachBlocksInRange(e,t,((e,t,i,n)=>{const r=e.extractTail(i,n);r.stop=this._findStopBefore(t),r.from=this._blockStartPos(t),r instanceof ChunksTailDetails&&(r.blockIndex=t),s.extend(r)})),s}extractInput(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length,s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(e===t)return"";let i="";return this._forEachBlocksInRange(e,t,((e,t,n,r)=>{i+=e.extractInput(n,r,s)})),i}_findStopBefore(e){let t;for(let s=0;s{if(!s.lazy||null!=e){const e=null!=s._blocks?[s._blocks.length]:[],i=s._appendPlaceholder(...e);this._value+=i.inserted,t.aggregate(i)}})),t}_mapPosToBlock(e){let t="";for(let s=0;se+t.value.length),0)}_forEachBlocksInRange(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length,s=arguments.length>2?arguments[2]:void 0;const i=this._mapPosToBlock(e);if(i){const e=this._mapPosToBlock(t),n=e&&i.index===e.index,r=i.offset,a=e&&n?e.offset:this._blocks[i.index].value.length;if(s(this._blocks[i.index],i.index,r,a),e&&!n){for(let t=i.index+1;t0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;const s=super.remove(e,t);return this._forEachBlocksInRange(e,t,((e,t,i,n)=>{s.aggregate(e.remove(i,n))})),s}nearestInputPos(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:DIRECTION.NONE;if(!this._blocks.length)return 0;const s=new PatternCursor(this,e);if(t===DIRECTION.NONE)return s.pushRightBeforeInput()?s.pos:(s.popState(),s.pushLeftBeforeInput()?s.pos:this.value.length);if(t===DIRECTION.LEFT||t===DIRECTION.FORCE_LEFT){if(t===DIRECTION.LEFT){if(s.pushRightBeforeFilled(),s.ok&&s.pos===e)return e;s.popState()}if(s.pushLeftBeforeInput(),s.pushLeftBeforeRequired(),s.pushLeftBeforeFilled(),t===DIRECTION.LEFT){if(s.pushRightBeforeInput(),s.pushRightBeforeRequired(),s.ok&&s.pos<=e)return s.pos;if(s.popState(),s.ok&&s.pos<=e)return s.pos;s.popState()}return s.ok?s.pos:t===DIRECTION.FORCE_LEFT?0:(s.popState(),s.ok?s.pos:(s.popState(),s.ok?s.pos:0))}return t===DIRECTION.RIGHT||t===DIRECTION.FORCE_RIGHT?(s.pushRightBeforeInput(),s.pushRightBeforeRequired(),s.pushRightBeforeFilled()?s.pos:t===DIRECTION.FORCE_RIGHT?this.value.length:(s.popState(),s.ok?s.pos:(s.popState(),s.ok?s.pos:this.nearestInputPos(e,DIRECTION.LEFT)))):e}totalInputPositions(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length,s=0;return this._forEachBlocksInRange(e,t,((e,t,i,n)=>{s+=e.totalInputPositions(i,n)})),s}maskedBlock(e){return this.maskedBlocks(e)[0]}maskedBlocks(e){const t=this._maskedBlocks[e];return t?t.map((e=>this._blocks[e])):[]}}MaskedPattern.DEFAULTS={lazy:!0,placeholderChar:"_"},MaskedPattern.STOP_CHAR="`",MaskedPattern.ESCAPE_CHAR="\\",MaskedPattern.InputDefinition=PatternInputDefinition,MaskedPattern.FixedDefinition=PatternFixedDefinition,IMask.MaskedPattern=MaskedPattern;class MaskedRange extends MaskedPattern{get _matchFrom(){return this.maxLength-String(this.from).length}_update(e){e=Object.assign({to:this.to||0,from:this.from||0,maxLength:this.maxLength||0},e);let t=String(e.to).length;null!=e.maxLength&&(t=Math.max(t,e.maxLength)),e.maxLength=t;const s=String(e.from).padStart(t,"0"),i=String(e.to).padStart(t,"0");let n=0;for(;n1&&void 0!==arguments[1]?arguments[1]:{};if([e,t]=normalizePrepare(super.doPrepare(e.replace(/\D/g,""),s)),!this.autofix||!e)return e;const i=String(this.from).padStart(this.maxLength,"0"),n=String(this.to).padStart(this.maxLength,"0");let r=this.value+e;if(r.length>this.maxLength)return"";const[a,o]=this.boundaries(r);return Number(o)this.to?"pad"===this.autofix&&r.length{const s=e.blocks[t];!("autofix"in s)&&"autofix"in e&&(s.autofix=e.autofix)})),super._update(e)}doValidate(){const e=this.date;return super.doValidate(...arguments)&&(!this.isComplete||this.isDateExist(this.value)&&null!=e&&(null==this.min||this.min<=e)&&(null==this.max||e<=this.max))}isDateExist(e){return this.format(this.parse(e,this),this).indexOf(e)>=0}get date(){return this.typedValue}set date(e){this.typedValue=e}get typedValue(){return this.isComplete?super.typedValue:null}set typedValue(e){super.typedValue=e}maskEquals(e){return e===Date||super.maskEquals(e)}}MaskedDate.DEFAULTS={pattern:"d{.}`m{.}`Y",format:e=>{if(!e)return"";return[String(e.getDate()).padStart(2,"0"),String(e.getMonth()+1).padStart(2,"0"),e.getFullYear()].join(".")},parse:e=>{const[t,s,i]=e.split(".");return new Date(i,s-1,t)}},MaskedDate.GET_DEFAULT_BLOCKS=()=>({d:{mask:MaskedRange,from:1,to:31,maxLength:2},m:{mask:MaskedRange,from:1,to:12,maxLength:2},Y:{mask:MaskedRange,from:1900,to:9999}}),IMask.MaskedDate=MaskedDate;class MaskElement{get selectionStart(){let e;try{e=this._unsafeSelectionStart}catch(e){}return null!=e?e:this.value.length}get selectionEnd(){let e;try{e=this._unsafeSelectionEnd}catch(e){}return null!=e?e:this.value.length}select(e,t){if(null!=e&&null!=t&&(e!==this.selectionStart||t!==this.selectionEnd))try{this._unsafeSelect(e,t)}catch(e){}}_unsafeSelect(e,t){}get isActive(){return!1}bindEvents(e){}unbindEvents(){}}IMask.MaskElement=MaskElement;class HTMLMaskElement extends MaskElement{constructor(e){super(),this.input=e,this._handlers={}}get rootElement(){var e,t,s;return null!==(e=null===(t=(s=this.input).getRootNode)||void 0===t?void 0:t.call(s))&&void 0!==e?e:document}get isActive(){return this.input===this.rootElement.activeElement}get _unsafeSelectionStart(){return this.input.selectionStart}get _unsafeSelectionEnd(){return this.input.selectionEnd}_unsafeSelect(e,t){this.input.setSelectionRange(e,t)}get value(){return this.input.value}set value(e){this.input.value=e}bindEvents(e){Object.keys(e).forEach((t=>this._toggleEventHandler(HTMLMaskElement.EVENTS_MAP[t],e[t])))}unbindEvents(){Object.keys(this._handlers).forEach((e=>this._toggleEventHandler(e)))}_toggleEventHandler(e,t){this._handlers[e]&&(this.input.removeEventListener(e,this._handlers[e]),delete this._handlers[e]),t&&(this.input.addEventListener(e,t),this._handlers[e]=t)}}HTMLMaskElement.EVENTS_MAP={selectionChange:"keydown",input:"input",drop:"drop",click:"click",focus:"focus",commit:"blur"},IMask.HTMLMaskElement=HTMLMaskElement;class HTMLContenteditableMaskElement extends HTMLMaskElement{get _unsafeSelectionStart(){const e=this.rootElement,t=e.getSelection&&e.getSelection(),s=t&&t.anchorOffset,i=t&&t.focusOffset;return null==i||null==s||si?s:i}_unsafeSelect(e,t){if(!this.rootElement.createRange)return;const s=this.rootElement.createRange();s.setStart(this.input.firstChild||this.input,e),s.setEnd(this.input.lastChild||this.input,t);const i=this.rootElement,n=i.getSelection&&i.getSelection();n&&(n.removeAllRanges(),n.addRange(s))}get value(){return this.input.textContent}set value(e){this.input.textContent=e}}IMask.HTMLContenteditableMaskElement=HTMLContenteditableMaskElement;const _excluded$1=["mask"];class InputMask{constructor(e,t){this.el=e instanceof MaskElement?e:e.isContentEditable&&"INPUT"!==e.tagName&&"TEXTAREA"!==e.tagName?new HTMLContenteditableMaskElement(e):new HTMLMaskElement(e),this.masked=createMask(t),this._listeners={},this._value="",this._unmaskedValue="",this._saveSelection=this._saveSelection.bind(this),this._onInput=this._onInput.bind(this),this._onChange=this._onChange.bind(this),this._onDrop=this._onDrop.bind(this),this._onFocus=this._onFocus.bind(this),this._onClick=this._onClick.bind(this),this.alignCursor=this.alignCursor.bind(this),this.alignCursorFriendly=this.alignCursorFriendly.bind(this),this._bindEvents(),this.updateValue(),this._onChange()}get mask(){return this.masked.mask}maskEquals(e){var t;return null==e||(null===(t=this.masked)||void 0===t?void 0:t.maskEquals(e))}set mask(e){if(this.maskEquals(e))return;if(!(e instanceof IMask.Masked)&&this.masked.constructor===maskedClass(e))return void this.masked.updateOptions({mask:e});const t=createMask({mask:e});t.unmaskedValue=this.masked.unmaskedValue,this.masked=t}get value(){return this._value}set value(e){this.value!==e&&(this.masked.value=e,this.updateControl(),this.alignCursor())}get unmaskedValue(){return this._unmaskedValue}set unmaskedValue(e){this.unmaskedValue!==e&&(this.masked.unmaskedValue=e,this.updateControl(),this.alignCursor())}get typedValue(){return this.masked.typedValue}set typedValue(e){this.masked.typedValueEquals(e)||(this.masked.typedValue=e,this.updateControl(),this.alignCursor())}get displayValue(){return this.masked.displayValue}_bindEvents(){this.el.bindEvents({selectionChange:this._saveSelection,input:this._onInput,drop:this._onDrop,click:this._onClick,focus:this._onFocus,commit:this._onChange})}_unbindEvents(){this.el&&this.el.unbindEvents()}_fireEvent(e){for(var t=arguments.length,s=new Array(t>1?t-1:0),i=1;ie(...s)))}get selectionStart(){return this._cursorChanging?this._changingCursorPos:this.el.selectionStart}get cursorPos(){return this._cursorChanging?this._changingCursorPos:this.el.selectionEnd}set cursorPos(e){this.el&&this.el.isActive&&(this.el.select(e,e),this._saveSelection())}_saveSelection(){this.displayValue!==this.el.value&&console.warn("Element value was changed outside of mask. Syncronize mask using `mask.updateValue()` to work properly."),this._selection={start:this.selectionStart,end:this.cursorPos}}updateValue(){this.masked.value=this.el.value,this._value=this.masked.value}updateControl(){const e=this.masked.unmaskedValue,t=this.masked.value,s=this.displayValue,i=this.unmaskedValue!==e||this.value!==t;this._unmaskedValue=e,this._value=t,this.el.value!==s&&(this.el.value=s),i&&this._fireChangeEvents()}updateOptions(e){const{mask:t}=e,s=_objectWithoutPropertiesLoose(e,_excluded$1),i=!this.maskEquals(t),n=!objectIncludes(this.masked,s);i&&(this.mask=t),n&&this.masked.updateOptions(s),(i||n)&&this.updateControl()}updateCursor(e){null!=e&&(this.cursorPos=e,this._delayUpdateCursor(e))}_delayUpdateCursor(e){this._abortUpdateCursor(),this._changingCursorPos=e,this._cursorChanging=setTimeout((()=>{this.el&&(this.cursorPos=this._changingCursorPos,this._abortUpdateCursor())}),10)}_fireChangeEvents(){this._fireEvent("accept",this._inputEvent),this.masked.isComplete&&this._fireEvent("complete",this._inputEvent)}_abortUpdateCursor(){this._cursorChanging&&(clearTimeout(this._cursorChanging),delete this._cursorChanging)}alignCursor(){this.cursorPos=this.masked.nearestInputPos(this.masked.nearestInputPos(this.cursorPos,DIRECTION.LEFT))}alignCursorFriendly(){this.selectionStart===this.cursorPos&&this.alignCursor()}on(e,t){return this._listeners[e]||(this._listeners[e]=[]),this._listeners[e].push(t),this}off(e,t){if(!this._listeners[e])return this;if(!t)return delete this._listeners[e],this;const s=this._listeners[e].indexOf(t);return s>=0&&this._listeners[e].splice(s,1),this}_onInput(e){if(this._inputEvent=e,this._abortUpdateCursor(),!this._selection)return this.updateValue();const t=new ActionDetails(this.el.value,this.cursorPos,this.displayValue,this._selection),s=this.masked.rawInputValue,i=this.masked.splice(t.startChangePos,t.removed.length,t.inserted,t.removeDirection,{input:!0,raw:!0}).offset,n=s===this.masked.rawInputValue?t.removeDirection:DIRECTION.NONE;let r=this.masked.nearestInputPos(t.startChangePos+i,n);n!==DIRECTION.NONE&&(r=this.masked.nearestInputPos(r,DIRECTION.NONE)),this.updateControl(),this.updateCursor(r),delete this._inputEvent}_onChange(){this.displayValue!==this.el.value&&this.updateValue(),this.masked.doCommit(),this.updateControl(),this._saveSelection()}_onDrop(e){e.preventDefault(),e.stopPropagation()}_onFocus(e){this.alignCursorFriendly()}_onClick(e){this.alignCursorFriendly()}destroy(){this._unbindEvents(),this._listeners.length=0,delete this.el}}IMask.InputMask=InputMask;class MaskedEnum extends MaskedPattern{_update(e){e.enum&&(e.mask="*".repeat(e.enum[0].length)),super._update(e)}doValidate(){return this.enum.some((e=>e.indexOf(this.unmaskedValue)>=0))&&super.doValidate(...arguments)}}IMask.MaskedEnum=MaskedEnum;class MaskedNumber extends Masked{constructor(e){super(Object.assign({},MaskedNumber.DEFAULTS,e))}_update(e){super._update(e),this._updateRegExps()}_updateRegExps(){let e="^"+(this.allowNegative?"[+|\\-]?":""),t=(this.scale?"(".concat(escapeRegExp(this.radix),"\\d{0,").concat(this.scale,"})?"):"")+"$";this._numberRegExp=new RegExp(e+"\\d*"+t),this._mapToRadixRegExp=new RegExp("[".concat(this.mapToRadix.map(escapeRegExp).join(""),"]"),"g"),this._thousandsSeparatorRegExp=new RegExp(escapeRegExp(this.thousandsSeparator),"g")}_removeThousandsSeparators(e){return e.replace(this._thousandsSeparatorRegExp,"")}_insertThousandsSeparators(e){const t=e.split(this.radix);return t[0]=t[0].replace(/\B(?=(\d{3})+(?!\d))/g,this.thousandsSeparator),t.join(this.radix)}doPrepare(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};e=this._removeThousandsSeparators(this.scale&&this.mapToRadix.length&&(t.input&&t.raw||!t.input&&!t.raw)?e.replace(this._mapToRadixRegExp,this.radix):e);const[s,i]=normalizePrepare(super.doPrepare(e,t));return e&&!s&&(i.skip=!0),[s,i]}_separatorsCount(e){let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],s=0;for(let i=0;i0&&void 0!==arguments[0]?arguments[0]:this._value;return this._separatorsCount(this._removeThousandsSeparators(e).length,!0)}extractInput(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length,s=arguments.length>2?arguments[2]:void 0;return[e,t]=this._adjustRangeWithSeparators(e,t),this._removeThousandsSeparators(super.extractInput(e,t,s))}_appendCharRaw(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!this.thousandsSeparator)return super._appendCharRaw(e,t);const s=t.tail&&t._beforeTailState?t._beforeTailState._value:this._value,i=this._separatorsCountFromSlice(s);this._value=this._removeThousandsSeparators(this.value);const n=super._appendCharRaw(e,t);this._value=this._insertThousandsSeparators(this._value);const r=t.tail&&t._beforeTailState?t._beforeTailState._value:this._value,a=this._separatorsCountFromSlice(r);return n.tailShift+=(a-i)*this.thousandsSeparator.length,n.skip=!n.rawInserted&&e===this.thousandsSeparator,n}_findSeparatorAround(e){if(this.thousandsSeparator){const t=e-this.thousandsSeparator.length+1,s=this.value.indexOf(this.thousandsSeparator,t);if(s<=e)return s}return-1}_adjustRangeWithSeparators(e,t){const s=this._findSeparatorAround(e);s>=0&&(e=s);const i=this._findSeparatorAround(t);return i>=0&&(t=i+this.thousandsSeparator.length),[e,t]}remove(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:this.value.length;[e,t]=this._adjustRangeWithSeparators(e,t);const s=this.value.slice(0,e),i=this.value.slice(t),n=this._separatorsCount(s.length);this._value=this._insertThousandsSeparators(this._removeThousandsSeparators(s+i));const r=this._separatorsCountFromSlice(s);return new ChangeDetails({tailShift:(r-n)*this.thousandsSeparator.length})}nearestInputPos(e,t){if(!this.thousandsSeparator)return e;switch(t){case DIRECTION.NONE:case DIRECTION.LEFT:case DIRECTION.FORCE_LEFT:{const s=this._findSeparatorAround(e-1);if(s>=0){const i=s+this.thousandsSeparator.length;if(e=0)return t+this.thousandsSeparator.length}}return e}doValidate(e){let t=Boolean(this._removeThousandsSeparators(this.value).match(this._numberRegExp));if(t){const e=this.number;t=t&&!isNaN(e)&&(null==this.min||this.min>=0||this.min<=this.number)&&(null==this.max||this.max<=0||this.number<=this.max)}return t&&super.doValidate(e)}doCommit(){if(this.value){const e=this.number;let t=e;null!=this.min&&(t=Math.max(t,this.min)),null!=this.max&&(t=Math.min(t,this.max)),t!==e&&(this.unmaskedValue=this.doFormat(t));let s=this.value;this.normalizeZeros&&(s=this._normalizeZeros(s)),this.padFractionalZeros&&this.scale>0&&(s=this._padFractionalZeros(s)),this._value=s}super.doCommit()}_normalizeZeros(e){const t=this._removeThousandsSeparators(e).split(this.radix);return t[0]=t[0].replace(/^(\D*)(0*)(\d*)/,((e,t,s,i)=>t+i)),e.length&&!/\d$/.test(t[0])&&(t[0]=t[0]+"0"),t.length>1&&(t[1]=t[1].replace(/0*$/,""),t[1].length||(t.length=1)),this._insertThousandsSeparators(t.join(this.radix))}_padFractionalZeros(e){if(!e)return e;const t=e.split(this.radix);return t.length<2&&t.push(""),t[1]=t[1].padEnd(this.scale,"0"),t.join(this.radix)}doSkipInvalid(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=arguments.length>2?arguments[2]:void 0;const i=0===this.scale&&e!==this.thousandsSeparator&&(e===this.radix||e===MaskedNumber.UNMASKED_RADIX||this.mapToRadix.includes(e));return super.doSkipInvalid(e,t,s)&&!i}get unmaskedValue(){return this._removeThousandsSeparators(this._normalizeZeros(this.value)).replace(this.radix,MaskedNumber.UNMASKED_RADIX)}set unmaskedValue(e){super.unmaskedValue=e}get typedValue(){return this.doParse(this.unmaskedValue)}set typedValue(e){this.rawInputValue=this.doFormat(e).replace(MaskedNumber.UNMASKED_RADIX,this.radix)}get number(){return this.typedValue}set number(e){this.typedValue=e}get allowNegative(){return this.signed||null!=this.min&&this.min<0||null!=this.max&&this.max<0}typedValueEquals(e){return(super.typedValueEquals(e)||MaskedNumber.EMPTY_VALUES.includes(e)&&MaskedNumber.EMPTY_VALUES.includes(this.typedValue))&&!(0===e&&""===this.value)}}MaskedNumber.UNMASKED_RADIX=".",MaskedNumber.DEFAULTS={radix:",",thousandsSeparator:"",mapToRadix:[MaskedNumber.UNMASKED_RADIX],scale:2,signed:!1,normalizeZeros:!0,padFractionalZeros:!1,parse:Number,format:e=>e.toLocaleString("en-US",{useGrouping:!1,maximumFractionDigits:20})},MaskedNumber.EMPTY_VALUES=[...Masked.EMPTY_VALUES,0],IMask.MaskedNumber=MaskedNumber;class MaskedFunction extends Masked{_update(e){e.mask&&(e.validate=e.mask),super._update(e)}}IMask.MaskedFunction=MaskedFunction;const _excluded=["compiledMasks","currentMaskRef","currentMask"],_excluded2=["mask"];class MaskedDynamic extends Masked{constructor(e){super(Object.assign({},MaskedDynamic.DEFAULTS,e)),this.currentMask=null}_update(e){super._update(e),"mask"in e&&(this.compiledMasks=Array.isArray(e.mask)?e.mask.map((e=>createMask(e))):[])}_appendCharRaw(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};const s=this._applyDispatch(e,t);return this.currentMask&&s.aggregate(this.currentMask._appendChar(e,this.currentMaskFlags(t))),s}_applyDispatch(){let e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"",t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"";const i=t.tail&&null!=t._beforeTailState?t._beforeTailState._value:this.value,n=this.rawInputValue,r=t.tail&&null!=t._beforeTailState?t._beforeTailState._rawInputValue:n,a=n.slice(r.length),o=this.currentMask,l=new ChangeDetails,u=null==o?void 0:o.state;if(this.currentMask=this.doDispatch(e,Object.assign({},t),s),this.currentMask)if(this.currentMask!==o){if(this.currentMask.reset(),r){const e=this.currentMask.append(r,{raw:!0});l.tailShift=e.inserted.length-i.length}a&&(l.tailShift+=this.currentMask.append(a,{raw:!0,tail:!0}).tailShift)}else this.currentMask.state=u;return l}_appendPlaceholder(){const e=this._applyDispatch(...arguments);return this.currentMask&&e.aggregate(this.currentMask._appendPlaceholder()),e}_appendEager(){const e=this._applyDispatch(...arguments);return this.currentMask&&e.aggregate(this.currentMask._appendEager()),e}appendTail(e){const t=new ChangeDetails;return e&&t.aggregate(this._applyDispatch("",{},e)),t.aggregate(this.currentMask?this.currentMask.appendTail(e):super.appendTail(e))}currentMaskFlags(e){var t,s;return Object.assign({},e,{_beforeTailState:(null===(t=e._beforeTailState)||void 0===t?void 0:t.currentMaskRef)===this.currentMask&&(null===(s=e._beforeTailState)||void 0===s?void 0:s.currentMask)||e._beforeTailState})}doDispatch(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"";return this.dispatch(e,this,t,s)}doValidate(e){return super.doValidate(e)&&(!this.currentMask||this.currentMask.doValidate(this.currentMaskFlags(e)))}doPrepare(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},[s,i]=normalizePrepare(super.doPrepare(e,t));if(this.currentMask){let e;[s,e]=normalizePrepare(super.doPrepare(s,this.currentMaskFlags(t))),i=i.aggregate(e)}return[s,i]}reset(){var e;null===(e=this.currentMask)||void 0===e||e.reset(),this.compiledMasks.forEach((e=>e.reset()))}get value(){return this.currentMask?this.currentMask.value:""}set value(e){super.value=e}get unmaskedValue(){return this.currentMask?this.currentMask.unmaskedValue:""}set unmaskedValue(e){super.unmaskedValue=e}get typedValue(){return this.currentMask?this.currentMask.typedValue:""}set typedValue(e){let t=String(e);this.currentMask&&(this.currentMask.typedValue=e,t=this.currentMask.unmaskedValue),this.unmaskedValue=t}get displayValue(){return this.currentMask?this.currentMask.displayValue:""}get isComplete(){var e;return Boolean(null===(e=this.currentMask)||void 0===e?void 0:e.isComplete)}get isFilled(){var e;return Boolean(null===(e=this.currentMask)||void 0===e?void 0:e.isFilled)}remove(){const e=new ChangeDetails;return this.currentMask&&e.aggregate(this.currentMask.remove(...arguments)).aggregate(this._applyDispatch()),e}get state(){var e;return Object.assign({},super.state,{_rawInputValue:this.rawInputValue,compiledMasks:this.compiledMasks.map((e=>e.state)),currentMaskRef:this.currentMask,currentMask:null===(e=this.currentMask)||void 0===e?void 0:e.state})}set state(e){const{compiledMasks:t,currentMaskRef:s,currentMask:i}=e,n=_objectWithoutPropertiesLoose(e,_excluded);this.compiledMasks.forEach(((e,s)=>e.state=t[s])),null!=s&&(this.currentMask=s,this.currentMask.state=i),super.state=n}extractInput(){return this.currentMask?this.currentMask.extractInput(...arguments):""}extractTail(){return this.currentMask?this.currentMask.extractTail(...arguments):super.extractTail(...arguments)}doCommit(){this.currentMask&&this.currentMask.doCommit(),super.doCommit()}nearestInputPos(){return this.currentMask?this.currentMask.nearestInputPos(...arguments):super.nearestInputPos(...arguments)}get overwrite(){return this.currentMask?this.currentMask.overwrite:super.overwrite}set overwrite(e){console.warn('"overwrite" option is not available in dynamic mask, use this option in siblings')}get eager(){return this.currentMask?this.currentMask.eager:super.eager}set eager(e){console.warn('"eager" option is not available in dynamic mask, use this option in siblings')}get skipInvalid(){return this.currentMask?this.currentMask.skipInvalid:super.skipInvalid}set skipInvalid(e){(this.isInitialized||e!==Masked.DEFAULTS.skipInvalid)&&console.warn('"skipInvalid" option is not available in dynamic mask, use this option in siblings')}maskEquals(e){return Array.isArray(e)&&this.compiledMasks.every(((t,s)=>{if(!e[s])return;const i=e[s],{mask:n}=i;return objectIncludes(t,_objectWithoutPropertiesLoose(i,_excluded2))&&t.maskEquals(n)}))}typedValueEquals(e){var t;return Boolean(null===(t=this.currentMask)||void 0===t?void 0:t.typedValueEquals(e))}}MaskedDynamic.DEFAULTS={dispatch:(e,t,s,i)=>{if(!t.compiledMasks.length)return;const n=t.rawInputValue,r=t.compiledMasks.map(((r,a)=>{const o=t.currentMask===r,l=o?r.value.length:r.nearestInputPos(r.value.length,DIRECTION.FORCE_LEFT);return r.rawInputValue!==n?(r.reset(),r.append(n,{raw:!0})):o||r.remove(l),r.append(e,t.currentMaskFlags(s)),r.appendTail(i),{index:a,weight:r.rawInputValue.length,totalInputPositions:r.totalInputPositions(0,Math.max(l,r.nearestInputPos(r.value.length,DIRECTION.FORCE_LEFT)))}}));return r.sort(((e,t)=>t.weight-e.weight||t.totalInputPositions-e.totalInputPositions)),t.compiledMasks[r[0].index]}},IMask.MaskedDynamic=MaskedDynamic;const PIPE_TYPE={MASKED:"value",UNMASKED:"unmaskedValue",TYPED:"typedValue"};function createPipe(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:PIPE_TYPE.MASKED,s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:PIPE_TYPE.MASKED;const i=createMask(e);return e=>i.runIsolated((i=>(i[t]=e,i[s])))}function pipe(e){for(var t=arguments.length,s=new Array(t>1?t-1:0),i=1;i0&&round(i.width)/e.offsetWidth||1,r=e.offsetHeight>0&&round(i.height)/e.offsetHeight||1);var a=(isElement$1(e)?getWindow(e):window).visualViewport,o=!isLayoutViewport()&&s,l=(i.left+(o&&a?a.offsetLeft:0))/n,u=(i.top+(o&&a?a.offsetTop:0))/r,c=i.width/n,h=i.height/r;return{width:c,height:h,top:u,right:l+c,bottom:u+h,left:l,x:l,y:u}}function getLayoutRect(e){var t=getBoundingClientRect(e),s=e.offsetWidth,i=e.offsetHeight;return Math.abs(t.width-s)<=1&&(s=t.width),Math.abs(t.height-i)<=1&&(i=t.height),{x:e.offsetLeft,y:e.offsetTop,width:s,height:i}}function contains(e,t){var s=t.getRootNode&&t.getRootNode();if(e.contains(t))return!0;if(s&&isShadowRoot(s)){var i=t;do{if(i&&e.isSameNode(i))return!0;i=i.parentNode||i.host}while(i)}return!1}function getComputedStyle$1(e){return getWindow(e).getComputedStyle(e)}function isTableElement(e){return["table","td","th"].indexOf(getNodeName(e))>=0}function getDocumentElement(e){return((isElement$1(e)?e.ownerDocument:e.document)||window.document).documentElement}function getParentNode(e){return"html"===getNodeName(e)?e:e.assignedSlot||e.parentNode||(isShadowRoot(e)?e.host:null)||getDocumentElement(e)}function getTrueOffsetParent(e){return isHTMLElement(e)&&"fixed"!==getComputedStyle$1(e).position?e.offsetParent:null}function getContainingBlock(e){var t=/firefox/i.test(getUAString());if(/Trident/i.test(getUAString())&&isHTMLElement(e)&&"fixed"===getComputedStyle$1(e).position)return null;var s=getParentNode(e);for(isShadowRoot(s)&&(s=s.host);isHTMLElement(s)&&["html","body"].indexOf(getNodeName(s))<0;){var i=getComputedStyle$1(s);if("none"!==i.transform||"none"!==i.perspective||"paint"===i.contain||-1!==["transform","perspective"].indexOf(i.willChange)||t&&"filter"===i.willChange||t&&i.filter&&"none"!==i.filter)return s;s=s.parentNode}return null}function getOffsetParent(e){for(var t=getWindow(e),s=getTrueOffsetParent(e);s&&isTableElement(s)&&"static"===getComputedStyle$1(s).position;)s=getTrueOffsetParent(s);return s&&("html"===getNodeName(s)||"body"===getNodeName(s)&&"static"===getComputedStyle$1(s).position)?t:s||getContainingBlock(e)||t}function getMainAxisFromPlacement(e){return["top","bottom"].indexOf(e)>=0?"x":"y"}function within(e,t,s){return max(e,min(t,s))}function withinMaxClamp(e,t,s){var i=within(e,t,s);return i>s?s:i}function getFreshSideObject(){return{top:0,right:0,bottom:0,left:0}}function mergePaddingObject(e){return Object.assign({},getFreshSideObject(),e)}function expandToHashMap(e,t){return t.reduce((function(t,s){return t[s]=e,t}),{})}var toPaddingObject=function(e,t){return mergePaddingObject("number"!=typeof(e="function"==typeof e?e(Object.assign({},t.rects,{placement:t.placement})):e)?e:expandToHashMap(e,basePlacements))};function arrow(e){var t,s=e.state,i=e.name,n=e.options,r=s.elements.arrow,a=s.modifiersData.popperOffsets,o=getBasePlacement(s.placement),l=getMainAxisFromPlacement(o),u=[left,right].indexOf(o)>=0?"height":"width";if(r&&a){var c=toPaddingObject(n.padding,s),h=getLayoutRect(r),d="y"===l?top:left,p="y"===l?bottom:right,g=s.rects.reference[u]+s.rects.reference[l]-a[l]-s.rects.popper[u],f=a[l]-s.rects.reference[l],E=getOffsetParent(r),_=E?"y"===l?E.clientHeight||0:E.clientWidth||0:0,m=g/2-f/2,v=c[d],T=_-h[u]-c[p],A=_/2-h[u]/2+m,b=within(v,A,T),C=l;s.modifiersData[i]=((t={})[C]=b,t.centerOffset=b-A,t)}}function effect$1(e){var t=e.state,s=e.options.element,i=void 0===s?"[data-popper-arrow]":s;null!=i&&("string"!=typeof i||(i=t.elements.popper.querySelector(i)))&&contains(t.elements.popper,i)&&(t.elements.arrow=i)}var arrow$1={name:"arrow",enabled:!0,phase:"main",fn:arrow,effect:effect$1,requires:["popperOffsets"],requiresIfExists:["preventOverflow"]};function getVariation(e){return e.split("-")[1]}var unsetSides={top:"auto",right:"auto",bottom:"auto",left:"auto"};function roundOffsetsByDPR(e,t){var s=e.x,i=e.y,n=t.devicePixelRatio||1;return{x:round(s*n)/n||0,y:round(i*n)/n||0}}function mapToStyles(e){var t,s=e.popper,i=e.popperRect,n=e.placement,r=e.variation,a=e.offsets,o=e.position,l=e.gpuAcceleration,u=e.adaptive,c=e.roundOffsets,h=e.isFixed,d=a.x,p=void 0===d?0:d,g=a.y,f=void 0===g?0:g,E="function"==typeof c?c({x:p,y:f}):{x:p,y:f};p=E.x,f=E.y;var _=a.hasOwnProperty("x"),m=a.hasOwnProperty("y"),v=left,T=top,A=window;if(u){var b=getOffsetParent(s),C="clientHeight",S="clientWidth";if(b===getWindow(s)&&"static"!==getComputedStyle$1(b=getDocumentElement(s)).position&&"absolute"===o&&(C="scrollHeight",S="scrollWidth"),n===top||(n===left||n===right)&&r===end)T=bottom,f-=(h&&b===A&&A.visualViewport?A.visualViewport.height:b[C])-i.height,f*=l?1:-1;if(n===left||(n===top||n===bottom)&&r===end)v=right,p-=(h&&b===A&&A.visualViewport?A.visualViewport.width:b[S])-i.width,p*=l?1:-1}var D,k=Object.assign({position:o},u&&unsetSides),N=!0===c?roundOffsetsByDPR({x:p,y:f},getWindow(s)):{x:p,y:f};return p=N.x,f=N.y,l?Object.assign({},k,((D={})[T]=m?"0":"",D[v]=_?"0":"",D.transform=(A.devicePixelRatio||1)<=1?"translate("+p+"px, "+f+"px)":"translate3d("+p+"px, "+f+"px, 0)",D)):Object.assign({},k,((t={})[T]=m?f+"px":"",t[v]=_?p+"px":"",t.transform="",t))}function computeStyles(e){var t=e.state,s=e.options,i=s.gpuAcceleration,n=void 0===i||i,r=s.adaptive,a=void 0===r||r,o=s.roundOffsets,l=void 0===o||o,u={placement:getBasePlacement(t.placement),variation:getVariation(t.placement),popper:t.elements.popper,popperRect:t.rects.popper,gpuAcceleration:n,isFixed:"fixed"===t.options.strategy};null!=t.modifiersData.popperOffsets&&(t.styles.popper=Object.assign({},t.styles.popper,mapToStyles(Object.assign({},u,{offsets:t.modifiersData.popperOffsets,position:t.options.strategy,adaptive:a,roundOffsets:l})))),null!=t.modifiersData.arrow&&(t.styles.arrow=Object.assign({},t.styles.arrow,mapToStyles(Object.assign({},u,{offsets:t.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:l})))),t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-placement":t.placement})}var computeStyles$1={name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:computeStyles,data:{}},passive={passive:!0};function effect(e){var t=e.state,s=e.instance,i=e.options,n=i.scroll,r=void 0===n||n,a=i.resize,o=void 0===a||a,l=getWindow(t.elements.popper),u=[].concat(t.scrollParents.reference,t.scrollParents.popper);return r&&u.forEach((function(e){e.addEventListener("scroll",s.update,passive)})),o&&l.addEventListener("resize",s.update,passive),function(){r&&u.forEach((function(e){e.removeEventListener("scroll",s.update,passive)})),o&&l.removeEventListener("resize",s.update,passive)}}var eventListeners={name:"eventListeners",enabled:!0,phase:"write",fn:function(){},effect:effect,data:{}},hash$1={left:"right",right:"left",bottom:"top",top:"bottom"};function getOppositePlacement(e){return e.replace(/left|right|bottom|top/g,(function(e){return hash$1[e]}))}var hash={start:"end",end:"start"};function getOppositeVariationPlacement(e){return e.replace(/start|end/g,(function(e){return hash[e]}))}function getWindowScroll(e){var t=getWindow(e);return{scrollLeft:t.pageXOffset,scrollTop:t.pageYOffset}}function getWindowScrollBarX(e){return getBoundingClientRect(getDocumentElement(e)).left+getWindowScroll(e).scrollLeft}function getViewportRect(e,t){var s=getWindow(e),i=getDocumentElement(e),n=s.visualViewport,r=i.clientWidth,a=i.clientHeight,o=0,l=0;if(n){r=n.width,a=n.height;var u=isLayoutViewport();(u||!u&&"fixed"===t)&&(o=n.offsetLeft,l=n.offsetTop)}return{width:r,height:a,x:o+getWindowScrollBarX(e),y:l}}function getDocumentRect(e){var t,s=getDocumentElement(e),i=getWindowScroll(e),n=null==(t=e.ownerDocument)?void 0:t.body,r=max(s.scrollWidth,s.clientWidth,n?n.scrollWidth:0,n?n.clientWidth:0),a=max(s.scrollHeight,s.clientHeight,n?n.scrollHeight:0,n?n.clientHeight:0),o=-i.scrollLeft+getWindowScrollBarX(e),l=-i.scrollTop;return"rtl"===getComputedStyle$1(n||s).direction&&(o+=max(s.clientWidth,n?n.clientWidth:0)-r),{width:r,height:a,x:o,y:l}}function isScrollParent(e){var t=getComputedStyle$1(e),s=t.overflow,i=t.overflowX,n=t.overflowY;return/auto|scroll|overlay|hidden/.test(s+n+i)}function getScrollParent(e){return["html","body","#document"].indexOf(getNodeName(e))>=0?e.ownerDocument.body:isHTMLElement(e)&&isScrollParent(e)?e:getScrollParent(getParentNode(e))}function listScrollParents(e,t){var s;void 0===t&&(t=[]);var i=getScrollParent(e),n=i===(null==(s=e.ownerDocument)?void 0:s.body),r=getWindow(i),a=n?[r].concat(r.visualViewport||[],isScrollParent(i)?i:[]):i,o=t.concat(a);return n?o:o.concat(listScrollParents(getParentNode(a)))}function rectToClientRect(e){return Object.assign({},e,{left:e.x,top:e.y,right:e.x+e.width,bottom:e.y+e.height})}function getInnerBoundingClientRect(e,t){var s=getBoundingClientRect(e,!1,"fixed"===t);return s.top=s.top+e.clientTop,s.left=s.left+e.clientLeft,s.bottom=s.top+e.clientHeight,s.right=s.left+e.clientWidth,s.width=e.clientWidth,s.height=e.clientHeight,s.x=s.left,s.y=s.top,s}function getClientRectFromMixedType(e,t,s){return t===viewport?rectToClientRect(getViewportRect(e,s)):isElement$1(t)?getInnerBoundingClientRect(t,s):rectToClientRect(getDocumentRect(getDocumentElement(e)))}function getClippingParents(e){var t=listScrollParents(getParentNode(e)),s=["absolute","fixed"].indexOf(getComputedStyle$1(e).position)>=0&&isHTMLElement(e)?getOffsetParent(e):e;return isElement$1(s)?t.filter((function(e){return isElement$1(e)&&contains(e,s)&&"body"!==getNodeName(e)})):[]}function getClippingRect(e,t,s,i){var n="clippingParents"===t?getClippingParents(e):[].concat(t),r=[].concat(n,[s]),a=r[0],o=r.reduce((function(t,s){var n=getClientRectFromMixedType(e,s,i);return t.top=max(n.top,t.top),t.right=min(n.right,t.right),t.bottom=min(n.bottom,t.bottom),t.left=max(n.left,t.left),t}),getClientRectFromMixedType(e,a,i));return o.width=o.right-o.left,o.height=o.bottom-o.top,o.x=o.left,o.y=o.top,o}function computeOffsets(e){var t,s=e.reference,i=e.element,n=e.placement,r=n?getBasePlacement(n):null,a=n?getVariation(n):null,o=s.x+s.width/2-i.width/2,l=s.y+s.height/2-i.height/2;switch(r){case top:t={x:o,y:s.y-i.height};break;case bottom:t={x:o,y:s.y+s.height};break;case right:t={x:s.x+s.width,y:l};break;case left:t={x:s.x-i.width,y:l};break;default:t={x:s.x,y:s.y}}var u=r?getMainAxisFromPlacement(r):null;if(null!=u){var c="y"===u?"height":"width";switch(a){case start:t[u]=t[u]-(s[c]/2-i[c]/2);break;case end:t[u]=t[u]+(s[c]/2-i[c]/2)}}return t}function detectOverflow(e,t){void 0===t&&(t={});var s=t,i=s.placement,n=void 0===i?e.placement:i,r=s.strategy,a=void 0===r?e.strategy:r,o=s.boundary,l=void 0===o?clippingParents:o,u=s.rootBoundary,c=void 0===u?viewport:u,h=s.elementContext,d=void 0===h?popper:h,p=s.altBoundary,g=void 0!==p&&p,f=s.padding,E=void 0===f?0:f,_=mergePaddingObject("number"!=typeof E?E:expandToHashMap(E,basePlacements)),m=d===popper?reference:popper,v=e.rects.popper,T=e.elements[g?m:d],A=getClippingRect(isElement$1(T)?T:T.contextElement||getDocumentElement(e.elements.popper),l,c,a),b=getBoundingClientRect(e.elements.reference),C=computeOffsets({reference:b,element:v,strategy:"absolute",placement:n}),S=rectToClientRect(Object.assign({},v,C)),D=d===popper?S:b,k={top:A.top-D.top+_.top,bottom:D.bottom-A.bottom+_.bottom,left:A.left-D.left+_.left,right:D.right-A.right+_.right},N=e.modifiersData.offset;if(d===popper&&N){var O=N[n];Object.keys(k).forEach((function(e){var t=[right,bottom].indexOf(e)>=0?1:-1,s=[top,bottom].indexOf(e)>=0?"y":"x";k[e]+=O[s]*t}))}return k}function computeAutoPlacement(e,t){void 0===t&&(t={});var s=t,i=s.placement,n=s.boundary,r=s.rootBoundary,a=s.padding,o=s.flipVariations,l=s.allowedAutoPlacements,u=void 0===l?placements:l,c=getVariation(i),h=c?o?variationPlacements:variationPlacements.filter((function(e){return getVariation(e)===c})):basePlacements,d=h.filter((function(e){return u.indexOf(e)>=0}));0===d.length&&(d=h);var p=d.reduce((function(t,s){return t[s]=detectOverflow(e,{placement:s,boundary:n,rootBoundary:r,padding:a})[getBasePlacement(s)],t}),{});return Object.keys(p).sort((function(e,t){return p[e]-p[t]}))}function getExpandedFallbackPlacements(e){if(getBasePlacement(e)===auto)return[];var t=getOppositePlacement(e);return[getOppositeVariationPlacement(e),t,getOppositeVariationPlacement(t)]}function flip(e){var t=e.state,s=e.options,i=e.name;if(!t.modifiersData[i]._skip){for(var n=s.mainAxis,r=void 0===n||n,a=s.altAxis,o=void 0===a||a,l=s.fallbackPlacements,u=s.padding,c=s.boundary,h=s.rootBoundary,d=s.altBoundary,p=s.flipVariations,g=void 0===p||p,f=s.allowedAutoPlacements,E=t.options.placement,_=getBasePlacement(E),m=l||(_===E||!g?[getOppositePlacement(E)]:getExpandedFallbackPlacements(E)),v=[E].concat(m).reduce((function(e,s){return e.concat(getBasePlacement(s)===auto?computeAutoPlacement(t,{placement:s,boundary:c,rootBoundary:h,padding:u,flipVariations:g,allowedAutoPlacements:f}):s)}),[]),T=t.rects.reference,A=t.rects.popper,b=new Map,C=!0,S=v[0],D=0;D=0,w=y?"width":"height",I=detectOverflow(t,{placement:k,boundary:c,rootBoundary:h,altBoundary:d,padding:u}),M=y?O?right:left:O?bottom:top;T[w]>A[w]&&(M=getOppositePlacement(M));var L=getOppositePlacement(M),R=[];if(r&&R.push(I[N]<=0),o&&R.push(I[M]<=0,I[L]<=0),R.every((function(e){return e}))){S=k,C=!1;break}b.set(k,R)}if(C)for(var P=function(e){var t=v.find((function(t){var s=b.get(t);if(s)return s.slice(0,e).every((function(e){return e}))}));if(t)return S=t,"break"},$=g?3:1;$>0;$--){if("break"===P($))break}t.placement!==S&&(t.modifiersData[i]._skip=!0,t.placement=S,t.reset=!0)}}var flip$1={name:"flip",enabled:!0,phase:"main",fn:flip,requiresIfExists:["offset"],data:{_skip:!1}};function getSideOffsets(e,t,s){return void 0===s&&(s={x:0,y:0}),{top:e.top-t.height-s.y,right:e.right-t.width+s.x,bottom:e.bottom-t.height+s.y,left:e.left-t.width-s.x}}function isAnySideFullyClipped(e){return[top,right,bottom,left].some((function(t){return e[t]>=0}))}function hide(e){var t=e.state,s=e.name,i=t.rects.reference,n=t.rects.popper,r=t.modifiersData.preventOverflow,a=detectOverflow(t,{elementContext:"reference"}),o=detectOverflow(t,{altBoundary:!0}),l=getSideOffsets(a,i),u=getSideOffsets(o,n,r),c=isAnySideFullyClipped(l),h=isAnySideFullyClipped(u);t.modifiersData[s]={referenceClippingOffsets:l,popperEscapeOffsets:u,isReferenceHidden:c,hasPopperEscaped:h},t.attributes.popper=Object.assign({},t.attributes.popper,{"data-popper-reference-hidden":c,"data-popper-escaped":h})}var hide$1={name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:hide};function distanceAndSkiddingToXY(e,t,s){var i=getBasePlacement(e),n=[left,top].indexOf(i)>=0?-1:1,r="function"==typeof s?s(Object.assign({},t,{placement:e})):s,a=r[0],o=r[1];return a=a||0,o=(o||0)*n,[left,right].indexOf(i)>=0?{x:o,y:a}:{x:a,y:o}}function offset(e){var t=e.state,s=e.options,i=e.name,n=s.offset,r=void 0===n?[0,0]:n,a=placements.reduce((function(e,s){return e[s]=distanceAndSkiddingToXY(s,t.rects,r),e}),{}),o=a[t.placement],l=o.x,u=o.y;null!=t.modifiersData.popperOffsets&&(t.modifiersData.popperOffsets.x+=l,t.modifiersData.popperOffsets.y+=u),t.modifiersData[i]=a}var offset$1={name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:offset};function popperOffsets(e){var t=e.state,s=e.name;t.modifiersData[s]=computeOffsets({reference:t.rects.reference,element:t.rects.popper,strategy:"absolute",placement:t.placement})}var popperOffsets$1={name:"popperOffsets",enabled:!0,phase:"read",fn:popperOffsets,data:{}};function getAltAxis(e){return"x"===e?"y":"x"}function preventOverflow(e){var t=e.state,s=e.options,i=e.name,n=s.mainAxis,r=void 0===n||n,a=s.altAxis,o=void 0!==a&&a,l=s.boundary,u=s.rootBoundary,c=s.altBoundary,h=s.padding,d=s.tether,p=void 0===d||d,g=s.tetherOffset,f=void 0===g?0:g,E=detectOverflow(t,{boundary:l,rootBoundary:u,padding:h,altBoundary:c}),_=getBasePlacement(t.placement),m=getVariation(t.placement),v=!m,T=getMainAxisFromPlacement(_),A=getAltAxis(T),b=t.modifiersData.popperOffsets,C=t.rects.reference,S=t.rects.popper,D="function"==typeof f?f(Object.assign({},t.rects,{placement:t.placement})):f,k="number"==typeof D?{mainAxis:D,altAxis:D}:Object.assign({mainAxis:0,altAxis:0},D),N=t.modifiersData.offset?t.modifiersData.offset[t.placement]:null,O={x:0,y:0};if(b){if(r){var y,w="y"===T?top:left,I="y"===T?bottom:right,M="y"===T?"height":"width",L=b[T],R=L+E[w],P=L-E[I],$=p?-S[M]/2:0,F=m===start?C[M]:S[M],x=m===start?-S[M]:-C[M],V=t.elements.arrow,H=p&&V?getLayoutRect(V):{width:0,height:0},B=t.modifiersData["arrow#persistent"]?t.modifiersData["arrow#persistent"].padding:getFreshSideObject(),W=B[w],K=B[I],Y=within(0,C[M],H[M]),j=v?C[M]/2-$-Y-W-k.mainAxis:F-Y-W-k.mainAxis,U=v?-C[M]/2+$+Y+K+k.mainAxis:x+Y+K+k.mainAxis,G=t.elements.arrow&&getOffsetParent(t.elements.arrow),z=G?"y"===T?G.clientTop||0:G.clientLeft||0:0,q=null!=(y=null==N?void 0:N[T])?y:0,X=L+U-q,Q=within(p?min(R,L+j-q-z):R,L,p?max(P,X):P);b[T]=Q,O[T]=Q-L}if(o){var Z,J="x"===T?top:left,ee="x"===T?bottom:right,te=b[A],se="y"===A?"height":"width",ie=te+E[J],ne=te-E[ee],re=-1!==[top,left].indexOf(_),ae=null!=(Z=null==N?void 0:N[A])?Z:0,oe=re?ie:te-C[se]-S[se]-ae+k.altAxis,le=re?te+C[se]+S[se]-ae-k.altAxis:ne,ue=p&&re?withinMaxClamp(oe,te,le):within(p?oe:ie,te,p?le:ne);b[A]=ue,O[A]=ue-te}t.modifiersData[i]=O}}var preventOverflow$1={name:"preventOverflow",enabled:!0,phase:"main",fn:preventOverflow,requiresIfExists:["offset"]};function getHTMLElementScroll(e){return{scrollLeft:e.scrollLeft,scrollTop:e.scrollTop}}function getNodeScroll(e){return e!==getWindow(e)&&isHTMLElement(e)?getHTMLElementScroll(e):getWindowScroll(e)}function isElementScaled(e){var t=e.getBoundingClientRect(),s=round(t.width)/e.offsetWidth||1,i=round(t.height)/e.offsetHeight||1;return 1!==s||1!==i}function getCompositeRect(e,t,s){void 0===s&&(s=!1);var i=isHTMLElement(t),n=isHTMLElement(t)&&isElementScaled(t),r=getDocumentElement(t),a=getBoundingClientRect(e,n,s),o={scrollLeft:0,scrollTop:0},l={x:0,y:0};return(i||!i&&!s)&&(("body"!==getNodeName(t)||isScrollParent(r))&&(o=getNodeScroll(t)),isHTMLElement(t)?((l=getBoundingClientRect(t,!0)).x+=t.clientLeft,l.y+=t.clientTop):r&&(l.x=getWindowScrollBarX(r))),{x:a.left+o.scrollLeft-l.x,y:a.top+o.scrollTop-l.y,width:a.width,height:a.height}}function order(e){var t=new Map,s=new Set,i=[];function n(e){s.add(e.name),[].concat(e.requires||[],e.requiresIfExists||[]).forEach((function(e){if(!s.has(e)){var i=t.get(e);i&&n(i)}})),i.push(e)}return e.forEach((function(e){t.set(e.name,e)})),e.forEach((function(e){s.has(e.name)||n(e)})),i}function orderModifiers(e){var t=order(e);return modifierPhases.reduce((function(e,s){return e.concat(t.filter((function(e){return e.phase===s})))}),[])}function debounce(e){var t;return function(){return t||(t=new Promise((function(s){Promise.resolve().then((function(){t=void 0,s(e())}))}))),t}}function mergeByName(e){var t=e.reduce((function(e,t){var s=e[t.name];return e[t.name]=s?Object.assign({},s,t,{options:Object.assign({},s.options,t.options),data:Object.assign({},s.data,t.data)}):t,e}),{});return Object.keys(t).map((function(e){return t[e]}))}var DEFAULT_OPTIONS={placement:"bottom",modifiers:[],strategy:"absolute"};function areValidElements(){for(var e=arguments.length,t=new Array(e),s=0;selementMap.has(e)&&elementMap.get(e).get(t)||null,remove(e,t){if(!elementMap.has(e))return;const s=elementMap.get(e);s.delete(t),0===s.size&&elementMap.delete(e)}},MAX_UID=1e6,MILLISECONDS_MULTIPLIER=1e3,TRANSITION_END="transitionend",parseSelector=e=>(e&&window.CSS&&window.CSS.escape&&(e=e.replace(/#([^\s"#']+)/g,((e,t)=>`#${CSS.escape(t)}`))),e),toType=e=>null==e?`${e}`:Object.prototype.toString.call(e).match(/\s([a-z]+)/i)[1].toLowerCase(),getUID=e=>{do{e+=Math.floor(1e6*Math.random())}while(document.getElementById(e));return e},getTransitionDurationFromElement=e=>{if(!e)return 0;let{transitionDuration:t,transitionDelay:s}=window.getComputedStyle(e);const i=Number.parseFloat(t),n=Number.parseFloat(s);return i||n?(t=t.split(",")[0],s=s.split(",")[0],1e3*(Number.parseFloat(t)+Number.parseFloat(s))):0},triggerTransitionEnd=e=>{e.dispatchEvent(new Event(TRANSITION_END))},isElement=e=>!(!e||"object"!=typeof e)&&(void 0!==e.jquery&&(e=e[0]),void 0!==e.nodeType),getElement=e=>isElement(e)?e.jquery?e[0]:e:"string"==typeof e&&e.length>0?document.querySelector(parseSelector(e)):null,isVisible=e=>{if(!isElement(e)||0===e.getClientRects().length)return!1;const t="visible"===getComputedStyle(e).getPropertyValue("visibility"),s=e.closest("details:not([open])");if(!s)return t;if(s!==e){const t=e.closest("summary");if(t&&t.parentNode!==s)return!1;if(null===t)return!1}return t},isDisabled=e=>!e||e.nodeType!==Node.ELEMENT_NODE||(!!e.classList.contains("disabled")||(void 0!==e.disabled?e.disabled:e.hasAttribute("disabled")&&"false"!==e.getAttribute("disabled"))),findShadowRoot=e=>{if(!document.documentElement.attachShadow)return null;if("function"==typeof e.getRootNode){const t=e.getRootNode();return t instanceof ShadowRoot?t:null}return e instanceof ShadowRoot?e:e.parentNode?findShadowRoot(e.parentNode):null},noop=()=>{},reflow=e=>{e.offsetHeight},getjQuery=()=>window.jQuery&&!document.body.hasAttribute("data-bs-no-jquery")?window.jQuery:null,DOMContentLoadedCallbacks=[],onDOMContentLoaded=e=>{"loading"===document.readyState?(DOMContentLoadedCallbacks.length||document.addEventListener("DOMContentLoaded",(()=>{for(const e of DOMContentLoadedCallbacks)e()})),DOMContentLoadedCallbacks.push(e)):e()},isRTL=()=>"rtl"===document.documentElement.dir,defineJQueryPlugin=e=>{var t;t=()=>{const t=getjQuery();if(t){const s=e.NAME,i=t.fn[s];t.fn[s]=e.jQueryInterface,t.fn[s].Constructor=e,t.fn[s].noConflict=()=>(t.fn[s]=i,e.jQueryInterface)}},"loading"===document.readyState?(DOMContentLoadedCallbacks.length||document.addEventListener("DOMContentLoaded",(()=>{for(const e of DOMContentLoadedCallbacks)e()})),DOMContentLoadedCallbacks.push(t)):t()},execute=(e,t=[],s=e)=>"function"==typeof e?e(...t):s,executeAfterTransition=(e,t,s=!0)=>{if(!s)return void execute(e);const i=getTransitionDurationFromElement(t)+5;let n=!1;const r=({target:s})=>{s===t&&(n=!0,t.removeEventListener(TRANSITION_END,r),execute(e))};t.addEventListener(TRANSITION_END,r),setTimeout((()=>{n||triggerTransitionEnd(t)}),i)},getNextActiveElement=(e,t,s,i)=>{const n=e.length;let r=e.indexOf(t);return-1===r?!s&&i?e[n-1]:e[0]:(r+=s?1:-1,i&&(r=(r+n)%n),e[Math.max(0,Math.min(r,n-1))])},namespaceRegex=/[^.]*(?=\..*)\.|.*/,stripNameRegex=/\..*/,stripUidRegex=/::\d+$/,eventRegistry={};let uidEvent=1;const customEvents={mouseenter:"mouseover",mouseleave:"mouseout"},nativeEvents=new Set(["click","dblclick","mouseup","mousedown","contextmenu","mousewheel","DOMMouseScroll","mouseover","mouseout","mousemove","selectstart","selectend","keydown","keypress","keyup","orientationchange","touchstart","touchmove","touchend","touchcancel","pointerdown","pointermove","pointerup","pointerleave","pointercancel","gesturestart","gesturechange","gestureend","focus","blur","change","reset","select","submit","focusin","focusout","load","unload","beforeunload","resize","move","DOMContentLoaded","readystatechange","error","abort","scroll"]);function makeEventUid(e,t){return t&&`${t}::${uidEvent++}`||e.uidEvent||uidEvent++}function getElementEvents(e){const t=makeEventUid(e);return e.uidEvent=t,eventRegistry[t]=eventRegistry[t]||{},eventRegistry[t]}function bootstrapHandler(e,t){return function s(i){return hydrateObj(i,{delegateTarget:e}),s.oneOff&&EventHandler.off(e,i.type,t),t.apply(e,[i])}}function bootstrapDelegationHandler(e,t,s){return function i(n){const r=e.querySelectorAll(t);for(let{target:a}=n;a&&a!==this;a=a.parentNode)for(const o of r)if(o===a)return hydrateObj(n,{delegateTarget:a}),i.oneOff&&EventHandler.off(e,n.type,t,s),s.apply(a,[n])}}function findHandler(e,t,s=null){return Object.values(e).find((e=>e.callable===t&&e.delegationSelector===s))}function normalizeParameters(e,t,s){const i="string"==typeof t,n=i?s:t||s;let r=getTypeEvent(e);return nativeEvents.has(r)||(r=e),[i,n,r]}function addHandler(e,t,s,i,n){if("string"!=typeof t||!e)return;let[r,a,o]=normalizeParameters(t,s,i);if(t in customEvents){const e=e=>function(t){if(!t.relatedTarget||t.relatedTarget!==t.delegateTarget&&!t.delegateTarget.contains(t.relatedTarget))return e.call(this,t)};a=e(a)}const l=getElementEvents(e),u=l[o]||(l[o]={}),c=findHandler(u,a,r?s:null);if(c)return void(c.oneOff=c.oneOff&&n);const h=makeEventUid(a,t.replace(namespaceRegex,"")),d=r?bootstrapDelegationHandler(e,s,a):bootstrapHandler(e,a);d.delegationSelector=r?s:null,d.callable=a,d.oneOff=n,d.uidEvent=h,u[h]=d,e.addEventListener(o,d,r)}function removeHandler(e,t,s,i,n){const r=findHandler(t[s],i,n);r&&(e.removeEventListener(s,r,Boolean(n)),delete t[s][r.uidEvent])}function removeNamespacedHandlers(e,t,s,i){const n=t[s]||{};for(const[r,a]of Object.entries(n))r.includes(i)&&removeHandler(e,t,s,a.callable,a.delegationSelector)}function getTypeEvent(e){return e=e.replace(stripNameRegex,""),customEvents[e]||e}const EventHandler={on(e,t,s,i){addHandler(e,t,s,i,!1)},one(e,t,s,i){addHandler(e,t,s,i,!0)},off(e,t,s,i){if("string"!=typeof t||!e)return;const[n,r,a]=normalizeParameters(t,s,i),o=a!==t,l=getElementEvents(e),u=l[a]||{},c=t.startsWith(".");if(void 0===r){if(c)for(const s of Object.keys(l))removeNamespacedHandlers(e,l,s,t.slice(1));for(const[s,i]of Object.entries(u)){const n=s.replace(stripUidRegex,"");o&&!t.includes(n)||removeHandler(e,l,a,i.callable,i.delegationSelector)}}else{if(!Object.keys(u).length)return;removeHandler(e,l,a,r,n?s:null)}},trigger(e,t,s){if("string"!=typeof t||!e)return null;const i=getjQuery();let n=null,r=!0,a=!0,o=!1;t!==getTypeEvent(t)&&i&&(n=i.Event(t,s),i(e).trigger(n),r=!n.isPropagationStopped(),a=!n.isImmediatePropagationStopped(),o=n.isDefaultPrevented());const l=hydrateObj(new Event(t,{bubbles:r,cancelable:!0}),s);return o&&l.preventDefault(),a&&e.dispatchEvent(l),l.defaultPrevented&&n&&n.preventDefault(),l}};function hydrateObj(e,t={}){for(const[s,i]of Object.entries(t))try{e[s]=i}catch(t){Object.defineProperty(e,s,{configurable:!0,get:()=>i})}return e}function normalizeData(e){if("true"===e)return!0;if("false"===e)return!1;if(e===Number(e).toString())return Number(e);if(""===e||"null"===e)return null;if("string"!=typeof e)return e;try{return JSON.parse(decodeURIComponent(e))}catch(t){return e}}function normalizeDataKey(e){return e.replace(/[A-Z]/g,(e=>`-${e.toLowerCase()}`))}const Manipulator={setDataAttribute(e,t,s){e.setAttribute(`data-bs-${normalizeDataKey(t)}`,s)},removeDataAttribute(e,t){e.removeAttribute(`data-bs-${normalizeDataKey(t)}`)},getDataAttributes(e){if(!e)return{};const t={},s=Object.keys(e.dataset).filter((e=>e.startsWith("bs")&&!e.startsWith("bsConfig")));for(const i of s){let s=i.replace(/^bs/,"");s=s.charAt(0).toLowerCase()+s.slice(1,s.length),t[s]=normalizeData(e.dataset[i])}return t},getDataAttribute:(e,t)=>normalizeData(e.getAttribute(`data-bs-${normalizeDataKey(t)}`))};class Config{static get Default(){return{}}static get DefaultType(){return{}}static get NAME(){throw new Error('You have to implement the static method "NAME", for each component!')}_getConfig(e){return e=this._mergeConfigObj(e),e=this._configAfterMerge(e),this._typeCheckConfig(e),e}_configAfterMerge(e){return e}_mergeConfigObj(e,t){const s=isElement(t)?Manipulator.getDataAttribute(t,"config"):{};return{...this.constructor.Default,..."object"==typeof s?s:{},...isElement(t)?Manipulator.getDataAttributes(t):{},..."object"==typeof e?e:{}}}_typeCheckConfig(e,t=this.constructor.DefaultType){for(const[i,n]of Object.entries(t)){const t=e[i],r=isElement(t)?"element":null==(s=t)?`${s}`:Object.prototype.toString.call(s).match(/\s([a-z]+)/i)[1].toLowerCase();if(!new RegExp(n).test(r))throw new TypeError(`${this.constructor.NAME.toUpperCase()}: Option "${i}" provided type "${r}" but expected type "${n}".`)}var s}}const VERSION="5.3.1";class BaseComponent extends Config{constructor(e,t){super(),(e=getElement(e))&&(this._element=e,this._config=this._getConfig(t),Data.set(this._element,this.constructor.DATA_KEY,this))}dispose(){Data.remove(this._element,this.constructor.DATA_KEY),EventHandler.off(this._element,this.constructor.EVENT_KEY);for(const e of Object.getOwnPropertyNames(this))this[e]=null}_queueCallback(e,t,s=!0){executeAfterTransition(e,t,s)}_getConfig(e){return e=this._mergeConfigObj(e,this._element),e=this._configAfterMerge(e),this._typeCheckConfig(e),e}static getInstance(e){return Data.get(getElement(e),this.DATA_KEY)}static getOrCreateInstance(e,t={}){return this.getInstance(e)||new this(e,"object"==typeof t?t:null)}static get VERSION(){return"5.3.1"}static get DATA_KEY(){return`bs.${this.NAME}`}static get EVENT_KEY(){return`.${this.DATA_KEY}`}static eventName(e){return`${e}${this.EVENT_KEY}`}}const getSelector=e=>{let t=e.getAttribute("data-bs-target");if(!t||"#"===t){let s=e.getAttribute("href");if(!s||!s.includes("#")&&!s.startsWith("."))return null;s.includes("#")&&!s.startsWith("#")&&(s=`#${s.split("#")[1]}`),t=s&&"#"!==s?s.trim():null}return parseSelector(t)},SelectorEngine={find:(e,t=document.documentElement)=>[].concat(...Element.prototype.querySelectorAll.call(t,e)),findOne:(e,t=document.documentElement)=>Element.prototype.querySelector.call(t,e),children:(e,t)=>[].concat(...e.children).filter((e=>e.matches(t))),parents(e,t){const s=[];let i=e.parentNode.closest(t);for(;i;)s.push(i),i=i.parentNode.closest(t);return s},prev(e,t){let s=e.previousElementSibling;for(;s;){if(s.matches(t))return[s];s=s.previousElementSibling}return[]},next(e,t){let s=e.nextElementSibling;for(;s;){if(s.matches(t))return[s];s=s.nextElementSibling}return[]},focusableChildren(e){const t=["a","button","input","textarea","select","details","[tabindex]",'[contenteditable="true"]'].map((e=>`${e}:not([tabindex^="-"])`)).join(",");return this.find(t,e).filter((e=>!isDisabled(e)&&isVisible(e)))},getSelectorFromElement(e){const t=getSelector(e);return t&&SelectorEngine.findOne(t)?t:null},getElementFromSelector(e){const t=getSelector(e);return t?SelectorEngine.findOne(t):null},getMultipleElementsFromSelector(e){const t=getSelector(e);return t?SelectorEngine.find(t):[]}},enableDismissTrigger=(e,t="hide")=>{const s=`click.dismiss${e.EVENT_KEY}`,i=e.NAME;EventHandler.on(document,s,`[data-bs-dismiss="${i}"]`,(function(s){if(["A","AREA"].includes(this.tagName)&&s.preventDefault(),isDisabled(this))return;const n=SelectorEngine.getElementFromSelector(this)||this.closest(`.${i}`);e.getOrCreateInstance(n)[t]()}))},NAME$f="alert",DATA_KEY$a="bs.alert",EVENT_KEY$b=".bs.alert",EVENT_CLOSE="close.bs.alert",EVENT_CLOSED="closed.bs.alert",CLASS_NAME_FADE$5="fade",CLASS_NAME_SHOW$8="show";class Alert extends BaseComponent{static get NAME(){return NAME$f}close(){if(EventHandler.trigger(this._element,EVENT_CLOSE).defaultPrevented)return;this._element.classList.remove("show");const e=this._element.classList.contains("fade");this._queueCallback((()=>this._destroyElement()),this._element,e)}_destroyElement(){this._element.remove(),EventHandler.trigger(this._element,EVENT_CLOSED),this.dispose()}static jQueryInterface(e){return this.each((function(){const t=Alert.getOrCreateInstance(this);if("string"==typeof e){if(void 0===t[e]||e.startsWith("_")||"constructor"===e)throw new TypeError(`No method named "${e}"`);t[e](this)}}))}}enableDismissTrigger(Alert,"close"),defineJQueryPlugin(Alert);const NAME$e="button",DATA_KEY$9="bs.button",EVENT_KEY$a=`.${DATA_KEY$9}`,DATA_API_KEY$6=".data-api",CLASS_NAME_ACTIVE$3="active",SELECTOR_DATA_TOGGLE$5='[data-bs-toggle="button"]',EVENT_CLICK_DATA_API$6=`click${EVENT_KEY$a}.data-api`;class Button extends BaseComponent{static get NAME(){return NAME$e}toggle(){this._element.setAttribute("aria-pressed",this._element.classList.toggle("active"))}static jQueryInterface(e){return this.each((function(){const t=Button.getOrCreateInstance(this);"toggle"===e&&t[e]()}))}}EventHandler.on(document,EVENT_CLICK_DATA_API$6,SELECTOR_DATA_TOGGLE$5,(e=>{e.preventDefault();const t=e.target.closest(SELECTOR_DATA_TOGGLE$5);Button.getOrCreateInstance(t).toggle()})),defineJQueryPlugin(Button);const NAME$d="swipe",EVENT_KEY$9=".bs.swipe",EVENT_TOUCHSTART="touchstart.bs.swipe",EVENT_TOUCHMOVE="touchmove.bs.swipe",EVENT_TOUCHEND="touchend.bs.swipe",EVENT_POINTERDOWN="pointerdown.bs.swipe",EVENT_POINTERUP="pointerup.bs.swipe",POINTER_TYPE_TOUCH="touch",POINTER_TYPE_PEN="pen",CLASS_NAME_POINTER_EVENT="pointer-event",SWIPE_THRESHOLD=40,Default$c={endCallback:null,leftCallback:null,rightCallback:null},DefaultType$c={endCallback:"(function|null)",leftCallback:"(function|null)",rightCallback:"(function|null)"};class Swipe extends Config{constructor(e,t){super(),this._element=e,e&&Swipe.isSupported()&&(this._config=this._getConfig(t),this._deltaX=0,this._supportPointerEvents=Boolean(window.PointerEvent),this._initEvents())}static get Default(){return Default$c}static get DefaultType(){return DefaultType$c}static get NAME(){return NAME$d}dispose(){EventHandler.off(this._element,".bs.swipe")}_start(e){this._supportPointerEvents?this._eventIsPointerPenTouch(e)&&(this._deltaX=e.clientX):this._deltaX=e.touches[0].clientX}_end(e){this._eventIsPointerPenTouch(e)&&(this._deltaX=e.clientX-this._deltaX),this._handleSwipe(),execute(this._config.endCallback)}_move(e){this._deltaX=e.touches&&e.touches.length>1?0:e.touches[0].clientX-this._deltaX}_handleSwipe(){const e=Math.abs(this._deltaX);if(e<=40)return;const t=e/this._deltaX;this._deltaX=0,t&&execute(t>0?this._config.rightCallback:this._config.leftCallback)}_initEvents(){this._supportPointerEvents?(EventHandler.on(this._element,EVENT_POINTERDOWN,(e=>this._start(e))),EventHandler.on(this._element,EVENT_POINTERUP,(e=>this._end(e))),this._element.classList.add("pointer-event")):(EventHandler.on(this._element,EVENT_TOUCHSTART,(e=>this._start(e))),EventHandler.on(this._element,EVENT_TOUCHMOVE,(e=>this._move(e))),EventHandler.on(this._element,EVENT_TOUCHEND,(e=>this._end(e))))}_eventIsPointerPenTouch(e){return this._supportPointerEvents&&("pen"===e.pointerType||"touch"===e.pointerType)}static isSupported(){return"ontouchstart"in document.documentElement||navigator.maxTouchPoints>0}}const NAME$c="carousel",DATA_KEY$8="bs.carousel",EVENT_KEY$8=`.${DATA_KEY$8}`,DATA_API_KEY$5=".data-api",ARROW_LEFT_KEY$1="ArrowLeft",ARROW_RIGHT_KEY$1="ArrowRight",TOUCHEVENT_COMPAT_WAIT=500,ORDER_NEXT="next",ORDER_PREV="prev",DIRECTION_LEFT="left",DIRECTION_RIGHT="right",EVENT_SLIDE=`slide${EVENT_KEY$8}`,EVENT_SLID=`slid${EVENT_KEY$8}`,EVENT_KEYDOWN$1=`keydown${EVENT_KEY$8}`,EVENT_MOUSEENTER$1=`mouseenter${EVENT_KEY$8}`,EVENT_MOUSELEAVE$1=`mouseleave${EVENT_KEY$8}`,EVENT_DRAG_START=`dragstart${EVENT_KEY$8}`,EVENT_LOAD_DATA_API$3=`load${EVENT_KEY$8}.data-api`,EVENT_CLICK_DATA_API$5=`click${EVENT_KEY$8}.data-api`,CLASS_NAME_CAROUSEL="carousel",CLASS_NAME_ACTIVE$2="active",CLASS_NAME_SLIDE="slide",CLASS_NAME_END="carousel-item-end",CLASS_NAME_START="carousel-item-start",CLASS_NAME_NEXT="carousel-item-next",CLASS_NAME_PREV="carousel-item-prev",SELECTOR_ACTIVE=".active",SELECTOR_ITEM=".carousel-item",SELECTOR_ACTIVE_ITEM=".active.carousel-item",SELECTOR_ITEM_IMG=".carousel-item img",SELECTOR_INDICATORS=".carousel-indicators",SELECTOR_DATA_SLIDE="[data-bs-slide], [data-bs-slide-to]",SELECTOR_DATA_RIDE='[data-bs-ride="carousel"]',KEY_TO_DIRECTION={ArrowLeft:"right",ArrowRight:"left"},Default$b={interval:5e3,keyboard:!0,pause:"hover",ride:!1,touch:!0,wrap:!0},DefaultType$b={interval:"(number|boolean)",keyboard:"boolean",pause:"(string|boolean)",ride:"(boolean|string)",touch:"boolean",wrap:"boolean"};class Carousel extends BaseComponent{constructor(e,t){super(e,t),this._interval=null,this._activeElement=null,this._isSliding=!1,this.touchTimeout=null,this._swipeHelper=null,this._indicatorsElement=SelectorEngine.findOne(SELECTOR_INDICATORS,this._element),this._addEventListeners(),"carousel"===this._config.ride&&this.cycle()}static get Default(){return Default$b}static get DefaultType(){return DefaultType$b}static get NAME(){return NAME$c}next(){this._slide("next")}nextWhenVisible(){!document.hidden&&isVisible(this._element)&&this.next()}prev(){this._slide("prev")}pause(){this._isSliding&&triggerTransitionEnd(this._element),this._clearInterval()}cycle(){this._clearInterval(),this._updateInterval(),this._interval=setInterval((()=>this.nextWhenVisible()),this._config.interval)}_maybeEnableCycle(){this._config.ride&&(this._isSliding?EventHandler.one(this._element,EVENT_SLID,(()=>this.cycle())):this.cycle())}to(e){const t=this._getItems();if(e>t.length-1||e<0)return;if(this._isSliding)return void EventHandler.one(this._element,EVENT_SLID,(()=>this.to(e)));const s=this._getItemIndex(this._getActive());if(s===e)return;const i=e>s?"next":"prev";this._slide(i,t[e])}dispose(){this._swipeHelper&&this._swipeHelper.dispose(),super.dispose()}_configAfterMerge(e){return e.defaultInterval=e.interval,e}_addEventListeners(){this._config.keyboard&&EventHandler.on(this._element,EVENT_KEYDOWN$1,(e=>this._keydown(e))),"hover"===this._config.pause&&(EventHandler.on(this._element,EVENT_MOUSEENTER$1,(()=>this.pause())),EventHandler.on(this._element,EVENT_MOUSELEAVE$1,(()=>this._maybeEnableCycle()))),this._config.touch&&Swipe.isSupported()&&this._addTouchEventListeners()}_addTouchEventListeners(){for(const e of SelectorEngine.find(SELECTOR_ITEM_IMG,this._element))EventHandler.on(e,EVENT_DRAG_START,(e=>e.preventDefault()));const e={leftCallback:()=>this._slide(this._directionToOrder("left")),rightCallback:()=>this._slide(this._directionToOrder("right")),endCallback:()=>{"hover"===this._config.pause&&(this.pause(),this.touchTimeout&&clearTimeout(this.touchTimeout),this.touchTimeout=setTimeout((()=>this._maybeEnableCycle()),500+this._config.interval))}};this._swipeHelper=new Swipe(this._element,e)}_keydown(e){if(/input|textarea/i.test(e.target.tagName))return;const t=KEY_TO_DIRECTION[e.key];t&&(e.preventDefault(),this._slide(this._directionToOrder(t)))}_getItemIndex(e){return this._getItems().indexOf(e)}_setActiveIndicatorElement(e){if(!this._indicatorsElement)return;const t=SelectorEngine.findOne(".active",this._indicatorsElement);t.classList.remove("active"),t.removeAttribute("aria-current");const s=SelectorEngine.findOne(`[data-bs-slide-to="${e}"]`,this._indicatorsElement);s&&(s.classList.add("active"),s.setAttribute("aria-current","true"))}_updateInterval(){const e=this._activeElement||this._getActive();if(!e)return;const t=Number.parseInt(e.getAttribute("data-bs-interval"),10);this._config.interval=t||this._config.defaultInterval}_slide(e,t=null){if(this._isSliding)return;const s=this._getActive(),i="next"===e,n=t||getNextActiveElement(this._getItems(),s,i,this._config.wrap);if(n===s)return;const r=this._getItemIndex(n),a=t=>EventHandler.trigger(this._element,t,{relatedTarget:n,direction:this._orderToDirection(e),from:this._getItemIndex(s),to:r});if(a(EVENT_SLIDE).defaultPrevented)return;if(!s||!n)return;const o=Boolean(this._interval);this.pause(),this._isSliding=!0,this._setActiveIndicatorElement(r),this._activeElement=n;const l=i?CLASS_NAME_START:CLASS_NAME_END,u=i?CLASS_NAME_NEXT:CLASS_NAME_PREV;n.classList.add(u),reflow(n),s.classList.add(l),n.classList.add(l);this._queueCallback((()=>{n.classList.remove(l,u),n.classList.add("active"),s.classList.remove("active",u,l),this._isSliding=!1,a(EVENT_SLID)}),s,this._isAnimated()),o&&this.cycle()}_isAnimated(){return this._element.classList.contains("slide")}_getActive(){return SelectorEngine.findOne(SELECTOR_ACTIVE_ITEM,this._element)}_getItems(){return SelectorEngine.find(SELECTOR_ITEM,this._element)}_clearInterval(){this._interval&&(clearInterval(this._interval),this._interval=null)}_directionToOrder(e){return isRTL()?"left"===e?"prev":"next":"left"===e?"next":"prev"}_orderToDirection(e){return isRTL()?"prev"===e?"left":"right":"prev"===e?"right":"left"}static jQueryInterface(e){return this.each((function(){const t=Carousel.getOrCreateInstance(this,e);if("number"!=typeof e){if("string"==typeof e){if(void 0===t[e]||e.startsWith("_")||"constructor"===e)throw new TypeError(`No method named "${e}"`);t[e]()}}else t.to(e)}))}}EventHandler.on(document,EVENT_CLICK_DATA_API$5,SELECTOR_DATA_SLIDE,(function(e){const t=SelectorEngine.getElementFromSelector(this);if(!t||!t.classList.contains("carousel"))return;e.preventDefault();const s=Carousel.getOrCreateInstance(t),i=this.getAttribute("data-bs-slide-to");return i?(s.to(i),void s._maybeEnableCycle()):"next"===Manipulator.getDataAttribute(this,"slide")?(s.next(),void s._maybeEnableCycle()):(s.prev(),void s._maybeEnableCycle())})),EventHandler.on(window,EVENT_LOAD_DATA_API$3,(()=>{const e=SelectorEngine.find(SELECTOR_DATA_RIDE);for(const t of e)Carousel.getOrCreateInstance(t)})),defineJQueryPlugin(Carousel);const NAME$b="collapse",DATA_KEY$7="bs.collapse",EVENT_KEY$7=`.${DATA_KEY$7}`,DATA_API_KEY$4=".data-api",EVENT_SHOW$6=`show${EVENT_KEY$7}`,EVENT_SHOWN$6=`shown${EVENT_KEY$7}`,EVENT_HIDE$6=`hide${EVENT_KEY$7}`,EVENT_HIDDEN$6=`hidden${EVENT_KEY$7}`,EVENT_CLICK_DATA_API$4=`click${EVENT_KEY$7}.data-api`,CLASS_NAME_SHOW$7="show",CLASS_NAME_COLLAPSE="collapse",CLASS_NAME_COLLAPSING="collapsing",CLASS_NAME_COLLAPSED="collapsed",CLASS_NAME_DEEPER_CHILDREN=":scope .collapse .collapse",CLASS_NAME_HORIZONTAL="collapse-horizontal",WIDTH="width",HEIGHT="height",SELECTOR_ACTIVES=".collapse.show, .collapse.collapsing",SELECTOR_DATA_TOGGLE$4='[data-bs-toggle="collapse"]',Default$a={parent:null,toggle:!0},DefaultType$a={parent:"(null|element)",toggle:"boolean"};class Collapse extends BaseComponent{constructor(e,t){super(e,t),this._isTransitioning=!1,this._triggerArray=[];const s=SelectorEngine.find(SELECTOR_DATA_TOGGLE$4);for(const e of s){const t=SelectorEngine.getSelectorFromElement(e),s=SelectorEngine.find(t).filter((e=>e===this._element));null!==t&&s.length&&this._triggerArray.push(e)}this._initializeChildren(),this._config.parent||this._addAriaAndCollapsedClass(this._triggerArray,this._isShown()),this._config.toggle&&this.toggle()}static get Default(){return Default$a}static get DefaultType(){return DefaultType$a}static get NAME(){return NAME$b}toggle(){this._isShown()?this.hide():this.show()}show(){if(this._isTransitioning||this._isShown())return;let e=[];if(this._config.parent&&(e=this._getFirstLevelChildren(SELECTOR_ACTIVES).filter((e=>e!==this._element)).map((e=>Collapse.getOrCreateInstance(e,{toggle:!1})))),e.length&&e[0]._isTransitioning)return;if(EventHandler.trigger(this._element,EVENT_SHOW$6).defaultPrevented)return;for(const t of e)t.hide();const t=this._getDimension();this._element.classList.remove("collapse"),this._element.classList.add("collapsing"),this._element.style[t]=0,this._addAriaAndCollapsedClass(this._triggerArray,!0),this._isTransitioning=!0;const s=`scroll${t[0].toUpperCase()+t.slice(1)}`;this._queueCallback((()=>{this._isTransitioning=!1,this._element.classList.remove("collapsing"),this._element.classList.add("collapse","show"),this._element.style[t]="",EventHandler.trigger(this._element,EVENT_SHOWN$6)}),this._element,!0),this._element.style[t]=`${this._element[s]}px`}hide(){if(this._isTransitioning||!this._isShown())return;if(EventHandler.trigger(this._element,EVENT_HIDE$6).defaultPrevented)return;const e=this._getDimension();this._element.style[e]=`${this._element.getBoundingClientRect()[e]}px`,reflow(this._element),this._element.classList.add("collapsing"),this._element.classList.remove("collapse","show");for(const e of this._triggerArray){const t=SelectorEngine.getElementFromSelector(e);t&&!this._isShown(t)&&this._addAriaAndCollapsedClass([e],!1)}this._isTransitioning=!0;this._element.style[e]="",this._queueCallback((()=>{this._isTransitioning=!1,this._element.classList.remove("collapsing"),this._element.classList.add("collapse"),EventHandler.trigger(this._element,EVENT_HIDDEN$6)}),this._element,!0)}_isShown(e=this._element){return e.classList.contains("show")}_configAfterMerge(e){return e.toggle=Boolean(e.toggle),e.parent=getElement(e.parent),e}_getDimension(){return this._element.classList.contains("collapse-horizontal")?WIDTH:HEIGHT}_initializeChildren(){if(!this._config.parent)return;const e=this._getFirstLevelChildren(SELECTOR_DATA_TOGGLE$4);for(const t of e){const e=SelectorEngine.getElementFromSelector(t);e&&this._addAriaAndCollapsedClass([t],this._isShown(e))}}_getFirstLevelChildren(e){const t=SelectorEngine.find(CLASS_NAME_DEEPER_CHILDREN,this._config.parent);return SelectorEngine.find(e,this._config.parent).filter((e=>!t.includes(e)))}_addAriaAndCollapsedClass(e,t){if(e.length)for(const s of e)s.classList.toggle("collapsed",!t),s.setAttribute("aria-expanded",t)}static jQueryInterface(e){const t={};return"string"==typeof e&&/show|hide/.test(e)&&(t.toggle=!1),this.each((function(){const s=Collapse.getOrCreateInstance(this,t);if("string"==typeof e){if(void 0===s[e])throw new TypeError(`No method named "${e}"`);s[e]()}}))}}EventHandler.on(document,EVENT_CLICK_DATA_API$4,SELECTOR_DATA_TOGGLE$4,(function(e){("A"===e.target.tagName||e.delegateTarget&&"A"===e.delegateTarget.tagName)&&e.preventDefault();for(const e of SelectorEngine.getMultipleElementsFromSelector(this))Collapse.getOrCreateInstance(e,{toggle:!1}).toggle()})),defineJQueryPlugin(Collapse);const NAME$a="dropdown",DATA_KEY$6="bs.dropdown",EVENT_KEY$6=`.${DATA_KEY$6}`,DATA_API_KEY$3=".data-api",ESCAPE_KEY$2="Escape",TAB_KEY$1="Tab",ARROW_UP_KEY$1="ArrowUp",ARROW_DOWN_KEY$1="ArrowDown",RIGHT_MOUSE_BUTTON=2,EVENT_HIDE$5=`hide${EVENT_KEY$6}`,EVENT_HIDDEN$5=`hidden${EVENT_KEY$6}`,EVENT_SHOW$5=`show${EVENT_KEY$6}`,EVENT_SHOWN$5=`shown${EVENT_KEY$6}`,EVENT_CLICK_DATA_API$3=`click${EVENT_KEY$6}.data-api`,EVENT_KEYDOWN_DATA_API=`keydown${EVENT_KEY$6}.data-api`,EVENT_KEYUP_DATA_API=`keyup${EVENT_KEY$6}.data-api`,CLASS_NAME_SHOW$6="show",CLASS_NAME_DROPUP="dropup",CLASS_NAME_DROPEND="dropend",CLASS_NAME_DROPSTART="dropstart",CLASS_NAME_DROPUP_CENTER="dropup-center",CLASS_NAME_DROPDOWN_CENTER="dropdown-center",SELECTOR_DATA_TOGGLE$3='[data-bs-toggle="dropdown"]:not(.disabled):not(:disabled)',SELECTOR_DATA_TOGGLE_SHOWN=`${SELECTOR_DATA_TOGGLE$3}.show`,SELECTOR_MENU=".dropdown-menu",SELECTOR_NAVBAR=".navbar",SELECTOR_NAVBAR_NAV=".navbar-nav",SELECTOR_VISIBLE_ITEMS=".dropdown-menu .dropdown-item:not(.disabled):not(:disabled)",PLACEMENT_TOP=isRTL()?"top-end":"top-start",PLACEMENT_TOPEND=isRTL()?"top-start":"top-end",PLACEMENT_BOTTOM=isRTL()?"bottom-end":"bottom-start",PLACEMENT_BOTTOMEND=isRTL()?"bottom-start":"bottom-end",PLACEMENT_RIGHT=isRTL()?"left-start":"right-start",PLACEMENT_LEFT=isRTL()?"right-start":"left-start",PLACEMENT_TOPCENTER="top",PLACEMENT_BOTTOMCENTER="bottom",Default$9={autoClose:!0,boundary:"clippingParents",display:"dynamic",offset:[0,2],popperConfig:null,reference:"toggle"},DefaultType$9={autoClose:"(boolean|string)",boundary:"(string|element)",display:"string",offset:"(array|string|function)",popperConfig:"(null|object|function)",reference:"(string|element|object)"};class Dropdown extends BaseComponent{constructor(e,t){super(e,t),this._popper=null,this._parent=this._element.parentNode,this._menu=SelectorEngine.next(this._element,SELECTOR_MENU)[0]||SelectorEngine.prev(this._element,SELECTOR_MENU)[0]||SelectorEngine.findOne(SELECTOR_MENU,this._parent),this._inNavbar=this._detectNavbar()}static get Default(){return Default$9}static get DefaultType(){return DefaultType$9}static get NAME(){return NAME$a}toggle(){return this._isShown()?this.hide():this.show()}show(){if(isDisabled(this._element)||this._isShown())return;const e={relatedTarget:this._element};if(!EventHandler.trigger(this._element,EVENT_SHOW$5,e).defaultPrevented){if(this._createPopper(),"ontouchstart"in document.documentElement&&!this._parent.closest(".navbar-nav"))for(const e of[].concat(...document.body.children))EventHandler.on(e,"mouseover",noop);this._element.focus(),this._element.setAttribute("aria-expanded",!0),this._menu.classList.add("show"),this._element.classList.add("show"),EventHandler.trigger(this._element,EVENT_SHOWN$5,e)}}hide(){if(isDisabled(this._element)||!this._isShown())return;const e={relatedTarget:this._element};this._completeHide(e)}dispose(){this._popper&&this._popper.destroy(),super.dispose()}update(){this._inNavbar=this._detectNavbar(),this._popper&&this._popper.update()}_completeHide(e){if(!EventHandler.trigger(this._element,EVENT_HIDE$5,e).defaultPrevented){if("ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))EventHandler.off(e,"mouseover",noop);this._popper&&this._popper.destroy(),this._menu.classList.remove("show"),this._element.classList.remove("show"),this._element.setAttribute("aria-expanded","false"),Manipulator.removeDataAttribute(this._menu,"popper"),EventHandler.trigger(this._element,EVENT_HIDDEN$5,e)}}_getConfig(e){if("object"==typeof(e=super._getConfig(e)).reference&&!isElement(e.reference)&&"function"!=typeof e.reference.getBoundingClientRect)throw new TypeError(`${NAME$a.toUpperCase()}: Option "reference" provided type "object" without a required "getBoundingClientRect" method.`);return e}_createPopper(){if(void 0===Popper)throw new TypeError("Bootstrap's dropdowns require Popper (https://popper.js.org)");let e=this._element;"parent"===this._config.reference?e=this._parent:isElement(this._config.reference)?e=getElement(this._config.reference):"object"==typeof this._config.reference&&(e=this._config.reference);const t=this._getPopperConfig();this._popper=createPopper(e,this._menu,t)}_isShown(){return this._menu.classList.contains("show")}_getPlacement(){const e=this._parent;if(e.classList.contains("dropend"))return PLACEMENT_RIGHT;if(e.classList.contains("dropstart"))return PLACEMENT_LEFT;if(e.classList.contains("dropup-center"))return"top";if(e.classList.contains("dropdown-center"))return"bottom";const t="end"===getComputedStyle(this._menu).getPropertyValue("--bs-position").trim();return e.classList.contains("dropup")?t?PLACEMENT_TOPEND:PLACEMENT_TOP:t?PLACEMENT_BOTTOMEND:PLACEMENT_BOTTOM}_detectNavbar(){return null!==this._element.closest(".navbar")}_getOffset(){const{offset:e}=this._config;return"string"==typeof e?e.split(",").map((e=>Number.parseInt(e,10))):"function"==typeof e?t=>e(t,this._element):e}_getPopperConfig(){const e={placement:this._getPlacement(),modifiers:[{name:"preventOverflow",options:{boundary:this._config.boundary}},{name:"offset",options:{offset:this._getOffset()}}]};return(this._inNavbar||"static"===this._config.display)&&(Manipulator.setDataAttribute(this._menu,"popper","static"),e.modifiers=[{name:"applyStyles",enabled:!1}]),{...e,...execute(this._config.popperConfig,[e])}}_selectMenuItem({key:e,target:t}){const s=SelectorEngine.find(SELECTOR_VISIBLE_ITEMS,this._menu).filter((e=>isVisible(e)));s.length&&getNextActiveElement(s,t,e===ARROW_DOWN_KEY$1,!s.includes(t)).focus()}static jQueryInterface(e){return this.each((function(){const t=Dropdown.getOrCreateInstance(this,e);if("string"==typeof e){if(void 0===t[e])throw new TypeError(`No method named "${e}"`);t[e]()}}))}static clearMenus(e){if(2===e.button||"keyup"===e.type&&"Tab"!==e.key)return;const t=SelectorEngine.find(SELECTOR_DATA_TOGGLE_SHOWN);for(const s of t){const t=Dropdown.getInstance(s);if(!t||!1===t._config.autoClose)continue;const i=e.composedPath(),n=i.includes(t._menu);if(i.includes(t._element)||"inside"===t._config.autoClose&&!n||"outside"===t._config.autoClose&&n)continue;if(t._menu.contains(e.target)&&("keyup"===e.type&&"Tab"===e.key||/input|select|option|textarea|form/i.test(e.target.tagName)))continue;const r={relatedTarget:t._element};"click"===e.type&&(r.clickEvent=e),t._completeHide(r)}}static dataApiKeydownHandler(e){const t=/input|textarea/i.test(e.target.tagName),s="Escape"===e.key,i=[ARROW_UP_KEY$1,ARROW_DOWN_KEY$1].includes(e.key);if(!i&&!s)return;if(t&&!s)return;e.preventDefault();const n=this.matches(SELECTOR_DATA_TOGGLE$3)?this:SelectorEngine.prev(this,SELECTOR_DATA_TOGGLE$3)[0]||SelectorEngine.next(this,SELECTOR_DATA_TOGGLE$3)[0]||SelectorEngine.findOne(SELECTOR_DATA_TOGGLE$3,e.delegateTarget.parentNode),r=Dropdown.getOrCreateInstance(n);if(i)return e.stopPropagation(),r.show(),void r._selectMenuItem(e);r._isShown()&&(e.stopPropagation(),r.hide(),n.focus())}}EventHandler.on(document,EVENT_KEYDOWN_DATA_API,SELECTOR_DATA_TOGGLE$3,Dropdown.dataApiKeydownHandler),EventHandler.on(document,EVENT_KEYDOWN_DATA_API,SELECTOR_MENU,Dropdown.dataApiKeydownHandler),EventHandler.on(document,EVENT_CLICK_DATA_API$3,Dropdown.clearMenus),EventHandler.on(document,EVENT_KEYUP_DATA_API,Dropdown.clearMenus),EventHandler.on(document,EVENT_CLICK_DATA_API$3,SELECTOR_DATA_TOGGLE$3,(function(e){e.preventDefault(),Dropdown.getOrCreateInstance(this).toggle()})),defineJQueryPlugin(Dropdown);const NAME$9="backdrop",CLASS_NAME_FADE$4="fade",CLASS_NAME_SHOW$5="show",EVENT_MOUSEDOWN=`mousedown.bs.${NAME$9}`,Default$8={className:"modal-backdrop",clickCallback:null,isAnimated:!1,isVisible:!0,rootElement:"body"},DefaultType$8={className:"string",clickCallback:"(function|null)",isAnimated:"boolean",isVisible:"boolean",rootElement:"(element|string)"};class Backdrop extends Config{constructor(e){super(),this._config=this._getConfig(e),this._isAppended=!1,this._element=null}static get Default(){return Default$8}static get DefaultType(){return DefaultType$8}static get NAME(){return NAME$9}show(e){if(!this._config.isVisible)return void execute(e);this._append();const t=this._getElement();this._config.isAnimated&&reflow(t),t.classList.add("show"),this._emulateAnimation((()=>{execute(e)}))}hide(e){this._config.isVisible?(this._getElement().classList.remove("show"),this._emulateAnimation((()=>{this.dispose(),execute(e)}))):execute(e)}dispose(){this._isAppended&&(EventHandler.off(this._element,EVENT_MOUSEDOWN),this._element.remove(),this._isAppended=!1)}_getElement(){if(!this._element){const e=document.createElement("div");e.className=this._config.className,this._config.isAnimated&&e.classList.add("fade"),this._element=e}return this._element}_configAfterMerge(e){return e.rootElement=getElement(e.rootElement),e}_append(){if(this._isAppended)return;const e=this._getElement();this._config.rootElement.append(e),EventHandler.on(e,EVENT_MOUSEDOWN,(()=>{execute(this._config.clickCallback)})),this._isAppended=!0}_emulateAnimation(e){executeAfterTransition(e,this._getElement(),this._config.isAnimated)}}const NAME$8="focustrap",DATA_KEY$5="bs.focustrap",EVENT_KEY$5=`.${DATA_KEY$5}`,EVENT_FOCUSIN$2=`focusin${EVENT_KEY$5}`,EVENT_KEYDOWN_TAB=`keydown.tab${EVENT_KEY$5}`,TAB_KEY="Tab",TAB_NAV_FORWARD="forward",TAB_NAV_BACKWARD="backward",Default$7={autofocus:!0,trapElement:null},DefaultType$7={autofocus:"boolean",trapElement:"element"};class FocusTrap extends Config{constructor(e){super(),this._config=this._getConfig(e),this._isActive=!1,this._lastTabNavDirection=null}static get Default(){return Default$7}static get DefaultType(){return DefaultType$7}static get NAME(){return NAME$8}activate(){this._isActive||(this._config.autofocus&&this._config.trapElement.focus(),EventHandler.off(document,EVENT_KEY$5),EventHandler.on(document,EVENT_FOCUSIN$2,(e=>this._handleFocusin(e))),EventHandler.on(document,EVENT_KEYDOWN_TAB,(e=>this._handleKeydown(e))),this._isActive=!0)}deactivate(){this._isActive&&(this._isActive=!1,EventHandler.off(document,EVENT_KEY$5))}_handleFocusin(e){const{trapElement:t}=this._config;if(e.target===document||e.target===t||t.contains(e.target))return;const s=SelectorEngine.focusableChildren(t);0===s.length?t.focus():"backward"===this._lastTabNavDirection?s[s.length-1].focus():s[0].focus()}_handleKeydown(e){"Tab"===e.key&&(this._lastTabNavDirection=e.shiftKey?"backward":"forward")}}const SELECTOR_FIXED_CONTENT=".fixed-top, .fixed-bottom, .is-fixed, .sticky-top",SELECTOR_STICKY_CONTENT=".sticky-top",PROPERTY_PADDING="padding-right",PROPERTY_MARGIN="margin-right";class ScrollBarHelper{constructor(){this._element=document.body}getWidth(){const e=document.documentElement.clientWidth;return Math.abs(window.innerWidth-e)}hide(){const e=this.getWidth();this._disableOverFlow(),this._setElementAttributes(this._element,"padding-right",(t=>t+e)),this._setElementAttributes(SELECTOR_FIXED_CONTENT,"padding-right",(t=>t+e)),this._setElementAttributes(".sticky-top","margin-right",(t=>t-e))}reset(){this._resetElementAttributes(this._element,"overflow"),this._resetElementAttributes(this._element,"padding-right"),this._resetElementAttributes(SELECTOR_FIXED_CONTENT,"padding-right"),this._resetElementAttributes(".sticky-top","margin-right")}isOverflowing(){return this.getWidth()>0}_disableOverFlow(){this._saveInitialAttribute(this._element,"overflow"),this._element.style.overflow="hidden"}_setElementAttributes(e,t,s){const i=this.getWidth();this._applyManipulationCallback(e,(e=>{if(e!==this._element&&window.innerWidth>e.clientWidth+i)return;this._saveInitialAttribute(e,t);const n=window.getComputedStyle(e).getPropertyValue(t);e.style.setProperty(t,`${s(Number.parseFloat(n))}px`)}))}_saveInitialAttribute(e,t){const s=e.style.getPropertyValue(t);s&&Manipulator.setDataAttribute(e,t,s)}_resetElementAttributes(e,t){this._applyManipulationCallback(e,(e=>{const s=Manipulator.getDataAttribute(e,t);null!==s?(Manipulator.removeDataAttribute(e,t),e.style.setProperty(t,s)):e.style.removeProperty(t)}))}_applyManipulationCallback(e,t){if(isElement(e))t(e);else for(const s of SelectorEngine.find(e,this._element))t(s)}}const NAME$7="modal",DATA_KEY$4="bs.modal",EVENT_KEY$4=".bs.modal",DATA_API_KEY$2=".data-api",ESCAPE_KEY$1="Escape",EVENT_HIDE$4="hide.bs.modal",EVENT_HIDE_PREVENTED$1="hidePrevented.bs.modal",EVENT_HIDDEN$4="hidden.bs.modal",EVENT_SHOW$4="show.bs.modal",EVENT_SHOWN$4="shown.bs.modal",EVENT_RESIZE$1="resize.bs.modal",EVENT_CLICK_DISMISS="click.dismiss.bs.modal",EVENT_MOUSEDOWN_DISMISS="mousedown.dismiss.bs.modal",EVENT_KEYDOWN_DISMISS$1="keydown.dismiss.bs.modal",EVENT_CLICK_DATA_API$2="click.bs.modal.data-api",CLASS_NAME_OPEN="modal-open",CLASS_NAME_FADE$3="fade",CLASS_NAME_SHOW$4="show",CLASS_NAME_STATIC="modal-static",OPEN_SELECTOR$1=".modal.show",SELECTOR_DIALOG=".modal-dialog",SELECTOR_MODAL_BODY=".modal-body",SELECTOR_DATA_TOGGLE$2='[data-bs-toggle="modal"]',Default$6={backdrop:!0,focus:!0,keyboard:!0},DefaultType$6={backdrop:"(boolean|string)",focus:"boolean",keyboard:"boolean"};class Modal extends BaseComponent{constructor(e,t){super(e,t),this._dialog=SelectorEngine.findOne(".modal-dialog",this._element),this._backdrop=this._initializeBackDrop(),this._focustrap=this._initializeFocusTrap(),this._isShown=!1,this._isTransitioning=!1,this._scrollBar=new ScrollBarHelper,this._addEventListeners()}static get Default(){return Default$6}static get DefaultType(){return DefaultType$6}static get NAME(){return NAME$7}toggle(e){return this._isShown?this.hide():this.show(e)}show(e){if(this._isShown||this._isTransitioning)return;EventHandler.trigger(this._element,EVENT_SHOW$4,{relatedTarget:e}).defaultPrevented||(this._isShown=!0,this._isTransitioning=!0,this._scrollBar.hide(),document.body.classList.add("modal-open"),this._adjustDialog(),this._backdrop.show((()=>this._showElement(e))))}hide(){if(!this._isShown||this._isTransitioning)return;EventHandler.trigger(this._element,EVENT_HIDE$4).defaultPrevented||(this._isShown=!1,this._isTransitioning=!0,this._focustrap.deactivate(),this._element.classList.remove("show"),this._queueCallback((()=>this._hideModal()),this._element,this._isAnimated()))}dispose(){EventHandler.off(window,".bs.modal"),EventHandler.off(this._dialog,".bs.modal"),this._backdrop.dispose(),this._focustrap.deactivate(),super.dispose()}handleUpdate(){this._adjustDialog()}_initializeBackDrop(){return new Backdrop({isVisible:Boolean(this._config.backdrop),isAnimated:this._isAnimated()})}_initializeFocusTrap(){return new FocusTrap({trapElement:this._element})}_showElement(e){document.body.contains(this._element)||document.body.append(this._element),this._element.style.display="block",this._element.removeAttribute("aria-hidden"),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.scrollTop=0;const t=SelectorEngine.findOne(".modal-body",this._dialog);t&&(t.scrollTop=0),reflow(this._element),this._element.classList.add("show");this._queueCallback((()=>{this._config.focus&&this._focustrap.activate(),this._isTransitioning=!1,EventHandler.trigger(this._element,EVENT_SHOWN$4,{relatedTarget:e})}),this._dialog,this._isAnimated())}_addEventListeners(){EventHandler.on(this._element,EVENT_KEYDOWN_DISMISS$1,(e=>{"Escape"===e.key&&(this._config.keyboard?this.hide():this._triggerBackdropTransition())})),EventHandler.on(window,EVENT_RESIZE$1,(()=>{this._isShown&&!this._isTransitioning&&this._adjustDialog()})),EventHandler.on(this._element,EVENT_MOUSEDOWN_DISMISS,(e=>{EventHandler.one(this._element,EVENT_CLICK_DISMISS,(t=>{this._element===e.target&&this._element===t.target&&("static"!==this._config.backdrop?this._config.backdrop&&this.hide():this._triggerBackdropTransition())}))}))}_hideModal(){this._element.style.display="none",this._element.setAttribute("aria-hidden",!0),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._isTransitioning=!1,this._backdrop.hide((()=>{document.body.classList.remove("modal-open"),this._resetAdjustments(),this._scrollBar.reset(),EventHandler.trigger(this._element,EVENT_HIDDEN$4)}))}_isAnimated(){return this._element.classList.contains("fade")}_triggerBackdropTransition(){if(EventHandler.trigger(this._element,EVENT_HIDE_PREVENTED$1).defaultPrevented)return;const e=this._element.scrollHeight>document.documentElement.clientHeight,t=this._element.style.overflowY;"hidden"===t||this._element.classList.contains("modal-static")||(e||(this._element.style.overflowY="hidden"),this._element.classList.add("modal-static"),this._queueCallback((()=>{this._element.classList.remove("modal-static"),this._queueCallback((()=>{this._element.style.overflowY=t}),this._dialog)}),this._dialog),this._element.focus())}_adjustDialog(){const e=this._element.scrollHeight>document.documentElement.clientHeight,t=this._scrollBar.getWidth(),s=t>0;if(s&&!e){const e=isRTL()?"paddingLeft":"paddingRight";this._element.style[e]=`${t}px`}if(!s&&e){const e=isRTL()?"paddingRight":"paddingLeft";this._element.style[e]=`${t}px`}}_resetAdjustments(){this._element.style.paddingLeft="",this._element.style.paddingRight=""}static jQueryInterface(e,t){return this.each((function(){const s=Modal.getOrCreateInstance(this,e);if("string"==typeof e){if(void 0===s[e])throw new TypeError(`No method named "${e}"`);s[e](t)}}))}}EventHandler.on(document,EVENT_CLICK_DATA_API$2,SELECTOR_DATA_TOGGLE$2,(function(e){const t=SelectorEngine.getElementFromSelector(this);["A","AREA"].includes(this.tagName)&&e.preventDefault(),EventHandler.one(t,EVENT_SHOW$4,(e=>{e.defaultPrevented||EventHandler.one(t,EVENT_HIDDEN$4,(()=>{isVisible(this)&&this.focus()}))}));const s=SelectorEngine.findOne(".modal.show");s&&Modal.getInstance(s).hide();Modal.getOrCreateInstance(t).toggle(this)})),enableDismissTrigger(Modal),defineJQueryPlugin(Modal);const NAME$6="offcanvas",DATA_KEY$3="bs.offcanvas",EVENT_KEY$3=`.${DATA_KEY$3}`,DATA_API_KEY$1=".data-api",EVENT_LOAD_DATA_API$2=`load${EVENT_KEY$3}.data-api`,ESCAPE_KEY="Escape",CLASS_NAME_SHOW$3="show",CLASS_NAME_SHOWING$1="showing",CLASS_NAME_HIDING="hiding",CLASS_NAME_BACKDROP="offcanvas-backdrop",OPEN_SELECTOR=".offcanvas.show",EVENT_SHOW$3=`show${EVENT_KEY$3}`,EVENT_SHOWN$3=`shown${EVENT_KEY$3}`,EVENT_HIDE$3=`hide${EVENT_KEY$3}`,EVENT_HIDE_PREVENTED=`hidePrevented${EVENT_KEY$3}`,EVENT_HIDDEN$3=`hidden${EVENT_KEY$3}`,EVENT_RESIZE=`resize${EVENT_KEY$3}`,EVENT_CLICK_DATA_API$1=`click${EVENT_KEY$3}.data-api`,EVENT_KEYDOWN_DISMISS=`keydown.dismiss${EVENT_KEY$3}`,SELECTOR_DATA_TOGGLE$1='[data-bs-toggle="offcanvas"]',Default$5={backdrop:!0,keyboard:!0,scroll:!1},DefaultType$5={backdrop:"(boolean|string)",keyboard:"boolean",scroll:"boolean"};class Offcanvas extends BaseComponent{constructor(e,t){super(e,t),this._isShown=!1,this._backdrop=this._initializeBackDrop(),this._focustrap=this._initializeFocusTrap(),this._addEventListeners()}static get Default(){return Default$5}static get DefaultType(){return DefaultType$5}static get NAME(){return NAME$6}toggle(e){return this._isShown?this.hide():this.show(e)}show(e){if(this._isShown)return;if(EventHandler.trigger(this._element,EVENT_SHOW$3,{relatedTarget:e}).defaultPrevented)return;this._isShown=!0,this._backdrop.show(),this._config.scroll||(new ScrollBarHelper).hide(),this._element.setAttribute("aria-modal",!0),this._element.setAttribute("role","dialog"),this._element.classList.add("showing");this._queueCallback((()=>{this._config.scroll&&!this._config.backdrop||this._focustrap.activate(),this._element.classList.add("show"),this._element.classList.remove("showing"),EventHandler.trigger(this._element,EVENT_SHOWN$3,{relatedTarget:e})}),this._element,!0)}hide(){if(!this._isShown)return;if(EventHandler.trigger(this._element,EVENT_HIDE$3).defaultPrevented)return;this._focustrap.deactivate(),this._element.blur(),this._isShown=!1,this._element.classList.add("hiding"),this._backdrop.hide();this._queueCallback((()=>{this._element.classList.remove("show","hiding"),this._element.removeAttribute("aria-modal"),this._element.removeAttribute("role"),this._config.scroll||(new ScrollBarHelper).reset(),EventHandler.trigger(this._element,EVENT_HIDDEN$3)}),this._element,!0)}dispose(){this._backdrop.dispose(),this._focustrap.deactivate(),super.dispose()}_initializeBackDrop(){const e=Boolean(this._config.backdrop);return new Backdrop({className:CLASS_NAME_BACKDROP,isVisible:e,isAnimated:!0,rootElement:this._element.parentNode,clickCallback:e?()=>{"static"!==this._config.backdrop?this.hide():EventHandler.trigger(this._element,EVENT_HIDE_PREVENTED)}:null})}_initializeFocusTrap(){return new FocusTrap({trapElement:this._element})}_addEventListeners(){EventHandler.on(this._element,EVENT_KEYDOWN_DISMISS,(e=>{"Escape"===e.key&&(this._config.keyboard?this.hide():EventHandler.trigger(this._element,EVENT_HIDE_PREVENTED))}))}static jQueryInterface(e){return this.each((function(){const t=Offcanvas.getOrCreateInstance(this,e);if("string"==typeof e){if(void 0===t[e]||e.startsWith("_")||"constructor"===e)throw new TypeError(`No method named "${e}"`);t[e](this)}}))}}EventHandler.on(document,EVENT_CLICK_DATA_API$1,SELECTOR_DATA_TOGGLE$1,(function(e){const t=SelectorEngine.getElementFromSelector(this);if(["A","AREA"].includes(this.tagName)&&e.preventDefault(),isDisabled(this))return;EventHandler.one(t,EVENT_HIDDEN$3,(()=>{isVisible(this)&&this.focus()}));const s=SelectorEngine.findOne(OPEN_SELECTOR);s&&s!==t&&Offcanvas.getInstance(s).hide();Offcanvas.getOrCreateInstance(t).toggle(this)})),EventHandler.on(window,EVENT_LOAD_DATA_API$2,(()=>{for(const e of SelectorEngine.find(OPEN_SELECTOR))Offcanvas.getOrCreateInstance(e).show()})),EventHandler.on(window,EVENT_RESIZE,(()=>{for(const e of SelectorEngine.find("[aria-modal][class*=show][class*=offcanvas-]"))"fixed"!==getComputedStyle(e).position&&Offcanvas.getOrCreateInstance(e).hide()})),enableDismissTrigger(Offcanvas),defineJQueryPlugin(Offcanvas);const ARIA_ATTRIBUTE_PATTERN=/^aria-[\w-]*$/i,DefaultAllowlist={"*":["class","dir","id","lang","role",ARIA_ATTRIBUTE_PATTERN],a:["target","href","title","rel"],area:[],b:[],br:[],col:[],code:[],div:[],em:[],hr:[],h1:[],h2:[],h3:[],h4:[],h5:[],h6:[],i:[],img:["src","srcset","alt","title","width","height"],li:[],ol:[],p:[],pre:[],s:[],small:[],span:[],sub:[],sup:[],strong:[],u:[],ul:[]},uriAttributes=new Set(["background","cite","href","itemtype","longdesc","poster","src","xlink:href"]),SAFE_URL_PATTERN=/^(?!javascript:)(?:[a-z0-9+.-]+:|[^&:/?#]*(?:[/?#]|$))/i,allowedAttribute=(e,t)=>{const s=e.nodeName.toLowerCase();return t.includes(s)?!uriAttributes.has(s)||Boolean(SAFE_URL_PATTERN.test(e.nodeValue)):t.filter((e=>e instanceof RegExp)).some((e=>e.test(s)))};function sanitizeHtml(e,t,s){if(!e.length)return e;if(s&&"function"==typeof s)return s(e);const i=(new window.DOMParser).parseFromString(e,"text/html"),n=[].concat(...i.body.querySelectorAll("*"));for(const e of n){const s=e.nodeName.toLowerCase();if(!Object.keys(t).includes(s)){e.remove();continue}const i=[].concat(...e.attributes),n=[].concat(t["*"]||[],t[s]||[]);for(const t of i)allowedAttribute(t,n)||e.removeAttribute(t.nodeName)}return i.body.innerHTML}const NAME$5="TemplateFactory",Default$4={allowList:DefaultAllowlist,content:{},extraClass:"",html:!1,sanitize:!0,sanitizeFn:null,template:"
"},DefaultType$4={allowList:"object",content:"object",extraClass:"(string|function)",html:"boolean",sanitize:"boolean",sanitizeFn:"(null|function)",template:"string"},DefaultContentType={entry:"(string|element|function|null)",selector:"(string|element)"};class TemplateFactory extends Config{constructor(e){super(),this._config=this._getConfig(e)}static get Default(){return Default$4}static get DefaultType(){return DefaultType$4}static get NAME(){return NAME$5}getContent(){return Object.values(this._config.content).map((e=>this._resolvePossibleFunction(e))).filter(Boolean)}hasContent(){return this.getContent().length>0}changeContent(e){return this._checkContent(e),this._config.content={...this._config.content,...e},this}toHtml(){const e=document.createElement("div");e.innerHTML=this._maybeSanitize(this._config.template);for(const[t,s]of Object.entries(this._config.content))this._setContent(e,s,t);const t=e.children[0],s=this._resolvePossibleFunction(this._config.extraClass);return s&&t.classList.add(...s.split(" ")),t}_typeCheckConfig(e){super._typeCheckConfig(e),this._checkContent(e.content)}_checkContent(e){for(const[t,s]of Object.entries(e))super._typeCheckConfig({selector:t,entry:s},DefaultContentType)}_setContent(e,t,s){const i=SelectorEngine.findOne(s,e);i&&((t=this._resolvePossibleFunction(t))?isElement(t)?this._putElementInTemplate(getElement(t),i):this._config.html?i.innerHTML=this._maybeSanitize(t):i.textContent=t:i.remove())}_maybeSanitize(e){return this._config.sanitize?sanitizeHtml(e,this._config.allowList,this._config.sanitizeFn):e}_resolvePossibleFunction(e){return execute(e,[this])}_putElementInTemplate(e,t){if(this._config.html)return t.innerHTML="",void t.append(e);t.textContent=e.textContent}}const NAME$4="tooltip",DISALLOWED_ATTRIBUTES=new Set(["sanitize","allowList","sanitizeFn"]),CLASS_NAME_FADE$2="fade",CLASS_NAME_MODAL="modal",CLASS_NAME_SHOW$2="show",SELECTOR_TOOLTIP_INNER=".tooltip-inner",SELECTOR_MODAL=".modal",EVENT_MODAL_HIDE="hide.bs.modal",TRIGGER_HOVER="hover",TRIGGER_FOCUS="focus",TRIGGER_CLICK="click",TRIGGER_MANUAL="manual",EVENT_HIDE$2="hide",EVENT_HIDDEN$2="hidden",EVENT_SHOW$2="show",EVENT_SHOWN$2="shown",EVENT_INSERTED="inserted",EVENT_CLICK$1="click",EVENT_FOCUSIN$1="focusin",EVENT_FOCUSOUT$1="focusout",EVENT_MOUSEENTER="mouseenter",EVENT_MOUSELEAVE="mouseleave",AttachmentMap={AUTO:"auto",TOP:"top",RIGHT:isRTL()?"left":"right",BOTTOM:"bottom",LEFT:isRTL()?"right":"left"},Default$3={allowList:DefaultAllowlist,animation:!0,boundary:"clippingParents",container:!1,customClass:"",delay:0,fallbackPlacements:["top","right","bottom","left"],html:!1,offset:[0,6],placement:"top",popperConfig:null,sanitize:!0,sanitizeFn:null,selector:!1,template:'',title:"",trigger:"hover focus"},DefaultType$3={allowList:"object",animation:"boolean",boundary:"(string|element)",container:"(string|element|boolean)",customClass:"(string|function)",delay:"(number|object)",fallbackPlacements:"array",html:"boolean",offset:"(array|string|function)",placement:"(string|function)",popperConfig:"(null|object|function)",sanitize:"boolean",sanitizeFn:"(null|function)",selector:"(string|boolean)",template:"string",title:"(string|element|function)",trigger:"string"};class Tooltip extends BaseComponent{constructor(e,t){if(void 0===Popper)throw new TypeError("Bootstrap's tooltips require Popper (https://popper.js.org)");super(e,t),this._isEnabled=!0,this._timeout=0,this._isHovered=null,this._activeTrigger={},this._popper=null,this._templateFactory=null,this._newContent=null,this.tip=null,this._setListeners(),this._config.selector||this._fixTitle()}static get Default(){return Default$3}static get DefaultType(){return DefaultType$3}static get NAME(){return NAME$4}enable(){this._isEnabled=!0}disable(){this._isEnabled=!1}toggleEnabled(){this._isEnabled=!this._isEnabled}toggle(){this._isEnabled&&(this._activeTrigger.click=!this._activeTrigger.click,this._isShown()?this._leave():this._enter())}dispose(){clearTimeout(this._timeout),EventHandler.off(this._element.closest(".modal"),"hide.bs.modal",this._hideModalHandler),this._element.getAttribute("data-bs-original-title")&&this._element.setAttribute("title",this._element.getAttribute("data-bs-original-title")),this._disposePopper(),super.dispose()}show(){if("none"===this._element.style.display)throw new Error("Please use show on visible elements");if(!this._isWithContent()||!this._isEnabled)return;const e=EventHandler.trigger(this._element,this.constructor.eventName("show")),t=(findShadowRoot(this._element)||this._element.ownerDocument.documentElement).contains(this._element);if(e.defaultPrevented||!t)return;this._disposePopper();const s=this._getTipElement();this._element.setAttribute("aria-describedby",s.getAttribute("id"));const{container:i}=this._config;if(this._element.ownerDocument.documentElement.contains(this.tip)||(i.append(s),EventHandler.trigger(this._element,this.constructor.eventName("inserted"))),this._popper=this._createPopper(s),s.classList.add("show"),"ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))EventHandler.on(e,"mouseover",noop);this._queueCallback((()=>{EventHandler.trigger(this._element,this.constructor.eventName("shown")),!1===this._isHovered&&this._leave(),this._isHovered=!1}),this.tip,this._isAnimated())}hide(){if(!this._isShown())return;if(EventHandler.trigger(this._element,this.constructor.eventName("hide")).defaultPrevented)return;if(this._getTipElement().classList.remove("show"),"ontouchstart"in document.documentElement)for(const e of[].concat(...document.body.children))EventHandler.off(e,"mouseover",noop);this._activeTrigger.click=!1,this._activeTrigger.focus=!1,this._activeTrigger.hover=!1,this._isHovered=null;this._queueCallback((()=>{this._isWithActiveTrigger()||(this._isHovered||this._disposePopper(),this._element.removeAttribute("aria-describedby"),EventHandler.trigger(this._element,this.constructor.eventName("hidden")))}),this.tip,this._isAnimated())}update(){this._popper&&this._popper.update()}_isWithContent(){return Boolean(this._getTitle())}_getTipElement(){return this.tip||(this.tip=this._createTipElement(this._newContent||this._getContentForTemplate())),this.tip}_createTipElement(e){const t=this._getTemplateFactory(e).toHtml();if(!t)return null;t.classList.remove("fade","show"),t.classList.add(`bs-${this.constructor.NAME}-auto`);const s=getUID(this.constructor.NAME).toString();return t.setAttribute("id",s),this._isAnimated()&&t.classList.add("fade"),t}setContent(e){this._newContent=e,this._isShown()&&(this._disposePopper(),this.show())}_getTemplateFactory(e){return this._templateFactory?this._templateFactory.changeContent(e):this._templateFactory=new TemplateFactory({...this._config,content:e,extraClass:this._resolvePossibleFunction(this._config.customClass)}),this._templateFactory}_getContentForTemplate(){return{".tooltip-inner":this._getTitle()}}_getTitle(){return this._resolvePossibleFunction(this._config.title)||this._element.getAttribute("data-bs-original-title")}_initializeOnDelegatedTarget(e){return this.constructor.getOrCreateInstance(e.delegateTarget,this._getDelegateConfig())}_isAnimated(){return this._config.animation||this.tip&&this.tip.classList.contains("fade")}_isShown(){return this.tip&&this.tip.classList.contains("show")}_createPopper(e){const t=execute(this._config.placement,[this,e,this._element]),s=AttachmentMap[t.toUpperCase()];return createPopper(this._element,e,this._getPopperConfig(s))}_getOffset(){const{offset:e}=this._config;return"string"==typeof e?e.split(",").map((e=>Number.parseInt(e,10))):"function"==typeof e?t=>e(t,this._element):e}_resolvePossibleFunction(e){return execute(e,[this._element])}_getPopperConfig(e){const t={placement:e,modifiers:[{name:"flip",options:{fallbackPlacements:this._config.fallbackPlacements}},{name:"offset",options:{offset:this._getOffset()}},{name:"preventOverflow",options:{boundary:this._config.boundary}},{name:"arrow",options:{element:`.${this.constructor.NAME}-arrow`}},{name:"preSetPlacement",enabled:!0,phase:"beforeMain",fn:e=>{this._getTipElement().setAttribute("data-popper-placement",e.state.placement)}}]};return{...t,...execute(this._config.popperConfig,[t])}}_setListeners(){const e=this._config.trigger.split(" ");for(const t of e)if("click"===t)EventHandler.on(this._element,this.constructor.eventName("click"),this._config.selector,(e=>{this._initializeOnDelegatedTarget(e).toggle()}));else if("manual"!==t){const e="hover"===t?this.constructor.eventName("mouseenter"):this.constructor.eventName("focusin"),s="hover"===t?this.constructor.eventName("mouseleave"):this.constructor.eventName("focusout");EventHandler.on(this._element,e,this._config.selector,(e=>{const t=this._initializeOnDelegatedTarget(e);t._activeTrigger["focusin"===e.type?"focus":"hover"]=!0,t._enter()})),EventHandler.on(this._element,s,this._config.selector,(e=>{const t=this._initializeOnDelegatedTarget(e);t._activeTrigger["focusout"===e.type?"focus":"hover"]=t._element.contains(e.relatedTarget),t._leave()}))}this._hideModalHandler=()=>{this._element&&this.hide()},EventHandler.on(this._element.closest(".modal"),"hide.bs.modal",this._hideModalHandler)}_fixTitle(){const e=this._element.getAttribute("title");e&&(this._element.getAttribute("aria-label")||this._element.textContent.trim()||this._element.setAttribute("aria-label",e),this._element.setAttribute("data-bs-original-title",e),this._element.removeAttribute("title"))}_enter(){this._isShown()||this._isHovered?this._isHovered=!0:(this._isHovered=!0,this._setTimeout((()=>{this._isHovered&&this.show()}),this._config.delay.show))}_leave(){this._isWithActiveTrigger()||(this._isHovered=!1,this._setTimeout((()=>{this._isHovered||this.hide()}),this._config.delay.hide))}_setTimeout(e,t){clearTimeout(this._timeout),this._timeout=setTimeout(e,t)}_isWithActiveTrigger(){return Object.values(this._activeTrigger).includes(!0)}_getConfig(e){const t=Manipulator.getDataAttributes(this._element);for(const e of Object.keys(t))DISALLOWED_ATTRIBUTES.has(e)&&delete t[e];return e={...t,..."object"==typeof e&&e?e:{}},e=this._mergeConfigObj(e),e=this._configAfterMerge(e),this._typeCheckConfig(e),e}_configAfterMerge(e){return e.container=!1===e.container?document.body:getElement(e.container),"number"==typeof e.delay&&(e.delay={show:e.delay,hide:e.delay}),"number"==typeof e.title&&(e.title=e.title.toString()),"number"==typeof e.content&&(e.content=e.content.toString()),e}_getDelegateConfig(){const e={};for(const[t,s]of Object.entries(this._config))this.constructor.Default[t]!==s&&(e[t]=s);return e.selector=!1,e.trigger="manual",e}_disposePopper(){this._popper&&(this._popper.destroy(),this._popper=null),this.tip&&(this.tip.remove(),this.tip=null)}static jQueryInterface(e){return this.each((function(){const t=Tooltip.getOrCreateInstance(this,e);if("string"==typeof e){if(void 0===t[e])throw new TypeError(`No method named "${e}"`);t[e]()}}))}}defineJQueryPlugin(Tooltip);const NAME$3="popover",SELECTOR_TITLE=".popover-header",SELECTOR_CONTENT=".popover-body",Default$2={...Tooltip.Default,content:"",offset:[0,8],placement:"right",template:'',trigger:"click"},DefaultType$2={...Tooltip.DefaultType,content:"(null|string|element|function)"};class Popover extends Tooltip{static get Default(){return Default$2}static get DefaultType(){return DefaultType$2}static get NAME(){return NAME$3}_isWithContent(){return this._getTitle()||this._getContent()}_getContentForTemplate(){return{[SELECTOR_TITLE]:this._getTitle(),".popover-body":this._getContent()}}_getContent(){return this._resolvePossibleFunction(this._config.content)}static jQueryInterface(e){return this.each((function(){const t=Popover.getOrCreateInstance(this,e);if("string"==typeof e){if(void 0===t[e])throw new TypeError(`No method named "${e}"`);t[e]()}}))}}defineJQueryPlugin(Popover);const NAME$2="scrollspy",DATA_KEY$2="bs.scrollspy",EVENT_KEY$2=`.${DATA_KEY$2}`,DATA_API_KEY=".data-api",EVENT_ACTIVATE=`activate${EVENT_KEY$2}`,EVENT_CLICK=`click${EVENT_KEY$2}`,EVENT_LOAD_DATA_API$1=`load${EVENT_KEY$2}.data-api`,CLASS_NAME_DROPDOWN_ITEM="dropdown-item",CLASS_NAME_ACTIVE$1="active",SELECTOR_DATA_SPY='[data-bs-spy="scroll"]',SELECTOR_TARGET_LINKS="[href]",SELECTOR_NAV_LIST_GROUP=".nav, .list-group",SELECTOR_NAV_LINKS=".nav-link",SELECTOR_NAV_ITEMS=".nav-item",SELECTOR_LIST_ITEMS=".list-group-item",SELECTOR_LINK_ITEMS=".nav-link, .nav-item > .nav-link, .list-group-item",SELECTOR_DROPDOWN=".dropdown",SELECTOR_DROPDOWN_TOGGLE$1=".dropdown-toggle",Default$1={offset:null,rootMargin:"0px 0px -25%",smoothScroll:!1,target:null,threshold:[.1,.5,1]},DefaultType$1={offset:"(number|null)",rootMargin:"string",smoothScroll:"boolean",target:"element",threshold:"array"};class ScrollSpy extends BaseComponent{constructor(e,t){super(e,t),this._targetLinks=new Map,this._observableSections=new Map,this._rootElement="visible"===getComputedStyle(this._element).overflowY?null:this._element,this._activeTarget=null,this._observer=null,this._previousScrollData={visibleEntryTop:0,parentScrollTop:0},this.refresh()}static get Default(){return Default$1}static get DefaultType(){return DefaultType$1}static get NAME(){return NAME$2}refresh(){this._initializeTargetsAndObservables(),this._maybeEnableSmoothScroll(),this._observer?this._observer.disconnect():this._observer=this._getNewObserver();for(const e of this._observableSections.values())this._observer.observe(e)}dispose(){this._observer.disconnect(),super.dispose()}_configAfterMerge(e){return e.target=getElement(e.target)||document.body,e.rootMargin=e.offset?`${e.offset}px 0px -30%`:e.rootMargin,"string"==typeof e.threshold&&(e.threshold=e.threshold.split(",").map((e=>Number.parseFloat(e)))),e}_maybeEnableSmoothScroll(){this._config.smoothScroll&&(EventHandler.off(this._config.target,EVENT_CLICK),EventHandler.on(this._config.target,EVENT_CLICK,"[href]",(e=>{const t=this._observableSections.get(e.target.hash);if(t){e.preventDefault();const s=this._rootElement||window,i=t.offsetTop-this._element.offsetTop;if(s.scrollTo)return void s.scrollTo({top:i,behavior:"smooth"});s.scrollTop=i}})))}_getNewObserver(){const e={root:this._rootElement,threshold:this._config.threshold,rootMargin:this._config.rootMargin};return new IntersectionObserver((e=>this._observerCallback(e)),e)}_observerCallback(e){const t=e=>this._targetLinks.get(`#${e.target.id}`),s=e=>{this._previousScrollData.visibleEntryTop=e.target.offsetTop,this._process(t(e))},i=(this._rootElement||document.documentElement).scrollTop,n=i>=this._previousScrollData.parentScrollTop;this._previousScrollData.parentScrollTop=i;for(const r of e){if(!r.isIntersecting){this._activeTarget=null,this._clearActiveClass(t(r));continue}const e=r.target.offsetTop>=this._previousScrollData.visibleEntryTop;if(n&&e){if(s(r),!i)return}else n||e||s(r)}}_initializeTargetsAndObservables(){this._targetLinks=new Map,this._observableSections=new Map;const e=SelectorEngine.find("[href]",this._config.target);for(const t of e){if(!t.hash||isDisabled(t))continue;const e=SelectorEngine.findOne(decodeURI(t.hash),this._element);isVisible(e)&&(this._targetLinks.set(decodeURI(t.hash),t),this._observableSections.set(t.hash,e))}}_process(e){this._activeTarget!==e&&(this._clearActiveClass(this._config.target),this._activeTarget=e,e.classList.add("active"),this._activateParents(e),EventHandler.trigger(this._element,EVENT_ACTIVATE,{relatedTarget:e}))}_activateParents(e){if(e.classList.contains("dropdown-item"))SelectorEngine.findOne(".dropdown-toggle",e.closest(".dropdown")).classList.add("active");else for(const t of SelectorEngine.parents(e,".nav, .list-group"))for(const e of SelectorEngine.prev(t,SELECTOR_LINK_ITEMS))e.classList.add("active")}_clearActiveClass(e){e.classList.remove("active");const t=SelectorEngine.find("[href].active",e);for(const e of t)e.classList.remove("active")}static jQueryInterface(e){return this.each((function(){const t=ScrollSpy.getOrCreateInstance(this,e);if("string"==typeof e){if(void 0===t[e]||e.startsWith("_")||"constructor"===e)throw new TypeError(`No method named "${e}"`);t[e]()}}))}}EventHandler.on(window,EVENT_LOAD_DATA_API$1,(()=>{for(const e of SelectorEngine.find(SELECTOR_DATA_SPY))ScrollSpy.getOrCreateInstance(e)})),defineJQueryPlugin(ScrollSpy);const NAME$1="tab",DATA_KEY$1="bs.tab",EVENT_KEY$1=".bs.tab",EVENT_HIDE$1="hide.bs.tab",EVENT_HIDDEN$1="hidden.bs.tab",EVENT_SHOW$1="show.bs.tab",EVENT_SHOWN$1="shown.bs.tab",EVENT_CLICK_DATA_API="click.bs.tab",EVENT_KEYDOWN="keydown.bs.tab",EVENT_LOAD_DATA_API="load.bs.tab",ARROW_LEFT_KEY="ArrowLeft",ARROW_RIGHT_KEY="ArrowRight",ARROW_UP_KEY="ArrowUp",ARROW_DOWN_KEY="ArrowDown",HOME_KEY="Home",END_KEY="End",CLASS_NAME_ACTIVE="active",CLASS_NAME_FADE$1="fade",CLASS_NAME_SHOW$1="show",CLASS_DROPDOWN="dropdown",SELECTOR_DROPDOWN_TOGGLE=".dropdown-toggle",SELECTOR_DROPDOWN_MENU=".dropdown-menu",NOT_SELECTOR_DROPDOWN_TOGGLE=":not(.dropdown-toggle)",SELECTOR_TAB_PANEL='.list-group, .nav, [role="tablist"]',SELECTOR_OUTER=".nav-item, .list-group-item",SELECTOR_INNER='.nav-link:not(.dropdown-toggle), .list-group-item:not(.dropdown-toggle), [role="tab"]:not(.dropdown-toggle)',SELECTOR_DATA_TOGGLE='[data-bs-toggle="tab"], [data-bs-toggle="pill"], [data-bs-toggle="list"]',SELECTOR_INNER_ELEM=`${SELECTOR_INNER}, ${SELECTOR_DATA_TOGGLE}`,SELECTOR_DATA_TOGGLE_ACTIVE='.active[data-bs-toggle="tab"], .active[data-bs-toggle="pill"], .active[data-bs-toggle="list"]';class Tab extends BaseComponent{constructor(e){super(e),this._parent=this._element.closest(SELECTOR_TAB_PANEL),this._parent&&(this._setInitialAttributes(this._parent,this._getChildren()),EventHandler.on(this._element,EVENT_KEYDOWN,(e=>this._keydown(e))))}static get NAME(){return"tab"}show(){const e=this._element;if(this._elemIsActive(e))return;const t=this._getActiveElem(),s=t?EventHandler.trigger(t,EVENT_HIDE$1,{relatedTarget:e}):null;EventHandler.trigger(e,EVENT_SHOW$1,{relatedTarget:t}).defaultPrevented||s&&s.defaultPrevented||(this._deactivate(t,e),this._activate(e,t))}_activate(e,t){if(!e)return;e.classList.add("active"),this._activate(SelectorEngine.getElementFromSelector(e));this._queueCallback((()=>{"tab"===e.getAttribute("role")?(e.removeAttribute("tabindex"),e.setAttribute("aria-selected",!0),this._toggleDropDown(e,!0),EventHandler.trigger(e,EVENT_SHOWN$1,{relatedTarget:t})):e.classList.add("show")}),e,e.classList.contains("fade"))}_deactivate(e,t){if(!e)return;e.classList.remove("active"),e.blur(),this._deactivate(SelectorEngine.getElementFromSelector(e));this._queueCallback((()=>{"tab"===e.getAttribute("role")?(e.setAttribute("aria-selected",!1),e.setAttribute("tabindex","-1"),this._toggleDropDown(e,!1),EventHandler.trigger(e,EVENT_HIDDEN$1,{relatedTarget:t})):e.classList.remove("show")}),e,e.classList.contains("fade"))}_keydown(e){if(![ARROW_LEFT_KEY,ARROW_RIGHT_KEY,ARROW_UP_KEY,ARROW_DOWN_KEY,HOME_KEY,END_KEY].includes(e.key))return;e.stopPropagation(),e.preventDefault();const t=this._getChildren().filter((e=>!isDisabled(e)));let s;if([HOME_KEY,END_KEY].includes(e.key))s=t[e.key===HOME_KEY?0:t.length-1];else{const i=[ARROW_RIGHT_KEY,ARROW_DOWN_KEY].includes(e.key);s=getNextActiveElement(t,e.target,i,!0)}s&&(s.focus({preventScroll:!0}),Tab.getOrCreateInstance(s).show())}_getChildren(){return SelectorEngine.find(SELECTOR_INNER_ELEM,this._parent)}_getActiveElem(){return this._getChildren().find((e=>this._elemIsActive(e)))||null}_setInitialAttributes(e,t){this._setAttributeIfNotExists(e,"role","tablist");for(const e of t)this._setInitialAttributesOnChild(e)}_setInitialAttributesOnChild(e){e=this._getInnerElement(e);const t=this._elemIsActive(e),s=this._getOuterElement(e);e.setAttribute("aria-selected",t),s!==e&&this._setAttributeIfNotExists(s,"role","presentation"),t||e.setAttribute("tabindex","-1"),this._setAttributeIfNotExists(e,"role","tab"),this._setInitialAttributesOnTargetPanel(e)}_setInitialAttributesOnTargetPanel(e){const t=SelectorEngine.getElementFromSelector(e);t&&(this._setAttributeIfNotExists(t,"role","tabpanel"),e.id&&this._setAttributeIfNotExists(t,"aria-labelledby",`${e.id}`))}_toggleDropDown(e,t){const s=this._getOuterElement(e);if(!s.classList.contains("dropdown"))return;const i=(e,i)=>{const n=SelectorEngine.findOne(e,s);n&&n.classList.toggle(i,t)};i(".dropdown-toggle","active"),i(".dropdown-menu","show"),s.setAttribute("aria-expanded",t)}_setAttributeIfNotExists(e,t,s){e.hasAttribute(t)||e.setAttribute(t,s)}_elemIsActive(e){return e.classList.contains("active")}_getInnerElement(e){return e.matches(SELECTOR_INNER_ELEM)?e:SelectorEngine.findOne(SELECTOR_INNER_ELEM,e)}_getOuterElement(e){return e.closest(SELECTOR_OUTER)||e}static jQueryInterface(e){return this.each((function(){const t=Tab.getOrCreateInstance(this);if("string"==typeof e){if(void 0===t[e]||e.startsWith("_")||"constructor"===e)throw new TypeError(`No method named "${e}"`);t[e]()}}))}}EventHandler.on(document,"click.bs.tab",SELECTOR_DATA_TOGGLE,(function(e){["A","AREA"].includes(this.tagName)&&e.preventDefault(),isDisabled(this)||Tab.getOrCreateInstance(this).show()})),EventHandler.on(window,"load.bs.tab",(()=>{for(const e of SelectorEngine.find(SELECTOR_DATA_TOGGLE_ACTIVE))Tab.getOrCreateInstance(e)})),defineJQueryPlugin(Tab);const NAME="toast",DATA_KEY="bs.toast",EVENT_KEY=`.${DATA_KEY}`,EVENT_MOUSEOVER=`mouseover${EVENT_KEY}`,EVENT_MOUSEOUT=`mouseout${EVENT_KEY}`,EVENT_FOCUSIN=`focusin${EVENT_KEY}`,EVENT_FOCUSOUT=`focusout${EVENT_KEY}`,EVENT_HIDE=`hide${EVENT_KEY}`,EVENT_HIDDEN=`hidden${EVENT_KEY}`,EVENT_SHOW=`show${EVENT_KEY}`,EVENT_SHOWN=`shown${EVENT_KEY}`,CLASS_NAME_FADE="fade",CLASS_NAME_HIDE="hide",CLASS_NAME_SHOW="show",CLASS_NAME_SHOWING="showing",DefaultType={animation:"boolean",autohide:"boolean",delay:"number"},Default={animation:!0,autohide:!0,delay:5e3};class Toast extends BaseComponent{constructor(e,t){super(e,t),this._timeout=null,this._hasMouseInteraction=!1,this._hasKeyboardInteraction=!1,this._setListeners()}static get Default(){return Default}static get DefaultType(){return DefaultType}static get NAME(){return NAME}show(){if(EventHandler.trigger(this._element,EVENT_SHOW).defaultPrevented)return;this._clearTimeout(),this._config.animation&&this._element.classList.add("fade");this._element.classList.remove("hide"),reflow(this._element),this._element.classList.add("show","showing"),this._queueCallback((()=>{this._element.classList.remove("showing"),EventHandler.trigger(this._element,EVENT_SHOWN),this._maybeScheduleHide()}),this._element,this._config.animation)}hide(){if(!this.isShown())return;if(EventHandler.trigger(this._element,EVENT_HIDE).defaultPrevented)return;this._element.classList.add("showing"),this._queueCallback((()=>{this._element.classList.add("hide"),this._element.classList.remove("showing","show"),EventHandler.trigger(this._element,EVENT_HIDDEN)}),this._element,this._config.animation)}dispose(){this._clearTimeout(),this.isShown()&&this._element.classList.remove("show"),super.dispose()}isShown(){return this._element.classList.contains("show")}_maybeScheduleHide(){this._config.autohide&&(this._hasMouseInteraction||this._hasKeyboardInteraction||(this._timeout=setTimeout((()=>{this.hide()}),this._config.delay)))}_onInteraction(e,t){switch(e.type){case"mouseover":case"mouseout":this._hasMouseInteraction=t;break;case"focusin":case"focusout":this._hasKeyboardInteraction=t}if(t)return void this._clearTimeout();const s=e.relatedTarget;this._element===s||this._element.contains(s)||this._maybeScheduleHide()}_setListeners(){EventHandler.on(this._element,EVENT_MOUSEOVER,(e=>this._onInteraction(e,!0))),EventHandler.on(this._element,EVENT_MOUSEOUT,(e=>this._onInteraction(e,!1))),EventHandler.on(this._element,EVENT_FOCUSIN,(e=>this._onInteraction(e,!0))),EventHandler.on(this._element,EVENT_FOCUSOUT,(e=>this._onInteraction(e,!1)))}_clearTimeout(){clearTimeout(this._timeout),this._timeout=null}static jQueryInterface(e){return this.each((function(){const t=Toast.getOrCreateInstance(this,e);if("string"==typeof e){if(void 0===t[e])throw new TypeError(`No method named "${e}"`);t[e](this)}}))}}enableDismissTrigger(Toast),defineJQueryPlugin(Toast);var dropdownTriggerList=[].slice.call(document.querySelectorAll('[data-bs-toggle="dropdown"]'));dropdownTriggerList.map((function(e){var t={boundary:"viewport"===e.getAttribute("data-bs-boundary")?document.querySelector(".btn"):"clippingParents"};return new Dropdown(e,t)}));var tooltipTriggerList=[].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'));tooltipTriggerList.map((function(e){var t,s,i={delay:{show:50,hide:50},html:null!==(t="true"===e.getAttribute("data-bs-html"))&&void 0!==t&&t,placement:null!==(s=e.getAttribute("data-bs-placement"))&&void 0!==s?s:"auto"};return new Tooltip(e,i)}));var popoverTriggerList=[].slice.call(document.querySelectorAll('[data-bs-toggle="popover"]'));popoverTriggerList.map((function(e){var t,s,i={delay:{show:50,hide:50},html:null!==(t="true"===e.getAttribute("data-bs-html"))&&void 0!==t&&t,placement:null!==(s=e.getAttribute("data-bs-placement"))&&void 0!==s?s:"auto"};return new Popover(e,i)}));var switchesTriggerList=[].slice.call(document.querySelectorAll('[data-bs-toggle="switch-icon"]'));switchesTriggerList.map((function(e){e.addEventListener("click",(function(t){t.stopPropagation(),e.classList.toggle("active")}))}));var toastsTriggerList=[].slice.call(document.querySelectorAll('[data-bs-toggle="toast"]'));toastsTriggerList.map((function(e){return new Toast(e)})); \ No newline at end of file diff --git a/cp/public/assets/js/tabulator_esm.min.js b/cp/public/assets/js/tabulator_esm.min.js deleted file mode 100644 index b7b7cde..0000000 --- a/cp/public/assets/js/tabulator_esm.min.js +++ /dev/null @@ -1,3 +0,0 @@ -/* Tabulator v5.5.2 (c) Oliver Folkerd 2023 */ -class e{constructor(e){this.table=e}reloadData(e,t,i){return this.table.dataLoader.load(e,void 0,void 0,void 0,t,i)}langText(){return this.table.modules.localize.getText(...arguments)}langBind(){return this.table.modules.localize.bind(...arguments)}langLocale(){return this.table.modules.localize.getLocale(...arguments)}commsConnections(){return this.table.modules.comms.getConnections(...arguments)}commsSend(){return this.table.modules.comms.send(...arguments)}layoutMode(){return this.table.modules.layout.getMode()}layoutRefresh(e){return this.table.modules.layout.layout(e)}subscribe(){return this.table.eventBus.subscribe(...arguments)}unsubscribe(){return this.table.eventBus.unsubscribe(...arguments)}subscribed(e){return this.table.eventBus.subscribed(e)}subscriptionChange(){return this.table.eventBus.subscriptionChange(...arguments)}dispatch(){return this.table.eventBus.dispatch(...arguments)}chain(){return this.table.eventBus.chain(...arguments)}confirm(){return this.table.eventBus.confirm(...arguments)}dispatchExternal(){return this.table.externalEvents.dispatch(...arguments)}subscribedExternal(e){return this.table.externalEvents.subscribed(e)}subscriptionChangeExternal(){return this.table.externalEvents.subscriptionChange(...arguments)}options(e){return this.table.options[e]}setOption(e,t){return void 0!==t&&(this.table.options[e]=t),this.table.options[e]}deprecationCheck(e,t){return this.table.deprecationAdvisor.check(e,t)}deprecationCheckMsg(e,t){return this.table.deprecationAdvisor.checkMsg(e,t)}deprecationMsg(e){return this.table.deprecationAdvisor.msg(e)}module(e){return this.table.module(e)}}class t{static elVisible(e){return!(e.offsetWidth<=0&&e.offsetHeight<=0)}static elOffset(e){var t=e.getBoundingClientRect();return{top:t.top+window.pageYOffset-document.documentElement.clientTop,left:t.left+window.pageXOffset-document.documentElement.clientLeft}}static deepClone(e,t,i=[]){var s={}.__proto__,o=[].__proto__;for(var n in t||(t=Object.assign(Array.isArray(e)?[]:{},e)),e){let r,a,l=e[n];null==l||"object"!=typeof l||l.__proto__!==s&&l.__proto__!==o||(r=i.findIndex((e=>e.subject===l)),r>-1?t[n]=i[r].copy:(a=Object.assign(Array.isArray(l)?[]:{},l),i.unshift({subject:l,copy:a}),t[n]=this.deepClone(l,a,i)))}return t}}class i extends e{constructor(e,t,i){super(e),this.element=t,this.container=this._lookupContainer(),this.parent=i,this.reversedX=!1,this.childPopup=null,this.blurable=!1,this.blurCallback=null,this.blurEventsBound=!1,this.renderedCallback=null,this.visible=!1,this.hideable=!0,this.element.classList.add("tabulator-popup-container"),this.blurEvent=this.hide.bind(this,!1),this.escEvent=this._escapeCheck.bind(this),this.destroyBinding=this.tableDestroyed.bind(this),this.destroyed=!1}tableDestroyed(){this.destroyed=!0,this.hide(!0)}_lookupContainer(){var e=this.table.options.popupContainer;return"string"==typeof e?(e=document.querySelector(e))||console.warn("Menu Error - no container element found matching selector:",this.table.options.popupContainer,"(defaulting to document body)"):!0===e&&(e=this.table.element),e&&!this._checkContainerIsParent(e)&&(e=!1,console.warn("Menu Error - container element does not contain this table:",this.table.options.popupContainer,"(defaulting to document body)")),e||(e=document.body),e}_checkContainerIsParent(e,t=this.table.element){return e===t||!!t.parentNode&&this._checkContainerIsParent(e,t.parentNode)}renderCallback(e){this.renderedCallback=e}containerEventCoords(e){var i=!(e instanceof MouseEvent),s=i?e.touches[0].pageX:e.pageX,o=i?e.touches[0].pageY:e.pageY;if(this.container!==document.body){let e=t.elOffset(this.container);s-=e.left,o-=e.top}return{x:s,y:o}}elementPositionCoords(e,i="right"){var s,o,n,r=t.elOffset(e);switch(this.container!==document.body&&(s=t.elOffset(this.container),r.left-=s.left,r.top-=s.top),i){case"right":o=r.left+e.offsetWidth,n=r.top-1;break;case"bottom":o=r.left,n=r.top+e.offsetHeight;break;case"left":o=r.left,n=r.top-1;break;case"top":o=r.left,n=r.top;break;case"center":o=r.left+e.offsetWidth/2,n=r.top+e.offsetHeight/2}return{x:o,y:n,offset:r}}show(e,t){var i,s,o,n,r;return this.destroyed||this.table.destroyed||(e instanceof HTMLElement?(o=e,n=(r=this.elementPositionCoords(e,t)).offset,i=r.x,s=r.y):"number"==typeof e?(n={top:0,left:0},i=e,s=t):(i=(r=this.containerEventCoords(e)).x,s=r.y,this.reversedX=!1),this.element.style.top=s+"px",this.element.style.left=i+"px",this.container.appendChild(this.element),"function"==typeof this.renderedCallback&&this.renderedCallback(),this._fitToScreen(i,s,o,n,t),this.visible=!0,this.subscribe("table-destroy",this.destroyBinding),this.element.addEventListener("mousedown",(e=>{e.stopPropagation()}))),this}_fitToScreen(e,t,i,s,o){var n=this.container===document.body?document.documentElement.scrollTop:this.container.scrollTop;if((e+this.element.offsetWidth>=this.container.offsetWidth||this.reversedX)&&(this.element.style.left="",this.element.style.right=i?this.container.offsetWidth-s.left+"px":this.container.offsetWidth-e+"px",this.reversedX=!0),t+this.element.offsetHeight>Math.max(this.container.offsetHeight,n?this.container.scrollHeight:0))if(i)if("bottom"===o)this.element.style.top=parseInt(this.element.style.top)-this.element.offsetHeight-i.offsetHeight-1+"px";else this.element.style.top=parseInt(this.element.style.top)-this.element.offsetHeight+i.offsetHeight+1+"px";else this.element.style.top=parseInt(this.element.style.top)-this.element.offsetHeight+"px"}isVisible(){return this.visible}hideOnBlur(e){return this.blurable=!0,this.visible&&(setTimeout((()=>{this.visible&&(this.table.rowManager.element.addEventListener("scroll",this.blurEvent),this.subscribe("cell-editing",this.blurEvent),document.body.addEventListener("click",this.blurEvent),document.body.addEventListener("contextmenu",this.blurEvent),document.body.addEventListener("mousedown",this.blurEvent),window.addEventListener("resize",this.blurEvent),document.body.addEventListener("keydown",this.escEvent),this.blurEventsBound=!0)}),100),this.blurCallback=e),this}_escapeCheck(e){27==e.keyCode&&this.hide()}blockHide(){this.hideable=!1}restoreHide(){this.hideable=!0}hide(e=!1){return this.visible&&this.hideable&&(this.blurable&&this.blurEventsBound&&(document.body.removeEventListener("keydown",this.escEvent),document.body.removeEventListener("click",this.blurEvent),document.body.removeEventListener("contextmenu",this.blurEvent),document.body.removeEventListener("mousedown",this.blurEvent),window.removeEventListener("resize",this.blurEvent),this.table.rowManager.element.removeEventListener("scroll",this.blurEvent),this.unsubscribe("cell-editing",this.blurEvent),this.blurEventsBound=!1),this.childPopup&&this.childPopup.hide(),this.parent&&(this.parent.childPopup=null),this.element.parentNode&&this.element.parentNode.removeChild(this.element),this.visible=!1,this.blurCallback&&!e&&this.blurCallback(),this.unsubscribe("table-destroy",this.destroyBinding)),this}child(e){return this.childPopup&&this.childPopup.hide(),this.childPopup=new i(this.table,e,this),this.childPopup}}class s extends e{constructor(e,t){super(e),this._handler=null}initialize(){}registerTableOption(e,t){this.table.optionsList.register(e,t)}registerColumnOption(e,t){this.table.columnManager.optionsList.register(e,t)}registerTableFunction(e,t){void 0===this.table[e]?this.table[e]=(...i)=>(this.table.initGuard(e),t(...i)):console.warn("Unable to bind table function, name already in use",e)}registerComponentFunction(e,t,i){return this.table.componentFunctionBinder.bind(e,t,i)}registerDataHandler(e,t){this.table.rowManager.registerDataPipelineHandler(e,t),this._handler=e}registerDisplayHandler(e,t){this.table.rowManager.registerDisplayPipelineHandler(e,t),this._handler=e}displayRows(e){var t,i=this.table.rowManager.displayRows.length-1;if(this._handler&&(t=this.table.rowManager.displayPipeline.findIndex((e=>e.handler===this._handler)))>-1&&(i=t),e&&(i+=e),this._handler)return i>-1?this.table.rowManager.getDisplayRows(i):this.activeRows()}activeRows(){return this.table.rowManager.activeRows}refreshData(e,t){t||(t=this._handler),t&&this.table.rowManager.refreshActiveData(t,!1,e)}footerAppend(e){return this.table.footerManager.append(e)}footerPrepend(e){return this.table.footerManager.prepend(e)}footerRemove(e){return this.table.footerManager.remove(e)}popup(e,t){return new i(this.table,e,t)}alert(e,t){return this.table.alertManager.alert(e,t)}clearAlert(){return this.table.alertManager.clear()}}class o extends s{constructor(e){super(e),this.allowedTypes=["","data","download","clipboard","print","htmlOutput"],this.registerColumnOption("accessor"),this.registerColumnOption("accessorParams"),this.registerColumnOption("accessorData"),this.registerColumnOption("accessorDataParams"),this.registerColumnOption("accessorDownload"),this.registerColumnOption("accessorDownloadParams"),this.registerColumnOption("accessorClipboard"),this.registerColumnOption("accessorClipboardParams"),this.registerColumnOption("accessorPrint"),this.registerColumnOption("accessorPrintParams"),this.registerColumnOption("accessorHtmlOutput"),this.registerColumnOption("accessorHtmlOutputParams")}initialize(){this.subscribe("column-layout",this.initializeColumn.bind(this)),this.subscribe("row-data-retrieve",this.transformRow.bind(this))}initializeColumn(e){var t=!1,i={};this.allowedTypes.forEach((s=>{var o,n="accessor"+(s.charAt(0).toUpperCase()+s.slice(1));e.definition[n]&&(o=this.lookupAccessor(e.definition[n]))&&(t=!0,i[n]={accessor:o,params:e.definition[n+"Params"]||{}})})),t&&(e.modules.accessor=i)}lookupAccessor(e){var t=!1;switch(typeof e){case"string":o.accessors[e]?t=o.accessors[e]:console.warn("Accessor Error - No such accessor found, ignoring: ",e);break;case"function":t=e}return t}transformRow(e,i){var s="accessor"+(i.charAt(0).toUpperCase()+i.slice(1)),o=e.getComponent(),n=t.deepClone(e.data||{});return this.table.columnManager.traverse((function(e){var t,r,a,l;e.modules.accessor&&(r=e.modules.accessor[s]||e.modules.accessor.accessor||!1)&&"undefined"!=(t=e.getFieldValue(n))&&(l=e.getComponent(),a="function"==typeof r.params?r.params(t,n,i,l,o):r.params,e.setFieldValue(n,r.accessor(t,n,i,a,l,o)))})),n}}o.moduleName="accessor",o.accessors={};function n(e,t){var i=[];if(t=t||"",Array.isArray(e))e.forEach(((e,s)=>{i=i.concat(n(e,t?t+"["+s+"]":s))}));else if("object"==typeof e)for(var s in e)i=i.concat(n(e[s],t?t+"["+s+"]":s));else i.push({key:t,value:e});return i}function r(e){var t=n(e),i=[];return t.forEach((function(e){i.push(encodeURIComponent(e.key)+"="+encodeURIComponent(e.value))})),i.join("&")}function a(e,t,i){return e&&i&&Object.keys(i).length&&(t.method&&"get"!=t.method.toLowerCase()||(t.method="get",e+=(e.includes("?")?"&":"?")+r(i))),e}function l(e,t){var i=[];if(t=t||"",Array.isArray(e))e.forEach(((e,s)=>{i=i.concat(l(e,t?t+"["+s+"]":s))}));else if("object"==typeof e)for(var s in e)i=i.concat(l(e[s],t?t+"["+s+"]":s));else i.push({key:t,value:e});return i}var h={json:{headers:{"Content-Type":"application/json"},body:function(e,t,i){return JSON.stringify(i)}},form:{headers:{},body:function(e,t,i){var s=l(i),o=new FormData;return s.forEach((function(e){o.append(e.key,e.value)})),o}}};class d extends s{constructor(e){super(e),this.config={},this.url="",this.urlGenerator=!1,this.params=!1,this.loaderPromise=!1,this.registerTableOption("ajaxURL",!1),this.registerTableOption("ajaxURLGenerator",!1),this.registerTableOption("ajaxParams",{}),this.registerTableOption("ajaxConfig","get"),this.registerTableOption("ajaxContentType","form"),this.registerTableOption("ajaxRequestFunc",!1),this.registerTableOption("ajaxRequesting",(function(){})),this.registerTableOption("ajaxResponse",!1),this.contentTypeFormatters=d.contentTypeFormatters}initialize(){this.loaderPromise=this.table.options.ajaxRequestFunc||d.defaultLoaderPromise,this.urlGenerator=this.table.options.ajaxURLGenerator||d.defaultURLGenerator,this.table.options.ajaxURL&&this.setUrl(this.table.options.ajaxURL),this.setDefaultConfig(this.table.options.ajaxConfig),this.registerTableFunction("getAjaxUrl",this.getUrl.bind(this)),this.subscribe("data-loading",this.requestDataCheck.bind(this)),this.subscribe("data-params",this.requestParams.bind(this)),this.subscribe("data-load",this.requestData.bind(this))}requestParams(e,t,i,s){var o=this.table.options.ajaxParams;return o&&("function"==typeof o&&(o=o.call(this.table)),s=Object.assign(s,o)),s}requestDataCheck(e,t,i,s){return!((e||!this.url)&&"string"!=typeof e)}requestData(e,t,i,s,o){var n;return!o&&this.requestDataCheck(e)?(e&&this.setUrl(e),n=this.generateConfig(i),this.sendRequest(this.url,t,n)):o}setDefaultConfig(e={}){this.config=Object.assign({},d.defaultConfig),"string"==typeof e?this.config.method=e:Object.assign(this.config,e)}generateConfig(e={}){var t=Object.assign({},this.config);return"string"==typeof e?t.method=e:Object.assign(t,e),t}setUrl(e){this.url=e}getUrl(){return this.url}sendRequest(e,t,i){return!1!==this.table.options.ajaxRequesting.call(this.table,e,t)?this.loaderPromise(e,i,t).then((i=>(this.table.options.ajaxResponse&&(i=this.table.options.ajaxResponse.call(this.table,e,t,i)),i))):Promise.reject()}}d.moduleName="ajax",d.defaultConfig={method:"GET"},d.defaultURLGenerator=a,d.defaultLoaderPromise=function(e,t,i){var s;return new Promise(((o,n)=>{if(e=this.urlGenerator.call(this.table,e,t,i),"GET"!=t.method.toUpperCase())if(s="object"==typeof this.table.options.ajaxContentType?this.table.options.ajaxContentType:this.contentTypeFormatters[this.table.options.ajaxContentType]){for(var r in s.headers)t.headers||(t.headers={}),void 0===t.headers[r]&&(t.headers[r]=s.headers[r]);t.body=s.body.call(this,e,t,i)}else console.warn("Ajax Error - Invalid ajaxContentType value:",this.table.options.ajaxContentType);e?(void 0===t.headers&&(t.headers={}),void 0===t.headers.Accept&&(t.headers.Accept="application/json"),void 0===t.headers["X-Requested-With"]&&(t.headers["X-Requested-With"]="XMLHttpRequest"),void 0===t.mode&&(t.mode="cors"),"cors"==t.mode?(void 0===t.headers.Origin&&(t.headers.Origin=window.location.origin),void 0===t.credentials&&(t.credentials="same-origin")):void 0===t.credentials&&(t.credentials="include"),fetch(e,t).then((e=>{e.ok?e.json().then((e=>{o(e)})).catch((e=>{n(e),console.warn("Ajax Load Error - Invalid JSON returned",e)})):(console.error("Ajax Load Error - Connection Error: "+e.status,e.statusText),n(e))})).catch((e=>{console.error("Ajax Load Error - Connection Error: ",e),n(e)}))):(console.warn("Ajax Load Error - No URL Set"),o([]))}))},d.contentTypeFormatters=h;class c extends s{constructor(e){super(e),this.mode=!0,this.pasteParser=function(){},this.pasteAction=function(){},this.customSelection=!1,this.rowRange=!1,this.blocked=!0,this.registerTableOption("clipboard",!1),this.registerTableOption("clipboardCopyStyled",!0),this.registerTableOption("clipboardCopyConfig",!1),this.registerTableOption("clipboardCopyFormatter",!1),this.registerTableOption("clipboardCopyRowRange","active"),this.registerTableOption("clipboardPasteParser","table"),this.registerTableOption("clipboardPasteAction","insert"),this.registerColumnOption("clipboard"),this.registerColumnOption("titleClipboard")}initialize(){this.mode=this.table.options.clipboard,this.rowRange=this.table.options.clipboardCopyRowRange,!0!==this.mode&&"copy"!==this.mode||this.table.element.addEventListener("copy",(e=>{var t,i,s;this.blocked||(e.preventDefault(),this.customSelection?(t=this.customSelection,this.table.options.clipboardCopyFormatter&&(t=this.table.options.clipboardCopyFormatter("plain",t))):(s=this.table.modules.export.generateExportList(this.table.options.clipboardCopyConfig,this.table.options.clipboardCopyStyled,this.rowRange,"clipboard"),t=(i=this.table.modules.export.generateHTMLTable(s))?this.generatePlainContent(s):"",this.table.options.clipboardCopyFormatter&&(t=this.table.options.clipboardCopyFormatter("plain",t),i=this.table.options.clipboardCopyFormatter("html",i))),window.clipboardData&&window.clipboardData.setData?window.clipboardData.setData("Text",t):e.clipboardData&&e.clipboardData.setData?(e.clipboardData.setData("text/plain",t),i&&e.clipboardData.setData("text/html",i)):e.originalEvent&&e.originalEvent.clipboardData.setData&&(e.originalEvent.clipboardData.setData("text/plain",t),i&&e.originalEvent.clipboardData.setData("text/html",i)),this.dispatchExternal("clipboardCopied",t,i),this.reset())})),!0!==this.mode&&"paste"!==this.mode||this.table.element.addEventListener("paste",(e=>{this.paste(e)})),this.setPasteParser(this.table.options.clipboardPasteParser),this.setPasteAction(this.table.options.clipboardPasteAction),this.registerTableFunction("copyToClipboard",this.copy.bind(this))}reset(){this.blocked=!0,this.customSelection=!1}generatePlainContent(e){var t=[];return e.forEach((e=>{var i=[];e.columns.forEach((t=>{var s="";if(t)if("group"===e.type&&(t.value=t.component.getKey()),null===t.value)s="";else switch(typeof t.value){case"object":s=JSON.stringify(t.value);break;case"undefined":s="";break;default:s=t.value}i.push(s)})),t.push(i.join("\t"))})),t.join("\n")}copy(e,t){var i,s;this.blocked=!1,this.customSelection=!1,!0!==this.mode&&"copy"!==this.mode||(this.rowRange=e||this.table.options.clipboardCopyRowRange,void 0!==window.getSelection&&void 0!==document.createRange?((e=document.createRange()).selectNodeContents(this.table.element),(i=window.getSelection()).toString()&&t&&(this.customSelection=i.toString()),i.removeAllRanges(),i.addRange(e)):void 0!==document.selection&&void 0!==document.body.createTextRange&&((s=document.body.createTextRange()).moveToElementText(this.table.element),s.select()),document.execCommand("copy"),i&&i.removeAllRanges())}setPasteAction(e){switch(typeof e){case"string":this.pasteAction=c.pasteActions[e],this.pasteAction||console.warn("Clipboard Error - No such paste action found:",e);break;case"function":this.pasteAction=e}}setPasteParser(e){switch(typeof e){case"string":this.pasteParser=c.pasteParsers[e],this.pasteParser||console.warn("Clipboard Error - No such paste parser found:",e);break;case"function":this.pasteParser=e}}paste(e){var t,i,s;this.checkPaseOrigin(e)&&(t=this.getPasteData(e),(i=this.pasteParser.call(this,t))?(e.preventDefault(),this.table.modExists("mutator")&&(i=this.mutateData(i)),s=this.pasteAction.call(this,i),this.dispatchExternal("clipboardPasted",t,i,s)):this.dispatchExternal("clipboardPasteError",t))}mutateData(e){var t=[];return Array.isArray(e)?e.forEach((e=>{t.push(this.table.modules.mutator.transformRow(e,"clipboard"))})):t=e,t}checkPaseOrigin(e){var t=!0;return("DIV"!=e.target.tagName||this.table.modules.edit.currentCell)&&(t=!1),t}getPasteData(e){var t;return window.clipboardData&&window.clipboardData.getData?t=window.clipboardData.getData("Text"):e.clipboardData&&e.clipboardData.getData?t=e.clipboardData.getData("text/plain"):e.originalEvent&&e.originalEvent.clipboardData.getData&&(t=e.originalEvent.clipboardData.getData("text/plain")),t}}c.moduleName="clipboard",c.pasteActions={replace:function(e){return this.table.setData(e)},update:function(e){return this.table.updateOrAddData(e)},insert:function(e){return this.table.addData(e)}},c.pasteParsers={table:function(e){var t=[],i=!0,s=this.table.columnManager.columns,o=[],n=[];return(e=e.split("\n")).forEach((function(e){t.push(e.split("\t"))})),!(!t.length||1===t.length&&t[0].length<2)&&(t[0].forEach((function(e){var t=s.find((function(t){return e&&t.definition.title&&e.trim()&&t.definition.title.trim()===e.trim()}));t?o.push(t):i=!1})),i||(i=!0,o=[],t[0].forEach((function(e){var t=s.find((function(t){return e&&t.field&&e.trim()&&t.field.trim()===e.trim()}));t?o.push(t):i=!1})),i||(o=this.table.columnManager.columnsByIndex)),i&&t.shift(),t.forEach((function(e){var t={};e.forEach((function(e,i){o[i]&&(t[o[i].field]=e)})),n.push(t)})),n)}};class u{constructor(e){return this._row=e,new Proxy(this,{get:function(e,t,i){return void 0!==e[t]?e[t]:e._row.table.componentFunctionBinder.handle("row",e._row,t)}})}getData(e){return this._row.getData(e)}getElement(){return this._row.getElement()}getTable(){return this._row.table}getCells(){var e=[];return this._row.getCells().forEach((function(t){e.push(t.getComponent())})),e}getCell(e){var t=this._row.getCell(e);return!!t&&t.getComponent()}_getSelf(){return this._row}}class p{constructor(e){return this._cell=e,new Proxy(this,{get:function(e,t,i){return void 0!==e[t]?e[t]:e._cell.table.componentFunctionBinder.handle("cell",e._cell,t)}})}getValue(){return this._cell.getValue()}getOldValue(){return this._cell.getOldValue()}getInitialValue(){return this._cell.initialValue}getElement(){return this._cell.getElement()}getRow(){return this._cell.row.getComponent()}getData(e){return this._cell.row.getData(e)}getType(){return"cell"}getField(){return this._cell.column.getField()}getColumn(){return this._cell.column.getComponent()}setValue(e,t){void 0===t&&(t=!0),this._cell.setValue(e,t)}restoreOldValue(){this._cell.setValueActual(this._cell.getOldValue())}restoreInitialValue(){this._cell.setValueActual(this._cell.initialValue)}checkHeight(){this._cell.checkHeight()}getTable(){return this._cell.table}_getSelf(){return this._cell}}class m extends e{constructor(e,t){super(e.table),this.table=e.table,this.column=e,this.row=t,this.element=null,this.value=null,this.initialValue,this.oldValue=null,this.modules={},this.height=null,this.width=null,this.minWidth=null,this.component=null,this.loaded=!1,this.build()}build(){this.generateElement(),this.setWidth(),this._configureCell(),this.setValueActual(this.column.getFieldValue(this.row.data)),this.initialValue=this.value}generateElement(){this.element=document.createElement("div"),this.element.className="tabulator-cell",this.element.setAttribute("role","gridcell")}_configureCell(){var e=this.element,t=this.column.getField();(e.style.textAlign=this.column.hozAlign,this.column.vertAlign&&(e.style.display="inline-flex",e.style.alignItems={top:"flex-start",bottom:"flex-end",middle:"center"}[this.column.vertAlign]||"",this.column.hozAlign&&(e.style.justifyContent={left:"flex-start",right:"flex-end",center:"center"}[this.column.hozAlign]||"")),t&&e.setAttribute("tabulator-field",t),this.column.definition.cssClass)&&this.column.definition.cssClass.split(" ").forEach((t=>{e.classList.add(t)}));this.dispatch("cell-init",this),this.column.visible||this.hide()}_generateContents(){var e;switch(typeof(e=this.chain("cell-format",this,null,(()=>this.element.innerHTML=this.value)))){case"object":if(e instanceof Node){for(;this.element.firstChild;)this.element.removeChild(this.element.firstChild);this.element.appendChild(e)}else this.element.innerHTML="",null!=e&&console.warn("Format Error - Formatter has returned a type of object, the only valid formatter object return is an instance of Node, the formatter returned:",e);break;case"undefined":this.element.innerHTML="";break;default:this.element.innerHTML=e}}cellRendered(){this.dispatch("cell-rendered",this)}getElement(e){return this.loaded||(this.loaded=!0,e||this.layoutElement()),this.element}getValue(){return this.value}getOldValue(){return this.oldValue}setValue(e,t,i){this.setValueProcessData(e,t,i)&&(this.dispatch("cell-value-updated",this),this.cellRendered(),this.column.definition.cellEdited&&this.column.definition.cellEdited.call(this.table,this.getComponent()),this.dispatchExternal("cellEdited",this.getComponent()),this.subscribedExternal("dataChanged")&&this.dispatchExternal("dataChanged",this.table.rowManager.getData()))}setValueProcessData(e,t,i){var s=!1;return(this.value!==e||i)&&(s=!0,t&&(e=this.chain("cell-value-changing",[this,e],null,e))),this.setValueActual(e),s&&this.dispatch("cell-value-changed",this),s}setValueActual(e){this.oldValue=this.value,this.value=e,this.dispatch("cell-value-save-before",this),this.column.setFieldValue(this.row.data,e),this.dispatch("cell-value-save-after",this),this.loaded&&this.layoutElement()}layoutElement(){this._generateContents(),this.dispatch("cell-layout",this)}setWidth(){this.width=this.column.width,this.element.style.width=this.column.widthStyled}clearWidth(){this.width="",this.element.style.width=""}getWidth(){return this.width||this.element.offsetWidth}setMinWidth(){this.minWidth=this.column.minWidth,this.element.style.minWidth=this.column.minWidthStyled}setMaxWidth(){this.maxWidth=this.column.maxWidth,this.element.style.maxWidth=this.column.maxWidthStyled}checkHeight(){this.row.reinitializeHeight()}clearHeight(){this.element.style.height="",this.height=null,this.dispatch("cell-height",this,"")}setHeight(){this.height=this.row.height,this.element.style.height=this.row.heightStyled,this.dispatch("cell-height",this,this.row.heightStyled)}getHeight(){return this.height||this.element.offsetHeight}show(){this.element.style.display=this.column.vertAlign?"inline-flex":""}hide(){this.element.style.display="none"}delete(){this.dispatch("cell-delete",this),!this.table.rowManager.redrawBlock&&this.element.parentNode&&this.element.parentNode.removeChild(this.element),this.element=!1,this.column.deleteCell(this),this.row.deleteCell(this),this.calcs={}}getIndex(){return this.row.getCellIndex(this)}getComponent(){return this.component||(this.component=new p(this)),this.component}}class g{constructor(e){return this._column=e,this.type="ColumnComponent",new Proxy(this,{get:function(e,t,i){return void 0!==e[t]?e[t]:e._column.table.componentFunctionBinder.handle("column",e._column,t)}})}getElement(){return this._column.getElement()}getDefinition(){return this._column.getDefinition()}getField(){return this._column.getField()}getTitleDownload(){return this._column.getTitleDownload()}getCells(){var e=[];return this._column.cells.forEach((function(t){e.push(t.getComponent())})),e}isVisible(){return this._column.visible}show(){this._column.isGroup?this._column.columns.forEach((function(e){e.show()})):this._column.show()}hide(){this._column.isGroup?this._column.columns.forEach((function(e){e.hide()})):this._column.hide()}toggle(){this._column.visible?this.hide():this.show()}delete(){return this._column.delete()}getSubColumns(){var e=[];return this._column.columns.length&&this._column.columns.forEach((function(t){e.push(t.getComponent())})),e}getParentColumn(){return this._column.parent instanceof f&&this._column.parent.getComponent()}_getSelf(){return this._column}scrollTo(e,t){return this._column.table.columnManager.scrollToColumn(this._column,e,t)}getTable(){return this._column.table}move(e,t){var i=this._column.table.columnManager.findColumn(e);i?this._column.table.columnManager.moveColumn(this._column,i,t):console.warn("Move Error - No matching column found:",i)}getNextColumn(){var e=this._column.nextColumn();return!!e&&e.getComponent()}getPrevColumn(){var e=this._column.prevColumn();return!!e&&e.getComponent()}updateDefinition(e){return this._column.updateDefinition(e)}getWidth(){return this._column.getWidth()}setWidth(e){var t;return t=!0===e?this._column.reinitializeWidth(!0):this._column.setWidth(e),this._column.table.columnManager.rerenderColumns(!0),t}}var b={title:void 0,field:void 0,columns:void 0,visible:void 0,hozAlign:void 0,vertAlign:void 0,width:void 0,minWidth:40,maxWidth:void 0,maxInitialWidth:void 0,cssClass:void 0,variableHeight:void 0,headerVertical:void 0,headerHozAlign:void 0,headerWordWrap:!1,editableTitle:void 0};class f extends e{constructor(e,t){super(t.table),this.definition=e,this.parent=t,this.type="column",this.columns=[],this.cells=[],this.element=this.createElement(),this.contentElement=!1,this.titleHolderElement=!1,this.titleElement=!1,this.groupElement=this.createGroupElement(),this.isGroup=!1,this.hozAlign="",this.vertAlign="",this.field="",this.fieldStructure="",this.getFieldValue="",this.setFieldValue="",this.titleDownload=null,this.titleFormatterRendered=!1,this.mapDefinitions(),this.setField(this.definition.field),this.modules={},this.width=null,this.widthStyled="",this.maxWidth=null,this.maxWidthStyled="",this.maxInitialWidth=null,this.minWidth=null,this.minWidthStyled="",this.widthFixed=!1,this.visible=!0,this.component=null,this.definition.columns?(this.isGroup=!0,this.definition.columns.forEach(((e,t)=>{var i=new f(e,this);this.attachColumn(i)})),this.checkColumnVisibility()):t.registerColumnField(this),this._initialize()}createElement(){var e=document.createElement("div");switch(e.classList.add("tabulator-col"),e.setAttribute("role","columnheader"),e.setAttribute("aria-sort","none"),this.table.options.columnHeaderVertAlign){case"middle":e.style.justifyContent="center";break;case"bottom":e.style.justifyContent="flex-end"}return e}createGroupElement(){var e=document.createElement("div");return e.classList.add("tabulator-col-group-cols"),e}mapDefinitions(){var e=this.table.options.columnDefaults;if(e)for(let t in e)void 0===this.definition[t]&&(this.definition[t]=e[t]);this.definition=this.table.columnManager.optionsList.generate(f.defaultOptionList,this.definition)}checkDefinition(){Object.keys(this.definition).forEach((e=>{-1===f.defaultOptionList.indexOf(e)&&console.warn("Invalid column definition option in '"+(this.field||this.definition.title)+"' column:",e)}))}setField(e){this.field=e,this.fieldStructure=e?this.table.options.nestedFieldSeparator?e.split(this.table.options.nestedFieldSeparator):[e]:[],this.getFieldValue=this.fieldStructure.length>1?this._getNestedData:this._getFlatData,this.setFieldValue=this.fieldStructure.length>1?this._setNestedData:this._setFlatData}registerColumnPosition(e){this.parent.registerColumnPosition(e)}registerColumnField(e){this.parent.registerColumnField(e)}reRegisterPosition(){this.isGroup?this.columns.forEach((function(e){e.reRegisterPosition()})):this.registerColumnPosition(this)}_initialize(){for(var e=this.definition;this.element.firstChild;)this.element.removeChild(this.element.firstChild);e.headerVertical&&(this.element.classList.add("tabulator-col-vertical"),"flip"===e.headerVertical&&this.element.classList.add("tabulator-col-vertical-flip")),this.contentElement=this._buildColumnHeaderContent(),this.element.appendChild(this.contentElement),this.isGroup?this._buildGroupHeader():this._buildColumnHeader(),this.dispatch("column-init",this)}_buildColumnHeader(){var e=this.definition;(this.dispatch("column-layout",this),void 0!==e.visible&&(e.visible?this.show(!0):this.hide(!0)),e.cssClass)&&e.cssClass.split(" ").forEach((e=>{this.element.classList.add(e)}));e.field&&this.element.setAttribute("tabulator-field",e.field),this.setMinWidth(parseInt(e.minWidth)),e.maxInitialWidth&&(this.maxInitialWidth=parseInt(e.maxInitialWidth)),e.maxWidth&&this.setMaxWidth(parseInt(e.maxWidth)),this.reinitializeWidth(),this.hozAlign=this.definition.hozAlign,this.vertAlign=this.definition.vertAlign,this.titleElement.style.textAlign=this.definition.headerHozAlign}_buildColumnHeaderContent(){var e=document.createElement("div");return e.classList.add("tabulator-col-content"),this.titleHolderElement=document.createElement("div"),this.titleHolderElement.classList.add("tabulator-col-title-holder"),e.appendChild(this.titleHolderElement),this.titleElement=this._buildColumnHeaderTitle(),this.titleHolderElement.appendChild(this.titleElement),e}_buildColumnHeaderTitle(){var e=this.definition,t=document.createElement("div");if(t.classList.add("tabulator-col-title"),e.headerWordWrap&&t.classList.add("tabulator-col-title-wrap"),e.editableTitle){var i=document.createElement("input");i.classList.add("tabulator-title-editor"),i.addEventListener("click",(e=>{e.stopPropagation(),i.focus()})),i.addEventListener("change",(()=>{e.title=i.value,this.dispatchExternal("columnTitleChanged",this.getComponent())})),t.appendChild(i),e.field?this.langBind("columns|"+e.field,(t=>{i.value=t||e.title||" "})):i.value=e.title||" "}else e.field?this.langBind("columns|"+e.field,(i=>{this._formatColumnHeaderTitle(t,i||e.title||" ")})):this._formatColumnHeaderTitle(t,e.title||" ");return t}_formatColumnHeaderTitle(e,t){var i=this.chain("column-format",[this,t,e],null,(()=>t));switch(typeof i){case"object":i instanceof Node?e.appendChild(i):(e.innerHTML="",console.warn("Format Error - Title formatter has returned a type of object, the only valid formatter object return is an instance of Node, the formatter returned:",i));break;case"undefined":e.innerHTML="";break;default:e.innerHTML=i}}_buildGroupHeader(){(this.element.classList.add("tabulator-col-group"),this.element.setAttribute("role","columngroup"),this.element.setAttribute("aria-title",this.definition.title),this.definition.cssClass)&&this.definition.cssClass.split(" ").forEach((e=>{this.element.classList.add(e)}));this.titleElement.style.textAlign=this.definition.headerHozAlign,this.element.appendChild(this.groupElement)}_getFlatData(e){return e[this.field]}_getNestedData(e){var t,i=e,s=this.fieldStructure,o=s.length;for(let e=0;e{t.push(e),t=t.concat(e.getColumns(!0))})):t=this.columns,t}getCells(){return this.cells}getTopColumn(){return this.parent.isGroup?this.parent.getTopColumn():this}getDefinition(e){var t=[];return this.isGroup&&e&&(this.columns.forEach((function(e){t.push(e.getDefinition(!0))})),this.definition.columns=t),this.definition}checkColumnVisibility(){var e=!1;this.columns.forEach((function(t){t.visible&&(e=!0)})),e?(this.show(),this.dispatchExternal("columnVisibilityChanged",this.getComponent(),!1)):this.hide()}show(e,t){this.visible||(this.visible=!0,this.element.style.display="",this.parent.isGroup&&this.parent.checkColumnVisibility(),this.cells.forEach((function(e){e.show()})),this.isGroup||null!==this.width||this.reinitializeWidth(),this.table.columnManager.verticalAlignHeaders(),this.dispatch("column-show",this,t),e||this.dispatchExternal("columnVisibilityChanged",this.getComponent(),!0),this.parent.isGroup&&this.parent.matchChildWidths(),this.silent||this.table.columnManager.rerenderColumns())}hide(e,t){this.visible&&(this.visible=!1,this.element.style.display="none",this.table.columnManager.verticalAlignHeaders(),this.parent.isGroup&&this.parent.checkColumnVisibility(),this.cells.forEach((function(e){e.hide()})),this.dispatch("column-hide",this,t),e||this.dispatchExternal("columnVisibilityChanged",this.getComponent(),!1),this.parent.isGroup&&this.parent.matchChildWidths(),this.silent||this.table.columnManager.rerenderColumns())}matchChildWidths(){var e=0;this.contentElement&&this.columns.length&&(this.columns.forEach((function(t){t.visible&&(e+=t.getWidth())})),this.contentElement.style.maxWidth=e-1+"px",this.parent.isGroup&&this.parent.matchChildWidths())}removeChild(e){var t=this.columns.indexOf(e);t>-1&&this.columns.splice(t,1),this.columns.length||this.delete()}setWidth(e){this.widthFixed=!0,this.setWidthActual(e)}setWidthActual(e){isNaN(e)&&(e=Math.floor(this.table.element.clientWidth/100*parseInt(e))),e=Math.max(this.minWidth,e),this.maxWidth&&(e=Math.min(this.maxWidth,e)),this.width=e,this.widthStyled=e?e+"px":"",this.element.style.width=this.widthStyled,this.isGroup||this.cells.forEach((function(e){e.setWidth()})),this.parent.isGroup&&this.parent.matchChildWidths(),this.dispatch("column-width",this)}checkCellHeights(){var e=[];this.cells.forEach((function(t){t.row.heightInitialized&&(null!==t.row.getElement().offsetParent?(e.push(t.row),t.row.clearCellHeight()):t.row.heightInitialized=!1)})),e.forEach((function(e){e.calcHeight()})),e.forEach((function(e){e.setCellHeight()}))}getWidth(){var e=0;return this.isGroup?this.columns.forEach((function(t){t.visible&&(e+=t.getWidth())})):e=this.width,e}getLeftOffset(){var e=this.element.offsetLeft;return this.parent.isGroup&&(e+=this.parent.getLeftOffset()),e}getHeight(){return Math.ceil(this.element.getBoundingClientRect().height)}setMinWidth(e){this.maxWidth&&e>this.maxWidth&&(e=this.maxWidth,console.warn("the minWidth ("+e+"px) for column '"+this.field+"' cannot be bigger that its maxWidth ("+this.maxWidthStyled+")")),this.minWidth=e,this.minWidthStyled=e?e+"px":"",this.element.style.minWidth=this.minWidthStyled,this.cells.forEach((function(e){e.setMinWidth()}))}setMaxWidth(e){this.minWidth&&e{this.isGroup&&this.columns.forEach((function(e){e.delete()})),this.dispatch("column-delete",this);var i=this.cells.length;for(let e=0;e-1&&this._nextVisibleColumn(e+1)}_nextVisibleColumn(e){var t=this.table.columnManager.getColumnByIndex(e);return!t||t.visible?t:this._nextVisibleColumn(e+1)}prevColumn(){var e=this.table.columnManager.findColumnIndex(this);return e>-1&&this._prevVisibleColumn(e-1)}_prevVisibleColumn(e){var t=this.table.columnManager.getColumnByIndex(e);return!t||t.visible?t:this._prevVisibleColumn(e-1)}reinitializeWidth(e){this.widthFixed=!1,void 0===this.definition.width||e||this.setWidth(this.definition.width),this.dispatch("column-width-fit-before",this),this.fitToData(e),this.dispatch("column-width-fit-after",this)}fitToData(e){if(!this.isGroup){this.widthFixed||(this.element.style.width="",this.cells.forEach((e=>{e.clearWidth()})));var t=this.element.offsetWidth;if((!this.width||!this.widthFixed)&&(this.cells.forEach((e=>{var i=e.getWidth();i>t&&(t=i)})),t)){var i=t+1;this.maxInitialWidth&&!e&&(i=Math.min(i,this.maxInitialWidth)),this.setWidthActual(i)}}}updateDefinition(e){var t;return this.isGroup||this.parent.isGroup?(console.error("Column Update Error - The updateDefinition function is only available on ungrouped columns"),Promise.reject("Column Update Error - The updateDefinition function is only available on columns, not column groups")):(t=Object.assign({},this.getDefinition()),t=Object.assign(t,e),this.table.columnManager.addColumn(t,!1,this).then((e=>(t.field==this.field&&(this.field=!1),this.delete().then((()=>e.getComponent()))))))}deleteCell(e){var t=this.cells.indexOf(e);t>-1&&this.cells.splice(t,1)}getComponent(){return this.component||(this.component=new g(this)),this.component}}f.defaultOptionList=b;class v{constructor(e){return this._row=e,new Proxy(this,{get:function(e,t,i){return void 0!==e[t]?e[t]:e._row.table.componentFunctionBinder.handle("row",e._row,t)}})}getData(e){return this._row.getData(e)}getElement(){return this._row.getElement()}getCells(){var e=[];return this._row.getCells().forEach((function(t){e.push(t.getComponent())})),e}getCell(e){var t=this._row.getCell(e);return!!t&&t.getComponent()}getIndex(){return this._row.getData("data")[this._row.table.options.index]}getPosition(){return this._row.getPosition()}watchPosition(e){return this._row.watchPosition(e)}delete(){return this._row.delete()}scrollTo(e,t){return this._row.table.rowManager.scrollToRow(this._row,e,t)}move(e,t){this._row.moveToRow(e,t)}update(e){return this._row.updateData(e)}normalizeHeight(){this._row.normalizeHeight(!0)}_getSelf(){return this._row}reformat(){return this._row.reinitialize()}getTable(){return this._row.table}getNextRow(){var e=this._row.nextRow();return e?e.getComponent():e}getPrevRow(){var e=this._row.prevRow();return e?e.getComponent():e}}class w extends e{constructor(e,t,i="row"){super(t.table),this.parent=t,this.data={},this.type=i,this.element=!1,this.modules={},this.cells=[],this.height=0,this.heightStyled="",this.manualHeight=!1,this.outerHeight=0,this.initialized=!1,this.heightInitialized=!1,this.position=0,this.positionWatchers=[],this.component=null,this.created=!1,this.setData(e)}create(){this.created||(this.created=!0,this.generateElement())}createElement(){var e=document.createElement("div");e.classList.add("tabulator-row"),e.setAttribute("role","row"),this.element=e}getElement(){return this.create(),this.element}detachElement(){this.element&&this.element.parentNode&&this.element.parentNode.removeChild(this.element)}generateElement(){this.createElement(),this.dispatch("row-init",this)}generateCells(){this.cells=this.table.columnManager.generateCells(this)}initialize(e,t){if(this.create(),!this.initialized||e){for(this.deleteCells();this.element.firstChild;)this.element.removeChild(this.element.firstChild);this.dispatch("row-layout-before",this),this.generateCells(),this.initialized=!0,this.table.columnManager.renderer.renderRowCells(this,t),e&&this.normalizeHeight(),this.dispatch("row-layout",this),this.table.options.rowFormatter&&this.table.options.rowFormatter(this.getComponent()),this.dispatch("row-layout-after",this)}else this.table.columnManager.renderer.rerenderRowCells(this,t)}rendered(){this.cells.forEach((e=>{e.cellRendered()}))}reinitializeHeight(){this.heightInitialized=!1,this.element&&null!==this.element.offsetParent&&this.normalizeHeight(!0)}deinitialize(){this.initialized=!1}deinitializeHeight(){this.heightInitialized=!1}reinitialize(e){this.initialized=!1,this.heightInitialized=!1,this.manualHeight||(this.height=0,this.heightStyled=""),this.element&&null!==this.element.offsetParent&&this.initialize(!0),this.dispatch("row-relayout",this)}calcHeight(e){var t,i=0;this.table.options.rowHeight?this.height=this.table.options.rowHeight:(t=this.table.options.resizableRows?this.element.clientHeight:0,this.cells.forEach((function(e){var t=e.getHeight();t>i&&(i=t)})),this.height=e?Math.max(i,t):this.manualHeight?this.height:Math.max(i,t)),this.heightStyled=this.height?this.height+"px":"",this.outerHeight=this.element.offsetHeight}setCellHeight(){this.cells.forEach((function(e){e.setHeight()})),this.heightInitialized=!0}clearCellHeight(){this.cells.forEach((function(e){e.clearHeight()}))}normalizeHeight(e){e&&!this.table.options.rowHeight&&this.clearCellHeight(),this.calcHeight(e),this.setCellHeight()}setHeight(e,t){(this.height!=e||t)&&(this.manualHeight=!0,this.height=e,this.heightStyled=e?e+"px":"",this.setCellHeight(),this.outerHeight=this.element.offsetHeight)}getHeight(){return this.outerHeight}getWidth(){return this.element.offsetWidth}deleteCell(e){var t=this.cells.indexOf(e);t>-1&&this.cells.splice(t,1)}setData(e){this.data=this.chain("row-data-init-before",[this,e],void 0,e),this.dispatch("row-data-init-after",this)}updateData(e){var i,s=this.element&&t.elVisible(this.element),o={};return new Promise(((t,n)=>{"string"==typeof e&&(e=JSON.parse(e)),this.dispatch("row-data-save-before",this),this.subscribed("row-data-changing")&&(o=Object.assign(o,this.data),o=Object.assign(o,e)),i=this.chain("row-data-changing",[this,o,e],null,e);for(let e in i)this.data[e]=i[e];this.dispatch("row-data-save-after",this);for(let t in e){this.table.columnManager.getColumnsByFieldRoot(t).forEach((e=>{let t=this.getCell(e.getField());if(t){let o=e.getFieldValue(i);t.getValue()!==o&&(t.setValueProcessData(o),s&&t.cellRendered())}}))}s?(this.normalizeHeight(!0),this.table.options.rowFormatter&&this.table.options.rowFormatter(this.getComponent())):(this.initialized=!1,this.height=0,this.heightStyled=""),this.dispatch("row-data-changed",this,s,e),this.dispatchExternal("rowUpdated",this.getComponent()),this.subscribedExternal("dataChanged")&&this.dispatchExternal("dataChanged",this.table.rowManager.getData()),t()}))}getData(e){return e?this.chain("row-data-retrieve",[this,e],null,this.data):this.data}getCell(e){return e=this.table.columnManager.findColumn(e),this.initialized||0!==this.cells.length||this.generateCells(),this.cells.find((function(t){return t.column===e}))}getCellIndex(e){return this.cells.findIndex((function(t){return t===e}))}findCell(e){return this.cells.find((t=>t.element===e))}getCells(){return this.initialized||0!==this.cells.length||this.generateCells(),this.cells}nextRow(){return this.table.rowManager.nextDisplayRow(this,!0)||!1}prevRow(){return this.table.rowManager.prevDisplayRow(this,!0)||!1}moveToRow(e,t){var i=this.table.rowManager.findRow(e);i?(this.table.rowManager.moveRowActual(this,i,!t),this.table.rowManager.refreshActiveData("display",!1,!0)):console.warn("Move Error - No matching row found:",e)}delete(){return this.dispatch("row-delete",this),this.deleteActual(),Promise.resolve()}deleteActual(e){this.detachModules(),this.table.rowManager.deleteRow(this,e),this.deleteCells(),this.initialized=!1,this.heightInitialized=!1,this.element=!1,this.dispatch("row-deleted",this)}detachModules(){this.dispatch("row-deleting",this)}deleteCells(){var e=this.cells.length;for(let t=0;t{e(this.position)})))}watchPosition(e){this.positionWatchers.push(e),e(this.position)}getGroup(){return this.modules.group||!1}getComponent(){return this.component||(this.component=new v(this)),this.component}}var C={avg:function(e,t,i){var s=0,o=void 0!==i.precision?i.precision:2;return e.length&&(s=e.reduce((function(e,t){return Number(e)+Number(t)})),s/=e.length,s=!1!==o?s.toFixed(o):s),parseFloat(s).toString()},max:function(e,t,i){var s=null,o=void 0!==i.precision&&i.precision;return e.forEach((function(e){((e=Number(e))>s||null===s)&&(s=e)})),null!==s?!1!==o?s.toFixed(o):s:""},min:function(e,t,i){var s=null,o=void 0!==i.precision&&i.precision;return e.forEach((function(e){((e=Number(e))(e||0===t)&&e.indexOf(t)===i)).length}};class E extends s{constructor(e){super(e),this.topCalcs=[],this.botCalcs=[],this.genColumn=!1,this.topElement=this.createElement(),this.botElement=this.createElement(),this.topRow=!1,this.botRow=!1,this.topInitialized=!1,this.botInitialized=!1,this.blocked=!1,this.recalcAfterBlock=!1,this.registerTableOption("columnCalcs",!0),this.registerColumnOption("topCalc"),this.registerColumnOption("topCalcParams"),this.registerColumnOption("topCalcFormatter"),this.registerColumnOption("topCalcFormatterParams"),this.registerColumnOption("bottomCalc"),this.registerColumnOption("bottomCalcParams"),this.registerColumnOption("bottomCalcFormatter"),this.registerColumnOption("bottomCalcFormatterParams")}createElement(){var e=document.createElement("div");return e.classList.add("tabulator-calcs-holder"),e}initialize(){this.genColumn=new f({field:"value"},this),this.subscribe("cell-value-changed",this.cellValueChanged.bind(this)),this.subscribe("column-init",this.initializeColumnCheck.bind(this)),this.subscribe("row-deleted",this.rowsUpdated.bind(this)),this.subscribe("scroll-horizontal",this.scrollHorizontal.bind(this)),this.subscribe("row-added",this.rowsUpdated.bind(this)),this.subscribe("column-moved",this.recalcActiveRows.bind(this)),this.subscribe("column-add",this.recalcActiveRows.bind(this)),this.subscribe("data-refreshed",this.recalcActiveRowsRefresh.bind(this)),this.subscribe("table-redraw",this.tableRedraw.bind(this)),this.subscribe("rows-visible",this.visibleRows.bind(this)),this.subscribe("scrollbar-vertical",this.adjustForScrollbar.bind(this)),this.subscribe("redraw-blocked",this.blockRedraw.bind(this)),this.subscribe("redraw-restored",this.restoreRedraw.bind(this)),this.subscribe("table-redrawing",this.resizeHolderWidth.bind(this)),this.subscribe("column-resized",this.resizeHolderWidth.bind(this)),this.subscribe("column-show",this.resizeHolderWidth.bind(this)),this.subscribe("column-hide",this.resizeHolderWidth.bind(this)),this.registerTableFunction("getCalcResults",this.getResults.bind(this)),this.registerTableFunction("recalc",this.userRecalc.bind(this)),this.resizeHolderWidth()}resizeHolderWidth(){this.topElement.style.minWidth=this.table.columnManager.headersElement.offsetWidth+"px"}tableRedraw(e){this.recalc(this.table.rowManager.activeRows),e&&this.redraw()}blockRedraw(){this.blocked=!0,this.recalcAfterBlock=!1}restoreRedraw(){this.blocked=!1,this.recalcAfterBlock&&(this.recalcAfterBlock=!1,this.recalcActiveRowsRefresh())}userRecalc(){this.recalc(this.table.rowManager.activeRows)}blockCheck(){return this.blocked&&(this.recalcAfterBlock=!0),this.blocked}visibleRows(e,t){return this.topRow&&t.unshift(this.topRow),this.botRow&&t.push(this.botRow),t}rowsUpdated(e){this.table.options.groupBy?this.recalcRowGroup(e):this.recalcActiveRows()}recalcActiveRowsRefresh(){this.table.options.groupBy&&this.table.options.dataTreeStartExpanded&&this.table.options.dataTree?this.recalcAll():this.recalcActiveRows()}recalcActiveRows(){this.recalc(this.table.rowManager.activeRows)}cellValueChanged(e){(e.column.definition.topCalc||e.column.definition.bottomCalc)&&(this.table.options.groupBy?("table"!=this.table.options.columnCalcs&&"both"!=this.table.options.columnCalcs||this.recalcActiveRows(),"table"!=this.table.options.columnCalcs&&this.recalcRowGroup(e.row)):this.recalcActiveRows())}initializeColumnCheck(e){(e.definition.topCalc||e.definition.bottomCalc)&&this.initializeColumn(e)}initializeColumn(e){var t=e.definition,i={topCalcParams:t.topCalcParams||{},botCalcParams:t.bottomCalcParams||{}};if(t.topCalc){switch(typeof t.topCalc){case"string":E.calculations[t.topCalc]?i.topCalc=E.calculations[t.topCalc]:console.warn("Column Calc Error - No such calculation found, ignoring: ",t.topCalc);break;case"function":i.topCalc=t.topCalc}i.topCalc&&(e.modules.columnCalcs=i,this.topCalcs.push(e),"group"!=this.table.options.columnCalcs&&this.initializeTopRow())}if(t.bottomCalc){switch(typeof t.bottomCalc){case"string":E.calculations[t.bottomCalc]?i.botCalc=E.calculations[t.bottomCalc]:console.warn("Column Calc Error - No such calculation found, ignoring: ",t.bottomCalc);break;case"function":i.botCalc=t.bottomCalc}i.botCalc&&(e.modules.columnCalcs=i,this.botCalcs.push(e),"group"!=this.table.options.columnCalcs&&this.initializeBottomRow())}}registerColumnField(){}removeCalcs(){var e=!1;this.topInitialized&&(this.topInitialized=!1,this.topElement.parentNode.removeChild(this.topElement),e=!0),this.botInitialized&&(this.botInitialized=!1,this.footerRemove(this.botElement),e=!0),e&&this.table.rowManager.adjustTableSize()}reinitializeCalcs(){this.topCalcs.length&&this.initializeTopRow(),this.botCalcs.length&&this.initializeBottomRow()}initializeTopRow(){this.topInitialized||(this.table.columnManager.getContentsElement().insertBefore(this.topElement,this.table.columnManager.headersElement.nextSibling),this.topInitialized=!0)}initializeBottomRow(){this.botInitialized||(this.footerPrepend(this.botElement),this.botInitialized=!0)}scrollHorizontal(e){this.botInitialized&&this.botRow&&(this.botElement.scrollLeft=e)}recalc(e){var t,i;if(!this.blockCheck()&&(this.topInitialized||this.botInitialized)){if(t=this.rowsToData(e),this.topInitialized){for(this.topRow&&this.topRow.deleteCells(),i=this.generateRow("top",t),this.topRow=i;this.topElement.firstChild;)this.topElement.removeChild(this.topElement.firstChild);this.topElement.appendChild(i.getElement()),i.initialize(!0)}if(this.botInitialized){for(this.botRow&&this.botRow.deleteCells(),i=this.generateRow("bottom",t),this.botRow=i;this.botElement.firstChild;)this.botElement.removeChild(this.botElement.firstChild);this.botElement.appendChild(i.getElement()),i.initialize(!0)}this.table.rowManager.adjustTableSize(),this.table.modExists("frozenColumns")&&this.table.modules.frozenColumns.layout()}}recalcRowGroup(e){this.recalcGroup(this.table.modules.groupRows.getRowGroup(e))}recalcAll(){(this.topCalcs.length||this.botCalcs.length)&&("group"!==this.table.options.columnCalcs&&this.recalcActiveRows(),this.table.options.groupBy&&"table"!==this.table.options.columnCalcs&&this.table.modules.groupRows.getChildGroups().forEach((e=>{this.recalcGroup(e)})))}recalcGroup(e){var t,i;this.blockCheck()||e&&e.calcs&&(e.calcs.bottom&&(t=this.rowsToData(e.rows),i=this.generateRowData("bottom",t),e.calcs.bottom.updateData(i),e.calcs.bottom.reinitialize()),e.calcs.top&&(t=this.rowsToData(e.rows),i=this.generateRowData("top",t),e.calcs.top.updateData(i),e.calcs.top.reinitialize()))}generateTopRow(e){return this.generateRow("top",this.rowsToData(e))}generateBottomRow(e){return this.generateRow("bottom",this.rowsToData(e))}rowsToData(e){var t=[];return e.forEach((e=>{if(t.push(e.getData()),this.table.options.dataTree&&this.table.options.dataTreeChildColumnCalcs&&e.modules.dataTree&&e.modules.dataTree.open){var i=this.rowsToData(this.table.modules.dataTree.getFilteredTreeChildren(e));t=t.concat(i)}})),t}generateRow(e,t){var i,s=this.generateRowData(e,t);return this.table.modExists("mutator")&&this.table.modules.mutator.disable(),i=new w(s,this,"calc"),this.table.modExists("mutator")&&this.table.modules.mutator.enable(),i.getElement().classList.add("tabulator-calcs","tabulator-calcs-"+e),i.component=!1,i.getComponent=()=>(i.component||(i.component=new u(i)),i.component),i.generateCells=()=>{var t=[];this.table.columnManager.columnsByIndex.forEach((s=>{this.genColumn.setField(s.getField()),this.genColumn.hozAlign=s.hozAlign,s.definition[e+"CalcFormatter"]&&this.table.modExists("format")?this.genColumn.modules.format={formatter:this.table.modules.format.getFormatter(s.definition[e+"CalcFormatter"]),params:s.definition[e+"CalcFormatterParams"]||{}}:this.genColumn.modules.format={formatter:this.table.modules.format.getFormatter("plaintext"),params:{}},this.genColumn.definition.cssClass=s.definition.cssClass;var o=new m(this.genColumn,i);o.getElement(),o.column=s,o.setWidth(),s.cells.push(o),t.push(o),s.visible||o.hide()})),i.cells=t},i}generateRowData(e,t){var i,s,o={},n="top"==e?this.topCalcs:this.botCalcs,r="top"==e?"topCalc":"botCalc";return n.forEach((function(e){var n=[];e.modules.columnCalcs&&e.modules.columnCalcs[r]&&(t.forEach((function(t){n.push(e.getFieldValue(t))})),s=r+"Params",i="function"==typeof e.modules.columnCalcs[s]?e.modules.columnCalcs[s](n,t):e.modules.columnCalcs[s],e.setFieldValue(o,e.modules.columnCalcs[r](n,t,i)))})),o}hasTopCalcs(){return!!this.topCalcs.length}hasBottomCalcs(){return!!this.botCalcs.length}redraw(){this.topRow&&this.topRow.normalizeHeight(!0),this.botRow&&this.botRow.normalizeHeight(!0)}getResults(){var e={};return this.table.options.groupBy&&this.table.modExists("groupRows")?this.table.modules.groupRows.getGroups(!0).forEach((t=>{e[t.getKey()]=this.getGroupResults(t)})):e={top:this.topRow?this.topRow.getData():{},bottom:this.botRow?this.botRow.getData():{}},e}getGroupResults(e){var t=e._getSelf(),i=e.getSubGroups(),s={};return i.forEach((e=>{s[e.getKey()]=this.getGroupResults(e)})),{top:t.calcs.top?t.calcs.top.getData():{},bottom:t.calcs.bottom?t.calcs.bottom.getData():{},groups:s}}adjustForScrollbar(e){this.botRow&&(this.table.rtl?this.botElement.style.paddingLeft=e+"px":this.botElement.style.paddingRight=e+"px")}}E.moduleName="columnCalcs",E.calculations=C;class y extends s{constructor(e){super(e),this.indent=10,this.field="",this.collapseEl=null,this.expandEl=null,this.branchEl=null,this.elementField=!1,this.startOpen=function(){},this.registerTableOption("dataTree",!1),this.registerTableOption("dataTreeFilter",!0),this.registerTableOption("dataTreeSort",!0),this.registerTableOption("dataTreeElementColumn",!1),this.registerTableOption("dataTreeBranchElement",!0),this.registerTableOption("dataTreeChildIndent",9),this.registerTableOption("dataTreeChildField","_children"),this.registerTableOption("dataTreeCollapseElement",!1),this.registerTableOption("dataTreeExpandElement",!1),this.registerTableOption("dataTreeStartExpanded",!1),this.registerTableOption("dataTreeChildColumnCalcs",!1),this.registerTableOption("dataTreeSelectPropagate",!1),this.registerComponentFunction("row","treeCollapse",this.collapseRow.bind(this)),this.registerComponentFunction("row","treeExpand",this.expandRow.bind(this)),this.registerComponentFunction("row","treeToggle",this.toggleRow.bind(this)),this.registerComponentFunction("row","getTreeParent",this.getTreeParent.bind(this)),this.registerComponentFunction("row","getTreeChildren",this.getRowChildren.bind(this)),this.registerComponentFunction("row","addTreeChild",this.addTreeChildRow.bind(this)),this.registerComponentFunction("row","isTreeExpanded",this.isRowExpanded.bind(this))}initialize(){if(this.table.options.dataTree){var e=null,t=this.table.options;switch(this.field=t.dataTreeChildField,this.indent=t.dataTreeChildIndent,this.options("movableRows")&&console.warn("The movableRows option is not available with dataTree enabled, moving of child rows could result in unpredictable behavior"),t.dataTreeBranchElement?!0===t.dataTreeBranchElement?(this.branchEl=document.createElement("div"),this.branchEl.classList.add("tabulator-data-tree-branch")):"string"==typeof t.dataTreeBranchElement?((e=document.createElement("div")).innerHTML=t.dataTreeBranchElement,this.branchEl=e.firstChild):this.branchEl=t.dataTreeBranchElement:(this.branchEl=document.createElement("div"),this.branchEl.classList.add("tabulator-data-tree-branch-empty")),t.dataTreeCollapseElement?"string"==typeof t.dataTreeCollapseElement?((e=document.createElement("div")).innerHTML=t.dataTreeCollapseElement,this.collapseEl=e.firstChild):this.collapseEl=t.dataTreeCollapseElement:(this.collapseEl=document.createElement("div"),this.collapseEl.classList.add("tabulator-data-tree-control"),this.collapseEl.tabIndex=0,this.collapseEl.innerHTML="
"),t.dataTreeExpandElement?"string"==typeof t.dataTreeExpandElement?((e=document.createElement("div")).innerHTML=t.dataTreeExpandElement,this.expandEl=e.firstChild):this.expandEl=t.dataTreeExpandElement:(this.expandEl=document.createElement("div"),this.expandEl.classList.add("tabulator-data-tree-control"),this.expandEl.tabIndex=0,this.expandEl.innerHTML="
"),typeof t.dataTreeStartExpanded){case"boolean":this.startOpen=function(e,i){return t.dataTreeStartExpanded};break;case"function":this.startOpen=t.dataTreeStartExpanded;break;default:this.startOpen=function(e,i){return t.dataTreeStartExpanded[i]}}this.subscribe("row-init",this.initializeRow.bind(this)),this.subscribe("row-layout-after",this.layoutRow.bind(this)),this.subscribe("row-deleted",this.rowDelete.bind(this),0),this.subscribe("row-data-changed",this.rowDataChanged.bind(this),10),this.subscribe("cell-value-updated",this.cellValueChanged.bind(this)),this.subscribe("edit-cancelled",this.cellValueChanged.bind(this)),this.subscribe("column-moving-rows",this.columnMoving.bind(this)),this.subscribe("table-built",this.initializeElementField.bind(this)),this.subscribe("table-redrawing",this.tableRedrawing.bind(this)),this.registerDisplayHandler(this.getRows.bind(this),30)}}tableRedrawing(e){e&&this.table.rowManager.getRows().forEach((e=>{this.reinitializeRowChildren(e)}))}initializeElementField(){var e=this.table.columnManager.getFirstVisibleColumn();this.elementField=this.table.options.dataTreeElementColumn||!!e&&e.field}getRowChildren(e){return this.getTreeChildren(e,!0)}columnMoving(){var e=[];return this.table.rowManager.rows.forEach((t=>{e=e.concat(this.getTreeChildren(t,!1,!0))})),e}rowDataChanged(e,t,i){this.redrawNeeded(i)&&(this.initializeRow(e),t&&(this.layoutRow(e),this.refreshData(!0)))}cellValueChanged(e){e.column.getField()===this.elementField&&this.layoutRow(e.row)}initializeRow(e){var t=e.getData()[this.field],i=Array.isArray(t),s=i||!i&&"object"==typeof t&&null!==t;!s&&e.modules.dataTree&&e.modules.dataTree.branchEl&&e.modules.dataTree.branchEl.parentNode.removeChild(e.modules.dataTree.branchEl),!s&&e.modules.dataTree&&e.modules.dataTree.controlEl&&e.modules.dataTree.controlEl.parentNode.removeChild(e.modules.dataTree.controlEl),e.modules.dataTree={index:e.modules.dataTree?e.modules.dataTree.index:0,open:!!s&&(e.modules.dataTree?e.modules.dataTree.open:this.startOpen(e.getComponent(),0)),controlEl:!(!e.modules.dataTree||!s)&&e.modules.dataTree.controlEl,branchEl:!(!e.modules.dataTree||!s)&&e.modules.dataTree.branchEl,parent:!!e.modules.dataTree&&e.modules.dataTree.parent,children:s}}reinitializeRowChildren(e){this.getTreeChildren(e,!1,!0).forEach((function(e){e.reinitialize(!0)}))}layoutRow(e){var t=(this.elementField?e.getCell(this.elementField):e.getCells()[0]).getElement(),i=e.modules.dataTree;i.branchEl&&(i.branchEl.parentNode&&i.branchEl.parentNode.removeChild(i.branchEl),i.branchEl=!1),i.controlEl&&(i.controlEl.parentNode&&i.controlEl.parentNode.removeChild(i.controlEl),i.controlEl=!1),this.generateControlElement(e,t),e.getElement().classList.add("tabulator-tree-level-"+i.index),i.index&&(this.branchEl?(i.branchEl=this.branchEl.cloneNode(!0),t.insertBefore(i.branchEl,t.firstChild),this.table.rtl?i.branchEl.style.marginRight=(i.branchEl.offsetWidth+i.branchEl.style.marginLeft)*(i.index-1)+i.index*this.indent+"px":i.branchEl.style.marginLeft=(i.branchEl.offsetWidth+i.branchEl.style.marginRight)*(i.index-1)+i.index*this.indent+"px"):this.table.rtl?t.style.paddingRight=parseInt(window.getComputedStyle(t,null).getPropertyValue("padding-right"))+i.index*this.indent+"px":t.style.paddingLeft=parseInt(window.getComputedStyle(t,null).getPropertyValue("padding-left"))+i.index*this.indent+"px")}generateControlElement(e,t){var i=e.modules.dataTree,s=i.controlEl;t=t||e.getCells()[0].getElement(),!1!==i.children&&(i.open?(i.controlEl=this.collapseEl.cloneNode(!0),i.controlEl.addEventListener("click",(t=>{t.stopPropagation(),this.collapseRow(e)}))):(i.controlEl=this.expandEl.cloneNode(!0),i.controlEl.addEventListener("click",(t=>{t.stopPropagation(),this.expandRow(e)}))),i.controlEl.addEventListener("mousedown",(e=>{e.stopPropagation()})),s&&s.parentNode===t?s.parentNode.replaceChild(i.controlEl,s):t.insertBefore(i.controlEl,t.firstChild))}getRows(e){var t=[];return e.forEach(((e,i)=>{var s;t.push(e),e instanceof w&&(e.create(),(s=e.modules.dataTree).index||!1===s.children||this.getChildren(e).forEach((e=>{e.create(),t.push(e)})))})),t}getChildren(e,t){var i=e.modules.dataTree,s=[],o=[];return!1!==i.children&&(i.open||t)&&(Array.isArray(i.children)||(i.children=this.generateChildren(e)),s=this.table.modExists("filter")&&this.table.options.dataTreeFilter?this.table.modules.filter.filter(i.children):i.children,this.table.modExists("sort")&&this.table.options.dataTreeSort&&this.table.modules.sort.sort(s),s.forEach((e=>{o.push(e),this.getChildren(e).forEach((e=>{o.push(e)}))}))),o}generateChildren(e){var t=[],i=e.getData()[this.field];return Array.isArray(i)||(i=[i]),i.forEach((i=>{var s=new w(i||{},this.table.rowManager);s.create(),s.modules.dataTree.index=e.modules.dataTree.index+1,s.modules.dataTree.parent=e,s.modules.dataTree.children&&(s.modules.dataTree.open=this.startOpen(s.getComponent(),s.modules.dataTree.index)),t.push(s)})),t}expandRow(e,t){var i=e.modules.dataTree;!1!==i.children&&(i.open=!0,e.reinitialize(),this.refreshData(!0),this.dispatchExternal("dataTreeRowExpanded",e.getComponent(),e.modules.dataTree.index))}collapseRow(e){var t=e.modules.dataTree;!1!==t.children&&(t.open=!1,e.reinitialize(),this.refreshData(!0),this.dispatchExternal("dataTreeRowCollapsed",e.getComponent(),e.modules.dataTree.index))}toggleRow(e){var t=e.modules.dataTree;!1!==t.children&&(t.open?this.collapseRow(e):this.expandRow(e))}isRowExpanded(e){return e.modules.dataTree.open}getTreeParent(e){return!!e.modules.dataTree.parent&&e.modules.dataTree.parent.getComponent()}getTreeParentRoot(e){return e.modules.dataTree&&e.modules.dataTree.parent?this.getTreeParentRoot(e.modules.dataTree.parent):e}getFilteredTreeChildren(e){var t=e.modules.dataTree,i=[];return t.children&&(Array.isArray(t.children)||(t.children=this.generateChildren(e)),(this.table.modExists("filter")&&this.table.options.dataTreeFilter?this.table.modules.filter.filter(t.children):t.children).forEach((e=>{e instanceof w&&i.push(e)}))),i}rowDelete(e){var t,i=e.modules.dataTree.parent;i&&(!1!==(t=this.findChildIndex(e,i))&&i.data[this.field].splice(t,1),i.data[this.field].length||delete i.data[this.field],this.initializeRow(i),this.layoutRow(i)),this.refreshData(!0)}addTreeChildRow(e,t,i,s){var o=!1;"string"==typeof t&&(t=JSON.parse(t)),Array.isArray(e.data[this.field])||(e.data[this.field]=[],e.modules.dataTree.open=this.startOpen(e.getComponent(),e.modules.dataTree.index)),void 0!==s&&!1!==(o=this.findChildIndex(s,e))&&e.data[this.field].splice(i?o:o+1,0,t),!1===o&&(i?e.data[this.field].unshift(t):e.data[this.field].push(t)),this.initializeRow(e),this.layoutRow(e),this.refreshData(!0)}findChildIndex(e,t){var i=!1;return"object"==typeof e?e instanceof w?i=e.data:e instanceof v?i=e._getSelf().data:"undefined"!=typeof HTMLElement&&e instanceof HTMLElement?t.modules.dataTree&&(i=t.modules.dataTree.children.find((t=>t instanceof w&&t.element===e)))&&(i=i.data):null===e&&(i=!1):i=void 0!==e&&t.data[this.field].find((t=>t.data[this.table.options.index]==e)),i&&(Array.isArray(t.data[this.field])&&(i=t.data[this.field].indexOf(i)),-1==i&&(i=!1)),i}getTreeChildren(e,t,i){var s=e.modules.dataTree,o=[];return s&&s.children&&(Array.isArray(s.children)||(s.children=this.generateChildren(e)),s.children.forEach((e=>{e instanceof w&&(o.push(t?e.getComponent():e),i&&(o=o.concat(this.getTreeChildren(e,t,i))))}))),o}getChildField(){return this.field}redrawNeeded(e){return!!this.field&&void 0!==e[this.field]||!!this.elementField&&void 0!==e[this.elementField]}}y.moduleName="dataTree";var R={csv:function(e,t={},i){var s=t.delimiter?t.delimiter:",",o=[],n=[];e.forEach((e=>{var t=[];switch(e.type){case"group":console.warn("Download Warning - CSV downloader cannot process row groups");break;case"calc":console.warn("Download Warning - CSV downloader cannot process column calculations");break;case"header":e.columns.forEach(((e,t)=>{e&&1===e.depth&&(n[t]=void 0===e.value||null===e.value?"":'"'+String(e.value).split('"').join('""')+'"')}));break;case"row":e.columns.forEach((e=>{if(e){switch(typeof e.value){case"object":e.value=null!==e.value?JSON.stringify(e.value):"";break;case"undefined":e.value=""}t.push('"'+String(e.value).split('"').join('""')+'"')}})),o.push(t.join(s))}})),n.length&&o.unshift(n.join(s)),o=o.join("\n"),t.bom&&(o="\ufeff"+o),i(o,"text/csv")},json:function(e,t,i){var s=[];e.forEach((e=>{var t={};switch(e.type){case"header":break;case"group":console.warn("Download Warning - JSON downloader cannot process row groups");break;case"calc":console.warn("Download Warning - JSON downloader cannot process column calculations");break;case"row":e.columns.forEach((e=>{e&&(t[e.component.getTitleDownload()||e.component.getField()]=e.value)})),s.push(t)}})),i(s=JSON.stringify(s,null,"\t"),"application/json")},jsonLines:function(e,t,i){const s=[];e.forEach((e=>{const t={};switch(e.type){case"header":break;case"group":console.warn("Download Warning - JSON downloader cannot process row groups");break;case"calc":console.warn("Download Warning - JSON downloader cannot process column calculations");break;case"row":e.columns.forEach((e=>{e&&(t[e.component.getTitleDownload()||e.component.getField()]=e.value)})),s.push(JSON.stringify(t))}})),i(s.join("\n"),"application/x-ndjson")},pdf:function(e,t={},i){var s=[],o=[],n={},r=t.rowGroupStyles||{fontStyle:"bold",fontSize:12,cellPadding:6,fillColor:220},a=t.rowCalcStyles||{fontStyle:"bold",fontSize:10,cellPadding:4,fillColor:232},l=t.jsPDF||{},h=t.title?t.title:"";function d(e,t){var i=[];return e.columns.forEach((e=>{var s;if(e){switch(typeof e.value){case"object":e.value=null!==e.value?JSON.stringify(e.value):"";break;case"undefined":e.value=""}s={content:e.value,colSpan:e.width,rowSpan:e.height},t&&(s.styles=t),i.push(s)}})),i}l.orientation||(l.orientation=t.orientation||"landscape"),l.unit||(l.unit="pt"),e.forEach((e=>{switch(e.type){case"header":s.push(d(e));break;case"group":o.push(d(e,r));break;case"calc":o.push(d(e,a));break;case"row":o.push(d(e))}}));var c=new jspdf.jsPDF(l);t.autoTable&&(n="function"==typeof t.autoTable?t.autoTable(c)||{}:t.autoTable),h&&(n.didDrawPage=function(e){c.text(h,40,30)}),n.head=s,n.body=o,c.autoTable(n),t.documentProcessing&&t.documentProcessing(c),i(c.output("arraybuffer"),"application/pdf")},xlsx:function(t,i,s){var o=i.sheetName||"Sheet1",n=XLSX.utils.book_new(),r=new e(this),a=!("compress"in i)||i.compress,l=i.writeOptions||{bookType:"xlsx",bookSST:!0,compression:a};function h(){var e=[],i=[],s={},o={s:{c:0,r:0},e:{c:t[0]?t[0].columns.reduce(((e,t)=>e+(t&&t.width?t.width:1)),0):0,r:t.length}};return t.forEach(((t,s)=>{var o=[];t.columns.forEach((function(e,t){e?(o.push(e.value instanceof Date||"object"!=typeof e.value?e.value:JSON.stringify(e.value)),(e.width>1||e.height>-1)&&(e.height>1||e.width>1)&&i.push({s:{r:s,c:t},e:{r:s+e.height-1,c:t+e.width-1}})):o.push("")})),e.push(o)})),XLSX.utils.sheet_add_aoa(s,e),s["!ref"]=XLSX.utils.encode_range(o),i.length&&(s["!merges"]=i),s}if(l.type="binary",n.SheetNames=[],n.Sheets={},i.sheetOnly)s(h());else{if(i.sheets)for(var d in i.sheets)!0===i.sheets[d]?(n.SheetNames.push(d),n.Sheets[d]=h()):(n.SheetNames.push(d),r.commsSend(i.sheets[d],"download","intercept",{type:"xlsx",options:{sheetOnly:!0},active:this.active,intercept:function(e){n.Sheets[d]=e}}));else n.SheetNames.push(o),n.Sheets[o]=h();i.documentProcessing&&(n=i.documentProcessing(n)),s(function(e){for(var t=new ArrayBuffer(e.length),i=new Uint8Array(t),s=0;s!=e.length;++s)i[s]=255&e.charCodeAt(s);return t}(XLSX.write(n,l)),"application/octet-stream")}},html:function(e,t,i){this.modExists("export",!0)&&i(this.modules.export.generateHTMLTable(e),"text/html")}};class x extends s{constructor(e){super(e),this.registerTableOption("downloadEncoder",(function(e,t){return new Blob([e],{type:t})})),this.registerTableOption("downloadReady",void 0),this.registerTableOption("downloadConfig",{}),this.registerTableOption("downloadRowRange","active"),this.registerColumnOption("download"),this.registerColumnOption("titleDownload")}initialize(){this.deprecatedOptionsCheck(),this.registerTableFunction("download",this.download.bind(this)),this.registerTableFunction("downloadToTab",this.downloadToTab.bind(this))}deprecatedOptionsCheck(){this.deprecationCheck("downloadReady","downloadEncoder")}downloadToTab(e,t,i,s){this.download(e,t,i,s,!0)}download(e,t,i,s,o){var n=!1;if("function"==typeof e?n=e:x.downloaders[e]?n=x.downloaders[e]:console.warn("Download Error - No such download type found: ",e),n){var r=this.generateExportList(s);n.call(this.table,r,i||{},function(i,s){o?!0===o?this.triggerDownload(i,s,e,t,!0):o(i):this.triggerDownload(i,s,e,t)}.bind(this))}}generateExportList(e){var t=this.table.modules.export.generateExportList(this.table.options.downloadConfig,!1,e||this.table.options.downloadRowRange,"download"),i=this.table.options.groupHeaderDownload;return i&&!Array.isArray(i)&&(i=[i]),t.forEach((e=>{var t;"group"===e.type&&(t=e.columns[0],i&&i[e.indent]&&(t.value=i[e.indent](t.value,e.component._group.getRowCount(),e.component._group.getData(),e.component)))})),t}triggerDownload(e,t,i,s,o){var n=document.createElement("a"),r=this.table.options.downloadEncoder(e,t);r&&(o?window.open(window.URL.createObjectURL(r)):(s=s||"Tabulator."+("function"==typeof i?"txt":i),navigator.msSaveOrOpenBlob?navigator.msSaveOrOpenBlob(r,s):(n.setAttribute("href",window.URL.createObjectURL(r)),n.setAttribute("download",s),n.style.display="none",document.body.appendChild(n),n.click(),document.body.removeChild(n))),this.dispatchExternal("downloadComplete"))}commsReceived(e,t,i){if("intercept"===t)this.download(i.type,"",i.options,i.active,i.intercept)}}function T(e,t){var i=t.mask,s=void 0!==t.maskLetterChar?t.maskLetterChar:"A",o=void 0!==t.maskNumberChar?t.maskNumberChar:"9",n=void 0!==t.maskWildcardChar?t.maskWildcardChar:"*";function r(t){var a=i[t];void 0!==a&&a!==n&&a!==s&&a!==o&&(e.value=e.value+""+a,r(t+1))}e.addEventListener("keydown",(t=>{var r=e.value.length,a=t.key;if(t.keyCode>46&&!t.ctrlKey&&!t.metaKey){if(r>=i.length)return t.preventDefault(),t.stopPropagation(),!1;switch(i[r]){case s:if(a.toUpperCase()==a.toLowerCase())return t.preventDefault(),t.stopPropagation(),!1;break;case o:if(isNaN(a))return t.preventDefault(),t.stopPropagation(),!1;break;case n:break;default:if(a!==i[r])return t.preventDefault(),t.stopPropagation(),!1}}})),e.addEventListener("keyup",(i=>{i.keyCode>46&&t.maskAutoFill&&r(e.value.length)})),e.placeholder||(e.placeholder=i),t.maskAutoFill&&r(e.value.length)}x.moduleName="download",x.downloaders=R;class M{constructor(e,t,i,s,o,n){this.edit=e,this.table=e.table,this.cell=t,this.params=this._initializeParams(n),this.data=[],this.displayItems=[],this.currentItems=[],this.focusedItem=null,this.input=this._createInputElement(),this.listEl=this._createListElement(),this.initialValues=null,this.isFilter="header"===t.getType(),this.filterTimeout=null,this.filtered=!1,this.typing=!1,this.values=[],this.popup=null,this.listIteration=0,this.lastAction="",this.filterTerm="",this.blurable=!0,this.actions={success:s,cancel:o},this._deprecatedOptionsCheck(),this._initializeValue(),i(this._onRendered.bind(this))}_deprecatedOptionsCheck(){this.params.listItemFormatter&&this.cell.getTable().deprecationAdvisor.msg("The listItemFormatter editor param has been deprecated, please see the latest editor documentation for updated options"),this.params.sortValuesList&&this.cell.getTable().deprecationAdvisor.msg("The sortValuesList editor param has been deprecated, please see the latest editor documentation for updated options"),this.params.searchFunc&&this.cell.getTable().deprecationAdvisor.msg("The searchFunc editor param has been deprecated, please see the latest editor documentation for updated options"),this.params.searchingPlaceholder&&this.cell.getTable().deprecationAdvisor.msg("The searchingPlaceholder editor param has been deprecated, please see the latest editor documentation for updated options")}_initializeValue(){var e=this.cell.getValue();void 0===e&&void 0!==this.params.defaultValue&&(e=this.params.defaultValue),this.initialValues=this.params.multiselect?e:[e],this.isFilter&&(this.input.value=this.initialValues?this.initialValues.join(","):"",this.headerFilterInitialListGen())}_onRendered(){var e=this.cell.getElement();function t(e){e.stopPropagation()}this.isFilter||(this.input.style.height="100%",this.input.focus({preventScroll:!0})),e.addEventListener("click",t),setTimeout((()=>{e.removeEventListener("click",t)}),1e3),this.input.addEventListener("mousedown",this._preventPopupBlur.bind(this))}_createListElement(){var e=document.createElement("div");return e.classList.add("tabulator-edit-list"),e.addEventListener("mousedown",this._preventBlur.bind(this)),e.addEventListener("keydown",this._inputKeyDown.bind(this)),e}_setListWidth(){var e=this.isFilter?this.input:this.cell.getElement();this.listEl.style.minWidth=e.offsetWidth+"px",this.params.maxWidth&&(!0===this.params.maxWidth?this.listEl.style.maxWidth=e.offsetWidth+"px":"number"==typeof this.params.maxWidth?this.listEl.style.maxWidth=this.params.maxWidth+"px":this.listEl.style.maxWidth=this.params.maxWidth)}_createInputElement(){var e=this.params.elementAttributes,t=document.createElement("input");if(t.setAttribute("type",this.params.clearable?"search":"text"),t.style.padding="4px",t.style.width="100%",t.style.boxSizing="border-box",this.params.autocomplete||(t.style.cursor="default",t.style.caretColor="transparent"),e&&"object"==typeof e)for(let i in e)"+"==i.charAt(0)?(i=i.slice(1),t.setAttribute(i,t.getAttribute(i)+e["+"+i])):t.setAttribute(i,e[i]);return this.params.mask&&T(t,this.params),this._bindInputEvents(t),t}_initializeParams(e){var t,i=["values","valuesURL","valuesLookup"];return(e=Object.assign({},e)).verticalNavigation=e.verticalNavigation||"editor",e.placeholderLoading=void 0===e.placeholderLoading?"Searching ...":e.placeholderLoading,e.placeholderEmpty=void 0===e.placeholderEmpty?"No Results Found":e.placeholderEmpty,e.filterDelay=void 0===e.filterDelay?300:e.filterDelay,e.emptyValue=Object.keys(e).includes("emptyValue")?e.emptyValue:"",(t=Object.keys(e).filter((e=>i.includes(e))).length)?t>1&&console.warn("list editor config error - only one of the values, valuesURL, or valuesLookup options can be set on the same editor"):console.warn("list editor config error - either the values, valuesURL, or valuesLookup option must be set"),e.autocomplete?e.multiselect&&(e.multiselect=!1,console.warn("list editor config error - multiselect option is not available when autocomplete is enabled")):(e.freetext&&(e.freetext=!1,console.warn("list editor config error - freetext option is only available when autocomplete is enabled")),e.filterFunc&&(e.filterFunc=!1,console.warn("list editor config error - filterFunc option is only available when autocomplete is enabled")),e.filterRemote&&(e.filterRemote=!1,console.warn("list editor config error - filterRemote option is only available when autocomplete is enabled")),e.mask&&(e.mask=!1,console.warn("list editor config error - mask option is only available when autocomplete is enabled")),e.allowEmpty&&(e.allowEmpty=!1,console.warn("list editor config error - allowEmpty option is only available when autocomplete is enabled")),e.listOnEmpty&&(e.listOnEmpty=!1,console.warn("list editor config error - listOnEmpty option is only available when autocomplete is enabled"))),e.filterRemote&&"function"!=typeof e.valuesLookup&&!e.valuesURL&&(e.filterRemote=!1,console.warn("list editor config error - filterRemote option should only be used when values list is populated from a remote source")),e}_bindInputEvents(e){e.addEventListener("focus",this._inputFocus.bind(this)),e.addEventListener("click",this._inputClick.bind(this)),e.addEventListener("blur",this._inputBlur.bind(this)),e.addEventListener("keydown",this._inputKeyDown.bind(this)),e.addEventListener("search",this._inputSearch.bind(this)),this.params.autocomplete&&e.addEventListener("keyup",this._inputKeyUp.bind(this))}_inputFocus(e){this.rebuildOptionsList()}_filter(){this.params.filterRemote?(clearTimeout(this.filterTimeout),this.filterTimeout=setTimeout((()=>{this.rebuildOptionsList()}),this.params.filterDelay)):this._filterList()}_inputClick(e){e.stopPropagation()}_inputBlur(e){this.blurable&&(this.popup?this.popup.hide():this._resolveValue(!0))}_inputSearch(){this._clearChoices()}_inputKeyDown(e){switch(e.keyCode){case 38:this._keyUp(e);break;case 40:this._keyDown(e);break;case 37:case 39:this._keySide(e);break;case 13:this._keyEnter();break;case 27:this._keyEsc();break;case 36:case 35:this._keyHomeEnd(e);break;case 9:this._keyTab(e);break;default:this._keySelectLetter(e)}}_inputKeyUp(e){switch(e.keyCode){case 38:case 37:case 39:case 40:case 13:case 27:break;default:this._keyAutoCompLetter(e)}}_preventPopupBlur(){this.popup&&this.popup.blockHide(),setTimeout((()=>{this.popup&&this.popup.restoreHide()}),10)}_preventBlur(){this.blurable=!1,setTimeout((()=>{this.blurable=!0}),10)}_keyTab(e){this.params.autocomplete&&"typing"===this.lastAction?this._resolveValue(!0):this.focusedItem&&this._chooseItem(this.focusedItem,!0)}_keyUp(e){var t=this.displayItems.indexOf(this.focusedItem);("editor"==this.params.verticalNavigation||"hybrid"==this.params.verticalNavigation&&t)&&(e.stopImmediatePropagation(),e.stopPropagation(),e.preventDefault(),t>0&&this._focusItem(this.displayItems[t-1]))}_keyDown(e){var t=this.displayItems.indexOf(this.focusedItem);("editor"==this.params.verticalNavigation||"hybrid"==this.params.verticalNavigation&&t=38&&e.keyCode<=90&&this._scrollToValue(e.keyCode))}_keyAutoCompLetter(e){this._filter(),this.lastAction="typing",this.typing=!0}_scrollToValue(e){clearTimeout(this.filterTimeout);var t=String.fromCharCode(e).toLowerCase();this.filterTerm+=t.toLowerCase();var i=this.displayItems.find((e=>void 0!==e.label&&e.label.toLowerCase().startsWith(this.filterTerm)));i&&this._focusItem(i),this.filterTimeout=setTimeout((()=>{this.filterTerm=""}),800)}_focusItem(e){this.lastAction="focus",this.focusedItem&&this.focusedItem.element&&this.focusedItem.element.classList.remove("focused"),this.focusedItem=e,e&&e.element&&(e.element.classList.add("focused"),e.element.scrollIntoView({behavior:"smooth",block:"nearest",inline:"start"}))}headerFilterInitialListGen(){this._generateOptions(!0)}rebuildOptionsList(){this._generateOptions().then(this._sortOptions.bind(this)).then(this._buildList.bind(this)).then(this._showList.bind(this)).catch((e=>{Number.isInteger(e)||console.error("List generation error",e)}))}_filterList(){this._buildList(this._filterOptions()),this._showList()}_generateOptions(e){var t=[],i=++this.listIteration;return this.filtered=!1,this.params.values?t=this.params.values:this.params.valuesURL?t=this._ajaxRequest(this.params.valuesURL,this.input.value):"function"==typeof this.params.valuesLookup?t=this.params.valuesLookup(this.cell,this.input.value):this.params.valuesLookup&&(t=this._uniqueColumnValues(this.params.valuesLookupField)),t instanceof Promise?(e||this._addPlaceholder(this.params.placeholderLoading),t.then().then((e=>this.listIteration===i?this._parseList(e):Promise.reject(i)))):Promise.resolve(this._parseList(t))}_addPlaceholder(e){var t=document.createElement("div");"function"==typeof e&&(e=e(this.cell.getComponent(),this.listEl)),e&&(this._clearList(),e instanceof HTMLElement?t=e:(t.classList.add("tabulator-edit-list-placeholder"),t.innerHTML=e),this.listEl.appendChild(t),this._showList())}_ajaxRequest(e,t){return e=a(e,{},this.params.filterRemote?{term:t}:{}),fetch(e).then((e=>e.ok?e.json().catch((e=>(console.warn("List Ajax Load Error - Invalid JSON returned",e),Promise.reject(e)))):(console.error("List Ajax Load Error - Connection Error: "+e.status,e.statusText),Promise.reject(e)))).catch((e=>(console.error("List Ajax Load Error - Connection Error: ",e),Promise.reject(e))))}_uniqueColumnValues(e){var t,i={},s=this.table.getData(this.params.valuesLookup);return(t=e?this.table.columnManager.getColumnByField(e):this.cell.getColumn()._getSelf())?s.forEach((e=>{var s=t.getFieldValue(e);null!=s&&""!==s&&(i[s]=!0)})):(console.warn("unable to find matching column to create select lookup list:",e),i=[]),Object.keys(i)}_parseList(e){var t=[];return Array.isArray(e)||(e=Object.entries(e).map((([e,t])=>({label:t,value:e})))),e.forEach((e=>{"object"!=typeof e&&(e={label:e,value:e}),this._parseListItem(e,t,0)})),!this.currentItems.length&&this.params.freetext&&(this.input.value=this.initialValues,this.typing=!0,this.lastAction="typing"),this.data=t,t}_parseListItem(e,t,i){var s={};e.options?s=this._parseListGroup(e,i+1):(s={label:e.label,value:e.value,itemParams:e.itemParams,elementAttributes:e.elementAttributes,element:!1,selected:!1,visible:!0,level:i,original:e},this.initialValues&&this.initialValues.indexOf(e.value)>-1&&this._chooseItem(s,!0)),t.push(s)}_parseListGroup(e,t){var i={label:e.label,group:!0,itemParams:e.itemParams,elementAttributes:e.elementAttributes,element:!1,visible:!0,level:t,options:[],original:e};return e.options.forEach((e=>{this._parseListItem(e,i.options,t)})),i}_sortOptions(e){var t;return this.params.sort&&(t="function"==typeof this.params.sort?this.params.sort:this._defaultSortFunction.bind(this),this._sortGroup(t,e)),e}_sortGroup(e,t){t.sort(((t,i)=>e(t.label,i.label,t.value,i.value,t.original,i.original))),t.forEach((t=>{t.group&&this._sortGroup(e,t.options)}))}_defaultSortFunction(e,t){var i,s,o,n,r,a=0,l=/(\d+)|(\D+)/g,h=/\d/,d=0;if("desc"===this.params.sort&&([e,t]=[t,e]),e||0===e){if(t||0===t){if(isFinite(e)&&isFinite(t))return e-t;if((i=String(e).toLowerCase())===(s=String(t).toLowerCase()))return 0;if(!h.test(i)||!h.test(s))return i>s?1:-1;for(i=i.match(l),s=s.match(l),r=i.length>s.length?s.length:i.length;an?1:-1;return i.length>s.length}d=1}else d=t||0===t?-1:0;return d}_filterOptions(){var e=this.params.filterFunc||this._defaultFilterFunc,t=this.input.value;return t?(this.filtered=!0,this.data.forEach((i=>{this._filterItem(e,t,i)}))):this.filtered=!1,this.data}_filterItem(e,t,i){var s=!1;return i.group?(i.options.forEach((i=>{this._filterItem(e,t,i)&&(s=!0)})),i.visible=s):i.visible=e(t,i.label,i.value,i.original),i.visible}_defaultFilterFunc(e,t,i,s){return e=String(e).toLowerCase(),null!=t&&(String(t).toLowerCase().indexOf(e)>-1||String(i).toLowerCase().indexOf(e)>-1)}_clearList(){for(;this.listEl.firstChild;)this.listEl.removeChild(this.listEl.firstChild);this.displayItems=[]}_buildList(e){this._clearList(),e.forEach((e=>{this._buildItem(e)})),this.displayItems.length||this._addPlaceholder(this.params.placeholderEmpty)}_buildItem(e){var t,i=e.element;if(!this.filtered||e.visible){if(!i){if((i=document.createElement("div")).tabIndex=0,(t=this.params.itemFormatter?this.params.itemFormatter(e.label,e.value,e.original,i):e.label)instanceof HTMLElement?i.appendChild(t):i.innerHTML=t,e.group?i.classList.add("tabulator-edit-list-group"):i.classList.add("tabulator-edit-list-item"),i.classList.add("tabulator-edit-list-group-level-"+e.level),e.elementAttributes&&"object"==typeof e.elementAttributes)for(let t in e.elementAttributes)"+"==t.charAt(0)?(t=t.slice(1),i.setAttribute(t,this.input.getAttribute(t)+e.elementAttributes["+"+t])):i.setAttribute(t,e.elementAttributes[t]);e.group?i.addEventListener("click",this._groupClick.bind(this,e)):i.addEventListener("click",this._itemClick.bind(this,e)),i.addEventListener("mousedown",this._preventBlur.bind(this)),e.element=i}this._styleItem(e),this.listEl.appendChild(i),e.group?e.options.forEach((e=>{this._buildItem(e)})):this.displayItems.push(e)}}_showList(){var e=this.popup&&this.popup.isVisible();if(this.input.parentNode){if(this.params.autocomplete&&""===this.input.value&&!this.params.listOnEmpty)return void(this.popup&&this.popup.hide(!0));this._setListWidth(),this.popup||(this.popup=this.edit.popup(this.listEl)),this.popup.show(this.cell.getElement(),"bottom"),e||setTimeout((()=>{this.popup.hideOnBlur(this._resolveValue.bind(this,!0))}),10)}}_styleItem(e){e&&e.element&&(e.selected?e.element.classList.add("active"):e.element.classList.remove("active"))}_itemClick(e,t){t.stopPropagation(),this._chooseItem(e)}_groupClick(e,t){t.stopPropagation()}_cancel(){this.popup.hide(!0),this.actions.cancel()}_clearChoices(){this.typing=!0,this.currentItems.forEach((e=>{e.selected=!1,this._styleItem(e)})),this.currentItems=[],this.focusedItem=null}_chooseItem(e,t){var i;this.typing=!1,this.params.multiselect?((i=this.currentItems.indexOf(e))>-1?(this.currentItems.splice(i,1),e.selected=!1):(this.currentItems.push(e),e.selected=!0),this.input.value=this.currentItems.map((e=>e.label)).join(","),this._styleItem(e)):(this.currentItems=[e],e.selected=!0,this.input.value=e.label,this._styleItem(e),t||this._resolveValue()),this._focusItem(e)}_resolveValue(e){var t,i;if(this.popup&&this.popup.hide(!0),this.params.multiselect)t=this.currentItems.map((e=>e.value));else if(e&&this.params.autocomplete&&this.typing){if(!(this.params.freetext||this.params.allowEmpty&&""===this.input.value))return void this.actions.cancel();t=this.input.value}else t=this.currentItems[0]?this.currentItems[0].value:null==(i=Array.isArray(this.initialValues)?this.initialValues[0]:this.initialValues)||""===i?i:this.params.emptyValue;""===t&&(t=this.params.emptyValue),this.actions.success(t),this.isFilter&&(this.initialValues=t&&!Array.isArray(t)?[t]:t,this.currentItems=[])}}var k={input:function(e,t,i,s,o){var n=e.getValue(),r=document.createElement("input");if(r.setAttribute("type",o.search?"search":"text"),r.style.padding="4px",r.style.width="100%",r.style.boxSizing="border-box",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),r.setAttribute(e,r.getAttribute(e)+o.elementAttributes["+"+e])):r.setAttribute(e,o.elementAttributes[e]);function a(e){null==n&&""!==r.value||r.value!==n?i(r.value)&&(n=r.value):s()}return r.value=void 0!==n?n:"",t((function(){"cell"===e.getType()&&(r.focus({preventScroll:!0}),r.style.height="100%",o.selectContents&&r.select())})),r.addEventListener("change",a),r.addEventListener("blur",a),r.addEventListener("keydown",(function(e){switch(e.keyCode){case 13:a();break;case 27:s();break;case 35:case 36:e.stopPropagation()}})),o.mask&&T(r,o),r},textarea:function(e,t,i,s,o){var n=e.getValue(),r=o.verticalNavigation||"hybrid",a=String(null!=n?n:""),l=document.createElement("textarea"),h=0;if(l.style.display="block",l.style.padding="2px",l.style.height="100%",l.style.width="100%",l.style.boxSizing="border-box",l.style.whiteSpace="pre-wrap",l.style.resize="none",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),l.setAttribute(e,l.getAttribute(e)+o.elementAttributes["+"+e])):l.setAttribute(e,o.elementAttributes[e]);function d(t){null==n&&""!==l.value||l.value!==n?(i(l.value)&&(n=l.value),setTimeout((function(){e.getRow().normalizeHeight()}),300)):s()}return l.value=a,t((function(){"cell"===e.getType()&&(l.focus({preventScroll:!0}),l.style.height="100%",l.scrollHeight,l.style.height=l.scrollHeight+"px",e.getRow().normalizeHeight(),o.selectContents&&l.select())})),l.addEventListener("change",d),l.addEventListener("blur",d),l.addEventListener("keyup",(function(){l.style.height="";var t=l.scrollHeight;l.style.height=t+"px",t!=h&&(h=t,e.getRow().normalizeHeight())})),l.addEventListener("keydown",(function(e){switch(e.keyCode){case 13:e.shiftKey&&o.shiftEnterSubmit&&d();break;case 27:s();break;case 38:("editor"==r||"hybrid"==r&&l.selectionStart)&&(e.stopImmediatePropagation(),e.stopPropagation());break;case 40:("editor"==r||"hybrid"==r&&l.selectionStart!==l.value.length)&&(e.stopImmediatePropagation(),e.stopPropagation());break;case 35:case 36:e.stopPropagation()}})),o.mask&&T(l,o),l},number:function(e,t,i,s,o){var n=e.getValue(),r=o.verticalNavigation||"editor",a=document.createElement("input");if(a.setAttribute("type","number"),void 0!==o.max&&a.setAttribute("max",o.max),void 0!==o.min&&a.setAttribute("min",o.min),void 0!==o.step&&a.setAttribute("step",o.step),a.style.padding="4px",a.style.width="100%",a.style.boxSizing="border-box",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),a.setAttribute(e,a.getAttribute(e)+o.elementAttributes["+"+e])):a.setAttribute(e,o.elementAttributes[e]);a.value=n;var l=function(e){h()};function h(){var e=a.value;isNaN(e)||""===e||(e=Number(e)),e!==n?i(e)&&(n=e):s()}return t((function(){"cell"===e.getType()&&(a.removeEventListener("blur",l),a.focus({preventScroll:!0}),a.style.height="100%",a.addEventListener("blur",l),o.selectContents&&a.select())})),a.addEventListener("keydown",(function(e){switch(e.keyCode){case 13:h();break;case 27:s();break;case 38:case 40:"editor"==r&&(e.stopImmediatePropagation(),e.stopPropagation());break;case 35:case 36:e.stopPropagation()}})),o.mask&&T(a,o),a},range:function(e,t,i,s,o){var n=e.getValue(),r=document.createElement("input");if(r.setAttribute("type","range"),void 0!==o.max&&r.setAttribute("max",o.max),void 0!==o.min&&r.setAttribute("min",o.min),void 0!==o.step&&r.setAttribute("step",o.step),r.style.padding="4px",r.style.width="100%",r.style.boxSizing="border-box",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),r.setAttribute(e,r.getAttribute(e)+o.elementAttributes["+"+e])):r.setAttribute(e,o.elementAttributes[e]);function a(){var e=r.value;isNaN(e)||""===e||(e=Number(e)),e!=n?i(e)&&(n=e):s()}return r.value=n,t((function(){"cell"===e.getType()&&(r.focus({preventScroll:!0}),r.style.height="100%")})),r.addEventListener("blur",(function(e){a()})),r.addEventListener("keydown",(function(e){switch(e.keyCode){case 13:a();break;case 27:s()}})),r},date:function(e,t,i,s,o){var n=o.format,r=o.verticalNavigation||"editor",a=n?window.DateTime||luxon.DateTime:null,l=e.getValue(),h=document.createElement("input");function d(e){return(a.isDateTime(e)?e:"iso"===n?a.fromISO(String(e)):a.fromFormat(String(e),n)).toFormat("yyyy-MM-dd")}if(h.type="date",h.style.padding="4px",h.style.width="100%",h.style.boxSizing="border-box",o.max&&h.setAttribute("max",n?d(o.max):o.max),o.min&&h.setAttribute("min",n?d(o.min):o.min),o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),h.setAttribute(e,h.getAttribute(e)+o.elementAttributes["+"+e])):h.setAttribute(e,o.elementAttributes[e]);function c(){var e,t=h.value;if(null==l&&""!==t||t!==l){if(t&&n)switch(e=a.fromFormat(String(t),"yyyy-MM-dd"),n){case!0:t=e;break;case"iso":t=e.toISO();break;default:t=e.toFormat(n)}i(t)&&(l=h.value)}else s()}return l=void 0!==l?l:"",n&&(a?l=d(l):console.error("Editor Error - 'date' editor 'format' param is dependant on luxon.js")),h.value=l,t((function(){"cell"===e.getType()&&(h.focus({preventScroll:!0}),h.style.height="100%",o.selectContents&&h.select())})),h.addEventListener("blur",(function(e){(e.relatedTarget||e.rangeParent||e.explicitOriginalTarget!==h)&&c()})),h.addEventListener("keydown",(function(e){switch(e.keyCode){case 13:c();break;case 27:s();break;case 35:case 36:e.stopPropagation();break;case 38:case 40:"editor"==r&&(e.stopImmediatePropagation(),e.stopPropagation())}})),h},time:function(e,t,i,s,o){var n,r=o.format,a=o.verticalNavigation||"editor",l=r?window.DateTime||luxon.DateTime:null,h=e.getValue(),d=document.createElement("input");if(d.type="time",d.style.padding="4px",d.style.width="100%",d.style.boxSizing="border-box",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),d.setAttribute(e,d.getAttribute(e)+o.elementAttributes["+"+e])):d.setAttribute(e,o.elementAttributes[e]);function c(){var e,t=d.value;if(null==h&&""!==t||t!==h){if(t&&r)switch(e=l.fromFormat(String(t),"hh:mm"),r){case!0:t=e;break;case"iso":t=e.toISO();break;default:t=e.toFormat(r)}i(t)&&(h=d.value)}else s()}return h=void 0!==h?h:"",r&&(l?(n=l.isDateTime(h)?h:"iso"===r?l.fromISO(String(h)):l.fromFormat(String(h),r),h=n.toFormat("hh:mm")):console.error("Editor Error - 'date' editor 'format' param is dependant on luxon.js")),d.value=h,t((function(){"cell"==e.getType()&&(d.focus({preventScroll:!0}),d.style.height="100%",o.selectContents&&d.select())})),d.addEventListener("blur",(function(e){(e.relatedTarget||e.rangeParent||e.explicitOriginalTarget!==d)&&c()})),d.addEventListener("keydown",(function(e){switch(e.keyCode){case 13:c();break;case 27:s();break;case 35:case 36:e.stopPropagation();break;case 38:case 40:"editor"==a&&(e.stopImmediatePropagation(),e.stopPropagation())}})),d},datetime:function(e,t,i,s,o){var n,r=o.format,a=o.verticalNavigation||"editor",l=r?window.DateTime||luxon.DateTime:null,h=e.getValue(),d=document.createElement("input");if(d.type="datetime-local",d.style.padding="4px",d.style.width="100%",d.style.boxSizing="border-box",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),d.setAttribute(e,d.getAttribute(e)+o.elementAttributes["+"+e])):d.setAttribute(e,o.elementAttributes[e]);function c(){var e,t=d.value;if(null==h&&""!==t||t!==h){if(t&&r)switch(e=l.fromISO(String(t)),r){case!0:t=e;break;case"iso":t=e.toISO();break;default:t=e.toFormat(r)}i(t)&&(h=d.value)}else s()}return h=void 0!==h?h:"",r&&(l?(n=l.isDateTime(h)?h:"iso"===r?l.fromISO(String(h)):l.fromFormat(String(h),r),h=n.toFormat("yyyy-MM-dd")+"T"+n.toFormat("hh:mm")):console.error("Editor Error - 'date' editor 'format' param is dependant on luxon.js")),d.value=h,t((function(){"cell"===e.getType()&&(d.focus({preventScroll:!0}),d.style.height="100%",o.selectContents&&d.select())})),d.addEventListener("blur",(function(e){(e.relatedTarget||e.rangeParent||e.explicitOriginalTarget!==d)&&c()})),d.addEventListener("keydown",(function(e){switch(e.keyCode){case 13:c();break;case 27:s();break;case 35:case 36:e.stopPropagation();break;case 38:case 40:"editor"==a&&(e.stopImmediatePropagation(),e.stopPropagation())}})),d},select:function(e,t,i,s,o){return this.deprecationMsg("The select editor has been deprecated, please use the new list editor"),new M(this,e,t,i,s,o).input},list:function(e,t,i,s,o){return new M(this,e,t,i,s,o).input},autocomplete:function(e,t,i,s,o){return this.deprecationMsg("The autocomplete editor has been deprecated, please use the new list editor with the 'autocomplete' editorParam"),o.autocomplete=!0,new M(this,e,t,i,s,o).input},star:function(e,t,i,s,o){var n=this,r=e.getElement(),a=e.getValue(),l=r.getElementsByTagName("svg").length||5,h=r.getElementsByTagName("svg")[0]?r.getElementsByTagName("svg")[0].getAttribute("width"):14,d=[],c=document.createElement("div"),u=document.createElementNS("http://www.w3.org/2000/svg","svg");function p(e){d.forEach((function(t,i){i'):("ie"==n.table.browser?t.setAttribute("class","tabulator-star-inactive"):t.classList.replace("tabulator-star-active","tabulator-star-inactive"),t.innerHTML='')}))}function m(e){var t=document.createElement("span"),s=u.cloneNode(!0);d.push(s),t.addEventListener("mouseenter",(function(t){t.stopPropagation(),t.stopImmediatePropagation(),p(e)})),t.addEventListener("mousemove",(function(e){e.stopPropagation(),e.stopImmediatePropagation()})),t.addEventListener("click",(function(t){t.stopPropagation(),t.stopImmediatePropagation(),i(e),r.blur()})),t.appendChild(s),c.appendChild(t)}function g(e){a=e,p(e)}if(r.style.whiteSpace="nowrap",r.style.overflow="hidden",r.style.textOverflow="ellipsis",c.style.verticalAlign="middle",c.style.display="inline-block",c.style.padding="4px",u.setAttribute("width",h),u.setAttribute("height",h),u.setAttribute("viewBox","0 0 512 512"),u.setAttribute("xml:space","preserve"),u.style.padding="0 1px",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),c.setAttribute(e,c.getAttribute(e)+o.elementAttributes["+"+e])):c.setAttribute(e,o.elementAttributes[e]);for(var b=1;b<=l;b++)m(b);return p(a=Math.min(parseInt(a),l)),c.addEventListener("mousemove",(function(e){p(0)})),c.addEventListener("click",(function(e){i(0)})),r.addEventListener("blur",(function(e){s()})),r.addEventListener("keydown",(function(e){switch(e.keyCode){case 39:g(a+1);break;case 37:g(a-1);break;case 13:i(a);break;case 27:s()}})),c},progress:function(e,t,i,s,o){var n,r,a=e.getElement(),l=void 0===o.max?a.getElementsByTagName("div")[0]&&a.getElementsByTagName("div")[0].getAttribute("max")||100:o.max,h=void 0===o.min?a.getElementsByTagName("div")[0]&&a.getElementsByTagName("div")[0].getAttribute("min")||0:o.min,d=(l-h)/100,c=e.getValue()||0,u=document.createElement("div"),p=document.createElement("div");function m(){var e=window.getComputedStyle(a,null),t=d*Math.round(p.offsetWidth/((a.clientWidth-parseInt(e.getPropertyValue("padding-left"))-parseInt(e.getPropertyValue("padding-right")))/100))+h;i(t),a.setAttribute("aria-valuenow",t),a.setAttribute("aria-label",c)}if(u.style.position="absolute",u.style.right="0",u.style.top="0",u.style.bottom="0",u.style.width="5px",u.classList.add("tabulator-progress-handle"),p.style.display="inline-block",p.style.position="relative",p.style.height="100%",p.style.backgroundColor="#488CE9",p.style.maxWidth="100%",p.style.minWidth="0%",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),p.setAttribute(e,p.getAttribute(e)+o.elementAttributes["+"+e])):p.setAttribute(e,o.elementAttributes[e]);return a.style.padding="4px 4px",c=Math.min(parseFloat(c),l),c=Math.max(parseFloat(c),h),c=Math.round((c-h)/d),p.style.width=c+"%",a.setAttribute("aria-valuemin",h),a.setAttribute("aria-valuemax",l),p.appendChild(u),u.addEventListener("mousedown",(function(e){n=e.screenX,r=p.offsetWidth})),u.addEventListener("mouseover",(function(){u.style.cursor="ew-resize"})),a.addEventListener("mousemove",(function(e){n&&(p.style.width=r+e.screenX-n+"px")})),a.addEventListener("mouseup",(function(e){n&&(e.stopPropagation(),e.stopImmediatePropagation(),n=!1,r=!1,m())})),a.addEventListener("keydown",(function(e){switch(e.keyCode){case 39:e.preventDefault(),p.style.width=p.clientWidth+a.clientWidth/100+"px";break;case 37:e.preventDefault(),p.style.width=p.clientWidth-a.clientWidth/100+"px";break;case 9:case 13:m();break;case 27:s()}})),a.addEventListener("blur",(function(){s()})),p},tickCross:function(e,t,i,s,o){var n=e.getValue(),r=document.createElement("input"),a=o.tristate,l=void 0===o.indeterminateValue?null:o.indeterminateValue,h=!1,d=Object.keys(o).includes("trueValue"),c=Object.keys(o).includes("falseValue");if(r.setAttribute("type","checkbox"),r.style.marginTop="5px",r.style.boxSizing="border-box",o.elementAttributes&&"object"==typeof o.elementAttributes)for(let e in o.elementAttributes)"+"==e.charAt(0)?(e=e.slice(1),r.setAttribute(e,r.getAttribute(e)+o.elementAttributes["+"+e])):r.setAttribute(e,o.elementAttributes[e]);function u(e){var t=r.checked;return d&&t?t=o.trueValue:c&&!t&&(t=o.falseValue),a?e?h?l:t:r.checked&&!h?(r.checked=!1,r.indeterminate=!0,h=!0,l):(h=!1,t):t}return r.value=n,!a||void 0!==n&&n!==l&&""!==n||(h=!0,r.indeterminate=!0),"firefox"!=this.table.browser&&"safari"!=this.table.browser&&t((function(){"cell"===e.getType()&&r.focus({preventScroll:!0})})),r.checked=d?n===o.trueValue:!0===n||"true"===n||"True"===n||1===n,r.addEventListener("change",(function(e){i(u())})),r.addEventListener("blur",(function(e){i(u(!0))})),r.addEventListener("keydown",(function(e){13==e.keyCode&&i(u()),27==e.keyCode&&s()})),r}};class L extends s{constructor(e){super(e),this.currentCell=!1,this.mouseClick=!1,this.recursionBlock=!1,this.invalidEdit=!1,this.editedCells=[],this.editors=L.editors,this.registerColumnOption("editable"),this.registerColumnOption("editor"),this.registerColumnOption("editorParams"),this.registerColumnOption("cellEditing"),this.registerColumnOption("cellEdited"),this.registerColumnOption("cellEditCancelled"),this.registerTableFunction("getEditedCells",this.getEditedCells.bind(this)),this.registerTableFunction("clearCellEdited",this.clearCellEdited.bind(this)),this.registerTableFunction("navigatePrev",this.navigatePrev.bind(this)),this.registerTableFunction("navigateNext",this.navigateNext.bind(this)),this.registerTableFunction("navigateLeft",this.navigateLeft.bind(this)),this.registerTableFunction("navigateRight",this.navigateRight.bind(this)),this.registerTableFunction("navigateUp",this.navigateUp.bind(this)),this.registerTableFunction("navigateDown",this.navigateDown.bind(this)),this.registerComponentFunction("cell","isEdited",this.cellIsEdited.bind(this)),this.registerComponentFunction("cell","clearEdited",this.clearEdited.bind(this)),this.registerComponentFunction("cell","edit",this.editCell.bind(this)),this.registerComponentFunction("cell","cancelEdit",this.cellCancelEdit.bind(this)),this.registerComponentFunction("cell","navigatePrev",this.navigatePrev.bind(this)),this.registerComponentFunction("cell","navigateNext",this.navigateNext.bind(this)),this.registerComponentFunction("cell","navigateLeft",this.navigateLeft.bind(this)),this.registerComponentFunction("cell","navigateRight",this.navigateRight.bind(this)),this.registerComponentFunction("cell","navigateUp",this.navigateUp.bind(this)),this.registerComponentFunction("cell","navigateDown",this.navigateDown.bind(this))}initialize(){this.subscribe("cell-init",this.bindEditor.bind(this)),this.subscribe("cell-delete",this.clearEdited.bind(this)),this.subscribe("cell-value-changed",this.updateCellClass.bind(this)),this.subscribe("column-layout",this.initializeColumnCheck.bind(this)),this.subscribe("column-delete",this.columnDeleteCheck.bind(this)),this.subscribe("row-deleting",this.rowDeleteCheck.bind(this)),this.subscribe("row-layout",this.rowEditableCheck.bind(this)),this.subscribe("data-refreshing",this.cancelEdit.bind(this)),this.subscribe("keybinding-nav-prev",this.navigatePrev.bind(this,void 0)),this.subscribe("keybinding-nav-next",this.keybindingNavigateNext.bind(this)),this.subscribe("keybinding-nav-left",this.navigateLeft.bind(this,void 0)),this.subscribe("keybinding-nav-right",this.navigateRight.bind(this,void 0)),this.subscribe("keybinding-nav-up",this.navigateUp.bind(this,void 0)),this.subscribe("keybinding-nav-down",this.navigateDown.bind(this,void 0))}keybindingNavigateNext(e){var t=this.currentCell,i=this.options("tabEndNewRow");t&&(this.navigateNext(t,e)||i&&(t.getElement().firstChild.blur(),(i=!0===i?this.table.addRow({}):"function"==typeof i?this.table.addRow(i(t.row.getComponent())):this.table.addRow(Object.assign({},i))).then((()=>{setTimeout((()=>{t.getComponent().navigateNext()}))}))))}cellIsEdited(e){return!!e.modules.edit&&e.modules.edit.edited}cellCancelEdit(e){e===this.currentCell?this.table.modules.edit.cancelEdit():console.warn("Cancel Editor Error - This cell is not currently being edited ")}updateCellClass(e){this.allowEdit(e)?e.getElement().classList.add("tabulator-editable"):e.getElement().classList.remove("tabulator-editable")}clearCellEdited(e){e||(e=this.table.modules.edit.getEditedCells()),Array.isArray(e)||(e=[e]),e.forEach((e=>{this.table.modules.edit.clearEdited(e._getSelf())}))}navigatePrev(e=this.currentCell,t){var i,s;if(e){if(t&&t.preventDefault(),i=this.navigateLeft())return!0;if((s=this.table.rowManager.prevDisplayRow(e.row,!0))&&(i=this.findPrevEditableCell(s,s.cells.length)))return i.getComponent().edit(),!0}return!1}navigateNext(e=this.currentCell,t){var i,s;if(e){if(t&&t.preventDefault(),i=this.navigateRight())return!0;if((s=this.table.rowManager.nextDisplayRow(e.row,!0))&&(i=this.findNextEditableCell(s,-1)))return i.getComponent().edit(),!0}return!1}navigateLeft(e=this.currentCell,t){var i,s;return!!(e&&(t&&t.preventDefault(),i=e.getIndex(),s=this.findPrevEditableCell(e.row,i)))&&(s.getComponent().edit(),!0)}navigateRight(e=this.currentCell,t){var i,s;return!!(e&&(t&&t.preventDefault(),i=e.getIndex(),s=this.findNextEditableCell(e.row,i)))&&(s.getComponent().edit(),!0)}navigateUp(e=this.currentCell,t){var i,s;return!!(e&&(t&&t.preventDefault(),i=e.getIndex(),s=this.table.rowManager.prevDisplayRow(e.row,!0)))&&(s.cells[i].getComponent().edit(),!0)}navigateDown(e=this.currentCell,t){var i,s;return!!(e&&(t&&t.preventDefault(),i=e.getIndex(),s=this.table.rowManager.nextDisplayRow(e.row,!0)))&&(s.cells[i].getComponent().edit(),!0)}findNextEditableCell(e,i){var s=!1;if(i0)for(var o=i-1;o>=0;o--){let i=e.cells[o];if(i.column.modules.edit&&t.elVisible(i.getElement())){if(this.allowEdit(i)){s=i;break}}}return s}initializeColumnCheck(e){void 0!==e.definition.editor&&this.initializeColumn(e)}columnDeleteCheck(e){this.currentCell&&this.currentCell.column===e&&this.cancelEdit()}rowDeleteCheck(e){this.currentCell&&this.currentCell.row===e&&this.cancelEdit()}rowEditableCheck(e){e.getCells().forEach((e=>{e.column.modules.edit&&"function"==typeof e.column.modules.edit.check&&this.updateCellClass(e)}))}initializeColumn(e){var t={editor:!1,blocked:!1,check:e.definition.editable,params:e.definition.editorParams||{}};switch(typeof e.definition.editor){case"string":this.editors[e.definition.editor]?t.editor=this.editors[e.definition.editor]:console.warn("Editor Error - No such editor found: ",e.definition.editor);break;case"function":t.editor=e.definition.editor;break;case"boolean":!0===e.definition.editor&&("function"!=typeof e.definition.formatter?this.editors[e.definition.formatter]?t.editor=this.editors[e.definition.formatter]:t.editor=this.editors.input:console.warn("Editor Error - Cannot auto lookup editor for a custom formatter: ",e.definition.formatter))}t.editor&&(e.modules.edit=t)}getCurrentCell(){return!!this.currentCell&&this.currentCell.getComponent()}clearEditor(e){var t,i=this.currentCell;if(this.invalidEdit=!1,i){for(this.currentCell=!1,t=i.getElement(),this.dispatch("edit-editor-clear",i,e),t.classList.remove("tabulator-editing");t.firstChild;)t.removeChild(t.firstChild);i.row.getElement().classList.remove("tabulator-editing"),i.table.element.classList.remove("tabulator-editing")}}cancelEdit(){if(this.currentCell){var e=this.currentCell,t=this.currentCell.getComponent();this.clearEditor(!0),e.setValueActual(e.getValue()),e.cellRendered(),("textarea"==e.column.definition.editor||e.column.definition.variableHeight)&&e.row.normalizeHeight(!0),e.column.definition.cellEditCancelled&&e.column.definition.cellEditCancelled.call(this.table,t),this.dispatch("edit-cancelled",e),this.dispatchExternal("cellEditCancelled",t)}}bindEditor(e){if(e.column.modules.edit){var t=this,i=e.getElement(!0);this.updateCellClass(e),i.setAttribute("tabindex",0),i.addEventListener("click",(function(e){i.classList.contains("tabulator-editing")||i.focus({preventScroll:!0})})),i.addEventListener("mousedown",(function(e){2===e.button?e.preventDefault():t.mouseClick=!0})),i.addEventListener("focus",(function(i){t.recursionBlock||t.edit(e,i,!1)}))}}focusCellNoEvent(e,t){this.recursionBlock=!0,t&&"ie"===this.table.browser||e.getElement().focus({preventScroll:!0}),this.recursionBlock=!1}editCell(e,t){this.focusCellNoEvent(e),this.edit(e,!1,t)}focusScrollAdjust(e){if("virtual"==this.table.rowManager.getRenderMode()){var t=this.table.rowManager.element.scrollTop,i=this.table.rowManager.element.clientHeight+this.table.rowManager.element.scrollTop,s=e.row.getElement();s.offsetTopi&&(this.table.rowManager.element.scrollTop+=s.offsetTop+s.offsetHeight-i);var o=this.table.rowManager.element.scrollLeft,n=this.table.rowManager.element.clientWidth+this.table.rowManager.element.scrollLeft,r=e.getElement();this.table.modExists("frozenColumns")&&(o+=parseInt(this.table.modules.frozenColumns.leftMargin||0),n-=parseInt(this.table.modules.frozenColumns.rightMargin||0)),"virtual"===this.table.options.renderHorizontal&&(o-=parseInt(this.table.columnManager.renderer.vDomPadLeft),n-=parseInt(this.table.columnManager.renderer.vDomPadLeft)),r.offsetLeftn&&(this.table.rowManager.element.scrollLeft+=r.offsetLeft+r.offsetWidth-n)}}allowEdit(e){var t=!!e.column.modules.edit;if(e.column.modules.edit)switch(typeof e.column.modules.edit.check){case"function":e.row.initialized&&(t=e.column.modules.edit.check(e.getComponent()));break;case"string":t=!!e.row.data[e.column.modules.edit.check];break;case"boolean":t=e.column.modules.edit.check}return t}edit(e,t,i){var s,o,n,r=this,a=function(){},l=e.getElement();if(!this.currentCell){if(e.column.modules.edit.blocked)return this.mouseClick=!1,l.blur(),!1;if(t&&t.stopPropagation(),this.allowEdit(e)||i){if(r.cancelEdit(),r.currentCell=e,this.focusScrollAdjust(e),o=e.getComponent(),this.mouseClick&&(this.mouseClick=!1,e.column.definition.cellClick&&e.column.definition.cellClick.call(this.table,t,o)),e.column.definition.cellEditing&&e.column.definition.cellEditing.call(this.table,o),this.dispatch("cell-editing",e),this.dispatchExternal("cellEditing",o),n="function"==typeof e.column.modules.edit.params?e.column.modules.edit.params(o):e.column.modules.edit.params,s=e.column.modules.edit.editor.call(r,o,(function(e){a=e}),(function(t){if(r.currentCell===e){var i=r.chain("edit-success",[e,t],!0,!0);return!0===i||"highlight"===r.table.options.validationMode?(r.clearEditor(),e.modules.edit||(e.modules.edit={}),e.modules.edit.edited=!0,-1==r.editedCells.indexOf(e)&&r.editedCells.push(e),e.setValue(t,!0),!0===i):(r.invalidEdit=!0,r.focusCellNoEvent(e,!0),a(),!1)}}),(function(){r.currentCell===e&&r.cancelEdit()}),n),!this.currentCell||!1===s)return l.blur(),!1;if(!(s instanceof Node))return console.warn("Edit Error - Editor should return an instance of Node, the editor returned:",s),l.blur(),!1;for(l.classList.add("tabulator-editing"),e.row.getElement().classList.add("tabulator-editing"),e.table.element.classList.add("tabulator-editing");l.firstChild;)l.removeChild(l.firstChild);l.appendChild(s),a();for(var h=l.children,d=0;d{e.push(t.getComponent())})),e}clearEdited(e){var t;e.modules.edit&&e.modules.edit.edited&&(e.modules.edit.edited=!1,this.dispatch("edit-edited-clear",e)),(t=this.editedCells.indexOf(e))>-1&&this.editedCells.splice(t,1)}}L.moduleName="edit",L.editors=k;class D{constructor(e,t,i,s){this.type=e,this.columns=t,this.component=i||!1,this.indent=s||0}}class S{constructor(e,t,i,s,o){this.value=e,this.component=t||!1,this.width=i,this.height=s,this.depth=o}}class P extends s{constructor(e){super(e),this.config={},this.cloneTableStyle=!0,this.colVisProp="",this.registerTableOption("htmlOutputConfig",!1),this.registerColumnOption("htmlOutput"),this.registerColumnOption("titleHtmlOutput")}initialize(){this.registerTableFunction("getHtml",this.getHtml.bind(this))}generateExportList(e,t,i,s){this.cloneTableStyle=t,this.config=e||{},this.colVisProp=s;var o=!1!==this.config.columnHeaders?this.headersToExportRows(this.generateColumnGroupHeaders()):[],n=this.bodyToExportRows(this.rowLookup(i));return o.concat(n)}generateTable(e,t,i,s){var o=this.generateExportList(e,t,i,s);return this.generateTableElement(o)}rowLookup(e){var t=[];if("function"==typeof e)e.call(this.table).forEach((e=>{(e=this.table.rowManager.findRow(e))&&t.push(e)}));else switch(e){case!0:case"visible":t=this.table.rowManager.getVisibleRows(!1,!0);break;case"all":t=this.table.rowManager.rows;break;case"selected":t=this.table.modules.selectRow.selectedRows;break;default:t=this.table.options.pagination?this.table.rowManager.getDisplayRows(this.table.rowManager.displayRows.length-2):this.table.rowManager.getDisplayRows()}return Object.assign([],t)}generateColumnGroupHeaders(){var e=[];return(!1!==this.config.columnGroups?this.table.columnManager.columns:this.table.columnManager.columnsByIndex).forEach((t=>{var i=this.processColumnGroup(t);i&&e.push(i)})),e}processColumnGroup(e){var t=e.columns,i=0,s={title:e.definition["title"+(this.colVisProp.charAt(0).toUpperCase()+this.colVisProp.slice(1))]||e.definition.title,column:e,depth:1};if(t.length){if(s.subGroups=[],s.width=0,t.forEach((e=>{var t=this.processColumnGroup(e);t&&(s.width+=t.width,s.subGroups.push(t),t.depth>i&&(i=t.depth))})),s.depth+=i,!s.width)return!1}else{if(!this.columnVisCheck(e))return!1;s.width=1}return s}columnVisCheck(e){var t=e.definition[this.colVisProp];return"function"==typeof t&&(t=t.call(this.table,e.getComponent())),!1!==t&&(e.visible||!e.visible&&t)}headersToExportRows(e){var t=[],i=0,s=[];function o(e,s){var n=i-s;if(void 0===t[s]&&(t[s]=[]),e.height=e.subGroups?1:n-e.depth+1,t[s].push(e),e.height>1)for(let i=1;i1)for(let i=1;ii&&(i=e.depth)})),e.forEach((function(e){o(e,0)})),t.forEach((e=>{var t=[];e.forEach((e=>{if(e){let i=void 0===e.title?"":e.title;t.push(new S(i,e.column.getComponent(),e.width,e.height,e.depth))}else t.push(null)})),s.push(new D("header",t))})),s}bodyToExportRows(e){var t=[],i=[];return this.table.columnManager.columnsByIndex.forEach((e=>{this.columnVisCheck(e)&&t.push(e.getComponent())})),!1!==this.config.columnCalcs&&this.table.modExists("columnCalcs")&&(this.table.modules.columnCalcs.topInitialized&&e.unshift(this.table.modules.columnCalcs.topRow),this.table.modules.columnCalcs.botInitialized&&e.push(this.table.modules.columnCalcs.botRow)),(e=e.filter((e=>{switch(e.type){case"group":return!1!==this.config.rowGroups;case"calc":return!1!==this.config.columnCalcs;case"row":return!(this.table.options.dataTree&&!1===this.config.dataTree&&e.modules.dataTree.parent)}return!0}))).forEach(((e,s)=>{var o=e.getData(this.colVisProp),n=[],r=0;switch(e.type){case"group":r=e.level,n.push(new S(e.key,e.getComponent(),t.length,1));break;case"calc":case"row":t.forEach((e=>{n.push(new S(e._column.getFieldValue(o),e,1,1))})),this.table.options.dataTree&&!1!==this.config.dataTree&&(r=e.modules.dataTree.index)}i.push(new D(e.type,n,e.getComponent(),r))})),i}generateTableElement(e){var t=document.createElement("table"),i=document.createElement("thead"),s=document.createElement("tbody"),o=this.lookupTableStyles(),n=this.table.options["rowFormatter"+(this.colVisProp.charAt(0).toUpperCase()+this.colVisProp.slice(1))],r={};return r.rowFormatter=null!==n?n:this.table.options.rowFormatter,this.table.options.dataTree&&!1!==this.config.dataTree&&this.table.modExists("columnCalcs")&&(r.treeElementField=this.table.modules.dataTree.elementField),r.groupHeader=this.table.options["groupHeader"+(this.colVisProp.charAt(0).toUpperCase()+this.colVisProp.slice(1))],r.groupHeader&&!Array.isArray(r.groupHeader)&&(r.groupHeader=[r.groupHeader]),t.classList.add("tabulator-print-table"),this.mapElementStyles(this.table.columnManager.getHeadersElement(),i,["border-top","border-left","border-right","border-bottom","background-color","color","font-weight","font-family","font-size"]),e.length>1e3&&console.warn("It may take a long time to render an HTML table with more than 1000 rows"),e.forEach(((e,t)=>{let n;switch(e.type){case"header":i.appendChild(this.generateHeaderElement(e,r,o));break;case"group":s.appendChild(this.generateGroupElement(e,r,o));break;case"calc":s.appendChild(this.generateCalcElement(e,r,o));break;case"row":n=this.generateRowElement(e,r,o),this.mapElementStyles(t%2&&o.evenRow?o.evenRow:o.oddRow,n,["border-top","border-left","border-right","border-bottom","color","font-weight","font-family","font-size","background-color"]),s.appendChild(n)}})),i.innerHTML&&t.appendChild(i),t.appendChild(s),this.mapElementStyles(this.table.element,t,["border-top","border-left","border-right","border-bottom"]),t}lookupTableStyles(){var e={};return this.cloneTableStyle&&window.getComputedStyle&&(e.oddRow=this.table.element.querySelector(".tabulator-row-odd:not(.tabulator-group):not(.tabulator-calcs)"),e.evenRow=this.table.element.querySelector(".tabulator-row-even:not(.tabulator-group):not(.tabulator-calcs)"),e.calcRow=this.table.element.querySelector(".tabulator-row.tabulator-calcs"),e.firstRow=this.table.element.querySelector(".tabulator-row:not(.tabulator-group):not(.tabulator-calcs)"),e.firstGroup=this.table.element.getElementsByClassName("tabulator-group")[0],e.firstRow&&(e.styleCells=e.firstRow.getElementsByClassName("tabulator-cell"),e.firstCell=e.styleCells[0],e.lastCell=e.styleCells[e.styleCells.length-1])),e}generateHeaderElement(e,t,i){var s=document.createElement("tr");return e.columns.forEach((e=>{if(e){var t=document.createElement("th"),i=e.component._column.definition.cssClass?e.component._column.definition.cssClass.split(" "):[];t.colSpan=e.width,t.rowSpan=e.height,t.innerHTML=e.value,this.cloneTableStyle&&(t.style.boxSizing="border-box"),i.forEach((function(e){t.classList.add(e)})),this.mapElementStyles(e.component.getElement(),t,["text-align","border-top","border-left","border-right","border-bottom","background-color","color","font-weight","font-family","font-size"]),this.mapElementStyles(e.component._column.contentElement,t,["padding-top","padding-left","padding-right","padding-bottom"]),e.component._column.visible?this.mapElementStyles(e.component.getElement(),t,["width"]):e.component._column.definition.width&&(t.style.width=e.component._column.definition.width+"px"),e.component._column.parent&&this.mapElementStyles(e.component._column.parent.groupElement,t,["border-top"]),s.appendChild(t)}})),s}generateGroupElement(e,t,i){var s=document.createElement("tr"),o=document.createElement("td"),n=e.columns[0];return s.classList.add("tabulator-print-table-row"),t.groupHeader&&t.groupHeader[e.indent]?n.value=t.groupHeader[e.indent](n.value,e.component._group.getRowCount(),e.component._group.getData(),e.component):!1!==t.groupHeader&&(n.value=e.component._group.generator(n.value,e.component._group.getRowCount(),e.component._group.getData(),e.component)),o.colSpan=n.width,o.innerHTML=n.value,s.classList.add("tabulator-print-table-group"),s.classList.add("tabulator-group-level-"+e.indent),n.component.isVisible()&&s.classList.add("tabulator-group-visible"),this.mapElementStyles(i.firstGroup,s,["border-top","border-left","border-right","border-bottom","color","font-weight","font-family","font-size","background-color"]),this.mapElementStyles(i.firstGroup,o,["padding-top","padding-left","padding-right","padding-bottom"]),s.appendChild(o),s}generateCalcElement(e,t,i){var s=this.generateRowElement(e,t,i);return s.classList.add("tabulator-print-table-calcs"),this.mapElementStyles(i.calcRow,s,["border-top","border-left","border-right","border-bottom","color","font-weight","font-family","font-size","background-color"]),s}generateRowElement(e,t,i){var s=document.createElement("tr");if(s.classList.add("tabulator-print-table-row"),e.columns.forEach(((o,n)=>{if(o){var r,a=document.createElement("td"),l=o.component._column,h=this.table.columnManager.findColumnIndex(l),d=o.value,c={modules:{},getValue:function(){return d},getField:function(){return l.definition.field},getElement:function(){return a},getType:function(){return"cell"},getColumn:function(){return l.getComponent()},getData:function(){return e.component.getData()},getRow:function(){return e.component},getComponent:function(){return c},column:l};if((l.definition.cssClass?l.definition.cssClass.split(" "):[]).forEach((function(e){a.classList.add(e)})),this.table.modExists("format")&&!1!==this.config.formatCells)d=this.table.modules.format.formatExportValue(c,this.colVisProp);else switch(typeof d){case"object":d=null!==d?JSON.stringify(d):"";break;case"undefined":d=""}d instanceof Node?a.appendChild(d):a.innerHTML=d,(r=i.styleCells&&i.styleCells[h]?i.styleCells[h]:i.firstCell)&&(this.mapElementStyles(r,a,["padding-top","padding-left","padding-right","padding-bottom","border-top","border-left","border-right","border-bottom","color","font-weight","font-family","font-size","text-align"]),l.definition.align&&(a.style.textAlign=l.definition.align)),this.table.options.dataTree&&!1!==this.config.dataTree&&(t.treeElementField&&t.treeElementField==l.field||!t.treeElementField&&0==n)&&(e.component._row.modules.dataTree.controlEl&&a.insertBefore(e.component._row.modules.dataTree.controlEl.cloneNode(!0),a.firstChild),e.component._row.modules.dataTree.branchEl&&a.insertBefore(e.component._row.modules.dataTree.branchEl.cloneNode(!0),a.firstChild)),s.appendChild(a),c.modules.format&&c.modules.format.renderedCallback&&c.modules.format.renderedCallback()}})),t.rowFormatter&&"row"===e.type&&!1!==this.config.formatCells){Object.assign(e.component).getElement=function(){return s},t.rowFormatter(e.component)}return s}generateHTMLTable(e){var t=document.createElement("div");return t.appendChild(this.generateTableElement(e)),t.innerHTML}getHtml(e,t,i,s){var o=this.generateExportList(i||this.table.options.htmlOutputConfig,t,e,s||"htmlOutput");return this.generateHTMLTable(o)}mapElementStyles(e,t,i){if(this.cloneTableStyle&&e&&t){var s={"background-color":"backgroundColor",color:"fontColor",width:"width","font-weight":"fontWeight","font-family":"fontFamily","font-size":"fontSize","text-align":"textAlign","border-top":"borderTop","border-left":"borderLeft","border-right":"borderRight","border-bottom":"borderBottom","padding-top":"paddingTop","padding-left":"paddingLeft","padding-right":"paddingRight","padding-bottom":"paddingBottom"};if(window.getComputedStyle){var o=window.getComputedStyle(e);i.forEach((function(e){t.style[s[e]]||(t.style[s[e]]=o.getPropertyValue(e))}))}}}}P.moduleName="export";var z={"=":function(e,t,i,s){return t==e},"<":function(e,t,i,s){return t":function(e,t,i,s){return t>e},">=":function(e,t,i,s){return t>=e},"!=":function(e,t,i,s){return t!=e},regex:function(e,t,i,s){return"string"==typeof e&&(e=new RegExp(e)),e.test(t)},like:function(e,t,i,s){return null==e?t===e:null!=t&&String(t).toLowerCase().indexOf(e.toLowerCase())>-1},keywords:function(e,t,i,s){var o=e.toLowerCase().split(void 0===s.separator?" ":s.separator),n=String(null==t?"":t).toLowerCase(),r=[];return o.forEach((e=>{n.includes(e)&&r.push(!0)})),s.matchAll?r.length===o.length:!!r.length},starts:function(e,t,i,s){return null==e?t===e:null!=t&&String(t).toLowerCase().startsWith(e.toLowerCase())},ends:function(e,t,i,s){return null==e?t===e:null!=t&&String(t).toLowerCase().endsWith(e.toLowerCase())},in:function(e,t,i,s){return Array.isArray(e)?!e.length||e.indexOf(t)>-1:(console.warn("Filter Error - filter value is not an array:",e),!1)}};class F extends s{constructor(e){super(e),this.filterList=[],this.headerFilters={},this.headerFilterColumns=[],this.prevHeaderFilterChangeCheck="",this.prevHeaderFilterChangeCheck="{}",this.changed=!1,this.tableInitialized=!1,this.registerTableOption("filterMode","local"),this.registerTableOption("initialFilter",!1),this.registerTableOption("initialHeaderFilter",!1),this.registerTableOption("headerFilterLiveFilterDelay",300),this.registerTableOption("placeholderHeaderFilter",!1),this.registerColumnOption("headerFilter"),this.registerColumnOption("headerFilterPlaceholder"),this.registerColumnOption("headerFilterParams"),this.registerColumnOption("headerFilterEmptyCheck"),this.registerColumnOption("headerFilterFunc"),this.registerColumnOption("headerFilterFuncParams"),this.registerColumnOption("headerFilterLiveFilter"),this.registerTableFunction("searchRows",this.searchRows.bind(this)),this.registerTableFunction("searchData",this.searchData.bind(this)),this.registerTableFunction("setFilter",this.userSetFilter.bind(this)),this.registerTableFunction("refreshFilter",this.userRefreshFilter.bind(this)),this.registerTableFunction("addFilter",this.userAddFilter.bind(this)),this.registerTableFunction("getFilters",this.getFilters.bind(this)),this.registerTableFunction("setHeaderFilterFocus",this.userSetHeaderFilterFocus.bind(this)),this.registerTableFunction("getHeaderFilterValue",this.userGetHeaderFilterValue.bind(this)),this.registerTableFunction("setHeaderFilterValue",this.userSetHeaderFilterValue.bind(this)),this.registerTableFunction("getHeaderFilters",this.getHeaderFilters.bind(this)),this.registerTableFunction("removeFilter",this.userRemoveFilter.bind(this)),this.registerTableFunction("clearFilter",this.userClearFilter.bind(this)),this.registerTableFunction("clearHeaderFilter",this.userClearHeaderFilter.bind(this)),this.registerComponentFunction("column","headerFilterFocus",this.setHeaderFilterFocus.bind(this)),this.registerComponentFunction("column","reloadHeaderFilter",this.reloadHeaderFilter.bind(this)),this.registerComponentFunction("column","getHeaderFilterValue",this.getHeaderFilterValue.bind(this)),this.registerComponentFunction("column","setHeaderFilterValue",this.setHeaderFilterValue.bind(this))}initialize(){this.subscribe("column-init",this.initializeColumnHeaderFilter.bind(this)),this.subscribe("column-width-fit-before",this.hideHeaderFilterElements.bind(this)),this.subscribe("column-width-fit-after",this.showHeaderFilterElements.bind(this)),this.subscribe("table-built",this.tableBuilt.bind(this)),this.subscribe("placeholder",this.generatePlaceholder.bind(this)),"remote"===this.table.options.filterMode&&this.subscribe("data-params",this.remoteFilterParams.bind(this)),this.registerDataHandler(this.filter.bind(this),10)}tableBuilt(){this.table.options.initialFilter&&this.setFilter(this.table.options.initialFilter),this.table.options.initialHeaderFilter&&this.table.options.initialHeaderFilter.forEach((e=>{var t=this.table.columnManager.findColumn(e.field);if(!t)return console.warn("Column Filter Error - No matching column found:",e.field),!1;this.setHeaderFilterValue(t,e.value)})),this.tableInitialized=!0}remoteFilterParams(e,t,i,s){return s.filter=this.getFilters(!0,!0),s}generatePlaceholder(e){if(this.table.options.placeholderHeaderFilter&&Object.keys(this.headerFilters).length)return this.table.options.placeholderHeaderFilter}userSetFilter(e,t,i,s){this.setFilter(e,t,i,s),this.refreshFilter()}userRefreshFilter(){this.refreshFilter()}userAddFilter(e,t,i,s){this.addFilter(e,t,i,s),this.refreshFilter()}userSetHeaderFilterFocus(e){var t=this.table.columnManager.findColumn(e);if(!t)return console.warn("Column Filter Focus Error - No matching column found:",e),!1;this.setHeaderFilterFocus(t)}userGetHeaderFilterValue(e){var t=this.table.columnManager.findColumn(e);if(t)return this.getHeaderFilterValue(t);console.warn("Column Filter Error - No matching column found:",e)}userSetHeaderFilterValue(e,t){var i=this.table.columnManager.findColumn(e);if(!i)return console.warn("Column Filter Error - No matching column found:",e),!1;this.setHeaderFilterValue(i,t)}userRemoveFilter(e,t,i){this.removeFilter(e,t,i),this.refreshFilter()}userClearFilter(e){this.clearFilter(e),this.refreshFilter()}userClearHeaderFilter(){this.clearHeaderFilter(),this.refreshFilter()}searchRows(e,t,i){return this.search("rows",e,t,i)}searchData(e,t,i){return this.search("data",e,t,i)}initializeColumnHeaderFilter(e){e.definition.headerFilter&&this.initializeColumn(e)}initializeColumn(e,t){var i=this,s=e.getField();e.modules.filter={success:function(t){var o,n="input"==e.modules.filter.tagType&&"text"==e.modules.filter.attrType||"textarea"==e.modules.filter.tagType?"partial":"match",r="",a="";if(void 0===e.modules.filter.prevSuccess||e.modules.filter.prevSuccess!==t){if(e.modules.filter.prevSuccess=t,e.modules.filter.emptyFunc(t))delete i.headerFilters[s];else{switch(e.modules.filter.value=t,typeof e.definition.headerFilterFunc){case"string":F.filters[e.definition.headerFilterFunc]?(r=e.definition.headerFilterFunc,o=function(i){var s=e.definition.headerFilterFuncParams||{},o=e.getFieldValue(i);return s="function"==typeof s?s(t,o,i):s,F.filters[e.definition.headerFilterFunc](t,o,i,s)}):console.warn("Header Filter Error - Matching filter function not found: ",e.definition.headerFilterFunc);break;case"function":r=o=function(i){var s=e.definition.headerFilterFuncParams||{},o=e.getFieldValue(i);return s="function"==typeof s?s(t,o,i):s,e.definition.headerFilterFunc(t,o,i,s)}}if(!o)if("partial"===n)o=function(i){var s=e.getFieldValue(i);return null!=s&&String(s).toLowerCase().indexOf(String(t).toLowerCase())>-1},r="like";else o=function(i){return e.getFieldValue(i)==t},r="=";i.headerFilters[s]={value:t,func:o,type:r}}e.modules.filter.value=t,a=JSON.stringify(i.headerFilters),i.prevHeaderFilterChangeCheck!==a&&(i.prevHeaderFilterChangeCheck=a,i.trackChanges(),i.refreshFilter())}return!0},attrType:!1,tagType:!1,emptyFunc:!1},this.generateHeaderFilterElement(e)}generateHeaderFilterElement(e,t,i){var s,o,n,r,a,l,h,d,c=this,u=e.modules.filter.success,p=e.getField();if(e.modules.filter.value=t,e.modules.filter.headerElement&&e.modules.filter.headerElement.parentNode&&e.contentElement.removeChild(e.modules.filter.headerElement.parentNode),p){switch(e.modules.filter.emptyFunc=e.definition.headerFilterEmptyCheck||function(e){return!e&&0!==e},(s=document.createElement("div")).classList.add("tabulator-header-filter"),typeof e.definition.headerFilter){case"string":c.table.modules.edit.editors[e.definition.headerFilter]?(o=c.table.modules.edit.editors[e.definition.headerFilter],"tick"!==e.definition.headerFilter&&"tickCross"!==e.definition.headerFilter||e.definition.headerFilterEmptyCheck||(e.modules.filter.emptyFunc=function(e){return!0!==e&&!1!==e})):console.warn("Filter Error - Cannot build header filter, No such editor found: ",e.definition.editor);break;case"function":o=e.definition.headerFilter;break;case"boolean":e.modules.edit&&e.modules.edit.editor?o=e.modules.edit.editor:e.definition.formatter&&c.table.modules.edit.editors[e.definition.formatter]?(o=c.table.modules.edit.editors[e.definition.formatter],"tick"!==e.definition.formatter&&"tickCross"!==e.definition.formatter||e.definition.headerFilterEmptyCheck||(e.modules.filter.emptyFunc=function(e){return!0!==e&&!1!==e})):o=c.table.modules.edit.editors.input}if(o){if(r={getValue:function(){return void 0!==t?t:""},getField:function(){return e.definition.field},getElement:function(){return s},getColumn:function(){return e.getComponent()},getTable:()=>this.table,getType:()=>"header",getRow:function(){return{normalizeHeight:function(){}}}},h="function"==typeof(h=e.definition.headerFilterParams||{})?h.call(c.table,r):h,!(n=o.call(this.table.modules.edit,r,(function(e){d=e}),u,(function(){}),h)))return void console.warn("Filter Error - Cannot add filter to "+p+" column, editor returned a value of false");if(!(n instanceof Node))return void console.warn("Filter Error - Cannot add filter to "+p+" column, editor should return an instance of Node, the editor returned:",n);c.langBind("headerFilters|columns|"+e.definition.field,(function(t){n.setAttribute("placeholder",void 0!==t&&t?t:e.definition.headerFilterPlaceholder||c.langText("headerFilters|default"))})),n.addEventListener("click",(function(e){e.stopPropagation(),n.focus()})),n.addEventListener("focus",(e=>{var t=this.table.columnManager.contentsElement.scrollLeft;t!==this.table.rowManager.element.scrollLeft&&(this.table.rowManager.scrollHorizontal(t),this.table.columnManager.scrollHorizontal(t))})),a=!1,l=function(e){a&&clearTimeout(a),a=setTimeout((function(){u(n.value)}),c.table.options.headerFilterLiveFilterDelay)},e.modules.filter.headerElement=n,e.modules.filter.attrType=n.hasAttribute("type")?n.getAttribute("type").toLowerCase():"",e.modules.filter.tagType=n.tagName.toLowerCase(),!1!==e.definition.headerFilterLiveFilter&&("autocomplete"!==e.definition.headerFilter&&"tickCross"!==e.definition.headerFilter&&("autocomplete"!==e.definition.editor&&"tickCross"!==e.definition.editor||!0!==e.definition.headerFilter)&&(n.addEventListener("keyup",l),n.addEventListener("search",l),"number"==e.modules.filter.attrType&&n.addEventListener("change",(function(e){u(n.value)})),"text"==e.modules.filter.attrType&&"ie"!==this.table.browser&&n.setAttribute("type","search")),"input"!=e.modules.filter.tagType&&"select"!=e.modules.filter.tagType&&"textarea"!=e.modules.filter.tagType||n.addEventListener("mousedown",(function(e){e.stopPropagation()}))),s.appendChild(n),e.contentElement.appendChild(s),i||c.headerFilterColumns.push(e),d&&d()}}else console.warn("Filter Error - Cannot add header filter, column has no field set:",e.definition.title)}hideHeaderFilterElements(){this.headerFilterColumns.forEach((function(e){e.modules.filter&&e.modules.filter.headerElement&&(e.modules.filter.headerElement.style.display="none")}))}showHeaderFilterElements(){this.headerFilterColumns.forEach((function(e){e.modules.filter&&e.modules.filter.headerElement&&(e.modules.filter.headerElement.style.display="")}))}setHeaderFilterFocus(e){e.modules.filter&&e.modules.filter.headerElement?e.modules.filter.headerElement.focus():console.warn("Column Filter Focus Error - No header filter set on column:",e.getField())}getHeaderFilterValue(e){if(e.modules.filter&&e.modules.filter.headerElement)return e.modules.filter.value;console.warn("Column Filter Error - No header filter set on column:",e.getField())}setHeaderFilterValue(e,t){e&&(e.modules.filter&&e.modules.filter.headerElement?(this.generateHeaderFilterElement(e,t,!0),e.modules.filter.success(t)):console.warn("Column Filter Error - No header filter set on column:",e.getField()))}reloadHeaderFilter(e){e&&(e.modules.filter&&e.modules.filter.headerElement?this.generateHeaderFilterElement(e,e.modules.filter.value,!0):console.warn("Column Filter Error - No header filter set on column:",e.getField()))}refreshFilter(){this.tableInitialized&&("remote"===this.table.options.filterMode?this.reloadData(null,!1,!1):this.refreshData(!0))}trackChanges(){this.changed=!0,this.dispatch("filter-changed")}hasChanged(){var e=this.changed;return this.changed=!1,e}setFilter(e,t,i,s){this.filterList=[],Array.isArray(e)||(e=[{field:e,type:t,value:i,params:s}]),this.addFilter(e)}addFilter(e,t,i,s){var o=!1;Array.isArray(e)||(e=[{field:e,type:t,value:i,params:s}]),e.forEach((e=>{(e=this.findFilter(e))&&(this.filterList.push(e),o=!0)})),o&&this.trackChanges()}findFilter(e){var t;if(Array.isArray(e))return this.findSubFilters(e);var i=!1;return"function"==typeof e.field?i=function(t){return e.field(t,e.type||{})}:F.filters[e.type]?i=(t=this.table.columnManager.getColumnByField(e.field))?function(i){return F.filters[e.type](e.value,t.getFieldValue(i),i,e.params||{})}:function(t){return F.filters[e.type](e.value,t[e.field],t,e.params||{})}:console.warn("Filter Error - No such filter type found, ignoring: ",e.type),e.func=i,!!e.func&&e}findSubFilters(e){var t=[];return e.forEach((e=>{(e=this.findFilter(e))&&t.push(e)})),!!t.length&&t}getFilters(e,t){var i=[];return e&&(i=this.getHeaderFilters()),t&&i.forEach((function(e){"function"==typeof e.type&&(e.type="function")})),i=i.concat(this.filtersToArray(this.filterList,t))}filtersToArray(e,t){var i=[];return e.forEach((e=>{var s;Array.isArray(e)?i.push(this.filtersToArray(e,t)):(s={field:e.field,type:e.type,value:e.value},t&&"function"==typeof s.type&&(s.type="function"),i.push(s))})),i}getHeaderFilters(){var e=[];for(var t in this.headerFilters)e.push({field:t,type:this.headerFilters[t].type,value:this.headerFilters[t].value});return e}removeFilter(e,t,i){Array.isArray(e)||(e=[{field:e,type:t,value:i}]),e.forEach((e=>{var t=-1;(t="object"==typeof e.field?this.filterList.findIndex((t=>e===t)):this.filterList.findIndex((t=>e.field===t.field&&e.type===t.type&&e.value===t.value)))>-1?this.filterList.splice(t,1):console.warn("Filter Error - No matching filter type found, ignoring: ",e.type)})),this.trackChanges()}clearFilter(e){this.filterList=[],e&&this.clearHeaderFilter(),this.trackChanges()}clearHeaderFilter(){this.headerFilters={},this.prevHeaderFilterChangeCheck="{}",this.headerFilterColumns.forEach((e=>{void 0!==e.modules.filter.value&&delete e.modules.filter.value,e.modules.filter.prevSuccess=void 0,this.reloadHeaderFilter(e)})),this.trackChanges()}search(e,t,i,s){var o=[],n=[];return Array.isArray(t)||(t=[{field:t,type:i,value:s}]),t.forEach((e=>{(e=this.findFilter(e))&&n.push(e)})),this.table.rowManager.rows.forEach((t=>{var i=!0;n.forEach((e=>{this.filterRecurse(e,t.getData())||(i=!1)})),i&&o.push("data"===e?t.getData("data"):t.getComponent())})),o}filter(e,t){var i=[],s=[];return this.subscribedExternal("dataFiltering")&&this.dispatchExternal("dataFiltering",this.getFilters(!0)),"remote"!==this.table.options.filterMode&&(this.filterList.length||Object.keys(this.headerFilters).length)?e.forEach((e=>{this.filterRow(e)&&i.push(e)})):i=e.slice(0),this.subscribedExternal("dataFiltered")&&(i.forEach((e=>{s.push(e.getComponent())})),this.dispatchExternal("dataFiltered",this.getFilters(!0),s)),i}filterRow(e,t){var i=!0,s=e.getData();for(var o in this.filterList.forEach((e=>{this.filterRecurse(e,s)||(i=!1)})),this.headerFilters)this.headerFilters[o].func(s)||(i=!1);return i}filterRecurse(e,t){var i=!1;return Array.isArray(e)?e.forEach((e=>{this.filterRecurse(e,t)&&(i=!0)})):i=e.func(t),i}}F.moduleName="filter",F.filters=z;var H={plaintext:function(e,t,i){return this.emptyToSpace(this.sanitizeHTML(e.getValue()))},html:function(e,t,i){return e.getValue()},textarea:function(e,t,i){return e.getElement().style.whiteSpace="pre-wrap",this.emptyToSpace(this.sanitizeHTML(e.getValue()))},money:function(e,t,i){var s,o,n,r,a,l=parseFloat(e.getValue()),h="",d=t.decimal||".",c=t.thousand||",",u=t.negativeSign||"-",p=t.symbol||"",m=!!t.symbolAfter,g=void 0!==t.precision?t.precision:2;if(isNaN(l))return this.emptyToSpace(this.sanitizeHTML(e.getValue()));if(l<0&&(l=Math.abs(l),h=u),s=!1!==g?l.toFixed(g):l,o=(s=String(s).split("."))[0],n=s.length>1?d+s[1]:"",!1!==t.thousand)for(r=/(\d+)(\d{3})/;r.test(o);)o=o.replace(r,"$1"+c+"$2");return a=o+n,!0===h?(a="("+a+")",m?a+p:p+a):m?h+a+p:h+p+a},link:function(e,t,i){var s,o=e.getValue(),n=t.urlPrefix||"",r=t.download,a=o,l=document.createElement("a");if(t.labelField&&(s=e.getData(),a=function e(t,i){var s=i[t.shift()];return t.length&&"object"==typeof s?e(t,s):s}(t.labelField.split(this.table.options.nestedFieldSeparator),s)),t.label)switch(typeof t.label){case"string":a=t.label;break;case"function":a=t.label(e)}if(a){if(t.urlField&&(o=(s=e.getData())[t.urlField]),t.url)switch(typeof t.url){case"string":o=t.url;break;case"function":o=t.url(e)}return l.setAttribute("href",n+o),t.target&&l.setAttribute("target",t.target),t.download&&(r="function"==typeof r?r(e):!0===r?"":r,l.setAttribute("download",r)),l.innerHTML=this.emptyToSpace(this.sanitizeHTML(a)),l}return" "},image:function(e,t,i){var s=document.createElement("img"),o=e.getValue();switch(t.urlPrefix&&(o=t.urlPrefix+e.getValue()),t.urlSuffix&&(o+=t.urlSuffix),s.setAttribute("src",o),typeof t.height){case"number":s.style.height=t.height+"px";break;case"string":s.style.height=t.height}switch(typeof t.width){case"number":s.style.width=t.width+"px";break;case"string":s.style.width=t.width}return s.addEventListener("load",(function(){e.getRow().normalizeHeight()})),s},tickCross:function(e,t,i){var s=e.getValue(),o=e.getElement(),n=t.allowEmpty,r=t.allowTruthy,a=Object.keys(t).includes("trueValue"),l=void 0!==t.tickElement?t.tickElement:'',h=void 0!==t.crossElement?t.crossElement:'';return a&&s===t.trueValue||!a&&(r&&s||!0===s||"true"===s||"True"===s||1===s||"1"===s)?(o.setAttribute("aria-checked",!0),l||""):!n||"null"!==s&&""!==s&&null!=s?(o.setAttribute("aria-checked",!1),h||""):(o.setAttribute("aria-checked","mixed"),"")},datetime:function(e,t,i){var s,o=window.DateTime||luxon.DateTime,n=t.inputFormat||"yyyy-MM-dd HH:mm:ss",r=t.outputFormat||"dd/MM/yyyy HH:mm:ss",a=void 0!==t.invalidPlaceholder?t.invalidPlaceholder:"",l=e.getValue();if(void 0!==o)return(s=o.isDateTime(l)?l:"iso"===n?o.fromISO(String(l)):o.fromFormat(String(l),n)).isValid?(t.timezone&&(s=s.setZone(t.timezone)),s.toFormat(r)):!0!==a&&l?"function"==typeof a?a(l):a:l;console.error("Format Error - 'datetime' formatter is dependant on luxon.js")},datetimediff:function(e,t,i){var s,o=window.DateTime||luxon.DateTime,n=t.inputFormat||"yyyy-MM-dd HH:mm:ss",r=void 0!==t.invalidPlaceholder?t.invalidPlaceholder:"",a=void 0!==t.suffix&&t.suffix,l=void 0!==t.unit?t.unit:"days",h=void 0!==t.humanize&&t.humanize,d=void 0!==t.date?t.date:o.now(),c=e.getValue();if(void 0!==o)return(s=o.isDateTime(c)?c:"iso"===n?o.fromISO(String(c)):o.fromFormat(String(c),n)).isValid?h?s.diff(d,l).toHuman()+(a?" "+a:""):parseInt(s.diff(d,l)[l])+(a?" "+a:""):!0===r?c:"function"==typeof r?r(c):r;console.error("Format Error - 'datetimediff' formatter is dependant on luxon.js")},lookup:function(e,t,i){var s=e.getValue();return void 0===t[s]?(console.warn("Missing display value for "+s),s):t[s]},star:function(e,t,i){var s=e.getValue(),o=e.getElement(),n=t&&t.stars?t.stars:5,r=document.createElement("span"),a=document.createElementNS("http://www.w3.org/2000/svg","svg");r.style.verticalAlign="middle",a.setAttribute("width","14"),a.setAttribute("height","14"),a.setAttribute("viewBox","0 0 512 512"),a.setAttribute("xml:space","preserve"),a.style.padding="0 1px",s=s&&!isNaN(s)?parseInt(s):0,s=Math.max(0,Math.min(s,n));for(var l=1;l<=n;l++){var h=a.cloneNode(!0);h.innerHTML=l<=s?'':'',r.appendChild(h)}return o.style.whiteSpace="nowrap",o.style.overflow="hidden",o.style.textOverflow="ellipsis",o.setAttribute("aria-label",s),r},traffic:function(e,t,i){var s,o,n=this.sanitizeHTML(e.getValue())||0,r=document.createElement("span"),a=t&&t.max?t.max:100,l=t&&t.min?t.min:0,h=t&&void 0!==t.color?t.color:["red","orange","green"],d="#666666";if(!isNaN(n)&&void 0!==e.getValue()){switch(r.classList.add("tabulator-traffic-light"),o=parseFloat(n)<=a?parseFloat(n):a,o=parseFloat(o)>=l?parseFloat(o):l,s=(a-l)/100,o=Math.round((o-l)/s),typeof h){case"string":d=h;break;case"function":d=h(n);break;case"object":if(Array.isArray(h)){var c=100/h.length,u=Math.floor(o/c);u=Math.min(u,h.length-1),d=h[u=Math.max(u,0)];break}}return r.style.backgroundColor=d,r}},progress:function(e,t={},i){var s,o,n,r,a,l=this.sanitizeHTML(e.getValue())||0,h=e.getElement(),d=t.max?t.max:100,c=t.min?t.min:0,u=t.legendAlign?t.legendAlign:"center";switch(o=parseFloat(l)<=d?parseFloat(l):d,o=parseFloat(o)>=c?parseFloat(o):c,s=(d-c)/100,o=Math.round((o-c)/s),typeof t.color){case"string":n=t.color;break;case"function":n=t.color(l);break;case"object":if(Array.isArray(t.color)){let e=100/t.color.length,i=Math.floor(o/e);i=Math.min(i,t.color.length-1),i=Math.max(i,0),n=t.color[i];break}default:n="#2DC214"}switch(typeof t.legend){case"string":r=t.legend;break;case"function":r=t.legend(l);break;case"boolean":r=l;break;default:r=!1}switch(typeof t.legendColor){case"string":a=t.legendColor;break;case"function":a=t.legendColor(l);break;case"object":if(Array.isArray(t.legendColor)){let e=100/t.legendColor.length,i=Math.floor(o/e);i=Math.min(i,t.legendColor.length-1),i=Math.max(i,0),a=t.legendColor[i]}break;default:a="#000"}h.style.minWidth="30px",h.style.position="relative",h.setAttribute("aria-label",o);var m=document.createElement("div");m.style.display="inline-block",m.style.width=o+"%",m.style.backgroundColor=n,m.style.height="100%",m.setAttribute("data-max",d),m.setAttribute("data-min",c);var g=document.createElement("div");if(g.style.position="relative",g.style.width="100%",g.style.height="100%",r){var b=document.createElement("div");b.style.position="absolute",b.style.top=0,b.style.left=0,b.style.textAlign=u,b.style.width="100%",b.style.color=a,b.innerHTML=r}return i((function(){if(!(e instanceof p)){var t=document.createElement("div");t.style.position="absolute",t.style.top="4px",t.style.bottom="4px",t.style.left="4px",t.style.right="4px",h.appendChild(t),h=t}h.appendChild(g),g.appendChild(m),r&&g.appendChild(b)})),""},color:function(e,t,i){return e.getElement().style.backgroundColor=this.sanitizeHTML(e.getValue()),""},buttonTick:function(e,t,i){return''},buttonCross:function(e,t,i){return''},rownum:function(e,t,i){var s=document.createElement("span");return e.getRow().watchPosition((e=>{s.innerText=e})),s},handle:function(e,t,i){return e.getElement().classList.add("tabulator-row-handle"),"
"},responsiveCollapse:function(e,t,i){var s=document.createElement("div"),o=e.getRow()._row.modules.responsiveLayout;function n(e){var t=o.element;o.open=e,t&&(o.open?(s.classList.add("open"),t.style.display=""):(s.classList.remove("open"),t.style.display="none"))}return s.classList.add("tabulator-responsive-collapse-toggle"),s.innerHTML='\n \n \n\n\n\n \n',e.getElement().classList.add("tabulator-row-handle"),s.addEventListener("click",(function(t){t.stopImmediatePropagation(),n(!o.open),e.getTable().rowManager.adjustTableSize()})),n(o.open),s},rowSelection:function(e,t,i){var s=document.createElement("input"),o=!1;if(s.type="checkbox",s.setAttribute("aria-label","Select Row"),this.table.modExists("selectRow",!0))if(s.addEventListener("click",(e=>{e.stopPropagation()})),"function"==typeof e.getRow){var n=e.getRow();n instanceof v?(s.addEventListener("change",(e=>{"click"===this.table.options.selectableRangeMode&&o?o=!1:n.toggleSelect()})),"click"===this.table.options.selectableRangeMode&&s.addEventListener("click",(e=>{o=!0,this.table.modules.selectRow.handleComplexRowClick(n._row,e)})),s.checked=n.isSelected&&n.isSelected(),this.table.modules.selectRow.registerRowSelectCheckbox(n,s)):s=""}else s.addEventListener("change",(e=>{this.table.modules.selectRow.selectedRows.length?this.table.deselectRow():this.table.selectRow(t.rowRange)})),this.table.modules.selectRow.registerHeaderSelectCheckbox(s);return s}};class O extends s{constructor(e){super(e),this.registerColumnOption("formatter"),this.registerColumnOption("formatterParams"),this.registerColumnOption("formatterPrint"),this.registerColumnOption("formatterPrintParams"),this.registerColumnOption("formatterClipboard"),this.registerColumnOption("formatterClipboardParams"),this.registerColumnOption("formatterHtmlOutput"),this.registerColumnOption("formatterHtmlOutputParams"),this.registerColumnOption("titleFormatter"),this.registerColumnOption("titleFormatterParams")}initialize(){this.subscribe("cell-format",this.formatValue.bind(this)),this.subscribe("cell-rendered",this.cellRendered.bind(this)),this.subscribe("column-layout",this.initializeColumn.bind(this)),this.subscribe("column-format",this.formatHeader.bind(this))}initializeColumn(e){e.modules.format=this.lookupFormatter(e,""),void 0!==e.definition.formatterPrint&&(e.modules.format.print=this.lookupFormatter(e,"Print")),void 0!==e.definition.formatterClipboard&&(e.modules.format.clipboard=this.lookupFormatter(e,"Clipboard")),void 0!==e.definition.formatterHtmlOutput&&(e.modules.format.htmlOutput=this.lookupFormatter(e,"HtmlOutput"))}lookupFormatter(e,t){var i={params:e.definition["formatter"+t+"Params"]||{}},s=e.definition["formatter"+t];switch(typeof s){case"string":O.formatters[s]?i.formatter=O.formatters[s]:(console.warn("Formatter Error - No such formatter found: ",s),i.formatter=O.formatters.plaintext);break;case"function":i.formatter=s;break;default:i.formatter=O.formatters.plaintext}return i}cellRendered(e){e.modules.format&&e.modules.format.renderedCallback&&!e.modules.format.rendered&&(e.modules.format.renderedCallback(),e.modules.format.rendered=!0)}formatHeader(e,t,i){var s,o,n,r;return e.definition.titleFormatter?(s=this.getFormatter(e.definition.titleFormatter),n=t=>{e.titleFormatterRendered=t},r={getValue:function(){return t},getElement:function(){return i},getType:function(){return"header"},getColumn:function(){return e.getComponent()},getTable:()=>this.table},o="function"==typeof(o=e.definition.titleFormatterParams||{})?o():o,s.call(this,r,o,n)):t}formatValue(e){var t=e.getComponent(),i="function"==typeof e.column.modules.format.params?e.column.modules.format.params(t):e.column.modules.format.params;return e.column.modules.format.formatter.call(this,t,i,(function(t){e.modules.format||(e.modules.format={}),e.modules.format.renderedCallback=t,e.modules.format.rendered=!1}))}formatExportValue(e,t){var i,s=e.column.modules.format[t];if(s){function o(t){e.modules.format||(e.modules.format={}),e.modules.format.renderedCallback=t,e.modules.format.rendered=!1}return i="function"==typeof s.params?s.params(e.getComponent()):s.params,s.formatter.call(this,e.getComponent(),i,o)}return this.formatValue(e)}sanitizeHTML(e){if(e){var t={"&":"&","<":"<",">":">",'"':""","'":"'","/":"/","`":"`","=":"="};return String(e).replace(/[&<>"'`=/]/g,(function(e){return t[e]}))}return e}emptyToSpace(e){return null==e||""===e?" ":e}getFormatter(e){switch(typeof e){case"string":O.formatters[e]?e=O.formatters[e]:(console.warn("Formatter Error - No such formatter found: ",e),e=O.formatters.plaintext);break;case"function":break;default:e=O.formatters.plaintext}return e}}O.moduleName="format",O.formatters=H;class A extends s{constructor(e){super(e),this.leftColumns=[],this.rightColumns=[],this.initializationMode="left",this.active=!1,this.blocked=!0,this.registerColumnOption("frozen")}reset(){this.initializationMode="left",this.leftColumns=[],this.rightColumns=[],this.active=!1}initialize(){this.subscribe("cell-layout",this.layoutCell.bind(this)),this.subscribe("column-init",this.initializeColumn.bind(this)),this.subscribe("column-width",this.layout.bind(this)),this.subscribe("row-layout-after",this.layoutRow.bind(this)),this.subscribe("table-layout",this.layout.bind(this)),this.subscribe("columns-loading",this.reset.bind(this)),this.subscribe("column-add",this.reinitializeColumns.bind(this)),this.subscribe("column-delete",this.reinitializeColumns.bind(this)),this.subscribe("table-redraw",this.layout.bind(this)),this.subscribe("layout-refreshing",this.blockLayout.bind(this)),this.subscribe("layout-refreshed",this.unblockLayout.bind(this)),this.subscribe("scrollbar-vertical",this.adjustForScrollbar.bind(this))}blockLayout(){this.blocked=!0}unblockLayout(){this.blocked=!1}layoutCell(e){this.layoutElement(e.element,e.column)}reinitializeColumns(){this.reset(),this.table.columnManager.columnsByIndex.forEach((e=>{this.initializeColumn(e)}))}initializeColumn(e){var t={margin:0,edge:!1};e.isGroup||(this.frozenCheck(e)?(t.position=this.initializationMode,"left"==this.initializationMode?this.leftColumns.push(e):this.rightColumns.unshift(e),this.active=!0,e.modules.frozen=t):this.initializationMode="right")}frozenCheck(e){return e.parent.isGroup&&e.definition.frozen&&console.warn("Frozen Column Error - Parent column group must be frozen, not individual columns or sub column groups"),e.parent.isGroup?this.frozenCheck(e.parent):e.definition.frozen}layoutCalcRows(){this.table.modExists("columnCalcs")&&(this.table.modules.columnCalcs.topInitialized&&this.table.modules.columnCalcs.topRow&&this.layoutRow(this.table.modules.columnCalcs.topRow),this.table.modules.columnCalcs.botInitialized&&this.table.modules.columnCalcs.botRow&&this.layoutRow(this.table.modules.columnCalcs.botRow),this.table.modExists("groupRows")&&this.layoutGroupCalcs(this.table.modules.groupRows.getGroups()))}layoutGroupCalcs(e){e.forEach((e=>{e.calcs.top&&this.layoutRow(e.calcs.top),e.calcs.bottom&&this.layoutRow(e.calcs.bottom),e.groupList&&e.groupList.length&&this.layoutGroupCalcs(e.groupList)}))}layoutColumnPosition(e){var t=[],i=0,s=0;this.leftColumns.forEach(((s,o)=>{if(s.modules.frozen.marginValue=i,s.modules.frozen.margin=s.modules.frozen.marginValue+"px",s.visible&&(i+=s.getWidth()),o==this.leftColumns.length-1?s.modules.frozen.edge=!0:s.modules.frozen.edge=!1,s.parent.isGroup){var n=this.getColGroupParentElement(s);t.includes(n)||(this.layoutElement(n,s),t.push(n)),s.modules.frozen.edge&&n.classList.add("tabulator-frozen-"+s.modules.frozen.position)}else this.layoutElement(s.getElement(),s);e&&s.cells.forEach((e=>{this.layoutElement(e.getElement(!0),s)}))})),this.rightColumns.forEach(((t,i)=>{t.modules.frozen.marginValue=s,t.modules.frozen.margin=t.modules.frozen.marginValue+"px",t.visible&&(s+=t.getWidth()),i==this.rightColumns.length-1?t.modules.frozen.edge=!0:t.modules.frozen.edge=!1,t.parent.isGroup?this.layoutElement(this.getColGroupParentElement(t),t):this.layoutElement(t.getElement(),t),e&&t.cells.forEach((e=>{this.layoutElement(e.getElement(!0),t)}))}))}getColGroupParentElement(e){return e.parent.isGroup?this.getColGroupParentElement(e.parent):e.getElement()}layout(){this.active&&!this.blocked&&(this.layoutColumnPosition(),this.reinitializeRows(),this.layoutCalcRows())}reinitializeRows(){var e=this.table.rowManager.getVisibleRows(!0);this.table.rowManager.getRows().filter((t=>!e.includes(t))).forEach((e=>{e.deinitialize()})),e.forEach((e=>{"row"===e.type&&this.layoutRow(e)}))}layoutRow(e){"fitDataFill"===this.table.options.layout&&this.rightColumns.length&&(this.table.rowManager.getTableElement().style.minWidth="calc(100% - "+this.rightMargin+")"),this.leftColumns.forEach((t=>{var i=e.getCell(t);i&&this.layoutElement(i.getElement(!0),t)})),this.rightColumns.forEach((t=>{var i=e.getCell(t);i&&this.layoutElement(i.getElement(!0),t)}))}layoutElement(e,t){var i;t.modules.frozen&&e&&(e.style.position="sticky",i=this.table.rtl?"left"===t.modules.frozen.position?"right":"left":t.modules.frozen.position,e.style[i]=t.modules.frozen.margin,e.classList.add("tabulator-frozen"),t.modules.frozen.edge&&e.classList.add("tabulator-frozen-"+t.modules.frozen.position))}adjustForScrollbar(e){this.rightColumns.length&&(this.table.columnManager.getContentsElement().style.width="calc(100% - "+e+"px)")}_calcSpace(e,t){var i=0;for(let s=0;s{this.initializeRow(e)}))}initializeRow(e){var t=this.table.options.frozenRows,i=typeof t;"number"===i?e.getPosition()&&e.getPosition()+this.rows.length<=t&&this.freezeRow(e):"function"===i?t.call(this.table,e.getComponent())&&this.freezeRow(e):Array.isArray(t)&&t.includes(e.data[this.options("frozenRowsField")])&&this.freezeRow(e)}isRowFrozen(e){return this.rows.indexOf(e)>-1}isFrozen(){return!!this.rows.length}visibleRows(e,t){return this.rows.forEach((e=>{t.push(e)})),t}getRows(e){var t=e.slice(0);return this.rows.forEach((function(e){var i=t.indexOf(e);i>-1&&t.splice(i,1)})),t}freezeRow(e){e.modules.frozen?console.warn("Freeze Error - Row is already frozen"):(e.modules.frozen=!0,this.topElement.appendChild(e.getElement()),e.initialize(),e.normalizeHeight(),this.rows.push(e),this.refreshData(!1,"display"),this.table.rowManager.adjustTableSize(),this.styleRows())}unfreezeRow(e){e.modules.frozen?(e.modules.frozen=!1,this.detachRow(e),this.table.rowManager.adjustTableSize(),this.refreshData(!1,"display"),this.rows.length&&this.styleRows()):console.warn("Freeze Error - Row is already unfrozen")}detachRow(e){var t=this.rows.indexOf(e);if(t>-1){var i=e.getElement();i.parentNode&&i.parentNode.removeChild(i),this.rows.splice(t,1)}}styleRows(e){this.rows.forEach(((e,t)=>{this.table.rowManager.styleRow(e,t)}))}}_.moduleName="frozenRows";class B{constructor(e){return this._group=e,this.type="GroupComponent",new Proxy(this,{get:function(e,t,i){return void 0!==e[t]?e[t]:e._group.groupManager.table.componentFunctionBinder.handle("group",e._group,t)}})}getKey(){return this._group.key}getField(){return this._group.field}getElement(){return this._group.element}getRows(){return this._group.getRows(!0)}getSubGroups(){return this._group.getSubGroups(!0)}getParentGroup(){return!!this._group.parent&&this._group.parent.getComponent()}isVisible(){return this._group.visible}show(){this._group.show()}hide(){this._group.hide()}toggle(){this._group.toggleVisibility()}scrollTo(e,t){return this._group.groupManager.table.rowManager.scrollToRow(this._group,e,t)}_getSelf(){return this._group}getTable(){return this._group.groupManager.table}}class I{constructor(e,t,i,s,o,n,r){this.groupManager=e,this.parent=t,this.key=s,this.level=i,this.field=o,this.hasSubGroups=i{e.modules&&delete e.modules.group}))),this.element=!1,this.arrowElement=!1,this.elementContents=!1}createElements(){var e=document.createElement("div");e.classList.add("tabulator-arrow"),this.element=document.createElement("div"),this.element.classList.add("tabulator-row"),this.element.classList.add("tabulator-group"),this.element.classList.add("tabulator-group-level-"+this.level),this.element.setAttribute("role","rowgroup"),this.arrowElement=document.createElement("div"),this.arrowElement.classList.add("tabulator-group-toggle"),this.arrowElement.appendChild(e),!1!==this.groupManager.table.options.movableRows&&this.groupManager.table.modExists("moveRow")&&this.groupManager.table.modules.moveRow.initializeGroupHeader(this)}createValueGroups(){var e=this.level+1;this.groupManager.allowedValues&&this.groupManager.allowedValues[e]&&this.groupManager.allowedValues[e].forEach((t=>{this._createGroup(t,e)}))}addBindings(){this.groupManager.table.options.groupToggleElement&&("arrow"==this.groupManager.table.options.groupToggleElement?this.arrowElement:this.element).addEventListener("click",(e=>{"arrow"===this.groupManager.table.options.groupToggleElement&&(e.stopPropagation(),e.stopImmediatePropagation()),setTimeout((()=>{this.toggleVisibility()}))}))}_createGroup(e,t){var i=t+"_"+e,s=new I(this.groupManager,this,t,e,this.groupManager.groupIDLookups[t].field,this.groupManager.headerGenerator[t]||this.groupManager.headerGenerator[0],!!this.old&&this.old.groups[i]);this.groups[i]=s,this.groupList.push(s)}_addRowToGroup(e){var t=this.level+1;if(this.hasSubGroups){var i=this.groupManager.groupIDLookups[t].func(e.getData()),s=t+"_"+i;this.groupManager.allowedValues&&this.groupManager.allowedValues[t]?this.groups[s]&&this.groups[s].addRow(e):(this.groups[s]||this._createGroup(i,t),this.groups[s].addRow(e))}}_addRow(e){this.rows.push(e),e.modules.group=this}insertRow(e,t,i){var s=this.conformRowData({});e.updateData(s);var o=this.rows.indexOf(t);o>-1?i?this.rows.splice(o+1,0,e):this.rows.splice(o,0,e):i?this.rows.push(e):this.rows.unshift(e),e.modules.group=this,this.groupManager.table.modExists("columnCalcs")&&"table"!=this.groupManager.table.options.columnCalcs&&this.groupManager.table.modules.columnCalcs.recalcGroup(this),this.groupManager.updateGroupRows(!0)}scrollHeader(e){this.arrowElement&&(this.arrowElement.style.marginLeft=e,this.groupList.forEach((function(t){t.scrollHeader(e)})))}getRowIndex(e){}conformRowData(e){return this.field?e[this.field]=this.key:console.warn("Data Conforming Error - Cannot conform row data to match new group as groupBy is a function"),this.parent&&(e=this.parent.conformRowData(e)),e}removeRow(e){var t=this.rows.indexOf(e),i=e.getElement();t>-1&&this.rows.splice(t,1),this.groupManager.table.options.groupValues||this.rows.length?(i.parentNode&&i.parentNode.removeChild(i),this.groupManager.blockRedraw||(this.generateGroupHeaderContents(),this.groupManager.table.modExists("columnCalcs")&&"table"!=this.groupManager.table.options.columnCalcs&&this.groupManager.table.modules.columnCalcs.recalcGroup(this))):(this.parent?this.parent.removeGroup(this):this.groupManager.removeGroup(this),this.groupManager.updateGroupRows(!0))}removeGroup(e){var t,i=e.level+"_"+e.key;this.groups[i]&&(delete this.groups[i],(t=this.groupList.indexOf(e))>-1&&this.groupList.splice(t,1),this.groupList.length||(this.parent?this.parent.removeGroup(this):this.groupManager.removeGroup(this)))}getHeadersAndRows(){var e=[];return e.push(this),this._visSet(),this.calcs.top&&(this.calcs.top.detachElement(),this.calcs.top.deleteCells()),this.calcs.bottom&&(this.calcs.bottom.detachElement(),this.calcs.bottom.deleteCells()),this.visible?this.groupList.length?this.groupList.forEach((function(t){e=e.concat(t.getHeadersAndRows())})):("table"!=this.groupManager.table.options.columnCalcs&&this.groupManager.table.modExists("columnCalcs")&&this.groupManager.table.modules.columnCalcs.hasTopCalcs()&&(this.calcs.top=this.groupManager.table.modules.columnCalcs.generateTopRow(this.rows),e.push(this.calcs.top)),e=e.concat(this.rows),"table"!=this.groupManager.table.options.columnCalcs&&this.groupManager.table.modExists("columnCalcs")&&this.groupManager.table.modules.columnCalcs.hasBottomCalcs()&&(this.calcs.bottom=this.groupManager.table.modules.columnCalcs.generateBottomRow(this.rows),e.push(this.calcs.bottom))):this.groupList.length||"table"==this.groupManager.table.options.columnCalcs||this.groupManager.table.modExists("columnCalcs")&&(this.groupManager.table.modules.columnCalcs.hasTopCalcs()&&this.groupManager.table.options.groupClosedShowCalcs&&(this.calcs.top=this.groupManager.table.modules.columnCalcs.generateTopRow(this.rows),e.push(this.calcs.top)),this.groupManager.table.modules.columnCalcs.hasBottomCalcs()&&this.groupManager.table.options.groupClosedShowCalcs&&(this.calcs.bottom=this.groupManager.table.modules.columnCalcs.generateBottomRow(this.rows),e.push(this.calcs.bottom))),e}getData(e,t){var i=[];return this._visSet(),(!e||e&&this.visible)&&this.rows.forEach((e=>{i.push(e.getData(t||"data"))})),i}getRowCount(){var e=0;return this.groupList.length?this.groupList.forEach((t=>{e+=t.getRowCount()})):e=this.rows.length,e}toggleVisibility(){this.visible?this.hide():this.show()}hide(){this.visible=!1,"basic"!=this.groupManager.table.rowManager.getRenderMode()||this.groupManager.table.options.pagination||(this.element.classList.remove("tabulator-group-visible"),this.groupList.length?this.groupList.forEach((e=>{e.getHeadersAndRows().forEach((e=>{e.detachElement()}))})):this.rows.forEach((e=>{var t=e.getElement();t.parentNode.removeChild(t)}))),this.groupManager.updateGroupRows(!0),this.groupManager.table.externalEvents.dispatch("groupVisibilityChanged",this.getComponent(),!1)}show(){if(this.visible=!0,"basic"!=this.groupManager.table.rowManager.getRenderMode()||this.groupManager.table.options.pagination)this.groupManager.updateGroupRows(!0);else{this.element.classList.add("tabulator-group-visible");var e=this.generateElement();this.groupList.length?this.groupList.forEach((t=>{t.getHeadersAndRows().forEach((t=>{var i=t.getElement();e.parentNode.insertBefore(i,e.nextSibling),t.initialize(),e=i}))})):this.rows.forEach((t=>{var i=t.getElement();e.parentNode.insertBefore(i,e.nextSibling),t.initialize(),e=i})),this.groupManager.updateGroupRows(!0)}this.groupManager.table.externalEvents.dispatch("groupVisibilityChanged",this.getComponent(),!0)}_visSet(){var e=[];"function"==typeof this.visible&&(this.rows.forEach((function(t){e.push(t.getData())})),this.visible=this.visible(this.key,this.getRowCount(),e,this.getComponent()))}getRowGroup(e){var t=!1;return this.groupList.length?this.groupList.forEach((function(i){var s=i.getRowGroup(e);s&&(t=s)})):this.rows.find((function(t){return t===e}))&&(t=this),t}getSubGroups(e){var t=[];return this.groupList.forEach((function(i){t.push(e?i.getComponent():i)})),t}getRows(e,t){var i=[];return t&&this.groupList.length?this.groupList.forEach((s=>{i=i.concat(s.getRows(e,t))})):this.rows.forEach((function(t){i.push(e?t.getComponent():t)})),i}generateGroupHeaderContents(){var e=[];for(this.getRows(!1,!0).forEach((function(t){e.push(t.getData())})),this.elementContents=this.generator(this.key,this.getRowCount(),e,this.getComponent());this.element.firstChild;)this.element.removeChild(this.element.firstChild);"string"==typeof this.elementContents?this.element.innerHTML=this.elementContents:this.element.appendChild(this.elementContents),this.element.insertBefore(this.arrowElement,this.element.firstChild)}getPath(e=[]){return e.unshift(this.key),this.parent&&this.parent.getPath(e),e}getElement(){return this.elementContents?this.element:this.generateElement()}generateElement(){this.addBindings=!1,this._visSet(),this.visible?this.element.classList.add("tabulator-group-visible"):this.element.classList.remove("tabulator-group-visible");for(var e=0;ei.length&&console.warn("Error creating group headers, groupHeader array is shorter than groupBy array"),this.headerGenerator=[function(){return""}],this.startOpen=[function(){return!1}],this.langBind("groups|item",((e,t)=>{this.headerGenerator[0]=(i,s,o)=>(void 0===i?"":i)+"("+s+" "+(1===s?e:t.groups.items)+")"})),this.groupIDLookups=[],e)this.table.modExists("columnCalcs")&&"table"!=this.table.options.columnCalcs&&"both"!=this.table.options.columnCalcs&&this.table.modules.columnCalcs.removeCalcs();else if(this.table.modExists("columnCalcs")&&"group"!=this.table.options.columnCalcs)this.table.columnManager.getRealColumns().forEach((e=>{e.definition.topCalc&&this.table.modules.columnCalcs.initializeTopRow(),e.definition.bottomCalc&&this.table.modules.columnCalcs.initializeBottomRow()}));Array.isArray(e)||(e=[e]),e.forEach(((e,t)=>{var i,s;i="function"==typeof e?e:(s=this.table.columnManager.getColumnByField(e))?function(e){return s.getFieldValue(e)}:function(t){return t[e]},this.groupIDLookups.push({field:"function"!=typeof e&&e,func:i,values:!!this.allowedValues&&this.allowedValues[t]})})),t&&(Array.isArray(t)||(t=[t]),t.forEach((e=>{})),this.startOpen=t),i&&(this.headerGenerator=Array.isArray(i)?i:[i])}else this.groupList=[],this.groups={}}rowSample(e,t){if(this.table.options.groupBy){var i=this.getGroups(!1)[0];t.push(i.getRows(!1)[0])}return t}virtualRenderFill(){var e=this.table.rowManager.tableElement,t=this.table.rowManager.getVisibleRows();if(!this.table.options.groupBy)return t;t=t.filter((e=>"group"!==e.type)),e.style.minWidth=t.length?"":this.table.columnManager.getWidth()+"px"}rowAddingIndex(e,t,i){if(this.table.options.groupBy){this.assignRowToGroup(e);var s=e.modules.group.rows;return s.length>1&&(!t||t&&-1==s.indexOf(t)?i?s[0]!==e&&(t=s[0],this.table.rowManager.moveRowInArray(e.modules.group.rows,e,t,!i)):s[s.length-1]!==e&&(t=s[s.length-1],this.table.rowManager.moveRowInArray(e.modules.group.rows,e,t,!i)):this.table.rowManager.moveRowInArray(e.modules.group.rows,e,t,!i)),t}}trackChanges(){this.dispatch("group-changed")}setGroupBy(e){this.table.options.groupBy=e,this.initialized||this.initialize(),this.configureGroupSetup(),!e&&this.table.modExists("columnCalcs")&&!0===this.table.options.columnCalcs&&this.table.modules.columnCalcs.reinitializeCalcs(),this.refreshData(),this.trackChanges()}setGroupValues(e){this.table.options.groupValues=e,this.configureGroupSetup(),this.refreshData(),this.trackChanges()}setGroupStartOpen(e){this.table.options.groupStartOpen=e,this.configureGroupSetup(),this.table.options.groupBy?(this.refreshData(),this.trackChanges()):console.warn("Grouping Update - cant refresh view, no groups have been set")}setGroupHeader(e){this.table.options.groupHeader=e,this.configureGroupSetup(),this.table.options.groupBy?(this.refreshData(),this.trackChanges()):console.warn("Grouping Update - cant refresh view, no groups have been set")}userGetGroups(e){return this.getGroups(!0)}userGetGroupedData(){return this.table.options.groupBy?this.getGroupedData():this.getData()}rowGetGroup(e){return!!e.modules.group&&e.modules.group.getComponent()}rowMoving(e,t,i){if(this.table.options.groupBy){!i&&t instanceof I&&(t=this.table.rowManager.prevDisplayRow(e)||t);var s=t instanceof I?t:t.modules.group,o=e instanceof I?e:e.modules.group;s===o?this.table.rowManager.moveRowInArray(s.rows,e,t,i):(o&&o.removeRow(e),s.insertRow(e,t,i))}}rowDeleting(e){this.table.options.groupBy&&e.modules.group&&e.modules.group.removeRow(e)}rowsUpdated(e){this.table.options.groupBy&&this.updateGroupRows(!0)}cellUpdated(e){this.table.options.groupBy&&this.reassignRowToGroup(e.row)}getRows(e){return this.table.options.groupBy&&this.groupIDLookups.length?(this.dispatchExternal("dataGrouping"),this.generateGroups(e),this.subscribedExternal("dataGrouped")&&this.dispatchExternal("dataGrouped",this.getGroups(!0)),this.updateGroupRows()):e.slice(0)}getGroups(e){var t=[];return this.groupList.forEach((function(i){t.push(e?i.getComponent():i)})),t}getChildGroups(e){var t=[];return e||(e=this),e.groupList.forEach((e=>{e.groupList.length?t=t.concat(this.getChildGroups(e)):t.push(e)})),t}wipe(){this.table.options.groupBy&&(this.groupList.forEach((function(e){e.wipe()})),this.groupList=[],this.groups={})}pullGroupListData(e){var t=[];return e.forEach((e=>{var i={level:0,rowCount:0,headerContent:""},s=[];e.hasSubGroups?(s=this.pullGroupListData(e.groupList),i.level=e.level,i.rowCount=s.length-e.groupList.length,i.headerContent=e.generator(e.key,i.rowCount,e.rows,e),t.push(i),t=t.concat(s)):(i.level=e.level,i.headerContent=e.generator(e.key,e.rows.length,e.rows,e),i.rowCount=e.getRows().length,t.push(i),e.getRows().forEach((e=>{t.push(e.getData("data"))})))})),t}getGroupedData(){return this.pullGroupListData(this.groupList)}getRowGroup(e){var t=!1;return this.options("dataTree")&&(e=this.table.modules.dataTree.getTreeParentRoot(e)),this.groupList.forEach((i=>{var s=i.getRowGroup(e);s&&(t=s)})),t}countGroups(){return this.groupList.length}generateGroups(e){var t=this.groups;this.groups={},this.groupList=[],this.allowedValues&&this.allowedValues[0]?(this.allowedValues[0].forEach((e=>{this.createGroup(e,0,t)})),e.forEach((e=>{this.assignRowToExistingGroup(e,t)}))):e.forEach((e=>{this.assignRowToGroup(e,t)})),Object.values(t).forEach((e=>{e.wipe(!0)}))}createGroup(e,t,i){var s,o=t+"_"+e;i=i||[],s=new I(this,!1,t,e,this.groupIDLookups[0].field,this.headerGenerator[0],i[o]),this.groups[o]=s,this.groupList.push(s)}assignRowToExistingGroup(e,t){var i="0_"+this.groupIDLookups[0].func(e.getData());this.groups[i]&&this.groups[i].addRow(e)}assignRowToGroup(e,t){var i=this.groupIDLookups[0].func(e.getData()),s=!this.groups["0_"+i];return s&&this.createGroup(i,0,t),this.groups["0_"+i].addRow(e),!s}reassignRowToGroup(e){if("row"===e.type){var t=e.modules.group,i=t.getPath(),s=this.getExpectedPath(e);i.length==s.length&&i.every(((e,t)=>e===s[t]))||(t.removeRow(e),this.assignRowToGroup(e,this.groups),this.refreshData(!0))}}getExpectedPath(e){var t=[],i=e.getData();return this.groupIDLookups.forEach((e=>{t.push(e.func(i))})),t}updateGroupRows(e){var t=[];return this.blockRedraw||(this.groupList.forEach((e=>{t=t.concat(e.getHeadersAndRows())})),e&&this.refreshData(!0)),t}scrollHeaders(e){this.table.options.groupBy&&("virtual"===this.table.options.renderHorizontal&&(e-=this.table.columnManager.renderer.vDomPadLeft),e+="px",this.groupList.forEach((t=>{t.scrollHeader(e)})))}removeGroup(e){var t,i=e.level+"_"+e.key;this.groups[i]&&(delete this.groups[i],(t=this.groupList.indexOf(e))>-1&&this.groupList.splice(t,1))}checkBasicModeGroupHeaderWidth(){var e=this.table.rowManager.tableElement,t=!0;this.table.rowManager.getDisplayRows().forEach(((i,s)=>{this.table.rowManager.styleRow(i,s),e.appendChild(i.getElement()),i.initialize(!0),"group"!==i.type&&(t=!1)})),e.style.minWidth=t?this.table.columnManager.getWidth()+"px":""}}V.moduleName="groupRows";class N extends s{constructor(e){super(e),this.history=[],this.index=-1,this.registerTableOption("history",!1)}initialize(){this.table.options.history&&(this.subscribe("cell-value-updated",this.cellUpdated.bind(this)),this.subscribe("cell-delete",this.clearComponentHistory.bind(this)),this.subscribe("row-delete",this.rowDeleted.bind(this)),this.subscribe("rows-wipe",this.clear.bind(this)),this.subscribe("row-added",this.rowAdded.bind(this)),this.subscribe("row-move",this.rowMoved.bind(this))),this.registerTableFunction("undo",this.undo.bind(this)),this.registerTableFunction("redo",this.redo.bind(this)),this.registerTableFunction("getHistoryUndoSize",this.getHistoryUndoSize.bind(this)),this.registerTableFunction("getHistoryRedoSize",this.getHistoryRedoSize.bind(this)),this.registerTableFunction("clearHistory",this.clear.bind(this))}rowMoved(e,t,i){this.action("rowMove",e,{posFrom:e.getPosition(),posTo:t.getPosition(),to:t,after:i})}rowAdded(e,t,i,s){this.action("rowAdd",e,{data:t,pos:i,index:s})}rowDeleted(e){var t,i;this.table.options.groupBy?(t=(i=e.getComponent().getGroup()._getSelf().rows).indexOf(e))&&(t=i[t-1]):(t=e.table.rowManager.getRowIndex(e))&&(t=e.table.rowManager.rows[t-1]),this.action("rowDelete",e,{data:e.getData(),pos:!t,index:t})}cellUpdated(e){this.action("cellEdit",e,{oldValue:e.oldValue,newValue:e.value})}clear(){this.history=[],this.index=-1}action(e,t,i){this.history=this.history.slice(0,this.index+1),this.history.push({type:e,component:t,data:i}),this.index++}getHistoryUndoSize(){return this.index+1}getHistoryRedoSize(){return this.history.length-(this.index+1)}clearComponentHistory(e){var t=this.history.findIndex((function(t){return t.component===e}));t>-1&&(this.history.splice(t,1),t<=this.index&&this.index--,this.clearComponentHistory(e))}undo(){if(this.index>-1){let e=this.history[this.index];return N.undoers[e.type].call(this,e),this.index--,this.dispatchExternal("historyUndo",e.type,e.component.getComponent(),e.data),!0}return console.warn("History Undo Error - No more history to undo"),!1}redo(){if(this.history.length-1>this.index){this.index++;let e=this.history[this.index];return N.redoers[e.type].call(this,e),this.dispatchExternal("historyRedo",e.type,e.component.getComponent(),e.data),!0}return console.warn("History Redo Error - No more history to redo"),!1}_rebindRow(e,t){this.history.forEach((function(i){if(i.component instanceof w)i.component===e&&(i.component=t);else if(i.component instanceof m&&i.component.row===e){var s=i.component.column.getField();s&&(i.component=t.getCell(s))}}))}}N.moduleName="history",N.undoers={cellEdit:function(e){e.component.setValueProcessData(e.data.oldValue),e.component.cellRendered()},rowAdd:function(e){e.component.deleteActual()},rowDelete:function(e){var t=this.table.rowManager.addRowActual(e.data.data,e.data.pos,e.data.index);this.table.options.groupBy&&this.table.modExists("groupRows")&&this.table.modules.groupRows.updateGroupRows(!0),this._rebindRow(e.component,t)},rowMove:function(e){var t=e.data.posFrom-e.data.posTo>0;this.table.rowManager.moveRowActual(e.component,this.table.rowManager.getRowFromPosition(e.data.posFrom),t),this.table.rowManager.regenerateRowPositions(),this.table.rowManager.reRenderInPosition()}},N.redoers={cellEdit:function(e){e.component.setValueProcessData(e.data.newValue),e.component.cellRendered()},rowAdd:function(e){var t=this.table.rowManager.addRowActual(e.data.data,e.data.pos,e.data.index);this.table.options.groupBy&&this.table.modExists("groupRows")&&this.table.modules.groupRows.updateGroupRows(!0),this._rebindRow(e.component,t)},rowDelete:function(e){e.component.deleteActual()},rowMove:function(e){this.table.rowManager.moveRowActual(e.component,this.table.rowManager.getRowFromPosition(e.data.posTo),e.data.after),this.table.rowManager.regenerateRowPositions(),this.table.rowManager.reRenderInPosition()}};class W extends s{constructor(e){super(e),this.fieldIndex=[],this.hasIndex=!1}initialize(){this.tableElementCheck()}tableElementCheck(){this.table.originalElement&&"TABLE"===this.table.originalElement.tagName&&(this.table.originalElement.childNodes.length?this.parseTable():console.warn("Unable to parse data from empty table tag, Tabulator should be initialized on a div tag unless importing data from a table element."))}parseTable(){var e=this.table.originalElement,t=this.table.options,i=e.getElementsByTagName("th"),s=e.getElementsByTagName("tbody")[0],o=[];this.hasIndex=!1,this.dispatchExternal("htmlImporting"),s=s?s.getElementsByTagName("tr"):[],this._extractOptions(e,t),i.length?this._extractHeaders(i,s):this._generateBlankHeaders(i,s);for(var n=0;n{n[e.toLowerCase()]=e})),s){var a,l=s[r];l&&"object"==typeof l&&l.name&&0===l.name.indexOf("tabulator-")&&(a=l.name.replace("tabulator-",""),void 0!==n[a]&&(t[n[a]]=this._attribValue(l.value)))}}_attribValue(e){return"true"===e||"false"!==e&&e}_findCol(e){return this.table.options.columns.find((t=>t.title===e))||!1}_extractHeaders(e,t){for(var i=0;i(console.error("Import Error:",e||"Unable to import data"),Promise.reject(e))))}lookupImporter(e){var t;return e||(e=this.table.options.importFormat),(t="string"==typeof e?G.importers[e]:e)||console.error("Import Error - Importer not found:",e),t}importFromFile(e,t){var i=this.lookupImporter(e);if(i)return this.pickFile(t).then(this.importData.bind(this,i)).then(this.structureData.bind(this)).then(this.setData.bind(this)).catch((e=>(console.error("Import Error:",e||"Unable to import file"),Promise.reject(e))))}pickFile(e){return new Promise(((t,i)=>{var s=document.createElement("input");s.type="file",s.accept=e,s.addEventListener("change",(e=>{var o=s.files[0],n=new FileReader;switch(this.table.options.importReader){case"buffer":n.readAsArrayBuffer(o);break;case"binary":n.readAsBinaryString(o);break;case"url":n.readAsDataURL(o);break;default:n.readAsText(o)}n.onload=e=>{t(n.result)},n.onerror=e=>{console.warn("File Load Error - Unable to read file"),i()}})),s.click()}))}importData(e,t){var i=e.call(this.table,t);return i instanceof Promise?i:i?Promise.resolve(i):Promise.reject()}structureData(e){return Array.isArray(e)&&e.length&&Array.isArray(e[0])?this.table.options.autoColumns?this.structureArrayToObject(e):this.structureArrayToColumns(e):e}structureArrayToObject(e){var t=e.shift();return e.map((e=>{var i={};return t.forEach(((t,s)=>{i[t]=e[s]})),i}))}structureArrayToColumns(e){var t=[],i=this.table.getColumns();return i[0]&&e[0][0]&&i[0].getDefinition().title===e[0][0]&&e.shift(),e.forEach((e=>{var s={};e.forEach(((e,t)=>{var o=i[t];o&&(s[o.getField()]=e)})),t.push(s)})),t}setData(e){return this.table.setData(e)}}G.moduleName="import",G.importers=j;class U extends s{constructor(e){super(e),this.eventMap={rowClick:"row-click",rowDblClick:"row-dblclick",rowContext:"row-contextmenu",rowMouseEnter:"row-mouseenter",rowMouseLeave:"row-mouseleave",rowMouseOver:"row-mouseover",rowMouseOut:"row-mouseout",rowMouseMove:"row-mousemove",rowMouseDown:"row-mousedown",rowMouseUp:"row-mouseup",rowTap:"row",rowDblTap:"row",rowTapHold:"row",cellClick:"cell-click",cellDblClick:"cell-dblclick",cellContext:"cell-contextmenu",cellMouseEnter:"cell-mouseenter",cellMouseLeave:"cell-mouseleave",cellMouseOver:"cell-mouseover",cellMouseOut:"cell-mouseout",cellMouseMove:"cell-mousemove",cellMouseDown:"cell-mousedown",cellMouseUp:"cell-mouseup",cellTap:"cell",cellDblTap:"cell",cellTapHold:"cell",headerClick:"column-click",headerDblClick:"column-dblclick",headerContext:"column-contextmenu",headerMouseEnter:"column-mouseenter",headerMouseLeave:"column-mouseleave",headerMouseOver:"column-mouseover",headerMouseOut:"column-mouseout",headerMouseMove:"column-mousemove",headerMouseDown:"column-mousedown",headerMouseUp:"column-mouseup",headerTap:"column",headerDblTap:"column",headerTapHold:"column",groupClick:"group-click",groupDblClick:"group-dblclick",groupContext:"group-contextmenu",groupMouseEnter:"group-mouseenter",groupMouseLeave:"group-mouseleave",groupMouseOver:"group-mouseover",groupMouseOut:"group-mouseout",groupMouseMove:"group-mousemove",groupMouseDown:"group-mousedown",groupMouseUp:"group-mouseup",groupTap:"group",groupDblTap:"group",groupTapHold:"group"},this.subscribers={},this.touchSubscribers={},this.columnSubscribers={},this.touchWatchers={row:{tap:null,tapDbl:null,tapHold:null},cell:{tap:null,tapDbl:null,tapHold:null},column:{tap:null,tapDbl:null,tapHold:null},group:{tap:null,tapDbl:null,tapHold:null}},this.registerColumnOption("headerClick"),this.registerColumnOption("headerDblClick"),this.registerColumnOption("headerContext"),this.registerColumnOption("headerMouseEnter"),this.registerColumnOption("headerMouseLeave"),this.registerColumnOption("headerMouseOver"),this.registerColumnOption("headerMouseOut"),this.registerColumnOption("headerMouseMove"),this.registerColumnOption("headerMouseDown"),this.registerColumnOption("headerMouseUp"),this.registerColumnOption("headerTap"),this.registerColumnOption("headerDblTap"),this.registerColumnOption("headerTapHold"),this.registerColumnOption("cellClick"),this.registerColumnOption("cellDblClick"),this.registerColumnOption("cellContext"),this.registerColumnOption("cellMouseEnter"),this.registerColumnOption("cellMouseLeave"),this.registerColumnOption("cellMouseOver"),this.registerColumnOption("cellMouseOut"),this.registerColumnOption("cellMouseMove"),this.registerColumnOption("cellMouseDown"),this.registerColumnOption("cellMouseUp"),this.registerColumnOption("cellTap"),this.registerColumnOption("cellDblTap"),this.registerColumnOption("cellTapHold")}initialize(){this.initializeExternalEvents(),this.subscribe("column-init",this.initializeColumn.bind(this)),this.subscribe("cell-dblclick",this.cellContentsSelectionFixer.bind(this)),this.subscribe("scroll-horizontal",this.clearTouchWatchers.bind(this)),this.subscribe("scroll-vertical",this.clearTouchWatchers.bind(this))}clearTouchWatchers(){Object.values(this.touchWatchers).forEach((e=>{for(let t in e)e[t]=null}))}cellContentsSelectionFixer(e,t){var i;if(!this.table.modExists("edit")||this.table.modules.edit.currentCell!==t){e.preventDefault();try{document.selection?((i=document.body.createTextRange()).moveToElementText(t.getElement()),i.select()):window.getSelection&&((i=document.createRange()).selectNode(t.getElement()),window.getSelection().removeAllRanges(),window.getSelection().addRange(i))}catch(e){}}}initializeExternalEvents(){for(let e in this.eventMap)this.subscriptionChangeExternal(e,this.subscriptionChanged.bind(this,e))}subscriptionChanged(e,t){t?this.subscribers[e]||(this.eventMap[e].includes("-")?(this.subscribers[e]=this.handle.bind(this,e),this.subscribe(this.eventMap[e],this.subscribers[e])):this.subscribeTouchEvents(e)):this.eventMap[e].includes("-")?!this.subscribers[e]||this.columnSubscribers[e]||this.subscribedExternal(e)||(this.unsubscribe(this.eventMap[e],this.subscribers[e]),delete this.subscribers[e]):this.unsubscribeTouchEvents(e)}subscribeTouchEvents(e){var t=this.eventMap[e];this.touchSubscribers[t+"-touchstart"]||(this.touchSubscribers[t+"-touchstart"]=this.handleTouch.bind(this,t,"start"),this.touchSubscribers[t+"-touchend"]=this.handleTouch.bind(this,t,"end"),this.subscribe(t+"-touchstart",this.touchSubscribers[t+"-touchstart"]),this.subscribe(t+"-touchend",this.touchSubscribers[t+"-touchend"])),this.subscribers[e]=!0}unsubscribeTouchEvents(e){var t=!0,i=this.eventMap[e];if(this.subscribers[e]&&!this.subscribedExternal(e)){delete this.subscribers[e];for(let e in this.eventMap)this.eventMap[e]===i&&this.subscribers[e]&&(t=!1);t&&(this.unsubscribe(i+"-touchstart",this.touchSubscribers[i+"-touchstart"]),this.unsubscribe(i+"-touchend",this.touchSubscribers[i+"-touchend"]),delete this.touchSubscribers[i+"-touchstart"],delete this.touchSubscribers[i+"-touchend"])}}initializeColumn(e){var t=e.definition;for(let i in this.eventMap)t[i]&&(this.subscriptionChanged(i,!0),this.columnSubscribers[i]||(this.columnSubscribers[i]=[]),this.columnSubscribers[i].push(e))}handle(e,t,i){this.dispatchEvent(e,t,i)}handleTouch(e,t,i,s){var o=this.touchWatchers[e];switch("column"===e&&(e="header"),t){case"start":o.tap=!0,clearTimeout(o.tapHold),o.tapHold=setTimeout((()=>{clearTimeout(o.tapHold),o.tapHold=null,o.tap=null,clearTimeout(o.tapDbl),o.tapDbl=null,this.dispatchEvent(e+"TapHold",i,s)}),1e3);break;case"end":o.tap&&(o.tap=null,this.dispatchEvent(e+"Tap",i,s)),o.tapDbl?(clearTimeout(o.tapDbl),o.tapDbl=null,this.dispatchEvent(e+"DblTap",i,s)):o.tapDbl=setTimeout((()=>{clearTimeout(o.tapDbl),o.tapDbl=null}),300),clearTimeout(o.tapHold),o.tapHold=null}}dispatchEvent(e,t,i){var s,o=i.getComponent();this.columnSubscribers[e]&&(i instanceof m?s=i.column.definition[e]:i instanceof f&&(s=i.definition[e]),s&&s(t,o)),this.dispatchExternal(e,t,o)}}U.moduleName="interaction";class X extends s{constructor(e){super(e),this.watchKeys=null,this.pressedKeys=null,this.keyupBinding=!1,this.keydownBinding=!1,this.registerTableOption("keybindings",{}),this.registerTableOption("tabEndNewRow",!1)}initialize(){var e=this.table.options.keybindings,t={};this.watchKeys={},this.pressedKeys=[],!1!==e&&(Object.assign(t,X.bindings),Object.assign(t,e),this.mapBindings(t),this.bindEvents()),this.subscribe("table-destroy",this.clearBindings.bind(this))}mapBindings(e){for(let t in e)X.actions[t]?e[t]&&("object"!=typeof e[t]&&(e[t]=[e[t]]),e[t].forEach((e=>{(Array.isArray(e)?e:[e]).forEach((e=>{this.mapBinding(t,e)}))}))):console.warn("Key Binding Error - no such action:",t)}mapBinding(e,t){var i={action:X.actions[e],keys:[],ctrl:!1,shift:!1,meta:!1};t.toString().toLowerCase().split(" ").join("").split("+").forEach((e=>{switch(e){case"ctrl":i.ctrl=!0;break;case"shift":i.shift=!0;break;case"meta":i.meta=!0;break;default:e=isNaN(e)?e.toUpperCase().charCodeAt(0):parseInt(e),i.keys.push(e),this.watchKeys[e]||(this.watchKeys[e]=[]),this.watchKeys[e].push(i)}}))}bindEvents(){var e=this;this.keyupBinding=function(t){var i=t.keyCode,s=e.watchKeys[i];s&&(e.pressedKeys.push(i),s.forEach((function(i){e.checkBinding(t,i)})))},this.keydownBinding=function(t){var i=t.keyCode;if(e.watchKeys[i]){var s=e.pressedKeys.indexOf(i);s>-1&&e.pressedKeys.splice(s,1)}},this.table.element.addEventListener("keydown",this.keyupBinding),this.table.element.addEventListener("keyup",this.keydownBinding)}clearBindings(){this.keyupBinding&&this.table.element.removeEventListener("keydown",this.keyupBinding),this.keydownBinding&&this.table.element.removeEventListener("keyup",this.keydownBinding)}checkBinding(e,t){var i=!0;return e.ctrlKey==t.ctrl&&e.shiftKey==t.shift&&e.metaKey==t.meta&&(t.keys.forEach((e=>{-1==this.pressedKeys.indexOf(e)&&(i=!1)})),i&&t.action.call(this,e),!0)}}X.moduleName="keybindings",X.bindings={navPrev:"shift + 9",navNext:9,navUp:38,navDown:40,scrollPageUp:33,scrollPageDown:34,scrollToStart:36,scrollToEnd:35,undo:["ctrl + 90","meta + 90"],redo:["ctrl + 89","meta + 89"],copyToClipboard:["ctrl + 67","meta + 67"]},X.actions={keyBlock:function(e){e.stopPropagation(),e.preventDefault()},scrollPageUp:function(e){var t=this.table.rowManager,i=t.scrollTop-t.element.clientHeight;e.preventDefault(),t.displayRowsCount&&(i>=0?t.element.scrollTop=i:t.scrollToRow(t.getDisplayRows()[0])),this.table.element.focus()},scrollPageDown:function(e){var t=this.table.rowManager,i=t.scrollTop+t.element.clientHeight,s=t.element.scrollHeight;e.preventDefault(),t.displayRowsCount&&(i<=s?t.element.scrollTop=i:t.scrollToRow(t.getDisplayRows()[t.displayRowsCount-1])),this.table.element.focus()},scrollToStart:function(e){var t=this.table.rowManager;e.preventDefault(),t.displayRowsCount&&t.scrollToRow(t.getDisplayRows()[0]),this.table.element.focus()},scrollToEnd:function(e){var t=this.table.rowManager;e.preventDefault(),t.displayRowsCount&&t.scrollToRow(t.getDisplayRows()[t.displayRowsCount-1]),this.table.element.focus()},navPrev:function(e){this.dispatch("keybinding-nav-prev",e)},navNext:function(e){this.dispatch("keybinding-nav-next",e)},navLeft:function(e){this.dispatch("keybinding-nav-left",e)},navRight:function(e){this.dispatch("keybinding-nav-right",e)},navUp:function(e){this.dispatch("keybinding-nav-up",e)},navDown:function(e){this.dispatch("keybinding-nav-down",e)},undo:function(e){this.table.options.history&&this.table.modExists("history")&&this.table.modExists("edit")&&(this.table.modules.edit.currentCell||(e.preventDefault(),this.table.modules.history.undo()))},redo:function(e){this.table.options.history&&this.table.modExists("history")&&this.table.modExists("edit")&&(this.table.modules.edit.currentCell||(e.preventDefault(),this.table.modules.history.redo()))},copyToClipboard:function(e){this.table.modules.edit.currentCell||this.table.modExists("clipboard",!0)&&this.table.modules.clipboard.copy(!1,!0)}};class q extends s{constructor(e){super(e),this.menuContainer=null,this.nestedMenuBlock=!1,this.currentComponent=null,this.rootPopup=null,this.columnSubscribers={},this.registerTableOption("menuContainer",void 0),this.registerTableOption("rowContextMenu",!1),this.registerTableOption("rowClickMenu",!1),this.registerTableOption("rowDblClickMenu",!1),this.registerTableOption("groupContextMenu",!1),this.registerTableOption("groupClickMenu",!1),this.registerTableOption("groupDblClickMenu",!1),this.registerColumnOption("headerContextMenu"),this.registerColumnOption("headerClickMenu"),this.registerColumnOption("headerDblClickMenu"),this.registerColumnOption("headerMenu"),this.registerColumnOption("headerMenuIcon"),this.registerColumnOption("contextMenu"),this.registerColumnOption("clickMenu"),this.registerColumnOption("dblClickMenu")}initialize(){this.deprecatedOptionsCheck(),this.initializeRowWatchers(),this.initializeGroupWatchers(),this.subscribe("column-init",this.initializeColumn.bind(this))}deprecatedOptionsCheck(){this.deprecationCheck("menuContainer","popupContainer")||(this.table.options.popupContainer=this.table.options.menuContainer)}initializeRowWatchers(){this.table.options.rowContextMenu&&(this.subscribe("row-contextmenu",this.loadMenuEvent.bind(this,this.table.options.rowContextMenu)),this.table.on("rowTapHold",this.loadMenuEvent.bind(this,this.table.options.rowContextMenu))),this.table.options.rowClickMenu&&this.subscribe("row-click",this.loadMenuEvent.bind(this,this.table.options.rowClickMenu)),this.table.options.rowDblClickMenu&&this.subscribe("row-dblclick",this.loadMenuEvent.bind(this,this.table.options.rowDblClickMenu))}initializeGroupWatchers(){this.table.options.groupContextMenu&&(this.subscribe("group-contextmenu",this.loadMenuEvent.bind(this,this.table.options.groupContextMenu)),this.table.on("groupTapHold",this.loadMenuEvent.bind(this,this.table.options.groupContextMenu))),this.table.options.groupClickMenu&&this.subscribe("group-click",this.loadMenuEvent.bind(this,this.table.options.groupClickMenu)),this.table.options.groupDblClickMenu&&this.subscribe("group-dblclick",this.loadMenuEvent.bind(this,this.table.options.groupDblClickMenu))}initializeColumn(e){var t=e.definition;t.headerContextMenu&&!this.columnSubscribers.headerContextMenu&&(this.columnSubscribers.headerContextMenu=this.loadMenuTableColumnEvent.bind(this,"headerContextMenu"),this.subscribe("column-contextmenu",this.columnSubscribers.headerContextMenu),this.table.on("headerTapHold",this.loadMenuTableColumnEvent.bind(this,"headerContextMenu"))),t.headerClickMenu&&!this.columnSubscribers.headerClickMenu&&(this.columnSubscribers.headerClickMenu=this.loadMenuTableColumnEvent.bind(this,"headerClickMenu"),this.subscribe("column-click",this.columnSubscribers.headerClickMenu)),t.headerDblClickMenu&&!this.columnSubscribers.headerDblClickMenu&&(this.columnSubscribers.headerDblClickMenu=this.loadMenuTableColumnEvent.bind(this,"headerDblClickMenu"),this.subscribe("column-dblclick",this.columnSubscribers.headerDblClickMenu)),t.headerMenu&&this.initializeColumnHeaderMenu(e),t.contextMenu&&!this.columnSubscribers.contextMenu&&(this.columnSubscribers.contextMenu=this.loadMenuTableCellEvent.bind(this,"contextMenu"),this.subscribe("cell-contextmenu",this.columnSubscribers.contextMenu),this.table.on("cellTapHold",this.loadMenuTableCellEvent.bind(this,"contextMenu"))),t.clickMenu&&!this.columnSubscribers.clickMenu&&(this.columnSubscribers.clickMenu=this.loadMenuTableCellEvent.bind(this,"clickMenu"),this.subscribe("cell-click",this.columnSubscribers.clickMenu)),t.dblClickMenu&&!this.columnSubscribers.dblClickMenu&&(this.columnSubscribers.dblClickMenu=this.loadMenuTableCellEvent.bind(this,"dblClickMenu"),this.subscribe("cell-dblclick",this.columnSubscribers.dblClickMenu))}initializeColumnHeaderMenu(e){var t,i=e.definition.headerMenuIcon;(t=document.createElement("span")).classList.add("tabulator-header-popup-button"),i?("function"==typeof i&&(i=i(e.getComponent())),i instanceof HTMLElement?t.appendChild(i):t.innerHTML=i):t.innerHTML="⋮",t.addEventListener("click",(t=>{t.stopPropagation(),t.preventDefault(),this.loadMenuEvent(e.definition.headerMenu,t,e)})),e.titleElement.insertBefore(t,e.titleElement.firstChild)}loadMenuTableCellEvent(e,t,i){i._cell&&(i=i._cell),i.column.definition[e]&&this.loadMenuEvent(i.column.definition[e],t,i)}loadMenuTableColumnEvent(e,t,i){i._column&&(i=i._column),i.definition[e]&&this.loadMenuEvent(i.definition[e],t,i)}loadMenuEvent(e,t,i){i._group?i=i._group:i._row&&(i=i._row),e="function"==typeof e?e.call(this.table,t,i.getComponent()):e,this.loadMenu(t,i,e)}loadMenu(e,t,i,s,o){var n,r=!(e instanceof MouseEvent),a=document.createElement("div");if(a.classList.add("tabulator-menu"),r||e.preventDefault(),i&&i.length){if(s)n=o.child(a);else{if(this.nestedMenuBlock){if(this.rootPopup)return}else this.nestedMenuBlock=setTimeout((()=>{this.nestedMenuBlock=!1}),100);this.rootPopup&&this.rootPopup.hide(),this.rootPopup=n=this.popup(a)}i.forEach((e=>{var i=document.createElement("div"),s=e.label,o=e.disabled;e.separator?i.classList.add("tabulator-menu-separator"):(i.classList.add("tabulator-menu-item"),"function"==typeof s&&(s=s.call(this.table,t.getComponent())),s instanceof Node?i.appendChild(s):i.innerHTML=s,"function"==typeof o&&(o=o.call(this.table,t.getComponent())),o?(i.classList.add("tabulator-menu-item-disabled"),i.addEventListener("click",(e=>{e.stopPropagation()}))):e.menu&&e.menu.length?i.addEventListener("click",(s=>{s.stopPropagation(),this.loadMenu(s,t,e.menu,i,n)})):e.action&&i.addEventListener("click",(i=>{e.action(i,t.getComponent())})),e.menu&&e.menu.length&&i.classList.add("tabulator-menu-item-submenu")),a.appendChild(i)})),a.addEventListener("click",(e=>{this.rootPopup&&this.rootPopup.hide()})),n.show(s||e),n===this.rootPopup&&(this.rootPopup.hideOnBlur((()=>{this.rootPopup=null,this.currentComponent&&(this.dispatchExternal("menuClosed",this.currentComponent.getComponent()),this.currentComponent=null)})),this.currentComponent=t,this.dispatchExternal("menuOpened",t.getComponent()))}}}q.moduleName="menu";class K extends s{constructor(e){super(e),this.placeholderElement=this.createPlaceholderElement(),this.hoverElement=!1,this.checkTimeout=!1,this.checkPeriod=250,this.moving=!1,this.toCol=!1,this.toColAfter=!1,this.startX=0,this.autoScrollMargin=40,this.autoScrollStep=5,this.autoScrollTimeout=!1,this.touchMove=!1,this.moveHover=this.moveHover.bind(this),this.endMove=this.endMove.bind(this),this.registerTableOption("movableColumns",!1)}createPlaceholderElement(){var e=document.createElement("div");return e.classList.add("tabulator-col"),e.classList.add("tabulator-col-placeholder"),e}initialize(){this.table.options.movableColumns&&this.subscribe("column-init",this.initializeColumn.bind(this))}initializeColumn(e){var i,s=this,o={};e.modules.frozen||e.isGroup||(i=e.getElement(),o.mousemove=function(o){e.parent===s.moving.parent&&((s.touchMove?o.touches[0].pageX:o.pageX)-t.elOffset(i).left+s.table.columnManager.contentsElement.scrollLeft>e.getWidth()/2?s.toCol===e&&s.toColAfter||(i.parentNode.insertBefore(s.placeholderElement,i.nextSibling),s.moveColumn(e,!0)):(s.toCol!==e||s.toColAfter)&&(i.parentNode.insertBefore(s.placeholderElement,i),s.moveColumn(e,!1)))}.bind(s),i.addEventListener("mousedown",(function(t){s.touchMove=!1,1===t.which&&(s.checkTimeout=setTimeout((function(){s.startMove(t,e)}),s.checkPeriod))})),i.addEventListener("mouseup",(function(e){1===e.which&&s.checkTimeout&&clearTimeout(s.checkTimeout)})),s.bindTouchEvents(e)),e.modules.moveColumn=o}bindTouchEvents(e){var t,i,s,o,n,r,a=e.getElement(),l=!1;a.addEventListener("touchstart",(a=>{this.checkTimeout=setTimeout((()=>{this.touchMove=!0,t=e.nextColumn(),s=t?t.getWidth()/2:0,i=e.prevColumn(),o=i?i.getWidth()/2:0,n=0,r=0,l=!1,this.startMove(a,e)}),this.checkPeriod)}),{passive:!0}),a.addEventListener("touchmove",(a=>{var h,d;this.moving&&(this.moveHover(a),l||(l=a.touches[0].pageX),(h=a.touches[0].pageX-l)>0?t&&h-n>s&&(d=t)!==e&&(l=a.touches[0].pageX,d.getElement().parentNode.insertBefore(this.placeholderElement,d.getElement().nextSibling),this.moveColumn(d,!0)):i&&-h-r>o&&(d=i)!==e&&(l=a.touches[0].pageX,d.getElement().parentNode.insertBefore(this.placeholderElement,d.getElement()),this.moveColumn(d,!1)),d&&(t=d.nextColumn(),n=s,s=t?t.getWidth()/2:0,i=d.prevColumn(),r=o,o=i?i.getWidth()/2:0))}),{passive:!0}),a.addEventListener("touchend",(e=>{this.checkTimeout&&clearTimeout(this.checkTimeout),this.moving&&this.endMove(e)}))}startMove(e,i){var s=i.getElement(),o=this.table.columnManager.getContentsElement(),n=this.table.columnManager.getHeadersElement();this.moving=i,this.startX=(this.touchMove?e.touches[0].pageX:e.pageX)-t.elOffset(s).left,this.table.element.classList.add("tabulator-block-select"),this.placeholderElement.style.width=i.getWidth()+"px",this.placeholderElement.style.height=i.getHeight()+"px",s.parentNode.insertBefore(this.placeholderElement,s),s.parentNode.removeChild(s),this.hoverElement=s.cloneNode(!0),this.hoverElement.classList.add("tabulator-moving"),o.appendChild(this.hoverElement),this.hoverElement.style.left="0",this.hoverElement.style.bottom=o.clientHeight-n.offsetHeight+"px",this.touchMove||(this._bindMouseMove(),document.body.addEventListener("mousemove",this.moveHover),document.body.addEventListener("mouseup",this.endMove)),this.moveHover(e)}_bindMouseMove(){this.table.columnManager.columnsByIndex.forEach((function(e){e.modules.moveColumn.mousemove&&e.getElement().addEventListener("mousemove",e.modules.moveColumn.mousemove)}))}_unbindMouseMove(){this.table.columnManager.columnsByIndex.forEach((function(e){e.modules.moveColumn.mousemove&&e.getElement().removeEventListener("mousemove",e.modules.moveColumn.mousemove)}))}moveColumn(e,t){var i=this.moving.getCells();this.toCol=e,this.toColAfter=t,t?e.getCells().forEach((function(e,t){var s=e.getElement(!0);s.parentNode&&i[t]&&s.parentNode.insertBefore(i[t].getElement(),s.nextSibling)})):e.getCells().forEach((function(e,t){var s=e.getElement(!0);s.parentNode&&i[t]&&s.parentNode.insertBefore(i[t].getElement(),s)}))}endMove(e){(1===e.which||this.touchMove)&&(this._unbindMouseMove(),this.placeholderElement.parentNode.insertBefore(this.moving.getElement(),this.placeholderElement.nextSibling),this.placeholderElement.parentNode.removeChild(this.placeholderElement),this.hoverElement.parentNode.removeChild(this.hoverElement),this.table.element.classList.remove("tabulator-block-select"),this.toCol&&this.table.columnManager.moveColumnActual(this.moving,this.toCol,this.toColAfter),this.moving=!1,this.toCol=!1,this.toColAfter=!1,this.touchMove||(document.body.removeEventListener("mousemove",this.moveHover),document.body.removeEventListener("mouseup",this.endMove)))}moveHover(e){var i,s=this.table.columnManager.getContentsElement(),o=s.scrollLeft,n=(this.touchMove?e.touches[0].pageX:e.pageX)-t.elOffset(s).left+o;this.hoverElement.style.left=n-this.startX+"px",n-o{i=Math.max(0,o-5),this.table.rowManager.getElement().scrollLeft=i,this.autoScrollTimeout=!1}),1))),o+s.clientWidth-n{i=Math.min(s.clientWidth,o+5),this.table.rowManager.getElement().scrollLeft=i,this.autoScrollTimeout=!1}),1)))}}K.moduleName="moveColumn";class J extends s{constructor(e){super(e),this.placeholderElement=this.createPlaceholderElement(),this.hoverElement=!1,this.checkTimeout=!1,this.checkPeriod=150,this.moving=!1,this.toRow=!1,this.toRowAfter=!1,this.hasHandle=!1,this.startY=0,this.startX=0,this.moveHover=this.moveHover.bind(this),this.endMove=this.endMove.bind(this),this.tableRowDropEvent=!1,this.touchMove=!1,this.connection=!1,this.connectionSelectorsTables=!1,this.connectionSelectorsElements=!1,this.connectionElements=[],this.connections=[],this.connectedTable=!1,this.connectedRow=!1,this.registerTableOption("movableRows",!1),this.registerTableOption("movableRowsConnectedTables",!1),this.registerTableOption("movableRowsConnectedElements",!1),this.registerTableOption("movableRowsSender",!1),this.registerTableOption("movableRowsReceiver","insert"),this.registerColumnOption("rowHandle")}createPlaceholderElement(){var e=document.createElement("div");return e.classList.add("tabulator-row"),e.classList.add("tabulator-row-placeholder"),e}initialize(){this.table.options.movableRows&&(this.connectionSelectorsTables=this.table.options.movableRowsConnectedTables,this.connectionSelectorsElements=this.table.options.movableRowsConnectedElements,this.connection=this.connectionSelectorsTables||this.connectionSelectorsElements,this.subscribe("cell-init",this.initializeCell.bind(this)),this.subscribe("column-init",this.initializeColumn.bind(this)),this.subscribe("row-init",this.initializeRow.bind(this)))}initializeGroupHeader(e){var i=this,s={};s.mouseup=function(t){i.tableRowDrop(t,e)}.bind(i),s.mousemove=function(s){var o;s.pageY-t.elOffset(e.element).top+i.table.rowManager.element.scrollTop>e.getHeight()/2?i.toRow===e&&i.toRowAfter||((o=e.getElement()).parentNode.insertBefore(i.placeholderElement,o.nextSibling),i.moveRow(e,!0)):(i.toRow!==e||i.toRowAfter)&&(o=e.getElement()).previousSibling&&(o.parentNode.insertBefore(i.placeholderElement,o),i.moveRow(e,!1))}.bind(i),e.modules.moveRow=s}initializeRow(e){var i,s=this,o={};o.mouseup=function(t){s.tableRowDrop(t,e)}.bind(s),o.mousemove=function(i){var o=e.getElement();i.pageY-t.elOffset(o).top+s.table.rowManager.element.scrollTop>e.getHeight()/2?s.toRow===e&&s.toRowAfter||(o.parentNode.insertBefore(s.placeholderElement,o.nextSibling),s.moveRow(e,!0)):(s.toRow!==e||s.toRowAfter)&&(o.parentNode.insertBefore(s.placeholderElement,o),s.moveRow(e,!1))}.bind(s),this.hasHandle||((i=e.getElement()).addEventListener("mousedown",(function(t){1===t.which&&(s.checkTimeout=setTimeout((function(){s.startMove(t,e)}),s.checkPeriod))})),i.addEventListener("mouseup",(function(e){1===e.which&&s.checkTimeout&&clearTimeout(s.checkTimeout)})),this.bindTouchEvents(e,e.getElement())),e.modules.moveRow=o}initializeColumn(e){e.definition.rowHandle&&!1!==this.table.options.movableRows&&(this.hasHandle=!0)}initializeCell(e){if(e.column.definition.rowHandle&&!1!==this.table.options.movableRows){var t=this,i=e.getElement(!0);i.addEventListener("mousedown",(function(i){1===i.which&&(t.checkTimeout=setTimeout((function(){t.startMove(i,e.row)}),t.checkPeriod))})),i.addEventListener("mouseup",(function(e){1===e.which&&t.checkTimeout&&clearTimeout(t.checkTimeout)})),this.bindTouchEvents(e.row,i)}}bindTouchEvents(e,t){var i,s,o,n,r,a,l=!1;t.addEventListener("touchstart",(t=>{this.checkTimeout=setTimeout((()=>{this.touchMove=!0,i=e.nextRow(),o=i?i.getHeight()/2:0,s=e.prevRow(),n=s?s.getHeight()/2:0,r=0,a=0,l=!1,this.startMove(t,e)}),this.checkPeriod)}),{passive:!0}),this.moving,this.toRow,this.toRowAfter,t.addEventListener("touchmove",(t=>{var h,d;this.moving&&(t.preventDefault(),this.moveHover(t),l||(l=t.touches[0].pageY),(h=t.touches[0].pageY-l)>0?i&&h-r>o&&(d=i)!==e&&(l=t.touches[0].pageY,d.getElement().parentNode.insertBefore(this.placeholderElement,d.getElement().nextSibling),this.moveRow(d,!0)):s&&-h-a>n&&(d=s)!==e&&(l=t.touches[0].pageY,d.getElement().parentNode.insertBefore(this.placeholderElement,d.getElement()),this.moveRow(d,!1)),d&&(i=d.nextRow(),r=o,o=i?i.getHeight()/2:0,s=d.prevRow(),a=n,n=s?s.getHeight()/2:0))})),t.addEventListener("touchend",(e=>{this.checkTimeout&&clearTimeout(this.checkTimeout),this.moving&&(this.endMove(e),this.touchMove=!1)}))}_bindMouseMove(){this.table.rowManager.getDisplayRows().forEach((e=>{("row"===e.type||"group"===e.type)&&e.modules.moveRow&&e.modules.moveRow.mousemove&&e.getElement().addEventListener("mousemove",e.modules.moveRow.mousemove)}))}_unbindMouseMove(){this.table.rowManager.getDisplayRows().forEach((e=>{("row"===e.type||"group"===e.type)&&e.modules.moveRow&&e.modules.moveRow.mousemove&&e.getElement().removeEventListener("mousemove",e.modules.moveRow.mousemove)}))}startMove(e,t){var i=t.getElement();this.setStartPosition(e,t),this.moving=t,this.table.element.classList.add("tabulator-block-select"),this.placeholderElement.style.width=t.getWidth()+"px",this.placeholderElement.style.height=t.getHeight()+"px",this.connection?(this.table.element.classList.add("tabulator-movingrow-sending"),this.connectToTables(t)):(i.parentNode.insertBefore(this.placeholderElement,i),i.parentNode.removeChild(i)),this.hoverElement=i.cloneNode(!0),this.hoverElement.classList.add("tabulator-moving"),this.connection?(document.body.appendChild(this.hoverElement),this.hoverElement.style.left="0",this.hoverElement.style.top="0",this.hoverElement.style.width=this.table.element.clientWidth+"px",this.hoverElement.style.whiteSpace="nowrap",this.hoverElement.style.overflow="hidden",this.hoverElement.style.pointerEvents="none"):(this.table.rowManager.getTableElement().appendChild(this.hoverElement),this.hoverElement.style.left="0",this.hoverElement.style.top="0",this._bindMouseMove()),document.body.addEventListener("mousemove",this.moveHover),document.body.addEventListener("mouseup",this.endMove),this.dispatchExternal("rowMoving",t.getComponent()),this.moveHover(e)}setStartPosition(e,t){var i,s,o=this.touchMove?e.touches[0].pageX:e.pageX,n=this.touchMove?e.touches[0].pageY:e.pageY;i=t.getElement(),this.connection?(s=i.getBoundingClientRect(),this.startX=s.left-o+window.pageXOffset,this.startY=s.top-n+window.pageYOffset):this.startY=n-i.getBoundingClientRect().top}endMove(e){e&&1!==e.which&&!this.touchMove||(this._unbindMouseMove(),this.connection||(this.placeholderElement.parentNode.insertBefore(this.moving.getElement(),this.placeholderElement.nextSibling),this.placeholderElement.parentNode.removeChild(this.placeholderElement)),this.hoverElement.parentNode.removeChild(this.hoverElement),this.table.element.classList.remove("tabulator-block-select"),this.toRow?this.table.rowManager.moveRow(this.moving,this.toRow,this.toRowAfter):this.dispatchExternal("rowMoveCancelled",this.moving.getComponent()),this.moving=!1,this.toRow=!1,this.toRowAfter=!1,document.body.removeEventListener("mousemove",this.moveHover),document.body.removeEventListener("mouseup",this.endMove),this.connection&&(this.table.element.classList.remove("tabulator-movingrow-sending"),this.disconnectFromTables()))}moveRow(e,t){this.toRow=e,this.toRowAfter=t}moveHover(e){this.connection?this.moveHoverConnections.call(this,e):this.moveHoverTable.call(this,e)}moveHoverTable(e){var t=this.table.rowManager.getElement(),i=t.scrollTop,s=(this.touchMove?e.touches[0].pageY:e.pageY)-t.getBoundingClientRect().top+i;this.hoverElement.style.top=Math.min(s-this.startY,this.table.rowManager.element.scrollHeight-this.hoverElement.offsetHeight)+"px"}moveHoverConnections(e){this.hoverElement.style.left=this.startX+(this.touchMove?e.touches[0].pageX:e.pageX)+"px",this.hoverElement.style.top=this.startY+(this.touchMove?e.touches[0].pageY:e.pageY)+"px"}elementRowDrop(e,t,i){this.dispatchExternal("movableRowsElementDrop",e,t,!!i&&i.getComponent())}connectToTables(e){var t;this.connectionSelectorsTables&&(t=this.commsConnections(this.connectionSelectorsTables),this.dispatchExternal("movableRowsSendingStart",t),this.commsSend(this.connectionSelectorsTables,"moveRow","connect",{row:e})),this.connectionSelectorsElements&&(this.connectionElements=[],Array.isArray(this.connectionSelectorsElements)||(this.connectionSelectorsElements=[this.connectionSelectorsElements]),this.connectionSelectorsElements.forEach((e=>{"string"==typeof e?this.connectionElements=this.connectionElements.concat(Array.prototype.slice.call(document.querySelectorAll(e))):this.connectionElements.push(e)})),this.connectionElements.forEach((e=>{var t=t=>{this.elementRowDrop(t,e,this.moving)};e.addEventListener("mouseup",t),e.tabulatorElementDropEvent=t,e.classList.add("tabulator-movingrow-receiving")})))}disconnectFromTables(){var e;this.connectionSelectorsTables&&(e=this.commsConnections(this.connectionSelectorsTables),this.dispatchExternal("movableRowsSendingStop",e),this.commsSend(this.connectionSelectorsTables,"moveRow","disconnect")),this.connectionElements.forEach((e=>{e.classList.remove("tabulator-movingrow-receiving"),e.removeEventListener("mouseup",e.tabulatorElementDropEvent),delete e.tabulatorElementDropEvent}))}connect(e,t){return this.connectedTable?(console.warn("Move Row Error - Table cannot accept connection, already connected to table:",this.connectedTable),!1):(this.connectedTable=e,this.connectedRow=t,this.table.element.classList.add("tabulator-movingrow-receiving"),this.table.rowManager.getDisplayRows().forEach((e=>{"row"===e.type&&e.modules.moveRow&&e.modules.moveRow.mouseup&&e.getElement().addEventListener("mouseup",e.modules.moveRow.mouseup)})),this.tableRowDropEvent=this.tableRowDrop.bind(this),this.table.element.addEventListener("mouseup",this.tableRowDropEvent),this.dispatchExternal("movableRowsReceivingStart",t,e),!0)}disconnect(e){e===this.connectedTable?(this.connectedTable=!1,this.connectedRow=!1,this.table.element.classList.remove("tabulator-movingrow-receiving"),this.table.rowManager.getDisplayRows().forEach((e=>{"row"===e.type&&e.modules.moveRow&&e.modules.moveRow.mouseup&&e.getElement().removeEventListener("mouseup",e.modules.moveRow.mouseup)})),this.table.element.removeEventListener("mouseup",this.tableRowDropEvent),this.dispatchExternal("movableRowsReceivingStop",e)):console.warn("Move Row Error - trying to disconnect from non connected table")}dropComplete(e,t,i){var s=!1;if(i){switch(typeof this.table.options.movableRowsSender){case"string":s=this.senders[this.table.options.movableRowsSender];break;case"function":s=this.table.options.movableRowsSender}s?s.call(this,this.moving?this.moving.getComponent():void 0,t?t.getComponent():void 0,e):this.table.options.movableRowsSender&&console.warn("Mover Row Error - no matching sender found:",this.table.options.movableRowsSender),this.dispatchExternal("movableRowsSent",this.moving.getComponent(),t?t.getComponent():void 0,e)}else this.dispatchExternal("movableRowsSentFailed",this.moving.getComponent(),t?t.getComponent():void 0,e);this.endMove()}tableRowDrop(e,t){var i=!1,s=!1;switch(e.stopImmediatePropagation(),typeof this.table.options.movableRowsReceiver){case"string":i=this.receivers[this.table.options.movableRowsReceiver];break;case"function":i=this.table.options.movableRowsReceiver}i?s=i.call(this,this.connectedRow.getComponent(),t?t.getComponent():void 0,this.connectedTable):console.warn("Mover Row Error - no matching receiver found:",this.table.options.movableRowsReceiver),s?this.dispatchExternal("movableRowsReceived",this.connectedRow.getComponent(),t?t.getComponent():void 0,this.connectedTable):this.dispatchExternal("movableRowsReceivedFailed",this.connectedRow.getComponent(),t?t.getComponent():void 0,this.connectedTable),this.commsSend(this.connectedTable,"moveRow","dropcomplete",{row:t,success:s})}commsReceived(e,t,i){switch(t){case"connect":return this.connect(e,i.row);case"disconnect":return this.disconnect(e);case"dropcomplete":return this.dropComplete(e,i.row,i.success)}}}J.prototype.receivers={insert:function(e,t,i){return this.table.addRow(e.getData(),void 0,t),!0},add:function(e,t,i){return this.table.addRow(e.getData()),!0},update:function(e,t,i){return!!t&&(t.update(e.getData()),!0)},replace:function(e,t,i){return!!t&&(this.table.addRow(e.getData(),void 0,t),t.delete(),!0)}},J.prototype.senders={delete:function(e,t,i){e.delete()}},J.moduleName="moveRow";class Y extends s{constructor(e){super(e),this.allowedTypes=["","data","edit","clipboard"],this.enabled=!0,this.registerColumnOption("mutator"),this.registerColumnOption("mutatorParams"),this.registerColumnOption("mutatorData"),this.registerColumnOption("mutatorDataParams"),this.registerColumnOption("mutatorEdit"),this.registerColumnOption("mutatorEditParams"),this.registerColumnOption("mutatorClipboard"),this.registerColumnOption("mutatorClipboardParams"),this.registerColumnOption("mutateLink")}initialize(){this.subscribe("cell-value-changing",this.transformCell.bind(this)),this.subscribe("cell-value-changed",this.mutateLink.bind(this)),this.subscribe("column-layout",this.initializeColumn.bind(this)),this.subscribe("row-data-init-before",this.rowDataChanged.bind(this)),this.subscribe("row-data-changing",this.rowDataChanged.bind(this))}rowDataChanged(e,t,i){return this.transformRow(t,"data",i)}initializeColumn(e){var t=!1,i={};this.allowedTypes.forEach((s=>{var o,n="mutator"+(s.charAt(0).toUpperCase()+s.slice(1));e.definition[n]&&(o=this.lookupMutator(e.definition[n]))&&(t=!0,i[n]={mutator:o,params:e.definition[n+"Params"]||{}})})),t&&(e.modules.mutate=i)}lookupMutator(e){var t=!1;switch(typeof e){case"string":Y.mutators[e]?t=Y.mutators[e]:console.warn("Mutator Error - No such mutator found, ignoring: ",e);break;case"function":t=e}return t}transformRow(e,t,i){var s,o="mutator"+(t.charAt(0).toUpperCase()+t.slice(1));return this.enabled&&this.table.columnManager.traverse((n=>{var r,a,l;n.modules.mutate&&(r=n.modules.mutate[o]||n.modules.mutate.mutator||!1)&&(s=n.getFieldValue(void 0!==i?i:e),("data"==t&&!i||void 0!==s)&&(l=n.getComponent(),a="function"==typeof r.params?r.params(s,e,t,l):r.params,n.setFieldValue(e,r.mutator(s,e,t,a,l))))})),e}transformCell(e,t){if(e.column.modules.mutate){var i=e.column.modules.mutate.mutatorEdit||e.column.modules.mutate.mutator||!1,s={};if(i)return s=Object.assign(s,e.row.getData()),e.column.setFieldValue(s,t),i.mutator(t,s,"edit",i.params,e.getComponent())}return t}mutateLink(e){var t=e.column.definition.mutateLink;t&&(Array.isArray(t)||(t=[t]),t.forEach((t=>{var i=e.row.getCell(t);i&&i.setValue(i.getValue(),!0,!0)})))}enable(){this.enabled=!0}disable(){this.enabled=!1}}Y.moduleName="mutator",Y.mutators={};var $={rows:function(e,t,i,s,o){var n=document.createElement("span"),r=document.createElement("span"),a=document.createElement("span"),l=document.createElement("span"),h=document.createElement("span"),d=document.createElement("span");return this.table.modules.localize.langBind("pagination|counter|showing",(e=>{r.innerHTML=e})),this.table.modules.localize.langBind("pagination|counter|of",(e=>{l.innerHTML=e})),this.table.modules.localize.langBind("pagination|counter|rows",(e=>{d.innerHTML=e})),s?(a.innerHTML=" "+t+"-"+Math.min(t+e-1,s)+" ",h.innerHTML=" "+s+" ",n.appendChild(r),n.appendChild(a),n.appendChild(l),n.appendChild(h),n.appendChild(d)):(a.innerHTML=" 0 ",n.appendChild(r),n.appendChild(a),n.appendChild(d)),n},pages:function(e,t,i,s,o){var n=document.createElement("span"),r=document.createElement("span"),a=document.createElement("span"),l=document.createElement("span"),h=document.createElement("span"),d=document.createElement("span");return this.table.modules.localize.langBind("pagination|counter|showing",(e=>{r.innerHTML=e})),a.innerHTML=" "+i+" ",this.table.modules.localize.langBind("pagination|counter|of",(e=>{l.innerHTML=e})),h.innerHTML=" "+o+" ",this.table.modules.localize.langBind("pagination|counter|pages",(e=>{d.innerHTML=e})),n.appendChild(r),n.appendChild(a),n.appendChild(l),n.appendChild(h),n.appendChild(d),n}};class Z extends s{constructor(e){super(e),this.mode="local",this.progressiveLoad=!1,this.element=null,this.pageCounterElement=null,this.pageCounter=null,this.size=0,this.page=1,this.count=5,this.max=1,this.remoteRowCountEstimate=null,this.initialLoad=!0,this.dataChanging=!1,this.pageSizes=[],this.registerTableOption("pagination",!1),this.registerTableOption("paginationMode","local"),this.registerTableOption("paginationSize",!1),this.registerTableOption("paginationInitialPage",1),this.registerTableOption("paginationCounter",!1),this.registerTableOption("paginationCounterElement",!1),this.registerTableOption("paginationButtonCount",5),this.registerTableOption("paginationSizeSelector",!1),this.registerTableOption("paginationElement",!1),this.registerTableOption("paginationAddRow","page"),this.registerTableOption("progressiveLoad",!1),this.registerTableOption("progressiveLoadDelay",0),this.registerTableOption("progressiveLoadScrollMargin",0),this.registerTableFunction("setMaxPage",this.setMaxPage.bind(this)),this.registerTableFunction("setPage",this.setPage.bind(this)),this.registerTableFunction("setPageToRow",this.userSetPageToRow.bind(this)),this.registerTableFunction("setPageSize",this.userSetPageSize.bind(this)),this.registerTableFunction("getPageSize",this.getPageSize.bind(this)),this.registerTableFunction("previousPage",this.previousPage.bind(this)),this.registerTableFunction("nextPage",this.nextPage.bind(this)),this.registerTableFunction("getPage",this.getPage.bind(this)),this.registerTableFunction("getPageMax",this.getPageMax.bind(this)),this.registerComponentFunction("row","pageTo",this.setPageToRow.bind(this))}initialize(){this.table.options.pagination?(this.subscribe("row-deleted",this.rowsUpdated.bind(this)),this.subscribe("row-added",this.rowsUpdated.bind(this)),this.subscribe("data-processed",this.initialLoadComplete.bind(this)),this.subscribe("table-built",this.calculatePageSizes.bind(this)),this.subscribe("footer-redraw",this.footerRedraw.bind(this)),"page"==this.table.options.paginationAddRow&&this.subscribe("row-adding-position",this.rowAddingPosition.bind(this)),"remote"===this.table.options.paginationMode&&(this.subscribe("data-params",this.remotePageParams.bind(this)),this.subscribe("data-loaded",this._parseRemoteData.bind(this))),this.table.options.progressiveLoad&&console.error("Progressive Load Error - Pagination and progressive load cannot be used at the same time"),this.registerDisplayHandler(this.restOnRenderBefore.bind(this),40),this.registerDisplayHandler(this.getRows.bind(this),50),this.createElements(),this.initializePageCounter(),this.initializePaginator()):this.table.options.progressiveLoad&&(this.subscribe("data-params",this.remotePageParams.bind(this)),this.subscribe("data-loaded",this._parseRemoteData.bind(this)),this.subscribe("table-built",this.calculatePageSizes.bind(this)),this.subscribe("data-processed",this.initialLoadComplete.bind(this)),this.initializeProgressive(this.table.options.progressiveLoad),"scroll"===this.table.options.progressiveLoad&&this.subscribe("scroll-vertical",this.scrollVertical.bind(this)))}rowAddingPosition(e,t){var i,s=this.table.rowManager,o=s.getDisplayRows();return t?o.length?i=o[0]:s.activeRows.length&&(i=s.activeRows[s.activeRows.length-1],t=!1):o.length&&(i=o[o.length-1],t=!(o.length{}))}restOnRenderBefore(e,t){return t||"local"===this.mode&&this.reset(),e}rowsUpdated(){this.refreshData(!0,"all")}createElements(){var e;this.element=document.createElement("span"),this.element.classList.add("tabulator-paginator"),this.pagesElement=document.createElement("span"),this.pagesElement.classList.add("tabulator-pages"),(e=document.createElement("button")).classList.add("tabulator-page"),e.setAttribute("type","button"),e.setAttribute("role","button"),e.setAttribute("aria-label",""),e.setAttribute("title",""),this.firstBut=e.cloneNode(!0),this.firstBut.setAttribute("data-page","first"),this.prevBut=e.cloneNode(!0),this.prevBut.setAttribute("data-page","prev"),this.nextBut=e.cloneNode(!0),this.nextBut.setAttribute("data-page","next"),this.lastBut=e.cloneNode(!0),this.lastBut.setAttribute("data-page","last"),this.table.options.paginationSizeSelector&&(this.pageSizeSelect=document.createElement("select"),this.pageSizeSelect.classList.add("tabulator-page-size"))}generatePageSizeSelectList(){var e=[];if(this.pageSizeSelect){if(Array.isArray(this.table.options.paginationSizeSelector))e=this.table.options.paginationSizeSelector,this.pageSizes=e,-1==this.pageSizes.indexOf(this.size)&&e.unshift(this.size);else if(-1==this.pageSizes.indexOf(this.size)){e=[];for(let t=1;t<5;t++)e.push(this.size*t);this.pageSizes=e}else e=this.pageSizes;for(;this.pageSizeSelect.firstChild;)this.pageSizeSelect.removeChild(this.pageSizeSelect.firstChild);e.forEach((e=>{var t=document.createElement("option");t.value=e,!0===e?this.langBind("pagination|all",(function(e){t.innerHTML=e})):t.innerHTML=e,this.pageSizeSelect.appendChild(t)})),this.pageSizeSelect.value=this.size}}initializePageCounter(){var e=this.table.options.paginationCounter,t=null;e&&((t="function"==typeof e?e:Z.pageCounters[e])?(this.pageCounter=t,this.pageCounterElement=document.createElement("span"),this.pageCounterElement.classList.add("tabulator-page-counter")):console.warn("Pagination Error - No such page counter found: ",e))}initializePaginator(e){var t,i;e||(this.langBind("pagination|first",(e=>{this.firstBut.innerHTML=e})),this.langBind("pagination|first_title",(e=>{this.firstBut.setAttribute("aria-label",e),this.firstBut.setAttribute("title",e)})),this.langBind("pagination|prev",(e=>{this.prevBut.innerHTML=e})),this.langBind("pagination|prev_title",(e=>{this.prevBut.setAttribute("aria-label",e),this.prevBut.setAttribute("title",e)})),this.langBind("pagination|next",(e=>{this.nextBut.innerHTML=e})),this.langBind("pagination|next_title",(e=>{this.nextBut.setAttribute("aria-label",e),this.nextBut.setAttribute("title",e)})),this.langBind("pagination|last",(e=>{this.lastBut.innerHTML=e})),this.langBind("pagination|last_title",(e=>{this.lastBut.setAttribute("aria-label",e),this.lastBut.setAttribute("title",e)})),this.firstBut.addEventListener("click",(()=>{this.setPage(1)})),this.prevBut.addEventListener("click",(()=>{this.previousPage()})),this.nextBut.addEventListener("click",(()=>{this.nextPage()})),this.lastBut.addEventListener("click",(()=>{this.setPage(this.max)})),this.table.options.paginationElement&&(this.element=this.table.options.paginationElement),this.pageSizeSelect&&(t=document.createElement("label"),this.langBind("pagination|page_size",(e=>{this.pageSizeSelect.setAttribute("aria-label",e),this.pageSizeSelect.setAttribute("title",e),t.innerHTML=e})),this.element.appendChild(t),this.element.appendChild(this.pageSizeSelect),this.pageSizeSelect.addEventListener("change",(e=>{this.setPageSize("true"==this.pageSizeSelect.value||this.pageSizeSelect.value),this.setPage(1)}))),this.element.appendChild(this.firstBut),this.element.appendChild(this.prevBut),this.element.appendChild(this.pagesElement),this.element.appendChild(this.nextBut),this.element.appendChild(this.lastBut),this.table.options.paginationElement||(this.table.options.paginationCounter&&(this.table.options.paginationCounterElement?this.table.options.paginationCounterElement instanceof HTMLElement?this.table.options.paginationCounterElement.appendChild(this.pageCounterElement):"string"==typeof this.table.options.paginationCounterElement&&((i=document.querySelector(this.table.options.paginationCounterElement))?i.appendChild(this.pageCounterElement):console.warn("Pagination Error - Unable to find element matching paginationCounterElement selector:",this.table.options.paginationCounterElement)):this.footerAppend(this.pageCounterElement)),this.footerAppend(this.element)),this.page=this.table.options.paginationInitialPage,this.count=this.table.options.paginationButtonCount),this.mode=this.table.options.paginationMode}initializeProgressive(e){this.initializePaginator(!0),this.mode="progressive_"+e,this.progressiveLoad=!0}trackChanges(){this.dispatch("page-changed")}setMaxRows(e){this.max=e?!0===this.size?1:Math.ceil(e/this.size):1,this.page>this.max&&(this.page=this.max)}reset(e){this.initialLoad||("local"==this.mode||e)&&(this.page=1,this.trackChanges())}setMaxPage(e){e=parseInt(e),this.max=e||1,this.page>this.max&&(this.page=this.max,this.trigger())}setPage(e){switch(e){case"first":return this.setPage(1);case"prev":return this.previousPage();case"next":return this.nextPage();case"last":return this.setPage(this.max)}return(e=parseInt(e))>0&&e<=this.max||"local"!==this.mode?(this.page=e,this.trackChanges(),this.trigger()):(console.warn("Pagination Error - Requested page is out of range of 1 - "+this.max+":",e),Promise.reject())}setPageToRow(e){var t=this.displayRows(-1).indexOf(e);if(t>-1){var i=!0===this.size?1:Math.ceil((t+1)/this.size);return this.setPage(i)}return console.warn("Pagination Error - Requested row is not visible"),Promise.reject()}setPageSize(e){!0!==e&&(e=parseInt(e)),e>0&&(this.size=e,this.dispatchExternal("pageSizeChanged",e)),this.pageSizeSelect&&this.generatePageSizeSelectList(),this.trackChanges()}_setPageCounter(e,t,i){var s;if(this.pageCounter)switch("remote"===this.mode&&(t=this.size,i=(this.page-1)*this.size+1,e=this.remoteRowCountEstimate),typeof(s=this.pageCounter.call(this,t,i,this.page,e,this.max))){case"object":if(s instanceof Node){for(;this.pageCounterElement.firstChild;)this.pageCounterElement.removeChild(this.pageCounterElement.firstChild);this.pageCounterElement.appendChild(s)}else this.pageCounterElement.innerHTML="",null!=s&&console.warn("Page Counter Error - Page Counter has returned a type of object, the only valid page counter object return is an instance of Node, the page counter returned:",s);break;case"undefined":this.pageCounterElement.innerHTML="";break;default:this.pageCounterElement.innerHTML=s}}_setPageButtons(){let e=Math.floor((this.count-1)/2),t=Math.ceil((this.count-1)/2),i=this.max-this.page+e+10&&e<=this.max&&this.pagesElement.appendChild(this._generatePageButton(e));this.footerRedraw()}_generatePageButton(e){var t=document.createElement("button");return t.classList.add("tabulator-page"),e==this.page&&t.classList.add("active"),t.setAttribute("type","button"),t.setAttribute("role","button"),this.langBind("pagination|page_title",(i=>{t.setAttribute("aria-label",i+" "+e),t.setAttribute("title",i+" "+e)})),t.setAttribute("data-page",e),t.textContent=e,t.addEventListener("click",(t=>{this.setPage(e)})),t}previousPage(){return this.page>1?(this.page--,this.trackChanges(),this.trigger()):(console.warn("Pagination Error - Previous page would be less than page 1:",0),Promise.reject())}nextPage(){return this.page"row"===e.type));if("local"==this.mode){t=[],this.setMaxRows(e.length),!0===this.size?(i=0,s=e.length):s=(i=this.size*(this.page-1))+parseInt(this.size),this._setPageButtons();for(let r=i;r{this.dataChanging=!1}));case"progressive_load":case"progressive_scroll":return this.reloadData(null,!0);default:return console.warn("Pagination Error - no such pagination mode:",this.mode),Promise.reject()}}_parseRemoteData(e){var t;if(void 0===e.last_page&&console.warn("Remote Pagination Error - Server response missing '"+(this.options("dataReceiveParams").last_page||"last_page")+"' property"),e.data){if(this.max=parseInt(e.last_page)||1,this.remoteRowCountEstimate=void 0!==e.last_row?e.last_row:e.last_page*this.size-(this.page==e.last_page?this.size-e.data.length:0),this.progressiveLoad){switch(this.mode){case"progressive_load":1==this.page?this.table.rowManager.setData(e.data,!1,1==this.page):this.table.rowManager.addRows(e.data),this.page{this.nextPage()}),this.table.options.progressiveLoadDelay);break;case"progressive_scroll":e=1===this.page?e.data:this.table.rowManager.getData().concat(e.data),this.table.rowManager.setData(e,1!==this.page,1==this.page),t=this.table.options.progressiveLoadScrollMargin||2*this.table.rowManager.element.clientHeight,this.table.rowManager.element.scrollHeight<=this.table.rowManager.element.clientHeight+t&&this.page{this.nextPage()}))}return!1}this.dispatchExternal("pageLoaded",this.getPage())}else console.warn("Remote Pagination Error - Server response missing '"+(this.options("dataReceiveParams").data||"data")+"' property");return e.data}footerRedraw(){var e=this.table.footerManager.containerElement;Math.ceil(e.clientWidth)-e.scrollWidth<0?this.pagesElement.style.display="none":(this.pagesElement.style.display="",Math.ceil(e.clientWidth)-e.scrollWidth<0&&(this.pagesElement.style.display="none"))}}Z.moduleName="page",Z.pageCounters=$;var Q={local:function(e,t){var i=localStorage.getItem(e+"-"+t);return!!i&&JSON.parse(i)},cookie:function(e,t){var i,s,o=document.cookie,n=e+"-"+t,r=o.indexOf(n+"=");return r>-1&&((i=(o=o.slice(r)).indexOf(";"))>-1&&(o=o.slice(0,i)),s=o.replace(n+"=","")),!!s&&JSON.parse(s)}},ee={local:function(e,t,i){localStorage.setItem(e+"-"+t,JSON.stringify(i))},cookie:function(e,t,i){var s=new Date;s.setDate(s.getDate()+1e4),document.cookie=e+"-"+t+"="+JSON.stringify(i)+"; expires="+s.toUTCString()}};class te extends s{constructor(e){super(e),this.mode="",this.id="",this.defWatcherBlock=!1,this.config={},this.readFunc=!1,this.writeFunc=!1,this.registerTableOption("persistence",!1),this.registerTableOption("persistenceID",""),this.registerTableOption("persistenceMode",!0),this.registerTableOption("persistenceReaderFunc",!1),this.registerTableOption("persistenceWriterFunc",!1)}localStorageTest(){var e="_tabulator_test";try{return window.localStorage.setItem(e,e),window.localStorage.removeItem(e),!0}catch(e){return!1}}initialize(){if(this.table.options.persistence){var e,t=this.table.options.persistenceMode,i=this.table.options.persistenceID;this.mode=!0!==t?t:this.localStorageTest()?"local":"cookie",this.table.options.persistenceReaderFunc?"function"==typeof this.table.options.persistenceReaderFunc?this.readFunc=this.table.options.persistenceReaderFunc:te.readers[this.table.options.persistenceReaderFunc]?this.readFunc=te.readers[this.table.options.persistenceReaderFunc]:console.warn("Persistence Read Error - invalid reader set",this.table.options.persistenceReaderFunc):te.readers[this.mode]?this.readFunc=te.readers[this.mode]:console.warn("Persistence Read Error - invalid reader set",this.mode),this.table.options.persistenceWriterFunc?"function"==typeof this.table.options.persistenceWriterFunc?this.writeFunc=this.table.options.persistenceWriterFunc:te.writers[this.table.options.persistenceWriterFunc]?this.writeFunc=te.writers[this.table.options.persistenceWriterFunc]:console.warn("Persistence Write Error - invalid reader set",this.table.options.persistenceWriterFunc):te.writers[this.mode]?this.writeFunc=te.writers[this.mode]:console.warn("Persistence Write Error - invalid writer set",this.mode),this.id="tabulator-"+(i||this.table.element.getAttribute("id")||""),this.config={sort:!0===this.table.options.persistence||this.table.options.persistence.sort,filter:!0===this.table.options.persistence||this.table.options.persistence.filter,headerFilter:!0===this.table.options.persistence||this.table.options.persistence.headerFilter,group:!0===this.table.options.persistence||this.table.options.persistence.group,page:!0===this.table.options.persistence||this.table.options.persistence.page,columns:!0===this.table.options.persistence?["title","width","visible"]:this.table.options.persistence.columns},this.config.page&&(e=this.retrieveData("page"))&&(void 0===e.paginationSize||!0!==this.config.page&&!this.config.page.size||(this.table.options.paginationSize=e.paginationSize),void 0===e.paginationInitialPage||!0!==this.config.page&&!this.config.page.page||(this.table.options.paginationInitialPage=e.paginationInitialPage)),this.config.group&&(e=this.retrieveData("group"))&&(void 0===e.groupBy||!0!==this.config.group&&!this.config.group.groupBy||(this.table.options.groupBy=e.groupBy),void 0===e.groupStartOpen||!0!==this.config.group&&!this.config.group.groupStartOpen||(this.table.options.groupStartOpen=e.groupStartOpen),void 0===e.groupHeader||!0!==this.config.group&&!this.config.group.groupHeader||(this.table.options.groupHeader=e.groupHeader)),this.config.columns&&(this.table.options.columns=this.load("columns",this.table.options.columns),this.subscribe("column-init",this.initializeColumn.bind(this)),this.subscribe("column-show",this.save.bind(this,"columns")),this.subscribe("column-hide",this.save.bind(this,"columns")),this.subscribe("column-moved",this.save.bind(this,"columns"))),this.subscribe("table-built",this.tableBuilt.bind(this),0),this.subscribe("table-redraw",this.tableRedraw.bind(this)),this.subscribe("filter-changed",this.eventSave.bind(this,"filter")),this.subscribe("filter-changed",this.eventSave.bind(this,"headerFilter")),this.subscribe("sort-changed",this.eventSave.bind(this,"sort")),this.subscribe("group-changed",this.eventSave.bind(this,"group")),this.subscribe("page-changed",this.eventSave.bind(this,"page")),this.subscribe("column-resized",this.eventSave.bind(this,"columns")),this.subscribe("column-width",this.eventSave.bind(this,"columns")),this.subscribe("layout-refreshed",this.eventSave.bind(this,"columns"))}this.registerTableFunction("getColumnLayout",this.getColumnLayout.bind(this)),this.registerTableFunction("setColumnLayout",this.setColumnLayout.bind(this))}eventSave(e){this.config[e]&&this.save(e)}tableBuilt(){var e,t,i;this.config.sort&&!1==!(e=this.load("sort"))&&(this.table.options.initialSort=e),this.config.filter&&!1==!(t=this.load("filter"))&&(this.table.options.initialFilter=t),this.config.headerFilter&&!1==!(i=this.load("headerFilter"))&&(this.table.options.initialHeaderFilter=i)}tableRedraw(e){e&&this.config.columns&&this.save("columns")}getColumnLayout(){return this.parseColumns(this.table.columnManager.getColumns())}setColumnLayout(e){return this.table.columnManager.setColumns(this.mergeDefinition(this.table.options.columns,e)),!0}initializeColumn(e){var t;this.config.columns&&(this.defWatcherBlock=!0,t=e.getDefinition(),(!0===this.config.columns?Object.keys(t):this.config.columns).forEach((e=>{var i=Object.getOwnPropertyDescriptor(t,e),s=t[e];i&&Object.defineProperty(t,e,{set:e=>{s=e,this.defWatcherBlock||this.save("columns"),i.set&&i.set(e)},get:()=>(i.get&&i.get(),s)})})),this.defWatcherBlock=!1)}load(e,t){var i=this.retrieveData(e);return t&&(i=i?this.mergeDefinition(t,i):t),i}retrieveData(e){return!!this.readFunc&&this.readFunc(this.id,e)}mergeDefinition(e,t){var i=[];return(t=t||[]).forEach(((t,s)=>{var o,n=this._findColumn(e,t);n&&(!0===this.config.columns||null==this.config.columns?(o=Object.keys(n)).push("width"):o=this.config.columns,o.forEach((e=>{"columns"!==e&&void 0!==t[e]&&(n[e]=t[e])})),n.columns&&(n.columns=this.mergeDefinition(n.columns,t.columns)),i.push(n))})),e.forEach(((e,s)=>{this._findColumn(t,e)||(i.length>s?i.splice(s,0,e):i.push(e))})),i}_findColumn(e,t){var i=t.columns?"group":t.field?"field":"object";return e.find((function(e){switch(i){case"group":return e.title===t.title&&e.columns.length===t.columns.length;case"field":return e.field===t.field;case"object":return e===t}}))}save(e){var t={};switch(e){case"columns":t=this.parseColumns(this.table.columnManager.getColumns());break;case"filter":t=this.table.modules.filter.getFilters();break;case"headerFilter":t=this.table.modules.filter.getHeaderFilters();break;case"sort":t=this.validateSorters(this.table.modules.sort.getSort());break;case"group":t=this.getGroupConfig();break;case"page":t=this.getPageConfig()}this.writeFunc&&this.writeFunc(this.id,e,t)}validateSorters(e){return e.forEach((function(e){e.column=e.field,delete e.field})),e}getGroupConfig(){var e={};return this.config.group&&((!0===this.config.group||this.config.group.groupBy)&&(e.groupBy=this.table.options.groupBy),(!0===this.config.group||this.config.group.groupStartOpen)&&(e.groupStartOpen=this.table.options.groupStartOpen),(!0===this.config.group||this.config.group.groupHeader)&&(e.groupHeader=this.table.options.groupHeader)),e}getPageConfig(){var e={};return this.config.page&&((!0===this.config.page||this.config.page.size)&&(e.paginationSize=this.table.modules.page.getPageSize()),(!0===this.config.page||this.config.page.page)&&(e.paginationInitialPage=this.table.modules.page.getPage())),e}parseColumns(e){var t=[],i=["headerContextMenu","headerMenu","contextMenu","clickMenu"];return e.forEach((e=>{var s,o={},n=e.getDefinition();e.isGroup?(o.title=n.title,o.columns=this.parseColumns(e.getColumns())):(o.field=e.getField(),!0===this.config.columns||null==this.config.columns?((s=Object.keys(n)).push("width"),s.push("visible")):s=this.config.columns,s.forEach((t=>{switch(t){case"width":o.width=e.getWidth();break;case"visible":o.visible=e.visible;break;default:"function"!=typeof n[t]&&-1===i.indexOf(t)&&(o[t]=n[t])}}))),t.push(o)})),t}}te.moduleName="persistence",te.moduleInitOrder=-10,te.readers=Q,te.writers=ee;class ie extends s{constructor(e){super(e),this.columnSubscribers={},this.registerTableOption("rowContextPopup",!1),this.registerTableOption("rowClickPopup",!1),this.registerTableOption("rowDblClickPopup",!1),this.registerTableOption("groupContextPopup",!1),this.registerTableOption("groupClickPopup",!1),this.registerTableOption("groupDblClickPopup",!1),this.registerColumnOption("headerContextPopup"),this.registerColumnOption("headerClickPopup"),this.registerColumnOption("headerDblClickPopup"),this.registerColumnOption("headerPopup"),this.registerColumnOption("headerPopupIcon"),this.registerColumnOption("contextPopup"),this.registerColumnOption("clickPopup"),this.registerColumnOption("dblClickPopup"),this.registerComponentFunction("cell","popup",this._componentPopupCall.bind(this)),this.registerComponentFunction("column","popup",this._componentPopupCall.bind(this)),this.registerComponentFunction("row","popup",this._componentPopupCall.bind(this)),this.registerComponentFunction("group","popup",this._componentPopupCall.bind(this))}initialize(){this.initializeRowWatchers(),this.initializeGroupWatchers(),this.subscribe("column-init",this.initializeColumn.bind(this))}_componentPopupCall(e,t,i){this.loadPopupEvent(t,null,e,i)}initializeRowWatchers(){this.table.options.rowContextPopup&&(this.subscribe("row-contextmenu",this.loadPopupEvent.bind(this,this.table.options.rowContextPopup)),this.table.on("rowTapHold",this.loadPopupEvent.bind(this,this.table.options.rowContextPopup))),this.table.options.rowClickPopup&&this.subscribe("row-click",this.loadPopupEvent.bind(this,this.table.options.rowClickPopup)),this.table.options.rowDblClickPopup&&this.subscribe("row-dblclick",this.loadPopupEvent.bind(this,this.table.options.rowDblClickPopup))}initializeGroupWatchers(){this.table.options.groupContextPopup&&(this.subscribe("group-contextmenu",this.loadPopupEvent.bind(this,this.table.options.groupContextPopup)),this.table.on("groupTapHold",this.loadPopupEvent.bind(this,this.table.options.groupContextPopup))),this.table.options.groupClickPopup&&this.subscribe("group-click",this.loadPopupEvent.bind(this,this.table.options.groupClickPopup)),this.table.options.groupDblClickPopup&&this.subscribe("group-dblclick",this.loadPopupEvent.bind(this,this.table.options.groupDblClickPopup))}initializeColumn(e){var t=e.definition;t.headerContextPopup&&!this.columnSubscribers.headerContextPopup&&(this.columnSubscribers.headerContextPopup=this.loadPopupTableColumnEvent.bind(this,"headerContextPopup"),this.subscribe("column-contextmenu",this.columnSubscribers.headerContextPopup),this.table.on("headerTapHold",this.loadPopupTableColumnEvent.bind(this,"headerContextPopup"))),t.headerClickPopup&&!this.columnSubscribers.headerClickPopup&&(this.columnSubscribers.headerClickPopup=this.loadPopupTableColumnEvent.bind(this,"headerClickPopup"),this.subscribe("column-click",this.columnSubscribers.headerClickPopup)),t.headerDblClickPopup&&!this.columnSubscribers.headerDblClickPopup&&(this.columnSubscribers.headerDblClickPopup=this.loadPopupTableColumnEvent.bind(this,"headerDblClickPopup"),this.subscribe("column-dblclick",this.columnSubscribers.headerDblClickPopup)),t.headerPopup&&this.initializeColumnHeaderPopup(e),t.contextPopup&&!this.columnSubscribers.contextPopup&&(this.columnSubscribers.contextPopup=this.loadPopupTableCellEvent.bind(this,"contextPopup"),this.subscribe("cell-contextmenu",this.columnSubscribers.contextPopup),this.table.on("cellTapHold",this.loadPopupTableCellEvent.bind(this,"contextPopup"))),t.clickPopup&&!this.columnSubscribers.clickPopup&&(this.columnSubscribers.clickPopup=this.loadPopupTableCellEvent.bind(this,"clickPopup"),this.subscribe("cell-click",this.columnSubscribers.clickPopup)),t.dblClickPopup&&!this.columnSubscribers.dblClickPopup&&(this.columnSubscribers.dblClickPopup=this.loadPopupTableCellEvent.bind(this,"dblClickPopup"),this.subscribe("cell-click",this.columnSubscribers.dblClickPopup))}initializeColumnHeaderPopup(e){var t,i=e.definition.headerPopupIcon;(t=document.createElement("span")).classList.add("tabulator-header-popup-button"),i?("function"==typeof i&&(i=i(e.getComponent())),i instanceof HTMLElement?t.appendChild(i):t.innerHTML=i):t.innerHTML="⋮",t.addEventListener("click",(t=>{t.stopPropagation(),t.preventDefault(),this.loadPopupEvent(e.definition.headerPopup,t,e)})),e.titleElement.insertBefore(t,e.titleElement.firstChild)}loadPopupTableCellEvent(e,t,i){i._cell&&(i=i._cell),i.column.definition[e]&&this.loadPopupEvent(i.column.definition[e],t,i)}loadPopupTableColumnEvent(e,t,i){i._column&&(i=i._column),i.definition[e]&&this.loadPopupEvent(i.definition[e],t,i)}loadPopupEvent(e,t,i,s){var o;i._group?i=i._group:i._row&&(i=i._row),e="function"==typeof e?e.call(this.table,t,i.getComponent(),(function(e){o=e})):e,this.loadPopup(t,i,e,o,s)}loadPopup(e,t,i,s,o){var n,r,a=!(e instanceof MouseEvent);i instanceof HTMLElement?n=i:(n=document.createElement("div")).innerHTML=i,n.classList.add("tabulator-popup"),n.addEventListener("click",(e=>{e.stopPropagation()})),a||e.preventDefault(),r=this.popup(n),"function"==typeof s&&r.renderCallback(s),e?r.show(e):r.show(t.getElement(),o||"center"),r.hideOnBlur((()=>{this.dispatchExternal("popupClosed",t.getComponent())})),this.dispatchExternal("popupOpened",t.getComponent())}}ie.moduleName="popup";class se extends s{constructor(e){super(e),this.element=!1,this.manualBlock=!1,this.beforeprintEventHandler=null,this.afterprintEventHandler=null,this.registerTableOption("printAsHtml",!1),this.registerTableOption("printFormatter",!1),this.registerTableOption("printHeader",!1),this.registerTableOption("printFooter",!1),this.registerTableOption("printStyled",!0),this.registerTableOption("printRowRange","visible"),this.registerTableOption("printConfig",{}),this.registerColumnOption("print"),this.registerColumnOption("titlePrint")}initialize(){this.table.options.printAsHtml&&(this.beforeprintEventHandler=this.replaceTable.bind(this),this.afterprintEventHandler=this.cleanup.bind(this),window.addEventListener("beforeprint",this.beforeprintEventHandler),window.addEventListener("afterprint",this.afterprintEventHandler),this.subscribe("table-destroy",this.destroy.bind(this))),this.registerTableFunction("print",this.printFullscreen.bind(this))}destroy(){this.table.options.printAsHtml&&(window.removeEventListener("beforeprint",this.beforeprintEventHandler),window.removeEventListener("afterprint",this.afterprintEventHandler))}replaceTable(){this.manualBlock||(this.element=document.createElement("div"),this.element.classList.add("tabulator-print-table"),this.element.appendChild(this.table.modules.export.generateTable(this.table.options.printConfig,this.table.options.printStyled,this.table.options.printRowRange,"print")),this.table.element.style.display="none",this.table.element.parentNode.insertBefore(this.element,this.table.element))}cleanup(){document.body.classList.remove("tabulator-print-fullscreen-hide"),this.element&&this.element.parentNode&&(this.element.parentNode.removeChild(this.element),this.table.element.style.display="")}printFullscreen(e,t,i){var s,o,n=window.scrollX,r=window.scrollY,a=document.createElement("div"),l=document.createElement("div"),h=this.table.modules.export.generateTable(void 0!==i?i:this.table.options.printConfig,void 0!==t?t:this.table.options.printStyled,e||this.table.options.printRowRange,"print");this.manualBlock=!0,this.element=document.createElement("div"),this.element.classList.add("tabulator-print-fullscreen"),this.table.options.printHeader&&(a.classList.add("tabulator-print-header"),"string"==typeof(s="function"==typeof this.table.options.printHeader?this.table.options.printHeader.call(this.table):this.table.options.printHeader)?a.innerHTML=s:a.appendChild(s),this.element.appendChild(a)),this.element.appendChild(h),this.table.options.printFooter&&(l.classList.add("tabulator-print-footer"),"string"==typeof(o="function"==typeof this.table.options.printFooter?this.table.options.printFooter.call(this.table):this.table.options.printFooter)?l.innerHTML=o:l.appendChild(o),this.element.appendChild(l)),document.body.classList.add("tabulator-print-fullscreen-hide"),document.body.appendChild(this.element),this.table.options.printFormatter&&this.table.options.printFormatter(this.element,h),window.print(),this.cleanup(),window.scrollTo(n,r),this.manualBlock=!1}}se.moduleName="print";class oe extends s{constructor(e){super(e),this.data=!1,this.blocked=!1,this.origFuncs={},this.currentVersion=0,this.registerTableOption("reactiveData",!1)}initialize(){this.table.options.reactiveData&&(this.subscribe("cell-value-save-before",this.block.bind(this,"cellsave")),this.subscribe("cell-value-save-after",this.unblock.bind(this,"cellsave")),this.subscribe("row-data-save-before",this.block.bind(this,"rowsave")),this.subscribe("row-data-save-after",this.unblock.bind(this,"rowsave")),this.subscribe("row-data-init-after",this.watchRow.bind(this)),this.subscribe("data-processing",this.watchData.bind(this)),this.subscribe("table-destroy",this.unwatchData.bind(this)))}watchData(e){var t,i=this;this.currentVersion++,t=this.currentVersion,this.unwatchData(),this.data=e,this.origFuncs.push=e.push,Object.defineProperty(this.data,"push",{enumerable:!1,configurable:!0,value:function(){var s,o=Array.from(arguments);return i.blocked||t!==i.currentVersion||(i.block("data-push"),o.forEach((e=>{i.table.rowManager.addRowActual(e,!1)})),s=i.origFuncs.push.apply(e,arguments),i.unblock("data-push")),s}}),this.origFuncs.unshift=e.unshift,Object.defineProperty(this.data,"unshift",{enumerable:!1,configurable:!0,value:function(){var s,o=Array.from(arguments);return i.blocked||t!==i.currentVersion||(i.block("data-unshift"),o.forEach((e=>{i.table.rowManager.addRowActual(e,!0)})),s=i.origFuncs.unshift.apply(e,arguments),i.unblock("data-unshift")),s}}),this.origFuncs.shift=e.shift,Object.defineProperty(this.data,"shift",{enumerable:!1,configurable:!0,value:function(){var s,o;return i.blocked||t!==i.currentVersion||(i.block("data-shift"),i.data.length&&(s=i.table.rowManager.getRowFromDataObject(i.data[0]))&&s.deleteActual(),o=i.origFuncs.shift.call(e),i.unblock("data-shift")),o}}),this.origFuncs.pop=e.pop,Object.defineProperty(this.data,"pop",{enumerable:!1,configurable:!0,value:function(){var s,o;return i.blocked||t!==i.currentVersion||(i.block("data-pop"),i.data.length&&(s=i.table.rowManager.getRowFromDataObject(i.data[i.data.length-1]))&&s.deleteActual(),o=i.origFuncs.pop.call(e),i.unblock("data-pop")),o}}),this.origFuncs.splice=e.splice,Object.defineProperty(this.data,"splice",{enumerable:!1,configurable:!0,value:function(){var s,o,n=Array.from(arguments),r=n[0]<0?e.length+n[0]:n[0],a=n[1],l=!!n[2]&&n.slice(2);if(!i.blocked&&t===i.currentVersion){if(i.block("data-splice"),l&&((s=!!e[r]&&i.table.rowManager.getRowFromDataObject(e[r]))?l.forEach((e=>{i.table.rowManager.addRowActual(e,!0,s,!0)})):(l=l.slice().reverse()).forEach((e=>{i.table.rowManager.addRowActual(e,!0,!1,!0)}))),0!==a){var h=e.slice(r,void 0===n[1]?n[1]:r+a);h.forEach(((e,t)=>{var s=i.table.rowManager.getRowFromDataObject(e);s&&s.deleteActual(t!==h.length-1)}))}(l||0!==a)&&i.table.rowManager.reRenderInPosition(),o=i.origFuncs.splice.apply(e,arguments),i.unblock("data-splice")}return o}})}unwatchData(){if(!1!==this.data)for(var e in this.origFuncs)Object.defineProperty(this.data,e,{enumerable:!0,configurable:!0,writable:!0,value:this.origFuncs.key})}watchRow(e){var t=e.getData();for(var i in t)this.watchKey(e,t,i);this.table.options.dataTree&&this.watchTreeChildren(e)}watchTreeChildren(e){var t=this,i=e.getData()[this.table.options.dataTreeChildField],s={};i&&(s.push=i.push,Object.defineProperty(i,"push",{enumerable:!1,configurable:!0,value:()=>{if(!t.blocked){t.block("tree-push");var o=s.push.apply(i,arguments);this.rebuildTree(e),t.unblock("tree-push")}return o}}),s.unshift=i.unshift,Object.defineProperty(i,"unshift",{enumerable:!1,configurable:!0,value:()=>{if(!t.blocked){t.block("tree-unshift");var o=s.unshift.apply(i,arguments);this.rebuildTree(e),t.unblock("tree-unshift")}return o}}),s.shift=i.shift,Object.defineProperty(i,"shift",{enumerable:!1,configurable:!0,value:()=>{if(!t.blocked){t.block("tree-shift");var o=s.shift.call(i);this.rebuildTree(e),t.unblock("tree-shift")}return o}}),s.pop=i.pop,Object.defineProperty(i,"pop",{enumerable:!1,configurable:!0,value:()=>{if(!t.blocked){t.block("tree-pop");var o=s.pop.call(i);this.rebuildTree(e),t.unblock("tree-pop")}return o}}),s.splice=i.splice,Object.defineProperty(i,"splice",{enumerable:!1,configurable:!0,value:()=>{if(!t.blocked){t.block("tree-splice");var o=s.splice.apply(i,arguments);this.rebuildTree(e),t.unblock("tree-splice")}return o}}))}rebuildTree(e){this.table.modules.dataTree.initializeRow(e),this.table.modules.dataTree.layoutRow(e),this.table.rowManager.refreshActiveData("tree",!1,!0)}watchKey(e,t,i){var s=this,o=Object.getOwnPropertyDescriptor(t,i),n=t[i],r=this.currentVersion;Object.defineProperty(t,i,{set:t=>{if(n=t,!s.blocked&&r===s.currentVersion){s.block("key");var a={};a[i]=t,e.updateData(a),s.unblock("key")}o.set&&o.set(t)},get:()=>(o.get&&o.get(),n)})}unwatchRow(e){var t=e.getData();for(var i in t)Object.defineProperty(t,i,{value:t[i]})}block(e){this.blocked||(this.blocked=e)}unblock(e){this.blocked===e&&(this.blocked=!1)}}oe.moduleName="reactiveData";class ne extends s{constructor(e){super(e),this.startColumn=!1,this.startX=!1,this.startWidth=!1,this.latestX=!1,this.handle=null,this.initialNextColumn=null,this.nextColumn=null,this.initialized=!1,this.registerColumnOption("resizable",!0),this.registerTableOption("resizableColumnFit",!1)}initialize(){this.subscribe("column-rendered",this.layoutColumnHeader.bind(this))}initializeEventWatchers(){this.initialized||(this.subscribe("cell-rendered",this.layoutCellHandles.bind(this)),this.subscribe("cell-delete",this.deInitializeComponent.bind(this)),this.subscribe("cell-height",this.resizeHandle.bind(this)),this.subscribe("column-moved",this.columnLayoutUpdated.bind(this)),this.subscribe("column-hide",this.deInitializeColumn.bind(this)),this.subscribe("column-show",this.columnLayoutUpdated.bind(this)),this.subscribe("column-width",this.columnWidthUpdated.bind(this)),this.subscribe("column-delete",this.deInitializeComponent.bind(this)),this.subscribe("column-height",this.resizeHandle.bind(this)),this.initialized=!0)}layoutCellHandles(e){"row"===e.row.type&&(this.deInitializeComponent(e),this.initializeColumn("cell",e,e.column,e.element))}layoutColumnHeader(e){e.definition.resizable&&(this.initializeEventWatchers(),this.deInitializeComponent(e),this.initializeColumn("header",e,e,e.element))}columnLayoutUpdated(e){var t=e.prevColumn();this.reinitializeColumn(e),t&&this.reinitializeColumn(t)}columnWidthUpdated(e){e.modules.frozen&&(this.table.modules.frozenColumns.leftColumns.includes(e)?this.table.modules.frozenColumns.leftColumns.forEach((e=>{this.reinitializeColumn(e)})):this.table.modules.frozenColumns.rightColumns.includes(e)&&this.table.modules.frozenColumns.rightColumns.forEach((e=>{this.reinitializeColumn(e)})))}frozenColumnOffset(e){var t=!1;return e.modules.frozen&&(t=e.modules.frozen.marginValue,"left"===e.modules.frozen.position?t+=e.getWidth()-3:t&&(t-=3)),!1!==t&&t+"px"}reinitializeColumn(e){var t=this.frozenColumnOffset(e);e.cells.forEach((i=>{i.modules.resize&&i.modules.resize.handleEl&&(t&&(i.modules.resize.handleEl.style[e.modules.frozen.position]=t,i.modules.resize.handleEl.style["z-index"]=11),i.element.after(i.modules.resize.handleEl))})),e.modules.resize&&e.modules.resize.handleEl&&(t&&(e.modules.resize.handleEl.style[e.modules.frozen.position]=t),e.element.after(e.modules.resize.handleEl))}initializeColumn(e,t,i,s){var o=this,n=i.definition.resizable,r={},a=i.getLastColumn();if("header"===e&&(r={variableHeight:"textarea"==i.definition.formatter||i.definition.variableHeight}),(!0===n||n==e)&&this._checkResizability(a)){var l=document.createElement("span");l.className="tabulator-col-resize-handle",l.addEventListener("click",(function(e){e.stopPropagation()}));var h=function(e){o.startColumn=i,o.initialNextColumn=o.nextColumn=a.nextColumn(),o._mouseDown(e,a,l)};l.addEventListener("mousedown",h),l.addEventListener("touchstart",h,{passive:!0}),l.addEventListener("dblclick",(e=>{var t=a.getWidth();e.stopPropagation(),a.reinitializeWidth(!0),t!==a.getWidth()&&(o.dispatch("column-resized",a),o.table.externalEvents.dispatch("columnResized",a.getComponent()))})),i.modules.frozen&&(l.style.position="sticky",l.style[i.modules.frozen.position]=this.frozenColumnOffset(i)),r.handleEl=l,s.parentNode&&i.visible&&s.after(l)}t.modules.resize=r}deInitializeColumn(e){this.deInitializeComponent(e),e.cells.forEach((e=>{this.deInitializeComponent(e)}))}deInitializeComponent(e){var t;e.modules.resize&&(t=e.modules.resize.handleEl)&&t.parentElement&&t.parentElement.removeChild(t)}resizeHandle(e,t){e.modules.resize&&e.modules.resize.handleEl&&(e.modules.resize.handleEl.style.height=t)}_checkResizability(e){return e.definition.resizable}_mouseDown(e,t,i){var s=this;function o(e){var i,o,n=void 0===e.screenX?e.touches[0].screenX:e.screenX,r=n-s.startX,a=n-s.latestX;if(s.latestX=n,s.table.rtl&&(r=-r,a=-a),i=t.width==t.minWidth||t.width==t.maxWidth,t.setWidth(s.startWidth+r),o=t.width==t.minWidth||t.width==t.maxWidth,a<0&&(s.nextColumn=s.initialNextColumn),s.table.options.resizableColumnFit&&s.nextColumn&&(!i||!o)){let e=s.nextColumn.getWidth();a>0&&e<=s.nextColumn.minWidth&&(s.nextColumn=s.nextColumn.nextColumn()),s.nextColumn&&s.nextColumn.setWidth(s.nextColumn.getWidth()-a)}s.table.columnManager.rerenderColumns(!0),!s.table.browserSlow&&t.modules.resize&&t.modules.resize.variableHeight&&t.checkCellHeights()}function n(e){s.startColumn.modules.edit&&(s.startColumn.modules.edit.blocked=!1),s.table.browserSlow&&t.modules.resize&&t.modules.resize.variableHeight&&t.checkCellHeights(),document.body.removeEventListener("mouseup",n),document.body.removeEventListener("mousemove",o),i.removeEventListener("touchmove",o),i.removeEventListener("touchend",n),s.table.element.classList.remove("tabulator-block-select"),s.startWidth!==t.getWidth()&&(s.table.columnManager.verticalAlignHeaders(),s.dispatch("column-resized",t),s.table.externalEvents.dispatch("columnResized",t.getComponent()))}s.table.element.classList.add("tabulator-block-select"),e.stopPropagation(),s.startColumn.modules.edit&&(s.startColumn.modules.edit.blocked=!0),s.startX=void 0===e.screenX?e.touches[0].screenX:e.screenX,s.latestX=s.startX,s.startWidth=t.getWidth(),document.body.addEventListener("mousemove",o),document.body.addEventListener("mouseup",n),i.addEventListener("touchmove",o,{passive:!0}),i.addEventListener("touchend",n)}}ne.moduleName="resizeColumns";class re extends s{constructor(e){super(e),this.startColumn=!1,this.startY=!1,this.startHeight=!1,this.handle=null,this.prevHandle=null,this.registerTableOption("resizableRows",!1)}initialize(){this.table.options.resizableRows&&this.subscribe("row-layout-after",this.initializeRow.bind(this))}initializeRow(e){var t=this,i=e.getElement(),s=document.createElement("div");s.className="tabulator-row-resize-handle";var o=document.createElement("div");o.className="tabulator-row-resize-handle prev",s.addEventListener("click",(function(e){e.stopPropagation()}));var n=function(i){t.startRow=e,t._mouseDown(i,e,s)};s.addEventListener("mousedown",n),s.addEventListener("touchstart",n,{passive:!0}),o.addEventListener("click",(function(e){e.stopPropagation()}));var r=function(i){var s=t.table.rowManager.prevDisplayRow(e);s&&(t.startRow=s,t._mouseDown(i,s,o))};o.addEventListener("mousedown",r),o.addEventListener("touchstart",r,{passive:!0}),i.appendChild(s),i.appendChild(o)}_mouseDown(e,t,i){var s=this;function o(e){t.setHeight(s.startHeight+((void 0===e.screenY?e.touches[0].screenY:e.screenY)-s.startY))}function n(e){document.body.removeEventListener("mouseup",o),document.body.removeEventListener("mousemove",o),i.removeEventListener("touchmove",o),i.removeEventListener("touchend",n),s.table.element.classList.remove("tabulator-block-select"),s.dispatchExternal("rowResized",t.getComponent())}s.table.element.classList.add("tabulator-block-select"),e.stopPropagation(),s.startY=void 0===e.screenY?e.touches[0].screenY:e.screenY,s.startHeight=t.getHeight(),document.body.addEventListener("mousemove",o),document.body.addEventListener("mouseup",n),i.addEventListener("touchmove",o,{passive:!0}),i.addEventListener("touchend",n)}}re.moduleName="resizeRows";class ae extends s{constructor(e){super(e),this.binding=!1,this.visibilityObserver=!1,this.resizeObserver=!1,this.containerObserver=!1,this.tableHeight=0,this.tableWidth=0,this.containerHeight=0,this.containerWidth=0,this.autoResize=!1,this.visible=!1,this.initialized=!1,this.initialRedraw=!1,this.registerTableOption("autoResize",!0)}initialize(){if(this.table.options.autoResize){var e,t=this.table;this.tableHeight=t.element.clientHeight,this.tableWidth=t.element.clientWidth,t.element.parentNode&&(this.containerHeight=t.element.parentNode.clientHeight,this.containerWidth=t.element.parentNode.clientWidth),"undefined"!=typeof IntersectionObserver&&"undefined"!=typeof ResizeObserver&&"virtual"===t.rowManager.getRenderMode()?(this.initializeVisibilityObserver(),this.autoResize=!0,this.resizeObserver=new ResizeObserver((e=>{if(!t.browserMobile||t.browserMobile&&!t.modules.edit.currentCell){var i=Math.floor(e[0].contentRect.height),s=Math.floor(e[0].contentRect.width);this.tableHeight==i&&this.tableWidth==s||(this.tableHeight=i,this.tableWidth=s,t.element.parentNode&&(this.containerHeight=t.element.parentNode.clientHeight,this.containerWidth=t.element.parentNode.clientWidth),this.redrawTable())}})),this.resizeObserver.observe(t.element),e=window.getComputedStyle(t.element),this.table.element.parentNode&&!this.table.rowManager.fixedHeight&&(e.getPropertyValue("max-height")||e.getPropertyValue("min-height"))&&(this.containerObserver=new ResizeObserver((e=>{if(!t.browserMobile||t.browserMobile&&!t.modules.edit.currentCell){var i=Math.floor(e[0].contentRect.height),s=Math.floor(e[0].contentRect.width);this.containerHeight==i&&this.containerWidth==s||(this.containerHeight=i,this.containerWidth=s,this.tableHeight=t.element.clientHeight,this.tableWidth=t.element.clientWidth),this.redrawTable()}})),this.containerObserver.observe(this.table.element.parentNode)),this.subscribe("table-resize",this.tableResized.bind(this))):(this.binding=function(){(!t.browserMobile||t.browserMobile&&!t.modules.edit.currentCell)&&(t.columnManager.rerenderColumns(!0),t.redraw())},window.addEventListener("resize",this.binding)),this.subscribe("table-destroy",this.clearBindings.bind(this))}}initializeVisibilityObserver(){this.visibilityObserver=new IntersectionObserver((e=>{this.visible=e[0].isIntersecting,this.initialized?this.visible&&(this.redrawTable(this.initialRedraw),this.initialRedraw=!1):(this.initialized=!0,this.initialRedraw=!this.visible)})),this.visibilityObserver.observe(this.table.element)}redrawTable(e){this.initialized&&this.visible&&(this.table.columnManager.rerenderColumns(!0),this.table.redraw(e))}tableResized(){this.table.rowManager.redraw()}clearBindings(){this.binding&&window.removeEventListener("resize",this.binding),this.resizeObserver&&this.resizeObserver.unobserve(this.table.element),this.visibilityObserver&&this.visibilityObserver.unobserve(this.table.element),this.containerObserver&&this.containerObserver.unobserve(this.table.element.parentNode)}}ae.moduleName="resizeTable";class le extends s{constructor(e){super(e),this.columns=[],this.hiddenColumns=[],this.mode="",this.index=0,this.collapseFormatter=[],this.collapseStartOpen=!0,this.collapseHandleColumn=!1,this.registerTableOption("responsiveLayout",!1),this.registerTableOption("responsiveLayoutCollapseStartOpen",!0),this.registerTableOption("responsiveLayoutCollapseUseFormatters",!0),this.registerTableOption("responsiveLayoutCollapseFormatter",!1),this.registerColumnOption("responsive")}initialize(){this.table.options.responsiveLayout&&(this.subscribe("column-layout",this.initializeColumn.bind(this)),this.subscribe("column-show",this.updateColumnVisibility.bind(this)),this.subscribe("column-hide",this.updateColumnVisibility.bind(this)),this.subscribe("columns-loaded",this.initializeResponsivity.bind(this)),this.subscribe("column-moved",this.initializeResponsivity.bind(this)),this.subscribe("column-add",this.initializeResponsivity.bind(this)),this.subscribe("column-delete",this.initializeResponsivity.bind(this)),this.subscribe("table-redrawing",this.tableRedraw.bind(this)),"collapse"===this.table.options.responsiveLayout&&(this.subscribe("row-data-changed",this.generateCollapsedRowContent.bind(this)),this.subscribe("row-init",this.initializeRow.bind(this)),this.subscribe("row-layout",this.layoutRow.bind(this))))}tableRedraw(e){-1===["fitColumns","fitDataStretch"].indexOf(this.layoutMode())&&(e||this.update())}initializeResponsivity(){var e=[];this.mode=this.table.options.responsiveLayout,this.collapseFormatter=this.table.options.responsiveLayoutCollapseFormatter||this.formatCollapsedData,this.collapseStartOpen=this.table.options.responsiveLayoutCollapseStartOpen,this.hiddenColumns=[],this.table.columnManager.columnsByIndex.forEach(((t,i)=>{t.modules.responsive&&t.modules.responsive.order&&t.modules.responsive.visible&&(t.modules.responsive.index=i,e.push(t),t.visible||"collapse"!==this.mode||this.hiddenColumns.push(t))})),e=(e=e.reverse()).sort(((e,t)=>t.modules.responsive.order-e.modules.responsive.order||t.modules.responsive.index-e.modules.responsive.index)),this.columns=e,"collapse"===this.mode&&this.generateCollapsedContent();for(let e of this.table.columnManager.columnsByIndex)if("responsiveCollapse"==e.definition.formatter){this.collapseHandleColumn=e;break}this.collapseHandleColumn&&(this.hiddenColumns.length?this.collapseHandleColumn.show():this.collapseHandleColumn.hide())}initializeColumn(e){var t=e.getDefinition();e.modules.responsive={order:void 0===t.responsive?1:t.responsive,visible:!1!==t.visible}}initializeRow(e){var t;"calc"!==e.type&&((t=document.createElement("div")).classList.add("tabulator-responsive-collapse"),e.modules.responsiveLayout={element:t,open:this.collapseStartOpen},this.collapseStartOpen||(t.style.display="none"))}layoutRow(e){var t=e.getElement();e.modules.responsiveLayout&&(t.appendChild(e.modules.responsiveLayout.element),this.generateCollapsedRowContent(e))}updateColumnVisibility(e,t){!t&&e.modules.responsive&&(e.modules.responsive.visible=e.visible,this.initializeResponsivity())}hideColumn(e){var t=this.hiddenColumns.length;e.hide(!1,!0),"collapse"===this.mode&&(this.hiddenColumns.unshift(e),this.generateCollapsedContent(),this.collapseHandleColumn&&!t&&this.collapseHandleColumn.show())}showColumn(e){var t;e.show(!1,!0),e.setWidth(e.getWidth()),"collapse"===this.mode&&((t=this.hiddenColumns.indexOf(e))>-1&&this.hiddenColumns.splice(t,1),this.generateCollapsedContent(),this.collapseHandleColumn&&!this.hiddenColumns.length&&this.collapseHandleColumn.hide())}update(){for(var e=!0;e;){let t="fitColumns"==this.table.modules.layout.getMode()?this.table.columnManager.getFlexBaseWidth():this.table.columnManager.getWidth(),i=(this.table.options.headerVisible?this.table.columnManager.element.clientWidth:this.table.element.clientWidth)-t;if(i<0){let t=this.columns[this.index];t?(this.hideColumn(t),this.index++):e=!1}else{let t=this.columns[this.index-1];t&&i>0&&i>=t.getWidth()?(this.showColumn(t),this.index--):e=!1}this.table.rowManager.activeRowsCount||this.table.rowManager.renderEmptyScroll()}}generateCollapsedContent(){this.table.rowManager.getDisplayRows().forEach((e=>{this.generateCollapsedRowContent(e)}))}generateCollapsedRowContent(e){var t,i;if(e.modules.responsiveLayout){for(t=e.modules.responsiveLayout.element;t.firstChild;)t.removeChild(t.firstChild);(i=this.collapseFormatter(this.generateCollapsedRowData(e)))&&t.appendChild(i)}}generateCollapsedRowData(e){var t,i=e.getData(),s=[];return this.hiddenColumns.forEach((o=>{var n=o.getFieldValue(i);if(o.definition.title&&o.field)if(o.modules.format&&this.table.options.responsiveLayoutCollapseUseFormatters){function r(e){e()}t={value:!1,data:{},getValue:function(){return n},getData:function(){return i},getType:function(){return"cell"},getElement:function(){return document.createElement("div")},getRow:function(){return e.getComponent()},getColumn:function(){return o.getComponent()},getTable:()=>this.table},s.push({field:o.field,title:o.definition.title,value:o.modules.format.formatter.call(this.table.modules.format,t,o.modules.format.params,r)})}else s.push({field:o.field,title:o.definition.title,value:n})})),s}formatCollapsedData(e){var t=document.createElement("table");return e.forEach((function(e){var i,s=document.createElement("tr"),o=document.createElement("td"),n=document.createElement("td"),r=document.createElement("strong");o.appendChild(r),this.langBind("columns|"+e.field,(function(t){r.innerHTML=t||e.title})),e.value instanceof Node?((i=document.createElement("div")).appendChild(e.value),n.appendChild(i)):n.innerHTML=e.value,s.appendChild(o),s.appendChild(n),t.appendChild(s)}),this),Object.keys(e).length?t:""}}le.moduleName="responsiveLayout";class he extends s{constructor(e){super(e),this.selecting=!1,this.lastClickedRow=!1,this.selectPrev=[],this.selectedRows=[],this.headerCheckboxElement=null,this.registerTableOption("selectable","highlight"),this.registerTableOption("selectableRangeMode","drag"),this.registerTableOption("selectableRollingSelection",!0),this.registerTableOption("selectablePersistence",!0),this.registerTableOption("selectableCheck",(function(e,t){return!0})),this.registerTableFunction("selectRow",this.selectRows.bind(this)),this.registerTableFunction("deselectRow",this.deselectRows.bind(this)),this.registerTableFunction("toggleSelectRow",this.toggleRow.bind(this)),this.registerTableFunction("getSelectedRows",this.getSelectedRows.bind(this)),this.registerTableFunction("getSelectedData",this.getSelectedData.bind(this)),this.registerComponentFunction("row","select",this.selectRows.bind(this)),this.registerComponentFunction("row","deselect",this.deselectRows.bind(this)),this.registerComponentFunction("row","toggleSelect",this.toggleRow.bind(this)),this.registerComponentFunction("row","isSelected",this.isRowSelected.bind(this))}initialize(){!1!==this.table.options.selectable&&(this.subscribe("row-init",this.initializeRow.bind(this)),this.subscribe("row-deleting",this.rowDeleted.bind(this)),this.subscribe("rows-wipe",this.clearSelectionData.bind(this)),this.subscribe("rows-retrieve",this.rowRetrieve.bind(this)),this.table.options.selectable&&!this.table.options.selectablePersistence&&this.subscribe("data-refreshing",this.deselectRows.bind(this)))}rowRetrieve(e,t){return"selected"===e?this.selectedRows:t}rowDeleted(e){this._deselectRow(e,!0)}clearSelectionData(e){var t=this.selectedRows.length;this.selecting=!1,this.lastClickedRow=!1,this.selectPrev=[],this.selectedRows=[],t&&!0!==e&&this._rowSelectionChanged()}initializeRow(e){var t=this,i=e.getElement(),s=function(){setTimeout((function(){t.selecting=!1}),50),document.body.removeEventListener("mouseup",s)};e.modules.select={selected:!1},t.checkRowSelectability(e)?(i.classList.add("tabulator-selectable"),i.classList.remove("tabulator-unselectable"),t.table.options.selectable&&"highlight"!=t.table.options.selectable&&("click"===t.table.options.selectableRangeMode?i.addEventListener("click",this.handleComplexRowClick.bind(this,e)):(i.addEventListener("click",(function(i){t.table.modExists("edit")&&t.table.modules.edit.getCurrentCell()||t.table._clearSelection(),t.selecting||t.toggleRow(e)})),i.addEventListener("mousedown",(function(i){if(i.shiftKey)return t.table._clearSelection(),t.selecting=!0,t.selectPrev=[],document.body.addEventListener("mouseup",s),document.body.addEventListener("keyup",s),t.toggleRow(e),!1})),i.addEventListener("mouseenter",(function(i){t.selecting&&(t.table._clearSelection(),t.toggleRow(e),t.selectPrev[1]==e&&t.toggleRow(t.selectPrev[0]))})),i.addEventListener("mouseout",(function(i){t.selecting&&(t.table._clearSelection(),t.selectPrev.unshift(e))}))))):(i.classList.add("tabulator-unselectable"),i.classList.remove("tabulator-selectable"))}handleComplexRowClick(e,t){if(t.shiftKey){this.table._clearSelection(),this.lastClickedRow=this.lastClickedRow||e;var i=this.table.rowManager.getDisplayRowIndex(this.lastClickedRow),s=this.table.rowManager.getDisplayRowIndex(e),o=i<=s?i:s,n=i>=s?i:s,r=this.table.rowManager.getDisplayRows().slice(0).splice(o,n-o+1);t.ctrlKey||t.metaKey?(r.forEach((t=>{t!==this.lastClickedRow&&(!0===this.table.options.selectable||this.isRowSelected(e)||this.selectedRows.lengththis.table.options.selectable&&(r=r.slice(0,this.table.options.selectable)),this.selectRows(r)),this.table._clearSelection()}else t.ctrlKey||t.metaKey?(this.toggleRow(e),this.lastClickedRow=e):(this.deselectRows(void 0,!0),this.selectRows(e),this.lastClickedRow=e)}checkRowSelectability(e){return!(!e||"row"!==e.type)&&this.table.options.selectableCheck.call(this.table,e.getComponent())}toggleRow(e){this.checkRowSelectability(e)&&(e.modules.select&&e.modules.select.selected?this._deselectRow(e):this._selectRow(e))}selectRows(e){var t,i,s=[];switch(typeof e){case"undefined":t=this.table.rowManager.rows;break;case"string":(t=this.table.rowManager.findRow(e))||(t=this.table.rowManager.getRows(e));break;default:t=e}Array.isArray(t)?t.length&&(t.forEach((e=>{(i=this._selectRow(e,!0,!0))&&s.push(i)})),this._rowSelectionChanged(!1,s)):t&&this._selectRow(t,!1,!0)}_selectRow(e,t,i){if(!isNaN(this.table.options.selectable)&&!0!==this.table.options.selectable&&!i&&this.selectedRows.length>=this.table.options.selectable){if(!this.table.options.selectableRollingSelection)return!1;this._deselectRow(this.selectedRows[0])}var s=this.table.rowManager.findRow(e);if(s){if(-1==this.selectedRows.indexOf(s))return s.getElement().classList.add("tabulator-selected"),s.modules.select||(s.modules.select={}),s.modules.select.selected=!0,s.modules.select.checkboxEl&&(s.modules.select.checkboxEl.checked=!0),this.selectedRows.push(s),this.table.options.dataTreeSelectPropagate&&this.childRowSelection(s,!0),this.dispatchExternal("rowSelected",s.getComponent()),this._rowSelectionChanged(t,s),s}else t||console.warn("Selection Error - No such row found, ignoring selection:"+e)}isRowSelected(e){return-1!==this.selectedRows.indexOf(e)}deselectRows(e,t){var i,s,o=[];switch(typeof e){case"undefined":i=Object.assign([],this.selectedRows);break;case"string":(i=this.table.rowManager.findRow(e))||(i=this.table.rowManager.getRows(e));break;default:i=e}Array.isArray(i)?i.length&&(i.forEach((e=>{(s=this._deselectRow(e,!0,!0))&&o.push(s)})),this._rowSelectionChanged(t,[],o)):i&&this._deselectRow(i,t,!0)}_deselectRow(e,t){var i,s,o=this,n=o.table.rowManager.findRow(e);if(n){if((i=o.selectedRows.findIndex((function(e){return e==n})))>-1)return(s=n.getElement())&&s.classList.remove("tabulator-selected"),n.modules.select||(n.modules.select={}),n.modules.select.selected=!1,n.modules.select.checkboxEl&&(n.modules.select.checkboxEl.checked=!1),o.selectedRows.splice(i,1),this.table.options.dataTreeSelectPropagate&&this.childRowSelection(n,!1),this.dispatchExternal("rowDeselected",n.getComponent()),o._rowSelectionChanged(t,void 0,n),n}else t||console.warn("Deselection Error - No such row found, ignoring selection:"+e)}getSelectedData(){var e=[];return this.selectedRows.forEach((function(t){e.push(t.getData())})),e}getSelectedRows(){var e=[];return this.selectedRows.forEach((function(t){e.push(t.getComponent())})),e}_rowSelectionChanged(e,t=[],i=[]){this.headerCheckboxElement&&(0===this.selectedRows.length?(this.headerCheckboxElement.checked=!1,this.headerCheckboxElement.indeterminate=!1):this.table.rowManager.rows.length===this.selectedRows.length?(this.headerCheckboxElement.checked=!0,this.headerCheckboxElement.indeterminate=!1):(this.headerCheckboxElement.indeterminate=!0,this.headerCheckboxElement.checked=!1)),e||(Array.isArray(t)||(t=[t]),t=t.map((e=>e.getComponent())),Array.isArray(i)||(i=[i]),i=i.map((e=>e.getComponent())),this.dispatchExternal("rowSelectionChanged",this.getSelectedData(),this.getSelectedRows(),t,i))}registerRowSelectCheckbox(e,t){e._row.modules.select||(e._row.modules.select={}),e._row.modules.select.checkboxEl=t}registerHeaderSelectCheckbox(e){this.headerCheckboxElement=e}childRowSelection(e,t){var i=this.table.modules.dataTree.getChildren(e,!0);if(t)for(let e of i)this._selectRow(e,!0);else for(let e of i)this._deselectRow(e,!0)}}function de(e,t,i,s,o,n,r){var a=window.DateTime||luxon.DateTime,l=r.format||"dd/MM/yyyy HH:mm:ss",h=r.alignEmptyValues,d=0;if(void 0!==a){if(a.isDateTime(e)||(e="iso"===l?a.fromISO(String(e)):a.fromFormat(String(e),l)),a.isDateTime(t)||(t="iso"===l?a.fromISO(String(t)):a.fromFormat(String(t),l)),e.isValid){if(t.isValid)return e-t;d=1}else d=t.isValid?-1:0;return("top"===h&&"desc"===n||"bottom"===h&&"asc"===n)&&(d*=-1),d}console.error("Sort Error - 'datetime' sorter is dependant on luxon.js")}he.moduleName="selectRow";var ce={number:function(e,t,i,s,o,n,r){var a=r.alignEmptyValues,l=r.decimalSeparator,h=r.thousandSeparator,d=0;if(e=String(e),t=String(t),h&&(e=e.split(h).join(""),t=t.split(h).join("")),l&&(e=e.split(l).join("."),t=t.split(l).join(".")),e=parseFloat(e),t=parseFloat(t),isNaN(e))d=isNaN(t)?0:-1;else{if(!isNaN(t))return e-t;d=1}return("top"===a&&"desc"===n||"bottom"===a&&"asc"===n)&&(d*=-1),d},string:function(e,t,i,s,o,n,r){var a,l=r.alignEmptyValues,h=0;if(e){if(t){switch(typeof r.locale){case"boolean":r.locale&&(a=this.langLocale());break;case"string":a=r.locale}return String(e).toLowerCase().localeCompare(String(t).toLowerCase(),a)}h=1}else h=t?-1:0;return("top"===l&&"desc"===n||"bottom"===l&&"asc"===n)&&(h*=-1),h},date:function(e,t,i,s,o,n,r){return r.format||(r.format="dd/MM/yyyy"),de.call(this,e,t,i,s,o,n,r)},time:function(e,t,i,s,o,n,r){return r.format||(r.format="HH:mm"),de.call(this,e,t,i,s,o,n,r)},datetime:de,boolean:function(e,t,i,s,o,n,r){return(!0===e||"true"===e||"True"===e||1===e?1:0)-(!0===t||"true"===t||"True"===t||1===t?1:0)},array:function(e,t,i,s,o,n,r){var a=r.type||"length",l=r.alignEmptyValues,h=0;function d(e){var t;switch(a){case"length":t=e.length;break;case"sum":t=e.reduce((function(e,t){return e+t}));break;case"max":t=Math.max.apply(null,e);break;case"min":t=Math.min.apply(null,e);break;case"avg":t=e.reduce((function(e,t){return e+t}))/e.length}return t}if(Array.isArray(e)){if(Array.isArray(t))return d(t)-d(e);h=1}else h=Array.isArray(t)?-1:0;return("top"===l&&"desc"===n||"bottom"===l&&"asc"===n)&&(h*=-1),h},exists:function(e,t,i,s,o,n,r){return(void 0===e?0:1)-(void 0===t?0:1)},alphanum:function(e,t,i,s,o,n,r){var a,l,h,d,c,u=0,p=/(\d+)|(\D+)/g,m=/\d/,g=r.alignEmptyValues,b=0;if(e||0===e){if(t||0===t){if(isFinite(e)&&isFinite(t))return e-t;if((a=String(e).toLowerCase())===(l=String(t).toLowerCase()))return 0;if(!m.test(a)||!m.test(l))return a>l?1:-1;for(a=a.match(p),l=l.match(p),c=a.length>l.length?l.length:a.length;ud?1:-1;return a.length>l.length}b=1}else b=t||0===t?-1:0;return("top"===g&&"desc"===n||"bottom"===g&&"asc"===n)&&(b*=-1),b}};class ue extends s{constructor(e){super(e),this.sortList=[],this.changed=!1,this.registerTableOption("sortMode","local"),this.registerTableOption("initialSort",!1),this.registerTableOption("columnHeaderSortMulti",!0),this.registerTableOption("sortOrderReverse",!1),this.registerTableOption("headerSortElement","
"),this.registerTableOption("headerSortClickElement","header"),this.registerColumnOption("sorter"),this.registerColumnOption("sorterParams"),this.registerColumnOption("headerSort",!0),this.registerColumnOption("headerSortStartingDir"),this.registerColumnOption("headerSortTristate")}initialize(){this.subscribe("column-layout",this.initializeColumn.bind(this)),this.subscribe("table-built",this.tableBuilt.bind(this)),this.registerDataHandler(this.sort.bind(this),20),this.registerTableFunction("setSort",this.userSetSort.bind(this)),this.registerTableFunction("getSorters",this.getSort.bind(this)),this.registerTableFunction("clearSort",this.clearSort.bind(this)),"remote"===this.table.options.sortMode&&this.subscribe("data-params",this.remoteSortParams.bind(this))}tableBuilt(){this.table.options.initialSort&&this.setSort(this.table.options.initialSort)}remoteSortParams(e,t,i,s){var o=this.getSort();return o.forEach((e=>{delete e.column})),s.sort=o,s}userSetSort(e,t){this.setSort(e,t),this.refreshSort()}clearSort(){this.clear(),this.refreshSort()}initializeColumn(e){var t,i,s=!1;switch(typeof e.definition.sorter){case"string":ue.sorters[e.definition.sorter]?s=ue.sorters[e.definition.sorter]:console.warn("Sort Error - No such sorter found: ",e.definition.sorter);break;case"function":s=e.definition.sorter}if(e.modules.sort={sorter:s,dir:"none",params:e.definition.sorterParams||{},startingDir:e.definition.headerSortStartingDir||"asc",tristate:e.definition.headerSortTristate},!1!==e.definition.headerSort){if((t=e.getElement()).classList.add("tabulator-sortable"),(i=document.createElement("div")).classList.add("tabulator-col-sorter"),"icon"===this.table.options.headerSortClickElement)i.classList.add("tabulator-col-sorter-element");else t.classList.add("tabulator-col-sorter-element");switch(this.table.options.headerSortElement){case"function":break;case"object":i.appendChild(this.table.options.headerSortElement);break;default:i.innerHTML=this.table.options.headerSortElement}e.titleHolderElement.appendChild(i),e.modules.sort.element=i,this.setColumnHeaderSortIcon(e,"none"),("icon"===this.table.options.headerSortClickElement?i:t).addEventListener("click",(t=>{var i="",s=[],o=!1;if(e.modules.sort){if(e.modules.sort.tristate)i="none"==e.modules.sort.dir?e.modules.sort.startingDir:e.modules.sort.dir==e.modules.sort.startingDir?"asc"==e.modules.sort.dir?"desc":"asc":"none";else switch(e.modules.sort.dir){case"asc":i="desc";break;case"desc":i="asc";break;default:i=e.modules.sort.startingDir}this.table.options.columnHeaderSortMulti&&(t.shiftKey||t.ctrlKey)?(o=(s=this.getSort()).findIndex((t=>t.field===e.getField())),o>-1?(s[o].dir=i,o=s.splice(o,1)[0],"none"!=i&&s.push(o)):"none"!=i&&s.push({column:e,dir:i}),this.setSort(s)):"none"==i?this.clear():this.setSort(e,i),this.refreshSort()}}))}}refreshSort(){"remote"===this.table.options.sortMode?this.reloadData(null,!1,!1):this.refreshData(!0)}hasChanged(){var e=this.changed;return this.changed=!1,e}getSort(){var e=[];return this.sortList.forEach((function(t){t.column&&e.push({column:t.column.getComponent(),field:t.column.getField(),dir:t.dir})})),e}setSort(e,t){var i=this,s=[];Array.isArray(e)||(e=[{column:e,dir:t}]),e.forEach((function(e){var t;(t=i.table.columnManager.findColumn(e.column))?(e.column=t,s.push(e),i.changed=!0):console.warn("Sort Warning - Sort field does not exist and is being ignored: ",e.column)})),i.sortList=s,this.dispatch("sort-changed")}clear(){this.setSort([])}findSorter(e){var t,i=this.table.rowManager.activeRows[0],s="string";if(i&&(i=i.getData(),e.getField()))switch(typeof(t=e.getFieldValue(i))){case"undefined":s="string";break;case"boolean":s="boolean";break;default:isNaN(t)||""===t?t.match(/((^[0-9]+[a-z]+)|(^[a-z]+[0-9]+))+$/i)&&(s="alphanum"):s="number"}return ue.sorters[s]}sort(e){var t=this,i=this.table.options.sortOrderReverse?t.sortList.slice().reverse():t.sortList,s=[],o=[];return this.subscribedExternal("dataSorting")&&this.dispatchExternal("dataSorting",t.getSort()),t.clearColumnHeaders(),"remote"!==this.table.options.sortMode?(i.forEach((function(e,i){var o;e.column&&((o=e.column.modules.sort)&&(o.sorter||(o.sorter=t.findSorter(e.column)),e.params="function"==typeof o.params?o.params(e.column.getComponent(),e.dir):o.params,s.push(e)),t.setColumnHeader(e.column,e.dir))})),s.length&&t._sortItems(e,s)):i.forEach((function(e,i){t.setColumnHeader(e.column,e.dir)})),this.subscribedExternal("dataSorted")&&(e.forEach((e=>{o.push(e.getComponent())})),this.dispatchExternal("dataSorted",t.getSort(),o)),e}clearColumnHeaders(){this.table.columnManager.getRealColumns().forEach((e=>{e.modules.sort&&(e.modules.sort.dir="none",e.getElement().setAttribute("aria-sort","none"),this.setColumnHeaderSortIcon(e,"none"))}))}setColumnHeader(e,t){e.modules.sort.dir=t,e.getElement().setAttribute("aria-sort","asc"===t?"ascending":"descending"),this.setColumnHeaderSortIcon(e,t)}setColumnHeaderSortIcon(e,t){var i,s=e.modules.sort.element;if(e.definition.headerSort&&"function"==typeof this.table.options.headerSortElement){for(;s.firstChild;)s.removeChild(s.firstChild);"object"==typeof(i=this.table.options.headerSortElement.call(this.table,e.getComponent(),t))?s.appendChild(i):s.innerHTML=i}}_sortItems(e,t){var i=t.length-1;e.sort(((e,s)=>{for(var o,n=i;n>=0;n--){let i=t[n];if(0!==(o=this._sortRow(e,s,i.column,i.dir,i.params)))break}return o}))}_sortRow(e,t,i,s,o){var n,r,a="asc"==s?e:t,l="asc"==s?t:e;return e=void 0!==(e=i.getFieldValue(a.getData()))?e:"",t=void 0!==(t=i.getFieldValue(l.getData()))?t:"",n=a.getComponent(),r=l.getComponent(),i.modules.sort.sorter.call(this,e,t,n,r,i.getComponent(),s,o)}}ue.moduleName="sort",ue.sorters=ce;class pe extends s{constructor(e){super(e),this.tooltipSubscriber=null,this.headerSubscriber=null,this.timeout=null,this.popupInstance=null,this.registerTableOption("tooltipGenerationMode",void 0),this.registerTableOption("tooltipDelay",300),this.registerColumnOption("tooltip"),this.registerColumnOption("headerTooltip")}initialize(){this.deprecatedOptionsCheck(),this.subscribe("column-init",this.initializeColumn.bind(this))}deprecatedOptionsCheck(){this.deprecationCheckMsg("tooltipGenerationMode","This option is no longer needed as tooltips are always generated on hover now")}initializeColumn(e){e.definition.headerTooltip&&!this.headerSubscriber&&(this.headerSubscriber=!0,this.subscribe("column-mousemove",this.mousemoveCheck.bind(this,"headerTooltip")),this.subscribe("column-mouseout",this.mouseoutCheck.bind(this,"headerTooltip"))),e.definition.tooltip&&!this.tooltipSubscriber&&(this.tooltipSubscriber=!0,this.subscribe("cell-mousemove",this.mousemoveCheck.bind(this,"tooltip")),this.subscribe("cell-mouseout",this.mouseoutCheck.bind(this,"tooltip")))}mousemoveCheck(e,t,i){var s="tooltip"===e?i.column.definition.tooltip:i.definition.headerTooltip;s&&(this.clearPopup(),this.timeout=setTimeout(this.loadTooltip.bind(this,t,i,s),this.table.options.tooltipDelay))}mouseoutCheck(e,t,i){this.popupInstance||this.clearPopup()}clearPopup(e,t,i){clearTimeout(this.timeout),this.timeout=null,this.popupInstance&&this.popupInstance.hide()}loadTooltip(e,t,i){var s,o,n;"function"==typeof i&&(i=i(e,t.getComponent(),(function(e){o=e}))),i instanceof HTMLElement?s=i:(s=document.createElement("div"),!0===i&&(t instanceof m?i=t.value:t.definition.field?this.langBind("columns|"+t.definition.field,(e=>{s.innerHTML=i=e||t.definition.title})):i=t.definition.title),s.innerHTML=i),(i||0===i||!1===i)&&(s.classList.add("tabulator-tooltip"),s.addEventListener("mousemove",(e=>e.preventDefault())),this.popupInstance=this.popup(s),"function"==typeof o&&this.popupInstance.renderCallback(o),n=this.popupInstance.containerEventCoords(e),this.popupInstance.show(n.x+15,n.y+15).hideOnBlur((()=>{this.dispatchExternal("TooltipClosed",t.getComponent()),this.popupInstance=null})),this.dispatchExternal("TooltipOpened",t.getComponent()))}}pe.moduleName="tooltip";var me={integer:function(e,t,i){return""===t||null==t||(t=Number(t),!isNaN(t)&&isFinite(t)&&Math.floor(t)===t)},float:function(e,t,i){return""===t||null==t||(t=Number(t),!isNaN(t)&&isFinite(t)&&t%1!=0)},numeric:function(e,t,i){return""===t||null==t||!isNaN(t)},string:function(e,t,i){return""===t||null==t||isNaN(t)},max:function(e,t,i){return""===t||null==t||parseFloat(t)<=i},min:function(e,t,i){return""===t||null==t||parseFloat(t)>=i},starts:function(e,t,i){return""===t||null==t||String(t).toLowerCase().startsWith(String(i).toLowerCase())},ends:function(e,t,i){return""===t||null==t||String(t).toLowerCase().endsWith(String(i).toLowerCase())},minLength:function(e,t,i){return""===t||null==t||String(t).length>=i},maxLength:function(e,t,i){return""===t||null==t||String(t).length<=i},in:function(e,t,i){return""===t||null==t||("string"==typeof i&&(i=i.split("|")),i.indexOf(t)>-1)},regex:function(e,t,i){return""===t||null==t||new RegExp(i).test(t)},unique:function(e,t,i){if(""===t||null==t)return!0;var s=!0,o=e.getData(),n=e.getColumn()._getSelf();return this.table.rowManager.rows.forEach((function(e){var i=e.getData();i!==o&&t==n.getFieldValue(i)&&(s=!1)})),s},required:function(e,t,i){return""!==t&&null!=t}};class ge extends s{constructor(e){super(e),this.invalidCells=[],this.registerTableOption("validationMode","blocking"),this.registerColumnOption("validator"),this.registerTableFunction("getInvalidCells",this.getInvalidCells.bind(this)),this.registerTableFunction("clearCellValidation",this.userClearCellValidation.bind(this)),this.registerTableFunction("validate",this.userValidate.bind(this)),this.registerComponentFunction("cell","isValid",this.cellIsValid.bind(this)),this.registerComponentFunction("cell","clearValidation",this.clearValidation.bind(this)),this.registerComponentFunction("cell","validate",this.cellValidate.bind(this)),this.registerComponentFunction("column","validate",this.columnValidate.bind(this)),this.registerComponentFunction("row","validate",this.rowValidate.bind(this))}initialize(){this.subscribe("cell-delete",this.clearValidation.bind(this)),this.subscribe("column-layout",this.initializeColumnCheck.bind(this)),this.subscribe("edit-success",this.editValidate.bind(this)),this.subscribe("edit-editor-clear",this.editorClear.bind(this)),this.subscribe("edit-edited-clear",this.editedClear.bind(this))}editValidate(e,t,i){var s="manual"===this.table.options.validationMode||this.validate(e.column.modules.validate,e,t);return!0!==s&&setTimeout((()=>{e.getElement().classList.add("tabulator-validation-fail"),this.dispatchExternal("validationFailed",e.getComponent(),t,s)})),s}editorClear(e,t){t&&e.column.modules.validate&&this.cellValidate(e),e.getElement().classList.remove("tabulator-validation-fail")}editedClear(e){e.modules.validate&&(e.modules.validate.invalid=!1)}cellIsValid(e){return e.modules.validate&&e.modules.validate.invalid||!0}cellValidate(e){return this.validate(e.column.modules.validate,e,e.getValue())}columnValidate(e){var t=[];return e.cells.forEach((e=>{!0!==this.cellValidate(e)&&t.push(e.getComponent())})),!t.length||t}rowValidate(e){var t=[];return e.cells.forEach((e=>{!0!==this.cellValidate(e)&&t.push(e.getComponent())})),!t.length||t}userClearCellValidation(e){e||(e=this.getInvalidCells()),Array.isArray(e)||(e=[e]),e.forEach((e=>{this.clearValidation(e._getSelf())}))}userValidate(e){var t=[];return this.table.rowManager.rows.forEach((e=>{var i=(e=e.getComponent()).validate();!0!==i&&(t=t.concat(i))})),!t.length||t}initializeColumnCheck(e){void 0!==e.definition.validator&&this.initializeColumn(e)}initializeColumn(e){var t,i=this,s=[];e.definition.validator&&(Array.isArray(e.definition.validator)?e.definition.validator.forEach((e=>{(t=i._extractValidator(e))&&s.push(t)})):(t=this._extractValidator(e.definition.validator))&&s.push(t),e.modules.validate=!!s.length&&s)}_extractValidator(e){var t,i,s;switch(typeof e){case"string":return(s=e.indexOf(":"))>-1?(t=e.substring(0,s),i=e.substring(s+1)):t=e,this._buildValidator(t,i);case"function":return this._buildValidator(e);case"object":return this._buildValidator(e.type,e.parameters)}}_buildValidator(e,t){var i="function"==typeof e?e:ge.validators[e];return i?{type:"function"==typeof e?"function":e,func:i,params:t}:(console.warn("Validator Setup Error - No matching validator found:",e),!1)}validate(e,t,i){var s=this,o=[],n=this.invalidCells.indexOf(t);return e&&e.forEach((e=>{e.func.call(s,t.getComponent(),i,e.params)||o.push({type:e.type,parameters:e.params})})),t.modules.validate||(t.modules.validate={}),o.length?(t.modules.validate.invalid=o,"manual"!==this.table.options.validationMode&&t.getElement().classList.add("tabulator-validation-fail"),-1==n&&this.invalidCells.push(t)):(t.modules.validate.invalid=!1,t.getElement().classList.remove("tabulator-validation-fail"),n>-1&&this.invalidCells.splice(n,1)),!o.length||o}getInvalidCells(){var e=[];return this.invalidCells.forEach((t=>{e.push(t.getComponent())})),e}clearValidation(e){var t;e.modules.validate&&e.modules.validate.invalid&&(e.getElement().classList.remove("tabulator-validation-fail"),e.modules.validate.invalid=!1,(t=this.invalidCells.indexOf(e))>-1&&this.invalidCells.splice(t,1))}}ge.moduleName="validate",ge.validators=me;var be=Object.freeze({__proto__:null,AccessorModule:o,AjaxModule:d,ClipboardModule:c,ColumnCalcsModule:E,DataTreeModule:y,DownloadModule:x,EditModule:L,ExportModule:P,FilterModule:F,FormatModule:O,FrozenColumnsModule:A,FrozenRowsModule:_,GroupRowsModule:V,HistoryModule:N,HtmlTableImportModule:W,ImportModule:G,InteractionModule:U,KeybindingsModule:X,MenuModule:q,MoveColumnsModule:K,MoveRowsModule:J,MutatorModule:Y,PageModule:Z,PersistenceModule:te,PopupModule:ie,PrintModule:se,ReactiveDataModule:oe,ResizeColumnsModule:ne,ResizeRowsModule:re,ResizeTableModule:ae,ResponsiveLayoutModule:le,SelectRowModule:he,SortModule:ue,TooltipModule:pe,ValidateModule:ge});class fe{constructor(e,t,i={}){this.table=e,this.msgType=t,this.registeredDefaults=Object.assign({},i)}register(e,t){this.registeredDefaults[e]=t}generate(e,t={}){var i=Object.assign({},this.registeredDefaults),s=this.table.options.debugInvalidOptions||!0===t.debugInvalidOptions;Object.assign(i,e);for(let e in t)i.hasOwnProperty(e)||(s&&console.warn("Invalid "+this.msgType+" option:",e),i[e]=t.key);for(let e in i)e in t?i[e]=t[e]:Array.isArray(i[e])?i[e]=Object.assign([],i[e]):"object"==typeof i[e]&&null!==i[e]?i[e]=Object.assign({},i[e]):void 0===i[e]&&delete i[e];return i}}class ve extends e{constructor(e){super(e),this.elementVertical=e.rowManager.element,this.elementHorizontal=e.columnManager.element,this.tableElement=e.rowManager.tableElement,this.verticalFillMode="fit"}initialize(){}clearRows(){}clearColumns(){}reinitializeColumnWidths(e){}renderRows(){}renderColumns(){}rerenderRows(e){e&&e()}rerenderColumns(e,t){}renderRowCells(e){}rerenderRowCells(e,t){}scrollColumns(e,t){}scrollRows(e,t){}resize(){}scrollToRow(e){}scrollToRowNearestTop(e){}visibleRows(e){return[]}rows(){return this.table.rowManager.getDisplayRows()}styleRow(e,t){var i=e.getElement();t%2?(i.classList.add("tabulator-row-even"),i.classList.remove("tabulator-row-odd")):(i.classList.add("tabulator-row-odd"),i.classList.remove("tabulator-row-even"))}clear(){this.clearRows(),this.clearColumns()}render(){this.renderRows(),this.renderColumns()}rerender(e){this.rerenderRows(),this.rerenderColumns()}scrollToRowPosition(e,i,s){var o=this.rows().indexOf(e),n=e.getElement(),r=0;return new Promise(((a,l)=>{if(o>-1){if(void 0===s&&(s=this.table.options.scrollToRowIfVisible),!s&&t.elVisible(n)&&(r=t.elOffset(n).top-t.elOffset(this.elementVertical).top)>0&&r{i.appendChild(e.getElement())})),e.element.appendChild(i),t||e.cells.forEach((e=>{e.cellRendered()}))}reinitializeColumnWidths(e){e.forEach((function(e){e.reinitializeWidth()}))}}class Ce extends ve{constructor(e){super(e),this.leftCol=0,this.rightCol=0,this.scrollLeft=0,this.vDomScrollPosLeft=0,this.vDomScrollPosRight=0,this.vDomPadLeft=0,this.vDomPadRight=0,this.fitDataColAvg=0,this.windowBuffer=200,this.visibleRows=null,this.initialized=!1,this.isFitData=!1,this.columns=[]}initialize(){this.compatibilityCheck(),this.layoutCheck(),this.vertScrollListen()}compatibilityCheck(){"fitDataTable"==this.options("layout")&&console.warn("Horizontal Virtual DOM is not compatible with fitDataTable layout mode"),this.options("responsiveLayout")&&console.warn("Horizontal Virtual DOM is not compatible with responsive columns"),this.options("rtl")&&console.warn("Horizontal Virtual DOM is not currently compatible with RTL text direction")}layoutCheck(){this.isFitData=this.options("layout").startsWith("fitData")}vertScrollListen(){this.subscribe("scroll-vertical",this.clearVisRowCache.bind(this)),this.subscribe("data-refreshed",this.clearVisRowCache.bind(this))}clearVisRowCache(){this.visibleRows=null}renderColumns(e,t){this.dataChange()}scrollColumns(e,t){this.scrollLeft!=e&&(this.scrollLeft=e,this.scroll(e-(this.vDomScrollPosLeft+this.windowBuffer)))}calcWindowBuffer(){var e=this.elementVertical.clientWidth;this.table.columnManager.columnsByIndex.forEach((t=>{if(t.visible){var i=t.getWidth();i>e&&(e=i)}})),this.windowBuffer=2*e}rerenderColumns(e,t){var i={cols:this.columns,leftCol:this.leftCol,rightCol:this.rightCol},s=0;e&&!this.initialized||(this.clear(),this.calcWindowBuffer(),this.scrollLeft=this.elementVertical.scrollLeft,this.vDomScrollPosLeft=this.scrollLeft-this.windowBuffer,this.vDomScrollPosRight=this.scrollLeft+this.elementVertical.clientWidth+this.windowBuffer,this.table.columnManager.columnsByIndex.forEach((e=>{var t,i={};e.visible&&(e.modules.frozen||(t=e.getWidth(),i.leftPos=s,i.rightPos=s+t,i.width=t,this.isFitData&&(i.fitDataCheck=!e.modules.vdomHoz||e.modules.vdomHoz.fitDataCheck),s+t>this.vDomScrollPosLeft&&s{t.appendChild(e.getElement())})),e.element.appendChild(t),e.cells.forEach((e=>{e.cellRendered()}))}}rerenderRowCells(e,t){this.reinitializeRow(e,t)}reinitializeColumnWidths(e){for(let e=this.leftCol;e<=this.rightCol;e++)this.columns[e].reinitializeWidth()}deinitialize(){this.initialized=!1}clear(){this.columns=[],this.leftCol=-1,this.rightCol=0,this.vDomScrollPosLeft=0,this.vDomScrollPosRight=0,this.vDomPadLeft=0,this.vDomPadRight=0}dataChange(){var e,t,i=!1;if(this.isFitData){if(this.table.columnManager.columnsByIndex.forEach((e=>{!e.definition.width&&e.visible&&(i=!0)})),i&&this.table.rowManager.getDisplayRows().length&&(this.vDomScrollPosRight=this.scrollLeft+this.elementVertical.clientWidth+this.windowBuffer,e=this.chain("rows-sample",[1],[],(()=>this.table.rowManager.getDisplayRows()))[0])){t=e.getElement(),e.generateCells(),this.tableElement.appendChild(t);for(let i=0;i{e!==this.columns[i]&&(t=!1)})),!t)}reinitializeRows(){var e=this.getVisibleRows(),t=this.table.rowManager.getRows().filter((t=>!e.includes(t)));e.forEach((e=>{this.reinitializeRow(e,!0)})),t.forEach((e=>{e.deinitialize()}))}getVisibleRows(){return this.visibleRows||(this.visibleRows=this.table.rowManager.getVisibleRows()),this.visibleRows}scroll(e){this.vDomScrollPosLeft+=e,this.vDomScrollPosRight+=e,Math.abs(e)>this.windowBuffer/2?this.rerenderColumns():e>0?(this.addColRight(),this.removeColLeft()):(this.addColLeft(),this.removeColRight())}colPositionAdjust(e,t,i){for(let s=e;s{if("group"!==e.type){var t=e.getCell(i);e.getElement().insertBefore(t.getElement(),e.getCell(this.columns[this.rightCol]).getElement().nextSibling),t.cellRendered()}})),this.fitDataColActualWidthCheck(i),this.rightCol++,this.getVisibleRows().forEach((e=>{"group"!==e.type&&(e.modules.vdomHoz.rightCol=this.rightCol)})),this.rightCol>=this.columns.length-1?this.vDomPadRight=0:this.vDomPadRight-=i.getWidth()):t=!1}e&&(this.tableElement.style.paddingRight=this.vDomPadRight+"px")}addColLeft(){for(var e=!1,t=!0;t;){let i=this.columns[this.leftCol-1];if(i)if(i.modules.vdomHoz.rightPos>=this.vDomScrollPosLeft){e=!0,this.getVisibleRows().forEach((e=>{if("group"!==e.type){var t=e.getCell(i);e.getElement().insertBefore(t.getElement(),e.getCell(this.columns[this.leftCol]).getElement()),t.cellRendered()}})),this.leftCol--,this.getVisibleRows().forEach((e=>{"group"!==e.type&&(e.modules.vdomHoz.leftCol=this.leftCol)})),this.leftCol<=0?this.vDomPadLeft=0:this.vDomPadLeft-=i.getWidth();let t=this.fitDataColActualWidthCheck(i);t&&(this.scrollLeft=this.elementVertical.scrollLeft=this.elementVertical.scrollLeft+t,this.vDomPadRight-=t)}else t=!1;else t=!1}e&&(this.tableElement.style.paddingLeft=this.vDomPadLeft+"px")}removeColRight(){for(var e=!1,t=!0;t;){let i=this.columns[this.rightCol];i&&i.modules.vdomHoz.leftPos>this.vDomScrollPosRight?(e=!0,this.getVisibleRows().forEach((e=>{if("group"!==e.type){var t=e.getCell(i);try{e.getElement().removeChild(t.getElement())}catch(e){console.warn("Could not removeColRight",e.message)}}})),this.vDomPadRight+=i.getWidth(),this.rightCol--,this.getVisibleRows().forEach((e=>{"group"!==e.type&&(e.modules.vdomHoz.rightCol=this.rightCol)}))):t=!1}e&&(this.tableElement.style.paddingRight=this.vDomPadRight+"px")}removeColLeft(){for(var e=!1,t=!0;t;){let i=this.columns[this.leftCol];i&&i.modules.vdomHoz.rightPos{if("group"!==e.type){var t=e.getCell(i);try{e.getElement().removeChild(t.getElement())}catch(e){console.warn("Could not removeColLeft",e.message)}}})),this.vDomPadLeft+=i.getWidth(),this.leftCol++,this.getVisibleRows().forEach((e=>{"group"!==e.type&&(e.modules.vdomHoz.leftCol=this.leftCol)}))):t=!1}e&&(this.tableElement.style.paddingLeft=this.vDomPadLeft+"px")}fitDataColActualWidthCheck(e){var t,i;return e.modules.vdomHoz.fitDataCheck&&(e.reinitializeWidth(),(i=(t=e.getWidth())-e.modules.vdomHoz.width)&&(e.modules.vdomHoz.rightPos+=i,e.modules.vdomHoz.width=t,this.colPositionAdjust(this.columns.indexOf(e)+1,this.columns.length,i)),e.modules.vdomHoz.fitDataCheck=!1),i}initializeRow(e){if("group"!==e.type){e.modules.vdomHoz={leftCol:this.leftCol,rightCol:this.rightCol},this.table.modules.frozenColumns&&this.table.modules.frozenColumns.leftColumns.forEach((t=>{this.appendCell(e,t)}));for(let t=this.leftCol;t<=this.rightCol;t++)this.appendCell(e,this.columns[t]);this.table.modules.frozenColumns&&this.table.modules.frozenColumns.rightColumns.forEach((t=>{this.appendCell(e,t)}))}}appendCell(e,t){if(t&&t.visible){let i=e.getCell(t);e.getElement().appendChild(i.getElement()),i.cellRendered()}}reinitializeRow(e,t){if("group"!==e.type&&(t||!e.modules.vdomHoz||e.modules.vdomHoz.leftCol!==this.leftCol||e.modules.vdomHoz.rightCol!==this.rightCol)){for(var i=e.getElement();i.firstChild;)i.removeChild(i.firstChild);this.initializeRow(e)}}}class Ee extends e{constructor(e){super(e),this.blockHozScrollEvent=!1,this.headersElement=null,this.contentsElement=null,this.element=null,this.columns=[],this.columnsByIndex=[],this.columnsByField={},this.scrollLeft=0,this.optionsList=new fe(this.table,"column definition",b),this.redrawBlock=!1,this.redrawBlockUpdate=null,this.renderer=null}initialize(){this.initializeRenderer(),this.headersElement=this.createHeadersElement(),this.contentsElement=this.createHeaderContentsElement(),this.element=this.createHeaderElement(),this.contentsElement.insertBefore(this.headersElement,this.contentsElement.firstChild),this.element.insertBefore(this.contentsElement,this.element.firstChild),this.initializeScrollWheelWatcher(),this.subscribe("scroll-horizontal",this.scrollHorizontal.bind(this)),this.subscribe("scrollbar-vertical",this.padVerticalScrollbar.bind(this))}padVerticalScrollbar(e){this.table.rtl?this.headersElement.style.marginLeft=e+"px":this.headersElement.style.marginRight=e+"px"}initializeRenderer(){var e,t={virtual:Ce,basic:we};(e="string"==typeof this.table.options.renderHorizontal?t[this.table.options.renderHorizontal]:this.table.options.renderHorizontal)?(this.renderer=new e(this.table,this.element,this.tableElement),this.renderer.initialize()):console.error("Unable to find matching renderer:",this.table.options.renderHorizontal)}createHeadersElement(){var e=document.createElement("div");return e.classList.add("tabulator-headers"),e.setAttribute("role","row"),e}createHeaderContentsElement(){var e=document.createElement("div");return e.classList.add("tabulator-header-contents"),e.setAttribute("role","rowgroup"),e}createHeaderElement(){var e=document.createElement("div");return e.classList.add("tabulator-header"),e.setAttribute("role","rowgroup"),this.table.options.headerVisible||e.classList.add("tabulator-header-hidden"),e}getElement(){return this.element}getContentsElement(){return this.contentsElement}getHeadersElement(){return this.headersElement}scrollHorizontal(e){this.contentsElement.scrollLeft=e,this.scrollLeft=e,this.renderer.scrollColumns(e)}initializeScrollWheelWatcher(){this.contentsElement.addEventListener("wheel",(e=>{var t;e.deltaX&&(t=this.contentsElement.scrollLeft+e.deltaX,this.table.rowManager.scrollHorizontal(t),this.table.columnManager.scrollHorizontal(t))}))}generateColumnsFromRowData(e){var t,i,s=[],o=this.table.options.autoColumnsDefinitions;if(e&&e.length){for(var n in t=e[0]){let e={field:n,title:n},o=t[n];switch(typeof o){case"undefined":i="string";break;case"boolean":i="boolean";break;case"object":i=Array.isArray(o)?"array":"string";break;default:i=isNaN(o)||""===o?o.match(/((^[0-9]+[a-z]+)|(^[a-z]+[0-9]+))+$/i)?"alphanum":"string":"number"}e.sorter=i,s.push(e)}if(o)switch(typeof o){case"function":this.table.options.columns=o.call(this.table,s);break;case"object":Array.isArray(o)?s.forEach((e=>{var t=o.find((t=>t.field===e.field));t&&Object.assign(e,t)})):s.forEach((e=>{o[e.field]&&Object.assign(e,o[e.field])})),this.table.options.columns=s}else this.table.options.columns=s;this.setColumns(this.table.options.columns)}}setColumns(e,t){for(;this.headersElement.firstChild;)this.headersElement.removeChild(this.headersElement.firstChild);this.columns=[],this.columnsByIndex=[],this.columnsByField={},this.dispatch("columns-loading"),e.forEach(((e,t)=>{this._addColumn(e)})),this._reIndexColumns(),this.dispatch("columns-loaded"),this.rerenderColumns(!1,!0),this.redraw(!0)}_addColumn(e,t,i){var s=new f(e,this),o=s.getElement(),n=i?this.findColumnIndex(i):i;if(i&&n>-1){var r=i.getTopColumn(),a=this.columns.indexOf(r),l=r.getElement();t?(this.columns.splice(a,0,s),l.parentNode.insertBefore(o,l)):(this.columns.splice(a+1,0,s),l.parentNode.insertBefore(o,l.nextSibling))}else t?(this.columns.unshift(s),this.headersElement.insertBefore(s.getElement(),this.headersElement.firstChild)):(this.columns.push(s),this.headersElement.appendChild(s.getElement()));return s.columnRendered(),s}registerColumnField(e){e.definition.field&&(this.columnsByField[e.definition.field]=e)}registerColumnPosition(e){this.columnsByIndex.push(e)}_reIndexColumns(){this.columnsByIndex=[],this.columns.forEach((function(e){e.reRegisterPosition()}))}verticalAlignHeaders(){var e=0;this.redrawBlock||(this.headersElement.style.height="",this.columns.forEach((e=>{e.clearVerticalAlign()})),this.columns.forEach((t=>{var i=t.getHeight();i>e&&(e=i)})),this.headersElement.style.height=e+"px",this.columns.forEach((t=>{t.verticalAlign(this.table.options.columnHeaderVertAlign,e)})),this.table.rowManager.adjustTableSize())}findColumn(e){var t;if("object"!=typeof e)return this.columnsByField[e]||!1;if(e instanceof f)return e;if(e instanceof g)return e._getSelf()||!1;if("undefined"!=typeof HTMLElement&&e instanceof HTMLElement){return t=[],this.columns.forEach((e=>{t.push(e),t=t.concat(e.getColumns(!0))})),t.find((t=>t.element===e))||!1}return!1}getColumnByField(e){return this.columnsByField[e]}getColumnsByFieldRoot(e){var t=[];return Object.keys(this.columnsByField).forEach((i=>{i.split(".")[0]===e&&t.push(this.columnsByField[i])})),t}getColumnByIndex(e){return this.columnsByIndex[e]}getFirstVisibleColumn(){var e=this.columnsByIndex.findIndex((e=>e.visible));return e>-1&&this.columnsByIndex[e]}getColumns(){return this.columns}findColumnIndex(e){return this.columnsByIndex.findIndex((t=>e===t))}getRealColumns(){return this.columnsByIndex}traverse(e){this.columnsByIndex.forEach(((t,i)=>{e(t,i)}))}getDefinitions(e){var t=[];return this.columnsByIndex.forEach((i=>{(!e||e&&i.visible)&&t.push(i.getDefinition())})),t}getDefinitionTree(){var e=[];return this.columns.forEach((t=>{e.push(t.getDefinition(!0))})),e}getComponents(e){var t=[];return(e?this.columns:this.columnsByIndex).forEach((e=>{t.push(e.getComponent())})),t}getWidth(){var e=0;return this.columnsByIndex.forEach((t=>{t.visible&&(e+=t.getWidth())})),e}moveColumn(e,t,i){t.element.parentNode.insertBefore(e.element,t.element),i&&t.element.parentNode.insertBefore(t.element,e.element),this.moveColumnActual(e,t,i),this.verticalAlignHeaders(),this.table.rowManager.reinitialize()}moveColumnActual(e,t,i){e.parent.isGroup?this._moveColumnInArray(e.parent.columns,e,t,i):this._moveColumnInArray(this.columns,e,t,i),this._moveColumnInArray(this.columnsByIndex,e,t,i,!0),this.rerenderColumns(!0),this.dispatch("column-moved",e,t,i),this.subscribedExternal("columnMoved")&&this.dispatchExternal("columnMoved",e.getComponent(),this.table.columnManager.getComponents())}_moveColumnInArray(e,t,i,s,o){var n,r=e.indexOf(t);r>-1&&(e.splice(r,1),(n=e.indexOf(i))>-1?s&&(n+=1):n=r,e.splice(n,0,t),o&&(this.chain("column-moving-rows",[t,i,s],null,[])||[]).concat(this.table.rowManager.rows).forEach((function(e){if(e.cells.length){var t=e.cells.splice(r,1)[0];e.cells.splice(n,0,t)}})))}scrollToColumn(e,t,i){var s=0,o=e.getLeftOffset(),n=0,r=e.getElement();return new Promise(((a,l)=>{if(void 0===t&&(t=this.table.options.scrollToColumnPosition),void 0===i&&(i=this.table.options.scrollToColumnIfVisible),e.visible){switch(t){case"middle":case"center":n=-this.element.clientWidth/2;break;case"right":n=r.clientWidth-this.headersElement.clientWidth}if(!i&&o>0&&o+r.offsetWidth{t.push(i.generateCell(e))})),t}getFlexBaseWidth(){var e=this.table.element.clientWidth,t=0;return this.table.rowManager.element.scrollHeight>this.table.rowManager.element.clientHeight&&(e-=this.table.rowManager.element.offsetWidth-this.table.rowManager.element.clientWidth),this.columnsByIndex.forEach((function(i){var s,o,n;i.visible&&(s=i.definition.width||0,o=parseInt(i.minWidth),n="string"==typeof s?s.indexOf("%")>-1?e/100*parseInt(s):parseInt(s):s,t+=n>o?n:o)})),t}addColumn(e,t,i){return new Promise(((s,o)=>{var n=this._addColumn(e,t,i);this._reIndexColumns(),this.dispatch("column-add",e,t,i),"fitColumns"!=this.layoutMode()&&n.reinitializeWidth(),this.redraw(!0),this.table.rowManager.reinitialize(),this.rerenderColumns(),s(n)}))}deregisterColumn(e){var t,i=e.getField();i&&delete this.columnsByField[i],(t=this.columnsByIndex.indexOf(e))>-1&&this.columnsByIndex.splice(t,1),(t=this.columns.indexOf(e))>-1&&this.columns.splice(t,1),this.verticalAlignHeaders(),this.redraw()}rerenderColumns(e,t){this.redrawBlock?(!1===e||!0===e&&null===this.redrawBlockUpdate)&&(this.redrawBlockUpdate=e):this.renderer.rerenderColumns(e,t)}blockRedraw(){this.redrawBlock=!0,this.redrawBlockUpdate=null}restoreRedraw(){this.redrawBlock=!1,this.verticalAlignHeaders(),this.renderer.rerenderColumns(this.redrawBlockUpdate)}redraw(e){t.elVisible(this.element)&&this.verticalAlignHeaders(),e&&(this.table.rowManager.resetScroll(),this.table.rowManager.reinitialize()),this.confirm("table-redrawing",e)||this.layoutRefresh(e),this.dispatch("table-redraw",e),this.table.footerManager.redraw()}}class ye extends ve{constructor(e){super(e),this.verticalFillMode="fill",this.scrollTop=0,this.scrollLeft=0,this.scrollTop=0,this.scrollLeft=0}clearRows(){for(var e=this.tableElement;e.firstChild;)e.removeChild(e.firstChild);e.scrollTop=0,e.scrollLeft=0,e.style.minWidth="",e.style.minHeight="",e.style.display="",e.style.visibility=""}renderRows(){var e=this.tableElement,t=!0,i=document.createDocumentFragment(),s=this.rows();s.forEach(((e,s)=>{this.styleRow(e,s),e.initialize(!1,!0),"group"!==e.type&&(t=!1),i.appendChild(e.getElement())})),e.appendChild(i),s.forEach((e=>{e.rendered(),e.heightInitialized||e.calcHeight(!0)})),s.forEach((e=>{e.heightInitialized||e.setCellHeight()})),e.style.minWidth=t?this.table.columnManager.getWidth()+"px":""}rerenderRows(e){this.clearRows(),e&&e(),this.renderRows()}scrollToRowNearestTop(e){var i=t.elOffset(e.getElement()).top;return!(Math.abs(this.elementVertical.scrollTop-i)>Math.abs(this.elementVertical.scrollTop+this.elementVertical.clientHeight-i))}scrollToRow(e){var i=e.getElement();this.elementVertical.scrollTop=t.elOffset(i).top-t.elOffset(this.elementVertical).top+this.elementVertical.scrollTop}visibleRows(e){return this.rows()}}class Re extends ve{constructor(e){super(e),this.verticalFillMode="fill",this.scrollTop=0,this.scrollLeft=0,this.vDomRowHeight=20,this.vDomTop=0,this.vDomBottom=0,this.vDomScrollPosTop=0,this.vDomScrollPosBottom=0,this.vDomTopPad=0,this.vDomBottomPad=0,this.vDomMaxRenderChain=90,this.vDomWindowBuffer=0,this.vDomWindowMinTotalRows=20,this.vDomWindowMinMarginRows=5,this.vDomTopNewRows=[],this.vDomBottomNewRows=[]}clearRows(){for(var e=this.tableElement;e.firstChild;)e.removeChild(e.firstChild);e.style.paddingTop="",e.style.paddingBottom="",e.style.minHeight="",e.style.display="",e.style.visibility="",this.elementVertical.scrollTop=0,this.elementVertical.scrollLeft=0,this.scrollTop=0,this.scrollLeft=0,this.vDomTop=0,this.vDomBottom=0,this.vDomTopPad=0,this.vDomBottomPad=0,this.vDomScrollPosTop=0,this.vDomScrollPosBottom=0}renderRows(){this._virtualRenderFill()}rerenderRows(e){for(var t=this.elementVertical.scrollTop,i=!1,s=!1,o=this.table.rowManager.scrollLeft,n=this.rows(),r=this.vDomTop;r<=this.vDomBottom;r++)if(n[r]){var a=t-n[r].getElement().offsetTop;if(!(!1===s||Math.abs(a){e.deinitializeHeight()})),e&&e(),this.rows().length?this._virtualRenderFill(!1===i?this.rows.length-1:i,!0,s||0):(this.clear(),this.table.rowManager.tableEmpty()),this.scrollColumns(o)}scrollColumns(e){this.table.rowManager.scrollHorizontal(e)}scrollRows(e,t){var i=e-this.vDomScrollPosTop,s=e-this.vDomScrollPosBottom,o=2*this.vDomWindowBuffer,n=this.rows();if(this.scrollTop=e,-i>o||s>o){var r=this.table.rowManager.scrollLeft;this._virtualRenderFill(Math.floor(this.elementVertical.scrollTop/this.elementVertical.scrollHeight*n.length)),this.scrollColumns(r)}else t?(i<0&&this._addTopRow(n,-i),s<0&&(this.vDomScrollHeight-this.scrollTop>this.vDomWindowBuffer?this._removeBottomRow(n,-s):this.vDomScrollPosBottom=this.scrollTop)):(s>=0&&this._addBottomRow(n,s),i>=0&&(this.scrollTop>this.vDomWindowBuffer?this._removeTopRow(n,i):this.vDomScrollPosTop=this.scrollTop))}resize(){this.vDomWindowBuffer=this.table.options.renderVerticalBuffer||this.elementVertical.clientHeight}scrollToRowNearestTop(e){var t=this.rows().indexOf(e);return!(Math.abs(this.vDomTop-t)>Math.abs(this.vDomBottom-t))}scrollToRow(e){var t=this.rows().indexOf(e);t>-1&&this._virtualRenderFill(t,!0)}visibleRows(e){var t=this.elementVertical.scrollTop,i=this.elementVertical.clientHeight+t,s=!1,o=0,n=0,r=this.rows();if(e)o=this.vDomTop,n=this.vDomBottom;else for(var a=this.vDomTop;a<=this.vDomBottom;a++)if(r[a])if(s){if(!(i-r[a].getElement().offsetTop>=0))break;n=a}else if(t-r[a].getElement().offsetTop>=0)o=a;else{if(s=!0,!(i-r[a].getElement().offsetTop>=0))break;n=a}return r.slice(o,n+1)}_virtualRenderFill(e,i,s){var o,n,r=this.tableElement,a=this.elementVertical,l=0,h=0,d=0,c=0,u=0,p=0,m=this.rows(),g=m.length,b=0,f=[],v=0,w=0,C=this.table.rowManager.fixedHeight,E=this.elementVertical.clientHeight,y=this.table.options.rowHeight,R=!0;if(s=s||0,e=e||0){for(;r.firstChild;)r.removeChild(r.firstChild);(c=(g-e+1)*this.vDomRowHeight){e.rendered(),e.heightInitialized||e.calcHeight(!0)})),f.forEach((e=>{e.heightInitialized||e.setCellHeight()})),f.forEach((e=>{d=e.getHeight(),vthis.vDomWindowBuffer&&(this.vDomWindowBuffer=2*d),v++})),R=this.table.rowManager.adjustTableSize(),E=this.elementVertical.clientHeight,R&&(C||this.table.options.maxHeight)&&(y=h/v,w=Math.max(this.vDomWindowMinTotalRows,Math.ceil(E/y+this.vDomWindowBuffer/y)))}e?(this.vDomTopPad=i?this.vDomRowHeight*this.vDomTop+s:this.scrollTop-u,this.vDomBottomPad=this.vDomBottom==g-1?0:Math.max(this.vDomScrollHeight-this.vDomTopPad-h-u,0)):(this.vDomTopPad=0,this.vDomRowHeight=Math.floor((h+u)/v),this.vDomBottomPad=this.vDomRowHeight*(g-this.vDomBottom-1),this.vDomScrollHeight=u+h+this.vDomBottomPad-E),r.style.paddingTop=this.vDomTopPad+"px",r.style.paddingBottom=this.vDomBottomPad+"px",i&&(this.scrollTop=this.vDomTopPad+u+s-(this.elementVertical.scrollWidth>this.elementVertical.clientWidth?this.elementVertical.offsetHeight-E:0)),this.scrollTop=Math.min(this.scrollTop,this.elementVertical.scrollHeight-E),this.elementVertical.scrollWidth>this.elementVertical.clientWidth&&i&&(this.scrollTop+=this.elementVertical.offsetHeight-E),this.vDomScrollPosTop=this.scrollTop,this.vDomScrollPosBottom=this.scrollTop,a.scrollTop=this.scrollTop,this.dispatch("render-virtual-fill")}}_addTopRow(e,t){for(var i=this.tableElement,s=[],o=0,n=this.vDomTop-1,r=0,a=!0;a;)if(this.vDomTop){let l,h,d=e[n];d&&r=l?(this.styleRow(d,n),i.insertBefore(d.getElement(),i.firstChild),d.initialized&&d.heightInitialized||s.push(d),d.initialize(),h||(l=d.getElement().offsetHeight,l>this.vDomWindowBuffer&&(this.vDomWindowBuffer=2*l)),t-=l,o+=l,this.vDomTop--,n--,r++):a=!1):a=!1}else a=!1;for(let e of s)e.clearCellHeight();this._quickNormalizeRowHeight(s),o&&(this.vDomTopPad-=o,this.vDomTopPad<0&&(this.vDomTopPad=n*this.vDomRowHeight),n<1&&(this.vDomTopPad=0),i.style.paddingTop=this.vDomTopPad+"px",this.vDomScrollPosTop-=o)}_removeTopRow(e,t){for(var i=[],s=0,o=0,n=!0;n;){let r,a=e[this.vDomTop];a&&o=r?(this.vDomTop++,t-=r,s+=r,i.push(a),o++):n=!1):n=!1}for(let e of i){let t=e.getElement();t.parentNode&&t.parentNode.removeChild(t)}s&&(this.vDomTopPad+=s,this.tableElement.style.paddingTop=this.vDomTopPad+"px",this.vDomScrollPosTop+=this.vDomTop?s:s+this.vDomWindowBuffer)}_addBottomRow(e,t){for(var i=this.tableElement,s=[],o=0,n=this.vDomBottom+1,r=0,a=!0;a;){let l,h,d=e[n];d&&r=l?(this.styleRow(d,n),i.appendChild(d.getElement()),d.initialized&&d.heightInitialized||s.push(d),d.initialize(),h||(l=d.getElement().offsetHeight,l>this.vDomWindowBuffer&&(this.vDomWindowBuffer=2*l)),t-=l,o+=l,this.vDomBottom++,n++,r++):a=!1):a=!1}for(let e of s)e.clearCellHeight();this._quickNormalizeRowHeight(s),o&&(this.vDomBottomPad-=o,(this.vDomBottomPad<0||n==e.length-1)&&(this.vDomBottomPad=0),i.style.paddingBottom=this.vDomBottomPad+"px",this.vDomScrollPosBottom+=o)}_removeBottomRow(e,t){for(var i=[],s=0,o=0,n=!0;n;){let r,a=e[this.vDomBottom];a&&o=r?(this.vDomBottom--,t-=r,s+=r,i.push(a),o++):n=!1):n=!1}for(let e of i){let t=e.getElement();t.parentNode&&t.parentNode.removeChild(t)}s&&(this.vDomBottomPad+=s,this.vDomBottomPad<0&&(this.vDomBottomPad=0),this.tableElement.style.paddingBottom=this.vDomBottomPad+"px",this.vDomScrollPosBottom-=s)}_quickNormalizeRowHeight(e){for(let t of e)t.calcHeight();for(let t of e)t.setCellHeight()}}class xe extends e{constructor(e){super(e),this.element=this.createHolderElement(),this.tableElement=this.createTableElement(),this.heightFixer=this.createTableElement(),this.placeholder=null,this.placeholderContents=null,this.firstRender=!1,this.renderMode="virtual",this.fixedHeight=!1,this.rows=[],this.activeRowsPipeline=[],this.activeRows=[],this.activeRowsCount=0,this.displayRows=[],this.displayRowsCount=0,this.scrollTop=0,this.scrollLeft=0,this.redrawBlock=!1,this.redrawBlockRestoreConfig=!1,this.redrawBlockRenderInPosition=!1,this.dataPipeline=[],this.displayPipeline=[],this.scrollbarWidth=0,this.renderer=null}createHolderElement(){var e=document.createElement("div");return e.classList.add("tabulator-tableholder"),e.setAttribute("tabindex",0),e}createTableElement(){var e=document.createElement("div");return e.classList.add("tabulator-table"),e.setAttribute("role","rowgroup"),e}initializePlaceholder(){var e=this.table.options.placeholder;if("function"==typeof e&&(e=e.call(this.table)),e=this.chain("placeholder",[e],e,e)||e){let t=document.createElement("div");if(t.classList.add("tabulator-placeholder"),"string"==typeof e){let i=document.createElement("div");i.classList.add("tabulator-placeholder-contents"),i.innerHTML=e,t.appendChild(i),this.placeholderContents=i}else"undefined"!=typeof HTMLElement&&e instanceof HTMLElement?(t.appendChild(e),this.placeholderContents=e):(console.warn("Invalid placeholder provided, must be string or HTML Element",e),this.el=null);this.placeholder=t}}getElement(){return this.element}getTableElement(){return this.tableElement}initialize(){this.initializePlaceholder(),this.initializeRenderer(),this.element.appendChild(this.tableElement),this.firstRender=!0,this.element.addEventListener("scroll",(()=>{var e=this.element.scrollLeft,t=this.scrollLeft>e,i=this.element.scrollTop,s=this.scrollTop>i;this.scrollLeft!=e&&(this.scrollLeft=e,this.dispatch("scroll-horizontal",e,t),this.dispatchExternal("scrollHorizontal",e,t),this._positionPlaceholder()),this.scrollTop!=i&&(this.scrollTop=i,this.renderer.scrollRows(i,s),this.dispatch("scroll-vertical",i,s),this.dispatchExternal("scrollVertical",i,s))}))}findRow(e){if("object"!=typeof e){if(void 0===e)return!1;return this.rows.find((t=>t.data[this.table.options.index]==e))||!1}if(e instanceof w)return e;if(e instanceof v)return e._getSelf()||!1;if("undefined"!=typeof HTMLElement&&e instanceof HTMLElement){return this.rows.find((t=>t.getElement()===e))||!1}return!1}getRowFromDataObject(e){return this.rows.find((t=>t.data===e))||!1}getRowFromPosition(e){return this.getDisplayRows().find((t=>t.getPosition()===e&&t.isDisplayed()))}scrollToRow(e,t,i){return this.renderer.scrollToRowPosition(e,t,i)}setData(e,t,i){return new Promise(((s,o)=>{t&&this.getDisplayRows().length?this.table.options.pagination?this._setDataActual(e,!0):this.reRenderInPosition((()=>{this._setDataActual(e)})):(this.table.options.autoColumns&&i&&this.table.initialized&&this.table.columnManager.generateColumnsFromRowData(e),this.resetScroll(),this._setDataActual(e)),s()}))}_setDataActual(e,t){this.dispatchExternal("dataProcessing",e),this._wipeElements(),Array.isArray(e)?(this.dispatch("data-processing",e),e.forEach(((e,t)=>{if(e&&"object"==typeof e){var i=new w(e,this);this.rows.push(i)}else console.warn("Data Loading Warning - Invalid row data detected and ignored, expecting object but received:",e)})),this.refreshActiveData(!1,!1,t),this.dispatch("data-processed",e),this.dispatchExternal("dataProcessed",e)):console.error("Data Loading Error - Unable to process data due to invalid data type \nExpecting: array \nReceived: ",typeof e,"\nData: ",e)}_wipeElements(){this.dispatch("rows-wipe"),this.destroy(),this.adjustTableSize(),this.dispatch("rows-wiped")}destroy(){this.rows.forEach((e=>{e.wipe()})),this.rows=[],this.activeRows=[],this.activeRowsPipeline=[],this.activeRowsCount=0,this.displayRows=[],this.displayRowsCount=0}deleteRow(e,t){var i=this.rows.indexOf(e),s=this.activeRows.indexOf(e);s>-1&&this.activeRows.splice(s,1),i>-1&&this.rows.splice(i,1),this.setActiveRows(this.activeRows),this.displayRowIterator((t=>{var i=t.indexOf(e);i>-1&&t.splice(i,1)})),t||this.reRenderInPosition(),this.regenerateRowPositions(),this.dispatchExternal("rowDeleted",e.getComponent()),this.displayRowsCount||this.tableEmpty(),this.subscribedExternal("dataChanged")&&this.dispatchExternal("dataChanged",this.getData())}addRow(e,t,i,s){return this.addRowActual(e,t,i,s)}addRows(e,t,i,s){var o=[];return new Promise(((n,r)=>{t=this.findAddRowPos(t),Array.isArray(e)||(e=[e]),(void 0===i&&t||void 0!==i&&!t)&&e.reverse(),e.forEach(((e,s)=>{var n=this.addRow(e,t,i,!0);o.push(n),this.dispatch("row-added",n,e,t,i)})),this.refreshActiveData(!!s&&"displayPipeline",!1,!0),this.regenerateRowPositions(),o.length&&this._clearPlaceholder(),n(o)}))}findAddRowPos(e){return void 0===e&&(e=this.table.options.addRowPos),"pos"===e&&(e=!0),"bottom"===e&&(e=!1),e}addRowActual(e,t,i,s){var o,n,r=e instanceof w?e:new w(e||{},this),a=this.findAddRowPos(t),l=-1;return i||(n=this.chain("row-adding-position",[r,a],null,{index:i,top:a}),i=n.index,a=n.top),void 0!==i&&(i=this.findRow(i)),(i=this.chain("row-adding-index",[r,i,a],null,i))&&(l=this.rows.indexOf(i)),i&&l>-1?(o=this.activeRows.indexOf(i),this.displayRowIterator((function(e){var t=e.indexOf(i);t>-1&&e.splice(a?t:t+1,0,r)})),o>-1&&this.activeRows.splice(a?o:o+1,0,r),this.rows.splice(a?l:l+1,0,r)):a?(this.displayRowIterator((function(e){e.unshift(r)})),this.activeRows.unshift(r),this.rows.unshift(r)):(this.displayRowIterator((function(e){e.push(r)})),this.activeRows.push(r),this.rows.push(r)),this.setActiveRows(this.activeRows),this.dispatchExternal("rowAdded",r.getComponent()),this.subscribedExternal("dataChanged")&&this.dispatchExternal("dataChanged",this.table.rowManager.getData()),s||this.reRenderInPosition(),r}moveRow(e,t,i){this.dispatch("row-move",e,t,i),this.moveRowActual(e,t,i),this.regenerateRowPositions(),this.dispatch("row-moved",e,t,i),this.dispatchExternal("rowMoved",e.getComponent())}moveRowActual(e,t,i){this.moveRowInArray(this.rows,e,t,i),this.moveRowInArray(this.activeRows,e,t,i),this.displayRowIterator((s=>{this.moveRowInArray(s,e,t,i)})),this.dispatch("row-moving",e,t,i)}moveRowInArray(e,t,i,s){var o,n,r;if(t!==i&&((o=e.indexOf(t))>-1&&(e.splice(o,1),(n=e.indexOf(i))>-1?s?e.splice(n+1,0,t):e.splice(n,0,t):e.splice(o,0,t)),e===this.getDisplayRows())){r=n>o?n:o+1;for(let t=o-1&&t}nextDisplayRow(e,t){var i=this.getDisplayRowIndex(e),s=!1;return!1!==i&&i-1)&&i}getData(e,t){var i=[];return this.getRows(e).forEach((function(e){"row"==e.type&&i.push(e.getData(t||"data"))})),i}getComponents(e){var t=[];return this.getRows(e).forEach((function(e){t.push(e.getComponent())})),t}getDataCount(e){return this.getRows(e).length}scrollHorizontal(e){this.scrollLeft=e,this.element.scrollLeft=e,this.dispatch("scroll-horizontal",e)}registerDataPipelineHandler(e,t){void 0!==t?(this.dataPipeline.push({handler:e,priority:t}),this.dataPipeline.sort(((e,t)=>e.priority-t.priority))):console.error("Data pipeline handlers must have a priority in order to be registered")}registerDisplayPipelineHandler(e,t){void 0!==t?(this.displayPipeline.push({handler:e,priority:t}),this.displayPipeline.sort(((e,t)=>e.priority-t.priority))):console.error("Display pipeline handlers must have a priority in order to be registered")}refreshActiveData(e,i,s){var o=this.table,n="",r=0,a=["all","dataPipeline","display","displayPipeline","end"];if(!this.table.destroyed){if("function"==typeof e)if((r=this.dataPipeline.findIndex((t=>t.handler===e)))>-1)n="dataPipeline",i&&(r==this.dataPipeline.length-1?n="display":r++);else{if(!((r=this.displayPipeline.findIndex((t=>t.handler===e)))>-1))return void console.error("Unable to refresh data, invalid handler provided",e);n="displayPipeline",i&&(r==this.displayPipeline.length-1?n="end":r++)}else n=e||"all",r=0;if(this.redrawBlock)return void((!this.redrawBlockRestoreConfig||this.redrawBlockRestoreConfig&&(this.redrawBlockRestoreConfig.stage===n&&r{"row"===e.type&&(e.setPosition(t),t++)}))}setActiveRows(e){this.activeRows=this.activeRows=Object.assign([],e),this.activeRowsCount=this.activeRows.length}resetDisplayRows(){this.displayRows=[],this.displayRows.push(this.activeRows.slice(0)),this.displayRowsCount=this.displayRows[0].length}setDisplayRows(e,t){this.displayRows[t]=e,t==this.displayRows.length-1&&(this.displayRowsCount=this.displayRows[this.displayRows.length-1].length)}getDisplayRows(e){return void 0===e?this.displayRows.length?this.displayRows[this.displayRows.length-1]:[]:this.displayRows[e]||[]}getVisibleRows(e,t){var i=Object.assign([],this.renderer.visibleRows(!t));return e&&(i=this.chain("rows-visible",[t],i,i)),i}displayRowIterator(e){this.activeRowsPipeline.forEach(e),this.displayRows.forEach(e),this.displayRowsCount=this.displayRows[this.displayRows.length-1].length}getRows(e){var t=[];switch(e){case"active":t=this.activeRows;break;case"display":t=this.table.rowManager.getDisplayRows();break;case"visible":t=this.getVisibleRows(!1,!0);break;default:t=this.chain("rows-retrieve",e,null,this.rows)||this.rows}return t}reRenderInPosition(e){this.redrawBlock?e?e():this.redrawBlockRenderInPosition=!0:(this.dispatchExternal("renderStarted"),this.renderer.rerenderRows(e),this.fixedHeight||this.adjustTableSize(),this.scrollBarCheck(),this.dispatchExternal("renderComplete"))}scrollBarCheck(){var e=0;this.element.scrollHeight>this.element.clientHeight&&(e=this.element.offsetWidth-this.element.clientWidth),e!==this.scrollbarWidth&&(this.scrollbarWidth=e,this.dispatch("scrollbar-vertical",e))}initializeRenderer(){var e,t={virtual:Re,basic:ye};(e="string"==typeof this.table.options.renderVertical?t[this.table.options.renderVertical]:this.table.options.renderVertical)?(this.renderMode=this.table.options.renderVertical,this.renderer=new e(this.table,this.element,this.tableElement),this.renderer.initialize(),!this.table.element.clientHeight&&!this.table.options.height||this.table.options.minHeight&&this.table.options.maxHeight?this.fixedHeight=!1:this.fixedHeight=!0):console.error("Unable to find matching renderer:",this.table.options.renderVertical)}getRenderMode(){return this.renderMode}renderTable(){this.dispatchExternal("renderStarted"),this.element.scrollTop=0,this._clearTable(),this.displayRowsCount?(this.renderer.renderRows(),this.firstRender&&(this.firstRender=!1,this.fixedHeight||this.adjustTableSize(),this.layoutRefresh(!0))):this.renderEmptyScroll(),this.fixedHeight||this.adjustTableSize(),this.dispatch("table-layout"),this.displayRowsCount||this._showPlaceholder(),this.scrollBarCheck(),this.dispatchExternal("renderComplete")}renderEmptyScroll(){this.placeholder?this.tableElement.style.display="none":this.tableElement.style.minWidth=this.table.columnManager.getWidth()+"px"}_clearTable(){this._clearPlaceholder(),this.scrollTop=0,this.scrollLeft=0,this.renderer.clearRows()}tableEmpty(){this.renderEmptyScroll(),this._showPlaceholder()}_showPlaceholder(){this.placeholder&&(this.placeholder&&this.placeholder.parentNode&&this.placeholder.parentNode.removeChild(this.placeholder),this.initializePlaceholder(),this.placeholder.setAttribute("tabulator-render-mode",this.renderMode),this.getElement().appendChild(this.placeholder),this._positionPlaceholder(),this.adjustTableSize())}_clearPlaceholder(){this.placeholder&&this.placeholder.parentNode&&this.placeholder.parentNode.removeChild(this.placeholder),this.tableElement.style.minWidth="",this.tableElement.style.display=""}_positionPlaceholder(){this.placeholder&&this.placeholder.parentNode&&(this.placeholder.style.width=this.table.columnManager.getWidth()+"px",this.placeholderContents.style.width=this.table.rowManager.element.clientWidth+"px",this.placeholderContents.style.marginLeft=this.scrollLeft+"px")}styleRow(e,t){var i=e.getElement();t%2?(i.classList.add("tabulator-row-even"),i.classList.remove("tabulator-row-odd")):(i.classList.add("tabulator-row-odd"),i.classList.remove("tabulator-row-even"))}normalizeHeight(){this.activeRows.forEach((function(e){e.normalizeHeight()}))}adjustTableSize(){let e,t=this.element.clientHeight,i=!1;if("fill"===this.renderer.verticalFillMode){let s=Math.floor(this.table.columnManager.getElement().getBoundingClientRect().height+(this.table.footerManager&&this.table.footerManager.active&&!this.table.footerManager.external?this.table.footerManager.getElement().getBoundingClientRect().height:0));if(this.fixedHeight){e=isNaN(this.table.options.minHeight)?this.table.options.minHeight:this.table.options.minHeight+"px";const t="calc(100% - "+s+"px)";this.element.style.minHeight=e||"calc(100% - "+s+"px)",this.element.style.height=t,this.element.style.maxHeight=t}else this.element.style.height="",this.element.style.height=this.table.element.clientHeight-s+"px",this.element.scrollTop=this.scrollTop;this.renderer.resize(),this.fixedHeight||t==this.element.clientHeight||(i=!0,this.subscribed("table-resize")?this.dispatch("table-resize"):this.redraw()),this.scrollBarCheck()}return this._positionPlaceholder(),i}reinitialize(){this.rows.forEach((function(e){e.reinitialize(!0)}))}blockRedraw(){this.redrawBlock=!0,this.redrawBlockRestoreConfig=!1}restoreRedraw(){this.redrawBlock=!1,this.redrawBlockRestoreConfig?(this.refreshActiveData(this.redrawBlockRestoreConfig.handler,this.redrawBlockRestoreConfig.skipStage,this.redrawBlockRestoreConfig.renderInPosition),this.redrawBlockRestoreConfig=!1):this.redrawBlockRenderInPosition&&this.reRenderInPosition(),this.redrawBlockRenderInPosition=!1}redraw(e){const t=this.adjustTableSize();this.table.tableWidth=this.table.element.clientWidth,e?this.renderTable():(t&&this.reRenderInPosition(),this.scrollHorizontal(this.scrollLeft))}resetScroll(){if(this.element.scrollLeft=0,this.element.scrollTop=0,"ie"===this.table.browser){var e=document.createEvent("Event");e.initEvent("scroll",!1,!0),this.element.dispatchEvent(e)}else this.element.dispatchEvent(new Event("scroll"))}}class Te extends e{constructor(e){super(e),this.active=!1,this.element=this.createElement(),this.containerElement=this.createContainerElement(),this.external=!1}initialize(){this.initializeElement()}createElement(){var e=document.createElement("div");return e.classList.add("tabulator-footer"),e}createContainerElement(){var e=document.createElement("div");return e.classList.add("tabulator-footer-contents"),this.element.appendChild(e),e}initializeElement(){if(this.table.options.footerElement)if("string"==typeof this.table.options.footerElement)"<"===this.table.options.footerElement[0]?this.containerElement.innerHTML=this.table.options.footerElement:(this.external=!0,this.containerElement=document.querySelector(this.table.options.footerElement));else this.element=this.table.options.footerElement}getElement(){return this.element}append(e){this.activate(),this.containerElement.appendChild(e),this.table.rowManager.adjustTableSize()}prepend(e){this.activate(),this.element.insertBefore(e,this.element.firstChild),this.table.rowManager.adjustTableSize()}remove(e){e.parentNode.removeChild(e),this.deactivate()}deactivate(e){this.element.firstChild&&!e||(this.external||this.element.parentNode.removeChild(this.element),this.active=!1)}activate(){this.active||(this.active=!0,this.external||(this.table.element.appendChild(this.getElement()),this.table.element.style.display=""))}redraw(){this.dispatch("footer-redraw")}}class Me extends e{constructor(e){super(e),this.el=null,this.abortClasses=["tabulator-headers","tabulator-table"],this.previousTargets={},this.listeners=["click","dblclick","contextmenu","mouseenter","mouseleave","mouseover","mouseout","mousemove","mouseup","mousedown","touchstart","touchend"],this.componentMap={"tabulator-cell":"cell","tabulator-row":"row","tabulator-group":"group","tabulator-col":"column"},this.pseudoTrackers={row:{subscriber:null,target:null},cell:{subscriber:null,target:null},group:{subscriber:null,target:null},column:{subscriber:null,target:null}},this.pseudoTracking=!1}initialize(){this.el=this.table.element,this.buildListenerMap(),this.bindSubscriptionWatchers()}buildListenerMap(){var e={};this.listeners.forEach((t=>{e[t]={handler:null,components:[]}})),this.listeners=e}bindPseudoEvents(){Object.keys(this.pseudoTrackers).forEach((e=>{this.pseudoTrackers[e].subscriber=this.pseudoMouseEnter.bind(this,e),this.subscribe(e+"-mouseover",this.pseudoTrackers[e].subscriber)})),this.pseudoTracking=!0}pseudoMouseEnter(e,t,i){this.pseudoTrackers[e].target!==i&&(this.pseudoTrackers[e].target&&this.dispatch(e+"-mouseleave",t,this.pseudoTrackers[e].target),this.pseudoMouseLeave(e,t),this.pseudoTrackers[e].target=i,this.dispatch(e+"-mouseenter",t,i))}pseudoMouseLeave(e,t){var i=Object.keys(this.pseudoTrackers),s={row:["cell"],cell:["row"]};(i=i.filter((t=>{var i=s[e];return t!==e&&(!i||i&&!i.includes(t))}))).forEach((e=>{var i=this.pseudoTrackers[e].target;this.pseudoTrackers[e].target&&(this.dispatch(e+"-mouseleave",t,i),this.pseudoTrackers[e].target=null)}))}bindSubscriptionWatchers(){var e=Object.keys(this.listeners),t=Object.values(this.componentMap);for(let i of t)for(let t of e){let e=i+"-"+t;this.subscriptionChange(e,this.subscriptionChanged.bind(this,i,t))}this.subscribe("table-destroy",this.clearWatchers.bind(this))}subscriptionChanged(e,t,i){var s=this.listeners[t].components,o=s.indexOf(e),n=!1;i?-1===o&&(s.push(e),n=!0):this.subscribed(e+"-"+t)||o>-1&&(s.splice(o,1),n=!0),"mouseenter"!==t&&"mouseleave"!==t||this.pseudoTracking||this.bindPseudoEvents(),n&&this.updateEventListeners()}updateEventListeners(){for(let e in this.listeners){let t=this.listeners[e];t.components.length?t.handler||(t.handler=this.track.bind(this,e),this.el.addEventListener(e,t.handler)):t.handler&&(this.el.removeEventListener(e,t.handler),t.handler=null)}}track(e,t){var i=t.composedPath&&t.composedPath()||t.path,s=this.findTargets(i);s=this.bindComponents(e,s),this.triggerEvents(e,t,s),!this.pseudoTracking||"mouseover"!=e&&"mouseleave"!=e||Object.keys(s).length||this.pseudoMouseLeave("none",t)}findTargets(e){var t={};let i=Object.keys(this.componentMap);for(let s of e){let e=s.classList?[...s.classList]:[];if(e.filter((e=>this.abortClasses.includes(e))).length)break;let o=e.filter((e=>i.includes(e)));for(let e of o)t[this.componentMap[e]]||(t[this.componentMap[e]]=s)}return t.group&&t.group===t.row&&delete t.row,t}bindComponents(e,t){var i=Object.keys(t).reverse(),s=this.listeners[e],o={},n={};for(let e of i){let i,r=t[e],a=this.previousTargets[e];if(a&&a.target===r)i=a.component;else switch(e){case"row":case"group":if(s.components.includes("row")||s.components.includes("cell")||s.components.includes("group")){i=this.table.rowManager.getVisibleRows(!0).find((e=>e.getElement()===r)),t.row&&t.row.parentNode&&t.row.parentNode.closest(".tabulator-row")&&(t[e]=!1)}break;case"column":s.components.includes("column")&&(i=this.table.columnManager.findColumn(r));break;case"cell":s.components.includes("cell")&&(o.row instanceof w?i=o.row.findCell(r):t.row&&console.warn("Event Target Lookup Error - The row this cell is attached to cannot be found, has the table been reinitialized without being destroyed first?"))}i&&(o[e]=i,n[e]={target:r,component:i})}return this.previousTargets=n,o}triggerEvents(e,t,i){var s=this.listeners[e];for(let o in i)i[o]&&s.components.includes(o)&&this.dispatch(o+"-"+e,t,i[o])}clearWatchers(){for(let e in this.listeners){let t=this.listeners[e];t.handler&&(this.el.removeEventListener(e,t.handler),t.handler=null)}}}class ke{constructor(e){this.table=e,this.bindings={}}bind(e,t,i){this.bindings[e]||(this.bindings[e]={}),this.bindings[e][t]?console.warn("Unable to bind component handler, a matching function name is already bound",e,t,i):this.bindings[e][t]=i}handle(e,t,i){if(this.bindings[e]&&this.bindings[e][i]&&"function"==typeof this.bindings[e][i].bind)return this.bindings[e][i].bind(null,t);"then"===i||"string"!=typeof i||i.startsWith("_")||this.table.options.debugInvalidComponentFuncs&&console.error("The "+e+" component does not have a "+i+" function, have you checked that you have the correct Tabulator module installed?")}}class Le extends e{constructor(e){super(e),this.requestOrder=0,this.loading=!1}initialize(){}load(e,t,i,s,o,n){var r=++this.requestOrder;return this.table.destroyed?Promise.resolve():(this.dispatchExternal("dataLoading",e),!e||0!=e.indexOf("{")&&0!=e.indexOf("[")||(e=JSON.parse(e)),this.confirm("data-loading",[e,t,i,o])?(this.loading=!0,o||this.alertLoader(),t=this.chain("data-params",[e,i,o],t||{},t||{}),t=this.mapParams(t,this.table.options.dataSendParams),this.chain("data-load",[e,t,i,o],!1,Promise.resolve([])).then((e=>{if(this.table.destroyed)console.warn("Data Load Response Blocked - Table has been destroyed");else{Array.isArray(e)||"object"!=typeof e||(e=this.mapParams(e,this.objectInvert(this.table.options.dataReceiveParams)));var t=this.chain("data-loaded",e,null,e);r==this.requestOrder?(this.clearAlert(),!1!==t&&(this.dispatchExternal("dataLoaded",t),this.table.rowManager.setData(t,s,void 0===n?!s:n))):console.warn("Data Load Response Blocked - An active data load request was blocked by an attempt to change table data while the request was being made")}})).catch((e=>{console.error("Data Load Error: ",e),this.dispatchExternal("dataLoadError",e),o||this.alertError(),setTimeout((()=>{this.clearAlert()}),this.table.options.dataLoaderErrorTimeout)})).finally((()=>{this.loading=!1}))):(this.dispatchExternal("dataLoaded",e),e||(e=[]),this.table.rowManager.setData(e,s,void 0===n?!s:n),Promise.resolve()))}mapParams(e,t){var i={};for(let s in e)i[t.hasOwnProperty(s)?t[s]:s]=e[s];return i}objectInvert(e){var t={};for(let i in e)t[e[i]]=i;return t}blockActiveLoad(){this.requestOrder++}alertLoader(){("function"==typeof this.table.options.dataLoader?this.table.options.dataLoader():this.table.options.dataLoader)&&this.table.alertManager.alert(this.table.options.dataLoaderLoading||this.langText("data|loading"))}alertError(){this.table.alertManager.alert(this.table.options.dataLoaderError||this.langText("data|error"),"error")}clearAlert(){this.table.alertManager.clear()}}class De{constructor(e,t,i){this.table=e,this.events={},this.optionsList=t||{},this.subscriptionNotifiers={},this.dispatch=i?this._debugDispatch.bind(this):this._dispatch.bind(this),this.debug=i}subscriptionChange(e,t){this.subscriptionNotifiers[e]||(this.subscriptionNotifiers[e]=[]),this.subscriptionNotifiers[e].push(t),this.subscribed(e)&&this._notifySubscriptionChange(e,!0)}subscribe(e,t){this.events[e]||(this.events[e]=[]),this.events[e].push(t),this._notifySubscriptionChange(e,!0)}unsubscribe(e,t){var i;if(this.events[e]){if(t){if(!((i=this.events[e].findIndex((e=>e===t)))>-1))return void console.warn("Cannot remove event, no matching event found:",e,t);this.events[e].splice(i,1)}else delete this.events[e];this._notifySubscriptionChange(e,!1)}else console.warn("Cannot remove event, no events set on:",e)}subscribed(e){return this.events[e]&&this.events[e].length}_notifySubscriptionChange(e,t){var i=this.subscriptionNotifiers[e];i&&i.forEach((e=>{e(t)}))}_dispatch(){var e,t=Array.from(arguments),i=t.shift();return this.events[i]&&this.events[i].forEach(((i,s)=>{let o=i.apply(this.table,t);s||(e=o)})),e}_debugDispatch(){var e=Array.from(arguments),t=e[0];return e[0]="ExternalEvent:"+e[0],(!0===this.debug||this.debug.includes(t))&&console.log(...e),this._dispatch(...arguments)}}class Se{constructor(e){this.events={},this.subscriptionNotifiers={},this.dispatch=e?this._debugDispatch.bind(this):this._dispatch.bind(this),this.chain=e?this._debugChain.bind(this):this._chain.bind(this),this.confirm=e?this._debugConfirm.bind(this):this._confirm.bind(this),this.debug=e}subscriptionChange(e,t){this.subscriptionNotifiers[e]||(this.subscriptionNotifiers[e]=[]),this.subscriptionNotifiers[e].push(t),this.subscribed(e)&&this._notifySubscriptionChange(e,!0)}subscribe(e,t,i=1e4){this.events[e]||(this.events[e]=[]),this.events[e].push({callback:t,priority:i}),this.events[e].sort(((e,t)=>e.priority-t.priority)),this._notifySubscriptionChange(e,!0)}unsubscribe(e,t){var i;if(this.events[e]){if(t){if(!((i=this.events[e].findIndex((e=>e.callback===t)))>-1))return void console.warn("Cannot remove event, no matching event found:",e,t);this.events[e].splice(i,1)}this._notifySubscriptionChange(e,!1)}else console.warn("Cannot remove event, no events set on:",e)}subscribed(e){return this.events[e]&&this.events[e].length}_chain(e,t,i,s){var o=i;return Array.isArray(t)||(t=[t]),this.subscribed(e)?(this.events[e].forEach(((e,i)=>{o=e.callback.apply(this,t.concat([o]))})),o):"function"==typeof s?s():s}_confirm(e,t){var i=!1;return Array.isArray(t)||(t=[t]),this.subscribed(e)&&this.events[e].forEach(((e,s)=>{e.callback.apply(this,t)&&(i=!0)})),i}_notifySubscriptionChange(e,t){var i=this.subscriptionNotifiers[e];i&&i.forEach((e=>{e(t)}))}_dispatch(){var e=Array.from(arguments),t=e.shift();this.events[t]&&this.events[t].forEach((t=>{t.callback.apply(this,e)}))}_debugDispatch(){var e=Array.from(arguments),t=e[0];return e[0]="InternalEvent:"+t,(!0===this.debug||this.debug.includes(t))&&console.log(...e),this._dispatch(...arguments)}_debugChain(){var e=Array.from(arguments),t=e[0];return e[0]="InternalEvent:"+t,(!0===this.debug||this.debug.includes(t))&&console.log(...e),this._chain(...arguments)}_debugConfirm(){var e=Array.from(arguments),t=e[0];return e[0]="InternalEvent:"+t,(!0===this.debug||this.debug.includes(t))&&console.log(...e),this._confirm(...arguments)}}class Pe extends e{constructor(e){super(e)}_warnUser(){this.options("debugDeprecation")&&console.warn(...arguments)}check(e,t){var i="";return void 0===this.options(e)||(i="Deprecated Setup Option - Use of the %c"+e+"%c option is now deprecated",t?(i=i+", Please use the %c"+t+"%c option instead",this._warnUser(i,"font-weight: bold;","font-weight: normal;","font-weight: bold;","font-weight: normal;")):this._warnUser(i,"font-weight: bold;","font-weight: normal;"),!1)}checkMsg(e,t){return void 0===this.options(e)||(this._warnUser("%cDeprecated Setup Option - Use of the %c"+e+" %c option is now deprecated, "+t,"font-weight: normal;","font-weight: bold;","font-weight: normal;"),!1)}msg(e){this._warnUser(e)}}class ze{static register(e){ze.tables.push(e)}static deregister(e){var t=ze.tables.indexOf(e);t>-1&&ze.tables.splice(t,1)}static lookupTable(e,t){var i,s,o=[];if("string"==typeof e){if((i=document.querySelectorAll(e)).length)for(var n=0;n{e.widthFixed||e.reinitializeWidth(),(this.table.options.responsiveLayout?e.modules.responsive.visible:e.visible)&&(n=e),e.visible&&(i+=e.getWidth())})),n?(o=s-i+n.getWidth(),this.table.options.responsiveLayout&&this.table.modExists("responsiveLayout",!0)&&(n.setWidth(0),this.table.modules.responsiveLayout.update()),o>0?n.setWidth(o):n.reinitializeWidth()):this.table.options.responsiveLayout&&this.table.modExists("responsiveLayout",!0)&&this.table.modules.responsiveLayout.update()},fitColumns:function(e,t){var i,s,o=this.table.rowManager.element.getBoundingClientRect().width,n=0,r=0,a=0,l=[],h=[],d=0,c=0;function u(e){return"string"==typeof e?e.indexOf("%")>-1?o/100*parseInt(e):parseInt(e):e}function p(e,t,i,s){var o=[],n=0,r=0,l=0,h=a,d=0,c=0,m=[];function g(e){return i*(e.column.definition.widthGrow||1)}function b(e){return u(e.width)-i*(e.column.definition.widthShrink||0)}return e.forEach((function(e,n){var r=s?b(e):g(e);e.column.minWidth>=r?o.push(e):e.column.maxWidth&&e.column.maxWidththis.table.rowManager.element.clientHeight&&(o-=this.table.rowManager.element.offsetWidth-this.table.rowManager.element.clientWidth),e.forEach((function(e){var t,i,s;e.visible&&(t=e.definition.width,i=parseInt(e.minWidth),t?(s=u(t),n+=s>i?s:i,e.definition.widthShrink&&(h.push({column:e,width:s>i?s:i}),d+=e.definition.widthShrink)):(l.push({column:e,width:0}),a+=e.definition.widthGrow||1))})),r=o-n,i=Math.floor(r/a),c=p(l,r,i,!1),l.length&&c>0&&(l[l.length-1].width+=c),l.forEach((function(e){r-=e.width})),(s=Math.abs(c)+r)>0&&d&&(c=p(h,s,Math.floor(s/d),!0)),c&&h.length&&(h[h.length-1].width-=c),l.forEach((function(e){e.column.setWidth(e.width)})),h.forEach((function(e){e.column.setWidth(e.width)}))}};class Oe extends s{constructor(e){super(e,"layout"),this.mode=null,this.registerTableOption("layout","fitData"),this.registerTableOption("layoutColumnsOnNewData",!1),this.registerColumnOption("widthGrow"),this.registerColumnOption("widthShrink")}initialize(){var e=this.table.options.layout;Oe.modes[e]?this.mode=e:(console.warn("Layout Error - invalid mode set, defaulting to 'fitData' : "+e),this.mode="fitData"),this.table.element.setAttribute("tabulator-layout",this.mode),this.subscribe("column-init",this.initializeColumn.bind(this))}initializeColumn(e){e.definition.widthGrow&&(e.definition.widthGrow=Number(e.definition.widthGrow)),e.definition.widthShrink&&(e.definition.widthShrink=Number(e.definition.widthShrink))}getMode(){return this.mode}layout(e){this.dispatch("layout-refreshing"),Oe.modes[this.mode].call(this,this.table.columnManager.columnsByIndex,e),this.dispatch("layout-refreshed")}}Oe.moduleName="layout",Oe.modes=He;class Ae extends s{constructor(e){super(e),this.locale="default",this.lang=!1,this.bindings={},this.langList={},this.registerTableOption("locale",!1),this.registerTableOption("langs",{})}initialize(){this.langList=t.deepClone(Ae.langs),!1!==this.table.options.columnDefaults.headerFilterPlaceholder&&this.setHeaderFilterPlaceholder(this.table.options.columnDefaults.headerFilterPlaceholder);for(let e in this.table.options.langs)this.installLang(e,this.table.options.langs[e]);this.setLocale(this.table.options.locale),this.registerTableFunction("setLocale",this.setLocale.bind(this)),this.registerTableFunction("getLocale",this.getLocale.bind(this)),this.registerTableFunction("getLang",this.getLang.bind(this))}setHeaderFilterPlaceholder(e){this.langList.default.headerFilters.default=e}installLang(e,t){this.langList[e]?this._setLangProp(this.langList[e],t):this.langList[e]=t}_setLangProp(e,t){for(let i in t)e[i]&&"object"==typeof e[i]?this._setLangProp(e[i],t[i]):e[i]=t[i]}setLocale(e){if(!0===(e=e||"default")&&navigator.language&&(e=navigator.language.toLowerCase()),e&&!this.langList[e]){let t=e.split("-")[0];this.langList[t]?(console.warn("Localization Error - Exact matching locale not found, using closest match: ",e,t),e=t):(console.warn("Localization Error - Matching locale not found, using default: ",e),e="default")}this.locale=e,this.lang=t.deepClone(this.langList.default||{}),"default"!=e&&function e(t,i){for(var s in t)"object"==typeof t[s]?(i[s]||(i[s]={}),e(t[s],i[s])):i[s]=t[s]}(this.langList[e],this.lang),this.dispatchExternal("localized",this.locale,this.lang),this._executeBindings()}getLocale(e){return this.locale}getLang(e){return e?this.langList[e]:this.lang}getText(e,t){var i=(t?e+"|"+t:e).split("|");return this._getLangElement(i,this.locale)||""}_getLangElement(e,t){var i=this.lang;return e.forEach((function(e){var t;i&&(t=i[e],i=void 0!==t&&t)})),i}bind(e,t){this.bindings[e]||(this.bindings[e]=[]),this.bindings[e].push(t),t(this.getText(e),this.lang)}_executeBindings(){for(let e in this.bindings)this.bindings[e].forEach((t=>{t(this.getText(e),this.lang)}))}}Ae.moduleName="localize",Ae.langs={default:{groups:{item:"item",items:"items"},columns:{},data:{loading:"Loading",error:"Error"},pagination:{page_size:"Page Size",page_title:"Show Page",first:"First",first_title:"First Page",last:"Last",last_title:"Last Page",prev:"Prev",prev_title:"Prev Page",next:"Next",next_title:"Next Page",all:"All",counter:{showing:"Showing",of:"of",rows:"rows",pages:"pages"}},headerFilters:{default:"filter column...",columns:{}}}};class _e extends s{constructor(e){super(e)}initialize(){this.registerTableFunction("tableComms",this.receive.bind(this))}getConnections(e){var t=[];return ze.lookupTable(e).forEach((e=>{this.table!==e&&t.push(e)})),t}send(e,t,i,s){var o=this.getConnections(e);o.forEach((e=>{e.tableComms(this.table.element,t,i,s)})),!o.length&&e&&console.warn("Table Connection Error - No tables matching selector found",e)}receive(e,t,i,s){if(this.table.modExists(t))return this.table.modules[t].commsReceived(e,i,s);console.warn("Inter-table Comms Error - no such module:",t)}}_e.moduleName="comms";var Be=Object.freeze({__proto__:null,LayoutModule:Oe,LocalizeModule:Ae,CommsModule:_e});class Ie{constructor(e,t){this.bindStaticFunctionality(e),this.bindModules(e,Be,!0),t&&this.bindModules(e,t)}bindStaticFunctionality(e){e.moduleBindings={},e.extendModule=function(t,i,s){if(e.moduleBindings[t]){var o=e.moduleBindings[t][i];if(o)if("object"==typeof s)for(let e in s)o[e]=s[e];else console.warn("Module Error - Invalid value type, it must be an object");else console.warn("Module Error - property does not exist:",i)}else console.warn("Module Error - module does not exist:",t)},e.registerModule=function(t){Array.isArray(t)||(t=[t]),t.forEach((t=>{e.registerModuleBinding(t)}))},e.registerModuleBinding=function(t){e.moduleBindings[t.moduleName]=t},e.findTable=function(e){var t=ze.lookupTable(e,!0);return!(Array.isArray(t)&&!t.length)&&t},e.prototype.bindModules=function(){var t=[],i=[],s=[];for(var o in this.modules={},e.moduleBindings){let n=e.moduleBindings[o],r=new n(this);this.modules[o]=r,n.prototype.moduleCore?this.modulesCore.push(r):n.moduleInitOrder?n.moduleInitOrder<0?t.push(r):i.push(r):s.push(r)}t.sort(((e,t)=>e.moduleInitOrder>t.moduleInitOrder?1:-1)),i.sort(((e,t)=>e.moduleInitOrder>t.moduleInitOrder?1:-1)),this.modulesRegular=t.concat(s.concat(i))}}bindModules(e,t,i){var s=Object.values(t);i&&s.forEach((e=>{e.prototype.moduleCore=!0})),e.registerModule(s)}}class Ve extends e{constructor(e){super(e),this.element=this._createAlertElement(),this.msgElement=this._createMsgElement(),this.type=null,this.element.appendChild(this.msgElement)}_createAlertElement(){var e=document.createElement("div");return e.classList.add("tabulator-alert"),e}_createMsgElement(){var e=document.createElement("div");return e.classList.add("tabulator-alert-msg"),e.setAttribute("role","alert"),e}_typeClass(){return"tabulator-alert-state-"+this.type}alert(e,t="msg"){if(e){for(this.clear(),this.type=t;this.msgElement.firstChild;)this.msgElement.removeChild(this.msgElement.firstChild);this.msgElement.classList.add(this._typeClass()),"function"==typeof e&&(e=e()),e instanceof HTMLElement?this.msgElement.appendChild(e):this.msgElement.innerHTML=e,this.table.element.appendChild(this.element)}}clear(){this.element.parentNode&&this.element.parentNode.removeChild(this.element),this.msgElement.classList.remove(this._typeClass())}}class Ne{constructor(e,t){this.options={},this.columnManager=null,this.rowManager=null,this.footerManager=null,this.alertManager=null,this.vdomHoz=null,this.externalEvents=null,this.eventBus=null,this.interactionMonitor=!1,this.browser="",this.browserSlow=!1,this.browserMobile=!1,this.rtl=!1,this.originalElement=null,this.componentFunctionBinder=new ke(this),this.dataLoader=!1,this.modules={},this.modulesCore=[],this.modulesRegular=[],this.deprecationAdvisor=new Pe(this),this.optionsList=new fe(this,"table constructor"),this.initialized=!1,this.destroyed=!1,this.initializeElement(e)&&(this.initializeCoreSystems(t),setTimeout((()=>{this._create()}))),ze.register(this)}initializeElement(e){return"undefined"!=typeof HTMLElement&&e instanceof HTMLElement?(this.element=e,!0):"string"==typeof e?(this.element=document.querySelector(e),!!this.element||(console.error("Tabulator Creation Error - no element found matching selector: ",e),!1)):(console.error("Tabulator Creation Error - Invalid element provided:",e),!1)}initializeCoreSystems(e){this.columnManager=new Ee(this),this.rowManager=new xe(this),this.footerManager=new Te(this),this.dataLoader=new Le(this),this.alertManager=new Ve(this),this.bindModules(),this.options=this.optionsList.generate(Ne.defaultOptions,e),this._clearObjectPointers(),this._mapDeprecatedFunctionality(),this.externalEvents=new De(this,this.options,this.options.debugEventsExternal),this.eventBus=new Se(this.options.debugEventsInternal),this.interactionMonitor=new Me(this),this.dataLoader.initialize(),this.footerManager.initialize()}_mapDeprecatedFunctionality(){}_clearSelection(){this.element.classList.add("tabulator-block-select"),window.getSelection?window.getSelection().empty?window.getSelection().empty():window.getSelection().removeAllRanges&&window.getSelection().removeAllRanges():document.selection&&document.selection.empty(),this.element.classList.remove("tabulator-block-select")}_create(){this.externalEvents.dispatch("tableBuilding"),this.eventBus.dispatch("table-building"),this._rtlCheck(),this._buildElement(),this._initializeTable(),this._loadInitialData(),this.initialized=!0,this.externalEvents.dispatch("tableBuilt")}_rtlCheck(){var e=window.getComputedStyle(this.element);switch(this.options.textDirection){case"auto":if("rtl"!==e.direction)break;case"rtl":this.element.classList.add("tabulator-rtl"),this.rtl=!0;break;case"ltr":this.element.classList.add("tabulator-ltr");default:this.rtl=!1}}_clearObjectPointers(){this.options.columns=this.options.columns.slice(0),Array.isArray(this.options.data)&&!this.options.reactiveData&&(this.options.data=this.options.data.slice(0))}_buildElement(){var e,t=this.element,i=this.options;if("TABLE"===t.tagName){this.originalElement=this.element,e=document.createElement("div");var s=t.attributes;for(var o in s)"object"==typeof s[o]&&e.setAttribute(s[o].name,s[o].value);t.parentNode.replaceChild(e,t),this.element=t=e}for(t.classList.add("tabulator"),t.setAttribute("role","grid");t.firstChild;)t.removeChild(t.firstChild);i.height&&(i.height=isNaN(i.height)?i.height:i.height+"px",t.style.height=i.height),!1!==i.minHeight&&(i.minHeight=isNaN(i.minHeight)?i.minHeight:i.minHeight+"px",t.style.minHeight=i.minHeight),!1!==i.maxHeight&&(i.maxHeight=isNaN(i.maxHeight)?i.maxHeight:i.maxHeight+"px",t.style.maxHeight=i.maxHeight)}_initializeTable(){var e=this.element,t=this.options;this.interactionMonitor.initialize(),this.columnManager.initialize(),this.rowManager.initialize(),this._detectBrowser(),this.modulesCore.forEach((e=>{e.initialize()})),e.appendChild(this.columnManager.getElement()),e.appendChild(this.rowManager.getElement()),t.footerElement&&this.footerManager.activate(),t.autoColumns&&t.data&&this.columnManager.generateColumnsFromRowData(this.options.data),this.modulesRegular.forEach((e=>{e.initialize()})),this.columnManager.setColumns(t.columns),this.eventBus.dispatch("table-built")}_loadInitialData(){this.dataLoader.load(this.options.data)}destroy(){var e=this.element;for(this.destroyed=!0,ze.deregister(this),this.eventBus.dispatch("table-destroy"),this.rowManager.destroy();e.firstChild;)e.removeChild(e.firstChild);e.classList.remove("tabulator"),this.externalEvents.dispatch("tableDestroyed")}_detectBrowser(){var e=navigator.userAgent||navigator.vendor||window.opera;e.indexOf("Trident")>-1?(this.browser="ie",this.browserSlow=!0):e.indexOf("Edge")>-1?(this.browser="edge",this.browserSlow=!0):e.indexOf("Firefox")>-1?(this.browser="firefox",this.browserSlow=!1):e.indexOf("Mac OS")>-1?(this.browser="safari",this.browserSlow=!1):(this.browser="other",this.browserSlow=!1),this.browserMobile=/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(e)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw-(n|u)|c55\/|capi|ccwa|cdm-|cell|chtm|cldc|cmd-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc-s|devi|dica|dmob|do(c|p)o|ds(12|-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(-|_)|g1 u|g560|gene|gf-5|g-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd-(m|p|t)|hei-|hi(pt|ta)|hp( i|ip)|hs-c|ht(c(-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i-(20|go|ma)|i230|iac( |-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|-[a-w])|libw|lynx|m1-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|-([1-8]|c))|phil|pire|pl(ay|uc)|pn-2|po(ck|rt|se)|prox|psio|pt-g|qa-a|qc(07|12|21|32|60|-[2-7]|i-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h-|oo|p-)|sdk\/|se(c(-|0|1)|47|mc|nd|ri)|sgh-|shar|sie(-|m)|sk-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h-|v-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl-|tdg-|tel(i|m)|tim-|t-mo|to(pl|sh)|ts(70|m-|m3|m5)|tx-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas-|your|zeto|zte-/i.test(e.slice(0,4))}initGuard(e,t){var i,s;return this.options.debugInitialization&&!this.initialized&&(e||(e=" "==(s="Error"==(i=(new Error).stack.split("\n"))[0]?i[2]:i[1])[0]?s.trim().split(" ")[1].split(".")[1]:s.trim().split("@")[0]),console.warn("Table Not Initialized - Calling the "+e+" function before the table is initialized may result in inconsistent behavior, Please wait for the `tableBuilt` event before calling this function."+(t?" "+t:""))),this.initialized}blockRedraw(){this.initGuard(),this.eventBus.dispatch("redraw-blocking"),this.rowManager.blockRedraw(),this.columnManager.blockRedraw(),this.eventBus.dispatch("redraw-blocked")}restoreRedraw(){this.initGuard(),this.eventBus.dispatch("redraw-restoring"),this.rowManager.restoreRedraw(),this.columnManager.restoreRedraw(),this.eventBus.dispatch("redraw-restored")}setData(e,t,i){return this.initGuard(!1,"To set initial data please use the 'data' property in the table constructor."),this.dataLoader.load(e,t,i,!1)}clearData(){this.initGuard(),this.dataLoader.blockActiveLoad(),this.rowManager.clearData()}getData(e){return this.rowManager.getData(e)}getDataCount(e){return this.rowManager.getDataCount(e)}replaceData(e,t,i){return this.initGuard(),this.dataLoader.load(e,t,i,!0,!0)}updateData(e){var t=0;return this.initGuard(),new Promise(((i,s)=>{this.dataLoader.blockActiveLoad(),"string"==typeof e&&(e=JSON.parse(e)),e&&e.length>0?e.forEach((e=>{var o=this.rowManager.findRow(e[this.options.index]);o?(t++,o.updateData(e).then((()=>{--t||i()})).catch((t=>{s("Update Error - Unable to update row",e,t)}))):s("Update Error - Unable to find row",e)})):(console.warn("Update Error - No data provided"),s("Update Error - No data provided"))}))}addData(e,t,i){return this.initGuard(),new Promise(((s,o)=>{this.dataLoader.blockActiveLoad(),"string"==typeof e&&(e=JSON.parse(e)),e?this.rowManager.addRows(e,t,i).then((e=>{var t=[];e.forEach((function(e){t.push(e.getComponent())})),s(t)})):(console.warn("Update Error - No data provided"),o("Update Error - No data provided"))}))}updateOrAddData(e){var t=[],i=0;return this.initGuard(),new Promise(((s,o)=>{this.dataLoader.blockActiveLoad(),"string"==typeof e&&(e=JSON.parse(e)),e&&e.length>0?e.forEach((e=>{var o=this.rowManager.findRow(e[this.options.index]);i++,o?o.updateData(e).then((()=>{i--,t.push(o.getComponent()),i||s(t)})):this.rowManager.addRows(e).then((e=>{i--,t.push(e[0].getComponent()),i||s(t)}))})):(console.warn("Update Error - No data provided"),o("Update Error - No data provided"))}))}getRow(e){var t=this.rowManager.findRow(e);return t?t.getComponent():(console.warn("Find Error - No matching row found:",e),!1)}getRowFromPosition(e){var t=this.rowManager.getRowFromPosition(e);return t?t.getComponent():(console.warn("Find Error - No matching row found:",e),!1)}deleteRow(e){var t=[];this.initGuard(),Array.isArray(e)||(e=[e]);for(let i of e){let e=this.rowManager.findRow(i,!0);if(!e)return console.error("Delete Error - No matching row found:",i),Promise.reject("Delete Error - No matching row found");t.push(e)}return t.sort(((e,t)=>this.rowManager.rows.indexOf(e)>this.rowManager.rows.indexOf(t)?1:-1)),t.forEach((e=>{e.delete()})),this.rowManager.reRenderInPosition(),Promise.resolve()}addRow(e,t,i){return this.initGuard(),"string"==typeof e&&(e=JSON.parse(e)),this.rowManager.addRows(e,t,i,!0).then((e=>e[0].getComponent()))}updateOrAddRow(e,t){var i=this.rowManager.findRow(e);return this.initGuard(),"string"==typeof t&&(t=JSON.parse(t)),i?i.updateData(t).then((()=>i.getComponent())):this.rowManager.addRows(t).then((e=>e[0].getComponent()))}updateRow(e,t){var i=this.rowManager.findRow(e);return this.initGuard(),"string"==typeof t&&(t=JSON.parse(t)),i?i.updateData(t).then((()=>Promise.resolve(i.getComponent()))):(console.warn("Update Error - No matching row found:",e),Promise.reject("Update Error - No matching row found"))}scrollToRow(e,t,i){var s=this.rowManager.findRow(e);return s?this.rowManager.scrollToRow(s,t,i):(console.warn("Scroll Error - No matching row found:",e),Promise.reject("Scroll Error - No matching row found"))}moveRow(e,t,i){var s=this.rowManager.findRow(e);this.initGuard(),s?s.moveToRow(t,i):console.warn("Move Error - No matching row found:",e)}getRows(e){return this.rowManager.getComponents(e)}getRowPosition(e){var t=this.rowManager.findRow(e);return t?t.getPosition():(console.warn("Position Error - No matching row found:",e),!1)}setColumns(e){this.initGuard(!1,"To set initial columns please use the 'columns' property in the table constructor"),this.columnManager.setColumns(e)}getColumns(e){return this.columnManager.getComponents(e)}getColumn(e){var t=this.columnManager.findColumn(e);return t?t.getComponent():(console.warn("Find Error - No matching column found:",e),!1)}getColumnDefinitions(){return this.columnManager.getDefinitionTree()}showColumn(e){var t=this.columnManager.findColumn(e);if(this.initGuard(),!t)return console.warn("Column Show Error - No matching column found:",e),!1;t.show()}hideColumn(e){var t=this.columnManager.findColumn(e);if(this.initGuard(),!t)return console.warn("Column Hide Error - No matching column found:",e),!1;t.hide()}toggleColumn(e){var t=this.columnManager.findColumn(e);if(this.initGuard(),!t)return console.warn("Column Visibility Toggle Error - No matching column found:",e),!1;t.visible?t.hide():t.show()}addColumn(e,t,i){var s=this.columnManager.findColumn(i);return this.initGuard(),this.columnManager.addColumn(e,t,s).then((e=>e.getComponent()))}deleteColumn(e){var t=this.columnManager.findColumn(e);return this.initGuard(),t?t.delete():(console.warn("Column Delete Error - No matching column found:",e),Promise.reject())}updateColumnDefinition(e,t){var i=this.columnManager.findColumn(e);return this.initGuard(),i?i.updateDefinition(t):(console.warn("Column Update Error - No matching column found:",e),Promise.reject())}moveColumn(e,t,i){var s=this.columnManager.findColumn(e),o=this.columnManager.findColumn(t);this.initGuard(),s?o?this.columnManager.moveColumn(s,o,i):console.warn("Move Error - No matching column found:",o):console.warn("Move Error - No matching column found:",e)}scrollToColumn(e,t,i){return new Promise(((s,o)=>{var n=this.columnManager.findColumn(e);return n?this.columnManager.scrollToColumn(n,t,i):(console.warn("Scroll Error - No matching column found:",e),Promise.reject("Scroll Error - No matching column found"))}))}redraw(e){this.initGuard(),this.columnManager.redraw(e),this.rowManager.redraw(e)}setHeight(e){this.options.height=isNaN(e)?e:e+"px",this.element.style.height=this.options.height,this.rowManager.initializeRenderer(),this.rowManager.redraw()}on(e,t){this.externalEvents.subscribe(e,t)}off(e,t){this.externalEvents.unsubscribe(e,t)}dispatchEvent(){Array.from(arguments).shift(),this.externalEvents.dispatch(...arguments)}alert(e,t){this.initGuard(),this.alertManager.alert(e,t)}clearAlert(){this.initGuard(),this.alertManager.clear()}modExists(e,t){return!!this.modules[e]||(t&&console.error("Tabulator Module Not Installed: "+e),!1)}module(e){var t=this.modules[e];return t||console.error("Tabulator module not installed: "+e),t}}Ne.defaultOptions={debugEventsExternal:!1,debugEventsInternal:!1,debugInvalidOptions:!0,debugInvalidComponentFuncs:!0,debugInitialization:!0,debugDeprecation:!0,height:!1,minHeight:!1,maxHeight:!1,columnHeaderVertAlign:"top",popupContainer:!1,columns:[],columnDefaults:{},data:!1,autoColumns:!1,autoColumnsDefinitions:!1,nestedFieldSeparator:".",footerElement:!1,index:"id",textDirection:"auto",addRowPos:"bottom",headerVisible:!0,renderVertical:"virtual",renderHorizontal:"basic",renderVerticalBuffer:0,scrollToRowPosition:"top",scrollToRowIfVisible:!0,scrollToColumnPosition:"left",scrollToColumnIfVisible:!0,rowFormatter:!1,rowFormatterPrint:null,rowFormatterClipboard:null,rowFormatterHtmlOutput:null,rowHeight:null,placeholder:!1,dataLoader:!0,dataLoaderLoading:!1,dataLoaderError:!1,dataLoaderErrorTimeout:3e3,dataSendParams:{},dataReceiveParams:{}},new Ie(Ne);class We extends Ne{}new Ie(We,be);class je{constructor(e){this.type=e,this.element=this._createElement()}_createElement(){var e=document.createElement("div");return e.classList.add("tabulator-row"),e}getElement(){return this.element}getComponent(){return!1}getData(){return{}}getHeight(){return this.element.outerHeight}initialize(){}reinitialize(){}normalizeHeight(){}generateCells(){}reinitializeHeight(){}calcHeight(){}setCellHeight(){}clearCellHeight(){}}export{o as AccessorModule,d as AjaxModule,u as CalcComponent,p as CellComponent,c as ClipboardModule,E as ColumnCalcsModule,g as ColumnComponent,y as DataTreeModule,x as DownloadModule,L as EditModule,P as ExportModule,F as FilterModule,O as FormatModule,A as FrozenColumnsModule,_ as FrozenRowsModule,B as GroupComponent,V as GroupRowsModule,N as HistoryModule,W as HtmlTableImportModule,G as ImportModule,U as InteractionModule,X as KeybindingsModule,q as MenuModule,s as Module,K as MoveColumnsModule,J as MoveRowsModule,Y as MutatorModule,Z as PageModule,te as PersistenceModule,ie as PopupModule,se as PrintModule,je as PseudoRow,oe as ReactiveDataModule,ve as Renderer,ne as ResizeColumnsModule,re as ResizeRowsModule,ae as ResizeTableModule,le as ResponsiveLayoutModule,v as RowComponent,he as SelectRowModule,ue as SortModule,Ne as Tabulator,We as TabulatorFull,pe as TooltipModule,ge as ValidateModule}; -//# sourceMappingURL=tabulator_esm.min.js.map diff --git a/cp/public/assets/js/tabulator_esm.min.js.map b/cp/public/assets/js/tabulator_esm.min.js.map deleted file mode 100644 index 5b9a96f..0000000 --- a/cp/public/assets/js/tabulator_esm.min.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"tabulator_esm.min.js","sources":["../../src/js/core/CoreFeature.js","../../src/js/core/tools/Helpers.js","../../src/js/core/tools/Popup.js","../../src/js/core/Module.js","../../src/js/modules/Accessor/Accessor.js","../../src/js/modules/Accessor/defaults/accessors.js","../../src/js/modules/Ajax/defaults/urlGenerator.js","../../src/js/modules/Ajax/defaults/contentTypeFormatters.js","../../src/js/modules/Ajax/Ajax.js","../../src/js/modules/Ajax/defaults/config.js","../../src/js/modules/Ajax/defaults/loaderPromise.js","../../src/js/modules/Clipboard/Clipboard.js","../../src/js/modules/Clipboard/defaults/pasteActions.js","../../src/js/modules/Clipboard/defaults/pasteParsers.js","../../src/js/modules/ColumnCalcs/CalcComponent.js","../../src/js/core/cell/CellComponent.js","../../src/js/core/cell/Cell.js","../../src/js/core/column/ColumnComponent.js","../../src/js/core/column/defaults/options.js","../../src/js/core/column/Column.js","../../src/js/core/row/RowComponent.js","../../src/js/core/row/Row.js","../../src/js/modules/ColumnCalcs/defaults/calculations.js","../../src/js/modules/ColumnCalcs/ColumnCalcs.js","../../src/js/modules/DataTree/DataTree.js","../../src/js/modules/Download/defaults/downloaders.js","../../src/js/modules/Download/defaults/downloaders/csv.js","../../src/js/modules/Download/defaults/downloaders/json.js","../../src/js/modules/Download/defaults/downloaders/jsonLines.js","../../src/js/modules/Download/defaults/downloaders/pdf.js","../../src/js/modules/Download/defaults/downloaders/xlsx.js","../../src/js/modules/Download/defaults/downloaders/html.js","../../src/js/modules/Download/Download.js","../../src/js/modules/Edit/inputMask.js","../../src/js/modules/Edit/List.js","../../src/js/modules/Edit/defaults/editors.js","../../src/js/modules/Edit/defaults/editors/input.js","../../src/js/modules/Edit/defaults/editors/textarea.js","../../src/js/modules/Edit/defaults/editors/number.js","../../src/js/modules/Edit/defaults/editors/range.js","../../src/js/modules/Edit/defaults/editors/date.js","../../src/js/modules/Edit/defaults/editors/time.js","../../src/js/modules/Edit/defaults/editors/datetime.js","../../src/js/modules/Edit/defaults/editors/select.js","../../src/js/modules/Edit/defaults/editors/list.js","../../src/js/modules/Edit/defaults/editors/autocomplete.js","../../src/js/modules/Edit/defaults/editors/star.js","../../src/js/modules/Edit/defaults/editors/progress.js","../../src/js/modules/Edit/defaults/editors/tickCross.js","../../src/js/modules/Edit/Edit.js","../../src/js/modules/Export/ExportRow.js","../../src/js/modules/Export/ExportColumn.js","../../src/js/modules/Export/Export.js","../../src/js/modules/Filter/defaults/filters.js","../../src/js/modules/Filter/Filter.js","../../src/js/modules/Format/defaults/formatters.js","../../src/js/modules/Format/defaults/formatters/plaintext.js","../../src/js/modules/Format/defaults/formatters/html.js","../../src/js/modules/Format/defaults/formatters/textarea.js","../../src/js/modules/Format/defaults/formatters/money.js","../../src/js/modules/Format/defaults/formatters/link.js","../../src/js/modules/Format/defaults/formatters/image.js","../../src/js/modules/Format/defaults/formatters/tickCross.js","../../src/js/modules/Format/defaults/formatters/datetime.js","../../src/js/modules/Format/defaults/formatters/datetimediff.js","../../src/js/modules/Format/defaults/formatters/lookup.js","../../src/js/modules/Format/defaults/formatters/star.js","../../src/js/modules/Format/defaults/formatters/traffic.js","../../src/js/modules/Format/defaults/formatters/progress.js","../../src/js/modules/Format/defaults/formatters/color.js","../../src/js/modules/Format/defaults/formatters/buttonTick.js","../../src/js/modules/Format/defaults/formatters/buttonCross.js","../../src/js/modules/Format/defaults/formatters/rownum.js","../../src/js/modules/Format/defaults/formatters/handle.js","../../src/js/modules/Format/defaults/formatters/responsiveCollapse.js","../../src/js/modules/Format/defaults/formatters/rowSelection.js","../../src/js/modules/Format/Format.js","../../src/js/modules/FrozenColumns/FrozenColumns.js","../../src/js/modules/FrozenRows/FrozenRows.js","../../src/js/modules/GroupRows/GroupComponent.js","../../src/js/modules/GroupRows/Group.js","../../src/js/modules/GroupRows/GroupRows.js","../../src/js/modules/History/History.js","../../src/js/modules/History/defaults/undoers.js","../../src/js/modules/History/defaults/redoers.js","../../src/js/modules/HtmlTableImport/HtmlTableImport.js","../../src/js/modules/Import/defaults/importers.js","../../src/js/modules/Import/defaults/importers/csv.js","../../src/js/modules/Import/defaults/importers/json.js","../../src/js/modules/Import/defaults/importers/array.js","../../src/js/modules/Import/Import.js","../../src/js/modules/Interaction/Interaction.js","../../src/js/modules/Keybindings/Keybindings.js","../../src/js/modules/Keybindings/defaults/bindings.js","../../src/js/modules/Keybindings/defaults/actions.js","../../src/js/modules/Menu/Menu.js","../../src/js/modules/MoveColumns/MoveColumns.js","../../src/js/modules/MoveRows/MoveRows.js","../../src/js/modules/Mutator/Mutator.js","../../src/js/modules/Mutator/defaults/mutators.js","../../src/js/modules/Page/defaults/pageCounters.js","../../src/js/modules/Page/defaults/pageCounters/rows.js","../../src/js/modules/Page/defaults/pageCounters/pages.js","../../src/js/modules/Page/Page.js","../../src/js/modules/Persistence/defaults/readers.js","../../src/js/modules/Persistence/defaults/writers.js","../../src/js/modules/Persistence/Persistence.js","../../src/js/modules/Popup/Popup.js","../../src/js/modules/Print/Print.js","../../src/js/modules/ReactiveData/ReactiveData.js","../../src/js/modules/ResizeColumns/ResizeColumns.js","../../src/js/modules/ResizeRows/ResizeRows.js","../../src/js/modules/ResizeTable/ResizeTable.js","../../src/js/modules/ResponsiveLayout/ResponsiveLayout.js","../../src/js/modules/SelectRow/SelectRow.js","../../src/js/modules/Sort/defaults/sorters/datetime.js","../../src/js/modules/Sort/defaults/sorters.js","../../src/js/modules/Sort/defaults/sorters/number.js","../../src/js/modules/Sort/defaults/sorters/string.js","../../src/js/modules/Sort/defaults/sorters/date.js","../../src/js/modules/Sort/defaults/sorters/time.js","../../src/js/modules/Sort/defaults/sorters/boolean.js","../../src/js/modules/Sort/defaults/sorters/array.js","../../src/js/modules/Sort/defaults/sorters/exists.js","../../src/js/modules/Sort/defaults/sorters/alphanum.js","../../src/js/modules/Sort/Sort.js","../../src/js/modules/Tooltip/Tooltip.js","../../src/js/modules/Validate/defaults/validators.js","../../src/js/modules/Validate/Validate.js","../../src/js/core/tools/OptionsList.js","../../src/js/core/rendering/Renderer.js","../../src/js/core/rendering/renderers/BasicHorizontal.js","../../src/js/core/rendering/renderers/VirtualDomHorizontal.js","../../src/js/core/ColumnManager.js","../../src/js/core/rendering/renderers/BasicVertical.js","../../src/js/core/rendering/renderers/VirtualDomVertical.js","../../src/js/core/RowManager.js","../../src/js/core/FooterManager.js","../../src/js/core/tools/InteractionMonitor.js","../../src/js/core/tools/ComponentFunctionBinder.js","../../src/js/core/tools/DataLoader.js","../../src/js/core/tools/ExternalEventBus.js","../../src/js/core/tools/InternalEventBus.js","../../src/js/core/tools/DeprecationAdvisor.js","../../src/js/core/tools/TableRegistry.js","../../src/js/modules/Layout/defaults/modes/fitDataGeneral.js","../../src/js/modules/Layout/defaults/modes.js","../../src/js/modules/Layout/defaults/modes/fitData.js","../../src/js/modules/Layout/defaults/modes/fitDataStretch.js","../../src/js/modules/Layout/defaults/modes/fitColumns.js","../../src/js/modules/Layout/Layout.js","../../src/js/modules/Localize/Localize.js","../../src/js/modules/Localize/defaults/langs.js","../../src/js/modules/Comms/Comms.js","../../src/js/core/tools/ModuleBinder.js","../../src/js/core/tools/Alert.js","../../src/js/core/Tabulator.js","../../src/js/core/defaults/options.js","../../src/js/core/TabulatorFull.js","../../src/js/core/row/PseudoRow.js"],"sourcesContent":["export default class CoreFeature{\n\n\tconstructor(table){\n\t\tthis.table = table;\n\t}\n\n\t//////////////////////////////////////////\n\t/////////////// DataLoad /////////////////\n\t//////////////////////////////////////////\n\n\treloadData(data, silent, columnsChanged){\n\t\treturn this.table.dataLoader.load(data, undefined, undefined, undefined, silent, columnsChanged);\n\t}\n\n\t//////////////////////////////////////////\n\t///////////// Localization ///////////////\n\t//////////////////////////////////////////\n\n\tlangText(){\n\t\treturn this.table.modules.localize.getText(...arguments);\n\t}\n\n\tlangBind(){\n\t\treturn this.table.modules.localize.bind(...arguments);\n\t}\n\n\tlangLocale(){\n\t\treturn this.table.modules.localize.getLocale(...arguments);\n\t}\n\n\n\t//////////////////////////////////////////\n\t////////// Inter Table Comms /////////////\n\t//////////////////////////////////////////\n\n\tcommsConnections(){\n\t\treturn this.table.modules.comms.getConnections(...arguments);\n\t}\n\n\tcommsSend(){\n\t\treturn this.table.modules.comms.send(...arguments);\n\t}\n\n\t//////////////////////////////////////////\n\t//////////////// Layout /////////////////\n\t//////////////////////////////////////////\n\n\tlayoutMode(){\n\t\treturn this.table.modules.layout.getMode();\n\t}\n\n\tlayoutRefresh(force){\n\t\treturn this.table.modules.layout.layout(force);\n\t}\n\n\n\t//////////////////////////////////////////\n\t/////////////// Event Bus ////////////////\n\t//////////////////////////////////////////\n\n\tsubscribe(){\n\t\treturn this.table.eventBus.subscribe(...arguments);\n\t}\n\n\tunsubscribe(){\n\t\treturn this.table.eventBus.unsubscribe(...arguments);\n\t}\n\n\tsubscribed(key){\n\t\treturn this.table.eventBus.subscribed(key);\n\t}\n\n\tsubscriptionChange(){\n\t\treturn this.table.eventBus.subscriptionChange(...arguments);\n\t}\n\n\tdispatch(){\n\t\treturn this.table.eventBus.dispatch(...arguments);\n\t}\n\n\tchain(){\n\t\treturn this.table.eventBus.chain(...arguments);\n\t}\n\n\tconfirm(){\n\t\treturn this.table.eventBus.confirm(...arguments);\n\t}\n\n\tdispatchExternal(){\n\t\treturn this.table.externalEvents.dispatch(...arguments);\n\t}\n\n\tsubscribedExternal(key){\n\t\treturn this.table.externalEvents.subscribed(key);\n\t}\n\n\tsubscriptionChangeExternal(){\n\t\treturn this.table.externalEvents.subscriptionChange(...arguments);\n\t}\n\n\t//////////////////////////////////////////\n\t//////////////// Options /////////////////\n\t//////////////////////////////////////////\n\n\toptions(key){\n\t\treturn this.table.options[key];\n\t}\n\n\tsetOption(key, value){\n\t\tif(typeof value !== \"undefined\"){\n\t\t\tthis.table.options[key] = value;\n\t\t}\n\n\t\treturn this.table.options[key];\n\t}\n\n\t//////////////////////////////////////////\n\t/////////// Deprecation Checks ///////////\n\t//////////////////////////////////////////\n\n\tdeprecationCheck(oldOption, newOption){\n\t\treturn this.table.deprecationAdvisor.check(oldOption, newOption);\n\t}\n\n\tdeprecationCheckMsg(oldOption, msg){\n\t\treturn this.table.deprecationAdvisor.checkMsg(oldOption, msg);\n\t}\n\n\tdeprecationMsg(msg){\n\t\treturn this.table.deprecationAdvisor.msg(msg);\n\t}\n\t//////////////////////////////////////////\n\t//////////////// Modules /////////////////\n\t//////////////////////////////////////////\n\n\tmodule(key){\n\t\treturn this.table.module(key);\n\t}\n}","export default class Helpers{\n\n\tstatic elVisible(el){\n\t\treturn !(el.offsetWidth <= 0 && el.offsetHeight <= 0);\n\t}\n\n\tstatic elOffset(el){\n\t\tvar box = el.getBoundingClientRect();\n\n\t\treturn {\n\t\t\ttop: box.top + window.pageYOffset - document.documentElement.clientTop,\n\t\t\tleft: box.left + window.pageXOffset - document.documentElement.clientLeft\n\t\t};\n\t}\n\n\tstatic deepClone(obj, clone, list = []){\n\t\tvar objectProto = {}.__proto__,\n\t\tarrayProto = [].__proto__;\n\n\t\tif (!clone){\n\t\t\tclone = Object.assign(Array.isArray(obj) ? [] : {}, obj);\n\t\t}\n\n\t\tfor(var i in obj) {\n\t\t\tlet subject = obj[i],\n\t\t\tmatch, copy;\n\n\t\t\tif(subject != null && typeof subject === \"object\" && (subject.__proto__ === objectProto || subject.__proto__ === arrayProto)){\n\t\t\t\tmatch = list.findIndex((item) => {\n\t\t\t\t\treturn item.subject === subject;\n\t\t\t\t});\n\n\t\t\t\tif(match > -1){\n\t\t\t\t\tclone[i] = list[match].copy;\n\t\t\t\t}else{\n\t\t\t\t\tcopy = Object.assign(Array.isArray(subject) ? [] : {}, subject);\n\n\t\t\t\t\tlist.unshift({subject, copy});\n\n\t\t\t\t\tclone[i] = this.deepClone(subject, copy, list);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn clone;\n\t}\n}","import CoreFeature from '../CoreFeature.js';\nimport Helpers from './Helpers.js';\n\nexport default class Popup extends CoreFeature{\n\tconstructor(table, element, parent){\n\t\tsuper(table);\n\t\t\n\t\tthis.element = element;\n\t\tthis.container = this._lookupContainer();\n\t\t\n\t\tthis.parent = parent;\n\t\t\n\t\tthis.reversedX = false;\n\t\tthis.childPopup = null;\n\t\tthis.blurable = false;\n\t\tthis.blurCallback = null;\n\t\tthis.blurEventsBound = false;\n\t\tthis.renderedCallback = null;\n\t\t\n\t\tthis.visible = false;\n\t\tthis.hideable = true;\n\t\t\n\t\tthis.element.classList.add(\"tabulator-popup-container\");\n\t\t\n\t\tthis.blurEvent = this.hide.bind(this, false);\n\t\tthis.escEvent = this._escapeCheck.bind(this);\n\t\t\n\t\tthis.destroyBinding = this.tableDestroyed.bind(this);\n\t\tthis.destroyed = false;\n\t}\n\t\n\ttableDestroyed(){\n\t\tthis.destroyed = true;\n\t\tthis.hide(true);\n\t}\n\t\n\t_lookupContainer(){\n\t\tvar container = this.table.options.popupContainer;\n\t\t\n\t\tif(typeof container === \"string\"){\n\t\t\tcontainer = document.querySelector(container);\n\t\t\t\n\t\t\tif(!container){\n\t\t\t\tconsole.warn(\"Menu Error - no container element found matching selector:\", this.table.options.popupContainer , \"(defaulting to document body)\");\n\t\t\t}\n\t\t}else if (container === true){\n\t\t\tcontainer = this.table.element;\n\t\t}\n\t\t\n\t\tif(container && !this._checkContainerIsParent(container)){\n\t\t\tcontainer = false;\n\t\t\tconsole.warn(\"Menu Error - container element does not contain this table:\", this.table.options.popupContainer , \"(defaulting to document body)\");\n\t\t}\n\t\t\n\t\tif(!container){\n\t\t\tcontainer = document.body;\n\t\t}\n\t\t\n\t\treturn container;\n\t}\n\t\n\t_checkContainerIsParent(container, element = this.table.element){\n\t\tif(container === element){\n\t\t\treturn true;\n\t\t}else{\n\t\t\treturn element.parentNode ? this._checkContainerIsParent(container, element.parentNode) : false;\n\t\t}\n\t}\n\t\n\trenderCallback(callback){\n\t\tthis.renderedCallback = callback;\n\t}\n\t\n\tcontainerEventCoords(e){\n\t\tvar touch = !(e instanceof MouseEvent);\n\t\t\n\t\tvar x = touch ? e.touches[0].pageX : e.pageX;\n\t\tvar y = touch ? e.touches[0].pageY : e.pageY;\n\t\t\n\t\tif(this.container !== document.body){\n\t\t\tlet parentOffset = Helpers.elOffset(this.container);\n\t\t\t\n\t\t\tx -= parentOffset.left;\n\t\t\ty -= parentOffset.top;\n\t\t}\n\t\t\n\t\treturn {x, y};\n\t}\n\t\n\telementPositionCoords(element, position = \"right\"){\n\t\tvar offset = Helpers.elOffset(element),\n\t\tcontainerOffset, x, y;\n\t\t\n\t\tif(this.container !== document.body){\n\t\t\tcontainerOffset = Helpers.elOffset(this.container);\n\t\t\t\n\t\t\toffset.left -= containerOffset.left;\n\t\t\toffset.top -= containerOffset.top;\n\t\t}\n\t\t\n\t\tswitch(position){\n\t\t\tcase \"right\":\n\t\t\t\tx = offset.left + element.offsetWidth;\n\t\t\t\ty = offset.top - 1;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"bottom\":\n\t\t\t\tx = offset.left;\n\t\t\t\ty = offset.top + element.offsetHeight;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"left\":\n\t\t\t\tx = offset.left;\n\t\t\t\ty = offset.top - 1;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"top\":\n\t\t\t\tx = offset.left;\n\t\t\t\ty = offset.top;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"center\":\n\t\t\t\tx = offset.left + (element.offsetWidth / 2);\n\t\t\t\ty = offset.top + (element.offsetHeight / 2);\n\t\t\t\tbreak;\n\t\t\t\n\t\t}\n\t\t\n\t\treturn {x, y, offset};\n\t}\n\t\n\tshow(origin, position){\n\t\tvar x, y, parentEl, parentOffset, coords;\n\t\t\n\t\tif(this.destroyed || this.table.destroyed){\n\t\t\treturn this;\n\t\t}\n\t\t\n\t\tif(origin instanceof HTMLElement){\n\t\t\tparentEl = origin;\n\t\t\tcoords = this.elementPositionCoords(origin, position);\n\t\t\t\n\t\t\tparentOffset = coords.offset;\n\t\t\tx = coords.x;\n\t\t\ty = coords.y;\n\t\t\t\n\t\t}else if(typeof origin === \"number\"){\n\t\t\tparentOffset = {top:0, left:0};\n\t\t\tx = origin;\n\t\t\ty = position;\n\t\t}else{\n\t\t\tcoords = this.containerEventCoords(origin);\n\t\t\t\n\t\t\tx = coords.x;\n\t\t\ty = coords.y;\n\t\t\t\n\t\t\tthis.reversedX = false;\n\t\t}\n\t\t\n\t\tthis.element.style.top = y + \"px\";\n\t\tthis.element.style.left = x + \"px\";\n\t\t\n\t\tthis.container.appendChild(this.element);\n\t\t\n\t\tif(typeof this.renderedCallback === \"function\"){\n\t\t\tthis.renderedCallback();\n\t\t}\n\t\t\n\t\tthis._fitToScreen(x, y, parentEl, parentOffset, position);\n\t\t\n\t\tthis.visible = true;\n\t\t\n\t\tthis.subscribe(\"table-destroy\", this.destroyBinding);\n\t\t\n\t\tthis.element.addEventListener(\"mousedown\", (e) => {\n\t\t\te.stopPropagation();\n\t\t});\n\t\t\n\t\treturn this;\n\t}\n\t\n\t_fitToScreen(x, y, parentEl, parentOffset, position){\n\t\tvar scrollTop = this.container === document.body ? document.documentElement.scrollTop : this.container.scrollTop;\n\t\t\n\t\t//move menu to start on right edge if it is too close to the edge of the screen\n\t\tif((x + this.element.offsetWidth) >= this.container.offsetWidth || this.reversedX){\n\t\t\tthis.element.style.left = \"\";\n\t\t\t\n\t\t\tif(parentEl){\n\t\t\t\tthis.element.style.right = (this.container.offsetWidth - parentOffset.left) + \"px\";\n\t\t\t}else{\n\t\t\t\tthis.element.style.right = (this.container.offsetWidth - x) + \"px\";\n\t\t\t}\n\t\t\t\n\t\t\tthis.reversedX = true;\n\t\t}\n\t\t\n\t\t//move menu to start on bottom edge if it is too close to the edge of the screen\n\t\tif((y + this.element.offsetHeight) > Math.max(this.container.offsetHeight, scrollTop ? this.container.scrollHeight : 0)) {\n\t\t\tif(parentEl){\n\t\t\t\tswitch(position){\n\t\t\t\t\tcase \"bottom\":\n\t\t\t\t\t\tthis.element.style.top = (parseInt(this.element.style.top) - this.element.offsetHeight - parentEl.offsetHeight - 1) + \"px\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tthis.element.style.top = (parseInt(this.element.style.top) - this.element.offsetHeight + parentEl.offsetHeight + 1) + \"px\";\n\t\t\t\t}\n\t\t\t\t\n\t\t\t}else{\n\t\t\t\tthis.element.style.top = (parseInt(this.element.style.top) - this.element.offsetHeight) + \"px\";\n\t\t\t}\n\t\t}\n\t}\n\t\n\tisVisible(){\n\t\treturn this.visible;\n\t}\n\t\n\thideOnBlur(callback){\n\t\tthis.blurable = true;\n\t\t\n\t\tif(this.visible){\n\t\t\tsetTimeout(() => {\n\t\t\t\tif(this.visible){\n\t\t\t\t\tthis.table.rowManager.element.addEventListener(\"scroll\", this.blurEvent);\n\t\t\t\t\tthis.subscribe(\"cell-editing\", this.blurEvent);\n\t\t\t\t\tdocument.body.addEventListener(\"click\", this.blurEvent);\n\t\t\t\t\tdocument.body.addEventListener(\"contextmenu\", this.blurEvent);\n\t\t\t\t\tdocument.body.addEventListener(\"mousedown\", this.blurEvent);\n\t\t\t\t\twindow.addEventListener(\"resize\", this.blurEvent);\n\t\t\t\t\tdocument.body.addEventListener(\"keydown\", this.escEvent);\n\n\t\t\t\t\tthis.blurEventsBound = true;\n\t\t\t\t}\n\t\t\t}, 100);\n\t\t\t\n\t\t\tthis.blurCallback = callback;\n\t\t}\n\t\t\n\t\treturn this;\n\t}\n\t\n\t_escapeCheck(e){\n\t\tif(e.keyCode == 27){\n\t\t\tthis.hide();\n\t\t}\n\t}\n\t\n\tblockHide(){\n\t\tthis.hideable = false;\n\t}\n\t\n\trestoreHide(){\n\t\tthis.hideable = true;\n\t}\n\t\n\thide(silent = false){\n\t\tif(this.visible && this.hideable){\n\t\t\tif(this.blurable && this.blurEventsBound){\n\t\t\t\tdocument.body.removeEventListener(\"keydown\", this.escEvent);\n\t\t\t\tdocument.body.removeEventListener(\"click\", this.blurEvent);\n\t\t\t\tdocument.body.removeEventListener(\"contextmenu\", this.blurEvent);\n\t\t\t\tdocument.body.removeEventListener(\"mousedown\", this.blurEvent);\n\t\t\t\twindow.removeEventListener(\"resize\", this.blurEvent);\n\t\t\t\tthis.table.rowManager.element.removeEventListener(\"scroll\", this.blurEvent);\n\t\t\t\tthis.unsubscribe(\"cell-editing\", this.blurEvent);\n\n\t\t\t\tthis.blurEventsBound = false;\n\t\t\t}\n\t\t\t\n\t\t\tif(this.childPopup){\n\t\t\t\tthis.childPopup.hide();\n\t\t\t}\n\t\t\t\n\t\t\tif(this.parent){\n\t\t\t\tthis.parent.childPopup = null;\n\t\t\t}\n\t\t\t\n\t\t\tif(this.element.parentNode){\n\t\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t\t}\n\t\t\t\n\t\t\tthis.visible = false;\n\t\t\t\n\t\t\tif(this.blurCallback && !silent){\n\t\t\t\tthis.blurCallback();\n\t\t\t}\n\t\t\t\n\t\t\tthis.unsubscribe(\"table-destroy\", this.destroyBinding);\n\t\t}\n\t\t\n\t\treturn this;\n\t}\n\t\n\tchild(element){\n\t\tif(this.childPopup){\n\t\t\tthis.childPopup.hide();\n\t\t}\n\t\t\n\t\tthis.childPopup = new Popup(this.table, element, this);\n\t\t\n\t\treturn this.childPopup;\n\t}\n}","import CoreFeature from './CoreFeature.js';\nimport Popup from './tools/Popup.js';\n\nclass Module extends CoreFeature{\n\t\n\tconstructor(table, name){\n\t\tsuper(table);\n\t\t\n\t\tthis._handler = null;\n\t}\n\t\n\tinitialize(){\n\t\t// setup module when table is initialized, to be overridden in module\n\t}\n\t\n\t\n\t///////////////////////////////////\n\t////// Options Registration ///////\n\t///////////////////////////////////\n\t\n\tregisterTableOption(key, value){\n\t\tthis.table.optionsList.register(key, value);\n\t}\n\t\n\tregisterColumnOption(key, value){\n\t\tthis.table.columnManager.optionsList.register(key, value);\n\t}\n\t\n\t///////////////////////////////////\n\t/// Public Function Registration ///\n\t///////////////////////////////////\n\t\n\tregisterTableFunction(name, func){\n\t\tif(typeof this.table[name] === \"undefined\"){\n\t\t\tthis.table[name] = (...args) => {\n\t\t\t\tthis.table.initGuard(name);\n\t\t\t\t\n\t\t\t\treturn func(...args);\n\t\t\t};\n\t\t}else{\n\t\t\tconsole.warn(\"Unable to bind table function, name already in use\", name);\n\t\t}\n\t}\n\t\n\tregisterComponentFunction(component, func, handler){\n\t\treturn this.table.componentFunctionBinder.bind(component, func, handler);\n\t}\n\t\n\t///////////////////////////////////\n\t////////// Data Pipeline //////////\n\t///////////////////////////////////\n\t\n\tregisterDataHandler(handler, priority){\n\t\tthis.table.rowManager.registerDataPipelineHandler(handler, priority);\n\t\tthis._handler = handler;\n\t}\n\t\n\tregisterDisplayHandler(handler, priority){\n\t\tthis.table.rowManager.registerDisplayPipelineHandler(handler, priority);\n\t\tthis._handler = handler;\n\t}\n\t\n\tdisplayRows(adjust){\n\t\tvar index = this.table.rowManager.displayRows.length - 1, \n\t\tlookupIndex;\n\t\t\n\t\tif(this._handler){\n\t\t\tlookupIndex = this.table.rowManager.displayPipeline.findIndex((item) => {\n\t\t\t\treturn item.handler === this._handler;\n\t\t\t});\n\n\t\t\tif(lookupIndex > -1){\n\t\t\t\tindex = lookupIndex;\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(adjust){\n\t\t\tindex = index + adjust;\n\t\t}\n\n\t\tif(this._handler){\n\t\t\tif(index > -1){\n\t\t\t\treturn this.table.rowManager.getDisplayRows(index);\n\t\t\t}else{\n\t\t\t\treturn this.activeRows();\n\t\t\t}\n\t\t}\t\n\t}\n\t\n\tactiveRows(){\n\t\treturn this.table.rowManager.activeRows;\n\t}\n\t\n\trefreshData(renderInPosition, handler){\n\t\tif(!handler){\n\t\t\thandler = this._handler;\n\t\t}\n\t\t\n\t\tif(handler){\n\t\t\tthis.table.rowManager.refreshActiveData(handler, false, renderInPosition);\n\t\t}\n\t}\n\t\n\t///////////////////////////////////\n\t//////// Footer Management ////////\n\t///////////////////////////////////\n\t\n\tfooterAppend(element){\n\t\treturn this.table.footerManager.append(element);\n\t}\n\t\n\tfooterPrepend(element){\n\t\treturn this.table.footerManager.prepend(element);\n\t}\n\t\n\tfooterRemove(element){\n\t\treturn this.table.footerManager.remove(element);\n\t} \n\t\n\t///////////////////////////////////\n\t//////// Popups Management ////////\n\t///////////////////////////////////\n\t\n\tpopup(menuEl, menuContainer){\n\t\treturn new Popup(this.table, menuEl, menuContainer);\n\t}\n\t\n\t///////////////////////////////////\n\t//////// Alert Management ////////\n\t///////////////////////////////////\n\t\n\talert(content, type){\n\t\treturn this.table.alertManager.alert(content, type);\n\t}\n\t\n\tclearAlert(){\n\t\treturn this.table.alertManager.clear();\n\t}\n\t\n}\n\nexport default Module;","import Module from '../../core/Module.js';\nimport Helpers from '../../core/tools/Helpers.js';\n\nimport defaultAccessors from './defaults/accessors.js';\n\nclass Accessor extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.allowedTypes = [\"\", \"data\", \"download\", \"clipboard\", \"print\", \"htmlOutput\"]; //list of accessor types\n\n\t\tthis.registerColumnOption(\"accessor\");\n\t\tthis.registerColumnOption(\"accessorParams\");\n\t\tthis.registerColumnOption(\"accessorData\");\n\t\tthis.registerColumnOption(\"accessorDataParams\");\n\t\tthis.registerColumnOption(\"accessorDownload\");\n\t\tthis.registerColumnOption(\"accessorDownloadParams\");\n\t\tthis.registerColumnOption(\"accessorClipboard\");\n\t\tthis.registerColumnOption(\"accessorClipboardParams\");\n\t\tthis.registerColumnOption(\"accessorPrint\");\n\t\tthis.registerColumnOption(\"accessorPrintParams\");\n\t\tthis.registerColumnOption(\"accessorHtmlOutput\");\n\t\tthis.registerColumnOption(\"accessorHtmlOutputParams\");\n\t}\n\n\tinitialize(){\n\t\tthis.subscribe(\"column-layout\", this.initializeColumn.bind(this));\n\t\tthis.subscribe(\"row-data-retrieve\", this.transformRow.bind(this));\n\t}\n\n\t//initialize column accessor\n\tinitializeColumn(column){\n\t\tvar match = false,\n\t\tconfig = {};\n\n\t\tthis.allowedTypes.forEach((type) => {\n\t\t\tvar key = \"accessor\" + (type.charAt(0).toUpperCase() + type.slice(1)),\n\t\t\taccessor;\n\n\t\t\tif(column.definition[key]){\n\t\t\t\taccessor = this.lookupAccessor(column.definition[key]);\n\n\t\t\t\tif(accessor){\n\t\t\t\t\tmatch = true;\n\n\t\t\t\t\tconfig[key] = {\n\t\t\t\t\t\taccessor:accessor,\n\t\t\t\t\t\tparams: column.definition[key + \"Params\"] || {},\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tif(match){\n\t\t\tcolumn.modules.accessor = config;\n\t\t}\n\t}\n\n\tlookupAccessor(value){\n\t\tvar accessor = false;\n\n\t\t//set column accessor\n\t\tswitch(typeof value){\n\t\t\tcase \"string\":\n\t\t\t\tif(Accessor.accessors[value]){\n\t\t\t\t\taccessor = Accessor.accessors[value];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Accessor Error - No such accessor found, ignoring: \", value);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase \"function\":\n\t\t\t\taccessor = value;\n\t\t\t\tbreak;\n\t\t}\n\n\t\treturn accessor;\n\t}\n\n\t//apply accessor to row\n\ttransformRow(row, type){\n\t\tvar key = \"accessor\" + (type.charAt(0).toUpperCase() + type.slice(1)),\n\t\trowComponent = row.getComponent();\n\n\t\t//clone data object with deep copy to isolate internal data from returned result\n\t\tvar data = Helpers.deepClone(row.data || {});\n\n\t\tthis.table.columnManager.traverse(function(column){\n\t\t\tvar value, accessor, params, colComponent;\n\n\t\t\tif(column.modules.accessor){\n\n\t\t\t\taccessor = column.modules.accessor[key] || column.modules.accessor.accessor || false;\n\n\t\t\t\tif(accessor){\n\t\t\t\t\tvalue = column.getFieldValue(data);\n\n\t\t\t\t\tif(value != \"undefined\"){\n\t\t\t\t\t\tcolComponent = column.getComponent();\n\t\t\t\t\t\tparams = typeof accessor.params === \"function\" ? accessor.params(value, data, type, colComponent, rowComponent) : accessor.params;\n\t\t\t\t\t\tcolumn.setFieldValue(data, accessor.accessor(value, data, type, params, colComponent, rowComponent));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\treturn data;\n\t}\n}\n\n//load defaults\nAccessor.moduleName = \"accessor\";\nAccessor.accessors = defaultAccessors;\n\nexport default Accessor;","export default {};","function generateParamsList(data, prefix){\n\tvar output = [];\n\n\tprefix = prefix || \"\";\n\n\tif(Array.isArray(data)){\n\t\tdata.forEach((item, i) => {\n\t\t\toutput = output.concat(generateParamsList(item, prefix ? prefix + \"[\" + i + \"]\" : i));\n\t\t});\n\t}else if (typeof data === \"object\"){\n\t\tfor (var key in data){\n\t\t\toutput = output.concat(generateParamsList(data[key], prefix ? prefix + \"[\" + key + \"]\" : key));\n\t\t}\n\t}else{\n\t\toutput.push({key:prefix, value:data});\n\t}\n\n\treturn output;\n}\n\nfunction serializeParams(params){\n\tvar output = generateParamsList(params),\n\tencoded = [];\n\n\toutput.forEach(function(item){\n\t\tencoded.push(encodeURIComponent(item.key) + \"=\" + encodeURIComponent(item.value));\n\t});\n\n\treturn encoded.join(\"&\");\n}\n\nexport default function(url, config, params){\n\tif(url){\n\t\tif(params && Object.keys(params).length){\n\t\t\tif(!config.method || config.method.toLowerCase() == \"get\"){\n\t\t\t\tconfig.method = \"get\";\n\n\t\t\t\turl += (url.includes(\"?\") ? \"&\" : \"?\") + serializeParams(params);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn url;\n}","function generateParamsList(data, prefix){\n\tvar output = [];\n\n\tprefix = prefix || \"\";\n\n\tif(Array.isArray(data)){\n\t\tdata.forEach((item, i) => {\n\t\t\toutput = output.concat(generateParamsList(item, prefix ? prefix + \"[\" + i + \"]\" : i));\n\t\t});\n\t}else if (typeof data === \"object\"){\n\t\tfor (var key in data){\n\t\t\toutput = output.concat(generateParamsList(data[key], prefix ? prefix + \"[\" + key + \"]\" : key));\n\t\t}\n\t}else{\n\t\toutput.push({key:prefix, value:data});\n\t}\n\n\treturn output;\n}\n\nexport default {\n\t\"json\":{\n\t\theaders:{\n\t\t\t'Content-Type': 'application/json',\n\t\t},\n\t\tbody:function(url, config, params){\n\t\t\treturn JSON.stringify(params);\n\t\t},\n\t},\n\t\"form\":{\n\t\theaders:{\n\t\t},\n\t\tbody:function(url, config, params){\n\n\t\t\tvar output = generateParamsList(params),\n\t\t\tform = new FormData();\n\n\t\t\toutput.forEach(function(item){\n\t\t\t\tform.append(item.key, item.value);\n\t\t\t});\n\n\t\t\treturn form;\n\t\t},\n\t},\n};","import Module from '../../core/Module.js';\n\nimport defaultConfig from './defaults/config.js';\nimport defaultURLGenerator from './defaults/urlGenerator.js';\nimport defaultLoaderPromise from './defaults/loaderPromise.js';\nimport defaultContentTypeFormatters from './defaults/contentTypeFormatters.js';\n\nclass Ajax extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.config = {}; //hold config object for ajax request\n\t\tthis.url = \"\"; //request URL\n\t\tthis.urlGenerator = false;\n\t\tthis.params = false; //request parameters\n\t\t\n\t\tthis.loaderPromise = false;\n\t\t\n\t\tthis.registerTableOption(\"ajaxURL\", false); //url for ajax loading\n\t\tthis.registerTableOption(\"ajaxURLGenerator\", false);\n\t\tthis.registerTableOption(\"ajaxParams\", {}); //params for ajax loading\n\t\tthis.registerTableOption(\"ajaxConfig\", \"get\"); //ajax request type\n\t\tthis.registerTableOption(\"ajaxContentType\", \"form\"); //ajax request type\n\t\tthis.registerTableOption(\"ajaxRequestFunc\", false); //promise function\n\t\t\n\t\tthis.registerTableOption(\"ajaxRequesting\", function(){});\n\t\tthis.registerTableOption(\"ajaxResponse\", false);\n\t\t\n\t\tthis.contentTypeFormatters = Ajax.contentTypeFormatters;\n\t}\n\t\n\t//initialize setup options\n\tinitialize(){\n\t\tthis.loaderPromise = this.table.options.ajaxRequestFunc || Ajax.defaultLoaderPromise;\n\t\tthis.urlGenerator = this.table.options.ajaxURLGenerator || Ajax.defaultURLGenerator;\n\t\t\n\t\tif(this.table.options.ajaxURL){\n\t\t\tthis.setUrl(this.table.options.ajaxURL);\n\t\t}\n\n\n\t\tthis.setDefaultConfig(this.table.options.ajaxConfig);\n\t\t\n\t\tthis.registerTableFunction(\"getAjaxUrl\", this.getUrl.bind(this));\n\t\t\n\t\tthis.subscribe(\"data-loading\", this.requestDataCheck.bind(this));\n\t\tthis.subscribe(\"data-params\", this.requestParams.bind(this));\n\t\tthis.subscribe(\"data-load\", this.requestData.bind(this));\n\t}\n\t\n\trequestParams(data, config, silent, params){\n\t\tvar ajaxParams = this.table.options.ajaxParams;\n\t\t\n\t\tif(ajaxParams){\n\t\t\tif(typeof ajaxParams === \"function\"){\n\t\t\t\tajaxParams = ajaxParams.call(this.table);\n\t\t\t}\n\t\t\t\n\t\t\tparams = Object.assign(params, ajaxParams);\n\t\t}\t\t\n\t\t\n\t\treturn params;\n\t}\n\t\n\trequestDataCheck(data, params, config, silent){\n\t\treturn !!((!data && this.url) || typeof data === \"string\");\n\t}\n\t\n\trequestData(url, params, config, silent, previousData){\n\t\tvar ajaxConfig;\n\t\t\n\t\tif(!previousData && this.requestDataCheck(url)){\n\t\t\tif(url){\n\t\t\t\tthis.setUrl(url);\n\t\t\t}\n\t\t\t\n\t\t\tajaxConfig = this.generateConfig(config);\n\t\t\t\n\t\t\treturn this.sendRequest(this.url, params, ajaxConfig);\n\t\t}else{\n\t\t\treturn previousData;\n\t\t}\n\t}\n\t\n\tsetDefaultConfig(config = {}){\n\t\tthis.config = Object.assign({}, Ajax.defaultConfig);\n\n\t\tif(typeof config == \"string\"){\n\t\t\tthis.config.method = config;\n\t\t}else{\n\t\t\tObject.assign(this.config, config);\n\t\t}\n\t}\n\t\n\t//load config object\n\tgenerateConfig(config = {}){\n\t\tvar ajaxConfig = Object.assign({}, this.config);\n\t\t\n\t\tif(typeof config == \"string\"){\n\t\t\tajaxConfig.method = config;\n\t\t}else{\n\t\t\tObject.assign(ajaxConfig, config);\n\t\t}\n\t\t\n\t\treturn ajaxConfig;\n\t}\n\t\n\t//set request url\n\tsetUrl(url){\n\t\tthis.url = url;\n\t}\n\t\n\t//get request url\n\tgetUrl(){\n\t\treturn this.url;\n\t}\n\t\n\t//send ajax request\n\tsendRequest(url, params, config){\n\t\tif(this.table.options.ajaxRequesting.call(this.table, url, params) !== false){\n\t\t\treturn this.loaderPromise(url, config, params)\n\t\t\t\t.then((data)=>{\n\t\t\t\t\tif(this.table.options.ajaxResponse){\n\t\t\t\t\t\tdata = this.table.options.ajaxResponse.call(this.table, url, params, data);\n\t\t\t\t\t}\n\t\t\t\t\n\t\t\t\t\treturn data;\n\t\t\t\t});\n\t\t}else{\n\t\t\treturn Promise.reject();\n\t\t}\n\t}\n}\n\nAjax.moduleName = \"ajax\";\n\n//load defaults\nAjax.defaultConfig = defaultConfig;\nAjax.defaultURLGenerator = defaultURLGenerator;\nAjax.defaultLoaderPromise = defaultLoaderPromise;\nAjax.contentTypeFormatters = defaultContentTypeFormatters;\n\nexport default Ajax;","export default {\n\tmethod: \"GET\",\n};","export default function(url, config, params){\n\tvar contentType;\n\n\treturn new Promise((resolve, reject) => {\n\t\t//set url\n\t\turl = this.urlGenerator.call(this.table, url, config, params);\n\n\t\t//set body content if not GET request\n\t\tif(config.method.toUpperCase() != \"GET\"){\n\t\t\tcontentType = typeof this.table.options.ajaxContentType === \"object\" ? this.table.options.ajaxContentType : this.contentTypeFormatters[this.table.options.ajaxContentType];\n\t\t\tif(contentType){\n\n\t\t\t\tfor(var key in contentType.headers){\n\t\t\t\t\tif(!config.headers){\n\t\t\t\t\t\tconfig.headers = {};\n\t\t\t\t\t}\n\n\t\t\t\t\tif(typeof config.headers[key] === \"undefined\"){\n\t\t\t\t\t\tconfig.headers[key] = contentType.headers[key];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconfig.body = contentType.body.call(this, url, config, params);\n\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Ajax Error - Invalid ajaxContentType value:\", this.table.options.ajaxContentType);\n\t\t\t}\n\t\t}\n\n\t\tif(url){\n\t\t\t//configure headers\n\t\t\tif(typeof config.headers === \"undefined\"){\n\t\t\t\tconfig.headers = {};\n\t\t\t}\n\n\t\t\tif(typeof config.headers.Accept === \"undefined\"){\n\t\t\t\tconfig.headers.Accept = \"application/json\";\n\t\t\t}\n\n\t\t\tif(typeof config.headers[\"X-Requested-With\"] === \"undefined\"){\n\t\t\t\tconfig.headers[\"X-Requested-With\"] = \"XMLHttpRequest\";\n\t\t\t}\n\n\t\t\tif(typeof config.mode === \"undefined\"){\n\t\t\t\tconfig.mode = \"cors\";\n\t\t\t}\n\n\t\t\tif(config.mode == \"cors\"){\n\t\t\t\tif(typeof config.headers[\"Origin\"] === \"undefined\"){\n\t\t\t\t\tconfig.headers[\"Origin\"] = window.location.origin;\n\t\t\t\t}\n \n\t\t\t\tif(typeof config.credentials === \"undefined\"){\n\t\t\t\t\tconfig.credentials = 'same-origin';\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(typeof config.credentials === \"undefined\"){\n\t\t\t\t\tconfig.credentials = 'include';\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//send request\n\t\t\tfetch(url, config)\n\t\t\t\t.then((response)=>{\n\t\t\t\t\tif(response.ok) {\n\t\t\t\t\t\tresponse.json()\n\t\t\t\t\t\t\t.then((data)=>{\n\t\t\t\t\t\t\t\tresolve(data);\n\t\t\t\t\t\t\t}).catch((error)=>{\n\t\t\t\t\t\t\t\treject(error);\n\t\t\t\t\t\t\t\tconsole.warn(\"Ajax Load Error - Invalid JSON returned\", error);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.error(\"Ajax Load Error - Connection Error: \" + response.status, response.statusText);\n\t\t\t\t\t\treject(response);\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t\t.catch((error)=>{\n\t\t\t\t\tconsole.error(\"Ajax Load Error - Connection Error: \", error);\n\t\t\t\t\treject(error);\n\t\t\t\t});\n\t\t}else{\n\t\t\tconsole.warn(\"Ajax Load Error - No URL Set\");\n\t\t\tresolve([]);\n\t\t}\n\t});\n}","import Module from '../../core/Module.js';\n\nimport defaultPasteActions from './defaults/pasteActions.js';\nimport defaultPasteParsers from './defaults/pasteParsers.js';\n\nclass Clipboard extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.mode = true;\n\t\tthis.pasteParser = function(){};\n\t\tthis.pasteAction = function(){};\n\t\tthis.customSelection = false;\n\t\tthis.rowRange = false;\n\t\tthis.blocked = true; //block copy actions not originating from this command\n\n\t\tthis.registerTableOption(\"clipboard\", false); //enable clipboard\n\t\tthis.registerTableOption(\"clipboardCopyStyled\", true); //formatted table data\n\t\tthis.registerTableOption(\"clipboardCopyConfig\", false); //clipboard config\n\t\tthis.registerTableOption(\"clipboardCopyFormatter\", false); //DEPRECATED - REMOVE in 5.0\n\t\tthis.registerTableOption(\"clipboardCopyRowRange\", \"active\"); //restrict clipboard to visible rows only\n\t\tthis.registerTableOption(\"clipboardPasteParser\", \"table\"); //convert pasted clipboard data to rows\n\t\tthis.registerTableOption(\"clipboardPasteAction\", \"insert\"); //how to insert pasted data into the table\n\n\t\tthis.registerColumnOption(\"clipboard\");\n\t\tthis.registerColumnOption(\"titleClipboard\");\n\t}\n\n\tinitialize(){\n\t\tthis.mode = this.table.options.clipboard;\n\n\t\tthis.rowRange = this.table.options.clipboardCopyRowRange;\n\n\t\tif(this.mode === true || this.mode === \"copy\"){\n\t\t\tthis.table.element.addEventListener(\"copy\", (e) => {\n\t\t\t\tvar plain, html, list;\n\n\t\t\t\tif(!this.blocked){\n\t\t\t\t\te.preventDefault();\n\n\t\t\t\t\tif(this.customSelection){\n\t\t\t\t\t\tplain = this.customSelection;\n\n\t\t\t\t\t\tif(this.table.options.clipboardCopyFormatter){\n\t\t\t\t\t\t\tplain = this.table.options.clipboardCopyFormatter(\"plain\", plain);\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\n\t\t\t\t\t\tlist = this.table.modules.export.generateExportList(this.table.options.clipboardCopyConfig, this.table.options.clipboardCopyStyled, this.rowRange, \"clipboard\");\n\n\t\t\t\t\t\thtml = this.table.modules.export.generateHTMLTable(list);\n\t\t\t\t\t\tplain = html ? this.generatePlainContent(list) : \"\";\n\n\t\t\t\t\t\tif(this.table.options.clipboardCopyFormatter){\n\t\t\t\t\t\t\tplain = this.table.options.clipboardCopyFormatter(\"plain\", plain);\n\t\t\t\t\t\t\thtml = this.table.options.clipboardCopyFormatter(\"html\", html);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (window.clipboardData && window.clipboardData.setData) {\n\t\t\t\t\t\twindow.clipboardData.setData('Text', plain);\n\t\t\t\t\t} else if (e.clipboardData && e.clipboardData.setData) {\n\t\t\t\t\t\te.clipboardData.setData('text/plain', plain);\n\t\t\t\t\t\tif(html){\n\t\t\t\t\t\t\te.clipboardData.setData('text/html', html);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else if (e.originalEvent && e.originalEvent.clipboardData.setData) {\n\t\t\t\t\t\te.originalEvent.clipboardData.setData('text/plain', plain);\n\t\t\t\t\t\tif(html){\n\t\t\t\t\t\t\te.originalEvent.clipboardData.setData('text/html', html);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.dispatchExternal(\"clipboardCopied\", plain, html);\n\n\t\t\t\t\tthis.reset();\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\tif(this.mode === true || this.mode === \"paste\"){\n\t\t\tthis.table.element.addEventListener(\"paste\", (e) => {\n\t\t\t\tthis.paste(e);\n\t\t\t});\n\t\t}\n\n\t\tthis.setPasteParser(this.table.options.clipboardPasteParser);\n\t\tthis.setPasteAction(this.table.options.clipboardPasteAction);\n\n\t\tthis.registerTableFunction(\"copyToClipboard\", this.copy.bind(this));\n\t}\n\n\treset(){\n\t\tthis.blocked = true;\n\t\tthis.customSelection = false;\n\t}\n\n\tgeneratePlainContent (list) {\n\t\tvar output = [];\n\n\t\tlist.forEach((row) => {\n\t\t\tvar rowData = [];\n\n\t\t\trow.columns.forEach((col) => {\n\t\t\t\tvar value = \"\";\n\n\t\t\t\tif(col){\n\n\t\t\t\t\tif(row.type === \"group\"){\n\t\t\t\t\t\tcol.value = col.component.getKey();\n\t\t\t\t\t}\n\n\t\t\t\t\tif(col.value === null){\n\t\t\t\t\t\tvalue = \"\";\n\t\t\t\t\t}else{\n\t\t\t\t\t\tswitch(typeof col.value){\n\t\t\t\t\t\t\tcase \"object\":\n\t\t\t\t\t\t\t\tvalue = JSON.stringify(col.value);\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase \"undefined\":\n\t\t\t\t\t\t\t\tvalue = \"\";\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\tvalue = col.value;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\trowData.push(value);\n\t\t\t});\n\n\t\t\toutput.push(rowData.join(\"\\t\"));\n\t\t});\n\n\t\treturn output.join(\"\\n\");\n\t}\n\n\tcopy (range, internal) {\n\t\tvar sel, textRange;\n\t\tthis.blocked = false;\n\t\tthis.customSelection = false;\n\n\t\tif (this.mode === true || this.mode === \"copy\") {\n\n\t\t\tthis.rowRange = range || this.table.options.clipboardCopyRowRange;\n\n\t\t\tif (typeof window.getSelection != \"undefined\" && typeof document.createRange != \"undefined\") {\n\t\t\t\trange = document.createRange();\n\t\t\t\trange.selectNodeContents(this.table.element);\n\t\t\t\tsel = window.getSelection();\n\n\t\t\t\tif (sel.toString() && internal) {\n\t\t\t\t\tthis.customSelection = sel.toString();\n\t\t\t\t}\n\n\t\t\t\tsel.removeAllRanges();\n\t\t\t\tsel.addRange(range);\n\t\t\t} else if (typeof document.selection != \"undefined\" && typeof document.body.createTextRange != \"undefined\") {\n\t\t\t\ttextRange = document.body.createTextRange();\n\t\t\t\ttextRange.moveToElementText(this.table.element);\n\t\t\t\ttextRange.select();\n\t\t\t}\n\n\t\t\tdocument.execCommand('copy');\n\n\t\t\tif (sel) {\n\t\t\t\tsel.removeAllRanges();\n\t\t\t}\n\t\t}\n\t}\n\n\t//PASTE EVENT HANDLING\n\tsetPasteAction(action){\n\n\t\tswitch(typeof action){\n\t\t\tcase \"string\":\n\t\t\t\tthis.pasteAction = Clipboard.pasteActions[action];\n\n\t\t\t\tif(!this.pasteAction){\n\t\t\t\t\tconsole.warn(\"Clipboard Error - No such paste action found:\", action);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase \"function\":\n\t\t\t\tthis.pasteAction = action;\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\tsetPasteParser(parser){\n\t\tswitch(typeof parser){\n\t\t\tcase \"string\":\n\t\t\t\tthis.pasteParser = Clipboard.pasteParsers[parser];\n\n\t\t\t\tif(!this.pasteParser){\n\t\t\t\t\tconsole.warn(\"Clipboard Error - No such paste parser found:\", parser);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase \"function\":\n\t\t\t\tthis.pasteParser = parser;\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\tpaste(e){\n\t\tvar data, rowData, rows;\n\n\t\tif(this.checkPaseOrigin(e)){\n\n\t\t\tdata = this.getPasteData(e);\n\n\t\t\trowData = this.pasteParser.call(this, data);\n\n\t\t\tif(rowData){\n\t\t\t\te.preventDefault();\n\n\t\t\t\tif(this.table.modExists(\"mutator\")){\n\t\t\t\t\trowData = this.mutateData(rowData);\n\t\t\t\t}\n\n\t\t\t\trows = this.pasteAction.call(this, rowData);\n\n\t\t\t\tthis.dispatchExternal(\"clipboardPasted\", data, rowData, rows);\n\t\t\t}else{\n\t\t\t\tthis.dispatchExternal(\"clipboardPasteError\", data);\n\t\t\t}\n\t\t}\n\t}\n\n\tmutateData(data){\n\t\tvar output = [];\n\n\t\tif(Array.isArray(data)){\n\t\t\tdata.forEach((row) => {\n\t\t\t\toutput.push(this.table.modules.mutator.transformRow(row, \"clipboard\"));\n\t\t\t});\n\t\t}else{\n\t\t\toutput = data;\n\t\t}\n\n\t\treturn output;\n\t}\n\n\n\tcheckPaseOrigin(e){\n\t\tvar valid = true;\n\n\t\tif(e.target.tagName != \"DIV\" || this.table.modules.edit.currentCell){\n\t\t\tvalid = false;\n\t\t}\n\n\t\treturn valid;\n\t}\n\n\tgetPasteData(e){\n\t\tvar data;\n\n\t\tif (window.clipboardData && window.clipboardData.getData) {\n\t\t\tdata = window.clipboardData.getData('Text');\n\t\t} else if (e.clipboardData && e.clipboardData.getData) {\n\t\t\tdata = e.clipboardData.getData('text/plain');\n\t\t} else if (e.originalEvent && e.originalEvent.clipboardData.getData) {\n\t\t\tdata = e.originalEvent.clipboardData.getData('text/plain');\n\t\t}\n\n\t\treturn data;\n\t}\n}\n\nClipboard.moduleName = \"clipboard\";\n\n//load defaults\nClipboard.pasteActions = defaultPasteActions;\nClipboard.pasteParsers = defaultPasteParsers;\n\nexport default Clipboard;","export default {\n\treplace:function(rows){\n\t\treturn this.table.setData(rows);\n\t},\n\tupdate:function(rows){\n\t\treturn this.table.updateOrAddData(rows);\n\t},\n\tinsert:function(rows){\n\t\treturn this.table.addData(rows);\n\t},\n};","export default {\n\ttable:function(clipboard){\n\t\tvar data = [],\n\t\theaderFindSuccess = true,\n\t\tcolumns = this.table.columnManager.columns,\n\t\tcolumnMap = [],\n\t\trows = [];\n\n\t\t//get data from clipboard into array of columns and rows.\n\t\tclipboard = clipboard.split(\"\\n\");\n\n\t\tclipboard.forEach(function(row){\n\t\t\tdata.push(row.split(\"\\t\"));\n\t\t});\n\n\t\tif(data.length && !(data.length === 1 && data[0].length < 2)){\n\n\t\t\t//check if headers are present by title\n\t\t\tdata[0].forEach(function(value){\n\t\t\t\tvar column = columns.find(function(column){\n\t\t\t\t\treturn value && column.definition.title && value.trim() && column.definition.title.trim() === value.trim();\n\t\t\t\t});\n\n\t\t\t\tif(column){\n\t\t\t\t\tcolumnMap.push(column);\n\t\t\t\t}else{\n\t\t\t\t\theaderFindSuccess = false;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t//check if column headers are present by field\n\t\t\tif(!headerFindSuccess){\n\t\t\t\theaderFindSuccess = true;\n\t\t\t\tcolumnMap = [];\n\n\t\t\t\tdata[0].forEach(function(value){\n\t\t\t\t\tvar column = columns.find(function(column){\n\t\t\t\t\t\treturn value && column.field && value.trim() && column.field.trim() === value.trim();\n\t\t\t\t\t});\n\n\t\t\t\t\tif(column){\n\t\t\t\t\t\tcolumnMap.push(column);\n\t\t\t\t\t}else{\n\t\t\t\t\t\theaderFindSuccess = false;\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tif(!headerFindSuccess){\n\t\t\t\t\tcolumnMap = this.table.columnManager.columnsByIndex;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//remove header row if found\n\t\t\tif(headerFindSuccess){\n\t\t\t\tdata.shift();\n\t\t\t}\n\n\t\t\tdata.forEach(function(item){\n\t\t\t\tvar row = {};\n\n\t\t\t\titem.forEach(function(value, i){\n\t\t\t\t\tif(columnMap[i]){\n\t\t\t\t\t\trow[columnMap[i].field] = value;\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\trows.push(row);\n\t\t\t});\n\n\t\t\treturn rows;\n\t\t}else{\n\t\t\treturn false;\n\t\t}\n\t}\n};","class CalcComponent{\n\tconstructor (row){\n\t\tthis._row = row;\n\n\t\treturn new Proxy(this, {\n\t\t\tget: function(target, name, receiver) {\n\t\t\t\tif (typeof target[name] !== \"undefined\") {\n\t\t\t\t\treturn target[name];\n\t\t\t\t}else{\n\t\t\t\t\treturn target._row.table.componentFunctionBinder.handle(\"row\", target._row, name);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tgetData(transform){\n\t\treturn this._row.getData(transform);\n\t}\n\n\tgetElement(){\n\t\treturn this._row.getElement();\n\t}\n\n\tgetTable(){\n\t\treturn this._row.table;\n\t}\n\n\tgetCells(){\n\t\tvar cells = [];\n\n\t\tthis._row.getCells().forEach(function(cell){\n\t\t\tcells.push(cell.getComponent());\n\t\t});\n\n\t\treturn cells;\n\t}\n\n\tgetCell(column){\n\t\tvar cell = this._row.getCell(column);\n\t\treturn cell ? cell.getComponent() : false;\n\t}\n\n\t_getSelf(){\n\t\treturn this._row;\n\t}\n}\n\nexport default CalcComponent;","//public cell object\nexport default class CellComponent {\n\n\tconstructor (cell){\n\t\tthis._cell = cell;\n\n\t\treturn new Proxy(this, {\n\t\t\tget: function(target, name, receiver) {\n\t\t\t\tif (typeof target[name] !== \"undefined\") {\n\t\t\t\t\treturn target[name];\n\t\t\t\t}else{\n\t\t\t\t\treturn target._cell.table.componentFunctionBinder.handle(\"cell\", target._cell, name);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tgetValue(){\n\t\treturn this._cell.getValue();\n\t}\n\n\tgetOldValue(){\n\t\treturn this._cell.getOldValue();\n\t}\n\n\tgetInitialValue(){\n\t\treturn this._cell.initialValue;\n\t}\n\n\tgetElement(){\n\t\treturn this._cell.getElement();\n\t}\n\n\tgetRow(){\n\t\treturn this._cell.row.getComponent();\n\t}\n\n\tgetData(transform){\n\t\treturn this._cell.row.getData(transform);\n\t}\n\tgetType(){\n\t\treturn \"cell\";\n\t}\n\tgetField(){\n\t\treturn this._cell.column.getField();\n\t}\n\n\tgetColumn(){\n\t\treturn this._cell.column.getComponent();\n\t}\n\n\tsetValue(value, mutate){\n\t\tif(typeof mutate == \"undefined\"){\n\t\t\tmutate = true;\n\t\t}\n\n\t\tthis._cell.setValue(value, mutate);\n\t}\n\n\trestoreOldValue(){\n\t\tthis._cell.setValueActual(this._cell.getOldValue());\n\t}\n\n\trestoreInitialValue(){\n\t\tthis._cell.setValueActual(this._cell.initialValue);\n\t}\n\n\tcheckHeight(){\n\t\tthis._cell.checkHeight();\n\t}\n\n\tgetTable(){\n\t\treturn this._cell.table;\n\t}\n\n\t_getSelf(){\n\t\treturn this._cell;\n\t}\n}","import CoreFeature from '../CoreFeature.js';\nimport CellComponent from './CellComponent.js';\n\nexport default class Cell extends CoreFeature{\n\tconstructor(column, row){\n\t\tsuper(column.table);\n\n\t\tthis.table = column.table;\n\t\tthis.column = column;\n\t\tthis.row = row;\n\t\tthis.element = null;\n\t\tthis.value = null;\n\t\tthis.initialValue;\n\t\tthis.oldValue = null;\n\t\tthis.modules = {};\n\n\t\tthis.height = null;\n\t\tthis.width = null;\n\t\tthis.minWidth = null;\n\n\t\tthis.component = null;\n\n\t\tthis.loaded = false; //track if the cell has been added to the DOM yet\n\n\t\tthis.build();\n\t}\n\n\t//////////////// Setup Functions /////////////////\n\t//generate element\n\tbuild(){\n\t\tthis.generateElement();\n\n\t\tthis.setWidth();\n\n\t\tthis._configureCell();\n\n\t\tthis.setValueActual(this.column.getFieldValue(this.row.data));\n\n\t\tthis.initialValue = this.value;\n\t}\n\n\tgenerateElement(){\n\t\tthis.element = document.createElement('div');\n\t\tthis.element.className = \"tabulator-cell\";\n\t\tthis.element.setAttribute(\"role\", \"gridcell\");\n\t}\n\n\t_configureCell(){\n\t\tvar element = this.element,\n\t\tfield = this.column.getField(),\n\t\tvertAligns = {\n\t\t\ttop:\"flex-start\",\n\t\t\tbottom:\"flex-end\",\n\t\t\tmiddle:\"center\",\n\t\t},\n\t\thozAligns = {\n\t\t\tleft:\"flex-start\",\n\t\t\tright:\"flex-end\",\n\t\t\tcenter:\"center\",\n\t\t};\n\n\t\t//set text alignment\n\t\telement.style.textAlign = this.column.hozAlign;\n\n\t\tif(this.column.vertAlign){\n\t\t\telement.style.display = \"inline-flex\";\n\n\t\t\telement.style.alignItems = vertAligns[this.column.vertAlign] || \"\";\n\n\t\t\tif(this.column.hozAlign){\n\t\t\t\telement.style.justifyContent = hozAligns[this.column.hozAlign] || \"\";\n\t\t\t}\n\t\t}\n\n\t\tif(field){\n\t\t\telement.setAttribute(\"tabulator-field\", field);\n\t\t}\n\n\t\t//add class to cell if needed\n\t\tif(this.column.definition.cssClass){\n\t\t\tvar classNames = this.column.definition.cssClass.split(\" \");\n\t\t\tclassNames.forEach((className) => {\n\t\t\t\telement.classList.add(className);\n\t\t\t});\n\t\t}\n\n\t\tthis.dispatch(\"cell-init\", this);\n\n\t\t//hide cell if not visible\n\t\tif(!this.column.visible){\n\t\t\tthis.hide();\n\t\t}\n\t}\n\n\t//generate cell contents\n\t_generateContents(){\n\t\tvar val;\n\n\t\tval = this.chain(\"cell-format\", this, null, () => {\n\t\t\treturn this.element.innerHTML = this.value;\n\t\t});\n\n\t\tswitch(typeof val){\n\t\t\tcase \"object\":\n\t\t\t\tif(val instanceof Node){\n\n\t\t\t\t\t//clear previous cell contents\n\t\t\t\t\twhile(this.element.firstChild) this.element.removeChild(this.element.firstChild);\n\n\t\t\t\t\tthis.element.appendChild(val);\n\t\t\t\t}else{\n\t\t\t\t\tthis.element.innerHTML = \"\";\n\n\t\t\t\t\tif(val != null){\n\t\t\t\t\t\tconsole.warn(\"Format Error - Formatter has returned a type of object, the only valid formatter object return is an instance of Node, the formatter returned:\", val);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase \"undefined\":\n\t\t\t\tthis.element.innerHTML = \"\";\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tthis.element.innerHTML = val;\n\t\t}\n\t}\n\n\tcellRendered(){\n\t\tthis.dispatch(\"cell-rendered\", this);\n\t}\n\n\t//////////////////// Getters ////////////////////\n\tgetElement(containerOnly){\n\t\tif(!this.loaded){\n\t\t\tthis.loaded = true;\n\t\t\tif(!containerOnly){\n\t\t\t\tthis.layoutElement();\n\t\t\t}\n\t\t}\n\n\t\treturn this.element;\n\t}\n\n\tgetValue(){\n\t\treturn this.value;\n\t}\n\n\tgetOldValue(){\n\t\treturn this.oldValue;\n\t}\n\n\t//////////////////// Actions ////////////////////\n\tsetValue(value, mutate, force){\n\t\tvar changed = this.setValueProcessData(value, mutate, force);\n\n\t\tif(changed){\n\t\t\tthis.dispatch(\"cell-value-updated\", this);\n\n\t\t\tthis.cellRendered();\n\n\t\t\tif(this.column.definition.cellEdited){\n\t\t\t\tthis.column.definition.cellEdited.call(this.table, this.getComponent());\n\t\t\t}\n\n\t\t\tthis.dispatchExternal(\"cellEdited\", this.getComponent());\n\n\t\t\tif(this.subscribedExternal(\"dataChanged\")){\n\t\t\t\tthis.dispatchExternal(\"dataChanged\", this.table.rowManager.getData());\n\t\t\t}\n\t\t}\n\t}\n\n\tsetValueProcessData(value, mutate, force){\n\t\tvar changed = false;\n\n\t\tif(this.value !== value || force){\n\n\t\t\tchanged = true;\n\n\t\t\tif(mutate){\n\t\t\t\tvalue = this.chain(\"cell-value-changing\", [this, value], null, value);\n\t\t\t}\n\t\t}\n\n\t\tthis.setValueActual(value);\n\n\t\tif(changed){\n\t\t\tthis.dispatch(\"cell-value-changed\", this);\n\t\t}\n\n\t\treturn changed;\n\t}\n\n\tsetValueActual(value){\n\t\tthis.oldValue = this.value;\n\n\t\tthis.value = value;\n\n\t\tthis.dispatch(\"cell-value-save-before\", this);\n\n\t\tthis.column.setFieldValue(this.row.data, value);\n\n\t\tthis.dispatch(\"cell-value-save-after\", this);\n\n\t\tif(this.loaded){\n\t\t\tthis.layoutElement();\n\t\t}\n\t}\n\n\tlayoutElement(){\n\t\tthis._generateContents();\n\n\t\tthis.dispatch(\"cell-layout\", this);\n\t}\n\n\tsetWidth(){\n\t\tthis.width = this.column.width;\n\t\tthis.element.style.width = this.column.widthStyled;\n\t}\n\n\tclearWidth(){\n\t\tthis.width = \"\";\n\t\tthis.element.style.width = \"\";\n\t}\n\n\tgetWidth(){\n\t\treturn this.width || this.element.offsetWidth;\n\t}\n\n\tsetMinWidth(){\n\t\tthis.minWidth = this.column.minWidth;\n\t\tthis.element.style.minWidth = this.column.minWidthStyled;\n\t}\n\n\tsetMaxWidth(){\n\t\tthis.maxWidth = this.column.maxWidth;\n\t\tthis.element.style.maxWidth = this.column.maxWidthStyled;\n\t}\n\n\tcheckHeight(){\n\t\t// var height = this.element.css(\"height\");\n\t\tthis.row.reinitializeHeight();\n\t}\n\n\tclearHeight(){\n\t\tthis.element.style.height = \"\";\n\t\tthis.height = null;\n\n\t\tthis.dispatch(\"cell-height\", this, \"\");\n\t}\n\n\tsetHeight(){\n\t\tthis.height = this.row.height;\n\t\tthis.element.style.height = this.row.heightStyled;\n\n\t\tthis.dispatch(\"cell-height\", this, this.row.heightStyled);\n\t}\n\n\tgetHeight(){\n\t\treturn this.height || this.element.offsetHeight;\n\t}\n\n\tshow(){\n\t\tthis.element.style.display = this.column.vertAlign ? \"inline-flex\" : \"\";\n\t}\n\n\thide(){\n\t\tthis.element.style.display = \"none\";\n\t}\n\n\tdelete(){\n\t\tthis.dispatch(\"cell-delete\", this);\n\n\t\tif(!this.table.rowManager.redrawBlock && this.element.parentNode){\n\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t}\n\n\t\tthis.element = false;\n\t\tthis.column.deleteCell(this);\n\t\tthis.row.deleteCell(this);\n\t\tthis.calcs = {};\n\t}\n\n\tgetIndex(){\n\t\treturn this.row.getCellIndex(this);\n\t}\n\n\t//////////////// Object Generation /////////////////\n\tgetComponent(){\n\t\tif(!this.component){\n\t\t\tthis.component = new CellComponent(this);\n\t\t}\n\n\t\treturn this.component;\n\t}\n}\n","import Column from './Column.js';\n\n//public column object\nexport default class ColumnComponent {\n\tconstructor (column){\n\t\tthis._column = column;\n\t\tthis.type = \"ColumnComponent\";\n\n\t\treturn new Proxy(this, {\n\t\t\tget: function(target, name, receiver) {\n\t\t\t\tif (typeof target[name] !== \"undefined\") {\n\t\t\t\t\treturn target[name];\n\t\t\t\t}else{\n\t\t\t\t\treturn target._column.table.componentFunctionBinder.handle(\"column\", target._column, name);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tgetElement(){\n\t\treturn this._column.getElement();\n\t}\n\n\tgetDefinition(){\n\t\treturn this._column.getDefinition();\n\t}\n\n\tgetField(){\n\t\treturn this._column.getField();\n\t}\n\n\tgetTitleDownload() {\n\t\treturn this._column.getTitleDownload();\n\t}\n\n\tgetCells(){\n\t\tvar cells = [];\n\n\t\tthis._column.cells.forEach(function(cell){\n\t\t\tcells.push(cell.getComponent());\n\t\t});\n\n\t\treturn cells;\n\t}\n\n\tisVisible(){\n\t\treturn this._column.visible;\n\t}\n\n\tshow(){\n\t\tif(this._column.isGroup){\n\t\t\tthis._column.columns.forEach(function(column){\n\t\t\t\tcolumn.show();\n\t\t\t});\n\t\t}else{\n\t\t\tthis._column.show();\n\t\t}\n\t}\n\n\thide(){\n\t\tif(this._column.isGroup){\n\t\t\tthis._column.columns.forEach(function(column){\n\t\t\t\tcolumn.hide();\n\t\t\t});\n\t\t}else{\n\t\t\tthis._column.hide();\n\t\t}\n\t}\n\n\ttoggle(){\n\t\tif(this._column.visible){\n\t\t\tthis.hide();\n\t\t}else{\n\t\t\tthis.show();\n\t\t}\n\t}\n\n\tdelete(){\n\t\treturn this._column.delete();\n\t}\n\n\tgetSubColumns(){\n\t\tvar output = [];\n\n\t\tif(this._column.columns.length){\n\t\t\tthis._column.columns.forEach(function(column){\n\t\t\t\toutput.push(column.getComponent());\n\t\t\t});\n\t\t}\n\n\t\treturn output;\n\t}\n\n\tgetParentColumn(){\n\t\treturn this._column.parent instanceof Column ? this._column.parent.getComponent() : false;\n\t}\n\n\t_getSelf(){\n\t\treturn this._column;\n\t}\n\n\tscrollTo(position, ifVisible){\n\t\treturn this._column.table.columnManager.scrollToColumn(this._column, position, ifVisible);\n\t}\n\n\tgetTable(){\n\t\treturn this._column.table;\n\t}\n\n\tmove(to, after){\n\t\tvar toColumn = this._column.table.columnManager.findColumn(to);\n\n\t\tif(toColumn){\n\t\t\tthis._column.table.columnManager.moveColumn(this._column, toColumn, after);\n\t\t}else{\n\t\t\tconsole.warn(\"Move Error - No matching column found:\", toColumn);\n\t\t}\n\t}\n\n\tgetNextColumn(){\n\t\tvar nextCol = this._column.nextColumn();\n\n\t\treturn nextCol ? nextCol.getComponent() : false;\n\t}\n\n\tgetPrevColumn(){\n\t\tvar prevCol = this._column.prevColumn();\n\n\t\treturn prevCol ? prevCol.getComponent() : false;\n\t}\n\n\tupdateDefinition(updates){\n\t\treturn this._column.updateDefinition(updates);\n\t}\n\n\tgetWidth(){\n\t\treturn this._column.getWidth();\n\t}\n\n\tsetWidth(width){\n\t\tvar result;\n\n\t\tif(width === true){\n\t\t\tresult = this._column.reinitializeWidth(true);\n\t\t}else{\n\t\t\tresult = this._column.setWidth(width);\n\t\t}\n\n\t\tthis._column.table.columnManager.rerenderColumns(true);\n\n\t\treturn result;\n\t}\n}","export default {\n\t\"title\": undefined,\n\t\"field\": undefined,\n\t\"columns\": undefined,\n\t\"visible\": undefined,\n\t\"hozAlign\": undefined,\n\t\"vertAlign\": undefined,\n\t\"width\": undefined,\n\t\"minWidth\": 40,\n\t\"maxWidth\": undefined,\n\t\"maxInitialWidth\": undefined,\n\t\"cssClass\": undefined,\n\t\"variableHeight\": undefined,\n\t\"headerVertical\": undefined,\n\t\"headerHozAlign\": undefined,\n\t\"headerWordWrap\": false,\n\t\"editableTitle\": undefined,\n};","import CoreFeature from '../CoreFeature.js';\nimport ColumnComponent from './ColumnComponent.js';\nimport defaultOptions from './defaults/options.js';\n\nimport Cell from '../cell/Cell.js';\n\nclass Column extends CoreFeature{\n\n\tconstructor(def, parent){\n\t\tsuper(parent.table);\n\n\t\tthis.definition = def; //column definition\n\t\tthis.parent = parent; //hold parent object\n\t\tthis.type = \"column\"; //type of element\n\t\tthis.columns = []; //child columns\n\t\tthis.cells = []; //cells bound to this column\n\t\tthis.element = this.createElement(); //column header element\n\t\tthis.contentElement = false;\n\t\tthis.titleHolderElement = false;\n\t\tthis.titleElement = false;\n\t\tthis.groupElement = this.createGroupElement(); //column group holder element\n\t\tthis.isGroup = false;\n\t\tthis.hozAlign = \"\"; //horizontal text alignment\n\t\tthis.vertAlign = \"\"; //vert text alignment\n\n\t\t//multi dimensional filed handling\n\t\tthis.field =\"\";\n\t\tthis.fieldStructure = \"\";\n\t\tthis.getFieldValue = \"\";\n\t\tthis.setFieldValue = \"\";\n\n\t\tthis.titleDownload = null;\n\t\tthis.titleFormatterRendered = false;\n\n\t\tthis.mapDefinitions();\n\n\t\tthis.setField(this.definition.field);\n\n\t\tthis.modules = {}; //hold module variables;\n\n\t\tthis.width = null; //column width\n\t\tthis.widthStyled = \"\"; //column width pre-styled to improve render efficiency\n\t\tthis.maxWidth = null; //column maximum width\n\t\tthis.maxWidthStyled = \"\"; //column maximum pre-styled to improve render efficiency\n\t\tthis.maxInitialWidth = null;\n\t\tthis.minWidth = null; //column minimum width\n\t\tthis.minWidthStyled = \"\"; //column minimum pre-styled to improve render efficiency\n\t\tthis.widthFixed = false; //user has specified a width for this column\n\n\t\tthis.visible = true; //default visible state\n\n\t\tthis.component = null;\n\n\t\t//initialize column\n\t\tif(this.definition.columns){\n\n\t\t\tthis.isGroup = true;\n\n\t\t\tthis.definition.columns.forEach((def, i) => {\n\t\t\t\tvar newCol = new Column(def, this);\n\t\t\t\tthis.attachColumn(newCol);\n\t\t\t});\n\n\t\t\tthis.checkColumnVisibility();\n\t\t}else{\n\t\t\tparent.registerColumnField(this);\n\t\t}\n\n\t\tthis._initialize();\n\t}\n\n\tcreateElement (){\n\t\tvar el = document.createElement(\"div\");\n\n\t\tel.classList.add(\"tabulator-col\");\n\t\tel.setAttribute(\"role\", \"columnheader\");\n\t\tel.setAttribute(\"aria-sort\", \"none\");\n\n\t\tswitch(this.table.options.columnHeaderVertAlign){\n\t\t\tcase \"middle\":\n\t\t\t\tel.style.justifyContent = \"center\";\n\t\t\t\tbreak;\n\t\t\tcase \"bottom\":\n\t\t\t\tel.style.justifyContent = \"flex-end\";\n\t\t\t\tbreak;\n\t\t}\n\n\t\treturn el;\n\t}\n\n\tcreateGroupElement (){\n\t\tvar el = document.createElement(\"div\");\n\n\t\tel.classList.add(\"tabulator-col-group-cols\");\n\n\t\treturn el;\n\t}\n\n\tmapDefinitions(){\n\t\tvar defaults = this.table.options.columnDefaults;\n\n\t\t//map columnDefaults onto column definitions\n\t\tif(defaults){\n\t\t\tfor(let key in defaults){\n\t\t\t\tif(typeof this.definition[key] === \"undefined\"){\n\t\t\t\t\tthis.definition[key] = defaults[key];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.definition = this.table.columnManager.optionsList.generate(Column.defaultOptionList, this.definition);\n\t}\n\n\tcheckDefinition(){\n\t\tObject.keys(this.definition).forEach((key) => {\n\t\t\tif(Column.defaultOptionList.indexOf(key) === -1){\n\t\t\t\tconsole.warn(\"Invalid column definition option in '\" + (this.field || this.definition.title) + \"' column:\", key);\n\t\t\t}\n\t\t});\n\t}\n\n\tsetField(field){\n\t\tthis.field = field;\n\t\tthis.fieldStructure = field ? (this.table.options.nestedFieldSeparator ? field.split(this.table.options.nestedFieldSeparator) : [field]) : [];\n\t\tthis.getFieldValue = this.fieldStructure.length > 1 ? this._getNestedData : this._getFlatData;\n\t\tthis.setFieldValue = this.fieldStructure.length > 1 ? this._setNestedData : this._setFlatData;\n\t}\n\n\t//register column position with column manager\n\tregisterColumnPosition(column){\n\t\tthis.parent.registerColumnPosition(column);\n\t}\n\n\t//register column position with column manager\n\tregisterColumnField(column){\n\t\tthis.parent.registerColumnField(column);\n\t}\n\n\t//trigger position registration\n\treRegisterPosition(){\n\t\tif(this.isGroup){\n\t\t\tthis.columns.forEach(function(column){\n\t\t\t\tcolumn.reRegisterPosition();\n\t\t\t});\n\t\t}else{\n\t\t\tthis.registerColumnPosition(this);\n\t\t}\n\t}\n\n\t//build header element\n\t_initialize(){\n\t\tvar def = this.definition;\n\n\t\twhile(this.element.firstChild) this.element.removeChild(this.element.firstChild);\n\n\t\tif(def.headerVertical){\n\t\t\tthis.element.classList.add(\"tabulator-col-vertical\");\n\n\t\t\tif(def.headerVertical === \"flip\"){\n\t\t\t\tthis.element.classList.add(\"tabulator-col-vertical-flip\");\n\t\t\t}\n\t\t}\n\n\t\tthis.contentElement = this._buildColumnHeaderContent();\n\n\t\tthis.element.appendChild(this.contentElement);\n\n\t\tif(this.isGroup){\n\t\t\tthis._buildGroupHeader();\n\t\t}else{\n\t\t\tthis._buildColumnHeader();\n\t\t}\n\n\t\tthis.dispatch(\"column-init\", this);\n\t}\n\n\t//build header element for header\n\t_buildColumnHeader(){\n\t\tvar def = this.definition;\n\n\t\tthis.dispatch(\"column-layout\", this);\n\n\t\t//set column visibility\n\t\tif(typeof def.visible != \"undefined\"){\n\t\t\tif(def.visible){\n\t\t\t\tthis.show(true);\n\t\t\t}else{\n\t\t\t\tthis.hide(true);\n\t\t\t}\n\t\t}\n\n\t\t//assign additional css classes to column header\n\t\tif(def.cssClass){\n\t\t\tvar classNames = def.cssClass.split(\" \");\n\t\t\tclassNames.forEach((className) => {\n\t\t\t\tthis.element.classList.add(className);\n\t\t\t});\n\t\t}\n\n\t\tif(def.field){\n\t\t\tthis.element.setAttribute(\"tabulator-field\", def.field);\n\t\t}\n\n\t\t//set min width if present\n\t\tthis.setMinWidth(parseInt(def.minWidth));\n\n\t\tif (def.maxInitialWidth) {\n\t\t\tthis.maxInitialWidth = parseInt(def.maxInitialWidth);\n\t\t}\n\t\t\n\t\tif(def.maxWidth){\n\t\t\tthis.setMaxWidth(parseInt(def.maxWidth));\n\t\t}\n\n\t\tthis.reinitializeWidth();\n\n\t\t//set horizontal text alignment\n\t\tthis.hozAlign = this.definition.hozAlign;\n\t\tthis.vertAlign = this.definition.vertAlign;\n\n\t\tthis.titleElement.style.textAlign = this.definition.headerHozAlign;\n\t}\n\n\t_buildColumnHeaderContent(){\n\t\tvar contentElement = document.createElement(\"div\");\n\t\tcontentElement.classList.add(\"tabulator-col-content\");\n\n\t\tthis.titleHolderElement = document.createElement(\"div\");\n\t\tthis.titleHolderElement.classList.add(\"tabulator-col-title-holder\");\n\n\t\tcontentElement.appendChild(this.titleHolderElement);\n\n\t\tthis.titleElement = this._buildColumnHeaderTitle();\n\n\t\tthis.titleHolderElement.appendChild(this.titleElement);\n\n\t\treturn contentElement;\n\t}\n\n\t//build title element of column\n\t_buildColumnHeaderTitle(){\n\t\tvar def = this.definition;\n\n\t\tvar titleHolderElement = document.createElement(\"div\");\n\t\ttitleHolderElement.classList.add(\"tabulator-col-title\");\n\t\t\n\t\tif(def.headerWordWrap){\n\t\t\ttitleHolderElement.classList.add(\"tabulator-col-title-wrap\");\n\t\t}\n\n\t\tif(def.editableTitle){\n\t\t\tvar titleElement = document.createElement(\"input\");\n\t\t\ttitleElement.classList.add(\"tabulator-title-editor\");\n\n\t\t\ttitleElement.addEventListener(\"click\", (e) => {\n\t\t\t\te.stopPropagation();\n\t\t\t\ttitleElement.focus();\n\t\t\t});\n\n\t\t\ttitleElement.addEventListener(\"change\", () => {\n\t\t\t\tdef.title = titleElement.value;\n\t\t\t\tthis.dispatchExternal(\"columnTitleChanged\", this.getComponent());\n\t\t\t});\n\n\t\t\ttitleHolderElement.appendChild(titleElement);\n\n\t\t\tif(def.field){\n\t\t\t\tthis.langBind(\"columns|\" + def.field, (text) => {\n\t\t\t\t\ttitleElement.value = text || (def.title || \" \");\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\ttitleElement.value = def.title || \" \";\n\t\t\t}\n\n\t\t}else{\n\t\t\tif(def.field){\n\t\t\t\tthis.langBind(\"columns|\" + def.field, (text) => {\n\t\t\t\t\tthis._formatColumnHeaderTitle(titleHolderElement, text || (def.title || \" \"));\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tthis._formatColumnHeaderTitle(titleHolderElement, def.title || \" \");\n\t\t\t}\n\t\t}\n\n\t\treturn titleHolderElement;\n\t}\n\n\t_formatColumnHeaderTitle(el, title){\n\t\tvar contents = this.chain(\"column-format\", [this, title, el], null, () => {\n\t\t\treturn title;\n\t\t});\n\n\t\tswitch(typeof contents){\n\t\t\tcase \"object\":\n\t\t\t\tif(contents instanceof Node){\n\t\t\t\t\tel.appendChild(contents);\n\t\t\t\t}else{\n\t\t\t\t\tel.innerHTML = \"\";\n\t\t\t\t\tconsole.warn(\"Format Error - Title formatter has returned a type of object, the only valid formatter object return is an instance of Node, the formatter returned:\", contents);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase \"undefined\":\n\t\t\t\tel.innerHTML = \"\";\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tel.innerHTML = contents;\n\t\t}\n\t}\n\n\t//build header element for column group\n\t_buildGroupHeader(){\n\t\tthis.element.classList.add(\"tabulator-col-group\");\n\t\tthis.element.setAttribute(\"role\", \"columngroup\");\n\t\tthis.element.setAttribute(\"aria-title\", this.definition.title);\n\n\t\t//asign additional css classes to column header\n\t\tif(this.definition.cssClass){\n\t\t\tvar classNames = this.definition.cssClass.split(\" \");\n\t\t\tclassNames.forEach((className) => {\n\t\t\t\tthis.element.classList.add(className);\n\t\t\t});\n\t\t}\n\n\t\tthis.titleElement.style.textAlign = this.definition.headerHozAlign;\n\n\t\tthis.element.appendChild(this.groupElement);\n\t}\n\n\t//flat field lookup\n\t_getFlatData(data){\n\t\treturn data[this.field];\n\t}\n\n\t//nested field lookup\n\t_getNestedData(data){\n\t\tvar dataObj = data,\n\t\tstructure = this.fieldStructure,\n\t\tlength = structure.length,\n\t\toutput;\n\n\t\tfor(let i = 0; i < length; i++){\n\n\t\t\tdataObj = dataObj[structure[i]];\n\n\t\t\toutput = dataObj;\n\n\t\t\tif(!dataObj){\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn output;\n\t}\n\n\t//flat field set\n\t_setFlatData(data, value){\n\t\tif(this.field){\n\t\t\tdata[this.field] = value;\n\t\t}\n\t}\n\n\t//nested field set\n\t_setNestedData(data, value){\n\t\tvar dataObj = data,\n\t\tstructure = this.fieldStructure,\n\t\tlength = structure.length;\n\n\t\tfor(let i = 0; i < length; i++){\n\n\t\t\tif(i == length -1){\n\t\t\t\tdataObj[structure[i]] = value;\n\t\t\t}else{\n\t\t\t\tif(!dataObj[structure[i]]){\n\t\t\t\t\tif(typeof value !== \"undefined\"){\n\t\t\t\t\t\tdataObj[structure[i]] = {};\n\t\t\t\t\t}else{\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tdataObj = dataObj[structure[i]];\n\t\t\t}\n\t\t}\n\t}\n\n\t//attach column to this group\n\tattachColumn(column){\n\t\tif(this.groupElement){\n\t\t\tthis.columns.push(column);\n\t\t\tthis.groupElement.appendChild(column.getElement());\n\n\t\t\tcolumn.columnRendered();\n\t\t}else{\n\t\t\tconsole.warn(\"Column Warning - Column being attached to another column instead of column group\");\n\t\t}\n\t}\n\n\t//vertically align header in column\n\tverticalAlign(alignment, height){\n\n\t\t//calculate height of column header and group holder element\n\t\tvar parentHeight = this.parent.isGroup ? this.parent.getGroupElement().clientHeight : (height || this.parent.getHeadersElement().clientHeight);\n\t\t// var parentHeight = this.parent.isGroup ? this.parent.getGroupElement().clientHeight : this.parent.getHeadersElement().clientHeight;\n\n\t\tthis.element.style.height = parentHeight + \"px\";\n\n\t\tthis.dispatch(\"column-height\", this, this.element.style.height);\n\n\t\tif(this.isGroup){\n\t\t\tthis.groupElement.style.minHeight = (parentHeight - this.contentElement.offsetHeight) + \"px\";\n\t\t}\n\n\t\t//vertically align cell contents\n\t\t// if(!this.isGroup && alignment !== \"top\"){\n\t\t// \tif(alignment === \"bottom\"){\n\t\t// \t\tthis.element.style.paddingTop = (this.element.clientHeight - this.contentElement.offsetHeight) + \"px\";\n\t\t// \t}else{\n\t\t// \t\tthis.element.style.paddingTop = ((this.element.clientHeight - this.contentElement.offsetHeight) / 2) + \"px\";\n\t\t// \t}\n\t\t// }\n\n\t\tthis.columns.forEach(function(column){\n\t\t\tcolumn.verticalAlign(alignment);\n\t\t});\n\t}\n\n\t//clear vertical alignment\n\tclearVerticalAlign(){\n\t\tthis.element.style.paddingTop = \"\";\n\t\tthis.element.style.height = \"\";\n\t\tthis.element.style.minHeight = \"\";\n\t\tthis.groupElement.style.minHeight = \"\";\n\n\t\tthis.columns.forEach(function(column){\n\t\t\tcolumn.clearVerticalAlign();\n\t\t});\n\n\t\tthis.dispatch(\"column-height\", this, \"\");\n\t}\n\n\t//// Retrieve Column Information ////\n\t//return column header element\n\tgetElement(){\n\t\treturn this.element;\n\t}\n\n\t//return column group element\n\tgetGroupElement(){\n\t\treturn this.groupElement;\n\t}\n\n\t//return field name\n\tgetField(){\n\t\treturn this.field;\n\t}\n\n\tgetTitleDownload() {\n\t\treturn this.titleDownload;\n\t}\n\n\t//return the first column in a group\n\tgetFirstColumn(){\n\t\tif(!this.isGroup){\n\t\t\treturn this;\n\t\t}else{\n\t\t\tif(this.columns.length){\n\t\t\t\treturn this.columns[0].getFirstColumn();\n\t\t\t}else{\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t}\n\n\t//return the last column in a group\n\tgetLastColumn(){\n\t\tif(!this.isGroup){\n\t\t\treturn this;\n\t\t}else{\n\t\t\tif(this.columns.length){\n\t\t\t\treturn this.columns[this.columns.length -1].getLastColumn();\n\t\t\t}else{\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t}\n\n\t//return all columns in a group\n\tgetColumns(traverse){\n\t\tvar columns = [];\n\n\t\tif(traverse){\n\t\t\tthis.columns.forEach((column) => {\n\t\t\t\tcolumns.push(column);\n\t\t\t\t\t\n\t\t\t\tcolumns = columns.concat(column.getColumns(true));\n\t\t\t});\n\t\t}else{\n\t\t\tcolumns = this.columns;\n\t\t}\n\t\t\n\t\treturn columns;\n\t}\n\n\t//return all columns in a group\n\tgetCells(){\n\t\treturn this.cells;\n\t}\n\n\t//retrieve the top column in a group of columns\n\tgetTopColumn(){\n\t\tif(this.parent.isGroup){\n\t\t\treturn this.parent.getTopColumn();\n\t\t}else{\n\t\t\treturn this;\n\t\t}\n\t}\n\n\t//return column definition object\n\tgetDefinition(updateBranches){\n\t\tvar colDefs = [];\n\n\t\tif(this.isGroup && updateBranches){\n\t\t\tthis.columns.forEach(function(column){\n\t\t\t\tcolDefs.push(column.getDefinition(true));\n\t\t\t});\n\n\t\t\tthis.definition.columns = colDefs;\n\t\t}\n\n\t\treturn this.definition;\n\t}\n\n\t//////////////////// Actions ////////////////////\n\tcheckColumnVisibility(){\n\t\tvar visible = false;\n\n\t\tthis.columns.forEach(function(column){\n\t\t\tif(column.visible){\n\t\t\t\tvisible = true;\n\t\t\t}\n\t\t});\n\n\t\tif(visible){\n\t\t\tthis.show();\n\t\t\tthis.dispatchExternal(\"columnVisibilityChanged\", this.getComponent(), false);\n\t\t}else{\n\t\t\tthis.hide();\n\t\t}\n\t}\n\n\t//show column\n\tshow(silent, responsiveToggle){\n\t\tif(!this.visible){\n\t\t\tthis.visible = true;\n\n\t\t\tthis.element.style.display = \"\";\n\n\t\t\tif(this.parent.isGroup){\n\t\t\t\tthis.parent.checkColumnVisibility();\n\t\t\t}\n\n\t\t\tthis.cells.forEach(function(cell){\n\t\t\t\tcell.show();\n\t\t\t});\n\n\t\t\tif(!this.isGroup && this.width === null){\n\t\t\t\tthis.reinitializeWidth();\n\t\t\t}\n\n\t\t\tthis.table.columnManager.verticalAlignHeaders();\n\n\t\t\tthis.dispatch(\"column-show\", this, responsiveToggle);\n\n\t\t\tif(!silent){\n\t\t\t\tthis.dispatchExternal(\"columnVisibilityChanged\", this.getComponent(), true);\n\t\t\t}\n\n\t\t\tif(this.parent.isGroup){\n\t\t\t\tthis.parent.matchChildWidths();\n\t\t\t}\n\n\t\t\tif(!this.silent){\n\t\t\t\tthis.table.columnManager.rerenderColumns();\n\t\t\t}\n\t\t}\n\t}\n\n\t//hide column\n\thide(silent, responsiveToggle){\n\t\tif(this.visible){\n\t\t\tthis.visible = false;\n\n\t\t\tthis.element.style.display = \"none\";\n\n\t\t\tthis.table.columnManager.verticalAlignHeaders();\n\n\t\t\tif(this.parent.isGroup){\n\t\t\t\tthis.parent.checkColumnVisibility();\n\t\t\t}\n\n\t\t\tthis.cells.forEach(function(cell){\n\t\t\t\tcell.hide();\n\t\t\t});\n\n\t\t\tthis.dispatch(\"column-hide\", this, responsiveToggle);\n\n\t\t\tif(!silent){\n\t\t\t\tthis.dispatchExternal(\"columnVisibilityChanged\", this.getComponent(), false);\n\t\t\t}\n\n\t\t\tif(this.parent.isGroup){\n\t\t\t\tthis.parent.matchChildWidths();\n\t\t\t}\n\n\t\t\tif(!this.silent){\n\t\t\t\tthis.table.columnManager.rerenderColumns();\n\t\t\t}\n\t\t}\n\t}\n\n\tmatchChildWidths(){\n\t\tvar childWidth = 0;\n\n\t\tif(this.contentElement && this.columns.length){\n\t\t\tthis.columns.forEach(function(column){\n\t\t\t\tif(column.visible){\n\t\t\t\t\tchildWidth += column.getWidth();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.contentElement.style.maxWidth = (childWidth - 1) + \"px\";\n\n\t\t\tif(this.parent.isGroup){\n\t\t\t\tthis.parent.matchChildWidths();\n\t\t\t}\n\t\t}\n\t}\n\n\tremoveChild(child){\n\t\tvar index = this.columns.indexOf(child);\n\n\t\tif(index > -1){\n\t\t\tthis.columns.splice(index, 1);\n\t\t}\n\n\t\tif(!this.columns.length){\n\t\t\tthis.delete();\n\t\t}\n\t}\n\n\tsetWidth(width){\n\t\tthis.widthFixed = true;\n\t\tthis.setWidthActual(width);\n\t}\n\n\tsetWidthActual(width){\n\t\tif(isNaN(width)){\n\t\t\twidth = Math.floor((this.table.element.clientWidth/100) * parseInt(width));\n\t\t}\n\n\t\twidth = Math.max(this.minWidth, width);\n\n\t\tif(this.maxWidth){\n\t\t\twidth = Math.min(this.maxWidth, width);\n\t\t}\n\n\t\tthis.width = width;\n\t\tthis.widthStyled = width ? width + \"px\" : \"\";\n\n\t\tthis.element.style.width = this.widthStyled;\n\n\t\tif(!this.isGroup){\n\t\t\tthis.cells.forEach(function(cell){\n\t\t\t\tcell.setWidth();\n\t\t\t});\n\t\t}\n\n\t\tif(this.parent.isGroup){\n\t\t\tthis.parent.matchChildWidths();\n\t\t}\n\n\t\tthis.dispatch(\"column-width\", this);\n\t}\n\n\tcheckCellHeights(){\n\t\tvar rows = [];\n\n\t\tthis.cells.forEach(function(cell){\n\t\t\tif(cell.row.heightInitialized){\n\t\t\t\tif(cell.row.getElement().offsetParent !== null){\n\t\t\t\t\trows.push(cell.row);\n\t\t\t\t\tcell.row.clearCellHeight();\n\t\t\t\t}else{\n\t\t\t\t\tcell.row.heightInitialized = false;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\trows.forEach(function(row){\n\t\t\trow.calcHeight();\n\t\t});\n\n\t\trows.forEach(function(row){\n\t\t\trow.setCellHeight();\n\t\t});\n\t}\n\n\tgetWidth(){\n\t\tvar width = 0;\n\n\t\tif(this.isGroup){\n\t\t\tthis.columns.forEach(function(column){\n\t\t\t\tif(column.visible){\n\t\t\t\t\twidth += column.getWidth();\n\t\t\t\t}\n\t\t\t});\n\t\t}else{\n\t\t\twidth = this.width;\n\t\t}\n\n\t\treturn width;\n\t}\n\n\tgetLeftOffset(){\n\t\tvar offset = this.element.offsetLeft;\n\n\t\tif(this.parent.isGroup){\n\t\t\toffset += this.parent.getLeftOffset();\n\t\t}\n\n\t\treturn offset;\n\t}\n\n\tgetHeight(){\n\t\treturn Math.ceil(this.element.getBoundingClientRect().height);\n\t}\n\n\tsetMinWidth(minWidth){\n\t\tif(this.maxWidth && minWidth > this.maxWidth){\n\t\t\tminWidth = this.maxWidth;\n\n\t\t\tconsole.warn(\"the minWidth (\"+ minWidth + \"px) for column '\" + this.field + \"' cannot be bigger that its maxWidth (\"+ this.maxWidthStyled + \")\");\n\t\t}\n\n\t\tthis.minWidth = minWidth;\n\t\tthis.minWidthStyled = minWidth ? minWidth + \"px\" : \"\";\n\n\t\tthis.element.style.minWidth = this.minWidthStyled;\n\n\t\tthis.cells.forEach(function(cell){\n\t\t\tcell.setMinWidth();\n\t\t});\n\t}\n\n\tsetMaxWidth(maxWidth){\n\t\tif(this.minWidth && maxWidth < this.minWidth){\n\t\t\tmaxWidth = this.minWidth;\n\n\t\t\tconsole.warn(\"the maxWidth (\"+ maxWidth + \"px) for column '\" + this.field + \"' cannot be smaller that its minWidth (\"+ this.minWidthStyled + \")\");\n\t\t}\n\n\t\tthis.maxWidth = maxWidth;\n\t\tthis.maxWidthStyled = maxWidth ? maxWidth + \"px\" : \"\";\n\n\t\tthis.element.style.maxWidth = this.maxWidthStyled;\n\n\t\tthis.cells.forEach(function(cell){\n\t\t\tcell.setMaxWidth();\n\t\t});\n\t}\n\n\tdelete(){\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif(this.isGroup){\n\t\t\t\tthis.columns.forEach(function(column){\n\t\t\t\t\tcolumn.delete();\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tthis.dispatch(\"column-delete\", this);\n\n\t\t\tvar cellCount = this.cells.length;\n\n\t\t\tfor(let i = 0; i < cellCount; i++){\n\t\t\t\tthis.cells[0].delete();\n\t\t\t}\n\n\t\t\tif(this.element.parentNode){\n\t\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t\t}\n\n\t\t\tthis.element = false;\n\t\t\tthis.contentElement = false;\n\t\t\tthis.titleElement = false;\n\t\t\tthis.groupElement = false;\n\n\t\t\tif(this.parent.isGroup){\n\t\t\t\tthis.parent.removeChild(this);\n\t\t\t}\n\n\t\t\tthis.table.columnManager.deregisterColumn(this);\n\n\t\t\tthis.table.columnManager.rerenderColumns(true);\n\n\t\t\tresolve();\n\t\t});\n\t}\n\n\tcolumnRendered(){\n\t\tif(this.titleFormatterRendered){\n\t\t\tthis.titleFormatterRendered();\n\t\t}\n\n\t\tthis.dispatch(\"column-rendered\", this);\n\t}\n\n\t//////////////// Cell Management /////////////////\n\t//generate cell for this column\n\tgenerateCell(row){\n\t\tvar cell = new Cell(this, row);\n\n\t\tthis.cells.push(cell);\n\n\t\treturn cell;\n\t}\n\n\tnextColumn(){\n\t\tvar index = this.table.columnManager.findColumnIndex(this);\n\t\treturn index > -1 ? this._nextVisibleColumn(index + 1) : false;\n\t}\n\n\t_nextVisibleColumn(index){\n\t\tvar column = this.table.columnManager.getColumnByIndex(index);\n\t\treturn !column || column.visible ? column : this._nextVisibleColumn(index + 1);\n\t}\n\n\tprevColumn(){\n\t\tvar index = this.table.columnManager.findColumnIndex(this);\n\t\treturn index > -1 ? this._prevVisibleColumn(index - 1) : false;\n\t}\n\n\t_prevVisibleColumn(index){\n\t\tvar column = this.table.columnManager.getColumnByIndex(index);\n\t\treturn !column || column.visible ? column : this._prevVisibleColumn(index - 1);\n\t}\n\n\treinitializeWidth(force){\n\t\tthis.widthFixed = false;\n\n\t\t//set width if present\n\t\tif(typeof this.definition.width !== \"undefined\" && !force){\n\t\t\t// maxInitialWidth ignored here as width specified\n\t\t\tthis.setWidth(this.definition.width);\n\t\t}\n\n\t\tthis.dispatch(\"column-width-fit-before\", this);\n\n\t\tthis.fitToData(force);\n\n\t\tthis.dispatch(\"column-width-fit-after\", this);\n\t}\n\n\t//set column width to maximum cell width for non group columns\n\tfitToData(force){\n\t\tif(this.isGroup){\n\t\t\treturn;\n\t\t}\n\n\t\tif(!this.widthFixed){\n\t\t\tthis.element.style.width = \"\";\n\n\t\t\tthis.cells.forEach((cell) => {\n\t\t\t\tcell.clearWidth();\n\t\t\t});\n\t\t}\n\n\t\tvar maxWidth = this.element.offsetWidth;\n\n\t\tif(!this.width || !this.widthFixed){\n\t\t\tthis.cells.forEach((cell) => {\n\t\t\t\tvar width = cell.getWidth();\n\n\t\t\t\tif(width > maxWidth){\n\t\t\t\t\tmaxWidth = width;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tif(maxWidth){\n\t\t\t\tvar setTo = maxWidth + 1;\n\t\t\t\tif (this.maxInitialWidth && !force) {\n\t\t\t\t\tsetTo = Math.min(setTo, this.maxInitialWidth);\n\t\t\t\t}\n\t\t\t\tthis.setWidthActual(setTo);\n\t\t\t}\n\t\t}\n\t}\n\n\tupdateDefinition(updates){\n\t\tvar definition;\n\n\t\tif(!this.isGroup){\n\t\t\tif(!this.parent.isGroup){\n\t\t\t\tdefinition = Object.assign({}, this.getDefinition());\n\t\t\t\tdefinition = Object.assign(definition, updates);\n\n\t\t\t\treturn this.table.columnManager.addColumn(definition, false, this)\n\t\t\t\t\t.then((column) => {\n\n\t\t\t\t\t\tif(definition.field == this.field){\n\t\t\t\t\t\t\tthis.field = false; //clear field name to prevent deletion of duplicate column from arrays\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\treturn this.delete()\n\t\t\t\t\t\t\t.then(() => {\n\t\t\t\t\t\t\t\treturn column.getComponent();\n\t\t\t\t\t\t\t});\n\n\t\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tconsole.error(\"Column Update Error - The updateDefinition function is only available on ungrouped columns\");\n\t\t\t\treturn Promise.reject(\"Column Update Error - The updateDefinition function is only available on columns, not column groups\");\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.error(\"Column Update Error - The updateDefinition function is only available on ungrouped columns\");\n\t\t\treturn Promise.reject(\"Column Update Error - The updateDefinition function is only available on columns, not column groups\");\n\t\t}\n\t}\n\n\tdeleteCell(cell){\n\t\tvar index = this.cells.indexOf(cell);\n\n\t\tif(index > -1){\n\t\t\tthis.cells.splice(index, 1);\n\t\t}\n\t}\n\n\t//////////////// Object Generation /////////////////\n\tgetComponent(){\n\t\tif(!this.component){\n\t\t\tthis.component = new ColumnComponent(this);\n\t\t}\n\n\t\treturn this.component;\n\t}\n}\n\nColumn.defaultOptionList = defaultOptions;\n\nexport default Column;\n","//public row object\nexport default class RowComponent {\n\n\tconstructor (row){\n\t\tthis._row = row;\n\n\t\treturn new Proxy(this, {\n\t\t\tget: function(target, name, receiver) {\n\t\t\t\tif (typeof target[name] !== \"undefined\") {\n\t\t\t\t\treturn target[name];\n\t\t\t\t}else{\n\t\t\t\t\treturn target._row.table.componentFunctionBinder.handle(\"row\", target._row, name);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tgetData(transform){\n\t\treturn this._row.getData(transform);\n\t}\n\n\tgetElement(){\n\t\treturn this._row.getElement();\n\t}\n\n\tgetCells(){\n\t\tvar cells = [];\n\n\t\tthis._row.getCells().forEach(function(cell){\n\t\t\tcells.push(cell.getComponent());\n\t\t});\n\n\t\treturn cells;\n\t}\n\n\tgetCell(column){\n\t\tvar cell = this._row.getCell(column);\n\t\treturn cell ? cell.getComponent() : false;\n\t}\n\n\tgetIndex(){\n\t\treturn this._row.getData(\"data\")[this._row.table.options.index];\n\t}\n\n\tgetPosition(){\n\t\treturn this._row.getPosition();\n\t}\n\n\twatchPosition(callback){\n\t\treturn this._row.watchPosition(callback);\n\t}\n\n\tdelete(){\n\t\treturn this._row.delete();\n\t}\n\n\tscrollTo(position, ifVisible){\n\t\treturn this._row.table.rowManager.scrollToRow(this._row, position, ifVisible);\n\t}\n\n\tmove(to, after){\n\t\tthis._row.moveToRow(to, after);\n\t}\n\n\tupdate(data){\n\t\treturn this._row.updateData(data);\n\t}\n\n\tnormalizeHeight(){\n\t\tthis._row.normalizeHeight(true);\n\t}\n\n\t_getSelf(){\n\t\treturn this._row;\n\t}\n\n\treformat(){\n\t\treturn this._row.reinitialize();\n\t}\n\n\tgetTable(){\n\t\treturn this._row.table;\n\t}\n\n\tgetNextRow(){\n\t\tvar row = this._row.nextRow();\n\t\treturn row ? row.getComponent() : row;\n\t}\n\n\tgetPrevRow(){\n\t\tvar row = this._row.prevRow();\n\t\treturn row ? row.getComponent() : row;\n\t}\n}","import CoreFeature from '../CoreFeature.js';\nimport RowComponent from './RowComponent.js';\nimport Helpers from '../tools/Helpers.js';\n\nexport default class Row extends CoreFeature{\n\tconstructor (data, parent, type = \"row\"){\n\t\tsuper(parent.table);\n\t\t\n\t\tthis.parent = parent;\n\t\tthis.data = {};\n\t\tthis.type = type; //type of element\n\t\tthis.element = false;\n\t\tthis.modules = {}; //hold module variables;\n\t\tthis.cells = [];\n\t\tthis.height = 0; //hold element height\n\t\tthis.heightStyled = \"\"; //hold element height pre-styled to improve render efficiency\n\t\tthis.manualHeight = false; //user has manually set row height\n\t\tthis.outerHeight = 0; //hold elements outer height\n\t\tthis.initialized = false; //element has been rendered\n\t\tthis.heightInitialized = false; //element has resized cells to fit\n\t\tthis.position = 0; //store position of element in row list\n\t\tthis.positionWatchers = [];\n\t\t\n\t\tthis.component = null;\n\t\t\n\t\tthis.created = false;\n\t\t\n\t\tthis.setData(data);\n\t}\n\t\n\tcreate(){\n\t\tif(!this.created){\n\t\t\tthis.created = true;\n\t\t\tthis.generateElement();\n\t\t}\n\t}\n\t\n\tcreateElement (){\n\t\tvar el = document.createElement(\"div\");\n\t\t\n\t\tel.classList.add(\"tabulator-row\");\n\t\tel.setAttribute(\"role\", \"row\");\n\t\t\n\t\tthis.element = el;\n\t}\n\t\n\tgetElement(){\n\t\tthis.create();\n\t\treturn this.element;\n\t}\n\t\n\tdetachElement(){\n\t\tif (this.element && this.element.parentNode){\n\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t}\n\t}\n\t\n\tgenerateElement(){\n\t\tthis.createElement();\n\t\tthis.dispatch(\"row-init\", this);\n\t}\n\t\n\tgenerateCells(){\n\t\tthis.cells = this.table.columnManager.generateCells(this);\n\t}\n\t\n\t//functions to setup on first render\n\tinitialize(force, inFragment){\n\t\tthis.create();\n\t\t\n\t\tif(!this.initialized || force){\n\t\t\t\n\t\t\tthis.deleteCells();\n\t\t\t\n\t\t\twhile(this.element.firstChild) this.element.removeChild(this.element.firstChild);\n\t\t\t\n\t\t\tthis.dispatch(\"row-layout-before\", this);\n\t\t\t\n\t\t\tthis.generateCells();\n\t\t\t\n\t\t\tthis.initialized = true;\n\t\t\t\n\t\t\tthis.table.columnManager.renderer.renderRowCells(this, inFragment);\n\t\t\t\n\t\t\tif(force){\n\t\t\t\tthis.normalizeHeight();\n\t\t\t}\n\t\t\t\n\t\t\tthis.dispatch(\"row-layout\", this);\n\t\t\t\n\t\t\tif(this.table.options.rowFormatter){\n\t\t\t\tthis.table.options.rowFormatter(this.getComponent());\n\t\t\t}\n\t\t\t\n\t\t\tthis.dispatch(\"row-layout-after\", this);\n\t\t}else{\n\t\t\tthis.table.columnManager.renderer.rerenderRowCells(this, inFragment);\n\t\t}\n\t}\n\n\trendered(){\n\t\tthis.cells.forEach((cell) => {\n\t\t\tcell.cellRendered();\n\t\t});\n\t}\n\t\n\treinitializeHeight(){\n\t\tthis.heightInitialized = false;\n\t\t\n\t\tif(this.element && this.element.offsetParent !== null){\n\t\t\tthis.normalizeHeight(true);\n\t\t}\n\t}\n\n\tdeinitialize(){\n\t\tthis.initialized = false;\n\t}\n\t\n\tdeinitializeHeight(){\n\t\tthis.heightInitialized = false;\n\t}\n\t\n\treinitialize(children){\n\t\tthis.initialized = false;\n\t\tthis.heightInitialized = false;\n\t\t\n\t\tif(!this.manualHeight){\n\t\t\tthis.height = 0;\n\t\t\tthis.heightStyled = \"\";\n\t\t}\n\t\t\n\t\tif(this.element && this.element.offsetParent !== null){\n\t\t\tthis.initialize(true);\n\t\t}\n\t\t\n\t\tthis.dispatch(\"row-relayout\", this);\n\t}\n\t\n\t//get heights when doing bulk row style calcs in virtual DOM\n\tcalcHeight(force){\n\t\tvar maxHeight = 0,\n\t\tminHeight;\n\t\t\n\t\tif(this.table.options.rowHeight){\n\t\t\tthis.height = this.table.options.rowHeight;\n\t\t}else{\n\t\t\tminHeight = this.table.options.resizableRows ? this.element.clientHeight : 0;\n\t\t\t\n\t\t\tthis.cells.forEach(function(cell){\n\t\t\t\tvar height = cell.getHeight();\n\t\t\t\tif(height > maxHeight){\n\t\t\t\t\tmaxHeight = height;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tif(force){\n\t\t\t\tthis.height = Math.max(maxHeight, minHeight);\n\t\t\t}else{\n\t\t\t\tthis.height = this.manualHeight ? this.height : Math.max(maxHeight, minHeight);\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.heightStyled = this.height ? this.height + \"px\" : \"\";\n\t\tthis.outerHeight = this.element.offsetHeight;\n\t}\n\t\n\t//set of cells\n\tsetCellHeight(){\n\t\tthis.cells.forEach(function(cell){\n\t\t\tcell.setHeight();\n\t\t});\n\t\t\n\t\tthis.heightInitialized = true;\n\t}\n\t\n\tclearCellHeight(){\n\t\tthis.cells.forEach(function(cell){\n\t\t\tcell.clearHeight();\n\t\t});\n\t}\n\t\n\t//normalize the height of elements in the row\n\tnormalizeHeight(force){\n\t\tif(force && !this.table.options.rowHeight){\n\t\t\tthis.clearCellHeight();\n\t\t}\n\t\t\n\t\tthis.calcHeight(force);\n\t\t\n\t\tthis.setCellHeight();\n\t}\n\t\n\t//set height of rows\n\tsetHeight(height, force){\n\t\tif(this.height != height || force){\n\t\t\t\n\t\t\tthis.manualHeight = true;\n\t\t\t\n\t\t\tthis.height = height;\n\t\t\tthis.heightStyled = height ? height + \"px\" : \"\";\n\t\t\t\n\t\t\tthis.setCellHeight();\n\t\t\t\n\t\t\t// this.outerHeight = this.element.outerHeight();\n\t\t\tthis.outerHeight = this.element.offsetHeight;\n\t\t}\n\t}\n\t\n\t//return rows outer height\n\tgetHeight(){\n\t\treturn this.outerHeight;\n\t}\n\t\n\t//return rows outer Width\n\tgetWidth(){\n\t\treturn this.element.offsetWidth;\n\t}\n\t\n\t//////////////// Cell Management /////////////////\n\tdeleteCell(cell){\n\t\tvar index = this.cells.indexOf(cell);\n\t\t\n\t\tif(index > -1){\n\t\t\tthis.cells.splice(index, 1);\n\t\t}\n\t}\n\t\n\t//////////////// Data Management /////////////////\n\tsetData(data){\n\t\tthis.data = this.chain(\"row-data-init-before\", [this, data], undefined, data);\n\t\t\n\t\tthis.dispatch(\"row-data-init-after\", this);\n\t}\n\t\n\t//update the rows data\n\tupdateData(updatedData){\n\t\tvar visible = this.element && Helpers.elVisible(this.element),\n\t\ttempData = {},\n\t\tnewRowData;\n\t\t\n\t\treturn new Promise((resolve, reject) => {\n\t\t\t\n\t\t\tif(typeof updatedData === \"string\"){\n\t\t\t\tupdatedData = JSON.parse(updatedData);\n\t\t\t}\n\t\t\t\n\t\t\tthis.dispatch(\"row-data-save-before\", this);\n\t\t\t\n\t\t\tif(this.subscribed(\"row-data-changing\")){\n\t\t\t\ttempData = Object.assign(tempData, this.data);\n\t\t\t\ttempData = Object.assign(tempData, updatedData);\n\t\t\t}\n\t\t\t\n\t\t\tnewRowData = this.chain(\"row-data-changing\", [this, tempData, updatedData], null, updatedData);\n\t\t\t\n\t\t\t//set data\n\t\t\tfor (let attrname in newRowData) {\n\t\t\t\tthis.data[attrname] = newRowData[attrname];\n\t\t\t}\n\t\t\t\n\t\t\tthis.dispatch(\"row-data-save-after\", this);\n\t\t\t\n\t\t\t//update affected cells only\n\t\t\tfor (let attrname in updatedData) {\n\t\t\t\t\n\t\t\t\tlet columns = this.table.columnManager.getColumnsByFieldRoot(attrname);\n\t\t\t\t\n\t\t\t\tcolumns.forEach((column) => {\n\t\t\t\t\tlet cell = this.getCell(column.getField());\n\t\t\t\t\t\n\t\t\t\t\tif(cell){\n\t\t\t\t\t\tlet value = column.getFieldValue(newRowData);\n\t\t\t\t\t\tif(cell.getValue() !== value){\n\t\t\t\t\t\t\tcell.setValueProcessData(value);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tif(visible){\n\t\t\t\t\t\t\t\tcell.cellRendered();\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\t\n\t\t\t//Partial reinitialization if visible\n\t\t\tif(visible){\n\t\t\t\tthis.normalizeHeight(true);\n\t\t\t\t\n\t\t\t\tif(this.table.options.rowFormatter){\n\t\t\t\t\tthis.table.options.rowFormatter(this.getComponent());\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.initialized = false;\n\t\t\t\tthis.height = 0;\n\t\t\t\tthis.heightStyled = \"\";\n\t\t\t}\n\t\t\t\n\t\t\tthis.dispatch(\"row-data-changed\", this, visible, updatedData);\n\t\t\t\n\t\t\t//this.reinitialize();\n\t\t\t\n\t\t\tthis.dispatchExternal(\"rowUpdated\", this.getComponent());\n\t\t\t\n\t\t\tif(this.subscribedExternal(\"dataChanged\")){\n\t\t\t\tthis.dispatchExternal(\"dataChanged\", this.table.rowManager.getData());\n\t\t\t}\n\t\t\t\n\t\t\tresolve();\n\t\t});\n\t}\n\t\n\tgetData(transform){\n\t\tif(transform){\n\t\t\treturn this.chain(\"row-data-retrieve\", [this, transform], null, this.data);\n\t\t}\n\t\t\n\t\treturn this.data;\n\t}\n\t\n\tgetCell(column){\n\t\tvar match = false;\n\t\t\n\t\tcolumn = this.table.columnManager.findColumn(column);\n\t\t\n\t\tif(!this.initialized && this.cells.length === 0){\n\t\t\tthis.generateCells();\n\t\t}\n\t\t\n\t\tmatch = this.cells.find(function(cell){\n\t\t\treturn cell.column === column;\n\t\t});\n\t\t\n\t\treturn match;\n\t}\n\t\n\tgetCellIndex(findCell){\n\t\treturn this.cells.findIndex(function(cell){\n\t\t\treturn cell === findCell;\n\t\t});\n\t}\n\t\n\tfindCell(subject){\n\t\treturn this.cells.find((cell) => {\n\t\t\treturn cell.element === subject;\n\t\t});\n\t}\n\t\n\tgetCells(){\n\t\tif(!this.initialized && this.cells.length === 0){\n\t\t\tthis.generateCells();\n\t\t}\n\t\t\n\t\treturn this.cells;\n\t}\n\t\n\tnextRow(){\n\t\tvar row = this.table.rowManager.nextDisplayRow(this, true);\n\t\treturn row || false;\n\t}\n\t\n\tprevRow(){\n\t\tvar row = this.table.rowManager.prevDisplayRow(this, true);\n\t\treturn row || false;\n\t}\n\t\n\tmoveToRow(to, before){\n\t\tvar toRow = this.table.rowManager.findRow(to);\n\t\t\n\t\tif(toRow){\n\t\t\tthis.table.rowManager.moveRowActual(this, toRow, !before);\n\t\t\tthis.table.rowManager.refreshActiveData(\"display\", false, true);\n\t\t}else{\n\t\t\tconsole.warn(\"Move Error - No matching row found:\", to);\n\t\t}\n\t}\n\t\n\t///////////////////// Actions /////////////////////\n\tdelete(){\n\t\tthis.dispatch(\"row-delete\", this);\n\t\t\n\t\tthis.deleteActual();\n\t\t\n\t\treturn Promise.resolve();\n\t}\n\t\n\tdeleteActual(blockRedraw){\n\t\tthis.detachModules();\n\t\t\n\t\tthis.table.rowManager.deleteRow(this, blockRedraw);\n\t\t\n\t\tthis.deleteCells();\n\t\t\n\t\tthis.initialized = false;\n\t\tthis.heightInitialized = false;\n\t\tthis.element = false;\n\t\t\n\t\tthis.dispatch(\"row-deleted\", this);\n\t}\n\t\n\tdetachModules(){\n\t\tthis.dispatch(\"row-deleting\", this);\n\t}\n\t\n\tdeleteCells(){\n\t\tvar cellCount = this.cells.length;\n\t\t\n\t\tfor(let i = 0; i < cellCount; i++){\n\t\t\tthis.cells[0].delete();\n\t\t}\n\t}\n\t\n\twipe(){\n\t\tthis.detachModules();\n\t\tthis.deleteCells();\n\t\t\n\t\tif(this.element){\n\t\t\twhile(this.element.firstChild) this.element.removeChild(this.element.firstChild);\n\t\t\t\n\t\t\tif(this.element.parentNode){\n\t\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.element = false;\n\t\tthis.modules = {};\n\t}\n\n\tisDisplayed(){\n\t\treturn this.table.rowManager.getDisplayRows().includes(this);\n\t}\n\n\tgetPosition(){\n\t\treturn this.isDisplayed() ? this.position : false;\n\t}\n\n\tsetPosition(position){\n\t\tif(position != this.position){\n\t\t\tthis.position = position;\n\n\t\t\tthis.positionWatchers.forEach((callback) => {\n\t\t\t\tcallback(this.position);\n\t\t\t});\n\t\t}\n\t}\n\n\twatchPosition(callback){\n\t\tthis.positionWatchers.push(callback);\n\n\t\tcallback(this.position);\n\t}\n\t\n\tgetGroup(){\n\t\treturn this.modules.group || false;\n\t}\n\t\n\t//////////////// Object Generation /////////////////\n\tgetComponent(){\n\t\tif(!this.component){\n\t\t\tthis.component = new RowComponent(this);\n\t\t}\n\t\t\n\t\treturn this.component;\n\t}\n}\n","export default {\n\t\"avg\":function(values, data, calcParams){\n\t\tvar output = 0,\n\t\tprecision = typeof calcParams.precision !== \"undefined\" ? calcParams.precision : 2;\n\n\t\tif(values.length){\n\t\t\toutput = values.reduce(function(sum, value){\n\t\t\t\treturn Number(sum) + Number(value);\n\t\t\t});\n\n\t\t\toutput = output / values.length;\n\n\t\t\toutput = precision !== false ? output.toFixed(precision) : output;\n\t\t}\n\n\t\treturn parseFloat(output).toString();\n\t},\n\t\"max\":function(values, data, calcParams){\n\t\tvar output = null,\n\t\tprecision = typeof calcParams.precision !== \"undefined\" ? calcParams.precision : false;\n\n\t\tvalues.forEach(function(value){\n\n\t\t\tvalue = Number(value);\n\n\t\t\tif(value > output || output === null){\n\t\t\t\toutput = value;\n\t\t\t}\n\t\t});\n\n\t\treturn output !== null ? (precision !== false ? output.toFixed(precision) : output) : \"\";\n\t},\n\t\"min\":function(values, data, calcParams){\n\t\tvar output = null,\n\t\tprecision = typeof calcParams.precision !== \"undefined\" ? calcParams.precision : false;\n\n\t\tvalues.forEach(function(value){\n\n\t\t\tvalue = Number(value);\n\n\t\t\tif(value < output || output === null){\n\t\t\t\toutput = value;\n\t\t\t}\n\t\t});\n\n\t\treturn output !== null ? (precision !== false ? output.toFixed(precision) : output) : \"\";\n\t},\n\t\"sum\":function(values, data, calcParams){\n\t\tvar output = 0,\n\t\tprecision = typeof calcParams.precision !== \"undefined\" ? calcParams.precision : false;\n\n\t\tif(values.length){\n\t\t\tvalues.forEach(function(value){\n\t\t\t\tvalue = Number(value);\n\n\t\t\t\toutput += !isNaN(value) ? Number(value) : 0;\n\t\t\t});\n\t\t}\n\n\t\treturn precision !== false ? output.toFixed(precision) : output;\n\t},\n\t\"concat\":function(values, data, calcParams){\n\t\tvar output = 0;\n\n\t\tif(values.length){\n\t\t\toutput = values.reduce(function(sum, value){\n\t\t\t\treturn String(sum) + String(value);\n\t\t\t});\n\t\t}\n\n\t\treturn output;\n\t},\n\t\"count\":function(values, data, calcParams){\n\t\tvar output = 0;\n\n\t\tif(values.length){\n\t\t\tvalues.forEach(function(value){\n\t\t\t\tif(value){\n\t\t\t\t\toutput ++;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn output;\n\t},\n\t\"unique\":function(values, data, calcParams){\n\t\tvar unique = values.filter((value, index) => {\n\t\t\treturn (values || value === 0) && values.indexOf(value) === index;\n\t\t});\n\n\t\treturn unique.length;\n\t},\n};","import Module from '../../core/Module.js';\n\nimport CalcComponent from './CalcComponent.js';\n\nimport Cell from '../../core/cell/Cell.js';\nimport Column from '../../core/column/Column.js';\nimport Row from '../../core/row/Row.js';\n\nimport defaultCalculations from './defaults/calculations.js';\n\nclass ColumnCalcs extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.topCalcs = [];\n\t\tthis.botCalcs = [];\n\t\tthis.genColumn = false;\n\t\tthis.topElement = this.createElement();\n\t\tthis.botElement = this.createElement();\n\t\tthis.topRow = false;\n\t\tthis.botRow = false;\n\t\tthis.topInitialized = false;\n\t\tthis.botInitialized = false;\n\t\t\n\t\tthis.blocked = false;\n\t\tthis.recalcAfterBlock = false;\n\t\t\n\t\tthis.registerTableOption(\"columnCalcs\", true);\n\t\t\n\t\tthis.registerColumnOption(\"topCalc\");\n\t\tthis.registerColumnOption(\"topCalcParams\");\n\t\tthis.registerColumnOption(\"topCalcFormatter\");\n\t\tthis.registerColumnOption(\"topCalcFormatterParams\");\n\t\tthis.registerColumnOption(\"bottomCalc\");\n\t\tthis.registerColumnOption(\"bottomCalcParams\");\n\t\tthis.registerColumnOption(\"bottomCalcFormatter\");\n\t\tthis.registerColumnOption(\"bottomCalcFormatterParams\");\n\t}\n\t\n\tcreateElement (){\n\t\tvar el = document.createElement(\"div\");\n\t\tel.classList.add(\"tabulator-calcs-holder\");\n\t\treturn el;\n\t}\n\t\n\tinitialize(){\n\t\tthis.genColumn = new Column({field:\"value\"}, this);\n\t\t\n\t\tthis.subscribe(\"cell-value-changed\", this.cellValueChanged.bind(this));\n\t\tthis.subscribe(\"column-init\", this.initializeColumnCheck.bind(this));\n\t\tthis.subscribe(\"row-deleted\", this.rowsUpdated.bind(this));\n\t\tthis.subscribe(\"scroll-horizontal\", this.scrollHorizontal.bind(this));\n\t\tthis.subscribe(\"row-added\", this.rowsUpdated.bind(this));\n\t\tthis.subscribe(\"column-moved\", this.recalcActiveRows.bind(this));\n\t\tthis.subscribe(\"column-add\", this.recalcActiveRows.bind(this));\n\t\tthis.subscribe(\"data-refreshed\", this.recalcActiveRowsRefresh.bind(this));\n\t\tthis.subscribe(\"table-redraw\", this.tableRedraw.bind(this));\n\t\tthis.subscribe(\"rows-visible\", this.visibleRows.bind(this));\n\t\tthis.subscribe(\"scrollbar-vertical\", this.adjustForScrollbar.bind(this));\n\t\t\n\t\tthis.subscribe(\"redraw-blocked\", this.blockRedraw.bind(this));\n\t\tthis.subscribe(\"redraw-restored\", this.restoreRedraw.bind(this));\n\n\t\tthis.subscribe(\"table-redrawing\", this.resizeHolderWidth.bind(this));\n\t\tthis.subscribe(\"column-resized\", this.resizeHolderWidth.bind(this));\n\t\tthis.subscribe(\"column-show\", this.resizeHolderWidth.bind(this));\n\t\tthis.subscribe(\"column-hide\", this.resizeHolderWidth.bind(this));\n\t\t\n\t\tthis.registerTableFunction(\"getCalcResults\", this.getResults.bind(this));\n\t\tthis.registerTableFunction(\"recalc\", this.userRecalc.bind(this));\n\n\n\t\tthis.resizeHolderWidth();\n\t}\n\n\tresizeHolderWidth(){\n\t\tthis.topElement.style.minWidth = this.table.columnManager.headersElement.offsetWidth + \"px\";\n\t}\n\n\t\n\ttableRedraw(force){\n\t\tthis.recalc(this.table.rowManager.activeRows);\n\t\t\n\t\tif(force){\n\t\t\tthis.redraw();\n\t\t}\n\t}\n\t\n\tblockRedraw(){\n\t\tthis.blocked = true;\n\t\tthis.recalcAfterBlock = false;\n\t}\n\t\n\t\n\trestoreRedraw(){\n\t\tthis.blocked = false;\n\t\t\n\t\tif(this.recalcAfterBlock){\n\t\t\tthis.recalcAfterBlock = false;\n\t\t\tthis.recalcActiveRowsRefresh();\n\t\t}\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\tuserRecalc(){\n\t\tthis.recalc(this.table.rowManager.activeRows);\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\t\n\tblockCheck(){\n\t\tif(this.blocked){\n\t\t\tthis.recalcAfterBlock = true;\n\t\t}\n\t\t\n\t\treturn this.blocked;\n\t}\n\t\n\tvisibleRows(viewable, rows){\n\t\tif(this.topRow){\n\t\t\trows.unshift(this.topRow);\n\t\t}\n\t\t\n\t\tif(this.botRow){\n\t\t\trows.push(this.botRow);\n\t\t}\n\t\t\n\t\treturn rows;\n\t}\n\t\n\trowsUpdated(row){\n\t\tif(this.table.options.groupBy){\n\t\t\tthis.recalcRowGroup(row);\n\t\t}else{\n\t\t\tthis.recalcActiveRows();\n\t\t}\n\t}\n\t\n\trecalcActiveRowsRefresh(){\n\t\tif(this.table.options.groupBy && this.table.options.dataTreeStartExpanded && this.table.options.dataTree){\n\t\t\tthis.recalcAll();\n\t\t}else{\n\t\t\tthis.recalcActiveRows();\n\t\t}\n\t}\n\t\n\trecalcActiveRows(){\n\t\tthis.recalc(this.table.rowManager.activeRows);\n\t}\n\t\n\tcellValueChanged(cell){\n\t\tif(cell.column.definition.topCalc || cell.column.definition.bottomCalc){\n\t\t\tif(this.table.options.groupBy){\n\t\t\t\tif(this.table.options.columnCalcs == \"table\" || this.table.options.columnCalcs == \"both\"){\n\t\t\t\t\tthis.recalcActiveRows();\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(this.table.options.columnCalcs != \"table\"){\n\t\t\t\t\tthis.recalcRowGroup(cell.row);\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.recalcActiveRows();\n\t\t\t}\n\t\t}\n\t}\n\t\n\tinitializeColumnCheck(column){\n\t\tif(column.definition.topCalc || column.definition.bottomCalc){\n\t\t\tthis.initializeColumn(column);\n\t\t}\n\t}\n\t\n\t//initialize column calcs\n\tinitializeColumn(column){\n\t\tvar def = column.definition;\n\t\t\n\t\tvar config = {\n\t\t\ttopCalcParams:def.topCalcParams || {},\n\t\t\tbotCalcParams:def.bottomCalcParams || {},\n\t\t};\n\t\t\n\t\tif(def.topCalc){\n\t\t\t\n\t\t\tswitch(typeof def.topCalc){\n\t\t\t\tcase \"string\":\n\t\t\t\t\tif(ColumnCalcs.calculations[def.topCalc]){\n\t\t\t\t\t\tconfig.topCalc = ColumnCalcs.calculations[def.topCalc];\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Column Calc Error - No such calculation found, ignoring: \", def.topCalc);\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"function\":\n\t\t\t\t\tconfig.topCalc = def.topCalc;\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t}\n\t\t\t\n\t\t\tif(config.topCalc){\n\t\t\t\tcolumn.modules.columnCalcs = config;\n\t\t\t\tthis.topCalcs.push(column);\n\t\t\t\t\n\t\t\t\tif(this.table.options.columnCalcs != \"group\"){\n\t\t\t\t\tthis.initializeTopRow();\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t}\n\t\t\n\t\tif(def.bottomCalc){\n\t\t\tswitch(typeof def.bottomCalc){\n\t\t\t\tcase \"string\":\n\t\t\t\t\tif(ColumnCalcs.calculations[def.bottomCalc]){\n\t\t\t\t\t\tconfig.botCalc = ColumnCalcs.calculations[def.bottomCalc];\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Column Calc Error - No such calculation found, ignoring: \", def.bottomCalc);\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"function\":\n\t\t\t\t\tconfig.botCalc = def.bottomCalc;\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t}\n\t\t\t\n\t\t\tif(config.botCalc){\n\t\t\t\tcolumn.modules.columnCalcs = config;\n\t\t\t\tthis.botCalcs.push(column);\n\t\t\t\t\n\t\t\t\tif(this.table.options.columnCalcs != \"group\"){\n\t\t\t\t\tthis.initializeBottomRow();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t}\n\t\n\t//dummy functions to handle being mock column manager\n\tregisterColumnField(){}\n\t\n\tremoveCalcs(){\n\t\tvar changed = false;\n\t\t\n\t\tif(this.topInitialized){\n\t\t\tthis.topInitialized = false;\n\t\t\tthis.topElement.parentNode.removeChild(this.topElement);\n\t\t\tchanged = true;\n\t\t}\n\t\t\n\t\tif(this.botInitialized){\n\t\t\tthis.botInitialized = false;\n\t\t\tthis.footerRemove(this.botElement);\n\t\t\tchanged = true;\n\t\t}\n\t\t\n\t\tif(changed){\n\t\t\tthis.table.rowManager.adjustTableSize();\n\t\t}\n\t}\n\t\n\treinitializeCalcs(){\n\t\tif(this.topCalcs.length){\n\t\t\tthis.initializeTopRow();\n\t\t}\n\n\t\tif(this.botCalcs.length){\n\t\t\tthis.initializeBottomRow();\n\t\t}\n\t}\n\t\n\tinitializeTopRow(){\n\t\tif(!this.topInitialized){\n\t\t\tthis.table.columnManager.getContentsElement().insertBefore(this.topElement, this.table.columnManager.headersElement.nextSibling);\n\t\t\tthis.topInitialized = true;\n\t\t}\n\t}\n\t\n\tinitializeBottomRow(){\n\t\tif(!this.botInitialized){\n\t\t\tthis.footerPrepend(this.botElement);\n\t\t\tthis.botInitialized = true;\n\t\t}\n\t}\n\t\n\tscrollHorizontal(left){\n\t\tif(this.botInitialized && this.botRow){\n\t\t\tthis.botElement.scrollLeft = left;\n\t\t}\n\t}\n\t\n\trecalc(rows){\n\t\tvar data, row;\n\t\t\n\t\tif(!this.blockCheck()){\n\t\t\tif(this.topInitialized || this.botInitialized){\n\t\t\t\tdata = this.rowsToData(rows);\n\t\t\t\t\n\t\t\t\tif(this.topInitialized){\n\t\t\t\t\tif(this.topRow){\n\t\t\t\t\t\tthis.topRow.deleteCells();\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\trow = this.generateRow(\"top\", data);\n\t\t\t\t\tthis.topRow = row;\n\t\t\t\t\twhile(this.topElement.firstChild) this.topElement.removeChild(this.topElement.firstChild);\n\t\t\t\t\tthis.topElement.appendChild(row.getElement());\n\t\t\t\t\trow.initialize(true);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(this.botInitialized){\n\t\t\t\t\tif(this.botRow){\n\t\t\t\t\t\tthis.botRow.deleteCells();\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\trow = this.generateRow(\"bottom\", data);\n\t\t\t\t\tthis.botRow = row;\n\t\t\t\t\twhile(this.botElement.firstChild) this.botElement.removeChild(this.botElement.firstChild);\n\t\t\t\t\tthis.botElement.appendChild(row.getElement());\n\t\t\t\t\trow.initialize(true);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.table.rowManager.adjustTableSize();\n\t\t\t\t\n\t\t\t\t//set resizable handles\n\t\t\t\tif(this.table.modExists(\"frozenColumns\")){\n\t\t\t\t\tthis.table.modules.frozenColumns.layout();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\trecalcRowGroup(row){\n\t\tthis.recalcGroup(this.table.modules.groupRows.getRowGroup(row));\n\t}\n\t\n\trecalcAll(){\n\t\tif(this.topCalcs.length || this.botCalcs.length){\n\t\t\tif(this.table.options.columnCalcs !== \"group\"){\n\t\t\t\tthis.recalcActiveRows();\n\t\t\t}\n\t\t\t\n\t\t\tif(this.table.options.groupBy && this.table.options.columnCalcs !== \"table\"){\n\t\t\t\t\n\t\t\t\tvar groups = this.table.modules.groupRows.getChildGroups();\n\t\t\t\t\n\t\t\t\tgroups.forEach((group) => {\n\t\t\t\t\tthis.recalcGroup(group);\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\t\n\trecalcGroup(group){\n\t\tvar data, rowData;\n\t\t\n\t\tif(!this.blockCheck()){\n\t\t\tif(group){\n\t\t\t\tif(group.calcs){\n\t\t\t\t\tif(group.calcs.bottom){\n\t\t\t\t\t\tdata = this.rowsToData(group.rows);\n\t\t\t\t\t\trowData = this.generateRowData(\"bottom\", data);\n\t\t\t\t\t\t\n\t\t\t\t\t\tgroup.calcs.bottom.updateData(rowData);\n\t\t\t\t\t\tgroup.calcs.bottom.reinitialize();\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif(group.calcs.top){\n\t\t\t\t\t\tdata = this.rowsToData(group.rows);\n\t\t\t\t\t\trowData = this.generateRowData(\"top\", data);\n\t\t\t\t\t\t\n\t\t\t\t\t\tgroup.calcs.top.updateData(rowData);\n\t\t\t\t\t\tgroup.calcs.top.reinitialize();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t//generate top stats row\n\tgenerateTopRow(rows){\n\t\treturn this.generateRow(\"top\", this.rowsToData(rows));\n\t}\n\t//generate bottom stats row\n\tgenerateBottomRow(rows){\n\t\treturn this.generateRow(\"bottom\", this.rowsToData(rows));\n\t}\n\t\n\trowsToData(rows){\n\t\tvar data = [];\n\t\t\n\t\trows.forEach((row) => {\n\t\t\tdata.push(row.getData());\n\t\t\t\n\t\t\tif(this.table.options.dataTree && this.table.options.dataTreeChildColumnCalcs){\n\t\t\t\tif(row.modules.dataTree && row.modules.dataTree.open){\n\t\t\t\t\tvar children = this.rowsToData(this.table.modules.dataTree.getFilteredTreeChildren(row));\n\t\t\t\t\tdata = data.concat(children);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn data;\n\t}\n\t\n\t//generate stats row\n\tgenerateRow(pos, data){\n\t\tvar rowData = this.generateRowData(pos, data),\n\t\trow;\n\t\t\n\t\tif(this.table.modExists(\"mutator\")){\n\t\t\tthis.table.modules.mutator.disable();\n\t\t}\n\t\t\n\t\trow = new Row(rowData, this, \"calc\");\n\t\t\n\t\tif(this.table.modExists(\"mutator\")){\n\t\t\tthis.table.modules.mutator.enable();\n\t\t}\n\t\t\n\t\trow.getElement().classList.add(\"tabulator-calcs\", \"tabulator-calcs-\" + pos);\n\t\t\n\t\trow.component = false;\n\t\t\n\t\trow.getComponent = () => {\n\t\t\tif(!row.component){\n\t\t\t\trow.component = new CalcComponent(row);\n\t\t\t}\n\t\t\t\n\t\t\treturn row.component;\n\t\t};\n\t\t\n\t\trow.generateCells = () => {\n\t\t\t\n\t\t\tvar cells = [];\n\t\t\t\n\t\t\tthis.table.columnManager.columnsByIndex.forEach((column) => {\n\t\t\t\t\n\t\t\t\t//set field name of mock column\n\t\t\t\tthis.genColumn.setField(column.getField());\n\t\t\t\tthis.genColumn.hozAlign = column.hozAlign;\n\t\t\t\t\n\t\t\t\tif(column.definition[pos + \"CalcFormatter\"] && this.table.modExists(\"format\")){\n\t\t\t\t\tthis.genColumn.modules.format = {\n\t\t\t\t\t\tformatter: this.table.modules.format.getFormatter(column.definition[pos + \"CalcFormatter\"]),\n\t\t\t\t\t\tparams: column.definition[pos + \"CalcFormatterParams\"] || {},\n\t\t\t\t\t};\n\t\t\t\t}else{\n\t\t\t\t\tthis.genColumn.modules.format = {\n\t\t\t\t\t\tformatter: this.table.modules.format.getFormatter(\"plaintext\"),\n\t\t\t\t\t\tparams:{}\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t//ensure css class definition is replicated to calculation cell\n\t\t\t\tthis.genColumn.definition.cssClass = column.definition.cssClass;\n\t\t\t\t\n\t\t\t\t//generate cell and assign to correct column\n\t\t\t\tvar cell = new Cell(this.genColumn, row);\n\t\t\t\tcell.getElement();\n\t\t\t\tcell.column = column;\n\t\t\t\tcell.setWidth();\n\t\t\t\t\n\t\t\t\tcolumn.cells.push(cell);\n\t\t\t\tcells.push(cell);\n\t\t\t\t\n\t\t\t\tif(!column.visible){\n\t\t\t\t\tcell.hide();\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\trow.cells = cells;\n\t\t};\n\t\t\n\t\treturn row;\n\t}\n\t\n\t//generate stats row\n\tgenerateRowData(pos, data){\n\t\tvar rowData = {},\n\t\tcalcs = pos == \"top\" ? this.topCalcs : this.botCalcs,\n\t\ttype = pos == \"top\" ? \"topCalc\" : \"botCalc\",\n\t\tparams, paramKey;\n\t\t\n\t\tcalcs.forEach(function(column){\n\t\t\tvar values = [];\n\t\t\t\n\t\t\tif(column.modules.columnCalcs && column.modules.columnCalcs[type]){\n\t\t\t\tdata.forEach(function(item){\n\t\t\t\t\tvalues.push(column.getFieldValue(item));\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tparamKey = type + \"Params\";\n\t\t\t\tparams = typeof column.modules.columnCalcs[paramKey] === \"function\" ? column.modules.columnCalcs[paramKey](values, data) : column.modules.columnCalcs[paramKey];\n\t\t\t\t\n\t\t\t\tcolumn.setFieldValue(rowData, column.modules.columnCalcs[type](values, data, params));\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn rowData;\n\t}\n\t\n\thasTopCalcs(){\n\t\treturn\t!!(this.topCalcs.length);\n\t}\n\t\n\thasBottomCalcs(){\n\t\treturn\t!!(this.botCalcs.length);\n\t}\n\t\n\t//handle table redraw\n\tredraw(){\n\t\tif(this.topRow){\n\t\t\tthis.topRow.normalizeHeight(true);\n\t\t}\n\t\tif(this.botRow){\n\t\t\tthis.botRow.normalizeHeight(true);\n\t\t}\n\t}\n\t\n\t//return the calculated\n\tgetResults(){\n\t\tvar results = {},\n\t\tgroups;\n\t\t\n\t\tif(this.table.options.groupBy && this.table.modExists(\"groupRows\")){\n\t\t\tgroups = this.table.modules.groupRows.getGroups(true);\n\t\t\t\n\t\t\tgroups.forEach((group) => {\n\t\t\t\tresults[group.getKey()] = this.getGroupResults(group);\n\t\t\t});\n\t\t}else{\n\t\t\tresults = {\n\t\t\t\ttop: this.topRow ? this.topRow.getData() : {},\n\t\t\t\tbottom: this.botRow ? this.botRow.getData() : {},\n\t\t\t};\n\t\t}\n\t\t\n\t\treturn results;\n\t}\n\t\n\t//get results from a group\n\tgetGroupResults(group){\n\t\tvar groupObj = group._getSelf(),\n\t\tsubGroups = group.getSubGroups(),\n\t\tsubGroupResults = {},\n\t\tresults = {};\n\t\t\n\t\tsubGroups.forEach((subgroup) => {\n\t\t\tsubGroupResults[subgroup.getKey()] = this.getGroupResults(subgroup);\n\t\t});\n\t\t\n\t\tresults = {\n\t\t\ttop: groupObj.calcs.top ? groupObj.calcs.top.getData() : {},\n\t\t\tbottom: groupObj.calcs.bottom ? groupObj.calcs.bottom.getData() : {},\n\t\t\tgroups: subGroupResults,\n\t\t};\n\t\t\n\t\treturn results;\n\t}\n\t\n\tadjustForScrollbar(width){\n\t\tif(this.botRow){\n\t\t\tif(this.table.rtl){\n\t\t\t\tthis.botElement.style.paddingLeft = width + \"px\";\n\t\t\t}else{\n\t\t\t\tthis.botElement.style.paddingRight = width + \"px\";\n\t\t\t}\n\t\t}\n\t}\n}\n\nColumnCalcs.moduleName = \"columnCalcs\";\n\n//load defaults\nColumnCalcs.calculations = defaultCalculations;\n\nexport default ColumnCalcs;","import Module from '../../core/Module.js';\n\nimport Row from '../../core/row/Row.js';\n\nimport RowComponent from '../../core/row/RowComponent.js';\n\nclass DataTree extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.indent = 10;\n\t\tthis.field = \"\";\n\t\tthis.collapseEl = null;\n\t\tthis.expandEl = null;\n\t\tthis.branchEl = null;\n\t\tthis.elementField = false;\n\n\t\tthis.startOpen = function(){};\n\n\t\tthis.registerTableOption(\"dataTree\", false); //enable data tree\n\t\tthis.registerTableOption(\"dataTreeFilter\", true); //filter child rows\n\t\tthis.registerTableOption(\"dataTreeSort\", true); //sort child rows\n\t\tthis.registerTableOption(\"dataTreeElementColumn\", false);\n\t\tthis.registerTableOption(\"dataTreeBranchElement\", true);//show data tree branch element\n\t\tthis.registerTableOption(\"dataTreeChildIndent\", 9); //data tree child indent in px\n\t\tthis.registerTableOption(\"dataTreeChildField\", \"_children\");//data tre column field to look for child rows\n\t\tthis.registerTableOption(\"dataTreeCollapseElement\", false);//data tree row collapse element\n\t\tthis.registerTableOption(\"dataTreeExpandElement\", false);//data tree row expand element\n\t\tthis.registerTableOption(\"dataTreeStartExpanded\", false);\n\t\tthis.registerTableOption(\"dataTreeChildColumnCalcs\", false);//include visible data tree rows in column calculations\n\t\tthis.registerTableOption(\"dataTreeSelectPropagate\", false);//selecting a parent row selects its children\n\n\t\t//register component functions\n\t\tthis.registerComponentFunction(\"row\", \"treeCollapse\", this.collapseRow.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"treeExpand\", this.expandRow.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"treeToggle\", this.toggleRow.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"getTreeParent\", this.getTreeParent.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"getTreeChildren\", this.getRowChildren.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"addTreeChild\", this.addTreeChildRow.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"isTreeExpanded\", this.isRowExpanded.bind(this));\n\t}\n\n\tinitialize(){\n\t\tif(this.table.options.dataTree){\n\t\t\tvar dummyEl = null,\n\t\t\toptions = this.table.options;\n\n\t\t\tthis.field = options.dataTreeChildField;\n\t\t\tthis.indent = options.dataTreeChildIndent;\n\n\t\t\tif(this.options(\"movableRows\")){\n\t\t\t\tconsole.warn(\"The movableRows option is not available with dataTree enabled, moving of child rows could result in unpredictable behavior\");\n\t\t\t}\n\n\t\t\tif(options.dataTreeBranchElement){\n\n\t\t\t\tif(options.dataTreeBranchElement === true){\n\t\t\t\t\tthis.branchEl = document.createElement(\"div\");\n\t\t\t\t\tthis.branchEl.classList.add(\"tabulator-data-tree-branch\");\n\t\t\t\t}else{\n\t\t\t\t\tif(typeof options.dataTreeBranchElement === \"string\"){\n\t\t\t\t\t\tdummyEl = document.createElement(\"div\");\n\t\t\t\t\t\tdummyEl.innerHTML = options.dataTreeBranchElement;\n\t\t\t\t\t\tthis.branchEl = dummyEl.firstChild;\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.branchEl = options.dataTreeBranchElement;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.branchEl = document.createElement(\"div\");\n\t\t\t\tthis.branchEl.classList.add(\"tabulator-data-tree-branch-empty\");\n\t\t\t}\n\n\t\t\tif(options.dataTreeCollapseElement){\n\t\t\t\tif(typeof options.dataTreeCollapseElement === \"string\"){\n\t\t\t\t\tdummyEl = document.createElement(\"div\");\n\t\t\t\t\tdummyEl.innerHTML = options.dataTreeCollapseElement;\n\t\t\t\t\tthis.collapseEl = dummyEl.firstChild;\n\t\t\t\t}else{\n\t\t\t\t\tthis.collapseEl = options.dataTreeCollapseElement;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.collapseEl = document.createElement(\"div\");\n\t\t\t\tthis.collapseEl.classList.add(\"tabulator-data-tree-control\");\n\t\t\t\tthis.collapseEl.tabIndex = 0;\n\t\t\t\tthis.collapseEl.innerHTML = \"
\";\n\t\t\t}\n\n\t\t\tif(options.dataTreeExpandElement){\n\t\t\t\tif(typeof options.dataTreeExpandElement === \"string\"){\n\t\t\t\t\tdummyEl = document.createElement(\"div\");\n\t\t\t\t\tdummyEl.innerHTML = options.dataTreeExpandElement;\n\t\t\t\t\tthis.expandEl = dummyEl.firstChild;\n\t\t\t\t}else{\n\t\t\t\t\tthis.expandEl = options.dataTreeExpandElement;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.expandEl = document.createElement(\"div\");\n\t\t\t\tthis.expandEl.classList.add(\"tabulator-data-tree-control\");\n\t\t\t\tthis.expandEl.tabIndex = 0;\n\t\t\t\tthis.expandEl.innerHTML = \"
\";\n\t\t\t}\n\n\n\t\t\tswitch(typeof options.dataTreeStartExpanded){\n\t\t\t\tcase \"boolean\":\n\t\t\t\t\tthis.startOpen = function(row, index){\n\t\t\t\t\t\treturn options.dataTreeStartExpanded;\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"function\":\n\t\t\t\t\tthis.startOpen = options.dataTreeStartExpanded;\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\tthis.startOpen = function(row, index){\n\t\t\t\t\t\treturn options.dataTreeStartExpanded[index];\n\t\t\t\t\t};\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tthis.subscribe(\"row-init\", this.initializeRow.bind(this));\n\t\t\tthis.subscribe(\"row-layout-after\", this.layoutRow.bind(this));\n\t\t\tthis.subscribe(\"row-deleted\", this.rowDelete.bind(this),0);\n\t\t\tthis.subscribe(\"row-data-changed\", this.rowDataChanged.bind(this), 10);\n\t\t\tthis.subscribe(\"cell-value-updated\", this.cellValueChanged.bind(this));\n\t\t\tthis.subscribe(\"edit-cancelled\", this.cellValueChanged.bind(this));\n\t\t\tthis.subscribe(\"column-moving-rows\", this.columnMoving.bind(this));\n\t\t\tthis.subscribe(\"table-built\", this.initializeElementField.bind(this));\n\t\t\tthis.subscribe(\"table-redrawing\", this.tableRedrawing.bind(this));\n\n\t\t\tthis.registerDisplayHandler(this.getRows.bind(this), 30);\n\t\t}\n\t}\n\n\ttableRedrawing(force){\n\t\tvar rows;\n\n\t\tif(force){\n\t\t\trows = this.table.rowManager.getRows();\n\t\t\t\n\t\t\trows.forEach((row) => {\n\t\t\t\tthis.reinitializeRowChildren(row);\n\t\t\t});\n\t\t}\n\t}\n\n\tinitializeElementField(){\n\t\tvar firstCol = this.table.columnManager.getFirstVisibleColumn();\n\n\t\tthis.elementField = this.table.options.dataTreeElementColumn || (firstCol ? firstCol.field : false);\n\t}\n\t\n\tgetRowChildren(row){\n\t\treturn this.getTreeChildren(row, true);\n\t}\n\n\tcolumnMoving(){\n\t\tvar rows = [];\n\n\t\tthis.table.rowManager.rows.forEach((row) => {\n\t\t\trows = rows.concat(this.getTreeChildren(row, false, true));\n\t\t});\n\n\t\treturn rows;\n\t}\n\n\trowDataChanged(row, visible, updatedData){\n\t\tif(this.redrawNeeded(updatedData)){\n\t\t\tthis.initializeRow(row);\n\n\t\t\tif(visible){\n\t\t\t\tthis.layoutRow(row);\n\t\t\t\tthis.refreshData(true);\n\t\t\t}\n\t\t}\n\t}\n\n\tcellValueChanged(cell){\n\t\tvar field = cell.column.getField();\n\n\t\tif(field === this.elementField){\n\t\t\tthis.layoutRow(cell.row);\n\t\t}\n\t}\n\n\tinitializeRow(row){\n\t\tvar childArray = row.getData()[this.field];\n\t\tvar isArray = Array.isArray(childArray);\n\n\t\tvar children = isArray || (!isArray && typeof childArray === \"object\" && childArray !== null);\n\n\t\tif(!children && row.modules.dataTree && row.modules.dataTree.branchEl){\n\t\t\trow.modules.dataTree.branchEl.parentNode.removeChild(row.modules.dataTree.branchEl);\n\t\t}\n\n\t\tif(!children && row.modules.dataTree && row.modules.dataTree.controlEl){\n\t\t\trow.modules.dataTree.controlEl.parentNode.removeChild(row.modules.dataTree.controlEl);\n\t\t}\n\n\t\trow.modules.dataTree = {\n\t\t\tindex: row.modules.dataTree ? row.modules.dataTree.index : 0,\n\t\t\topen: children ? (row.modules.dataTree ? row.modules.dataTree.open : this.startOpen(row.getComponent(), 0)) : false,\n\t\t\tcontrolEl: row.modules.dataTree && children ? row.modules.dataTree.controlEl : false,\n\t\t\tbranchEl: row.modules.dataTree && children ? row.modules.dataTree.branchEl : false,\n\t\t\tparent: row.modules.dataTree ? row.modules.dataTree.parent : false,\n\t\t\tchildren:children,\n\t\t};\n\t}\n\n\treinitializeRowChildren(row){\n\t\tvar children = this.getTreeChildren(row, false, true);\n\n\t\tchildren.forEach(function(child){\n\t\t\tchild.reinitialize(true);\n\t\t});\n\t}\n\n\tlayoutRow(row){\n\t\tvar cell = this.elementField ? row.getCell(this.elementField) : row.getCells()[0],\n\t\tel = cell.getElement(),\n\t\tconfig = row.modules.dataTree;\n\n\t\tif(config.branchEl){\n\t\t\tif(config.branchEl.parentNode){\n\t\t\t\tconfig.branchEl.parentNode.removeChild(config.branchEl);\n\t\t\t}\n\t\t\tconfig.branchEl = false;\n\t\t}\n\n\t\tif(config.controlEl){\n\t\t\tif(config.controlEl.parentNode){\n\t\t\t\tconfig.controlEl.parentNode.removeChild(config.controlEl);\n\t\t\t}\n\t\t\tconfig.controlEl = false;\n\t\t}\n\n\t\tthis.generateControlElement(row, el);\n\n\t\trow.getElement().classList.add(\"tabulator-tree-level-\" + config.index);\n\n\t\tif(config.index){\n\t\t\tif(this.branchEl){\n\t\t\t\tconfig.branchEl = this.branchEl.cloneNode(true);\n\t\t\t\tel.insertBefore(config.branchEl, el.firstChild);\n\n\t\t\t\tif(this.table.rtl){\n\t\t\t\t\tconfig.branchEl.style.marginRight = (((config.branchEl.offsetWidth + config.branchEl.style.marginLeft) * (config.index - 1)) + (config.index * this.indent)) + \"px\";\n\t\t\t\t}else{\n\t\t\t\t\tconfig.branchEl.style.marginLeft = (((config.branchEl.offsetWidth + config.branchEl.style.marginRight) * (config.index - 1)) + (config.index * this.indent)) + \"px\";\n\t\t\t\t}\n\t\t\t}else{\n\n\t\t\t\tif(this.table.rtl){\n\t\t\t\t\tel.style.paddingRight = parseInt(window.getComputedStyle(el, null).getPropertyValue('padding-right')) + (config.index * this.indent) + \"px\";\n\t\t\t\t}else{\n\t\t\t\t\tel.style.paddingLeft = parseInt(window.getComputedStyle(el, null).getPropertyValue('padding-left')) + (config.index * this.indent) + \"px\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tgenerateControlElement(row, el){\n\t\tvar config = row.modules.dataTree,\n\t\toldControl = config.controlEl;\n\n\t\tel = el || row.getCells()[0].getElement();\n\n\t\tif(config.children !== false){\n\n\t\t\tif(config.open){\n\t\t\t\tconfig.controlEl = this.collapseEl.cloneNode(true);\n\t\t\t\tconfig.controlEl.addEventListener(\"click\", (e) => {\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t\tthis.collapseRow(row);\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tconfig.controlEl = this.expandEl.cloneNode(true);\n\t\t\t\tconfig.controlEl.addEventListener(\"click\", (e) => {\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t\tthis.expandRow(row);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconfig.controlEl.addEventListener(\"mousedown\", (e) => {\n\t\t\t\te.stopPropagation();\n\t\t\t});\n\n\t\t\tif(oldControl && oldControl.parentNode === el){\n\t\t\t\toldControl.parentNode.replaceChild(config.controlEl,oldControl);\n\t\t\t}else{\n\t\t\t\tel.insertBefore(config.controlEl, el.firstChild);\n\t\t\t}\n\t\t}\n\t}\n\n\tgetRows(rows){\n\t\tvar output = [];\n\n\t\trows.forEach((row, i) => {\n\t\t\tvar config, children;\n\n\t\t\toutput.push(row);\n\n\t\t\tif(row instanceof Row){\n\n\t\t\t\trow.create();\n\n\t\t\t\tconfig = row.modules.dataTree;\n\n\t\t\t\tif(!config.index && config.children !== false){\n\t\t\t\t\tchildren = this.getChildren(row);\n\n\t\t\t\t\tchildren.forEach((child) => {\n\t\t\t\t\t\tchild.create();\n\t\t\t\t\t\toutput.push(child);\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\treturn output;\n\t}\n\n\tgetChildren(row, allChildren){\n\t\tvar config = row.modules.dataTree,\n\t\tchildren = [],\n\t\toutput = [];\n\n\t\tif(config.children !== false && (config.open || allChildren)){\n\t\t\tif(!Array.isArray(config.children)){\n\t\t\t\tconfig.children = this.generateChildren(row);\n\t\t\t}\n\n\t\t\tif(this.table.modExists(\"filter\") && this.table.options.dataTreeFilter){\n\t\t\t\tchildren = this.table.modules.filter.filter(config.children);\n\t\t\t}else{\n\t\t\t\tchildren = config.children;\n\t\t\t}\n\n\t\t\tif(this.table.modExists(\"sort\") && this.table.options.dataTreeSort){\n\t\t\t\tthis.table.modules.sort.sort(children);\n\t\t\t}\n\n\t\t\tchildren.forEach((child) => {\n\t\t\t\toutput.push(child);\n\n\t\t\t\tvar subChildren = this.getChildren(child);\n\n\t\t\t\tsubChildren.forEach((sub) => {\n\t\t\t\t\toutput.push(sub);\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\n\t\treturn output;\n\t}\n\n\tgenerateChildren(row){\n\t\tvar children = [];\n\n\t\tvar childArray = row.getData()[this.field];\n\n\t\tif(!Array.isArray(childArray)){\n\t\t\tchildArray = [childArray];\n\t\t}\n\n\t\tchildArray.forEach((childData) => {\n\t\t\tvar childRow = new Row(childData || {}, this.table.rowManager);\n\n\t\t\tchildRow.create();\n\n\t\t\tchildRow.modules.dataTree.index = row.modules.dataTree.index + 1;\n\t\t\tchildRow.modules.dataTree.parent = row;\n\n\t\t\tif(childRow.modules.dataTree.children){\n\t\t\t\tchildRow.modules.dataTree.open = this.startOpen(childRow.getComponent(), childRow.modules.dataTree.index);\n\t\t\t}\n\t\t\tchildren.push(childRow);\n\t\t});\n\n\t\treturn children;\n\t}\n\n\texpandRow(row, silent){\n\t\tvar config = row.modules.dataTree;\n\n\t\tif(config.children !== false){\n\t\t\tconfig.open = true;\n\n\t\t\trow.reinitialize();\n\n\t\t\tthis.refreshData(true);\n\n\t\t\tthis.dispatchExternal(\"dataTreeRowExpanded\", row.getComponent(), row.modules.dataTree.index);\n\t\t}\n\t}\n\n\tcollapseRow(row){\n\t\tvar config = row.modules.dataTree;\n\n\t\tif(config.children !== false){\n\t\t\tconfig.open = false;\n\n\t\t\trow.reinitialize();\n\n\t\t\tthis.refreshData(true);\n\n\t\t\tthis.dispatchExternal(\"dataTreeRowCollapsed\", row.getComponent(), row.modules.dataTree.index);\n\t\t}\n\t}\n\n\ttoggleRow(row){\n\t\tvar config = row.modules.dataTree;\n\n\t\tif(config.children !== false){\n\t\t\tif(config.open){\n\t\t\t\tthis.collapseRow(row);\n\t\t\t}else{\n\t\t\t\tthis.expandRow(row);\n\t\t\t}\n\t\t}\n\t}\n\n\tisRowExpanded(row){\n\t\treturn row.modules.dataTree.open;\n\t}\n\n\tgetTreeParent(row){\n\t\treturn row.modules.dataTree.parent ? row.modules.dataTree.parent.getComponent() : false;\n\t}\n\n\tgetTreeParentRoot(row){\n\t\treturn row.modules.dataTree && row.modules.dataTree.parent ? this.getTreeParentRoot(row.modules.dataTree.parent) : row;\n\t}\n\n\tgetFilteredTreeChildren(row){\n\t\tvar config = row.modules.dataTree,\n\t\toutput = [], children;\n\n\t\tif(config.children){\n\n\t\t\tif(!Array.isArray(config.children)){\n\t\t\t\tconfig.children = this.generateChildren(row);\n\t\t\t}\n\n\t\t\tif(this.table.modExists(\"filter\") && this.table.options.dataTreeFilter){\n\t\t\t\tchildren = this.table.modules.filter.filter(config.children);\n\t\t\t}else{\n\t\t\t\tchildren = config.children;\n\t\t\t}\n\n\t\t\tchildren.forEach((childRow) => {\n\t\t\t\tif(childRow instanceof Row){\n\t\t\t\t\toutput.push(childRow);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn output;\n\t}\n\n\trowDelete(row){\n\t\tvar parent = row.modules.dataTree.parent,\n\t\tchildIndex;\n\n\t\tif(parent){\n\t\t\tchildIndex = this.findChildIndex(row, parent);\n\n\t\t\tif(childIndex !== false){\n\t\t\t\tparent.data[this.field].splice(childIndex, 1);\n\t\t\t}\n\n\t\t\tif(!parent.data[this.field].length){\n\t\t\t\tdelete parent.data[this.field];\n\t\t\t}\n\n\t\t\tthis.initializeRow(parent);\n\t\t\tthis.layoutRow(parent);\n\t\t}\n\n\t\tthis.refreshData(true);\n\t}\n\n\taddTreeChildRow(row, data, top, index){\n\t\tvar childIndex = false;\n\n\t\tif(typeof data === \"string\"){\n\t\t\tdata = JSON.parse(data);\n\t\t}\n\n\t\tif(!Array.isArray(row.data[this.field])){\n\t\t\trow.data[this.field] = [];\n\n\t\t\trow.modules.dataTree.open = this.startOpen(row.getComponent(), row.modules.dataTree.index);\n\t\t}\n\n\t\tif(typeof index !== \"undefined\"){\n\t\t\tchildIndex = this.findChildIndex(index, row);\n\n\t\t\tif(childIndex !== false){\n\t\t\t\trow.data[this.field].splice((top ? childIndex : childIndex + 1), 0, data);\n\t\t\t}\n\t\t}\n\n\t\tif(childIndex === false){\n\t\t\tif(top){\n\t\t\t\trow.data[this.field].unshift(data);\n\t\t\t}else{\n\t\t\t\trow.data[this.field].push(data);\n\t\t\t}\n\t\t}\n\n\t\tthis.initializeRow(row);\n\t\tthis.layoutRow(row);\n\n\t\tthis.refreshData(true);\n\t}\n\n\tfindChildIndex(subject, parent){\n\t\tvar match = false;\n\n\t\tif(typeof subject == \"object\"){\n\n\t\t\tif(subject instanceof Row){\n\t\t\t\t//subject is row element\n\t\t\t\tmatch = subject.data;\n\t\t\t}else if(subject instanceof RowComponent){\n\t\t\t\t//subject is public row component\n\t\t\t\tmatch = subject._getSelf().data;\n\t\t\t}else if(typeof HTMLElement !== \"undefined\" && subject instanceof HTMLElement){\n\t\t\t\tif(parent.modules.dataTree){\n\t\t\t\t\tmatch = parent.modules.dataTree.children.find((childRow) => {\n\t\t\t\t\t\treturn childRow instanceof Row ? childRow.element === subject : false;\n\t\t\t\t\t});\n\n\t\t\t\t\tif(match){\n\t\t\t\t\t\tmatch = match.data;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}else if(subject === null){\n\t\t\t\tmatch = false;\n\t\t\t}\n\n\t\t}else if(typeof subject == \"undefined\"){\n\t\t\tmatch = false;\n\t\t}else{\n\t\t\t//subject should be treated as the index of the row\n\t\t\tmatch = parent.data[this.field].find((row) => {\n\t\t\t\treturn row.data[this.table.options.index] == subject;\n\t\t\t});\n\t\t}\n\n\t\tif(match){\n\n\t\t\tif(Array.isArray(parent.data[this.field])){\n\t\t\t\tmatch = parent.data[this.field].indexOf(match);\n\t\t\t}\n\n\t\t\tif(match == -1){\n\t\t\t\tmatch = false;\n\t\t\t}\n\t\t}\n\n\t\t//catch all for any other type of input\n\n\t\treturn match;\n\t}\n\n\tgetTreeChildren(row, component, recurse){\n\t\tvar config = row.modules.dataTree,\n\t\toutput = [];\n\n\t\tif(config && config.children){\n\n\t\t\tif(!Array.isArray(config.children)){\n\t\t\t\tconfig.children = this.generateChildren(row);\n\t\t\t}\n\n\t\t\tconfig.children.forEach((childRow) => {\n\t\t\t\tif(childRow instanceof Row){\n\t\t\t\t\toutput.push(component ? childRow.getComponent() : childRow);\n\n\t\t\t\t\tif(recurse){\n\t\t\t\t\t\toutput = output.concat(this.getTreeChildren(childRow, component, recurse));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn output;\n\t}\n\n\tgetChildField(){\n\t\treturn this.field;\n\t}\n\n\tredrawNeeded(data){\n\t\treturn (this.field ? typeof data[this.field] !== \"undefined\" : false) || (this.elementField ? typeof data[this.elementField] !== \"undefined\" : false);\n\t}\n}\n\nDataTree.moduleName = \"dataTree\";\n\nexport default DataTree;","import csv from './downloaders/csv.js';\nimport json from './downloaders/json.js';\nimport pdf from './downloaders/pdf.js';\nimport xlsx from './downloaders/xlsx.js';\nimport html from './downloaders/html.js';\nimport jsonLines from './downloaders/jsonLines.js';\n\nexport default {\n\tcsv:csv,\n\tjson:json,\n\tjsonLines:jsonLines,\n\tpdf:pdf,\n\txlsx:xlsx,\n\thtml:html,\n};","export default function(list, options = {}, setFileContents){\n\tvar delimiter = options.delimiter ? options.delimiter : \",\",\n\tfileContents = [],\n\theaders = [];\n\n\tlist.forEach((row) => {\n\t\tvar item = [];\n\n\t\tswitch(row.type){\n\t\t\tcase \"group\":\n\t\t\t\tconsole.warn(\"Download Warning - CSV downloader cannot process row groups\");\n\t\t\t\tbreak;\n\n\t\t\tcase \"calc\":\n\t\t\t\tconsole.warn(\"Download Warning - CSV downloader cannot process column calculations\");\n\t\t\t\tbreak;\n\n\t\t\tcase \"header\":\n\t\t\t\trow.columns.forEach((col, i) => {\n\t\t\t\t\tif(col && col.depth === 1){\n\t\t\t\t\t\theaders[i] = typeof col.value == \"undefined\" || col.value === null ? \"\" : ('\"' + String(col.value).split('\"').join('\"\"') + '\"');\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tbreak;\n\n\t\t\tcase \"row\":\n\t\t\t\trow.columns.forEach((col) => {\n\n\t\t\t\t\tif(col){\n\n\t\t\t\t\t\tswitch(typeof col.value){\n\t\t\t\t\t\t\tcase \"object\":\n\t\t\t\t\t\t\t\tcol.value = col.value !== null ? JSON.stringify(col.value) : \"\";\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase \"undefined\":\n\t\t\t\t\t\t\t\tcol.value = \"\";\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\titem.push('\"' + String(col.value).split('\"').join('\"\"') + '\"');\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tfileContents.push(item.join(delimiter));\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tif(headers.length){\n\t\tfileContents.unshift(headers.join(delimiter));\n\t}\n\n\tfileContents = fileContents.join(\"\\n\");\n\n\tif(options.bom){\n\t\tfileContents = \"\\ufeff\" + fileContents;\n\t}\n\n\tsetFileContents(fileContents, \"text/csv\");\n}\n","export default function(list, options, setFileContents){\n\tvar fileContents = [];\n\n\tlist.forEach((row) => {\n\t\tvar item = {};\n\n\t\tswitch(row.type){\n\t\t\tcase \"header\":\n\t\t\t\tbreak;\n\n\t\t\tcase \"group\":\n\t\t\t\tconsole.warn(\"Download Warning - JSON downloader cannot process row groups\");\n\t\t\t\tbreak;\n\n\t\t\tcase \"calc\":\n\t\t\t\tconsole.warn(\"Download Warning - JSON downloader cannot process column calculations\");\n\t\t\t\tbreak;\n\n\t\t\tcase \"row\":\n\t\t\t\trow.columns.forEach((col) => {\n\t\t\t\t\tif(col){\n\t\t\t\t\t\titem[col.component.getTitleDownload() || col.component.getField()] = col.value;\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tfileContents.push(item);\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tfileContents = JSON.stringify(fileContents, null, '\\t');\n\n\tsetFileContents(fileContents, \"application/json\");\n}","export default function (list, options, setFileContents) {\n\tconst fileContents = [];\n\n\tlist.forEach((row) => {\n\t\tconst item = {};\n\n\t\tswitch (row.type) {\n\t\t\tcase \"header\":\n\t\t\t\tbreak;\n\n\t\t\tcase \"group\":\n\t\t\t\tconsole.warn(\"Download Warning - JSON downloader cannot process row groups\");\n\t\t\t\tbreak;\n\n\t\t\tcase \"calc\":\n\t\t\t\tconsole.warn(\"Download Warning - JSON downloader cannot process column calculations\");\n\t\t\t\tbreak;\n\n\t\t\tcase \"row\":\n\t\t\t\trow.columns.forEach((col) => {\n\t\t\t\t\tif (col) {\n\t\t\t\t\t\titem[col.component.getTitleDownload() || col.component.getField()] = col.value;\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tfileContents.push(JSON.stringify(item));\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tsetFileContents(fileContents.join(\"\\n\"), \"application/x-ndjson\");\n}","export default function(list, options = {}, setFileContents){\n\tvar header = [],\n\tbody = [],\n\tautoTableParams = {},\n\trowGroupStyles = options.rowGroupStyles || {\n\t\tfontStyle: \"bold\",\n\t\tfontSize: 12,\n\t\tcellPadding: 6,\n\t\tfillColor: 220,\n\t},\n\trowCalcStyles = options.rowCalcStyles || {\n\t\tfontStyle: \"bold\",\n\t\tfontSize: 10,\n\t\tcellPadding: 4,\n\t\tfillColor: 232,\n\t},\n\tjsPDFParams = options.jsPDF || {},\n\ttitle = options.title ? options.title : \"\";\n\n\tif(!jsPDFParams.orientation){\n\t\tjsPDFParams.orientation = options.orientation || \"landscape\";\n\t}\n\n\tif(!jsPDFParams.unit){\n\t\tjsPDFParams.unit = \"pt\";\n\t}\n\n\t//parse row list\n\tlist.forEach((row) => {\n\t\tswitch(row.type){\n\t\t\tcase \"header\":\n\t\t\t\theader.push(parseRow(row));\n\t\t\t\tbreak;\n\n\t\t\tcase \"group\":\n\t\t\t\tbody.push(parseRow(row, rowGroupStyles));\n\t\t\t\tbreak;\n\n\t\t\tcase \"calc\":\n\t\t\t\tbody.push(parseRow(row, rowCalcStyles));\n\t\t\t\tbreak;\n\n\t\t\tcase \"row\":\n\t\t\t\tbody.push(parseRow(row));\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tfunction parseRow(row, styles){\n\t\tvar rowData = [];\n\n\t\trow.columns.forEach((col) =>{\n\t\t\tvar cell;\n\n\t\t\tif(col){\n\t\t\t\tswitch(typeof col.value){\n\t\t\t\t\tcase \"object\":\n\t\t\t\t\t\tcol.value = col.value !== null ? JSON.stringify(col.value) : \"\";\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"undefined\":\n\t\t\t\t\t\tcol.value = \"\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tcell = {\n\t\t\t\t\tcontent:col.value,\n\t\t\t\t\tcolSpan:col.width,\n\t\t\t\t\trowSpan:col.height,\n\t\t\t\t};\n\n\t\t\t\tif(styles){\n\t\t\t\t\tcell.styles = styles;\n\t\t\t\t}\n\n\t\t\t\trowData.push(cell);\n\t\t\t}\n\t\t});\n\n\t\treturn rowData;\n\t}\n\n\n\t//configure PDF\n\tvar doc = new jspdf.jsPDF(jsPDFParams); //set document to landscape, better for most tables\n\n\tif(options.autoTable){\n\t\tif(typeof options.autoTable === \"function\"){\n\t\t\tautoTableParams = options.autoTable(doc) || {};\n\t\t}else{\n\t\t\tautoTableParams = options.autoTable;\n\t\t}\n\t}\n\n\tif(title){\n\t\tautoTableParams.didDrawPage = function(data) {\n\t\t\tdoc.text(title, 40, 30);\n\t\t};\n\t}\n\n\tautoTableParams.head = header;\n\tautoTableParams.body = body;\n\n\tdoc.autoTable(autoTableParams);\n\n\tif(options.documentProcessing){\n\t\toptions.documentProcessing(doc);\n\t}\n\n\tsetFileContents(doc.output(\"arraybuffer\"), \"application/pdf\");\n}\n","import CoreFeature from '../../../../core/CoreFeature.js';\n\nexport default function(list, options, setFileContents){\n\tvar self = this,\n\tsheetName = options.sheetName || \"Sheet1\",\n\tworkbook = XLSX.utils.book_new(),\n\ttableFeatures = new CoreFeature(this),\n\tcompression = 'compress' in options ? options.compress : true,\n\twriteOptions = options.writeOptions || {bookType:'xlsx', bookSST:true, compression},\n\toutput;\n\n\twriteOptions.type = 'binary';\n\n\tworkbook.SheetNames = [];\n\tworkbook.Sheets = {};\n\n\tfunction generateSheet(){\n\t\tvar rows = [],\n\t\tmerges = [],\n\t\tworksheet = {},\n\t\trange = {s: {c:0, r:0}, e: {c:(list[0] ? list[0].columns.reduce((a, b) => a + (b && b.width ? b.width : 1), 0) : 0), r:list.length }};\n\n\t\t//parse row list\n\t\tlist.forEach((row, i) => {\n\t\t\tvar rowData = [];\n\n\t\t\trow.columns.forEach(function(col, j){\n\n\t\t\t\tif(col){\n\t\t\t\t\trowData.push(!(col.value instanceof Date) && typeof col.value === \"object\" ? JSON.stringify(col.value) : col.value);\n\n\t\t\t\t\tif(col.width > 1 || col.height > -1){\n\t\t\t\t\t\tif(col.height > 1 || col.width > 1){\n\t\t\t\t\t\t\tmerges.push({s:{r:i,c:j},e:{r:i + col.height - 1,c:j + col.width - 1}});\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\trowData.push(\"\");\n\t\t\t\t}\n\t\t\t});\n\n\t\t\trows.push(rowData);\n\t\t});\n\n\t\t//convert rows to worksheet\n\t\tXLSX.utils.sheet_add_aoa(worksheet, rows);\n\n\t\tworksheet['!ref'] = XLSX.utils.encode_range(range);\n\n\t\tif(merges.length){\n\t\t\tworksheet[\"!merges\"] = merges;\n\t\t}\n\n\t\treturn worksheet;\n\t}\n\n\tif(options.sheetOnly){\n\t\tsetFileContents(generateSheet());\n\t\treturn;\n\t}\n\n\tif(options.sheets){\n\t\tfor(var sheet in options.sheets){\n\n\t\t\tif(options.sheets[sheet] === true){\n\t\t\t\tworkbook.SheetNames.push(sheet);\n\t\t\t\tworkbook.Sheets[sheet] = generateSheet();\n\t\t\t}else{\n\n\t\t\t\tworkbook.SheetNames.push(sheet);\n\n\t\t\t\ttableFeatures.commsSend(options.sheets[sheet], \"download\", \"intercept\",{\n\t\t\t\t\ttype:\"xlsx\",\n\t\t\t\t\toptions:{sheetOnly:true},\n\t\t\t\t\tactive:self.active,\n\t\t\t\t\tintercept:function(data){\n\t\t\t\t\t\tworkbook.Sheets[sheet] = data;\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}else{\n\t\tworkbook.SheetNames.push(sheetName);\n\t\tworkbook.Sheets[sheetName] = generateSheet();\n\t}\n\n\tif(options.documentProcessing){\n\t\tworkbook = options.documentProcessing(workbook);\n\t}\n\n\t//convert workbook to binary array\n\tfunction s2ab(s) {\n\t\tvar buf = new ArrayBuffer(s.length);\n\t\tvar view = new Uint8Array(buf);\n\t\tfor (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;\n\t\treturn buf;\n\t}\n\n\toutput = XLSX.write(workbook, writeOptions);\n\n\tsetFileContents(s2ab(output), \"application/octet-stream\");\n}\n","export default function(list, options, setFileContents){\n\tif(this.modExists(\"export\", true)){\n\t\tsetFileContents(this.modules.export.generateHTMLTable(list), \"text/html\");\n\t}\n}","import Module from '../../core/Module.js';\n\nimport defaultDownloaders from './defaults/downloaders.js';\n\nclass Download extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.registerTableOption(\"downloadEncoder\", function(data, mimeType){\n\t\t\treturn new Blob([data],{type:mimeType});\n\t\t}); //function to manipulate download data\n\t\tthis.registerTableOption(\"downloadReady\", undefined); //warn of function deprecation\n\t\tthis.registerTableOption(\"downloadConfig\", {}); //download config\n\t\tthis.registerTableOption(\"downloadRowRange\", \"active\"); //restrict download to active rows only\n\n\t\tthis.registerColumnOption(\"download\");\n\t\tthis.registerColumnOption(\"titleDownload\");\n\t}\n\n\tinitialize(){\n\t\tthis.deprecatedOptionsCheck();\n\n\t\tthis.registerTableFunction(\"download\", this.download.bind(this));\n\t\tthis.registerTableFunction(\"downloadToTab\", this.downloadToTab.bind(this));\n\t}\n\n\tdeprecatedOptionsCheck(){\n\t\tthis.deprecationCheck(\"downloadReady\", \"downloadEncoder\");\n\t}\t\n\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\n\tdownloadToTab(type, filename, options, active){\n\t\tthis.download(type, filename, options, active, true);\n\t}\n\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\n\t//trigger file download\n\tdownload(type, filename, options, range, interceptCallback){\n\t\tvar downloadFunc = false;\n\n\t\tfunction buildLink(data, mime){\n\t\t\tif(interceptCallback){\n\t\t\t\tif(interceptCallback === true){\n\t\t\t\t\tthis.triggerDownload(data, mime, type, filename, true);\n\t\t\t\t}else{\n\t\t\t\t\tinterceptCallback(data);\n\t\t\t\t}\n\n\t\t\t}else{\n\t\t\t\tthis.triggerDownload(data, mime, type, filename);\n\t\t\t}\n\t\t}\n\n\t\tif(typeof type == \"function\"){\n\t\t\tdownloadFunc = type;\n\t\t}else{\n\t\t\tif(Download.downloaders[type]){\n\t\t\t\tdownloadFunc = Download.downloaders[type];\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Download Error - No such download type found: \", type);\n\t\t\t}\n\t\t}\n\n\t\tif(downloadFunc){\n\t\t\tvar list = this.generateExportList(range);\n\n\t\t\tdownloadFunc.call(this.table, list , options || {}, buildLink.bind(this));\n\t\t}\n\t}\n\n\tgenerateExportList(range){\n\t\tvar list = this.table.modules.export.generateExportList(this.table.options.downloadConfig, false, range || this.table.options.downloadRowRange, \"download\");\n\n\t\t//assign group header formatter\n\t\tvar groupHeader = this.table.options.groupHeaderDownload;\n\n\t\tif(groupHeader && !Array.isArray(groupHeader)){\n\t\t\tgroupHeader = [groupHeader];\n\t\t}\n\n\t\tlist.forEach((row) => {\n\t\t\tvar group;\n\n\t\t\tif(row.type === \"group\"){\n\t\t\t\tgroup = row.columns[0];\n\n\t\t\t\tif(groupHeader && groupHeader[row.indent]){\n\t\t\t\t\tgroup.value = groupHeader[row.indent](group.value, row.component._group.getRowCount(), row.component._group.getData(), row.component);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\treturn list;\n\t}\n\n\ttriggerDownload(data, mime, type, filename, newTab){\n\t\tvar element = document.createElement('a'),\n\t\tblob = this.table.options.downloadEncoder(data, mime);\n\n\t\tif(blob){\n\t\t\tif(newTab){\n\t\t\t\twindow.open(window.URL.createObjectURL(blob));\n\t\t\t}else{\n\t\t\t\tfilename = filename || \"Tabulator.\" + (typeof type === \"function\" ? \"txt\" : type);\n\t\t\t\t\n\t\t\t\tif(navigator.msSaveOrOpenBlob){\n\t\t\t\t\tnavigator.msSaveOrOpenBlob(blob, filename);\n\t\t\t\t}else{\n\t\t\t\t\telement.setAttribute('href', window.URL.createObjectURL(blob));\n\n\t\t\t\t\t//set file title\n\t\t\t\t\telement.setAttribute('download', filename);\n\n\t\t\t\t\t//trigger download\n\t\t\t\t\telement.style.display = 'none';\n\t\t\t\t\tdocument.body.appendChild(element);\n\t\t\t\t\telement.click();\n\n\t\t\t\t\t//remove temporary link element\n\t\t\t\t\tdocument.body.removeChild(element);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.dispatchExternal(\"downloadComplete\");\n\t\t}\n\t}\n\n\tcommsReceived(table, action, data){\n\t\tswitch(action){\n\t\t\tcase \"intercept\":\n\t\t\t\tthis.download(data.type, \"\", data.options, data.active, data.intercept);\n\t\t\t\tbreak;\n\t\t}\n\t}\n}\n\nDownload.moduleName = \"download\";\n\n//load defaults\nDownload.downloaders = defaultDownloaders;\n\nexport default Download;","export default function maskInput(el, options){\n\tvar mask = options.mask,\n\tmaskLetter = typeof options.maskLetterChar !== \"undefined\" ? options.maskLetterChar : \"A\",\n\tmaskNumber = typeof options.maskNumberChar !== \"undefined\" ? options.maskNumberChar : \"9\",\n\tmaskWildcard = typeof options.maskWildcardChar !== \"undefined\" ? options.maskWildcardChar : \"*\";\n\n\tfunction fillSymbols(index){\n\t\tvar symbol = mask[index];\n\t\tif(typeof symbol !== \"undefined\" && symbol !== maskWildcard && symbol !== maskLetter && symbol !== maskNumber){\n\t\t\tel.value = el.value + \"\" + symbol;\n\t\t\tfillSymbols(index+1);\n\t\t}\n\t}\n\n\tel.addEventListener(\"keydown\", (e) => {\n\t\tvar index = el.value.length,\n\t\tchar = e.key;\n\n\t\tif(e.keyCode > 46 && !e.ctrlKey && !e.metaKey){\n\t\t\tif(index >= mask.length){\n\t\t\t\te.preventDefault();\n\t\t\t\te.stopPropagation();\n\t\t\t\treturn false;\n\t\t\t}else{\n\t\t\t\tswitch(mask[index]){\n\t\t\t\t\tcase maskLetter:\n\t\t\t\t\t\tif(char.toUpperCase() == char.toLowerCase()){\n\t\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\t\te.stopPropagation();\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase maskNumber:\n\t\t\t\t\t\tif(isNaN(char)){\n\t\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\t\te.stopPropagation();\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase maskWildcard:\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tif(char !== mask[index]){\n\t\t\t\t\t\t\te.preventDefault();\n\t\t\t\t\t\t\te.stopPropagation();\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn;\n\t});\n\n\tel.addEventListener(\"keyup\", (e) => {\n\t\tif(e.keyCode > 46){\n\t\t\tif(options.maskAutoFill){\n\t\t\t\tfillSymbols(el.value.length);\n\t\t\t}\n\t\t}\n\t});\n\n\n\tif(!el.placeholder){\n\t\tel.placeholder = mask;\n\t}\n\n\tif(options.maskAutoFill){\n\t\tfillSymbols(el.value.length);\n\t}\n}","import maskInput from './inputMask.js';\nimport urlBuilder from '../Ajax/defaults/urlGenerator.js';\n\nexport default class Edit{\n\tconstructor(editor, cell, onRendered, success, cancel, editorParams){\n\t\tthis.edit = editor;\n\t\tthis.table = editor.table;\n\t\tthis.cell = cell;\n\t\tthis.params = this._initializeParams(editorParams);\n\t\t\n\t\tthis.data = [];\n\t\tthis.displayItems = [];\n\t\tthis.currentItems = [];\n\t\tthis.focusedItem = null;\n\t\t\n\t\tthis.input = this._createInputElement();\n\t\tthis.listEl = this._createListElement();\n\t\t\n\t\tthis.initialValues = null; \n\t\t\n\t\tthis.isFilter = cell.getType() === \"header\";\n\t\t\n\t\tthis.filterTimeout = null;\n\t\tthis.filtered = false;\n\t\tthis.typing = false;\n\t\t\n\t\tthis.values = []; \n\t\tthis.popup = null; \n\t\t\n\t\tthis.listIteration = 0;\n\t\t\n\t\tthis.lastAction=\"\";\n\t\tthis.filterTerm=\"\";\n\t\t\n\t\tthis.blurable = true;\n\t\t\n\t\tthis.actions = {\n\t\t\tsuccess:success,\n\t\t\tcancel:cancel\n\t\t};\n\t\t\n\t\tthis._deprecatedOptionsCheck();\n\t\tthis._initializeValue();\n\t\t\n\t\tonRendered(this._onRendered.bind(this));\n\t}\n\t\n\t_deprecatedOptionsCheck(){\n\t\tif(this.params.listItemFormatter){\n\t\t\tthis.cell.getTable().deprecationAdvisor.msg(\"The listItemFormatter editor param has been deprecated, please see the latest editor documentation for updated options\");\n\t\t}\n\t\t\n\t\tif(this.params.sortValuesList){\n\t\t\tthis.cell.getTable().deprecationAdvisor.msg(\"The sortValuesList editor param has been deprecated, please see the latest editor documentation for updated options\");\n\t\t}\n\t\t\n\t\tif(this.params.searchFunc){\n\t\t\tthis.cell.getTable().deprecationAdvisor.msg(\"The searchFunc editor param has been deprecated, please see the latest editor documentation for updated options\");\n\t\t}\n\t\t\n\t\tif(this.params.searchingPlaceholder){\n\t\t\tthis.cell.getTable().deprecationAdvisor.msg(\"The searchingPlaceholder editor param has been deprecated, please see the latest editor documentation for updated options\");\n\t\t}\n\t}\n\t\n\t_initializeValue(){\n\t\tvar initialValue = this.cell.getValue();\n\t\t\n\t\tif(typeof initialValue === \"undefined\" && typeof this.params.defaultValue !== \"undefined\"){\n\t\t\tinitialValue = this.params.defaultValue;\n\t\t}\n\t\t\n\t\tthis.initialValues = this.params.multiselect ? initialValue : [initialValue];\n\t\t\n\t\tif(this.isFilter){\n\t\t\tthis.input.value = this.initialValues ? this.initialValues.join(\",\") : \"\";\n\t\t\tthis.headerFilterInitialListGen(); \n\t\t}\n\t}\n\t\n\t_onRendered(){\n\t\tvar cellEl = this.cell.getElement();\n\t\t\n\t\tfunction clickStop(e){\n\t\t\te.stopPropagation();\n\t\t}\t\n\t\t\n\t\tif(!this.isFilter){\n\t\t\tthis.input.style.height = \"100%\";\n\t\t\tthis.input.focus({preventScroll: true});\n\t\t}\n\t\t\n\t\t\n\t\tcellEl.addEventListener(\"click\", clickStop);\n\t\t\n\t\tsetTimeout(() => {\n\t\t\tcellEl.removeEventListener(\"click\", clickStop);\n\t\t}, 1000);\n\t\t\n\t\tthis.input.addEventListener(\"mousedown\", this._preventPopupBlur.bind(this));\n\t}\n\t\n\t_createListElement(){\n\t\tvar listEl = document.createElement(\"div\");\n\t\tlistEl.classList.add(\"tabulator-edit-list\");\n\t\t\n\t\tlistEl.addEventListener(\"mousedown\", this._preventBlur.bind(this));\n\t\tlistEl.addEventListener(\"keydown\", this._inputKeyDown.bind(this));\n\t\t\n\t\treturn listEl;\n\t}\n\t\n\t_setListWidth(){\n\t\tvar element = this.isFilter ? this.input : this.cell.getElement();\n\t\t\n\t\tthis.listEl.style.minWidth = element.offsetWidth + \"px\";\n\t\t\n\t\tif(this.params.maxWidth){\n\t\t\tif(this.params.maxWidth === true){\n\t\t\t\tthis.listEl.style.maxWidth = element.offsetWidth + \"px\";\n\t\t\t}else if(typeof this.params.maxWidth === \"number\"){\n\t\t\t\tthis.listEl.style.maxWidth = this.params.maxWidth + \"px\";\n\t\t\t}else{\n\t\t\t\tthis.listEl.style.maxWidth = this.params.maxWidth;\n\t\t\t}\n\t\t}\n\t\t\n\t}\n\t\n\t_createInputElement(){\n\t\tvar attribs = this.params.elementAttributes;\n\t\tvar input = document.createElement(\"input\");\n\t\t\n\t\tinput.setAttribute(\"type\", this.params.clearable ? \"search\" : \"text\");\n\t\t\n\t\tinput.style.padding = \"4px\";\n\t\tinput.style.width = \"100%\";\n\t\tinput.style.boxSizing = \"border-box\";\n\t\t\n\t\tif(!this.params.autocomplete){\n\t\t\tinput.style.cursor = \"default\";\n\t\t\tinput.style.caretColor = \"transparent\";\n\t\t\t// input.readOnly = (this.edit.currentCell != false);\n\t\t}\n\t\t\n\t\tif(attribs && typeof attribs == \"object\"){\n\t\t\tfor (let key in attribs){\n\t\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\t\tkey = key.slice(1);\n\t\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + attribs[\"+\" + key]);\n\t\t\t\t}else{\n\t\t\t\t\tinput.setAttribute(key, attribs[key]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(this.params.mask){\n\t\t\tmaskInput(input, this.params);\n\t\t}\n\t\t\n\t\tthis._bindInputEvents(input);\n\t\t\n\t\treturn input;\n\t}\n\t\n\t_initializeParams(params){\n\t\tvar valueKeys = [\"values\", \"valuesURL\", \"valuesLookup\"],\n\t\tvalueCheck;\n\t\t\n\t\tparams = Object.assign({}, params);\n\t\t\n\t\tparams.verticalNavigation = params.verticalNavigation || \"editor\";\n\t\tparams.placeholderLoading = typeof params.placeholderLoading === \"undefined\" ? \"Searching ...\" : params.placeholderLoading;\n\t\tparams.placeholderEmpty = typeof params.placeholderEmpty === \"undefined\" ? \"No Results Found\" : params.placeholderEmpty;\n\t\tparams.filterDelay = typeof params.filterDelay === \"undefined\" ? 300 : params.filterDelay;\n\t\t\n\t\tparams.emptyValue = Object.keys(params).includes(\"emptyValue\") ? params.emptyValue : \"\";\n\t\t\n\t\tvalueCheck = Object.keys(params).filter(key => valueKeys.includes(key)).length;\n\t\t\n\t\tif(!valueCheck){\n\t\t\tconsole.warn(\"list editor config error - either the values, valuesURL, or valuesLookup option must be set\");\n\t\t}else if(valueCheck > 1){\n\t\t\tconsole.warn(\"list editor config error - only one of the values, valuesURL, or valuesLookup options can be set on the same editor\");\n\t\t}\n\t\t\n\t\tif(params.autocomplete){\n\t\t\tif(params.multiselect){\n\t\t\t\tparams.multiselect = false;\n\t\t\t\tconsole.warn(\"list editor config error - multiselect option is not available when autocomplete is enabled\");\n\t\t\t}\n\t\t}else{\n\t\t\tif(params.freetext){\n\t\t\t\tparams.freetext = false;\n\t\t\t\tconsole.warn(\"list editor config error - freetext option is only available when autocomplete is enabled\");\n\t\t\t}\n\t\t\t\n\t\t\tif(params.filterFunc){\n\t\t\t\tparams.filterFunc = false;\n\t\t\t\tconsole.warn(\"list editor config error - filterFunc option is only available when autocomplete is enabled\");\n\t\t\t}\n\t\t\t\n\t\t\tif(params.filterRemote){\n\t\t\t\tparams.filterRemote = false;\n\t\t\t\tconsole.warn(\"list editor config error - filterRemote option is only available when autocomplete is enabled\");\n\t\t\t}\n\t\t\t\n\t\t\tif(params.mask){\n\t\t\t\tparams.mask = false;\n\t\t\t\tconsole.warn(\"list editor config error - mask option is only available when autocomplete is enabled\");\n\t\t\t}\n\t\t\t\n\t\t\tif(params.allowEmpty){\n\t\t\t\tparams.allowEmpty = false;\n\t\t\t\tconsole.warn(\"list editor config error - allowEmpty option is only available when autocomplete is enabled\");\n\t\t\t}\n\t\t\t\n\t\t\tif(params.listOnEmpty){\n\t\t\t\tparams.listOnEmpty = false;\n\t\t\t\tconsole.warn(\"list editor config error - listOnEmpty option is only available when autocomplete is enabled\");\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(params.filterRemote && !(typeof params.valuesLookup === \"function\" || params.valuesURL)){\n\t\t\tparams.filterRemote = false;\n\t\t\tconsole.warn(\"list editor config error - filterRemote option should only be used when values list is populated from a remote source\");\n\t\t}\n\t\treturn params;\n\t}\n\t//////////////////////////////////////\n\t////////// Event Handling ////////////\n\t//////////////////////////////////////\n\t\n\t_bindInputEvents(input){\n\t\tinput.addEventListener(\"focus\", this._inputFocus.bind(this));\n\t\tinput.addEventListener(\"click\", this._inputClick.bind(this));\n\t\tinput.addEventListener(\"blur\", this._inputBlur.bind(this));\n\t\tinput.addEventListener(\"keydown\", this._inputKeyDown.bind(this));\n\t\tinput.addEventListener(\"search\", this._inputSearch.bind(this));\n\t\t\n\t\tif(this.params.autocomplete){\n\t\t\tinput.addEventListener(\"keyup\", this._inputKeyUp.bind(this));\n\t\t}\n\t}\n\t\n\t\n\t_inputFocus(e){\n\t\tthis.rebuildOptionsList();\n\t}\n\t\n\t_filter(){\n\t\tif(this.params.filterRemote){\n\t\t\tclearTimeout(this.filterTimeout);\n\t\t\t\n\t\t\tthis.filterTimeout = setTimeout(() => {\n\t\t\t\tthis.rebuildOptionsList();\n\t\t\t}, this.params.filterDelay);\n\t\t}else{\n\t\t\tthis._filterList();\n\t\t}\n\t}\n\t\n\t_inputClick(e){\n\t\te.stopPropagation();\n\t}\n\t\n\t_inputBlur(e){\n\t\tif(this.blurable){\n\t\t\tif(this.popup){\n\t\t\t\tthis.popup.hide();\n\t\t\t}else{\n\t\t\t\tthis._resolveValue(true);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_inputSearch(){\n\t\tthis._clearChoices();\n\t}\n\t\n\t_inputKeyDown(e){\n\t\tswitch(e.keyCode){\n\t\t\t\n\t\t\tcase 38: //up arrow\n\t\t\t\tthis._keyUp(e);\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 40: //down arrow\n\t\t\t\tthis._keyDown(e);\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 37: //left arrow\n\t\t\tcase 39: //right arrow\n\t\t\t\tthis._keySide(e);\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 13: //enter\n\t\t\t\tthis._keyEnter();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 27: //escape\n\t\t\t\tthis._keyEsc();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 36: //home\n\t\t\tcase 35: //end\n\t\t\t\tthis._keyHomeEnd(e);\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 9: //tab\n\t\t\t\tthis._keyTab(e);\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tdefault:\n\t\t\t\tthis._keySelectLetter(e);\n\t\t}\n\t}\n\t\n\t_inputKeyUp(e){\n\t\tswitch(e.keyCode){\n\t\t\tcase 38: //up arrow\n\t\t\tcase 37: //left arrow\n\t\t\tcase 39: //up arrow\n\t\t\tcase 40: //right arrow\n\t\t\tcase 13: //enter\n\t\t\tcase 27: //escape\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tdefault:\n\t\t\t\tthis._keyAutoCompLetter(e);\n\t\t}\n\t}\n\t\n\t_preventPopupBlur(){\n\t\tif(this.popup){\n\t\t\tthis.popup.blockHide();\n\t\t}\n\t\t\n\t\tsetTimeout(() =>{\n\t\t\tif(this.popup){\n\t\t\t\tthis.popup.restoreHide();\n\t\t\t}\n\t\t}, 10);\n\t}\n\t\n\t_preventBlur(){\n\t\tthis.blurable = false;\n\t\t\n\t\tsetTimeout(() =>{\n\t\t\tthis.blurable = true;\n\t\t}, 10);\n\t}\n\t\n\t//////////////////////////////////////\n\t//////// Keyboard Navigation /////////\n\t//////////////////////////////////////\n\t\n\t_keyTab(e){\n\t\tif(this.params.autocomplete && this.lastAction === \"typing\"){\n\t\t\tthis._resolveValue(true);\n\t\t}else{\n\t\t\tif(this.focusedItem){\n\t\t\t\tthis._chooseItem(this.focusedItem, true);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_keyUp(e){\n\t\tvar index = this.displayItems.indexOf(this.focusedItem);\n\t\t\n\t\tif(this.params.verticalNavigation == \"editor\" || (this.params.verticalNavigation == \"hybrid\" && index)){\n\t\t\te.stopImmediatePropagation();\n\t\t\te.stopPropagation();\n\t\t\te.preventDefault();\n\t\t\t\n\t\t\tif(index > 0){\n\t\t\t\tthis._focusItem(this.displayItems[index - 1]);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_keyDown(e){\n\t\tvar index = this.displayItems.indexOf(this.focusedItem);\n\t\t\n\t\tif(this.params.verticalNavigation == \"editor\" || (this.params.verticalNavigation == \"hybrid\" && index < this.displayItems.length - 1)){\n\t\t\te.stopImmediatePropagation();\n\t\t\te.stopPropagation();\n\t\t\te.preventDefault();\n\t\t\t\n\t\t\tif(index < this.displayItems.length - 1){\n\t\t\t\tif(index == -1){\n\t\t\t\t\tthis._focusItem(this.displayItems[0]);\n\t\t\t\t}else{\n\t\t\t\t\tthis._focusItem(this.displayItems[index + 1]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_keySide(e){\n\t\tif(!this.params.autocomplete){\n\t\t\te.stopImmediatePropagation();\n\t\t\te.stopPropagation();\n\t\t\te.preventDefault();\n\t\t}\n\t}\n\t\n\t_keyEnter(e){\n\t\tif(this.params.autocomplete && this.lastAction === \"typing\"){\n\t\t\tthis._resolveValue(true);\n\t\t}else{\n\t\t\tif(this.focusedItem){\n\t\t\t\tthis._chooseItem(this.focusedItem);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_keyEsc(e){\n\t\tthis._cancel();\n\t}\n\t\n\t_keyHomeEnd(e){\n\t\tif(this.params.autocomplete){\n\t\t\t//prevent table navigation while using input element\n\t\t\te.stopImmediatePropagation();\n\t\t}\n\t}\n\t\n\t_keySelectLetter(e){\n\t\tif(!this.params.autocomplete){\n\t\t\t// if(this.edit.currentCell === false){\n\t\t\te.preventDefault();\n\t\t\t// }\n\t\t\t\n\t\t\tif(e.keyCode >= 38 && e.keyCode <= 90){\n\t\t\t\tthis._scrollToValue(e.keyCode);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_keyAutoCompLetter(e){\n\t\tthis._filter();\n\t\tthis.lastAction = \"typing\";\n\t\tthis.typing = true;\n\t}\n\t\n\t\n\t_scrollToValue(char){\n\t\tclearTimeout(this.filterTimeout);\n\t\t\n\t\tvar character = String.fromCharCode(char).toLowerCase();\n\t\tthis.filterTerm += character.toLowerCase();\n\t\t\n\t\tvar match = this.displayItems.find((item) => {\n\t\t\treturn typeof item.label !== \"undefined\" && item.label.toLowerCase().startsWith(this.filterTerm);\n\t\t});\n\t\t\n\t\tif(match){\n\t\t\tthis._focusItem(match);\n\t\t}\n\t\t\n\t\tthis.filterTimeout = setTimeout(() => {\n\t\t\tthis.filterTerm = \"\";\n\t\t}, 800);\n\t}\n\t\n\t_focusItem(item){\n\t\tthis.lastAction = \"focus\";\n\t\t\n\t\tif(this.focusedItem && this.focusedItem.element){\n\t\t\tthis.focusedItem.element.classList.remove(\"focused\");\n\t\t}\n\t\t\n\t\tthis.focusedItem = item;\n\t\t\n\t\tif(item && item.element){\n\t\t\titem.element.classList.add(\"focused\");\n\t\t\titem.element.scrollIntoView({behavior: 'smooth', block: 'nearest', inline: 'start'});\n\t\t}\n\t}\n\t\n\t\n\t//////////////////////////////////////\n\t/////// Data List Generation /////////\n\t//////////////////////////////////////\n\theaderFilterInitialListGen(){\n\t\tthis._generateOptions(true);\n\t}\n\t\n\trebuildOptionsList(){\n\t\tthis._generateOptions()\n\t\t\t.then(this._sortOptions.bind(this))\n\t\t\t.then(this._buildList.bind(this))\n\t\t\t.then(this._showList.bind(this))\n\t\t\t.catch((e) => {\n\t\t\t\tif(!Number.isInteger(e)){\n\t\t\t\t\tconsole.error(\"List generation error\", e);\n\t\t\t\t}\n\t\t\t});\n\t}\n\t\n\t_filterList(){\n\t\tthis._buildList(this._filterOptions());\n\t\tthis._showList();\n\t}\n\t\n\t_generateOptions(silent){\n\t\tvar values = [];\n\t\tvar iteration = ++ this.listIteration;\n\t\t\n\t\tthis.filtered = false;\n\t\t\n\t\tif(this.params.values){\n\t\t\tvalues = this.params.values;\n\t\t}else if (this.params.valuesURL){\n\t\t\tvalues = this._ajaxRequest(this.params.valuesURL, this.input.value);\n\t\t}else{\n\t\t\tif(typeof this.params.valuesLookup === \"function\"){\n\t\t\t\tvalues = this.params.valuesLookup(this.cell, this.input.value);\n\t\t\t}else if(this.params.valuesLookup){\n\t\t\t\tvalues = this._uniqueColumnValues(this.params.valuesLookupField);\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(values instanceof Promise){\n\t\t\tif(!silent){\n\t\t\t\tthis._addPlaceholder(this.params.placeholderLoading);\n\t\t\t}\n\t\t\t\n\t\t\treturn values.then()\n\t\t\t\t.then((responseValues) => {\n\t\t\t\t\tif(this.listIteration === iteration){\n\t\t\t\t\t\treturn this._parseList(responseValues);\n\t\t\t\t\t}else{\n\t\t\t\t\t\treturn Promise.reject(iteration);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t}else{\n\t\t\treturn Promise.resolve(this._parseList(values));\n\t\t}\n\t}\n\t\n\t_addPlaceholder(contents){\n\t\tvar placeholder = document.createElement(\"div\");\n\t\t\n\t\tif(typeof contents === \"function\"){\n\t\t\tcontents = contents(this.cell.getComponent(), this.listEl);\n\t\t}\n\t\t\n\t\tif(contents){\n\t\t\tthis._clearList();\n\t\t\t\n\t\t\tif(contents instanceof HTMLElement){\n\t\t\t\tplaceholder = contents;\n\t\t\t}else{\n\t\t\t\tplaceholder.classList.add(\"tabulator-edit-list-placeholder\");\n\t\t\t\tplaceholder.innerHTML = contents;\n\t\t\t}\n\t\t\t\n\t\t\tthis.listEl.appendChild(placeholder);\n\t\t\t\n\t\t\tthis._showList();\n\t\t}\n\t}\n\t\n\t_ajaxRequest(url, term){\n\t\tvar params = this.params.filterRemote ? {term:term} : {};\n\t\turl = urlBuilder(url, {}, params);\n\t\t\n\t\treturn fetch(url)\n\t\t\t.then((response)=>{\n\t\t\t\tif(response.ok) {\n\t\t\t\t\treturn response.json()\n\t\t\t\t\t\t.catch((error)=>{\n\t\t\t\t\t\t\tconsole.warn(\"List Ajax Load Error - Invalid JSON returned\", error);\n\t\t\t\t\t\t\treturn Promise.reject(error);\n\t\t\t\t\t\t});\n\t\t\t\t}else{\n\t\t\t\t\tconsole.error(\"List Ajax Load Error - Connection Error: \" + response.status, response.statusText);\n\t\t\t\t\treturn Promise.reject(response);\n\t\t\t\t}\n\t\t\t})\n\t\t\t.catch((error)=>{\n\t\t\t\tconsole.error(\"List Ajax Load Error - Connection Error: \", error);\n\t\t\t\treturn Promise.reject(error);\n\t\t\t});\n\t}\n\t\n\t_uniqueColumnValues(field){\n\t\tvar output = {},\n\t\tdata = this.table.getData(this.params.valuesLookup),\n\t\tcolumn;\n\t\t\n\t\tif(field){\n\t\t\tcolumn = this.table.columnManager.getColumnByField(field);\n\t\t}else{\n\t\t\tcolumn = this.cell.getColumn()._getSelf();\n\t\t}\n\t\t\n\t\tif(column){\n\t\t\tdata.forEach((row) => {\n\t\t\t\tvar val = column.getFieldValue(row);\n\t\t\t\t\n\t\t\t\tif(val !== null && typeof val !== \"undefined\" && val !== \"\"){\n\t\t\t\t\toutput[val] = true;\n\t\t\t\t}\n\t\t\t});\n\t\t}else{\n\t\t\tconsole.warn(\"unable to find matching column to create select lookup list:\", field);\n\t\t\toutput = [];\n\t\t}\n\t\t\n\t\treturn Object.keys(output);\n\t}\n\t\n\t\n\t_parseList(inputValues){\n\t\tvar data = [];\n\t\t\n\t\tif(!Array.isArray(inputValues)){\n\t\t\tinputValues = Object.entries(inputValues).map(([key, value]) => {\n\t\t\t\treturn {\n\t\t\t\t\tlabel:value,\n\t\t\t\t\tvalue:key,\n\t\t\t\t};\n\t\t\t});\n\t\t}\n\t\t\n\t\tinputValues.forEach((value) => {\n\t\t\tif(typeof value !== \"object\"){\n\t\t\t\tvalue = {\n\t\t\t\t\tlabel:value,\n\t\t\t\t\tvalue:value,\n\t\t\t\t};\n\t\t\t}\n\t\t\t\n\t\t\tthis._parseListItem(value, data, 0);\n\t\t});\n\t\t\n\t\tif(!this.currentItems.length && this.params.freetext){\n\t\t\tthis.input.value = this.initialValues;\n\t\t\tthis.typing = true;\n\t\t\tthis.lastAction = \"typing\";\n\t\t}\n\t\t\n\t\tthis.data = data;\n\t\t\n\t\treturn data; \n\t}\n\t\n\t_parseListItem(option, data, level){\n\t\tvar item = {};\n\t\t\n\t\tif(option.options){\n\t\t\titem = this._parseListGroup(option, level + 1);\n\t\t}else{\n\t\t\titem = {\n\t\t\t\tlabel:option.label,\n\t\t\t\tvalue:option.value,\n\t\t\t\titemParams:option.itemParams,\n\t\t\t\telementAttributes: option.elementAttributes,\n\t\t\t\telement:false,\n\t\t\t\tselected:false,\n\t\t\t\tvisible:true,\n\t\t\t\tlevel:level,\n\t\t\t\toriginal:option,\n\t\t\t};\n\t\t\t\n\t\t\tif(this.initialValues && this.initialValues.indexOf(option.value) > -1){\n\t\t\t\tthis._chooseItem(item, true);\n\t\t\t}\n\t\t}\n\t\t\n\t\tdata.push(item);\n\t}\n\t\n\t_parseListGroup(option, level){\n\t\tvar item = {\n\t\t\tlabel:option.label,\n\t\t\tgroup:true,\n\t\t\titemParams:option.itemParams,\n\t\t\telementAttributes:option.elementAttributes,\n\t\t\telement:false,\n\t\t\tvisible:true,\n\t\t\tlevel:level,\n\t\t\toptions:[],\n\t\t\toriginal:option,\n\t\t};\n\t\t\n\t\toption.options.forEach((child) => {\n\t\t\tthis._parseListItem(child, item.options, level);\n\t\t});\n\t\t\n\t\treturn item;\n\t}\n\t\n\t_sortOptions(options){\n\t\tvar sorter;\n\t\t\n\t\tif(this.params.sort){\n\t\t\tsorter = typeof this.params.sort === \"function\" ? this.params.sort : this._defaultSortFunction.bind(this);\n\t\t\t\n\t\t\tthis._sortGroup(sorter, options);\n\t\t}\n\t\t\n\t\treturn options;\n\t}\n\t\n\t_sortGroup(sorter, options){\n\t\toptions.sort((a,b) => {\n\t\t\treturn sorter(a.label, b.label, a.value, b.value, a.original, b.original);\n\t\t});\n\t\t\n\t\toptions.forEach((option) => {\n\t\t\tif(option.group){\n\t\t\t\tthis._sortGroup(sorter, option.options);\n\t\t\t}\n\t\t});\n\t}\n\t\n\t_defaultSortFunction(as, bs){\n\t\tvar a, b, a1, b1, i= 0, L, rx = /(\\d+)|(\\D+)/g, rd = /\\d/;\n\t\tvar emptyAlign = 0;\n\t\t\n\t\tif(this.params.sort === \"desc\"){\n\t\t\t[as, bs] = [bs, as];\n\t\t}\n\t\t\n\t\t//handle empty values\n\t\tif(!as && as!== 0){\n\t\t\temptyAlign = !bs && bs!== 0 ? 0 : -1;\n\t\t}else if(!bs && bs!== 0){\n\t\t\temptyAlign = 1;\n\t\t}else{\n\t\t\tif(isFinite(as) && isFinite(bs)) return as - bs;\n\t\t\ta = String(as).toLowerCase();\n\t\t\tb = String(bs).toLowerCase();\n\t\t\tif(a === b) return 0;\n\t\t\tif(!(rd.test(a) && rd.test(b))) return a > b ? 1 : -1;\n\t\t\ta = a.match(rx);\n\t\t\tb = b.match(rx);\n\t\t\tL = a.length > b.length ? b.length : a.length;\n\t\t\twhile(i < L){\n\t\t\t\ta1= a[i];\n\t\t\t\tb1= b[i++];\n\t\t\t\tif(a1 !== b1){\n\t\t\t\t\tif(isFinite(a1) && isFinite(b1)){\n\t\t\t\t\t\tif(a1.charAt(0) === \"0\") a1 = \".\" + a1;\n\t\t\t\t\t\tif(b1.charAt(0) === \"0\") b1 = \".\" + b1;\n\t\t\t\t\t\treturn a1 - b1;\n\t\t\t\t\t}\n\t\t\t\t\telse return a1 > b1 ? 1 : -1;\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\treturn a.length > b.length;\n\t\t}\n\t\t\n\t\treturn emptyAlign;\n\t}\n\t\n\t_filterOptions(){\n\t\tvar filterFunc = this.params.filterFunc || this._defaultFilterFunc,\n\t\tterm = this.input.value;\n\t\t\n\t\tif(term){\n\t\t\tthis.filtered = true;\n\t\t\t\n\t\t\tthis.data.forEach((item) => {\n\t\t\t\tthis._filterItem(filterFunc, term, item);\n\t\t\t});\n\t\t}else{\n\t\t\tthis.filtered = false;\n\t\t}\n\t\t\n\t\treturn this.data;\n\t}\n\t\n\t_filterItem(func, term, item){\n\t\tvar matches = false;\n\t\t\n\t\tif(!item.group){\n\t\t\titem.visible = func(term, item.label, item.value, item.original);\n\t\t}else{\n\t\t\titem.options.forEach((option) => {\n\t\t\t\tif(this._filterItem(func, term, option)){\n\t\t\t\t\tmatches = true;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\titem.visible = matches;\n\t\t}\n\t\t\n\t\treturn item.visible;\n\t}\n\t\n\t_defaultFilterFunc(term, label, value, item){\n\t\tterm = String(term).toLowerCase();\n\t\t\n\t\tif(label !== null && typeof label !== \"undefined\"){\n\t\t\tif(String(label).toLowerCase().indexOf(term) > -1 || String(value).toLowerCase().indexOf(term) > -1){\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\t//////////////////////////////////////\n\t/////////// Display List /////////////\n\t//////////////////////////////////////\n\t\n\t_clearList(){\n\t\twhile(this.listEl.firstChild) this.listEl.removeChild(this.listEl.firstChild);\n\t\t\n\t\tthis.displayItems = [];\n\t}\n\t\n\t_buildList(data){\n\t\tthis._clearList();\n\t\t\n\t\tdata.forEach((option) => {\n\t\t\tthis._buildItem(option);\n\t\t});\n\t\t\n\t\tif(!this.displayItems.length){\n\t\t\tthis._addPlaceholder(this.params.placeholderEmpty);\n\t\t} \n\t}\n\t\n\t_buildItem(item){\n\t\tvar el = item.element,\n\t\tcontents;\n\t\t\n\t\tif(!this.filtered || item.visible){\n\t\t\t\n\t\t\tif(!el){\n\t\t\t\tel = document.createElement(\"div\");\n\t\t\t\tel.tabIndex = 0;\n\t\t\t\t\n\t\t\t\tcontents = this.params.itemFormatter ? this.params.itemFormatter(item.label, item.value, item.original, el) : item.label;\n\t\t\t\t\n\t\t\t\tif(contents instanceof HTMLElement){\n\t\t\t\t\tel.appendChild(contents);\n\t\t\t\t}else{\n\t\t\t\t\tel.innerHTML = contents;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(item.group){\n\t\t\t\t\tel.classList.add(\"tabulator-edit-list-group\");\n\t\t\t\t}else{\n\t\t\t\t\tel.classList.add(\"tabulator-edit-list-item\");\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tel.classList.add(\"tabulator-edit-list-group-level-\" + item.level);\n\t\t\t\t\n\t\t\t\tif(item.elementAttributes && typeof item.elementAttributes == \"object\"){\n\t\t\t\t\tfor (let key in item.elementAttributes){\n\t\t\t\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\t\t\t\tkey = key.slice(1);\n\t\t\t\t\t\t\tel.setAttribute(key, this.input.getAttribute(key) + item.elementAttributes[\"+\" + key]);\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tel.setAttribute(key, item.elementAttributes[key]);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(item.group){\n\t\t\t\t\tel.addEventListener(\"click\", this._groupClick.bind(this, item));\n\t\t\t\t}else{\n\t\t\t\t\tel.addEventListener(\"click\", this._itemClick.bind(this, item));\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tel.addEventListener(\"mousedown\", this._preventBlur.bind(this));\n\t\t\t\t\n\t\t\t\titem.element = el;\n\t\t\t}\n\t\t\t\n\t\t\tthis._styleItem(item);\n\t\t\t\n\t\t\tthis.listEl.appendChild(el);\n\t\t\t\n\t\t\tif(item.group){\n\t\t\t\titem.options.forEach((option) => {\n\t\t\t\t\tthis._buildItem(option);\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tthis.displayItems.push(item);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_showList(){\n\t\tvar startVis = this.popup && this.popup.isVisible();\n\t\t\n\t\tif(this.input.parentNode){\n\t\t\tif(this.params.autocomplete && this.input.value === \"\" && !this.params.listOnEmpty){\n\t\t\t\tif(this.popup){\n\t\t\t\t\tthis.popup.hide(true);\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\t\t\t\n\t\t\tthis._setListWidth();\n\t\t\t\n\t\t\tif(!this.popup){\n\t\t\t\tthis.popup = this.edit.popup(this.listEl);\n\t\t\t}\n\t\t\t\n\t\t\tthis.popup.show(this.cell.getElement(), \"bottom\");\n\t\t\t\n\t\t\tif(!startVis){\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis.popup.hideOnBlur(this._resolveValue.bind(this, true));\n\t\t\t\t}, 10);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_styleItem(item){\n\t\tif(item && item.element){\n\t\t\tif(item.selected){\n\t\t\t\titem.element.classList.add(\"active\");\n\t\t\t}else{\n\t\t\t\titem.element.classList.remove(\"active\");\n\t\t\t}\n\t\t}\n\t}\n\t\n\t//////////////////////////////////////\n\t///////// User Interaction ///////////\n\t//////////////////////////////////////\n\t\n\t_itemClick(item, e){\n\t\te.stopPropagation();\n\t\t\n\t\tthis._chooseItem(item);\n\t}\n\t\n\t_groupClick(item, e){\n\t\te.stopPropagation();\n\t}\n\t\n\t\n\t//////////////////////////////////////\n\t////// Current Item Management ///////\n\t//////////////////////////////////////\n\t\n\t_cancel(){\n\t\tthis.popup.hide(true);\n\t\tthis.actions.cancel();\n\t}\n\t\n\t_clearChoices(){\n\t\tthis.typing = true;\n\t\t\n\t\tthis.currentItems.forEach((item) => {\n\t\t\titem.selected = false;\n\t\t\tthis._styleItem(item);\n\t\t});\n\t\t\n\t\tthis.currentItems = [];\n\t\t\n\t\tthis.focusedItem = null;\n\t}\n\t\n\t_chooseItem(item, silent){\n\t\tvar index;\n\t\t\n\t\tthis.typing = false;\n\t\t\n\t\tif(this.params.multiselect){\n\t\t\tindex = this.currentItems.indexOf(item);\n\t\t\t\n\t\t\tif(index > -1){\n\t\t\t\tthis.currentItems.splice(index, 1);\n\t\t\t\titem.selected = false;\n\t\t\t}else{\n\t\t\t\tthis.currentItems.push(item);\n\t\t\t\titem.selected = true;\n\t\t\t}\n\t\t\t\n\t\t\tthis.input.value = this.currentItems.map(item => item.label).join(\",\");\n\t\t\t\n\t\t\tthis._styleItem(item);\n\t\t\t\n\t\t}else{\n\t\t\tthis.currentItems = [item];\n\t\t\titem.selected = true;\n\t\t\t\n\t\t\tthis.input.value = item.label;\n\t\t\t\n\t\t\tthis._styleItem(item);\n\t\t\t\n\t\t\tif(!silent){\n\t\t\t\tthis._resolveValue();\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis._focusItem(item);\n\t}\n\t\n\t_resolveValue(blur){\n\t\tvar output, initialValue;\n\t\t\n\t\tif(this.popup){\n\t\t\tthis.popup.hide(true);\n\t\t}\n\t\t\n\t\tif(this.params.multiselect){\n\t\t\toutput = this.currentItems.map(item => item.value);\n\t\t}else{\n\t\t\tif(blur && this.params.autocomplete && this.typing){\n\t\t\t\tif(this.params.freetext || (this.params.allowEmpty && this.input.value === \"\")){\n\t\t\t\t\toutput = this.input.value;\n\t\t\t\t}else{\n\t\t\t\t\tthis.actions.cancel();\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(this.currentItems[0]){\n\t\t\t\t\toutput = this.currentItems[0].value;\n\t\t\t\t}else{\n\t\t\t\t\tinitialValue = Array.isArray(this.initialValues) ? this.initialValues[0] : this.initialValues;\n\t\t\t\t\t\n\t\t\t\t\tif(initialValue === null || typeof initialValue === \"undefined\" || initialValue === \"\"){\n\t\t\t\t\t\toutput = initialValue;\n\t\t\t\t\t}else{\n\t\t\t\t\t\toutput = this.params.emptyValue;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(output === \"\"){\n\t\t\toutput = this.params.emptyValue;\n\t\t}\n\t\t\n\t\tthis.actions.success(output);\n\t\t\n\t\tif(this.isFilter){\n\t\t\tthis.initialValues = output && !Array.isArray(output) ? [output] : output;\n\t\t\tthis.currentItems = [];\n\t\t}\n\t}\n\t\n}\n","import input from './editors/input.js';\nimport textarea from './editors/textarea.js';\nimport number from './editors/number.js';\nimport range from './editors/range.js';\nimport date from './editors/date.js';\nimport time from './editors/time.js';\nimport datetime from './editors/datetime.js';\nimport select from './editors/select.js';\nimport list from './editors/list.js';\nimport autocomplete from './editors/autocomplete.js';\nimport star from './editors/star.js';\nimport progress from './editors/progress.js';\nimport tickCross from './editors/tickCross.js';\n\nexport default {\n\tinput:input,\n\ttextarea:textarea,\n\tnumber:number,\n\trange:range,\n\tdate:date,\n\ttime:time,\n\tdatetime:datetime,\n\tselect:select,\n\tlist:list,\n\tautocomplete:autocomplete,\n\tstar:star,\n\tprogress:progress,\n\ttickCross:tickCross,\n};","import maskInput from '../../inputMask.js';\n\n//input element\nexport default function(cell, onRendered, success, cancel, editorParams){\n\t//create and style input\n\tvar cellValue = cell.getValue(),\n\tinput = document.createElement(\"input\");\n\n\tinput.setAttribute(\"type\", editorParams.search ? \"search\" : \"text\");\n\n\tinput.style.padding = \"4px\";\n\tinput.style.width = \"100%\";\n\tinput.style.boxSizing = \"border-box\";\n\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\n\tinput.value = typeof cellValue !== \"undefined\" ? cellValue : \"\";\n\n\tonRendered(function(){\n\t\tif(cell.getType() === \"cell\"){\n\t\t\tinput.focus({preventScroll: true});\n\t\t\tinput.style.height = \"100%\";\n\n\t\t\tif(editorParams.selectContents){\n\t\t\t\tinput.select();\n\t\t\t}\n\t\t}\n\t});\n\n\tfunction onChange(e){\n\t\tif(((cellValue === null || typeof cellValue === \"undefined\") && input.value !== \"\") || input.value !== cellValue){\n\t\t\tif(success(input.value)){\n\t\t\t\tcellValue = input.value; //persist value if successfully validated incase editor is used as header filter\n\t\t\t}\n\t\t}else{\n\t\t\tcancel();\n\t\t}\n\t}\n\n\t//submit new value on blur or change\n\tinput.addEventListener(\"change\", onChange);\n\tinput.addEventListener(\"blur\", onChange);\n\n\t//submit new value on enter\n\tinput.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\t// case 9:\n\t\t\tcase 13:\n\t\t\t\tonChange(e);\n\t\t\t\tbreak;\n\n\t\t\tcase 27:\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\n\t\t\tcase 35:\n\t\t\tcase 36:\n\t\t\t\te.stopPropagation();\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tif(editorParams.mask){\n\t\tmaskInput(input, editorParams);\n\t}\n\n\treturn input;\n}","import maskInput from '../../inputMask.js';\n\n//resizable text area element\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar cellValue = cell.getValue(),\n\tvertNav = editorParams.verticalNavigation || \"hybrid\",\n\tvalue = String(cellValue !== null && typeof cellValue !== \"undefined\" ? cellValue : \"\"),\n\tinput = document.createElement(\"textarea\"),\n\tscrollHeight = 0;\n\n\t//create and style input\n\tinput.style.display = \"block\";\n\tinput.style.padding = \"2px\";\n\tinput.style.height = \"100%\";\n\tinput.style.width = \"100%\";\n\tinput.style.boxSizing = \"border-box\";\n\tinput.style.whiteSpace = \"pre-wrap\";\n\tinput.style.resize = \"none\";\n\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\n\tinput.value = value;\n\n\tonRendered(function(){\n\t\tif(cell.getType() === \"cell\"){\n\t\t\tinput.focus({preventScroll: true});\n\t\t\tinput.style.height = \"100%\";\n\n\t\t\tinput.scrollHeight;\n\t\t\tinput.style.height = input.scrollHeight + \"px\";\n\t\t\tcell.getRow().normalizeHeight();\n\n\t\t\tif(editorParams.selectContents){\n\t\t\t\tinput.select();\n\t\t\t}\n\t\t}\n\t});\n\n\tfunction onChange(e){\n\n\t\tif(((cellValue === null || typeof cellValue === \"undefined\") && input.value !== \"\") || input.value !== cellValue){\n\n\t\t\tif(success(input.value)){\n\t\t\t\tcellValue = input.value; //persist value if successfully validated incase editor is used as header filter\n\t\t\t}\n\n\t\t\tsetTimeout(function(){\n\t\t\t\tcell.getRow().normalizeHeight();\n\t\t\t},300);\n\t\t}else{\n\t\t\tcancel();\n\t\t}\n\t}\n\n\t//submit new value on blur or change\n\tinput.addEventListener(\"change\", onChange);\n\tinput.addEventListener(\"blur\", onChange);\n\n\tinput.addEventListener(\"keyup\", function(){\n\n\t\tinput.style.height = \"\";\n\n\t\tvar heightNow = input.scrollHeight;\n\n\t\tinput.style.height = heightNow + \"px\";\n\n\t\tif(heightNow != scrollHeight){\n\t\t\tscrollHeight = heightNow;\n\t\t\tcell.getRow().normalizeHeight();\n\t\t}\n\t});\n\n\tinput.addEventListener(\"keydown\", function(e){\n\n\t\tswitch(e.keyCode){\n\n\t\t\tcase 13:\n\t\t\t\tif(e.shiftKey && editorParams.shiftEnterSubmit){\n\t\t\t\t\tonChange(e);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 27:\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\n\t\t\tcase 38: //up arrow\n\t\t\t\tif(vertNav == \"editor\" || (vertNav == \"hybrid\" && input.selectionStart)){\n\t\t\t\t\te.stopImmediatePropagation();\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\n\t\t\tcase 40: //down arrow\n\t\t\t\tif(vertNav == \"editor\" || (vertNav == \"hybrid\" && input.selectionStart !== input.value.length)){\n\t\t\t\t\te.stopImmediatePropagation();\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 35:\n\t\t\tcase 36:\n\t\t\t\te.stopPropagation();\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tif(editorParams.mask){\n\t\tmaskInput(input, editorParams);\n\t}\n\n\treturn input;\n}","import maskInput from '../../inputMask.js';\n\n//input element with type of number\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar cellValue = cell.getValue(),\n\tvertNav = editorParams.verticalNavigation || \"editor\",\n\tinput = document.createElement(\"input\");\n\n\tinput.setAttribute(\"type\", \"number\");\n\n\tif(typeof editorParams.max != \"undefined\"){\n\t\tinput.setAttribute(\"max\", editorParams.max);\n\t}\n\n\tif(typeof editorParams.min != \"undefined\"){\n\t\tinput.setAttribute(\"min\", editorParams.min);\n\t}\n\n\tif(typeof editorParams.step != \"undefined\"){\n\t\tinput.setAttribute(\"step\", editorParams.step);\n\t}\n\n\t//create and style input\n\tinput.style.padding = \"4px\";\n\tinput.style.width = \"100%\";\n\tinput.style.boxSizing = \"border-box\";\n\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\n\tinput.value = cellValue;\n\n\tvar blurFunc = function(e){\n\t\tonChange();\n\t};\n\n\tonRendered(function () {\n\t\tif(cell.getType() === \"cell\"){\n\t\t\t//submit new value on blur\n\t\t\tinput.removeEventListener(\"blur\", blurFunc);\n\n\t\t\tinput.focus({preventScroll: true});\n\t\t\tinput.style.height = \"100%\";\n\n\t\t\t//submit new value on blur\n\t\t\tinput.addEventListener(\"blur\", blurFunc);\n\n\t\t\tif(editorParams.selectContents){\n\t\t\t\tinput.select();\n\t\t\t}\n\t\t}\n\t});\n\n\tfunction onChange(){\n\t\tvar value = input.value;\n\n\t\tif(!isNaN(value) && value !==\"\"){\n\t\t\tvalue = Number(value);\n\t\t}\n\n\t\tif(value !== cellValue){\n\t\t\tif(success(value)){\n\t\t\t\tcellValue = value; //persist value if successfully validated incase editor is used as header filter\n\t\t\t}\n\t\t}else{\n\t\t\tcancel();\n\t\t}\n\t}\n\n\t//submit new value on enter\n\tinput.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\tcase 13:\n\t\t\t// case 9:\n\t\t\t\tonChange();\n\t\t\t\tbreak;\n\n\t\t\tcase 27:\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\n\t\t\tcase 38: //up arrow\n\t\t\tcase 40: //down arrow\n\t\t\t\tif(vertNav == \"editor\"){\n\t\t\t\t\te.stopImmediatePropagation();\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 35:\n\t\t\tcase 36:\n\t\t\t\te.stopPropagation();\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tif(editorParams.mask){\n\t\tmaskInput(input, editorParams);\n\t}\n\n\treturn input;\n}","//input element with type of number\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar cellValue = cell.getValue(),\n\tinput = document.createElement(\"input\");\n\t\n\tinput.setAttribute(\"type\", \"range\");\n\t\n\tif (typeof editorParams.max != \"undefined\") {\n\t\tinput.setAttribute(\"max\", editorParams.max);\n\t}\n\t\n\tif (typeof editorParams.min != \"undefined\") {\n\t\tinput.setAttribute(\"min\", editorParams.min);\n\t}\n\t\n\tif (typeof editorParams.step != \"undefined\") {\n\t\tinput.setAttribute(\"step\", editorParams.step);\n\t}\n\t\n\t//create and style input\n\tinput.style.padding = \"4px\";\n\tinput.style.width = \"100%\";\n\tinput.style.boxSizing = \"border-box\";\n\t\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tinput.value = cellValue;\n\t\n\tonRendered(function () {\n\t\tif(cell.getType() === \"cell\"){\n\t\t\tinput.focus({preventScroll: true});\n\t\t\tinput.style.height = \"100%\";\n\t\t}\n\t});\n\t\n\tfunction onChange(){\n\t\tvar value = input.value;\n\t\t\n\t\tif(!isNaN(value) && value !==\"\"){\n\t\t\tvalue = Number(value);\n\t\t}\n\t\t\n\t\tif(value != cellValue){\n\t\t\tif(success(value)){\n\t\t\t\tcellValue = value; //persist value if successfully validated incase editor is used as header filter\n\t\t\t}\n\t\t}else{\n\t\t\tcancel();\n\t\t}\n\t}\n\t\n\t//submit new value on blur\n\tinput.addEventListener(\"blur\", function(e){\n\t\tonChange();\n\t});\n\t\n\t//submit new value on enter\n\tinput.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\tcase 13:\n\t\t\t// case 9:\n\t\t\t\tonChange();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 27:\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\t\t}\n\t});\n\t\n\treturn input;\n}","//input element\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar inputFormat = editorParams.format,\n\tvertNav = editorParams.verticalNavigation || \"editor\",\n\tDT = inputFormat ? (window.DateTime || luxon.DateTime) : null;\n\t\n\t//create and style input\n\tvar cellValue = cell.getValue(),\n\tinput = document.createElement(\"input\");\n\t\n\tfunction convertDate(value){\n\t\tvar newDatetime;\n\t\t\n\t\tif(DT.isDateTime(value)){\n\t\t\tnewDatetime = value;\n\t\t}else if(inputFormat === \"iso\"){\n\t\t\tnewDatetime = DT.fromISO(String(value));\n\t\t}else{\n\t\t\tnewDatetime = DT.fromFormat(String(value), inputFormat);\n\t\t}\n\t\t\n\t\treturn newDatetime.toFormat(\"yyyy-MM-dd\");\n\t}\n\t\n\tinput.type = \"date\";\n\tinput.style.padding = \"4px\";\n\tinput.style.width = \"100%\";\n\tinput.style.boxSizing = \"border-box\";\n\n\tif(editorParams.max){\n\t\tinput.setAttribute(\"max\", inputFormat ? convertDate(editorParams.max) : editorParams.max);\n\t}\n\n\tif(editorParams.min){\n\t\tinput.setAttribute(\"min\", inputFormat ? convertDate(editorParams.min) : editorParams.min);\n\t}\n\t\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tcellValue = typeof cellValue !== \"undefined\" ? cellValue : \"\";\n\t\n\tif(inputFormat){\n\t\tif(DT){\t\t\n\t\t\tcellValue = convertDate(cellValue);\t\t\t\n\t\t}else{\n\t\t\tconsole.error(\"Editor Error - 'date' editor 'format' param is dependant on luxon.js\");\n\t\t}\n\t}\n\t\n\tinput.value = cellValue;\n\t\n\tonRendered(function(){\n\t\tif(cell.getType() === \"cell\"){\n\t\t\tinput.focus({preventScroll: true});\n\t\t\tinput.style.height = \"100%\";\n\t\t\t\n\t\t\tif(editorParams.selectContents){\n\t\t\t\tinput.select();\n\t\t\t}\n\t\t}\n\t});\n\t\n\tfunction onChange(){\n\t\tvar value = input.value,\n\t\tluxDate;\n\t\t\n\t\tif(((cellValue === null || typeof cellValue === \"undefined\") && value !== \"\") || value !== cellValue){\n\t\t\t\n\t\t\tif(value && inputFormat){\n\t\t\t\tluxDate = DT.fromFormat(String(value), \"yyyy-MM-dd\");\n\n\t\t\t\tswitch(inputFormat){\n\t\t\t\t\tcase true:\n\t\t\t\t\t\tvalue = luxDate;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"iso\":\n\t\t\t\t\t\tvalue = luxDate.toISO();\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tvalue = luxDate.toFormat(inputFormat);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tif(success(value)){\n\t\t\t\tcellValue = input.value; //persist value if successfully validated incase editor is used as header filter\n\t\t\t}\n\t\t}else{\n\t\t\tcancel();\n\t\t}\n\t}\n\t\n\t//submit new value on blur\n\tinput.addEventListener(\"blur\", function(e) {\n\t\tif (e.relatedTarget || e.rangeParent || e.explicitOriginalTarget !== input) {\n\t\t\tonChange(); // only on a \"true\" blur; not when focusing browser's date/time picker\n\t\t}\n\t});\n\t\n\t//submit new value on enter\n\tinput.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\t// case 9:\n\t\t\tcase 13:\n\t\t\t\tonChange();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 27:\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 35:\n\t\t\tcase 36:\n\t\t\t\te.stopPropagation();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 38: //up arrow\n\t\t\tcase 40: //down arrow\n\t\t\t\tif(vertNav == \"editor\"){\n\t\t\t\t\te.stopImmediatePropagation();\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t}\n\t});\n\t\n\treturn input;\n}\n","//input element\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar inputFormat = editorParams.format,\n\tvertNav = editorParams.verticalNavigation || \"editor\",\n\tDT = inputFormat ? (window.DateTime || luxon.DateTime) : null, \n\tnewDatetime;\n\t\n\t//create and style input\n\tvar cellValue = cell.getValue(),\n\tinput = document.createElement(\"input\");\n\t\n\tinput.type = \"time\";\n\tinput.style.padding = \"4px\";\n\tinput.style.width = \"100%\";\n\tinput.style.boxSizing = \"border-box\";\n\t\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tcellValue = typeof cellValue !== \"undefined\" ? cellValue : \"\";\n\t\n\tif(inputFormat){\n\t\tif(DT){\n\t\t\tif(DT.isDateTime(cellValue)){\n\t\t\t\tnewDatetime = cellValue;\n\t\t\t}else if(inputFormat === \"iso\"){\n\t\t\t\tnewDatetime = DT.fromISO(String(cellValue));\n\t\t\t}else{\n\t\t\t\tnewDatetime = DT.fromFormat(String(cellValue), inputFormat);\n\t\t\t}\n\t\t\t\n\t\t\tcellValue = newDatetime.toFormat(\"hh:mm\");\n\t\t\t\n\t\t}else{\n\t\t\tconsole.error(\"Editor Error - 'date' editor 'format' param is dependant on luxon.js\");\n\t\t}\n\t}\n\t\n\tinput.value = cellValue;\n\t\n\tonRendered(function(){\n\t\tif(cell.getType() == \"cell\"){\n\t\t\tinput.focus({preventScroll: true});\n\t\t\tinput.style.height = \"100%\";\n\t\t\t\n\t\t\tif(editorParams.selectContents){\n\t\t\t\tinput.select();\n\t\t\t}\n\t\t}\n\t});\n\t\n\tfunction onChange(){\n\t\tvar value = input.value,\n\t\tluxTime;\n\t\t\n\t\tif(((cellValue === null || typeof cellValue === \"undefined\") && value !== \"\") || value !== cellValue){\n\t\t\t\n\t\t\tif(value && inputFormat){\n\t\t\t\tluxTime = DT.fromFormat(String(value), \"hh:mm\");\n\n\t\t\t\tswitch(inputFormat){\n\t\t\t\t\tcase true:\n\t\t\t\t\t\tvalue = luxTime;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"iso\":\n\t\t\t\t\t\tvalue = luxTime.toISO();\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tvalue = luxTime.toFormat(inputFormat);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tif(success(value)){\n\t\t\t\tcellValue = input.value; //persist value if successfully validated incase editor is used as header filter\n\t\t\t}\n\t\t}else{\n\t\t\tcancel();\n\t\t}\n\t}\n\t\n\t//submit new value on blur\n\tinput.addEventListener(\"blur\", function(e) {\n\t\tif (e.relatedTarget || e.rangeParent || e.explicitOriginalTarget !== input) {\n\t\t\tonChange(); // only on a \"true\" blur; not when focusing browser's date/time picker\n\t\t}\n\t});\n\t\n\t//submit new value on enter\n\tinput.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\t// case 9:\n\t\t\tcase 13:\n\t\t\t\tonChange();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 27:\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 35:\n\t\t\tcase 36:\n\t\t\t\te.stopPropagation();\n\t\t\t\tbreak;\n\n\t\t\tcase 38: //up arrow\n\t\t\tcase 40: //down arrow\n\t\t\t\tif(vertNav == \"editor\"){\n\t\t\t\t\te.stopImmediatePropagation();\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t}\n\t});\n\t\n\treturn input;\n}\n","//input element\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar inputFormat = editorParams.format,\n\tvertNav = editorParams.verticalNavigation || \"editor\",\n\tDT = inputFormat ? (window.DateTime || luxon.DateTime) : null, \n\tnewDatetime;\n\t\n\t//create and style input\n\tvar cellValue = cell.getValue(),\n\tinput = document.createElement(\"input\");\n\t\n\tinput.type = \"datetime-local\";\n\tinput.style.padding = \"4px\";\n\tinput.style.width = \"100%\";\n\tinput.style.boxSizing = \"border-box\";\n\t\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tcellValue = typeof cellValue !== \"undefined\" ? cellValue : \"\";\n\t\n\tif(inputFormat){\n\t\tif(DT){\n\t\t\tif(DT.isDateTime(cellValue)){\n\t\t\t\tnewDatetime = cellValue;\n\t\t\t}else if(inputFormat === \"iso\"){\n\t\t\t\tnewDatetime = DT.fromISO(String(cellValue));\n\t\t\t}else{\n\t\t\t\tnewDatetime = DT.fromFormat(String(cellValue), inputFormat);\n\t\t\t}\n\t\t\t\n\t\t\tcellValue = newDatetime.toFormat(\"yyyy-MM-dd\") + \"T\" + newDatetime.toFormat(\"hh:mm\");\n\t\t}else{\n\t\t\tconsole.error(\"Editor Error - 'date' editor 'format' param is dependant on luxon.js\");\n\t\t}\n\t}\n\t\n\tinput.value = cellValue;\n\t\n\tonRendered(function(){\n\t\tif(cell.getType() === \"cell\"){\n\t\t\tinput.focus({preventScroll: true});\n\t\t\tinput.style.height = \"100%\";\n\t\t\t\n\t\t\tif(editorParams.selectContents){\n\t\t\t\tinput.select();\n\t\t\t}\n\t\t}\n\t});\n\t\n\tfunction onChange(){\n\t\tvar value = input.value,\n\t\tluxDateTime;\n\t\t\n\t\tif(((cellValue === null || typeof cellValue === \"undefined\") && value !== \"\") || value !== cellValue){\n\n\t\t\tif(value && inputFormat){\n\t\t\t\tluxDateTime = DT.fromISO(String(value));\n\n\t\t\t\tswitch(inputFormat){\n\t\t\t\t\tcase true:\n\t\t\t\t\t\tvalue = luxDateTime;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"iso\":\n\t\t\t\t\t\tvalue = luxDateTime.toISO();\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tvalue = luxDateTime.toFormat(inputFormat);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tif(success(value)){\n\t\t\t\tcellValue = input.value; //persist value if successfully validated incase editor is used as header filter\n\t\t\t}\n\t\t}else{\n\t\t\tcancel();\n\t\t}\n\t}\n\t\n\t//submit new value on blur\n\tinput.addEventListener(\"blur\", function(e) {\n\t\tif (e.relatedTarget || e.rangeParent || e.explicitOriginalTarget !== input) {\n\t\t\tonChange(); // only on a \"true\" blur; not when focusing browser's date/time picker\n\t\t}\n\t});\n\t\n\t//submit new value on enter\n\tinput.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\t// case 9:\n\t\t\tcase 13:\n\t\t\t\tonChange();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 27:\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase 35:\n\t\t\tcase 36:\n\t\t\t\te.stopPropagation();\n\t\t\t\tbreak;\n\n\t\t\tcase 38: //up arrow\n\t\t\tcase 40: //down arrow\n\t\t\t\tif(vertNav == \"editor\"){\n\t\t\t\t\te.stopImmediatePropagation();\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t}\n\t});\n\t\n\treturn input;\n}\n","import List from '../../List.js';\n\nexport default function(cell, onRendered, success, cancel, editorParams){\n\n\tthis.deprecationMsg(\"The select editor has been deprecated, please use the new list editor\");\n\n\tvar list = new List(this, cell, onRendered, success, cancel, editorParams);\n\n\treturn list.input;\n}","import List from '../../List.js';\n\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar list = new List(this, cell, onRendered, success, cancel, editorParams);\n\n\treturn list.input;\n}","import List from '../../List.js';\n\nexport default function(cell, onRendered, success, cancel, editorParams){\n\n\tthis.deprecationMsg(\"The autocomplete editor has been deprecated, please use the new list editor with the 'autocomplete' editorParam\");\n\n\teditorParams.autocomplete = true;\n\n\tvar list = new List(this, cell, onRendered, success, cancel, editorParams);\n\n\treturn list.input;\n}","//star rating\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar self = this,\n\telement = cell.getElement(),\n\tvalue = cell.getValue(),\n\tmaxStars = element.getElementsByTagName(\"svg\").length || 5,\n\tsize = element.getElementsByTagName(\"svg\")[0] ? element.getElementsByTagName(\"svg\")[0].getAttribute(\"width\") : 14,\n\tstars = [],\n\tstarsHolder = document.createElement(\"div\"),\n\tstar = document.createElementNS('http://www.w3.org/2000/svg', \"svg\");\n\n\n\t//change star type\n\tfunction starChange(val){\n\t\tstars.forEach(function(star, i){\n\t\t\tif(i < val){\n\t\t\t\tif(self.table.browser == \"ie\"){\n\t\t\t\t\tstar.setAttribute(\"class\", \"tabulator-star-active\");\n\t\t\t\t}else{\n\t\t\t\t\tstar.classList.replace(\"tabulator-star-inactive\", \"tabulator-star-active\");\n\t\t\t\t}\n\n\t\t\t\tstar.innerHTML = '';\n\t\t\t}else{\n\t\t\t\tif(self.table.browser == \"ie\"){\n\t\t\t\t\tstar.setAttribute(\"class\", \"tabulator-star-inactive\");\n\t\t\t\t}else{\n\t\t\t\t\tstar.classList.replace(\"tabulator-star-active\", \"tabulator-star-inactive\");\n\t\t\t\t}\n\n\t\t\t\tstar.innerHTML = '';\n\t\t\t}\n\t\t});\n\t}\n\n\t//build stars\n\tfunction buildStar(i){\n\n\t\tvar starHolder = document.createElement(\"span\");\n\t\tvar nextStar = star.cloneNode(true);\n\n\t\tstars.push(nextStar);\n\n\t\tstarHolder.addEventListener(\"mouseenter\", function(e){\n\t\t\te.stopPropagation();\n\t\t\te.stopImmediatePropagation();\n\t\t\tstarChange(i);\n\t\t});\n\n\t\tstarHolder.addEventListener(\"mousemove\", function(e){\n\t\t\te.stopPropagation();\n\t\t\te.stopImmediatePropagation();\n\t\t});\n\n\t\tstarHolder.addEventListener(\"click\", function(e){\n\t\t\te.stopPropagation();\n\t\t\te.stopImmediatePropagation();\n\t\t\tsuccess(i);\n\t\t\telement.blur();\n\t\t});\n\n\t\tstarHolder.appendChild(nextStar);\n\t\tstarsHolder.appendChild(starHolder);\n\n\t}\n\n\t//handle keyboard navigation value change\n\tfunction changeValue(val){\n\t\tvalue = val;\n\t\tstarChange(val);\n\t}\n\n\t//style cell\n\telement.style.whiteSpace = \"nowrap\";\n\telement.style.overflow = \"hidden\";\n\telement.style.textOverflow = \"ellipsis\";\n\n\t//style holding element\n\tstarsHolder.style.verticalAlign = \"middle\";\n\tstarsHolder.style.display = \"inline-block\";\n\tstarsHolder.style.padding = \"4px\";\n\n\t//style star\n\tstar.setAttribute(\"width\", size);\n\tstar.setAttribute(\"height\", size);\n\tstar.setAttribute(\"viewBox\", \"0 0 512 512\");\n\tstar.setAttribute(\"xml:space\", \"preserve\");\n\tstar.style.padding = \"0 1px\";\n\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tstarsHolder.setAttribute(key, starsHolder.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tstarsHolder.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\n\t//create correct number of stars\n\tfor(var i=1;i<= maxStars;i++){\n\t\tbuildStar(i);\n\t}\n\n\t//ensure value does not exceed number of stars\n\tvalue = Math.min(parseInt(value), maxStars);\n\n\t// set initial styling of stars\n\tstarChange(value);\n\n\tstarsHolder.addEventListener(\"mousemove\", function(e){\n\t\tstarChange(0);\n\t});\n\n\tstarsHolder.addEventListener(\"click\", function(e){\n\t\tsuccess(0);\n\t});\n\n\telement.addEventListener(\"blur\", function(e){\n\t\tcancel();\n\t});\n\n\t//allow key based navigation\n\telement.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\tcase 39: //right arrow\n\t\t\t\tchangeValue(value + 1);\n\t\t\t\tbreak;\n\n\t\t\tcase 37: //left arrow\n\t\t\t\tchangeValue(value - 1);\n\t\t\t\tbreak;\n\n\t\t\tcase 13: //enter\n\t\t\t\tsuccess(value);\n\t\t\t\tbreak;\n\n\t\t\tcase 27: //escape\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\treturn starsHolder;\n}","//draggable progress bar\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar element = cell.getElement(),\n\tmax = typeof editorParams.max === \"undefined\" ? ((element.getElementsByTagName(\"div\")[0] && element.getElementsByTagName(\"div\")[0].getAttribute(\"max\")) || 100) : editorParams.max,\n\tmin = typeof editorParams.min === \"undefined\" ? ((element.getElementsByTagName(\"div\")[0] && element.getElementsByTagName(\"div\")[0].getAttribute(\"min\")) || 0) : editorParams.min,\n\tpercent = (max - min) / 100,\n\tvalue = cell.getValue() || 0,\n\thandle = document.createElement(\"div\"),\n\tbar = document.createElement(\"div\"),\n\tmouseDrag, mouseDragWidth;\n\n\t//set new value\n\tfunction updateValue(){\n\t\tvar style = window.getComputedStyle(element, null);\n\n\t\tvar calcVal = (percent * Math.round(bar.offsetWidth / ((element.clientWidth - parseInt(style.getPropertyValue(\"padding-left\")) - parseInt(style.getPropertyValue(\"padding-right\")))/100))) + min;\n\t\tsuccess(calcVal);\n\t\telement.setAttribute(\"aria-valuenow\", calcVal);\n\t\telement.setAttribute(\"aria-label\", value);\n\t}\n\n\t//style handle\n\thandle.style.position = \"absolute\";\n\thandle.style.right = \"0\";\n\thandle.style.top = \"0\";\n\thandle.style.bottom = \"0\";\n\thandle.style.width = \"5px\";\n\thandle.classList.add(\"tabulator-progress-handle\");\n\n\t//style bar\n\tbar.style.display = \"inline-block\";\n\tbar.style.position = \"relative\";\n\t// bar.style.top = \"8px\";\n\t// bar.style.bottom = \"8px\";\n\t// bar.style.left = \"4px\";\n\t// bar.style.marginRight = \"4px\";\n\tbar.style.height = \"100%\";\n\tbar.style.backgroundColor = \"#488CE9\";\n\tbar.style.maxWidth = \"100%\";\n\tbar.style.minWidth = \"0%\";\n\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tbar.setAttribute(key, bar.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tbar.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\n\t//style cell\n\telement.style.padding = \"4px 4px\";\n\n\t//make sure value is in range\n\tvalue = Math.min(parseFloat(value), max);\n\tvalue = Math.max(parseFloat(value), min);\n\n\t//workout percentage\n\tvalue = Math.round((value - min) / percent);\n\t// bar.style.right = value + \"%\";\n\tbar.style.width = value + \"%\";\n\n\telement.setAttribute(\"aria-valuemin\", min);\n\telement.setAttribute(\"aria-valuemax\", max);\n\n\tbar.appendChild(handle);\n\n\thandle.addEventListener(\"mousedown\", function(e){\n\t\tmouseDrag = e.screenX;\n\t\tmouseDragWidth = bar.offsetWidth;\n\t});\n\n\thandle.addEventListener(\"mouseover\", function(){\n\t\thandle.style.cursor = \"ew-resize\";\n\t});\n\n\telement.addEventListener(\"mousemove\", function(e){\n\t\tif(mouseDrag){\n\t\t\tbar.style.width = (mouseDragWidth + e.screenX - mouseDrag) + \"px\";\n\t\t}\n\t});\n\n\telement.addEventListener(\"mouseup\", function(e){\n\t\tif(mouseDrag){\n\t\t\te.stopPropagation();\n\t\t\te.stopImmediatePropagation();\n\n\t\t\tmouseDrag = false;\n\t\t\tmouseDragWidth = false;\n\n\t\t\tupdateValue();\n\t\t}\n\t});\n\n\t//allow key based navigation\n\telement.addEventListener(\"keydown\", function(e){\n\t\tswitch(e.keyCode){\n\t\t\tcase 39: //right arrow\n\t\t\t\te.preventDefault();\n\t\t\t\tbar.style.width = (bar.clientWidth + element.clientWidth/100) + \"px\";\n\t\t\t\tbreak;\n\n\t\t\tcase 37: //left arrow\n\t\t\t\te.preventDefault();\n\t\t\t\tbar.style.width = (bar.clientWidth - element.clientWidth/100) + \"px\";\n\t\t\t\tbreak;\n\n\t\t\tcase 9: //tab\n\t\t\tcase 13: //enter\n\t\t\t\tupdateValue();\n\t\t\t\tbreak;\n\n\t\t\tcase 27: //escape\n\t\t\t\tcancel();\n\t\t\t\tbreak;\n\n\t\t}\n\t});\n\n\telement.addEventListener(\"blur\", function(){\n\t\tcancel();\n\t});\n\n\treturn bar;\n}","//checkbox\nexport default function(cell, onRendered, success, cancel, editorParams){\n\tvar value = cell.getValue(),\n\tinput = document.createElement(\"input\"),\n\ttristate = editorParams.tristate,\n\tindetermValue = typeof editorParams.indeterminateValue === \"undefined\" ? null : editorParams.indeterminateValue,\n\tindetermState = false,\n\ttrueValueSet = Object.keys(editorParams).includes(\"trueValue\"),\n\tfalseValueSet = Object.keys(editorParams).includes(\"falseValue\");\n\t\n\tinput.setAttribute(\"type\", \"checkbox\");\n\tinput.style.marginTop = \"5px\";\n\tinput.style.boxSizing = \"border-box\";\n\t\n\tif(editorParams.elementAttributes && typeof editorParams.elementAttributes == \"object\"){\n\t\tfor (let key in editorParams.elementAttributes){\n\t\t\tif(key.charAt(0) == \"+\"){\n\t\t\t\tkey = key.slice(1);\n\t\t\t\tinput.setAttribute(key, input.getAttribute(key) + editorParams.elementAttributes[\"+\" + key]);\n\t\t\t}else{\n\t\t\t\tinput.setAttribute(key, editorParams.elementAttributes[key]);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tinput.value = value;\n\t\n\tif(tristate && (typeof value === \"undefined\" || value === indetermValue || value === \"\")){\n\t\tindetermState = true;\n\t\tinput.indeterminate = true;\n\t}\n\t\n\tif(this.table.browser != \"firefox\" && this.table.browser != \"safari\"){ //prevent blur issue on mac firefox\n\t\tonRendered(function(){\n\t\t\tif(cell.getType() === \"cell\"){\n\t\t\t\tinput.focus({preventScroll: true});\n\t\t\t}\n\t\t});\n\t}\n\t\n\tinput.checked = trueValueSet ? value === editorParams.trueValue : (value === true || value === \"true\" || value === \"True\" || value === 1);\n\t\n\tfunction setValue(blur){\n\t\tvar checkedValue = input.checked;\n\t\t\n\t\tif(trueValueSet && checkedValue){\n\t\t\tcheckedValue = editorParams.trueValue;\n\t\t}else if(falseValueSet && !checkedValue){\n\t\t\tcheckedValue = editorParams.falseValue;\n\t\t}\n\t\t\n\t\tif(tristate){\n\t\t\tif(!blur){\n\t\t\t\tif(input.checked && !indetermState){\n\t\t\t\t\tinput.checked = false;\n\t\t\t\t\tinput.indeterminate = true;\n\t\t\t\t\tindetermState = true;\n\t\t\t\t\treturn indetermValue;\n\t\t\t\t}else{\n\t\t\t\t\tindetermState = false;\n\t\t\t\t\treturn checkedValue;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(indetermState){\n\t\t\t\t\treturn indetermValue;\n\t\t\t\t}else{\n\t\t\t\t\treturn checkedValue;\n\t\t\t\t}\n\t\t\t}\n\t\t}else{\n\t\t\treturn checkedValue;\n\t\t}\n\t}\n\t\n\t//submit new value on blur\n\tinput.addEventListener(\"change\", function(e){\n\t\tsuccess(setValue());\n\t});\n\n\tinput.addEventListener(\"blur\", function(e){\n\t\tsuccess(setValue(true));\n\t});\n\t\n\t//submit new value on enter\n\tinput.addEventListener(\"keydown\", function(e){\n\t\tif(e.keyCode == 13){\n\t\t\tsuccess(setValue());\n\t\t}\n\t\tif(e.keyCode == 27){\n\t\t\tcancel();\n\t\t}\n\t});\n\t\n\treturn input;\n}","import Module from '../../core/Module.js';\nimport Helpers from '../../core/tools/Helpers.js';\n\nimport defaultEditors from './defaults/editors.js';\n\nclass Edit extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.currentCell = false; //hold currently editing cell\n\t\tthis.mouseClick = false; //hold mousedown state to prevent click binding being overridden by editor opening\n\t\tthis.recursionBlock = false; //prevent focus recursion\n\t\tthis.invalidEdit = false;\n\t\tthis.editedCells = [];\n\t\t\n\t\tthis.editors = Edit.editors;\n\t\t\n\t\tthis.registerColumnOption(\"editable\");\n\t\tthis.registerColumnOption(\"editor\");\n\t\tthis.registerColumnOption(\"editorParams\");\n\t\t\n\t\tthis.registerColumnOption(\"cellEditing\");\n\t\tthis.registerColumnOption(\"cellEdited\");\n\t\tthis.registerColumnOption(\"cellEditCancelled\");\n\t\t\n\t\tthis.registerTableFunction(\"getEditedCells\", this.getEditedCells.bind(this));\n\t\tthis.registerTableFunction(\"clearCellEdited\", this.clearCellEdited.bind(this));\n\t\tthis.registerTableFunction(\"navigatePrev\", this.navigatePrev.bind(this));\n\t\tthis.registerTableFunction(\"navigateNext\", this.navigateNext.bind(this));\n\t\tthis.registerTableFunction(\"navigateLeft\", this.navigateLeft.bind(this));\n\t\tthis.registerTableFunction(\"navigateRight\", this.navigateRight.bind(this));\n\t\tthis.registerTableFunction(\"navigateUp\", this.navigateUp.bind(this));\n\t\tthis.registerTableFunction(\"navigateDown\", this.navigateDown.bind(this));\n\t\t\n\t\tthis.registerComponentFunction(\"cell\", \"isEdited\", this.cellIsEdited.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"clearEdited\", this.clearEdited.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"edit\", this.editCell.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"cancelEdit\", this.cellCancelEdit.bind(this));\n\t\t\n\t\tthis.registerComponentFunction(\"cell\", \"navigatePrev\", this.navigatePrev.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"navigateNext\", this.navigateNext.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"navigateLeft\", this.navigateLeft.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"navigateRight\", this.navigateRight.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"navigateUp\", this.navigateUp.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"navigateDown\", this.navigateDown.bind(this));\n\t}\n\t\n\tinitialize(){\n\t\tthis.subscribe(\"cell-init\", this.bindEditor.bind(this));\n\t\tthis.subscribe(\"cell-delete\", this.clearEdited.bind(this));\n\t\tthis.subscribe(\"cell-value-changed\", this.updateCellClass.bind(this));\n\t\tthis.subscribe(\"column-layout\", this.initializeColumnCheck.bind(this));\n\t\tthis.subscribe(\"column-delete\", this.columnDeleteCheck.bind(this));\n\t\tthis.subscribe(\"row-deleting\", this.rowDeleteCheck.bind(this));\n\t\tthis.subscribe(\"row-layout\", this.rowEditableCheck.bind(this));\n\t\tthis.subscribe(\"data-refreshing\", this.cancelEdit.bind(this));\n\t\t\n\t\tthis.subscribe(\"keybinding-nav-prev\", this.navigatePrev.bind(this, undefined));\n\t\tthis.subscribe(\"keybinding-nav-next\", this.keybindingNavigateNext.bind(this));\n\t\tthis.subscribe(\"keybinding-nav-left\", this.navigateLeft.bind(this, undefined));\n\t\tthis.subscribe(\"keybinding-nav-right\", this.navigateRight.bind(this, undefined));\n\t\tthis.subscribe(\"keybinding-nav-up\", this.navigateUp.bind(this, undefined));\n\t\tthis.subscribe(\"keybinding-nav-down\", this.navigateDown.bind(this, undefined));\n\t}\n\t\n\t\n\t///////////////////////////////////\n\t////// Keybinding Functions ///////\n\t///////////////////////////////////\n\t\n\tkeybindingNavigateNext(e){\n\t\tvar cell = this.currentCell,\n\t\tnewRow = this.options(\"tabEndNewRow\");\n\t\t\n\t\tif(cell){\n\t\t\tif(!this.navigateNext(cell, e)){\n\t\t\t\tif(newRow){\n\t\t\t\t\tcell.getElement().firstChild.blur();\n\t\t\t\t\t\n\t\t\t\t\tif(newRow === true){\n\t\t\t\t\t\tnewRow = this.table.addRow({});\n\t\t\t\t\t}else{\n\t\t\t\t\t\tif(typeof newRow == \"function\"){\n\t\t\t\t\t\t\tnewRow = this.table.addRow(newRow(cell.row.getComponent()));\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tnewRow = this.table.addRow(Object.assign({}, newRow));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tnewRow.then(() => {\n\t\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\t\tcell.getComponent().navigateNext();\n\t\t\t\t\t\t});\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Cell Functions //////////\n\t///////////////////////////////////\n\t\n\tcellIsEdited(cell){\n\t\treturn !! cell.modules.edit && cell.modules.edit.edited;\n\t}\n\t\n\tcellCancelEdit(cell){\n\t\tif(cell === this.currentCell){\n\t\t\tthis.table.modules.edit.cancelEdit();\n\t\t}else{\n\t\t\tconsole.warn(\"Cancel Editor Error - This cell is not currently being edited \");\n\t\t}\n\t}\n\t\n\t\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\tupdateCellClass(cell){\n\t\tif(this.allowEdit(cell)) {\n\t\t\tcell.getElement().classList.add(\"tabulator-editable\");\n\t\t}\n\t\telse {\n\t\t\tcell.getElement().classList.remove(\"tabulator-editable\");\n\t\t}\n\t}\n\t\n\tclearCellEdited(cells){\n\t\tif(!cells){\n\t\t\tcells = this.table.modules.edit.getEditedCells();\n\t\t}\n\t\t\n\t\tif(!Array.isArray(cells)){\n\t\t\tcells = [cells];\n\t\t}\n\t\t\n\t\tcells.forEach((cell) => {\n\t\t\tthis.table.modules.edit.clearEdited(cell._getSelf());\n\t\t});\n\t}\n\t\n\tnavigatePrev(cell = this.currentCell, e){\n\t\tvar nextCell, prevRow;\n\t\t\n\t\tif(cell){\n\t\t\t\n\t\t\tif(e){\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t\t\n\t\t\tnextCell = this.navigateLeft();\n\t\t\t\n\t\t\tif(nextCell){\n\t\t\t\treturn true;\n\t\t\t}else{\n\t\t\t\tprevRow = this.table.rowManager.prevDisplayRow(cell.row, true);\n\t\t\t\t\n\t\t\t\tif(prevRow){\n\t\t\t\t\tnextCell = this.findPrevEditableCell(prevRow, prevRow.cells.length);\n\t\t\t\t\t\n\t\t\t\t\tif(nextCell){\n\t\t\t\t\t\tnextCell.getComponent().edit();\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\tnavigateNext(cell = this.currentCell, e){\n\t\tvar nextCell, nextRow;\n\t\t\n\t\tif(cell){\n\t\t\t\n\t\t\tif(e){\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t\t\n\t\t\tnextCell = this.navigateRight();\n\t\t\t\n\t\t\tif(nextCell){\n\t\t\t\treturn true;\n\t\t\t}else{\n\t\t\t\tnextRow = this.table.rowManager.nextDisplayRow(cell.row, true);\n\t\t\t\t\n\t\t\t\tif(nextRow){\n\t\t\t\t\tnextCell = this.findNextEditableCell(nextRow, -1);\n\t\t\t\t\t\n\t\t\t\t\tif(nextCell){\n\t\t\t\t\t\tnextCell.getComponent().edit();\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\tnavigateLeft(cell = this.currentCell, e){\n\t\tvar index, nextCell;\n\t\t\n\t\tif(cell){\n\t\t\t\n\t\t\tif(e){\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t\t\n\t\t\tindex = cell.getIndex();\n\t\t\tnextCell = this.findPrevEditableCell(cell.row, index);\n\t\t\t\n\t\t\tif(nextCell){\n\t\t\t\tnextCell.getComponent().edit();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\tnavigateRight(cell = this.currentCell, e){\n\t\tvar index, nextCell;\n\t\t\n\t\tif(cell){\n\t\t\t\n\t\t\tif(e){\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t\t\n\t\t\tindex = cell.getIndex();\n\t\t\tnextCell = this.findNextEditableCell(cell.row, index);\n\t\t\t\n\t\t\tif(nextCell){\n\t\t\t\tnextCell.getComponent().edit();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\tnavigateUp(cell = this.currentCell, e){\n\t\tvar index, nextRow;\n\t\t\n\t\tif(cell){\n\t\t\t\n\t\t\tif(e){\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t\t\n\t\t\tindex = cell.getIndex();\n\t\t\tnextRow = this.table.rowManager.prevDisplayRow(cell.row, true);\n\t\t\t\n\t\t\tif(nextRow){\n\t\t\t\tnextRow.cells[index].getComponent().edit();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\tnavigateDown(cell = this.currentCell, e){\n\t\tvar index, nextRow;\n\t\t\n\t\tif(cell){\n\t\t\t\n\t\t\tif(e){\n\t\t\t\te.preventDefault();\n\t\t\t}\n\t\t\t\n\t\t\tindex = cell.getIndex();\n\t\t\tnextRow = this.table.rowManager.nextDisplayRow(cell.row, true);\n\t\t\t\n\t\t\tif(nextRow){\n\t\t\t\tnextRow.cells[index].getComponent().edit();\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\tfindNextEditableCell(row, index){\n\t\tvar nextCell = false;\n\t\t\n\t\tif(index < row.cells.length-1){\n\t\t\tfor(var i = index+1; i < row.cells.length; i++){\n\t\t\t\tlet cell = row.cells[i];\n\t\t\t\t\n\t\t\t\tif(cell.column.modules.edit && Helpers.elVisible(cell.getElement())){\n\t\t\t\t\tlet allowEdit = this.allowEdit(cell);\n\t\t\t\t\t\n\t\t\t\t\tif(allowEdit){\n\t\t\t\t\t\tnextCell = cell;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn nextCell;\n\t}\n\t\n\tfindPrevEditableCell(row, index){\n\t\tvar prevCell = false;\n\t\t\n\t\tif(index > 0){\n\t\t\tfor(var i = index-1; i >= 0; i--){\n\t\t\t\tlet cell = row.cells[i];\n\t\t\t\t\n\t\t\t\tif(cell.column.modules.edit && Helpers.elVisible(cell.getElement())){\n\t\t\t\t\tlet allowEdit = this.allowEdit(cell);\n\t\t\t\t\t\n\t\t\t\t\tif(allowEdit){\n\t\t\t\t\t\tprevCell = cell;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn prevCell;\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\t\n\tinitializeColumnCheck(column){\n\t\tif(typeof column.definition.editor !== \"undefined\"){\n\t\t\tthis.initializeColumn(column);\n\t\t}\n\t}\n\t\n\tcolumnDeleteCheck(column){\n\t\tif(this.currentCell && this.currentCell.column === column){\n\t\t\tthis.cancelEdit();\n\t\t}\n\t}\n\t\n\trowDeleteCheck(row){\n\t\tif(this.currentCell && this.currentCell.row === row){\n\t\t\tthis.cancelEdit();\n\t\t}\n\t}\n\n\trowEditableCheck(row){\n\t\trow.getCells().forEach((cell) => {\n\t\t\tif(cell.column.modules.edit && typeof cell.column.modules.edit.check === \"function\"){\n\t\t\t\tthis.updateCellClass(cell);\n\t\t\t}\n\t\t});\n\t}\n\t\n\t//initialize column editor\n\tinitializeColumn(column){\n\t\tvar config = {\n\t\t\teditor:false,\n\t\t\tblocked:false,\n\t\t\tcheck:column.definition.editable,\n\t\t\tparams:column.definition.editorParams || {}\n\t\t};\n\t\t\n\t\t//set column editor\n\t\tswitch(typeof column.definition.editor){\n\t\t\tcase \"string\":\n\t\t\t\tif(this.editors[column.definition.editor]){\n\t\t\t\t\tconfig.editor = this.editors[column.definition.editor];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Editor Error - No such editor found: \", column.definition.editor);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"function\":\n\t\t\t\tconfig.editor = column.definition.editor;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"boolean\":\n\t\t\t\tif(column.definition.editor === true){\n\t\t\t\t\tif(typeof column.definition.formatter !== \"function\"){\n\t\t\t\t\t\tif(this.editors[column.definition.formatter]){\n\t\t\t\t\t\t\tconfig.editor = this.editors[column.definition.formatter];\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tconfig.editor = this.editors[\"input\"];\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Editor Error - Cannot auto lookup editor for a custom formatter: \", column.definition.formatter);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t}\n\t\t\n\t\tif(config.editor){\n\t\t\tcolumn.modules.edit = config;\n\t\t}\n\t}\n\t\n\tgetCurrentCell(){\n\t\treturn this.currentCell ? this.currentCell.getComponent() : false;\n\t}\n\t\n\tclearEditor(cancel){\n\t\tvar cell = this.currentCell,\n\t\tcellEl;\n\t\t\n\t\tthis.invalidEdit = false;\n\t\t\n\t\tif(cell){\n\t\t\tthis.currentCell = false;\n\t\t\t\n\t\t\tcellEl = cell.getElement();\n\t\t\t\n\t\t\tthis.dispatch(\"edit-editor-clear\", cell, cancel);\n\t\t\t\n\t\t\tcellEl.classList.remove(\"tabulator-editing\");\n\t\t\t\n\t\t\twhile(cellEl.firstChild) cellEl.removeChild(cellEl.firstChild);\n\t\t\t\n\t\t\tcell.row.getElement().classList.remove(\"tabulator-editing\");\n\t\t\t\n\t\t\tcell.table.element.classList.remove(\"tabulator-editing\");\n\t\t}\n\t}\n\t\n\tcancelEdit(){\n\t\tif(this.currentCell){\n\t\t\tvar cell = this.currentCell;\n\t\t\tvar component = this.currentCell.getComponent();\n\t\t\t\n\t\t\tthis.clearEditor(true);\n\t\t\tcell.setValueActual(cell.getValue());\n\t\t\tcell.cellRendered();\n\t\t\t\n\t\t\tif(cell.column.definition.editor == \"textarea\" || cell.column.definition.variableHeight){\n\t\t\t\tcell.row.normalizeHeight(true);\n\t\t\t}\n\t\t\t\n\t\t\tif(cell.column.definition.cellEditCancelled){\n\t\t\t\tcell.column.definition.cellEditCancelled.call(this.table, component);\n\t\t\t}\n\t\t\t\n\t\t\tthis.dispatch(\"edit-cancelled\", cell);\n\t\t\tthis.dispatchExternal(\"cellEditCancelled\", component);\n\t\t}\n\t}\n\t\n\t//return a formatted value for a cell\n\tbindEditor(cell){\n\t\tif(cell.column.modules.edit){\n\t\t\tvar self = this,\n\t\t\telement = cell.getElement(true);\n\t\t\t\n\t\t\tthis.updateCellClass(cell);\n\t\t\telement.setAttribute(\"tabindex\", 0);\n\t\t\t\n\t\t\telement.addEventListener(\"click\", function(e){\n\t\t\t\tif(!element.classList.contains(\"tabulator-editing\")){\n\t\t\t\t\telement.focus({preventScroll: true});\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\telement.addEventListener(\"mousedown\", function(e){\n\t\t\t\tif (e.button === 2) {\n\t\t\t\t\te.preventDefault();\n\t\t\t\t}else{\n\t\t\t\t\tself.mouseClick = true;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\telement.addEventListener(\"focus\", function(e){\n\t\t\t\tif(!self.recursionBlock){\n\t\t\t\t\tself.edit(cell, e, false);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\t\n\tfocusCellNoEvent(cell, block){\n\t\tthis.recursionBlock = true;\n\t\t\n\t\tif(!(block && this.table.browser === \"ie\")){\n\t\t\tcell.getElement().focus({preventScroll: true});\n\t\t}\n\t\t\n\t\tthis.recursionBlock = false;\n\t}\n\t\n\teditCell(cell, forceEdit){\n\t\tthis.focusCellNoEvent(cell);\n\t\tthis.edit(cell, false, forceEdit);\n\t}\n\t\n\tfocusScrollAdjust(cell){\n\t\tif(this.table.rowManager.getRenderMode() == \"virtual\"){\n\t\t\tvar topEdge = this.table.rowManager.element.scrollTop,\n\t\t\tbottomEdge = this.table.rowManager.element.clientHeight + this.table.rowManager.element.scrollTop,\n\t\t\trowEl = cell.row.getElement();\n\t\t\t\n\t\t\tif(rowEl.offsetTop < topEdge){\n\t\t\t\tthis.table.rowManager.element.scrollTop -= (topEdge - rowEl.offsetTop);\n\t\t\t}else{\n\t\t\t\tif(rowEl.offsetTop + rowEl.offsetHeight > bottomEdge){\n\t\t\t\t\tthis.table.rowManager.element.scrollTop += (rowEl.offsetTop + rowEl.offsetHeight - bottomEdge);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tvar leftEdge = this.table.rowManager.element.scrollLeft,\n\t\t\trightEdge = this.table.rowManager.element.clientWidth + this.table.rowManager.element.scrollLeft,\n\t\t\tcellEl = cell.getElement();\n\t\t\t\n\t\t\tif(this.table.modExists(\"frozenColumns\")){\n\t\t\t\tleftEdge += parseInt(this.table.modules.frozenColumns.leftMargin || 0);\n\t\t\t\trightEdge -= parseInt(this.table.modules.frozenColumns.rightMargin || 0);\n\t\t\t}\n\t\t\t\n\t\t\tif(this.table.options.renderHorizontal === \"virtual\"){\n\t\t\t\tleftEdge -= parseInt(this.table.columnManager.renderer.vDomPadLeft);\n\t\t\t\trightEdge -= parseInt(this.table.columnManager.renderer.vDomPadLeft);\n\t\t\t}\n\t\t\t\n\t\t\tif(cellEl.offsetLeft < leftEdge){\n\t\t\t\tthis.table.rowManager.element.scrollLeft -= (leftEdge - cellEl.offsetLeft);\n\t\t\t}else{\n\t\t\t\tif(cellEl.offsetLeft + cellEl.offsetWidth > rightEdge){\n\t\t\t\t\tthis.table.rowManager.element.scrollLeft += (cellEl.offsetLeft + cellEl.offsetWidth - rightEdge);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\tallowEdit(cell) {\n\t\tvar check = cell.column.modules.edit ? true : false;\n\n\t\tif(cell.column.modules.edit){\n\t\t\tswitch(typeof cell.column.modules.edit.check){\n\t\t\t\tcase \"function\":\n\t\t\t\t\tif(cell.row.initialized){\n\t\t\t\t\t\tcheck = cell.column.modules.edit.check(cell.getComponent());\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"string\":\n\t\t\t\t\tcheck = !!cell.row.data[cell.column.modules.edit.check];\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"boolean\":\n\t\t\t\t\tcheck = cell.column.modules.edit.check;\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn check;\n\t}\n\t\n\tedit(cell, e, forceEdit){\n\t\tvar self = this,\n\t\tallowEdit = true,\n\t\trendered = function(){},\n\t\telement = cell.getElement(),\n\t\tcellEditor, component, params;\n\t\t\n\t\t//prevent editing if another cell is refusing to leave focus (eg. validation fail)\n\n\t\tif(this.currentCell){\n\t\t\tif(!this.invalidEdit && this.currentCell !== cell){\n\t\t\t\tthis.cancelEdit();\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\t\t\n\t\t//handle successful value change\n\t\tfunction success(value){\n\t\t\tif(self.currentCell === cell){\n\t\t\t\tvar valid = self.chain(\"edit-success\", [cell, value], true, true);\n\t\t\t\t\n\t\t\t\tif(valid === true || self.table.options.validationMode === \"highlight\"){\n\t\t\t\t\tself.clearEditor();\n\t\t\t\t\t\n\t\t\t\t\t\n\t\t\t\t\tif(!cell.modules.edit){\n\t\t\t\t\t\tcell.modules.edit = {};\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tcell.modules.edit.edited = true;\n\t\t\t\t\t\n\t\t\t\t\tif(self.editedCells.indexOf(cell) == -1){\n\t\t\t\t\t\tself.editedCells.push(cell);\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tcell.setValue(value, true);\n\t\t\t\t\t\n\t\t\t\t\treturn valid === true;\n\t\t\t\t}else{\n\t\t\t\t\tself.invalidEdit = true;\n\t\t\t\t\tself.focusCellNoEvent(cell, true);\n\t\t\t\t\trendered();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\t// console.warn(\"Edit Success Error - cannot call success on a cell that is no longer being edited\");\n\t\t\t}\n\t\t}\n\t\t\n\t\t//handle aborted edit\n\t\tfunction cancel(){\n\t\t\tif(self.currentCell === cell){\n\t\t\t\tself.cancelEdit();\n\t\t\t}else{\n\t\t\t\t// console.warn(\"Edit Success Error - cannot call cancel on a cell that is no longer being edited\");\n\t\t\t}\n\t\t}\n\t\t\n\t\tfunction onRendered(callback){\n\t\t\trendered = callback;\n\t\t}\n\t\t\n\t\tif(!cell.column.modules.edit.blocked){\n\t\t\tif(e){\n\t\t\t\te.stopPropagation();\n\t\t\t}\n\t\t\t\n\t\t\tallowEdit = this.allowEdit(cell);\n\t\t\t\n\t\t\tif(allowEdit || forceEdit){\n\t\t\t\t\n\t\t\t\tself.cancelEdit();\n\t\t\t\t\n\t\t\t\tself.currentCell = cell;\n\t\t\t\t\n\t\t\t\tthis.focusScrollAdjust(cell);\n\t\t\t\t\n\t\t\t\tcomponent = cell.getComponent();\n\t\t\t\t\n\t\t\t\tif(this.mouseClick){\n\t\t\t\t\tthis.mouseClick = false;\n\t\t\t\t\t\n\t\t\t\t\tif(cell.column.definition.cellClick){\n\t\t\t\t\t\tcell.column.definition.cellClick.call(this.table, e, component);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(cell.column.definition.cellEditing){\n\t\t\t\t\tcell.column.definition.cellEditing.call(this.table, component);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.dispatch(\"cell-editing\", cell);\n\t\t\t\tthis.dispatchExternal(\"cellEditing\", component);\n\t\t\t\t\n\t\t\t\tparams = typeof cell.column.modules.edit.params === \"function\" ? cell.column.modules.edit.params(component) : cell.column.modules.edit.params;\n\t\t\t\t\n\t\t\t\tcellEditor = cell.column.modules.edit.editor.call(self, component, onRendered, success, cancel, params);\n\t\t\t\t\n\t\t\t\t//if editor returned, add to DOM, if false, abort edit\n\t\t\t\tif(this.currentCell && cellEditor !== false){\n\t\t\t\t\tif(cellEditor instanceof Node){\n\t\t\t\t\t\telement.classList.add(\"tabulator-editing\");\n\t\t\t\t\t\tcell.row.getElement().classList.add(\"tabulator-editing\");\n\t\t\t\t\t\tcell.table.element.classList.add(\"tabulator-editing\");\n\t\t\t\t\t\twhile(element.firstChild) element.removeChild(element.firstChild);\n\t\t\t\t\t\telement.appendChild(cellEditor);\n\t\t\t\t\t\t\n\t\t\t\t\t\t//trigger onRendered Callback\n\t\t\t\t\t\trendered();\n\t\t\t\t\t\t\n\t\t\t\t\t\t//prevent editing from triggering rowClick event\n\t\t\t\t\t\tvar children = element.children;\n\t\t\t\t\t\t\n\t\t\t\t\t\tfor (var i = 0; i < children.length; i++) {\n\t\t\t\t\t\t\tchildren[i].addEventListener(\"click\", function(e){\n\t\t\t\t\t\t\t\te.stopPropagation();\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Edit Error - Editor should return an instance of Node, the editor returned:\", cellEditor);\n\t\t\t\t\t\telement.blur();\n\t\t\t\t\t\treturn false;\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\telement.blur();\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn true;\n\t\t\t}else{\n\t\t\t\tthis.mouseClick = false;\n\t\t\t\telement.blur();\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}else{\n\t\t\tthis.mouseClick = false;\n\t\t\telement.blur();\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\tgetEditedCells(){\n\t\tvar output = [];\n\t\t\n\t\tthis.editedCells.forEach((cell) => {\n\t\t\toutput.push(cell.getComponent());\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tclearEdited(cell){\n\t\tvar editIndex;\n\t\t\n\t\tif(cell.modules.edit && cell.modules.edit.edited){\n\t\t\tcell.modules.edit.edited = false;\n\t\t\t\n\t\t\tthis.dispatch(\"edit-edited-clear\", cell);\n\t\t}\n\t\t\n\t\teditIndex = this.editedCells.indexOf(cell);\n\t\t\n\t\tif(editIndex > -1){\n\t\t\tthis.editedCells.splice(editIndex, 1);\n\t\t}\n\t}\n}\n\nEdit.moduleName = \"edit\";\n\n//load defaults\nEdit.editors = defaultEditors;\n\n\nexport default Edit;\n","class ExportRow{\n\tconstructor(type, columns, component, indent){\n\t\tthis.type = type;\n\t\tthis.columns = columns;\n\t\tthis.component = component || false;\n\t\tthis.indent = indent || 0;\n\t}\n}\n\nexport default ExportRow;","class ExportColumn{\n\tconstructor(value, component, width, height, depth){\n\t\tthis.value = value;\n\t\tthis.component = component || false;\n\t\tthis.width = width;\n\t\tthis.height = height;\n\t\tthis.depth = depth;\n\t}\n}\n\nexport default ExportColumn;","import Module from '../../core/Module.js';\n\nimport ExportRow from './ExportRow.js';\nimport ExportColumn from './ExportColumn.js';\n\nclass Export extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.config = {};\n\t\tthis.cloneTableStyle = true;\n\t\tthis.colVisProp = \"\";\n\t\t\n\t\tthis.registerTableOption(\"htmlOutputConfig\", false); //html output config\n\t\t\n\t\tthis.registerColumnOption(\"htmlOutput\");\n\t\tthis.registerColumnOption(\"titleHtmlOutput\");\n\t}\n\t\n\tinitialize(){\n\t\tthis.registerTableFunction(\"getHtml\", this.getHtml.bind(this));\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\t\n\t\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\t\n\tgenerateExportList(config, style, range, colVisProp){\n\t\tthis.cloneTableStyle = style;\n\t\tthis.config = config || {};\n\t\tthis.colVisProp = colVisProp;\n\t\t\n\t\tvar headers = this.config.columnHeaders !== false ? this.headersToExportRows(this.generateColumnGroupHeaders()) : [];\n\t\tvar body = this.bodyToExportRows(this.rowLookup(range));\n\t\t\n\t\treturn headers.concat(body);\n\t}\n\t\n\tgenerateTable(config, style, range, colVisProp){\n\t\tvar list = this.generateExportList(config, style, range, colVisProp);\n\t\t\n\t\treturn this.generateTableElement(list);\n\t}\n\t\n\trowLookup(range){\n\t\tvar rows = [];\n\t\t\n\t\tif(typeof range == \"function\"){\n\t\t\trange.call(this.table).forEach((row) =>{\n\t\t\t\trow = this.table.rowManager.findRow(row);\n\t\t\t\t\n\t\t\t\tif(row){\n\t\t\t\t\trows.push(row);\n\t\t\t\t}\n\t\t\t});\n\t\t}else{\n\t\t\tswitch(range){\n\t\t\t\tcase true:\n\t\t\t\tcase \"visible\":\n\t\t\t\t\trows = this.table.rowManager.getVisibleRows(false, true);\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"all\":\n\t\t\t\t\trows = this.table.rowManager.rows;\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"selected\":\n\t\t\t\t\trows = this.table.modules.selectRow.selectedRows;\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"active\":\n\t\t\t\tdefault:\n\t\t\t\t\tif(this.table.options.pagination){\n\t\t\t\t\t\trows = this.table.rowManager.getDisplayRows(this.table.rowManager.displayRows.length - 2);\n\t\t\t\t\t}else{\n\t\t\t\t\t\trows = this.table.rowManager.getDisplayRows();\n\t\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn Object.assign([], rows);\n\t}\n\t\n\tgenerateColumnGroupHeaders(){\n\t\tvar output = [];\n\t\t\n\t\tvar columns = this.config.columnGroups !== false ? this.table.columnManager.columns : this.table.columnManager.columnsByIndex;\n\t\t\n\t\tcolumns.forEach((column) => {\n\t\t\tvar colData = this.processColumnGroup(column);\n\t\t\t\n\t\t\tif(colData){\n\t\t\t\toutput.push(colData);\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tprocessColumnGroup(column){\n\t\tvar subGroups = column.columns,\n\t\tmaxDepth = 0,\n\t\ttitle = column.definition[\"title\" + (this.colVisProp.charAt(0).toUpperCase() + this.colVisProp.slice(1))] || column.definition.title;\n\t\t\n\t\tvar groupData = {\n\t\t\ttitle:title,\n\t\t\tcolumn:column,\n\t\t\tdepth:1,\n\t\t};\n\t\t\n\t\tif(subGroups.length){\n\t\t\tgroupData.subGroups = [];\n\t\t\tgroupData.width = 0;\n\t\t\t\n\t\t\tsubGroups.forEach((subGroup) => {\n\t\t\t\tvar subGroupData = this.processColumnGroup(subGroup);\n\t\t\t\t\n\t\t\t\tif(subGroupData){\n\t\t\t\t\tgroupData.width += subGroupData.width;\n\t\t\t\t\tgroupData.subGroups.push(subGroupData);\n\t\t\t\t\t\n\t\t\t\t\tif(subGroupData.depth > maxDepth){\n\t\t\t\t\t\tmaxDepth = subGroupData.depth;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tgroupData.depth += maxDepth;\n\t\t\t\n\t\t\tif(!groupData.width){\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}else{\n\t\t\tif(this.columnVisCheck(column)){\n\t\t\t\tgroupData.width = 1;\n\t\t\t}else{\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn groupData;\n\t}\n\t\n\tcolumnVisCheck(column){\n\t\tvar visProp = column.definition[this.colVisProp];\n\t\t\n\t\tif(typeof visProp === \"function\"){\n\t\t\tvisProp = visProp.call(this.table, column.getComponent());\n\t\t}\n\t\t\n\t\treturn visProp !== false && (column.visible || (!column.visible && visProp));\n\t}\n\t\n\theadersToExportRows(columns){\n\t\tvar headers = [],\n\t\theaderDepth = 0,\n\t\texportRows = [];\n\t\t\n\t\tfunction parseColumnGroup(column, level){\n\t\t\t\n\t\t\tvar depth = headerDepth - level;\n\t\t\t\n\t\t\tif(typeof headers[level] === \"undefined\"){\n\t\t\t\theaders[level] = [];\n\t\t\t}\n\t\t\t\n\t\t\tcolumn.height = column.subGroups ? 1 : (depth - column.depth) + 1;\n\t\t\t\n\t\t\theaders[level].push(column);\n\t\t\t\n\t\t\tif(column.height > 1){\n\t\t\t\tfor(let i = 1; i < column.height; i ++){\n\t\t\t\t\t\n\t\t\t\t\tif(typeof headers[level + i] === \"undefined\"){\n\t\t\t\t\t\theaders[level + i] = [];\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\theaders[level + i].push(false);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tif(column.width > 1){\n\t\t\t\tfor(let i = 1; i < column.width; i ++){\n\t\t\t\t\theaders[level].push(false);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tif(column.subGroups){\n\t\t\t\tcolumn.subGroups.forEach(function(subGroup){\n\t\t\t\t\tparseColumnGroup(subGroup, level+1);\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t\t\n\t\t//calculate maximum header depth\n\t\tcolumns.forEach(function(column){\n\t\t\tif(column.depth > headerDepth){\n\t\t\t\theaderDepth = column.depth;\n\t\t\t}\n\t\t});\n\t\t\n\t\tcolumns.forEach(function(column){\n\t\t\tparseColumnGroup(column,0);\n\t\t});\n\t\t\n\t\theaders.forEach((header) => {\n\t\t\tvar columns = [];\n\t\t\t\n\t\t\theader.forEach((col) => {\n\t\t\t\tif(col){\n\t\t\t\t\tlet title = typeof col.title === \"undefined\" ? \"\" : col.title;\n\t\t\t\t\tcolumns.push(new ExportColumn(title, col.column.getComponent(), col.width, col.height, col.depth));\n\t\t\t\t}else{\n\t\t\t\t\tcolumns.push(null);\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\texportRows.push(new ExportRow(\"header\", columns));\n\t\t});\n\t\t\n\t\treturn exportRows;\n\t}\n\t\n\tbodyToExportRows(rows){\n\t\t\n\t\tvar columns = [];\n\t\tvar exportRows = [];\n\t\t\n\t\tthis.table.columnManager.columnsByIndex.forEach((column) => {\n\t\t\tif (this.columnVisCheck(column)) {\n\t\t\t\tcolumns.push(column.getComponent());\n\t\t\t}\n\t\t});\n\t\t\n\t\tif(this.config.columnCalcs !== false && this.table.modExists(\"columnCalcs\")){\n\t\t\tif(this.table.modules.columnCalcs.topInitialized){\n\t\t\t\trows.unshift(this.table.modules.columnCalcs.topRow);\n\t\t\t}\n\t\t\t\n\t\t\tif(this.table.modules.columnCalcs.botInitialized){\n\t\t\t\trows.push(this.table.modules.columnCalcs.botRow);\n\t\t\t}\n\t\t}\n\t\t\n\t\trows = rows.filter((row) => {\n\t\t\tswitch(row.type){\n\t\t\t\tcase \"group\":\n\t\t\t\t\treturn this.config.rowGroups !== false;\n\t\t\t\t\n\t\t\t\tcase \"calc\":\n\t\t\t\t\treturn this.config.columnCalcs !== false;\n\t\t\t\t\n\t\t\t\tcase \"row\":\n\t\t\t\t\treturn !(this.table.options.dataTree && this.config.dataTree === false && row.modules.dataTree.parent);\n\t\t\t}\n\t\t\t\n\t\t\treturn true;\n\t\t});\n\t\t\n\t\trows.forEach((row, i) => {\n\t\t\tvar rowData = row.getData(this.colVisProp);\n\t\t\tvar exportCols = [];\n\t\t\tvar indent = 0;\n\t\t\t\n\t\t\tswitch(row.type){\n\t\t\t\tcase \"group\":\n\t\t\t\t\tindent = row.level;\n\t\t\t\t\texportCols.push(new ExportColumn(row.key, row.getComponent(), columns.length, 1));\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"calc\" :\n\t\t\t\tcase \"row\" :\n\t\t\t\t\tcolumns.forEach((col) => {\n\t\t\t\t\t\texportCols.push(new ExportColumn(col._column.getFieldValue(rowData), col, 1, 1));\n\t\t\t\t\t});\n\t\t\t\t\n\t\t\t\t\tif(this.table.options.dataTree && this.config.dataTree !== false){\n\t\t\t\t\t\tindent = row.modules.dataTree.index;\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\t\n\t\t\texportRows.push(new ExportRow(row.type, exportCols, row.getComponent(), indent));\n\t\t});\n\t\t\n\t\treturn exportRows;\n\t}\n\t\n\tgenerateTableElement(list){\n\t\tvar table = document.createElement(\"table\"),\n\t\theaderEl = document.createElement(\"thead\"),\n\t\tbodyEl = document.createElement(\"tbody\"),\n\t\tstyles = this.lookupTableStyles(),\n\t\trowFormatter = this.table.options[\"rowFormatter\" + (this.colVisProp.charAt(0).toUpperCase() + this.colVisProp.slice(1))],\n\t\tsetup = {};\n\t\t\n\t\tsetup.rowFormatter = rowFormatter !== null ? rowFormatter : this.table.options.rowFormatter;\n\t\t\n\t\tif(this.table.options.dataTree &&this.config.dataTree !== false && this.table.modExists(\"columnCalcs\")){\n\t\t\tsetup.treeElementField = this.table.modules.dataTree.elementField;\n\t\t}\n\t\t\n\t\t//assign group header formatter\n\t\tsetup.groupHeader = this.table.options[\"groupHeader\" + (this.colVisProp.charAt(0).toUpperCase() + this.colVisProp.slice(1))];\n\t\t\n\t\tif(setup.groupHeader && !Array.isArray(setup.groupHeader)){\n\t\t\tsetup.groupHeader = [setup.groupHeader];\n\t\t}\n\t\t\n\t\ttable.classList.add(\"tabulator-print-table\");\n\t\t\n\t\tthis.mapElementStyles(this.table.columnManager.getHeadersElement(), headerEl, [\"border-top\", \"border-left\", \"border-right\", \"border-bottom\", \"background-color\", \"color\", \"font-weight\", \"font-family\", \"font-size\"]);\n\t\t\n\t\t\n\t\tif(list.length > 1000){\n\t\t\tconsole.warn(\"It may take a long time to render an HTML table with more than 1000 rows\");\n\t\t}\n\t\t\n\t\tlist.forEach((row, i) => {\n\t\t\tlet rowEl;\n\t\t\t\n\t\t\tswitch(row.type){\n\t\t\t\tcase \"header\":\n\t\t\t\t\theaderEl.appendChild(this.generateHeaderElement(row, setup, styles));\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"group\":\n\t\t\t\t\tbodyEl.appendChild(this.generateGroupElement(row, setup, styles));\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"calc\":\n\t\t\t\t\tbodyEl.appendChild(this.generateCalcElement(row, setup, styles));\n\t\t\t\t\tbreak;\n\t\t\t\t\n\t\t\t\tcase \"row\":\n\t\t\t\t\trowEl = this.generateRowElement(row, setup, styles);\n\t\t\t\t\n\t\t\t\t\tthis.mapElementStyles(((i % 2) && styles.evenRow) ? styles.evenRow : styles.oddRow, rowEl, [\"border-top\", \"border-left\", \"border-right\", \"border-bottom\", \"color\", \"font-weight\", \"font-family\", \"font-size\", \"background-color\"]);\n\t\t\t\t\tbodyEl.appendChild(rowEl);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t});\n\t\t\n\t\tif(headerEl.innerHTML){\n\t\t\ttable.appendChild(headerEl);\n\t\t}\n\t\t\n\t\ttable.appendChild(bodyEl);\n\t\t\n\t\t\n\t\tthis.mapElementStyles(this.table.element, table, [\"border-top\", \"border-left\", \"border-right\", \"border-bottom\"]);\n\t\treturn table;\n\t}\n\t\n\tlookupTableStyles(){\n\t\tvar styles = {};\n\t\t\n\t\t//lookup row styles\n\t\tif(this.cloneTableStyle && window.getComputedStyle){\n\t\t\tstyles.oddRow = this.table.element.querySelector(\".tabulator-row-odd:not(.tabulator-group):not(.tabulator-calcs)\");\n\t\t\tstyles.evenRow = this.table.element.querySelector(\".tabulator-row-even:not(.tabulator-group):not(.tabulator-calcs)\");\n\t\t\tstyles.calcRow = this.table.element.querySelector(\".tabulator-row.tabulator-calcs\");\n\t\t\tstyles.firstRow = this.table.element.querySelector(\".tabulator-row:not(.tabulator-group):not(.tabulator-calcs)\");\n\t\t\tstyles.firstGroup = this.table.element.getElementsByClassName(\"tabulator-group\")[0];\n\t\t\t\n\t\t\tif(styles.firstRow){\n\t\t\t\tstyles.styleCells = styles.firstRow.getElementsByClassName(\"tabulator-cell\");\n\t\t\t\tstyles.firstCell = styles.styleCells[0];\n\t\t\t\tstyles.lastCell = styles.styleCells[styles.styleCells.length - 1];\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn styles;\n\t}\n\t\n\tgenerateHeaderElement(row, setup, styles){\n\t\tvar rowEl = document.createElement(\"tr\");\n\t\t\n\t\trow.columns.forEach((column) => {\n\t\t\tif(column){\n\t\t\t\tvar cellEl = document.createElement(\"th\");\n\t\t\t\tvar classNames = column.component._column.definition.cssClass ? column.component._column.definition.cssClass.split(\" \") : [];\n\t\t\t\t\n\t\t\t\tcellEl.colSpan = column.width;\n\t\t\t\tcellEl.rowSpan = column.height;\n\t\t\t\t\n\t\t\t\tcellEl.innerHTML = column.value;\n\t\t\t\t\n\t\t\t\tif(this.cloneTableStyle){\n\t\t\t\t\tcellEl.style.boxSizing = \"border-box\";\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tclassNames.forEach(function(className) {\n\t\t\t\t\tcellEl.classList.add(className);\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tthis.mapElementStyles(column.component.getElement(), cellEl, [\"text-align\", \"border-top\", \"border-left\", \"border-right\", \"border-bottom\", \"background-color\", \"color\", \"font-weight\", \"font-family\", \"font-size\"]);\n\t\t\t\tthis.mapElementStyles(column.component._column.contentElement, cellEl, [\"padding-top\", \"padding-left\", \"padding-right\", \"padding-bottom\"]);\n\t\t\t\t\n\t\t\t\tif(column.component._column.visible){\n\t\t\t\t\tthis.mapElementStyles(column.component.getElement(), cellEl, [\"width\"]);\n\t\t\t\t}else{\n\t\t\t\t\tif(column.component._column.definition.width){\n\t\t\t\t\t\tcellEl.style.width = column.component._column.definition.width + \"px\";\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(column.component._column.parent){\n\t\t\t\t\tthis.mapElementStyles(column.component._column.parent.groupElement, cellEl, [\"border-top\"]);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\trowEl.appendChild(cellEl);\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn rowEl;\n\t}\n\t\n\tgenerateGroupElement(row, setup, styles){\n\t\t\n\t\tvar rowEl = document.createElement(\"tr\"),\n\t\tcellEl = document.createElement(\"td\"),\n\t\tgroup = row.columns[0];\n\t\t\n\t\trowEl.classList.add(\"tabulator-print-table-row\");\n\t\t\n\t\tif(setup.groupHeader && setup.groupHeader[row.indent]){\n\t\t\tgroup.value = setup.groupHeader[row.indent](group.value, row.component._group.getRowCount(), row.component._group.getData(), row.component);\n\t\t}else{\n\t\t\tif(setup.groupHeader !== false){\n\t\t\t\tgroup.value = row.component._group.generator(group.value, row.component._group.getRowCount(), row.component._group.getData(), row.component);\n\t\t\t}\n\t\t}\n\t\t\n\t\tcellEl.colSpan = group.width;\n\t\tcellEl.innerHTML = group.value;\n\t\t\n\t\trowEl.classList.add(\"tabulator-print-table-group\");\n\t\trowEl.classList.add(\"tabulator-group-level-\" + row.indent);\n\t\t\n\t\tif(group.component.isVisible()){\n\t\t\trowEl.classList.add(\"tabulator-group-visible\");\n\t\t}\n\t\t\n\t\tthis.mapElementStyles(styles.firstGroup, rowEl, [\"border-top\", \"border-left\", \"border-right\", \"border-bottom\", \"color\", \"font-weight\", \"font-family\", \"font-size\", \"background-color\"]);\n\t\tthis.mapElementStyles(styles.firstGroup, cellEl, [\"padding-top\", \"padding-left\", \"padding-right\", \"padding-bottom\"]);\n\t\t\n\t\trowEl.appendChild(cellEl);\n\t\t\n\t\treturn rowEl;\n\t}\n\t\n\tgenerateCalcElement(row, setup, styles){\n\t\tvar rowEl = this.generateRowElement(row, setup, styles);\n\t\t\n\t\trowEl.classList.add(\"tabulator-print-table-calcs\");\n\t\tthis.mapElementStyles(styles.calcRow, rowEl, [\"border-top\", \"border-left\", \"border-right\", \"border-bottom\", \"color\", \"font-weight\", \"font-family\", \"font-size\", \"background-color\"]);\n\t\t\n\t\treturn rowEl;\n\t}\n\t\n\tgenerateRowElement(row, setup, styles){\n\t\tvar rowEl = document.createElement(\"tr\");\n\t\t\n\t\trowEl.classList.add(\"tabulator-print-table-row\");\n\t\t\n\t\trow.columns.forEach((col, i) => {\n\t\t\tif(col){\n\t\t\t\tvar cellEl = document.createElement(\"td\"),\n\t\t\t\tcolumn = col.component._column,\n\t\t\t\tindex = this.table.columnManager.findColumnIndex(column),\n\t\t\t\tvalue = col.value,\n\t\t\t\tcellStyle;\n\t\t\t\t\n\t\t\t\tvar cellWrapper = {\n\t\t\t\t\tmodules:{},\n\t\t\t\t\tgetValue:function(){\n\t\t\t\t\t\treturn value;\n\t\t\t\t\t},\n\t\t\t\t\tgetField:function(){\n\t\t\t\t\t\treturn column.definition.field;\n\t\t\t\t\t},\n\t\t\t\t\tgetElement:function(){\n\t\t\t\t\t\treturn cellEl;\n\t\t\t\t\t},\n\t\t\t\t\tgetType:function(){\n\t\t\t\t\t\treturn \"cell\";\n\t\t\t\t\t},\n\t\t\t\t\tgetColumn:function(){\n\t\t\t\t\t\treturn column.getComponent();\n\t\t\t\t\t},\n\t\t\t\t\tgetData:function(){\n\t\t\t\t\t\treturn row.component.getData();\n\t\t\t\t\t},\n\t\t\t\t\tgetRow:function(){\n\t\t\t\t\t\treturn row.component;\n\t\t\t\t\t},\n\t\t\t\t\tgetComponent:function(){\n\t\t\t\t\t\treturn cellWrapper;\n\t\t\t\t\t},\n\t\t\t\t\tcolumn:column,\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tvar classNames = column.definition.cssClass ? column.definition.cssClass.split(\" \") : [];\n\t\t\t\t\n\t\t\t\tclassNames.forEach(function(className) {\n\t\t\t\t\tcellEl.classList.add(className);\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tif(this.table.modExists(\"format\") && this.config.formatCells !== false){\n\t\t\t\t\tvalue = this.table.modules.format.formatExportValue(cellWrapper, this.colVisProp);\n\t\t\t\t}else{\n\t\t\t\t\tswitch(typeof value){\n\t\t\t\t\t\tcase \"object\":\n\t\t\t\t\t\t\tvalue = value !== null ? JSON.stringify(value) : \"\";\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\n\t\t\t\t\t\tcase \"undefined\":\n\t\t\t\t\t\t\tvalue = \"\";\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(value instanceof Node){\n\t\t\t\t\tcellEl.appendChild(value);\n\t\t\t\t}else{\n\t\t\t\t\tcellEl.innerHTML = value;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tcellStyle = styles.styleCells && styles.styleCells[index] ? styles.styleCells[index] : styles.firstCell;\n\t\t\t\t\n\t\t\t\tif(cellStyle){\n\t\t\t\t\tthis.mapElementStyles(cellStyle, cellEl, [\"padding-top\", \"padding-left\", \"padding-right\", \"padding-bottom\", \"border-top\", \"border-left\", \"border-right\", \"border-bottom\", \"color\", \"font-weight\", \"font-family\", \"font-size\", \"text-align\"]);\n\t\t\t\t\t\n\t\t\t\t\tif(column.definition.align){\n\t\t\t\t\t\tcellEl.style.textAlign = column.definition.align;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(this.table.options.dataTree && this.config.dataTree !== false){\n\t\t\t\t\tif((setup.treeElementField && setup.treeElementField == column.field) || (!setup.treeElementField && i == 0)){\n\t\t\t\t\t\tif(row.component._row.modules.dataTree.controlEl){\n\t\t\t\t\t\t\tcellEl.insertBefore(row.component._row.modules.dataTree.controlEl.cloneNode(true), cellEl.firstChild);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(row.component._row.modules.dataTree.branchEl){\n\t\t\t\t\t\t\tcellEl.insertBefore(row.component._row.modules.dataTree.branchEl.cloneNode(true), cellEl.firstChild);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\trowEl.appendChild(cellEl);\n\t\t\t\t\n\t\t\t\tif(cellWrapper.modules.format && cellWrapper.modules.format.renderedCallback){\n\t\t\t\t\tcellWrapper.modules.format.renderedCallback();\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\t\n\t\tif(setup.rowFormatter && row.type === \"row\" && this.config.formatCells !== false){\n\t\t\tlet formatComponent = Object.assign(row.component);\n\n\t\t\tformatComponent.getElement = function(){return rowEl;};\n\n\t\t\tsetup.rowFormatter(row.component);\n\t\t}\n\t\t\n\t\treturn rowEl;\n\t}\n\t\n\tgenerateHTMLTable(list){\n\t\tvar holder = document.createElement(\"div\");\n\t\t\n\t\tholder.appendChild(this.generateTableElement(list));\n\t\t\n\t\treturn holder.innerHTML;\n\t}\n\t\n\tgetHtml(visible, style, config, colVisProp){\n\t\tvar list = this.generateExportList(config || this.table.options.htmlOutputConfig, style, visible, colVisProp || \"htmlOutput\");\n\t\t\n\t\treturn this.generateHTMLTable(list);\n\t}\n\t\n\tmapElementStyles(from, to, props){\n\t\tif(this.cloneTableStyle && from && to){\n\t\t\t\n\t\t\tvar lookup = {\n\t\t\t\t\"background-color\" : \"backgroundColor\",\n\t\t\t\t\"color\" : \"fontColor\",\n\t\t\t\t\"width\" : \"width\",\n\t\t\t\t\"font-weight\" : \"fontWeight\",\n\t\t\t\t\"font-family\" : \"fontFamily\",\n\t\t\t\t\"font-size\" : \"fontSize\",\n\t\t\t\t\"text-align\" : \"textAlign\",\n\t\t\t\t\"border-top\" : \"borderTop\",\n\t\t\t\t\"border-left\" : \"borderLeft\",\n\t\t\t\t\"border-right\" : \"borderRight\",\n\t\t\t\t\"border-bottom\" : \"borderBottom\",\n\t\t\t\t\"padding-top\" : \"paddingTop\",\n\t\t\t\t\"padding-left\" : \"paddingLeft\",\n\t\t\t\t\"padding-right\" : \"paddingRight\",\n\t\t\t\t\"padding-bottom\" : \"paddingBottom\",\n\t\t\t};\n\t\t\t\n\t\t\tif(window.getComputedStyle){\n\t\t\t\tvar fromStyle = window.getComputedStyle(from);\n\t\t\t\t\n\t\t\t\tprops.forEach(function(prop){\n\t\t\t\t\tif(!to.style[lookup[prop]]){\n\t\t\t\t\t\tto.style[lookup[prop]] = fromStyle.getPropertyValue(prop);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n}\n\nExport.moduleName = \"export\";\n\nexport default Export;\n","export default {\n\n\t//equal to\n\t\"=\":function(filterVal, rowVal, rowData, filterParams){\n\t\treturn rowVal == filterVal ? true : false;\n\t},\n\n\t//less than\n\t\"<\":function(filterVal, rowVal, rowData, filterParams){\n\t\treturn rowVal < filterVal ? true : false;\n\t},\n\n\t//less than or equal to\n\t\"<=\":function(filterVal, rowVal, rowData, filterParams){\n\t\treturn rowVal <= filterVal ? true : false;\n\t},\n\n\t//greater than\n\t\">\":function(filterVal, rowVal, rowData, filterParams){\n\t\treturn rowVal > filterVal ? true : false;\n\t},\n\n\t//greater than or equal to\n\t\">=\":function(filterVal, rowVal, rowData, filterParams){\n\t\treturn rowVal >= filterVal ? true : false;\n\t},\n\n\t//not equal to\n\t\"!=\":function(filterVal, rowVal, rowData, filterParams){\n\t\treturn rowVal != filterVal ? true : false;\n\t},\n\n\t\"regex\":function(filterVal, rowVal, rowData, filterParams){\n\n\t\tif(typeof filterVal == \"string\"){\n\t\t\tfilterVal = new RegExp(filterVal);\n\t\t}\n\n\t\treturn filterVal.test(rowVal);\n\t},\n\n\t//contains the string\n\t\"like\":function(filterVal, rowVal, rowData, filterParams){\n\t\tif(filterVal === null || typeof filterVal === \"undefined\"){\n\t\t\treturn rowVal === filterVal ? true : false;\n\t\t}else{\n\t\t\tif(typeof rowVal !== 'undefined' && rowVal !== null){\n\t\t\t\treturn String(rowVal).toLowerCase().indexOf(filterVal.toLowerCase()) > -1;\n\t\t\t}\n\t\t\telse{\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t},\n\n\t//contains the keywords\n\t\"keywords\":function(filterVal, rowVal, rowData, filterParams){\n\t\tvar keywords = filterVal.toLowerCase().split(typeof filterParams.separator === \"undefined\" ? \" \" : filterParams.separator),\n\t\tvalue = String(rowVal === null || typeof rowVal === \"undefined\" ? \"\" : rowVal).toLowerCase(),\n\t\tmatches = [];\n\n\t\tkeywords.forEach((keyword) =>{\n\t\t\tif(value.includes(keyword)){\n\t\t\t\tmatches.push(true);\n\t\t\t}\n\t\t});\n\n\t\treturn filterParams.matchAll ? matches.length === keywords.length : !!matches.length;\n\t},\n\n\t//starts with the string\n\t\"starts\":function(filterVal, rowVal, rowData, filterParams){\n\t\tif(filterVal === null || typeof filterVal === \"undefined\"){\n\t\t\treturn rowVal === filterVal ? true : false;\n\t\t}else{\n\t\t\tif(typeof rowVal !== 'undefined' && rowVal !== null){\n\t\t\t\treturn String(rowVal).toLowerCase().startsWith(filterVal.toLowerCase());\n\t\t\t}\n\t\t\telse{\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t},\n\n\t//ends with the string\n\t\"ends\":function(filterVal, rowVal, rowData, filterParams){\n\t\tif(filterVal === null || typeof filterVal === \"undefined\"){\n\t\t\treturn rowVal === filterVal ? true : false;\n\t\t}else{\n\t\t\tif(typeof rowVal !== 'undefined' && rowVal !== null){\n\t\t\t\treturn String(rowVal).toLowerCase().endsWith(filterVal.toLowerCase());\n\t\t\t}\n\t\t\telse{\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\t},\n\n\t//in array\n\t\"in\":function(filterVal, rowVal, rowData, filterParams){\n\t\tif(Array.isArray(filterVal)){\n\t\t\treturn filterVal.length ? filterVal.indexOf(rowVal) > -1 : true;\n\t\t}else{\n\t\t\tconsole.warn(\"Filter Error - filter value is not an array:\", filterVal);\n\t\t\treturn false;\n\t\t}\n\t},\n};","import Module from '../../core/Module.js';\n\nimport defaultFilters from './defaults/filters.js';\n\nclass Filter extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.filterList = []; //hold filter list\n\t\tthis.headerFilters = {}; //hold column filters\n\t\tthis.headerFilterColumns = []; //hold columns that use header filters\n\n\t\tthis.prevHeaderFilterChangeCheck = \"\";\n\t\tthis.prevHeaderFilterChangeCheck = \"{}\";\n\n\t\tthis.changed = false; //has filtering changed since last render\n\t\tthis.tableInitialized = false;\n\n\t\tthis.registerTableOption(\"filterMode\", \"local\"); //local or remote filtering\n\n\t\tthis.registerTableOption(\"initialFilter\", false); //initial filtering criteria\n\t\tthis.registerTableOption(\"initialHeaderFilter\", false); //initial header filtering criteria\n\t\tthis.registerTableOption(\"headerFilterLiveFilterDelay\", 300); //delay before updating column after user types in header filter\n\t\tthis.registerTableOption(\"placeholderHeaderFilter\", false); //placeholder when header filter is empty\n\n\t\tthis.registerColumnOption(\"headerFilter\");\n\t\tthis.registerColumnOption(\"headerFilterPlaceholder\");\n\t\tthis.registerColumnOption(\"headerFilterParams\");\n\t\tthis.registerColumnOption(\"headerFilterEmptyCheck\");\n\t\tthis.registerColumnOption(\"headerFilterFunc\");\n\t\tthis.registerColumnOption(\"headerFilterFuncParams\");\n\t\tthis.registerColumnOption(\"headerFilterLiveFilter\");\n\n\t\tthis.registerTableFunction(\"searchRows\", this.searchRows.bind(this));\n\t\tthis.registerTableFunction(\"searchData\", this.searchData.bind(this));\n\n\t\tthis.registerTableFunction(\"setFilter\", this.userSetFilter.bind(this));\n\t\tthis.registerTableFunction(\"refreshFilter\", this.userRefreshFilter.bind(this));\n\t\tthis.registerTableFunction(\"addFilter\", this.userAddFilter.bind(this));\n\t\tthis.registerTableFunction(\"getFilters\", this.getFilters.bind(this));\n\t\tthis.registerTableFunction(\"setHeaderFilterFocus\", this.userSetHeaderFilterFocus.bind(this));\n\t\tthis.registerTableFunction(\"getHeaderFilterValue\", this.userGetHeaderFilterValue.bind(this));\n\t\tthis.registerTableFunction(\"setHeaderFilterValue\", this.userSetHeaderFilterValue.bind(this));\n\t\tthis.registerTableFunction(\"getHeaderFilters\", this.getHeaderFilters.bind(this));\n\t\tthis.registerTableFunction(\"removeFilter\", this.userRemoveFilter.bind(this));\n\t\tthis.registerTableFunction(\"clearFilter\", this.userClearFilter.bind(this));\n\t\tthis.registerTableFunction(\"clearHeaderFilter\", this.userClearHeaderFilter.bind(this));\n\n\t\tthis.registerComponentFunction(\"column\", \"headerFilterFocus\", this.setHeaderFilterFocus.bind(this));\n\t\tthis.registerComponentFunction(\"column\", \"reloadHeaderFilter\", this.reloadHeaderFilter.bind(this));\n\t\tthis.registerComponentFunction(\"column\", \"getHeaderFilterValue\", this.getHeaderFilterValue.bind(this));\n\t\tthis.registerComponentFunction(\"column\", \"setHeaderFilterValue\", this.setHeaderFilterValue.bind(this));\n\t}\n\n\tinitialize(){\n\t\tthis.subscribe(\"column-init\", this.initializeColumnHeaderFilter.bind(this));\n\t\tthis.subscribe(\"column-width-fit-before\", this.hideHeaderFilterElements.bind(this));\n\t\tthis.subscribe(\"column-width-fit-after\", this.showHeaderFilterElements.bind(this));\n\t\tthis.subscribe(\"table-built\", this.tableBuilt.bind(this));\n\t\tthis.subscribe(\"placeholder\", this.generatePlaceholder.bind(this));\n\n\t\tif(this.table.options.filterMode === \"remote\"){\n\t\t\tthis.subscribe(\"data-params\", this.remoteFilterParams.bind(this));\n\t\t}\n\n\t\tthis.registerDataHandler(this.filter.bind(this), 10);\n\t}\n\n\ttableBuilt(){\n\t\tif(this.table.options.initialFilter){\n\t\t\tthis.setFilter(this.table.options.initialFilter);\n\t\t}\n\n\t\tif(this.table.options.initialHeaderFilter){\n\t\t\tthis.table.options.initialHeaderFilter.forEach((item) => {\n\n\t\t\t\tvar column = this.table.columnManager.findColumn(item.field);\n\n\t\t\t\tif(column){\n\t\t\t\t\tthis.setHeaderFilterValue(column, item.value);\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Column Filter Error - No matching column found:\", item.field);\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\tthis.tableInitialized = true;\n\t}\n\n\tremoteFilterParams(data, config, silent, params){\n\t\tparams.filter = this.getFilters(true, true);\n\t\treturn params;\n\t}\n\n\tgeneratePlaceholder(text){\n\t\tif(this.table.options.placeholderHeaderFilter && Object.keys(this.headerFilters).length){\n\t\t\treturn this.table.options.placeholderHeaderFilter;\n\t\t}\n\t}\n\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\n\t//set standard filters\n\tuserSetFilter(field, type, value, params){\n\t\tthis.setFilter(field, type, value, params);\n\t\tthis.refreshFilter();\n\t}\n\n\t//set standard filters\n\tuserRefreshFilter(){\n\t\tthis.refreshFilter();\n\t}\n\n\t//add filter to array\n\tuserAddFilter(field, type, value, params){\n\t\tthis.addFilter(field, type, value, params);\n\t\tthis.refreshFilter();\n\t}\n\n\tuserSetHeaderFilterFocus(field){\n\t\tvar column = this.table.columnManager.findColumn(field);\n\n\t\tif(column){\n\t\t\tthis.setHeaderFilterFocus(column);\n\t\t}else{\n\t\t\tconsole.warn(\"Column Filter Focus Error - No matching column found:\", field);\n\t\t\treturn false;\n\t\t}\n\t}\n\n\tuserGetHeaderFilterValue(field) {\n\t\tvar column = this.table.columnManager.findColumn(field);\n\n\t\tif(column){\n\t\t\treturn this.getHeaderFilterValue(column);\n\t\t}else{\n\t\t\tconsole.warn(\"Column Filter Error - No matching column found:\", field);\n\t\t}\n\t}\n\n\tuserSetHeaderFilterValue(field, value){\n\t\tvar column = this.table.columnManager.findColumn(field);\n\n\t\tif(column){\n\t\t\tthis.setHeaderFilterValue(column, value);\n\t\t}else{\n\t\t\tconsole.warn(\"Column Filter Error - No matching column found:\", field);\n\t\t\treturn false;\n\t\t}\n\t}\n\n\t//remove filter from array\n\tuserRemoveFilter(field, type, value){\n\t\tthis.removeFilter(field, type, value);\n\t\tthis.refreshFilter();\n\t}\n\n\t//clear filters\n\tuserClearFilter(all){\n\t\tthis.clearFilter(all);\n\t\tthis.refreshFilter();\n\t}\n\n\t//clear header filters\n\tuserClearHeaderFilter(){\n\t\tthis.clearHeaderFilter();\n\t\tthis.refreshFilter();\n\t}\n\n\n\t//search for specific row components\n\tsearchRows(field, type, value){\n\t\treturn this.search(\"rows\", field, type, value);\n\t}\n\n\t//search for specific data\n\tsearchData(field, type, value){\n\t\treturn this.search(\"data\", field, type, value);\n\t}\n\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\n\tinitializeColumnHeaderFilter(column){\n\t\tvar def = column.definition;\n\n\t\tif(def.headerFilter){\n\t\t\tthis.initializeColumn(column);\n\t\t}\n\t}\n\n\t//initialize column header filter\n\tinitializeColumn(column, value){\n\t\tvar self = this,\n\t\tfield = column.getField();\n\n\t\t//handle successfully value change\n\t\tfunction success(value){\n\t\t\tvar filterType = (column.modules.filter.tagType == \"input\" && column.modules.filter.attrType == \"text\") || column.modules.filter.tagType == \"textarea\" ? \"partial\" : \"match\",\n\t\t\ttype = \"\",\n\t\t\tfilterChangeCheck = \"\",\n\t\t\tfilterFunc;\n\n\t\t\tif(typeof column.modules.filter.prevSuccess === \"undefined\" || column.modules.filter.prevSuccess !== value){\n\n\t\t\t\tcolumn.modules.filter.prevSuccess = value;\n\n\t\t\t\tif(!column.modules.filter.emptyFunc(value)){\n\t\t\t\t\tcolumn.modules.filter.value = value;\n\n\t\t\t\t\tswitch(typeof column.definition.headerFilterFunc){\n\t\t\t\t\t\tcase \"string\":\n\t\t\t\t\t\t\tif(Filter.filters[column.definition.headerFilterFunc]){\n\t\t\t\t\t\t\t\ttype = column.definition.headerFilterFunc;\n\t\t\t\t\t\t\t\tfilterFunc = function(data){\n\t\t\t\t\t\t\t\t\tvar params = column.definition.headerFilterFuncParams || {};\n\t\t\t\t\t\t\t\t\tvar fieldVal = column.getFieldValue(data);\n\n\t\t\t\t\t\t\t\t\tparams = typeof params === \"function\" ? params(value, fieldVal, data) : params;\n\n\t\t\t\t\t\t\t\t\treturn Filter.filters[column.definition.headerFilterFunc](value, fieldVal, data, params);\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t\tconsole.warn(\"Header Filter Error - Matching filter function not found: \", column.definition.headerFilterFunc);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tcase \"function\":\n\t\t\t\t\t\t\tfilterFunc = function(data){\n\t\t\t\t\t\t\t\tvar params = column.definition.headerFilterFuncParams || {};\n\t\t\t\t\t\t\t\tvar fieldVal = column.getFieldValue(data);\n\n\t\t\t\t\t\t\t\tparams = typeof params === \"function\" ? params(value, fieldVal, data) : params;\n\n\t\t\t\t\t\t\t\treturn column.definition.headerFilterFunc(value, fieldVal, data, params);\n\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\ttype = filterFunc;\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\n\t\t\t\t\tif(!filterFunc){\n\t\t\t\t\t\tswitch(filterType){\n\t\t\t\t\t\t\tcase \"partial\":\n\t\t\t\t\t\t\t\tfilterFunc = function(data){\n\t\t\t\t\t\t\t\t\tvar colVal = column.getFieldValue(data);\n\n\t\t\t\t\t\t\t\t\tif(typeof colVal !== 'undefined' && colVal !== null){\n\t\t\t\t\t\t\t\t\t\treturn String(colVal).toLowerCase().indexOf(String(value).toLowerCase()) > -1;\n\t\t\t\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\ttype = \"like\";\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\tfilterFunc = function(data){\n\t\t\t\t\t\t\t\t\treturn column.getFieldValue(data) == value;\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t\ttype = \"=\";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tself.headerFilters[field] = {value:value, func:filterFunc, type:type};\n\t\t\t\t}else{\n\t\t\t\t\tdelete self.headerFilters[field];\n\t\t\t\t}\n\n\t\t\t\tcolumn.modules.filter.value = value;\n\n\t\t\t\tfilterChangeCheck = JSON.stringify(self.headerFilters);\n\n\t\t\t\tif(self.prevHeaderFilterChangeCheck !== filterChangeCheck){\n\t\t\t\t\tself.prevHeaderFilterChangeCheck = filterChangeCheck;\n\n\t\t\t\t\tself.trackChanges();\n\t\t\t\t\tself.refreshFilter();\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn true;\n\t\t}\n\n\t\tcolumn.modules.filter = {\n\t\t\tsuccess:success,\n\t\t\tattrType:false,\n\t\t\ttagType:false,\n\t\t\temptyFunc:false,\n\t\t};\n\n\t\tthis.generateHeaderFilterElement(column);\n\t}\n\n\tgenerateHeaderFilterElement(column, initialValue, reinitialize){\n\t\tvar self = this,\n\t\tsuccess = column.modules.filter.success,\n\t\tfield = column.getField(),\n\t\tfilterElement, editor, editorElement, cellWrapper, typingTimer, searchTrigger, params, onRenderedCallback;\n\n\t\tcolumn.modules.filter.value = initialValue;\n\n\t\t//handle aborted edit\n\t\tfunction cancel(){}\n\n\t\tfunction onRendered(callback){\n\t\t\tonRenderedCallback = callback;\n\t\t}\n\n\t\tif(column.modules.filter.headerElement && column.modules.filter.headerElement.parentNode){\n\t\t\tcolumn.contentElement.removeChild(column.modules.filter.headerElement.parentNode);\n\t\t}\n\n\t\tif(field){\n\n\t\t\t//set empty value function\n\t\t\tcolumn.modules.filter.emptyFunc = column.definition.headerFilterEmptyCheck || function(value){\n\t\t\t\treturn !value && value !== 0;\n\t\t\t};\n\n\t\t\tfilterElement = document.createElement(\"div\");\n\t\t\tfilterElement.classList.add(\"tabulator-header-filter\");\n\n\t\t\t//set column editor\n\t\t\tswitch(typeof column.definition.headerFilter){\n\t\t\t\tcase \"string\":\n\t\t\t\t\tif(self.table.modules.edit.editors[column.definition.headerFilter]){\n\t\t\t\t\t\teditor = self.table.modules.edit.editors[column.definition.headerFilter];\n\n\t\t\t\t\t\tif((column.definition.headerFilter === \"tick\" || column.definition.headerFilter === \"tickCross\") && !column.definition.headerFilterEmptyCheck){\n\t\t\t\t\t\t\tcolumn.modules.filter.emptyFunc = function(value){\n\t\t\t\t\t\t\t\treturn value !== true && value !== false;\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Filter Error - Cannot build header filter, No such editor found: \", column.definition.editor);\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"function\":\n\t\t\t\t\teditor = column.definition.headerFilter;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"boolean\":\n\t\t\t\t\tif(column.modules.edit && column.modules.edit.editor){\n\t\t\t\t\t\teditor = column.modules.edit.editor;\n\t\t\t\t\t}else{\n\t\t\t\t\t\tif(column.definition.formatter && self.table.modules.edit.editors[column.definition.formatter]){\n\t\t\t\t\t\t\teditor = self.table.modules.edit.editors[column.definition.formatter];\n\n\t\t\t\t\t\t\tif((column.definition.formatter === \"tick\" || column.definition.formatter === \"tickCross\") && !column.definition.headerFilterEmptyCheck){\n\t\t\t\t\t\t\t\tcolumn.modules.filter.emptyFunc = function(value){\n\t\t\t\t\t\t\t\t\treturn value !== true && value !== false;\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\teditor = self.table.modules.edit.editors[\"input\"];\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tif(editor){\n\n\t\t\t\tcellWrapper = {\n\t\t\t\t\tgetValue:function(){\n\t\t\t\t\t\treturn typeof initialValue !== \"undefined\" ? initialValue : \"\";\n\t\t\t\t\t},\n\t\t\t\t\tgetField:function(){\n\t\t\t\t\t\treturn column.definition.field;\n\t\t\t\t\t},\n\t\t\t\t\tgetElement:function(){\n\t\t\t\t\t\treturn filterElement;\n\t\t\t\t\t},\n\t\t\t\t\tgetColumn:function(){\n\t\t\t\t\t\treturn column.getComponent();\n\t\t\t\t\t},\n\t\t\t\t\tgetTable:() => {\n\t\t\t\t\t\treturn this.table;\n\t\t\t\t\t},\n\t\t\t\t\tgetType:() => {\n\t\t\t\t\t\treturn \"header\";\n\t\t\t\t\t},\n\t\t\t\t\tgetRow:function(){\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\tnormalizeHeight:function(){\n\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t};\n\n\t\t\t\tparams = column.definition.headerFilterParams || {};\n\n\t\t\t\tparams = typeof params === \"function\" ? params.call(self.table, cellWrapper) : params;\n\n\t\t\t\teditorElement = editor.call(this.table.modules.edit, cellWrapper, onRendered, success, cancel, params);\n\n\t\t\t\tif(!editorElement){\n\t\t\t\t\tconsole.warn(\"Filter Error - Cannot add filter to \" + field + \" column, editor returned a value of false\");\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif(!(editorElement instanceof Node)){\n\t\t\t\t\tconsole.warn(\"Filter Error - Cannot add filter to \" + field + \" column, editor should return an instance of Node, the editor returned:\", editorElement);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\t//set Placeholder Text\n\t\t\t\tself.langBind(\"headerFilters|columns|\" + column.definition.field, function(value){\n\t\t\t\t\teditorElement.setAttribute(\"placeholder\", typeof value !== \"undefined\" && value ? value : (column.definition.headerFilterPlaceholder || self.langText(\"headerFilters|default\")));\n\t\t\t\t});\n\n\t\t\t\t//focus on element on click\n\t\t\t\teditorElement.addEventListener(\"click\", function(e){\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t\teditorElement.focus();\n\t\t\t\t});\n\n\t\t\t\teditorElement.addEventListener(\"focus\", (e) => {\n\t\t\t\t\tvar left = this.table.columnManager.contentsElement.scrollLeft;\n\n\t\t\t\t\tvar headerPos = this.table.rowManager.element.scrollLeft;\n\n\t\t\t\t\tif(left !== headerPos){\n\t\t\t\t\t\tthis.table.rowManager.scrollHorizontal(left);\n\t\t\t\t\t\tthis.table.columnManager.scrollHorizontal(left);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\t//live update filters as user types\n\t\t\t\ttypingTimer = false;\n\n\t\t\t\tsearchTrigger = function(e){\n\t\t\t\t\tif(typingTimer){\n\t\t\t\t\t\tclearTimeout(typingTimer);\n\t\t\t\t\t}\n\n\t\t\t\t\ttypingTimer = setTimeout(function(){\n\t\t\t\t\t\tsuccess(editorElement.value);\n\t\t\t\t\t},self.table.options.headerFilterLiveFilterDelay);\n\t\t\t\t};\n\n\t\t\t\tcolumn.modules.filter.headerElement = editorElement;\n\t\t\t\tcolumn.modules.filter.attrType = editorElement.hasAttribute(\"type\") ? editorElement.getAttribute(\"type\").toLowerCase() : \"\" ;\n\t\t\t\tcolumn.modules.filter.tagType = editorElement.tagName.toLowerCase();\n\n\t\t\t\tif(column.definition.headerFilterLiveFilter !== false){\n\n\t\t\t\t\tif (\n\t\t\t\t\t\t!(\n\t\t\t\t\t\t\tcolumn.definition.headerFilter === 'autocomplete' ||\n\t\t\t\t\t\t\tcolumn.definition.headerFilter === 'tickCross' ||\n\t\t\t\t\t\t\t((column.definition.editor === 'autocomplete' ||\n\t\t\t\t\t\t\t\tcolumn.definition.editor === 'tickCross') &&\n\t\t\t\t\t\t\tcolumn.definition.headerFilter === true)\n\t\t\t\t\t\t)\n\t\t\t\t\t) {\n\t\t\t\t\t\teditorElement.addEventListener(\"keyup\", searchTrigger);\n\t\t\t\t\t\teditorElement.addEventListener(\"search\", searchTrigger);\n\n\n\t\t\t\t\t\t//update number filtered columns on change\n\t\t\t\t\t\tif(column.modules.filter.attrType == \"number\"){\n\t\t\t\t\t\t\teditorElement.addEventListener(\"change\", function(e){\n\t\t\t\t\t\t\t\tsuccess(editorElement.value);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t//change text inputs to search inputs to allow for clearing of field\n\t\t\t\t\t\tif(column.modules.filter.attrType == \"text\" && this.table.browser !== \"ie\"){\n\t\t\t\t\t\t\teditorElement.setAttribute(\"type\", \"search\");\n\t\t\t\t\t\t// editorElement.off(\"change blur\"); //prevent blur from triggering filter and preventing selection click\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\t//prevent input and select elements from propagating click to column sorters etc\n\t\t\t\t\tif(column.modules.filter.tagType == \"input\" || column.modules.filter.tagType == \"select\" || column.modules.filter.tagType == \"textarea\"){\n\t\t\t\t\t\teditorElement.addEventListener(\"mousedown\",function(e){\n\t\t\t\t\t\t\te.stopPropagation();\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tfilterElement.appendChild(editorElement);\n\n\t\t\t\tcolumn.contentElement.appendChild(filterElement);\n\n\t\t\t\tif(!reinitialize){\n\t\t\t\t\tself.headerFilterColumns.push(column);\n\t\t\t\t}\n\n\t\t\t\tif(onRenderedCallback){\n\t\t\t\t\tonRenderedCallback();\n\t\t\t\t}\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.warn(\"Filter Error - Cannot add header filter, column has no field set:\", column.definition.title);\n\t\t}\n\t}\n\n\t//hide all header filter elements (used to ensure correct column widths in \"fitData\" layout mode)\n\thideHeaderFilterElements(){\n\t\tthis.headerFilterColumns.forEach(function(column){\n\t\t\tif(column.modules.filter && column.modules.filter.headerElement){\n\t\t\t\tcolumn.modules.filter.headerElement.style.display = 'none';\n\t\t\t}\n\t\t});\n\t}\n\n\t//show all header filter elements (used to ensure correct column widths in \"fitData\" layout mode)\n\tshowHeaderFilterElements(){\n\t\tthis.headerFilterColumns.forEach(function(column){\n\t\t\tif(column.modules.filter && column.modules.filter.headerElement){\n\t\t\t\tcolumn.modules.filter.headerElement.style.display = '';\n\t\t\t}\n\t\t});\n\t}\n\n\t//programmatically set focus of header filter\n\tsetHeaderFilterFocus(column){\n\t\tif(column.modules.filter && column.modules.filter.headerElement){\n\t\t\tcolumn.modules.filter.headerElement.focus();\n\t\t}else{\n\t\t\tconsole.warn(\"Column Filter Focus Error - No header filter set on column:\", column.getField());\n\t\t}\n\t}\n\n\t//programmatically get value of header filter\n\tgetHeaderFilterValue(column){\n\t\tif(column.modules.filter && column.modules.filter.headerElement){\n\t\t\treturn column.modules.filter.value;\n\t\t} else {\n\t\t\tconsole.warn(\"Column Filter Error - No header filter set on column:\", column.getField());\n\t\t}\n\t}\n\n\t//programmatically set value of header filter\n\tsetHeaderFilterValue(column, value){\n\t\tif (column){\n\t\t\tif(column.modules.filter && column.modules.filter.headerElement){\n\t\t\t\tthis.generateHeaderFilterElement(column, value, true);\n\t\t\t\tcolumn.modules.filter.success(value);\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Column Filter Error - No header filter set on column:\", column.getField());\n\t\t\t}\n\t\t}\n\t}\n\n\treloadHeaderFilter(column){\n\t\tif (column){\n\t\t\tif(column.modules.filter && column.modules.filter.headerElement){\n\t\t\t\tthis.generateHeaderFilterElement(column, column.modules.filter.value, true);\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Column Filter Error - No header filter set on column:\", column.getField());\n\t\t\t}\n\t\t}\n\t}\n\n\trefreshFilter(){\n\t\tif(this.tableInitialized){\n\t\t\tif(this.table.options.filterMode === \"remote\"){\n\t\t\t\tthis.reloadData(null, false, false);\n\t\t\t}else{\n\t\t\t\tthis.refreshData(true);\n\t\t\t}\n\t\t}\n\n\t\t//TODO - Persist left position of row manager\n\t\t// left = this.scrollLeft;\n\t\t// this.scrollHorizontal(left);\n\t}\n\n\t//check if the filters has changed since last use\n\ttrackChanges(){\n\t\tthis.changed = true;\n\t\tthis.dispatch(\"filter-changed\");\n\t}\n\n\t//check if the filters has changed since last use\n\thasChanged(){\n\t\tvar changed = this.changed;\n\t\tthis.changed = false;\n\t\treturn changed;\n\t}\n\n\t//set standard filters\n\tsetFilter(field, type, value, params){\n\t\tthis.filterList = [];\n\n\t\tif(!Array.isArray(field)){\n\t\t\tfield = [{field:field, type:type, value:value, params:params}];\n\t\t}\n\n\t\tthis.addFilter(field);\n\t}\n\n\t//add filter to array\n\taddFilter(field, type, value, params){\n\t\tvar changed = false;\n\n\t\tif(!Array.isArray(field)){\n\t\t\tfield = [{field:field, type:type, value:value, params:params}];\n\t\t}\n\n\t\tfield.forEach((filter) => {\n\t\t\tfilter = this.findFilter(filter);\n\n\t\t\tif(filter){\n\t\t\t\tthis.filterList.push(filter);\n\t\t\t\tchanged = true;\n\t\t\t}\n\t\t});\n\n\t\tif(changed){\n\t\t\tthis.trackChanges();\n\t\t}\n\t}\n\n\tfindFilter(filter){\n\t\tvar column;\n\n\t\tif(Array.isArray(filter)){\n\t\t\treturn this.findSubFilters(filter);\n\t\t}\n\n\t\tvar filterFunc = false;\n\n\t\tif(typeof filter.field == \"function\"){\n\t\t\tfilterFunc = function(data){\n\t\t\t\treturn filter.field(data, filter.type || {});// pass params to custom filter function\n\t\t\t};\n\t\t}else{\n\n\t\t\tif(Filter.filters[filter.type]){\n\n\t\t\t\tcolumn = this.table.columnManager.getColumnByField(filter.field);\n\n\t\t\t\tif(column){\n\t\t\t\t\tfilterFunc = function(data){\n\t\t\t\t\t\treturn Filter.filters[filter.type](filter.value, column.getFieldValue(data), data, filter.params || {});\n\t\t\t\t\t};\n\t\t\t\t}else{\n\t\t\t\t\tfilterFunc = function(data){\n\t\t\t\t\t\treturn Filter.filters[filter.type](filter.value, data[filter.field], data, filter.params || {});\n\t\t\t\t\t};\n\t\t\t\t}\n\n\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Filter Error - No such filter type found, ignoring: \", filter.type);\n\t\t\t}\n\t\t}\n\n\t\tfilter.func = filterFunc;\n\n\t\treturn filter.func ? filter : false;\n\t}\n\n\tfindSubFilters(filters){\n\t\tvar output = [];\n\n\t\tfilters.forEach((filter) => {\n\t\t\tfilter = this.findFilter(filter);\n\n\t\t\tif(filter){\n\t\t\t\toutput.push(filter);\n\t\t\t}\n\t\t});\n\n\t\treturn output.length ? output : false;\n\t}\n\n\t//get all filters\n\tgetFilters(all, ajax){\n\t\tvar output = [];\n\n\t\tif(all){\n\t\t\toutput = this.getHeaderFilters();\n\t\t}\n\n\t\tif(ajax){\n\t\t\toutput.forEach(function(item){\n\t\t\t\tif(typeof item.type == \"function\"){\n\t\t\t\t\titem.type = \"function\";\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\toutput = output.concat(this.filtersToArray(this.filterList, ajax));\n\n\t\treturn output;\n\t}\n\n\t//filter to Object\n\tfiltersToArray(filterList, ajax){\n\t\tvar output = [];\n\n\t\tfilterList.forEach((filter) => {\n\t\t\tvar item;\n\n\t\t\tif(Array.isArray(filter)){\n\t\t\t\toutput.push(this.filtersToArray(filter, ajax));\n\t\t\t}else{\n\t\t\t\titem = {field:filter.field, type:filter.type, value:filter.value};\n\n\t\t\t\tif(ajax){\n\t\t\t\t\tif(typeof item.type == \"function\"){\n\t\t\t\t\t\titem.type = \"function\";\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\toutput.push(item);\n\t\t\t}\n\t\t});\n\n\t\treturn output;\n\t}\n\n\t//get all filters\n\tgetHeaderFilters(){\n\t\tvar output = [];\n\n\t\tfor(var key in this.headerFilters){\n\t\t\toutput.push({field:key, type:this.headerFilters[key].type, value:this.headerFilters[key].value});\n\t\t}\n\n\t\treturn output;\n\t}\n\n\t//remove filter from array\n\tremoveFilter(field, type, value){\n\t\tif(!Array.isArray(field)){\n\t\t\tfield = [{field:field, type:type, value:value}];\n\t\t}\n\n\t\tfield.forEach((filter) => {\n\t\t\tvar index = -1;\n\n\t\t\tif(typeof filter.field == \"object\"){\n\t\t\t\tindex = this.filterList.findIndex((element) => {\n\t\t\t\t\treturn filter === element;\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tindex = this.filterList.findIndex((element) => {\n\t\t\t\t\treturn filter.field === element.field && filter.type === element.type && filter.value === element.value;\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tif(index > -1){\n\t\t\t\tthis.filterList.splice(index, 1);\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Filter Error - No matching filter type found, ignoring: \", filter.type);\n\t\t\t}\n\t\t});\n\n\t\tthis.trackChanges();\n\t}\n\n\t//clear filters\n\tclearFilter(all){\n\t\tthis.filterList = [];\n\n\t\tif(all){\n\t\t\tthis.clearHeaderFilter();\n\t\t}\n\n\t\tthis.trackChanges();\n\t}\n\n\t//clear header filters\n\tclearHeaderFilter(){\n\t\tthis.headerFilters = {};\n\t\tthis.prevHeaderFilterChangeCheck = \"{}\";\n\n\t\tthis.headerFilterColumns.forEach((column) => {\n\t\t\tif(typeof column.modules.filter.value !== \"undefined\"){\n\t\t\t\tdelete column.modules.filter.value;\n\t\t\t}\n\t\t\tcolumn.modules.filter.prevSuccess = undefined;\n\t\t\tthis.reloadHeaderFilter(column);\n\t\t});\n\n\t\tthis.trackChanges();\n\t}\n\n\t//search data and return matching rows\n\tsearch (searchType, field, type, value){\n\t\tvar activeRows = [],\n\t\tfilterList = [];\n\n\t\tif(!Array.isArray(field)){\n\t\t\tfield = [{field:field, type:type, value:value}];\n\t\t}\n\n\t\tfield.forEach((filter) => {\n\t\t\tfilter = this.findFilter(filter);\n\n\t\t\tif(filter){\n\t\t\t\tfilterList.push(filter);\n\t\t\t}\n\t\t});\n\n\t\tthis.table.rowManager.rows.forEach((row) => {\n\t\t\tvar match = true;\n\n\t\t\tfilterList.forEach((filter) => {\n\t\t\t\tif(!this.filterRecurse(filter, row.getData())){\n\t\t\t\t\tmatch = false;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tif(match){\n\t\t\t\tactiveRows.push(searchType === \"data\" ? row.getData(\"data\") : row.getComponent());\n\t\t\t}\n\n\t\t});\n\n\t\treturn activeRows;\n\t}\n\n\t//filter row array\n\tfilter(rowList, filters){\n\t\tvar activeRows = [],\n\t\tactiveRowComponents = [];\n\n\t\tif(this.subscribedExternal(\"dataFiltering\")){\n\t\t\tthis.dispatchExternal(\"dataFiltering\", this.getFilters(true));\n\t\t}\n\n\t\tif(this.table.options.filterMode !== \"remote\" && (this.filterList.length || Object.keys(this.headerFilters).length)){\n\n\t\t\trowList.forEach((row) => {\n\t\t\t\tif(this.filterRow(row)){\n\t\t\t\t\tactiveRows.push(row);\n\t\t\t\t}\n\t\t\t});\n\n\t\t}else{\n\t\t\tactiveRows = rowList.slice(0);\n\t\t}\n\n\t\tif(this.subscribedExternal(\"dataFiltered\")){\n\n\t\t\tactiveRows.forEach((row) => {\n\t\t\t\tactiveRowComponents.push(row.getComponent());\n\t\t\t});\n\n\t\t\tthis.dispatchExternal(\"dataFiltered\", this.getFilters(true), activeRowComponents);\n\t\t}\n\n\t\treturn activeRows;\n\t}\n\n\t//filter individual row\n\tfilterRow(row, filters){\n\t\tvar match = true,\n\t\tdata = row.getData();\n\n\t\tthis.filterList.forEach((filter) => {\n\t\t\tif(!this.filterRecurse(filter, data)){\n\t\t\t\tmatch = false;\n\t\t\t}\n\t\t});\n\n\n\t\tfor(var field in this.headerFilters){\n\t\t\tif(!this.headerFilters[field].func(data)){\n\t\t\t\tmatch = false;\n\t\t\t}\n\t\t}\n\n\t\treturn match;\n\t}\n\n\tfilterRecurse(filter, data){\n\t\tvar match = false;\n\n\t\tif(Array.isArray(filter)){\n\t\t\tfilter.forEach((subFilter) => {\n\t\t\t\tif(this.filterRecurse(subFilter, data)){\n\t\t\t\t\tmatch = true;\n\t\t\t\t}\n\t\t\t});\n\t\t}else{\n\t\t\tmatch = filter.func(data);\n\t\t}\n\n\t\treturn match;\n\t}\n}\n\nFilter.moduleName = \"filter\";\n\n//load defaults\nFilter.filters = defaultFilters;\n\nexport default Filter;","import plaintext from './formatters/plaintext.js';\nimport html from './formatters/html.js';\nimport textarea from './formatters/textarea.js';\nimport money from './formatters/money.js';\nimport link from './formatters/link.js';\nimport image from './formatters/image.js';\nimport tickCross from './formatters/tickCross.js';\nimport datetime from './formatters/datetime.js';\nimport datetimediff from './formatters/datetimediff.js';\nimport lookup from './formatters/lookup.js';\nimport star from './formatters/star.js';\nimport traffic from './formatters/traffic.js';\nimport progress from './formatters/progress.js';\nimport color from './formatters/color.js';\nimport buttonTick from './formatters/buttonTick.js';\nimport buttonCross from './formatters/buttonCross.js';\nimport rownum from './formatters/rownum.js';\nimport handle from './formatters/handle.js';\nimport responsiveCollapse from './formatters/responsiveCollapse.js';\nimport rowSelection from './formatters/rowSelection.js';\n\nexport default {\n\tplaintext:plaintext,\n\thtml:html,\n\ttextarea:textarea,\n\tmoney:money,\n\tlink:link,\n\timage:image,\n\ttickCross:tickCross,\n\tdatetime:datetime,\n\tdatetimediff:datetimediff,\n\tlookup:lookup,\n\tstar:star,\n\ttraffic:traffic,\n\tprogress:progress,\n\tcolor:color,\n\tbuttonTick:buttonTick,\n\tbuttonCross:buttonCross,\n\trownum:rownum,\n\thandle:handle,\n\tresponsiveCollapse:responsiveCollapse,\n\trowSelection:rowSelection,\n};","export default function(cell, formatterParams, onRendered){\n\treturn this.emptyToSpace(this.sanitizeHTML(cell.getValue()));\n}","export default function(cell, formatterParams, onRendered){\n\treturn cell.getValue();\n}","export default function(cell, formatterParams, onRendered){\n\tcell.getElement().style.whiteSpace = \"pre-wrap\";\n\treturn this.emptyToSpace(this.sanitizeHTML(cell.getValue()));\n}","export default function(cell, formatterParams, onRendered){\n\tvar floatVal = parseFloat(cell.getValue()),\n\tsign = \"\",\n\tnumber, integer, decimal, rgx, value;\n\n\tvar decimalSym = formatterParams.decimal || \".\";\n\tvar thousandSym = formatterParams.thousand || \",\";\n\tvar negativeSign = formatterParams.negativeSign || \"-\";\n\tvar symbol = formatterParams.symbol || \"\";\n\tvar after = !!formatterParams.symbolAfter;\n\tvar precision = typeof formatterParams.precision !== \"undefined\" ? formatterParams.precision : 2;\n\n\tif(isNaN(floatVal)){\n\t\treturn this.emptyToSpace(this.sanitizeHTML(cell.getValue()));\n\t}\n\n\tif(floatVal < 0){\n\t\tfloatVal = Math.abs(floatVal);\n\t\tsign = negativeSign;\n\t}\n\n\tnumber = precision !== false ? floatVal.toFixed(precision) : floatVal;\n\tnumber = String(number).split(\".\");\n\n\tinteger = number[0];\n\tdecimal = number.length > 1 ? decimalSym + number[1] : \"\";\n\n\tif (formatterParams.thousand !== false) {\n\t\trgx = /(\\d+)(\\d{3})/;\n\n\t\twhile (rgx.test(integer)){\n\t\t\tinteger = integer.replace(rgx, \"$1\" + thousandSym + \"$2\");\n\t\t}\n\t}\n\n\tvalue = integer + decimal;\n\t\n\tif(sign === true){\n\t\tvalue = \"(\" + value + \")\";\n\t\treturn after ? value + symbol : symbol + value;\n\t}else{\n\t\treturn after ? sign + value + symbol : sign + symbol + value;\n\t}\n}","export default function(cell, formatterParams, onRendered){\n\tvar value = cell.getValue(),\n\turlPrefix = formatterParams.urlPrefix || \"\",\n\tdownload = formatterParams.download,\n\tlabel = value,\n\tel = document.createElement(\"a\"),\n\tdata;\n\n\tfunction labelTraverse(path, data){\n\t\tvar item = path.shift(),\n\t\tvalue = data[item];\n\t\t\n\t\tif(path.length && typeof value === \"object\"){\n\t\t\treturn labelTraverse(path, value);\n\t\t}\n\n\t\treturn value;\n\t}\n\n\tif(formatterParams.labelField){\n\t\tdata = cell.getData();\n\t\tlabel = labelTraverse(formatterParams.labelField.split(this.table.options.nestedFieldSeparator), data);\n\t}\n\n\tif(formatterParams.label){\n\t\tswitch(typeof formatterParams.label){\n\t\t\tcase \"string\":\n\t\t\t\tlabel = formatterParams.label;\n\t\t\t\tbreak;\n\n\t\t\tcase \"function\":\n\t\t\t\tlabel = formatterParams.label(cell);\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\tif(label){\n\t\tif(formatterParams.urlField){\n\t\t\tdata = cell.getData();\n\t\t\tvalue = data[formatterParams.urlField];\n\t\t}\n\n\t\tif(formatterParams.url){\n\t\t\tswitch(typeof formatterParams.url){\n\t\t\t\tcase \"string\":\n\t\t\t\t\tvalue = formatterParams.url;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"function\":\n\t\t\t\t\tvalue = formatterParams.url(cell);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tel.setAttribute(\"href\", urlPrefix + value);\n\n\t\tif(formatterParams.target){\n\t\t\tel.setAttribute(\"target\", formatterParams.target);\n\t\t}\n\n\t\tif(formatterParams.download){\n\n\t\t\tif(typeof download == \"function\"){\n\t\t\t\tdownload = download(cell);\n\t\t\t}else{\n\t\t\t\tdownload = download === true ? \"\" : download;\n\t\t\t}\n\n\t\t\tel.setAttribute(\"download\", download);\n\t\t}\n\n\t\tel.innerHTML = this.emptyToSpace(this.sanitizeHTML(label));\n\n\t\treturn el;\n\t}else{\n\t\treturn \" \";\n\t}\n}","export default function(cell, formatterParams, onRendered){\n\tvar el = document.createElement(\"img\"),\n\tsrc = cell.getValue();\n\n\tif(formatterParams.urlPrefix){\n\t\tsrc = formatterParams.urlPrefix + cell.getValue();\n\t}\n\n\tif(formatterParams.urlSuffix){\n\t\tsrc = src + formatterParams.urlSuffix;\n\t}\n\n\tel.setAttribute(\"src\", src);\n\n\tswitch(typeof formatterParams.height){\n\t\tcase \"number\":\n\t\t\tel.style.height = formatterParams.height + \"px\";\n\t\t\tbreak;\n\n\t\tcase \"string\":\n\t\t\tel.style.height = formatterParams.height;\n\t\t\tbreak;\n\t}\n\n\tswitch(typeof formatterParams.width){\n\t\tcase \"number\":\n\t\t\tel.style.width = formatterParams.width + \"px\";\n\t\t\tbreak;\n\n\t\tcase \"string\":\n\t\t\tel.style.width = formatterParams.width;\n\t\t\tbreak;\n\t}\n\n\tel.addEventListener(\"load\", function(){\n\t\tcell.getRow().normalizeHeight();\n\t});\n\n\treturn el;\n}","export default function(cell, formatterParams, onRendered){\n\tvar value = cell.getValue(),\n\telement = cell.getElement(),\n\tempty = formatterParams.allowEmpty,\n\ttruthy = formatterParams.allowTruthy,\n\ttrueValueSet = Object.keys(formatterParams).includes(\"trueValue\"),\n\ttick = typeof formatterParams.tickElement !== \"undefined\" ? formatterParams.tickElement : '',\n\tcross = typeof formatterParams.crossElement !== \"undefined\" ? formatterParams.crossElement : '';\n\n\tif((trueValueSet && value === formatterParams.trueValue) || (!trueValueSet && ((truthy && value) || (value === true || value === \"true\" || value === \"True\" || value === 1 || value === \"1\")))){\n\t\telement.setAttribute(\"aria-checked\", true);\n\t\treturn tick || \"\";\n\t}else{\n\t\tif(empty && (value === \"null\" || value === \"\" || value === null || typeof value === \"undefined\")){\n\t\t\telement.setAttribute(\"aria-checked\", \"mixed\");\n\t\t\treturn \"\";\n\t\t}else{\n\t\t\telement.setAttribute(\"aria-checked\", false);\n\t\t\treturn cross || \"\";\n\t\t}\n\t}\n}","export default function(cell, formatterParams, onRendered){\n\tvar DT = window.DateTime || luxon.DateTime;\n\tvar inputFormat = formatterParams.inputFormat || \"yyyy-MM-dd HH:mm:ss\";\n\tvar\toutputFormat = formatterParams.outputFormat || \"dd/MM/yyyy HH:mm:ss\";\n\tvar\tinvalid = typeof formatterParams.invalidPlaceholder !== \"undefined\" ? formatterParams.invalidPlaceholder : \"\";\n\tvar value = cell.getValue();\n\n\tif(typeof DT != \"undefined\"){\n\t\tvar newDatetime;\n\n\t\tif(DT.isDateTime(value)){\n\t\t\tnewDatetime = value;\n\t\t}else if(inputFormat === \"iso\"){\n\t\t\tnewDatetime = DT.fromISO(String(value));\n\t\t}else{\n\t\t\tnewDatetime = DT.fromFormat(String(value), inputFormat);\n\t\t}\n\n\t\tif(newDatetime.isValid){\n\t\t\tif(formatterParams.timezone){\n\t\t\t\tnewDatetime = newDatetime.setZone(formatterParams.timezone);\n\t\t\t}\n\n\t\t\treturn newDatetime.toFormat(outputFormat);\n\t\t}else{\n\t\t\tif(invalid === true || !value){\n\t\t\t\treturn value;\n\t\t\t}else if(typeof invalid === \"function\"){\n\t\t\t\treturn invalid(value);\n\t\t\t}else{\n\t\t\t\treturn invalid;\n\t\t\t}\n\t\t}\n\t}else{\n\t\tconsole.error(\"Format Error - 'datetime' formatter is dependant on luxon.js\");\n\t}\n}","export default function (cell, formatterParams, onRendered) {\n\tvar DT = window.DateTime || luxon.DateTime;\n\tvar inputFormat = formatterParams.inputFormat || \"yyyy-MM-dd HH:mm:ss\";\n\tvar invalid = typeof formatterParams.invalidPlaceholder !== \"undefined\" ? formatterParams.invalidPlaceholder : \"\";\n\tvar suffix = typeof formatterParams.suffix !== \"undefined\" ? formatterParams.suffix : false;\n\tvar unit = typeof formatterParams.unit !== \"undefined\" ? formatterParams.unit : \"days\";\n\tvar humanize = typeof formatterParams.humanize !== \"undefined\" ? formatterParams.humanize : false;\n\tvar date = typeof formatterParams.date !== \"undefined\" ? formatterParams.date : DT.now();\n\tvar value = cell.getValue();\n\n\tif(typeof DT != \"undefined\"){\n\t\tvar newDatetime;\n\n\t\tif(DT.isDateTime(value)){\n\t\t\tnewDatetime = value;\n\t\t}else if(inputFormat === \"iso\"){\n\t\t\tnewDatetime = DT.fromISO(String(value));\n\t\t}else{\n\t\t\tnewDatetime = DT.fromFormat(String(value), inputFormat);\n\t\t}\n\n\t\tif (newDatetime.isValid){\n\t\t\tif(humanize){\n\t\t\t\treturn newDatetime.diff(date, unit).toHuman() + (suffix ? \" \" + suffix : \"\");\n\t\t\t}else{\n\t\t\t\treturn parseInt(newDatetime.diff(date, unit)[unit]) + (suffix ? \" \" + suffix : \"\");\n\t\t\t}\n\t\t} else {\n\n\t\t\tif (invalid === true) {\n\t\t\t\treturn value;\n\t\t\t} else if (typeof invalid === \"function\") {\n\t\t\t\treturn invalid(value);\n\t\t\t} else {\n\t\t\t\treturn invalid;\n\t\t\t}\n\t\t}\n\t}else{\n\t\tconsole.error(\"Format Error - 'datetimediff' formatter is dependant on luxon.js\");\n\t}\n}","export default function (cell, formatterParams, onRendered) {\n\tvar value = cell.getValue();\n\n\tif (typeof formatterParams[value] === \"undefined\") {\n\t\tconsole.warn('Missing display value for ' + value);\n\t\treturn value;\n\t}\n\n\treturn formatterParams[value];\n}","export default function(cell, formatterParams, onRendered){\n\tvar value = cell.getValue(),\n\telement = cell.getElement(),\n\tmaxStars = formatterParams && formatterParams.stars ? formatterParams.stars : 5,\n\tstars = document.createElement(\"span\"),\n\tstar = document.createElementNS('http://www.w3.org/2000/svg', \"svg\"),\n\tstarActive = '',\n\tstarInactive = '';\n\n\t//style stars holder\n\tstars.style.verticalAlign = \"middle\";\n\n\t//style star\n\tstar.setAttribute(\"width\", \"14\");\n\tstar.setAttribute(\"height\", \"14\");\n\tstar.setAttribute(\"viewBox\", \"0 0 512 512\");\n\tstar.setAttribute(\"xml:space\", \"preserve\");\n\tstar.style.padding = \"0 1px\";\n\n\tvalue = value && !isNaN(value) ? parseInt(value) : 0;\n\n\tvalue = Math.max(0, Math.min(value, maxStars));\n\n\tfor(var i=1;i<= maxStars;i++){\n\t\tvar nextStar = star.cloneNode(true);\n\t\tnextStar.innerHTML = i <= value ? starActive : starInactive;\n\n\t\tstars.appendChild(nextStar);\n\t}\n\n\telement.style.whiteSpace = \"nowrap\";\n\telement.style.overflow = \"hidden\";\n\telement.style.textOverflow = \"ellipsis\";\n\n\telement.setAttribute(\"aria-label\", value);\n\n\treturn stars;\n}","export default function(cell, formatterParams, onRendered){\n\tvar value = this.sanitizeHTML(cell.getValue()) || 0,\n\tel = document.createElement(\"span\"),\n\tmax = formatterParams && formatterParams.max ? formatterParams.max : 100,\n\tmin = formatterParams && formatterParams.min ? formatterParams.min : 0,\n\tcolors = formatterParams && typeof formatterParams.color !== \"undefined\" ? formatterParams.color : [\"red\", \"orange\", \"green\"],\n\tcolor = \"#666666\",\n\tpercent, percentValue;\n\n\tif(isNaN(value) || typeof cell.getValue() === \"undefined\"){\n\t\treturn;\n\t}\n\n\tel.classList.add(\"tabulator-traffic-light\");\n\n\t//make sure value is in range\n\tpercentValue = parseFloat(value) <= max ? parseFloat(value) : max;\n\tpercentValue = parseFloat(percentValue) >= min ? parseFloat(percentValue) : min;\n\n\t//workout percentage\n\tpercent = (max - min) / 100;\n\tpercentValue = Math.round((percentValue - min) / percent);\n\n\t//set color\n\tswitch(typeof colors){\n\t\tcase \"string\":\n\t\t\tcolor = colors;\n\t\t\tbreak;\n\t\tcase \"function\":\n\t\t\tcolor = colors(value);\n\t\t\tbreak;\n\t\tcase \"object\":\n\t\t\tif(Array.isArray(colors)){\n\t\t\t\tvar unit = 100 / colors.length;\n\t\t\t\tvar index = Math.floor(percentValue / unit);\n\n\t\t\t\tindex = Math.min(index, colors.length - 1);\n\t\t\t\tindex = Math.max(index, 0);\n\t\t\t\tcolor = colors[index];\n\t\t\t\tbreak;\n\t\t\t}\n\t}\n\n\tel.style.backgroundColor = color;\n\n\treturn el;\n}","import CellComponent from '../../../../core/cell/CellComponent.js';\n\nexport default function(cell, formatterParams = {}, onRendered){ //progress bar\n\tvar value = this.sanitizeHTML(cell.getValue()) || 0,\n\telement = cell.getElement(),\n\tmax = formatterParams.max ? formatterParams.max : 100,\n\tmin = formatterParams.min ? formatterParams.min : 0,\n\tlegendAlign = formatterParams.legendAlign ? formatterParams.legendAlign : \"center\",\n\tpercent, percentValue, color, legend, legendColor;\n\n\t//make sure value is in range\n\tpercentValue = parseFloat(value) <= max ? parseFloat(value) : max;\n\tpercentValue = parseFloat(percentValue) >= min ? parseFloat(percentValue) : min;\n\n\t//workout percentage\n\tpercent = (max - min) / 100;\n\tpercentValue = Math.round((percentValue - min) / percent);\n\n\t//set bar color\n\tswitch(typeof formatterParams.color){\n\t\tcase \"string\":\n\t\t\tcolor = formatterParams.color;\n\t\t\tbreak;\n\t\tcase \"function\":\n\t\t\tcolor = formatterParams.color(value);\n\t\t\tbreak;\n\t\tcase \"object\":\n\t\t\tif(Array.isArray(formatterParams.color)){\n\t\t\t\tlet unit = 100 / formatterParams.color.length;\n\t\t\t\tlet index = Math.floor(percentValue / unit);\n\n\t\t\t\tindex = Math.min(index, formatterParams.color.length - 1);\n\t\t\t\tindex = Math.max(index, 0);\n\t\t\t\tcolor = formatterParams.color[index];\n\t\t\t\tbreak;\n\t\t\t}\n\t\tdefault:\n\t\t\tcolor = \"#2DC214\";\n\t}\n\n\t//generate legend\n\tswitch(typeof formatterParams.legend){\n\t\tcase \"string\":\n\t\t\tlegend = formatterParams.legend;\n\t\t\tbreak;\n\t\tcase \"function\":\n\t\t\tlegend = formatterParams.legend(value);\n\t\t\tbreak;\n\t\tcase \"boolean\":\n\t\t\tlegend = value;\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tlegend = false;\n\t}\n\n\t//set legend color\n\tswitch(typeof formatterParams.legendColor){\n\t\tcase \"string\":\n\t\t\tlegendColor = formatterParams.legendColor;\n\t\t\tbreak;\n\t\tcase \"function\":\n\t\t\tlegendColor = formatterParams.legendColor(value);\n\t\t\tbreak;\n\t\tcase \"object\":\n\t\t\tif(Array.isArray(formatterParams.legendColor)){\n\t\t\t\tlet unit = 100 / formatterParams.legendColor.length;\n\t\t\t\tlet index = Math.floor(percentValue / unit);\n\n\t\t\t\tindex = Math.min(index, formatterParams.legendColor.length - 1);\n\t\t\t\tindex = Math.max(index, 0);\n\t\t\t\tlegendColor = formatterParams.legendColor[index];\n\t\t\t}\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tlegendColor = \"#000\";\n\t}\n\n\telement.style.minWidth = \"30px\";\n\telement.style.position = \"relative\";\n\n\telement.setAttribute(\"aria-label\", percentValue);\n\n\tvar barEl = document.createElement(\"div\");\n\tbarEl.style.display = \"inline-block\";\n\tbarEl.style.width = percentValue + \"%\";\n\tbarEl.style.backgroundColor = color;\n\tbarEl.style.height = \"100%\";\n\n\tbarEl.setAttribute('data-max', max);\n\tbarEl.setAttribute('data-min', min);\n\n\tvar barContainer = document.createElement(\"div\");\n\tbarContainer.style.position = \"relative\";\n\tbarContainer.style.width = \"100%\";\n\tbarContainer.style.height = \"100%\";\n\n\tif(legend){\n\t\tvar legendEl = document.createElement(\"div\");\n\t\tlegendEl.style.position = \"absolute\";\n\t\tlegendEl.style.top = 0;\n\t\tlegendEl.style.left = 0;\n\t\tlegendEl.style.textAlign = legendAlign;\n\t\tlegendEl.style.width = \"100%\";\n\t\tlegendEl.style.color = legendColor;\n\t\tlegendEl.innerHTML = legend;\n\t}\n\n\tonRendered(function(){\n\n\t\t//handle custom element needed if formatter is to be included in printed/downloaded output\n\t\tif(!(cell instanceof CellComponent)){\n\t\t\tvar holderEl = document.createElement(\"div\");\n\t\t\tholderEl.style.position = \"absolute\";\n\t\t\tholderEl.style.top = \"4px\";\n\t\t\tholderEl.style.bottom = \"4px\";\n\t\t\tholderEl.style.left = \"4px\";\n\t\t\tholderEl.style.right = \"4px\";\n\n\t\t\telement.appendChild(holderEl);\n\n\t\t\telement = holderEl;\n\t\t}\n\n\t\telement.appendChild(barContainer);\n\t\tbarContainer.appendChild(barEl);\n\n\t\tif(legend){\n\t\t\tbarContainer.appendChild(legendEl);\n\t\t}\n\t});\n\n\treturn \"\";\n}","export default function(cell, formatterParams, onRendered){\n\tcell.getElement().style.backgroundColor = this.sanitizeHTML(cell.getValue());\n\treturn \"\";\n}","export default function(cell, formatterParams, onRendered){\n\treturn '';\n}","export default function(cell, formatterParams, onRendered){\n\treturn '';\n}","export default function(cell, formatterParams, onRendered){\n\tvar content = document.createElement(\"span\");\n\tvar row = cell.getRow();\n\n\trow.watchPosition((position) => {\n\t\tcontent.innerText = position;\n\t});\n\t\n\treturn content;\n}","export default function(cell, formatterParams, onRendered){\n\tcell.getElement().classList.add(\"tabulator-row-handle\");\n\treturn \"
\";\n}","export default function(cell, formatterParams, onRendered){\n\tvar el = document.createElement(\"div\"),\n\tconfig = cell.getRow()._row.modules.responsiveLayout;\n\n\tel.classList.add(\"tabulator-responsive-collapse-toggle\");\n\t\n\tel.innerHTML = `\n \n \n\n\n\n \n`;\n\n\tcell.getElement().classList.add(\"tabulator-row-handle\");\n\n\tfunction toggleList(isOpen){\n\t\tvar collapseEl = config.element;\n\n\t\tconfig.open = isOpen;\n\n\t\tif(collapseEl){\n\n\t\t\tif(config.open){\n\t\t\t\tel.classList.add(\"open\");\n\t\t\t\tcollapseEl.style.display = '';\n\t\t\t}else{\n\t\t\t\tel.classList.remove(\"open\");\n\t\t\t\tcollapseEl.style.display = 'none';\n\t\t\t}\n\t\t}\n\t}\n\n\tel.addEventListener(\"click\", function(e){\n\t\te.stopImmediatePropagation();\n\t\ttoggleList(!config.open);\n\t\tcell.getTable().rowManager.adjustTableSize();\n\t});\n\n\ttoggleList(config.open);\n\n\treturn el;\n}","import RowComponent from '../../../../core/row/RowComponent.js';\n\nexport default function(cell, formatterParams, onRendered){\n\tvar checkbox = document.createElement(\"input\");\n\tvar blocked = false;\n\n\tcheckbox.type = 'checkbox';\n\n\tcheckbox.setAttribute(\"aria-label\", \"Select Row\");\n\t\n\tif(this.table.modExists(\"selectRow\", true)){\n\n\t\tcheckbox.addEventListener(\"click\", (e) => {\n\t\t\te.stopPropagation();\n\t\t});\n\n\t\tif(typeof cell.getRow == 'function'){\n\t\t\tvar row = cell.getRow();\n\n\t\t\tif(row instanceof RowComponent){\n\n\t\t\t\tcheckbox.addEventListener(\"change\", (e) => {\n\t\t\t\t\tif(this.table.options.selectableRangeMode === \"click\"){\n\t\t\t\t\t\tif(!blocked){\n\t\t\t\t\t\t\trow.toggleSelect();\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tblocked = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\trow.toggleSelect();\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tif(this.table.options.selectableRangeMode === \"click\"){\n\t\t\t\t\tcheckbox.addEventListener(\"click\", (e) => {\n\t\t\t\t\t\tblocked = true;\n\t\t\t\t\t\tthis.table.modules.selectRow.handleComplexRowClick(row._row, e);\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\tcheckbox.checked = row.isSelected && row.isSelected();\n\t\t\t\tthis.table.modules.selectRow.registerRowSelectCheckbox(row, checkbox);\n\t\t\t}else{\n\t\t\t\tcheckbox = \"\";\n\t\t\t}\n\t\t}else {\n\t\t\tcheckbox.addEventListener(\"change\", (e) => {\n\t\t\t\tif(this.table.modules.selectRow.selectedRows.length){\n\t\t\t\t\tthis.table.deselectRow();\n\t\t\t\t}else {\n\t\t\t\t\tthis.table.selectRow(formatterParams.rowRange);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.table.modules.selectRow.registerHeaderSelectCheckbox(checkbox);\n\t\t}\n\t}\n\n\treturn checkbox;\n}","import Module from '../../core/Module.js';\n\nimport defaultFormatters from './defaults/formatters.js';\n\nclass Format extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.registerColumnOption(\"formatter\");\n\t\tthis.registerColumnOption(\"formatterParams\");\n\t\t\n\t\tthis.registerColumnOption(\"formatterPrint\");\n\t\tthis.registerColumnOption(\"formatterPrintParams\");\n\t\tthis.registerColumnOption(\"formatterClipboard\");\n\t\tthis.registerColumnOption(\"formatterClipboardParams\");\n\t\tthis.registerColumnOption(\"formatterHtmlOutput\");\n\t\tthis.registerColumnOption(\"formatterHtmlOutputParams\");\n\t\tthis.registerColumnOption(\"titleFormatter\");\n\t\tthis.registerColumnOption(\"titleFormatterParams\");\n\t}\n\t\n\tinitialize(){\n\t\tthis.subscribe(\"cell-format\", this.formatValue.bind(this));\n\t\tthis.subscribe(\"cell-rendered\", this.cellRendered.bind(this));\n\t\tthis.subscribe(\"column-layout\", this.initializeColumn.bind(this));\n\t\tthis.subscribe(\"column-format\", this.formatHeader.bind(this));\n\t}\n\t\n\t//initialize column formatter\n\tinitializeColumn(column){\n\t\tcolumn.modules.format = this.lookupFormatter(column, \"\");\n\t\t\n\t\tif(typeof column.definition.formatterPrint !== \"undefined\"){\n\t\t\tcolumn.modules.format.print = this.lookupFormatter(column, \"Print\");\n\t\t}\n\t\t\n\t\tif(typeof column.definition.formatterClipboard !== \"undefined\"){\n\t\t\tcolumn.modules.format.clipboard = this.lookupFormatter(column, \"Clipboard\");\n\t\t}\n\t\t\n\t\tif(typeof column.definition.formatterHtmlOutput !== \"undefined\"){\n\t\t\tcolumn.modules.format.htmlOutput = this.lookupFormatter(column, \"HtmlOutput\");\n\t\t}\n\t}\n\t\n\tlookupFormatter(column, type){\n\t\tvar config = {params:column.definition[\"formatter\" + type + \"Params\"] || {}},\n\t\tformatter = column.definition[\"formatter\" + type];\n\t\t\n\t\t//set column formatter\n\t\tswitch(typeof formatter){\n\t\t\tcase \"string\":\n\t\t\t\tif(Format.formatters[formatter]){\n\t\t\t\t\tconfig.formatter = Format.formatters[formatter];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Formatter Error - No such formatter found: \", formatter);\n\t\t\t\t\tconfig.formatter = Format.formatters.plaintext;\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"function\":\n\t\t\t\tconfig.formatter = formatter;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tdefault:\n\t\t\t\tconfig.formatter = Format.formatters.plaintext;\n\t\t\t\tbreak;\n\t\t}\n\t\t\n\t\treturn config;\n\t}\n\t\n\tcellRendered(cell){\n\t\tif(cell.modules.format && cell.modules.format.renderedCallback && !cell.modules.format.rendered){\n\t\t\tcell.modules.format.renderedCallback();\n\t\t\tcell.modules.format.rendered = true;\n\t\t}\n\t}\n\t\n\t//return a formatted value for a column header\n\tformatHeader(column, title, el){\n\t\tvar formatter, params, onRendered, mockCell;\n\t\t\n\t\tif(column.definition.titleFormatter){\n\t\t\tformatter = this.getFormatter(column.definition.titleFormatter);\n\t\t\t\n\t\t\tonRendered = (callback) => {\n\t\t\t\tcolumn.titleFormatterRendered = callback;\n\t\t\t};\n\t\t\t\n\t\t\tmockCell = {\n\t\t\t\tgetValue:function(){\n\t\t\t\t\treturn title;\n\t\t\t\t},\n\t\t\t\tgetElement:function(){\n\t\t\t\t\treturn el;\n\t\t\t\t},\n\t\t\t\tgetType:function(){\n\t\t\t\t\treturn \"header\";\n\t\t\t\t},\n\t\t\t\tgetColumn:function(){\n\t\t\t\t\treturn column.getComponent();\n\t\t\t\t},\n\t\t\t\tgetTable:() => {\n\t\t\t\t\treturn this.table;\n\t\t\t\t}\n\t\t\t};\n\t\t\t\n\t\t\tparams = column.definition.titleFormatterParams || {};\n\t\t\t\n\t\t\tparams = typeof params === \"function\" ? params() : params;\n\t\t\t\n\t\t\treturn formatter.call(this, mockCell, params, onRendered);\n\t\t}else{\n\t\t\treturn title;\n\t\t}\n\t}\n\t\n\t\n\t//return a formatted value for a cell\n\tformatValue(cell){\n\t\tvar component = cell.getComponent(),\n\t\tparams = typeof cell.column.modules.format.params === \"function\" ? cell.column.modules.format.params(component) : cell.column.modules.format.params;\n\t\t\n\t\tfunction onRendered(callback){\n\t\t\tif(!cell.modules.format){\n\t\t\t\tcell.modules.format = {};\n\t\t\t}\n\t\t\t\n\t\t\tcell.modules.format.renderedCallback = callback;\n\t\t\tcell.modules.format.rendered = false;\n\t\t}\n\t\t\n\t\treturn cell.column.modules.format.formatter.call(this, component, params, onRendered);\n\t}\n\t\n\tformatExportValue(cell, type){\n\t\tvar formatter = cell.column.modules.format[type],\n\t\tparams;\n\t\t\n\t\tif(formatter){\n\t\t\tparams = typeof formatter.params === \"function\" ? formatter.params(cell.getComponent()) : formatter.params;\n\t\t\t\n\t\t\tfunction onRendered(callback){\n\t\t\t\tif(!cell.modules.format){\n\t\t\t\t\tcell.modules.format = {};\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tcell.modules.format.renderedCallback = callback;\n\t\t\t\tcell.modules.format.rendered = false;\n\t\t\t}\n\t\t\t\n\t\t\treturn formatter.formatter.call(this, cell.getComponent(), params, onRendered);\n\t\t\t\n\t\t}else{\n\t\t\treturn this.formatValue(cell);\n\t\t}\n\t}\n\t\n\tsanitizeHTML(value){\n\t\tif(value){\n\t\t\tvar entityMap = {\n\t\t\t\t'&': '&',\n\t\t\t\t'<': '<',\n\t\t\t\t'>': '>',\n\t\t\t\t'\"': '"',\n\t\t\t\t\"'\": ''',\n\t\t\t\t'/': '/',\n\t\t\t\t'`': '`',\n\t\t\t\t'=': '='\n\t\t\t};\n\t\t\t\n\t\t\treturn String(value).replace(/[&<>\"'`=/]/g, function (s) {\n\t\t\t\treturn entityMap[s];\n\t\t\t});\n\t\t}else{\n\t\t\treturn value;\n\t\t}\n\t}\n\t\n\temptyToSpace(value){\n\t\treturn value === null || typeof value === \"undefined\" || value === \"\" ? \" \" : value;\n\t}\n\t\n\t//get formatter for cell\n\tgetFormatter(formatter){\n\t\tswitch(typeof formatter){\n\t\t\tcase \"string\":\n\t\t\t\tif(Format.formatters[formatter]){\n\t\t\t\t\tformatter = Format.formatters[formatter];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Formatter Error - No such formatter found: \", formatter);\n\t\t\t\t\tformatter = Format.formatters.plaintext;\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"function\":\n\t\t\t//Custom formatter Function, do nothing\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tdefault:\n\t\t\t\tformatter = Format.formatters.plaintext;\n\t\t\t\tbreak;\n\t\t}\n\t\t\n\t\treturn formatter;\n\t}\n}\n\nFormat.moduleName = \"format\";\n\n//load defaults\nFormat.formatters = defaultFormatters;\n\nexport default Format;","import Module from '../../core/Module.js';\n\nclass FrozenColumns extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.leftColumns = [];\n\t\tthis.rightColumns = [];\n\t\tthis.initializationMode = \"left\";\n\t\tthis.active = false;\n\t\tthis.blocked = true;\n\t\t\n\t\tthis.registerColumnOption(\"frozen\");\n\t}\n\t\n\t//reset initial state\n\treset(){\n\t\tthis.initializationMode = \"left\";\n\t\tthis.leftColumns = [];\n\t\tthis.rightColumns = [];\n\t\tthis.active = false;\n\t}\n\t\n\tinitialize(){\n\t\tthis.subscribe(\"cell-layout\", this.layoutCell.bind(this));\n\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t\tthis.subscribe(\"column-width\", this.layout.bind(this));\n\t\tthis.subscribe(\"row-layout-after\", this.layoutRow.bind(this));\n\t\tthis.subscribe(\"table-layout\", this.layout.bind(this));\n\t\tthis.subscribe(\"columns-loading\", this.reset.bind(this));\n\t\t\n\t\tthis.subscribe(\"column-add\", this.reinitializeColumns.bind(this));\n\t\tthis.subscribe(\"column-delete\", this.reinitializeColumns.bind(this));\n\t\t\n\t\tthis.subscribe(\"table-redraw\", this.layout.bind(this));\n\t\tthis.subscribe(\"layout-refreshing\", this.blockLayout.bind(this));\n\t\tthis.subscribe(\"layout-refreshed\", this.unblockLayout.bind(this));\n\t\tthis.subscribe(\"scrollbar-vertical\", this.adjustForScrollbar.bind(this));\n\t}\n\t\n\tblockLayout(){\n\t\tthis.blocked = true;\n\t}\n\t\n\tunblockLayout(){\n\t\tthis.blocked = false;\n\t}\n\t\n\tlayoutCell(cell){\n\t\tthis.layoutElement(cell.element, cell.column);\n\t}\n\t\n\treinitializeColumns(){\n\t\tthis.reset();\n\t\t\n\t\tthis.table.columnManager.columnsByIndex.forEach((column) => {\n\t\t\tthis.initializeColumn(column);\n\t\t});\n\t}\n\t\n\t//initialize specific column\n\tinitializeColumn(column){\n\t\tvar config = {margin:0, edge:false};\n\t\t\n\t\tif(!column.isGroup){\n\t\t\t\n\t\t\tif(this.frozenCheck(column)){\n\t\t\t\t\n\t\t\t\tconfig.position = this.initializationMode;\n\t\t\t\t\n\t\t\t\tif(this.initializationMode == \"left\"){\n\t\t\t\t\tthis.leftColumns.push(column);\n\t\t\t\t}else{\n\t\t\t\t\tthis.rightColumns.unshift(column);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.active = true;\n\t\t\t\t\n\t\t\t\tcolumn.modules.frozen = config;\n\t\t\t}else{\n\t\t\t\tthis.initializationMode = \"right\";\n\t\t\t}\n\t\t}\n\t}\n\t\n\tfrozenCheck(column){\n\t\tif(column.parent.isGroup && column.definition.frozen){\n\t\t\tconsole.warn(\"Frozen Column Error - Parent column group must be frozen, not individual columns or sub column groups\");\n\t\t}\n\t\t\n\t\tif(column.parent.isGroup){\n\t\t\treturn this.frozenCheck(column.parent);\n\t\t}else{\n\t\t\treturn column.definition.frozen;\n\t\t}\n\t}\n\t\n\t//layout calculation rows\n\tlayoutCalcRows(){\n\t\tif(this.table.modExists(\"columnCalcs\")){\n\t\t\tif(this.table.modules.columnCalcs.topInitialized && this.table.modules.columnCalcs.topRow){\n\t\t\t\tthis.layoutRow(this.table.modules.columnCalcs.topRow);\n\t\t\t}\n\t\t\t\n\t\t\tif(this.table.modules.columnCalcs.botInitialized && this.table.modules.columnCalcs.botRow){\n\t\t\t\tthis.layoutRow(this.table.modules.columnCalcs.botRow);\n\t\t\t}\n\t\t\t\n\t\t\tif(this.table.modExists(\"groupRows\")){\n\t\t\t\tthis.layoutGroupCalcs(this.table.modules.groupRows.getGroups());\n\t\t\t}\n\t\t}\n\t}\n\t\n\tlayoutGroupCalcs(groups){\n\t\tgroups.forEach((group) => {\n\t\t\tif(group.calcs.top){\n\t\t\t\tthis.layoutRow(group.calcs.top);\n\t\t\t}\n\t\t\t\n\t\t\tif(group.calcs.bottom){\n\t\t\t\tthis.layoutRow(group.calcs.bottom);\n\t\t\t}\n\t\t\t\n\t\t\tif(group.groupList && group.groupList.length){\n\t\t\t\tthis.layoutGroupCalcs(group.groupList);\n\t\t\t}\n\t\t});\n\t}\n\t\n\t//calculate column positions and layout headers\n\tlayoutColumnPosition(allCells){\n\t\tvar leftParents = [];\n\t\t\n\t\tvar leftMargin = 0;\n\t\tvar rightMargin = 0;\n\t\t\n\t\tthis.leftColumns.forEach((column, i) => {\t\n\t\t\tcolumn.modules.frozen.marginValue = leftMargin;\n\t\t\tcolumn.modules.frozen.margin = column.modules.frozen.marginValue + \"px\";\n\t\t\t\n\t\t\tif(column.visible){\n\t\t\t\tleftMargin += column.getWidth();\n\t\t\t}\n\t\t\t\n\t\t\tif(i == this.leftColumns.length - 1){\n\t\t\t\tcolumn.modules.frozen.edge = true;\n\t\t\t}else{\n\t\t\t\tcolumn.modules.frozen.edge = false;\n\t\t\t}\n\t\t\t\n\t\t\tif(column.parent.isGroup){\n\t\t\t\tvar parentEl = this.getColGroupParentElement(column);\n\t\t\t\tif(!leftParents.includes(parentEl)){\n\t\t\t\t\tthis.layoutElement(parentEl, column);\n\t\t\t\t\tleftParents.push(parentEl);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(column.modules.frozen.edge){\n\t\t\t\t\tparentEl.classList.add(\"tabulator-frozen-\" + column.modules.frozen.position);\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.layoutElement(column.getElement(), column);\n\t\t\t}\n\t\t\t\n\t\t\tif(allCells){\n\t\t\t\tcolumn.cells.forEach((cell) => {\n\t\t\t\t\tthis.layoutElement(cell.getElement(true), column);\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t\t\n\t\tthis.rightColumns.forEach((column, i) => {\n\t\t\t\n\t\t\tcolumn.modules.frozen.marginValue = rightMargin;\n\t\t\tcolumn.modules.frozen.margin = column.modules.frozen.marginValue + \"px\";\n\t\t\t\n\t\t\tif(column.visible){\n\t\t\t\trightMargin += column.getWidth();\n\t\t\t}\n\t\t\t\n\t\t\tif(i == this.rightColumns.length - 1){\n\t\t\t\tcolumn.modules.frozen.edge = true;\n\t\t\t}else{\n\t\t\t\tcolumn.modules.frozen.edge = false;\n\t\t\t}\n\t\t\t\n\t\t\tif(column.parent.isGroup){\n\t\t\t\tthis.layoutElement(this.getColGroupParentElement(column), column);\n\t\t\t}else{\n\t\t\t\tthis.layoutElement(column.getElement(), column);\n\t\t\t}\n\t\t\t\n\t\t\tif(allCells){\n\t\t\t\tcolumn.cells.forEach((cell) => {\n\t\t\t\t\tthis.layoutElement(cell.getElement(true), column);\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t}\n\t\n\tgetColGroupParentElement(column){\n\t\treturn column.parent.isGroup ? this.getColGroupParentElement(column.parent) : column.getElement();\n\t}\n\t\n\t//layout columns appropriately\n\tlayout(){\t\n\t\tif(this.active && !this.blocked){\n\t\t\n\t\t\t//calculate left columns\n\t\t\tthis.layoutColumnPosition();\n\t\t\t\n\t\t\tthis.reinitializeRows();\n\t\t\t\n\t\t\tthis.layoutCalcRows();\n\t\t}\n\t}\n\t\n\treinitializeRows(){\n\t\tvar visibleRows = this.table.rowManager.getVisibleRows(true);\n\t\tvar otherRows = this.table.rowManager.getRows().filter(row => !visibleRows.includes(row));\n\t\t\n\t\totherRows.forEach((row) =>{\n\t\t\trow.deinitialize();\n\t\t});\n\t\t\n\t\tvisibleRows.forEach((row) =>{\n\t\t\tif(row.type === \"row\"){\n\t\t\t\tthis.layoutRow(row);\n\t\t\t}\n\t\t});\n\t}\n\t\n\tlayoutRow(row){\n\t\tif(this.table.options.layout === \"fitDataFill\" && this.rightColumns.length){\n\t\t\tthis.table.rowManager.getTableElement().style.minWidth = \"calc(100% - \" + this.rightMargin + \")\";\n\t\t}\n\t\t\n\t\tthis.leftColumns.forEach((column) => {\n\t\t\tvar cell = row.getCell(column);\n\t\t\t\n\t\t\tif(cell){\n\t\t\t\tthis.layoutElement(cell.getElement(true), column);\n\t\t\t}\n\t\t});\n\t\t\n\t\tthis.rightColumns.forEach((column) => {\n\t\t\tvar cell = row.getCell(column);\n\t\t\t\n\t\t\tif(cell){\n\t\t\t\tthis.layoutElement(cell.getElement(true), column);\n\t\t\t}\n\t\t});\n\t}\n\t\n\tlayoutElement(element, column){\n\t\tvar position;\n\t\t\n\t\tif(column.modules.frozen && element){\n\t\t\telement.style.position = \"sticky\";\n\n\t\t\tif(this.table.rtl){\n\t\t\t\tposition = column.modules.frozen.position === \"left\" ? \"right\" : \"left\";\n\t\t\t}else{\n\t\t\t\tposition = column.modules.frozen.position;\n\t\t\t}\n\t\t\n\t\t\telement.style[position] = column.modules.frozen.margin;\n\n\t\t\telement.classList.add(\"tabulator-frozen\");\n\t\t\t\n\t\t\tif(column.modules.frozen.edge){\n\t\t\t\telement.classList.add(\"tabulator-frozen-\" + column.modules.frozen.position);\n\t\t\t}\n\t\t}\n\t}\n\n\tadjustForScrollbar(width){\n\t\tif(this.rightColumns.length){\n\t\t\tthis.table.columnManager.getContentsElement().style.width = \"calc(100% - \" + width + \"px)\";\n\t\t}\n\t}\n\t\n\t_calcSpace(columns, index){\n\t\tvar width = 0;\n\t\t\n\t\tfor (let i = 0; i < index; i++){\n\t\t\tif(columns[i].visible){\n\t\t\t\twidth += columns[i].getWidth();\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn width;\n\t}\n}\n\nFrozenColumns.moduleName = \"frozenColumns\";\n\nexport default FrozenColumns;","import Module from '../../core/Module.js';\n\nclass FrozenRows extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.topElement = document.createElement(\"div\");\n\t\tthis.rows = [];\n\n\t\t//register component functions\n\t\tthis.registerComponentFunction(\"row\", \"freeze\", this.freezeRow.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"unfreeze\", this.unfreezeRow.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"isFrozen\", this.isRowFrozen.bind(this));\n\n\t\t//register table options\n\t\tthis.registerTableOption(\"frozenRowsField\", \"id\"); //field to choose frozen rows by\n\t\tthis.registerTableOption(\"frozenRows\", false); //holder for frozen row identifiers\n\t}\n\n\tinitialize(){\n\t\tthis.rows = [];\n\n\t\tthis.topElement.classList.add(\"tabulator-frozen-rows-holder\");\n\n\t\t// this.table.columnManager.element.append(this.topElement);\n\t\tthis.table.columnManager.getContentsElement().insertBefore(this.topElement, this.table.columnManager.headersElement.nextSibling);\n\n\t\tthis.subscribe(\"row-deleting\", this.detachRow.bind(this));\n\t\tthis.subscribe(\"rows-visible\", this.visibleRows.bind(this));\n\n\t\tthis.registerDisplayHandler(this.getRows.bind(this), 10);\n\n\t\tif(this.table.options.frozenRows){\n\t\t\tthis.subscribe(\"data-processed\", this.initializeRows.bind(this));\n\t\t\tthis.subscribe(\"row-added\", this.initializeRow.bind(this));\n\t\t\tthis.subscribe(\"table-redrawing\", this.resizeHolderWidth.bind(this));\n\t\t\tthis.subscribe(\"column-resized\", this.resizeHolderWidth.bind(this));\n\t\t\tthis.subscribe(\"column-show\", this.resizeHolderWidth.bind(this));\n\t\t\tthis.subscribe(\"column-hide\", this.resizeHolderWidth.bind(this));\n\t\t}\n\n\t\tthis.resizeHolderWidth();\n\t}\n\n\tresizeHolderWidth(){\n\t\tthis.topElement.style.minWidth = this.table.columnManager.headersElement.offsetWidth + \"px\";\n\t}\n\n\tinitializeRows(){\n\t\tthis.table.rowManager.getRows().forEach((row) => {\n\t\t\tthis.initializeRow(row);\n\t\t});\n\t}\n\n\tinitializeRow(row){\n\t\tvar frozenRows = this.table.options.frozenRows,\n\t\trowType = typeof frozenRows;\n\n\t\tif(rowType === \"number\"){\n\t\t\tif(row.getPosition() && (row.getPosition() + this.rows.length) <= frozenRows){\n\t\t\t\tthis.freezeRow(row);\n\t\t\t}\n\t\t}else if(rowType === \"function\"){\n\t\t\tif(frozenRows.call(this.table, row.getComponent())){\n\t\t\t\tthis.freezeRow(row);\n\t\t\t}\n\t\t}else if(Array.isArray(frozenRows)){\n\t\t\tif(frozenRows.includes(row.data[this.options(\"frozenRowsField\")])){\n\t\t\t\tthis.freezeRow(row);\n\t\t\t}\n\t\t}\n\t}\n\n\tisRowFrozen(row){\n\t\tvar index = this.rows.indexOf(row);\n\t\treturn index > -1;\n\t}\n\n\tisFrozen(){\n\t\treturn !!this.rows.length;\n\t}\n\n\tvisibleRows(viewable, rows){\n\t\tthis.rows.forEach((row) => {\n\t\t\trows.push(row);\n\t\t});\n\n\t\treturn rows;\n\t}\n\n\t//filter frozen rows out of display data\n\tgetRows(rows){\n\t\tvar output = rows.slice(0);\n\n\t\tthis.rows.forEach(function(row){\n\t\t\tvar index = output.indexOf(row);\n\n\t\t\tif(index > -1){\n\t\t\t\toutput.splice(index, 1);\n\t\t\t}\n\t\t});\n\n\t\treturn output;\n\t}\n\n\tfreezeRow(row){\n\t\tif(!row.modules.frozen){\n\t\t\trow.modules.frozen = true;\n\t\t\tthis.topElement.appendChild(row.getElement());\n\t\t\trow.initialize();\n\t\t\trow.normalizeHeight();\n\t\t\n\t\t\tthis.rows.push(row);\n\n\t\t\tthis.refreshData(false, \"display\");\n\n\t\t\tthis.table.rowManager.adjustTableSize();\n\n\t\t\tthis.styleRows();\n\n\t\t}else{\n\t\t\tconsole.warn(\"Freeze Error - Row is already frozen\");\n\t\t}\n\t}\n\n\tunfreezeRow(row){\n\t\tif(row.modules.frozen){\n\n\t\t\trow.modules.frozen = false;\n\n\t\t\tthis.detachRow(row);\n\n\t\t\tthis.table.rowManager.adjustTableSize();\n\n\t\t\tthis.refreshData(false, \"display\");\n\n\t\t\tif(this.rows.length){\n\t\t\t\tthis.styleRows();\n\t\t\t}\n\n\t\t}else{\n\t\t\tconsole.warn(\"Freeze Error - Row is already unfrozen\");\n\t\t}\n\t}\n\n\tdetachRow(row){\n\t\tvar index = this.rows.indexOf(row);\n\n\t\tif(index > -1){\n\t\t\tvar rowEl = row.getElement();\n\n\t\t\tif(rowEl.parentNode){\n\t\t\t\trowEl.parentNode.removeChild(rowEl);\n\t\t\t}\n\n\t\t\tthis.rows.splice(index, 1);\n\t\t}\n\t}\n\n\tstyleRows(row){\n\t\tthis.rows.forEach((row, i) => {\n\t\t\tthis.table.rowManager.styleRow(row, i);\n\t\t});\n\t}\n}\n\nFrozenRows.moduleName = \"frozenRows\";\n\nexport default FrozenRows;","//public group object\nclass GroupComponent {\n\tconstructor (group){\n\t\tthis._group = group;\n\t\tthis.type = \"GroupComponent\";\n\n\t\treturn new Proxy(this, {\n\t\t\tget: function(target, name, receiver) {\n\t\t\t\tif (typeof target[name] !== \"undefined\") {\n\t\t\t\t\treturn target[name];\n\t\t\t\t}else{\n\t\t\t\t\treturn target._group.groupManager.table.componentFunctionBinder.handle(\"group\", target._group, name);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tgetKey(){\n\t\treturn this._group.key;\n\t}\n\n\tgetField(){\n\t\treturn this._group.field;\n\t}\n\n\tgetElement(){\n\t\treturn this._group.element;\n\t}\n\n\tgetRows(){\n\t\treturn this._group.getRows(true);\n\t}\n\n\tgetSubGroups(){\n\t\treturn this._group.getSubGroups(true);\n\t}\n\n\tgetParentGroup(){\n\t\treturn this._group.parent ? this._group.parent.getComponent() : false;\n\t}\n\n\tisVisible(){\n\t\treturn this._group.visible;\n\t}\n\n\tshow(){\n\t\tthis._group.show();\n\t}\n\n\thide(){\n\t\tthis._group.hide();\n\t}\n\n\ttoggle(){\n\t\tthis._group.toggleVisibility();\n\t}\n\n\tscrollTo(position, ifVisible){\n\t\treturn this._group.groupManager.table.rowManager.scrollToRow(this._group, position, ifVisible);\n\t}\n\n\t_getSelf(){\n\t\treturn this._group;\n\t}\n\n\tgetTable(){\n\t\treturn this._group.groupManager.table;\n\t}\n}\n\nexport default GroupComponent;","import Helpers from '../../core/tools/Helpers.js';\nimport GroupComponent from './GroupComponent.js';\n\n//Group functions\nclass Group{\n\t\n\tconstructor(groupManager, parent, level, key, field, generator, oldGroup){\n\t\tthis.groupManager = groupManager;\n\t\tthis.parent = parent;\n\t\tthis.key = key;\n\t\tthis.level = level;\n\t\tthis.field = field;\n\t\tthis.hasSubGroups = level < (groupManager.groupIDLookups.length - 1);\n\t\tthis.addRow = this.hasSubGroups ? this._addRowToGroup : this._addRow;\n\t\tthis.type = \"group\"; //type of element\n\t\tthis.old = oldGroup;\n\t\tthis.rows = [];\n\t\tthis.groups = [];\n\t\tthis.groupList = [];\n\t\tthis.generator = generator;\n\t\tthis.element = false;\n\t\tthis.elementContents = false;\n\t\tthis.height = 0;\n\t\tthis.outerHeight = 0;\n\t\tthis.initialized = false;\n\t\tthis.calcs = {};\n\t\tthis.initialized = false;\n\t\tthis.modules = {};\n\t\tthis.arrowElement = false;\n\t\t\n\t\tthis.visible = oldGroup ? oldGroup.visible : (typeof groupManager.startOpen[level] !== \"undefined\" ? groupManager.startOpen[level] : groupManager.startOpen[0]);\n\t\t\n\t\tthis.component = null;\n\t\t\n\t\tthis.createElements();\n\t\tthis.addBindings();\n\t\t\n\t\tthis.createValueGroups();\n\t}\n\t\n\twipe(elementsOnly){\n\t\tif(!elementsOnly){\n\t\t\tif(this.groupList.length){\n\t\t\t\tthis.groupList.forEach(function(group){\n\t\t\t\t\tgroup.wipe();\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tthis.rows.forEach((row) => {\n\t\t\t\t\tif(row.modules){\n\t\t\t\t\t\tdelete row.modules.group;\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.element = false;\n\t\tthis.arrowElement = false;\n\t\tthis.elementContents = false;\n\t}\n\t\n\tcreateElements(){\n\t\tvar arrow = document.createElement(\"div\");\n\t\tarrow.classList.add(\"tabulator-arrow\");\n\t\t\n\t\tthis.element = document.createElement(\"div\");\n\t\tthis.element.classList.add(\"tabulator-row\");\n\t\tthis.element.classList.add(\"tabulator-group\");\n\t\tthis.element.classList.add(\"tabulator-group-level-\" + this.level);\n\t\tthis.element.setAttribute(\"role\", \"rowgroup\");\n\t\t\n\t\tthis.arrowElement = document.createElement(\"div\");\n\t\tthis.arrowElement.classList.add(\"tabulator-group-toggle\");\n\t\tthis.arrowElement.appendChild(arrow);\n\t\t\n\t\t//setup movable rows\n\t\tif(this.groupManager.table.options.movableRows !== false && this.groupManager.table.modExists(\"moveRow\")){\n\t\t\tthis.groupManager.table.modules.moveRow.initializeGroupHeader(this);\n\t\t}\n\t}\n\t\n\tcreateValueGroups(){\n\t\tvar level = this.level + 1;\n\t\tif(this.groupManager.allowedValues && this.groupManager.allowedValues[level]){\n\t\t\tthis.groupManager.allowedValues[level].forEach((value) => {\n\t\t\t\tthis._createGroup(value, level);\n\t\t\t});\n\t\t}\n\t}\n\t\n\taddBindings(){\n\t\tvar toggleElement;\n\t\t\n\t\tif(this.groupManager.table.options.groupToggleElement){\n\t\t\ttoggleElement = this.groupManager.table.options.groupToggleElement == \"arrow\" ? this.arrowElement : this.element;\n\t\t\t\n\t\t\ttoggleElement.addEventListener(\"click\", (e) => {\n\t\t\t\tif(this.groupManager.table.options.groupToggleElement === \"arrow\"){\n\t\t\t\t\te.stopPropagation();\n\t\t\t\t\te.stopImmediatePropagation();\n\t\t\t\t}\n\n\t\t\t\t//allow click event to propagate before toggling visibility\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis.toggleVisibility();\n\t\t\t\t});\n\t\t\t});\n\t\t}\n\t}\n\t\n\t_createGroup(groupID, level){\n\t\tvar groupKey = level + \"_\" + groupID;\n\t\tvar group = new Group(this.groupManager, this, level, groupID, this.groupManager.groupIDLookups[level].field, this.groupManager.headerGenerator[level] || this.groupManager.headerGenerator[0], this.old ? this.old.groups[groupKey] : false);\n\t\t\n\t\tthis.groups[groupKey] = group;\n\t\tthis.groupList.push(group);\n\t}\n\t\n\t_addRowToGroup(row){\n\t\t\n\t\tvar level = this.level + 1;\n\t\t\n\t\tif(this.hasSubGroups){\n\t\t\tvar groupID = this.groupManager.groupIDLookups[level].func(row.getData()),\n\t\t\tgroupKey = level + \"_\" + groupID;\n\t\t\t\n\t\t\tif(this.groupManager.allowedValues && this.groupManager.allowedValues[level]){\n\t\t\t\tif(this.groups[groupKey]){\n\t\t\t\t\tthis.groups[groupKey].addRow(row);\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(!this.groups[groupKey]){\n\t\t\t\t\tthis._createGroup(groupID, level);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.groups[groupKey].addRow(row);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t_addRow(row){\n\t\tthis.rows.push(row);\n\t\trow.modules.group = this;\n\t}\n\t\n\tinsertRow(row, to, after){\n\t\tvar data = this.conformRowData({});\n\t\t\n\t\trow.updateData(data);\n\t\t\n\t\tvar toIndex = this.rows.indexOf(to);\n\t\t\n\t\tif(toIndex > -1){\n\t\t\tif(after){\n\t\t\t\tthis.rows.splice(toIndex+1, 0, row);\n\t\t\t}else{\n\t\t\t\tthis.rows.splice(toIndex, 0, row);\n\t\t\t}\n\t\t}else{\n\t\t\tif(after){\n\t\t\t\tthis.rows.push(row);\n\t\t\t}else{\n\t\t\t\tthis.rows.unshift(row);\n\t\t\t}\n\t\t}\n\t\t\n\t\trow.modules.group = this;\n\t\t\n\t\t// this.generateGroupHeaderContents();\n\t\t\n\t\tif(this.groupManager.table.modExists(\"columnCalcs\") && this.groupManager.table.options.columnCalcs != \"table\"){\n\t\t\tthis.groupManager.table.modules.columnCalcs.recalcGroup(this);\n\t\t}\n\t\t\n\t\tthis.groupManager.updateGroupRows(true);\n\t}\n\t\n\tscrollHeader(left){\n\t\tif(this.arrowElement){\n\t\t\tthis.arrowElement.style.marginLeft = left;\n\t\t\t\n\t\t\tthis.groupList.forEach(function(child){\n\t\t\t\tchild.scrollHeader(left);\n\t\t\t});\n\t\t}\n\t}\n\t\n\tgetRowIndex(row){}\n\t\n\t//update row data to match grouping constraints\n\tconformRowData(data){\n\t\tif(this.field){\n\t\t\tdata[this.field] = this.key;\n\t\t}else{\n\t\t\tconsole.warn(\"Data Conforming Error - Cannot conform row data to match new group as groupBy is a function\");\n\t\t}\n\t\t\n\t\tif(this.parent){\n\t\t\tdata = this.parent.conformRowData(data);\n\t\t}\n\t\t\n\t\treturn data;\n\t}\n\t\n\tremoveRow(row){\n\t\tvar index = this.rows.indexOf(row);\n\t\tvar el = row.getElement();\n\t\t\n\t\tif(index > -1){\n\t\t\tthis.rows.splice(index, 1);\n\t\t}\n\t\t\n\t\tif(!this.groupManager.table.options.groupValues && !this.rows.length){\n\t\t\tif(this.parent){\n\t\t\t\tthis.parent.removeGroup(this);\n\t\t\t}else{\n\t\t\t\tthis.groupManager.removeGroup(this);\n\t\t\t}\t\t\n\t\t\t\n\t\t\tthis.groupManager.updateGroupRows(true);\n\t\t\t\n\t\t}else{\n\t\t\t\n\t\t\tif(el.parentNode){\n\t\t\t\tel.parentNode.removeChild(el);\n\t\t\t}\n\t\t\t\n\t\t\tif(!this.groupManager.blockRedraw){\n\t\t\t\tthis.generateGroupHeaderContents();\n\t\t\t\t\n\t\t\t\tif(this.groupManager.table.modExists(\"columnCalcs\") && this.groupManager.table.options.columnCalcs != \"table\"){\n\t\t\t\t\tthis.groupManager.table.modules.columnCalcs.recalcGroup(this);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t}\n\t}\n\t\n\tremoveGroup(group){\n\t\tvar groupKey = group.level + \"_\" + group.key,\n\t\tindex;\n\t\t\n\t\tif(this.groups[groupKey]){\n\t\t\tdelete this.groups[groupKey];\n\t\t\t\n\t\t\tindex = this.groupList.indexOf(group);\n\t\t\t\n\t\t\tif(index > -1){\n\t\t\t\tthis.groupList.splice(index, 1);\n\t\t\t}\n\t\t\t\n\t\t\tif(!this.groupList.length){\n\t\t\t\tif(this.parent){\n\t\t\t\t\tthis.parent.removeGroup(this);\n\t\t\t\t}else{\n\t\t\t\t\tthis.groupManager.removeGroup(this);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\tgetHeadersAndRows(){\n\t\tvar output = [];\n\t\t\n\t\toutput.push(this);\n\t\t\n\t\tthis._visSet();\n\t\t\n\t\t\n\t\tif(this.calcs.top){\n\t\t\tthis.calcs.top.detachElement();\n\t\t\tthis.calcs.top.deleteCells();\n\t\t}\n\t\t\n\t\tif(this.calcs.bottom){\n\t\t\tthis.calcs.bottom.detachElement();\n\t\t\tthis.calcs.bottom.deleteCells();\n\t\t}\n\t\t\n\t\t\n\t\t\n\t\tif(this.visible){\n\t\t\tif(this.groupList.length){\n\t\t\t\tthis.groupList.forEach(function(group){\n\t\t\t\t\toutput = output.concat(group.getHeadersAndRows());\n\t\t\t\t});\n\t\t\t\t\n\t\t\t}else{\n\t\t\t\tif(this.groupManager.table.options.columnCalcs != \"table\" && this.groupManager.table.modExists(\"columnCalcs\") && this.groupManager.table.modules.columnCalcs.hasTopCalcs()){\n\t\t\t\t\tthis.calcs.top = this.groupManager.table.modules.columnCalcs.generateTopRow(this.rows);\n\t\t\t\t\toutput.push(this.calcs.top);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\toutput = output.concat(this.rows);\n\t\t\t\t\n\t\t\t\tif(this.groupManager.table.options.columnCalcs != \"table\" && this.groupManager.table.modExists(\"columnCalcs\") && this.groupManager.table.modules.columnCalcs.hasBottomCalcs()){\n\t\t\t\t\tthis.calcs.bottom = this.groupManager.table.modules.columnCalcs.generateBottomRow(this.rows);\n\t\t\t\t\toutput.push(this.calcs.bottom);\n\t\t\t\t}\n\t\t\t}\n\t\t}else{\n\t\t\tif(!this.groupList.length && this.groupManager.table.options.columnCalcs != \"table\"){\n\t\t\t\t\n\t\t\t\tif(this.groupManager.table.modExists(\"columnCalcs\")){\n\t\t\t\t\tif(this.groupManager.table.modules.columnCalcs.hasTopCalcs()){\n\t\t\t\t\t\tif(this.groupManager.table.options.groupClosedShowCalcs){\n\t\t\t\t\t\t\tthis.calcs.top = this.groupManager.table.modules.columnCalcs.generateTopRow(this.rows);\n\t\t\t\t\t\t\toutput.push(this.calcs.top);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif(this.groupManager.table.modules.columnCalcs.hasBottomCalcs()){\t\t\t\t\t\t\n\t\t\t\t\t\tif(this.groupManager.table.options.groupClosedShowCalcs){\n\t\t\t\t\t\t\tthis.calcs.bottom = this.groupManager.table.modules.columnCalcs.generateBottomRow(this.rows);\n\t\t\t\t\t\t\toutput.push(this.calcs.bottom);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t}\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgetData(visible, transform){\n\t\tvar output = [];\n\t\t\n\t\tthis._visSet();\n\t\t\n\t\tif(!visible || (visible && this.visible)){\n\t\t\tthis.rows.forEach((row) => {\n\t\t\t\toutput.push(row.getData(transform || \"data\"));\n\t\t\t});\n\t\t}\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgetRowCount(){\n\t\tvar count = 0;\n\t\t\n\t\tif(this.groupList.length){\n\t\t\tthis.groupList.forEach((group) => {\n\t\t\t\tcount += group.getRowCount();\n\t\t\t});\n\t\t}else{\n\t\t\tcount = this.rows.length;\n\t\t}\n\t\treturn count;\n\t}\n\n\t\n\ttoggleVisibility(){\n\t\tif(this.visible){\n\t\t\tthis.hide();\n\t\t}else{\n\t\t\tthis.show();\n\t\t}\n\t}\n\t\n\thide(){\n\t\tthis.visible = false;\n\t\t\n\t\tif(this.groupManager.table.rowManager.getRenderMode() == \"basic\" && !this.groupManager.table.options.pagination){\n\t\t\t\n\t\t\tthis.element.classList.remove(\"tabulator-group-visible\");\n\t\t\t\n\t\t\tif(this.groupList.length){\n\t\t\t\tthis.groupList.forEach((group) => {\n\t\t\t\t\t\n\t\t\t\t\tvar rows = group.getHeadersAndRows();\n\t\t\t\t\t\n\t\t\t\t\trows.forEach((row) => {\n\t\t\t\t\t\trow.detachElement();\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t\t\n\t\t\t}else{\n\t\t\t\tthis.rows.forEach((row) => {\n\t\t\t\t\tvar rowEl = row.getElement();\n\t\t\t\t\trowEl.parentNode.removeChild(rowEl);\n\t\t\t\t});\n\t\t\t}\n\t\t\t\n\t\t\tthis.groupManager.updateGroupRows(true);\n\t\t\t\n\t\t}else{\n\t\t\tthis.groupManager.updateGroupRows(true);\n\t\t}\n\t\t\n\t\tthis.groupManager.table.externalEvents.dispatch(\"groupVisibilityChanged\", this.getComponent(), false);\n\t}\n\t\n\tshow(){\n\t\tthis.visible = true;\n\t\t\n\t\tif(this.groupManager.table.rowManager.getRenderMode() == \"basic\" && !this.groupManager.table.options.pagination){\n\t\t\t\n\t\t\tthis.element.classList.add(\"tabulator-group-visible\");\n\t\t\t\n\t\t\tvar prev = this.generateElement();\n\t\t\t\n\t\t\tif(this.groupList.length){\n\t\t\t\tthis.groupList.forEach((group) => {\n\t\t\t\t\tvar rows = group.getHeadersAndRows();\n\t\t\t\t\t\n\t\t\t\t\trows.forEach((row) => {\n\t\t\t\t\t\tvar rowEl = row.getElement();\n\t\t\t\t\t\tprev.parentNode.insertBefore(rowEl, prev.nextSibling);\n\t\t\t\t\t\trow.initialize();\n\t\t\t\t\t\tprev = rowEl;\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t\t\n\t\t\t}else{\n\t\t\t\tthis.rows.forEach((row) => {\n\t\t\t\t\tvar rowEl = row.getElement();\n\t\t\t\t\tprev.parentNode.insertBefore(rowEl, prev.nextSibling);\n\t\t\t\t\trow.initialize();\n\t\t\t\t\tprev = rowEl;\n\t\t\t\t});\n\t\t\t}\n\t\t\t\n\t\t\tthis.groupManager.updateGroupRows(true);\n\t\t}else{\n\t\t\tthis.groupManager.updateGroupRows(true);\n\t\t}\n\t\t\n\t\tthis.groupManager.table.externalEvents.dispatch(\"groupVisibilityChanged\", this.getComponent(), true);\n\t}\n\t\n\t_visSet(){\n\t\tvar data = [];\n\t\t\n\t\tif(typeof this.visible == \"function\"){\n\t\t\t\n\t\t\tthis.rows.forEach(function(row){\n\t\t\t\tdata.push(row.getData());\n\t\t\t});\n\t\t\t\n\t\t\tthis.visible = this.visible(this.key, this.getRowCount(), data, this.getComponent());\n\t\t}\n\t}\n\t\n\tgetRowGroup(row){\n\t\tvar match = false;\n\t\tif(this.groupList.length){\n\t\t\tthis.groupList.forEach(function(group){\n\t\t\t\tvar result = group.getRowGroup(row);\n\t\t\t\t\n\t\t\t\tif(result){\n\t\t\t\t\tmatch = result;\n\t\t\t\t}\n\t\t\t});\n\t\t}else{\n\t\t\tif(this.rows.find(function(item){\n\t\t\t\treturn item === row;\n\t\t\t})){\n\t\t\t\tmatch = this;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn match;\n\t}\n\t\n\tgetSubGroups(component){\n\t\tvar output = [];\n\t\t\n\t\tthis.groupList.forEach(function(child){\n\t\t\toutput.push(component ? child.getComponent() : child);\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgetRows(component, includeChildren){\n\t\tvar output = [];\n\t\t\n\t\tif(includeChildren && this.groupList.length){\n\t\t\tthis.groupList.forEach((group) => {\n\t\t\t\toutput = output.concat(group.getRows(component, includeChildren));\n\t\t\t});\n\t\t}else{\n\t\t\tthis.rows.forEach(function(row){\n\t\t\t\toutput.push(component ? row.getComponent() : row);\n\t\t\t});\n\t\t}\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgenerateGroupHeaderContents(){\n\t\tvar data = [];\n\t\t\n\t\tvar rows = this.getRows(false, true);\n\t\t\n\t\trows.forEach(function(row){\n\t\t\tdata.push(row.getData());\n\t\t});\n\t\t\n\t\tthis.elementContents = this.generator(this.key, this.getRowCount(), data, this.getComponent());\n\t\t\n\t\twhile(this.element.firstChild) this.element.removeChild(this.element.firstChild);\n\t\t\n\t\tif(typeof this.elementContents === \"string\"){\n\t\t\tthis.element.innerHTML = this.elementContents;\n\t\t}else{\n\t\t\tthis.element.appendChild(this.elementContents);\n\t\t}\n\t\t\n\t\tthis.element.insertBefore(this.arrowElement, this.element.firstChild);\n\t}\n\t\n\tgetPath(path = []) {\n\t\tpath.unshift(this.key);\n\t\tif(this.parent) {\n\t\t\tthis.parent.getPath(path);\n\t\t}\n\t\treturn path;\n\t}\n\t\n\t////////////// Standard Row Functions //////////////\n\t\n\tgetElement(){\n\t\treturn this.elementContents ? this.element : this.generateElement();\n\t}\n\t\n\tgenerateElement(){\n\t\tthis.addBindings = false;\n\t\t\n\t\tthis._visSet();\n\t\t\n\t\tif(this.visible){\n\t\t\tthis.element.classList.add(\"tabulator-group-visible\");\n\t\t}else{\n\t\t\tthis.element.classList.remove(\"tabulator-group-visible\");\n\t\t}\n\t\t\n\t\tfor(var i = 0; i < this.element.childNodes.length; ++i){\n\t\t\tthis.element.childNodes[i].parentNode.removeChild(this.element.childNodes[i]);\n\t\t}\n\t\t\n\t\tthis.generateGroupHeaderContents();\n\t\t\n\t\t// this.addBindings();\n\t\t\n\t\treturn this.element;\n\t}\n\t\n\tdetachElement(){\n\t\tif (this.element && this.element.parentNode){\n\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t}\n\t}\n\t\n\t//normalize the height of elements in the row\n\tnormalizeHeight(){\n\t\tthis.setHeight(this.element.clientHeight);\n\t}\n\t\n\tinitialize(force){\n\t\tif(!this.initialized || force){\n\t\t\tthis.normalizeHeight();\n\t\t\tthis.initialized = true;\n\t\t}\n\t}\n\t\n\treinitialize(){\n\t\tthis.initialized = false;\n\t\tthis.height = 0;\n\t\t\n\t\tif(Helpers.elVisible(this.element)){\n\t\t\tthis.initialize(true);\n\t\t}\n\t}\n\t\n\tsetHeight(height){\n\t\tif(this.height != height){\n\t\t\tthis.height = height;\n\t\t\tthis.outerHeight = this.element.offsetHeight;\n\t\t}\n\t}\n\t\n\t//return rows outer height\n\tgetHeight(){\n\t\treturn this.outerHeight;\n\t}\n\t\n\tgetGroup(){\n\t\treturn this;\n\t}\n\t\n\treinitializeHeight(){}\n\t\n\tcalcHeight(){}\n\t\n\tsetCellHeight(){}\n\t\n\tclearCellHeight(){}\n\t\n\tdeinitializeHeight(){}\n\n\trendered(){}\n\t\n\t//////////////// Object Generation /////////////////\n\tgetComponent(){\n\t\tif(!this.component){\n\t\t\tthis.component = new GroupComponent(this);\n\t\t}\n\t\t\n\t\treturn this.component;\n\t}\n}\n\nexport default Group;","import Module from '../../core/Module.js';\n\nimport Group from './Group.js';\n\nclass GroupRows extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.groupIDLookups = false; //enable table grouping and set field to group by\n\t\tthis.startOpen = [function(){return false;}]; //starting state of group\n\t\tthis.headerGenerator = [function(){return \"\";}];\n\t\tthis.groupList = []; //ordered list of groups\n\t\tthis.allowedValues = false;\n\t\tthis.groups = {}; //hold row groups\n\t\t\n\t\tthis.displayHandler = this.getRows.bind(this);\n\n\t\tthis.blockRedraw = false;\n\t\t\n\t\t//register table options\n\t\tthis.registerTableOption(\"groupBy\", false); //enable table grouping and set field to group by\n\t\tthis.registerTableOption(\"groupStartOpen\", true); //starting state of group\n\t\tthis.registerTableOption(\"groupValues\", false);\n\t\tthis.registerTableOption(\"groupUpdateOnCellEdit\", false);\n\t\tthis.registerTableOption(\"groupHeader\", false); //header generation function\n\t\tthis.registerTableOption(\"groupHeaderPrint\", null);\n\t\tthis.registerTableOption(\"groupHeaderClipboard\", null);\n\t\tthis.registerTableOption(\"groupHeaderHtmlOutput\", null);\n\t\tthis.registerTableOption(\"groupHeaderDownload\", null);\n\t\tthis.registerTableOption(\"groupToggleElement\", \"arrow\");\n\t\tthis.registerTableOption(\"groupClosedShowCalcs\", false);\n\t\t\n\t\t//register table functions\n\t\tthis.registerTableFunction(\"setGroupBy\", this.setGroupBy.bind(this));\n\t\tthis.registerTableFunction(\"setGroupValues\", this.setGroupValues.bind(this));\n\t\tthis.registerTableFunction(\"setGroupStartOpen\", this.setGroupStartOpen.bind(this));\n\t\tthis.registerTableFunction(\"setGroupHeader\", this.setGroupHeader.bind(this));\n\t\tthis.registerTableFunction(\"getGroups\", this.userGetGroups.bind(this));\n\t\tthis.registerTableFunction(\"getGroupedData\", this.userGetGroupedData.bind(this));\n\t\t\n\t\t//register component functions\n\t\tthis.registerComponentFunction(\"row\", \"getGroup\", this.rowGetGroup.bind(this));\n\t}\n\t\n\t//initialize group configuration\n\tinitialize(){\n\t\tthis.subscribe(\"table-destroy\", this._blockRedrawing.bind(this));\n\t\tthis.subscribe(\"rows-wipe\", this._blockRedrawing.bind(this));\n\t\tthis.subscribe(\"rows-wiped\", this._restore_redrawing.bind(this));\n\n\t\tif(this.table.options.groupBy){\n\t\t\tif(this.table.options.groupUpdateOnCellEdit){\n\t\t\t\tthis.subscribe(\"cell-value-updated\", this.cellUpdated.bind(this));\n\t\t\t\tthis.subscribe(\"row-data-changed\", this.reassignRowToGroup.bind(this), 0);\n\t\t\t}\n\t\t\t\n\t\t\tthis.subscribe(\"table-built\", this.configureGroupSetup.bind(this));\n\t\t\t\n\t\t\tthis.subscribe(\"row-deleting\", this.rowDeleting.bind(this));\n\t\t\tthis.subscribe(\"row-deleted\", this.rowsUpdated.bind(this));\n\t\t\tthis.subscribe(\"scroll-horizontal\", this.scrollHeaders.bind(this));\n\t\t\tthis.subscribe(\"rows-wipe\", this.wipe.bind(this));\n\t\t\tthis.subscribe(\"rows-added\", this.rowsUpdated.bind(this));\n\t\t\tthis.subscribe(\"row-moving\", this.rowMoving.bind(this));\n\t\t\tthis.subscribe(\"row-adding-index\", this.rowAddingIndex.bind(this));\n\t\t\t\n\t\t\tthis.subscribe(\"rows-sample\", this.rowSample.bind(this));\n\t\t\t\n\t\t\tthis.subscribe(\"render-virtual-fill\", this.virtualRenderFill.bind(this));\n\t\t\t\n\t\t\tthis.registerDisplayHandler(this.displayHandler, 20);\n\t\t\t\n\t\t\tthis.initialized = true;\n\t\t}\n\t}\n\t\n\t_blockRedrawing(){\n\t\tthis.blockRedraw = true;\n\t}\n\n\t_restore_redrawing(){\n\t\tthis.blockRedraw = false;\n\t}\n\n\tconfigureGroupSetup(){\n\t\tif(this.table.options.groupBy){\n\t\t\tvar groupBy = this.table.options.groupBy,\n\t\t\tstartOpen = this.table.options.groupStartOpen,\n\t\t\tgroupHeader = this.table.options.groupHeader;\n\t\t\t\n\t\t\tthis.allowedValues = this.table.options.groupValues;\n\t\t\t\n\t\t\tif(Array.isArray(groupBy) && Array.isArray(groupHeader) && groupBy.length > groupHeader.length){\n\t\t\t\tconsole.warn(\"Error creating group headers, groupHeader array is shorter than groupBy array\");\n\t\t\t}\n\t\t\t\n\t\t\tthis.headerGenerator = [function(){return \"\";}];\n\t\t\tthis.startOpen = [function(){return false;}]; //starting state of group\n\t\t\t\n\t\t\tthis.langBind(\"groups|item\", (langValue, lang) => {\n\t\t\t\tthis.headerGenerator[0] = (value, count, data) => { //header layout function\n\t\t\t\t\treturn (typeof value === \"undefined\" ? \"\" : value) + \"(\" + count + \" \" + ((count === 1) ? langValue : lang.groups.items) + \")\";\n\t\t\t\t};\n\t\t\t});\n\t\t\t\n\t\t\tthis.groupIDLookups = [];\n\t\t\t\n\t\t\tif(groupBy){\n\t\t\t\tif(this.table.modExists(\"columnCalcs\") && this.table.options.columnCalcs != \"table\" && this.table.options.columnCalcs != \"both\"){\n\t\t\t\t\tthis.table.modules.columnCalcs.removeCalcs();\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(this.table.modExists(\"columnCalcs\") && this.table.options.columnCalcs != \"group\"){\n\t\t\t\t\t\n\t\t\t\t\tvar cols = this.table.columnManager.getRealColumns();\n\t\t\t\t\t\n\t\t\t\t\tcols.forEach((col) => {\n\t\t\t\t\t\tif(col.definition.topCalc){\n\t\t\t\t\t\t\tthis.table.modules.columnCalcs.initializeTopRow();\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(col.definition.bottomCalc){\n\t\t\t\t\t\t\tthis.table.modules.columnCalcs.initializeBottomRow();\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tif(!Array.isArray(groupBy)){\n\t\t\t\tgroupBy = [groupBy];\n\t\t\t}\n\t\t\t\n\t\t\tgroupBy.forEach((group, i) => {\n\t\t\t\tvar lookupFunc, column;\n\t\t\t\t\n\t\t\t\tif(typeof group == \"function\"){\n\t\t\t\t\tlookupFunc = group;\n\t\t\t\t}else{\n\t\t\t\t\tcolumn = this.table.columnManager.getColumnByField(group);\n\t\t\t\t\t\n\t\t\t\t\tif(column){\n\t\t\t\t\t\tlookupFunc = function(data){\n\t\t\t\t\t\t\treturn column.getFieldValue(data);\n\t\t\t\t\t\t};\n\t\t\t\t\t}else{\n\t\t\t\t\t\tlookupFunc = function(data){\n\t\t\t\t\t\t\treturn data[group];\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.groupIDLookups.push({\n\t\t\t\t\tfield: typeof group === \"function\" ? false : group,\n\t\t\t\t\tfunc:lookupFunc,\n\t\t\t\t\tvalues:this.allowedValues ? this.allowedValues[i] : false,\n\t\t\t\t});\n\t\t\t});\n\t\t\t\n\t\t\tif(startOpen){\n\t\t\t\tif(!Array.isArray(startOpen)){\n\t\t\t\t\tstartOpen = [startOpen];\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tstartOpen.forEach((level) => {\n\t\t\t\t\tlevel = typeof level == \"function\" ? level : function(){return true;};\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tthis.startOpen = startOpen;\n\t\t\t}\n\t\t\t\n\t\t\tif(groupHeader){\n\t\t\t\tthis.headerGenerator = Array.isArray(groupHeader) ? groupHeader : [groupHeader];\n\t\t\t}\n\t\t}else{\n\t\t\tthis.groupList = [];\n\t\t\tthis.groups = {};\n\t\t}\n\t}\n\t\n\trowSample(rows, prevValue){\n\t\tif(this.table.options.groupBy){\n\t\t\tvar group = this.getGroups(false)[0];\n\t\t\t\n\t\t\tprevValue.push(group.getRows(false)[0]);\n\t\t}\n\t\t\n\t\treturn prevValue;\n\t}\n\t\n\tvirtualRenderFill(){\n\t\tvar el = this.table.rowManager.tableElement;\n\t\tvar rows = this.table.rowManager.getVisibleRows();\n\t\t\n\t\tif(this.table.options.groupBy){\n\t\t\trows = rows.filter((row) => {\n\t\t\t\treturn row.type !== \"group\";\n\t\t\t});\n\t\t\t\n\t\t\tel.style.minWidth = !rows.length ? this.table.columnManager.getWidth() + \"px\" : \"\";\n\t\t}else{\n\t\t\treturn rows;\n\t\t}\n\t}\n\t\n\trowAddingIndex(row, index, top){\n\t\tif(this.table.options.groupBy){\n\t\t\tthis.assignRowToGroup(row);\n\t\t\t\n\t\t\tvar groupRows = row.modules.group.rows;\n\t\t\t\n\t\t\tif(groupRows.length > 1){\n\t\t\t\tif(!index || (index && groupRows.indexOf(index) == -1)){\n\t\t\t\t\tif(top){\n\t\t\t\t\t\tif(groupRows[0] !== row){\n\t\t\t\t\t\t\tindex = groupRows[0];\n\t\t\t\t\t\t\tthis.table.rowManager.moveRowInArray(row.modules.group.rows, row, index, !top);\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tif(groupRows[groupRows.length -1] !== row){\n\t\t\t\t\t\t\tindex = groupRows[groupRows.length -1];\n\t\t\t\t\t\t\tthis.table.rowManager.moveRowInArray(row.modules.group.rows, row, index, !top);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tthis.table.rowManager.moveRowInArray(row.modules.group.rows, row, index, !top);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\treturn index;\n\t\t}\n\t}\n\t\n\ttrackChanges(){\n\t\tthis.dispatch(\"group-changed\");\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\t\n\tsetGroupBy(groups){\n\t\tthis.table.options.groupBy = groups;\n\t\t\n\t\tif(!this.initialized){\n\t\t\tthis.initialize();\n\t\t}\n\t\t\n\t\tthis.configureGroupSetup();\n\n\t\tif(!groups && this.table.modExists(\"columnCalcs\") && this.table.options.columnCalcs === true){\n\t\t\tthis.table.modules.columnCalcs.reinitializeCalcs();\n\t\t}\n\t\t\n\t\tthis.refreshData();\n\t\t\n\t\tthis.trackChanges();\n\t}\n\t\n\tsetGroupValues(groupValues){\n\t\tthis.table.options.groupValues = groupValues;\n\t\tthis.configureGroupSetup();\n\t\tthis.refreshData();\n\t\t\n\t\tthis.trackChanges();\n\t}\n\t\n\tsetGroupStartOpen(values){\n\t\tthis.table.options.groupStartOpen = values;\n\t\tthis.configureGroupSetup();\n\t\t\n\t\tif(this.table.options.groupBy){\n\t\t\tthis.refreshData();\n\t\t\t\n\t\t\tthis.trackChanges();\n\t\t}else{\n\t\t\tconsole.warn(\"Grouping Update - cant refresh view, no groups have been set\");\n\t\t}\n\t}\n\t\n\tsetGroupHeader(values){\n\t\tthis.table.options.groupHeader = values;\n\t\tthis.configureGroupSetup();\n\t\t\n\t\tif(this.table.options.groupBy){\n\t\t\tthis.refreshData();\n\t\t\t\n\t\t\tthis.trackChanges();\n\t\t}else{\n\t\t\tconsole.warn(\"Grouping Update - cant refresh view, no groups have been set\");\n\t\t}\n\t}\n\t\n\tuserGetGroups(values){\n\t\treturn this.getGroups(true);\n\t}\n\t\n\t// get grouped table data in the same format as getData()\n\tuserGetGroupedData(){\n\t\treturn this.table.options.groupBy ? this.getGroupedData() : this.getData();\n\t}\n\t\n\t\n\t///////////////////////////////////////\n\t///////// Component Functions /////////\n\t///////////////////////////////////////\n\t\n\trowGetGroup(row){\n\t\treturn row.modules.group ? row.modules.group.getComponent() : false;\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\t\n\trowMoving(from, to, after){\n\t\tif(this.table.options.groupBy){\n\t\t\tif(!after && to instanceof Group){\n\t\t\t\tto = this.table.rowManager.prevDisplayRow(from) || to;\n\t\t\t}\n\t\t\t\n\t\t\tvar toGroup = to instanceof Group ? to : to.modules.group;\n\t\t\tvar fromGroup = from instanceof Group ? from : from.modules.group;\n\t\t\t\n\t\t\tif(toGroup === fromGroup){\n\t\t\t\tthis.table.rowManager.moveRowInArray(toGroup.rows, from, to, after);\n\t\t\t}else{\n\t\t\t\tif(fromGroup){\n\t\t\t\t\tfromGroup.removeRow(from);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\ttoGroup.insertRow(from, to, after);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t\n\trowDeleting(row){\n\t\t//remove from group\n\t\tif(this.table.options.groupBy && row.modules.group){\n\t\t\trow.modules.group.removeRow(row);\n\t\t}\n\t}\n\t\n\trowsUpdated(row){\n\t\tif(this.table.options.groupBy){\n\t\t\tthis.updateGroupRows(true);\n\t\t}\t\n\t}\n\t\n\tcellUpdated(cell){\n\t\tif(this.table.options.groupBy){\n\t\t\tthis.reassignRowToGroup(cell.row);\n\t\t}\n\t}\n\t\n\t//return appropriate rows with group headers\n\tgetRows(rows){\n\t\tif(this.table.options.groupBy && this.groupIDLookups.length){\n\t\t\t\n\t\t\tthis.dispatchExternal(\"dataGrouping\");\n\t\t\t\n\t\t\tthis.generateGroups(rows);\n\t\t\t\n\t\t\tif(this.subscribedExternal(\"dataGrouped\")){\n\t\t\t\tthis.dispatchExternal(\"dataGrouped\", this.getGroups(true));\n\t\t\t}\n\t\t\t\n\t\t\treturn this.updateGroupRows();\n\t\t\t\n\t\t}else{\n\t\t\treturn rows.slice(0);\n\t\t}\n\t}\n\t\n\tgetGroups(component){\n\t\tvar groupComponents = [];\n\t\t\n\t\tthis.groupList.forEach(function(group){\n\t\t\tgroupComponents.push(component ? group.getComponent() : group);\n\t\t});\n\t\t\n\t\treturn groupComponents;\n\t}\n\t\n\tgetChildGroups(group){\n\t\tvar groupComponents = [];\n\t\t\n\t\tif(!group){\n\t\t\tgroup = this;\n\t\t}\n\t\t\n\t\tgroup.groupList.forEach((child) => {\n\t\t\tif(child.groupList.length){\n\t\t\t\tgroupComponents = groupComponents.concat(this.getChildGroups(child));\n\t\t\t}else{\n\t\t\t\tgroupComponents.push(child);\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn groupComponents;\n\t}\n\t\n\twipe(){\n\t\tif(this.table.options.groupBy){\n\t\t\tthis.groupList.forEach(function(group){\n\t\t\t\tgroup.wipe();\n\t\t\t});\n\t\t\t\n\t\t\tthis.groupList = [];\n\t\t\tthis.groups = {};\n\t\t}\n\t}\n\t\n\tpullGroupListData(groupList) {\n\t\tvar groupListData = [];\n\t\t\n\t\tgroupList.forEach((group) => {\n\t\t\tvar groupHeader = {};\n\t\t\tgroupHeader.level = 0;\n\t\t\tgroupHeader.rowCount = 0;\n\t\t\tgroupHeader.headerContent = \"\";\n\t\t\tvar childData = [];\n\t\t\t\n\t\t\tif (group.hasSubGroups) {\n\t\t\t\tchildData = this.pullGroupListData(group.groupList);\n\t\t\t\t\n\t\t\t\tgroupHeader.level = group.level;\n\t\t\t\tgroupHeader.rowCount = childData.length - group.groupList.length; // data length minus number of sub-headers\n\t\t\t\tgroupHeader.headerContent = group.generator(group.key, groupHeader.rowCount, group.rows, group);\n\t\t\t\t\n\t\t\t\tgroupListData.push(groupHeader);\n\t\t\t\tgroupListData = groupListData.concat(childData);\n\t\t\t}\n\t\t\t\n\t\t\telse {\n\t\t\t\tgroupHeader.level = group.level;\n\t\t\t\tgroupHeader.headerContent = group.generator(group.key, group.rows.length, group.rows, group);\n\t\t\t\tgroupHeader.rowCount = group.getRows().length;\n\t\t\t\t\n\t\t\t\tgroupListData.push(groupHeader);\n\t\t\t\t\n\t\t\t\tgroup.getRows().forEach((row) => {\n\t\t\t\t\tgroupListData.push(row.getData(\"data\"));\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn groupListData;\n\t}\n\t\n\tgetGroupedData(){\n\t\t\n\t\treturn this.pullGroupListData(this.groupList);\n\t}\n\t\n\tgetRowGroup(row){\n\t\tvar match = false;\n\t\t\n\t\tif(this.options(\"dataTree\")){\n\t\t\trow = this.table.modules.dataTree.getTreeParentRoot(row);\n\t\t}\n\t\t\n\t\tthis.groupList.forEach((group) => {\n\t\t\tvar result = group.getRowGroup(row);\n\t\t\t\n\t\t\tif(result){\n\t\t\t\tmatch = result;\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn match;\n\t}\n\t\n\tcountGroups(){\n\t\treturn this.groupList.length;\n\t}\n\t\n\tgenerateGroups(rows){\n\t\tvar oldGroups = this.groups;\n\t\t\n\t\tthis.groups = {};\n\t\tthis.groupList = [];\n\t\t\n\t\tif(this.allowedValues && this.allowedValues[0]){\n\t\t\tthis.allowedValues[0].forEach((value) => {\n\t\t\t\tthis.createGroup(value, 0, oldGroups);\n\t\t\t});\n\t\t\t\n\t\t\trows.forEach((row) => {\n\t\t\t\tthis.assignRowToExistingGroup(row, oldGroups);\n\t\t\t});\n\t\t}else{\n\t\t\trows.forEach((row) => {\n\t\t\t\tthis.assignRowToGroup(row, oldGroups);\n\t\t\t});\n\t\t}\n\t\t\n\t\tObject.values(oldGroups).forEach((group) => {\n\t\t\tgroup.wipe(true);\n\t\t});\t\n\t}\n\t\n\t\n\tcreateGroup(groupID, level, oldGroups){\n\t\tvar groupKey = level + \"_\" + groupID,\n\t\tgroup;\n\t\t\n\t\toldGroups = oldGroups || [];\n\t\t\n\t\tgroup = new Group(this, false, level, groupID, this.groupIDLookups[0].field, this.headerGenerator[0], oldGroups[groupKey]);\n\t\t\n\t\tthis.groups[groupKey] = group;\n\t\tthis.groupList.push(group);\n\t}\n\t\n\tassignRowToExistingGroup(row, oldGroups){\n\t\tvar groupID = this.groupIDLookups[0].func(row.getData()),\n\t\tgroupKey = \"0_\" + groupID;\n\t\t\n\t\tif(this.groups[groupKey]){\n\t\t\tthis.groups[groupKey].addRow(row);\n\t\t}\n\t}\n\t\n\tassignRowToGroup(row, oldGroups){\n\t\tvar groupID = this.groupIDLookups[0].func(row.getData()),\n\t\tnewGroupNeeded = !this.groups[\"0_\" + groupID];\n\t\t\n\t\tif(newGroupNeeded){\n\t\t\tthis.createGroup(groupID, 0, oldGroups);\n\t\t}\n\t\t\n\t\tthis.groups[\"0_\" + groupID].addRow(row);\n\t\t\n\t\treturn !newGroupNeeded;\n\t}\n\t\n\treassignRowToGroup(row){\n\t\tif(row.type === \"row\"){\n\t\t\tvar oldRowGroup = row.modules.group,\n\t\t\toldGroupPath = oldRowGroup.getPath(),\n\t\t\tnewGroupPath = this.getExpectedPath(row),\n\t\t\tsamePath;\n\t\t\t\n\t\t\t// figure out if new group path is the same as old group path\n\t\t\tsamePath = (oldGroupPath.length == newGroupPath.length) && oldGroupPath.every((element, index) => {\n\t\t\t\treturn element === newGroupPath[index];\n\t\t\t});\n\t\t\t\n\t\t\t// refresh if they new path and old path aren't the same (aka the row's groupings have changed)\n\t\t\tif(!samePath) {\n\t\t\t\toldRowGroup.removeRow(row);\n\t\t\t\tthis.assignRowToGroup(row, this.groups);\n\t\t\t\tthis.refreshData(true);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tgetExpectedPath(row) {\n\t\tvar groupPath = [], rowData = row.getData();\n\t\t\n\t\tthis.groupIDLookups.forEach((groupId) => {\n\t\t\tgroupPath.push(groupId.func(rowData));\n\t\t});\n\t\t\n\t\treturn groupPath;\n\t}\n\t\n\tupdateGroupRows(force){\n\t\tvar output = [];\n\n\t\tif(!this.blockRedraw){\n\t\t\tthis.groupList.forEach((group) => {\n\t\t\t\toutput = output.concat(group.getHeadersAndRows());\n\t\t\t});\n\t\t\t\n\t\t\tif(force){\n\t\t\t\tthis.refreshData(true);\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn output;\n\t}\n\t\n\tscrollHeaders(left){\n\t\tif(this.table.options.groupBy){\n\t\t\tif(this.table.options.renderHorizontal === \"virtual\"){\n\t\t\t\tleft -= this.table.columnManager.renderer.vDomPadLeft;\n\t\t\t}\n\t\t\t\n\t\t\tleft = left + \"px\";\n\t\t\t\n\t\t\tthis.groupList.forEach((group) => {\n\t\t\t\tgroup.scrollHeader(left);\n\t\t\t});\n\t\t}\n\t}\n\t\n\tremoveGroup(group){\n\t\tvar groupKey = group.level + \"_\" + group.key,\n\t\tindex;\n\t\t\n\t\tif(this.groups[groupKey]){\n\t\t\tdelete this.groups[groupKey];\n\t\t\t\n\t\t\tindex = this.groupList.indexOf(group);\n\t\t\t\n\t\t\tif(index > -1){\n\t\t\t\tthis.groupList.splice(index, 1);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tcheckBasicModeGroupHeaderWidth(){\n\t\tvar element = this.table.rowManager.tableElement,\n\t\tonlyGroupHeaders = true;\n\t\t\n\t\tthis.table.rowManager.getDisplayRows().forEach((row, index) =>{\n\t\t\tthis.table.rowManager.styleRow(row, index);\n\t\t\telement.appendChild(row.getElement());\n\t\t\trow.initialize(true);\n\t\t\t\n\t\t\tif(row.type !== \"group\"){\n\t\t\t\tonlyGroupHeaders = false;\n\t\t\t}\n\t\t});\n\t\t\n\t\tif(onlyGroupHeaders){\n\t\t\telement.style.minWidth = this.table.columnManager.getWidth() + \"px\";\n\t\t}else{\n\t\t\telement.style.minWidth = \"\";\n\t\t}\n\t}\n\t\n}\n\nGroupRows.moduleName = \"groupRows\";\n\nexport default GroupRows;","import Module from '../../core/Module.js';\nimport Row from '../../core/row/Row.js';\nimport Cell from '../../core/cell/Cell.js';\n\nimport defaultUndoers from './defaults/undoers.js';\nimport defaultRedoers from './defaults/redoers.js';\n\nclass History extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.history = [];\n\t\tthis.index = -1;\n\n\t\tthis.registerTableOption(\"history\", false); //enable edit history\n\t}\n\n\tinitialize(){\n\t\tif(this.table.options.history){\n\t\t\tthis.subscribe(\"cell-value-updated\", this.cellUpdated.bind(this));\n\t\t\tthis.subscribe(\"cell-delete\", this.clearComponentHistory.bind(this));\n\t\t\tthis.subscribe(\"row-delete\", this.rowDeleted.bind(this));\n\t\t\tthis.subscribe(\"rows-wipe\", this.clear.bind(this));\n\t\t\tthis.subscribe(\"row-added\", this.rowAdded.bind(this));\n\t\t\tthis.subscribe(\"row-move\", this.rowMoved.bind(this));\n\t\t}\n\n\t\tthis.registerTableFunction(\"undo\", this.undo.bind(this));\n\t\tthis.registerTableFunction(\"redo\", this.redo.bind(this));\n\t\tthis.registerTableFunction(\"getHistoryUndoSize\", this.getHistoryUndoSize.bind(this));\n\t\tthis.registerTableFunction(\"getHistoryRedoSize\", this.getHistoryRedoSize.bind(this));\n\t\tthis.registerTableFunction(\"clearHistory\", this.clear.bind(this));\n\t}\n\n\trowMoved(from, to, after){\n\t\tthis.action(\"rowMove\", from, {posFrom:from.getPosition(), posTo:to.getPosition(), to:to, after:after});\n\t}\n\n\trowAdded(row, data, pos, index){\n\t\tthis.action(\"rowAdd\", row, {data:data, pos:pos, index:index});\n\t}\n\n\trowDeleted(row){\n\t\tvar index, rows;\n\n\t\tif(this.table.options.groupBy){\n\n\t\t\trows = row.getComponent().getGroup()._getSelf().rows;\n\t\t\tindex = rows.indexOf(row);\n\n\t\t\tif(index){\n\t\t\t\tindex = rows[index-1];\n\t\t\t}\n\t\t}else{\n\t\t\tindex = row.table.rowManager.getRowIndex(row);\n\n\t\t\tif(index){\n\t\t\t\tindex = row.table.rowManager.rows[index-1];\n\t\t\t}\n\t\t}\n\n\t\tthis.action(\"rowDelete\", row, {data:row.getData(), pos:!index, index:index});\n\t}\n\n\tcellUpdated(cell){\n\t\tthis.action(\"cellEdit\", cell, {oldValue:cell.oldValue, newValue:cell.value});\n\t}\n\n\tclear(){\n\t\tthis.history = [];\n\t\tthis.index = -1;\n\t}\n\n\taction(type, component, data){\n\t\tthis.history = this.history.slice(0, this.index + 1);\n\n\t\tthis.history.push({\n\t\t\ttype:type,\n\t\t\tcomponent:component,\n\t\t\tdata:data,\n\t\t});\n\n\t\tthis.index ++;\n\t}\n\n\tgetHistoryUndoSize(){\n\t\treturn this.index + 1;\n\t}\n\n\tgetHistoryRedoSize(){\n\t\treturn this.history.length - (this.index + 1);\n\t}\n\n\tclearComponentHistory(component){\n\t\tvar index = this.history.findIndex(function(item){\n\t\t\treturn item.component === component;\n\t\t});\n\n\t\tif(index > -1){\n\t\t\tthis.history.splice(index, 1);\n\t\t\tif(index <= this.index){\n\t\t\t\tthis.index--;\n\t\t\t}\n\n\t\t\tthis.clearComponentHistory(component);\n\t\t}\n\t}\n\n\tundo(){\n\t\tif(this.index > -1){\n\t\t\tlet action = this.history[this.index];\n\n\t\t\tHistory.undoers[action.type].call(this, action);\n\n\t\t\tthis.index--;\n\n\t\t\tthis.dispatchExternal(\"historyUndo\", action.type, action.component.getComponent(), action.data);\n\n\t\t\treturn true;\n\t\t}else{\n\t\t\tconsole.warn(\"History Undo Error - No more history to undo\");\n\t\t\treturn false;\n\t\t}\n\t}\n\n\tredo(){\n\t\tif(this.history.length-1 > this.index){\n\n\t\t\tthis.index++;\n\n\t\t\tlet action = this.history[this.index];\n\n\t\t\tHistory.redoers[action.type].call(this, action);\n\n\t\t\tthis.dispatchExternal(\"historyRedo\", action.type, action.component.getComponent(), action.data);\n\n\t\t\treturn true;\n\t\t}else{\n\t\t\tconsole.warn(\"History Redo Error - No more history to redo\");\n\t\t\treturn false;\n\t\t}\n\t}\n\n\t//rebind rows to new element after deletion\n\t_rebindRow(oldRow, newRow){\n\t\tthis.history.forEach(function(action){\n\t\t\tif(action.component instanceof Row){\n\t\t\t\tif(action.component === oldRow){\n\t\t\t\t\taction.component = newRow;\n\t\t\t\t}\n\t\t\t}else if(action.component instanceof Cell){\n\t\t\t\tif(action.component.row === oldRow){\n\t\t\t\t\tvar field = action.component.column.getField();\n\n\t\t\t\t\tif(field){\n\t\t\t\t\t\taction.component = newRow.getCell(field);\n\t\t\t\t\t}\n\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n}\n\nHistory.moduleName = \"history\";\n\n//load defaults\nHistory.undoers = defaultUndoers;\nHistory.redoers = defaultRedoers;\n\nexport default History;","export default {\n\tcellEdit: function(action){\n\t\taction.component.setValueProcessData(action.data.oldValue);\n\t\taction.component.cellRendered();\n\t},\n\n\trowAdd: function(action){\n\t\taction.component.deleteActual();\n\t},\n\n\trowDelete: function(action){\n\t\tvar newRow = this.table.rowManager.addRowActual(action.data.data, action.data.pos, action.data.index);\n\n\t\tif(this.table.options.groupBy && this.table.modExists(\"groupRows\")){\n\t\t\tthis.table.modules.groupRows.updateGroupRows(true);\n\t\t}\n\n\t\tthis._rebindRow(action.component, newRow);\n\t},\n\n\trowMove: function(action){\n\t\tvar after = (action.data.posFrom - action.data.posTo) > 0;\n\n\t\tthis.table.rowManager.moveRowActual(action.component, this.table.rowManager.getRowFromPosition(action.data.posFrom), after);\n\n\t\tthis.table.rowManager.regenerateRowPositions();\n\t\tthis.table.rowManager.reRenderInPosition();\n\t},\n};","export default {\n\tcellEdit: function(action){\n\t\taction.component.setValueProcessData(action.data.newValue);\n\t\taction.component.cellRendered();\n\t},\n\n\trowAdd: function(action){\n\t\tvar newRow = this.table.rowManager.addRowActual(action.data.data, action.data.pos, action.data.index);\n\n\t\tif(this.table.options.groupBy && this.table.modExists(\"groupRows\")){\n\t\t\tthis.table.modules.groupRows.updateGroupRows(true);\n\t\t}\n\n\t\tthis._rebindRow(action.component, newRow);\n\t},\n\n\trowDelete:function(action){\n\t\taction.component.deleteActual();\n\t},\n\n\trowMove: function(action){\n\t\tthis.table.rowManager.moveRowActual(action.component, this.table.rowManager.getRowFromPosition(action.data.posTo), action.data.after);\n\t\t\n\t\tthis.table.rowManager.regenerateRowPositions();\n\t\tthis.table.rowManager.reRenderInPosition();\n\t},\n};","import Module from '../../core/Module.js';\n\nclass HtmlTableImport extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.fieldIndex = [];\n\t\tthis.hasIndex = false;\n\t}\n\n\tinitialize(){\n\t\tthis.tableElementCheck();\n\t}\n\n\ttableElementCheck(){\n\t\tif(this.table.originalElement && this.table.originalElement.tagName === \"TABLE\"){\n\t\t\tif(this.table.originalElement.childNodes.length){\n\t\t\t\tthis.parseTable();\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Unable to parse data from empty table tag, Tabulator should be initialized on a div tag unless importing data from a table element.\");\n\t\t\t}\n\t\t}\n\t}\n\n\tparseTable(){\n\t\tvar element = this.table.originalElement,\n\t\toptions = this.table.options,\n\t\theaders = element.getElementsByTagName(\"th\"),\n\t\trows = element.getElementsByTagName(\"tbody\")[0],\n\t\tdata = [];\n\n\t\tthis.hasIndex = false;\n\n\t\tthis.dispatchExternal(\"htmlImporting\");\n\n\t\trows = rows ? rows.getElementsByTagName(\"tr\") : [];\n\n\t\t//check for Tabulator inline options\n\t\tthis._extractOptions(element, options);\n\n\t\tif(headers.length){\n\t\t\tthis._extractHeaders(headers, rows);\n\t\t}else{\n\t\t\tthis._generateBlankHeaders(headers, rows);\n\t\t}\n\n\t\t//iterate through table rows and build data set\n\t\tfor(var index = 0; index < rows.length; index++){\n\t\t\tvar row = rows[index],\n\t\t\tcells = row.getElementsByTagName(\"td\"),\n\t\t\titem = {};\n\n\t\t\t//create index if the don't exist in table\n\t\t\tif(!this.hasIndex){\n\t\t\t\titem[options.index] = index;\n\t\t\t}\n\n\t\t\tfor(var i = 0; i < cells.length; i++){\n\t\t\t\tvar cell = cells[i];\n\t\t\t\tif(typeof this.fieldIndex[i] !== \"undefined\"){\n\t\t\t\t\titem[this.fieldIndex[i]] = cell.innerHTML;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//add row data to item\n\t\t\tdata.push(item);\n\t\t}\n\n\t\toptions.data = data;\n\n\t\tthis.dispatchExternal(\"htmlImported\");\n\t}\n\n\t//extract tabulator attribute options\n\t_extractOptions(element, options, defaultOptions){\n\t\tvar attributes = element.attributes;\n\t\tvar optionsArr = defaultOptions ? Object.keys(defaultOptions) : Object.keys(options);\n\t\tvar optionsList = {};\n\n\t\toptionsArr.forEach((item) => {\n\t\t\toptionsList[item.toLowerCase()] = item;\n\t\t});\n\n\t\tfor(var index in attributes){\n\t\t\tvar attrib = attributes[index];\n\t\t\tvar name;\n\n\t\t\tif(attrib && typeof attrib == \"object\" && attrib.name && attrib.name.indexOf(\"tabulator-\") === 0){\n\t\t\t\tname = attrib.name.replace(\"tabulator-\", \"\");\n\n\t\t\t\tif(typeof optionsList[name] !== \"undefined\"){\n\t\t\t\t\toptions[optionsList[name]] = this._attribValue(attrib.value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t//get value of attribute\n\t_attribValue(value){\n\t\tif(value === \"true\"){\n\t\t\treturn true;\n\t\t}\n\n\t\tif(value === \"false\"){\n\t\t\treturn false;\n\t\t}\n\n\t\treturn value;\n\t}\n\n\t//find column if it has already been defined\n\t_findCol(title){\n\t\tvar match = this.table.options.columns.find((column) => {\n\t\t\treturn column.title === title;\n\t\t});\n\n\t\treturn match || false;\n\t}\n\n\t//extract column from headers\n\t_extractHeaders(headers, rows){\n\t\tfor(var index = 0; index < headers.length; index++){\n\t\t\tvar header = headers[index],\n\t\t\texists = false,\n\t\t\tcol = this._findCol(header.textContent),\n\t\t\twidth;\n\n\t\t\tif(col){\n\t\t\t\texists = true;\n\t\t\t}else{\n\t\t\t\tcol = {title:header.textContent.trim()};\n\t\t\t}\n\n\t\t\tif(!col.field) {\n\t\t\t\tcol.field = header.textContent.trim().toLowerCase().replaceAll(\" \", \"_\");\n\t\t\t}\n\n\t\t\twidth = header.getAttribute(\"width\");\n\n\t\t\tif(width && !col.width)\t{\n\t\t\t\tcol.width = width;\n\t\t\t}\n\n\t\t\t//check for Tabulator inline options\n\t\t\tthis._extractOptions(header, col, this.table.columnManager.optionsList.registeredDefaults);\n\n\t\t\tthis.fieldIndex[index] = col.field;\n\n\t\t\tif(col.field == this.table.options.index){\n\t\t\t\tthis.hasIndex = true;\n\t\t\t}\n\n\t\t\tif(!exists){\n\t\t\t\tthis.table.options.columns.push(col);\n\t\t\t}\n\n\t\t}\n\t}\n\n\t//generate blank headers\n\t_generateBlankHeaders(headers, rows){\n\t\tfor(var index = 0; index < headers.length; index++){\n\t\t\tvar header = headers[index],\n\t\t\tcol = {title:\"\", field:\"col\" + index};\n\n\t\t\tthis.fieldIndex[index] = col.field;\n\n\t\t\tvar width = header.getAttribute(\"width\");\n\n\t\t\tif(width){\n\t\t\t\tcol.width = width;\n\t\t\t}\n\n\t\t\tthis.table.options.columns.push(col);\n\t\t}\n\t}\n}\n\nHtmlTableImport.moduleName = \"htmlTableImport\";\n\nexport default HtmlTableImport;\n","import csv from './importers/csv.js';\nimport json from './importers/json.js';\nimport array from './importers/array.js';\n\nexport default {\n\tcsv:csv,\n\tjson:json,\n\tarray:array,\n};","function csvImporter(input){\n\tvar data = [],\n\trow = 0, \n\tcol = 0,\n\tinQuote = false;\n \n\t//Iterate over each character\n\tfor (let index = 0; index < input.length; index++) {\n\t\tlet char = input[index], \n\t\tnextChar = input[index+1]; \n \n\t\t//Initialize empty row\n\t\tif(!data[row]){\n\t\t\tdata[row] = [];\n\t\t}\n\n\t\t//Initialize empty column\n\t\tif(!data[row][col]){\n\t\t\tdata[row][col] = \"\";\n\t\t}\n \n\t\t//Handle quotation mark inside string\n\t\tif (char == '\"' && inQuote && nextChar == '\"') { \n\t\t\tdata[row][col] += char; \n\t\t\tindex++;\n\t\t\tcontinue; \n\t\t}\n \n\t\t//Begin / End Quote\n\t\tif (char == '\"') { \n\t\t\tinQuote = !inQuote;\n\t\t\tcontinue;\n\t\t}\n \n\t\t//Next column (if not in quote)\n\t\tif (char == ',' && !inQuote) { \n\t\t\tcol++;\n\t\t\tcontinue; \n\t\t}\n \n\t\t//New row if new line and not in quote (CRLF) \n\t\tif (char == '\\r' && nextChar == '\\n' && !inQuote) { \n\t\t\tcol = 0; \n\t\t\trow++; \n\t\t\tindex++; \n\t\t\tcontinue; \n\t\t}\n \n\t\t//New row if new line and not in quote (CR or LF) \n\t\tif ((char == '\\r' || char == '\\n') && !inQuote) { \n\t\t\tcol = 0;\n\t\t\trow++;\n\t\t\tcontinue; \n\t\t}\n\n\t\t//Normal Character, append to column\n\t\tdata[row][col] += char;\n\t}\n\n\treturn data;\n}\n\nexport default csvImporter;","export default function(input){\n\ttry {\n\t\treturn JSON.parse(input);\n\t} catch(e) {\n\t\tconsole.warn(\"JSON Import Error - File contents is invalid JSON\", e);\n\t\treturn Promise.reject();\n\t}\n}","function arrayImporter(input){\n\treturn input;\n}\n\nexport default arrayImporter;","import Module from '../../core/Module.js';\n\nimport defaultImporters from './defaults/importers.js';\n\nclass Import extends Module{\n \n\tconstructor(table){\n\t\tsuper(table);\n \n\t\tthis.registerTableOption(\"importFormat\");\n\t\tthis.registerTableOption(\"importReader\", \"text\");\n\t}\n \n\tinitialize(){\n\t\tthis.registerTableFunction(\"import\", this.importFromFile.bind(this));\n\n\t\tif(this.table.options.importFormat){\n\t\t\tthis.subscribe(\"data-loading\", this.loadDataCheck.bind(this), 10);\n\t\t\tthis.subscribe(\"data-load\", this.loadData.bind(this), 10);\n\t\t}\n\t}\n\n\tloadDataCheck(data){\n\t\treturn this.table.options.importFormat && (typeof data === \"string\" || (Array.isArray(data) && data.length && Array.isArray(data)));\n\t}\n\n\tloadData(data, params, config, silent, previousData){\n\t\treturn this.importData(this.lookupImporter(), data)\n\t\t\t.then(this.structureData.bind(this))\n\t\t\t.catch((err) => {\n\t\t\t\tconsole.error(\"Import Error:\", err || \"Unable to import data\");\n\t\t\t\treturn Promise.reject(err);\n\t\t\t});\n\t}\n\n\tlookupImporter(importFormat){\n\t\tvar importer;\n \n\t\tif(!importFormat){\n\t\t\timportFormat = this.table.options.importFormat;\n\t\t}\n \n\t\tif(typeof importFormat === \"string\"){\n\t\t\timporter = Import.importers[importFormat];\n\t\t}else{\n\t\t\timporter = importFormat;\n\t\t}\n\n\t\tif(!importer){\n\t\t\tconsole.error(\"Import Error - Importer not found:\", importFormat);\n\t\t}\n \n\t\treturn importer;\n\t}\n \n\timportFromFile(importFormat, extension){\n\t\tvar importer = this.lookupImporter(importFormat);\n \n\t\tif(importer){\n\t\t\treturn this.pickFile(extension)\n\t\t\t\t.then(this.importData.bind(this, importer))\n\t\t\t\t.then(this.structureData.bind(this))\n\t\t\t\t.then(this.setData.bind(this))\n\t\t\t\t.catch((err) => {\n\t\t\t\t\tconsole.error(\"Import Error:\", err || \"Unable to import file\");\n\t\t\t\t\treturn Promise.reject(err);\n\t\t\t\t});\n\t\t}\n\t}\n \n\tpickFile(extensions){\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tvar input = document.createElement(\"input\");\n\t\t\tinput.type = \"file\";\n\t\t\tinput.accept = extensions;\n \n\t\t\tinput.addEventListener(\"change\", (e) => {\n\t\t\t\tvar file = input.files[0],\n\t\t\t\treader = new FileReader();\n \n\t\t\t\tswitch(this.table.options.importReader){\n\t\t\t\t\tcase \"buffer\":\n\t\t\t\t\t\treader.readAsArrayBuffer(file);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"binary\":\n\t\t\t\t\t\treader.readAsBinaryString(file);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"url\":\n\t\t\t\t\t\treader.readAsDataURL(file);\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"text\":\n\t\t\t\t\tdefault:\n\t\t\t\t\t\treader.readAsText(file);\n\t\t\t\t}\n \n\t\t\t\treader.onload = (e) => {\n\t\t\t\t\tresolve(reader.result);\n\t\t\t\t};\n \n\t\t\t\treader.onerror = (e) => {\n\t\t\t\t\tconsole.warn(\"File Load Error - Unable to read file\");\n\t\t\t\t\treject();\n\t\t\t\t};\n\t\t\t});\n \n\t\t\tinput.click();\n\t\t});\n\t}\n \n\timportData(importer, fileContents){\n\t\tvar data = importer.call(this.table, fileContents);\n \n\t\tif(data instanceof Promise){\n\t\t\treturn data;\n\t\t}else{\n\t\t\treturn data ? Promise.resolve(data) : Promise.reject();\n\t\t}\n\t}\n\n\tstructureData(parsedData){\n\t\tvar data = [];\n \n\t\tif(Array.isArray(parsedData) && parsedData.length && Array.isArray(parsedData[0])){\n\t\t\tif(this.table.options.autoColumns){\n\t\t\t\tdata = this.structureArrayToObject(parsedData);\n\t\t\t}else{\n\t\t\t\tdata = this.structureArrayToColumns(parsedData);\n\t\t\t}\n\n\t\t\treturn data;\n\t\t}else{\n\t\t\treturn parsedData;\n\t\t}\n\t}\n\n\tstructureArrayToObject(parsedData){\n\t\tvar columns = parsedData.shift();\n\n\t\tvar data = parsedData.map((values) => {\n\t\t\tvar row = {};\n\n\t\t\tcolumns.forEach((key, i) => {\n\t\t\t\trow[key] = values[i];\n\t\t\t});\n\n\t\t\treturn row;\n\t\t});\n\n\t\treturn data;\n\t}\n\n\tstructureArrayToColumns(parsedData){\n\t\tvar data = [],\n\t\tcolumns = this.table.getColumns();\n\n\t\t//remove first row if it is the column names\n\t\tif(columns[0] && parsedData[0][0]){\n\t\t\tif(columns[0].getDefinition().title === parsedData[0][0]){\n\t\t\t\tparsedData.shift();\n\t\t\t}\n\t\t}\n \n\t\t//convert row arrays to objects\n\t\tparsedData.forEach((rowData) => {\n\t\t\tvar row = {};\n\n\t\t\trowData.forEach((value, index) => {\n\t\t\t\tvar column = columns[index];\n\n\t\t\t\tif(column){\n\t\t\t\t\trow[column.getField()] = value;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tdata.push(row);\n\t\t});\n\n\t\treturn data;\n\t}\n \n\tsetData(data){\n\t\treturn this.table.setData(data);\n\t}\n}\n\nImport.moduleName = \"import\";\n\n//load defaults\nImport.importers = defaultImporters;\n\nexport default Import;","import Module from '../../core/Module.js';\n\nimport Cell from '../../core/cell/Cell.js';\nimport Column from '../../core/column/Column.js';\n\nclass Interaction extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.eventMap = {\n\t\t\t//row events\n\t\t\trowClick:\"row-click\",\n\t\t\trowDblClick:\"row-dblclick\",\n\t\t\trowContext:\"row-contextmenu\",\n\t\t\trowMouseEnter:\"row-mouseenter\",\n\t\t\trowMouseLeave:\"row-mouseleave\",\n\t\t\trowMouseOver:\"row-mouseover\",\n\t\t\trowMouseOut:\"row-mouseout\",\n\t\t\trowMouseMove:\"row-mousemove\",\n\t\t\trowMouseDown:\"row-mousedown\",\n\t\t\trowMouseUp:\"row-mouseup\",\n\t\t\trowTap:\"row\",\n\t\t\trowDblTap:\"row\",\n\t\t\trowTapHold:\"row\",\n\n\t\t\t//cell events\n\t\t\tcellClick:\"cell-click\",\n\t\t\tcellDblClick:\"cell-dblclick\",\n\t\t\tcellContext:\"cell-contextmenu\",\n\t\t\tcellMouseEnter:\"cell-mouseenter\",\n\t\t\tcellMouseLeave:\"cell-mouseleave\",\n\t\t\tcellMouseOver:\"cell-mouseover\",\n\t\t\tcellMouseOut:\"cell-mouseout\",\n\t\t\tcellMouseMove:\"cell-mousemove\",\n\t\t\tcellMouseDown:\"cell-mousedown\",\n\t\t\tcellMouseUp:\"cell-mouseup\",\n\t\t\tcellTap:\"cell\",\n\t\t\tcellDblTap:\"cell\",\n\t\t\tcellTapHold:\"cell\",\n\n\t\t\t//column header events\n\t\t\theaderClick:\"column-click\",\n\t\t\theaderDblClick:\"column-dblclick\",\n\t\t\theaderContext:\"column-contextmenu\",\n\t\t\theaderMouseEnter:\"column-mouseenter\",\n\t\t\theaderMouseLeave:\"column-mouseleave\",\n\t\t\theaderMouseOver:\"column-mouseover\",\n\t\t\theaderMouseOut:\"column-mouseout\",\n\t\t\theaderMouseMove:\"column-mousemove\",\n\t\t\theaderMouseDown:\"column-mousedown\",\n\t\t\theaderMouseUp:\"column-mouseup\",\n\t\t\theaderTap:\"column\",\n\t\t\theaderDblTap:\"column\",\n\t\t\theaderTapHold:\"column\",\n\n\t\t\t//group header\n\t\t\tgroupClick:\"group-click\",\n\t\t\tgroupDblClick:\"group-dblclick\",\n\t\t\tgroupContext:\"group-contextmenu\",\n\t\t\tgroupMouseEnter:\"group-mouseenter\",\n\t\t\tgroupMouseLeave:\"group-mouseleave\",\n\t\t\tgroupMouseOver:\"group-mouseover\",\n\t\t\tgroupMouseOut:\"group-mouseout\",\n\t\t\tgroupMouseMove:\"group-mousemove\",\n\t\t\tgroupMouseDown:\"group-mousedown\",\n\t\t\tgroupMouseUp:\"group-mouseup\",\n\t\t\tgroupTap:\"group\",\n\t\t\tgroupDblTap:\"group\",\n\t\t\tgroupTapHold:\"group\",\n\t\t};\n\n\t\tthis.subscribers = {};\n\n\t\tthis.touchSubscribers = {};\n\n\t\tthis.columnSubscribers = {};\n\n\t\tthis.touchWatchers = {\n\t\t\trow:{\n\t\t\t\ttap:null,\n\t\t\t\ttapDbl:null,\n\t\t\t\ttapHold:null,\n\t\t\t},\n\t\t\tcell:{\n\t\t\t\ttap:null,\n\t\t\t\ttapDbl:null,\n\t\t\t\ttapHold:null,\n\t\t\t},\n\t\t\tcolumn:{\n\t\t\t\ttap:null,\n\t\t\t\ttapDbl:null,\n\t\t\t\ttapHold:null,\n\t\t\t},\n\t\t\tgroup:{\n\t\t\t\ttap:null,\n\t\t\t\ttapDbl:null,\n\t\t\t\ttapHold:null,\n\t\t\t}\n\t\t};\n\n\t\tthis.registerColumnOption(\"headerClick\");\n\t\tthis.registerColumnOption(\"headerDblClick\");\n\t\tthis.registerColumnOption(\"headerContext\");\n\t\tthis.registerColumnOption(\"headerMouseEnter\");\n\t\tthis.registerColumnOption(\"headerMouseLeave\");\n\t\tthis.registerColumnOption(\"headerMouseOver\");\n\t\tthis.registerColumnOption(\"headerMouseOut\");\n\t\tthis.registerColumnOption(\"headerMouseMove\");\n\t\tthis.registerColumnOption(\"headerMouseDown\");\n\t\tthis.registerColumnOption(\"headerMouseUp\");\n\t\tthis.registerColumnOption(\"headerTap\");\n\t\tthis.registerColumnOption(\"headerDblTap\");\n\t\tthis.registerColumnOption(\"headerTapHold\");\n\n\t\tthis.registerColumnOption(\"cellClick\");\n\t\tthis.registerColumnOption(\"cellDblClick\");\n\t\tthis.registerColumnOption(\"cellContext\");\n\t\tthis.registerColumnOption(\"cellMouseEnter\");\n\t\tthis.registerColumnOption(\"cellMouseLeave\");\n\t\tthis.registerColumnOption(\"cellMouseOver\");\n\t\tthis.registerColumnOption(\"cellMouseOut\");\n\t\tthis.registerColumnOption(\"cellMouseMove\");\n\t\tthis.registerColumnOption(\"cellMouseDown\");\n\t\tthis.registerColumnOption(\"cellMouseUp\");\n\t\tthis.registerColumnOption(\"cellTap\");\n\t\tthis.registerColumnOption(\"cellDblTap\");\n\t\tthis.registerColumnOption(\"cellTapHold\");\n\n\t}\n\n\tinitialize(){\n\t\tthis.initializeExternalEvents();\n\n\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t\tthis.subscribe(\"cell-dblclick\", this.cellContentsSelectionFixer.bind(this));\n\t\tthis.subscribe(\"scroll-horizontal\", this.clearTouchWatchers.bind(this));\n\t\tthis.subscribe(\"scroll-vertical\", this.clearTouchWatchers.bind(this));\n\t}\n\n\tclearTouchWatchers(){\n\t\tvar types = Object.values(this.touchWatchers);\n\n\t\ttypes.forEach((type) => {\n\t\t\tfor(let key in type){\n\t\t\t\ttype[key] = null;\n\t\t\t}\n\t\t});\n\t}\n\t\t\n\tcellContentsSelectionFixer(e, cell){\n\t\tvar range;\n\n\t\tif(this.table.modExists(\"edit\")){\n\t\t\tif (this.table.modules.edit.currentCell === cell){\n\t\t\t\treturn; //prevent instant selection of editor content\n\t\t\t}\n\t\t}\n\n\t\te.preventDefault();\n\n\t\ttry{\n\t\t\tif (document.selection) { // IE\n\t\t\t\trange = document.body.createTextRange();\n\t\t\t\trange.moveToElementText(cell.getElement());\n\t\t\t\trange.select();\n\t\t\t} else if (window.getSelection) {\n\t\t\t\trange = document.createRange();\n\t\t\t\trange.selectNode(cell.getElement());\n\t\t\t\twindow.getSelection().removeAllRanges();\n\t\t\t\twindow.getSelection().addRange(range);\n\t\t\t}\n\t\t}catch(e){}\n\t}\n\n\tinitializeExternalEvents(){\n\t\tfor(let key in this.eventMap){\n\t\t\tthis.subscriptionChangeExternal(key, this.subscriptionChanged.bind(this, key));\n\t\t}\n\t}\n\n\tsubscriptionChanged(key, added){\n\t\tif(added){\n\t\t\tif(!this.subscribers[key]){\n\t\t\t\tif(this.eventMap[key].includes(\"-\")){\n\t\t\t\t\tthis.subscribers[key] = this.handle.bind(this, key);\n\t\t\t\t\tthis.subscribe(this.eventMap[key], this.subscribers[key]);\n\t\t\t\t}else{\n\t\t\t\t\tthis.subscribeTouchEvents(key);\n\t\t\t\t}\n\t\t\t}\n\t\t}else{\n\t\t\tif(this.eventMap[key].includes(\"-\")){\n\t\t\t\tif(this.subscribers[key] && !this.columnSubscribers[key] && !this.subscribedExternal(key)){\n\t\t\t\t\tthis.unsubscribe(this.eventMap[key], this.subscribers[key]);\n\t\t\t\t\tdelete this.subscribers[key];\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.unsubscribeTouchEvents(key);\n\t\t\t}\n\t\t}\n\t}\n\n\n\tsubscribeTouchEvents(key){\n\t\tvar type = this.eventMap[key];\n\n\t\tif(!this.touchSubscribers[type + \"-touchstart\"]){\n\t\t\tthis.touchSubscribers[type + \"-touchstart\"] = this.handleTouch.bind(this, type, \"start\");\n\t\t\tthis.touchSubscribers[type + \"-touchend\"] = this.handleTouch.bind(this, type, \"end\");\n\n\t\t\tthis.subscribe(type + \"-touchstart\", this.touchSubscribers[type + \"-touchstart\"]);\n\t\t\tthis.subscribe(type + \"-touchend\", this.touchSubscribers[type + \"-touchend\"]);\n\t\t}\n\n\t\tthis.subscribers[key] = true;\n\t}\n\n\tunsubscribeTouchEvents(key){\n\t\tvar noTouch = true,\n\t\ttype = this.eventMap[key];\n\n\t\tif(this.subscribers[key] && !this.subscribedExternal(key)){\n\t\t\tdelete this.subscribers[key];\n\n\t\t\tfor(let i in this.eventMap){\n\t\t\t\tif(this.eventMap[i] === type){\n\t\t\t\t\tif(this.subscribers[i]){\n\t\t\t\t\t\tnoTouch = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif(noTouch){\n\t\t\t\tthis.unsubscribe(type + \"-touchstart\", this.touchSubscribers[type + \"-touchstart\"]);\n\t\t\t\tthis.unsubscribe(type + \"-touchend\", this.touchSubscribers[type + \"-touchend\"]);\n\n\t\t\t\tdelete this.touchSubscribers[type + \"-touchstart\"];\n\t\t\t\tdelete this.touchSubscribers[type + \"-touchend\"];\n\t\t\t}\n\t\t}\n\t}\n\n\tinitializeColumn(column){\n\t\tvar def = column.definition;\n\n\t\tfor(let key in this.eventMap){\n\t\t\tif(def[key]){\n\t\t\t\tthis.subscriptionChanged(key, true);\n\n\t\t\t\tif(!this.columnSubscribers[key]){\n\t\t\t\t\tthis.columnSubscribers[key] = [];\n\t\t\t\t}\n\n\t\t\t\tthis.columnSubscribers[key].push(column);\n\t\t\t}\n\t\t}\n\t}\n\n\thandle(action, e, component){\n\t\tthis.dispatchEvent(action, e, component);\n\t}\n\n\thandleTouch(type, action, e, component){\n\t\tvar watchers = this.touchWatchers[type];\n\n\t\tif(type === \"column\"){\n\t\t\ttype = \"header\";\n\t\t}\n\n\t\tswitch(action){\n\t\t\tcase \"start\":\n\t\t\t\twatchers.tap = true;\n\n\t\t\t\tclearTimeout(watchers.tapHold);\n\n\t\t\t\twatchers.tapHold = setTimeout(() => {\n\t\t\t\t\tclearTimeout(watchers.tapHold);\n\t\t\t\t\twatchers.tapHold = null;\n\n\t\t\t\t\twatchers.tap = null;\n\t\t\t\t\tclearTimeout(watchers.tapDbl);\n\t\t\t\t\twatchers.tapDbl = null;\n\n\t\t\t\t\tthis.dispatchEvent(type + \"TapHold\", e, component);\n\t\t\t\t}, 1000);\n\t\t\t\tbreak;\n\n\t\t\tcase \"end\":\n\t\t\t\tif(watchers.tap){\n\n\t\t\t\t\twatchers.tap = null;\n\t\t\t\t\tthis.dispatchEvent(type + \"Tap\", e, component);\n\t\t\t\t}\n\n\t\t\t\tif(watchers.tapDbl){\n\t\t\t\t\tclearTimeout(watchers.tapDbl);\n\t\t\t\t\twatchers.tapDbl = null;\n\n\t\t\t\t\tthis.dispatchEvent(type + \"DblTap\", e, component);\n\t\t\t\t}else{\n\t\t\t\t\twatchers.tapDbl = setTimeout(() => {\n\t\t\t\t\t\tclearTimeout(watchers.tapDbl);\n\t\t\t\t\t\twatchers.tapDbl = null;\n\t\t\t\t\t}, 300);\n\t\t\t\t}\n\n\t\t\t\tclearTimeout(watchers.tapHold);\n\t\t\t\twatchers.tapHold = null;\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\tdispatchEvent(action, e, component){\n\t\tvar componentObj = component.getComponent(),\n\t\tcallback;\n\n\t\tif(this.columnSubscribers[action]){\n\n\t\t\tif(component instanceof Cell){\n\t\t\t\tcallback = component.column.definition[action];\n\t\t\t}else if(component instanceof Column){\n\t\t\t\tcallback = component.definition[action];\n\t\t\t}\n\n\t\t\tif(callback){\n\t\t\t\tcallback(e, componentObj);\n\t\t\t}\n\t\t}\n\n\t\tthis.dispatchExternal(action, e, componentObj);\n\t}\n}\n\nInteraction.moduleName = \"interaction\";\n\nexport default Interaction;\n","import Module from '../../core/Module.js';\n\nimport defaultBindings from './defaults/bindings.js';\nimport defaultActions from './defaults/actions.js';\n\nclass Keybindings extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.watchKeys = null;\n\t\tthis.pressedKeys = null;\n\t\tthis.keyupBinding = false;\n\t\tthis.keydownBinding = false;\n\n\t\tthis.registerTableOption(\"keybindings\", {}); //array for keybindings\n\t\tthis.registerTableOption(\"tabEndNewRow\", false); //create new row when tab to end of table\n\t}\n\n\tinitialize(){\n\t\tvar bindings = this.table.options.keybindings,\n\t\tmergedBindings = {};\n\n\t\tthis.watchKeys = {};\n\t\tthis.pressedKeys = [];\n\n\t\tif(bindings !== false){\n\t\t\tObject.assign(mergedBindings, Keybindings.bindings);\n\t\t\tObject.assign(mergedBindings, bindings);\n\n\t\t\tthis.mapBindings(mergedBindings);\n\t\t\tthis.bindEvents();\n\t\t}\n\n\t\tthis.subscribe(\"table-destroy\", this.clearBindings.bind(this));\n\t}\n\n\tmapBindings(bindings){\n\t\tfor(let key in bindings){\n\t\t\tif(Keybindings.actions[key]){\n\t\t\t\tif(bindings[key]){\n\t\t\t\t\tif(typeof bindings[key] !== \"object\"){\n\t\t\t\t\t\tbindings[key] = [bindings[key]];\n\t\t\t\t\t}\n\n\t\t\t\t\tbindings[key].forEach((binding) => {\n\t\t\t\t\t\tvar bindingList = Array.isArray(binding) ? binding : [binding];\n\t\t\t\t\t\t\n\t\t\t\t\t\tbindingList.forEach((item) => {\n\t\t\t\t\t\t\tthis.mapBinding(key, item);\n\t\t\t\t\t\t});\t\t\t\t\t\t\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Key Binding Error - no such action:\", key);\n\t\t\t}\n\t\t}\n\t}\n\n\tmapBinding(action, symbolsList){\n\t\tvar binding = {\n\t\t\taction: Keybindings.actions[action],\n\t\t\tkeys: [],\n\t\t\tctrl: false,\n\t\t\tshift: false,\n\t\t\tmeta: false,\n\t\t};\n\n\t\tvar symbols = symbolsList.toString().toLowerCase().split(\" \").join(\"\").split(\"+\");\n\n\t\tsymbols.forEach((symbol) => {\n\t\t\tswitch(symbol){\n\t\t\t\tcase \"ctrl\":\n\t\t\t\t\tbinding.ctrl = true;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"shift\":\n\t\t\t\t\tbinding.shift = true;\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"meta\":\n\t\t\t\t\tbinding.meta = true;\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\tsymbol = isNaN(symbol) ? symbol.toUpperCase().charCodeAt(0) : parseInt(symbol);\n\t\t\t\t\tbinding.keys.push(symbol);\n\n\t\t\t\t\tif(!this.watchKeys[symbol]){\n\t\t\t\t\t\tthis.watchKeys[symbol] = [];\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.watchKeys[symbol].push(binding);\n\t\t\t}\n\t\t});\n\t}\n\n\tbindEvents(){\n\t\tvar self = this;\n\n\t\tthis.keyupBinding = function(e){\n\t\t\tvar code = e.keyCode;\n\t\t\tvar bindings = self.watchKeys[code];\n\n\t\t\tif(bindings){\n\n\t\t\t\tself.pressedKeys.push(code);\n\n\t\t\t\tbindings.forEach(function(binding){\n\t\t\t\t\tself.checkBinding(e, binding);\n\t\t\t\t});\n\t\t\t}\n\t\t};\n\n\t\tthis.keydownBinding = function(e){\n\t\t\tvar code = e.keyCode;\n\t\t\tvar bindings = self.watchKeys[code];\n\n\t\t\tif(bindings){\n\n\t\t\t\tvar index = self.pressedKeys.indexOf(code);\n\n\t\t\t\tif(index > -1){\n\t\t\t\t\tself.pressedKeys.splice(index, 1);\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\tthis.table.element.addEventListener(\"keydown\", this.keyupBinding);\n\n\t\tthis.table.element.addEventListener(\"keyup\", this.keydownBinding);\n\t}\n\n\tclearBindings(){\n\t\tif(this.keyupBinding){\n\t\t\tthis.table.element.removeEventListener(\"keydown\", this.keyupBinding);\n\t\t}\n\n\t\tif(this.keydownBinding){\n\t\t\tthis.table.element.removeEventListener(\"keyup\", this.keydownBinding);\n\t\t}\n\t}\n\n\tcheckBinding(e, binding){\n\t\tvar match = true;\n\n\t\tif(e.ctrlKey == binding.ctrl && e.shiftKey == binding.shift && e.metaKey == binding.meta){\n\t\t\tbinding.keys.forEach((key) => {\n\t\t\t\tvar index = this.pressedKeys.indexOf(key);\n\n\t\t\t\tif(index == -1){\n\t\t\t\t\tmatch = false;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tif(match){\n\t\t\t\tbinding.action.call(this, e);\n\t\t\t}\n\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t}\n}\n\nKeybindings.moduleName = \"keybindings\";\n\n//load defaults\nKeybindings.bindings = defaultBindings;\nKeybindings.actions = defaultActions;\n\nexport default Keybindings;","export default {\n\tnavPrev:\"shift + 9\",\n\tnavNext:9,\n\tnavUp:38,\n\tnavDown:40,\n\tscrollPageUp:33,\n\tscrollPageDown:34,\n\tscrollToStart:36,\n\tscrollToEnd:35,\n\tundo:[\"ctrl + 90\", \"meta + 90\"],\n\tredo:[\"ctrl + 89\", \"meta + 89\"],\n\tcopyToClipboard:[\"ctrl + 67\", \"meta + 67\"],\n};","export default {\n\tkeyBlock:function(e){\n\t\te.stopPropagation();\n\t\te.preventDefault();\n\t},\n\tscrollPageUp:function(e){\n\t\tvar rowManager = this.table.rowManager,\n\t\tnewPos = rowManager.scrollTop - rowManager.element.clientHeight;\n\n\t\te.preventDefault();\n\n\t\tif(rowManager.displayRowsCount){\n\t\t\tif(newPos >= 0){\n\t\t\t\trowManager.element.scrollTop = newPos;\n\t\t\t}else{\n\t\t\t\trowManager.scrollToRow(rowManager.getDisplayRows()[0]);\n\t\t\t}\n\t\t}\n\n\t\tthis.table.element.focus();\n\t},\n\tscrollPageDown:function(e){\n\t\tvar rowManager = this.table.rowManager,\n\t\tnewPos = rowManager.scrollTop + rowManager.element.clientHeight,\n\t\tscrollMax = rowManager.element.scrollHeight;\n\n\t\te.preventDefault();\n\n\t\tif(rowManager.displayRowsCount){\n\t\t\tif(newPos <= scrollMax){\n\t\t\t\trowManager.element.scrollTop = newPos;\n\t\t\t}else{\n\t\t\t\trowManager.scrollToRow(rowManager.getDisplayRows()[rowManager.displayRowsCount - 1]);\n\t\t\t}\n\t\t}\n\n\t\tthis.table.element.focus();\n\n\t},\n\tscrollToStart:function(e){\n\t\tvar rowManager = this.table.rowManager;\n\n\t\te.preventDefault();\n\n\t\tif(rowManager.displayRowsCount){\n\t\t\trowManager.scrollToRow(rowManager.getDisplayRows()[0]);\n\t\t}\n\n\t\tthis.table.element.focus();\n\t},\n\tscrollToEnd:function(e){\n\t\tvar rowManager = this.table.rowManager;\n\n\t\te.preventDefault();\n\n\t\tif(rowManager.displayRowsCount){\n\t\t\trowManager.scrollToRow(rowManager.getDisplayRows()[rowManager.displayRowsCount - 1]);\n\t\t}\n\n\t\tthis.table.element.focus();\n\t},\n\tnavPrev:function(e){\n\t\tthis.dispatch(\"keybinding-nav-prev\", e);\n\t},\n\n\tnavNext:function(e){\n\t\tthis.dispatch(\"keybinding-nav-next\", e);\n\t},\n\n\tnavLeft:function(e){\n\t\tthis.dispatch(\"keybinding-nav-left\", e);\n\t},\n\n\tnavRight:function(e){\n\t\tthis.dispatch(\"keybinding-nav-right\", e);\n\t},\n\n\tnavUp:function(e){\n\t\tthis.dispatch(\"keybinding-nav-up\", e);\n\t},\n\n\tnavDown:function(e){\n\t\tthis.dispatch(\"keybinding-nav-down\", e);\n\t},\n\n\tundo:function(e){\n\t\tvar cell = false;\n\t\tif(this.table.options.history && this.table.modExists(\"history\") && this.table.modExists(\"edit\")){\n\n\t\t\tcell = this.table.modules.edit.currentCell;\n\n\t\t\tif(!cell){\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.table.modules.history.undo();\n\t\t\t}\n\t\t}\n\t},\n\n\tredo:function(e){\n\t\tvar cell = false;\n\t\tif(this.table.options.history && this.table.modExists(\"history\") && this.table.modExists(\"edit\")){\n\n\t\t\tcell = this.table.modules.edit.currentCell;\n\n\t\t\tif(!cell){\n\t\t\t\te.preventDefault();\n\t\t\t\tthis.table.modules.history.redo();\n\t\t\t}\n\t\t}\n\t},\n\n\tcopyToClipboard:function(e){\n\t\tif(!this.table.modules.edit.currentCell){\n\t\t\tif(this.table.modExists(\"clipboard\", true)){\n\t\t\t\tthis.table.modules.clipboard.copy(false, true);\n\t\t\t}\n\t\t}\n\t},\n};","import Module from '../../core/Module.js';\n\nclass Menu extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.menuContainer = null;\n\t\tthis.nestedMenuBlock = false;\n\t\t\n\t\tthis.currentComponent = null;\n\t\tthis.rootPopup = null;\n\t\t\n\t\tthis.columnSubscribers = {};\n\t\t\n\t\tthis.registerTableOption(\"menuContainer\", undefined); //deprecated\n\t\t\n\t\tthis.registerTableOption(\"rowContextMenu\", false);\n\t\tthis.registerTableOption(\"rowClickMenu\", false);\n\t\tthis.registerTableOption(\"rowDblClickMenu\", false);\n\t\tthis.registerTableOption(\"groupContextMenu\", false);\n\t\tthis.registerTableOption(\"groupClickMenu\", false);\n\t\tthis.registerTableOption(\"groupDblClickMenu\", false);\n\t\t\n\t\tthis.registerColumnOption(\"headerContextMenu\");\n\t\tthis.registerColumnOption(\"headerClickMenu\");\n\t\tthis.registerColumnOption(\"headerDblClickMenu\");\n\t\tthis.registerColumnOption(\"headerMenu\");\n\t\tthis.registerColumnOption(\"headerMenuIcon\");\n\t\tthis.registerColumnOption(\"contextMenu\");\n\t\tthis.registerColumnOption(\"clickMenu\");\n\t\tthis.registerColumnOption(\"dblClickMenu\");\n\t\t\n\t}\n\t\n\tinitialize(){\n\t\tthis.deprecatedOptionsCheck();\n\t\tthis.initializeRowWatchers();\n\t\tthis.initializeGroupWatchers();\n\t\t\n\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t}\n\t\n\tdeprecatedOptionsCheck(){\n\t\tif(!this.deprecationCheck(\"menuContainer\", \"popupContainer\")){\n\t\t\tthis.table.options.popupContainer = this.table.options.menuContainer;\n\t\t}\n\t}\t\n\t\n\tinitializeRowWatchers(){\n\t\tif(this.table.options.rowContextMenu){\n\t\t\tthis.subscribe(\"row-contextmenu\", this.loadMenuEvent.bind(this, this.table.options.rowContextMenu));\n\t\t\tthis.table.on(\"rowTapHold\", this.loadMenuEvent.bind(this, this.table.options.rowContextMenu));\n\t\t}\n\t\t\n\t\tif(this.table.options.rowClickMenu){\n\t\t\tthis.subscribe(\"row-click\", this.loadMenuEvent.bind(this, this.table.options.rowClickMenu));\n\t\t}\n\t\t\n\t\tif(this.table.options.rowDblClickMenu){\n\t\t\tthis.subscribe(\"row-dblclick\", this.loadMenuEvent.bind(this, this.table.options.rowDblClickMenu));\n\t\t}\n\t}\n\t\n\tinitializeGroupWatchers(){\n\t\tif(this.table.options.groupContextMenu){\n\t\t\tthis.subscribe(\"group-contextmenu\", this.loadMenuEvent.bind(this, this.table.options.groupContextMenu));\n\t\t\tthis.table.on(\"groupTapHold\", this.loadMenuEvent.bind(this, this.table.options.groupContextMenu));\n\t\t}\n\t\t\n\t\tif(this.table.options.groupClickMenu){\n\t\t\tthis.subscribe(\"group-click\", this.loadMenuEvent.bind(this, this.table.options.groupClickMenu));\n\t\t}\n\t\t\n\t\tif(this.table.options.groupDblClickMenu){\n\t\t\tthis.subscribe(\"group-dblclick\", this.loadMenuEvent.bind(this, this.table.options.groupDblClickMenu));\n\t\t}\n\t}\n\t\n\tinitializeColumn(column){\n\t\tvar\tdef = column.definition;\n\t\t\n\t\t//handle column events\n\t\tif(def.headerContextMenu && !this.columnSubscribers.headerContextMenu){\n\t\t\tthis.columnSubscribers.headerContextMenu = this.loadMenuTableColumnEvent.bind(this, \"headerContextMenu\");\n\t\t\tthis.subscribe(\"column-contextmenu\", this.columnSubscribers.headerContextMenu);\n\t\t\tthis.table.on(\"headerTapHold\", this.loadMenuTableColumnEvent.bind(this, \"headerContextMenu\"));\n\t\t}\n\t\t\n\t\tif(def.headerClickMenu && !this.columnSubscribers.headerClickMenu){\n\t\t\tthis.columnSubscribers.headerClickMenu = this.loadMenuTableColumnEvent.bind(this, \"headerClickMenu\");\n\t\t\tthis.subscribe(\"column-click\", this.columnSubscribers.headerClickMenu);\n\t\t}\n\t\t\n\t\tif(def.headerDblClickMenu && !this.columnSubscribers.headerDblClickMenu){\n\t\t\tthis.columnSubscribers.headerDblClickMenu = this.loadMenuTableColumnEvent.bind(this, \"headerDblClickMenu\");\n\t\t\tthis.subscribe(\"column-dblclick\", this.columnSubscribers.headerDblClickMenu);\n\t\t}\n\t\t\n\t\tif(def.headerMenu){\n\t\t\tthis.initializeColumnHeaderMenu(column);\n\t\t}\n\t\t\n\t\t//handle cell events\n\t\tif(def.contextMenu && !this.columnSubscribers.contextMenu){\n\t\t\tthis.columnSubscribers.contextMenu = this.loadMenuTableCellEvent.bind(this, \"contextMenu\");\n\t\t\tthis.subscribe(\"cell-contextmenu\", this.columnSubscribers.contextMenu);\n\t\t\tthis.table.on(\"cellTapHold\", this.loadMenuTableCellEvent.bind(this, \"contextMenu\"));\n\t\t}\n\t\t\n\t\tif(def.clickMenu && !this.columnSubscribers.clickMenu){\n\t\t\tthis.columnSubscribers.clickMenu = this.loadMenuTableCellEvent.bind(this, \"clickMenu\");\n\t\t\tthis.subscribe(\"cell-click\", this.columnSubscribers.clickMenu);\n\t\t}\n\t\t\n\t\tif(def.dblClickMenu && !this.columnSubscribers.dblClickMenu){\n\t\t\tthis.columnSubscribers.dblClickMenu = this.loadMenuTableCellEvent.bind(this, \"dblClickMenu\");\n\t\t\tthis.subscribe(\"cell-dblclick\", this.columnSubscribers.dblClickMenu);\n\t\t}\n\t}\n\t\n\tinitializeColumnHeaderMenu(column){\n\t\tvar icon = column.definition.headerMenuIcon,\n\t\theaderMenuEl;\n\t\t\n\t\theaderMenuEl = document.createElement(\"span\");\n\t\theaderMenuEl.classList.add(\"tabulator-header-popup-button\");\n\t\t\n\t\tif(icon){\n\t\t\tif(typeof icon === \"function\"){\n\t\t\t\ticon = icon(column.getComponent());\n\t\t\t}\n\t\t\t\n\t\t\tif(icon instanceof HTMLElement){\n\t\t\t\theaderMenuEl.appendChild(icon);\n\t\t\t}else{\n\t\t\t\theaderMenuEl.innerHTML = icon;\n\t\t\t}\n\t\t}else{\n\t\t\theaderMenuEl.innerHTML = \"⋮\";\n\t\t}\n\t\t\n\t\theaderMenuEl.addEventListener(\"click\", (e) => {\n\t\t\te.stopPropagation();\n\t\t\te.preventDefault();\n\t\t\t\n\t\t\tthis.loadMenuEvent(column.definition.headerMenu, e, column);\n\t\t});\n\t\t\n\t\tcolumn.titleElement.insertBefore(headerMenuEl, column.titleElement.firstChild);\n\t}\n\t\n\tloadMenuTableCellEvent(option, e, cell){\n\t\tif(cell._cell){\n\t\t\tcell = cell._cell;\n\t\t}\n\t\t\n\t\tif(cell.column.definition[option]){\n\t\t\tthis.loadMenuEvent(cell.column.definition[option], e, cell);\n\t\t}\n\t}\n\t\n\tloadMenuTableColumnEvent(option, e, column){\n\t\tif(column._column){\n\t\t\tcolumn = column._column;\n\t\t}\n\t\t\n\t\tif(column.definition[option]){\n\t\t\tthis.loadMenuEvent(column.definition[option], e, column);\n\t\t}\n\t}\n\t\n\tloadMenuEvent(menu, e, component){\n\t\tif(component._group){\n\t\t\tcomponent = component._group;\n\t\t}else if(component._row){\n\t\t\tcomponent = component._row;\n\t\t}\n\t\t\n\t\tmenu = typeof menu == \"function\" ? menu.call(this.table, e, component.getComponent()) : menu;\n\t\t\n\t\tthis.loadMenu(e, component, menu);\n\t}\n\t\n\tloadMenu(e, component, menu, parentEl, parentPopup){\n\t\tvar touch = !(e instanceof MouseEvent),\t\t\n\t\tmenuEl = document.createElement(\"div\"),\n\t\tpopup;\n\t\t\n\t\tmenuEl.classList.add(\"tabulator-menu\");\n\t\t\n\t\tif(!touch){\n\t\t\te.preventDefault();\n\t\t}\n\t\t\n\t\t//abort if no menu set\n\t\tif(!menu || !menu.length){\n\t\t\treturn;\n\t\t}\n\t\t\n\t\tif(!parentEl){\n\t\t\tif(this.nestedMenuBlock){\n\t\t\t\t//abort if child menu already open\n\t\t\t\tif(this.rootPopup){\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.nestedMenuBlock = setTimeout(() => {\n\t\t\t\t\tthis.nestedMenuBlock = false;\n\t\t\t\t}, 100);\n\t\t\t}\n\t\t\t\n\t\t\tif(this.rootPopup){\n\t\t\t\tthis.rootPopup.hide();\t\n\t\t\t}\n\t\t\t\n\t\t\tthis.rootPopup = popup = this.popup(menuEl);\n\t\t\t\n\t\t}else{\n\t\t\tpopup = parentPopup.child(menuEl);\n\t\t}\n\t\t\n\t\tmenu.forEach((item) => {\n\t\t\tvar itemEl = document.createElement(\"div\"),\n\t\t\tlabel = item.label,\n\t\t\tdisabled = item.disabled;\n\t\t\t\n\t\t\tif(item.separator){\n\t\t\t\titemEl.classList.add(\"tabulator-menu-separator\");\n\t\t\t}else{\n\t\t\t\titemEl.classList.add(\"tabulator-menu-item\");\n\t\t\t\t\n\t\t\t\tif(typeof label == \"function\"){\n\t\t\t\t\tlabel = label.call(this.table, component.getComponent());\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(label instanceof Node){\n\t\t\t\t\titemEl.appendChild(label);\n\t\t\t\t}else{\n\t\t\t\t\titemEl.innerHTML = label;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(typeof disabled == \"function\"){\n\t\t\t\t\tdisabled = disabled.call(this.table, component.getComponent());\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(disabled){\n\t\t\t\t\titemEl.classList.add(\"tabulator-menu-item-disabled\");\n\t\t\t\t\titemEl.addEventListener(\"click\", (e) => {\n\t\t\t\t\t\te.stopPropagation();\n\t\t\t\t\t});\n\t\t\t\t}else{\n\t\t\t\t\tif(item.menu && item.menu.length){\n\t\t\t\t\t\titemEl.addEventListener(\"click\", (e) => {\n\t\t\t\t\t\t\te.stopPropagation();\n\t\t\t\t\t\t\tthis.loadMenu(e, component, item.menu, itemEl, popup);\n\t\t\t\t\t\t});\n\t\t\t\t\t}else{\n\t\t\t\t\t\tif(item.action){\n\t\t\t\t\t\t\titemEl.addEventListener(\"click\", (e) => {\n\t\t\t\t\t\t\t\titem.action(e, component.getComponent());\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(item.menu && item.menu.length){\n\t\t\t\t\titemEl.classList.add(\"tabulator-menu-item-submenu\");\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tmenuEl.appendChild(itemEl);\n\t\t});\n\t\t\n\t\tmenuEl.addEventListener(\"click\", (e) => {\n\t\t\tif(this.rootPopup){\n\t\t\t\tthis.rootPopup.hide();\n\t\t\t}\n\t\t});\n\t\t\n\t\tpopup.show(parentEl || e);\n\t\t\n\t\tif(popup === this.rootPopup){\n\t\t\tthis.rootPopup.hideOnBlur(() => {\n\t\t\t\tthis.rootPopup = null;\n\t\t\t\t\n\t\t\t\tif(this.currentComponent){\n\t\t\t\t\tthis.dispatchExternal(\"menuClosed\", this.currentComponent.getComponent());\n\t\t\t\t\tthis.currentComponent = null;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tthis.currentComponent = component;\n\t\t\t\n\t\t\tthis.dispatchExternal(\"menuOpened\", component.getComponent());\n\t\t}\n\t}\n}\n\nMenu.moduleName = \"menu\";\n\nexport default Menu;\n","import Module from '../../core/Module.js';\nimport Helpers from '../../core/tools/Helpers.js';\n\nclass MoveColumns extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.placeholderElement = this.createPlaceholderElement();\n\t\tthis.hoverElement = false; //floating column header element\n\t\tthis.checkTimeout = false; //click check timeout holder\n\t\tthis.checkPeriod = 250; //period to wait on mousedown to consider this a move and not a click\n\t\tthis.moving = false; //currently moving column\n\t\tthis.toCol = false; //destination column\n\t\tthis.toColAfter = false; //position of moving column relative to the destination column\n\t\tthis.startX = 0; //starting position within header element\n\t\tthis.autoScrollMargin = 40; //auto scroll on edge when within margin\n\t\tthis.autoScrollStep = 5; //auto scroll distance in pixels\n\t\tthis.autoScrollTimeout = false; //auto scroll timeout\n\t\tthis.touchMove = false;\n\t\t\n\t\tthis.moveHover = this.moveHover.bind(this);\n\t\tthis.endMove = this.endMove.bind(this);\n\t\t\n\t\tthis.registerTableOption(\"movableColumns\", false); //enable movable columns\n\t}\n\t\n\tcreatePlaceholderElement(){\n\t\tvar el = document.createElement(\"div\");\n\t\t\n\t\tel.classList.add(\"tabulator-col\");\n\t\tel.classList.add(\"tabulator-col-placeholder\");\n\t\t\n\t\treturn el;\n\t}\n\t\n\tinitialize(){\n\t\tif(this.table.options.movableColumns){\n\t\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t\t}\n\t}\n\t\n\tinitializeColumn(column){\n\t\tvar self = this,\n\t\tconfig = {},\n\t\tcolEl;\n\t\t\n\t\tif(!column.modules.frozen && !column.isGroup){\n\t\t\tcolEl = column.getElement();\n\t\t\t\n\t\t\tconfig.mousemove = function(e){\n\t\t\t\tif(column.parent === self.moving.parent){\n\t\t\t\t\tif((((self.touchMove ? e.touches[0].pageX : e.pageX) - Helpers.elOffset(colEl).left) + self.table.columnManager.contentsElement.scrollLeft) > (column.getWidth() / 2)){\n\t\t\t\t\t\tif(self.toCol !== column || !self.toColAfter){\n\t\t\t\t\t\t\tcolEl.parentNode.insertBefore(self.placeholderElement, colEl.nextSibling);\n\t\t\t\t\t\t\tself.moveColumn(column, true);\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tif(self.toCol !== column || self.toColAfter){\n\t\t\t\t\t\t\tcolEl.parentNode.insertBefore(self.placeholderElement, colEl);\n\t\t\t\t\t\t\tself.moveColumn(column, false);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}.bind(self);\n\t\t\t\n\t\t\tcolEl.addEventListener(\"mousedown\", function(e){\n\t\t\t\tself.touchMove = false;\n\t\t\t\tif(e.which === 1){\n\t\t\t\t\tself.checkTimeout = setTimeout(function(){\n\t\t\t\t\t\tself.startMove(e, column);\n\t\t\t\t\t}, self.checkPeriod);\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tcolEl.addEventListener(\"mouseup\", function(e){\n\t\t\t\tif(e.which === 1){\n\t\t\t\t\tif(self.checkTimeout){\n\t\t\t\t\t\tclearTimeout(self.checkTimeout);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tself.bindTouchEvents(column);\n\t\t}\n\t\t\n\t\tcolumn.modules.moveColumn = config;\n\t}\n\t\n\tbindTouchEvents(column){\n\t\tvar colEl = column.getElement(),\n\t\tstartXMove = false, //shifting center position of the cell\n\t\tnextCol, prevCol, nextColWidth, prevColWidth, nextColWidthLast, prevColWidthLast;\n\t\t\n\t\tcolEl.addEventListener(\"touchstart\", (e) => {\n\t\t\tthis.checkTimeout = setTimeout(() => {\n\t\t\t\tthis.touchMove = true;\n\t\t\t\tnextCol = column.nextColumn();\n\t\t\t\tnextColWidth = nextCol ? nextCol.getWidth()/2 : 0;\n\t\t\t\tprevCol = column.prevColumn();\n\t\t\t\tprevColWidth = prevCol ? prevCol.getWidth()/2 : 0;\n\t\t\t\tnextColWidthLast = 0;\n\t\t\t\tprevColWidthLast = 0;\n\t\t\t\tstartXMove = false;\n\t\t\t\t\n\t\t\t\tthis.startMove(e, column);\n\t\t\t}, this.checkPeriod);\n\t\t}, {passive: true});\n\t\t\n\t\tcolEl.addEventListener(\"touchmove\", (e) => {\n\t\t\tvar diff, moveToCol;\n\t\t\t\n\t\t\tif(this.moving){\n\t\t\t\tthis.moveHover(e);\n\t\t\t\t\n\t\t\t\tif(!startXMove){\n\t\t\t\t\tstartXMove = e.touches[0].pageX;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tdiff = e.touches[0].pageX - startXMove;\n\t\t\t\t\n\t\t\t\tif(diff > 0){\n\t\t\t\t\tif(nextCol && diff - nextColWidthLast > nextColWidth){\n\t\t\t\t\t\tmoveToCol = nextCol;\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(moveToCol !== column){\n\t\t\t\t\t\t\tstartXMove = e.touches[0].pageX;\n\t\t\t\t\t\t\tmoveToCol.getElement().parentNode.insertBefore(this.placeholderElement, moveToCol.getElement().nextSibling);\n\t\t\t\t\t\t\tthis.moveColumn(moveToCol, true);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tif(prevCol && -diff - prevColWidthLast > prevColWidth){\n\t\t\t\t\t\tmoveToCol = prevCol;\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(moveToCol !== column){\n\t\t\t\t\t\t\tstartXMove = e.touches[0].pageX;\n\t\t\t\t\t\t\tmoveToCol.getElement().parentNode.insertBefore(this.placeholderElement, moveToCol.getElement());\n\t\t\t\t\t\t\tthis.moveColumn(moveToCol, false);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(moveToCol){\n\t\t\t\t\tnextCol = moveToCol.nextColumn();\n\t\t\t\t\tnextColWidthLast = nextColWidth;\n\t\t\t\t\tnextColWidth = nextCol ? nextCol.getWidth() / 2 : 0;\n\t\t\t\t\tprevCol = moveToCol.prevColumn();\n\t\t\t\t\tprevColWidthLast = prevColWidth;\n\t\t\t\t\tprevColWidth = prevCol ? prevCol.getWidth() / 2 : 0;\n\t\t\t\t}\n\t\t\t}\n\t\t}, {passive: true});\n\t\t\n\t\tcolEl.addEventListener(\"touchend\", (e) => {\n\t\t\tif(this.checkTimeout){\n\t\t\t\tclearTimeout(this.checkTimeout);\n\t\t\t}\n\t\t\tif(this.moving){\n\t\t\t\tthis.endMove(e);\n\t\t\t}\n\t\t});\n\t}\n\t\n\tstartMove(e, column){\n\t\tvar element = column.getElement(),\n\t\theaderElement = this.table.columnManager.getContentsElement(),\n\t\theadersElement = this.table.columnManager.getHeadersElement();\n\t\t\n\t\tthis.moving = column;\n\t\tthis.startX = (this.touchMove ? e.touches[0].pageX : e.pageX) - Helpers.elOffset(element).left;\n\t\t\n\t\tthis.table.element.classList.add(\"tabulator-block-select\");\n\t\t\n\t\t//create placeholder\n\t\tthis.placeholderElement.style.width = column.getWidth() + \"px\";\n\t\tthis.placeholderElement.style.height = column.getHeight() + \"px\";\n\t\t\n\t\telement.parentNode.insertBefore(this.placeholderElement, element);\n\t\telement.parentNode.removeChild(element);\n\t\t\n\t\t//create hover element\n\t\tthis.hoverElement = element.cloneNode(true);\n\t\tthis.hoverElement.classList.add(\"tabulator-moving\");\n\t\t\n\t\theaderElement.appendChild(this.hoverElement);\n\t\t\n\t\tthis.hoverElement.style.left = \"0\";\n\t\tthis.hoverElement.style.bottom = (headerElement.clientHeight - headersElement.offsetHeight) + \"px\";\n\t\t\n\t\tif(!this.touchMove){\n\t\t\tthis._bindMouseMove();\n\t\t\t\n\t\t\tdocument.body.addEventListener(\"mousemove\", this.moveHover);\n\t\t\tdocument.body.addEventListener(\"mouseup\", this.endMove);\n\t\t}\n\t\t\n\t\tthis.moveHover(e);\n\t}\n\t\n\t_bindMouseMove(){\n\t\tthis.table.columnManager.columnsByIndex.forEach(function(column){\n\t\t\tif(column.modules.moveColumn.mousemove){\n\t\t\t\tcolumn.getElement().addEventListener(\"mousemove\", column.modules.moveColumn.mousemove);\n\t\t\t}\n\t\t});\n\t}\n\t\n\t_unbindMouseMove(){\n\t\tthis.table.columnManager.columnsByIndex.forEach(function(column){\n\t\t\tif(column.modules.moveColumn.mousemove){\n\t\t\t\tcolumn.getElement().removeEventListener(\"mousemove\", column.modules.moveColumn.mousemove);\n\t\t\t}\n\t\t});\n\t}\n\t\n\tmoveColumn(column, after){\n\t\tvar movingCells = this.moving.getCells();\n\t\t\n\t\tthis.toCol = column;\n\t\tthis.toColAfter = after;\n\t\t\n\t\tif(after){\n\t\t\tcolumn.getCells().forEach(function(cell, i){\n\t\t\t\tvar cellEl = cell.getElement(true);\n\t\t\t\t\n\t\t\t\tif(cellEl.parentNode && movingCells[i]){\n\t\t\t\t\tcellEl.parentNode.insertBefore(movingCells[i].getElement(), cellEl.nextSibling);\n\t\t\t\t}\n\t\t\t});\n\t\t}else{\n\t\t\tcolumn.getCells().forEach(function(cell, i){\n\t\t\t\tvar cellEl = cell.getElement(true);\n\t\t\t\t\n\t\t\t\tif(cellEl.parentNode && movingCells[i]){\n\t\t\t\t\tcellEl.parentNode.insertBefore(movingCells[i].getElement(), cellEl);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\t\n\tendMove(e){\n\t\tif(e.which === 1 || this.touchMove){\n\t\t\tthis._unbindMouseMove();\n\t\t\t\n\t\t\tthis.placeholderElement.parentNode.insertBefore(this.moving.getElement(), this.placeholderElement.nextSibling);\n\t\t\tthis.placeholderElement.parentNode.removeChild(this.placeholderElement);\n\t\t\tthis.hoverElement.parentNode.removeChild(this.hoverElement);\n\t\t\t\n\t\t\tthis.table.element.classList.remove(\"tabulator-block-select\");\n\t\t\t\n\t\t\tif(this.toCol){\n\t\t\t\tthis.table.columnManager.moveColumnActual(this.moving, this.toCol, this.toColAfter);\n\t\t\t}\n\t\t\t\n\t\t\tthis.moving = false;\n\t\t\tthis.toCol = false;\n\t\t\tthis.toColAfter = false;\n\t\t\t\n\t\t\tif(!this.touchMove){\n\t\t\t\tdocument.body.removeEventListener(\"mousemove\", this.moveHover);\n\t\t\t\tdocument.body.removeEventListener(\"mouseup\", this.endMove);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tmoveHover(e){\n\t\tvar columnHolder = this.table.columnManager.getContentsElement(),\n\t\tscrollLeft = columnHolder.scrollLeft,\n\t\txPos = ((this.touchMove ? e.touches[0].pageX : e.pageX) - Helpers.elOffset(columnHolder).left) + scrollLeft,\n\t\tscrollPos;\n\t\t\n\t\tthis.hoverElement.style.left = (xPos - this.startX) + \"px\";\n\t\t\n\t\tif(xPos - scrollLeft < this.autoScrollMargin){\n\t\t\tif(!this.autoScrollTimeout){\n\t\t\t\tthis.autoScrollTimeout = setTimeout(() => {\n\t\t\t\t\tscrollPos = Math.max(0,scrollLeft-5);\n\t\t\t\t\tthis.table.rowManager.getElement().scrollLeft = scrollPos;\n\t\t\t\t\tthis.autoScrollTimeout = false;\n\t\t\t\t}, 1);\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(scrollLeft + columnHolder.clientWidth - xPos < this.autoScrollMargin){\n\t\t\tif(!this.autoScrollTimeout){\n\t\t\t\tthis.autoScrollTimeout = setTimeout(() => {\n\t\t\t\t\tscrollPos = Math.min(columnHolder.clientWidth, scrollLeft+5);\n\t\t\t\t\tthis.table.rowManager.getElement().scrollLeft = scrollPos;\n\t\t\t\t\tthis.autoScrollTimeout = false;\n\t\t\t\t}, 1);\n\t\t\t}\n\t\t}\n\t}\n}\n\nMoveColumns.moduleName = \"moveColumn\";\n\nexport default MoveColumns;\n","import Module from '../../core/Module.js';\nimport Helpers from '../../core/tools/Helpers.js';\n\nclass MoveRows extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.placeholderElement = this.createPlaceholderElement();\n\t\tthis.hoverElement = false; //floating row header element\n\t\tthis.checkTimeout = false; //click check timeout holder\n\t\tthis.checkPeriod = 150; //period to wait on mousedown to consider this a move and not a click\n\t\tthis.moving = false; //currently moving row\n\t\tthis.toRow = false; //destination row\n\t\tthis.toRowAfter = false; //position of moving row relative to the destination row\n\t\tthis.hasHandle = false; //row has handle instead of fully movable row\n\t\tthis.startY = 0; //starting Y position within header element\n\t\tthis.startX = 0; //starting X position within header element\n\n\t\tthis.moveHover = this.moveHover.bind(this);\n\t\tthis.endMove = this.endMove.bind(this);\n\t\tthis.tableRowDropEvent = false;\n\n\t\tthis.touchMove = false;\n\n\t\tthis.connection = false;\n\t\tthis.connectionSelectorsTables = false;\n\t\tthis.connectionSelectorsElements = false;\n\t\tthis.connectionElements = [];\n\t\tthis.connections = [];\n\n\t\tthis.connectedTable = false;\n\t\tthis.connectedRow = false;\n\n\t\tthis.registerTableOption(\"movableRows\", false); //enable movable rows\n\t\tthis.registerTableOption(\"movableRowsConnectedTables\", false); //tables for movable rows to be connected to\n\t\tthis.registerTableOption(\"movableRowsConnectedElements\", false); //other elements for movable rows to be connected to\n\t\tthis.registerTableOption(\"movableRowsSender\", false);\n\t\tthis.registerTableOption(\"movableRowsReceiver\", \"insert\");\n\n\t\tthis.registerColumnOption(\"rowHandle\");\n\t}\n\n\tcreatePlaceholderElement(){\n\t\tvar el = document.createElement(\"div\");\n\n\t\tel.classList.add(\"tabulator-row\");\n\t\tel.classList.add(\"tabulator-row-placeholder\");\n\n\t\treturn el;\n\t}\n\n\tinitialize(){\n\t\tif(this.table.options.movableRows){\n\t\t\tthis.connectionSelectorsTables = this.table.options.movableRowsConnectedTables;\n\t\t\tthis.connectionSelectorsElements = this.table.options.movableRowsConnectedElements;\n\n\t\t\tthis.connection = this.connectionSelectorsTables || this.connectionSelectorsElements;\n\n\t\t\tthis.subscribe(\"cell-init\", this.initializeCell.bind(this));\n\t\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t\t\tthis.subscribe(\"row-init\", this.initializeRow.bind(this));\n\t\t}\n\t}\n\n\tinitializeGroupHeader(group){\n\t\tvar self = this,\n\t\tconfig = {};\n\n\t\t//inter table drag drop\n\t\tconfig.mouseup = function(e){\n\t\t\tself.tableRowDrop(e, group);\n\t\t}.bind(self);\n\n\t\t//same table drag drop\n\t\tconfig.mousemove = function(e){\n\t\t\tvar rowEl;\n\n\t\t\tif(((e.pageY - Helpers.elOffset(group.element).top) + self.table.rowManager.element.scrollTop) > (group.getHeight() / 2)){\n\t\t\t\tif(self.toRow !== group || !self.toRowAfter){\n\t\t\t\t\trowEl = group.getElement();\n\t\t\t\t\trowEl.parentNode.insertBefore(self.placeholderElement, rowEl.nextSibling);\n\t\t\t\t\tself.moveRow(group, true);\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(self.toRow !== group || self.toRowAfter){\n\t\t\t\t\trowEl = group.getElement();\n\t\t\t\t\tif(rowEl.previousSibling){\n\t\t\t\t\t\trowEl.parentNode.insertBefore(self.placeholderElement, rowEl);\n\t\t\t\t\t\tself.moveRow(group, false);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}.bind(self);\n\n\t\tgroup.modules.moveRow = config;\n\t}\n\n\tinitializeRow(row){\n\t\tvar self = this,\n\t\tconfig = {},\n\t\trowEl;\n\n\t\t//inter table drag drop\n\t\tconfig.mouseup = function(e){\n\t\t\tself.tableRowDrop(e, row);\n\t\t}.bind(self);\n\n\t\t//same table drag drop\n\t\tconfig.mousemove = function(e){\n\t\t\tvar rowEl = row.getElement();\n\n\t\t\tif(((e.pageY - Helpers.elOffset(rowEl).top) + self.table.rowManager.element.scrollTop) > (row.getHeight() / 2)){\n\t\t\t\tif(self.toRow !== row || !self.toRowAfter){\n\t\t\t\t\trowEl.parentNode.insertBefore(self.placeholderElement, rowEl.nextSibling);\n\t\t\t\t\tself.moveRow(row, true);\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(self.toRow !== row || self.toRowAfter){\n\t\t\t\t\trowEl.parentNode.insertBefore(self.placeholderElement, rowEl);\n\t\t\t\t\tself.moveRow(row, false);\n\t\t\t\t}\n\t\t\t}\n\t\t}.bind(self);\n\n\n\t\tif(!this.hasHandle){\n\n\t\t\trowEl = row.getElement();\n\n\t\t\trowEl.addEventListener(\"mousedown\", function(e){\n\t\t\t\tif(e.which === 1){\n\t\t\t\t\tself.checkTimeout = setTimeout(function(){\n\t\t\t\t\t\tself.startMove(e, row);\n\t\t\t\t\t}, self.checkPeriod);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\trowEl.addEventListener(\"mouseup\", function(e){\n\t\t\t\tif(e.which === 1){\n\t\t\t\t\tif(self.checkTimeout){\n\t\t\t\t\t\tclearTimeout(self.checkTimeout);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.bindTouchEvents(row, row.getElement());\n\t\t}\n\n\t\trow.modules.moveRow = config;\n\t}\n\n\tinitializeColumn(column){\n\t\tif(column.definition.rowHandle && this.table.options.movableRows !== false){\n\t\t\tthis.hasHandle = true;\n\t\t}\n\t}\n\n\tinitializeCell(cell){\n\t\tif(cell.column.definition.rowHandle && this.table.options.movableRows !== false){\n\t\t\tvar self = this,\n\t\t\tcellEl = cell.getElement(true);\n\n\t\t\tcellEl.addEventListener(\"mousedown\", function(e){\n\t\t\t\tif(e.which === 1){\n\t\t\t\t\tself.checkTimeout = setTimeout(function(){\n\t\t\t\t\t\tself.startMove(e, cell.row);\n\t\t\t\t\t}, self.checkPeriod);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tcellEl.addEventListener(\"mouseup\", function(e){\n\t\t\t\tif(e.which === 1){\n\t\t\t\t\tif(self.checkTimeout){\n\t\t\t\t\t\tclearTimeout(self.checkTimeout);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.bindTouchEvents(cell.row, cellEl);\n\t\t}\n\t}\n\n\tbindTouchEvents(row, element){\n\t\tvar startYMove = false, //shifting center position of the cell\n\t\tnextRow, prevRow, nextRowHeight, prevRowHeight, nextRowHeightLast, prevRowHeightLast;\n\n\t\telement.addEventListener(\"touchstart\", (e) => {\n\t\t\tthis.checkTimeout = setTimeout(() => {\n\t\t\t\tthis.touchMove = true;\n\t\t\t\tnextRow = row.nextRow();\n\t\t\t\tnextRowHeight = nextRow ? nextRow.getHeight()/2 : 0;\n\t\t\t\tprevRow = row.prevRow();\n\t\t\t\tprevRowHeight = prevRow ? prevRow.getHeight()/2 : 0;\n\t\t\t\tnextRowHeightLast = 0;\n\t\t\t\tprevRowHeightLast = 0;\n\t\t\t\tstartYMove = false;\n\n\t\t\t\tthis.startMove(e, row);\n\t\t\t}, this.checkPeriod);\n\t\t}, {passive: true});\n\t\tthis.moving, this.toRow, this.toRowAfter;\n\t\telement.addEventListener(\"touchmove\", (e) => {\n\n\t\t\tvar diff, moveToRow;\n\n\t\t\tif(this.moving){\n\t\t\t\te.preventDefault();\n\n\t\t\t\tthis.moveHover(e);\n\n\t\t\t\tif(!startYMove){\n\t\t\t\t\tstartYMove = e.touches[0].pageY;\n\t\t\t\t}\n\n\t\t\t\tdiff = e.touches[0].pageY - startYMove;\n\n\t\t\t\tif(diff > 0){\n\t\t\t\t\tif(nextRow && diff - nextRowHeightLast > nextRowHeight){\n\t\t\t\t\t\tmoveToRow = nextRow;\n\n\t\t\t\t\t\tif(moveToRow !== row){\n\t\t\t\t\t\t\tstartYMove = e.touches[0].pageY;\n\t\t\t\t\t\t\tmoveToRow.getElement().parentNode.insertBefore(this.placeholderElement, moveToRow.getElement().nextSibling);\n\t\t\t\t\t\t\tthis.moveRow(moveToRow, true);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tif(prevRow && -diff - prevRowHeightLast > prevRowHeight){\n\t\t\t\t\t\tmoveToRow = prevRow;\n\n\t\t\t\t\t\tif(moveToRow !== row){\n\t\t\t\t\t\t\tstartYMove = e.touches[0].pageY;\n\t\t\t\t\t\t\tmoveToRow.getElement().parentNode.insertBefore(this.placeholderElement, moveToRow.getElement());\n\t\t\t\t\t\t\tthis.moveRow(moveToRow, false);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif(moveToRow){\n\t\t\t\t\tnextRow = moveToRow.nextRow();\n\t\t\t\t\tnextRowHeightLast = nextRowHeight;\n\t\t\t\t\tnextRowHeight = nextRow ? nextRow.getHeight() / 2 : 0;\n\t\t\t\t\tprevRow = moveToRow.prevRow();\n\t\t\t\t\tprevRowHeightLast = prevRowHeight;\n\t\t\t\t\tprevRowHeight = prevRow ? prevRow.getHeight() / 2 : 0;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\telement.addEventListener(\"touchend\", (e) => {\n\t\t\tif(this.checkTimeout){\n\t\t\t\tclearTimeout(this.checkTimeout);\n\t\t\t}\n\t\t\tif(this.moving){\n\t\t\t\tthis.endMove(e);\n\t\t\t\tthis.touchMove = false;\n\t\t\t}\n\t\t});\n\t}\n\n\t_bindMouseMove(){\n\t\tthis.table.rowManager.getDisplayRows().forEach((row) => {\n\t\t\tif((row.type === \"row\" || row.type === \"group\") && row.modules.moveRow && row.modules.moveRow.mousemove){\n\t\t\t\trow.getElement().addEventListener(\"mousemove\", row.modules.moveRow.mousemove);\n\t\t\t}\n\t\t});\n\t}\n\n\t_unbindMouseMove(){\n\t\tthis.table.rowManager.getDisplayRows().forEach((row) => {\n\t\t\tif((row.type === \"row\" || row.type === \"group\") && row.modules.moveRow && row.modules.moveRow.mousemove){\n\t\t\t\trow.getElement().removeEventListener(\"mousemove\", row.modules.moveRow.mousemove);\n\t\t\t}\n\t\t});\n\t}\n\n\tstartMove(e, row){\n\t\tvar element = row.getElement();\n\n\t\tthis.setStartPosition(e, row);\n\n\t\tthis.moving = row;\n\n\t\tthis.table.element.classList.add(\"tabulator-block-select\");\n\n\t\t//create placeholder\n\t\tthis.placeholderElement.style.width = row.getWidth() + \"px\";\n\t\tthis.placeholderElement.style.height = row.getHeight() + \"px\";\n\n\t\tif(!this.connection){\n\t\t\telement.parentNode.insertBefore(this.placeholderElement, element);\n\t\t\telement.parentNode.removeChild(element);\n\t\t}else{\n\t\t\tthis.table.element.classList.add(\"tabulator-movingrow-sending\");\n\t\t\tthis.connectToTables(row);\n\t\t}\n\n\t\t//create hover element\n\t\tthis.hoverElement = element.cloneNode(true);\n\t\tthis.hoverElement.classList.add(\"tabulator-moving\");\n\n\t\tif(this.connection){\n\t\t\tdocument.body.appendChild(this.hoverElement);\n\t\t\tthis.hoverElement.style.left = \"0\";\n\t\t\tthis.hoverElement.style.top = \"0\";\n\t\t\tthis.hoverElement.style.width = this.table.element.clientWidth + \"px\";\n\t\t\tthis.hoverElement.style.whiteSpace = \"nowrap\";\n\t\t\tthis.hoverElement.style.overflow = \"hidden\";\n\t\t\tthis.hoverElement.style.pointerEvents = \"none\";\n\t\t}else{\n\t\t\tthis.table.rowManager.getTableElement().appendChild(this.hoverElement);\n\n\t\t\tthis.hoverElement.style.left = \"0\";\n\t\t\tthis.hoverElement.style.top = \"0\";\n\n\t\t\tthis._bindMouseMove();\n\t\t}\n\n\t\tdocument.body.addEventListener(\"mousemove\", this.moveHover);\n\t\tdocument.body.addEventListener(\"mouseup\", this.endMove);\n\n\t\tthis.dispatchExternal(\"rowMoving\", row.getComponent());\n\n\t\tthis.moveHover(e);\n\t}\n\n\tsetStartPosition(e, row){\n\t\tvar pageX = this.touchMove ? e.touches[0].pageX : e.pageX,\n\t\tpageY = this.touchMove ? e.touches[0].pageY : e.pageY,\n\t\telement, position;\n\n\t\telement = row.getElement();\n\t\tif(this.connection){\n\t\t\tposition = element.getBoundingClientRect();\n\n\t\t\tthis.startX = position.left - pageX + window.pageXOffset;\n\t\t\tthis.startY = position.top - pageY + window.pageYOffset;\n\t\t}else{\n\t\t\tthis.startY = (pageY - element.getBoundingClientRect().top);\n\t\t}\n\t}\n\n\tendMove(e){\n\t\tif(!e || e.which === 1 || this.touchMove){\n\t\t\tthis._unbindMouseMove();\n\n\t\t\tif(!this.connection){\n\t\t\t\tthis.placeholderElement.parentNode.insertBefore(this.moving.getElement(), this.placeholderElement.nextSibling);\n\t\t\t\tthis.placeholderElement.parentNode.removeChild(this.placeholderElement);\n\t\t\t}\n\n\t\t\tthis.hoverElement.parentNode.removeChild(this.hoverElement);\n\n\t\t\tthis.table.element.classList.remove(\"tabulator-block-select\");\n\n\t\t\tif(this.toRow){\n\t\t\t\tthis.table.rowManager.moveRow(this.moving, this.toRow, this.toRowAfter);\n\t\t\t}else{\n\t\t\t\tthis.dispatchExternal(\"rowMoveCancelled\", this.moving.getComponent());\n\t\t\t}\n\n\t\t\tthis.moving = false;\n\t\t\tthis.toRow = false;\n\t\t\tthis.toRowAfter = false;\n\n\t\t\tdocument.body.removeEventListener(\"mousemove\", this.moveHover);\n\t\t\tdocument.body.removeEventListener(\"mouseup\", this.endMove);\n\n\t\t\tif(this.connection){\n\t\t\t\tthis.table.element.classList.remove(\"tabulator-movingrow-sending\");\n\t\t\t\tthis.disconnectFromTables();\n\t\t\t}\n\t\t}\n\t}\n\n\tmoveRow(row, after){\n\t\tthis.toRow = row;\n\t\tthis.toRowAfter = after;\n\t}\n\n\tmoveHover(e){\n\t\tif(this.connection){\n\t\t\tthis.moveHoverConnections.call(this, e);\n\t\t}else{\n\t\t\tthis.moveHoverTable.call(this, e);\n\t\t}\n\t}\n\n\tmoveHoverTable(e){\n\t\tvar rowHolder = this.table.rowManager.getElement(),\n\t\tscrollTop = rowHolder.scrollTop,\n\t\tyPos = ((this.touchMove ? e.touches[0].pageY : e.pageY) - rowHolder.getBoundingClientRect().top) + scrollTop;\n\t\t\n\t\tthis.hoverElement.style.top = Math.min(yPos - this.startY, this.table.rowManager.element.scrollHeight - this.hoverElement.offsetHeight) + \"px\";\n\t}\n\n\tmoveHoverConnections(e){\n\t\tthis.hoverElement.style.left = (this.startX + (this.touchMove ? e.touches[0].pageX : e.pageX)) + \"px\";\n\t\tthis.hoverElement.style.top = (this.startY + (this.touchMove ? e.touches[0].pageY : e.pageY)) + \"px\";\n\t}\n\n\telementRowDrop(e, element, row){\n\t\tthis.dispatchExternal(\"movableRowsElementDrop\", e, element, row ? row.getComponent() : false);\n\t}\n\n\t//establish connection with other tables\n\tconnectToTables(row){\n\t\tvar connectionTables;\n\n\t\tif(this.connectionSelectorsTables){\n\t\t\tconnectionTables = this.commsConnections(this.connectionSelectorsTables);\n\n\t\t\tthis.dispatchExternal(\"movableRowsSendingStart\", connectionTables);\n\n\t\t\tthis.commsSend(this.connectionSelectorsTables, \"moveRow\", \"connect\", {\n\t\t\t\trow:row,\n\t\t\t});\n\t\t}\n\n\t\tif(this.connectionSelectorsElements){\n\n\t\t\tthis.connectionElements = [];\n\n\t\t\tif(!Array.isArray(this.connectionSelectorsElements)){\n\t\t\t\tthis.connectionSelectorsElements = [this.connectionSelectorsElements];\n\t\t\t}\n\n\t\t\tthis.connectionSelectorsElements.forEach((query) => {\n\t\t\t\tif(typeof query === \"string\"){\n\t\t\t\t\tthis.connectionElements = this.connectionElements.concat(Array.prototype.slice.call(document.querySelectorAll(query)));\n\t\t\t\t}else{\n\t\t\t\t\tthis.connectionElements.push(query);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.connectionElements.forEach((element) => {\n\t\t\t\tvar dropEvent = (e) => {\n\t\t\t\t\tthis.elementRowDrop(e, element, this.moving);\n\t\t\t\t};\n\n\t\t\t\telement.addEventListener(\"mouseup\", dropEvent);\n\t\t\t\telement.tabulatorElementDropEvent = dropEvent;\n\n\t\t\t\telement.classList.add(\"tabulator-movingrow-receiving\");\n\t\t\t});\n\t\t}\n\t}\n\n\t//disconnect from other tables\n\tdisconnectFromTables(){\n\t\tvar connectionTables;\n\n\t\tif(this.connectionSelectorsTables){\n\t\t\tconnectionTables = this.commsConnections(this.connectionSelectorsTables);\n\n\t\t\tthis.dispatchExternal(\"movableRowsSendingStop\", connectionTables);\n\n\t\t\tthis.commsSend(this.connectionSelectorsTables, \"moveRow\", \"disconnect\");\n\t\t}\n\n\t\tthis.connectionElements.forEach((element) => {\n\t\t\telement.classList.remove(\"tabulator-movingrow-receiving\");\n\t\t\telement.removeEventListener(\"mouseup\", element.tabulatorElementDropEvent);\n\t\t\tdelete element.tabulatorElementDropEvent;\n\t\t});\n\t}\n\n\t//accept incomming connection\n\tconnect(table, row){\n\t\tif(!this.connectedTable){\n\t\t\tthis.connectedTable = table;\n\t\t\tthis.connectedRow = row;\n\n\t\t\tthis.table.element.classList.add(\"tabulator-movingrow-receiving\");\n\n\t\t\tthis.table.rowManager.getDisplayRows().forEach((row) => {\n\t\t\t\tif(row.type === \"row\" && row.modules.moveRow && row.modules.moveRow.mouseup){\n\t\t\t\t\trow.getElement().addEventListener(\"mouseup\", row.modules.moveRow.mouseup);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.tableRowDropEvent = this.tableRowDrop.bind(this);\n\n\t\t\tthis.table.element.addEventListener(\"mouseup\", this.tableRowDropEvent);\n\n\t\t\tthis.dispatchExternal(\"movableRowsReceivingStart\", row, table);\n\n\t\t\treturn true;\n\t\t}else{\n\t\t\tconsole.warn(\"Move Row Error - Table cannot accept connection, already connected to table:\", this.connectedTable);\n\t\t\treturn false;\n\t\t}\n\t}\n\n\t//close incoming connection\n\tdisconnect(table){\n\t\tif(table === this.connectedTable){\n\t\t\tthis.connectedTable = false;\n\t\t\tthis.connectedRow = false;\n\n\t\t\tthis.table.element.classList.remove(\"tabulator-movingrow-receiving\");\n\n\t\t\tthis.table.rowManager.getDisplayRows().forEach((row) =>{\n\t\t\t\tif(row.type === \"row\" && row.modules.moveRow && row.modules.moveRow.mouseup){\n\t\t\t\t\trow.getElement().removeEventListener(\"mouseup\", row.modules.moveRow.mouseup);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.table.element.removeEventListener(\"mouseup\", this.tableRowDropEvent);\n\n\t\t\tthis.dispatchExternal(\"movableRowsReceivingStop\", table);\n\t\t}else{\n\t\t\tconsole.warn(\"Move Row Error - trying to disconnect from non connected table\");\n\t\t}\n\t}\n\n\tdropComplete(table, row, success){\n\t\tvar sender = false;\n\n\t\tif(success){\n\n\t\t\tswitch(typeof this.table.options.movableRowsSender){\n\t\t\t\tcase \"string\":\n\t\t\t\t\tsender = this.senders[this.table.options.movableRowsSender];\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"function\":\n\t\t\t\t\tsender = this.table.options.movableRowsSender;\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tif(sender){\n\t\t\t\tsender.call(this, this.moving ? this.moving.getComponent() : undefined, row ? row.getComponent() : undefined, table);\n\t\t\t}else{\n\t\t\t\tif(this.table.options.movableRowsSender){\n\t\t\t\t\tconsole.warn(\"Mover Row Error - no matching sender found:\", this.table.options.movableRowsSender);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tthis.dispatchExternal(\"movableRowsSent\", this.moving.getComponent(), row ? row.getComponent() : undefined, table);\n\t\t}else{\n\t\t\tthis.dispatchExternal(\"movableRowsSentFailed\", this.moving.getComponent(), row ? row.getComponent() : undefined, table);\n\t\t}\n\n\t\tthis.endMove();\n\t}\n\n\ttableRowDrop(e, row){\n\t\tvar receiver = false,\n\t\tsuccess = false;\n\n\t\te.stopImmediatePropagation();\n\n\t\tswitch(typeof this.table.options.movableRowsReceiver){\n\t\t\tcase \"string\":\n\t\t\t\treceiver = this.receivers[this.table.options.movableRowsReceiver];\n\t\t\t\tbreak;\n\n\t\t\tcase \"function\":\n\t\t\t\treceiver = this.table.options.movableRowsReceiver;\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif(receiver){\n\t\t\tsuccess = receiver.call(this, this.connectedRow.getComponent(), row ? row.getComponent() : undefined, this.connectedTable);\n\t\t}else{\n\t\t\tconsole.warn(\"Mover Row Error - no matching receiver found:\", this.table.options.movableRowsReceiver);\n\t\t}\n\n\t\tif(success){\n\t\t\tthis.dispatchExternal(\"movableRowsReceived\", this.connectedRow.getComponent(), row ? row.getComponent() : undefined, this.connectedTable);\n\t\t}else{\n\t\t\tthis.dispatchExternal(\"movableRowsReceivedFailed\", this.connectedRow.getComponent(), row ? row.getComponent() : undefined, this.connectedTable);\n\t\t}\n\n\t\tthis.commsSend(this.connectedTable, \"moveRow\", \"dropcomplete\", {\n\t\t\trow:row,\n\t\t\tsuccess:success,\n\t\t});\n\t}\n\n\tcommsReceived(table, action, data){\n\t\tswitch(action){\n\t\t\tcase \"connect\":\n\t\t\t\treturn this.connect(table, data.row);\n\n\t\t\tcase \"disconnect\":\n\t\t\t\treturn this.disconnect(table);\n\n\t\t\tcase \"dropcomplete\":\n\t\t\t\treturn this.dropComplete(table, data.row, data.success);\n\t\t}\n\t}\n}\n\nMoveRows.prototype.receivers = {\n\tinsert:function(fromRow, toRow, fromTable){\n\t\tthis.table.addRow(fromRow.getData(), undefined, toRow);\n\t\treturn true;\n\t},\n\n\tadd:function(fromRow, toRow, fromTable){\n\t\tthis.table.addRow(fromRow.getData());\n\t\treturn true;\n\t},\n\n\tupdate:function(fromRow, toRow, fromTable){\n\t\tif(toRow){\n\t\t\ttoRow.update(fromRow.getData());\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t},\n\n\treplace:function(fromRow, toRow, fromTable){\n\t\tif(toRow){\n\t\t\tthis.table.addRow(fromRow.getData(), undefined, toRow);\n\t\t\ttoRow.delete();\n\t\t\treturn true;\n\t\t}\n\n\t\treturn false;\n\t},\n};\n\nMoveRows.prototype.senders = {\n\tdelete:function(fromRow, toRow, toTable){\n\t\tfromRow.delete();\n\t}\n};\n\nMoveRows.moduleName = \"moveRow\";\n\nexport default MoveRows;","import Module from '../../core/Module.js';\n\nimport defaultMutators from './defaults/mutators.js';\n\nclass Mutator extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.allowedTypes = [\"\", \"data\", \"edit\", \"clipboard\"]; //list of mutation types\n\t\tthis.enabled = true;\n\n\t\tthis.registerColumnOption(\"mutator\");\n\t\tthis.registerColumnOption(\"mutatorParams\");\n\t\tthis.registerColumnOption(\"mutatorData\");\n\t\tthis.registerColumnOption(\"mutatorDataParams\");\n\t\tthis.registerColumnOption(\"mutatorEdit\");\n\t\tthis.registerColumnOption(\"mutatorEditParams\");\n\t\tthis.registerColumnOption(\"mutatorClipboard\");\n\t\tthis.registerColumnOption(\"mutatorClipboardParams\");\n\t\tthis.registerColumnOption(\"mutateLink\");\n\t}\n\n\tinitialize(){\n\t\tthis.subscribe(\"cell-value-changing\", this.transformCell.bind(this));\n\t\tthis.subscribe(\"cell-value-changed\", this.mutateLink.bind(this));\n\t\tthis.subscribe(\"column-layout\", this.initializeColumn.bind(this));\n\t\tthis.subscribe(\"row-data-init-before\", this.rowDataChanged.bind(this));\n\t\tthis.subscribe(\"row-data-changing\", this.rowDataChanged.bind(this));\n\t}\n\n\trowDataChanged(row, tempData, updatedData){\n\t\treturn this.transformRow(tempData, \"data\", updatedData);\n\t}\n\n\t//initialize column mutator\n\tinitializeColumn(column){\n\t\tvar match = false,\n\t\tconfig = {};\n\n\t\tthis.allowedTypes.forEach((type) => {\n\t\t\tvar key = \"mutator\" + (type.charAt(0).toUpperCase() + type.slice(1)),\n\t\t\tmutator;\n\n\t\t\tif(column.definition[key]){\n\t\t\t\tmutator = this.lookupMutator(column.definition[key]);\n\n\t\t\t\tif(mutator){\n\t\t\t\t\tmatch = true;\n\n\t\t\t\t\tconfig[key] = {\n\t\t\t\t\t\tmutator:mutator,\n\t\t\t\t\t\tparams: column.definition[key + \"Params\"] || {},\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tif(match){\n\t\t\tcolumn.modules.mutate = config;\n\t\t}\n\t}\n\n\tlookupMutator(value){\n\t\tvar mutator = false;\n\n\t\t//set column mutator\n\t\tswitch(typeof value){\n\t\t\tcase \"string\":\n\t\t\t\tif(Mutator.mutators[value]){\n\t\t\t\t\tmutator = Mutator.mutators[value];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Mutator Error - No such mutator found, ignoring: \", value);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase \"function\":\n\t\t\t\tmutator = value;\n\t\t\t\tbreak;\n\t\t}\n\n\t\treturn mutator;\n\t}\n\n\t//apply mutator to row\n\ttransformRow(data, type, updatedData){\n\t\tvar key = \"mutator\" + (type.charAt(0).toUpperCase() + type.slice(1)),\n\t\tvalue;\n\n\t\tif(this.enabled){\n\n\t\t\tthis.table.columnManager.traverse((column) => {\n\t\t\t\tvar mutator, params, component;\n\n\t\t\t\tif(column.modules.mutate){\n\t\t\t\t\tmutator = column.modules.mutate[key] || column.modules.mutate.mutator || false;\n\n\t\t\t\t\tif(mutator){\n\t\t\t\t\t\tvalue = column.getFieldValue(typeof updatedData !== \"undefined\" ? updatedData : data);\n\n\t\t\t\t\t\tif((type == \"data\" && !updatedData)|| typeof value !== \"undefined\"){\n\t\t\t\t\t\t\tcomponent = column.getComponent();\n\t\t\t\t\t\t\tparams = typeof mutator.params === \"function\" ? mutator.params(value, data, type, component) : mutator.params;\n\t\t\t\t\t\t\tcolumn.setFieldValue(data, mutator.mutator(value, data, type, params, component));\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn data;\n\t}\n\n\t//apply mutator to new cell value\n\ttransformCell(cell, value){\n\t\tif(cell.column.modules.mutate){\n\t\t\tvar mutator = cell.column.modules.mutate.mutatorEdit || cell.column.modules.mutate.mutator || false,\n\t\t\ttempData = {};\n\n\t\t\tif(mutator){\n\t\t\t\ttempData = Object.assign(tempData, cell.row.getData());\n\t\t\t\tcell.column.setFieldValue(tempData, value);\n\t\t\t\treturn mutator.mutator(value, tempData, \"edit\", mutator.params, cell.getComponent());\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t}\n\n\tmutateLink(cell){\n\t\tvar links = cell.column.definition.mutateLink;\n\n\t\tif(links){\n\t\t\tif(!Array.isArray(links)){\n\t\t\t\tlinks = [links];\n\t\t\t}\n\n\t\t\tlinks.forEach((link) => {\n\t\t\t\tvar linkCell = cell.row.getCell(link);\n\n\t\t\t\tif(linkCell){\n\t\t\t\t\tlinkCell.setValue(linkCell.getValue(), true, true);\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tenable(){\n\t\tthis.enabled = true;\n\t}\n\n\tdisable(){\n\t\tthis.enabled = false;\n\t}\n}\n\nMutator.moduleName = \"mutator\";\n\n//load defaults\nMutator.mutators = defaultMutators;\n\nexport default Mutator;","export default {};","import rows from './pageCounters/rows.js';\nimport pages from './pageCounters/pages.js';\n\n\nexport default {\n\trows:rows,\n\tpages:pages,\n};","export default function(pageSize, currentRow, currentPage, totalRows, totalPages){\n\tvar el = document.createElement(\"span\"),\n\tshowingEl = document.createElement(\"span\"),\n\tvalueEl = document.createElement(\"span\"),\n\tofEl = document.createElement(\"span\"),\n\ttotalEl = document.createElement(\"span\"),\n\trowsEl = document.createElement(\"span\");\n\n\tthis.table.modules.localize.langBind(\"pagination|counter|showing\", (value) => {\n\t\tshowingEl.innerHTML = value;\n\t});\n\n\tthis.table.modules.localize.langBind(\"pagination|counter|of\", (value) => {\n\t\tofEl.innerHTML = value;\n\t});\n\n\tthis.table.modules.localize.langBind(\"pagination|counter|rows\", (value) => {\n\t\trowsEl.innerHTML = value;\n\t});\n\n\tif(totalRows){\n\t\tvalueEl.innerHTML = \" \" + currentRow + \"-\" + Math.min((currentRow + pageSize - 1), totalRows) + \" \";\n\t\t\n\t\ttotalEl.innerHTML = \" \" + totalRows + \" \";\n\t\t\n\t\tel.appendChild(showingEl);\n\t\tel.appendChild(valueEl);\n\t\tel.appendChild(ofEl);\n\t\tel.appendChild(totalEl);\n\t\tel.appendChild(rowsEl);\n\t}else{\n\t\tvalueEl.innerHTML = \" 0 \";\n\n\t\tel.appendChild(showingEl);\n\t\tel.appendChild(valueEl);\n\t\tel.appendChild(rowsEl);\n\t}\n\t\n\treturn el;\n}","export default function(pageSize, currentRow, currentPage, totalRows, totalPages){\n\n\tvar el = document.createElement(\"span\"),\n\tshowingEl = document.createElement(\"span\"),\n\tvalueEl = document.createElement(\"span\"),\n\tofEl = document.createElement(\"span\"),\n\ttotalEl = document.createElement(\"span\"),\n\trowsEl = document.createElement(\"span\");\n\t\n\tthis.table.modules.localize.langBind(\"pagination|counter|showing\", (value) => {\n\t\tshowingEl.innerHTML = value;\n\t});\n\t\n\tvalueEl.innerHTML = \" \" + currentPage + \" \";\n\t\n\tthis.table.modules.localize.langBind(\"pagination|counter|of\", (value) => {\n\t\tofEl.innerHTML = value;\n\t});\n\t\n\ttotalEl.innerHTML = \" \" + totalPages + \" \";\n\t\n\tthis.table.modules.localize.langBind(\"pagination|counter|pages\", (value) => {\n\t\trowsEl.innerHTML = value;\n\t});\n\t\n\tel.appendChild(showingEl);\n\tel.appendChild(valueEl);\n\tel.appendChild(ofEl);\n\tel.appendChild(totalEl);\n\tel.appendChild(rowsEl);\n\t\n\treturn el;\n}","import Module from '../../core/Module.js';\n\nimport defaultPageCounters from './defaults/pageCounters.js';\n\nclass Page extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.mode = \"local\";\n\t\tthis.progressiveLoad = false;\n\t\t\n\t\tthis.element = null;\n\t\tthis.pageCounterElement = null;\n\t\tthis.pageCounter = null;\n\t\t\n\t\tthis.size = 0;\n\t\tthis.page = 1;\n\t\tthis.count = 5;\n\t\tthis.max = 1;\n\n\t\tthis.remoteRowCountEstimate = null;\n\t\t\n\t\tthis.initialLoad = true;\n\t\tthis.dataChanging = false; //flag to check if data is being changed by this module\n\t\t\n\t\tthis.pageSizes = [];\n\t\t\n\t\tthis.registerTableOption(\"pagination\", false); //set pagination type\n\t\tthis.registerTableOption(\"paginationMode\", \"local\"); //local or remote pagination\n\t\tthis.registerTableOption(\"paginationSize\", false); //set number of rows to a page\n\t\tthis.registerTableOption(\"paginationInitialPage\", 1); //initial page to show on load\n\t\tthis.registerTableOption(\"paginationCounter\", false); // set pagination counter\n\t\tthis.registerTableOption(\"paginationCounterElement\", false); // set pagination counter\n\t\tthis.registerTableOption(\"paginationButtonCount\", 5); // set count of page button\n\t\tthis.registerTableOption(\"paginationSizeSelector\", false); //add pagination size selector element\n\t\tthis.registerTableOption(\"paginationElement\", false); //element to hold pagination numbers\n\t\t// this.registerTableOption(\"paginationDataSent\", {}); //pagination data sent to the server\n\t\t// this.registerTableOption(\"paginationDataReceived\", {}); //pagination data received from the server\n\t\tthis.registerTableOption(\"paginationAddRow\", \"page\"); //add rows on table or page\n\t\t\n\t\tthis.registerTableOption(\"progressiveLoad\", false); //progressive loading\n\t\tthis.registerTableOption(\"progressiveLoadDelay\", 0); //delay between requests\n\t\tthis.registerTableOption(\"progressiveLoadScrollMargin\", 0); //margin before scroll begins\n\t\t\n\t\tthis.registerTableFunction(\"setMaxPage\", this.setMaxPage.bind(this));\n\t\tthis.registerTableFunction(\"setPage\", this.setPage.bind(this));\n\t\tthis.registerTableFunction(\"setPageToRow\", this.userSetPageToRow.bind(this));\n\t\tthis.registerTableFunction(\"setPageSize\", this.userSetPageSize.bind(this));\n\t\tthis.registerTableFunction(\"getPageSize\", this.getPageSize.bind(this));\n\t\tthis.registerTableFunction(\"previousPage\", this.previousPage.bind(this));\n\t\tthis.registerTableFunction(\"nextPage\", this.nextPage.bind(this));\n\t\tthis.registerTableFunction(\"getPage\", this.getPage.bind(this));\n\t\tthis.registerTableFunction(\"getPageMax\", this.getPageMax.bind(this));\n\t\t\n\t\t//register component functions\n\t\tthis.registerComponentFunction(\"row\", \"pageTo\", this.setPageToRow.bind(this));\n\t}\n\t\n\tinitialize(){\n\t\tif(this.table.options.pagination){\n\t\t\tthis.subscribe(\"row-deleted\", this.rowsUpdated.bind(this));\n\t\t\tthis.subscribe(\"row-added\", this.rowsUpdated.bind(this));\n\t\t\tthis.subscribe(\"data-processed\", this.initialLoadComplete.bind(this));\n\t\t\tthis.subscribe(\"table-built\", this.calculatePageSizes.bind(this));\n\t\t\tthis.subscribe(\"footer-redraw\", this.footerRedraw.bind(this));\n\n\t\t\tif(this.table.options.paginationAddRow == \"page\"){\n\t\t\t\tthis.subscribe(\"row-adding-position\", this.rowAddingPosition.bind(this));\n\t\t\t}\n\t\t\t\n\t\t\tif(this.table.options.paginationMode === \"remote\"){\n\t\t\t\tthis.subscribe(\"data-params\", this.remotePageParams.bind(this));\n\t\t\t\tthis.subscribe(\"data-loaded\", this._parseRemoteData.bind(this));\n\t\t\t}\n\t\t\t\n\t\t\tif(this.table.options.progressiveLoad){\n\t\t\t\tconsole.error(\"Progressive Load Error - Pagination and progressive load cannot be used at the same time\");\n\t\t\t}\n\t\t\t\n\t\t\tthis.registerDisplayHandler(this.restOnRenderBefore.bind(this), 40);\n\t\t\tthis.registerDisplayHandler(this.getRows.bind(this), 50);\n\t\t\t\n\t\t\tthis.createElements();\n\t\t\tthis.initializePageCounter();\n\t\t\tthis.initializePaginator();\n\t\t}else if(this.table.options.progressiveLoad){\n\t\t\tthis.subscribe(\"data-params\", this.remotePageParams.bind(this));\n\t\t\tthis.subscribe(\"data-loaded\", this._parseRemoteData.bind(this));\n\t\t\tthis.subscribe(\"table-built\", this.calculatePageSizes.bind(this));\n\t\t\tthis.subscribe(\"data-processed\", this.initialLoadComplete.bind(this));\n\t\t\t\n\t\t\tthis.initializeProgressive(this.table.options.progressiveLoad);\n\t\t\t\n\t\t\tif(this.table.options.progressiveLoad === \"scroll\"){\n\t\t\t\tthis.subscribe(\"scroll-vertical\", this.scrollVertical.bind(this));\n\t\t\t}\n\t\t}\n\t}\n\t\n\trowAddingPosition(row, top){\n\t\tvar rowManager = this.table.rowManager,\n\t\tdisplayRows = rowManager.getDisplayRows(),\n\t\tindex;\n\t\t\n\t\tif(top){\n\t\t\tif(displayRows.length){\n\t\t\t\tindex = displayRows[0];\n\t\t\t}else{\n\t\t\t\tif(rowManager.activeRows.length){\n\t\t\t\t\tindex = rowManager.activeRows[rowManager.activeRows.length-1];\n\t\t\t\t\ttop = false;\n\t\t\t\t}\n\t\t\t}\n\t\t}else{\n\t\t\tif(displayRows.length){\n\t\t\t\tindex = displayRows[displayRows.length - 1];\n\t\t\t\ttop = displayRows.length < this.size ? false : true;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn {index, top};\n\t}\n\t\n\tcalculatePageSizes(){\n\t\tvar testElRow, testElCell;\n\t\t\n\t\tif(this.table.options.paginationSize){\n\t\t\tthis.size = this.table.options.paginationSize;\n\t\t}else{\n\t\t\ttestElRow = document.createElement(\"div\");\n\t\t\ttestElRow.classList.add(\"tabulator-row\");\n\t\t\ttestElRow.style.visibility = \"hidden\";\n\t\t\t\n\t\t\ttestElCell = document.createElement(\"div\");\n\t\t\ttestElCell.classList.add(\"tabulator-cell\");\n\t\t\ttestElCell.innerHTML = \"Page Row Test\";\n\t\t\t\n\t\t\ttestElRow.appendChild(testElCell);\n\t\t\t\n\t\t\tthis.table.rowManager.getTableElement().appendChild(testElRow);\n\t\t\t\n\t\t\tthis.size = Math.floor(this.table.rowManager.getElement().clientHeight / testElRow.offsetHeight);\n\t\t\t\n\t\t\tthis.table.rowManager.getTableElement().removeChild(testElRow);\n\t\t}\n\n\t\tthis.dispatchExternal(\"pageSizeChanged\", this.size);\n\t\t\n\t\tthis.generatePageSizeSelectList();\n\t}\n\t\n\tinitialLoadComplete(){\n\t\tthis.initialLoad = false;\n\t}\n\t\n\tremotePageParams(data, config, silent, params){\n\t\tif(!this.initialLoad){\n\t\t\tif((this.progressiveLoad && !silent) || (!this.progressiveLoad && !this.dataChanging)){\n\t\t\t\tthis.reset(true);\n\t\t\t}\n\t\t}\n\t\t\n\t\t//configure request params\n\t\tparams.page = this.page;\n\t\t\n\t\t//set page size if defined\n\t\tif(this.size){\n\t\t\tparams.size = this.size;\n\t\t}\n\t\t\n\t\treturn params;\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\t\n\tuserSetPageToRow(row){\n\t\tif(this.table.options.pagination){\n\t\t\trow = this.rowManager.findRow(row);\n\t\t\t\n\t\t\tif(row){\n\t\t\t\treturn this.setPageToRow(row);\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn Promise.reject();\n\t}\n\t\n\tuserSetPageSize(size){\n\t\tif(this.table.options.pagination){\n\t\t\tthis.setPageSize(size);\n\t\t\treturn this.setPage(1);\n\t\t}else{\n\t\t\treturn false;\n\t\t}\n\t}\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\t\n\tscrollVertical(top, dir){\n\t\tvar element, diff, margin;\n\t\tif(!dir && !this.table.dataLoader.loading){\n\t\t\telement = this.table.rowManager.getElement();\n\t\t\tdiff = element.scrollHeight - element.clientHeight - top;\n\t\t\tmargin = this.table.options.progressiveLoadScrollMargin || (element.clientHeight * 2);\n\t\t\t\n\t\t\tif(diff < margin){\n\t\t\t\tthis.nextPage()\n\t\t\t\t\t.catch(() => {}); //consume the exception thrown when on the last page\n\t\t\t}\n\t\t}\n\t}\n\t\n\trestOnRenderBefore(rows, renderInPosition){\n\t\tif(!renderInPosition){\n\t\t\tif(this.mode === \"local\"){\n\t\t\t\tthis.reset();\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn rows;\n\t}\n\t\n\trowsUpdated(){\n\t\tthis.refreshData(true, \"all\");\n\t}\n\t\n\tcreateElements(){\n\t\tvar button;\n\t\t\n\t\tthis.element = document.createElement(\"span\");\n\t\tthis.element.classList.add(\"tabulator-paginator\");\n\t\t\n\t\tthis.pagesElement = document.createElement(\"span\");\n\t\tthis.pagesElement.classList.add(\"tabulator-pages\");\n\t\t\n\t\tbutton = document.createElement(\"button\");\n\t\tbutton.classList.add(\"tabulator-page\");\n\t\tbutton.setAttribute(\"type\", \"button\");\n\t\tbutton.setAttribute(\"role\", \"button\");\n\t\tbutton.setAttribute(\"aria-label\", \"\");\n\t\tbutton.setAttribute(\"title\", \"\");\n\t\t\n\t\tthis.firstBut = button.cloneNode(true);\n\t\tthis.firstBut.setAttribute(\"data-page\", \"first\");\n\t\t\n\t\tthis.prevBut = button.cloneNode(true);\n\t\tthis.prevBut.setAttribute(\"data-page\", \"prev\");\n\t\t\n\t\tthis.nextBut = button.cloneNode(true);\n\t\tthis.nextBut.setAttribute(\"data-page\", \"next\");\n\t\t\n\t\tthis.lastBut = button.cloneNode(true);\n\t\tthis.lastBut.setAttribute(\"data-page\", \"last\");\n\t\t\n\t\tif(this.table.options.paginationSizeSelector){\n\t\t\tthis.pageSizeSelect = document.createElement(\"select\");\n\t\t\tthis.pageSizeSelect.classList.add(\"tabulator-page-size\");\n\t\t}\n\t}\n\t\n\tgeneratePageSizeSelectList(){\n\t\tvar pageSizes = [];\n\t\t\n\t\tif(this.pageSizeSelect){\n\t\t\t\n\t\t\tif(Array.isArray(this.table.options.paginationSizeSelector)){\n\t\t\t\tpageSizes = this.table.options.paginationSizeSelector;\n\t\t\t\tthis.pageSizes = pageSizes;\n\t\t\t\t\n\t\t\t\tif(this.pageSizes.indexOf(this.size) == -1){\n\t\t\t\t\tpageSizes.unshift(this.size);\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\t\n\t\t\t\tif(this.pageSizes.indexOf(this.size) == -1){\n\t\t\t\t\tpageSizes = [];\n\t\t\t\t\t\n\t\t\t\t\tfor (let i = 1; i < 5; i++){\n\t\t\t\t\t\tpageSizes.push(this.size * i);\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tthis.pageSizes = pageSizes;\n\t\t\t\t}else{\n\t\t\t\t\tpageSizes = this.pageSizes;\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\twhile(this.pageSizeSelect.firstChild) this.pageSizeSelect.removeChild(this.pageSizeSelect.firstChild);\n\t\t\t\n\t\t\tpageSizes.forEach((item) => {\n\t\t\t\tvar itemEl = document.createElement(\"option\");\n\t\t\t\titemEl.value = item;\n\t\t\t\t\n\t\t\t\tif(item === true){\n\t\t\t\t\tthis.langBind(\"pagination|all\", function(value){\n\t\t\t\t\t\titemEl.innerHTML = value;\n\t\t\t\t\t});\n\t\t\t\t}else{\n\t\t\t\t\titemEl.innerHTML = item;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t\n\t\t\t\t\n\t\t\t\tthis.pageSizeSelect.appendChild(itemEl);\n\t\t\t});\n\t\t\t\n\t\t\tthis.pageSizeSelect.value = this.size;\n\t\t}\n\t}\n\t\n\tinitializePageCounter(){\n\t\tvar counter = this.table.options.paginationCounter,\n\t\tpageCounter = null;\n\t\t\n\t\tif(counter){\n\t\t\tif(typeof counter === \"function\"){\n\t\t\t\tpageCounter = counter;\n\t\t\t}else{\n\t\t\t\tpageCounter = Page.pageCounters[counter];\n\t\t\t}\n\t\t\t\n\t\t\tif(pageCounter){\n\t\t\t\tthis.pageCounter = pageCounter;\n\t\t\t\t\n\t\t\t\tthis.pageCounterElement = document.createElement(\"span\");\n\t\t\t\tthis.pageCounterElement.classList.add(\"tabulator-page-counter\");\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Pagination Error - No such page counter found: \", counter);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t//setup pagination\n\tinitializePaginator(hidden){\n\t\tvar pageSelectLabel, paginationCounterHolder;\n\t\t\n\t\tif(!hidden){\n\t\t\t//build pagination element\n\t\t\t\n\t\t\t//bind localizations\n\t\t\tthis.langBind(\"pagination|first\", (value) => {\n\t\t\t\tthis.firstBut.innerHTML = value;\n\t\t\t});\n\t\t\t\n\t\t\tthis.langBind(\"pagination|first_title\", (value) => {\n\t\t\t\tthis.firstBut.setAttribute(\"aria-label\", value);\n\t\t\t\tthis.firstBut.setAttribute(\"title\", value);\n\t\t\t});\n\t\t\t\n\t\t\tthis.langBind(\"pagination|prev\", (value) => {\n\t\t\t\tthis.prevBut.innerHTML = value;\n\t\t\t});\n\t\t\t\n\t\t\tthis.langBind(\"pagination|prev_title\", (value) => {\n\t\t\t\tthis.prevBut.setAttribute(\"aria-label\", value);\n\t\t\t\tthis.prevBut.setAttribute(\"title\", value);\n\t\t\t});\n\t\t\t\n\t\t\tthis.langBind(\"pagination|next\", (value) => {\n\t\t\t\tthis.nextBut.innerHTML = value;\n\t\t\t});\n\t\t\t\n\t\t\tthis.langBind(\"pagination|next_title\", (value) => {\n\t\t\t\tthis.nextBut.setAttribute(\"aria-label\", value);\n\t\t\t\tthis.nextBut.setAttribute(\"title\", value);\n\t\t\t});\n\t\t\t\n\t\t\tthis.langBind(\"pagination|last\", (value) => {\n\t\t\t\tthis.lastBut.innerHTML = value;\n\t\t\t});\n\t\t\t\n\t\t\tthis.langBind(\"pagination|last_title\", (value) => {\n\t\t\t\tthis.lastBut.setAttribute(\"aria-label\", value);\n\t\t\t\tthis.lastBut.setAttribute(\"title\", value);\n\t\t\t});\n\t\t\t\n\t\t\t//click bindings\n\t\t\tthis.firstBut.addEventListener(\"click\", () => {\n\t\t\t\tthis.setPage(1);\n\t\t\t});\n\t\t\t\n\t\t\tthis.prevBut.addEventListener(\"click\", () => {\n\t\t\t\tthis.previousPage();\n\t\t\t});\n\t\t\t\n\t\t\tthis.nextBut.addEventListener(\"click\", () => {\n\t\t\t\tthis.nextPage();\n\t\t\t});\n\t\t\t\n\t\t\tthis.lastBut.addEventListener(\"click\", () => {\n\t\t\t\tthis.setPage(this.max);\n\t\t\t});\n\t\t\t\n\t\t\tif(this.table.options.paginationElement){\n\t\t\t\tthis.element = this.table.options.paginationElement;\n\t\t\t}\n\t\t\t\n\t\t\tif(this.pageSizeSelect){\n\t\t\t\tpageSelectLabel = document.createElement(\"label\");\n\t\t\t\t\n\t\t\t\tthis.langBind(\"pagination|page_size\", (value) => {\n\t\t\t\t\tthis.pageSizeSelect.setAttribute(\"aria-label\", value);\n\t\t\t\t\tthis.pageSizeSelect.setAttribute(\"title\", value);\n\t\t\t\t\tpageSelectLabel.innerHTML = value;\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tthis.element.appendChild(pageSelectLabel);\n\t\t\t\tthis.element.appendChild(this.pageSizeSelect);\n\t\t\t\t\n\t\t\t\tthis.pageSizeSelect.addEventListener(\"change\", (e) => {\n\t\t\t\t\tthis.setPageSize(this.pageSizeSelect.value == \"true\" ? true : this.pageSizeSelect.value);\n\t\t\t\t\tthis.setPage(1);\n\t\t\t\t});\n\t\t\t}\n\t\t\t\n\t\t\t//append to DOM\n\t\t\tthis.element.appendChild(this.firstBut);\n\t\t\tthis.element.appendChild(this.prevBut);\n\t\t\tthis.element.appendChild(this.pagesElement);\n\t\t\tthis.element.appendChild(this.nextBut);\n\t\t\tthis.element.appendChild(this.lastBut);\n\t\t\t\n\t\t\tif(!this.table.options.paginationElement){\n\t\t\t\tif(this.table.options.paginationCounter){\n\n\t\t\t\t\tpaginationCounterHolder; \n\n\t\t\t\t\tif(this.table.options.paginationCounterElement){\n\t\t\t\t\t\tif(this.table.options.paginationCounterElement instanceof HTMLElement){\n\t\t\t\t\t\t\tthis.table.options.paginationCounterElement.appendChild(this.pageCounterElement);\n\t\t\t\t\t\t}else if(typeof this.table.options.paginationCounterElement === \"string\"){\n\t\t\t\t\t\t\tpaginationCounterHolder = document.querySelector(this.table.options.paginationCounterElement);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tif(paginationCounterHolder){\n\t\t\t\t\t\t\t\tpaginationCounterHolder.appendChild(this.pageCounterElement);\n\t\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t\tconsole.warn(\"Pagination Error - Unable to find element matching paginationCounterElement selector:\", this.table.options.paginationCounterElement);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.footerAppend(this.pageCounterElement);\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.footerAppend(this.element);\n\t\t\t}\n\t\t\t\n\t\t\tthis.page = this.table.options.paginationInitialPage;\n\t\t\tthis.count = this.table.options.paginationButtonCount;\n\t\t}\n\t\t\n\t\t//set default values\n\t\tthis.mode = this.table.options.paginationMode;\n\t}\n\t\n\tinitializeProgressive(mode){\n\t\tthis.initializePaginator(true);\n\t\tthis.mode = \"progressive_\" + mode;\n\t\tthis.progressiveLoad = true;\n\t}\n\t\n\ttrackChanges(){\n\t\tthis.dispatch(\"page-changed\");\n\t}\n\t\n\t//calculate maximum page from number of rows\n\tsetMaxRows(rowCount){\n\t\tif(!rowCount){\n\t\t\tthis.max = 1;\n\t\t}else{\n\t\t\tthis.max = this.size === true ? 1 : Math.ceil(rowCount/this.size);\n\t\t}\n\t\t\n\t\tif(this.page > this.max){\n\t\t\tthis.page = this.max;\n\t\t}\n\t}\n\t\n\t//reset to first page without triggering action\n\treset(force){\n\t\tif(!this.initialLoad){\n\t\t\tif(this.mode == \"local\" || force){\n\t\t\t\tthis.page = 1;\n\t\t\t\tthis.trackChanges();\n\t\t\t}\n\t\t}\n\t}\n\t\n\t//set the maximum page\n\tsetMaxPage(max){\n\t\t\n\t\tmax = parseInt(max);\n\t\t\n\t\tthis.max = max || 1;\n\t\t\n\t\tif(this.page > this.max){\n\t\t\tthis.page = this.max;\n\t\t\tthis.trigger();\n\t\t}\n\t}\n\t\n\t//set current page number\n\tsetPage(page){\n\t\tswitch(page){\n\t\t\tcase \"first\":\n\t\t\t\treturn this.setPage(1);\n\t\n\t\t\tcase \"prev\":\n\t\t\t\treturn this.previousPage();\n\t\t\t\n\t\t\tcase \"next\":\n\t\t\t\treturn this.nextPage();\n\t\t\t\n\t\t\tcase \"last\":\n\t\t\t\treturn this.setPage(this.max);\n\t\t}\n\t\t\n\t\tpage = parseInt(page);\n\t\t\n\t\tif((page > 0 && page <= this.max) || this.mode !== \"local\"){\n\t\t\tthis.page = page;\n\t\t\t\n\t\t\tthis.trackChanges();\n\t\t\t\n\t\t\treturn this.trigger();\n\t\t}else{\n\t\t\tconsole.warn(\"Pagination Error - Requested page is out of range of 1 - \" + this.max + \":\", page);\n\t\t\treturn Promise.reject();\n\t\t}\n\t}\n\t\n\tsetPageToRow(row){\n\t\tvar rows = this.displayRows(-1);\n\t\tvar index = rows.indexOf(row);\n\t\n\t\tif(index > -1){\n\t\t\tvar page = this.size === true ? 1 : Math.ceil((index + 1) / this.size);\n\t\t\t\n\t\t\treturn this.setPage(page);\n\t\t}else{\n\t\t\tconsole.warn(\"Pagination Error - Requested row is not visible\");\n\t\t\treturn Promise.reject();\n\t\t}\n\t}\n\t\n\tsetPageSize(size){\n\t\tif(size !== true){\n\t\t\tsize = parseInt(size);\n\t\t}\n\n\t\tif(size > 0){\n\t\t\tthis.size = size;\n\t\t\tthis.dispatchExternal(\"pageSizeChanged\", size);\n\t\t}\n\t\t\n\t\tif(this.pageSizeSelect){\n\t\t\t// this.pageSizeSelect.value = size;\n\t\t\tthis.generatePageSizeSelectList();\n\t\t}\n\t\t\n\t\tthis.trackChanges();\n\t}\n\t\n\t_setPageCounter(totalRows, size, currentRow){\n\t\tvar content;\n\t\t\n\t\tif(this.pageCounter){\n\n\t\t\tif(this.mode === \"remote\"){\n\t\t\t\tsize = this.size;\n\t\t\t\tcurrentRow = ((this.page - 1) * this.size) + 1;\n\t\t\t\ttotalRows = this.remoteRowCountEstimate;\n\t\t\t}\n\n\t\t\tcontent = this.pageCounter.call(this, size, currentRow, this.page, totalRows, this.max);\n\t\t\t\n\t\t\tswitch(typeof content){\n\t\t\t\tcase \"object\":\n\t\t\t\t\tif(content instanceof Node){\n\t\t\t\t\t\n\t\t\t\t\t\t//clear previous cell contents\n\t\t\t\t\t\twhile(this.pageCounterElement.firstChild) this.pageCounterElement.removeChild(this.pageCounterElement.firstChild);\n\t\t\t\t\t\n\t\t\t\t\t\tthis.pageCounterElement.appendChild(content);\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.pageCounterElement.innerHTML = \"\";\n\t\t\t\t\t\n\t\t\t\t\t\tif(content != null){\n\t\t\t\t\t\t\tconsole.warn(\"Page Counter Error - Page Counter has returned a type of object, the only valid page counter object return is an instance of Node, the page counter returned:\", content);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"undefined\":\n\t\t\t\t\tthis.pageCounterElement.innerHTML = \"\";\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tthis.pageCounterElement.innerHTML = content;\n\t\t\t}\n\t\t}\n\t}\n\t\n\t//setup the pagination buttons\n\t_setPageButtons(){\n\t\tlet leftSize = Math.floor((this.count-1) / 2);\n\t\tlet rightSize = Math.ceil((this.count-1) / 2);\n\t\tlet min = this.max - this.page + leftSize + 1 < this.count ? this.max-this.count+1: Math.max(this.page-leftSize,1);\n\t\tlet max = this.page <= rightSize? Math.min(this.count, this.max) :Math.min(this.page+rightSize, this.max);\n\t\t\n\t\twhile(this.pagesElement.firstChild) this.pagesElement.removeChild(this.pagesElement.firstChild);\n\t\t\n\t\tif(this.page == 1){\n\t\t\tthis.firstBut.disabled = true;\n\t\t\tthis.prevBut.disabled = true;\n\t\t}else{\n\t\t\tthis.firstBut.disabled = false;\n\t\t\tthis.prevBut.disabled = false;\n\t\t}\n\t\t\n\t\tif(this.page == this.max){\n\t\t\tthis.lastBut.disabled = true;\n\t\t\tthis.nextBut.disabled = true;\n\t\t}else{\n\t\t\tthis.lastBut.disabled = false;\n\t\t\tthis.nextBut.disabled = false;\n\t\t}\n\t\t\n\t\tfor(let i = min; i <= max; i++){\n\t\t\tif(i>0 && i <= this.max){\n\t\t\t\tthis.pagesElement.appendChild(this._generatePageButton(i));\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.footerRedraw();\n\t}\n\t\n\t_generatePageButton(page){\n\t\tvar button = document.createElement(\"button\");\n\t\t\n\t\tbutton.classList.add(\"tabulator-page\");\n\t\tif(page == this.page){\n\t\t\tbutton.classList.add(\"active\");\n\t\t}\n\t\t\n\t\tbutton.setAttribute(\"type\", \"button\");\n\t\tbutton.setAttribute(\"role\", \"button\");\n\t\t\n\t\tthis.langBind(\"pagination|page_title\", (value) => {\n\t\t\tbutton.setAttribute(\"aria-label\", value + \" \" + page);\n\t\t\tbutton.setAttribute(\"title\", value + \" \" + page);\n\t\t});\n\t\t\n\t\tbutton.setAttribute(\"data-page\", page);\n\t\tbutton.textContent = page;\n\t\t\n\t\tbutton.addEventListener(\"click\", (e) => {\n\t\t\tthis.setPage(page);\n\t\t});\n\t\t\n\t\treturn button;\n\t}\n\t\n\t//previous page\n\tpreviousPage(){\n\t\tif(this.page > 1){\n\t\t\tthis.page--;\n\t\t\t\n\t\t\tthis.trackChanges();\n\t\t\t\n\t\t\treturn this.trigger();\n\t\t\t\n\t\t}else{\n\t\t\tconsole.warn(\"Pagination Error - Previous page would be less than page 1:\", 0);\n\t\t\treturn Promise.reject();\n\t\t}\n\t}\n\t\n\t//next page\n\tnextPage(){\n\t\tif(this.page < this.max){\n\t\t\tthis.page++;\n\t\t\t\n\t\t\tthis.trackChanges();\n\t\t\t\n\t\t\treturn this.trigger();\n\t\t\t\n\t\t}else{\n\t\t\tif(!this.progressiveLoad){\n\t\t\t\tconsole.warn(\"Pagination Error - Next page would be greater than maximum page of \" + this.max + \":\", this.max + 1);\n\t\t\t}\n\t\t\treturn Promise.reject();\n\t\t}\n\t}\n\t\n\t//return current page number\n\tgetPage(){\n\t\treturn this.page;\n\t}\n\t\n\t//return max page number\n\tgetPageMax(){\n\t\treturn this.max;\n\t}\n\t\n\tgetPageSize(size){\n\t\treturn this.size;\n\t}\n\t\n\tgetMode(){\n\t\treturn this.mode;\n\t}\n\t\n\t//return appropriate rows for current page\n\tgetRows(data){\n\t\tvar actualRowPageSize = 0,\n\t\toutput, start, end, actualStartRow;\n\n\t\tvar actualRows = data.filter((row) => {\n\t\t\treturn row.type === \"row\";\n\t\t});\n\t\t\n\t\tif(this.mode == \"local\"){\n\t\t\toutput = [];\n\t\t\t\n\t\t\tthis.setMaxRows(data.length);\n\t\t\t\n\t\t\tif(this.size === true){\n\t\t\t\tstart = 0;\n\t\t\t\tend = data.length;\n\t\t\t}else{\n\t\t\t\tstart = this.size * (this.page - 1);\n\t\t\t\tend = start + parseInt(this.size);\n\t\t\t}\n\t\t\t\n\t\t\tthis._setPageButtons();\n\t\t\t\n\t\t\tfor(let i = start; i < end; i++){\n\t\t\t\tlet row = data[i];\n\n\t\t\t\tif(row){\n\t\t\t\t\toutput.push(row);\n\n\t\t\t\t\tif(row.type === \"row\"){\n\t\t\t\t\t\tif(!actualStartRow){\n\t\t\t\t\t\t\tactualStartRow = row;\n\t\t\t\t\t\t}\t\n\n\t\t\t\t\t\tactualRowPageSize++;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tthis._setPageCounter(actualRows.length, actualRowPageSize, actualStartRow ? (actualRows.indexOf(actualStartRow) + 1) : 0);\n\t\t\t\n\t\t\treturn output;\n\t\t}else{\n\t\t\tthis._setPageButtons();\n\t\t\tthis._setPageCounter(actualRows.length);\n\t\t\t\n\t\t\treturn data.slice(0);\n\t\t}\n\t}\n\t\n\ttrigger(){\n\t\tvar left;\n\t\t\n\t\tswitch(this.mode){\n\t\t\tcase \"local\":\n\t\t\t\tleft = this.table.rowManager.scrollLeft;\n\t\t\t\n\t\t\t\tthis.refreshData();\n\t\t\t\tthis.table.rowManager.scrollHorizontal(left);\n\t\t\t\n\t\t\t\tthis.dispatchExternal(\"pageLoaded\", this.getPage());\n\t\t\t\n\t\t\t\treturn Promise.resolve();\n\t\t\t\n\t\t\tcase \"remote\":\n\t\t\t\tthis.dataChanging = true;\n\t\t\t\treturn this.reloadData(null)\n\t\t\t\t\t.finally(() => {\n\t\t\t\t\t\tthis.dataChanging = false;\n\t\t\t\t\t});\n\t\t\t\n\t\t\tcase \"progressive_load\":\n\t\t\tcase \"progressive_scroll\":\n\t\t\t\treturn this.reloadData(null, true);\n\t\t\t\n\t\t\tdefault:\n\t\t\t\tconsole.warn(\"Pagination Error - no such pagination mode:\", this.mode);\n\t\t\t\treturn Promise.reject();\n\t\t}\n\t}\n\t\n\t_parseRemoteData(data){\n\t\tvar margin;\n\t\t\n\t\tif(typeof data.last_page === \"undefined\"){\n\t\t\tconsole.warn(\"Remote Pagination Error - Server response missing '\" + (this.options(\"dataReceiveParams\").last_page || \"last_page\") + \"' property\");\n\t\t}\n\t\t\n\t\tif(data.data){\n\t\t\tthis.max = parseInt(data.last_page) || 1;\n\n\t\t\tthis.remoteRowCountEstimate = typeof data.last_row !== \"undefined\" ? data.last_row : (data.last_page * this.size - (this.page == data.last_page ? (this.size - data.data.length) : 0));\n\t\t\t\n\t\t\tif(this.progressiveLoad){\n\t\t\t\tswitch(this.mode){\n\t\t\t\t\tcase \"progressive_load\":\n\t\t\t\t\t\n\t\t\t\t\t\tif(this.page == 1){\n\t\t\t\t\t\t\tthis.table.rowManager.setData(data.data, false, this.page == 1);\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tthis.table.rowManager.addRows(data.data);\n\t\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\t\tif(this.page < this.max){\n\t\t\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\t\t\tthis.nextPage();\n\t\t\t\t\t\t\t}, this.table.options.progressiveLoadDelay);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tcase \"progressive_scroll\":\n\t\t\t\t\t\tdata = this.page === 1 ? data.data : this.table.rowManager.getData().concat(data.data);\n\t\t\t\t\t\n\t\t\t\t\t\tthis.table.rowManager.setData(data, this.page !== 1, this.page == 1);\n\t\t\t\t\t\n\t\t\t\t\t\tmargin = this.table.options.progressiveLoadScrollMargin || (this.table.rowManager.element.clientHeight * 2);\n\t\t\t\t\t\n\t\t\t\t\t\tif(this.table.rowManager.element.scrollHeight <= (this.table.rowManager.element.clientHeight + margin)){\n\t\t\t\t\t\t\tif(this.page < this.max){\n\t\t\t\t\t\t\t\tsetTimeout(() => {\n\t\t\t\t\t\t\t\t\tthis.nextPage();\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn false;\n\t\t\t}else{\n\t\t\t\t// left = this.table.rowManager.scrollLeft;\n\t\t\t\tthis.dispatchExternal(\"pageLoaded\", this.getPage());\n\t\t\t\t// this.table.rowManager.scrollHorizontal(left);\n\t\t\t\t// this.table.columnManager.scrollHorizontal(left);\n\t\t\t}\n\t\t\t\n\t\t}else{\n\t\t\tconsole.warn(\"Remote Pagination Error - Server response missing '\" + (this.options(\"dataReceiveParams\").data || \"data\") + \"' property\");\n\t\t}\n\t\t\n\t\treturn data.data;\n\t}\n\t\n\t//handle the footer element being redrawn\n\tfooterRedraw(){\n\t\tvar footer = this.table.footerManager.containerElement;\n\n\t\tif((Math.ceil(footer.clientWidth) - footer.scrollWidth) < 0){\n\t\t\tthis.pagesElement.style.display = 'none';\n\t\t}else{\n\t\t\tthis.pagesElement.style.display = '';\n\t\t\t\n\t\t\tif((Math.ceil(footer.clientWidth) - footer.scrollWidth) < 0){\n\t\t\t\tthis.pagesElement.style.display = 'none';\n\t\t\t}\n\t\t}\n\t}\n}\n\nPage.moduleName = \"page\";\n\n//load defaults\nPage.pageCounters = defaultPageCounters;\n\nexport default Page;\n","// read persistance information from storage\nexport default {\n\tlocal:function(id, type){\n\t\tvar data = localStorage.getItem(id + \"-\" + type);\n\n\t\treturn data ? JSON.parse(data) : false;\n\t},\n\tcookie:function(id, type){\n\t\tvar cookie = document.cookie,\n\t\tkey = id + \"-\" + type,\n\t\tcookiePos = cookie.indexOf(key + \"=\"),\n\t\tend, data;\n\n\t\t//if cookie exists, decode and load column data into tabulator\n\t\tif(cookiePos > -1){\n\t\t\tcookie = cookie.slice(cookiePos);\n\n\t\t\tend = cookie.indexOf(\";\");\n\n\t\t\tif(end > -1){\n\t\t\t\tcookie = cookie.slice(0, end);\n\t\t\t}\n\n\t\t\tdata = cookie.replace(key + \"=\", \"\");\n\t\t}\n\n\t\treturn data ? JSON.parse(data) : false;\n\t}\n};\n","//write persistence information to storage\nexport default {\n\tlocal:function(id, type, data){\n\t\tlocalStorage.setItem(id + \"-\" + type, JSON.stringify(data));\n\t},\n\tcookie:function(id, type, data){\n\t\tvar expireDate = new Date();\n\n\t\texpireDate.setDate(expireDate.getDate() + 10000);\n\n\t\tdocument.cookie = id + \"-\" + type + \"=\" + JSON.stringify(data) + \"; expires=\" + expireDate.toUTCString();\n\t}\n};","import Module from '../../core/Module.js';\n\nimport defaultReaders from './defaults/readers.js';\nimport defaultWriters from './defaults/writers.js';\n\nclass Persistence extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.mode = \"\";\n\t\tthis.id = \"\";\n\t\t// this.persistProps = [\"field\", \"width\", \"visible\"];\n\t\tthis.defWatcherBlock = false;\n\t\tthis.config = {};\n\t\tthis.readFunc = false;\n\t\tthis.writeFunc = false;\n\n\t\tthis.registerTableOption(\"persistence\", false);\n\t\tthis.registerTableOption(\"persistenceID\", \"\"); //key for persistent storage\n\t\tthis.registerTableOption(\"persistenceMode\", true); //mode for storing persistence information\n\t\tthis.registerTableOption(\"persistenceReaderFunc\", false); //function for handling persistence data reading\n\t\tthis.registerTableOption(\"persistenceWriterFunc\", false); //function for handling persistence data writing\n\t}\n\n\t// Test for whether localStorage is available for use.\n\tlocalStorageTest() {\n\t\tvar testKey = \"_tabulator_test\";\n\n\t\ttry {\n\t\t\twindow.localStorage.setItem( testKey, testKey);\n\t\t\twindow.localStorage.removeItem( testKey );\n\t\t\treturn true;\n\t\t} catch(e) {\n\t\t\treturn false;\n\t\t}\n\t}\n\n\t//setup parameters\n\tinitialize(){\n\t\tif(this.table.options.persistence){\n\t\t\t//determine persistent layout storage type\n\t\t\tvar mode = this.table.options.persistenceMode,\n\t\t\tid = this.table.options.persistenceID,\n\t\t\tretrievedData;\n\n\t\t\tthis.mode = mode !== true ? mode : (this.localStorageTest() ? \"local\" : \"cookie\");\n\n\t\t\tif(this.table.options.persistenceReaderFunc){\n\t\t\t\tif(typeof this.table.options.persistenceReaderFunc === \"function\"){\n\t\t\t\t\tthis.readFunc = this.table.options.persistenceReaderFunc;\n\t\t\t\t}else{\n\t\t\t\t\tif(Persistence.readers[this.table.options.persistenceReaderFunc]){\n\t\t\t\t\t\tthis.readFunc = Persistence.readers[this.table.options.persistenceReaderFunc];\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Persistence Read Error - invalid reader set\", this.table.options.persistenceReaderFunc);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(Persistence.readers[this.mode]){\n\t\t\t\t\tthis.readFunc = Persistence.readers[this.mode];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Persistence Read Error - invalid reader set\", this.mode);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif(this.table.options.persistenceWriterFunc){\n\t\t\t\tif(typeof this.table.options.persistenceWriterFunc === \"function\"){\n\t\t\t\t\tthis.writeFunc = this.table.options.persistenceWriterFunc;\n\t\t\t\t}else{\n\t\t\t\t\tif(Persistence.writers[this.table.options.persistenceWriterFunc]){\n\t\t\t\t\t\tthis.writeFunc = Persistence.writers[this.table.options.persistenceWriterFunc];\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Persistence Write Error - invalid reader set\", this.table.options.persistenceWriterFunc);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(Persistence.writers[this.mode]){\n\t\t\t\t\tthis.writeFunc = Persistence.writers[this.mode];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Persistence Write Error - invalid writer set\", this.mode);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//set storage tag\n\t\t\tthis.id = \"tabulator-\" + (id || (this.table.element.getAttribute(\"id\") || \"\"));\n\n\t\t\tthis.config = {\n\t\t\t\tsort:this.table.options.persistence === true || this.table.options.persistence.sort,\n\t\t\t\tfilter:this.table.options.persistence === true || this.table.options.persistence.filter,\n\t\t\t\theaderFilter:this.table.options.persistence === true || this.table.options.persistence.headerFilter,\n\t\t\t\tgroup:this.table.options.persistence === true || this.table.options.persistence.group,\n\t\t\t\tpage:this.table.options.persistence === true || this.table.options.persistence.page,\n\t\t\t\tcolumns:this.table.options.persistence === true ? [\"title\", \"width\", \"visible\"] : this.table.options.persistence.columns,\n\t\t\t};\n\n\t\t\t//load pagination data if needed\n\t\t\tif(this.config.page){\n\t\t\t\tretrievedData = this.retrieveData(\"page\");\n\n\t\t\t\tif(retrievedData){\n\t\t\t\t\tif(typeof retrievedData.paginationSize !== \"undefined\" && (this.config.page === true || this.config.page.size)){\n\t\t\t\t\t\tthis.table.options.paginationSize = retrievedData.paginationSize;\n\t\t\t\t\t}\n\n\t\t\t\t\tif(typeof retrievedData.paginationInitialPage !== \"undefined\" && (this.config.page === true || this.config.page.page)){\n\t\t\t\t\t\tthis.table.options.paginationInitialPage = retrievedData.paginationInitialPage;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//load group data if needed\n\t\t\tif(this.config.group){\n\t\t\t\tretrievedData = this.retrieveData(\"group\");\n\n\t\t\t\tif(retrievedData){\n\t\t\t\t\tif(typeof retrievedData.groupBy !== \"undefined\" && (this.config.group === true || this.config.group.groupBy)){\n\t\t\t\t\t\tthis.table.options.groupBy = retrievedData.groupBy;\n\t\t\t\t\t}\n\t\t\t\t\tif(typeof retrievedData.groupStartOpen !== \"undefined\" && (this.config.group === true || this.config.group.groupStartOpen)){\n\t\t\t\t\t\tthis.table.options.groupStartOpen = retrievedData.groupStartOpen;\n\t\t\t\t\t}\n\t\t\t\t\tif(typeof retrievedData.groupHeader !== \"undefined\" && (this.config.group === true || this.config.group.groupHeader)){\n\t\t\t\t\t\tthis.table.options.groupHeader = retrievedData.groupHeader;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif(this.config.columns){\n\t\t\t\tthis.table.options.columns = this.load(\"columns\", this.table.options.columns);\n\t\t\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t\t\t\tthis.subscribe(\"column-show\", this.save.bind(this, \"columns\"));\n\t\t\t\tthis.subscribe(\"column-hide\", this.save.bind(this, \"columns\"));\n\t\t\t\tthis.subscribe(\"column-moved\", this.save.bind(this, \"columns\"));\n\t\t\t}\n\n\t\t\tthis.subscribe(\"table-built\", this.tableBuilt.bind(this), 0);\n\n\t\t\tthis.subscribe(\"table-redraw\", this.tableRedraw.bind(this));\n\n\t\t\tthis.subscribe(\"filter-changed\", this.eventSave.bind(this, \"filter\"));\n\t\t\tthis.subscribe(\"filter-changed\", this.eventSave.bind(this, \"headerFilter\"));\n\t\t\tthis.subscribe(\"sort-changed\", this.eventSave.bind(this, \"sort\"));\n\t\t\tthis.subscribe(\"group-changed\", this.eventSave.bind(this, \"group\"));\n\t\t\tthis.subscribe(\"page-changed\", this.eventSave.bind(this, \"page\"));\n\t\t\tthis.subscribe(\"column-resized\", this.eventSave.bind(this, \"columns\"));\n\t\t\tthis.subscribe(\"column-width\", this.eventSave.bind(this, \"columns\"));\n\t\t\tthis.subscribe(\"layout-refreshed\", this.eventSave.bind(this, \"columns\"));\n\t\t}\n\n\t\tthis.registerTableFunction(\"getColumnLayout\", this.getColumnLayout.bind(this));\n\t\tthis.registerTableFunction(\"setColumnLayout\", this.setColumnLayout.bind(this));\n\t}\n\n\teventSave(type){\n\t\tif(this.config[type]){\n\t\t\tthis.save(type);\n\t\t}\n\t}\n\n\ttableBuilt(){\n\t\tvar sorters, filters, headerFilters;\n\n\t\tif(this.config.sort){\n\t\t\tsorters = this.load(\"sort\");\n\n\t\t\tif(!sorters === false){\n\t\t\t\tthis.table.options.initialSort = sorters;\n\t\t\t}\n\t\t}\n\n\t\tif(this.config.filter){\n\t\t\tfilters = this.load(\"filter\");\n\n\t\t\tif(!filters === false){\n\t\t\t\tthis.table.options.initialFilter = filters;\n\t\t\t}\n\t\t}\n\t\tif(this.config.headerFilter){\n\t\t\theaderFilters = this.load(\"headerFilter\");\n\n\t\t\tif(!headerFilters === false){\n\t\t\t\tthis.table.options.initialHeaderFilter = headerFilters;\n\t\t\t}\n\t\t}\n\t\t\n\t}\n\n\ttableRedraw(force){\n\t\tif(force && this.config.columns){\n\t\t\tthis.save(\"columns\");\n\t\t}\n\t}\n\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\n\tgetColumnLayout(){\n\t\treturn this.parseColumns(this.table.columnManager.getColumns());\n\t}\n\n\tsetColumnLayout(layout){\n\t\tthis.table.columnManager.setColumns(this.mergeDefinition(this.table.options.columns, layout));\n\t\treturn true;\n\t}\n\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\n\tinitializeColumn(column){\n\t\tvar def, keys;\n\n\t\tif(this.config.columns){\n\t\t\tthis.defWatcherBlock = true;\n\n\t\t\tdef = column.getDefinition();\n\n\t\t\tkeys = this.config.columns === true ? Object.keys(def) : this.config.columns;\n\n\t\t\tkeys.forEach((key)=>{\n\t\t\t\tvar props = Object.getOwnPropertyDescriptor(def, key);\n\t\t\t\tvar value = def[key];\n\n\t\t\t\tif(props){\n\t\t\t\t\tObject.defineProperty(def, key, {\n\t\t\t\t\t\tset: (newValue) => {\n\t\t\t\t\t\t\tvalue = newValue;\n\n\t\t\t\t\t\t\tif(!this.defWatcherBlock){\n\t\t\t\t\t\t\t\tthis.save(\"columns\");\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif(props.set){\n\t\t\t\t\t\t\t\tprops.set(newValue);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t},\n\t\t\t\t\t\tget:() => {\n\t\t\t\t\t\t\tif(props.get){\n\t\t\t\t\t\t\t\tprops.get();\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn value;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.defWatcherBlock = false;\n\t\t}\n\t}\n\n\t//load saved definitions\n\tload(type, current){\n\t\tvar data = this.retrieveData(type);\n\n\t\tif(current){\n\t\t\tdata = data ? this.mergeDefinition(current, data) : current;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\t//retrieve data from memory\n\tretrieveData(type){\n\t\treturn this.readFunc ? this.readFunc(this.id, type) : false;\n\t}\n\n\t//merge old and new column definitions\n\tmergeDefinition(oldCols, newCols){\n\t\tvar output = [];\n\n\t\tnewCols = newCols || [];\n\n\t\tnewCols.forEach((column, to) => {\n\t\t\tvar from = this._findColumn(oldCols, column),\n\t\t\tkeys;\n\n\t\t\tif(from){\n\t\t\t\tif(this.config.columns === true || this.config.columns == undefined){\n\t\t\t\t\tkeys = Object.keys(from);\n\t\t\t\t\tkeys.push(\"width\");\n\t\t\t\t}else{\n\t\t\t\t\tkeys = this.config.columns;\n\t\t\t\t}\n\n\t\t\t\tkeys.forEach((key)=>{\n\t\t\t\t\tif(key !== \"columns\" && typeof column[key] !== \"undefined\"){\n\t\t\t\t\t\tfrom[key] = column[key];\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tif(from.columns){\n\t\t\t\t\tfrom.columns = this.mergeDefinition(from.columns, column.columns);\n\t\t\t\t}\n\n\t\t\t\toutput.push(from);\n\t\t\t}\n\t\t});\n\n\t\toldCols.forEach((column, i) => {\n\t\t\tvar from = this._findColumn(newCols, column);\n\n\t\t\tif (!from) {\n\t\t\t\tif(output.length>i){\n\t\t\t\t\toutput.splice(i, 0, column);\n\t\t\t\t}else{\n\t\t\t\t\toutput.push(column);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\treturn output;\n\t}\n\n\t//find matching columns\n\t_findColumn(columns, subject){\n\t\tvar type = subject.columns ? \"group\" : (subject.field ? \"field\" : \"object\");\n\n\t\treturn columns.find(function(col){\n\t\t\tswitch(type){\n\t\t\t\tcase \"group\":\n\t\t\t\t\treturn col.title === subject.title && col.columns.length === subject.columns.length;\n\n\t\t\t\tcase \"field\":\n\t\t\t\t\treturn col.field === subject.field;\n\n\t\t\t\tcase \"object\":\n\t\t\t\t\treturn col === subject;\n\t\t\t}\n\t\t});\n\t}\n\n\t//save data\n\tsave(type){\n\t\tvar data = {};\n\n\t\tswitch(type){\n\t\t\tcase \"columns\":\n\t\t\t\tdata = this.parseColumns(this.table.columnManager.getColumns());\n\t\t\t\tbreak;\n\n\t\t\tcase \"filter\":\n\t\t\t\tdata = this.table.modules.filter.getFilters();\n\t\t\t\tbreak;\n\n\t\t\tcase \"headerFilter\":\n\t\t\t\tdata = this.table.modules.filter.getHeaderFilters();\n\t\t\t\tbreak;\n\n\t\t\tcase \"sort\":\n\t\t\t\tdata = this.validateSorters(this.table.modules.sort.getSort());\n\t\t\t\tbreak;\n\n\t\t\tcase \"group\":\n\t\t\t\tdata = this.getGroupConfig();\n\t\t\t\tbreak;\n\n\t\t\tcase \"page\":\n\t\t\t\tdata = this.getPageConfig();\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif(this.writeFunc){\n\t\t\tthis.writeFunc(this.id, type, data);\n\t\t}\n\n\t}\n\n\t//ensure sorters contain no function data\n\tvalidateSorters(data){\n\t\tdata.forEach(function(item){\n\t\t\titem.column = item.field;\n\t\t\tdelete item.field;\n\t\t});\n\n\t\treturn data;\n\t}\n\n\tgetGroupConfig(){\n\t\tvar data = {};\n\n\t\tif(this.config.group){\n\t\t\tif(this.config.group === true || this.config.group.groupBy){\n\t\t\t\tdata.groupBy = this.table.options.groupBy;\n\t\t\t}\n\n\t\t\tif(this.config.group === true || this.config.group.groupStartOpen){\n\t\t\t\tdata.groupStartOpen = this.table.options.groupStartOpen;\n\t\t\t}\n\n\t\t\tif(this.config.group === true || this.config.group.groupHeader){\n\t\t\t\tdata.groupHeader = this.table.options.groupHeader;\n\t\t\t}\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tgetPageConfig(){\n\t\tvar data = {};\n\n\t\tif(this.config.page){\n\t\t\tif(this.config.page === true || this.config.page.size){\n\t\t\t\tdata.paginationSize = this.table.modules.page.getPageSize();\n\t\t\t}\n\n\t\t\tif(this.config.page === true || this.config.page.page){\n\t\t\t\tdata.paginationInitialPage = this.table.modules.page.getPage();\n\t\t\t}\n\t\t}\n\n\t\treturn data;\n\t}\n\n\n\t//parse columns for data to store\n\tparseColumns(columns){\n\t\tvar definitions = [],\n\t\texcludedKeys = [\"headerContextMenu\", \"headerMenu\", \"contextMenu\", \"clickMenu\"];\n\n\t\tcolumns.forEach((column) => {\n\t\t\tvar defStore = {},\n\t\t\tcolDef = column.getDefinition(),\n\t\t\tkeys;\n\n\t\t\tif(column.isGroup){\n\t\t\t\tdefStore.title = colDef.title;\n\t\t\t\tdefStore.columns = this.parseColumns(column.getColumns());\n\t\t\t}else{\n\t\t\t\tdefStore.field = column.getField();\n\n\t\t\t\tif(this.config.columns === true || this.config.columns == undefined){\n\t\t\t\t\tkeys = Object.keys(colDef);\n\t\t\t\t\tkeys.push(\"width\");\n\t\t\t\t\tkeys.push(\"visible\");\n\t\t\t\t}else{\n\t\t\t\t\tkeys = this.config.columns;\n\t\t\t\t}\n\n\t\t\t\tkeys.forEach((key)=>{\n\t\t\t\t\tswitch(key){\n\t\t\t\t\t\tcase \"width\":\n\t\t\t\t\t\t\tdefStore.width = column.getWidth();\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase \"visible\":\n\t\t\t\t\t\t\tdefStore.visible = column.visible;\n\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tif(typeof colDef[key] !== \"function\" && excludedKeys.indexOf(key) === -1){\n\t\t\t\t\t\t\t\tdefStore[key] = colDef[key];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tdefinitions.push(defStore);\n\t\t});\n\n\t\treturn definitions;\n\t}\n}\n\nPersistence.moduleName = \"persistence\";\n\nPersistence.moduleInitOrder = -10;\n\n//load defaults\nPersistence.readers = defaultReaders;\nPersistence.writers = defaultWriters;\n\nexport default Persistence;","import Module from '../../core/Module.js';\n\nclass Popup extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.columnSubscribers = {};\n\t\t\n\t\tthis.registerTableOption(\"rowContextPopup\", false);\n\t\tthis.registerTableOption(\"rowClickPopup\", false);\n\t\tthis.registerTableOption(\"rowDblClickPopup\", false);\n\t\tthis.registerTableOption(\"groupContextPopup\", false);\n\t\tthis.registerTableOption(\"groupClickPopup\", false);\n\t\tthis.registerTableOption(\"groupDblClickPopup\", false);\n\t\t\n\t\tthis.registerColumnOption(\"headerContextPopup\");\n\t\tthis.registerColumnOption(\"headerClickPopup\");\n\t\tthis.registerColumnOption(\"headerDblClickPopup\");\n\t\tthis.registerColumnOption(\"headerPopup\");\n\t\tthis.registerColumnOption(\"headerPopupIcon\");\n\t\tthis.registerColumnOption(\"contextPopup\");\n\t\tthis.registerColumnOption(\"clickPopup\");\n\t\tthis.registerColumnOption(\"dblClickPopup\");\n\n\t\tthis.registerComponentFunction(\"cell\", \"popup\", this._componentPopupCall.bind(this));\n\t\tthis.registerComponentFunction(\"column\", \"popup\", this._componentPopupCall.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"popup\", this._componentPopupCall.bind(this));\n\t\tthis.registerComponentFunction(\"group\", \"popup\", this._componentPopupCall.bind(this));\n\t\t\n\t}\n\t\n\tinitialize(){\n\t\tthis.initializeRowWatchers();\n\t\tthis.initializeGroupWatchers();\n\t\t\n\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t}\n\n\t_componentPopupCall(component, contents, position){\n\t\tthis.loadPopupEvent(contents, null, component, position);\n\t}\n\t\n\tinitializeRowWatchers(){\n\t\tif(this.table.options.rowContextPopup){\n\t\t\tthis.subscribe(\"row-contextmenu\", this.loadPopupEvent.bind(this, this.table.options.rowContextPopup));\n\t\t\tthis.table.on(\"rowTapHold\", this.loadPopupEvent.bind(this, this.table.options.rowContextPopup));\n\t\t}\n\t\t\n\t\tif(this.table.options.rowClickPopup){\n\t\t\tthis.subscribe(\"row-click\", this.loadPopupEvent.bind(this, this.table.options.rowClickPopup));\n\t\t}\n\n\t\tif(this.table.options.rowDblClickPopup){\n\t\t\tthis.subscribe(\"row-dblclick\", this.loadPopupEvent.bind(this, this.table.options.rowDblClickPopup));\n\t\t}\n\t}\n\t\n\tinitializeGroupWatchers(){\n\t\tif(this.table.options.groupContextPopup){\n\t\t\tthis.subscribe(\"group-contextmenu\", this.loadPopupEvent.bind(this, this.table.options.groupContextPopup));\n\t\t\tthis.table.on(\"groupTapHold\", this.loadPopupEvent.bind(this, this.table.options.groupContextPopup));\n\t\t}\n\t\t\n\t\tif(this.table.options.groupClickPopup){\n\t\t\tthis.subscribe(\"group-click\", this.loadPopupEvent.bind(this, this.table.options.groupClickPopup));\n\t\t}\n\n\t\tif(this.table.options.groupDblClickPopup){\n\t\t\tthis.subscribe(\"group-dblclick\", this.loadPopupEvent.bind(this, this.table.options.groupDblClickPopup));\n\t\t}\n\t}\n\t\n\tinitializeColumn(column){\n\t\tvar def = column.definition;\n\t\t\n\t\t//handle column events\n\t\tif(def.headerContextPopup && !this.columnSubscribers.headerContextPopup){\n\t\t\tthis.columnSubscribers.headerContextPopup = this.loadPopupTableColumnEvent.bind(this, \"headerContextPopup\");\n\t\t\tthis.subscribe(\"column-contextmenu\", this.columnSubscribers.headerContextPopup);\n\t\t\tthis.table.on(\"headerTapHold\", this.loadPopupTableColumnEvent.bind(this, \"headerContextPopup\"));\n\t\t}\n\t\t\n\t\tif(def.headerClickPopup && !this.columnSubscribers.headerClickPopup){\n\t\t\tthis.columnSubscribers.headerClickPopup = this.loadPopupTableColumnEvent.bind(this, \"headerClickPopup\");\n\t\t\tthis.subscribe(\"column-click\", this.columnSubscribers.headerClickPopup);\n\t\t\n\t\t\n\t\t}if(def.headerDblClickPopup && !this.columnSubscribers.headerDblClickPopup){\n\t\t\tthis.columnSubscribers.headerDblClickPopup = this.loadPopupTableColumnEvent.bind(this, \"headerDblClickPopup\");\n\t\t\tthis.subscribe(\"column-dblclick\", this.columnSubscribers.headerDblClickPopup);\n\t\t}\n\t\t\n\t\tif(def.headerPopup){\n\t\t\tthis.initializeColumnHeaderPopup(column);\n\t\t}\n\t\t\n\t\t//handle cell events\n\t\tif(def.contextPopup && !this.columnSubscribers.contextPopup){\n\t\t\tthis.columnSubscribers.contextPopup = this.loadPopupTableCellEvent.bind(this, \"contextPopup\");\n\t\t\tthis.subscribe(\"cell-contextmenu\", this.columnSubscribers.contextPopup);\n\t\t\tthis.table.on(\"cellTapHold\", this.loadPopupTableCellEvent.bind(this, \"contextPopup\"));\n\t\t}\n\t\t\n\t\tif(def.clickPopup && !this.columnSubscribers.clickPopup){\n\t\t\tthis.columnSubscribers.clickPopup = this.loadPopupTableCellEvent.bind(this, \"clickPopup\");\n\t\t\tthis.subscribe(\"cell-click\", this.columnSubscribers.clickPopup);\n\t\t}\n\n\t\tif(def.dblClickPopup && !this.columnSubscribers.dblClickPopup){\n\t\t\tthis.columnSubscribers.dblClickPopup = this.loadPopupTableCellEvent.bind(this, \"dblClickPopup\");\n\t\t\tthis.subscribe(\"cell-click\", this.columnSubscribers.dblClickPopup);\n\t\t}\n\t}\n\t\n\tinitializeColumnHeaderPopup(column){\n\t\tvar icon = column.definition.headerPopupIcon,\n\t\theaderPopupEl;\n\t\t\n\t\theaderPopupEl = document.createElement(\"span\");\n\t\theaderPopupEl.classList.add(\"tabulator-header-popup-button\");\n\n\t\tif(icon){\n\t\t\tif(typeof icon === \"function\"){\n\t\t\t\ticon = icon(column.getComponent());\n\t\t\t}\n\n\t\t\tif(icon instanceof HTMLElement){\n\t\t\t\theaderPopupEl.appendChild(icon);\n\t\t\t}else{\n\t\t\t\theaderPopupEl.innerHTML = icon;\n\t\t\t}\n\t\t}else{\n\t\t\theaderPopupEl.innerHTML = \"⋮\";\n\t\t}\n\t\t\n\t\theaderPopupEl.addEventListener(\"click\", (e) => {\n\t\t\te.stopPropagation();\n\t\t\te.preventDefault();\n\t\t\t\n\t\t\tthis.loadPopupEvent(column.definition.headerPopup, e, column);\n\t\t});\n\t\t\n\t\tcolumn.titleElement.insertBefore(headerPopupEl, column.titleElement.firstChild);\n\t}\n\t\n\tloadPopupTableCellEvent(option, e, cell){\n\t\tif(cell._cell){\n\t\t\tcell = cell._cell;\n\t\t}\n\t\t\n\t\tif(cell.column.definition[option]){\n\t\t\tthis.loadPopupEvent(cell.column.definition[option], e, cell);\n\t\t}\n\t}\n\t\n\tloadPopupTableColumnEvent(option, e, column){\n\t\tif(column._column){\n\t\t\tcolumn = column._column;\n\t\t}\n\t\t\n\t\tif(column.definition[option]){\n\t\t\tthis.loadPopupEvent(column.definition[option], e, column);\n\t\t}\n\t}\n\t\n\tloadPopupEvent(contents, e, component, position){\n\t\tvar renderedCallback;\n\n\t\tfunction onRendered(callback){\n\t\t\trenderedCallback = callback;\n\t\t}\n\t\t\n\t\tif(component._group){\n\t\t\tcomponent = component._group;\n\t\t}else if(component._row){\n\t\t\tcomponent = component._row;\n\t\t}\n\t\t\n\t\tcontents = typeof contents == \"function\" ? contents.call(this.table, e, component.getComponent(), onRendered) : contents;\n\t\t\n\t\tthis.loadPopup(e, component, contents, renderedCallback, position);\n\t}\n\t\n\tloadPopup(e, component, contents, renderedCallback, position){\n\t\tvar touch = !(e instanceof MouseEvent),\n\t\tcontentsEl, popup;\n\t\t\n\t\tif(contents instanceof HTMLElement){\n\t\t\tcontentsEl = contents;\n\t\t}else{\n\t\t\tcontentsEl = document.createElement(\"div\");\n\t\t\tcontentsEl.innerHTML = contents;\n\t\t}\n\t\t\n\t\tcontentsEl.classList.add(\"tabulator-popup\");\n\n\t\tcontentsEl.addEventListener(\"click\", (e) =>{\n\t\t\te.stopPropagation();\n\t\t});\n\n\t\tif(!touch){\n\t\t\te.preventDefault();\n\t\t}\n\t\t\n\t\tpopup = this.popup(contentsEl);\n\n\t\tif(typeof renderedCallback === \"function\"){\n\t\t\tpopup.renderCallback(renderedCallback);\n\t\t}\n\n\t\tif(e){\n\t\t\tpopup.show(e);\n\t\t}else{\n\t\t\tpopup.show(component.getElement(), position || \"center\");\n\t\t}\n\n\t\t\n\t\tpopup.hideOnBlur(() => {\n\t\t\tthis.dispatchExternal(\"popupClosed\", component.getComponent());\n\t\t});\n\n\n\n\t\tthis.dispatchExternal(\"popupOpened\", component.getComponent());\n\t}\n}\n\nPopup.moduleName = \"popup\";\n\nexport default Popup;\n","import Module from '../../core/Module.js';\n\nclass Print extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.element = false;\n\t\tthis.manualBlock = false;\n\t\tthis.beforeprintEventHandler = null;\n\t\tthis.afterprintEventHandler = null;\n\n\t\tthis.registerTableOption(\"printAsHtml\", false); //enable print as html\n\t\tthis.registerTableOption(\"printFormatter\", false); //printing page formatter\n\t\tthis.registerTableOption(\"printHeader\", false); //page header contents\n\t\tthis.registerTableOption(\"printFooter\", false); //page footer contents\n\t\tthis.registerTableOption(\"printStyled\", true); //enable print as html styling\n\t\tthis.registerTableOption(\"printRowRange\", \"visible\"); //restrict print to visible rows only\n\t\tthis.registerTableOption(\"printConfig\", {}); //print config options\n\n\t\tthis.registerColumnOption(\"print\");\n\t\tthis.registerColumnOption(\"titlePrint\");\n\t}\n\n\tinitialize(){\n\t\tif(this.table.options.printAsHtml){\n\t\t\tthis.beforeprintEventHandler = this.replaceTable.bind(this);\n\t\t\tthis.afterprintEventHandler = this.cleanup.bind(this);\n\n\t\t\twindow.addEventListener(\"beforeprint\", this.beforeprintEventHandler );\n\t\t\twindow.addEventListener(\"afterprint\", this.afterprintEventHandler);\n\t\t\tthis.subscribe(\"table-destroy\", this.destroy.bind(this));\n\t\t}\n\n\t\tthis.registerTableFunction(\"print\", this.printFullscreen.bind(this));\n\t}\n\n\tdestroy(){\n\t\tif(this.table.options.printAsHtml){\n\t\t\twindow.removeEventListener( \"beforeprint\", this.beforeprintEventHandler );\n\t\t\twindow.removeEventListener( \"afterprint\", this.afterprintEventHandler );\n\t\t}\n\t}\n\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\n\treplaceTable(){\n\t\tif(!this.manualBlock){\n\t\t\tthis.element = document.createElement(\"div\");\n\t\t\tthis.element.classList.add(\"tabulator-print-table\");\n\n\t\t\tthis.element.appendChild(this.table.modules.export.generateTable(this.table.options.printConfig, this.table.options.printStyled, this.table.options.printRowRange, \"print\"));\n\n\t\t\tthis.table.element.style.display = \"none\";\n\n\t\t\tthis.table.element.parentNode.insertBefore(this.element, this.table.element);\n\t\t}\n\t}\n\n\tcleanup(){\n\t\tdocument.body.classList.remove(\"tabulator-print-fullscreen-hide\");\n\n\t\tif(this.element && this.element.parentNode){\n\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t\tthis.table.element.style.display = \"\";\n\t\t}\n\t}\n\n\tprintFullscreen(visible, style, config){\n\t\tvar scrollX = window.scrollX,\n\t\tscrollY = window.scrollY,\n\t\theaderEl = document.createElement(\"div\"),\n\t\tfooterEl = document.createElement(\"div\"),\n\t\ttableEl = this.table.modules.export.generateTable(typeof config != \"undefined\" ? config : this.table.options.printConfig, typeof style != \"undefined\" ? style : this.table.options.printStyled, visible || this.table.options.printRowRange, \"print\"),\n\t\theaderContent, footerContent;\n\n\t\tthis.manualBlock = true;\n\n\t\tthis.element = document.createElement(\"div\");\n\t\tthis.element.classList.add(\"tabulator-print-fullscreen\");\n\n\t\tif(this.table.options.printHeader){\n\t\t\theaderEl.classList.add(\"tabulator-print-header\");\n\n\t\t\theaderContent = typeof this.table.options.printHeader == \"function\" ? this.table.options.printHeader.call(this.table) : this.table.options.printHeader;\n\n\t\t\tif(typeof headerContent == \"string\"){\n\t\t\t\theaderEl.innerHTML = headerContent;\n\t\t\t}else{\n\t\t\t\theaderEl.appendChild(headerContent);\n\t\t\t}\n\n\t\t\tthis.element.appendChild(headerEl);\n\t\t}\n\n\t\tthis.element.appendChild(tableEl);\n\n\t\tif(this.table.options.printFooter){\n\t\t\tfooterEl.classList.add(\"tabulator-print-footer\");\n\n\t\t\tfooterContent = typeof this.table.options.printFooter == \"function\" ? this.table.options.printFooter.call(this.table) : this.table.options.printFooter;\n\n\n\t\t\tif(typeof footerContent == \"string\"){\n\t\t\t\tfooterEl.innerHTML = footerContent;\n\t\t\t}else{\n\t\t\t\tfooterEl.appendChild(footerContent);\n\t\t\t}\n\n\t\t\tthis.element.appendChild(footerEl);\n\t\t}\n\n\t\tdocument.body.classList.add(\"tabulator-print-fullscreen-hide\");\n\t\tdocument.body.appendChild(this.element);\n\n\t\tif(this.table.options.printFormatter){\n\t\t\tthis.table.options.printFormatter(this.element, tableEl);\n\t\t}\n\n\t\twindow.print();\n\n\t\tthis.cleanup();\n\n\t\twindow.scrollTo(scrollX, scrollY);\n\n\t\tthis.manualBlock = false;\n\t}\n}\n\nPrint.moduleName = \"print\";\n\nexport default Print;","import Module from '../../core/Module.js';\n\nclass ReactiveData extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.data = false;\n\t\tthis.blocked = false; //block reactivity while performing update\n\t\tthis.origFuncs = {}; // hold original data array functions to allow replacement after data is done with\n\t\tthis.currentVersion = 0;\n\t\t\n\t\tthis.registerTableOption(\"reactiveData\", false); //enable data reactivity\n\t}\n\t\n\tinitialize(){\n\t\tif(this.table.options.reactiveData){\n\t\t\tthis.subscribe(\"cell-value-save-before\", this.block.bind(this, \"cellsave\"));\n\t\t\tthis.subscribe(\"cell-value-save-after\", this.unblock.bind(this, \"cellsave\"));\n\t\t\tthis.subscribe(\"row-data-save-before\", this.block.bind(this, \"rowsave\"));\n\t\t\tthis.subscribe(\"row-data-save-after\", this.unblock.bind(this, \"rowsave\"));\n\t\t\tthis.subscribe(\"row-data-init-after\", this.watchRow.bind(this));\n\t\t\tthis.subscribe(\"data-processing\", this.watchData.bind(this));\n\t\t\tthis.subscribe(\"table-destroy\", this.unwatchData.bind(this));\n\t\t}\n\t}\n\t\n\twatchData(data){\n\t\tvar self = this,\n\t\tversion;\n\t\t\n\t\tthis.currentVersion ++;\n\t\t\n\t\tversion = this.currentVersion;\n\t\t\n\t\tthis.unwatchData();\n\t\t\n\t\tthis.data = data;\n\t\t\n\t\t//override array push function\n\t\tthis.origFuncs.push = data.push;\n\t\t\n\t\tObject.defineProperty(this.data, \"push\", {\n\t\t\tenumerable: false,\n\t\t\tconfigurable: true,\n\t\t\tvalue: function(){\n\t\t\t\tvar args = Array.from(arguments),\n\t\t\t\tresult;\n\n\t\t\t\tif(!self.blocked && version === self.currentVersion){\t\n\t\t\t\t\tself.block(\"data-push\");\n\n\t\t\t\t\targs.forEach((arg) => {\n\t\t\t\t\t\tself.table.rowManager.addRowActual(arg, false);\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tresult = self.origFuncs.push.apply(data, arguments);\n\t\t\t\t\t\n\t\t\t\t\tself.unblock(\"data-push\");\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn result;\n\t\t\t}\n\t\t});\n\t\t\n\t\t//override array unshift function\n\t\tthis.origFuncs.unshift = data.unshift;\n\t\t\n\t\tObject.defineProperty(this.data, \"unshift\", {\n\t\t\tenumerable: false,\n\t\t\tconfigurable: true,\n\t\t\tvalue: function(){\n\t\t\t\tvar args = Array.from(arguments),\n\t\t\t\tresult;\n\t\t\t\t\n\t\t\t\tif(!self.blocked && version === self.currentVersion){\n\t\t\t\t\tself.block(\"data-unshift\");\n\t\t\t\t\t\n\t\t\t\t\targs.forEach((arg) => {\n\t\t\t\t\t\tself.table.rowManager.addRowActual(arg, true);\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tresult = self.origFuncs.unshift.apply(data, arguments);\n\t\t\t\t\t\n\t\t\t\t\tself.unblock(\"data-unshift\");\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn result;\n\t\t\t}\n\t\t});\n\t\t\n\t\t\n\t\t//override array shift function\n\t\tthis.origFuncs.shift = data.shift;\n\t\t\n\t\tObject.defineProperty(this.data, \"shift\", {\n\t\t\tenumerable: false,\n\t\t\tconfigurable: true,\n\t\t\tvalue: function(){\n\t\t\t\tvar row, result;\n\t\t\t\t\n\t\t\t\tif(!self.blocked && version === self.currentVersion){\n\t\t\t\t\tself.block(\"data-shift\");\n\t\t\t\t\t\n\t\t\t\t\tif(self.data.length){\n\t\t\t\t\t\trow = self.table.rowManager.getRowFromDataObject(self.data[0]);\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(row){\n\t\t\t\t\t\t\trow.deleteActual();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tresult = self.origFuncs.shift.call(data);\n\n\t\t\t\t\tself.unblock(\"data-shift\");\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn result;\n\t\t\t}\n\t\t});\n\t\t\n\t\t//override array pop function\n\t\tthis.origFuncs.pop = data.pop;\n\t\t\n\t\tObject.defineProperty(this.data, \"pop\", {\n\t\t\tenumerable: false,\n\t\t\tconfigurable: true,\n\t\t\tvalue: function(){\n\t\t\t\tvar row, result;\n\t\t\t\n\t\t\t\tif(!self.blocked && version === self.currentVersion){\n\t\t\t\t\tself.block(\"data-pop\");\n\t\t\t\t\t\n\t\t\t\t\tif(self.data.length){\n\t\t\t\t\t\trow = self.table.rowManager.getRowFromDataObject(self.data[self.data.length - 1]);\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(row){\n\t\t\t\t\t\t\trow.deleteActual();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tresult = self.origFuncs.pop.call(data);\n\t\t\t\t\t\n\t\t\t\t\tself.unblock(\"data-pop\");\n\t\t\t\t}\n\n\t\t\t\treturn result;\n\t\t\t}\n\t\t});\n\t\t\n\t\t\n\t\t//override array splice function\n\t\tthis.origFuncs.splice = data.splice;\n\t\t\n\t\tObject.defineProperty(this.data, \"splice\", {\n\t\t\tenumerable: false,\n\t\t\tconfigurable: true,\n\t\t\tvalue: function(){\n\t\t\t\tvar args = Array.from(arguments),\n\t\t\t\tstart = args[0] < 0 ? data.length + args[0] : args[0],\n\t\t\t\tend = args[1],\n\t\t\t\tnewRows = args[2] ? args.slice(2) : false,\n\t\t\t\tstartRow, result;\n\t\t\t\t\n\t\t\t\tif(!self.blocked && version === self.currentVersion){\n\t\t\t\t\tself.block(\"data-splice\");\n\t\t\t\t\t//add new rows\n\t\t\t\t\tif(newRows){\n\t\t\t\t\t\tstartRow = data[start] ? self.table.rowManager.getRowFromDataObject(data[start]) : false;\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(startRow){\n\t\t\t\t\t\t\tnewRows.forEach((rowData) => {\n\t\t\t\t\t\t\t\tself.table.rowManager.addRowActual(rowData, true, startRow, true);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tnewRows = newRows.slice().reverse();\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tnewRows.forEach((rowData) => {\n\t\t\t\t\t\t\t\tself.table.rowManager.addRowActual(rowData, true, false, true);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\t//delete removed rows\n\t\t\t\t\tif(end !== 0){\n\t\t\t\t\t\tvar oldRows = data.slice(start, typeof args[1] === \"undefined\" ? args[1] : start + end);\n\t\t\t\t\t\t\n\t\t\t\t\t\toldRows.forEach((rowData, i) => {\n\t\t\t\t\t\t\tvar row = self.table.rowManager.getRowFromDataObject(rowData);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tif(row){\n\t\t\t\t\t\t\t\trow.deleteActual(i !== oldRows.length - 1);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif(newRows || end !== 0){\n\t\t\t\t\t\tself.table.rowManager.reRenderInPosition();\n\t\t\t\t\t}\n\n\t\t\t\t\tresult = self.origFuncs.splice.apply(data, arguments);\n\t\t\t\t\t\n\t\t\t\t\tself.unblock(\"data-splice\");\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn result ;\n\t\t\t}\n\t\t});\n\t}\n\t\n\tunwatchData(){\n\t\tif(this.data !== false){\n\t\t\tfor(var key in this.origFuncs){\n\t\t\t\tObject.defineProperty(this.data, key, {\n\t\t\t\t\tenumerable: true,\n\t\t\t\t\tconfigurable:true,\n\t\t\t\t\twritable:true,\n\t\t\t\t\tvalue: this.origFuncs.key,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\t\n\twatchRow(row){\n\t\tvar data = row.getData();\n\t\t\n\t\tfor(var key in data){\n\t\t\tthis.watchKey(row, data, key);\n\t\t}\n\t\t\n\t\tif(this.table.options.dataTree){\n\t\t\tthis.watchTreeChildren(row);\n\t\t}\n\t}\n\t\n\twatchTreeChildren (row){\n\t\tvar self = this,\n\t\tchildField = row.getData()[this.table.options.dataTreeChildField],\n\t\torigFuncs = {};\n\t\t\n\t\tif(childField){\n\t\t\t\n\t\t\torigFuncs.push = childField.push;\n\t\t\t\n\t\t\tObject.defineProperty(childField, \"push\", {\n\t\t\t\tenumerable: false,\n\t\t\t\tconfigurable: true,\n\t\t\t\tvalue: () => {\n\t\t\t\t\tif(!self.blocked){\n\t\t\t\t\t\tself.block(\"tree-push\");\n\t\t\t\t\t\t\n\t\t\t\t\t\tvar result = origFuncs.push.apply(childField, arguments);\n\t\t\t\t\t\tthis.rebuildTree(row);\n\t\t\t\t\t\t\n\t\t\t\t\t\tself.unblock(\"tree-push\");\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\torigFuncs.unshift = childField.unshift;\n\t\t\t\n\t\t\tObject.defineProperty(childField, \"unshift\", {\n\t\t\t\tenumerable: false,\n\t\t\t\tconfigurable: true,\n\t\t\t\tvalue: () => {\n\t\t\t\t\tif(!self.blocked){\n\t\t\t\t\t\tself.block(\"tree-unshift\");\n\t\t\t\t\t\t\n\t\t\t\t\t\tvar result = origFuncs.unshift.apply(childField, arguments);\n\t\t\t\t\t\tthis.rebuildTree(row);\n\t\t\t\t\t\t\n\t\t\t\t\t\tself.unblock(\"tree-unshift\");\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\torigFuncs.shift = childField.shift;\n\t\t\t\n\t\t\tObject.defineProperty(childField, \"shift\", {\n\t\t\t\tenumerable: false,\n\t\t\t\tconfigurable: true,\n\t\t\t\tvalue: () => {\n\t\t\t\t\tif(!self.blocked){\n\t\t\t\t\t\tself.block(\"tree-shift\");\n\t\t\t\t\t\t\n\t\t\t\t\t\tvar result = origFuncs.shift.call(childField);\n\t\t\t\t\t\tthis.rebuildTree(row);\n\t\t\t\t\t\t\n\t\t\t\t\t\tself.unblock(\"tree-shift\");\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\torigFuncs.pop = childField.pop;\n\t\t\t\n\t\t\tObject.defineProperty(childField, \"pop\", {\n\t\t\t\tenumerable: false,\n\t\t\t\tconfigurable: true,\n\t\t\t\tvalue: () => {\n\t\t\t\t\tif(!self.blocked){\n\t\t\t\t\t\tself.block(\"tree-pop\");\n\t\t\t\t\t\t\n\t\t\t\t\t\tvar result = origFuncs.pop.call(childField);\n\t\t\t\t\t\tthis.rebuildTree(row);\n\t\t\t\t\t\t\n\t\t\t\t\t\tself.unblock(\"tree-pop\");\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\torigFuncs.splice = childField.splice;\n\t\t\t\n\t\t\tObject.defineProperty(childField, \"splice\", {\n\t\t\t\tenumerable: false,\n\t\t\t\tconfigurable: true,\n\t\t\t\tvalue: () => {\n\t\t\t\t\tif(!self.blocked){\n\t\t\t\t\t\tself.block(\"tree-splice\");\n\t\t\t\t\t\t\n\t\t\t\t\t\tvar result = origFuncs.splice.apply(childField, arguments);\n\t\t\t\t\t\tthis.rebuildTree(row);\n\t\t\t\t\t\t\n\t\t\t\t\t\tself.unblock(\"tree-splice\");\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\t\n\trebuildTree(row){\n\t\tthis.table.modules.dataTree.initializeRow(row);\n\t\tthis.table.modules.dataTree.layoutRow(row);\n\t\tthis.table.rowManager.refreshActiveData(\"tree\", false, true);\n\t}\n\t\n\twatchKey(row, data, key){\n\t\tvar self = this,\n\t\tprops = Object.getOwnPropertyDescriptor(data, key),\n\t\tvalue = data[key],\n\t\tversion = this.currentVersion;\n\t\t\n\t\tObject.defineProperty(data, key, {\n\t\t\tset: (newValue) => {\n\t\t\t\tvalue = newValue;\n\t\t\t\tif(!self.blocked && version === self.currentVersion){\n\t\t\t\t\tself.block(\"key\");\n\t\t\t\t\t\n\t\t\t\t\tvar update = {};\n\t\t\t\t\tupdate[key] = newValue;\n\t\t\t\t\trow.updateData(update);\n\t\t\t\t\t\n\t\t\t\t\tself.unblock(\"key\");\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(props.set){\n\t\t\t\t\tprops.set(newValue);\n\t\t\t\t}\n\t\t\t},\n\t\t\tget:() => {\n\t\t\t\t\n\t\t\t\tif(props.get){\n\t\t\t\t\tprops.get();\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn value;\n\t\t\t}\n\t\t});\n\t}\n\t\n\tunwatchRow(row){\n\t\tvar data = row.getData();\n\t\t\n\t\tfor(var key in data){\n\t\t\tObject.defineProperty(data, key, {\n\t\t\t\tvalue:data[key],\n\t\t\t});\n\t\t}\n\t}\n\t\n\tblock(key){\n\t\tif(!this.blocked){\n\t\t\tthis.blocked = key;\n\t\t}\n\t}\n\t\n\tunblock(key){\n\t\tif(this.blocked === key){\n\t\t\tthis.blocked = false;\n\t\t}\n\t}\n}\n\nReactiveData.moduleName = \"reactiveData\";\n\nexport default ReactiveData;\n\n\n\n","import Module from '../../core/Module.js';\n\nclass ResizeColumns extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.startColumn = false;\n\t\tthis.startX = false;\n\t\tthis.startWidth = false;\n\t\tthis.latestX = false;\n\t\tthis.handle = null;\n\t\tthis.initialNextColumn = null;\n\t\tthis.nextColumn = null;\n\t\t\n\t\tthis.initialized = false;\n\t\tthis.registerColumnOption(\"resizable\", true);\n\t\tthis.registerTableOption(\"resizableColumnFit\", false);\n\t}\n\t\n\tinitialize(){\n\t\tthis.subscribe(\"column-rendered\", this.layoutColumnHeader.bind(this));\n\t}\n\t\n\tinitializeEventWatchers(){\n\t\tif(!this.initialized){\n\t\t\t\n\t\t\tthis.subscribe(\"cell-rendered\", this.layoutCellHandles.bind(this));\n\t\t\tthis.subscribe(\"cell-delete\", this.deInitializeComponent.bind(this));\n\t\t\t\n\t\t\tthis.subscribe(\"cell-height\", this.resizeHandle.bind(this));\n\t\t\tthis.subscribe(\"column-moved\", this.columnLayoutUpdated.bind(this));\n\t\t\t\n\t\t\tthis.subscribe(\"column-hide\", this.deInitializeColumn.bind(this));\n\t\t\tthis.subscribe(\"column-show\", this.columnLayoutUpdated.bind(this));\n\t\t\tthis.subscribe(\"column-width\", this.columnWidthUpdated.bind(this));\n\t\t\t\n\t\t\tthis.subscribe(\"column-delete\", this.deInitializeComponent.bind(this));\n\t\t\tthis.subscribe(\"column-height\", this.resizeHandle.bind(this));\n\t\t\t\n\t\t\tthis.initialized = true;\n\t\t}\n\t}\n\t\n\t\n\tlayoutCellHandles(cell){\n\t\tif(cell.row.type === \"row\"){\n\t\t\tthis.deInitializeComponent(cell);\n\t\t\tthis.initializeColumn(\"cell\", cell, cell.column, cell.element);\n\t\t}\n\t}\n\t\n\tlayoutColumnHeader(column){\n\t\tif(column.definition.resizable){\n\t\t\tthis.initializeEventWatchers();\n\t\t\tthis.deInitializeComponent(column);\n\t\t\tthis.initializeColumn(\"header\", column, column, column.element);\n\t\t}\n\t}\n\t\n\tcolumnLayoutUpdated(column){\n\t\tvar prev = column.prevColumn();\n\t\t\n\t\tthis.reinitializeColumn(column);\n\t\t\n\t\tif(prev){\n\t\t\tthis.reinitializeColumn(prev);\n\t\t}\n\t}\n\t\n\tcolumnWidthUpdated(column){\n\t\tif(column.modules.frozen){\n\t\t\tif(this.table.modules.frozenColumns.leftColumns.includes(column)){\n\t\t\t\tthis.table.modules.frozenColumns.leftColumns.forEach((col) => {\n\t\t\t\t\tthis.reinitializeColumn(col);\n\t\t\t\t});\n\t\t\t}else if(this.table.modules.frozenColumns.rightColumns.includes(column)){\n\t\t\t\tthis.table.modules.frozenColumns.rightColumns.forEach((col) => {\n\t\t\t\t\tthis.reinitializeColumn(col);\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\n\tfrozenColumnOffset(column){\n\t\tvar offset = false;\n\n\t\tif(column.modules.frozen){\n\t\t\toffset = column.modules.frozen.marginValue; \n\n\t\t\tif(column.modules.frozen.position === \"left\"){\n\t\t\t\toffset += column.getWidth() - 3;\n\t\t\t}else{\n\t\t\t\tif(offset){\n\t\t\t\t\toffset -= 3;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn offset !== false ? offset + \"px\" : false;\n\t}\n\t\n\treinitializeColumn(column){\n\t\tvar frozenOffset = this.frozenColumnOffset(column);\n\t\t\n\t\tcolumn.cells.forEach((cell) => {\n\t\t\tif(cell.modules.resize && cell.modules.resize.handleEl){\n\t\t\t\tif(frozenOffset){\n\t\t\t\t\tcell.modules.resize.handleEl.style[column.modules.frozen.position] = frozenOffset;\n\t\t\t\t\tcell.modules.resize.handleEl.style[\"z-index\"] = 11;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tcell.element.after(cell.modules.resize.handleEl);\n\t\t\t}\n\t\t});\n\t\t\n\t\tif(column.modules.resize && column.modules.resize.handleEl){\n\t\t\tif(frozenOffset){\n\t\t\t\tcolumn.modules.resize.handleEl.style[column.modules.frozen.position] = frozenOffset;\n\t\t\t}\n\t\t\t\n\t\t\tcolumn.element.after(column.modules.resize.handleEl);\n\t\t}\n\t}\n\t\n\tinitializeColumn(type, component, column, element){\n\t\tvar self = this,\n\t\tvariableHeight = false,\n\t\tmode = column.definition.resizable,\n\t\tconfig = {},\n\t\tnearestColumn = column.getLastColumn();\n\t\t\n\t\t//set column resize mode\n\t\tif(type === \"header\"){\n\t\t\tvariableHeight = column.definition.formatter == \"textarea\" || column.definition.variableHeight;\n\t\t\tconfig = {variableHeight:variableHeight};\n\t\t}\n\t\t\n\t\tif((mode === true || mode == type) && this._checkResizability(nearestColumn)){\n\t\t\t\n\t\t\tvar handle = document.createElement('span');\n\t\t\thandle.className = \"tabulator-col-resize-handle\";\n\t\t\t\n\t\t\thandle.addEventListener(\"click\", function(e){\n\t\t\t\te.stopPropagation();\n\t\t\t});\n\t\t\t\n\t\t\tvar handleDown = function(e){\n\t\t\t\tself.startColumn = column;\n\t\t\t\tself.initialNextColumn = self.nextColumn = nearestColumn.nextColumn();\n\t\t\t\tself._mouseDown(e, nearestColumn, handle);\n\t\t\t};\n\t\t\t\n\t\t\thandle.addEventListener(\"mousedown\", handleDown);\n\t\t\thandle.addEventListener(\"touchstart\", handleDown, {passive: true});\n\t\t\t\n\t\t\t//resize column on double click\n\t\t\thandle.addEventListener(\"dblclick\", (e) => {\n\t\t\t\tvar oldWidth = nearestColumn.getWidth();\n\t\t\t\t\n\t\t\t\te.stopPropagation();\n\t\t\t\tnearestColumn.reinitializeWidth(true);\n\t\t\t\t\n\t\t\t\tif(oldWidth !== nearestColumn.getWidth()){\n\t\t\t\t\tself.dispatch(\"column-resized\", nearestColumn);\n\t\t\t\t\tself.table.externalEvents.dispatch(\"columnResized\", nearestColumn.getComponent());\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tif(column.modules.frozen){\n\t\t\t\thandle.style.position = \"sticky\";\n\t\t\t\thandle.style[column.modules.frozen.position] = this.frozenColumnOffset(column);\n\t\t\t}\n\t\t\t\n\t\t\tconfig.handleEl = handle;\n\t\t\t\n\t\t\tif(element.parentNode && column.visible){\n\t\t\t\telement.after(handle);\t\t\t\n\t\t\t}\n\t\t}\n\t\t\n\t\tcomponent.modules.resize = config;\n\t}\n\t\n\tdeInitializeColumn(column){\n\t\tthis.deInitializeComponent(column);\n\t\t\n\t\tcolumn.cells.forEach((cell) => {\n\t\t\tthis.deInitializeComponent(cell);\n\t\t});\n\t}\n\t\n\tdeInitializeComponent(component){\n\t\tvar handleEl;\n\t\t\n\t\tif(component.modules.resize){\n\t\t\thandleEl = component.modules.resize.handleEl;\n\t\t\t\n\t\t\tif(handleEl && handleEl.parentElement){\n\t\t\t\thandleEl.parentElement.removeChild(handleEl);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tresizeHandle(component, height){\n\t\tif(component.modules.resize && component.modules.resize.handleEl){\n\t\t\tcomponent.modules.resize.handleEl.style.height = height;\n\t\t}\n\t}\n\t\n\t_checkResizability(column){\n\t\treturn column.definition.resizable;\n\t}\n\t\n\t_mouseDown(e, column, handle){\n\t\tvar self = this;\n\t\t\n\t\tself.table.element.classList.add(\"tabulator-block-select\");\n\t\t\n\t\tfunction mouseMove(e){\n\t\t\tvar x = typeof e.screenX === \"undefined\" ? e.touches[0].screenX : e.screenX,\n\t\t\tstartDiff = x - self.startX,\n\t\t\tmoveDiff = x - self.latestX,\n\t\t\tblockedBefore, blockedAfter;\n\t\t\t\n\t\t\tself.latestX = x;\n\t\t\t\n\t\t\tif(self.table.rtl){\n\t\t\t\tstartDiff = -startDiff;\n\t\t\t\tmoveDiff = -moveDiff;\n\t\t\t}\n\t\t\t\n\t\t\tblockedBefore = column.width == column.minWidth || column.width == column.maxWidth;\n\t\t\t\n\t\t\tcolumn.setWidth(self.startWidth + startDiff);\n\t\t\t\n\t\t\tblockedAfter = column.width == column.minWidth || column.width == column.maxWidth;\n\t\t\t\n\t\t\tif(moveDiff < 0){\n\t\t\t\tself.nextColumn = self.initialNextColumn;\n\t\t\t}\n\t\t\t\n\t\t\tif(self.table.options.resizableColumnFit && self.nextColumn && !(blockedBefore && blockedAfter)){\n\t\t\t\tlet colWidth = self.nextColumn.getWidth();\n\t\t\t\t\n\t\t\t\tif(moveDiff > 0){\n\t\t\t\t\tif(colWidth <= self.nextColumn.minWidth){\n\t\t\t\t\t\tself.nextColumn = self.nextColumn.nextColumn();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(self.nextColumn){\n\t\t\t\t\tself.nextColumn.setWidth(self.nextColumn.getWidth() - moveDiff);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tself.table.columnManager.rerenderColumns(true);\n\t\t\t\n\t\t\tif(!self.table.browserSlow && column.modules.resize && column.modules.resize.variableHeight){\n\t\t\t\tcolumn.checkCellHeights();\n\t\t\t}\n\t\t}\n\t\t\n\t\tfunction mouseUp(e){\n\t\t\t\n\t\t\t//block editor from taking action while resizing is taking place\n\t\t\tif(self.startColumn.modules.edit){\n\t\t\t\tself.startColumn.modules.edit.blocked = false;\n\t\t\t}\n\t\t\t\n\t\t\tif(self.table.browserSlow && column.modules.resize && column.modules.resize.variableHeight){\n\t\t\t\tcolumn.checkCellHeights();\n\t\t\t}\n\t\t\t\n\t\t\tdocument.body.removeEventListener(\"mouseup\", mouseUp);\n\t\t\tdocument.body.removeEventListener(\"mousemove\", mouseMove);\n\t\t\t\n\t\t\thandle.removeEventListener(\"touchmove\", mouseMove);\n\t\t\thandle.removeEventListener(\"touchend\", mouseUp);\n\t\t\t\n\t\t\tself.table.element.classList.remove(\"tabulator-block-select\");\n\t\t\t\n\t\t\tif(self.startWidth !== column.getWidth()){\n\t\t\t\tself.table.columnManager.verticalAlignHeaders();\n\n\t\t\t\tself.dispatch(\"column-resized\", column);\n\t\t\t\tself.table.externalEvents.dispatch(\"columnResized\", column.getComponent());\n\t\t\t}\n\t\t}\n\t\t\n\t\te.stopPropagation(); //prevent resize from interfering with movable columns\n\t\t\n\t\t//block editor from taking action while resizing is taking place\n\t\tif(self.startColumn.modules.edit){\n\t\t\tself.startColumn.modules.edit.blocked = true;\n\t\t}\n\t\t\n\t\tself.startX = typeof e.screenX === \"undefined\" ? e.touches[0].screenX : e.screenX;\n\t\tself.latestX = self.startX;\n\t\tself.startWidth = column.getWidth();\n\t\t\n\t\tdocument.body.addEventListener(\"mousemove\", mouseMove);\n\t\tdocument.body.addEventListener(\"mouseup\", mouseUp);\n\t\thandle.addEventListener(\"touchmove\", mouseMove, {passive: true});\n\t\thandle.addEventListener(\"touchend\", mouseUp);\n\t}\n}\n\nResizeColumns.moduleName = \"resizeColumns\";\n\nexport default ResizeColumns;","import Module from '../../core/Module.js';\n\nclass ResizeRows extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.startColumn = false;\n\t\tthis.startY = false;\n\t\tthis.startHeight = false;\n\t\tthis.handle = null;\n\t\tthis.prevHandle = null;\n\n\t\tthis.registerTableOption(\"resizableRows\", false); //resizable rows\n\t}\n\n\tinitialize(){\n\t\tif(this.table.options.resizableRows){\n\t\t\tthis.subscribe(\"row-layout-after\", this.initializeRow.bind(this));\n\t\t}\n\t}\n\n\tinitializeRow(row){\n\t\tvar self = this,\n\t\trowEl = row.getElement();\n\n\t\tvar handle = document.createElement('div');\n\t\thandle.className = \"tabulator-row-resize-handle\";\n\n\t\tvar prevHandle = document.createElement('div');\n\t\tprevHandle.className = \"tabulator-row-resize-handle prev\";\n\n\t\thandle.addEventListener(\"click\", function(e){\n\t\t\te.stopPropagation();\n\t\t});\n\n\t\tvar handleDown = function(e){\n\t\t\tself.startRow = row;\n\t\t\tself._mouseDown(e, row, handle);\n\t\t};\n\n\t\thandle.addEventListener(\"mousedown\", handleDown);\n\t\thandle.addEventListener(\"touchstart\", handleDown, {passive: true});\n\n\t\tprevHandle.addEventListener(\"click\", function(e){\n\t\t\te.stopPropagation();\n\t\t});\n\n\t\tvar prevHandleDown = function(e){\n\t\t\tvar prevRow = self.table.rowManager.prevDisplayRow(row);\n\n\t\t\tif(prevRow){\n\t\t\t\tself.startRow = prevRow;\n\t\t\t\tself._mouseDown(e, prevRow, prevHandle);\n\t\t\t}\n\t\t};\n\n\t\tprevHandle.addEventListener(\"mousedown\",prevHandleDown);\n\t\tprevHandle.addEventListener(\"touchstart\",prevHandleDown, {passive: true});\n\n\t\trowEl.appendChild(handle);\n\t\trowEl.appendChild(prevHandle);\n\t}\n\n\t_mouseDown(e, row, handle){\n\t\tvar self = this;\n\n\t\tself.table.element.classList.add(\"tabulator-block-select\");\n\n\t\tfunction mouseMove(e){\n\t\t\trow.setHeight(self.startHeight + ((typeof e.screenY === \"undefined\" ? e.touches[0].screenY : e.screenY) - self.startY));\n\t\t}\n\n\t\tfunction mouseUp(e){\n\n\t\t\t// //block editor from taking action while resizing is taking place\n\t\t\t// if(self.startColumn.modules.edit){\n\t\t\t// \tself.startColumn.modules.edit.blocked = false;\n\t\t\t// }\n\n\t\t\tdocument.body.removeEventListener(\"mouseup\", mouseMove);\n\t\t\tdocument.body.removeEventListener(\"mousemove\", mouseMove);\n\n\t\t\thandle.removeEventListener(\"touchmove\", mouseMove);\n\t\t\thandle.removeEventListener(\"touchend\", mouseUp);\n\n\t\t\tself.table.element.classList.remove(\"tabulator-block-select\");\n\n\t\t\tself.dispatchExternal(\"rowResized\", row.getComponent());\n\t\t}\n\n\t\te.stopPropagation(); //prevent resize from interfering with movable columns\n\n\t\t//block editor from taking action while resizing is taking place\n\t\t// if(self.startColumn.modules.edit){\n\t\t// \tself.startColumn.modules.edit.blocked = true;\n\t\t// }\n\n\t\tself.startY = typeof e.screenY === \"undefined\" ? e.touches[0].screenY : e.screenY;\n\t\tself.startHeight = row.getHeight();\n\n\t\tdocument.body.addEventListener(\"mousemove\", mouseMove);\n\t\tdocument.body.addEventListener(\"mouseup\", mouseUp);\n\n\t\thandle.addEventListener(\"touchmove\", mouseMove, {passive: true});\n\t\thandle.addEventListener(\"touchend\", mouseUp);\n\t}\n}\n\nResizeRows.moduleName = \"resizeRows\";\n\nexport default ResizeRows;","import Module from '../../core/Module.js';\n\nclass ResizeTable extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.binding = false;\n\t\tthis.visibilityObserver = false;\n\t\tthis.resizeObserver = false;\n\t\tthis.containerObserver = false;\n\t\t\n\t\tthis.tableHeight = 0;\n\t\tthis.tableWidth = 0;\n\t\tthis.containerHeight = 0;\n\t\tthis.containerWidth = 0;\n\t\t\n\t\tthis.autoResize = false;\n\t\t\n\t\tthis.visible = false;\n\t\t\n\t\tthis.initialized = false;\n\t\tthis.initialRedraw = false;\n\t\t\n\t\tthis.registerTableOption(\"autoResize\", true); //auto resize table\n\t}\n\t\n\tinitialize(){\n\t\tif(this.table.options.autoResize){\n\t\t\tvar table = this.table,\n\t\t\ttableStyle;\n\t\t\t\n\t\t\tthis.tableHeight = table.element.clientHeight;\n\t\t\tthis.tableWidth = table.element.clientWidth;\n\t\t\t\n\t\t\tif(table.element.parentNode){\n\t\t\t\tthis.containerHeight = table.element.parentNode.clientHeight;\n\t\t\t\tthis.containerWidth = table.element.parentNode.clientWidth;\n\t\t\t}\n\t\t\t\n\t\t\tif(typeof IntersectionObserver !== \"undefined\" && typeof ResizeObserver !== \"undefined\" && table.rowManager.getRenderMode() === \"virtual\"){\n\t\t\t\t\n\t\t\t\tthis.initializeVisibilityObserver();\n\t\t\t\t\n\t\t\t\tthis.autoResize = true;\n\t\t\t\t\n\t\t\t\tthis.resizeObserver = new ResizeObserver((entry) => {\n\t\t\t\t\tif(!table.browserMobile || (table.browserMobile &&!table.modules.edit.currentCell)){\n\t\t\t\t\t\t\n\t\t\t\t\t\tvar nodeHeight = Math.floor(entry[0].contentRect.height);\n\t\t\t\t\t\tvar nodeWidth = Math.floor(entry[0].contentRect.width);\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(this.tableHeight != nodeHeight || this.tableWidth != nodeWidth){\n\t\t\t\t\t\t\tthis.tableHeight = nodeHeight;\n\t\t\t\t\t\t\tthis.tableWidth = nodeWidth;\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tif(table.element.parentNode){\n\t\t\t\t\t\t\t\tthis.containerHeight = table.element.parentNode.clientHeight;\n\t\t\t\t\t\t\t\tthis.containerWidth = table.element.parentNode.clientWidth;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tthis.redrawTable();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tthis.resizeObserver.observe(table.element);\n\t\t\t\t\n\t\t\t\ttableStyle = window.getComputedStyle(table.element);\n\t\t\t\t\n\t\t\t\tif(this.table.element.parentNode && !this.table.rowManager.fixedHeight && (tableStyle.getPropertyValue(\"max-height\") || tableStyle.getPropertyValue(\"min-height\"))){\n\t\t\t\t\t\n\t\t\t\t\tthis.containerObserver = new ResizeObserver((entry) => {\n\t\t\t\t\t\tif(!table.browserMobile || (table.browserMobile &&!table.modules.edit.currentCell)){\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tvar nodeHeight = Math.floor(entry[0].contentRect.height);\n\t\t\t\t\t\t\tvar nodeWidth = Math.floor(entry[0].contentRect.width);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tif(this.containerHeight != nodeHeight || this.containerWidth != nodeWidth){\n\t\t\t\t\t\t\t\tthis.containerHeight = nodeHeight;\n\t\t\t\t\t\t\t\tthis.containerWidth = nodeWidth;\n\t\t\t\t\t\t\t\tthis.tableHeight = table.element.clientHeight;\n\t\t\t\t\t\t\t\tthis.tableWidth = table.element.clientWidth;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tthis.redrawTable();\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tthis.containerObserver.observe(this.table.element.parentNode);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.subscribe(\"table-resize\", this.tableResized.bind(this));\n\t\t\t\t\n\t\t\t}else{\n\t\t\t\tthis.binding = function(){\n\t\t\t\t\tif(!table.browserMobile || (table.browserMobile && !table.modules.edit.currentCell)){\n\t\t\t\t\t\ttable.columnManager.rerenderColumns(true);\n\t\t\t\t\t\ttable.redraw();\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\twindow.addEventListener(\"resize\", this.binding);\n\t\t\t}\n\t\t\t\n\t\t\tthis.subscribe(\"table-destroy\", this.clearBindings.bind(this));\n\t\t}\n\t}\n\t\n\tinitializeVisibilityObserver(){\n\t\tthis.visibilityObserver = new IntersectionObserver((entries) => {\n\t\t\tthis.visible = entries[0].isIntersecting;\n\t\t\t\n\t\t\tif(!this.initialized){\n\t\t\t\tthis.initialized = true;\n\t\t\t\tthis.initialRedraw = !this.visible;\n\t\t\t}else{\n\t\t\t\tif(this.visible){\n\t\t\t\t\tthis.redrawTable(this.initialRedraw);\n\t\t\t\t\tthis.initialRedraw = false;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\t\n\t\tthis.visibilityObserver.observe(this.table.element);\n\t}\n\t\n\tredrawTable(force){\n\t\tif(this.initialized && this.visible){\n\t\t\tthis.table.columnManager.rerenderColumns(true);\n\t\t\tthis.table.redraw(force);\n\t\t}\n\t}\n\t\n\ttableResized(){\n\t\tthis.table.rowManager.redraw();\n\t}\n\t\n\tclearBindings(){\n\t\tif(this.binding){\n\t\t\twindow.removeEventListener(\"resize\", this.binding);\n\t\t}\n\t\t\n\t\tif(this.resizeObserver){\n\t\t\tthis.resizeObserver.unobserve(this.table.element);\n\t\t}\n\t\t\n\t\tif(this.visibilityObserver){\n\t\t\tthis.visibilityObserver.unobserve(this.table.element);\n\t\t}\n\t\t\n\t\tif(this.containerObserver){\n\t\t\tthis.containerObserver.unobserve(this.table.element.parentNode);\n\t\t}\n\t}\n}\n\nResizeTable.moduleName = \"resizeTable\";\n\nexport default ResizeTable;","import Module from '../../core/Module.js';\n\nclass ResponsiveLayout extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.columns = [];\n\t\tthis.hiddenColumns = [];\n\t\tthis.mode = \"\";\n\t\tthis.index = 0;\n\t\tthis.collapseFormatter = [];\n\t\tthis.collapseStartOpen = true;\n\t\tthis.collapseHandleColumn = false;\n\n\t\tthis.registerTableOption(\"responsiveLayout\", false); //responsive layout flags\n\t\tthis.registerTableOption(\"responsiveLayoutCollapseStartOpen\", true); //start showing collapsed data\n\t\tthis.registerTableOption(\"responsiveLayoutCollapseUseFormatters\", true); //responsive layout collapse formatter\n\t\tthis.registerTableOption(\"responsiveLayoutCollapseFormatter\", false); //responsive layout collapse formatter\n\n\t\tthis.registerColumnOption(\"responsive\");\n\t}\n\n\t//generate responsive columns list\n\tinitialize(){\n\t\tif(this.table.options.responsiveLayout){\n\t\t\tthis.subscribe(\"column-layout\", this.initializeColumn.bind(this));\n\t\t\tthis.subscribe(\"column-show\", this.updateColumnVisibility.bind(this));\n\t\t\tthis.subscribe(\"column-hide\", this.updateColumnVisibility.bind(this));\n\t\t\tthis.subscribe(\"columns-loaded\", this.initializeResponsivity.bind(this));\n\t\t\tthis.subscribe(\"column-moved\", this.initializeResponsivity.bind(this));\n\t\t\tthis.subscribe(\"column-add\", this.initializeResponsivity.bind(this));\n\t\t\tthis.subscribe(\"column-delete\", this.initializeResponsivity.bind(this));\n\n\t\t\tthis.subscribe(\"table-redrawing\", this.tableRedraw.bind(this));\n\t\t\t\n\t\t\tif(this.table.options.responsiveLayout === \"collapse\"){\n\t\t\t\tthis.subscribe(\"row-data-changed\", this.generateCollapsedRowContent.bind(this));\n\t\t\t\tthis.subscribe(\"row-init\", this.initializeRow.bind(this));\n\t\t\t\tthis.subscribe(\"row-layout\", this.layoutRow.bind(this));\n\t\t\t}\n\t\t}\n\t}\n\n\ttableRedraw(force){\n\t\tif([\"fitColumns\", \"fitDataStretch\"].indexOf(this.layoutMode()) === -1){\n\t\t\tif(!force){\n\t\t\t\tthis.update();\n\t\t\t}\n\t\t}\n\t}\n\n\tinitializeResponsivity(){\n\t\tvar columns = [];\n\n\t\tthis.mode = this.table.options.responsiveLayout;\n\t\tthis.collapseFormatter = this.table.options.responsiveLayoutCollapseFormatter || this.formatCollapsedData;\n\t\tthis.collapseStartOpen = this.table.options.responsiveLayoutCollapseStartOpen;\n\t\tthis.hiddenColumns = [];\n\n\t\t//determine level of responsivity for each column\n\t\tthis.table.columnManager.columnsByIndex.forEach((column, i) => {\n\t\t\tif(column.modules.responsive){\n\t\t\t\tif(column.modules.responsive.order && column.modules.responsive.visible){\n\t\t\t\t\tcolumn.modules.responsive.index = i;\n\t\t\t\t\tcolumns.push(column);\n\n\t\t\t\t\tif(!column.visible && this.mode === \"collapse\"){\n\t\t\t\t\t\tthis.hiddenColumns.push(column);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\t//sort list by responsivity\n\t\tcolumns = columns.reverse();\n\t\tcolumns = columns.sort((a, b) => {\n\t\t\tvar diff = b.modules.responsive.order - a.modules.responsive.order;\n\t\t\treturn diff || (b.modules.responsive.index - a.modules.responsive.index);\n\t\t});\n\n\t\tthis.columns = columns;\n\n\t\tif(this.mode === \"collapse\"){\n\t\t\tthis.generateCollapsedContent();\n\t\t}\n\n\t\t//assign collapse column\n\t\tfor (let col of this.table.columnManager.columnsByIndex){\n\t\t\tif(col.definition.formatter == \"responsiveCollapse\"){\n\t\t\t\tthis.collapseHandleColumn = col;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tif(this.collapseHandleColumn){\n\t\t\tif(this.hiddenColumns.length){\n\t\t\t\tthis.collapseHandleColumn.show();\n\t\t\t}else{\n\t\t\t\tthis.collapseHandleColumn.hide();\n\t\t\t}\n\t\t}\n\t}\n\n\t//define layout information\n\tinitializeColumn(column){\n\t\tvar def = column.getDefinition();\n\n\t\tcolumn.modules.responsive = {order: typeof def.responsive === \"undefined\" ? 1 : def.responsive, visible:def.visible === false ? false : true};\n\t}\n\n\tinitializeRow(row){\n\t\tvar el;\n\n\t\tif(row.type !== \"calc\"){\n\t\t\tel = document.createElement(\"div\");\n\t\t\tel.classList.add(\"tabulator-responsive-collapse\");\n\n\t\t\trow.modules.responsiveLayout = {\n\t\t\t\telement:el,\n\t\t\t\topen:this.collapseStartOpen,\n\t\t\t};\n\n\t\t\tif(!this.collapseStartOpen){\n\t\t\t\tel.style.display = 'none';\n\t\t\t}\n\t\t}\n\t}\n\n\tlayoutRow(row){\n\t\tvar rowEl = row.getElement();\n\n\t\tif(row.modules.responsiveLayout){\n\t\t\trowEl.appendChild(row.modules.responsiveLayout.element);\n\t\t\tthis.generateCollapsedRowContent(row);\n\t\t}\n\t}\n\n\t//update column visibility\n\tupdateColumnVisibility(column, responsiveToggle){\n\t\tif(!responsiveToggle && column.modules.responsive){\n\t\t\tcolumn.modules.responsive.visible = column.visible;\n\t\t\tthis.initializeResponsivity();\n\t\t}\n\t}\n\n\thideColumn(column){\n\t\tvar colCount = this.hiddenColumns.length;\n\n\t\tcolumn.hide(false, true);\n\n\t\tif(this.mode === \"collapse\"){\n\t\t\tthis.hiddenColumns.unshift(column);\n\t\t\tthis.generateCollapsedContent();\n\n\t\t\tif(this.collapseHandleColumn && !colCount){\n\t\t\t\tthis.collapseHandleColumn.show();\n\t\t\t}\n\t\t}\n\t}\n\n\tshowColumn(column){\n\t\tvar index;\n\n\t\tcolumn.show(false, true);\n\t\t//set column width to prevent calculation loops on uninitialized columns\n\t\tcolumn.setWidth(column.getWidth());\n\n\t\tif(this.mode === \"collapse\"){\n\t\t\tindex = this.hiddenColumns.indexOf(column);\n\n\t\t\tif(index > -1){\n\t\t\t\tthis.hiddenColumns.splice(index, 1);\n\t\t\t}\n\n\t\t\tthis.generateCollapsedContent();\n\n\t\t\tif(this.collapseHandleColumn && !this.hiddenColumns.length){\n\t\t\t\tthis.collapseHandleColumn.hide();\n\t\t\t}\n\t\t}\n\t}\n\n\t//redraw columns to fit space\n\tupdate(){\n\t\tvar working = true;\n\n\t\twhile(working){\n\n\t\t\tlet width = this.table.modules.layout.getMode() == \"fitColumns\" ? this.table.columnManager.getFlexBaseWidth() : this.table.columnManager.getWidth();\n\n\t\t\tlet diff = (this.table.options.headerVisible ? this.table.columnManager.element.clientWidth : this.table.element.clientWidth) - width;\n\n\t\t\tif(diff < 0){\n\t\t\t\t//table is too wide\n\t\t\t\tlet column = this.columns[this.index];\n\n\t\t\t\tif(column){\n\t\t\t\t\tthis.hideColumn(column);\n\t\t\t\t\tthis.index ++;\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\n\t\t\t}else{\n\n\t\t\t\t//table has spare space\n\t\t\t\tlet column = this.columns[this.index -1];\n\n\t\t\t\tif(column){\n\t\t\t\t\tif(diff > 0){\n\t\t\t\t\t\tif(diff >= column.getWidth()){\n\t\t\t\t\t\t\tthis.showColumn(column);\n\t\t\t\t\t\t\tthis.index --;\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tworking = false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tworking = false;\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif(!this.table.rowManager.activeRowsCount){\n\t\t\t\tthis.table.rowManager.renderEmptyScroll();\n\t\t\t}\n\t\t}\n\t}\n\n\tgenerateCollapsedContent(){\n\t\tvar rows = this.table.rowManager.getDisplayRows();\n\n\t\trows.forEach((row) => {\n\t\t\tthis.generateCollapsedRowContent(row);\n\t\t});\n\t}\n\n\tgenerateCollapsedRowContent(row){\n\t\tvar el, contents;\n\n\t\tif(row.modules.responsiveLayout){\n\t\t\tel = row.modules.responsiveLayout.element;\n\n\t\t\twhile(el.firstChild) el.removeChild(el.firstChild);\n\n\t\t\tcontents = this.collapseFormatter(this.generateCollapsedRowData(row));\n\t\t\tif(contents){\n\t\t\t\tel.appendChild(contents);\n\t\t\t}\n\t\t}\n\t}\n\n\tgenerateCollapsedRowData(row){\n\t\tvar data = row.getData(),\n\t\toutput = [],\n\t\tmockCellComponent;\n\n\t\tthis.hiddenColumns.forEach((column) => {\n\t\t\tvar value = column.getFieldValue(data);\n\n\t\t\tif(column.definition.title && column.field){\n\t\t\t\tif(column.modules.format && this.table.options.responsiveLayoutCollapseUseFormatters){\n\n\t\t\t\t\tmockCellComponent = {\n\t\t\t\t\t\tvalue:false,\n\t\t\t\t\t\tdata:{},\n\t\t\t\t\t\tgetValue:function(){\n\t\t\t\t\t\t\treturn value;\n\t\t\t\t\t\t},\n\t\t\t\t\t\tgetData:function(){\n\t\t\t\t\t\t\treturn data;\n\t\t\t\t\t\t},\n\t\t\t\t\t\tgetType:function(){\n\t\t\t\t\t\t\treturn \"cell\";\n\t\t\t\t\t\t},\n\t\t\t\t\t\tgetElement:function(){\n\t\t\t\t\t\t\treturn document.createElement(\"div\");\n\t\t\t\t\t\t},\n\t\t\t\t\t\tgetRow:function(){\n\t\t\t\t\t\t\treturn row.getComponent();\n\t\t\t\t\t\t},\n\t\t\t\t\t\tgetColumn:function(){\n\t\t\t\t\t\t\treturn column.getComponent();\n\t\t\t\t\t\t},\n\t\t\t\t\t\tgetTable:() => {\n\t\t\t\t\t\t\treturn this.table;\n\t\t\t\t\t\t},\n\t\t\t\t\t};\n\n\t\t\t\t\tfunction onRendered(callback){\n\t\t\t\t\t\tcallback();\n\t\t\t\t\t}\n\n\t\t\t\t\toutput.push({\n\t\t\t\t\t\tfield: column.field,\n\t\t\t\t\t\ttitle: column.definition.title,\n\t\t\t\t\t\tvalue: column.modules.format.formatter.call(this.table.modules.format, mockCellComponent, column.modules.format.params, onRendered)\n\t\t\t\t\t});\n\t\t\t\t}else{\n\t\t\t\t\toutput.push({\n\t\t\t\t\t\tfield: column.field,\n\t\t\t\t\t\ttitle: column.definition.title,\n\t\t\t\t\t\tvalue: value\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\treturn output;\n\t}\n\n\tformatCollapsedData(data){\n\t\tvar list = document.createElement(\"table\");\n\n\t\tdata.forEach(function(item){\n\t\t\tvar row = document.createElement(\"tr\");\n\t\t\tvar titleData = document.createElement(\"td\");\n\t\t\tvar valueData = document.createElement(\"td\");\n\t\t\tvar node_content;\n\n\t\t\tvar titleHighlight = document.createElement(\"strong\");\n\t\t\ttitleData.appendChild(titleHighlight);\n\t\t\tthis.langBind(\"columns|\" + item.field, function(text){\n\t\t\t\ttitleHighlight.innerHTML = text || item.title;\n\t\t\t});\n\n\t\t\tif(item.value instanceof Node){\n\t\t\t\tnode_content = document.createElement(\"div\");\n\t\t\t\tnode_content.appendChild(item.value);\n\t\t\t\tvalueData.appendChild(node_content);\n\t\t\t}else{\n\t\t\t\tvalueData.innerHTML = item.value;\n\t\t\t}\n\n\t\t\trow.appendChild(titleData);\n\t\t\trow.appendChild(valueData);\n\t\t\tlist.appendChild(row);\n\t\t}, this);\n\n\t\treturn Object.keys(data).length ? list : \"\";\n\t}\n}\n\nResponsiveLayout.moduleName = \"responsiveLayout\";\n\nexport default ResponsiveLayout;\n","import Module from '../../core/Module.js';\n\nclass SelectRow extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.selecting = false; //flag selecting in progress\n\t\tthis.lastClickedRow = false; //last clicked row\n\t\tthis.selectPrev = []; //hold previously selected element for drag drop selection\n\t\tthis.selectedRows = []; //hold selected rows\n\t\tthis.headerCheckboxElement = null; // hold header select element\n\t\t\n\t\tthis.registerTableOption(\"selectable\", \"highlight\"); //highlight rows on hover\n\t\tthis.registerTableOption(\"selectableRangeMode\", \"drag\"); //highlight rows on hover\n\t\tthis.registerTableOption(\"selectableRollingSelection\", true); //roll selection once maximum number of selectable rows is reached\n\t\tthis.registerTableOption(\"selectablePersistence\", true); // maintain selection when table view is updated\n\t\tthis.registerTableOption(\"selectableCheck\", function(data, row){return true;}); //check whether row is selectable\n\t\t\n\t\tthis.registerTableFunction(\"selectRow\", this.selectRows.bind(this));\n\t\tthis.registerTableFunction(\"deselectRow\", this.deselectRows.bind(this));\n\t\tthis.registerTableFunction(\"toggleSelectRow\", this.toggleRow.bind(this));\n\t\tthis.registerTableFunction(\"getSelectedRows\", this.getSelectedRows.bind(this));\n\t\tthis.registerTableFunction(\"getSelectedData\", this.getSelectedData.bind(this));\n\t\t\n\t\t//register component functions\n\t\tthis.registerComponentFunction(\"row\", \"select\", this.selectRows.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"deselect\", this.deselectRows.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"toggleSelect\", this.toggleRow.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"isSelected\", this.isRowSelected.bind(this));\n\t}\n\t\n\tinitialize(){\n\t\tif(this.table.options.selectable !== false){\n\t\t\tthis.subscribe(\"row-init\", this.initializeRow.bind(this));\n\t\t\tthis.subscribe(\"row-deleting\", this.rowDeleted.bind(this));\n\t\t\tthis.subscribe(\"rows-wipe\", this.clearSelectionData.bind(this));\n\t\t\tthis.subscribe(\"rows-retrieve\", this.rowRetrieve.bind(this));\n\t\t\t\n\t\t\tif(this.table.options.selectable && !this.table.options.selectablePersistence){\n\t\t\t\tthis.subscribe(\"data-refreshing\", this.deselectRows.bind(this));\n\t\t\t}\n\t\t}\n\t}\n\t\n\trowRetrieve(type, prevValue){\n\t\treturn type === \"selected\" ? this.selectedRows : prevValue;\n\t}\n\t\n\trowDeleted(row){\n\t\tthis._deselectRow(row, true);\n\t}\n\t\n\tclearSelectionData(silent){\n\t\tvar prevSelected = this.selectedRows.length;\n\n\t\tthis.selecting = false;\n\t\tthis.lastClickedRow = false;\n\t\tthis.selectPrev = [];\n\t\tthis.selectedRows = [];\n\t\t\n\t\tif(prevSelected && silent !== true){\n\t\t\tthis._rowSelectionChanged();\n\t\t}\n\t}\n\t\n\tinitializeRow(row){\n\t\tvar self = this,\n\t\telement = row.getElement();\n\t\t\n\t\t// trigger end of row selection\n\t\tvar endSelect = function(){\n\t\t\t\n\t\t\tsetTimeout(function(){\n\t\t\t\tself.selecting = false;\n\t\t\t}, 50);\n\t\t\t\n\t\t\tdocument.body.removeEventListener(\"mouseup\", endSelect);\n\t\t};\n\t\t\n\t\trow.modules.select = {selected:false};\n\t\t\n\t\t//set row selection class\n\t\tif(self.checkRowSelectability(row)){\n\t\t\telement.classList.add(\"tabulator-selectable\");\n\t\t\telement.classList.remove(\"tabulator-unselectable\");\n\t\t\t\n\t\t\tif(self.table.options.selectable && self.table.options.selectable != \"highlight\"){\n\t\t\t\tif(self.table.options.selectableRangeMode === \"click\"){\n\t\t\t\t\telement.addEventListener(\"click\", this.handleComplexRowClick.bind(this, row));\n\t\t\t\t}else{\n\t\t\t\t\telement.addEventListener(\"click\", function(e){\n\t\t\t\t\t\tif(!self.table.modExists(\"edit\") || !self.table.modules.edit.getCurrentCell()){\n\t\t\t\t\t\t\tself.table._clearSelection();\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(!self.selecting){\n\t\t\t\t\t\t\tself.toggleRow(row);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\telement.addEventListener(\"mousedown\", function(e){\n\t\t\t\t\t\tif(e.shiftKey){\n\t\t\t\t\t\t\tself.table._clearSelection();\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tself.selecting = true;\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tself.selectPrev = [];\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tdocument.body.addEventListener(\"mouseup\", endSelect);\n\t\t\t\t\t\t\tdocument.body.addEventListener(\"keyup\", endSelect);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tself.toggleRow(row);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\telement.addEventListener(\"mouseenter\", function(e){\n\t\t\t\t\t\tif(self.selecting){\n\t\t\t\t\t\t\tself.table._clearSelection();\n\t\t\t\t\t\t\tself.toggleRow(row);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\tif(self.selectPrev[1] == row){\n\t\t\t\t\t\t\t\tself.toggleRow(self.selectPrev[0]);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\telement.addEventListener(\"mouseout\", function(e){\n\t\t\t\t\t\tif(self.selecting){\n\t\t\t\t\t\t\tself.table._clearSelection();\n\t\t\t\t\t\t\tself.selectPrev.unshift(row);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t}else{\n\t\t\telement.classList.add(\"tabulator-unselectable\");\n\t\t\telement.classList.remove(\"tabulator-selectable\");\n\t\t}\n\t}\n\t\n\thandleComplexRowClick(row, e){\n\t\tif(e.shiftKey){\n\t\t\tthis.table._clearSelection();\n\t\t\tthis.lastClickedRow = this.lastClickedRow || row;\n\t\t\t\n\t\t\tvar lastClickedRowIdx = this.table.rowManager.getDisplayRowIndex(this.lastClickedRow);\n\t\t\tvar rowIdx = this.table.rowManager.getDisplayRowIndex(row);\n\t\t\t\n\t\t\tvar fromRowIdx = lastClickedRowIdx <= rowIdx ? lastClickedRowIdx : rowIdx;\n\t\t\tvar toRowIdx = lastClickedRowIdx >= rowIdx ? lastClickedRowIdx : rowIdx;\n\t\t\t\n\t\t\tvar rows = this.table.rowManager.getDisplayRows().slice(0);\n\t\t\tvar toggledRows = rows.splice(fromRowIdx, toRowIdx - fromRowIdx + 1);\n\t\t\t\n\t\t\tif(e.ctrlKey || e.metaKey){\n\t\t\t\ttoggledRows.forEach((toggledRow)=>{\n\t\t\t\t\tif(toggledRow !== this.lastClickedRow){\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(this.table.options.selectable !== true && !this.isRowSelected(row)){\n\t\t\t\t\t\t\tif(this.selectedRows.length < this.table.options.selectable){\n\t\t\t\t\t\t\t\tthis.toggleRow(toggledRow);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tthis.toggleRow(toggledRow);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tthis.lastClickedRow = row;\n\t\t\t}else{\n\t\t\t\tthis.deselectRows(undefined, true);\n\t\t\t\t\n\t\t\t\tif(this.table.options.selectable !== true){\n\t\t\t\t\tif(toggledRows.length > this.table.options.selectable){\n\t\t\t\t\t\ttoggledRows = toggledRows.slice(0, this.table.options.selectable);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.selectRows(toggledRows);\n\t\t\t}\n\t\t\tthis.table._clearSelection();\n\t\t}\n\t\telse if(e.ctrlKey || e.metaKey){\n\t\t\tthis.toggleRow(row);\n\t\t\tthis.lastClickedRow = row;\n\t\t}else{\n\t\t\tthis.deselectRows(undefined, true);\n\t\t\tthis.selectRows(row);\n\t\t\tthis.lastClickedRow = row;\n\t\t}\n\t}\n\n\tcheckRowSelectability(row){\n\t\tif(row && row.type === \"row\"){\n\t\t\treturn this.table.options.selectableCheck.call(this.table, row.getComponent());\n\t\t}\n\n\t\treturn false;\n\t}\n\t\n\t//toggle row selection\n\ttoggleRow(row){\n\t\tif(this.checkRowSelectability(row)){\n\t\t\tif(row.modules.select && row.modules.select.selected){\n\t\t\t\tthis._deselectRow(row);\n\t\t\t}else{\n\t\t\t\tthis._selectRow(row);\n\t\t\t}\n\t\t}\n\t}\n\t\n\t//select a number of rows\n\tselectRows(rows){\n\t\tvar changes = [], \n\t\trowMatch, change;\n\t\t\n\t\tswitch(typeof rows){\n\t\t\tcase \"undefined\":\n\t\t\t\trowMatch = this.table.rowManager.rows;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"string\":\n\t\t\t\trowMatch = this.table.rowManager.findRow(rows);\n\t\t\t\n\t\t\t\tif(!rowMatch){\n\t\t\t\t\trowMatch = this.table.rowManager.getRows(rows);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tdefault:\n\t\t\t\trowMatch = rows;\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif(Array.isArray(rowMatch)){\n\t\t\tif(rowMatch.length){\n\t\t\t\trowMatch.forEach((row) => {\n\t\t\t\t\tchange = this._selectRow(row, true, true);\n\n\t\t\t\t\tif(change){\n\t\t\t\t\t\tchanges.push(change);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tthis._rowSelectionChanged(false, changes);\n\t\t\t}\n\t\t}else{\n\t\t\tif(rowMatch){\n\t\t\t\tthis._selectRow(rowMatch, false, true);\n\t\t\t}\n\t\t}\t\n\t}\n\t\n\t//select an individual row\n\t_selectRow(rowInfo, silent, force){\n\t\t//handle max row count\n\t\tif(!isNaN(this.table.options.selectable) && this.table.options.selectable !== true && !force){\n\t\t\tif(this.selectedRows.length >= this.table.options.selectable){\n\t\t\t\tif(this.table.options.selectableRollingSelection){\n\t\t\t\t\tthis._deselectRow(this.selectedRows[0]);\n\t\t\t\t}else{\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\tvar row = this.table.rowManager.findRow(rowInfo);\n\t\t\n\t\tif(row){\n\t\t\tif(this.selectedRows.indexOf(row) == -1){\n\t\t\t\trow.getElement().classList.add(\"tabulator-selected\");\n\t\t\t\tif(!row.modules.select){\n\t\t\t\t\trow.modules.select = {};\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\trow.modules.select.selected = true;\n\t\t\t\tif(row.modules.select.checkboxEl){\n\t\t\t\t\trow.modules.select.checkboxEl.checked = true;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.selectedRows.push(row);\n\t\t\t\t\n\t\t\t\tif(this.table.options.dataTreeSelectPropagate){\n\t\t\t\t\tthis.childRowSelection(row, true);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.dispatchExternal(\"rowSelected\", row.getComponent());\n\t\t\t\t\n\t\t\t\tthis._rowSelectionChanged(silent, row);\n\n\t\t\t\treturn row;\n\t\t\t}\n\t\t}else{\n\t\t\tif(!silent){\n\t\t\t\tconsole.warn(\"Selection Error - No such row found, ignoring selection:\" + rowInfo);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tisRowSelected(row){\n\t\treturn this.selectedRows.indexOf(row) !== -1;\n\t}\n\t\n\t//deselect a number of rows\n\tdeselectRows(rows, silent){\n\t\tvar changes = [], \n\t\trowMatch, change;\n\t\t\n\t\tswitch(typeof rows){\n\t\t\tcase \"undefined\":\n\t\t\t\trowMatch = Object.assign([], this.selectedRows);\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"string\":\n\t\t\t\trowMatch = this.table.rowManager.findRow(rows);\n\t\t\t\n\t\t\t\tif(!rowMatch){\n\t\t\t\t\trowMatch = this.table.rowManager.getRows(rows);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tdefault:\n\t\t\t\trowMatch = rows;\n\t\t\t\tbreak;\n\t\t}\n\n\t\tif(Array.isArray(rowMatch)){\n\t\t\tif(rowMatch.length){\n\t\t\t\trowMatch.forEach((row) => {\n\t\t\t\t\tchange = this._deselectRow(row, true, true);\n\n\t\t\t\t\tif(change){\n\t\t\t\t\t\tchanges.push(change);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tthis._rowSelectionChanged(silent, [], changes);\n\t\t\t}\n\t\t}else{\n\t\t\tif(rowMatch){\n\t\t\t\tthis._deselectRow(rowMatch, silent, true);\n\t\t\t}\n\t\t}\t\n\t}\n\t\n\t//deselect an individual row\n\t_deselectRow(rowInfo, silent){\n\t\tvar self = this,\n\t\trow = self.table.rowManager.findRow(rowInfo),\n\t\tindex, element;\n\t\t\n\t\tif(row){\n\t\t\tindex = self.selectedRows.findIndex(function(selectedRow){\n\t\t\t\treturn selectedRow == row;\n\t\t\t});\n\t\t\t\n\t\t\tif(index > -1){\n\n\t\t\t\telement = row.getElement();\n\t\t\t\t\n\t\t\t\tif(element){\n\t\t\t\t\telement.classList.remove(\"tabulator-selected\");\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tif(!row.modules.select){\n\t\t\t\t\trow.modules.select = {};\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\trow.modules.select.selected = false;\n\t\t\t\tif(row.modules.select.checkboxEl){\n\t\t\t\t\trow.modules.select.checkboxEl.checked = false;\n\t\t\t\t}\n\t\t\t\tself.selectedRows.splice(index, 1);\n\t\t\t\t\n\t\t\t\tif(this.table.options.dataTreeSelectPropagate){\n\t\t\t\t\tthis.childRowSelection(row, false);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.dispatchExternal(\"rowDeselected\", row.getComponent());\n\t\t\t\t\n\t\t\t\tself._rowSelectionChanged(silent, undefined, row);\n\n\t\t\t\treturn row;\n\t\t\t}\n\t\t}else{\n\t\t\tif(!silent){\n\t\t\t\tconsole.warn(\"Deselection Error - No such row found, ignoring selection:\" + rowInfo);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tgetSelectedData(){\n\t\tvar data = [];\n\t\t\n\t\tthis.selectedRows.forEach(function(row){\n\t\t\tdata.push(row.getData());\n\t\t});\n\t\t\n\t\treturn data;\n\t}\n\t\n\tgetSelectedRows(){\n\t\tvar rows = [];\n\t\t\n\t\tthis.selectedRows.forEach(function(row){\n\t\t\trows.push(row.getComponent());\n\t\t});\n\t\t\n\t\treturn rows;\n\t}\n\t\n\t_rowSelectionChanged(silent, selected = [], deselected = []){\n\t\tif(this.headerCheckboxElement){\n\t\t\tif(this.selectedRows.length === 0){\n\t\t\t\tthis.headerCheckboxElement.checked = false;\n\t\t\t\tthis.headerCheckboxElement.indeterminate = false;\n\t\t\t} else if(this.table.rowManager.rows.length === this.selectedRows.length){\n\t\t\t\tthis.headerCheckboxElement.checked = true;\n\t\t\t\tthis.headerCheckboxElement.indeterminate = false;\n\t\t\t} else {\n\t\t\t\tthis.headerCheckboxElement.indeterminate = true;\n\t\t\t\tthis.headerCheckboxElement.checked = false;\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(!silent){\n\t\t\tif(!Array.isArray(selected)){\n\t\t\t\tselected = [selected];\n\t\t\t}\n\n\t\t\tselected = selected.map(row => row.getComponent());\n\n\t\t\tif(!Array.isArray(deselected)){\n\t\t\t\tdeselected = [deselected];\n\t\t\t}\n\n\t\t\tdeselected = deselected.map(row => row.getComponent());\n\n\t\t\tthis.dispatchExternal(\"rowSelectionChanged\", this.getSelectedData(), this.getSelectedRows(), selected, deselected);\n\t\t}\n\t}\n\t\n\tregisterRowSelectCheckbox (row, element) {\n\t\tif(!row._row.modules.select){\n\t\t\trow._row.modules.select = {};\n\t\t}\n\t\t\n\t\trow._row.modules.select.checkboxEl = element;\n\t}\n\t\n\tregisterHeaderSelectCheckbox (element) {\n\t\tthis.headerCheckboxElement = element;\n\t}\n\t\n\tchildRowSelection(row, select){\n\t\tvar children = this.table.modules.dataTree.getChildren(row, true);\n\t\t\n\t\tif(select){\n\t\t\tfor(let child of children){\n\t\t\t\tthis._selectRow(child, true);\n\t\t\t}\n\t\t}else{\n\t\t\tfor(let child of children){\n\t\t\t\tthis._deselectRow(child, true);\n\t\t\t}\n\t\t}\n\t}\n}\n\nSelectRow.moduleName = \"selectRow\";\n\nexport default SelectRow;","//sort datetime\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tvar DT = window.DateTime || luxon.DateTime;\n\tvar format = params.format || \"dd/MM/yyyy HH:mm:ss\",\n\talignEmptyValues = params.alignEmptyValues,\n\temptyAlign = 0;\n\n\tif(typeof DT != \"undefined\"){\n\t\tif(!DT.isDateTime(a)){\n\t\t\tif(format === \"iso\"){\n\t\t\t\ta = DT.fromISO(String(a));\n\t\t\t}else{\n\t\t\t\ta = DT.fromFormat(String(a), format);\n\t\t\t}\n\t\t}\n\n\t\tif(!DT.isDateTime(b)){\n\t\t\tif(format === \"iso\"){\n\t\t\t\tb = DT.fromISO(String(b));\n\t\t\t}else{\n\t\t\t\tb = DT.fromFormat(String(b), format);\n\t\t\t}\n\t\t}\n\n\t\tif(!a.isValid){\n\t\t\temptyAlign = !b.isValid ? 0 : -1;\n\t\t}else if(!b.isValid){\n\t\t\temptyAlign = 1;\n\t\t}else{\n\t\t\t//compare valid values\n\t\t\treturn a - b;\n\t\t}\n\n\t\t//fix empty values in position\n\t\tif((alignEmptyValues === \"top\" && dir === \"desc\") || (alignEmptyValues === \"bottom\" && dir === \"asc\")){\n\t\t\temptyAlign *= -1;\n\t\t}\n\n\t\treturn emptyAlign;\n\n\t}else{\n\t\tconsole.error(\"Sort Error - 'datetime' sorter is dependant on luxon.js\");\n\t}\n}","import number from './sorters/number.js';\nimport string from './sorters/string.js';\nimport date from './sorters/date.js';\nimport time from './sorters/time.js';\nimport datetime from './sorters/datetime.js';\nimport boolean from './sorters/boolean.js';\nimport array from './sorters/array.js';\nimport exists from './sorters/exists.js';\nimport alphanum from './sorters/alphanum.js';\n\nexport default {\n\tnumber:number,\n\tstring:string,\n\tdate:date,\n\ttime:time,\n\tdatetime:datetime,\n\tboolean:boolean,\n\tarray:array,\n\texists:exists,\n\talphanum:alphanum\n};","//sort numbers\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tvar alignEmptyValues = params.alignEmptyValues;\n\tvar decimal = params.decimalSeparator;\n\tvar thousand = params.thousandSeparator;\n\tvar emptyAlign = 0;\n\n\ta = String(a);\n\tb = String(b);\n\n\tif(thousand){\n\t\ta = a.split(thousand).join(\"\");\n\t\tb = b.split(thousand).join(\"\");\n\t}\n\n\tif(decimal){\n\t\ta = a.split(decimal).join(\".\");\n\t\tb = b.split(decimal).join(\".\");\n\t}\n\n\ta = parseFloat(a);\n\tb = parseFloat(b);\n\n\t//handle non numeric values\n\tif(isNaN(a)){\n\t\temptyAlign = isNaN(b) ? 0 : -1;\n\t}else if(isNaN(b)){\n\t\temptyAlign = 1;\n\t}else{\n\t\t//compare valid values\n\t\treturn a - b;\n\t}\n\n\t//fix empty values in position\n\tif((alignEmptyValues === \"top\" && dir === \"desc\") || (alignEmptyValues === \"bottom\" && dir === \"asc\")){\n\t\temptyAlign *= -1;\n\t}\n\n\treturn emptyAlign;\n}","//sort strings\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tvar alignEmptyValues = params.alignEmptyValues;\n\tvar emptyAlign = 0;\n\tvar locale;\n\n\t//handle empty values\n\tif(!a){\n\t\temptyAlign = !b ? 0 : -1;\n\t}else if(!b){\n\t\temptyAlign = 1;\n\t}else{\n\t\t//compare valid values\n\t\tswitch(typeof params.locale){\n\t\t\tcase \"boolean\":\n\t\t\t\tif(params.locale){\n\t\t\t\t\tlocale = this.langLocale();\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase \"string\":\n\t\t\t\tlocale = params.locale;\n\t\t\t\tbreak;\n\t\t}\n\n\t\treturn String(a).toLowerCase().localeCompare(String(b).toLowerCase(), locale);\n\t}\n\n\t//fix empty values in position\n\tif((alignEmptyValues === \"top\" && dir === \"desc\") || (alignEmptyValues === \"bottom\" && dir === \"asc\")){\n\t\temptyAlign *= -1;\n\t}\n\n\treturn emptyAlign;\n}","import datetime from './datetime.js';\n\n//sort date\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tif(!params.format){\n\t\tparams.format = \"dd/MM/yyyy\";\n\t}\n\n\treturn datetime.call(this, a, b, aRow, bRow, column, dir, params);\n}","import datetime from './datetime.js';\n\n//sort times\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tif(!params.format){\n\t\tparams.format = \"HH:mm\";\n\t}\n\n\treturn datetime.call(this, a, b, aRow, bRow, column, dir, params);\n}","//sort booleans\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tvar el1 = a === true || a === \"true\" || a === \"True\" || a === 1 ? 1 : 0;\n\tvar el2 = b === true || b === \"true\" || b === \"True\" || b === 1 ? 1 : 0;\n\n\treturn el1 - el2;\n}","//sort if element contains any data\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tvar type = params.type || \"length\",\n\talignEmptyValues = params.alignEmptyValues,\n\temptyAlign = 0;\n\n\tfunction calc(value){\n\t\tvar result;\n\n\t\tswitch(type){\n\t\t\tcase \"length\":\n\t\t\t\tresult = value.length;\n\t\t\t\tbreak;\n\n\t\t\tcase \"sum\":\n\t\t\t\tresult = value.reduce(function(c, d){\n\t\t\t\t\treturn c + d;\n\t\t\t\t});\n\t\t\t\tbreak;\n\n\t\t\tcase \"max\":\n\t\t\t\tresult = Math.max.apply(null, value) ;\n\t\t\t\tbreak;\n\n\t\t\tcase \"min\":\n\t\t\t\tresult = Math.min.apply(null, value) ;\n\t\t\t\tbreak;\n\n\t\t\tcase \"avg\":\n\t\t\t\tresult = value.reduce(function(c, d){\n\t\t\t\t\treturn c + d;\n\t\t\t\t}) / value.length;\n\t\t\t\tbreak;\n\t\t}\n\n\t\treturn result;\n\t}\n\n\t//handle non array values\n\tif(!Array.isArray(a)){\n\t\temptyAlign = !Array.isArray(b) ? 0 : -1;\n\t}else if(!Array.isArray(b)){\n\t\temptyAlign = 1;\n\t}else{\n\t\treturn calc(b) - calc(a);\n\t}\n\n\t//fix empty values in position\n\tif((alignEmptyValues === \"top\" && dir === \"desc\") || (alignEmptyValues === \"bottom\" && dir === \"asc\")){\n\t\temptyAlign *= -1;\n\t}\n\n\treturn emptyAlign;\n}","//sort if element contains any data\nexport default function(a, b, aRow, bRow, column, dir, params){\n\tvar el1 = typeof a == \"undefined\" ? 0 : 1;\n\tvar el2 = typeof b == \"undefined\" ? 0 : 1;\n\n\treturn el1 - el2;\n}","//sort alpha numeric strings\nexport default function(as, bs, aRow, bRow, column, dir, params){\n\tvar a, b, a1, b1, i= 0, L, rx = /(\\d+)|(\\D+)/g, rd = /\\d/;\n\tvar alignEmptyValues = params.alignEmptyValues;\n\tvar emptyAlign = 0;\n\n\t//handle empty values\n\tif(!as && as!== 0){\n\t\temptyAlign = !bs && bs!== 0 ? 0 : -1;\n\t}else if(!bs && bs!== 0){\n\t\temptyAlign = 1;\n\t}else{\n\n\t\tif(isFinite(as) && isFinite(bs)) return as - bs;\n\t\ta = String(as).toLowerCase();\n\t\tb = String(bs).toLowerCase();\n\t\tif(a === b) return 0;\n\t\tif(!(rd.test(a) && rd.test(b))) return a > b ? 1 : -1;\n\t\ta = a.match(rx);\n\t\tb = b.match(rx);\n\t\tL = a.length > b.length ? b.length : a.length;\n\t\twhile(i < L){\n\t\t\ta1= a[i];\n\t\t\tb1= b[i++];\n\t\t\tif(a1 !== b1){\n\t\t\t\tif(isFinite(a1) && isFinite(b1)){\n\t\t\t\t\tif(a1.charAt(0) === \"0\") a1 = \".\" + a1;\n\t\t\t\t\tif(b1.charAt(0) === \"0\") b1 = \".\" + b1;\n\t\t\t\t\treturn a1 - b1;\n\t\t\t\t}\n\t\t\t\telse return a1 > b1 ? 1 : -1;\n\t\t\t}\n\t\t}\n\n\t\treturn a.length > b.length;\n\t}\n\n\t//fix empty values in position\n\tif((alignEmptyValues === \"top\" && dir === \"desc\") || (alignEmptyValues === \"bottom\" && dir === \"asc\")){\n\t\temptyAlign *= -1;\n\t}\n\n\treturn emptyAlign;\n}","import Module from '../../core/Module.js';\n\nimport defaultSorters from './defaults/sorters.js';\n\nclass Sort extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.sortList = []; //holder current sort\n\t\tthis.changed = false; //has the sort changed since last render\n\n\t\tthis.registerTableOption(\"sortMode\", \"local\"); //local or remote sorting\n\n\t\tthis.registerTableOption(\"initialSort\", false); //initial sorting criteria\n\t\tthis.registerTableOption(\"columnHeaderSortMulti\", true); //multiple or single column sorting\n\t\tthis.registerTableOption(\"sortOrderReverse\", false); //reverse internal sort ordering\n\t\tthis.registerTableOption(\"headerSortElement\", \"
\"); //header sort element\n\t\tthis.registerTableOption(\"headerSortClickElement\", \"header\"); //element which triggers sort when clicked\n\n\t\tthis.registerColumnOption(\"sorter\");\n\t\tthis.registerColumnOption(\"sorterParams\");\n\n\t\tthis.registerColumnOption(\"headerSort\", true);\n\t\tthis.registerColumnOption(\"headerSortStartingDir\");\n\t\tthis.registerColumnOption(\"headerSortTristate\");\n\n\t}\n\n\tinitialize(){\n\t\tthis.subscribe(\"column-layout\", this.initializeColumn.bind(this));\n\t\tthis.subscribe(\"table-built\", this.tableBuilt.bind(this));\n\t\tthis.registerDataHandler(this.sort.bind(this), 20);\n\n\t\tthis.registerTableFunction(\"setSort\", this.userSetSort.bind(this));\n\t\tthis.registerTableFunction(\"getSorters\", this.getSort.bind(this));\n\t\tthis.registerTableFunction(\"clearSort\", this.clearSort.bind(this));\n\n\t\tif(this.table.options.sortMode === \"remote\"){\n\t\t\tthis.subscribe(\"data-params\", this.remoteSortParams.bind(this));\n\t\t}\n\t}\n\n\ttableBuilt(){\n\t\tif(this.table.options.initialSort){\n\t\t\tthis.setSort(this.table.options.initialSort);\n\t\t}\n\t}\n\n\tremoteSortParams(data, config, silent, params){\n\t\tvar sorters = this.getSort();\n\n\t\tsorters.forEach((item) => {\n\t\t\tdelete item.column;\n\t\t});\n\n\t\tparams.sort = sorters;\n\n\t\treturn params;\n\t}\n\n\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\n\tuserSetSort(sortList, dir){\n\t\tthis.setSort(sortList, dir);\n\t\t// this.table.rowManager.sorterRefresh();\n\t\tthis.refreshSort();\n\t}\n\n\tclearSort(){\n\t\tthis.clear();\n\t\t// this.table.rowManager.sorterRefresh();\n\t\tthis.refreshSort();\n\t}\n\n\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\n\t//initialize column header for sorting\n\tinitializeColumn(column){\n\t\tvar sorter = false,\n\t\tcolEl,\n\t\tarrowEl;\n\n\t\tswitch(typeof column.definition.sorter){\n\t\t\tcase \"string\":\n\t\t\t\tif(Sort.sorters[column.definition.sorter]){\n\t\t\t\t\tsorter = Sort.sorters[column.definition.sorter];\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Sort Error - No such sorter found: \", column.definition.sorter);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase \"function\":\n\t\t\t\tsorter = column.definition.sorter;\n\t\t\t\tbreak;\n\t\t}\n\n\t\tcolumn.modules.sort = {\n\t\t\tsorter:sorter, dir:\"none\",\n\t\t\tparams:column.definition.sorterParams || {},\n\t\t\tstartingDir:column.definition.headerSortStartingDir || \"asc\",\n\t\t\ttristate: column.definition.headerSortTristate,\n\t\t};\n\n\t\tif(column.definition.headerSort !== false){\n\n\t\t\tcolEl = column.getElement();\n\n\t\t\tcolEl.classList.add(\"tabulator-sortable\");\n\n\t\t\tarrowEl = document.createElement(\"div\");\n\t\t\tarrowEl.classList.add(\"tabulator-col-sorter\");\n\n\t\t\tswitch(this.table.options.headerSortClickElement){\n\t\t\t\tcase \"icon\":\n\t\t\t\t\tarrowEl.classList.add(\"tabulator-col-sorter-element\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"header\":\n\t\t\t\t\tcolEl.classList.add(\"tabulator-col-sorter-element\");\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\tcolEl.classList.add(\"tabulator-col-sorter-element\");\n\t\t\t\t\tbreak;\n\t\t\t}\n\n\t\t\tswitch(this.table.options.headerSortElement){\n\t\t\t\tcase \"function\":\n\t\t\t\t\t//do nothing\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase \"object\":\n\t\t\t\t\tarrowEl.appendChild(this.table.options.headerSortElement);\n\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\tdefault:\n\t\t\t\t\tarrowEl.innerHTML = this.table.options.headerSortElement;\n\t\t\t}\n\n\t\t\t//create sorter arrow\n\t\t\tcolumn.titleHolderElement.appendChild(arrowEl);\n\n\t\t\tcolumn.modules.sort.element = arrowEl;\n\n\t\t\tthis.setColumnHeaderSortIcon(column, \"none\");\n\n\t\t\t//sort on click\n\t\t\t(this.table.options.headerSortClickElement === \"icon\" ? arrowEl : colEl).addEventListener(\"click\", (e) => {\n\t\t\t\tvar dir = \"\",\n\t\t\t\tsorters=[],\n\t\t\t\tmatch = false;\n\n\t\t\t\tif(column.modules.sort){\n\t\t\t\t\tif(column.modules.sort.tristate){\n\t\t\t\t\t\tif(column.modules.sort.dir == \"none\"){\n\t\t\t\t\t\t\tdir = column.modules.sort.startingDir;\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tif(column.modules.sort.dir == column.modules.sort.startingDir){\n\t\t\t\t\t\t\t\tdir = column.modules.sort.dir == \"asc\" ? \"desc\" : \"asc\";\n\t\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t\tdir = \"none\";\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tswitch(column.modules.sort.dir){\n\t\t\t\t\t\t\tcase \"asc\":\n\t\t\t\t\t\t\t\tdir = \"desc\";\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tcase \"desc\":\n\t\t\t\t\t\t\t\tdir = \"asc\";\n\t\t\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\tdir = column.modules.sort.startingDir;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (this.table.options.columnHeaderSortMulti && (e.shiftKey || e.ctrlKey)) {\n\t\t\t\t\t\tsorters = this.getSort();\n\n\t\t\t\t\t\tmatch = sorters.findIndex((sorter) => {\n\t\t\t\t\t\t\treturn sorter.field === column.getField();\n\t\t\t\t\t\t});\n\n\t\t\t\t\t\tif(match > -1){\n\t\t\t\t\t\t\tsorters[match].dir = dir;\n\n\t\t\t\t\t\t\tmatch = sorters.splice(match, 1)[0];\n\t\t\t\t\t\t\tif(dir != \"none\"){\n\t\t\t\t\t\t\t\tsorters.push(match);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tif(dir != \"none\"){\n\t\t\t\t\t\t\t\tsorters.push({column:column, dir:dir});\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t//add to existing sort\n\t\t\t\t\t\tthis.setSort(sorters);\n\t\t\t\t\t}else{\n\t\t\t\t\t\tif(dir == \"none\"){\n\t\t\t\t\t\t\tthis.clear();\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t//sort by column only\n\t\t\t\t\t\t\tthis.setSort(column, dir);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t}\n\n\t\t\t\t\t// this.table.rowManager.sorterRefresh(!this.sortList.length);\n\t\t\t\t\tthis.refreshSort();\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\trefreshSort(){\n\t\tif(this.table.options.sortMode === \"remote\"){\n\t\t\tthis.reloadData(null, false, false);\n\t\t}else{\n\t\t\tthis.refreshData(true);\n\t\t}\n\n\t\t//TODO - Persist left position of row manager\n\t\t// left = this.scrollLeft;\n\t\t// this.scrollHorizontal(left);\n\t}\n\n\t//check if the sorters have changed since last use\n\thasChanged(){\n\t\tvar changed = this.changed;\n\t\tthis.changed = false;\n\t\treturn changed;\n\t}\n\n\t//return current sorters\n\tgetSort(){\n\t\tvar self = this,\n\t\tsorters = [];\n\n\t\tself.sortList.forEach(function(item){\n\t\t\tif(item.column){\n\t\t\t\tsorters.push({column:item.column.getComponent(), field:item.column.getField(), dir:item.dir});\n\t\t\t}\n\t\t});\n\n\t\treturn sorters;\n\t}\n\n\t//change sort list and trigger sort\n\tsetSort(sortList, dir){\n\t\tvar self = this,\n\t\tnewSortList = [];\n\n\t\tif(!Array.isArray(sortList)){\n\t\t\tsortList = [{column: sortList, dir:dir}];\n\t\t}\n\n\t\tsortList.forEach(function(item){\n\t\t\tvar column;\n\n\t\t\tcolumn = self.table.columnManager.findColumn(item.column);\n\n\t\t\tif(column){\n\t\t\t\titem.column = column;\n\t\t\t\tnewSortList.push(item);\n\t\t\t\tself.changed = true;\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Sort Warning - Sort field does not exist and is being ignored: \", item.column);\n\t\t\t}\n\n\t\t});\n\n\t\tself.sortList = newSortList;\n\n\t\tthis.dispatch(\"sort-changed\");\n\t}\n\n\t//clear sorters\n\tclear(){\n\t\tthis.setSort([]);\n\t}\n\n\t//find appropriate sorter for column\n\tfindSorter(column){\n\t\tvar row = this.table.rowManager.activeRows[0],\n\t\tsorter = \"string\",\n\t\tfield, value;\n\n\t\tif(row){\n\t\t\trow = row.getData();\n\t\t\tfield = column.getField();\n\n\t\t\tif(field){\n\n\t\t\t\tvalue = column.getFieldValue(row);\n\n\t\t\t\tswitch(typeof value){\n\t\t\t\t\tcase \"undefined\":\n\t\t\t\t\t\tsorter = \"string\";\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"boolean\":\n\t\t\t\t\t\tsorter = \"boolean\";\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tif(!isNaN(value) && value !== \"\"){\n\t\t\t\t\t\t\tsorter = \"number\";\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tif(value.match(/((^[0-9]+[a-z]+)|(^[a-z]+[0-9]+))+$/i)){\n\t\t\t\t\t\t\t\tsorter = \"alphanum\";\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn Sort.sorters[sorter];\n\t}\n\n\t//work through sort list sorting data\n\tsort(data){\n\t\tvar self = this,\n\t\tsortList = this.table.options.sortOrderReverse ? self.sortList.slice().reverse() : self.sortList,\n\t\tsortListActual = [],\n\t\trowComponents = [];\n\n\t\tif(this.subscribedExternal(\"dataSorting\")){\n\t\t\tthis.dispatchExternal(\"dataSorting\", self.getSort());\n\t\t}\n\n\t\tself.clearColumnHeaders();\n\n\t\tif(this.table.options.sortMode !== \"remote\"){\n\n\t\t\t//build list of valid sorters and trigger column specific callbacks before sort begins\n\t\t\tsortList.forEach(function(item, i){\n\t\t\t\tvar sortObj;\n\n\t\t\t\tif(item.column){\n\t\t\t\t\tsortObj = item.column.modules.sort;\n\n\t\t\t\t\tif(sortObj){\n\n\t\t\t\t\t\t//if no sorter has been defined, take a guess\n\t\t\t\t\t\tif(!sortObj.sorter){\n\t\t\t\t\t\t\tsortObj.sorter = self.findSorter(item.column);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\titem.params = typeof sortObj.params === \"function\" ? sortObj.params(item.column.getComponent(), item.dir) : sortObj.params;\n\n\t\t\t\t\t\tsortListActual.push(item);\n\t\t\t\t\t}\n\n\t\t\t\t\tself.setColumnHeader(item.column, item.dir);\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t//sort data\n\t\t\tif (sortListActual.length) {\n\t\t\t\tself._sortItems(data, sortListActual);\n\t\t\t}\n\n\t\t}else{\n\t\t\tsortList.forEach(function(item, i){\n\t\t\t\tself.setColumnHeader(item.column, item.dir);\n\t\t\t});\n\t\t}\n\n\t\tif(this.subscribedExternal(\"dataSorted\")){\n\t\t\tdata.forEach((row) => {\n\t\t\t\trowComponents.push(row.getComponent());\n\t\t\t});\n\n\t\t\tthis.dispatchExternal(\"dataSorted\", self.getSort(), rowComponents);\n\t\t}\n\n\t\treturn data;\n\t}\n\n\t//clear sort arrows on columns\n\tclearColumnHeaders(){\n\t\tthis.table.columnManager.getRealColumns().forEach((column) => {\n\t\t\tif(column.modules.sort){\n\t\t\t\tcolumn.modules.sort.dir = \"none\";\n\t\t\t\tcolumn.getElement().setAttribute(\"aria-sort\", \"none\");\n\t\t\t\tthis.setColumnHeaderSortIcon(column, \"none\");\n\t\t\t}\n\t\t});\n\t}\n\n\t//set the column header sort direction\n\tsetColumnHeader(column, dir){\n\t\tcolumn.modules.sort.dir = dir;\n\t\tcolumn.getElement().setAttribute(\"aria-sort\", dir === \"asc\" ? \"ascending\" : \"descending\");\n\t\tthis.setColumnHeaderSortIcon(column, dir);\n\t}\n\n\tsetColumnHeaderSortIcon(column, dir){\n\t\tvar sortEl = column.modules.sort.element,\n\t\tarrowEl;\n\n\t\tif(column.definition.headerSort && typeof this.table.options.headerSortElement === \"function\"){\n\t\t\twhile(sortEl.firstChild) sortEl.removeChild(sortEl.firstChild);\n\n\t\t\tarrowEl = this.table.options.headerSortElement.call(this.table, column.getComponent(), dir);\n\t\t\t\n\t\t\tif(typeof arrowEl === \"object\"){\n\t\t\t\tsortEl.appendChild(arrowEl);\n\t\t\t}else{\n\t\t\t\tsortEl.innerHTML = arrowEl;\n\t\t\t}\n\t\t}\n\t}\n\n\t//sort each item in sort list\n\t_sortItems(data, sortList){\n\t\tvar sorterCount = sortList.length - 1;\n\n\t\tdata.sort((a, b) => {\n\t\t\tvar result;\n\n\t\t\tfor(var i = sorterCount; i>= 0; i--){\n\t\t\t\tlet sortItem = sortList[i];\n\n\t\t\t\tresult = this._sortRow(a, b, sortItem.column, sortItem.dir, sortItem.params);\n\n\t\t\t\tif(result !== 0){\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn result;\n\t\t});\n\t}\n\n\t//process individual rows for a sort function on active data\n\t_sortRow(a, b, column, dir, params){\n\t\tvar el1Comp, el2Comp;\n\n\t\t//switch elements depending on search direction\n\t\tvar el1 = dir == \"asc\" ? a : b;\n\t\tvar el2 = dir == \"asc\" ? b : a;\n\n\t\ta = column.getFieldValue(el1.getData());\n\t\tb = column.getFieldValue(el2.getData());\n\n\t\ta = typeof a !== \"undefined\" ? a : \"\";\n\t\tb = typeof b !== \"undefined\" ? b : \"\";\n\n\t\tel1Comp = el1.getComponent();\n\t\tel2Comp = el2.getComponent();\n\n\t\treturn column.modules.sort.sorter.call(this, a, b, el1Comp, el2Comp, column.getComponent(), dir, params);\n\t}\n}\n\nSort.moduleName = \"sort\";\n\n//load defaults\nSort.sorters = defaultSorters;\n\nexport default Sort;","import Module from '../../core/Module.js';\nimport Cell from '../../core/cell/Cell.js';\n\nclass Tooltip extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.tooltipSubscriber = null,\n\t\tthis.headerSubscriber = null,\n\t\t\n\t\tthis.timeout = null;\n\t\tthis.popupInstance = null;\n\t\t\n\t\tthis.registerTableOption(\"tooltipGenerationMode\", undefined); //deprecated\n\t\tthis.registerTableOption(\"tooltipDelay\", 300); \n\t\t\n\t\tthis.registerColumnOption(\"tooltip\");\n\t\tthis.registerColumnOption(\"headerTooltip\");\n\t}\n\t\n\tinitialize(){\n\t\tthis.deprecatedOptionsCheck();\n\t\t\n\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t}\n\t\n\tdeprecatedOptionsCheck(){\n\t\tthis.deprecationCheckMsg(\"tooltipGenerationMode\", \"This option is no longer needed as tooltips are always generated on hover now\");\n\t}\t\n\t\n\tinitializeColumn(column){\n\t\tif(column.definition.headerTooltip && !this.headerSubscriber){\n\t\t\tthis.headerSubscriber = true;\n\t\t\t\n\t\t\tthis.subscribe(\"column-mousemove\", this.mousemoveCheck.bind(this, \"headerTooltip\"));\n\t\t\tthis.subscribe(\"column-mouseout\", this.mouseoutCheck.bind(this, \"headerTooltip\"));\n\t\t}\n\t\t\n\t\tif(column.definition.tooltip && !this.tooltipSubscriber){\n\t\t\tthis.tooltipSubscriber = true;\n\t\t\t\n\t\t\tthis.subscribe(\"cell-mousemove\", this.mousemoveCheck.bind(this, \"tooltip\"));\n\t\t\tthis.subscribe(\"cell-mouseout\", this.mouseoutCheck.bind(this, \"tooltip\"));\n\t\t}\n\t}\n\t\n\tmousemoveCheck(action, e, component){\n\t\tvar tooltip = action === \"tooltip\" ? component.column.definition.tooltip : component.definition.headerTooltip;\n\t\t\n\t\tif(tooltip){\n\t\t\tthis.clearPopup();\n\t\t\tthis.timeout = setTimeout(this.loadTooltip.bind(this, e, component, tooltip), this.table.options.tooltipDelay);\n\t\t}\n\t}\n\n\tmouseoutCheck(action, e, component){\n\t\tif(!this.popupInstance){\n\t\t\tthis.clearPopup();\n\t\t}\n\t}\n\t\n\tclearPopup(action, e, component){\n\t\tclearTimeout(this.timeout);\n\t\tthis.timeout = null;\n\t\t\n\t\tif(this.popupInstance){\n\t\t\tthis.popupInstance.hide();\n\t\t}\n\t}\n\t\n\tloadTooltip(e, component, tooltip){\n\t\tvar contentsEl, renderedCallback, coords;\n\n\t\tfunction onRendered(callback){\n\t\t\trenderedCallback = callback;\n\t\t}\n\t\t\n\t\tif(typeof tooltip === \"function\"){\n\t\t\ttooltip = tooltip(e, component.getComponent(), onRendered);\n\t\t}\n\t\t\n\t\tif(tooltip instanceof HTMLElement){\n\t\t\tcontentsEl = tooltip;\n\t\t}else{\n\t\t\tcontentsEl = document.createElement(\"div\");\n\t\t\t\n\t\t\tif(tooltip === true){\n\t\t\t\tif(component instanceof Cell){\n\t\t\t\t\ttooltip = component.value;\n\t\t\t\t}else{\n\t\t\t\t\tif(component.definition.field){\n\t\t\t\t\t\tthis.langBind(\"columns|\" + component.definition.field, (value) => {\n\t\t\t\t\t\t\tcontentsEl.innerHTML = tooltip = value || component.definition.title;\n\t\t\t\t\t\t});\n\t\t\t\t\t}else{\n\t\t\t\t\t\ttooltip = component.definition.title;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tcontentsEl.innerHTML = tooltip;\n\t\t}\n\t\t\n\t\tif(tooltip || tooltip === 0 || tooltip === false){\n\t\t\tcontentsEl.classList.add(\"tabulator-tooltip\");\n\n\t\t\tcontentsEl.addEventListener(\"mousemove\", e => e.preventDefault());\n\t\t\t\n\t\t\tthis.popupInstance = this.popup(contentsEl);\n\t\t\t\n\t\t\tif(typeof renderedCallback === \"function\"){\n\t\t\t\tthis.popupInstance.renderCallback(renderedCallback);\n\t\t\t}\n\n\t\t\tcoords = this.popupInstance.containerEventCoords(e);\n\t\t\t\n\t\t\tthis.popupInstance.show(coords.x + 15, coords.y + 15).hideOnBlur(() => {\n\t\t\t\tthis.dispatchExternal(\"TooltipClosed\", component.getComponent());\n\t\t\t\tthis.popupInstance = null;\n\t\t\t});\n\t\t\t\n\t\t\tthis.dispatchExternal(\"TooltipOpened\", component.getComponent());\n\t\t}\n\t}\n}\n\nTooltip.moduleName = \"tooltip\";\n\nexport default Tooltip;\n","export default {\n\t//is integer\n\tinteger: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\n\t\tvalue = Number(value);\n\n\t\treturn !isNaN(value) && isFinite(value) && Math.floor(value) === value;\n\t},\n\n\t//is float\n\tfloat: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\t\n\t\tvalue = Number(value);\n\n\t\treturn !isNaN(value) && isFinite(value) && value % 1 !== 0;\n\t},\n\n\t//must be a number\n\tnumeric: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn !isNaN(value);\n\t},\n\n\t//must be a string\n\tstring: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn isNaN(value);\n\t},\n\n\t//maximum value\n\tmax: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn parseFloat(value) <= parameters;\n\t},\n\n\t//minimum value\n\tmin: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn parseFloat(value) >= parameters;\n\t},\n\n\t//starts with value\n\tstarts: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn String(value).toLowerCase().startsWith(String(parameters).toLowerCase());\n\t},\n\n\t//ends with value\n\tends: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn String(value).toLowerCase().endsWith(String(parameters).toLowerCase());\n\t},\n\n\n\t//minimum string length\n\tminLength: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn String(value).length >= parameters;\n\t},\n\n\t//maximum string length\n\tmaxLength: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\treturn String(value).length <= parameters;\n\t},\n\n\t//in provided value list\n\tin: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\n\t\tif(typeof parameters == \"string\"){\n\t\t\tparameters = parameters.split(\"|\");\n\t\t}\n\n\t\treturn parameters.indexOf(value) > -1;\n\t},\n\n\t//must match provided regex\n\tregex: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\tvar reg = new RegExp(parameters);\n\n\t\treturn reg.test(value);\n\t},\n\n\t//value must be unique in this column\n\tunique: function(cell, value, parameters){\n\t\tif(value === \"\" || value === null || typeof value === \"undefined\"){\n\t\t\treturn true;\n\t\t}\n\t\tvar unique = true;\n\n\t\tvar cellData = cell.getData();\n\t\tvar column = cell.getColumn()._getSelf();\n\n\t\tthis.table.rowManager.rows.forEach(function(row){\n\t\t\tvar data = row.getData();\n\n\t\t\tif(data !== cellData){\n\t\t\t\tif(value == column.getFieldValue(data)){\n\t\t\t\t\tunique = false;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\treturn unique;\n\t},\n\n\t//must have a value\n\trequired:function(cell, value, parameters){\n\t\treturn value !== \"\" && value !== null && typeof value !== \"undefined\";\n\t},\n};","import Module from '../../core/Module.js';\n\nimport defaultValidators from './defaults/validators.js';\n\nclass Validate extends Module{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.invalidCells = [];\n\t\t\n\t\tthis.registerTableOption(\"validationMode\", \"blocking\");\n\t\t\n\t\tthis.registerColumnOption(\"validator\");\n\t\t\n\t\tthis.registerTableFunction(\"getInvalidCells\", this.getInvalidCells.bind(this));\n\t\tthis.registerTableFunction(\"clearCellValidation\", this.userClearCellValidation.bind(this));\n\t\tthis.registerTableFunction(\"validate\", this.userValidate.bind(this));\n\t\t\n\t\tthis.registerComponentFunction(\"cell\", \"isValid\", this.cellIsValid.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"clearValidation\", this.clearValidation.bind(this));\n\t\tthis.registerComponentFunction(\"cell\", \"validate\", this.cellValidate.bind(this));\n\t\t\n\t\tthis.registerComponentFunction(\"column\", \"validate\", this.columnValidate.bind(this));\n\t\tthis.registerComponentFunction(\"row\", \"validate\", this.rowValidate.bind(this));\n\t}\n\t\n\t\n\tinitialize(){\n\t\tthis.subscribe(\"cell-delete\", this.clearValidation.bind(this));\n\t\tthis.subscribe(\"column-layout\", this.initializeColumnCheck.bind(this));\n\t\t\n\t\tthis.subscribe(\"edit-success\", this.editValidate.bind(this));\n\t\tthis.subscribe(\"edit-editor-clear\", this.editorClear.bind(this));\n\t\tthis.subscribe(\"edit-edited-clear\", this.editedClear.bind(this));\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Event Handling //////////\n\t///////////////////////////////////\n\t\n\teditValidate(cell, value, previousValue){\n\t\tvar valid = this.table.options.validationMode !== \"manual\" ? this.validate(cell.column.modules.validate, cell, value) : true;\n\t\t\n\t\t// allow time for editor to make render changes then style cell\n\t\tif(valid !== true){\n\t\t\tsetTimeout(() => {\n\t\t\t\tcell.getElement().classList.add(\"tabulator-validation-fail\");\n\t\t\t\tthis.dispatchExternal(\"validationFailed\", cell.getComponent(), value, valid);\n\t\t\t});\n\t\t}\n\t\t\n\t\treturn valid;\n\t}\n\t\n\teditorClear(cell, cancelled){\n\t\tif(cancelled){\n\t\t\tif(cell.column.modules.validate){\n\t\t\t\tthis.cellValidate(cell);\n\t\t\t}\n\t\t}\n\n\t\tcell.getElement().classList.remove(\"tabulator-validation-fail\");\n\t}\n\t\n\teditedClear(cell){\n\t\tif(cell.modules.validate){\n\t\t\tcell.modules.validate.invalid = false;\n\t\t}\n\t}\n\t\n\t///////////////////////////////////\n\t////////// Cell Functions /////////\n\t///////////////////////////////////\n\t\n\tcellIsValid(cell){\n\t\treturn cell.modules.validate ? (cell.modules.validate.invalid || true) : true;\n\t}\n\t\n\tcellValidate(cell){\n\t\treturn this.validate(cell.column.modules.validate, cell, cell.getValue());\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Column Functions ////////\n\t///////////////////////////////////\n\t\n\tcolumnValidate(column){\n\t\tvar invalid = [];\n\t\t\n\t\tcolumn.cells.forEach((cell) => {\n\t\t\tif(this.cellValidate(cell) !== true){\n\t\t\t\tinvalid.push(cell.getComponent());\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn invalid.length ? invalid : true;\n\t}\n\t\n\t///////////////////////////////////\n\t////////// Row Functions //////////\n\t///////////////////////////////////\n\t\n\trowValidate(row){\n\t\tvar invalid = [];\n\t\t\n\t\trow.cells.forEach((cell) => {\n\t\t\tif(this.cellValidate(cell) !== true){\n\t\t\t\tinvalid.push(cell.getComponent());\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn invalid.length ? invalid : true;\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Table Functions /////////\n\t///////////////////////////////////\n\t\n\t\n\tuserClearCellValidation(cells){\n\t\tif(!cells){\n\t\t\tcells = this.getInvalidCells();\n\t\t}\n\t\t\n\t\tif(!Array.isArray(cells)){\n\t\t\tcells = [cells];\n\t\t}\n\t\t\n\t\tcells.forEach((cell) => {\n\t\t\tthis.clearValidation(cell._getSelf());\n\t\t});\n\t}\n\t\n\tuserValidate(cells){\n\t\tvar output = [];\n\t\t\n\t\t//clear row data\n\t\tthis.table.rowManager.rows.forEach((row) => {\n\t\t\trow = row.getComponent();\n\t\t\t\n\t\t\tvar valid = row.validate();\n\t\t\t\n\t\t\tif(valid !== true){\n\t\t\t\toutput = output.concat(valid);\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn output.length ? output : true;\n\t}\n\t\n\t///////////////////////////////////\n\t///////// Internal Logic //////////\n\t///////////////////////////////////\n\t\n\tinitializeColumnCheck(column){\n\t\tif(typeof column.definition.validator !== \"undefined\"){\n\t\t\tthis.initializeColumn(column);\n\t\t}\n\t}\n\t\n\t//validate\n\tinitializeColumn(column){\n\t\tvar self = this,\n\t\tconfig = [],\n\t\tvalidator;\n\t\t\n\t\tif(column.definition.validator){\n\t\t\t\n\t\t\tif(Array.isArray(column.definition.validator)){\n\t\t\t\tcolumn.definition.validator.forEach((item) => {\n\t\t\t\t\tvalidator = self._extractValidator(item);\n\t\t\t\t\t\n\t\t\t\t\tif(validator){\n\t\t\t\t\t\tconfig.push(validator);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\t\n\t\t\t}else{\n\t\t\t\tvalidator = this._extractValidator(column.definition.validator);\n\t\t\t\t\n\t\t\t\tif(validator){\n\t\t\t\t\tconfig.push(validator);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tcolumn.modules.validate = config.length ? config : false;\n\t\t}\n\t}\n\t\n\t_extractValidator(value){\n\t\tvar type, params, pos;\n\t\t\n\t\tswitch(typeof value){\n\t\t\tcase \"string\":\n\t\t\t\tpos = value.indexOf(':');\n\t\t\t\n\t\t\t\tif(pos > -1){\n\t\t\t\t\ttype = value.substring(0,pos);\n\t\t\t\t\tparams = value.substring(pos+1);\n\t\t\t\t}else{\n\t\t\t\t\ttype = value;\n\t\t\t\t}\n\t\t\t\n\t\t\t\treturn this._buildValidator(type, params);\n\t\t\t\n\t\t\tcase \"function\":\n\t\t\t\treturn this._buildValidator(value);\n\t\t\t\n\t\t\tcase \"object\":\n\t\t\t\treturn this._buildValidator(value.type, value.parameters);\n\t\t}\n\t}\n\t\n\t_buildValidator(type, params){\n\t\t\n\t\tvar func = typeof type == \"function\" ? type : Validate.validators[type];\n\t\t\n\t\tif(!func){\n\t\t\tconsole.warn(\"Validator Setup Error - No matching validator found:\", type);\n\t\t\treturn false;\n\t\t}else{\n\t\t\treturn {\n\t\t\t\ttype:typeof type == \"function\" ? \"function\" : type,\n\t\t\t\tfunc:func,\n\t\t\t\tparams:params,\n\t\t\t};\n\t\t}\n\t}\n\t\n\tvalidate(validators, cell, value){\n\t\tvar self = this,\n\t\tfailedValidators = [],\n\t\tinvalidIndex = this.invalidCells.indexOf(cell);\n\t\t\n\t\tif(validators){\n\t\t\tvalidators.forEach((item) => {\n\t\t\t\tif(!item.func.call(self, cell.getComponent(), value, item.params)){\n\t\t\t\t\tfailedValidators.push({\n\t\t\t\t\t\ttype:item.type,\n\t\t\t\t\t\tparameters:item.params\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t\t\n\t\tif(!cell.modules.validate){\n\t\t\tcell.modules.validate = {};\n\t\t}\n\t\t\n\t\tif(!failedValidators.length){\n\t\t\tcell.modules.validate.invalid = false;\n\t\t\tcell.getElement().classList.remove(\"tabulator-validation-fail\");\n\t\t\t\n\t\t\tif(invalidIndex > -1){\n\t\t\t\tthis.invalidCells.splice(invalidIndex, 1);\n\t\t\t}\n\t\t}else{\n\t\t\tcell.modules.validate.invalid = failedValidators;\n\t\t\t\n\t\t\tif(this.table.options.validationMode !== \"manual\"){\n\t\t\t\tcell.getElement().classList.add(\"tabulator-validation-fail\");\n\t\t\t}\n\t\t\t\n\t\t\tif(invalidIndex == -1){\n\t\t\t\tthis.invalidCells.push(cell);\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn failedValidators.length ? failedValidators : true;\n\t}\n\t\n\tgetInvalidCells(){\n\t\tvar output = [];\n\t\t\n\t\tthis.invalidCells.forEach((cell) => {\n\t\t\toutput.push(cell.getComponent());\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tclearValidation(cell){\n\t\tvar invalidIndex;\n\t\t\n\t\tif(cell.modules.validate && cell.modules.validate.invalid){\n\t\t\t\n\t\t\tcell.getElement().classList.remove(\"tabulator-validation-fail\");\n\t\t\tcell.modules.validate.invalid = false;\n\t\t\t\n\t\t\tinvalidIndex = this.invalidCells.indexOf(cell);\n\t\t\t\n\t\t\tif(invalidIndex > -1){\n\t\t\t\tthis.invalidCells.splice(invalidIndex, 1);\n\t\t\t}\n\t\t}\n\t}\n}\n\nValidate.moduleName = \"validate\";\n\n//load defaults\nValidate.validators = defaultValidators;\n\nexport default Validate;\n","export default class OptionsList {\n\tconstructor(table, msgType, defaults = {}){\n\t\tthis.table = table;\n\t\tthis.msgType = msgType;\n\t\tthis.registeredDefaults = Object.assign({}, defaults);\n\t}\n\t\n\tregister(option, value){\n\t\tthis.registeredDefaults[option] = value;\n\t}\n\t\n\tgenerate(defaultOptions, userOptions = {}){\n\t\tvar output = Object.assign({}, this.registeredDefaults),\n\t\twarn = this.table.options.debugInvalidOptions || userOptions.debugInvalidOptions === true;\n\t\t\n\t\tObject.assign(output, defaultOptions);\n\t\t\n\t\tfor (let key in userOptions){\n\t\t\tif(!output.hasOwnProperty(key)){\n\t\t\t\tif(warn){\n\t\t\t\t\tconsole.warn(\"Invalid \" + this.msgType + \" option:\", key);\n\t\t\t\t}\n\n\t\t\t\toutput[key] = userOptions.key;\n\t\t\t}\n\t\t}\n\t\n\t\t\n\t\tfor (let key in output){\n\t\t\tif(key in userOptions){\n\t\t\t\toutput[key] = userOptions[key];\n\t\t\t}else{\n\t\t\t\tif(Array.isArray(output[key])){\n\t\t\t\t\toutput[key] = Object.assign([], output[key]);\n\t\t\t\t}else if(typeof output[key] === \"object\" && output[key] !== null){\n\t\t\t\t\toutput[key] = Object.assign({}, output[key]);\n\t\t\t\t}else if (typeof output[key] === \"undefined\"){\n\t\t\t\t\tdelete output[key];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn output;\n\t}\n}","import CoreFeature from '../CoreFeature.js';\nimport Helpers from '../tools/Helpers.js';\n\nexport default class Renderer extends CoreFeature{\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.elementVertical = table.rowManager.element;\n\t\tthis.elementHorizontal = table.columnManager.element;\n\t\tthis.tableElement = table.rowManager.tableElement;\n\n\t\tthis.verticalFillMode = \"fit\"; // used by row manager to determine how to size the render area (\"fit\" - fits container to the contents, \"fill\" - fills the container without resizing it)\n\t}\n\n\n\t///////////////////////////////////\n\t/////// Internal Bindings /////////\n\t///////////////////////////////////\n\n\tinitialize(){\n\t\t//initialize core functionality\n\t}\n\n\tclearRows(){\n\t\t//clear down existing rows layout\n\t}\n\n\tclearColumns(){\n\t\t//clear down existing columns layout\n\t}\n\n\n\treinitializeColumnWidths(columns){\n\t\t//resize columns to fit data\n\t}\n\n\n\trenderRows(){\n\t\t//render rows from a clean slate\n\t}\n\n\trenderColumns(){\n\t\t//render columns from a clean slate\n\t}\n\n\trerenderRows(callback){\n\t\t// rerender rows and keep position\n\t\tif(callback){\n\t\t\tcallback();\n\t\t}\n\t}\n\n\trerenderColumns(update, blockRedraw){\n\t\t//rerender columns\n\t}\n\n\trenderRowCells(row){\n\t\t//render the cells in a row\n\t}\n\n\trerenderRowCells(row, force){\n\t\t//rerender the cells in a row\n\t}\n\n\tscrollColumns(left, dir){\n\t\t//handle horizontal scrolling\n\t}\n\n\tscrollRows(top, dir){\n\t\t//handle vertical scrolling\n\t}\n\n\tresize(){\n\t\t//container has resized, carry out any needed recalculations (DO NOT RERENDER IN THIS FUNCTION)\n\t}\n\n\tscrollToRow(row){\n\t\t//scroll to a specific row\n\t}\n\n\tscrollToRowNearestTop(row){\n\t\t//determine weather the row is nearest the top or bottom of the table, return true for top or false for bottom\n\t}\n\n\tvisibleRows(includingBuffer){\n\t\t//return the visible rows\n\t\treturn [];\n\t}\n\n\t///////////////////////////////////\n\t//////// Helper Functions /////////\n\t///////////////////////////////////\n\n\trows(){\n\t\treturn this.table.rowManager.getDisplayRows();\n\t}\n\n\tstyleRow(row, index){\n\t\tvar rowEl = row.getElement();\n\n\t\tif(index % 2){\n\t\t\trowEl.classList.add(\"tabulator-row-even\");\n\t\t\trowEl.classList.remove(\"tabulator-row-odd\");\n\t\t}else{\n\t\t\trowEl.classList.add(\"tabulator-row-odd\");\n\t\t\trowEl.classList.remove(\"tabulator-row-even\");\n\t\t}\n\t}\n\n\t///////////////////////////////////\n\t/////// External Triggers /////////\n\t/////// (DO NOT OVERRIDE) /////////\n\t///////////////////////////////////\n\n\tclear(){\n\t\t//clear down existing layout\n\t\tthis.clearRows();\n\t\tthis.clearColumns();\n\t}\n\n\trender(){\n\t\t//render from a clean slate\n\t\tthis.renderRows();\n\t\tthis.renderColumns();\n\t}\n\n\trerender(callback){\n\t\t// rerender and keep position\n\t\tthis.rerenderRows();\n\t\tthis.rerenderColumns();\n\t}\n\n\tscrollToRowPosition(row, position, ifVisible){\n\t\tvar rowIndex = this.rows().indexOf(row),\n\t\trowEl = row.getElement(),\n\t\toffset = 0;\n\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif(rowIndex > -1){\n\n\t\t\t\tif(typeof ifVisible === \"undefined\"){\n\t\t\t\t\tifVisible = this.table.options.scrollToRowIfVisible;\n\t\t\t\t}\n\n\t\t\t\t//check row visibility\n\t\t\t\tif(!ifVisible){\n\t\t\t\t\tif(Helpers.elVisible(rowEl)){\n\t\t\t\t\t\toffset = Helpers.elOffset(rowEl).top - Helpers.elOffset(this.elementVertical).top;\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(offset > 0 && offset < this.elementVertical.clientHeight - rowEl.offsetHeight){\n\t\t\t\t\t\t\tresolve();\n\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif(typeof position === \"undefined\"){\n\t\t\t\t\tposition = this.table.options.scrollToRowPosition;\n\t\t\t\t}\n\n\t\t\t\tif(position === \"nearest\"){\n\t\t\t\t\tposition = this.scrollToRowNearestTop(row) ? \"top\" : \"bottom\";\n\t\t\t\t}\n\n\t\t\t\t//scroll to row\n\t\t\t\tthis.scrollToRow(row);\n\n\t\t\t\t//align to correct position\n\t\t\t\tswitch(position){\n\t\t\t\t\tcase \"middle\":\n\t\t\t\t\tcase \"center\":\n\n\t\t\t\t\t\tif(this.elementVertical.scrollHeight - this.elementVertical.scrollTop == this.elementVertical.clientHeight){\n\t\t\t\t\t\t\tthis.elementVertical.scrollTop = this.elementVertical.scrollTop + (rowEl.offsetTop - this.elementVertical.scrollTop) - ((this.elementVertical.scrollHeight - rowEl.offsetTop) / 2);\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tthis.elementVertical.scrollTop = this.elementVertical.scrollTop - (this.elementVertical.clientHeight / 2);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"bottom\":\n\n\t\t\t\t\t\tif(this.elementVertical.scrollHeight - this.elementVertical.scrollTop == this.elementVertical.clientHeight){\n\t\t\t\t\t\t\tthis.elementVertical.scrollTop = this.elementVertical.scrollTop - (this.elementVertical.scrollHeight - rowEl.offsetTop) + rowEl.offsetHeight;\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tthis.elementVertical.scrollTop = this.elementVertical.scrollTop - this.elementVertical.clientHeight + rowEl.offsetHeight;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase \"top\":\n\t\t\t\t\t\tthis.elementVertical.scrollTop = rowEl.offsetTop;\t\t\t\t\t\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tresolve();\n\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Scroll Error - Row not visible\");\n\t\t\t\treject(\"Scroll Error - Row not visible\");\n\t\t\t}\n\t\t});\n\t}\n}","import Renderer from '../Renderer.js';\n\nexport default class BasicHorizontal extends Renderer{\n\tconstructor(table){\n\t\tsuper(table);\n\t}\n\t\n\trenderRowCells(row, inFragment) {\n\t\tconst rowFrag = document.createDocumentFragment();\n\t\trow.cells.forEach((cell) => {\n\t\t\trowFrag.appendChild(cell.getElement());\n\t\t});\n\t\trow.element.appendChild(rowFrag);\n\t\t\n\t\tif(!inFragment){\n\t\t\trow.cells.forEach((cell) => {\n\t\t\t\tcell.cellRendered();\n\t\t\t});\n\t\t}\n\t}\n\t\n\treinitializeColumnWidths(columns){\n\t\tcolumns.forEach(function(column){\n\t\t\tcolumn.reinitializeWidth();\n\t\t});\n\t}\n}","import Renderer from '../Renderer.js';\n\nexport default class VirtualDomHorizontal extends Renderer{\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.leftCol = 0;\n\t\tthis.rightCol = 0;\n\t\tthis.scrollLeft = 0;\n\t\t\n\t\tthis.vDomScrollPosLeft = 0;\n\t\tthis.vDomScrollPosRight = 0;\n\t\t\n\t\tthis.vDomPadLeft = 0;\n\t\tthis.vDomPadRight = 0;\n\t\t\n\t\tthis.fitDataColAvg = 0;\n\t\t\n\t\tthis.windowBuffer = 200; //pixel margin to make column visible before it is shown on screen\n\t\t\n\t\tthis.visibleRows = null;\n\t\t\n\t\tthis.initialized = false;\n\t\tthis.isFitData = false;\n\t\t\n\t\tthis.columns = [];\n\t}\n\t\n\tinitialize(){\n\t\tthis.compatibilityCheck();\n\t\tthis.layoutCheck();\n\t\tthis.vertScrollListen();\n\t}\n\t\n\tcompatibilityCheck(){\t\t\n\t\tif(this.options(\"layout\") == \"fitDataTable\"){\n\t\t\tconsole.warn(\"Horizontal Virtual DOM is not compatible with fitDataTable layout mode\");\n\t\t}\n\t\t\n\t\tif(this.options(\"responsiveLayout\")){\n\t\t\tconsole.warn(\"Horizontal Virtual DOM is not compatible with responsive columns\");\n\t\t}\n\t\t\n\t\tif(this.options(\"rtl\")){\n\t\t\tconsole.warn(\"Horizontal Virtual DOM is not currently compatible with RTL text direction\");\n\t\t}\n\t}\n\t\n\tlayoutCheck(){\n\t\tthis.isFitData = this.options(\"layout\").startsWith('fitData');\n\t}\n\t\n\tvertScrollListen(){\n\t\tthis.subscribe(\"scroll-vertical\", this.clearVisRowCache.bind(this));\n\t\tthis.subscribe(\"data-refreshed\", this.clearVisRowCache.bind(this));\n\t}\n\t\n\tclearVisRowCache(){\n\t\tthis.visibleRows = null;\n\t}\n\t\n\t//////////////////////////////////////\n\t///////// Public Functions ///////////\n\t//////////////////////////////////////\n\t\n\trenderColumns(row, force){\n\t\tthis.dataChange();\n\t}\n\t\n\t\n\tscrollColumns(left, dir){\n\t\tif(this.scrollLeft != left){\n\t\t\tthis.scrollLeft = left;\n\t\t\t\n\t\t\tthis.scroll(left - (this.vDomScrollPosLeft + this.windowBuffer));\n\t\t}\n\t}\n\t\n\tcalcWindowBuffer(){\n\t\tvar buffer = this.elementVertical.clientWidth;\n\t\t\n\t\tthis.table.columnManager.columnsByIndex.forEach((column) => {\n\t\t\tif(column.visible){\n\t\t\t\tvar width = column.getWidth();\n\t\t\t\t\n\t\t\t\tif(width > buffer){\n\t\t\t\t\tbuffer = width;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\t\n\t\tthis.windowBuffer = buffer * 2;\n\t}\n\t\n\trerenderColumns(update, blockRedraw){\t\t\n\t\tvar old = {\n\t\t\tcols:this.columns,\n\t\t\tleftCol:this.leftCol,\n\t\t\trightCol:this.rightCol,\n\t\t},\n\t\tcolPos = 0;\n\t\t\n\t\tif(update && !this.initialized){\n\t\t\treturn;\n\t\t}\n\t\t\n\t\tthis.clear();\n\t\t\n\t\tthis.calcWindowBuffer();\n\t\t\n\t\tthis.scrollLeft = this.elementVertical.scrollLeft;\n\t\t\n\t\tthis.vDomScrollPosLeft = this.scrollLeft - this.windowBuffer;\n\t\tthis.vDomScrollPosRight = this.scrollLeft + this.elementVertical.clientWidth + this.windowBuffer;\n\t\t\n\t\tthis.table.columnManager.columnsByIndex.forEach((column) => {\n\t\t\tvar config = {},\n\t\t\twidth;\n\t\t\t\n\t\t\tif(column.visible){\n\t\t\t\tif(!column.modules.frozen){\t\t\t\n\t\t\t\t\twidth = column.getWidth();\n\n\t\t\t\t\tconfig.leftPos = colPos;\n\t\t\t\t\tconfig.rightPos = colPos + width;\n\t\t\t\t\t\n\t\t\t\t\tconfig.width = width;\n\t\t\t\t\t\n\t\t\t\t\tif (this.isFitData) {\n\t\t\t\t\t\tconfig.fitDataCheck = column.modules.vdomHoz ? column.modules.vdomHoz.fitDataCheck : true;\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tif((colPos + width > this.vDomScrollPosLeft) && (colPos < this.vDomScrollPosRight)){\n\t\t\t\t\t\t//column is visible\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(this.leftCol == -1){\n\t\t\t\t\t\t\tthis.leftCol = this.columns.length;\n\t\t\t\t\t\t\tthis.vDomPadLeft = colPos;\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t\tthis.rightCol = this.columns.length;\n\t\t\t\t\t}else{\n\t\t\t\t\t\t// column is hidden\n\t\t\t\t\t\tif(this.leftCol !== -1){\n\t\t\t\t\t\t\tthis.vDomPadRight += width;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tthis.columns.push(column);\n\t\t\t\t\t\n\t\t\t\t\tcolumn.modules.vdomHoz = config;\n\t\t\t\t\t\n\t\t\t\t\tcolPos += width;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t\t\n\t\tthis.tableElement.style.paddingLeft = this.vDomPadLeft + \"px\";\n\t\tthis.tableElement.style.paddingRight = this.vDomPadRight + \"px\";\n\t\t\n\t\tthis.initialized = true;\n\t\t\n\t\tif(!blockRedraw){\n\t\t\tif(!update || this.reinitChanged(old)){\n\t\t\t\tthis.reinitializeRows();\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.elementVertical.scrollLeft = this.scrollLeft;\n\t}\n\t\n\trenderRowCells(row){\n\t\tif(this.initialized){\n\t\t\tthis.initializeRow(row);\n\t\t}else{\n\t\t\tconst rowFrag = document.createDocumentFragment();\n\t\t\trow.cells.forEach((cell) => {\n\t\t\t\trowFrag.appendChild(cell.getElement());\n\t\t\t});\n\t\t\trow.element.appendChild(rowFrag);\n\n\t\t\trow.cells.forEach((cell) => {\n\t\t\t\tcell.cellRendered();\n\t\t\t});\n\t\t}\n\t}\n\t\n\trerenderRowCells(row, force){\n\t\tthis.reinitializeRow(row, force);\n\t}\n\t\n\treinitializeColumnWidths(columns){\n\t\tfor(let i = this.leftCol; i <= this.rightCol; i++){\n\t\t\tthis.columns[i].reinitializeWidth();\n\t\t}\n\t}\n\t\n\t//////////////////////////////////////\n\t//////// Internal Rendering //////////\n\t//////////////////////////////////////\n\t\n\tdeinitialize(){\n\t\tthis.initialized = false;\n\t}\n\t\n\tclear(){\n\t\tthis.columns = [];\n\t\t\n\t\tthis.leftCol = -1;\n\t\tthis.rightCol = 0;\n\t\t\n\t\tthis.vDomScrollPosLeft = 0;\n\t\tthis.vDomScrollPosRight = 0;\n\t\tthis.vDomPadLeft = 0;\n\t\tthis.vDomPadRight = 0;\n\t}\n\t\n\tdataChange(){\n\t\tvar change = false,\n\t\trow, rowEl;\n\t\t\n\t\tif(this.isFitData){\n\t\t\tthis.table.columnManager.columnsByIndex.forEach((column) => {\n\t\t\t\tif(!column.definition.width && column.visible){\n\t\t\t\t\tchange = true;\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tif(change && this.table.rowManager.getDisplayRows().length){\n\t\t\t\tthis.vDomScrollPosRight = this.scrollLeft + this.elementVertical.clientWidth + this.windowBuffer;\n\t\t\t\t\n\t\t\t\trow = this.chain(\"rows-sample\", [1], [], () => {\n\t\t\t\t\treturn this.table.rowManager.getDisplayRows();\n\t\t\t\t})[0];\n\t\t\t\t\n\t\t\t\tif(row){\n\t\t\t\t\trowEl = row.getElement();\n\t\t\t\t\t\n\t\t\t\t\trow.generateCells();\n\t\t\t\t\t\n\t\t\t\t\tthis.tableElement.appendChild(rowEl);\n\t\t\t\t\t\n\t\t\t\t\tfor(let colEnd = 0; colEnd < row.cells.length; colEnd++){\n\t\t\t\t\t\tlet cell = row.cells[colEnd];\n\t\t\t\t\t\trowEl.appendChild(cell.getElement());\n\t\t\t\t\t\t\n\t\t\t\t\t\tcell.column.reinitializeWidth();\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\trowEl.parentNode.removeChild(rowEl);\n\t\t\t\t\t\n\t\t\t\t\tthis.rerenderColumns(false, true);\n\t\t\t\t}\n\t\t\t}\n\t\t}else{\n\t\t\tif(this.options(\"layout\") === \"fitColumns\"){\n\t\t\t\tthis.layoutRefresh();\n\t\t\t\tthis.rerenderColumns(false, true);\n\t\t\t}\n\t\t}\n\t}\n\t\n\treinitChanged(old){\n\t\tvar match = true;\n\t\t\n\t\tif(old.cols.length !== this.columns.length || old.leftCol !== this.leftCol || old.rightCol !== this.rightCol){\n\t\t\treturn true;\n\t\t}\n\t\t\n\t\told.cols.forEach((col, i) => {\n\t\t\tif(col !== this.columns[i]){\n\t\t\t\tmatch = false;\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn !match;\n\t}\n\t\n\treinitializeRows(){\n\t\tvar visibleRows = this.getVisibleRows(),\n\t\totherRows = this.table.rowManager.getRows().filter(row => !visibleRows.includes(row));\n\n\t\tvisibleRows.forEach((row) => {\n\t\t\tthis.reinitializeRow(row, true);\n\t\t});\n\n\t\totherRows.forEach((row) =>{\n\t\t\trow.deinitialize();\n\t\t});\n\t}\n\t\n\tgetVisibleRows(){\n\t\tif (!this.visibleRows){\n\t\t\tthis.visibleRows = this.table.rowManager.getVisibleRows();\n\t\t}\n\t\t\n\t\treturn this.visibleRows;\t\n\t}\n\t\n\tscroll(diff){\n\t\tthis.vDomScrollPosLeft += diff;\n\t\tthis.vDomScrollPosRight += diff;\n\t\t\n\t\tif(Math.abs(diff) > (this.windowBuffer / 2)){\n\t\t\tthis.rerenderColumns();\n\t\t}else{\n\t\t\tif(diff > 0){\n\t\t\t\t//scroll right\n\t\t\t\tthis.addColRight();\n\t\t\t\tthis.removeColLeft();\n\t\t\t}else{\n\t\t\t\t//scroll left\n\t\t\t\tthis.addColLeft();\n\t\t\t\tthis.removeColRight();\n\t\t\t}\n\t\t}\n\t}\n\t\n\tcolPositionAdjust (start, end, diff){\n\t\tfor(let i = start; i < end; i++){\n\t\t\tlet column = this.columns[i];\n\t\t\t\n\t\t\tcolumn.modules.vdomHoz.leftPos += diff;\n\t\t\tcolumn.modules.vdomHoz.rightPos += diff;\n\t\t}\n\t}\n\t\n\taddColRight(){\n\t\tvar changes = false,\n\t\tworking = true;\n\t\t\n\t\twhile(working){\n\n\t\t\tlet column = this.columns[this.rightCol + 1];\n\t\t\t\n\t\t\tif(column){\n\t\t\t\tif(column.modules.vdomHoz.leftPos <= this.vDomScrollPosRight){\n\t\t\t\t\tchanges = true;\n\t\t\t\t\t\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\tvar cell = row.getCell(column);\n\t\t\t\t\t\t\trow.getElement().insertBefore(cell.getElement(), row.getCell(this.columns[this.rightCol]).getElement().nextSibling);\n\t\t\t\t\t\t\tcell.cellRendered();\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tthis.fitDataColActualWidthCheck(column);\n\t\t\t\t\t\n\t\t\t\t\tthis.rightCol++; // Don't move this below the >= check below\n\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\trow.modules.vdomHoz.rightCol = this.rightCol;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tif(this.rightCol >= (this.columns.length - 1)){\n\t\t\t\t\t\tthis.vDomPadRight = 0;\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.vDomPadRight -= column.getWidth();\n\t\t\t\t\t}\t\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(changes){\n\t\t\tthis.tableElement.style.paddingRight = this.vDomPadRight + \"px\";\n\t\t}\n\t}\n\t\n\taddColLeft(){\n\t\tvar changes = false,\n\t\tworking = true;\n\t\t\n\t\twhile(working){\n\t\t\tlet column = this.columns[this.leftCol - 1];\n\t\t\t\n\t\t\tif(column){\n\t\t\t\tif(column.modules.vdomHoz.rightPos >= this.vDomScrollPosLeft){\n\t\t\t\t\tchanges = true;\n\t\t\t\t\t\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\tvar cell = row.getCell(column);\n\t\t\t\t\t\t\trow.getElement().insertBefore(cell.getElement(), row.getCell(this.columns[this.leftCol]).getElement());\n\t\t\t\t\t\t\tcell.cellRendered();\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tthis.leftCol--; // don't move this below the <= check below\n\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\trow.modules.vdomHoz.leftCol = this.leftCol;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tif(this.leftCol <= 0){ // replicating logic in addColRight\n\t\t\t\t\t\tthis.vDomPadLeft = 0;\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.vDomPadLeft -= column.getWidth();\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tlet diff = this.fitDataColActualWidthCheck(column);\n\t\t\t\t\t\n\t\t\t\t\tif(diff){\n\t\t\t\t\t\tthis.scrollLeft = this.elementVertical.scrollLeft = this.elementVertical.scrollLeft + diff;\n\t\t\t\t\t\tthis.vDomPadRight -= diff;\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(changes){\n\t\t\tthis.tableElement.style.paddingLeft = this.vDomPadLeft + \"px\";\n\t\t}\n\t}\n\t\n\tremoveColRight(){\n\t\tvar changes = false,\n\t\tworking = true;\n\t\t\n\t\twhile(working){\n\t\t\tlet column = this.columns[this.rightCol];\n\t\t\t\n\t\t\tif(column){\n\t\t\t\tif(column.modules.vdomHoz.leftPos > this.vDomScrollPosRight){\n\t\t\t\t\tchanges = true;\n\t\t\t\t\t\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\tvar cell = row.getCell(column);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\trow.getElement().removeChild(cell.getElement());\n\t\t\t\t\t\t\t} catch (ex) {\n\t\t\t\t\t\t\t\tconsole.warn(\"Could not removeColRight\", ex.message);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tthis.vDomPadRight += column.getWidth();\n\t\t\t\t\tthis.rightCol --;\n\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\trow.modules.vdomHoz.rightCol = this.rightCol;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(changes){\n\t\t\tthis.tableElement.style.paddingRight = this.vDomPadRight + \"px\";\n\t\t}\n\t}\n\t\n\tremoveColLeft(){\n\t\tvar changes = false,\n\t\tworking = true;\n\n\t\twhile(working){\n\t\t\tlet column = this.columns[this.leftCol];\n\t\t\t\n\t\t\tif(column){\n\t\t\t\tif(column.modules.vdomHoz.rightPos < this.vDomScrollPosLeft){\n\t\t\t\t\tchanges = true;\n\t\t\t\t\t\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\t\t\t\t\t\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\tvar cell = row.getCell(column);\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\trow.getElement().removeChild(cell.getElement());\n\t\t\t\t\t\t\t} catch (ex) {\n\t\t\t\t\t\t\t\tconsole.warn(\"Could not removeColLeft\", ex.message);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tthis.vDomPadLeft += column.getWidth();\n\t\t\t\t\tthis.leftCol ++;\n\n\t\t\t\t\tthis.getVisibleRows().forEach((row) => {\n\t\t\t\t\t\tif(row.type !== \"group\"){\n\t\t\t\t\t\t\trow.modules.vdomHoz.leftCol = this.leftCol;\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(changes){\n\t\t\tthis.tableElement.style.paddingLeft = this.vDomPadLeft + \"px\";\n\t\t}\n\t}\n\t\n\tfitDataColActualWidthCheck(column){\n\t\tvar newWidth, widthDiff;\n\t\t\n\t\tif(column.modules.vdomHoz.fitDataCheck){\n\t\t\tcolumn.reinitializeWidth();\n\t\t\t\n\t\t\tnewWidth = column.getWidth();\n\t\t\twidthDiff = newWidth - column.modules.vdomHoz.width;\n\t\t\t\n\t\t\tif(widthDiff){\n\t\t\t\tcolumn.modules.vdomHoz.rightPos += widthDiff;\n\t\t\t\tcolumn.modules.vdomHoz.width = newWidth;\n\t\t\t\tthis.colPositionAdjust(this.columns.indexOf(column) + 1, this.columns.length, widthDiff);\n\t\t\t}\n\t\t\t\n\t\t\tcolumn.modules.vdomHoz.fitDataCheck = false;\n\t\t}\n\t\t\n\t\treturn widthDiff;\n\t}\n\t\n\tinitializeRow(row){\n\t\tif(row.type !== \"group\"){\n\t\t\trow.modules.vdomHoz = {\n\t\t\t\tleftCol:this.leftCol,\n\t\t\t\trightCol:this.rightCol,\n\t\t\t};\n\n\t\t\tif(this.table.modules.frozenColumns){\n\t\t\t\tthis.table.modules.frozenColumns.leftColumns.forEach((column) => {\n\t\t\t\t\tthis.appendCell(row, column);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tfor(let i = this.leftCol; i <= this.rightCol; i++){\n\t\t\t\tthis.appendCell(row, this.columns[i]);\n\t\t\t}\n\n\t\t\tif(this.table.modules.frozenColumns){\n\t\t\t\tthis.table.modules.frozenColumns.rightColumns.forEach((column) => {\n\t\t\t\t\tthis.appendCell(row, column);\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t}\n\t\n\tappendCell(row, column){\n\t\tif(column && column.visible){\n\t\t\tlet cell = row.getCell(column);\n\t\t\t\n\t\t\trow.getElement().appendChild(cell.getElement());\n\t\t\tcell.cellRendered();\n\t\t}\n\t}\n\t\n\treinitializeRow(row, force){\n\t\tif(row.type !== \"group\"){\n\t\t\tif(force || !row.modules.vdomHoz || row.modules.vdomHoz.leftCol !== this.leftCol || row.modules.vdomHoz.rightCol !== this.rightCol){\n\t\t\t\t\n\t\t\t\tvar rowEl = row.getElement();\n\t\t\t\twhile(rowEl.firstChild) rowEl.removeChild(rowEl.firstChild);\n\n\t\t\t\tthis.initializeRow(row);\n\t\t\t}\n\t\t}\n\t}\n}","import CoreFeature from './CoreFeature.js';\nimport Column from './column/Column.js';\nimport ColumnComponent from './column/ColumnComponent.js';\nimport Helpers from './tools/Helpers.js';\nimport OptionsList from './tools/OptionsList.js';\n\nimport RendererBasicHorizontal from './rendering/renderers/BasicHorizontal.js';\nimport RendererVirtualDomHorizontal from './rendering/renderers/VirtualDomHorizontal.js';\n\nimport defaultColumnOptions from './column/defaults/options.js';\n\nexport default class ColumnManager extends CoreFeature {\n\t\n\tconstructor (table){\n\t\tsuper(table);\n\t\t\n\t\tthis.blockHozScrollEvent = false;\n\t\tthis.headersElement = null;\n\t\tthis.contentsElement = null;\n\t\tthis.element = null ; //containing element\n\t\tthis.columns = []; // column definition object\n\t\tthis.columnsByIndex = []; //columns by index\n\t\tthis.columnsByField = {}; //columns by field\n\t\tthis.scrollLeft = 0;\n\t\tthis.optionsList = new OptionsList(this.table, \"column definition\", defaultColumnOptions);\n\t\t\n\t\tthis.redrawBlock = false; //prevent redraws to allow multiple data manipulations before continuing\n\t\tthis.redrawBlockUpdate = null; //store latest redraw update only status\n\t\t\n\t\tthis.renderer = null;\n\t}\n\t\n\t////////////// Setup Functions /////////////////\n\t\n\tinitialize(){\n\t\tthis.initializeRenderer();\n\t\t\n\t\tthis.headersElement = this.createHeadersElement();\n\t\tthis.contentsElement = this.createHeaderContentsElement();\n\t\tthis.element = this.createHeaderElement();\n\t\t\n\t\tthis.contentsElement.insertBefore(this.headersElement, this.contentsElement.firstChild);\n\t\tthis.element.insertBefore(this.contentsElement, this.element.firstChild);\n\n\t\tthis.initializeScrollWheelWatcher();\n\t\t\n\t\tthis.subscribe(\"scroll-horizontal\", this.scrollHorizontal.bind(this));\n\t\tthis.subscribe(\"scrollbar-vertical\", this.padVerticalScrollbar.bind(this));\n\t}\n\n\tpadVerticalScrollbar(width){\n\t\tif(this.table.rtl){\n\t\t\tthis.headersElement.style.marginLeft = width + \"px\";\n\t\t}else{\n\t\t\tthis.headersElement.style.marginRight = width + \"px\";\n\t\t}\n\t}\n\t\n\tinitializeRenderer(){\n\t\tvar renderClass;\n\t\t\n\t\tvar renderers = {\n\t\t\t\"virtual\": RendererVirtualDomHorizontal,\n\t\t\t\"basic\": RendererBasicHorizontal,\n\t\t};\n\t\t\n\t\tif(typeof this.table.options.renderHorizontal === \"string\"){\n\t\t\trenderClass = renderers[this.table.options.renderHorizontal];\n\t\t}else{\n\t\t\trenderClass = this.table.options.renderHorizontal;\n\t\t}\n\t\t\n\t\tif(renderClass){\n\t\t\tthis.renderer = new renderClass(this.table, this.element, this.tableElement);\n\t\t\tthis.renderer.initialize();\n\t\t}else{\n\t\t\tconsole.error(\"Unable to find matching renderer:\", this.table.options.renderHorizontal);\n\t\t}\n\t}\n\t\n\t\n\tcreateHeadersElement (){\n\t\tvar el = document.createElement(\"div\");\n\t\t\n\t\tel.classList.add(\"tabulator-headers\");\n\t\tel.setAttribute(\"role\", \"row\");\n\t\t\n\t\treturn el;\n\t}\n\n\tcreateHeaderContentsElement (){\n\t\tvar el = document.createElement(\"div\");\n\t\t\n\t\tel.classList.add(\"tabulator-header-contents\");\n\t\tel.setAttribute(\"role\", \"rowgroup\");\n\t\t\n\t\treturn el;\n\t}\n\t\n\tcreateHeaderElement (){\n\t\tvar el = document.createElement(\"div\");\n\t\t\n\t\tel.classList.add(\"tabulator-header\");\n\t\tel.setAttribute(\"role\", \"rowgroup\");\n\t\t\n\t\tif(!this.table.options.headerVisible){\n\t\t\tel.classList.add(\"tabulator-header-hidden\");\n\t\t}\n\t\t\n\t\treturn el;\n\t}\n\t\n\t//return containing element\n\tgetElement(){\n\t\treturn this.element;\n\t}\n\n\t//return containing contents element\n\tgetContentsElement(){\n\t\treturn this.contentsElement;\n\t}\n\t\n\t\n\t//return header containing element\n\tgetHeadersElement(){\n\t\treturn this.headersElement;\n\t}\n\t\n\t//scroll horizontally to match table body\n\tscrollHorizontal(left){\n\t\tthis.contentsElement.scrollLeft = left;\n\n\t\tthis.scrollLeft = left;\n\t\t\n\t\tthis.renderer.scrollColumns(left);\n\t}\n\n\tinitializeScrollWheelWatcher(){\n\t\tthis.contentsElement.addEventListener(\"wheel\", (e) => {\n\t\t\tvar left;\n\n\t\t\tif(e.deltaX){\n\t\t\t\tleft = this.contentsElement.scrollLeft + e.deltaX;\n\n\t\t\t\tthis.table.rowManager.scrollHorizontal(left);\n\t\t\t\tthis.table.columnManager.scrollHorizontal(left);\n\t\t\t}\n\t\t});\n\t}\n\t\n\t///////////// Column Setup Functions /////////////\n\tgenerateColumnsFromRowData(data){\n\t\tvar cols = [],\n\t\tdefinitions = this.table.options.autoColumnsDefinitions,\n\t\trow, sorter;\n\t\t\n\t\tif(data && data.length){\n\t\t\t\n\t\t\trow = data[0];\n\t\t\t\n\t\t\tfor(var key in row){\n\t\t\t\tlet col = {\n\t\t\t\t\tfield:key,\n\t\t\t\t\ttitle:key,\n\t\t\t\t};\n\t\t\t\t\n\t\t\t\tlet value = row[key];\n\t\t\t\t\n\t\t\t\tswitch(typeof value){\n\t\t\t\t\tcase \"undefined\":\n\t\t\t\t\t\tsorter = \"string\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tcase \"boolean\":\n\t\t\t\t\t\tsorter = \"boolean\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tcase \"object\":\n\t\t\t\t\t\tif(Array.isArray(value)){\n\t\t\t\t\t\t\tsorter = \"array\";\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tsorter = \"string\";\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tif(!isNaN(value) && value !== \"\"){\n\t\t\t\t\t\t\tsorter = \"number\";\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tif(value.match(/((^[0-9]+[a-z]+)|(^[a-z]+[0-9]+))+$/i)){\n\t\t\t\t\t\t\t\tsorter = \"alphanum\";\n\t\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t\tsorter = \"string\";\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tcol.sorter = sorter;\n\t\t\t\t\n\t\t\t\tcols.push(col);\n\t\t\t}\n\t\t\t\n\t\t\tif(definitions){\n\t\t\t\t\n\t\t\t\tswitch(typeof definitions){\n\t\t\t\t\tcase \"function\":\n\t\t\t\t\t\tthis.table.options.columns = definitions.call(this.table, cols);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tcase \"object\":\n\t\t\t\t\t\tif(Array.isArray(definitions)){\n\t\t\t\t\t\t\tcols.forEach((col) => {\n\t\t\t\t\t\t\t\tvar match = definitions.find((def) => {\n\t\t\t\t\t\t\t\t\treturn def.field === col.field;\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tif(match){\n\t\t\t\t\t\t\t\t\tObject.assign(col, match);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tcols.forEach((col) => {\n\t\t\t\t\t\t\t\tif(definitions[col.field]){\n\t\t\t\t\t\t\t\t\tObject.assign(col, definitions[col.field]);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t\tthis.table.options.columns = cols;\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tthis.table.options.columns = cols;\n\t\t\t}\n\t\t\t\n\t\t\tthis.setColumns(this.table.options.columns);\n\t\t}\n\t}\n\t\n\tsetColumns(cols, row){\n\t\twhile(this.headersElement.firstChild) this.headersElement.removeChild(this.headersElement.firstChild);\n\t\t\n\t\tthis.columns = [];\n\t\tthis.columnsByIndex = [];\n\t\tthis.columnsByField = {};\n\t\t\n\t\tthis.dispatch(\"columns-loading\");\n\t\t\n\t\tcols.forEach((def, i) => {\n\t\t\tthis._addColumn(def);\n\t\t});\n\t\t\n\t\tthis._reIndexColumns();\n\t\t\n\t\tthis.dispatch(\"columns-loaded\");\n\t\t\n\t\tthis.rerenderColumns(false, true);\n\t\t\n\t\tthis.redraw(true);\n\t}\n\t\n\t_addColumn(definition, before, nextToColumn){\n\t\tvar column = new Column(definition, this),\n\t\tcolEl = column.getElement(),\n\t\tindex = nextToColumn ? this.findColumnIndex(nextToColumn) : nextToColumn;\n\t\t\n\t\tif(nextToColumn && index > -1){\n\t\t\tvar topColumn = nextToColumn.getTopColumn();\n\t\t\tvar parentIndex = this.columns.indexOf(topColumn);\n\t\t\tvar nextEl = topColumn.getElement();\n\t\t\t\n\t\t\tif(before){\n\t\t\t\tthis.columns.splice(parentIndex, 0, column);\n\t\t\t\tnextEl.parentNode.insertBefore(colEl, nextEl);\n\t\t\t}else{\n\t\t\t\tthis.columns.splice(parentIndex + 1, 0, column);\n\t\t\t\tnextEl.parentNode.insertBefore(colEl, nextEl.nextSibling);\n\t\t\t}\n\t\t}else{\n\t\t\tif(before){\n\t\t\t\tthis.columns.unshift(column);\n\t\t\t\tthis.headersElement.insertBefore(column.getElement(), this.headersElement.firstChild);\n\t\t\t}else{\n\t\t\t\tthis.columns.push(column);\n\t\t\t\tthis.headersElement.appendChild(column.getElement());\n\t\t\t}\n\t\t}\n\t\t\n\t\tcolumn.columnRendered();\n\t\t\n\t\treturn column;\n\t}\n\t\n\tregisterColumnField(col){\n\t\tif(col.definition.field){\n\t\t\tthis.columnsByField[col.definition.field] = col;\n\t\t}\n\t}\n\t\n\tregisterColumnPosition(col){\n\t\tthis.columnsByIndex.push(col);\n\t}\n\t\n\t_reIndexColumns(){\n\t\tthis.columnsByIndex = [];\n\t\t\n\t\tthis.columns.forEach(function(column){\n\t\t\tcolumn.reRegisterPosition();\n\t\t});\n\t}\n\t\n\t//ensure column headers take up the correct amount of space in column groups\n\tverticalAlignHeaders(){\n\t\tvar minHeight = 0;\n\t\t\n\t\tif(!this.redrawBlock){\n\n\t\t\tthis.headersElement.style.height=\"\";\n\t\t\t\n\t\t\tthis.columns.forEach((column) => {\n\t\t\t\tcolumn.clearVerticalAlign();\n\t\t\t});\n\t\t\t\n\t\t\tthis.columns.forEach((column) => {\n\t\t\t\tvar height = column.getHeight();\n\t\t\t\t\n\t\t\t\tif(height > minHeight){\n\t\t\t\t\tminHeight = height;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tthis.headersElement.style.height = minHeight + \"px\";\n\n\t\t\tthis.columns.forEach((column) => {\n\t\t\t\tcolumn.verticalAlign(this.table.options.columnHeaderVertAlign, minHeight);\n\t\t\t});\n\t\t\t\n\t\t\tthis.table.rowManager.adjustTableSize();\n\t\t}\n\t}\n\t\n\t//////////////// Column Details /////////////////\n\tfindColumn(subject){\n\t\tvar columns;\n\n\t\tif(typeof subject == \"object\"){\n\t\t\t\n\t\t\tif(subject instanceof Column){\n\t\t\t\t//subject is column element\n\t\t\t\treturn subject;\n\t\t\t}else if(subject instanceof ColumnComponent){\n\t\t\t\t//subject is public column component\n\t\t\t\treturn subject._getSelf() || false;\n\t\t\t}else if(typeof HTMLElement !== \"undefined\" && subject instanceof HTMLElement){\n\n\t\t\t\tcolumns = [];\n\n\t\t\t\tthis.columns.forEach((column) => {\n\t\t\t\t\tcolumns.push(column);\n\t\t\t\t\tcolumns = columns.concat(column.getColumns(true));\n\t\t\t\t});\n\n\t\t\t\t//subject is a HTML element of the column header\n\t\t\t\tlet match = columns.find((column) => {\n\t\t\t\t\treturn column.element === subject;\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\treturn match || false;\n\t\t\t}\n\t\t\t\n\t\t}else{\n\t\t\t//subject should be treated as the field name of the column\n\t\t\treturn this.columnsByField[subject] || false;\n\t\t}\n\t\t\n\t\t//catch all for any other type of input\n\t\treturn false;\n\t}\n\t\n\tgetColumnByField(field){\n\t\treturn this.columnsByField[field];\n\t}\n\t\n\tgetColumnsByFieldRoot(root){\n\t\tvar matches = [];\n\t\t\n\t\tObject.keys(this.columnsByField).forEach((field) => {\n\t\t\tvar fieldRoot = field.split(\".\")[0];\n\t\t\tif(fieldRoot === root){\n\t\t\t\tmatches.push(this.columnsByField[field]);\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn matches;\n\t}\n\t\n\tgetColumnByIndex(index){\n\t\treturn this.columnsByIndex[index];\n\t}\n\t\n\tgetFirstVisibleColumn(){\n\t\tvar index = this.columnsByIndex.findIndex((col) => {\n\t\t\treturn col.visible;\n\t\t});\n\t\t\n\t\treturn index > -1 ? this.columnsByIndex[index] : false;\n\t}\n\t\n\tgetColumns(){\n\t\treturn this.columns;\n\t}\n\t\n\tfindColumnIndex(column){\n\t\treturn this.columnsByIndex.findIndex((col) => {\n\t\t\treturn column === col;\n\t\t});\n\t}\n\t\n\t//return all columns that are not groups\n\tgetRealColumns(){\n\t\treturn this.columnsByIndex;\n\t}\n\t\n\t//traverse across columns and call action\n\ttraverse(callback){\n\t\tthis.columnsByIndex.forEach((column,i) =>{\n\t\t\tcallback(column, i);\n\t\t});\n\t}\n\t\n\t//get definitions of actual columns\n\tgetDefinitions(active){\n\t\tvar output = [];\n\t\t\n\t\tthis.columnsByIndex.forEach((column) => {\n\t\t\tif(!active || (active && column.visible)){\n\t\t\t\toutput.push(column.getDefinition());\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\t//get full nested definition tree\n\tgetDefinitionTree(){\n\t\tvar output = [];\n\t\t\n\t\tthis.columns.forEach((column) => {\n\t\t\toutput.push(column.getDefinition(true));\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgetComponents(structured){\n\t\tvar output = [],\n\t\tcolumns = structured ? this.columns : this.columnsByIndex;\n\t\t\n\t\tcolumns.forEach((column) => {\n\t\t\toutput.push(column.getComponent());\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgetWidth(){\n\t\tvar width = 0;\n\t\t\n\t\tthis.columnsByIndex.forEach((column) => {\n\t\t\tif(column.visible){\n\t\t\t\twidth += column.getWidth();\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn width;\n\t}\n\t\n\tmoveColumn(from, to, after){\n\t\tto.element.parentNode.insertBefore(from.element, to.element);\n\t\t\n\t\tif(after){\n\t\t\tto.element.parentNode.insertBefore(to.element, from.element);\n\t\t}\n\t\t\n\t\tthis.moveColumnActual(from, to, after);\n\n\t\tthis.verticalAlignHeaders();\n\t\t\n\t\tthis.table.rowManager.reinitialize();\n\t}\n\t\n\tmoveColumnActual(from, to, after){\n\t\tif(from.parent.isGroup){\n\t\t\tthis._moveColumnInArray(from.parent.columns, from, to, after);\n\t\t}else{\n\t\t\tthis._moveColumnInArray(this.columns, from, to, after);\n\t\t}\n\t\t\n\t\tthis._moveColumnInArray(this.columnsByIndex, from, to, after, true);\n\t\t\n\t\tthis.rerenderColumns(true);\n\t\t\n\t\tthis.dispatch(\"column-moved\", from, to, after);\n\t\t\n\t\tif(this.subscribedExternal(\"columnMoved\")){\n\t\t\tthis.dispatchExternal(\"columnMoved\", from.getComponent(), this.table.columnManager.getComponents());\n\t\t}\n\t}\n\t\n\t_moveColumnInArray(columns, from, to, after, updateRows){\n\t\tvar\tfromIndex = columns.indexOf(from),\n\t\ttoIndex, rows = [];\n\t\t\n\t\tif (fromIndex > -1) {\n\t\t\t\n\t\t\tcolumns.splice(fromIndex, 1);\n\t\t\t\n\t\t\ttoIndex = columns.indexOf(to);\n\t\t\t\n\t\t\tif (toIndex > -1) {\n\t\t\t\t\n\t\t\t\tif(after){\n\t\t\t\t\ttoIndex = toIndex+1;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t}else{\n\t\t\t\ttoIndex = fromIndex;\n\t\t\t}\n\t\t\t\n\t\t\tcolumns.splice(toIndex, 0, from);\n\t\t\t\n\t\t\tif(updateRows){\n\t\t\t\t\n\t\t\t\trows = this.chain(\"column-moving-rows\", [from, to, after], null, []) || [];\n\t\t\t\t\n\t\t\t\trows = rows.concat(this.table.rowManager.rows);\n\t\t\t\t\n\t\t\t\trows.forEach(function(row){\n\t\t\t\t\tif(row.cells.length){\n\t\t\t\t\t\tvar cell = row.cells.splice(fromIndex, 1)[0];\n\t\t\t\t\t\trow.cells.splice(toIndex, 0, cell);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\t\n\t\t\t}\n\t\t}\n\t}\n\t\n\tscrollToColumn(column, position, ifVisible){\n\t\tvar left = 0,\n\t\toffset = column.getLeftOffset(),\n\t\tadjust = 0,\n\t\tcolEl = column.getElement();\n\t\t\n\t\t\n\t\treturn new Promise((resolve, reject) => {\n\t\t\t\n\t\t\tif(typeof position === \"undefined\"){\n\t\t\t\tposition = this.table.options.scrollToColumnPosition;\n\t\t\t}\n\t\t\t\n\t\t\tif(typeof ifVisible === \"undefined\"){\n\t\t\t\tifVisible = this.table.options.scrollToColumnIfVisible;\n\t\t\t}\n\t\t\t\n\t\t\tif(column.visible){\n\t\t\t\t\n\t\t\t\t//align to correct position\n\t\t\t\tswitch(position){\n\t\t\t\t\tcase \"middle\":\n\t\t\t\t\tcase \"center\":\n\t\t\t\t\t\tadjust = -this.element.clientWidth / 2;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tcase \"right\":\n\t\t\t\t\t\tadjust = colEl.clientWidth - this.headersElement.clientWidth;\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t//check column visibility\n\t\t\t\tif(!ifVisible){\n\t\t\t\t\tif(offset > 0 && offset + colEl.offsetWidth < this.element.clientWidth){\n\t\t\t\t\t\treturn false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\t//calculate scroll position\n\t\t\t\tleft = offset + adjust;\n\t\t\t\t\n\t\t\t\tleft = Math.max(Math.min(left, this.table.rowManager.element.scrollWidth - this.table.rowManager.element.clientWidth),0);\n\t\t\t\t\n\t\t\t\tthis.table.rowManager.scrollHorizontal(left);\n\t\t\t\tthis.scrollHorizontal(left);\n\t\t\t\t\n\t\t\t\tresolve();\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Scroll Error - Column not visible\");\n\t\t\t\treject(\"Scroll Error - Column not visible\");\n\t\t\t}\n\t\t\t\n\t\t});\n\t}\n\t\n\t//////////////// Cell Management /////////////////\n\tgenerateCells(row){\n\t\tvar cells = [];\n\t\t\n\t\tthis.columnsByIndex.forEach((column) => {\n\t\t\tcells.push(column.generateCell(row));\n\t\t});\n\t\t\n\t\treturn cells;\n\t}\n\t\n\t//////////////// Column Management /////////////////\n\tgetFlexBaseWidth(){\n\t\tvar totalWidth = this.table.element.clientWidth, //table element width\n\t\tfixedWidth = 0;\n\t\t\n\t\t//adjust for vertical scrollbar if present\n\t\tif(this.table.rowManager.element.scrollHeight > this.table.rowManager.element.clientHeight){\n\t\t\ttotalWidth -= this.table.rowManager.element.offsetWidth - this.table.rowManager.element.clientWidth;\n\t\t}\n\t\t\n\t\tthis.columnsByIndex.forEach(function(column){\n\t\t\tvar width, minWidth, colWidth;\n\t\t\t\n\t\t\tif(column.visible){\n\t\t\t\t\n\t\t\t\twidth = column.definition.width || 0;\n\t\t\t\t\n\t\t\t\tminWidth = parseInt(column.minWidth);\n\t\t\t\t\n\t\t\t\tif(typeof(width) == \"string\"){\n\t\t\t\t\tif(width.indexOf(\"%\") > -1){\n\t\t\t\t\t\tcolWidth = (totalWidth / 100) * parseInt(width) ;\n\t\t\t\t\t}else{\n\t\t\t\t\t\tcolWidth = parseInt(width);\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tcolWidth = width;\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tfixedWidth += colWidth > minWidth ? colWidth : minWidth;\n\t\t\t\t\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn fixedWidth;\n\t}\n\t\n\taddColumn(definition, before, nextToColumn){\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tvar column = this._addColumn(definition, before, nextToColumn);\n\t\t\t\n\t\t\tthis._reIndexColumns();\n\t\t\t\n\t\t\tthis.dispatch(\"column-add\", definition, before, nextToColumn);\n\t\t\t\n\t\t\tif(this.layoutMode() != \"fitColumns\"){\n\t\t\t\tcolumn.reinitializeWidth();\n\t\t\t}\n\t\t\t\n\t\t\tthis.redraw(true);\n\t\t\t\n\t\t\tthis.table.rowManager.reinitialize();\n\t\t\t\n\t\t\tthis.rerenderColumns();\n\t\t\t\n\t\t\tresolve(column);\n\t\t});\n\t}\n\t\n\t//remove column from system\n\tderegisterColumn(column){\n\t\tvar field = column.getField(),\n\t\tindex;\n\t\t\n\t\t//remove from field list\n\t\tif(field){\n\t\t\tdelete this.columnsByField[field];\n\t\t}\n\t\t\n\t\t//remove from index list\n\t\tindex = this.columnsByIndex.indexOf(column);\n\t\t\n\t\tif(index > -1){\n\t\t\tthis.columnsByIndex.splice(index, 1);\n\t\t}\n\t\t\n\t\t//remove from column list\n\t\tindex = this.columns.indexOf(column);\n\t\t\n\t\tif(index > -1){\n\t\t\tthis.columns.splice(index, 1);\n\t\t}\n\t\t\n\t\tthis.verticalAlignHeaders();\n\t\t\n\t\tthis.redraw();\n\t}\n\t\n\trerenderColumns(update, silent){\n\t\tif(!this.redrawBlock){\n\t\t\tthis.renderer.rerenderColumns(update, silent);\n\t\t}else{\n\t\t\tif(update === false || (update === true && this.redrawBlockUpdate === null)){\n\t\t\t\tthis.redrawBlockUpdate = update;\n\t\t\t}\n\t\t}\n\t}\n\t\n\tblockRedraw(){\n\t\tthis.redrawBlock = true;\n\t\tthis.redrawBlockUpdate = null;\n\t}\n\t\n\trestoreRedraw(){\n\t\tthis.redrawBlock = false;\n\t\tthis.verticalAlignHeaders();\n\t\tthis.renderer.rerenderColumns(this.redrawBlockUpdate);\n\t\t\n\t}\n\t\n\t//redraw columns\n\tredraw(force){\n\t\tif(Helpers.elVisible(this.element)){\n\t\t\tthis.verticalAlignHeaders();\n\t\t}\n\t\t\n\t\tif(force){\n\t\t\tthis.table.rowManager.resetScroll();\n\t\t\tthis.table.rowManager.reinitialize();\n\t\t}\n\t\t\n\t\tif(!this.confirm(\"table-redrawing\", force)){\n\t\t\tthis.layoutRefresh(force);\n\t\t}\n\t\t\n\t\tthis.dispatch(\"table-redraw\", force);\n\t\t\n\t\tthis.table.footerManager.redraw();\n\t}\n}","import Renderer from '../Renderer.js';\nimport Helpers from '../../tools/Helpers.js';\n\nexport default class BasicVertical extends Renderer{\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.verticalFillMode = \"fill\";\n\t\t\n\t\tthis.scrollTop = 0;\n\t\tthis.scrollLeft = 0;\n\t\t\n\t\tthis.scrollTop = 0;\n\t\tthis.scrollLeft = 0;\n\t}\n\t\n\tclearRows(){\n\t\tvar element = this.tableElement;\n\t\t\n\t\t// element.children.detach();\n\t\twhile(element.firstChild) element.removeChild(element.firstChild);\n\t\t\n\t\telement.scrollTop = 0;\n\t\telement.scrollLeft = 0;\n\t\t\n\t\telement.style.minWidth = \"\";\n\t\telement.style.minHeight = \"\";\n\t\telement.style.display = \"\";\n\t\telement.style.visibility = \"\";\n\t}\n\t\n\trenderRows() {\n\t\tvar element = this.tableElement,\n\t\tonlyGroupHeaders = true,\n\t\ttableFrag = document.createDocumentFragment(),\n\t\trows = this.rows();\n\t\t\n\t\trows.forEach((row, index) => {\n\t\t\tthis.styleRow(row, index);\n\t\t\trow.initialize(false, true);\n\t\t\t\n\t\t\tif (row.type !== \"group\") {\n\t\t\t\tonlyGroupHeaders = false;\n\t\t\t}\n\t\t\t\n\t\t\ttableFrag.appendChild(row.getElement());\n\t\t});\n\t\t\n\t\telement.appendChild(tableFrag);\n\t\t\n\t\trows.forEach((row) => {\n\t\t\trow.rendered();\n\t\t\t\n\t\t\tif(!row.heightInitialized) {\n\t\t\t\trow.calcHeight(true);\n\t\t\t}\n\t\t});\n\t\t\n\t\trows.forEach((row) => {\n\t\t\tif(!row.heightInitialized) {\n\t\t\t\trow.setCellHeight();\n\t\t\t}\n\t\t});\n\t\t\n\t\t\n\t\t\n\t\tif(onlyGroupHeaders){\n\t\t\telement.style.minWidth = this.table.columnManager.getWidth() + \"px\";\n\t\t}else{\n\t\t\telement.style.minWidth = \"\";\n\t\t}\n\t}\n\t\n\t\n\trerenderRows(callback){\t\n\t\tthis.clearRows();\n\t\t\n\t\tif(callback){\n\t\t\tcallback();\n\t\t}\n\t\t\n\t\tthis.renderRows();\n\t}\n\t\n\tscrollToRowNearestTop(row){\n\t\tvar rowTop = Helpers.elOffset(row.getElement()).top;\n\t\t\n\t\treturn !(Math.abs(this.elementVertical.scrollTop - rowTop) > Math.abs(this.elementVertical.scrollTop + this.elementVertical.clientHeight - rowTop));\n\t}\n\t\n\tscrollToRow(row){\n\t\tvar rowEl = row.getElement();\n\t\t\n\t\tthis.elementVertical.scrollTop = Helpers.elOffset(rowEl).top - Helpers.elOffset(this.elementVertical).top + this.elementVertical.scrollTop;\n\t}\n\t\n\tvisibleRows(includingBuffer){\n\t\treturn this.rows();\n\t}\n\t\n}\n","import Renderer from '../Renderer.js';\nimport Helpers from '../../tools/Helpers.js';\n\nexport default class VirtualDomVertical extends Renderer{\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.verticalFillMode = \"fill\";\n\n\t\tthis.scrollTop = 0;\n\t\tthis.scrollLeft = 0;\n\n\t\tthis.vDomRowHeight = 20; //approximation of row heights for padding\n\n\t\tthis.vDomTop = 0; //hold position for first rendered row in the virtual DOM\n\t\tthis.vDomBottom = 0; //hold position for last rendered row in the virtual DOM\n\n\t\tthis.vDomScrollPosTop = 0; //last scroll position of the vDom top;\n\t\tthis.vDomScrollPosBottom = 0; //last scroll position of the vDom bottom;\n\n\t\tthis.vDomTopPad = 0; //hold value of padding for top of virtual DOM\n\t\tthis.vDomBottomPad = 0; //hold value of padding for bottom of virtual DOM\n\n\t\tthis.vDomMaxRenderChain = 90; //the maximum number of dom elements that can be rendered in 1 go\n\n\t\tthis.vDomWindowBuffer = 0; //window row buffer before removing elements, to smooth scrolling\n\n\t\tthis.vDomWindowMinTotalRows = 20; //minimum number of rows to be generated in virtual dom (prevent buffering issues on tables with tall rows)\n\t\tthis.vDomWindowMinMarginRows = 5; //minimum number of rows to be generated in virtual dom margin\n\n\t\tthis.vDomTopNewRows = []; //rows to normalize after appending to optimize render speed\n\t\tthis.vDomBottomNewRows = []; //rows to normalize after appending to optimize render speed\n\t}\n\n\t//////////////////////////////////////\n\t///////// Public Functions ///////////\n\t//////////////////////////////////////\n\n\tclearRows(){\n\t\tvar element = this.tableElement;\n\n\t\t// element.children.detach();\n\t\twhile(element.firstChild) element.removeChild(element.firstChild);\n\n\t\telement.style.paddingTop = \"\";\n\t\telement.style.paddingBottom = \"\";\n\t\telement.style.minHeight = \"\";\n\t\telement.style.display = \"\";\n\t\telement.style.visibility = \"\";\n\n\t\tthis.elementVertical.scrollTop = 0;\n\t\tthis.elementVertical.scrollLeft = 0;\n\n\t\tthis.scrollTop = 0;\n\t\tthis.scrollLeft = 0;\n\n\t\tthis.vDomTop = 0;\n\t\tthis.vDomBottom = 0;\n\t\tthis.vDomTopPad = 0;\n\t\tthis.vDomBottomPad = 0;\n\t\tthis.vDomScrollPosTop = 0;\n\t\tthis.vDomScrollPosBottom = 0;\n\t}\n\n\trenderRows(){\n\t\tthis._virtualRenderFill();\n\t}\n\n\trerenderRows(callback){\n\t\tvar scrollTop = this.elementVertical.scrollTop;\n\t\tvar topRow = false;\n\t\tvar topOffset = false;\n\n\t\tvar left = this.table.rowManager.scrollLeft;\n\n\t\tvar rows = this.rows();\n\n\t\tfor(var i = this.vDomTop; i <= this.vDomBottom; i++){\n\n\t\t\tif(rows[i]){\n\t\t\t\tvar diff = scrollTop - rows[i].getElement().offsetTop;\n\n\t\t\t\tif(topOffset === false || Math.abs(diff) < topOffset){\n\t\t\t\t\ttopOffset = diff;\n\t\t\t\t\ttopRow = i;\n\t\t\t\t}else{\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\trows.forEach((row) => {\n\t\t\trow.deinitializeHeight();\n\t\t});\n\n\t\tif(callback){\n\t\t\tcallback();\n\t\t}\n\n\t\tif(this.rows().length){\n\t\t\tthis._virtualRenderFill((topRow === false ? this.rows.length - 1 : topRow), true, topOffset || 0);\n\t\t}else{\n\t\t\tthis.clear();\n\t\t\tthis.table.rowManager.tableEmpty();\n\t\t}\n\n\t\tthis.scrollColumns(left);\n\t}\n\n\tscrollColumns(left){\n\t\tthis.table.rowManager.scrollHorizontal(left);\n\t}\n\n\tscrollRows(top, dir){\n\t\tvar topDiff = top - this.vDomScrollPosTop;\n\t\tvar bottomDiff = top - this.vDomScrollPosBottom;\n\t\tvar margin = this.vDomWindowBuffer * 2;\n\t\tvar rows = this.rows();\n\n\t\tthis.scrollTop = top;\n\n\t\tif(-topDiff > margin || bottomDiff > margin){\n\t\t\t//if big scroll redraw table;\n\t\t\tvar left = this.table.rowManager.scrollLeft;\n\t\t\tthis._virtualRenderFill(Math.floor((this.elementVertical.scrollTop / this.elementVertical.scrollHeight) * rows.length));\n\t\t\tthis.scrollColumns(left);\n\t\t}else{\n\n\t\t\tif(dir){\n\t\t\t\t//scrolling up\n\t\t\t\tif(topDiff < 0){\n\t\t\t\t\tthis._addTopRow(rows, -topDiff);\n\t\t\t\t}\n\n\t\t\t\tif(bottomDiff < 0){\n\t\t\t\t\t//hide bottom row if needed\n\t\t\t\t\tif(this.vDomScrollHeight - this.scrollTop > this.vDomWindowBuffer){\n\t\t\t\t\t\tthis._removeBottomRow(rows, -bottomDiff);\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.vDomScrollPosBottom = this.scrollTop;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}else{\n\n\t\t\t\tif(bottomDiff >= 0){\n\t\t\t\t\tthis._addBottomRow(rows, bottomDiff);\n\t\t\t\t}\n\n\t\t\t\t//scrolling down\n\t\t\t\tif(topDiff >= 0){\n\t\t\t\t\t//hide top row if needed\n\t\t\t\t\tif(this.scrollTop > this.vDomWindowBuffer){\n\t\t\t\t\t\tthis._removeTopRow(rows, topDiff);\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.vDomScrollPosTop = this.scrollTop;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tresize(){\n\t\tthis.vDomWindowBuffer = this.table.options.renderVerticalBuffer || this.elementVertical.clientHeight;\n\t}\n\n\tscrollToRowNearestTop(row){\n\t\tvar rowIndex = this.rows().indexOf(row);\n\n\t\treturn !(Math.abs(this.vDomTop - rowIndex) > Math.abs(this.vDomBottom - rowIndex));\n\t}\n\n\tscrollToRow(row){\n\t\tvar index = this.rows().indexOf(row);\n\n\t\tif(index > -1){\n\t\t\tthis._virtualRenderFill(index, true);\n\t\t}\n\t}\n\n\tvisibleRows(includingBuffer){\n\t\tvar topEdge = this.elementVertical.scrollTop,\n\t\tbottomEdge = this.elementVertical.clientHeight + topEdge,\n\t\ttopFound = false,\n\t\ttopRow = 0,\n\t\tbottomRow = 0,\n\t\trows = this.rows();\n\n\t\tif(includingBuffer){\n\t\t\ttopRow = this.vDomTop;\n\t\t\tbottomRow = this.vDomBottom;\n\t\t}else{\n\t\t\tfor(var i = this.vDomTop; i <= this.vDomBottom; i++){\n\t\t\t\tif(rows[i]){\n\t\t\t\t\tif(!topFound){\n\t\t\t\t\t\tif((topEdge - rows[i].getElement().offsetTop) >= 0){\n\t\t\t\t\t\t\ttopRow = i;\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\ttopFound = true;\n\n\t\t\t\t\t\t\tif(bottomEdge - rows[i].getElement().offsetTop >= 0){\n\t\t\t\t\t\t\t\tbottomRow = i;\n\t\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tif(bottomEdge - rows[i].getElement().offsetTop >= 0){\n\t\t\t\t\t\t\tbottomRow = i;\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn rows.slice(topRow, bottomRow + 1);\n\t}\n\n\t//////////////////////////////////////\n\t//////// Internal Rendering //////////\n\t//////////////////////////////////////\n\n\t//full virtual render\n\t_virtualRenderFill(position, forceMove, offset) {\n\t\tvar\telement = this.tableElement,\n\t\tholder = this.elementVertical,\n\t\ttopPad = 0,\n\t\trowsHeight = 0,\n\t\trowHeight = 0,\n\t\theightOccupied = 0,\n\t\ttopPadHeight = 0,\n\t\ti = 0,\n\t\trows = this.rows(),\n\t\trowsCount = rows.length,\n\t\tindex = 0,\n\t\trow,\n\t\trowFragment,\n\t\trenderedRows = [],\n\t\ttotalRowsRendered = 0,\n\t\trowsToRender = 0,\n\t\tfixedHeight = this.table.rowManager.fixedHeight,\n\t\tcontainerHeight = this.elementVertical.clientHeight, \n\t\tavgRowHeight = this.table.options.rowHeight, \n\t\tresized = true;\n\n\t\tposition = position || 0;\n\n\t\toffset = offset || 0;\n\n\t\tif(!position){\n\t\t\tthis.clear();\n\t\t}else {\n\t\t\twhile(element.firstChild) element.removeChild(element.firstChild);\n\n\t\t\t//check if position is too close to bottom of table\n\t\t\theightOccupied = (rowsCount - position + 1) * this.vDomRowHeight;\n\n\t\t\tif(heightOccupied < containerHeight){\n\t\t\t\tposition -= Math.ceil((containerHeight - heightOccupied) / this.vDomRowHeight);\n\t\t\t\tif(position < 0){\n\t\t\t\t\tposition = 0;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t//calculate initial pad\n\t\t\ttopPad = Math.min(Math.max(Math.floor(this.vDomWindowBuffer / this.vDomRowHeight), this.vDomWindowMinMarginRows), position);\n\t\t\tposition -= topPad;\n\t\t}\n\n\t\tif(rowsCount && Helpers.elVisible(this.elementVertical)){\n\t\t\tthis.vDomTop = position;\n\t\t\tthis.vDomBottom = position -1;\n\n\t\t\tif(fixedHeight || this.table.options.maxHeight) {\n\t\t\t\tif(avgRowHeight) {\n\t\t\t\t\trowsToRender = (containerHeight / avgRowHeight) + (this.vDomWindowBuffer / avgRowHeight);\n\t\t\t\t}\n\t\t\t\trowsToRender = Math.max(this.vDomWindowMinTotalRows, Math.ceil(rowsToRender));\n\t\t\t}\n\t\t\telse {\n\t\t\t\trowsToRender = rowsCount;\n\t\t\t}\n\n\t\t\twhile(((rowsToRender == rowsCount || rowsHeight <= containerHeight + this.vDomWindowBuffer) || totalRowsRendered < this.vDomWindowMinTotalRows) && this.vDomBottom < rowsCount -1) {\n\t\t\t\trenderedRows = [];\n\t\t\t\trowFragment = document.createDocumentFragment();\n\n\t\t\t\ti = 0;\n\n\t\t\t\twhile ((i < rowsToRender) && this.vDomBottom < rowsCount -1) {\t\n\t\t\t\t\tindex = this.vDomBottom + 1,\n\t\t\t\t\trow = rows[index];\n\n\t\t\t\t\tthis.styleRow(row, index);\n\n\t\t\t\t\trow.initialize(false, true);\n\t\t\t\t\tif(!row.heightInitialized && !this.table.options.rowHeight){\n\t\t\t\t\t\trow.clearCellHeight();\n\t\t\t\t\t}\n\n\t\t\t\t\trowFragment.appendChild(row.getElement());\n\t\t\t\t\trenderedRows.push(row);\n\t\t\t\t\tthis.vDomBottom ++;\n\t\t\t\t\ti++;\n\t\t\t\t}\n\n\t\t\t\tif(!renderedRows.length){\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\telement.appendChild(rowFragment);\n\t\t\t\t\n\t\t\t\t// NOTE: The next 3 loops are separate on purpose\n\t\t\t\t// This is to batch up the dom writes and reads which drastically improves performance \n\n\t\t\t\trenderedRows.forEach((row) => {\n\t\t\t\t\trow.rendered();\n\n\t\t\t\t\tif(!row.heightInitialized) {\n\t\t\t\t\t\trow.calcHeight(true);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\trenderedRows.forEach((row) => {\n\t\t\t\t\tif(!row.heightInitialized) {\n\t\t\t\t\t\trow.setCellHeight();\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\trenderedRows.forEach((row) => {\n\t\t\t\t\trowHeight = row.getHeight();\n\t\t\t\t\t\n\t\t\t\t\tif(totalRowsRendered < topPad){\n\t\t\t\t\t\ttopPadHeight += rowHeight;\n\t\t\t\t\t}else {\n\t\t\t\t\t\trowsHeight += rowHeight;\n\t\t\t\t\t}\n\n\t\t\t\t\tif(rowHeight > this.vDomWindowBuffer){\n\t\t\t\t\t\tthis.vDomWindowBuffer = rowHeight * 2;\n\t\t\t\t\t}\n\t\t\t\t\ttotalRowsRendered++;\n\t\t\t\t});\n\n\t\t\t\tresized = this.table.rowManager.adjustTableSize();\n\t\t\t\tcontainerHeight = this.elementVertical.clientHeight;\n\t\t\t\tif(resized && (fixedHeight || this.table.options.maxHeight))\n\t\t\t\t{\n\t\t\t\t\tavgRowHeight = rowsHeight / totalRowsRendered;\n\t\t\t\t\trowsToRender = Math.max(this.vDomWindowMinTotalRows, Math.ceil((containerHeight / avgRowHeight) + (this.vDomWindowBuffer / avgRowHeight)));\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif(!position){\n\t\t\t\tthis.vDomTopPad = 0;\n\t\t\t\t//adjust row height to match average of rendered elements\n\t\t\t\tthis.vDomRowHeight = Math.floor((rowsHeight + topPadHeight) / totalRowsRendered);\n\t\t\t\tthis.vDomBottomPad = this.vDomRowHeight * (rowsCount - this.vDomBottom -1);\n\n\t\t\t\tthis.vDomScrollHeight = topPadHeight + rowsHeight + this.vDomBottomPad - containerHeight;\n\t\t\t}else {\n\t\t\t\tthis.vDomTopPad = !forceMove ? this.scrollTop - topPadHeight : (this.vDomRowHeight * this.vDomTop) + offset;\n\t\t\t\tthis.vDomBottomPad = this.vDomBottom == rowsCount-1 ? 0 : Math.max(this.vDomScrollHeight - this.vDomTopPad - rowsHeight - topPadHeight, 0);\n\t\t\t}\n\t\t\t\n\t\t\telement.style.paddingTop = this.vDomTopPad+\"px\";\n\t\t\telement.style.paddingBottom = this.vDomBottomPad+\"px\";\n\n\t\t\tif(forceMove){\n\t\t\t\tthis.scrollTop = this.vDomTopPad + (topPadHeight) + offset - (this.elementVertical.scrollWidth > this.elementVertical.clientWidth ? this.elementVertical.offsetHeight - containerHeight : 0);\n\t\t\t}\n\n\t\t\tthis.scrollTop = Math.min(this.scrollTop, this.elementVertical.scrollHeight - containerHeight);\n\n\t\t\t//adjust for horizontal scrollbar if present (and not at top of table)\n\t\t\tif(this.elementVertical.scrollWidth > this.elementVertical.clientWidth && forceMove){\n\t\t\t\tthis.scrollTop += this.elementVertical.offsetHeight - containerHeight;\n\t\t\t}\n\n\t\t\tthis.vDomScrollPosTop = this.scrollTop;\n\t\t\tthis.vDomScrollPosBottom = this.scrollTop;\n\n\t\t\tholder.scrollTop = this.scrollTop;\n\n\t\t\tthis.dispatch(\"render-virtual-fill\");\n\t\t}\n\t}\n\n\t_addTopRow(rows, fillableSpace){\n\t\tvar table = this.tableElement,\n\t\taddedRows = [],\n\t\tpaddingAdjust = 0,\n\t\tindex = this.vDomTop -1,\n\t\ti = 0,\n\t\tworking = true;\n\n\t\twhile(working){\n\t\t\tif(this.vDomTop){\n\t\t\t\tlet row = rows[index],\n\t\t\t\trowHeight, initialized;\n\n\t\t\t\tif(row && i < this.vDomMaxRenderChain){\n\t\t\t\t\trowHeight = row.getHeight() || this.vDomRowHeight;\n\t\t\t\t\tinitialized = row.initialized;\n\n\t\t\t\t\tif(fillableSpace >= rowHeight){\n\n\t\t\t\t\t\tthis.styleRow(row, index);\n\t\t\t\t\t\ttable.insertBefore(row.getElement(), table.firstChild);\n\n\t\t\t\t\t\tif(!row.initialized || !row.heightInitialized){\n\t\t\t\t\t\t\taddedRows.push(row);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\trow.initialize();\n\n\t\t\t\t\t\tif(!initialized){\n\t\t\t\t\t\t\trowHeight = row.getElement().offsetHeight;\n\n\t\t\t\t\t\t\tif(rowHeight > this.vDomWindowBuffer){\n\t\t\t\t\t\t\t\tthis.vDomWindowBuffer = rowHeight * 2;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tfillableSpace -= rowHeight;\n\t\t\t\t\t\tpaddingAdjust += rowHeight;\n\n\t\t\t\t\t\tthis.vDomTop--;\n\t\t\t\t\t\tindex--;\n\t\t\t\t\t\ti++;\n\n\t\t\t\t\t}else{\n\t\t\t\t\t\tworking = false;\n\t\t\t\t\t}\n\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\n\t\tfor (let row of addedRows){\n\t\t\trow.clearCellHeight();\n\t\t}\n\n\t\tthis._quickNormalizeRowHeight(addedRows);\n\n\t\tif(paddingAdjust){\n\t\t\tthis.vDomTopPad -= paddingAdjust;\n\n\t\t\tif(this.vDomTopPad < 0){\n\t\t\t\tthis.vDomTopPad = index * this.vDomRowHeight;\n\t\t\t}\n\n\t\t\tif(index < 1){\n\t\t\t\tthis.vDomTopPad = 0;\n\t\t\t}\n\n\t\t\ttable.style.paddingTop = this.vDomTopPad + \"px\";\n\t\t\tthis.vDomScrollPosTop -= paddingAdjust;\n\t\t}\n\t}\n\n\t_removeTopRow(rows, fillableSpace){\n\t\tvar removableRows = [],\n\t\tpaddingAdjust = 0,\n\t\ti = 0,\n\t\tworking = true;\n\n\t\twhile(working){\n\t\t\tlet row = rows[this.vDomTop],\n\t\t\trowHeight;\n\n\t\t\tif(row && i < this.vDomMaxRenderChain){\n\t\t\t\trowHeight = row.getHeight() || this.vDomRowHeight;\n\n\t\t\t\tif(fillableSpace >= rowHeight){\n\t\t\t\t\tthis.vDomTop++;\n\n\t\t\t\t\tfillableSpace -= rowHeight;\n\t\t\t\t\tpaddingAdjust += rowHeight;\n\n\t\t\t\t\tremovableRows.push(row);\n\t\t\t\t\ti++;\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\n\t\tfor (let row of removableRows){\n\t\t\tlet rowEl = row.getElement();\n\n\t\t\tif(rowEl.parentNode){\n\t\t\t\trowEl.parentNode.removeChild(rowEl);\n\t\t\t}\n\t\t}\n\n\t\tif(paddingAdjust){\n\t\t\tthis.vDomTopPad += paddingAdjust;\n\t\t\tthis.tableElement.style.paddingTop = this.vDomTopPad + \"px\";\n\t\t\tthis.vDomScrollPosTop += this.vDomTop ? paddingAdjust : paddingAdjust + this.vDomWindowBuffer;\n\t\t}\n\t}\n\n\t_addBottomRow(rows, fillableSpace){\n\t\tvar table = this.tableElement,\n\t\taddedRows = [],\n\t\tpaddingAdjust = 0,\n\t\tindex = this.vDomBottom + 1,\n\t\ti = 0,\n\t\tworking = true;\n\n\t\twhile(working){\n\t\t\tlet row = rows[index],\n\t\t\trowHeight, initialized;\n\n\t\t\tif(row && i < this.vDomMaxRenderChain){\n\t\t\t\trowHeight = row.getHeight() || this.vDomRowHeight;\n\t\t\t\tinitialized = row.initialized;\n\n\t\t\t\tif(fillableSpace >= rowHeight){\n\n\t\t\t\t\tthis.styleRow(row, index);\n\t\t\t\t\ttable.appendChild(row.getElement());\n\n\t\t\t\t\tif(!row.initialized || !row.heightInitialized){\n\t\t\t\t\t\taddedRows.push(row);\n\t\t\t\t\t}\n\n\t\t\t\t\trow.initialize();\n\n\t\t\t\t\tif(!initialized){\n\t\t\t\t\t\trowHeight = row.getElement().offsetHeight;\n\n\t\t\t\t\t\tif(rowHeight > this.vDomWindowBuffer){\n\t\t\t\t\t\t\tthis.vDomWindowBuffer = rowHeight * 2;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tfillableSpace -= rowHeight;\n\t\t\t\t\tpaddingAdjust += rowHeight;\n\n\t\t\t\t\tthis.vDomBottom++;\n\t\t\t\t\tindex++;\n\t\t\t\t\ti++;\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\n\t\tfor (let row of addedRows){\n\t\t\trow.clearCellHeight();\n\t\t}\n\n\t\tthis._quickNormalizeRowHeight(addedRows);\n\n\t\tif(paddingAdjust){\n\t\t\tthis.vDomBottomPad -= paddingAdjust;\n\n\t\t\tif(this.vDomBottomPad < 0 || index == rows.length -1){\n\t\t\t\tthis.vDomBottomPad = 0;\n\t\t\t}\n\n\t\t\ttable.style.paddingBottom = this.vDomBottomPad + \"px\";\n\t\t\tthis.vDomScrollPosBottom += paddingAdjust;\n\t\t}\n\t}\n\n\t_removeBottomRow(rows, fillableSpace){\n\t\tvar removableRows = [],\n\t\tpaddingAdjust = 0,\n\t\ti = 0,\n\t\tworking = true;\n\n\t\twhile(working){\n\t\t\tlet row = rows[this.vDomBottom],\n\t\t\trowHeight;\n\n\t\t\tif(row && i < this.vDomMaxRenderChain){\n\t\t\t\trowHeight = row.getHeight() || this.vDomRowHeight;\n\n\t\t\t\tif(fillableSpace >= rowHeight){\n\t\t\t\t\tthis.vDomBottom --;\n\n\t\t\t\t\tfillableSpace -= rowHeight;\n\t\t\t\t\tpaddingAdjust += rowHeight;\n\n\t\t\t\t\tremovableRows.push(row);\n\t\t\t\t\ti++;\n\t\t\t\t}else{\n\t\t\t\t\tworking = false;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tworking = false;\n\t\t\t}\n\t\t}\n\n\t\tfor (let row of removableRows){\n\t\t\tlet rowEl = row.getElement();\n\n\t\t\tif(rowEl.parentNode){\n\t\t\t\trowEl.parentNode.removeChild(rowEl);\n\t\t\t}\n\t\t}\n\n\t\tif(paddingAdjust){\n\t\t\tthis.vDomBottomPad += paddingAdjust;\n\n\t\t\tif(this.vDomBottomPad < 0){\n\t\t\t\tthis.vDomBottomPad = 0;\n\t\t\t}\n\n\t\t\tthis.tableElement.style.paddingBottom = this.vDomBottomPad + \"px\";\n\t\t\tthis.vDomScrollPosBottom -= paddingAdjust;\n\t\t}\n\t}\n\n\t_quickNormalizeRowHeight(rows){\n\t\tfor(let row of rows){\n\t\t\trow.calcHeight();\n\t\t}\n\n\t\tfor(let row of rows){\n\t\t\trow.setCellHeight();\n\t\t}\n\t}\n}\n","import CoreFeature from './CoreFeature.js';\nimport Row from './row/Row.js';\nimport RowComponent from './row/RowComponent.js';\nimport Helpers from './tools/Helpers.js';\n\nimport RendererBasicVertical from './rendering/renderers/BasicVertical.js';\nimport RendererVirtualDomVertical from './rendering/renderers/VirtualDomVertical.js';\n\nexport default class RowManager extends CoreFeature{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.element = this.createHolderElement(); //containing element\n\t\tthis.tableElement = this.createTableElement(); //table element\n\t\tthis.heightFixer = this.createTableElement(); //table element\n\t\tthis.placeholder = null; //placeholder element\n\t\tthis.placeholderContents = null; //placeholder element\n\t\t\n\t\tthis.firstRender = false; //handle first render\n\t\tthis.renderMode = \"virtual\"; //current rendering mode\n\t\tthis.fixedHeight = false; //current rendering mode\n\t\t\n\t\tthis.rows = []; //hold row data objects\n\t\tthis.activeRowsPipeline = []; //hold calculation of active rows\n\t\tthis.activeRows = []; //rows currently available to on display in the table\n\t\tthis.activeRowsCount = 0; //count of active rows\n\t\t\n\t\tthis.displayRows = []; //rows currently on display in the table\n\t\tthis.displayRowsCount = 0; //count of display rows\n\t\t\n\t\tthis.scrollTop = 0;\n\t\tthis.scrollLeft = 0;\n\t\t\n\t\tthis.redrawBlock = false; //prevent redraws to allow multiple data manipulations before continuing\n\t\tthis.redrawBlockRestoreConfig = false; //store latest redraw function calls for when redraw is needed\n\t\tthis.redrawBlockRenderInPosition = false; //store latest redraw function calls for when redraw is needed\n\t\t\n\t\tthis.dataPipeline = []; //hold data pipeline tasks\n\t\tthis.displayPipeline = []; //hold data display pipeline tasks\n\t\t\n\t\tthis.scrollbarWidth = 0;\n\t\t\n\t\tthis.renderer = null;\n\t}\n\t\n\t//////////////// Setup Functions /////////////////\n\t\n\tcreateHolderElement (){\n\t\tvar el = document.createElement(\"div\");\n\t\t\n\t\tel.classList.add(\"tabulator-tableholder\");\n\t\tel.setAttribute(\"tabindex\", 0);\n\t\t// el.setAttribute(\"role\", \"rowgroup\");\n\t\t\n\t\treturn el;\n\t}\n\t\n\tcreateTableElement (){\n\t\tvar el = document.createElement(\"div\");\n\t\t\n\t\tel.classList.add(\"tabulator-table\");\n\t\tel.setAttribute(\"role\", \"rowgroup\");\n\t\t\n\t\treturn el;\n\t}\n\t\n\tinitializePlaceholder(){\n\t\tvar placeholder = this.table.options.placeholder;\n\t\t\n\t\tif(typeof placeholder === \"function\"){\n\t\t\tplaceholder = placeholder.call(this.table);\n\t\t}\n\t\t\n\t\tplaceholder = this.chain(\"placeholder\", [placeholder], placeholder, placeholder) || placeholder;\n\t\t\n\t\t//configure placeholder element\n\t\tif(placeholder){\t\n\t\t\tlet el = document.createElement(\"div\");\n\t\t\tel.classList.add(\"tabulator-placeholder\");\n\t\t\t\n\t\t\tif(typeof placeholder == \"string\"){\n\t\t\t\tlet contents = document.createElement(\"div\");\n\t\t\t\tcontents.classList.add(\"tabulator-placeholder-contents\");\n\t\t\t\tcontents.innerHTML = placeholder;\n\t\t\t\t\n\t\t\t\tel.appendChild(contents);\n\t\t\t\t\n\t\t\t\tthis.placeholderContents = contents;\n\t\t\t\t\n\t\t\t}else if(typeof HTMLElement !== \"undefined\" && placeholder instanceof HTMLElement){\n\t\t\t\t\n\t\t\t\tel.appendChild(placeholder);\n\t\t\t\tthis.placeholderContents = placeholder;\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Invalid placeholder provided, must be string or HTML Element\", placeholder);\n\t\t\t\t\n\t\t\t\tthis.el = null;\n\t\t\t}\n\t\t\t\n\t\t\tthis.placeholder = el;\n\t\t}\n\t}\n\t\n\t//return containing element\n\tgetElement(){\n\t\treturn this.element;\n\t}\n\t\n\t//return table element\n\tgetTableElement(){\n\t\treturn this.tableElement;\n\t}\n\t\n\tinitialize(){\n\t\tthis.initializePlaceholder();\n\t\tthis.initializeRenderer();\n\t\t\n\t\t//initialize manager\n\t\tthis.element.appendChild(this.tableElement);\n\t\t\n\t\tthis.firstRender = true;\n\t\t\n\t\t//scroll header along with table body\n\t\tthis.element.addEventListener(\"scroll\", () => {\n\t\t\tvar left = this.element.scrollLeft,\n\t\t\tleftDir = this.scrollLeft > left,\n\t\t\ttop = this.element.scrollTop,\n\t\t\ttopDir = this.scrollTop > top;\n\t\t\t\n\t\t\t//handle horizontal scrolling\n\t\t\tif(this.scrollLeft != left){\n\t\t\t\tthis.scrollLeft = left;\n\t\t\t\t\n\t\t\t\tthis.dispatch(\"scroll-horizontal\", left, leftDir);\n\t\t\t\tthis.dispatchExternal(\"scrollHorizontal\", left, leftDir);\n\t\t\t\t\n\t\t\t\tthis._positionPlaceholder();\n\t\t\t}\n\t\t\t\n\t\t\t//handle vertical scrolling\n\t\t\tif(this.scrollTop != top){\n\t\t\t\tthis.scrollTop = top;\n\t\t\t\t\n\t\t\t\tthis.renderer.scrollRows(top, topDir);\n\t\t\t\t\n\t\t\t\tthis.dispatch(\"scroll-vertical\", top, topDir);\n\t\t\t\tthis.dispatchExternal(\"scrollVertical\", top, topDir);\n\t\t\t}\n\t\t});\n\t}\n\t\n\t////////////////// Row Manipulation //////////////////\n\tfindRow(subject){\n\t\tif(typeof subject == \"object\"){\n\t\t\tif(subject instanceof Row){\n\t\t\t\t//subject is row element\n\t\t\t\treturn subject;\n\t\t\t}else if(subject instanceof RowComponent){\n\t\t\t\t//subject is public row component\n\t\t\t\treturn subject._getSelf() || false;\n\t\t\t}else if(typeof HTMLElement !== \"undefined\" && subject instanceof HTMLElement){\n\t\t\t\t//subject is a HTML element of the row\n\t\t\t\tlet match = this.rows.find((row) => {\n\t\t\t\t\treturn row.getElement() === subject;\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\treturn match || false;\n\t\t\t}else if(subject === null){\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}else if(typeof subject == \"undefined\"){\n\t\t\treturn false;\n\t\t}else{\n\t\t\t//subject should be treated as the index of the row\n\t\t\tlet match = this.rows.find((row) => {\n\t\t\t\treturn row.data[this.table.options.index] == subject;\n\t\t\t});\n\t\t\t\n\t\t\treturn match || false;\n\t\t}\n\t\t\n\t\t//catch all for any other type of input\n\t\treturn false;\n\t}\n\t\n\tgetRowFromDataObject(data){\n\t\tvar match = this.rows.find((row) => {\n\t\t\treturn row.data === data;\n\t\t});\n\t\t\n\t\treturn match || false;\n\t}\n\t\n\tgetRowFromPosition(position){\n\t\treturn this.getDisplayRows().find((row) => {\n\t\t\treturn row.getPosition() === position && row.isDisplayed();\n\t\t});\n\t}\n\t\n\tscrollToRow(row, position, ifVisible){\n\t\treturn this.renderer.scrollToRowPosition(row, position, ifVisible);\n\t}\n\t\n\t////////////////// Data Handling //////////////////\n\tsetData(data, renderInPosition, columnsChanged){\n\t\treturn new Promise((resolve, reject)=>{\n\t\t\tif(renderInPosition && this.getDisplayRows().length){\n\t\t\t\tif(this.table.options.pagination){\n\t\t\t\t\tthis._setDataActual(data, true);\n\t\t\t\t}else{\n\t\t\t\t\tthis.reRenderInPosition(() => {\n\t\t\t\t\t\tthis._setDataActual(data);\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(this.table.options.autoColumns && columnsChanged && this.table.initialized){\n\t\t\t\t\tthis.table.columnManager.generateColumnsFromRowData(data);\n\t\t\t\t}\n\t\t\t\tthis.resetScroll();\n\t\t\t\t\n\t\t\t\tthis._setDataActual(data);\n\t\t\t}\n\t\t\t\n\t\t\tresolve();\n\t\t});\n\t}\n\t\n\t_setDataActual(data, renderInPosition){\n\t\tthis.dispatchExternal(\"dataProcessing\", data);\n\t\t\n\t\tthis._wipeElements();\n\t\t\n\t\tif(Array.isArray(data)){\n\t\t\tthis.dispatch(\"data-processing\", data);\n\t\t\t\n\t\t\tdata.forEach((def, i) => {\n\t\t\t\tif(def && typeof def === \"object\"){\n\t\t\t\t\tvar row = new Row(def, this);\n\t\t\t\t\tthis.rows.push(row);\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Data Loading Warning - Invalid row data detected and ignored, expecting object but received:\", def);\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tthis.refreshActiveData(false, false, renderInPosition);\n\t\t\t\n\t\t\tthis.dispatch(\"data-processed\", data);\n\t\t\tthis.dispatchExternal(\"dataProcessed\", data);\n\t\t}else{\n\t\t\tconsole.error(\"Data Loading Error - Unable to process data due to invalid data type \\nExpecting: array \\nReceived: \", typeof data, \"\\nData: \", data);\n\t\t}\n\t}\n\t\n\t_wipeElements(){\n\t\tthis.dispatch(\"rows-wipe\");\n\t\t\n\t\tthis.destroy();\n\t\t\n\t\tthis.adjustTableSize();\n\t\t\n\t\tthis.dispatch(\"rows-wiped\");\n\t}\n\t\n\tdestroy(){\n\t\tthis.rows.forEach((row) => {\n\t\t\trow.wipe();\n\t\t});\n\t\t\n\t\tthis.rows = [];\n\t\tthis.activeRows = [];\n\t\tthis.activeRowsPipeline = [];\n\t\tthis.activeRowsCount = 0;\n\t\tthis.displayRows = [];\n\t\tthis.displayRowsCount = 0;\n\t}\n\t\n\tdeleteRow(row, blockRedraw){\n\t\tvar allIndex = this.rows.indexOf(row),\n\t\tactiveIndex = this.activeRows.indexOf(row);\n\t\t\n\t\tif(activeIndex > -1){\n\t\t\tthis.activeRows.splice(activeIndex, 1);\n\t\t}\n\t\t\n\t\tif(allIndex > -1){\n\t\t\tthis.rows.splice(allIndex, 1);\n\t\t}\n\t\t\n\t\tthis.setActiveRows(this.activeRows);\n\t\t\n\t\tthis.displayRowIterator((rows) => {\n\t\t\tvar displayIndex = rows.indexOf(row);\n\t\t\t\n\t\t\tif(displayIndex > -1){\n\t\t\t\trows.splice(displayIndex, 1);\n\t\t\t}\n\t\t});\n\t\t\n\t\tif(!blockRedraw){\n\t\t\tthis.reRenderInPosition();\n\t\t}\n\t\t\n\t\tthis.regenerateRowPositions();\n\t\t\n\t\tthis.dispatchExternal(\"rowDeleted\", row.getComponent());\n\t\t\n\t\tif(!this.displayRowsCount){\n\t\t\tthis.tableEmpty();\n\t\t}\n\t\t\n\t\tif(this.subscribedExternal(\"dataChanged\")){\n\t\t\tthis.dispatchExternal(\"dataChanged\", this.getData());\n\t\t}\n\t}\n\t\n\taddRow(data, pos, index, blockRedraw){\n\t\tvar row = this.addRowActual(data, pos, index, blockRedraw);\n\t\treturn row;\n\t}\n\t\n\t//add multiple rows\n\taddRows(data, pos, index, refreshDisplayOnly){\n\t\tvar rows = [];\n\t\t\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tpos = this.findAddRowPos(pos);\n\t\t\t\n\t\t\tif(!Array.isArray(data)){\n\t\t\t\tdata = [data];\n\t\t\t}\n\t\t\t\n\t\t\tif((typeof index == \"undefined\" && pos) || (typeof index !== \"undefined\" && !pos)){\n\t\t\t\tdata.reverse();\n\t\t\t}\n\t\t\t\n\t\t\tdata.forEach((item, i) => {\n\t\t\t\tvar row = this.addRow(item, pos, index, true);\n\t\t\t\trows.push(row);\n\t\t\t\tthis.dispatch(\"row-added\", row, item, pos, index);\n\t\t\t});\n\t\t\t\n\t\t\tthis.refreshActiveData(refreshDisplayOnly ? \"displayPipeline\" : false, false, true);\n\t\t\t\n\t\t\tthis.regenerateRowPositions();\n\t\t\t\n\t\t\tif(rows.length){\n\t\t\t\tthis._clearPlaceholder();\n\t\t\t}\n\t\t\t\n\t\t\tresolve(rows);\n\t\t});\n\t}\n\t\n\tfindAddRowPos(pos){\n\t\tif(typeof pos === \"undefined\"){\n\t\t\tpos = this.table.options.addRowPos;\n\t\t}\n\t\t\n\t\tif(pos === \"pos\"){\n\t\t\tpos = true;\n\t\t}\n\t\t\n\t\tif(pos === \"bottom\"){\n\t\t\tpos = false;\n\t\t}\n\t\t\n\t\treturn pos;\n\t}\n\t\n\taddRowActual(data, pos, index, blockRedraw){\n\t\tvar row = data instanceof Row ? data : new Row(data || {}, this),\n\t\ttop = this.findAddRowPos(pos),\n\t\tallIndex = -1,\n\t\tactiveIndex, chainResult;\n\t\t\n\t\tif(!index){\n\t\t\tchainResult = this.chain(\"row-adding-position\", [row, top], null, {index, top});\n\t\t\t\n\t\t\tindex = chainResult.index;\n\t\t\ttop = chainResult.top;\n\t\t}\n\t\t\n\t\tif(typeof index !== \"undefined\"){\n\t\t\tindex = this.findRow(index);\n\t\t}\n\t\t\n\t\tindex = this.chain(\"row-adding-index\", [row, index, top], null, index);\n\t\t\n\t\tif(index){\n\t\t\tallIndex = this.rows.indexOf(index);\n\t\t}\n\t\t\n\t\tif(index && allIndex > -1){\n\t\t\tactiveIndex = this.activeRows.indexOf(index);\n\t\t\t\n\t\t\tthis.displayRowIterator(function(rows){\n\t\t\t\tvar displayIndex = rows.indexOf(index);\n\t\t\t\t\n\t\t\t\tif(displayIndex > -1){\n\t\t\t\t\trows.splice((top ? displayIndex : displayIndex + 1), 0, row);\n\t\t\t\t}\n\t\t\t});\n\t\t\t\n\t\t\tif(activeIndex > -1){\n\t\t\t\tthis.activeRows.splice((top ? activeIndex : activeIndex + 1), 0, row);\n\t\t\t}\n\t\t\t\n\t\t\tthis.rows.splice((top ? allIndex : allIndex + 1), 0, row);\n\t\t\t\n\t\t}else{\n\t\t\t\n\t\t\tif(top){\n\t\t\t\t\n\t\t\t\tthis.displayRowIterator(function(rows){\n\t\t\t\t\trows.unshift(row);\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tthis.activeRows.unshift(row);\n\t\t\t\tthis.rows.unshift(row);\n\t\t\t}else{\n\t\t\t\tthis.displayRowIterator(function(rows){\n\t\t\t\t\trows.push(row);\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tthis.activeRows.push(row);\n\t\t\t\tthis.rows.push(row);\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.setActiveRows(this.activeRows);\n\t\t\n\t\tthis.dispatchExternal(\"rowAdded\", row.getComponent());\n\t\t\n\t\tif(this.subscribedExternal(\"dataChanged\")){\n\t\t\tthis.dispatchExternal(\"dataChanged\", this.table.rowManager.getData());\n\t\t}\n\t\t\n\t\tif(!blockRedraw){\n\t\t\tthis.reRenderInPosition();\n\t\t}\n\t\t\n\t\treturn row;\n\t}\n\t\n\tmoveRow(from, to, after){\n\t\tthis.dispatch(\"row-move\", from, to, after);\n\t\t\n\t\tthis.moveRowActual(from, to, after);\n\t\t\n\t\tthis.regenerateRowPositions();\n\t\t\n\t\tthis.dispatch(\"row-moved\", from, to, after);\n\t\tthis.dispatchExternal(\"rowMoved\", from.getComponent());\n\t}\n\t\n\tmoveRowActual(from, to, after){\n\t\tthis.moveRowInArray(this.rows, from, to, after);\n\t\tthis.moveRowInArray(this.activeRows, from, to, after);\n\t\t\n\t\tthis.displayRowIterator((rows) => {\n\t\t\tthis.moveRowInArray(rows, from, to, after);\n\t\t});\n\t\t\n\t\tthis.dispatch(\"row-moving\", from, to, after);\n\t}\n\t\n\tmoveRowInArray(rows, from, to, after){\n\t\tvar\tfromIndex, toIndex, start, end;\n\t\t\n\t\tif(from !== to){\n\t\t\t\n\t\t\tfromIndex = rows.indexOf(from);\n\t\t\t\n\t\t\tif (fromIndex > -1) {\n\t\t\t\t\n\t\t\t\trows.splice(fromIndex, 1);\n\t\t\t\t\n\t\t\t\ttoIndex = rows.indexOf(to);\n\t\t\t\t\n\t\t\t\tif (toIndex > -1) {\n\t\t\t\t\t\n\t\t\t\t\tif(after){\n\t\t\t\t\t\trows.splice(toIndex+1, 0, from);\n\t\t\t\t\t}else{\n\t\t\t\t\t\trows.splice(toIndex, 0, from);\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t}else{\n\t\t\t\t\trows.splice(fromIndex, 0, from);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t//restyle rows\n\t\t\tif(rows === this.getDisplayRows()){\n\t\t\t\t\n\t\t\t\tstart = fromIndex < toIndex ? fromIndex : toIndex;\n\t\t\t\tend = toIndex > fromIndex ? toIndex : fromIndex +1;\n\t\t\t\t\n\t\t\t\tfor(let i = start; i <= end; i++){\n\t\t\t\t\tif(rows[i]){\n\t\t\t\t\t\tthis.styleRow(rows[i], i);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\tclearData(){\n\t\tthis.setData([]);\n\t}\n\t\n\tgetRowIndex(row){\n\t\treturn this.findRowIndex(row, this.rows);\n\t}\n\t\n\tgetDisplayRowIndex(row){\n\t\tvar index = this.getDisplayRows().indexOf(row);\n\t\treturn index > -1 ? index : false;\n\t}\n\t\n\tnextDisplayRow(row, rowOnly){\n\t\tvar index = this.getDisplayRowIndex(row),\n\t\tnextRow = false;\n\t\t\n\t\t\n\t\tif(index !== false && index < this.displayRowsCount -1){\n\t\t\tnextRow = this.getDisplayRows()[index+1];\n\t\t}\n\t\t\n\t\tif(nextRow && (!(nextRow instanceof Row) || nextRow.type != \"row\")){\n\t\t\treturn this.nextDisplayRow(nextRow, rowOnly);\n\t\t}\n\t\t\n\t\treturn nextRow;\n\t}\n\t\n\tprevDisplayRow(row, rowOnly){\n\t\tvar index = this.getDisplayRowIndex(row),\n\t\tprevRow = false;\n\t\t\n\t\tif(index){\n\t\t\tprevRow = this.getDisplayRows()[index-1];\n\t\t}\n\t\t\n\t\tif(rowOnly && prevRow && (!(prevRow instanceof Row) || prevRow.type != \"row\")){\n\t\t\treturn this.prevDisplayRow(prevRow, rowOnly);\n\t\t}\n\t\t\n\t\treturn prevRow;\n\t}\n\t\n\tfindRowIndex(row, list){\n\t\tvar rowIndex;\n\t\t\n\t\trow = this.findRow(row);\n\t\t\n\t\tif(row){\n\t\t\trowIndex = list.indexOf(row);\n\t\t\t\n\t\t\tif(rowIndex > -1){\n\t\t\t\treturn rowIndex;\n\t\t\t}\n\t\t}\n\t\t\n\t\treturn false;\n\t}\n\t\n\tgetData(active, transform){\n\t\tvar output = [],\n\t\trows = this.getRows(active);\n\t\t\n\t\trows.forEach(function(row){\n\t\t\tif(row.type == \"row\"){\n\t\t\t\toutput.push(row.getData(transform || \"data\"));\n\t\t\t}\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgetComponents(active){\n\t\tvar\toutput = [],\n\t\trows = this.getRows(active);\n\t\t\n\t\trows.forEach(function(row){\n\t\t\toutput.push(row.getComponent());\n\t\t});\n\t\t\n\t\treturn output;\n\t}\n\t\n\tgetDataCount(active){\n\t\tvar rows = this.getRows(active);\n\t\t\n\t\treturn rows.length;\n\t}\n\t\n\tscrollHorizontal(left){\n\t\tthis.scrollLeft = left;\n\t\tthis.element.scrollLeft = left;\n\t\t\n\t\tthis.dispatch(\"scroll-horizontal\", left);\n\t}\n\t\n\tregisterDataPipelineHandler(handler, priority){\n\t\tif(typeof priority !== \"undefined\"){\n\t\t\tthis.dataPipeline.push({handler, priority});\n\t\t\tthis.dataPipeline.sort((a, b) => {\n\t\t\t\treturn a.priority - b.priority;\n\t\t\t});\n\t\t}else{\n\t\t\tconsole.error(\"Data pipeline handlers must have a priority in order to be registered\");\n\t\t}\n\t}\n\t\n\tregisterDisplayPipelineHandler(handler, priority){\n\t\tif(typeof priority !== \"undefined\"){\n\t\t\tthis.displayPipeline.push({handler, priority});\n\t\t\tthis.displayPipeline.sort((a, b) => {\n\t\t\t\treturn a.priority - b.priority;\n\t\t\t});\n\t\t}else{\n\t\t\tconsole.error(\"Display pipeline handlers must have a priority in order to be registered\");\n\t\t}\n\t}\n\t\n\t//set active data set\n\trefreshActiveData(handler, skipStage, renderInPosition){\n\t\tvar table = this.table,\n\t\tstage = \"\",\n\t\tindex = 0,\n\t\tcascadeOrder = [\"all\", \"dataPipeline\", \"display\", \"displayPipeline\", \"end\"];\n\t\t\n\t\tif(!this.table.destroyed){\n\t\t\tif(typeof handler === \"function\"){\n\t\t\t\tindex = this.dataPipeline.findIndex((item) => {\n\t\t\t\t\treturn item.handler === handler;\n\t\t\t\t});\n\t\t\t\t\n\t\t\t\tif(index > -1){\n\t\t\t\t\tstage = \"dataPipeline\";\n\t\t\t\t\t\n\t\t\t\t\tif(skipStage){\n\t\t\t\t\t\tif(index == this.dataPipeline.length - 1){\n\t\t\t\t\t\t\tstage = \"display\";\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\tindex++;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tindex = this.displayPipeline.findIndex((item) => {\n\t\t\t\t\t\treturn item.handler === handler;\n\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\tif(index > -1){\n\t\t\t\t\t\tstage = \"displayPipeline\";\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(skipStage){\n\t\t\t\t\t\t\tif(index == this.displayPipeline.length - 1){\n\t\t\t\t\t\t\t\tstage = \"end\";\n\t\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\t\tindex++;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.error(\"Unable to refresh data, invalid handler provided\", handler);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tstage = handler || \"all\";\n\t\t\t\tindex = 0;\n\t\t\t}\n\t\t\t\n\t\t\tif(this.redrawBlock){\n\t\t\t\tif(!this.redrawBlockRestoreConfig || (this.redrawBlockRestoreConfig && ((this.redrawBlockRestoreConfig.stage === stage && index < this.redrawBlockRestoreConfig.index) || (cascadeOrder.indexOf(stage) < cascadeOrder.indexOf(this.redrawBlockRestoreConfig.stage))))){\n\t\t\t\t\tthis.redrawBlockRestoreConfig = {\n\t\t\t\t\t\thandler: handler,\n\t\t\t\t\t\tskipStage: skipStage,\n\t\t\t\t\t\trenderInPosition: renderInPosition,\n\t\t\t\t\t\tstage:stage,\n\t\t\t\t\t\tindex:index,\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\treturn;\n\t\t\t}else{\n\t\t\t\tif(Helpers.elVisible(this.element)){\n\t\t\t\t\tif(renderInPosition){\n\t\t\t\t\t\tthis.reRenderInPosition(this.refreshPipelines.bind(this, handler, stage, index, renderInPosition));\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.refreshPipelines(handler, stage, index, renderInPosition);\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(!handler){\n\t\t\t\t\t\t\tthis.table.columnManager.renderer.renderColumns();\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t\tthis.renderTable();\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(table.options.layoutColumnsOnNewData){\n\t\t\t\t\t\t\tthis.table.columnManager.redraw(true);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tthis.refreshPipelines(handler, stage, index, renderInPosition);\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.dispatch(\"data-refreshed\");\n\t\t\t}\n\t\t}\n\t}\n\t\n\trefreshPipelines(handler, stage, index, renderInPosition){\n\t\tthis.dispatch(\"data-refreshing\");\n\t\t\n\t\tif(!handler){\n\t\t\tthis.activeRowsPipeline[0] = this.rows.slice(0);\n\t\t}\n\t\t\n\t\t//cascade through data refresh stages\n\t\tswitch(stage){\n\t\t\tcase \"all\":\n\t\t\t//handle case where all data needs refreshing\n\t\t\t\n\t\t\tcase \"dataPipeline\":\n\t\t\t\n\t\t\t\tfor(let i = index; i < this.dataPipeline.length; i++){\n\t\t\t\t\tlet result = this.dataPipeline[i].handler(this.activeRowsPipeline[i].slice(0));\n\t\t\t\t\n\t\t\t\t\tthis.activeRowsPipeline[i + 1] = result || this.activeRowsPipeline[i].slice(0);\n\t\t\t\t}\n\t\t\t\n\t\t\t\tthis.setActiveRows(this.activeRowsPipeline[this.dataPipeline.length]);\n\t\t\t\n\t\t\tcase \"display\":\n\t\t\t\tindex = 0;\n\t\t\t\tthis.resetDisplayRows();\n\t\t\t\n\t\t\tcase \"displayPipeline\":\n\t\t\t\tfor(let i = index; i < this.displayPipeline.length; i++){\n\t\t\t\t\tlet result = this.displayPipeline[i].handler((i ? this.getDisplayRows(i - 1) : this.activeRows).slice(0), renderInPosition);\n\t\t\t\t\n\t\t\t\t\tthis.setDisplayRows(result || this.getDisplayRows(i - 1).slice(0), i);\n\t\t\t\t}\n\t\t\t\n\t\t\tcase \"end\":\n\t\t\t//case to handle scenario when trying to skip past end stage\n\t\t\t\tthis.regenerateRowPositions();\n\t\t}\n\t\t\n\t\tif(this.getDisplayRows().length){\n\t\t\tthis._clearPlaceholder();\n\t\t}\n\t}\n\t\n\t//regenerate row positions\n\tregenerateRowPositions(){\n\t\tvar rows = this.getDisplayRows();\n\t\tvar index = 1;\n\t\t\n\t\trows.forEach((row) => {\n\t\t\tif (row.type === \"row\"){\n\t\t\t\trow.setPosition(index);\n\t\t\t\tindex++;\n\t\t\t}\n\t\t});\n\t}\n\t\n\tsetActiveRows(activeRows){\n\t\tthis.activeRows = this.activeRows = Object.assign([], activeRows);\n\t\tthis.activeRowsCount = this.activeRows.length;\n\t}\n\t\n\t//reset display rows array\n\tresetDisplayRows(){\n\t\tthis.displayRows = [];\n\t\t\n\t\tthis.displayRows.push(this.activeRows.slice(0));\n\t\t\n\t\tthis.displayRowsCount = this.displayRows[0].length;\n\t}\n\t\n\t//set display row pipeline data\n\tsetDisplayRows(displayRows, index){\n\t\tthis.displayRows[index] = displayRows;\n\t\t\n\t\tif(index == this.displayRows.length -1){\n\t\t\tthis.displayRowsCount = this.displayRows[this.displayRows.length -1].length;\n\t\t}\n\t}\n\t\n\tgetDisplayRows(index){\n\t\tif(typeof index == \"undefined\"){\n\t\t\treturn this.displayRows.length ? this.displayRows[this.displayRows.length -1] : [];\n\t\t}else{\n\t\t\treturn this.displayRows[index] || [];\n\t\t}\n\t}\n\t\n\tgetVisibleRows(chain, viewable){\n\t\tvar rows = Object.assign([], this.renderer.visibleRows(!viewable));\n\t\t\n\t\tif(chain){\n\t\t\trows = this.chain(\"rows-visible\", [viewable], rows, rows);\n\t\t}\n\t\t\n\t\treturn rows;\n\t}\n\t\n\t//repeat action across display rows\n\tdisplayRowIterator(callback){\n\t\tthis.activeRowsPipeline.forEach(callback);\n\t\tthis.displayRows.forEach(callback);\n\t\t\n\t\tthis.displayRowsCount = this.displayRows[this.displayRows.length -1].length;\n\t}\n\t\n\t//return only actual rows (not group headers etc)\n\tgetRows(type){\n\t\tvar rows = [];\n\t\t\n\t\tswitch(type){\n\t\t\tcase \"active\":\n\t\t\t\trows = this.activeRows;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"display\":\n\t\t\t\trows = this.table.rowManager.getDisplayRows();\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"visible\":\n\t\t\t\trows = this.getVisibleRows(false, true);\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tdefault:\n\t\t\t\trows = this.chain(\"rows-retrieve\", type, null, this.rows) || this.rows;\n\t\t}\n\t\t\n\t\treturn rows;\n\t}\n\t\n\t///////////////// Table Rendering /////////////////\n\t//trigger rerender of table in current position\n\treRenderInPosition(callback){\n\t\tif(this.redrawBlock){\n\t\t\tif(callback){\n\t\t\t\tcallback();\n\t\t\t}else{\n\t\t\t\tthis.redrawBlockRenderInPosition = true;\n\t\t\t}\n\t\t}else{\n\t\t\tthis.dispatchExternal(\"renderStarted\");\n\t\t\t\n\t\t\tthis.renderer.rerenderRows(callback);\n\t\t\t\n\t\t\tif(!this.fixedHeight){\n\t\t\t\tthis.adjustTableSize();\n\t\t\t}\n\t\t\t\n\t\t\tthis.scrollBarCheck();\n\t\t\t\n\t\t\tthis.dispatchExternal(\"renderComplete\");\n\t\t}\n\t}\n\t\n\tscrollBarCheck(){\n\t\tvar scrollbarWidth = 0;\n\t\t\n\t\t//adjust for vertical scrollbar moving table when present\n\t\tif(this.element.scrollHeight > this.element.clientHeight){\n\t\t\tscrollbarWidth = this.element.offsetWidth - this.element.clientWidth;\n\t\t}\n\t\t\n\t\tif(scrollbarWidth !== this.scrollbarWidth){\n\t\t\tthis.scrollbarWidth = scrollbarWidth;\n\t\t\tthis.dispatch(\"scrollbar-vertical\", scrollbarWidth);\n\t\t}\n\t}\n\t\n\tinitializeRenderer(){\n\t\tvar renderClass;\n\t\t\n\t\tvar renderers = {\n\t\t\t\"virtual\": RendererVirtualDomVertical,\n\t\t\t\"basic\": RendererBasicVertical,\n\t\t};\n\t\t\n\t\tif(typeof this.table.options.renderVertical === \"string\"){\n\t\t\trenderClass = renderers[this.table.options.renderVertical];\n\t\t}else{\n\t\t\trenderClass = this.table.options.renderVertical;\n\t\t}\n\t\t\n\t\tif(renderClass){\n\t\t\tthis.renderMode = this.table.options.renderVertical;\n\t\t\t\n\t\t\tthis.renderer = new renderClass(this.table, this.element, this.tableElement);\n\t\t\tthis.renderer.initialize();\n\t\t\t\n\t\t\tif((this.table.element.clientHeight || this.table.options.height) && !(this.table.options.minHeight && this.table.options.maxHeight)){\n\t\t\t\tthis.fixedHeight = true;\n\t\t\t}else{\n\t\t\t\tthis.fixedHeight = false;\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.error(\"Unable to find matching renderer:\", this.table.options.renderVertical);\n\t\t}\n\t}\n\t\n\tgetRenderMode(){\n\t\treturn this.renderMode;\n\t}\n\t\n\trenderTable(){\n\t\tthis.dispatchExternal(\"renderStarted\");\n\t\t\n\t\tthis.element.scrollTop = 0;\n\t\t\n\t\tthis._clearTable();\n\t\t\n\t\tif(this.displayRowsCount){\n\t\t\tthis.renderer.renderRows();\n\t\t\t\n\t\t\tif(this.firstRender){\n\t\t\t\tthis.firstRender = false;\n\t\t\t\t\n\t\t\t\tif(!this.fixedHeight){\n\t\t\t\t\tthis.adjustTableSize();\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tthis.layoutRefresh(true);\n\t\t\t}\n\t\t}else{\n\t\t\tthis.renderEmptyScroll();\n\t\t}\n\t\t\n\t\tif(!this.fixedHeight){\n\t\t\tthis.adjustTableSize();\n\t\t}\n\t\t\n\t\tthis.dispatch(\"table-layout\");\n\t\t\n\t\tif(!this.displayRowsCount){\n\t\t\tthis._showPlaceholder();\n\t\t}\n\t\t\n\t\tthis.scrollBarCheck();\n\t\t\n\t\tthis.dispatchExternal(\"renderComplete\");\n\t}\n\t\n\t//show scrollbars on empty table div\n\trenderEmptyScroll(){\n\t\tif(this.placeholder){\n\t\t\tthis.tableElement.style.display = \"none\";\n\t\t}else{\n\t\t\tthis.tableElement.style.minWidth = this.table.columnManager.getWidth() + \"px\";\n\t\t\t// this.tableElement.style.minHeight = \"1px\";\n\t\t\t// this.tableElement.style.visibility = \"hidden\";\n\t\t}\n\t}\n\t\n\t_clearTable(){\t\n\t\tthis._clearPlaceholder();\n\t\t\n\t\tthis.scrollTop = 0;\n\t\tthis.scrollLeft = 0;\n\t\t\n\t\tthis.renderer.clearRows();\n\t}\n\t\n\ttableEmpty(){\n\t\tthis.renderEmptyScroll();\n\t\tthis._showPlaceholder();\n\t}\n\t\n\t_showPlaceholder(){\n\t\tif(this.placeholder){\n\t\t\tif(this.placeholder && this.placeholder.parentNode){\n\t\t\t\tthis.placeholder.parentNode.removeChild(this.placeholder);\n\t\t\t}\n\t\t\t\n\t\t\tthis.initializePlaceholder();\n\t\t\t\n\t\t\tthis.placeholder.setAttribute(\"tabulator-render-mode\", this.renderMode);\n\t\t\t\n\t\t\tthis.getElement().appendChild(this.placeholder);\n\t\t\tthis._positionPlaceholder();\n\n\t\t\tthis.adjustTableSize();\n\t\t}\n\t}\n\t\n\t_clearPlaceholder(){\n\t\tif(this.placeholder && this.placeholder.parentNode){\n\t\t\tthis.placeholder.parentNode.removeChild(this.placeholder);\n\t\t}\n\t\t\n\t\t// clear empty table placeholder min\n\t\tthis.tableElement.style.minWidth = \"\";\n\t\tthis.tableElement.style.display = \"\";\n\t}\n\t\n\t_positionPlaceholder(){\n\t\tif(this.placeholder && this.placeholder.parentNode){\n\t\t\tthis.placeholder.style.width = this.table.columnManager.getWidth() + \"px\";\n\t\t\tthis.placeholderContents.style.width = this.table.rowManager.element.clientWidth + \"px\";\n\t\t\tthis.placeholderContents.style.marginLeft = this.scrollLeft + \"px\";\n\t\t}\n\t}\n\t\n\tstyleRow(row, index){\n\t\tvar rowEl = row.getElement();\n\t\t\n\t\tif(index % 2){\n\t\t\trowEl.classList.add(\"tabulator-row-even\");\n\t\t\trowEl.classList.remove(\"tabulator-row-odd\");\n\t\t}else{\n\t\t\trowEl.classList.add(\"tabulator-row-odd\");\n\t\t\trowEl.classList.remove(\"tabulator-row-even\");\n\t\t}\n\t}\n\t\n\t//normalize height of active rows\n\tnormalizeHeight(){\n\t\tthis.activeRows.forEach(function(row){\n\t\t\trow.normalizeHeight();\n\t\t});\n\t}\n\t\n\t//adjust the height of the table holder to fit in the Tabulator element\n\tadjustTableSize(){\n\t\tlet initialHeight = this.element.clientHeight, minHeight;\n\t\tlet resized = false;\n\t\t\n\t\tif(this.renderer.verticalFillMode === \"fill\"){\n\t\t\tlet otherHeight = Math.floor(this.table.columnManager.getElement().getBoundingClientRect().height + (this.table.footerManager && this.table.footerManager.active && !this.table.footerManager.external ? this.table.footerManager.getElement().getBoundingClientRect().height : 0));\n\t\t\t\n\t\t\tif(this.fixedHeight){\n\t\t\t\tminHeight = isNaN(this.table.options.minHeight) ? this.table.options.minHeight : this.table.options.minHeight + \"px\";\n\t\t\t\t\n\t\t\t\tconst height = \"calc(100% - \" + otherHeight + \"px)\";\n\t\t\t\tthis.element.style.minHeight = minHeight || \"calc(100% - \" + otherHeight + \"px)\";\n\t\t\t\tthis.element.style.height = height;\n\t\t\t\tthis.element.style.maxHeight = height;\n\t\t\t} else {\n\t\t\t\tthis.element.style.height = \"\";\n\t\t\t\tthis.element.style.height =\n\t\t\t\tthis.table.element.clientHeight - otherHeight + \"px\";\n\t\t\t\tthis.element.scrollTop = this.scrollTop;\n\t\t\t}\n\t\t\t\n\t\t\tthis.renderer.resize();\n\t\t\t\n\t\t\t//check if the table has changed size when dealing with variable height tables\n\t\t\tif(!this.fixedHeight && initialHeight != this.element.clientHeight){\n\t\t\t\tresized = true;\n\t\t\t\tif(this.subscribed(\"table-resize\")){\n\t\t\t\t\tthis.dispatch(\"table-resize\");\n\t\t\t\t}else{\n\t\t\t\t\tthis.redraw();\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tthis.scrollBarCheck();\n\t\t}\n\t\t\n\t\tthis._positionPlaceholder();\n\t\treturn resized;\n\t}\n\t\n\t//reinitialize all rows\n\treinitialize(){\n\t\tthis.rows.forEach(function(row){\n\t\t\trow.reinitialize(true);\n\t\t});\n\t}\n\t\n\t//prevent table from being redrawn\n\tblockRedraw (){\n\t\tthis.redrawBlock = true;\n\t\tthis.redrawBlockRestoreConfig = false;\n\t}\n\t\n\t//restore table redrawing\n\trestoreRedraw (){\n\t\tthis.redrawBlock = false;\n\t\t\n\t\tif(this.redrawBlockRestoreConfig){\n\t\t\tthis.refreshActiveData(this.redrawBlockRestoreConfig.handler, this.redrawBlockRestoreConfig.skipStage, this.redrawBlockRestoreConfig.renderInPosition);\n\t\t\t\n\t\t\tthis.redrawBlockRestoreConfig = false;\n\t\t}else{\n\t\t\tif(this.redrawBlockRenderInPosition){\n\t\t\t\tthis.reRenderInPosition();\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.redrawBlockRenderInPosition = false;\n\t}\n\t\n\t//redraw table\n\tredraw (force){\n\t\tconst resized = this.adjustTableSize();\n\t\tthis.table.tableWidth = this.table.element.clientWidth;\n\t\t\n\t\tif(!force){\n\t\t\tif(resized) {\n\t\t\t\tthis.reRenderInPosition();\n\t\t\t}\n\t\t\tthis.scrollHorizontal(this.scrollLeft);\n\t\t}else{\n\t\t\tthis.renderTable();\n\t\t}\n\t}\n\t\n\tresetScroll(){\n\t\tthis.element.scrollLeft = 0;\n\t\tthis.element.scrollTop = 0;\n\t\t\n\t\tif(this.table.browser === \"ie\"){\n\t\t\tvar event = document.createEvent(\"Event\");\n\t\t\tevent.initEvent(\"scroll\", false, true);\n\t\t\tthis.element.dispatchEvent(event);\n\t\t}else{\n\t\t\tthis.element.dispatchEvent(new Event('scroll'));\n\t\t}\n\t}\n}\n","import CoreFeature from './CoreFeature.js';\n\nexport default class FooterManager extends CoreFeature{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.active = false;\n\t\tthis.element = this.createElement(); //containing element\n\t\tthis.containerElement = this.createContainerElement(); //containing element\n\t\tthis.external = false;\n\t}\n\n\tinitialize(){\n\t\tthis.initializeElement();\n\t}\n\n\tcreateElement(){\n\t\tvar el = document.createElement(\"div\");\n\n\t\tel.classList.add(\"tabulator-footer\");\n\n\t\treturn el;\n\t}\n\n\t\n\tcreateContainerElement(){\n\t\tvar el = document.createElement(\"div\");\n\n\t\tel.classList.add(\"tabulator-footer-contents\");\n\n\t\tthis.element.appendChild(el);\n\n\t\treturn el;\n\t}\n\n\tinitializeElement(){\n\t\tif(this.table.options.footerElement){\n\n\t\t\tswitch(typeof this.table.options.footerElement){\n\t\t\t\tcase \"string\":\n\t\t\t\t\tif(this.table.options.footerElement[0] === \"<\"){\n\t\t\t\t\t\tthis.containerElement.innerHTML = this.table.options.footerElement;\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.external = true;\n\t\t\t\t\t\tthis.containerElement = document.querySelector(this.table.options.footerElement);\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\tthis.element = this.table.options.footerElement;\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\tgetElement(){\n\t\treturn this.element;\n\t}\n\n\tappend(element){\n\t\tthis.activate();\n\n\t\tthis.containerElement.appendChild(element);\n\t\tthis.table.rowManager.adjustTableSize();\n\t}\n\n\tprepend(element){\n\t\tthis.activate();\n\n\t\tthis.element.insertBefore(element, this.element.firstChild);\n\t\tthis.table.rowManager.adjustTableSize();\n\t}\n\n\tremove(element){\n\t\telement.parentNode.removeChild(element);\n\t\tthis.deactivate();\n\t}\n\n\tdeactivate(force){\n\t\tif(!this.element.firstChild || force){\n\t\t\tif(!this.external){\n\t\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t\t}\n\t\t\tthis.active = false;\n\t\t}\n\t}\n\n\tactivate(){\n\t\tif(!this.active){\n\t\t\tthis.active = true;\n\t\t\tif(!this.external){\n\t\t\t\tthis.table.element.appendChild(this.getElement());\n\t\t\t\tthis.table.element.style.display = '';\n\t\t\t}\n\t\t}\n\t}\n\n\tredraw(){\n\t\tthis.dispatch(\"footer-redraw\");\n\t}\n}","import CoreFeature from '../CoreFeature.js';\nimport Row from '../row/Row.js';\n\nexport default class InteractionManager extends CoreFeature {\n\t\n\tconstructor (table){\n\t\tsuper(table);\n\t\t\n\t\tthis.el = null;\n\t\t\n\t\tthis.abortClasses = [\"tabulator-headers\", \"tabulator-table\"];\n\t\t\n\t\tthis.previousTargets = {};\n\t\t\n\t\tthis.listeners = [\n\t\t\t\"click\",\n\t\t\t\"dblclick\",\n\t\t\t\"contextmenu\",\n\t\t\t\"mouseenter\",\n\t\t\t\"mouseleave\",\n\t\t\t\"mouseover\",\n\t\t\t\"mouseout\",\n\t\t\t\"mousemove\",\n\t\t\t\"mouseup\",\n\t\t\t\"mousedown\",\n\t\t\t\"touchstart\",\n\t\t\t\"touchend\",\n\t\t];\n\t\t\n\t\tthis.componentMap = {\n\t\t\t\"tabulator-cell\":\"cell\",\n\t\t\t\"tabulator-row\":\"row\",\n\t\t\t\"tabulator-group\":\"group\",\n\t\t\t\"tabulator-col\":\"column\",\n\t\t};\n\t\t\n\t\tthis.pseudoTrackers = {\n\t\t\t\"row\":{\n\t\t\t\tsubscriber:null,\n\t\t\t\ttarget:null,\n\t\t\t},\n\t\t\t\"cell\":{\n\t\t\t\tsubscriber:null,\n\t\t\t\ttarget:null,\n\t\t\t},\n\t\t\t\"group\":{\n\t\t\t\tsubscriber:null,\n\t\t\t\ttarget:null,\n\t\t\t},\n\t\t\t\"column\":{\n\t\t\t\tsubscriber:null,\n\t\t\t\ttarget:null,\n\t\t\t},\n\t\t};\n\t\t\n\t\tthis.pseudoTracking = false;\n\t}\n\t\n\tinitialize(){\n\t\tthis.el = this.table.element;\n\t\t\n\t\tthis.buildListenerMap();\n\t\tthis.bindSubscriptionWatchers();\n\t}\n\t\n\tbuildListenerMap(){\n\t\tvar listenerMap = {};\n\t\t\n\t\tthis.listeners.forEach((listener) => {\n\t\t\tlistenerMap[listener] = {\n\t\t\t\thandler:null,\n\t\t\t\tcomponents:[],\n\t\t\t};\n\t\t});\n\t\t\n\t\tthis.listeners = listenerMap;\n\t}\n\t\n\tbindPseudoEvents(){\n\t\tObject.keys(this.pseudoTrackers).forEach((key) => {\n\t\t\tthis.pseudoTrackers[key].subscriber = this.pseudoMouseEnter.bind(this, key);\n\t\t\tthis.subscribe(key + \"-mouseover\", this.pseudoTrackers[key].subscriber);\n\t\t});\n\t\t\n\t\tthis.pseudoTracking = true;\n\t}\n\t\n\tpseudoMouseEnter(key, e, target){\n\t\tif(this.pseudoTrackers[key].target !== target){\n\t\t\t\n\t\t\tif(this.pseudoTrackers[key].target){\n\t\t\t\tthis.dispatch(key + \"-mouseleave\", e, this.pseudoTrackers[key].target);\n\t\t\t}\n\t\t\t\n\t\t\tthis.pseudoMouseLeave(key, e);\n\t\t\t\n\t\t\tthis.pseudoTrackers[key].target = target;\n\t\t\t\n\t\t\tthis.dispatch(key + \"-mouseenter\", e, target);\n\t\t}\n\t}\n\t\n\tpseudoMouseLeave(key, e){\n\t\tvar leaveList = Object.keys(this.pseudoTrackers),\n\t\tlinkedKeys = {\n\t\t\t\"row\":[\"cell\"],\n\t\t\t\"cell\":[\"row\"],\n\t\t};\n\t\t\n\t\tleaveList = leaveList.filter((item) => {\n\t\t\tvar links = linkedKeys[key];\n\t\t\treturn item !== key && (!links || (links && !links.includes(item)));\n\t\t});\n\t\t\n\t\t\n\t\tleaveList.forEach((key) => {\n\t\t\tvar target = this.pseudoTrackers[key].target;\n\t\t\t\n\t\t\tif(this.pseudoTrackers[key].target){\n\t\t\t\tthis.dispatch(key + \"-mouseleave\", e, target);\n\t\t\t\t\n\t\t\t\tthis.pseudoTrackers[key].target = null;\n\t\t\t}\n\t\t});\n\t}\n\t\n\t\n\tbindSubscriptionWatchers(){\n\t\tvar listeners = Object.keys(this.listeners),\n\t\tcomponents = Object.values(this.componentMap);\n\t\t\n\t\tfor(let comp of components){\n\t\t\tfor(let listener of listeners){\n\t\t\t\tlet key = comp + \"-\" + listener;\n\t\t\t\t\n\t\t\t\tthis.subscriptionChange(key, this.subscriptionChanged.bind(this, comp, listener));\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.subscribe(\"table-destroy\", this.clearWatchers.bind(this));\n\t}\n\t\n\tsubscriptionChanged(component, key, added){\n\t\tvar listener = this.listeners[key].components,\n\t\tindex = listener.indexOf(component),\n\t\tchanged = false;\n\t\t\n\t\tif(added){\n\t\t\tif(index === -1){\n\t\t\t\tlistener.push(component);\n\t\t\t\tchanged = true;\n\t\t\t}\n\t\t}else{\n\t\t\tif(!this.subscribed(component + \"-\" + key)){\n\t\t\t\tif(index > -1){\n\t\t\t\t\tlistener.splice(index, 1);\n\t\t\t\t\tchanged = true;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\tif((key === \"mouseenter\" || key === \"mouseleave\") && !this.pseudoTracking){\n\t\t\tthis.bindPseudoEvents();\n\t\t}\n\t\t\n\t\tif(changed){\n\t\t\tthis.updateEventListeners();\n\t\t}\n\t}\n\t\n\tupdateEventListeners(){\n\t\tfor(let key in this.listeners){\n\t\t\tlet listener = this.listeners[key];\n\t\t\t\n\t\t\tif(listener.components.length){\n\t\t\t\tif(!listener.handler){\n\t\t\t\t\tlistener.handler = this.track.bind(this, key);\n\t\t\t\t\tthis.el.addEventListener(key, listener.handler);\n\t\t\t\t\t// this.el.addEventListener(key, listener.handler, {passive: true})\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tif(listener.handler){\n\t\t\t\t\tthis.el.removeEventListener(key, listener.handler);\n\t\t\t\t\tlistener.handler = null;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\t\n\ttrack(type, e){\n\t\tvar path = (e.composedPath && e.composedPath()) || e.path;\n\t\t\n\t\tvar targets = this.findTargets(path);\n\t\ttargets = this.bindComponents(type, targets);\n\t\t\n\t\tthis.triggerEvents(type, e, targets);\n\t\t\n\t\tif(this.pseudoTracking && (type == \"mouseover\" || type == \"mouseleave\") && !Object.keys(targets).length){\n\t\t\tthis.pseudoMouseLeave(\"none\", e);\n\t\t}\n\t}\n\t\n\tfindTargets(path){\n\t\tvar targets = {};\n\t\t\n\t\tlet componentMap = Object.keys(this.componentMap);\n\t\t\n\t\tfor (let el of path) {\n\t\t\tlet classList = el.classList ? [...el.classList] : [];\n\t\t\t\n\t\t\tlet abort = classList.filter((item) => {\n\t\t\t\treturn this.abortClasses.includes(item);\n\t\t\t});\n\t\t\t\n\t\t\tif(abort.length){\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\t\n\t\t\tlet elTargets = classList.filter((item) => {\n\t\t\t\treturn componentMap.includes(item);\n\t\t\t});\n\t\t\t\n\t\t\tfor (let target of elTargets) {\n\t\t\t\tif(!targets[this.componentMap[target]]){\n\t\t\t\t\ttargets[this.componentMap[target]] = el;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t\n\t\tif(targets.group && targets.group === targets.row){\n\t\t\tdelete targets.row;\n\t\t}\n\t\t\n\t\treturn targets;\n\t}\n\t\n\tbindComponents(type, targets){\n\t\t//ensure row component is looked up before cell\n\t\tvar keys = Object.keys(targets).reverse(),\n\t\tlistener = this.listeners[type],\n\t\tmatches = {},\n\t\ttargetMatches = {};\n\t\t\n\t\tfor(let key of keys){\n\t\t\tlet component,\n\t\t\ttarget = targets[key],\n\t\t\tpreviousTarget = this.previousTargets[key];\n\t\t\t\n\t\t\tif(previousTarget && previousTarget.target === target){\n\t\t\t\tcomponent = previousTarget.component;\n\t\t\t}else{\n\t\t\t\tswitch(key){\n\t\t\t\t\tcase \"row\":\n\t\t\t\t\tcase \"group\":\n\t\t\t\t\t\tif(listener.components.includes(\"row\") || listener.components.includes(\"cell\") || listener.components.includes(\"group\")){\n\t\t\t\t\t\t\tlet rows = this.table.rowManager.getVisibleRows(true);\n\t\t\t\t\t\t\n\t\t\t\t\t\t\tcomponent = rows.find((row) => {\n\t\t\t\t\t\t\t\treturn row.getElement() === target;\n\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\n\t\t\t\t\t\t\tif(targets[\"row\"] && targets[\"row\"].parentNode && targets[\"row\"].parentNode.closest(\".tabulator-row\")){\n\t\t\t\t\t\t\t\ttargets[key] = false;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tcase \"column\":\n\t\t\t\t\t\tif(listener.components.includes(\"column\")){\n\t\t\t\t\t\t\tcomponent = this.table.columnManager.findColumn(target);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t\n\t\t\t\t\tcase \"cell\":\n\t\t\t\t\t\tif(listener.components.includes(\"cell\")){\n\t\t\t\t\t\t\tif(matches[\"row\"] instanceof Row){\n\t\t\t\t\t\t\t\tcomponent = matches[\"row\"].findCell(target);\n\t\t\t\t\t\t\t}else{\t\n\t\t\t\t\t\t\t\tif(targets[\"row\"]){\n\t\t\t\t\t\t\t\t\tconsole.warn(\"Event Target Lookup Error - The row this cell is attached to cannot be found, has the table been reinitialized without being destroyed first?\");\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tif(component){\n\t\t\t\tmatches[key] = component;\n\t\t\t\ttargetMatches[key] = {\n\t\t\t\t\ttarget:target,\n\t\t\t\t\tcomponent:component,\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t\t\n\t\tthis.previousTargets = targetMatches;\n\t\t\n\t\treturn matches;\n\t}\n\t\n\ttriggerEvents(type, e, targets){\n\t\tvar listener = this.listeners[type];\n\n\t\tfor(let key in targets){\n\t\t\tif(targets[key] && listener.components.includes(key)){\n\t\t\t\tthis.dispatch(key + \"-\" + type, e, targets[key]);\n\t\t\t}\n\t\t}\n\t}\n\t\n\tclearWatchers(){\n\t\tfor(let key in this.listeners){\n\t\t\tlet listener = this.listeners[key];\n\t\t\t\n\t\t\tif(listener.handler){\n\t\t\t\tthis.el.removeEventListener(key, listener.handler);\n\t\t\t\tlistener.handler = null;\n\t\t\t}\n\t\t}\n\t}\n}","export default class ComponentFunctionBinder{\n\n\tconstructor(table){\n\t\tthis.table = table;\n\n\t\tthis.bindings = {};\n\t}\n\n\tbind(type, funcName, handler){\n\t\tif(!this.bindings[type]){\n\t\t\tthis.bindings[type] = {};\n\t\t}\n\n\t\tif(this.bindings[type][funcName]){\n\t\t\tconsole.warn(\"Unable to bind component handler, a matching function name is already bound\", type, funcName, handler);\n\t\t}else{\n\t\t\tthis.bindings[type][funcName] = handler;\n\t\t}\n\t}\n\n\thandle(type, component, name){\n\t\tif(this.bindings[type] && this.bindings[type][name] && typeof this.bindings[type][name].bind === 'function'){\n\t\t\treturn this.bindings[type][name].bind(null, component);\n\t\t}else{\n\t\t\tif(name !== \"then\" && typeof name === \"string\" && !name.startsWith(\"_\")){\n\t\t\t\tif(this.table.options.debugInvalidComponentFuncs){\n\t\t\t\t\tconsole.error(\"The \" + type + \" component does not have a \" + name + \" function, have you checked that you have the correct Tabulator module installed?\");\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n}\n","import CoreFeature from '../CoreFeature.js';\n\nexport default class DataLoader extends CoreFeature{\n\tconstructor(table){\n\t\tsuper(table);\n\t\t\n\t\tthis.requestOrder = 0; //prevent requests coming out of sequence if overridden by another load request\n\t\tthis.loading = false;\n\t}\n\t\n\tinitialize(){}\n\t\n\tload(data, params, config, replace, silent, columnsChanged){\n\t\tvar requestNo = ++this.requestOrder;\n\n\t\tif(this.table.destroyed){\n\t\t\treturn Promise.resolve();\n\t\t}\n\t\t\n\t\tthis.dispatchExternal(\"dataLoading\", data);\n\t\t\n\t\t//parse json data to array\n\t\tif (data && (data.indexOf(\"{\") == 0 || data.indexOf(\"[\") == 0)){\n\t\t\tdata = JSON.parse(data);\n\t\t}\n\t\t\n\t\tif(this.confirm(\"data-loading\", [data, params, config, silent])){\n\t\t\tthis.loading = true;\n\t\t\t\n\t\t\tif(!silent){\n\t\t\t\tthis.alertLoader();\n\t\t\t}\n\t\t\t\n\t\t\t//get params for request\n\t\t\tparams = this.chain(\"data-params\", [data, config, silent], params || {}, params || {});\n\t\t\t\n\t\t\tparams = this.mapParams(params, this.table.options.dataSendParams);\n\t\t\t\n\t\t\tvar result = this.chain(\"data-load\", [data, params, config, silent], false, Promise.resolve([]));\n\t\t\t\n\t\t\treturn result.then((response) => {\n\t\t\t\tif(!this.table.destroyed){\n\t\t\t\t\tif(!Array.isArray(response) && typeof response == \"object\"){\n\t\t\t\t\t\tresponse = this.mapParams(response, this.objectInvert(this.table.options.dataReceiveParams));\n\t\t\t\t\t}\n\t\t\t\t\t\n\t\t\t\t\tvar rowData = this.chain(\"data-loaded\", response, null, response);\n\t\t\t\t\t\n\t\t\t\t\tif(requestNo == this.requestOrder){\n\t\t\t\t\t\tthis.clearAlert();\n\t\t\t\t\t\t\n\t\t\t\t\t\tif(rowData !== false){\n\t\t\t\t\t\t\tthis.dispatchExternal(\"dataLoaded\", rowData);\n\t\t\t\t\t\t\tthis.table.rowManager.setData(rowData, replace, typeof columnsChanged === \"undefined\" ? !replace : columnsChanged);\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Data Load Response Blocked - An active data load request was blocked by an attempt to change table data while the request was being made\");\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Data Load Response Blocked - Table has been destroyed\");\n\t\t\t\t}\n\t\t\t}).catch((error) => {\n\t\t\t\tconsole.error(\"Data Load Error: \", error);\n\t\t\t\tthis.dispatchExternal(\"dataLoadError\", error);\n\t\t\t\t\n\t\t\t\tif(!silent){\n\t\t\t\t\tthis.alertError();\n\t\t\t\t}\n\t\t\t\t\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tthis.clearAlert();\n\t\t\t\t}, this.table.options.dataLoaderErrorTimeout);\n\t\t\t})\n\t\t\t\t.finally(() => {\n\t\t\t\t\tthis.loading = false;\n\t\t\t\t});\n\t\t}else{\n\t\t\tthis.dispatchExternal(\"dataLoaded\", data);\n\t\t\t\n\t\t\tif(!data){\n\t\t\t\tdata = [];\n\t\t\t}\n\t\t\t\n\t\t\tthis.table.rowManager.setData(data, replace, typeof columnsChanged === \"undefined\" ? !replace : columnsChanged);\n\t\t\treturn Promise.resolve();\n\t\t}\n\t}\n\t\n\tmapParams(params, map){\n\t\tvar output = {};\n\t\t\n\t\tfor(let key in params){\n\t\t\toutput[map.hasOwnProperty(key) ? map[key] : key] = params[key];\n\t\t}\n\t\t\n\t\treturn output;\n\t}\n\t\n\tobjectInvert(obj){\n\t\tvar output = {};\n\t\t\n\t\tfor(let key in obj){\n\t\t\toutput[obj[key]] = key;\n\t\t}\n\t\t\n\t\treturn output;\n\t}\n\t\n\tblockActiveLoad(){\n\t\tthis.requestOrder++;\n\t}\n\t\n\talertLoader(){\n\t\tvar shouldLoad = typeof this.table.options.dataLoader === \"function\" ? this.table.options.dataLoader() : this.table.options.dataLoader;\n\t\t\n\t\tif(shouldLoad){\n\t\t\tthis.table.alertManager.alert(this.table.options.dataLoaderLoading || this.langText(\"data|loading\"));\n\t\t}\n\t}\n\t\n\talertError(){\n\t\tthis.table.alertManager.alert(this.table.options.dataLoaderError || this.langText(\"data|error\"), \"error\");\n\t}\n\t\n\tclearAlert(){\n\t\tthis.table.alertManager.clear();\n\t}\n}","export default class ExternalEventBus {\n\n\tconstructor(table, optionsList, debug){\n\t\tthis.table = table;\n\t\tthis.events = {};\n\t\tthis.optionsList = optionsList || {};\n\t\tthis.subscriptionNotifiers = {};\n\n\t\tthis.dispatch = debug ? this._debugDispatch.bind(this) : this._dispatch.bind(this);\n\t\tthis.debug = debug;\n\t}\n\n\tsubscriptionChange(key, callback){\n\t\tif(!this.subscriptionNotifiers[key]){\n\t\t\tthis.subscriptionNotifiers[key] = [];\n\t\t}\n\n\t\tthis.subscriptionNotifiers[key].push(callback);\n\n\t\tif(this.subscribed(key)){\n\t\t\tthis._notifySubscriptionChange(key, true);\n\t\t}\n\t}\n\n\tsubscribe(key, callback){\n\t\tif(!this.events[key]){\n\t\t\tthis.events[key] = [];\n\t\t}\n\n\t\tthis.events[key].push(callback);\n\n\t\tthis._notifySubscriptionChange(key, true);\n\t}\n\n\tunsubscribe(key, callback){\n\t\tvar index;\n\n\t\tif(this.events[key]){\n\t\t\tif(callback){\n\t\t\t\tindex = this.events[key].findIndex((item) => {\n\t\t\t\t\treturn item === callback;\n\t\t\t\t});\n\n\t\t\t\tif(index > -1){\n\t\t\t\t\tthis.events[key].splice(index, 1);\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Cannot remove event, no matching event found:\", key, callback);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tdelete this.events[key];\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.warn(\"Cannot remove event, no events set on:\", key);\n\t\t\treturn;\n\t\t}\n\n\t\tthis._notifySubscriptionChange(key, false);\n\t}\n\n\tsubscribed(key){\n\t\treturn this.events[key] && this.events[key].length;\n\t}\n\n\t_notifySubscriptionChange(key, subscribed){\n\t\tvar notifiers = this.subscriptionNotifiers[key];\n\n\t\tif(notifiers){\n\t\t\tnotifiers.forEach((callback)=>{\n\t\t\t\tcallback(subscribed);\n\t\t\t});\n\t\t}\n\t}\n\n\t_dispatch(){\n\t\tvar args = Array.from(arguments),\n\t\tkey = args.shift(),\n\t\tresult;\n\n\t\tif(this.events[key]){\n\t\t\tthis.events[key].forEach((callback, i) => {\n\t\t\t\tlet callResult = callback.apply(this.table, args);\n\n\t\t\t\tif(!i){\n\t\t\t\t\tresult = callResult;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn result;\n\t}\n\n\t_debugDispatch(){\n\t\tvar args = Array.from(arguments),\n\t\tkey = args[0];\n\n\t\targs[0] = \"ExternalEvent:\" + args[0];\n\n\t\tif(this.debug === true || this.debug.includes(key)){\n\t\t\tconsole.log(...args);\n\t\t}\n\n\t\treturn this._dispatch(...arguments);\n\t}\n}","export default class InternalEventBus {\n\n\tconstructor(debug){\n\t\tthis.events = {};\n\t\tthis.subscriptionNotifiers = {};\n\n\t\tthis.dispatch = debug ? this._debugDispatch.bind(this) : this._dispatch.bind(this);\n\t\tthis.chain = debug ? this._debugChain.bind(this) : this._chain.bind(this);\n\t\tthis.confirm = debug ? this._debugConfirm.bind(this) : this._confirm.bind(this);\n\t\tthis.debug = debug;\n\t}\n\n\tsubscriptionChange(key, callback){\n\t\tif(!this.subscriptionNotifiers[key]){\n\t\t\tthis.subscriptionNotifiers[key] = [];\n\t\t}\n\n\t\tthis.subscriptionNotifiers[key].push(callback);\n\n\t\tif(this.subscribed(key)){\n\t\t\tthis._notifySubscriptionChange(key, true);\n\t\t}\n\t}\n\n\tsubscribe(key, callback, priority = 10000){\n\t\tif(!this.events[key]){\n\t\t\tthis.events[key] = [];\n\t\t}\n\n\t\tthis.events[key].push({callback, priority});\n\n\t\tthis.events[key].sort((a, b) => {\n\t\t\treturn a.priority - b.priority;\n\t\t});\n\n\t\tthis._notifySubscriptionChange(key, true);\n\t}\n\n\tunsubscribe(key, callback){\n\t\tvar index;\n\n\t\tif(this.events[key]){\n\t\t\tif(callback){\n\t\t\t\tindex = this.events[key].findIndex((item) => {\n\t\t\t\t\treturn item.callback === callback;\n\t\t\t\t});\n\n\t\t\t\tif(index > -1){\n\t\t\t\t\tthis.events[key].splice(index, 1);\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Cannot remove event, no matching event found:\", key, callback);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.warn(\"Cannot remove event, no events set on:\", key);\n\t\t\treturn;\n\t\t}\n\n\t\tthis._notifySubscriptionChange(key, false);\n\t}\n\n\tsubscribed(key){\n\t\treturn this.events[key] && this.events[key].length;\n\t}\n\n\t_chain(key, args, initialValue, fallback){\n\t\tvar value = initialValue;\n\n\t\tif(!Array.isArray(args)){\n\t\t\targs = [args];\n\t\t}\n\n\t\tif(this.subscribed(key)){\n\t\t\tthis.events[key].forEach((subscriber, i) => {\n\t\t\t\tvalue = subscriber.callback.apply(this, args.concat([value]));\n\t\t\t});\n\n\t\t\treturn value;\n\t\t}else{\n\t\t\treturn typeof fallback === \"function\" ? fallback() : fallback;\n\t\t}\n\t}\n\n\t_confirm(key, args){\n\t\tvar confirmed = false;\n\n\t\tif(!Array.isArray(args)){\n\t\t\targs = [args];\n\t\t}\n\n\t\tif(this.subscribed(key)){\n\t\t\tthis.events[key].forEach((subscriber, i) => {\n\t\t\t\tif(subscriber.callback.apply(this, args)){\n\t\t\t\t\tconfirmed = true;\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\n\t\treturn confirmed;\n\t}\n\n\t_notifySubscriptionChange(key, subscribed){\n\t\tvar notifiers = this.subscriptionNotifiers[key];\n\n\t\tif(notifiers){\n\t\t\tnotifiers.forEach((callback)=>{\n\t\t\t\tcallback(subscribed);\n\t\t\t});\n\t\t}\n\t}\n\n\t_dispatch(){\n\t\tvar args = Array.from(arguments),\n\t\tkey = args.shift();\n\n\t\tif(this.events[key]){\n\t\t\tthis.events[key].forEach((subscriber) => {\n\t\t\t\tsubscriber.callback.apply(this, args);\n\t\t\t});\n\t\t}\n\t}\n\n\t_debugDispatch(){\n\t\tvar args = Array.from(arguments),\n\t\tkey = args[0];\n\n\t\targs[0] = \"InternalEvent:\" + key;\n\n\t\tif(this.debug === true || this.debug.includes(key)){\n\t\t\tconsole.log(...args);\n\t\t}\n\n\t\treturn this._dispatch(...arguments);\n\t}\n\n\t_debugChain(){\n\t\tvar args = Array.from(arguments),\n\t\tkey = args[0];\n\n\t\targs[0] = \"InternalEvent:\" + key;\n\n\t\tif(this.debug === true || this.debug.includes(key)){\n\t\t\tconsole.log(...args);\n\t\t}\n\n\t\treturn this._chain(...arguments);\n\t}\n\n\t_debugConfirm(){\n\t\tvar args = Array.from(arguments),\n\t\tkey = args[0];\n\n\t\targs[0] = \"InternalEvent:\" + key;\n\n\t\tif(this.debug === true || this.debug.includes(key)){\n\t\t\tconsole.log(...args);\n\t\t}\n\n\t\treturn this._confirm(...arguments);\n\t}\n}","import CoreFeature from '../CoreFeature.js';\n\nexport default class DeprecationAdvisor extends CoreFeature{\n\t\n\tconstructor(table){\n\t\tsuper(table);\n\t}\n\t\n\t_warnUser(){\n\t\tif(this.options(\"debugDeprecation\")){\n\t\t\tconsole.warn(...arguments);\n\t\t}\n\t}\n\t\n\tcheck(oldOption, newOption){\n\t\tvar msg = \"\";\n\t\t\n\t\tif(typeof this.options(oldOption) !== \"undefined\"){\n\t\t\tmsg = \"Deprecated Setup Option - Use of the %c\" + oldOption + \"%c option is now deprecated\";\n\t\t\t\n\t\t\tif(newOption){\n\t\t\t\tmsg = msg + \", Please use the %c\" + newOption + \"%c option instead\";\n\t\t\t\tthis._warnUser(msg, 'font-weight: bold;', 'font-weight: normal;', 'font-weight: bold;', 'font-weight: normal;');\n\t\t\t}else{\n\t\t\t\tthis._warnUser(msg, 'font-weight: bold;', 'font-weight: normal;');\n\t\t\t}\n\t\t\t\n\t\t\treturn false;\n\t\t}else{\n\t\t\treturn true;\n\t\t}\n\t}\n\t\n\tcheckMsg(oldOption, msg){\n\t\tif(typeof this.options(oldOption) !== \"undefined\"){\n\t\t\tthis._warnUser(\"%cDeprecated Setup Option - Use of the %c\" + oldOption + \" %c option is now deprecated, \" + msg, 'font-weight: normal;', 'font-weight: bold;', 'font-weight: normal;');\n\t\t\t\n\t\t\treturn false;\n\t\t}else{\n\t\t\treturn true;\n\t\t}\n\t}\n\t\n\tmsg(msg){\n\t\tthis._warnUser(msg);\n\t}\n}","import Tabulator from '../Tabulator.js';\n\nclass TableRegistry {\n\n\tstatic register(table){\n\t\tTableRegistry.tables.push(table);\n\t}\n\n\tstatic deregister(table){\n\t\tvar index = TableRegistry.tables.indexOf(table);\n\n\t\tif(index > -1){\n\t\t\tTableRegistry.tables.splice(index, 1);\n\t\t}\n\t}\n\n\tstatic lookupTable(query, silent){\n\t\tvar results = [],\n\t\tmatches, match;\n\n\t\tif(typeof query === \"string\"){\n\t\t\tmatches = document.querySelectorAll(query);\n\n\t\t\tif(matches.length){\n\t\t\t\tfor(var i = 0; i < matches.length; i++){\n\t\t\t\t\tmatch = TableRegistry.matchElement(matches[i]);\n\n\t\t\t\t\tif(match){\n\t\t\t\t\t\tresults.push(match);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t}else if((typeof HTMLElement !== \"undefined\" && query instanceof HTMLElement) || query instanceof Tabulator){\n\t\t\tmatch = TableRegistry.matchElement(query);\n\n\t\t\tif(match){\n\t\t\t\tresults.push(match);\n\t\t\t}\n\t\t}else if(Array.isArray(query)){\n\t\t\tquery.forEach(function(item){\n\t\t\t\tresults = results.concat(TableRegistry.lookupTable(item));\n\t\t\t});\n\t\t}else{\n\t\t\tif(!silent){\n\t\t\t\tconsole.warn(\"Table Connection Error - Invalid Selector\", query);\n\t\t\t}\n\t\t}\n\n\t\treturn results;\n\t}\n\n\tstatic matchElement(element){\n\t\treturn TableRegistry.tables.find(function(table){\n\t\t\treturn element instanceof Tabulator ? table === element : table.element === element;\n\t\t});\n\t}\n}\n\nTableRegistry.tables = [];\n\nexport default TableRegistry;","//resize columns to fit data they contain and stretch row to fill table, also used for fitDataTable\nexport default function(columns, forced){\n\tcolumns.forEach(function(column){\n\t\tcolumn.reinitializeWidth();\n\t});\n\n\tif(this.table.options.responsiveLayout && this.table.modExists(\"responsiveLayout\", true)){\n\t\tthis.table.modules.responsiveLayout.update();\n\t}\n}","import fitData from './modes/fitData.js';\nimport fitDataGeneral from './modes/fitDataGeneral.js';\nimport fitDataStretch from './modes/fitDataStretch.js';\nimport fitColumns from './modes/fitColumns.js';\n\nexport default {\n\tfitData:fitData,\n\tfitDataFill:fitDataGeneral,\n\tfitDataTable:fitDataGeneral,\n\tfitDataStretch:fitDataStretch,\n\tfitColumns:fitColumns ,\n};","//resize columns to fit data they contain\nexport default function(columns, forced){\n\tif(forced){\n\t\tthis.table.columnManager.renderer.reinitializeColumnWidths(columns);\n\t}\n\t\n\tif(this.table.options.responsiveLayout && this.table.modExists(\"responsiveLayout\", true)){\n\t\tthis.table.modules.responsiveLayout.update();\n\t}\n}","//resize columns to fit data the contain and stretch last column to fill table\nexport default function(columns, forced){\n\tvar colsWidth = 0,\n\ttableWidth = this.table.rowManager.element.clientWidth,\n\tgap = 0,\n\tlastCol = false;\n\n\tcolumns.forEach((column, i) => {\n\t\tif(!column.widthFixed){\n\t\t\tcolumn.reinitializeWidth();\n\t\t}\n\n\t\tif(this.table.options.responsiveLayout ? column.modules.responsive.visible : column.visible){\n\t\t\tlastCol = column;\n\t\t}\n\n\t\tif(column.visible){\n\t\t\tcolsWidth += column.getWidth();\n\t\t}\n\t});\n\n\tif(lastCol){\n\t\tgap = tableWidth - colsWidth + lastCol.getWidth();\n\n\t\tif(this.table.options.responsiveLayout && this.table.modExists(\"responsiveLayout\", true)){\n\t\t\tlastCol.setWidth(0);\n\t\t\tthis.table.modules.responsiveLayout.update();\n\t\t}\n\n\t\tif(gap > 0){\n\t\t\tlastCol.setWidth(gap);\n\t\t}else{\n\t\t\tlastCol.reinitializeWidth();\n\t\t}\n\t}else{\n\t\tif(this.table.options.responsiveLayout && this.table.modExists(\"responsiveLayout\", true)){\n\t\t\tthis.table.modules.responsiveLayout.update();\n\t\t}\n\t}\n}","//resize columns to fit\nexport default function(columns, forced){\n\tvar totalWidth = this.table.rowManager.element.getBoundingClientRect().width; //table element width\n\tvar fixedWidth = 0; //total width of columns with a defined width\n\tvar flexWidth = 0; //total width available to flexible columns\n\tvar flexGrowUnits = 0; //total number of widthGrow blocks across all columns\n\tvar flexColWidth = 0; //desired width of flexible columns\n\tvar flexColumns = []; //array of flexible width columns\n\tvar fixedShrinkColumns = []; //array of fixed width columns that can shrink\n\tvar flexShrinkUnits = 0; //total number of widthShrink blocks across all columns\n\tvar overflowWidth = 0; //horizontal overflow width\n\tvar gapFill = 0; //number of pixels to be added to final column to close and half pixel gaps\n\n\tfunction calcWidth(width){\n\t\tvar colWidth;\n\n\t\tif(typeof(width) == \"string\"){\n\t\t\tif(width.indexOf(\"%\") > -1){\n\t\t\t\tcolWidth = (totalWidth / 100) * parseInt(width);\n\t\t\t}else{\n\t\t\t\tcolWidth = parseInt(width);\n\t\t\t}\n\t\t}else{\n\t\t\tcolWidth = width;\n\t\t}\n\n\t\treturn colWidth;\n\t}\n\n\t//ensure columns resize to take up the correct amount of space\n\tfunction scaleColumns(columns, freeSpace, colWidth, shrinkCols){\n\t\tvar oversizeCols = [],\n\t\toversizeSpace = 0,\n\t\tremainingSpace = 0,\n\t\tnextColWidth = 0,\n\t\tremainingFlexGrowUnits = flexGrowUnits,\n\t\tgap = 0,\n\t\tchangeUnits = 0,\n\t\tundersizeCols = [];\n\n\t\tfunction calcGrow(col){\n\t\t\treturn (colWidth * (col.column.definition.widthGrow || 1));\n\t\t}\n\n\t\tfunction calcShrink(col){\n\t\t\treturn (calcWidth(col.width) - (colWidth * (col.column.definition.widthShrink || 0)));\n\t\t}\n\n\t\tcolumns.forEach(function(col, i){\n\t\t\tvar width = shrinkCols ? calcShrink(col) : calcGrow(col);\n\t\t\tif(col.column.minWidth >= width){\n\t\t\t\toversizeCols.push(col);\n\t\t\t}else{\n\t\t\t\tif(col.column.maxWidth && col.column.maxWidth < width){\n\t\t\t\t\tcol.width = col.column.maxWidth;\n\t\t\t\t\tfreeSpace -= col.column.maxWidth;\n\n\t\t\t\t\tremainingFlexGrowUnits -= shrinkCols ? (col.column.definition.widthShrink || 1) : (col.column.definition.widthGrow || 1);\n\n\t\t\t\t\tif(remainingFlexGrowUnits){\n\t\t\t\t\t\tcolWidth = Math.floor(freeSpace/remainingFlexGrowUnits);\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tundersizeCols.push(col);\n\t\t\t\t\tchangeUnits += shrinkCols ? (col.column.definition.widthShrink || 1) : (col.column.definition.widthGrow || 1);\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\tif(oversizeCols.length){\n\t\t\toversizeCols.forEach(function(col){\n\t\t\t\toversizeSpace += shrinkCols ? col.width - col.column.minWidth : col.column.minWidth;\n\t\t\t\tcol.width = col.column.minWidth;\n\t\t\t});\n\n\t\t\tremainingSpace = freeSpace - oversizeSpace;\n\n\t\t\tnextColWidth = changeUnits ? Math.floor(remainingSpace/changeUnits) : remainingSpace;\n\n\t\t\tgap = scaleColumns(undersizeCols, remainingSpace, nextColWidth, shrinkCols);\n\t\t}else{\n\t\t\tgap = changeUnits ? freeSpace - (Math.floor(freeSpace/changeUnits) * changeUnits) : freeSpace;\n\n\t\t\tundersizeCols.forEach(function(column){\n\t\t\t\tcolumn.width = shrinkCols ? calcShrink(column) : calcGrow(column);\n\t\t\t});\n\t\t}\n\n\t\treturn gap;\n\t}\n\n\tif(this.table.options.responsiveLayout && this.table.modExists(\"responsiveLayout\", true)){\n\t\tthis.table.modules.responsiveLayout.update();\n\t}\n\n\t//adjust for vertical scrollbar if present\n\tif(this.table.rowManager.element.scrollHeight > this.table.rowManager.element.clientHeight){\n\t\ttotalWidth -= this.table.rowManager.element.offsetWidth - this.table.rowManager.element.clientWidth;\n\t}\n\n\tcolumns.forEach(function(column){\n\t\tvar width, minWidth, colWidth;\n\n\t\tif(column.visible){\n\n\t\t\twidth = column.definition.width;\n\t\t\tminWidth = parseInt(column.minWidth);\n\n\t\t\tif(width){\n\n\t\t\t\tcolWidth = calcWidth(width);\n\n\t\t\t\tfixedWidth += colWidth > minWidth ? colWidth : minWidth;\n\n\t\t\t\tif(column.definition.widthShrink){\n\t\t\t\t\tfixedShrinkColumns.push({\n\t\t\t\t\t\tcolumn:column,\n\t\t\t\t\t\twidth:colWidth > minWidth ? colWidth : minWidth\n\t\t\t\t\t});\n\t\t\t\t\tflexShrinkUnits += column.definition.widthShrink;\n\t\t\t\t}\n\n\t\t\t}else{\n\t\t\t\tflexColumns.push({\n\t\t\t\t\tcolumn:column,\n\t\t\t\t\twidth:0,\n\t\t\t\t});\n\t\t\t\tflexGrowUnits += column.definition.widthGrow || 1;\n\t\t\t}\n\t\t}\n\t});\n\n\t//calculate available space\n\tflexWidth = totalWidth - fixedWidth;\n\n\t//calculate correct column size\n\tflexColWidth = Math.floor(flexWidth / flexGrowUnits);\n\n\t//generate column widths\n\tgapFill = scaleColumns(flexColumns, flexWidth, flexColWidth, false);\n\n\t//increase width of last column to account for rounding errors\n\tif(flexColumns.length && gapFill > 0){\n\t\tflexColumns[flexColumns.length-1].width += gapFill;\n\t}\n\n\t//calculate space for columns to be shrunk into\n\tflexColumns.forEach(function(col){\n\t\tflexWidth -= col.width;\n\t});\n\n\toverflowWidth = Math.abs(gapFill) + flexWidth;\n\n\t//shrink oversize columns if there is no available space\n\tif(overflowWidth > 0 && flexShrinkUnits){\n\t\tgapFill = scaleColumns(fixedShrinkColumns, overflowWidth, Math.floor(overflowWidth / flexShrinkUnits), true);\n\t}\n\n\t//decrease width of last column to account for rounding errors\n\tif(gapFill && fixedShrinkColumns.length){\n\t\tfixedShrinkColumns[fixedShrinkColumns.length-1].width -= gapFill;\n\t}\n\n\tflexColumns.forEach(function(col){\n\t\tcol.column.setWidth(col.width);\n\t});\n\n\tfixedShrinkColumns.forEach(function(col){\n\t\tcol.column.setWidth(col.width);\n\t});\n}\n","import Module from '../../core/Module.js';\n\nimport defaultModes from './defaults/modes.js';\n\nclass Layout extends Module{\n\n\tconstructor(table){\n\t\tsuper(table, \"layout\");\n\n\t\tthis.mode = null;\n\n\t\tthis.registerTableOption(\"layout\", \"fitData\"); //layout type\n\t\tthis.registerTableOption(\"layoutColumnsOnNewData\", false); //update column widths on setData\n\n\t\tthis.registerColumnOption(\"widthGrow\");\n\t\tthis.registerColumnOption(\"widthShrink\");\n\t}\n\n\t//initialize layout system\n\tinitialize(){\n\t\tvar layout = this.table.options.layout;\n\n\t\tif(Layout.modes[layout]){\n\t\t\tthis.mode = layout;\n\t\t}else{\n\t\t\tconsole.warn(\"Layout Error - invalid mode set, defaulting to 'fitData' : \" + layout);\n\t\t\tthis.mode = 'fitData';\n\t\t}\n\n\t\tthis.table.element.setAttribute(\"tabulator-layout\", this.mode);\n\t\tthis.subscribe(\"column-init\", this.initializeColumn.bind(this));\n\t}\n\n\tinitializeColumn(column){\n\t\tif(column.definition.widthGrow){\n\t\t\tcolumn.definition.widthGrow = Number(column.definition.widthGrow);\n\t\t}\n\t\tif(column.definition.widthShrink){\n\t\t\tcolumn.definition.widthShrink = Number(column.definition.widthShrink);\n\t\t}\n\t}\n\n\tgetMode(){\n\t\treturn this.mode;\n\t}\n\n\t//trigger table layout\n\tlayout(dataChanged){\n\t\tthis.dispatch(\"layout-refreshing\");\n\t\tLayout.modes[this.mode].call(this, this.table.columnManager.columnsByIndex, dataChanged);\n\t\tthis.dispatch(\"layout-refreshed\");\n\t}\n}\n\nLayout.moduleName = \"layout\";\n\n//load defaults\nLayout.modes = defaultModes;\n\nexport default Layout;","import Module from '../../core/Module.js';\n\nimport Helpers from '../../core/tools/Helpers.js';\n\nimport defaultLangs from './defaults/langs.js';\n\nclass Localize extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\n\t\tthis.locale = \"default\"; //current locale\n\t\tthis.lang = false; //current language\n\t\tthis.bindings = {}; //update events to call when locale is changed\n\t\tthis.langList = {};\n\n\t\tthis.registerTableOption(\"locale\", false); //current system language\n\t\tthis.registerTableOption(\"langs\", {});\n\t}\n\n\tinitialize(){\n\t\tthis.langList = Helpers.deepClone(Localize.langs);\n\n\t\tif(this.table.options.columnDefaults.headerFilterPlaceholder !== false){\n\t\t\tthis.setHeaderFilterPlaceholder(this.table.options.columnDefaults.headerFilterPlaceholder);\n\t\t}\n\n\t\tfor(let locale in this.table.options.langs){\n\t\t\tthis.installLang(locale, this.table.options.langs[locale]);\n\t\t}\n\n\t\tthis.setLocale(this.table.options.locale);\n\n\t\tthis.registerTableFunction(\"setLocale\", this.setLocale.bind(this));\n\t\tthis.registerTableFunction(\"getLocale\", this.getLocale.bind(this));\n\t\tthis.registerTableFunction(\"getLang\", this.getLang.bind(this));\n\t}\n\n\t//set header placeholder\n\tsetHeaderFilterPlaceholder(placeholder){\n\t\tthis.langList.default.headerFilters.default = placeholder;\n\t}\n\n\t//setup a lang description object\n\tinstallLang(locale, lang){\n\t\tif(this.langList[locale]){\n\t\t\tthis._setLangProp(this.langList[locale], lang);\n\t\t}else{\n\t\t\tthis.langList[locale] = lang;\n\t\t}\n\t}\n\n\t_setLangProp(lang, values){\n\t\tfor(let key in values){\n\t\t\tif(lang[key] && typeof lang[key] == \"object\"){\n\t\t\t\tthis._setLangProp(lang[key], values[key]);\n\t\t\t}else{\n\t\t\t\tlang[key] = values[key];\n\t\t\t}\n\t\t}\n\t}\n\n\t//set current locale\n\tsetLocale(desiredLocale){\n\t\tdesiredLocale = desiredLocale || \"default\";\n\n\t\t//fill in any matching language values\n\t\tfunction traverseLang(trans, path){\n\t\t\tfor(var prop in trans){\n\t\t\t\tif(typeof trans[prop] == \"object\"){\n\t\t\t\t\tif(!path[prop]){\n\t\t\t\t\t\tpath[prop] = {};\n\t\t\t\t\t}\n\t\t\t\t\ttraverseLang(trans[prop], path[prop]);\n\t\t\t\t}else{\n\t\t\t\t\tpath[prop] = trans[prop];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t//determining correct locale to load\n\t\tif(desiredLocale === true && navigator.language){\n\t\t\t//get local from system\n\t\t\tdesiredLocale = navigator.language.toLowerCase();\n\t\t}\n\n\t\tif(desiredLocale){\n\t\t\t//if locale is not set, check for matching top level locale else use default\n\t\t\tif(!this.langList[desiredLocale]){\n\t\t\t\tlet prefix = desiredLocale.split(\"-\")[0];\n\n\t\t\t\tif(this.langList[prefix]){\n\t\t\t\t\tconsole.warn(\"Localization Error - Exact matching locale not found, using closest match: \", desiredLocale, prefix);\n\t\t\t\t\tdesiredLocale = prefix;\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Localization Error - Matching locale not found, using default: \", desiredLocale);\n\t\t\t\t\tdesiredLocale = \"default\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthis.locale = desiredLocale;\n\n\t\t//load default lang template\n\t\tthis.lang = Helpers.deepClone(this.langList.default || {});\n\n\t\tif(desiredLocale != \"default\"){\n\t\t\ttraverseLang(this.langList[desiredLocale], this.lang);\n\t\t}\n\n\t\tthis.dispatchExternal(\"localized\", this.locale, this.lang);\n\n\t\tthis._executeBindings();\n\t}\n\n\t//get current locale\n\tgetLocale(locale){\n\t\treturn this.locale;\n\t}\n\n\t//get lang object for given local or current if none provided\n\tgetLang(locale){\n\t\treturn locale ? this.langList[locale] : this.lang;\n\t}\n\n\t//get text for current locale\n\tgetText(path, value){\n\t\tvar fillPath = value ? path + \"|\" + value : path,\n\t\tpathArray = fillPath.split(\"|\"),\n\t\ttext = this._getLangElement(pathArray, this.locale);\n\n\t\t// if(text === false){\n\t\t// \tconsole.warn(\"Localization Error - Matching localized text not found for given path: \", path);\n\t\t// }\n\n\t\treturn text || \"\";\n\t}\n\n\t//traverse langs object and find localized copy\n\t_getLangElement(path, locale){\n\t\tvar root = this.lang;\n\n\t\tpath.forEach(function(level){\n\t\t\tvar rootPath;\n\n\t\t\tif(root){\n\t\t\t\trootPath = root[level];\n\n\t\t\t\tif(typeof rootPath != \"undefined\"){\n\t\t\t\t\troot = rootPath;\n\t\t\t\t}else{\n\t\t\t\t\troot = false;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\treturn root;\n\t}\n\n\t//set update binding\n\tbind(path, callback){\n\t\tif(!this.bindings[path]){\n\t\t\tthis.bindings[path] = [];\n\t\t}\n\n\t\tthis.bindings[path].push(callback);\n\n\t\tcallback(this.getText(path), this.lang);\n\t}\n\n\t//iterate through bindings and trigger updates\n\t_executeBindings(){\n\t\tfor(let path in this.bindings){\n\t\t\tthis.bindings[path].forEach((binding) => {\n\t\t\t\tbinding(this.getText(path), this.lang);\n\t\t\t});\n\t\t}\n\t}\n}\n\nLocalize.moduleName = \"localize\";\n\n//load defaults\nLocalize.langs = defaultLangs;\n\nexport default Localize;","export default {\n\t\"default\":{ //hold default locale text\n\t\t\"groups\":{\n\t\t\t\"item\":\"item\",\n\t\t\t\"items\":\"items\",\n\t\t},\n\t\t\"columns\":{\n\t\t},\n\t\t\"data\":{\n\t\t\t\"loading\":\"Loading\",\n\t\t\t\"error\":\"Error\",\n\t\t},\n\t\t\"pagination\":{\n\t\t\t\"page_size\":\"Page Size\",\n\t\t\t\"page_title\":\"Show Page\",\n\t\t\t\"first\":\"First\",\n\t\t\t\"first_title\":\"First Page\",\n\t\t\t\"last\":\"Last\",\n\t\t\t\"last_title\":\"Last Page\",\n\t\t\t\"prev\":\"Prev\",\n\t\t\t\"prev_title\":\"Prev Page\",\n\t\t\t\"next\":\"Next\",\n\t\t\t\"next_title\":\"Next Page\",\n\t\t\t\"all\":\"All\",\n\t\t\t\"counter\":{\n\t\t\t\t\"showing\": \"Showing\",\n\t\t\t\t\"of\": \"of\",\n\t\t\t\t\"rows\": \"rows\",\n\t\t\t\t\"pages\": \"pages\",\n\t\t\t}\n\t\t},\n\t\t\"headerFilters\":{\n\t\t\t\"default\":\"filter column...\",\n\t\t\t\"columns\":{}\n\t\t}\n\t},\n};","import Module from '../../core/Module.js';\nimport TableRegistry from '../../core/tools/TableRegistry.js';\n\nclass Comms extends Module{\n\n\tconstructor(table){\n\t\tsuper(table);\n\t}\n\n\tinitialize(){\n\t\tthis.registerTableFunction(\"tableComms\", this.receive.bind(this));\n\t}\n\n\tgetConnections(selectors){\n\t\tvar connections = [],\n\t\tconnection;\n\n\t\tconnection = TableRegistry.lookupTable(selectors);\n\n\t\tconnection.forEach((con) =>{\n\t\t\tif(this.table !== con){\n\t\t\t\tconnections.push(con);\n\t\t\t}\n\t\t});\n\n\t\treturn connections;\n\t}\n\n\tsend(selectors, module, action, data){\n\t\tvar connections = this.getConnections(selectors);\n\n\t\tconnections.forEach((connection) => {\n\t\t\tconnection.tableComms(this.table.element, module, action, data);\n\t\t});\n\n\t\tif(!connections.length && selectors){\n\t\t\tconsole.warn(\"Table Connection Error - No tables matching selector found\", selectors);\n\t\t}\n\t}\n\n\treceive(table, module, action, data){\n\t\tif(this.table.modExists(module)){\n\t\t\treturn this.table.modules[module].commsReceived(table, action, data);\n\t\t}else{\n\t\t\tconsole.warn(\"Inter-table Comms Error - no such module:\", module);\n\t\t}\n\t}\n}\n\nComms.moduleName = \"comms\";\n\nexport default Comms;","import * as coreModules from '../modules/core.js';\nimport TableRegistry from './TableRegistry.js';\n\nexport default class ModuleBinder {\n\t\n\tconstructor(tabulator, modules){\n\t\tthis.bindStaticFunctionality(tabulator);\n\t\tthis.bindModules(tabulator, coreModules, true);\n\t\t\n\t\tif(modules){\n\t\t\tthis.bindModules(tabulator, modules);\n\t\t}\n\t}\n\t\n\tbindStaticFunctionality(tabulator){\n\t\ttabulator.moduleBindings = {};\n\t\t\n\t\ttabulator.extendModule = function(name, property, values){\n\t\t\tif(tabulator.moduleBindings[name]){\n\t\t\t\tvar source = tabulator.moduleBindings[name][property];\n\t\t\t\t\n\t\t\t\tif(source){\n\t\t\t\t\tif(typeof values == \"object\"){\n\t\t\t\t\t\tfor(let key in values){\n\t\t\t\t\t\t\tsource[key] = values[key];\n\t\t\t\t\t\t}\n\t\t\t\t\t}else{\n\t\t\t\t\t\tconsole.warn(\"Module Error - Invalid value type, it must be an object\");\n\t\t\t\t\t}\n\t\t\t\t}else{\n\t\t\t\t\tconsole.warn(\"Module Error - property does not exist:\", property);\n\t\t\t\t}\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Module Error - module does not exist:\", name);\n\t\t\t}\n\t\t};\n\t\t\n\t\ttabulator.registerModule = function(modules){\n\t\t\tif(!Array.isArray(modules)){\n\t\t\t\tmodules = [modules];\n\t\t\t}\n\t\t\t\n\t\t\tmodules.forEach((mod) => {\n\t\t\t\ttabulator.registerModuleBinding(mod);\n\t\t\t});\n\t\t};\n\t\t\n\t\ttabulator.registerModuleBinding = function(mod){\n\t\t\ttabulator.moduleBindings[mod.moduleName] = mod;\n\t\t};\n\t\t\n\t\ttabulator.findTable = function(query){\n\t\t\tvar results = TableRegistry.lookupTable(query, true);\n\t\t\treturn Array.isArray(results) && !results.length ? false : results;\n\t\t};\n\t\t\n\t\t//ensure that module are bound to instantiated function\n\t\ttabulator.prototype.bindModules = function(){\n\t\t\tvar orderedStartMods = [],\n\t\t\torderedEndMods = [],\n\t\t\tunOrderedMods = [];\n\t\t\t\n\t\t\tthis.modules = {};\n\t\t\t\n\t\t\tfor(var name in tabulator.moduleBindings){\n\t\t\t\tlet mod = tabulator.moduleBindings[name];\n\t\t\t\tlet module = new mod(this);\n\t\t\t\t\n\t\t\t\tthis.modules[name] = module;\n\t\t\t\t\n\t\t\t\tif(mod.prototype.moduleCore){\n\t\t\t\t\tthis.modulesCore.push(module);\n\t\t\t\t}else{\n\t\t\t\t\tif(mod.moduleInitOrder){\n\t\t\t\t\t\tif(mod.moduleInitOrder < 0){\n\t\t\t\t\t\t\torderedStartMods.push(module);\n\t\t\t\t\t\t}else{\n\t\t\t\t\t\t\torderedEndMods.push(module);\n\t\t\t\t\t\t}\n\t\t\t\t\t\t\n\t\t\t\t\t}else{\n\t\t\t\t\t\tunOrderedMods.push(module);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\torderedStartMods.sort((a, b) => a.moduleInitOrder > b.moduleInitOrder ? 1 : -1);\n\t\t\torderedEndMods.sort((a, b) => a.moduleInitOrder > b.moduleInitOrder ? 1 : -1);\n\t\t\t\n\t\t\tthis.modulesRegular = orderedStartMods.concat(unOrderedMods.concat(orderedEndMods));\n\t\t};\n\t}\n\t\n\tbindModules(tabulator, modules, core){\n\t\tvar mods = Object.values(modules);\n\t\t\n\t\tif(core){\n\t\t\tmods.forEach((mod) => {\n\t\t\t\tmod.prototype.moduleCore = true;\n\t\t\t});\n\t\t}\n\t\t\n\t\ttabulator.registerModule(mods);\n\t}\n}","import CoreFeature from '../CoreFeature.js';\n\nexport default class Alert extends CoreFeature{\n\tconstructor(table){\n\t\tsuper(table);\n \n\t\tthis.element = this._createAlertElement();\n\t\tthis.msgElement = this._createMsgElement();\n\t\tthis.type = null;\n \n\t\tthis.element.appendChild(this.msgElement);\n\t}\n \n\t_createAlertElement(){\n\t\tvar el = document.createElement(\"div\");\n\t\tel.classList.add(\"tabulator-alert\");\n\t\treturn el;\n\t}\n \n\t_createMsgElement(){\n\t\tvar el = document.createElement(\"div\");\n\t\tel.classList.add(\"tabulator-alert-msg\");\n\t\tel.setAttribute(\"role\", \"alert\");\n\t\treturn el;\n\t}\n \n\t_typeClass(){\n\t\treturn \"tabulator-alert-state-\" + this.type;\n\t}\n \n\talert(content, type = \"msg\"){\n\t\tif(content){\n\t\t\tthis.clear();\n \n\t\t\tthis.type = type;\n \n\t\t\twhile(this.msgElement.firstChild) this.msgElement.removeChild(this.msgElement.firstChild);\n \n\t\t\tthis.msgElement.classList.add(this._typeClass());\n \n\t\t\tif(typeof content === \"function\"){\n\t\t\t\tcontent = content();\n\t\t\t}\n \n\t\t\tif(content instanceof HTMLElement){\n\t\t\t\tthis.msgElement.appendChild(content);\n\t\t\t}else{\n\t\t\t\tthis.msgElement.innerHTML = content;\n\t\t\t}\n \n\t\t\tthis.table.element.appendChild(this.element);\n\t\t}\n\t}\n \n\tclear(){\n\t\tif(this.element.parentNode){\n\t\t\tthis.element.parentNode.removeChild(this.element);\n\t\t}\n \n\t\tthis.msgElement.classList.remove(this._typeClass());\n\t}\n}","'use strict';\n\nimport defaultOptions from './defaults/options.js';\n\nimport ColumnManager from './ColumnManager.js';\nimport RowManager from './RowManager.js';\nimport FooterManager from './FooterManager.js';\n\nimport InteractionMonitor from './tools/InteractionMonitor.js';\nimport ComponentFunctionBinder from './tools/ComponentFunctionBinder.js';\nimport DataLoader from './tools/DataLoader.js';\n\nimport ExternalEventBus from './tools/ExternalEventBus.js';\nimport InternalEventBus from './tools/InternalEventBus.js';\n\nimport DeprecationAdvisor from './tools/DeprecationAdvisor.js';\n\nimport TableRegistry from './tools/TableRegistry.js';\nimport ModuleBinder from './tools/ModuleBinder.js';\n\nimport OptionsList from './tools/OptionsList.js';\n\nimport Alert from './tools/Alert.js';\n\nclass Tabulator {\n\t\n\tconstructor(element, options){\n\t\t\n\t\tthis.options = {};\n\t\t\n\t\tthis.columnManager = null; // hold Column Manager\n\t\tthis.rowManager = null; //hold Row Manager\n\t\tthis.footerManager = null; //holder Footer Manager\n\t\tthis.alertManager = null; //hold Alert Manager\n\t\tthis.vdomHoz = null; //holder horizontal virtual dom\n\t\tthis.externalEvents = null; //handle external event messaging\n\t\tthis.eventBus = null; //handle internal event messaging\n\t\tthis.interactionMonitor = false; //track user interaction\n\t\tthis.browser = \"\"; //hold current browser type\n\t\tthis.browserSlow = false; //handle reduced functionality for slower browsers\n\t\tthis.browserMobile = false; //check if running on mobile, prevent resize cancelling edit on keyboard appearance\n\t\tthis.rtl = false; //check if the table is in RTL mode\n\t\tthis.originalElement = null; //hold original table element if it has been replaced\n\t\t\n\t\tthis.componentFunctionBinder = new ComponentFunctionBinder(this); //bind component functions\n\t\tthis.dataLoader = false; //bind component functions\n\t\t\n\t\tthis.modules = {}; //hold all modules bound to this table\n\t\tthis.modulesCore = []; //hold core modules bound to this table (for initialization purposes)\n\t\tthis.modulesRegular = []; //hold regular modules bound to this table (for initialization purposes)\n\t\t\n\t\tthis.deprecationAdvisor = new DeprecationAdvisor(this);\n\t\tthis.optionsList = new OptionsList(this, \"table constructor\");\n\t\t\n\t\tthis.initialized = false;\n\t\tthis.destroyed = false;\n\t\t\n\t\tif(this.initializeElement(element)){\n\t\t\t\n\t\t\tthis.initializeCoreSystems(options);\n\t\t\t\n\t\t\t//delay table creation to allow event bindings immediately after the constructor\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis._create();\n\t\t\t});\n\t\t}\n\t\t\n\t\tTableRegistry.register(this); //register table for inter-device communication\n\t}\n\t\n\tinitializeElement(element){\n\t\tif(typeof HTMLElement !== \"undefined\" && element instanceof HTMLElement){\n\t\t\tthis.element = element;\n\t\t\treturn true;\n\t\t}else if(typeof element === \"string\"){\n\t\t\tthis.element = document.querySelector(element);\n\t\t\t\n\t\t\tif(this.element){\n\t\t\t\treturn true;\n\t\t\t}else{\n\t\t\t\tconsole.error(\"Tabulator Creation Error - no element found matching selector: \", element);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.error(\"Tabulator Creation Error - Invalid element provided:\", element);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\tinitializeCoreSystems(options){\n\t\tthis.columnManager = new ColumnManager(this);\n\t\tthis.rowManager = new RowManager(this);\n\t\tthis.footerManager = new FooterManager(this);\n\t\tthis.dataLoader = new DataLoader(this);\n\t\tthis.alertManager = new Alert(this);\n\t\t\n\t\tthis.bindModules();\n\t\t\n\t\tthis.options = this.optionsList.generate(Tabulator.defaultOptions, options);\n\t\t\n\t\tthis._clearObjectPointers();\n\t\t\n\t\tthis._mapDeprecatedFunctionality();\n\t\t\n\t\tthis.externalEvents = new ExternalEventBus(this, this.options, this.options.debugEventsExternal);\n\t\tthis.eventBus = new InternalEventBus(this.options.debugEventsInternal);\n\t\t\n\t\tthis.interactionMonitor = new InteractionMonitor(this);\n\t\t\n\t\tthis.dataLoader.initialize();\n\t\t// this.columnManager.initialize();\n\t\t// this.rowManager.initialize();\n\t\tthis.footerManager.initialize();\n\t}\n\t\n\t//convert deprecated functionality to new functions\n\t_mapDeprecatedFunctionality(){\n\t\t//all previously deprecated functionality removed in the 5.0 release\n\t}\n\t\n\t_clearSelection(){\n\t\t\n\t\tthis.element.classList.add(\"tabulator-block-select\");\n\t\t\n\t\tif (window.getSelection) {\n\t\t\tif (window.getSelection().empty) { // Chrome\n\t\t\t\twindow.getSelection().empty();\n\t\t\t} else if (window.getSelection().removeAllRanges) { // Firefox\n\t\t\t\twindow.getSelection().removeAllRanges();\n\t\t\t}\n\t\t} else if (document.selection) { // IE?\n\t\t\tdocument.selection.empty();\n\t\t}\n\t\t\n\t\tthis.element.classList.remove(\"tabulator-block-select\");\n\t}\n\t\n\t//create table\n\t_create(){\n\t\tthis.externalEvents.dispatch(\"tableBuilding\");\n\t\tthis.eventBus.dispatch(\"table-building\");\n\t\t\n\t\tthis._rtlCheck();\n\t\t\n\t\tthis._buildElement();\n\t\t\n\t\tthis._initializeTable();\n\t\t\n\t\tthis._loadInitialData();\n\t\t\n\t\tthis.initialized = true;\n\t\t\n\t\tthis.externalEvents.dispatch(\"tableBuilt\");\n\t}\n\t\n\t_rtlCheck(){\n\t\tvar style = window.getComputedStyle(this.element);\n\t\t\n\t\tswitch(this.options.textDirection){\n\t\t\tcase\"auto\":\n\t\t\t\tif(style.direction !== \"rtl\"){\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\n\t\t\tcase \"rtl\":\n\t\t\t\tthis.element.classList.add(\"tabulator-rtl\");\n\t\t\t\tthis.rtl = true;\n\t\t\t\tbreak;\n\t\t\t\n\t\t\tcase \"ltr\":\n\t\t\t\tthis.element.classList.add(\"tabulator-ltr\");\n\t\t\t\n\t\t\tdefault:\n\t\t\t\tthis.rtl = false;\n\t\t}\n\t}\n\t\n\t//clear pointers to objects in default config object\n\t_clearObjectPointers(){\n\t\tthis.options.columns = this.options.columns.slice(0);\n\t\t\n\t\tif(Array.isArray(this.options.data) && !this.options.reactiveData){\n\t\t\tthis.options.data = this.options.data.slice(0);\n\t\t}\n\t}\n\t\n\t//build tabulator element\n\t_buildElement(){\n\t\tvar element = this.element,\n\t\toptions = this.options,\n\t\tnewElement;\n\t\t\n\t\tif(element.tagName === \"TABLE\"){\n\t\t\tthis.originalElement = this.element;\n\t\t\tnewElement = document.createElement(\"div\");\n\t\t\t\n\t\t\t//transfer attributes to new element\n\t\t\tvar attributes = element.attributes;\n\t\t\t\n\t\t\t// loop through attributes and apply them on div\n\t\t\tfor(var i in attributes){\n\t\t\t\tif(typeof attributes[i] == \"object\"){\n\t\t\t\t\tnewElement.setAttribute(attributes[i].name, attributes[i].value);\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\t// replace table with div element\n\t\t\telement.parentNode.replaceChild(newElement, element);\n\t\t\t\n\t\t\tthis.element = element = newElement;\n\t\t}\n\t\t\n\t\telement.classList.add(\"tabulator\");\n\t\telement.setAttribute(\"role\", \"grid\");\n\t\t\n\t\t//empty element\n\t\twhile(element.firstChild) element.removeChild(element.firstChild);\n\t\t\n\t\t//set table height\n\t\tif(options.height){\n\t\t\toptions.height = isNaN(options.height) ? options.height : options.height + \"px\";\n\t\t\telement.style.height = options.height;\n\t\t}\n\t\t\n\t\t//set table min height\n\t\tif(options.minHeight !== false){\n\t\t\toptions.minHeight = isNaN(options.minHeight) ? options.minHeight : options.minHeight + \"px\";\n\t\t\telement.style.minHeight = options.minHeight;\n\t\t}\n\t\t\n\t\t//set table maxHeight\n\t\tif(options.maxHeight !== false){\n\t\t\toptions.maxHeight = isNaN(options.maxHeight) ? options.maxHeight : options.maxHeight + \"px\";\n\t\t\telement.style.maxHeight = options.maxHeight;\n\t\t}\n\t}\n\t\n\t//initialize core systems and modules\n\t_initializeTable(){\n\t\tvar element = this.element,\n\t\toptions = this.options;\n\t\t\n\t\tthis.interactionMonitor.initialize();\n\t\t\n\t\tthis.columnManager.initialize();\n\t\tthis.rowManager.initialize();\n\t\t\n\t\tthis._detectBrowser();\n\t\t\n\t\t//initialize core modules\n\t\tthis.modulesCore.forEach((mod) => {\n\t\t\tmod.initialize();\n\t\t});\n\t\t\n\t\t//build table elements\n\t\telement.appendChild(this.columnManager.getElement());\n\t\telement.appendChild(this.rowManager.getElement());\n\t\t\n\t\tif(options.footerElement){\n\t\t\tthis.footerManager.activate();\n\t\t}\n\t\t\n\t\tif(options.autoColumns && options.data){\n\t\t\t\n\t\t\tthis.columnManager.generateColumnsFromRowData(this.options.data);\n\t\t}\n\t\t\n\t\t//initialize regular modules\n\t\tthis.modulesRegular.forEach((mod) => {\n\t\t\tmod.initialize();\n\t\t});\n\t\t\n\t\tthis.columnManager.setColumns(options.columns);\n\t\t\n\t\tthis.eventBus.dispatch(\"table-built\");\n\t}\n\t\n\t_loadInitialData(){\n\t\tthis.dataLoader.load(this.options.data);\n\t}\n\t\n\t//deconstructor\n\tdestroy(){\n\t\tvar element = this.element;\n\t\t\n\t\tthis.destroyed = true;\n\t\t\n\t\tTableRegistry.deregister(this); //deregister table from inter-device communication\n\t\t\n\t\tthis.eventBus.dispatch(\"table-destroy\");\n\t\t\n\t\t//clear row data\n\t\tthis.rowManager.destroy();\n\t\t\n\t\t//clear DOM\n\t\twhile(element.firstChild) element.removeChild(element.firstChild);\n\t\telement.classList.remove(\"tabulator\");\n\n\t\tthis.externalEvents.dispatch(\"tableDestroyed\");\n\t}\n\t\n\t_detectBrowser(){\n\t\tvar ua = navigator.userAgent||navigator.vendor||window.opera;\n\t\t\n\t\tif(ua.indexOf(\"Trident\") > -1){\n\t\t\tthis.browser = \"ie\";\n\t\t\tthis.browserSlow = true;\n\t\t}else if(ua.indexOf(\"Edge\") > -1){\n\t\t\tthis.browser = \"edge\";\n\t\t\tthis.browserSlow = true;\n\t\t}else if(ua.indexOf(\"Firefox\") > -1){\n\t\t\tthis.browser = \"firefox\";\n\t\t\tthis.browserSlow = false;\n\t\t}else if(ua.indexOf(\"Mac OS\") > -1){\n\t\t\tthis.browser = \"safari\";\n\t\t\tthis.browserSlow = false;\n\t\t}else{\n\t\t\tthis.browser = \"other\";\n\t\t\tthis.browserSlow = false;\n\t\t}\n\t\t\n\t\tthis.browserMobile = /(android|bb\\d+|meego).+mobile|avantgo|bada\\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(ua)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw-(n|u)|c55\\/|capi|ccwa|cdm-|cell|chtm|cldc|cmd-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc-s|devi|dica|dmob|do(c|p)o|ds(12|-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(-|_)|g1 u|g560|gene|gf-5|g-mo|go(\\.w|od)|gr(ad|un)|haie|hcit|hd-(m|p|t)|hei-|hi(pt|ta)|hp( i|ip)|hs-c|ht(c(-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i-(20|go|ma)|i230|iac( |-|\\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\\/)|klon|kpt |kwc-|kyo(c|k)|le(no|xi)|lg( g|\\/(k|l|u)|50|54|-[a-w])|libw|lynx|m1-w|m3ga|m50\\/|ma(te|ui|xo)|mc(01|21|ca)|m-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|-([1-8]|c))|phil|pire|pl(ay|uc)|pn-2|po(ck|rt|se)|prox|psio|pt-g|qa-a|qc(07|12|21|32|60|-[2-7]|i-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h-|oo|p-)|sdk\\/|se(c(-|0|1)|47|mc|nd|ri)|sgh-|shar|sie(-|m)|sk-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h-|v-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl-|tdg-|tel(i|m)|tim-|t-mo|to(pl|sh)|ts(70|m-|m3|m5)|tx-9|up(\\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas-|your|zeto|zte-/i.test(ua.slice(0,4));\n\t}\n\t\n\tinitGuard(func, msg){\n\t\tvar stack, line;\n\t\t\n\t\tif(this.options.debugInitialization && !this.initialized){\n\t\t\tif(!func){\n\t\t\t\tstack = new Error().stack.split(\"\\n\");\n\t\t\t\t\n\t\t\t\tline = stack[0] == \"Error\" ? stack[2] : stack[1];\n\t\t\t\t\n\t\t\t\tif(line[0] == \" \"){\n\t\t\t\t\tfunc = line.trim().split(\" \")[1].split(\".\")[1];\n\t\t\t\t}else{\n\t\t\t\t\tfunc = line.trim().split(\"@\")[0];\n\t\t\t\t}\n\t\t\t}\n\t\t\t\n\t\t\tconsole.warn(\"Table Not Initialized - Calling the \" + func + \" function before the table is initialized may result in inconsistent behavior, Please wait for the `tableBuilt` event before calling this function.\" + (msg ? \" \" + msg : \"\"));\n\t\t}\n\t\t\n\t\treturn this.initialized;\n\t}\n\t\n\t////////////////// Data Handling //////////////////\n\t//block table redrawing\n\tblockRedraw(){\n\t\tthis.initGuard();\n\n\t\tthis.eventBus.dispatch(\"redraw-blocking\");\n\t\t\n\t\tthis.rowManager.blockRedraw();\n\t\tthis.columnManager.blockRedraw();\n\n\t\tthis.eventBus.dispatch(\"redraw-blocked\");\n\t}\n\t\n\t//restore table redrawing\n\trestoreRedraw(){\n\t\tthis.initGuard();\n\n\t\tthis.eventBus.dispatch(\"redraw-restoring\");\n\n\t\tthis.rowManager.restoreRedraw();\n\t\tthis.columnManager.restoreRedraw();\n\n\t\tthis.eventBus.dispatch(\"redraw-restored\");\n\t}\n\t\n\t//load data\n\tsetData(data, params, config){\n\t\tthis.initGuard(false, \"To set initial data please use the 'data' property in the table constructor.\");\n\t\t\n\t\treturn this.dataLoader.load(data, params, config, false);\n\t}\n\t\n\t//clear data\n\tclearData(){\n\t\tthis.initGuard();\n\t\t\n\t\tthis.dataLoader.blockActiveLoad();\n\t\tthis.rowManager.clearData();\n\t}\n\t\n\t//get table data array\n\tgetData(active){\n\t\treturn this.rowManager.getData(active);\n\t}\n\t\n\t//get table data array count\n\tgetDataCount(active){\n\t\treturn this.rowManager.getDataCount(active);\n\t}\n\t\n\t//replace data, keeping table in position with same sort\n\treplaceData(data, params, config){\n\t\tthis.initGuard();\n\t\t\n\t\treturn this.dataLoader.load(data, params, config, true, true);\n\t}\n\t\n\t//update table data\n\tupdateData(data){\n\t\tvar responses = 0;\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tthis.dataLoader.blockActiveLoad();\n\t\t\t\n\t\t\tif(typeof data === \"string\"){\n\t\t\t\tdata = JSON.parse(data);\n\t\t\t}\n\t\t\t\n\t\t\tif(data && data.length > 0){\n\t\t\t\tdata.forEach((item) => {\n\t\t\t\t\tvar row = this.rowManager.findRow(item[this.options.index]);\n\t\t\t\t\t\n\t\t\t\t\tif(row){\n\t\t\t\t\t\tresponses++;\n\t\t\t\t\t\t\n\t\t\t\t\t\trow.updateData(item)\n\t\t\t\t\t\t\t.then(()=>{\n\t\t\t\t\t\t\t\tresponses--;\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tif(!responses){\n\t\t\t\t\t\t\t\t\tresolve();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.catch((e) => {\n\t\t\t\t\t\t\t\treject(\"Update Error - Unable to update row\", item, e);\n\t\t\t\t\t\t\t});\n\t\t\t\t\t}else{\n\t\t\t\t\t\treject(\"Update Error - Unable to find row\", item);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Update Error - No data provided\");\n\t\t\t\treject(\"Update Error - No data provided\");\n\t\t\t}\n\t\t});\n\t}\n\t\n\taddData(data, pos, index){\n\t\tthis.initGuard();\n\t\t\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tthis.dataLoader.blockActiveLoad();\n\t\t\t\n\t\t\tif(typeof data === \"string\"){\n\t\t\t\tdata = JSON.parse(data);\n\t\t\t}\n\t\t\t\n\t\t\tif(data){\n\t\t\t\tthis.rowManager.addRows(data, pos, index)\n\t\t\t\t\t.then((rows) => {\n\t\t\t\t\t\tvar output = [];\n\t\t\t\t\t\n\t\t\t\t\t\trows.forEach(function(row){\n\t\t\t\t\t\t\toutput.push(row.getComponent());\n\t\t\t\t\t\t});\n\t\t\t\t\t\n\t\t\t\t\t\tresolve(output);\n\t\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Update Error - No data provided\");\n\t\t\t\treject(\"Update Error - No data provided\");\n\t\t\t}\n\t\t});\n\t}\n\t\n\t//update table data\n\tupdateOrAddData(data){\n\t\tvar rows = [],\n\t\tresponses = 0;\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tthis.dataLoader.blockActiveLoad();\n\t\t\t\n\t\t\tif(typeof data === \"string\"){\n\t\t\t\tdata = JSON.parse(data);\n\t\t\t}\n\t\t\t\n\t\t\tif(data && data.length > 0){\n\t\t\t\tdata.forEach((item) => {\n\t\t\t\t\tvar row = this.rowManager.findRow(item[this.options.index]);\n\t\t\t\t\t\n\t\t\t\t\tresponses++;\n\t\t\t\t\t\n\t\t\t\t\tif(row){\n\t\t\t\t\t\trow.updateData(item)\n\t\t\t\t\t\t\t.then(()=>{\n\t\t\t\t\t\t\t\tresponses--;\n\t\t\t\t\t\t\t\trows.push(row.getComponent());\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tif(!responses){\n\t\t\t\t\t\t\t\t\tresolve(rows);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t}else{\n\t\t\t\t\t\tthis.rowManager.addRows(item)\n\t\t\t\t\t\t\t.then((newRows)=>{\n\t\t\t\t\t\t\t\tresponses--;\n\t\t\t\t\t\t\t\trows.push(newRows[0].getComponent());\n\t\t\t\t\t\t\t\n\t\t\t\t\t\t\t\tif(!responses){\n\t\t\t\t\t\t\t\t\tresolve(rows);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Update Error - No data provided\");\n\t\t\t\treject(\"Update Error - No data provided\");\n\t\t\t}\n\t\t});\n\t}\n\t\n\t//get row object\n\tgetRow(index){\n\t\tvar row = this.rowManager.findRow(index);\n\t\t\n\t\tif(row){\n\t\t\treturn row.getComponent();\n\t\t}else{\n\t\t\tconsole.warn(\"Find Error - No matching row found:\", index);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\t//get row object\n\tgetRowFromPosition(position){\n\t\tvar row = this.rowManager.getRowFromPosition(position);\n\t\t\n\t\tif(row){\n\t\t\treturn row.getComponent();\n\t\t}else{\n\t\t\tconsole.warn(\"Find Error - No matching row found:\", position);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\t//delete row from table\n\tdeleteRow(index){\n\t\tvar foundRows = [];\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(!Array.isArray(index)){\n\t\t\tindex = [index];\n\t\t}\n\t\t\n\t\t//find matching rows\n\t\tfor(let item of index){\n\t\t\tlet row = this.rowManager.findRow(item, true);\n\t\t\t\n\t\t\tif(row){\n\t\t\t\tfoundRows.push(row);\n\t\t\t}else{\n\t\t\t\tconsole.error(\"Delete Error - No matching row found:\", item);\n\t\t\t\treturn Promise.reject(\"Delete Error - No matching row found\");\n\t\t\t}\n\t\t}\n\t\t\n\t\t//sort rows into correct order to ensure smooth delete from table\n\t\tfoundRows.sort((a, b) => {\n\t\t\treturn this.rowManager.rows.indexOf(a) > this.rowManager.rows.indexOf(b) ? 1 : -1;\n\t\t});\n\t\t\n\t\t//delete rows\n\t\tfoundRows.forEach((row) =>{\n\t\t\trow.delete();\n\t\t});\n\t\t\n\t\tthis.rowManager.reRenderInPosition();\n\t\t\n\t\treturn Promise.resolve();\n\t}\n\t\n\t//add row to table\n\taddRow(data, pos, index){\n\t\tthis.initGuard();\n\t\t\n\t\tif(typeof data === \"string\"){\n\t\t\tdata = JSON.parse(data);\n\t\t}\n\t\t\n\t\treturn this.rowManager.addRows(data, pos, index, true)\n\t\t\t.then((rows)=>{\n\t\t\t\treturn rows[0].getComponent();\n\t\t\t});\n\t}\n\t\n\t//update a row if it exists otherwise create it\n\tupdateOrAddRow(index, data){\n\t\tvar row = this.rowManager.findRow(index);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(typeof data === \"string\"){\n\t\t\tdata = JSON.parse(data);\n\t\t}\n\t\t\n\t\tif(row){\n\t\t\treturn row.updateData(data)\n\t\t\t\t.then(()=>{\n\t\t\t\t\treturn row.getComponent();\n\t\t\t\t});\n\t\t}else{\n\t\t\treturn this.rowManager.addRows(data)\n\t\t\t\t.then((rows)=>{\n\t\t\t\t\treturn rows[0].getComponent();\n\t\t\t\t});\n\t\t}\n\t}\n\t\n\t//update row data\n\tupdateRow(index, data){\n\t\tvar row = this.rowManager.findRow(index);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(typeof data === \"string\"){\n\t\t\tdata = JSON.parse(data);\n\t\t}\n\t\t\n\t\tif(row){\n\t\t\treturn row.updateData(data)\n\t\t\t\t.then(()=>{\n\t\t\t\t\treturn Promise.resolve(row.getComponent());\n\t\t\t\t});\n\t\t}else{\n\t\t\tconsole.warn(\"Update Error - No matching row found:\", index);\n\t\t\treturn Promise.reject(\"Update Error - No matching row found\");\n\t\t}\n\t}\n\t\n\t//scroll to row in DOM\n\tscrollToRow(index, position, ifVisible){\n\t\tvar row = this.rowManager.findRow(index);\n\t\t\n\t\tif(row){\n\t\t\treturn this.rowManager.scrollToRow(row, position, ifVisible);\n\t\t}else{\n\t\t\tconsole.warn(\"Scroll Error - No matching row found:\", index);\n\t\t\treturn Promise.reject(\"Scroll Error - No matching row found\");\n\t\t}\n\t}\n\t\n\tmoveRow(from, to, after){\n\t\tvar fromRow = this.rowManager.findRow(from);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(fromRow){\n\t\t\tfromRow.moveToRow(to, after);\n\t\t}else{\n\t\t\tconsole.warn(\"Move Error - No matching row found:\", from);\n\t\t}\n\t}\n\t\n\tgetRows(active){\n\t\treturn this.rowManager.getComponents(active);\t\n\t}\n\t\n\t//get position of row in table\n\tgetRowPosition(index){\n\t\tvar row = this.rowManager.findRow(index);\n\t\t\n\t\tif(row){\n\t\t\treturn row.getPosition();\n\t\t}else{\n\t\t\tconsole.warn(\"Position Error - No matching row found:\", index);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\t/////////////// Column Functions ///////////////\n\tsetColumns(definition){\n\t\tthis.initGuard(false, \"To set initial columns please use the 'columns' property in the table constructor\");\n\t\t\n\t\tthis.columnManager.setColumns(definition);\n\t}\n\t\n\tgetColumns(structured){\n\t\treturn this.columnManager.getComponents(structured);\n\t}\n\t\n\tgetColumn(field){\n\t\tvar column = this.columnManager.findColumn(field);\n\t\t\n\t\tif(column){\n\t\t\treturn column.getComponent();\n\t\t}else{\n\t\t\tconsole.warn(\"Find Error - No matching column found:\", field);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\tgetColumnDefinitions(){\n\t\treturn this.columnManager.getDefinitionTree();\n\t}\n\t\n\tshowColumn(field){\n\t\tvar column = this.columnManager.findColumn(field);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(column){\n\t\t\tcolumn.show();\n\t\t}else{\n\t\t\tconsole.warn(\"Column Show Error - No matching column found:\", field);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\thideColumn(field){\n\t\tvar column = this.columnManager.findColumn(field); \n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(column){\n\t\t\tcolumn.hide();\n\t\t}else{\n\t\t\tconsole.warn(\"Column Hide Error - No matching column found:\", field);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\ttoggleColumn(field){\n\t\tvar column = this.columnManager.findColumn(field);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(column){\n\t\t\tif(column.visible){\n\t\t\t\tcolumn.hide();\n\t\t\t}else{\n\t\t\t\tcolumn.show();\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.warn(\"Column Visibility Toggle Error - No matching column found:\", field);\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\taddColumn(definition, before, field){\n\t\tvar column = this.columnManager.findColumn(field);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\treturn this.columnManager.addColumn(definition, before, column)\n\t\t\t.then((column) => {\n\t\t\t\treturn column.getComponent();\n\t\t\t});\n\t}\n\t\n\tdeleteColumn(field){\n\t\tvar column = this.columnManager.findColumn(field);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(column){\n\t\t\treturn column.delete();\n\t\t}else{\n\t\t\tconsole.warn(\"Column Delete Error - No matching column found:\", field);\n\t\t\treturn Promise.reject();\n\t\t}\n\t}\n\t\n\tupdateColumnDefinition(field, definition){\n\t\tvar column = this.columnManager.findColumn(field);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(column){\n\t\t\treturn column.updateDefinition(definition);\n\t\t}else{\n\t\t\tconsole.warn(\"Column Update Error - No matching column found:\", field);\n\t\t\treturn Promise.reject();\n\t\t}\n\t}\n\t\n\tmoveColumn(from, to, after){\n\t\tvar fromColumn = this.columnManager.findColumn(from),\n\t\ttoColumn = this.columnManager.findColumn(to);\n\t\t\n\t\tthis.initGuard();\n\t\t\n\t\tif(fromColumn){\n\t\t\tif(toColumn){\n\t\t\t\tthis.columnManager.moveColumn(fromColumn, toColumn, after);\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Move Error - No matching column found:\", toColumn);\n\t\t\t}\n\t\t}else{\n\t\t\tconsole.warn(\"Move Error - No matching column found:\", from);\n\t\t}\n\t}\n\t\n\t//scroll to column in DOM\n\tscrollToColumn(field, position, ifVisible){\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tvar column = this.columnManager.findColumn(field);\n\t\t\t\n\t\t\tif(column){\n\t\t\t\treturn this.columnManager.scrollToColumn(column, position, ifVisible);\n\t\t\t}else{\n\t\t\t\tconsole.warn(\"Scroll Error - No matching column found:\", field);\n\t\t\t\treturn Promise.reject(\"Scroll Error - No matching column found\");\n\t\t\t}\n\t\t});\n\t}\n\t\n\t//////////// General Public Functions ////////////\n\t//redraw list without updating data\n\tredraw(force){\n\t\tthis.initGuard();\n\n\t\tthis.columnManager.redraw(force);\n\t\tthis.rowManager.redraw(force);\n\t}\n\t\n\tsetHeight(height){\n\t\tthis.options.height = isNaN(height) ? height : height + \"px\";\n\t\tthis.element.style.height = this.options.height;\n\t\tthis.rowManager.initializeRenderer();\n\t\tthis.rowManager.redraw();\n\t}\n\t\n\t//////////////////// Event Bus ///////////////////\n\t\n\ton(key, callback){\n\t\tthis.externalEvents.subscribe(key, callback);\n\t}\n\t\n\toff(key, callback){\n\t\tthis.externalEvents.unsubscribe(key, callback);\n\t}\n\t\n\tdispatchEvent(){\n\t\tvar args = Array.from(arguments);\n\t\targs.shift();\n\t\t\n\t\tthis.externalEvents.dispatch(...arguments);\n\t}\n\n\t//////////////////// Alerts ///////////////////\n\n\talert(contents, type){\n\t\tthis.initGuard();\n\n\t\tthis.alertManager.alert(contents, type);\n\t}\n\n\tclearAlert(){\n\t\tthis.initGuard();\n\n\t\tthis.alertManager.clear();\n\t}\n\t\n\t////////////// Extension Management //////////////\n\tmodExists(plugin, required){\n\t\tif(this.modules[plugin]){\n\t\t\treturn true;\n\t\t}else{\n\t\t\tif(required){\n\t\t\t\tconsole.error(\"Tabulator Module Not Installed: \" + plugin);\n\t\t\t}\n\t\t\treturn false;\n\t\t}\n\t}\n\t\n\tmodule(key){\n\t\tvar mod = this.modules[key];\n\t\t\n\t\tif(!mod){\n\t\t\tconsole.error(\"Tabulator module not installed: \" + key);\n\t\t}\n\t\t\n\t\treturn mod;\n\t}\n}\n\n//default setup options\nTabulator.defaultOptions = defaultOptions;\n\n//bind modules and static functionality\nnew ModuleBinder(Tabulator);\n\nexport default Tabulator;\n","export default {\n\n\tdebugEventsExternal:false, //flag to console log events\n\tdebugEventsInternal:false, //flag to console log events\n\tdebugInvalidOptions:true, //allow toggling of invalid option warnings\n\tdebugInvalidComponentFuncs:true, //allow toggling of invalid component warnings\n\tdebugInitialization:true, //allow toggling of pre initialization function call warnings\n\tdebugDeprecation:true, //allow toggling of deprecation warnings\n\n\theight:false, //height of tabulator\n\tminHeight:false, //minimum height of tabulator\n\tmaxHeight:false, //maximum height of tabulator\n\n\tcolumnHeaderVertAlign:\"top\", //vertical alignment of column headers\n\n\tpopupContainer:false,\n\n\tcolumns:[],//store for colum header info\n\tcolumnDefaults:{}, //store column default props\n\n\tdata:false, //default starting data\n\n\tautoColumns:false, //build columns from data row structure\n\tautoColumnsDefinitions:false,\n\n\tnestedFieldSeparator:\".\", //separator for nested data\n\n\tfooterElement:false, //hold footer element\n\n\tindex:\"id\", //filed for row index\n\n\ttextDirection:\"auto\",\n\n\taddRowPos:\"bottom\", //position to insert blank rows, top|bottom\n\n\theaderVisible:true, //hide header\n\n\trenderVertical:\"virtual\",\n\trenderHorizontal:\"basic\",\n\trenderVerticalBuffer:0, // set virtual DOM buffer size\n\n\tscrollToRowPosition:\"top\",\n\tscrollToRowIfVisible:true,\n\n\tscrollToColumnPosition:\"left\",\n\tscrollToColumnIfVisible:true,\n\n\trowFormatter:false,\n\trowFormatterPrint:null,\n\trowFormatterClipboard:null,\n\trowFormatterHtmlOutput:null,\n\n\trowHeight:null,\n\n\tplaceholder:false,\n\n\tdataLoader:true,\n\tdataLoaderLoading:false,\n\tdataLoaderError:false,\n\tdataLoaderErrorTimeout:3000,\n\n\tdataSendParams:{},\n\n\tdataReceiveParams:{},\n};\n","//tabulator with all modules installed\nimport {default as Tabulator} from './Tabulator.js';\nimport * as modules from '../core/modules/optional.js';\nimport ModuleBinder from './tools/ModuleBinder.js';\n\nclass TabulatorFull extends Tabulator {}\n\n//bind modules and static functionality\nnew ModuleBinder(TabulatorFull, modules);\n\nexport default TabulatorFull;","export default class PseudoRow {\n\n\tconstructor (type){\n\t\tthis.type = type;\n\t\tthis.element = this._createElement();\n\t}\n\n\t_createElement(){\n\t\tvar el = document.createElement(\"div\");\n\t\tel.classList.add(\"tabulator-row\");\n\t\treturn el;\n\t}\n\n\tgetElement(){\n\t\treturn this.element;\n\t}\n\n\tgetComponent(){\n\t\treturn false;\n\t}\n\n\tgetData(){\n\t\treturn {};\n\t}\n\n\tgetHeight(){\n\t\treturn this.element.outerHeight;\n\t}\n\n\tinitialize(){}\n\n\treinitialize(){}\n\n\tnormalizeHeight(){}\n\n\tgenerateCells(){}\n\n\treinitializeHeight(){}\n\n\tcalcHeight(){}\n\n\tsetCellHeight(){}\n\n\tclearCellHeight(){}\n}"],"names":["CoreFeature","constructor","table","this","reloadData","data","silent","columnsChanged","dataLoader","load","undefined","langText","modules","localize","getText","arguments","langBind","bind","langLocale","getLocale","commsConnections","comms","getConnections","commsSend","send","layoutMode","layout","getMode","layoutRefresh","force","subscribe","eventBus","unsubscribe","subscribed","key","subscriptionChange","dispatch","chain","confirm","dispatchExternal","externalEvents","subscribedExternal","subscriptionChangeExternal","options","setOption","value","deprecationCheck","oldOption","newOption","deprecationAdvisor","check","deprecationCheckMsg","msg","checkMsg","deprecationMsg","module","Helpers","static","el","offsetWidth","offsetHeight","box","getBoundingClientRect","top","window","pageYOffset","document","documentElement","clientTop","left","pageXOffset","clientLeft","obj","clone","list","objectProto","__proto__","arrayProto","i","Object","assign","Array","isArray","match","copy","subject","findIndex","item","unshift","deepClone","Popup","element","parent","super","container","_lookupContainer","reversedX","childPopup","blurable","blurCallback","blurEventsBound","renderedCallback","visible","hideable","classList","add","blurEvent","hide","escEvent","_escapeCheck","destroyBinding","tableDestroyed","destroyed","popupContainer","querySelector","console","warn","_checkContainerIsParent","body","parentNode","renderCallback","callback","containerEventCoords","e","touch","MouseEvent","x","touches","pageX","y","pageY","parentOffset","elOffset","elementPositionCoords","position","containerOffset","offset","show","origin","parentEl","coords","HTMLElement","style","appendChild","_fitToScreen","addEventListener","stopPropagation","scrollTop","right","Math","max","scrollHeight","parseInt","isVisible","hideOnBlur","setTimeout","rowManager","keyCode","blockHide","restoreHide","removeEventListener","removeChild","child","Module","name","_handler","initialize","registerTableOption","optionsList","register","registerColumnOption","columnManager","registerTableFunction","func","args","initGuard","registerComponentFunction","component","handler","componentFunctionBinder","registerDataHandler","priority","registerDataPipelineHandler","registerDisplayHandler","registerDisplayPipelineHandler","displayRows","adjust","lookupIndex","index","length","displayPipeline","getDisplayRows","activeRows","refreshData","renderInPosition","refreshActiveData","footerAppend","footerManager","append","footerPrepend","prepend","footerRemove","remove","popup","menuEl","menuContainer","alert","content","type","alertManager","clearAlert","clear","Accessor","allowedTypes","initializeColumn","transformRow","column","config","forEach","accessor","charAt","toUpperCase","slice","definition","lookupAccessor","params","accessors","row","rowComponent","getComponent","traverse","colComponent","getFieldValue","setFieldValue","moduleName","generateParamsList","prefix","output","concat","push","serializeParams","encoded","encodeURIComponent","join","url","keys","method","toLowerCase","includes","json","headers","JSON","stringify","form","FormData","Ajax","urlGenerator","loaderPromise","contentTypeFormatters","ajaxRequestFunc","defaultLoaderPromise","ajaxURLGenerator","defaultURLGenerator","ajaxURL","setUrl","setDefaultConfig","ajaxConfig","getUrl","requestDataCheck","requestParams","requestData","ajaxParams","call","previousData","generateConfig","sendRequest","defaultConfig","ajaxRequesting","then","ajaxResponse","Promise","reject","contentType","resolve","ajaxContentType","Accept","mode","location","credentials","fetch","response","ok","catch","error","status","statusText","defaultContentTypeFormatters","Clipboard","pasteParser","pasteAction","customSelection","rowRange","blocked","clipboard","clipboardCopyRowRange","plain","html","preventDefault","clipboardCopyFormatter","export","generateExportList","clipboardCopyConfig","clipboardCopyStyled","generateHTMLTable","generatePlainContent","clipboardData","setData","originalEvent","reset","paste","setPasteParser","clipboardPasteParser","setPasteAction","clipboardPasteAction","rowData","columns","col","getKey","range","internal","sel","textRange","getSelection","createRange","selectNodeContents","toString","removeAllRanges","addRange","selection","createTextRange","moveToElementText","select","execCommand","action","pasteActions","parser","pasteParsers","rows","checkPaseOrigin","getPasteData","modExists","mutateData","mutator","valid","target","tagName","edit","currentCell","getData","replace","update","updateOrAddData","insert","addData","headerFindSuccess","columnMap","split","find","title","trim","field","columnsByIndex","shift","CalcComponent","_row","Proxy","get","receiver","handle","transform","getElement","getTable","getCells","cells","cell","getCell","_getSelf","CellComponent","_cell","getValue","getOldValue","getInitialValue","initialValue","getRow","getType","getField","getColumn","setValue","mutate","restoreOldValue","setValueActual","restoreInitialValue","checkHeight","Cell","oldValue","height","width","minWidth","loaded","build","generateElement","setWidth","_configureCell","createElement","className","setAttribute","textAlign","hozAlign","vertAlign","display","alignItems","bottom","middle","justifyContent","center","cssClass","_generateContents","val","innerHTML","Node","firstChild","cellRendered","containerOnly","layoutElement","setValueProcessData","cellEdited","changed","widthStyled","clearWidth","getWidth","setMinWidth","minWidthStyled","setMaxWidth","maxWidth","maxWidthStyled","reinitializeHeight","clearHeight","setHeight","heightStyled","getHeight","delete","redrawBlock","deleteCell","calcs","getIndex","getCellIndex","ColumnComponent","_column","getDefinition","getTitleDownload","isGroup","toggle","getSubColumns","getParentColumn","Column","scrollTo","ifVisible","scrollToColumn","move","to","after","toColumn","findColumn","moveColumn","getNextColumn","nextCol","nextColumn","getPrevColumn","prevCol","prevColumn","updateDefinition","updates","result","reinitializeWidth","rerenderColumns","maxInitialWidth","variableHeight","headerVertical","headerHozAlign","headerWordWrap","editableTitle","def","contentElement","titleHolderElement","titleElement","groupElement","createGroupElement","fieldStructure","titleDownload","titleFormatterRendered","mapDefinitions","setField","widthFixed","newCol","attachColumn","checkColumnVisibility","registerColumnField","_initialize","columnHeaderVertAlign","defaults","columnDefaults","generate","defaultOptionList","checkDefinition","indexOf","nestedFieldSeparator","_getNestedData","_getFlatData","_setNestedData","_setFlatData","registerColumnPosition","reRegisterPosition","_buildColumnHeaderContent","_buildGroupHeader","_buildColumnHeader","_buildColumnHeaderTitle","focus","text","_formatColumnHeaderTitle","contents","dataObj","structure","columnRendered","verticalAlign","alignment","parentHeight","getGroupElement","clientHeight","getHeadersElement","minHeight","clearVerticalAlign","paddingTop","getFirstColumn","getLastColumn","getColumns","getTopColumn","updateBranches","colDefs","responsiveToggle","verticalAlignHeaders","matchChildWidths","childWidth","splice","setWidthActual","isNaN","floor","clientWidth","min","checkCellHeights","heightInitialized","offsetParent","clearCellHeight","calcHeight","setCellHeight","getLeftOffset","offsetLeft","ceil","cellCount","deregisterColumn","generateCell","findColumnIndex","_nextVisibleColumn","getColumnByIndex","_prevVisibleColumn","fitToData","setTo","addColumn","defaultOptions","RowComponent","getPosition","watchPosition","scrollToRow","moveToRow","updateData","normalizeHeight","reformat","reinitialize","getNextRow","nextRow","getPrevRow","prevRow","Row","manualHeight","outerHeight","initialized","positionWatchers","created","create","detachElement","generateCells","inFragment","deleteCells","renderer","renderRowCells","rowFormatter","rerenderRowCells","rendered","deinitialize","deinitializeHeight","children","maxHeight","rowHeight","resizableRows","updatedData","newRowData","elVisible","tempData","parse","attrname","getColumnsByFieldRoot","findCell","nextDisplayRow","prevDisplayRow","before","toRow","findRow","moveRowActual","deleteActual","blockRedraw","detachModules","deleteRow","wipe","isDisplayed","setPosition","getGroup","group","avg","values","calcParams","precision","reduce","sum","Number","toFixed","parseFloat","String","count","unique","filter","ColumnCalcs","topCalcs","botCalcs","genColumn","topElement","botElement","topRow","botRow","topInitialized","botInitialized","recalcAfterBlock","cellValueChanged","initializeColumnCheck","rowsUpdated","scrollHorizontal","recalcActiveRows","recalcActiveRowsRefresh","tableRedraw","visibleRows","adjustForScrollbar","restoreRedraw","resizeHolderWidth","getResults","userRecalc","headersElement","recalc","redraw","blockCheck","viewable","groupBy","recalcRowGroup","dataTreeStartExpanded","dataTree","recalcAll","topCalc","bottomCalc","columnCalcs","topCalcParams","botCalcParams","bottomCalcParams","calculations","initializeTopRow","botCalc","initializeBottomRow","removeCalcs","adjustTableSize","reinitializeCalcs","getContentsElement","insertBefore","nextSibling","scrollLeft","rowsToData","generateRow","frozenColumns","recalcGroup","groupRows","getRowGroup","getChildGroups","generateRowData","generateTopRow","generateBottomRow","dataTreeChildColumnCalcs","open","getFilteredTreeChildren","pos","disable","enable","format","formatter","getFormatter","paramKey","hasTopCalcs","hasBottomCalcs","results","getGroups","getGroupResults","groupObj","subGroups","getSubGroups","subGroupResults","subgroup","groups","rtl","paddingLeft","paddingRight","defaultCalculations","DataTree","indent","collapseEl","expandEl","branchEl","elementField","startOpen","collapseRow","expandRow","toggleRow","getTreeParent","getRowChildren","addTreeChildRow","isRowExpanded","dummyEl","dataTreeChildField","dataTreeChildIndent","dataTreeBranchElement","dataTreeCollapseElement","tabIndex","dataTreeExpandElement","initializeRow","layoutRow","rowDelete","rowDataChanged","columnMoving","initializeElementField","tableRedrawing","getRows","reinitializeRowChildren","firstCol","getFirstVisibleColumn","dataTreeElementColumn","getTreeChildren","redrawNeeded","childArray","controlEl","generateControlElement","cloneNode","marginRight","marginLeft","getComputedStyle","getPropertyValue","oldControl","replaceChild","getChildren","allChildren","generateChildren","dataTreeFilter","dataTreeSort","sort","sub","childData","childRow","getTreeParentRoot","childIndex","findChildIndex","recurse","getChildField","csv","setFileContents","delimiter","fileContents","depth","bom","jsonLines","pdf","header","autoTableParams","rowGroupStyles","fontStyle","fontSize","cellPadding","fillColor","rowCalcStyles","jsPDFParams","jsPDF","parseRow","styles","colSpan","rowSpan","orientation","unit","doc","jspdf","autoTable","didDrawPage","head","documentProcessing","xlsx","sheetName","workbook","XLSX","utils","book_new","tableFeatures","compression","compress","writeOptions","bookType","bookSST","generateSheet","merges","worksheet","s","c","r","a","b","j","Date","sheet_add_aoa","encode_range","SheetNames","Sheets","sheetOnly","sheets","sheet","active","intercept","buf","ArrayBuffer","view","Uint8Array","charCodeAt","s2ab","write","Download","mimeType","Blob","deprecatedOptionsCheck","download","downloadToTab","filename","interceptCallback","downloadFunc","downloaders","mime","triggerDownload","downloadConfig","downloadRowRange","groupHeader","groupHeaderDownload","_group","getRowCount","newTab","blob","downloadEncoder","URL","createObjectURL","navigator","msSaveOrOpenBlob","click","commsReceived","maskInput","mask","maskLetter","maskLetterChar","maskNumber","maskNumberChar","maskWildcard","maskWildcardChar","fillSymbols","symbol","char","ctrlKey","metaKey","maskAutoFill","placeholder","defaultDownloaders","Edit","editor","onRendered","success","cancel","editorParams","_initializeParams","displayItems","currentItems","focusedItem","input","_createInputElement","listEl","_createListElement","initialValues","isFilter","filterTimeout","filtered","typing","listIteration","lastAction","filterTerm","actions","_deprecatedOptionsCheck","_initializeValue","_onRendered","listItemFormatter","sortValuesList","searchFunc","searchingPlaceholder","defaultValue","multiselect","headerFilterInitialListGen","cellEl","clickStop","preventScroll","_preventPopupBlur","_preventBlur","_inputKeyDown","_setListWidth","attribs","elementAttributes","clearable","padding","boxSizing","autocomplete","cursor","caretColor","getAttribute","_bindInputEvents","valueCheck","valueKeys","verticalNavigation","placeholderLoading","placeholderEmpty","filterDelay","emptyValue","freetext","filterFunc","filterRemote","allowEmpty","listOnEmpty","valuesLookup","valuesURL","_inputFocus","_inputClick","_inputBlur","_inputSearch","_inputKeyUp","rebuildOptionsList","_filter","clearTimeout","_filterList","_resolveValue","_clearChoices","_keyUp","_keyDown","_keySide","_keyEnter","_keyEsc","_keyHomeEnd","_keyTab","_keySelectLetter","_keyAutoCompLetter","_chooseItem","stopImmediatePropagation","_focusItem","_cancel","_scrollToValue","character","fromCharCode","label","startsWith","scrollIntoView","behavior","block","inline","_generateOptions","_sortOptions","_buildList","_showList","isInteger","_filterOptions","iteration","_ajaxRequest","_uniqueColumnValues","valuesLookupField","_addPlaceholder","responseValues","_parseList","_clearList","term","urlBuilder","getColumnByField","inputValues","entries","map","_parseListItem","option","level","_parseListGroup","itemParams","selected","original","sorter","_defaultSortFunction","_sortGroup","as","bs","a1","b1","L","rx","rd","emptyAlign","isFinite","test","_defaultFilterFunc","_filterItem","matches","_buildItem","itemFormatter","_groupClick","_itemClick","_styleItem","startVis","blur","cellValue","search","onChange","selectContents","textarea","vertNav","whiteSpace","resize","heightNow","shiftKey","shiftEnterSubmit","selectionStart","number","step","blurFunc","date","inputFormat","DT","DateTime","luxon","convertDate","isDateTime","fromISO","fromFormat","toFormat","luxDate","toISO","relatedTarget","rangeParent","explicitOriginalTarget","time","newDatetime","luxTime","datetime","luxDateTime","List","star","self","maxStars","getElementsByTagName","size","stars","starsHolder","createElementNS","starChange","browser","buildStar","starHolder","nextStar","changeValue","overflow","textOverflow","progress","mouseDrag","mouseDragWidth","percent","bar","updateValue","calcVal","round","backgroundColor","screenX","tickCross","tristate","indetermValue","indeterminateValue","indetermState","trueValueSet","falseValueSet","marginTop","checkedValue","checked","trueValue","falseValue","indeterminate","mouseClick","recursionBlock","invalidEdit","editedCells","editors","getEditedCells","clearCellEdited","navigatePrev","navigateNext","navigateLeft","navigateRight","navigateUp","navigateDown","cellIsEdited","clearEdited","editCell","cellCancelEdit","bindEditor","updateCellClass","columnDeleteCheck","rowDeleteCheck","rowEditableCheck","cancelEdit","keybindingNavigateNext","newRow","addRow","edited","allowEdit","nextCell","findPrevEditableCell","findNextEditableCell","prevCell","editable","getCurrentCell","clearEditor","cellEditCancelled","contains","button","focusCellNoEvent","forceEdit","focusScrollAdjust","getRenderMode","topEdge","bottomEdge","rowEl","offsetTop","leftEdge","rightEdge","leftMargin","rightMargin","renderHorizontal","vDomPadLeft","cellEditor","cellClick","cellEditing","validationMode","editIndex","defaultEditors","ExportRow","ExportColumn","Export","cloneTableStyle","colVisProp","getHtml","columnHeaders","headersToExportRows","generateColumnGroupHeaders","bodyToExportRows","rowLookup","generateTable","generateTableElement","getVisibleRows","selectRow","selectedRows","pagination","columnGroups","colData","processColumnGroup","maxDepth","groupData","subGroup","subGroupData","columnVisCheck","visProp","headerDepth","exportRows","parseColumnGroup","rowGroups","exportCols","headerEl","bodyEl","lookupTableStyles","setup","treeElementField","mapElementStyles","generateHeaderElement","generateGroupElement","generateCalcElement","generateRowElement","evenRow","oddRow","calcRow","firstRow","firstGroup","getElementsByClassName","styleCells","firstCell","lastCell","classNames","generator","cellStyle","cellWrapper","formatCells","formatExportValue","align","holder","htmlOutputConfig","from","props","lookup","color","fromStyle","prop","filterVal","rowVal","filterParams","regex","RegExp","like","keywords","separator","keyword","matchAll","starts","ends","endsWith","in","Filter","filterList","headerFilters","headerFilterColumns","prevHeaderFilterChangeCheck","tableInitialized","searchRows","searchData","userSetFilter","userRefreshFilter","userAddFilter","getFilters","userSetHeaderFilterFocus","userGetHeaderFilterValue","userSetHeaderFilterValue","getHeaderFilters","userRemoveFilter","userClearFilter","userClearHeaderFilter","setHeaderFilterFocus","reloadHeaderFilter","getHeaderFilterValue","setHeaderFilterValue","initializeColumnHeaderFilter","hideHeaderFilterElements","showHeaderFilterElements","tableBuilt","generatePlaceholder","filterMode","remoteFilterParams","initialFilter","setFilter","initialHeaderFilter","placeholderHeaderFilter","refreshFilter","addFilter","removeFilter","all","clearFilter","clearHeaderFilter","headerFilter","filterType","tagType","attrType","filterChangeCheck","prevSuccess","emptyFunc","headerFilterFunc","filters","headerFilterFuncParams","fieldVal","colVal","trackChanges","generateHeaderFilterElement","filterElement","editorElement","typingTimer","searchTrigger","onRenderedCallback","headerElement","headerFilterEmptyCheck","headerFilterParams","headerFilterPlaceholder","contentsElement","headerFilterLiveFilterDelay","hasAttribute","headerFilterLiveFilter","hasChanged","findFilter","findSubFilters","ajax","filtersToArray","searchType","filterRecurse","rowList","activeRowComponents","filterRow","subFilter","defaultFilters","plaintext","formatterParams","emptyToSpace","sanitizeHTML","money","integer","decimal","rgx","floatVal","sign","decimalSym","thousandSym","thousand","negativeSign","symbolAfter","abs","link","urlPrefix","labelField","labelTraverse","path","urlField","image","src","urlSuffix","empty","truthy","allowTruthy","tick","tickElement","cross","crossElement","outputFormat","invalid","invalidPlaceholder","isValid","timezone","setZone","datetimediff","suffix","humanize","now","diff","toHuman","traffic","percentValue","colors","legend","legendColor","legendAlign","barEl","barContainer","legendEl","holderEl","buttonTick","buttonCross","rownum","innerText","responsiveCollapse","responsiveLayout","toggleList","isOpen","rowSelection","checkbox","selectableRangeMode","toggleSelect","handleComplexRowClick","isSelected","registerRowSelectCheckbox","deselectRow","registerHeaderSelectCheckbox","Format","formatValue","formatHeader","lookupFormatter","formatterPrint","print","formatterClipboard","formatterHtmlOutput","htmlOutput","formatters","mockCell","titleFormatter","titleFormatterParams","entityMap","defaultFormatters","FrozenColumns","leftColumns","rightColumns","initializationMode","layoutCell","reinitializeColumns","blockLayout","unblockLayout","margin","edge","frozenCheck","frozen","layoutCalcRows","layoutGroupCalcs","groupList","layoutColumnPosition","allCells","leftParents","marginValue","getColGroupParentElement","reinitializeRows","getTableElement","_calcSpace","FrozenRows","freezeRow","unfreezeRow","isRowFrozen","detachRow","frozenRows","initializeRows","rowType","isFrozen","styleRows","styleRow","GroupComponent","groupManager","getParentGroup","toggleVisibility","Group","oldGroup","hasSubGroups","groupIDLookups","_addRowToGroup","_addRow","old","elementContents","arrowElement","createElements","addBindings","createValueGroups","elementsOnly","arrow","movableRows","moveRow","initializeGroupHeader","allowedValues","_createGroup","groupToggleElement","groupID","groupKey","headerGenerator","insertRow","conformRowData","toIndex","updateGroupRows","scrollHeader","getRowIndex","removeRow","groupValues","generateGroupHeaderContents","removeGroup","getHeadersAndRows","_visSet","groupClosedShowCalcs","prev","includeChildren","getPath","childNodes","GroupRows","displayHandler","setGroupBy","setGroupValues","setGroupStartOpen","setGroupHeader","userGetGroups","userGetGroupedData","rowGetGroup","_blockRedrawing","_restore_redrawing","groupUpdateOnCellEdit","cellUpdated","reassignRowToGroup","configureGroupSetup","rowDeleting","scrollHeaders","rowMoving","rowAddingIndex","rowSample","virtualRenderFill","groupStartOpen","langValue","lang","items","getRealColumns","lookupFunc","prevValue","tableElement","assignRowToGroup","moveRowInArray","getGroupedData","toGroup","fromGroup","generateGroups","groupComponents","pullGroupListData","groupListData","rowCount","headerContent","countGroups","oldGroups","createGroup","assignRowToExistingGroup","newGroupNeeded","oldRowGroup","oldGroupPath","newGroupPath","getExpectedPath","every","groupPath","groupId","checkBasicModeGroupHeaderWidth","onlyGroupHeaders","History","history","clearComponentHistory","rowDeleted","rowAdded","rowMoved","undo","redo","getHistoryUndoSize","getHistoryRedoSize","posFrom","posTo","newValue","undoers","redoers","_rebindRow","oldRow","cellEdit","rowAdd","addRowActual","rowMove","getRowFromPosition","regenerateRowPositions","reRenderInPosition","HtmlTableImport","fieldIndex","hasIndex","tableElementCheck","originalElement","parseTable","_extractOptions","_extractHeaders","_generateBlankHeaders","attributes","optionsArr","attrib","_attribValue","_findCol","exists","textContent","replaceAll","registeredDefaults","inQuote","nextChar","array","Import","importFromFile","importFormat","loadDataCheck","loadData","importData","lookupImporter","structureData","err","importer","importers","extension","pickFile","extensions","accept","file","files","reader","FileReader","importReader","readAsArrayBuffer","readAsBinaryString","readAsDataURL","readAsText","onload","onerror","parsedData","autoColumns","structureArrayToObject","structureArrayToColumns","defaultImporters","Interaction","eventMap","rowClick","rowDblClick","rowContext","rowMouseEnter","rowMouseLeave","rowMouseOver","rowMouseOut","rowMouseMove","rowMouseDown","rowMouseUp","rowTap","rowDblTap","rowTapHold","cellDblClick","cellContext","cellMouseEnter","cellMouseLeave","cellMouseOver","cellMouseOut","cellMouseMove","cellMouseDown","cellMouseUp","cellTap","cellDblTap","cellTapHold","headerClick","headerDblClick","headerContext","headerMouseEnter","headerMouseLeave","headerMouseOver","headerMouseOut","headerMouseMove","headerMouseDown","headerMouseUp","headerTap","headerDblTap","headerTapHold","groupClick","groupDblClick","groupContext","groupMouseEnter","groupMouseLeave","groupMouseOver","groupMouseOut","groupMouseMove","groupMouseDown","groupMouseUp","groupTap","groupDblTap","groupTapHold","subscribers","touchSubscribers","columnSubscribers","touchWatchers","tap","tapDbl","tapHold","initializeExternalEvents","cellContentsSelectionFixer","clearTouchWatchers","selectNode","subscriptionChanged","added","subscribeTouchEvents","unsubscribeTouchEvents","handleTouch","noTouch","dispatchEvent","watchers","componentObj","Keybindings","watchKeys","pressedKeys","keyupBinding","keydownBinding","bindings","keybindings","mergedBindings","mapBindings","bindEvents","clearBindings","binding","mapBinding","symbolsList","ctrl","meta","code","checkBinding","navPrev","navNext","navUp","navDown","scrollPageUp","scrollPageDown","scrollToStart","scrollToEnd","copyToClipboard","keyBlock","newPos","displayRowsCount","scrollMax","navLeft","navRight","Menu","nestedMenuBlock","currentComponent","rootPopup","initializeRowWatchers","initializeGroupWatchers","rowContextMenu","loadMenuEvent","on","rowClickMenu","rowDblClickMenu","groupContextMenu","groupClickMenu","groupDblClickMenu","headerContextMenu","loadMenuTableColumnEvent","headerClickMenu","headerDblClickMenu","headerMenu","initializeColumnHeaderMenu","contextMenu","loadMenuTableCellEvent","clickMenu","dblClickMenu","headerMenuEl","icon","headerMenuIcon","menu","loadMenu","parentPopup","itemEl","disabled","MoveColumns","placeholderElement","createPlaceholderElement","hoverElement","checkTimeout","checkPeriod","moving","toCol","toColAfter","startX","autoScrollMargin","autoScrollStep","autoScrollTimeout","touchMove","moveHover","endMove","movableColumns","colEl","mousemove","which","startMove","bindTouchEvents","nextColWidth","prevColWidth","nextColWidthLast","prevColWidthLast","startXMove","passive","moveToCol","_bindMouseMove","_unbindMouseMove","movingCells","moveColumnActual","scrollPos","columnHolder","xPos","MoveRows","toRowAfter","hasHandle","startY","tableRowDropEvent","connection","connectionSelectorsTables","connectionSelectorsElements","connectionElements","connections","connectedTable","connectedRow","movableRowsConnectedTables","movableRowsConnectedElements","initializeCell","mouseup","tableRowDrop","previousSibling","rowHandle","nextRowHeight","prevRowHeight","nextRowHeightLast","prevRowHeightLast","startYMove","setStartPosition","connectToTables","pointerEvents","disconnectFromTables","moveHoverConnections","moveHoverTable","rowHolder","yPos","elementRowDrop","connectionTables","query","prototype","querySelectorAll","dropEvent","tabulatorElementDropEvent","connect","disconnect","dropComplete","sender","movableRowsSender","senders","movableRowsReceiver","receivers","fromRow","fromTable","toTable","Mutator","enabled","transformCell","mutateLink","lookupMutator","mutators","mutatorEdit","links","linkCell","pageSize","currentRow","currentPage","totalRows","totalPages","showingEl","valueEl","ofEl","totalEl","rowsEl","pages","Page","progressiveLoad","pageCounterElement","pageCounter","page","remoteRowCountEstimate","initialLoad","dataChanging","pageSizes","setMaxPage","setPage","userSetPageToRow","userSetPageSize","getPageSize","previousPage","nextPage","getPage","getPageMax","setPageToRow","initialLoadComplete","calculatePageSizes","footerRedraw","paginationAddRow","rowAddingPosition","paginationMode","remotePageParams","_parseRemoteData","restOnRenderBefore","initializePageCounter","initializePaginator","initializeProgressive","scrollVertical","testElRow","testElCell","paginationSize","visibility","generatePageSizeSelectList","setPageSize","dir","loading","progressiveLoadScrollMargin","pagesElement","firstBut","prevBut","nextBut","lastBut","paginationSizeSelector","pageSizeSelect","counter","paginationCounter","pageCounters","hidden","pageSelectLabel","paginationCounterHolder","paginationElement","paginationCounterElement","paginationInitialPage","paginationButtonCount","setMaxRows","trigger","_setPageCounter","_setPageButtons","leftSize","rightSize","_generatePageButton","start","end","actualStartRow","actualRowPageSize","actualRows","finally","last_page","last_row","addRows","progressiveLoadDelay","footer","containerElement","scrollWidth","defaultPageCounters","local","id","localStorage","getItem","cookie","cookiePos","setItem","expireDate","setDate","getDate","toUTCString","Persistence","defWatcherBlock","readFunc","writeFunc","localStorageTest","testKey","removeItem","persistence","retrievedData","persistenceMode","persistenceID","persistenceReaderFunc","readers","persistenceWriterFunc","writers","retrieveData","save","eventSave","getColumnLayout","setColumnLayout","sorters","initialSort","parseColumns","setColumns","mergeDefinition","getOwnPropertyDescriptor","defineProperty","set","current","oldCols","newCols","_findColumn","validateSorters","getSort","getGroupConfig","getPageConfig","definitions","excludedKeys","defStore","colDef","moduleInitOrder","defaultReaders","defaultWriters","_componentPopupCall","loadPopupEvent","rowContextPopup","rowClickPopup","rowDblClickPopup","groupContextPopup","groupClickPopup","groupDblClickPopup","headerContextPopup","loadPopupTableColumnEvent","headerClickPopup","headerDblClickPopup","headerPopup","initializeColumnHeaderPopup","contextPopup","loadPopupTableCellEvent","clickPopup","dblClickPopup","headerPopupEl","headerPopupIcon","loadPopup","contentsEl","Print","manualBlock","beforeprintEventHandler","afterprintEventHandler","printAsHtml","replaceTable","cleanup","destroy","printFullscreen","printConfig","printStyled","printRowRange","footerContent","scrollX","scrollY","footerEl","tableEl","printHeader","printFooter","printFormatter","ReactiveData","origFuncs","currentVersion","reactiveData","unblock","watchRow","watchData","unwatchData","version","enumerable","configurable","arg","apply","getRowFromDataObject","pop","startRow","newRows","reverse","oldRows","writable","watchKey","watchTreeChildren","childField","rebuildTree","unwatchRow","ResizeColumns","startColumn","startWidth","latestX","initialNextColumn","layoutColumnHeader","initializeEventWatchers","layoutCellHandles","deInitializeComponent","resizeHandle","columnLayoutUpdated","deInitializeColumn","columnWidthUpdated","resizable","reinitializeColumn","frozenColumnOffset","frozenOffset","handleEl","nearestColumn","_checkResizability","handleDown","_mouseDown","oldWidth","parentElement","mouseMove","blockedBefore","blockedAfter","startDiff","moveDiff","resizableColumnFit","colWidth","browserSlow","mouseUp","ResizeRows","startHeight","prevHandle","prevHandleDown","screenY","ResizeTable","visibilityObserver","resizeObserver","containerObserver","tableHeight","tableWidth","containerHeight","containerWidth","autoResize","initialRedraw","tableStyle","IntersectionObserver","ResizeObserver","initializeVisibilityObserver","entry","browserMobile","nodeHeight","contentRect","nodeWidth","redrawTable","observe","fixedHeight","tableResized","isIntersecting","unobserve","ResponsiveLayout","hiddenColumns","collapseFormatter","collapseStartOpen","collapseHandleColumn","updateColumnVisibility","initializeResponsivity","generateCollapsedRowContent","responsiveLayoutCollapseFormatter","formatCollapsedData","responsiveLayoutCollapseStartOpen","responsive","order","generateCollapsedContent","hideColumn","colCount","showColumn","working","getFlexBaseWidth","headerVisible","activeRowsCount","renderEmptyScroll","generateCollapsedRowData","mockCellComponent","responsiveLayoutCollapseUseFormatters","node_content","titleData","valueData","titleHighlight","SelectRow","selecting","lastClickedRow","selectPrev","headerCheckboxElement","selectRows","deselectRows","getSelectedRows","getSelectedData","isRowSelected","selectable","clearSelectionData","rowRetrieve","selectablePersistence","_deselectRow","prevSelected","_rowSelectionChanged","endSelect","checkRowSelectability","_clearSelection","lastClickedRowIdx","getDisplayRowIndex","rowIdx","fromRowIdx","toRowIdx","toggledRows","toggledRow","selectableCheck","_selectRow","rowMatch","change","changes","rowInfo","selectableRollingSelection","checkboxEl","dataTreeSelectPropagate","childRowSelection","selectedRow","deselected","aRow","bRow","alignEmptyValues","decimalSeparator","thousandSeparator","string","locale","localeCompare","boolean","calc","d","alphanum","Sort","sortList","userSetSort","clearSort","sortMode","remoteSortParams","setSort","refreshSort","arrowEl","sorterParams","startingDir","headerSortStartingDir","headerSortTristate","headerSort","headerSortClickElement","headerSortElement","setColumnHeaderSortIcon","columnHeaderSortMulti","newSortList","findSorter","sortOrderReverse","sortListActual","rowComponents","clearColumnHeaders","sortObj","setColumnHeader","_sortItems","sortEl","sorterCount","sortItem","_sortRow","el1Comp","el2Comp","el1","el2","defaultSorters","Tooltip","tooltipSubscriber","headerSubscriber","timeout","popupInstance","headerTooltip","mousemoveCheck","mouseoutCheck","tooltip","clearPopup","loadTooltip","tooltipDelay","parameters","float","numeric","minLength","maxLength","cellData","required","Validate","invalidCells","getInvalidCells","userClearCellValidation","userValidate","cellIsValid","clearValidation","cellValidate","columnValidate","rowValidate","editValidate","editorClear","editedClear","previousValue","validate","cancelled","validator","_extractValidator","substring","_buildValidator","validators","failedValidators","invalidIndex","defaultValidators","OptionsList","msgType","userOptions","debugInvalidOptions","hasOwnProperty","Renderer","elementVertical","elementHorizontal","verticalFillMode","clearRows","clearColumns","reinitializeColumnWidths","renderRows","renderColumns","rerenderRows","scrollColumns","scrollRows","scrollToRowNearestTop","includingBuffer","render","rerender","scrollToRowPosition","rowIndex","scrollToRowIfVisible","BasicHorizontal","rowFrag","createDocumentFragment","VirtualDomHorizontal","leftCol","rightCol","vDomScrollPosLeft","vDomScrollPosRight","vDomPadRight","fitDataColAvg","windowBuffer","isFitData","compatibilityCheck","layoutCheck","vertScrollListen","clearVisRowCache","dataChange","scroll","calcWindowBuffer","buffer","cols","colPos","leftPos","rightPos","fitDataCheck","vdomHoz","reinitChanged","reinitializeRow","colEnd","otherRows","addColRight","removeColLeft","addColLeft","removeColRight","colPositionAdjust","fitDataColActualWidthCheck","ex","message","newWidth","widthDiff","appendCell","ColumnManager","blockHozScrollEvent","columnsByField","defaultColumnOptions","redrawBlockUpdate","initializeRenderer","createHeadersElement","createHeaderContentsElement","createHeaderElement","initializeScrollWheelWatcher","padVerticalScrollbar","renderClass","renderers","virtual","RendererVirtualDomHorizontal","basic","RendererBasicHorizontal","deltaX","generateColumnsFromRowData","autoColumnsDefinitions","_addColumn","_reIndexColumns","nextToColumn","topColumn","parentIndex","nextEl","root","getDefinitions","getDefinitionTree","getComponents","structured","_moveColumnInArray","updateRows","fromIndex","scrollToColumnPosition","scrollToColumnIfVisible","totalWidth","fixedWidth","resetScroll","BasicVertical","tableFrag","rowTop","VirtualDomVertical","vDomRowHeight","vDomTop","vDomBottom","vDomScrollPosTop","vDomScrollPosBottom","vDomTopPad","vDomBottomPad","vDomMaxRenderChain","vDomWindowBuffer","vDomWindowMinTotalRows","vDomWindowMinMarginRows","vDomTopNewRows","vDomBottomNewRows","paddingBottom","_virtualRenderFill","topOffset","tableEmpty","topDiff","bottomDiff","_addTopRow","vDomScrollHeight","_removeBottomRow","_addBottomRow","_removeTopRow","renderVerticalBuffer","topFound","bottomRow","forceMove","rowFragment","topPad","rowsHeight","heightOccupied","topPadHeight","rowsCount","renderedRows","totalRowsRendered","rowsToRender","avgRowHeight","resized","fillableSpace","addedRows","paddingAdjust","_quickNormalizeRowHeight","removableRows","RowManager","createHolderElement","createTableElement","heightFixer","placeholderContents","firstRender","renderMode","activeRowsPipeline","redrawBlockRestoreConfig","redrawBlockRenderInPosition","dataPipeline","scrollbarWidth","initializePlaceholder","leftDir","topDir","_positionPlaceholder","_setDataActual","_wipeElements","allIndex","activeIndex","setActiveRows","displayRowIterator","displayIndex","refreshDisplayOnly","findAddRowPos","_clearPlaceholder","addRowPos","chainResult","clearData","findRowIndex","rowOnly","getDataCount","skipStage","stage","cascadeOrder","refreshPipelines","renderTable","layoutColumnsOnNewData","resetDisplayRows","setDisplayRows","scrollBarCheck","RendererVirtualDomVertical","RendererBasicVertical","renderVertical","_clearTable","_showPlaceholder","initialHeight","otherHeight","external","event","createEvent","initEvent","Event","FooterManager","createContainerElement","initializeElement","footerElement","activate","deactivate","InteractionManager","abortClasses","previousTargets","listeners","componentMap","pseudoTrackers","subscriber","pseudoTracking","buildListenerMap","bindSubscriptionWatchers","listenerMap","listener","components","bindPseudoEvents","pseudoMouseEnter","pseudoMouseLeave","leaveList","linkedKeys","comp","clearWatchers","updateEventListeners","track","composedPath","targets","findTargets","bindComponents","triggerEvents","elTargets","targetMatches","previousTarget","closest","ComponentFunctionBinder","funcName","debugInvalidComponentFuncs","DataLoader","requestOrder","requestNo","alertLoader","mapParams","dataSendParams","objectInvert","dataReceiveParams","alertError","dataLoaderErrorTimeout","blockActiveLoad","dataLoaderLoading","dataLoaderError","ExternalEventBus","debug","events","subscriptionNotifiers","_debugDispatch","_dispatch","_notifySubscriptionChange","notifiers","callResult","log","InternalEventBus","_debugChain","_chain","_debugConfirm","_confirm","fallback","confirmed","DeprecationAdvisor","_warnUser","TableRegistry","tables","matchElement","Tabulator","lookupTable","forced","fitData","fitDataFill","fitDataGeneral","fitDataTable","fitDataStretch","colsWidth","gap","lastCol","fitColumns","flexColWidth","overflowWidth","flexWidth","flexGrowUnits","flexColumns","fixedShrinkColumns","flexShrinkUnits","gapFill","calcWidth","scaleColumns","freeSpace","shrinkCols","oversizeCols","oversizeSpace","remainingSpace","remainingFlexGrowUnits","changeUnits","undersizeCols","calcGrow","widthGrow","calcShrink","widthShrink","Layout","modes","dataChanged","defaultModes","Localize","langList","langs","setHeaderFilterPlaceholder","installLang","setLocale","getLang","default","_setLangProp","desiredLocale","language","traverseLang","trans","_executeBindings","pathArray","_getLangElement","rootPath","page_size","page_title","first","first_title","last","last_title","prev_title","next","next_title","showing","of","Comms","receive","selectors","con","tableComms","ModuleBinder","tabulator","bindStaticFunctionality","bindModules","coreModules","moduleBindings","extendModule","property","source","registerModule","mod","registerModuleBinding","findTable","orderedStartMods","orderedEndMods","unOrderedMods","moduleCore","modulesCore","modulesRegular","core","mods","Alert","_createAlertElement","msgElement","_createMsgElement","_typeClass","interactionMonitor","initializeCoreSystems","_create","_clearObjectPointers","_mapDeprecatedFunctionality","debugEventsExternal","debugEventsInternal","InteractionMonitor","_rtlCheck","_buildElement","_initializeTable","_loadInitialData","textDirection","direction","newElement","_detectBrowser","deregister","ua","userAgent","vendor","opera","stack","line","debugInitialization","Error","replaceData","responses","foundRows","updateOrAddRow","updateRow","getRowPosition","getColumnDefinitions","toggleColumn","deleteColumn","updateColumnDefinition","fromColumn","off","plugin","debugDeprecation","rowFormatterPrint","rowFormatterClipboard","rowFormatterHtmlOutput","TabulatorFull","PseudoRow","_createElement"],"mappings":"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"} \ No newline at end of file diff --git a/cp/public/assets/libs/apexcharts/dist/apexcharts.amd.js b/cp/public/assets/libs/apexcharts/dist/apexcharts.amd.js deleted file mode 100644 index e1bb040..0000000 --- a/cp/public/assets/libs/apexcharts/dist/apexcharts.amd.js +++ /dev/null @@ -1,2 +0,0 @@ -/*! For license information please see apexcharts.amd.js.LICENSE.txt */ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.ApexCharts=e():t.ApexCharts=e()}(self,(()=>(()=>{var t={922:t=>{"use strict";t.exports=function(t){var e=[];return e.toString=function(){return this.map((function(e){var i=function(t,e){var i,a,r,s=t[1]||"",n=t[3];if(!n)return s;if(e&&"function"==typeof btoa){var o=(i=n,a=btoa(unescape(encodeURIComponent(JSON.stringify(i)))),r="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(a),"/*# ".concat(r," */")),l=n.sources.map((function(t){return"/*# sourceURL=".concat(n.sourceRoot||"").concat(t," */")}));return[s].concat(l).concat([o]).join("\n")}return[s].join("\n")}(e,t);return e[2]?"@media ".concat(e[2]," {").concat(i,"}"):i})).join("")},e.i=function(t,i){"string"==typeof t&&(t=[[null,t,""]]);for(var a=0;an.maxX-i.width&&(o=(r=n.maxX-i.width)-this.startPoints.box.x),null!=n.minY&&sn.maxY-i.height&&(l=(s=n.maxY-i.height)-this.startPoints.box.y),null!=n.snapToGrid&&(r-=r%n.snapToGrid,s-=s%n.snapToGrid,o-=o%n.snapToGrid,l-=l%n.snapToGrid),this.el instanceof SVG.G?this.el.matrix(this.startPoints.transform).transform({x:o,y:l},!0):this.el.move(r,s));return a},e.prototype.end=function(t){var e=this.drag(t);this.el.fire("dragend",{event:t,p:e,m:this.m,handler:this}),SVG.off(window,"mousemove.drag"),SVG.off(window,"touchmove.drag"),SVG.off(window,"mouseup.drag"),SVG.off(window,"touchend.drag")},SVG.extend(SVG.Element,{draggable:function(i,a){"function"!=typeof i&&"object"!=t(i)||(a=i,i=!0);var r=this.remember("_draggable")||new e(this);return(i=void 0===i||i)?r.init(a||{},i):(this.off("mousedown.drag"),this.off("touchstart.drag")),this}})}).call(this)},872:function(){(function(){SVG.Filter=SVG.invent({create:"filter",inherit:SVG.Parent,extend:{source:"SourceGraphic",sourceAlpha:"SourceAlpha",background:"BackgroundImage",backgroundAlpha:"BackgroundAlpha",fill:"FillPaint",stroke:"StrokePaint",autoSetIn:!0,put:function(t,e){return this.add(t,e),!t.attr("in")&&this.autoSetIn&&t.attr("in",this.source),t.attr("result")||t.attr("result",t),t},blend:function(t,e,i){return this.put(new SVG.BlendEffect(t,e,i))},colorMatrix:function(t,e){return this.put(new SVG.ColorMatrixEffect(t,e))},convolveMatrix:function(t){return this.put(new SVG.ConvolveMatrixEffect(t))},componentTransfer:function(t){return this.put(new SVG.ComponentTransferEffect(t))},composite:function(t,e,i){return this.put(new SVG.CompositeEffect(t,e,i))},flood:function(t,e){return this.put(new SVG.FloodEffect(t,e))},offset:function(t,e){return this.put(new SVG.OffsetEffect(t,e))},image:function(t){return this.put(new SVG.ImageEffect(t))},merge:function(){var t=[void 0];for(var e in arguments)t.push(arguments[e]);return this.put(new(SVG.MergeEffect.bind.apply(SVG.MergeEffect,t)))},gaussianBlur:function(t,e){return this.put(new SVG.GaussianBlurEffect(t,e))},morphology:function(t,e){return this.put(new SVG.MorphologyEffect(t,e))},diffuseLighting:function(t,e,i){return this.put(new SVG.DiffuseLightingEffect(t,e,i))},displacementMap:function(t,e,i,a,r){return this.put(new SVG.DisplacementMapEffect(t,e,i,a,r))},specularLighting:function(t,e,i,a){return this.put(new SVG.SpecularLightingEffect(t,e,i,a))},tile:function(){return this.put(new SVG.TileEffect)},turbulence:function(t,e,i,a,r){return this.put(new SVG.TurbulenceEffect(t,e,i,a,r))},toString:function(){return"url(#"+this.attr("id")+")"}}}),SVG.extend(SVG.Defs,{filter:function(t){var e=this.put(new SVG.Filter);return"function"==typeof t&&t.call(e,e),e}}),SVG.extend(SVG.Container,{filter:function(t){return this.defs().filter(t)}}),SVG.extend(SVG.Element,SVG.G,SVG.Nested,{filter:function(t){return this.filterer=t instanceof SVG.Element?t:this.doc().filter(t),this.doc()&&this.filterer.doc()!==this.doc()&&this.doc().defs().add(this.filterer),this.attr("filter",this.filterer),this.filterer},unfilter:function(t){return this.filterer&&!0===t&&this.filterer.remove(),delete this.filterer,this.attr("filter",null)}}),SVG.Effect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}}),SVG.ParentEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Parent,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}});var t={blend:function(t,e){return this.parent()&&this.parent().blend(this,t,e)},colorMatrix:function(t,e){return this.parent()&&this.parent().colorMatrix(t,e).in(this)},convolveMatrix:function(t){return this.parent()&&this.parent().convolveMatrix(t).in(this)},componentTransfer:function(t){return this.parent()&&this.parent().componentTransfer(t).in(this)},composite:function(t,e){return this.parent()&&this.parent().composite(this,t,e)},flood:function(t,e){return this.parent()&&this.parent().flood(t,e)},offset:function(t,e){return this.parent()&&this.parent().offset(t,e).in(this)},image:function(t){return this.parent()&&this.parent().image(t)},merge:function(){return this.parent()&&this.parent().merge.apply(this.parent(),[this].concat(arguments))},gaussianBlur:function(t,e){return this.parent()&&this.parent().gaussianBlur(t,e).in(this)},morphology:function(t,e){return this.parent()&&this.parent().morphology(t,e).in(this)},diffuseLighting:function(t,e,i){return this.parent()&&this.parent().diffuseLighting(t,e,i).in(this)},displacementMap:function(t,e,i,a){return this.parent()&&this.parent().displacementMap(this,t,e,i,a)},specularLighting:function(t,e,i,a){return this.parent()&&this.parent().specularLighting(t,e,i,a).in(this)},tile:function(){return this.parent()&&this.parent().tile().in(this)},turbulence:function(t,e,i,a,r){return this.parent()&&this.parent().turbulence(t,e,i,a,r).in(this)}};SVG.extend(SVG.Effect,t),SVG.extend(SVG.ParentEffect,t),SVG.ChildEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){this.attr("in",t)}}});var e={blend:function(t,e,i){this.attr({in:t,in2:e,mode:i||"normal"})},colorMatrix:function(t,e){"matrix"==t&&(e=r(e)),this.attr({type:t,values:void 0===e?null:e})},convolveMatrix:function(t){t=r(t),this.attr({order:Math.sqrt(t.split(" ").length),kernelMatrix:t})},composite:function(t,e,i){this.attr({in:t,in2:e,operator:i})},flood:function(t,e){this.attr("flood-color",t),null!=e&&this.attr("flood-opacity",e)},offset:function(t,e){this.attr({dx:t,dy:e})},image:function(t){this.attr("href",t,SVG.xlink)},displacementMap:function(t,e,i,a,r){this.attr({in:t,in2:e,scale:i,xChannelSelector:a,yChannelSelector:r})},gaussianBlur:function(t,e){null!=t||null!=e?this.attr("stdDeviation",function(t){if(!Array.isArray(t))return t;for(var e=0,i=t.length,a=[];e{!function(){"use strict";function t(t,r,s,n,o,l,c){for(var h=t.slice(r,s||c),d=n.slice(o,l||c),u=0,g={pos:[0,0],start:[0,0]},f={pos:[0,0],start:[0,0]};h[u]=e.call(g,h[u]),d[u]=e.call(f,d[u]),h[u][0]!=d[u][0]||"M"==h[u][0]||"A"==h[u][0]&&(h[u][4]!=d[u][4]||h[u][5]!=d[u][5])?(Array.prototype.splice.apply(h,[u,1].concat(a.call(g,h[u]))),Array.prototype.splice.apply(d,[u,1].concat(a.call(f,d[u])))):(h[u]=i.call(g,h[u]),d[u]=i.call(f,d[u])),++u!=h.length||u!=d.length;)u==h.length&&h.push(["C",g.pos[0],g.pos[1],g.pos[0],g.pos[1],g.pos[0],g.pos[1]]),u==d.length&&d.push(["C",f.pos[0],f.pos[1],f.pos[0],f.pos[1],f.pos[0],f.pos[1]]);return{start:h,dest:d}}function e(t){switch(t[0]){case"z":case"Z":t[0]="L",t[1]=this.start[0],t[2]=this.start[1];break;case"H":t[0]="L",t[2]=this.pos[1];break;case"V":t[0]="L",t[2]=t[1],t[1]=this.pos[0];break;case"T":t[0]="Q",t[3]=t[1],t[4]=t[2],t[1]=this.reflection[1],t[2]=this.reflection[0];break;case"S":t[0]="C",t[6]=t[4],t[5]=t[3],t[4]=t[2],t[3]=t[1],t[2]=this.reflection[1],t[1]=this.reflection[0]}return t}function i(t){var e=t.length;return this.pos=[t[e-2],t[e-1]],-1!="SCQT".indexOf(t[0])&&(this.reflection=[2*this.pos[0]-t[e-4],2*this.pos[1]-t[e-3]]),t}function a(t){var e=[t];switch(t[0]){case"M":return this.pos=this.start=[t[1],t[2]],e;case"L":t[5]=t[3]=t[1],t[6]=t[4]=t[2],t[1]=this.pos[0],t[2]=this.pos[1];break;case"Q":t[6]=t[4],t[5]=t[3],t[4]=1*t[4]/3+2*t[2]/3,t[3]=1*t[3]/3+2*t[1]/3,t[2]=1*this.pos[1]/3+2*t[2]/3,t[1]=1*this.pos[0]/3+2*t[1]/3;break;case"A":e=function(t,e){var i,a,r,s,n,o,l,c,h,d,u,g,f,p,x,b,v,m,y,w,k,A,S,C,P,L,O=Math.abs(e[1]),T=Math.abs(e[2]),I=e[3]%360,E=e[4],M=e[5],X=e[6],z=e[7],Y=new SVG.Point(t),D=new SVG.Point(X,z),R=[];if(0===O||0===T||Y.x===D.x&&Y.y===D.y)return[["C",Y.x,Y.y,D.x,D.y,D.x,D.y]];for((a=(i=new SVG.Point((Y.x-D.x)/2,(Y.y-D.y)/2).transform((new SVG.Matrix).rotate(I))).x*i.x/(O*O)+i.y*i.y/(T*T))>1&&(O*=a=Math.sqrt(a),T*=a),r=(new SVG.Matrix).rotate(I).scale(1/O,1/T).rotate(-I),Y=Y.transform(r),o=(s=[(D=D.transform(r)).x-Y.x,D.y-Y.y])[0]*s[0]+s[1]*s[1],n=Math.sqrt(o),s[0]/=n,s[1]/=n,l=o<4?Math.sqrt(1-o/4):0,E===M&&(l*=-1),c=new SVG.Point((D.x+Y.x)/2+l*-s[1],(D.y+Y.y)/2+l*s[0]),h=new SVG.Point(Y.x-c.x,Y.y-c.y),d=new SVG.Point(D.x-c.x,D.y-c.y),u=Math.acos(h.x/Math.sqrt(h.x*h.x+h.y*h.y)),h.y<0&&(u*=-1),g=Math.acos(d.x/Math.sqrt(d.x*d.x+d.y*d.y)),d.y<0&&(g*=-1),M&&u>g&&(g+=2*Math.PI),!M&&u{!function(){"use strict";(function(){function t(t){t.remember("_resizeHandler",this),this.el=t,this.parameters={},this.lastUpdateCall=null,this.p=t.doc().node.createSVGPoint()}t.prototype.transformPoint=function(t,e,i){return this.p.x=t-(this.offset.x-window.pageXOffset),this.p.y=e-(this.offset.y-window.pageYOffset),this.p.matrixTransform(i||this.m)},t.prototype._extractPosition=function(t){return{x:null!=t.clientX?t.clientX:t.touches[0].clientX,y:null!=t.clientY?t.clientY:t.touches[0].clientY}},t.prototype.init=function(t){var e=this;if(this.stop(),"stop"!==t){for(var i in this.options={},this.el.resize.defaults)this.options[i]=this.el.resize.defaults[i],void 0!==t[i]&&(this.options[i]=t[i]);this.el.on("lt.resize",(function(t){e.resize(t||window.event)})),this.el.on("rt.resize",(function(t){e.resize(t||window.event)})),this.el.on("rb.resize",(function(t){e.resize(t||window.event)})),this.el.on("lb.resize",(function(t){e.resize(t||window.event)})),this.el.on("t.resize",(function(t){e.resize(t||window.event)})),this.el.on("r.resize",(function(t){e.resize(t||window.event)})),this.el.on("b.resize",(function(t){e.resize(t||window.event)})),this.el.on("l.resize",(function(t){e.resize(t||window.event)})),this.el.on("rot.resize",(function(t){e.resize(t||window.event)})),this.el.on("point.resize",(function(t){e.resize(t||window.event)})),this.update()}},t.prototype.stop=function(){return this.el.off("lt.resize"),this.el.off("rt.resize"),this.el.off("rb.resize"),this.el.off("lb.resize"),this.el.off("t.resize"),this.el.off("r.resize"),this.el.off("b.resize"),this.el.off("l.resize"),this.el.off("rot.resize"),this.el.off("point.resize"),this},t.prototype.resize=function(t){var e=this;this.m=this.el.node.getScreenCTM().inverse(),this.offset={x:window.pageXOffset,y:window.pageYOffset};var i=this._extractPosition(t.detail.event);if(this.parameters={type:this.el.type,p:this.transformPoint(i.x,i.y),x:t.detail.x,y:t.detail.y,box:this.el.bbox(),rotation:this.el.transform().rotation},"text"===this.el.type&&(this.parameters.fontSize=this.el.attr()["font-size"]),void 0!==t.detail.i){var a=this.el.array().valueOf();this.parameters.i=t.detail.i,this.parameters.pointCoords=[a[t.detail.i][0],a[t.detail.i][1]]}switch(t.type){case"lt":this.calc=function(t,e){var i=this.snapToGrid(t,e);if(this.parameters.box.width-i[0]>0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y+i[1]).size(this.parameters.box.width-i[0],this.parameters.box.height-i[1])}};break;case"rt":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).size(this.parameters.box.width+i[0],this.parameters.box.height-i[1])}};break;case"rb":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x,this.parameters.box.y).size(this.parameters.box.width+i[0],this.parameters.box.height+i[1])}};break;case"lb":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).size(this.parameters.box.width-i[0],this.parameters.box.height+i[1])}};break;case"t":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).height(this.parameters.box.height-i[1])}};break;case"r":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).width(this.parameters.box.width+i[0])}};break;case"b":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).height(this.parameters.box.height+i[1])}};break;case"l":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).width(this.parameters.box.width-i[0])}};break;case"rot":this.calc=function(t,e){var i=t+this.parameters.p.x,a=e+this.parameters.p.y,r=Math.atan2(this.parameters.p.y-this.parameters.box.y-this.parameters.box.height/2,this.parameters.p.x-this.parameters.box.x-this.parameters.box.width/2),s=Math.atan2(a-this.parameters.box.y-this.parameters.box.height/2,i-this.parameters.box.x-this.parameters.box.width/2),n=this.parameters.rotation+180*(s-r)/Math.PI+this.options.snapToAngle/2;this.el.center(this.parameters.box.cx,this.parameters.box.cy).rotate(n-n%this.options.snapToAngle,this.parameters.box.cx,this.parameters.box.cy)};break;case"point":this.calc=function(t,e){var i=this.snapToGrid(t,e,this.parameters.pointCoords[0],this.parameters.pointCoords[1]),a=this.el.array().valueOf();a[this.parameters.i][0]=this.parameters.pointCoords[0]+i[0],a[this.parameters.i][1]=this.parameters.pointCoords[1]+i[1],this.el.plot(a)}}this.el.fire("resizestart",{dx:this.parameters.x,dy:this.parameters.y,event:t}),SVG.on(window,"touchmove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"touchend.resize",(function(){e.done()})),SVG.on(window,"mousemove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"mouseup.resize",(function(){e.done()}))},t.prototype.update=function(t){if(t){var e=this._extractPosition(t),i=this.transformPoint(e.x,e.y),a=i.x-this.parameters.p.x,r=i.y-this.parameters.p.y;this.lastUpdateCall=[a,r],this.calc(a,r),this.el.fire("resizing",{dx:a,dy:r,event:t})}else this.lastUpdateCall&&this.calc(this.lastUpdateCall[0],this.lastUpdateCall[1])},t.prototype.done=function(){this.lastUpdateCall=null,SVG.off(window,"mousemove.resize"),SVG.off(window,"mouseup.resize"),SVG.off(window,"touchmove.resize"),SVG.off(window,"touchend.resize"),this.el.fire("resizedone")},t.prototype.snapToGrid=function(t,e,i,a){var r;return void 0!==a?r=[(i+t)%this.options.snapToGrid,(a+e)%this.options.snapToGrid]:(i=null==i?3:i,r=[(this.parameters.box.x+t+(1&i?0:this.parameters.box.width))%this.options.snapToGrid,(this.parameters.box.y+e+(2&i?0:this.parameters.box.height))%this.options.snapToGrid]),t<0&&(r[0]-=this.options.snapToGrid),e<0&&(r[1]-=this.options.snapToGrid),t-=Math.abs(r[0])n.maxX&&(t=n.maxX-r),void 0!==n.minY&&s+en.maxY&&(e=n.maxY-s),[t,e]},t.prototype.checkAspectRatio=function(t,e){if(!this.options.saveAspectRatio)return t;var i=t.slice(),a=this.parameters.box.width/this.parameters.box.height,r=this.parameters.box.width+t[0],s=this.parameters.box.height-t[1],n=r/s;return na&&(i[0]=this.parameters.box.width-s*a,e&&(i[0]=-i[0])),i},SVG.extend(SVG.Element,{resize:function(e){return(this.remember("_resizeHandler")||new t(this)).init(e||{}),this}}),SVG.Element.prototype.resize.defaults={snapToAngle:.1,snapToGrid:1,constraint:{},saveAspectRatio:!1}}).call(this)}()},769:()=>{function t(e){return t="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},t(e)}!function(){"use strict";function e(t){this.el=t,t.remember("_selectHandler",this),this.pointSelection={isSelected:!1},this.rectSelection={isSelected:!1},this.pointsList={lt:[0,0],rt:["width",0],rb:["width","height"],lb:[0,"height"],t:["width",0],r:["width","height"],b:["width","height"],l:[0,"height"]},this.pointCoord=function(t,e,i){var a="string"!=typeof t?t:e[t];return i?a/2:a},this.pointCoords=function(t,e){var i=this.pointsList[t];return{x:this.pointCoord(i[0],e,"t"===t||"b"===t),y:this.pointCoord(i[1],e,"r"===t||"l"===t)}}}e.prototype.init=function(t,e){var i=this.el.bbox();this.options={};var a=this.el.selectize.defaults.points;for(var r in this.el.selectize.defaults)this.options[r]=this.el.selectize.defaults[r],void 0!==e[r]&&(this.options[r]=e[r]);var s=["points","pointsExclude"];for(var r in s){var n=this.options[s[r]];"string"==typeof n?n=n.length>0?n.split(/\s*,\s*/i):[]:"boolean"==typeof n&&"points"===s[r]&&(n=n?a:[]),this.options[s[r]]=n}this.options.points=[a,this.options.points].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)>-1}))})),this.options.points=[this.options.points,this.options.pointsExclude].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)<0}))})),this.parent=this.el.parent(),this.nested=this.nested||this.parent.group(),this.nested.matrix(new SVG.Matrix(this.el).translate(i.x,i.y)),this.options.deepSelect&&-1!==["line","polyline","polygon"].indexOf(this.el.type)?this.selectPoints(t):this.selectRect(t),this.observe(),this.cleanup()},e.prototype.selectPoints=function(t){return this.pointSelection.isSelected=t,this.pointSelection.set||(this.pointSelection.set=this.parent.set(),this.drawPoints()),this},e.prototype.getPointArray=function(){var t=this.el.bbox();return this.el.array().valueOf().map((function(e){return[e[0]-t.x,e[1]-t.y]}))},e.prototype.drawPoints=function(){for(var t=this,e=this.getPointArray(),i=0,a=e.length;i{window.TreemapSquared={},function(){"use strict";window.TreemapSquared.generate=function(){function t(e,i,a,r){this.xoffset=e,this.yoffset=i,this.height=r,this.width=a,this.shortestEdge=function(){return Math.min(this.height,this.width)},this.getCoordinates=function(t){var e,i=[],a=this.xoffset,r=this.yoffset,n=s(t)/this.height,o=s(t)/this.width;if(this.width>=this.height)for(e=0;e=this.height){var a=e/this.height,r=this.width-a;i=new t(this.xoffset+a,this.yoffset,r,this.height)}else{var s=e/this.width,n=this.height-s;i=new t(this.xoffset,this.yoffset+s,this.width,n)}return i}}function e(e,a,r,n,o){n=void 0===n?0:n,o=void 0===o?0:o;var l=i(function(t,e){var i,a=[],r=e/s(t);for(i=0;i=a(r,i))}(e,l=t[0],o)?(e.push(l),i(t.slice(1),e,r,n)):(c=r.cutArea(s(e),n),n.push(r.getCoordinates(e)),i(t,[],c,n)),n;n.push(r.getCoordinates(e))}function a(t,e){var i=Math.min.apply(Math,t),a=Math.max.apply(Math,t),r=s(t);return Math.max(Math.pow(e,2)*a/Math.pow(r,2),Math.pow(r,2)/(Math.pow(e,2)*i))}function r(t){return t&&t.constructor===Array}function s(t){var e,i=0;for(e=0;e=0;a--)if(t[a])for(var r in e)t[a].prototype[r]=e[r];i.Set&&i.Set.inherit&&i.Set.inherit()},i.invent=function(t){var e="function"==typeof t.create?t.create:function(){this.constructor.call(this,i.create(t.create))};return t.inherit&&(e.prototype=new t.inherit),t.extend&&i.extend(e,t.extend),t.construct&&i.extend(t.parent||i.Container,t.construct),e},i.adopt=function(e){return e?e.instance?e.instance:((a="svg"==e.nodeName?e.parentNode instanceof t.SVGElement?new i.Nested:new i.Doc:"linearGradient"==e.nodeName?new i.Gradient("linear"):"radialGradient"==e.nodeName?new i.Gradient("radial"):i[d(e.nodeName)]?new(i[d(e.nodeName)]):new i.Element(e)).type=e.nodeName,a.node=e,e.instance=a,a instanceof i.Doc&&a.namespace().defs(),a.setData(JSON.parse(e.getAttribute("svgjs:data"))||{}),a):null;var a},i.prepare=function(){var t=e.getElementsByTagName("body")[0],a=(t?new i.Doc(t):i.adopt(e.documentElement).nested()).size(2,0);i.parser={body:t||e.documentElement,draw:a.style("opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden").node,poly:a.polyline().node,path:a.path().node,native:i.create("svg")}},i.parser={native:i.create("svg")},e.addEventListener("DOMContentLoaded",(function(){i.parser.draw||i.prepare()}),!1),i.regex={numberAndUnit:/^([+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?)([a-z%]*)$/i,hex:/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i,rgb:/rgb\((\d+),(\d+),(\d+)\)/,reference:/#([a-z0-9\-_]+)/i,transforms:/\)\s*,?\s*/,whitespace:/\s/g,isHex:/^#[a-f0-9]{3,6}$/i,isRgb:/^rgb\(/,isCss:/[^:]+:[^;]+;?/,isBlank:/^(\s+)?$/,isNumber:/^[+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i,isPercent:/^-?[\d\.]+%$/,isImage:/\.(jpg|jpeg|png|gif|svg)(\?[^=]+.*)?/i,delimiter:/[\s,]+/,hyphen:/([^e])\-/gi,pathLetters:/[MLHVCSQTAZ]/gi,isPathLetter:/[MLHVCSQTAZ]/i,numbersWithDots:/((\d?\.\d+(?:e[+-]?\d+)?)((?:\.\d+(?:e[+-]?\d+)?)+))+/gi,dots:/\./g},i.utils={map:function(t,e){for(var i=t.length,a=[],r=0;r1?1:t,new i.Color({r:~~(this.r+(this.destination.r-this.r)*t),g:~~(this.g+(this.destination.g-this.g)*t),b:~~(this.b+(this.destination.b-this.b)*t)})):this}}),i.Color.test=function(t){return t+="",i.regex.isHex.test(t)||i.regex.isRgb.test(t)},i.Color.isRgb=function(t){return t&&"number"==typeof t.r&&"number"==typeof t.g&&"number"==typeof t.b},i.Color.isColor=function(t){return i.Color.isRgb(t)||i.Color.test(t)},i.Array=function(t,e){0==(t=(t||[]).valueOf()).length&&e&&(t=e.valueOf()),this.value=this.parse(t)},i.extend(i.Array,{toString:function(){return this.value.join(" ")},valueOf:function(){return this.value},parse:function(t){return t=t.valueOf(),Array.isArray(t)?t:this.split(t)}}),i.PointArray=function(t,e){i.Array.call(this,t,e||[[0,0]])},i.PointArray.prototype=new i.Array,i.PointArray.prototype.constructor=i.PointArray;for(var a={M:function(t,e,i){return e.x=i.x=t[0],e.y=i.y=t[1],["M",e.x,e.y]},L:function(t,e){return e.x=t[0],e.y=t[1],["L",t[0],t[1]]},H:function(t,e){return e.x=t[0],["H",t[0]]},V:function(t,e){return e.y=t[0],["V",t[0]]},C:function(t,e){return e.x=t[4],e.y=t[5],["C",t[0],t[1],t[2],t[3],t[4],t[5]]},Q:function(t,e){return e.x=t[2],e.y=t[3],["Q",t[0],t[1],t[2],t[3]]},Z:function(t,e,i){return e.x=i.x,e.y=i.y,["Z"]}},r="mlhvqtcsaz".split(""),n=0,o=r.length;nl);return s},bbox:function(){return i.parser.draw||i.prepare(),i.parser.path.setAttribute("d",this.toString()),i.parser.path.getBBox()}}),i.Number=i.invent({create:function(t,e){this.value=0,this.unit=e||"","number"==typeof t?this.value=isNaN(t)?0:isFinite(t)?t:t<0?-34e37:34e37:"string"==typeof t?(e=t.match(i.regex.numberAndUnit))&&(this.value=parseFloat(e[1]),"%"==e[5]?this.value/=100:"s"==e[5]&&(this.value*=1e3),this.unit=e[5]):t instanceof i.Number&&(this.value=t.valueOf(),this.unit=t.unit)},extend:{toString:function(){return("%"==this.unit?~~(1e8*this.value)/1e6:"s"==this.unit?this.value/1e3:this.value)+this.unit},toJSON:function(){return this.toString()},valueOf:function(){return this.value},plus:function(t){return t=new i.Number(t),new i.Number(this+t,this.unit||t.unit)},minus:function(t){return t=new i.Number(t),new i.Number(this-t,this.unit||t.unit)},times:function(t){return t=new i.Number(t),new i.Number(this*t,this.unit||t.unit)},divide:function(t){return t=new i.Number(t),new i.Number(this/t,this.unit||t.unit)},to:function(t){var e=new i.Number(this);return"string"==typeof t&&(e.unit=t),e},morph:function(t){return this.destination=new i.Number(t),t.relative&&(this.destination.value+=this.value),this},at:function(t){return this.destination?new i.Number(this.destination).minus(this).times(t).plus(this):this}}}),i.Element=i.invent({create:function(t){this._stroke=i.defaults.attrs.stroke,this._event=null,this.dom={},(this.node=t)&&(this.type=t.nodeName,this.node.instance=this,this._stroke=t.getAttribute("stroke")||this._stroke)},extend:{x:function(t){return this.attr("x",t)},y:function(t){return this.attr("y",t)},cx:function(t){return null==t?this.x()+this.width()/2:this.x(t-this.width()/2)},cy:function(t){return null==t?this.y()+this.height()/2:this.y(t-this.height()/2)},move:function(t,e){return this.x(t).y(e)},center:function(t,e){return this.cx(t).cy(e)},width:function(t){return this.attr("width",t)},height:function(t){return this.attr("height",t)},size:function(t,e){var a=g(this,t,e);return this.width(new i.Number(a.width)).height(new i.Number(a.height))},clone:function(t){this.writeDataToDom();var e=x(this.node.cloneNode(!0));return t?t.add(e):this.after(e),e},remove:function(){return this.parent()&&this.parent().removeElement(this),this},replace:function(t){return this.after(t).remove(),t},addTo:function(t){return t.put(this)},putIn:function(t){return t.add(this)},id:function(t){return this.attr("id",t)},show:function(){return this.style("display","")},hide:function(){return this.style("display","none")},visible:function(){return"none"!=this.style("display")},toString:function(){return this.attr("id")},classes:function(){var t=this.attr("class");return null==t?[]:t.trim().split(i.regex.delimiter)},hasClass:function(t){return-1!=this.classes().indexOf(t)},addClass:function(t){if(!this.hasClass(t)){var e=this.classes();e.push(t),this.attr("class",e.join(" "))}return this},removeClass:function(t){return this.hasClass(t)&&this.attr("class",this.classes().filter((function(e){return e!=t})).join(" ")),this},toggleClass:function(t){return this.hasClass(t)?this.removeClass(t):this.addClass(t)},reference:function(t){return i.get(this.attr(t))},parent:function(e){var a=this;if(!a.node.parentNode)return null;if(a=i.adopt(a.node.parentNode),!e)return a;for(;a&&a.node instanceof t.SVGElement;){if("string"==typeof e?a.matches(e):a instanceof e)return a;if(!a.node.parentNode||"#document"==a.node.parentNode.nodeName)return null;a=i.adopt(a.node.parentNode)}},doc:function(){return this instanceof i.Doc?this:this.parent(i.Doc)},parents:function(t){var e=[],i=this;do{if(!(i=i.parent(t))||!i.node)break;e.push(i)}while(i.parent);return e},matches:function(t){return function(t,e){return(t.matches||t.matchesSelector||t.msMatchesSelector||t.mozMatchesSelector||t.webkitMatchesSelector||t.oMatchesSelector).call(t,e)}(this.node,t)},native:function(){return this.node},svg:function(t){var a=e.createElement("svg");if(!(t&&this instanceof i.Parent))return a.appendChild(t=e.createElement("svg")),this.writeDataToDom(),t.appendChild(this.node.cloneNode(!0)),a.innerHTML.replace(/^/,"").replace(/<\/svg>$/,"");a.innerHTML=""+t.replace(/\n/,"").replace(/<([\w:-]+)([^<]+?)\/>/g,"<$1$2>")+"";for(var r=0,s=a.firstChild.childNodes.length;r":function(t){return-Math.cos(t*Math.PI)/2+.5},">":function(t){return Math.sin(t*Math.PI/2)},"<":function(t){return 1-Math.cos(t*Math.PI/2)}},i.morph=function(t){return function(e,a){return new i.MorphObj(e,a).at(t)}},i.Situation=i.invent({create:function(t){this.init=!1,this.reversed=!1,this.reversing=!1,this.duration=new i.Number(t.duration).valueOf(),this.delay=new i.Number(t.delay).valueOf(),this.start=+new Date+this.delay,this.finish=this.start+this.duration,this.ease=t.ease,this.loop=0,this.loops=!1,this.animations={},this.attrs={},this.styles={},this.transforms=[],this.once={}}}),i.FX=i.invent({create:function(t){this._target=t,this.situations=[],this.active=!1,this.situation=null,this.paused=!1,this.lastPos=0,this.pos=0,this.absPos=0,this._speed=1},extend:{animate:function(t,e,a){"object"===s(t)&&(e=t.ease,a=t.delay,t=t.duration);var r=new i.Situation({duration:t||1e3,delay:a||0,ease:i.easing[e||"-"]||e});return this.queue(r),this},target:function(t){return t&&t instanceof i.Element?(this._target=t,this):this._target},timeToAbsPos:function(t){return(t-this.situation.start)/(this.situation.duration/this._speed)},absPosToTime:function(t){return this.situation.duration/this._speed*t+this.situation.start},startAnimFrame:function(){this.stopAnimFrame(),this.animationFrame=t.requestAnimationFrame(function(){this.step()}.bind(this))},stopAnimFrame:function(){t.cancelAnimationFrame(this.animationFrame)},start:function(){return!this.active&&this.situation&&(this.active=!0,this.startCurrent()),this},startCurrent:function(){return this.situation.start=+new Date+this.situation.delay/this._speed,this.situation.finish=this.situation.start+this.situation.duration/this._speed,this.initAnimations().step()},queue:function(t){return("function"==typeof t||t instanceof i.Situation)&&this.situations.push(t),this.situation||(this.situation=this.situations.shift()),this},dequeue:function(){return this.stop(),this.situation=this.situations.shift(),this.situation&&(this.situation instanceof i.Situation?this.start():this.situation.call(this)),this},initAnimations:function(){var t,e=this.situation;if(e.init)return this;for(var a in e.animations){t=this.target()[a](),Array.isArray(t)||(t=[t]),Array.isArray(e.animations[a])||(e.animations[a]=[e.animations[a]]);for(var r=t.length;r--;)e.animations[a][r]instanceof i.Number&&(t[r]=new i.Number(t[r])),e.animations[a][r]=t[r].morph(e.animations[a][r])}for(var a in e.attrs)e.attrs[a]=new i.MorphObj(this.target().attr(a),e.attrs[a]);for(var a in e.styles)e.styles[a]=new i.MorphObj(this.target().style(a),e.styles[a]);return e.initialTransformation=this.target().matrixify(),e.init=!0,this},clearQueue:function(){return this.situations=[],this},clearCurrent:function(){return this.situation=null,this},stop:function(t,e){var i=this.active;return this.active=!1,e&&this.clearQueue(),t&&this.situation&&(!i&&this.startCurrent(),this.atEnd()),this.stopAnimFrame(),this.clearCurrent()},after:function(t){var e=this.last();return this.target().on("finished.fx",(function i(a){a.detail.situation==e&&(t.call(this,e),this.off("finished.fx",i))})),this._callStart()},during:function(t){var e=this.last(),a=function(a){a.detail.situation==e&&t.call(this,a.detail.pos,i.morph(a.detail.pos),a.detail.eased,e)};return this.target().off("during.fx",a).on("during.fx",a),this.after((function(){this.off("during.fx",a)})),this._callStart()},afterAll:function(t){var e=function e(i){t.call(this),this.off("allfinished.fx",e)};return this.target().off("allfinished.fx",e).on("allfinished.fx",e),this._callStart()},last:function(){return this.situations.length?this.situations[this.situations.length-1]:this.situation},add:function(t,e,i){return this.last()[i||"animations"][t]=e,this._callStart()},step:function(t){var e,i,a;t||(this.absPos=this.timeToAbsPos(+new Date)),!1!==this.situation.loops?(e=Math.max(this.absPos,0),i=Math.floor(e),!0===this.situation.loops||ithis.lastPos&&s<=r&&(this.situation.once[s].call(this.target(),this.pos,r),delete this.situation.once[s]);return this.active&&this.target().fire("during",{pos:this.pos,eased:r,fx:this,situation:this.situation}),this.situation?(this.eachAt(),1==this.pos&&!this.situation.reversed||this.situation.reversed&&0==this.pos?(this.stopAnimFrame(),this.target().fire("finished",{fx:this,situation:this.situation}),this.situations.length||(this.target().fire("allfinished"),this.situations.length||(this.target().off(".fx"),this.active=!1)),this.active?this.dequeue():this.clearCurrent()):!this.paused&&this.active&&this.startAnimFrame(),this.lastPos=r,this):this},eachAt:function(){var t,e=this,a=this.target(),r=this.situation;for(var s in r.animations)t=[].concat(r.animations[s]).map((function(t){return"string"!=typeof t&&t.at?t.at(r.ease(e.pos),e.pos):t})),a[s].apply(a,t);for(var s in r.attrs)t=[s].concat(r.attrs[s]).map((function(t){return"string"!=typeof t&&t.at?t.at(r.ease(e.pos),e.pos):t})),a.attr.apply(a,t);for(var s in r.styles)t=[s].concat(r.styles[s]).map((function(t){return"string"!=typeof t&&t.at?t.at(r.ease(e.pos),e.pos):t})),a.style.apply(a,t);if(r.transforms.length){t=r.initialTransformation,s=0;for(var n=r.transforms.length;s=0;--a)this[v[a]]=null!=t[v[a]]?t[v[a]]:e[v[a]]},extend:{extract:function(){var t=f(this,0,1),e=(f(this,1,0),180/Math.PI*Math.atan2(t.y,t.x)-90);return{x:this.e,y:this.f,transformedX:(this.e*Math.cos(e*Math.PI/180)+this.f*Math.sin(e*Math.PI/180))/Math.sqrt(this.a*this.a+this.b*this.b),transformedY:(this.f*Math.cos(e*Math.PI/180)+this.e*Math.sin(-e*Math.PI/180))/Math.sqrt(this.c*this.c+this.d*this.d),rotation:e,a:this.a,b:this.b,c:this.c,d:this.d,e:this.e,f:this.f,matrix:new i.Matrix(this)}},clone:function(){return new i.Matrix(this)},morph:function(t){return this.destination=new i.Matrix(t),this},multiply:function(t){return new i.Matrix(this.native().multiply(function(t){return t instanceof i.Matrix||(t=new i.Matrix(t)),t}(t).native()))},inverse:function(){return new i.Matrix(this.native().inverse())},translate:function(t,e){return new i.Matrix(this.native().translate(t||0,e||0))},native:function(){for(var t=i.parser.native.createSVGMatrix(),e=v.length-1;e>=0;e--)t[v[e]]=this[v[e]];return t},toString:function(){return"matrix("+b(this.a)+","+b(this.b)+","+b(this.c)+","+b(this.d)+","+b(this.e)+","+b(this.f)+")"}},parent:i.Element,construct:{ctm:function(){return new i.Matrix(this.node.getCTM())},screenCTM:function(){if(this instanceof i.Nested){var t=this.rect(1,1),e=t.node.getScreenCTM();return t.remove(),new i.Matrix(e)}return new i.Matrix(this.node.getScreenCTM())}}}),i.Point=i.invent({create:function(t,e){var i;i=Array.isArray(t)?{x:t[0],y:t[1]}:"object"===s(t)?{x:t.x,y:t.y}:null!=t?{x:t,y:null!=e?e:t}:{x:0,y:0},this.x=i.x,this.y=i.y},extend:{clone:function(){return new i.Point(this)},morph:function(t,e){return this.destination=new i.Point(t,e),this}}}),i.extend(i.Element,{point:function(t,e){return new i.Point(t,e).transform(this.screenCTM().inverse())}}),i.extend(i.Element,{attr:function(t,e,a){if(null==t){for(t={},a=(e=this.node.attributes).length-1;a>=0;a--)t[e[a].nodeName]=i.regex.isNumber.test(e[a].nodeValue)?parseFloat(e[a].nodeValue):e[a].nodeValue;return t}if("object"===s(t))for(var r in t)this.attr(r,t[r]);else if(null===e)this.node.removeAttribute(t);else{if(null==e)return null==(e=this.node.getAttribute(t))?i.defaults.attrs[t]:i.regex.isNumber.test(e)?parseFloat(e):e;"stroke-width"==t?this.attr("stroke",parseFloat(e)>0?this._stroke:null):"stroke"==t&&(this._stroke=e),"fill"!=t&&"stroke"!=t||(i.regex.isImage.test(e)&&(e=this.doc().defs().image(e,0,0)),e instanceof i.Image&&(e=this.doc().defs().pattern(0,0,(function(){this.add(e)})))),"number"==typeof e?e=new i.Number(e):i.Color.isColor(e)?e=new i.Color(e):Array.isArray(e)&&(e=new i.Array(e)),"leading"==t?this.leading&&this.leading(e):"string"==typeof a?this.node.setAttributeNS(a,t,e.toString()):this.node.setAttribute(t,e.toString()),!this.rebuild||"font-size"!=t&&"x"!=t||this.rebuild(t,e)}return this}}),i.extend(i.Element,{transform:function(t,e){var a;return"object"!==s(t)?(a=new i.Matrix(this).extract(),"string"==typeof t?a[t]:a):(a=new i.Matrix(this),e=!!e||!!t.relative,null!=t.a&&(a=e?a.multiply(new i.Matrix(t)):new i.Matrix(t)),this.attr("transform",a))}}),i.extend(i.Element,{untransform:function(){return this.attr("transform",null)},matrixify:function(){return(this.attr("transform")||"").split(i.regex.transforms).slice(0,-1).map((function(t){var e=t.trim().split("(");return[e[0],e[1].split(i.regex.delimiter).map((function(t){return parseFloat(t)}))]})).reduce((function(t,e){return"matrix"==e[0]?t.multiply(p(e[1])):t[e[0]].apply(t,e[1])}),new i.Matrix)},toParent:function(t){if(this==t)return this;var e=this.screenCTM(),i=t.screenCTM().inverse();return this.addTo(t).untransform().transform(i.multiply(e)),this},toDoc:function(){return this.toParent(this.doc())}}),i.Transformation=i.invent({create:function(t,e){if(arguments.length>1&&"boolean"!=typeof e)return this.constructor.call(this,[].slice.call(arguments));if(Array.isArray(t))for(var i=0,a=this.arguments.length;i=0},index:function(t){return[].slice.call(this.node.childNodes).indexOf(t.node)},get:function(t){return i.adopt(this.node.childNodes[t])},first:function(){return this.get(0)},last:function(){return this.get(this.node.childNodes.length-1)},each:function(t,e){for(var a=this.children(),r=0,s=a.length;r=0;a--)e.childNodes[a]instanceof t.SVGElement&&x(e.childNodes[a]);return i.adopt(e).id(i.eid(e.nodeName))}function b(t){return Math.abs(t)>1e-37?t:0}["fill","stroke"].forEach((function(t){var e={};e[t]=function(e){if(void 0===e)return this;if("string"==typeof e||i.Color.isRgb(e)||e&&"function"==typeof e.fill)this.attr(t,e);else for(var a=l[t].length-1;a>=0;a--)null!=e[l[t][a]]&&this.attr(l.prefix(t,l[t][a]),e[l[t][a]]);return this},i.extend(i.Element,i.FX,e)})),i.extend(i.Element,i.FX,{translate:function(t,e){return this.transform({x:t,y:e})},matrix:function(t){return this.attr("transform",new i.Matrix(6==arguments.length?[].slice.call(arguments):t))},opacity:function(t){return this.attr("opacity",t)},dx:function(t){return this.x(new i.Number(t).plus(this instanceof i.FX?0:this.x()),!0)},dy:function(t){return this.y(new i.Number(t).plus(this instanceof i.FX?0:this.y()),!0)}}),i.extend(i.Path,{length:function(){return this.node.getTotalLength()},pointAt:function(t){return this.node.getPointAtLength(t)}}),i.Set=i.invent({create:function(t){Array.isArray(t)?this.members=t:this.clear()},extend:{add:function(){for(var t=[].slice.call(arguments),e=0,i=t.length;e-1&&this.members.splice(e,1),this},each:function(t){for(var e=0,i=this.members.length;e=0},index:function(t){return this.members.indexOf(t)},get:function(t){return this.members[t]},first:function(){return this.get(0)},last:function(){return this.get(this.members.length-1)},valueOf:function(){return this.members}},construct:{set:function(t){return new i.Set(t)}}}),i.FX.Set=i.invent({create:function(t){this.set=t}}),i.Set.inherit=function(){var t=[];for(var e in i.Shape.prototype)"function"==typeof i.Shape.prototype[e]&&"function"!=typeof i.Set.prototype[e]&&t.push(e);for(var e in t.forEach((function(t){i.Set.prototype[t]=function(){for(var e=0,a=this.members.length;e=0;t--)delete this.memory()[arguments[t]];return this},memory:function(){return this._memory||(this._memory={})}}),i.get=function(t){var a=e.getElementById(function(t){var e=(t||"").toString().match(i.regex.reference);if(e)return e[1]}(t)||t);return i.adopt(a)},i.select=function(t,a){return new i.Set(i.utils.map((a||e).querySelectorAll(t),(function(t){return i.adopt(t)})))},i.extend(i.Parent,{select:function(t){return i.select(t,this.node)}});var v="abcdef".split("");if("function"!=typeof t.CustomEvent){var m=function(t,i){i=i||{bubbles:!1,cancelable:!1,detail:void 0};var a=e.createEvent("CustomEvent");return a.initCustomEvent(t,i.bubbles,i.cancelable,i.detail),a};m.prototype=t.Event.prototype,i.CustomEvent=m}else i.CustomEvent=t.CustomEvent;return i}(r,r.document)}.call(e,i,e,t),void 0===a||(t.exports=a)},539:(t,e,i)=>{(e=i(922)(!1)).push([t.id,'@keyframes opaque {\n 0% {\n opacity: 0\n }\n\n to {\n opacity: 1\n }\n}\n\n@keyframes resizeanim {\n 0%,to {\n opacity: 0\n }\n}\n\n.apexcharts-canvas {\n position: relative;\n user-select: none\n}\n\n.apexcharts-canvas ::-webkit-scrollbar {\n -webkit-appearance: none;\n width: 6px\n}\n\n.apexcharts-canvas ::-webkit-scrollbar-thumb {\n border-radius: 4px;\n background-color: rgba(0,0,0,.5);\n box-shadow: 0 0 1px rgba(255,255,255,.5);\n -webkit-box-shadow: 0 0 1px rgba(255,255,255,.5)\n}\n\n.apexcharts-inner {\n position: relative\n}\n\n.apexcharts-text tspan {\n font-family: inherit\n}\n\n.legend-mouseover-inactive {\n transition: .15s ease all;\n opacity: .2\n}\n\n.apexcharts-legend-text {\n padding-left: 15px;\n margin-left: -15px;\n}\n\n.apexcharts-series-collapsed {\n opacity: 0\n}\n\n.apexcharts-tooltip {\n border-radius: 5px;\n box-shadow: 2px 2px 6px -4px #999;\n cursor: default;\n font-size: 14px;\n left: 62px;\n opacity: 0;\n pointer-events: none;\n position: absolute;\n top: 20px;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n white-space: nowrap;\n z-index: 12;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-theme-light {\n border: 1px solid #e3e3e3;\n background: rgba(255,255,255,.96)\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark {\n color: #fff;\n background: rgba(30,30,30,.8)\n}\n\n.apexcharts-tooltip * {\n font-family: inherit\n}\n\n.apexcharts-tooltip-title {\n padding: 6px;\n font-size: 15px;\n margin-bottom: 4px\n}\n\n.apexcharts-tooltip.apexcharts-theme-light .apexcharts-tooltip-title {\n background: #eceff1;\n border-bottom: 1px solid #ddd\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark .apexcharts-tooltip-title {\n background: rgba(0,0,0,.7);\n border-bottom: 1px solid #333\n}\n\n.apexcharts-tooltip-text-goals-value,.apexcharts-tooltip-text-y-value,.apexcharts-tooltip-text-z-value {\n display: inline-block;\n margin-left: 5px;\n font-weight: 600\n}\n\n.apexcharts-tooltip-text-goals-label:empty,.apexcharts-tooltip-text-goals-value:empty,.apexcharts-tooltip-text-y-label:empty,.apexcharts-tooltip-text-y-value:empty,.apexcharts-tooltip-text-z-value:empty,.apexcharts-tooltip-title:empty {\n display: none\n}\n\n.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n padding: 6px 0 5px\n}\n\n.apexcharts-tooltip-goals-group,.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n display: flex\n}\n\n.apexcharts-tooltip-text-goals-label:not(:empty),.apexcharts-tooltip-text-goals-value:not(:empty) {\n margin-top: -6px\n}\n\n.apexcharts-tooltip-marker {\n width: 12px;\n height: 12px;\n position: relative;\n top: 0;\n margin-right: 10px;\n border-radius: 50%\n}\n\n.apexcharts-tooltip-series-group {\n padding: 0 10px;\n display: none;\n text-align: left;\n justify-content: left;\n align-items: center\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-marker {\n opacity: 1\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active,.apexcharts-tooltip-series-group:last-child {\n padding-bottom: 4px\n}\n\n.apexcharts-tooltip-series-group-hidden {\n opacity: 0;\n height: 0;\n line-height: 0;\n padding: 0!important\n}\n\n.apexcharts-tooltip-y-group {\n padding: 6px 0 5px\n}\n\n.apexcharts-custom-tooltip,.apexcharts-tooltip-box {\n padding: 4px 8px\n}\n\n.apexcharts-tooltip-boxPlot {\n display: flex;\n flex-direction: column-reverse\n}\n\n.apexcharts-tooltip-box>div {\n margin: 4px 0\n}\n\n.apexcharts-tooltip-box span.value {\n font-weight: 700\n}\n\n.apexcharts-tooltip-rangebar {\n padding: 5px 8px\n}\n\n.apexcharts-tooltip-rangebar .category {\n font-weight: 600;\n color: #777\n}\n\n.apexcharts-tooltip-rangebar .series-name {\n font-weight: 700;\n display: block;\n margin-bottom: 5px\n}\n\n.apexcharts-xaxistooltip,.apexcharts-yaxistooltip {\n opacity: 0;\n pointer-events: none;\n color: #373d3f;\n font-size: 13px;\n text-align: center;\n border-radius: 2px;\n position: absolute;\n z-index: 10;\n background: #eceff1;\n border: 1px solid #90a4ae\n}\n\n.apexcharts-xaxistooltip {\n padding: 9px 10px;\n transition: .15s ease all\n}\n\n.apexcharts-xaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-xaxistooltip:after,.apexcharts-xaxistooltip:before {\n left: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-xaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-left: -6px\n}\n\n.apexcharts-xaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-left: -7px\n}\n\n.apexcharts-xaxistooltip-bottom:after,.apexcharts-xaxistooltip-bottom:before {\n bottom: 100%\n}\n\n.apexcharts-xaxistooltip-top:after,.apexcharts-xaxistooltip-top:before {\n top: 100%\n}\n\n.apexcharts-xaxistooltip-bottom:after {\n border-bottom-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-bottom:before {\n border-bottom-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:before {\n border-bottom-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip-top:after {\n border-top-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-top:before {\n border-top-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-top.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-top.apexcharts-theme-dark:before {\n border-top-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-yaxistooltip {\n padding: 4px 10px\n}\n\n.apexcharts-yaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-yaxistooltip:after,.apexcharts-yaxistooltip:before {\n top: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-yaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-top: -6px\n}\n\n.apexcharts-yaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-top: -7px\n}\n\n.apexcharts-yaxistooltip-left:after,.apexcharts-yaxistooltip-left:before {\n left: 100%\n}\n\n.apexcharts-yaxistooltip-right:after,.apexcharts-yaxistooltip-right:before {\n right: 100%\n}\n\n.apexcharts-yaxistooltip-left:after {\n border-left-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-left:before {\n border-left-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-left.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-left.apexcharts-theme-dark:before {\n border-left-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip-right:after {\n border-right-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-right:before {\n border-right-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-right.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-right.apexcharts-theme-dark:before {\n border-right-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip.apexcharts-active {\n opacity: 1\n}\n\n.apexcharts-yaxistooltip-hidden {\n display: none\n}\n\n.apexcharts-xcrosshairs,.apexcharts-ycrosshairs {\n pointer-events: none;\n opacity: 0;\n transition: .15s ease all\n}\n\n.apexcharts-xcrosshairs.apexcharts-active,.apexcharts-ycrosshairs.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-ycrosshairs-hidden {\n opacity: 0\n}\n\n.apexcharts-selection-rect {\n cursor: move\n}\n\n.svg_select_boundingRect,.svg_select_points_rot {\n pointer-events: none;\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_boundingRect,.apexcharts-selection-rect+g .svg_select_points_rot {\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_points_l,.apexcharts-selection-rect+g .svg_select_points_r {\n cursor: ew-resize;\n opacity: 1;\n visibility: visible\n}\n\n.svg_select_points {\n fill: #efefef;\n stroke: #333;\n rx: 2\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-zoom {\n cursor: crosshair\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-pan {\n cursor: move\n}\n\n.apexcharts-menu-icon,.apexcharts-pan-icon,.apexcharts-reset-icon,.apexcharts-selection-icon,.apexcharts-toolbar-custom-icon,.apexcharts-zoom-icon,.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n cursor: pointer;\n width: 20px;\n height: 20px;\n line-height: 24px;\n color: #6e8192;\n text-align: center\n}\n\n.apexcharts-menu-icon svg,.apexcharts-reset-icon svg,.apexcharts-zoom-icon svg,.apexcharts-zoomin-icon svg,.apexcharts-zoomout-icon svg {\n fill: #6e8192\n}\n\n.apexcharts-selection-icon svg {\n fill: #444;\n transform: scale(.76)\n}\n\n.apexcharts-theme-dark .apexcharts-menu-icon svg,.apexcharts-theme-dark .apexcharts-pan-icon svg,.apexcharts-theme-dark .apexcharts-reset-icon svg,.apexcharts-theme-dark .apexcharts-selection-icon svg,.apexcharts-theme-dark .apexcharts-toolbar-custom-icon svg,.apexcharts-theme-dark .apexcharts-zoom-icon svg,.apexcharts-theme-dark .apexcharts-zoomin-icon svg,.apexcharts-theme-dark .apexcharts-zoomout-icon svg {\n fill: #f3f4f5\n}\n\n.apexcharts-canvas .apexcharts-reset-zoom-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-selection-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-zoom-icon.apexcharts-selected svg {\n fill: #008ffb\n}\n\n.apexcharts-theme-light .apexcharts-menu-icon:hover svg,.apexcharts-theme-light .apexcharts-reset-icon:hover svg,.apexcharts-theme-light .apexcharts-selection-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoom-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoomin-icon:hover svg,.apexcharts-theme-light .apexcharts-zoomout-icon:hover svg {\n fill: #333\n}\n\n.apexcharts-menu-icon,.apexcharts-selection-icon {\n position: relative\n}\n\n.apexcharts-reset-icon {\n margin-left: 5px\n}\n\n.apexcharts-menu-icon,.apexcharts-reset-icon,.apexcharts-zoom-icon {\n transform: scale(.85)\n}\n\n.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n transform: scale(.7)\n}\n\n.apexcharts-zoomout-icon {\n margin-right: 3px\n}\n\n.apexcharts-pan-icon {\n transform: scale(.62);\n position: relative;\n left: 1px;\n top: 0\n}\n\n.apexcharts-pan-icon svg {\n fill: #fff;\n stroke: #6e8192;\n stroke-width: 2\n}\n\n.apexcharts-pan-icon.apexcharts-selected svg {\n stroke: #008ffb\n}\n\n.apexcharts-pan-icon:not(.apexcharts-selected):hover svg {\n stroke: #333\n}\n\n.apexcharts-toolbar {\n position: absolute;\n z-index: 11;\n max-width: 176px;\n text-align: right;\n border-radius: 3px;\n padding: 0 6px 2px;\n display: flex;\n justify-content: space-between;\n align-items: center\n}\n\n.apexcharts-menu {\n background: #fff;\n position: absolute;\n top: 100%;\n border: 1px solid #ddd;\n border-radius: 3px;\n padding: 3px;\n right: 10px;\n opacity: 0;\n min-width: 110px;\n transition: .15s ease all;\n pointer-events: none\n}\n\n.apexcharts-menu.apexcharts-menu-open {\n opacity: 1;\n pointer-events: all;\n transition: .15s ease all\n}\n\n.apexcharts-menu-item {\n padding: 6px 7px;\n font-size: 12px;\n cursor: pointer\n}\n\n.apexcharts-theme-light .apexcharts-menu-item:hover {\n background: #eee\n}\n\n.apexcharts-theme-dark .apexcharts-menu {\n background: rgba(0,0,0,.7);\n color: #fff\n}\n\n@media screen and (min-width:768px) {\n .apexcharts-canvas:hover .apexcharts-toolbar {\n opacity: 1\n }\n}\n\n.apexcharts-canvas .apexcharts-element-hidden,.apexcharts-datalabel.apexcharts-element-hidden,.apexcharts-hide .apexcharts-series-points {\n opacity: 0\n}\n\n.apexcharts-datalabel,.apexcharts-datalabel-label,.apexcharts-datalabel-value,.apexcharts-datalabels,.apexcharts-pie-label {\n cursor: default;\n pointer-events: none\n}\n\n.apexcharts-pie-label-delay {\n opacity: 0;\n animation-name: opaque;\n animation-duration: .3s;\n animation-fill-mode: forwards;\n animation-timing-function: ease\n}\n\n.apexcharts-annotation-rect,.apexcharts-area-series .apexcharts-area,.apexcharts-area-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-gridline,.apexcharts-line,.apexcharts-line-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-point-annotation-label,.apexcharts-radar-series path,.apexcharts-radar-series polygon,.apexcharts-toolbar svg,.apexcharts-tooltip .apexcharts-marker,.apexcharts-xaxis-annotation-label,.apexcharts-yaxis-annotation-label,.apexcharts-zoom-rect {\n pointer-events: none\n}\n\n.apexcharts-marker {\n transition: .15s ease all\n}\n\n.resize-triggers {\n animation: 1ms resizeanim;\n visibility: hidden;\n opacity: 0;\n height: 100%;\n width: 100%;\n overflow: hidden\n}\n\n.contract-trigger:before,.resize-triggers,.resize-triggers>div {\n content: " ";\n display: block;\n position: absolute;\n top: 0;\n left: 0\n}\n\n.resize-triggers>div {\n height: 100%;\n width: 100%;\n background: #eee;\n overflow: auto\n}\n\n.contract-trigger:before {\n overflow: hidden;\n width: 200%;\n height: 200%\n}\n',""]),t.exports=e},274:(t,e,i)=>{var a=i(379),r=i(539);"string"==typeof(r=r.__esModule?r.default:r)&&(r=[[t.id,r,""]]);var s=(a(t.id,r,{insert:"head",singleton:!1}),r.locals?r.locals:{});t.exports=s},379:(t,e,i)=>{"use strict";var a,r=function(){var t={};return function(e){if(void 0===t[e]){var i=document.querySelector(e);if(window.HTMLIFrameElement&&i instanceof window.HTMLIFrameElement)try{i=i.contentDocument.head}catch(t){i=null}t[e]=i}return t[e]}}(),s={};function n(t,e,i){for(var a=0;a{t.exports=''},355:t=>{t.exports=''},686:t=>{t.exports=''},798:t=>{t.exports=''},323:t=>{t.exports=''},618:t=>{t.exports=''},688:t=>{t.exports=''}},e={};function i(a){var r=e[a];if(void 0!==r)return r.exports;var s=e[a]={id:a,exports:{}};return t[a].call(s.exports,s,s.exports,i),s.exports}i.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return i.d(e,{a:e}),e},i.d=(t,e)=>{for(var a in e)i.o(e,a)&&!i.o(t,a)&&Object.defineProperty(t,a,{enumerable:!0,get:e[a]})},i.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),i.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},i.nc=void 0;var a={};return(()=>{"use strict";function t(e){return t="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},t(e)}function e(t,e){for(var i=0;iXa});const r=function(){function i(){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i)}var a,r,s;return a=i,s=[{key:"bind",value:function(t,e){return function(){return t.apply(e,arguments)}}},{key:"isObject",value:function(e){return e&&"object"===t(e)&&!Array.isArray(e)&&null!=e}},{key:"is",value:function(t,e){return Object.prototype.toString.call(e)==="[object "+t+"]"}},{key:"listToArray",value:function(t){var e,i=[];for(e=0;ee.length?t:e}))),t.length>e.length?t:e}),0)}},{key:"hexToRgba",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"#999999",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:.6;"#"!==t.substring(0,1)&&(t="#999999");var i=t.replace("#","");i=i.match(new RegExp("(.{"+i.length/3+"})","g"));for(var a=0;a1&&void 0!==arguments[1]?arguments[1]:"x",i=t.toString().slice();return i.replace(/[` ~!@#$%^&*()|+\=?;:'",.<>{}[\]\\/]/gi,e)}},{key:"negToZero",value:function(t){return t<0?0:t}},{key:"moveIndexInArray",value:function(t,e,i){if(i>=t.length)for(var a=i-t.length+1;a--;)t.push(void 0);return t.splice(i,0,t.splice(e,1)[0]),t}},{key:"extractNumber",value:function(t){return parseFloat(t.replace(/[^\d.]*/g,""))}},{key:"findAncestor",value:function(t,e){for(;(t=t.parentElement)&&!t.classList.contains(e););return t}},{key:"setELstyles",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&(t.style.key=e[i])}},{key:"isNumber",value:function(t){return!isNaN(t)&&parseFloat(Number(t))===t&&!isNaN(parseInt(t,10))}},{key:"isFloat",value:function(t){return Number(t)===t&&t%1!=0}},{key:"isSafari",value:function(){return/^((?!chrome|android).)*safari/i.test(navigator.userAgent)}},{key:"isFirefox",value:function(){return navigator.userAgent.toLowerCase().indexOf("firefox")>-1}},{key:"isIE11",value:function(){if(-1!==window.navigator.userAgent.indexOf("MSIE")||window.navigator.appVersion.indexOf("Trident/")>-1)return!0}},{key:"isIE",value:function(){var t=window.navigator.userAgent,e=t.indexOf("MSIE ");if(e>0)return parseInt(t.substring(e+5,t.indexOf(".",e)),10);if(t.indexOf("Trident/")>0){var i=t.indexOf("rv:");return parseInt(t.substring(i+3,t.indexOf(".",i)),10)}var a=t.indexOf("Edge/");return a>0&&parseInt(t.substring(a+5,t.indexOf(".",a)),10)}}],(r=[{key:"shadeRGBColor",value:function(t,e){var i=e.split(","),a=t<0?0:255,r=t<0?-1*t:t,s=parseInt(i[0].slice(4),10),n=parseInt(i[1],10),o=parseInt(i[2],10);return"rgb("+(Math.round((a-s)*r)+s)+","+(Math.round((a-n)*r)+n)+","+(Math.round((a-o)*r)+o)+")"}},{key:"shadeHexColor",value:function(t,e){var i=parseInt(e.slice(1),16),a=t<0?0:255,r=t<0?-1*t:t,s=i>>16,n=i>>8&255,o=255&i;return"#"+(16777216+65536*(Math.round((a-s)*r)+s)+256*(Math.round((a-n)*r)+n)+(Math.round((a-o)*r)+o)).toString(16).slice(1)}},{key:"shadeColor",value:function(t,e){return i.isColorHex(e)?this.shadeHexColor(t,e):this.shadeRGBColor(t,e)}}])&&e(a.prototype,r),s&&e(a,s),i}();function s(t,e){for(var i=0;i-1||s.indexOf("NaN")>-1)&&(s=d()),(!n||n.indexOf("undefined")>-1||n.indexOf("NaN")>-1)&&(n=d()),h.globals.shouldAnimate||(o=1),t.plot(s).animate(1,h.globals.easing,l).plot(s).animate(o,h.globals.easing,l).plot(n).afterAll((function(){r.isNumber(i)?i===h.globals.series[h.globals.maxValsInArrayIndex].length-2&&h.globals.shouldAnimate&&c.animationCompleted(t):"none"!==a&&h.globals.shouldAnimate&&(!h.globals.comboCharts&&e===h.globals.series.length-1||h.globals.comboCharts)&&c.animationCompleted(t),c.showDelayedElements()}))}}])&&s(e.prototype,i),t}();function o(t,e){for(var i=0;i3&&void 0!==arguments[3]?arguments[3]:.5;switch(i){case"none":this.addNormalFilter(t,e);break;case"lighten":this.addLightenFilter(t,e,{intensity:a});break;case"darken":this.addDarkenFilter(t,e,{intensity:a})}}},{key:"addShadow",value:function(t,e,i){var a=i.blur,r=i.top,s=i.left,n=i.color,o=i.opacity,l=t.flood(Array.isArray(n)?n[e]:n,o).composite(t.sourceAlpha,"in").offset(s,r).gaussianBlur(a).merge(t.source);return t.blend(t.source,l)}},{key:"dropShadow",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=e.top,s=e.left,n=e.blur,o=e.color,l=e.opacity,c=e.noUserSpaceOnUse,h=this.w;return t.unfilter(!0),r.isIE()&&"radialBar"===h.config.chart.type||(o=Array.isArray(o)?o[i]:o,t.filter((function(t){var e;e=r.isSafari()||r.isFirefox()||r.isIE()?t.flood(o,l).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(n):t.flood(o,l).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(n).merge(t.source),t.blend(t.source,e)})),c||t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)),t}},{key:"setSelectionFilter",value:function(t,e,i){var a=this.w;if(void 0!==a.globals.selectedDataPoints[e]&&a.globals.selectedDataPoints[e].indexOf(i)>-1){t.node.setAttribute("selected",!0);var r=a.config.states.active.filter;"none"!==r&&this.applyFilter(t,e,r.type,r.value)}}},{key:"_scaleFilterSize",value:function(t){!function(e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}({width:"200%",height:"200%",x:"-50%",y:"-50%"})}}],i&&o(e.prototype,i),t}();function c(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function h(t){for(var e=1;e2&&(t[t.length-2]=e.x,t[t.length-1]=e.y)}function s(t){return{x:parseFloat(t[t.length-2]),y:parseFloat(t[t.length-1])}}t.indexOf("NaN")>-1&&(t="");var n=t.split(/[,\s]/).reduce((function(t,e){var i=e.match("([a-zA-Z])(.+)");return i?(t.push(i[1]),t.push(i[2])):t.push(e),t}),[]).reduce((function(t,e){return parseFloat(e)==e&&t.length?t[t.length-1].push(e):t.push([e]),t}),[]),o=[];if(n.length>1){var l=s(n[0]),c=null;"Z"==n[n.length-1][0]&&n[0].length>2&&(c=["L",l.x,l.y],n[n.length-1]=c),o.push(n[0]);for(var h=1;h2&&"L"==u[0]&&g.length>2&&"L"==g[0]){var f,p,x=s(d),b=s(u),v=s(g);f=i(b,x,e),p=i(b,v,e),r(u,f),u.origPoint=b,o.push(u);var m=a(f,b,.5),y=a(b,p,.5),w=["C",m.x,m.y,y.x,y.y,p.x,p.y];w.origPoint=b,o.push(w)}else o.push(u)}if(c){var k=s(o[o.length-1]);o.push(["Z"]),r(o[0],k)}}else o=n;return o.reduce((function(t,e){return t+e.join(" ")+" "}),"")}},{key:"drawLine",value:function(t,e,i,a){var r=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"#a8a8a8",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,n=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,o=arguments.length>7&&void 0!==arguments[7]?arguments[7]:"butt";return this.w.globals.dom.Paper.line().attr({x1:t,y1:e,x2:i,y2:a,stroke:r,"stroke-dasharray":s,"stroke-width":n,"stroke-linecap":o})}},{key:"drawRect",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,r=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"#fefefe",n=arguments.length>6&&void 0!==arguments[6]?arguments[6]:1,o=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,l=arguments.length>8&&void 0!==arguments[8]?arguments[8]:null,c=arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,h=this.w.globals.dom.Paper.rect();return h.attr({x:t,y:e,width:i>0?i:0,height:a>0?a:0,rx:r,ry:r,opacity:n,"stroke-width":null!==o?o:0,stroke:null!==l?l:"none","stroke-dasharray":c}),h.node.setAttribute("fill",s),h}},{key:"drawPolygon",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"#e1e1e1",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none";return this.w.globals.dom.Paper.polygon(t).attr({fill:a,stroke:e,"stroke-width":i})}},{key:"drawCircle",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;t<0&&(t=0);var i=this.w.globals.dom.Paper.circle(2*t);return null!==e&&i.attr(e),i}},{key:"drawPath",value:function(t){var e=t.d,i=void 0===e?"":e,a=t.stroke,r=void 0===a?"#a8a8a8":a,s=t.strokeWidth,n=void 0===s?1:s,o=t.fill,l=t.fillOpacity,c=void 0===l?1:l,h=t.strokeOpacity,d=void 0===h?1:h,u=t.classes,g=t.strokeLinecap,f=void 0===g?null:g,p=t.strokeDashArray,x=void 0===p?0:p,b=this.w;return null===f&&(f=b.config.stroke.lineCap),(i.indexOf("undefined")>-1||i.indexOf("NaN")>-1)&&(i="M 0 ".concat(b.globals.gridHeight)),b.globals.dom.Paper.path(i).attr({fill:o,"fill-opacity":c,stroke:r,"stroke-opacity":d,"stroke-linecap":f,"stroke-width":n,"stroke-dasharray":x,class:u})}},{key:"group",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w.globals.dom.Paper.group();return null!==t&&e.attr(t),e}},{key:"move",value:function(t,e){return["M",t,e].join(" ")}},{key:"line",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=null;return null===i?a=[" L",t,e].join(" "):"H"===i?a=[" H",t].join(" "):"V"===i&&(a=[" V",e].join(" ")),a}},{key:"curve",value:function(t,e,i,a,r,s){return["C",t,e,i,a,r,s].join(" ")}},{key:"quadraticCurve",value:function(t,e,i,a){return["Q",t,e,i,a].join(" ")}},{key:"arc",value:function(t,e,i,a,r,s,n){var o="A";return arguments.length>7&&void 0!==arguments[7]&&arguments[7]&&(o="a"),[o,t,e,i,a,r,s,n].join(" ")}},{key:"renderPaths",value:function(t){var e,i=t.j,a=t.realIndex,r=t.pathFrom,s=t.pathTo,o=t.stroke,c=t.strokeWidth,d=t.strokeLinecap,u=t.fill,g=t.animationDelay,f=t.initialSpeed,p=t.dataChangeSpeed,x=t.className,b=t.shouldClipToGrid,v=void 0===b||b,m=t.bindEventsOnPaths,y=void 0===m||m,w=t.drawShadow,k=void 0===w||w,A=this.w,S=new l(this.ctx),C=new n(this.ctx),P=this.w.config.chart.animations.enabled,L=P&&this.w.config.chart.animations.dynamicAnimation.enabled,O=!!(P&&!A.globals.resized||L&&A.globals.dataChanged&&A.globals.shouldAnimate);O?e=r:(e=s,A.globals.animationEnded=!0);var T,I=A.config.stroke.dashArray;T=Array.isArray(I)?I[a]:A.config.stroke.dashArray;var E=this.drawPath({d:e,stroke:o,strokeWidth:c,fill:u,fillOpacity:1,classes:x,strokeLinecap:d,strokeDashArray:T});if(E.attr("index",a),v&&E.attr({"clip-path":"url(#gridRectMask".concat(A.globals.cuid,")")}),"none"!==A.config.states.normal.filter.type)S.getDefaultFilter(E,a);else if(A.config.chart.dropShadow.enabled&&k&&(!A.config.chart.dropShadow.enabledOnSeries||A.config.chart.dropShadow.enabledOnSeries&&-1!==A.config.chart.dropShadow.enabledOnSeries.indexOf(a))){var M=A.config.chart.dropShadow;S.dropShadow(E,M,a)}y&&(E.node.addEventListener("mouseenter",this.pathMouseEnter.bind(this,E)),E.node.addEventListener("mouseleave",this.pathMouseLeave.bind(this,E)),E.node.addEventListener("mousedown",this.pathMouseDown.bind(this,E))),E.attr({pathTo:s,pathFrom:r});var X={el:E,j:i,realIndex:a,pathFrom:r,pathTo:s,fill:u,strokeWidth:c,delay:g};return!P||A.globals.resized||A.globals.dataChanged?!A.globals.resized&&A.globals.dataChanged||C.showDelayedElements():C.animatePathsGradually(h(h({},X),{},{speed:f})),A.globals.dataChanged&&L&&O&&C.animatePathsGradually(h(h({},X),{},{speed:p})),E}},{key:"drawPattern",value:function(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"#a8a8a8",r=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0;return this.w.globals.dom.Paper.pattern(e,i,(function(s){"horizontalLines"===t?s.line(0,0,i,0).stroke({color:a,width:r+1}):"verticalLines"===t?s.line(0,0,0,e).stroke({color:a,width:r+1}):"slantedLines"===t?s.line(0,0,e,i).stroke({color:a,width:r}):"squares"===t?s.rect(e,i).fill("none").stroke({color:a,width:r}):"circles"===t&&s.circle(e).fill("none").stroke({color:a,width:r})}))}},{key:"drawGradient",value:function(t,e,i,a,s){var n,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:null,l=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,c=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,h=arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,d=this.w;e.length<9&&0===e.indexOf("#")&&(e=r.hexToRgba(e,a)),i.length<9&&0===i.indexOf("#")&&(i=r.hexToRgba(i,s));var u=0,g=1,f=1,p=null;null!==l&&(u=void 0!==l[0]?l[0]/100:0,g=void 0!==l[1]?l[1]/100:1,f=void 0!==l[2]?l[2]/100:1,p=void 0!==l[3]?l[3]/100:null);var x=!("donut"!==d.config.chart.type&&"pie"!==d.config.chart.type&&"polarArea"!==d.config.chart.type&&"bubble"!==d.config.chart.type);if(n=null===c||0===c.length?d.globals.dom.Paper.gradient(x?"radial":"linear",(function(t){t.at(u,e,a),t.at(g,i,s),t.at(f,i,s),null!==p&&t.at(p,e,a)})):d.globals.dom.Paper.gradient(x?"radial":"linear",(function(t){(Array.isArray(c[h])?c[h]:c).forEach((function(e){t.at(e.offset/100,e.color,e.opacity)}))})),x){var b=d.globals.gridWidth/2,v=d.globals.gridHeight/2;"bubble"!==d.config.chart.type?n.attr({gradientUnits:"userSpaceOnUse",cx:b,cy:v,r:o}):n.attr({cx:.5,cy:.5,r:.8,fx:.2,fy:.2})}else"vertical"===t?n.from(0,0).to(0,1):"diagonal"===t?n.from(0,0).to(1,1):"horizontal"===t?n.from(0,1).to(1,1):"diagonal2"===t&&n.from(1,0).to(0,1);return n}},{key:"getTextBasedOnMaxWidth",value:function(t){var e=t.text,i=t.maxWidth,a=t.fontSize,r=t.fontFamily,s=this.getTextRects(e,a,r),n=s.width/e.length,o=Math.floor(i/n);return i-1){var o=i.globals.selectedDataPoints[r].indexOf(s);i.globals.selectedDataPoints[r].splice(o,1)}}else{if(!i.config.states.active.allowMultipleDataPointsSelection&&i.globals.selectedDataPoints.length>0){i.globals.selectedDataPoints=[];var c=i.globals.dom.Paper.select(".apexcharts-series path").members,h=i.globals.dom.Paper.select(".apexcharts-series circle, .apexcharts-series rect").members,d=function(t){Array.prototype.forEach.call(t,(function(t){t.node.setAttribute("selected","false"),a.getDefaultFilter(t,r)}))};d(c),d(h)}t.node.setAttribute("selected","true"),n="true",void 0===i.globals.selectedDataPoints[r]&&(i.globals.selectedDataPoints[r]=[]),i.globals.selectedDataPoints[r].push(s)}if("true"===n){var u=i.config.states.active.filter;if("none"!==u)a.applyFilter(t,r,u.type,u.value);else if("none"!==i.config.states.hover.filter&&!i.globals.isTouchDevice){var g=i.config.states.hover.filter;a.applyFilter(t,r,g.type,g.value)}}else"none"!==i.config.states.active.filter.type&&("none"===i.config.states.hover.filter.type||i.globals.isTouchDevice?a.getDefaultFilter(t,r):(g=i.config.states.hover.filter,a.applyFilter(t,r,g.type,g.value)));"function"==typeof i.config.chart.events.dataPointSelection&&i.config.chart.events.dataPointSelection(e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:r,dataPointIndex:s,w:i}),e&&this.ctx.events.fireEvent("dataPointSelection",[e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:r,dataPointIndex:s,w:i}])}},{key:"rotateAroundCenter",value:function(t){var e={};return t&&"function"==typeof t.getBBox&&(e=t.getBBox()),{x:e.x+e.width/2,y:e.y+e.height/2}}},{key:"getTextRects",value:function(t,e,i,a){var r=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],s=this.w,n=this.drawText({x:-200,y:-200,text:t,textAnchor:"start",fontSize:e,fontFamily:i,foreColor:"#fff",opacity:0});a&&n.attr("transform",a),s.globals.dom.Paper.add(n);var o=n.bbox();return r||(o=n.node.getBoundingClientRect()),n.remove(),{width:o.width,height:o.height}}},{key:"placeTextWithEllipsis",value:function(t,e,i){if("function"==typeof t.getComputedTextLength&&(t.textContent=e,e.length>0&&t.getComputedTextLength()>=i/1.1)){for(var a=e.length-3;a>0;a-=3)if(t.getSubStringLength(0,a)<=i/1.1)return void(t.textContent=e.substring(0,a)+"...");t.textContent="."}}}],a=[{key:"setAttrs",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}}],i&&u(e.prototype,i),a&&u(e,a),t}();function f(t,e){for(var i=0;i0&&void 0!==arguments[0]?arguments[0]:[],e=this.w,i=[];if(0===e.globals.series.length)return i;for(var a=0;a0&&void 0!==arguments[0]?arguments[0]:null;return null===t?this.w.config.series.reduce((function(t,e){return t+e}),0):this.w.globals.series[t].reduce((function(t,e){return t+e}),0)}},{key:"isSeriesNull",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;return 0===(null===t?this.w.config.series.filter((function(t){return null!==t})):this.w.config.series[t].data.filter((function(t){return null!==t}))).length}},{key:"seriesHaveSameValues",value:function(t){return this.w.globals.series[t].every((function(t,e,i){return t===i[0]}))}},{key:"getCategoryLabels",value:function(t){var e=this.w,i=t.slice();return e.config.xaxis.convertedCatToNumeric&&(i=t.map((function(t,i){return e.config.xaxis.labels.formatter(t-e.globals.minX+1)}))),i}},{key:"getLargestSeries",value:function(){var t=this.w;t.globals.maxValsInArrayIndex=t.globals.series.map((function(t){return t.length})).indexOf(Math.max.apply(Math,t.globals.series.map((function(t){return t.length}))))}},{key:"getLargestMarkerSize",value:function(){var t=this.w,e=0;return t.globals.markers.size.forEach((function(t){e=Math.max(e,t)})),t.config.markers.discrete&&t.config.markers.discrete.length&&t.config.markers.discrete.forEach((function(t){e=Math.max(e,t.size)})),e>0&&(e+=t.config.markers.hover.sizeOffset+1),t.globals.markers.largestSize=e,e}},{key:"getSeriesTotals",value:function(){var t=this.w;t.globals.seriesTotals=t.globals.series.map((function(t,e){var i=0;if(Array.isArray(t))for(var a=0;at&&i.globals.seriesX[r][n]0&&(e=!0),{comboBarCount:i,comboCharts:e}}},{key:"extendArrayProps",value:function(t,e,i){return e.yaxis&&(e=t.extendYAxis(e,i)),e.annotations&&(e.annotations.yaxis&&(e=t.extendYAxisAnnotations(e)),e.annotations.xaxis&&(e=t.extendXAxisAnnotations(e)),e.annotations.points&&(e=t.extendPointAnnotations(e))),e}}],i&&f(e.prototype,i),a&&f(e,a),t}();function x(t,e){for(var i=0;i1&&void 0!==arguments[1]?arguments[1]:null,i=this.w;if("vertical"===t.label.orientation){var a=null!==e?e:0,r=i.globals.dom.baseEl.querySelector(".apexcharts-xaxis-annotations .apexcharts-xaxis-annotation-label[rel='".concat(a,"']"));if(null!==r){var s=r.getBoundingClientRect();r.setAttribute("x",parseFloat(r.getAttribute("x"))-s.height+4),"top"===t.label.position?r.setAttribute("y",parseFloat(r.getAttribute("y"))+s.width):r.setAttribute("y",parseFloat(r.getAttribute("y"))-s.width);var n=this.annoCtx.graphics.rotateAroundCenter(r),o=n.x,l=n.y;r.setAttribute("transform","rotate(-90 ".concat(o," ").concat(l,")"))}}}},{key:"addBackgroundToAnno",value:function(t,e){var i=this.w;if(!t||void 0===e.label.text||void 0!==e.label.text&&!String(e.label.text).trim())return null;var a=i.globals.dom.baseEl.querySelector(".apexcharts-grid").getBoundingClientRect(),r=t.getBoundingClientRect(),s=e.label.style.padding.left,n=e.label.style.padding.right,o=e.label.style.padding.top,l=e.label.style.padding.bottom;"vertical"===e.label.orientation&&(o=e.label.style.padding.left,l=e.label.style.padding.right,s=e.label.style.padding.top,n=e.label.style.padding.bottom);var c=r.left-a.left-s,h=r.top-a.top-o,d=this.annoCtx.graphics.drawRect(c-i.globals.barPadForNumericAxis,h,r.width+s+n,r.height+o+l,e.label.borderRadius,e.label.style.background,1,e.label.borderWidth,e.label.borderColor,0);return e.id&&d.node.classList.add(e.id),d}},{key:"annotationsBackground",value:function(){var t=this,e=this.w,i=function(i,a,r){var s=e.globals.dom.baseEl.querySelector(".apexcharts-".concat(r,"-annotations .apexcharts-").concat(r,"-annotation-label[rel='").concat(a,"']"));if(s){var n=s.parentNode,o=t.addBackgroundToAnno(s,i);o&&(n.insertBefore(o.node,s),i.label.mouseEnter&&o.node.addEventListener("mouseenter",i.label.mouseEnter.bind(t,i)),i.label.mouseLeave&&o.node.addEventListener("mouseleave",i.label.mouseLeave.bind(t,i)),i.label.click&&o.node.addEventListener("click",i.label.click.bind(t,i)))}};e.config.annotations.xaxis.map((function(t,e){i(t,e,"xaxis")})),e.config.annotations.yaxis.map((function(t,e){i(t,e,"yaxis")})),e.config.annotations.points.map((function(t,e){i(t,e,"point")}))}},{key:"getY1Y2",value:function(t,e){var i,a="y1"===t?e.y:e.y2,r=this.w;if(this.annoCtx.invertAxis){var s=r.globals.labels.indexOf(a);r.config.xaxis.convertedCatToNumeric&&(s=r.globals.categoryLabels.indexOf(a));var n=r.globals.dom.baseEl.querySelector(".apexcharts-yaxis-texts-g text:nth-child("+(s+1)+")");n&&(i=parseFloat(n.getAttribute("y")))}else{var o;o=r.config.yaxis[e.yAxisIndex].logarithmic?(a=new p(this.annoCtx.ctx).getLogVal(a,e.yAxisIndex))/r.globals.yLogRatio[e.yAxisIndex]:(a-r.globals.minYArr[e.yAxisIndex])/(r.globals.yRange[e.yAxisIndex]/r.globals.gridHeight),i=r.globals.gridHeight-o,!e.marker||void 0!==e.y&&null!==e.y||(i=0),r.config.yaxis[e.yAxisIndex]&&r.config.yaxis[e.yAxisIndex].reversed&&(i=o)}return"string"==typeof a&&a.indexOf("px")>-1&&(i=parseFloat(a)),i}},{key:"getX1X2",value:function(t,e){var i=this.w,a=this.annoCtx.invertAxis?i.globals.minY:i.globals.minX,r=this.annoCtx.invertAxis?i.globals.maxY:i.globals.maxX,s=this.annoCtx.invertAxis?i.globals.yRange[0]:i.globals.xRange,n=(e.x-a)/(s/i.globals.gridWidth);this.annoCtx.inversedReversedAxis&&(n=(r-e.x)/(s/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(n=this.getStringX(e.x));var o=(e.x2-a)/(s/i.globals.gridWidth);return this.annoCtx.inversedReversedAxis&&(o=(r-e.x2)/(s/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(o=this.getStringX(e.x2)),void 0!==e.x&&null!==e.x||!e.marker||(n=i.globals.gridWidth),"x1"===t&&"string"==typeof e.x&&e.x.indexOf("px")>-1&&(n=parseFloat(e.x)),"x2"===t&&"string"==typeof e.x2&&e.x2.indexOf("px")>-1&&(o=parseFloat(e.x2)),"x1"===t?n:o}},{key:"getStringX",value:function(t){var e=this.w,i=t;e.config.xaxis.convertedCatToNumeric&&e.globals.categoryLabels.length&&(t=e.globals.categoryLabels.indexOf(t)+1);var a=e.globals.labels.indexOf(t),r=e.globals.dom.baseEl.querySelector(".apexcharts-xaxis-texts-g text:nth-child("+(a+1)+")");return r&&(i=parseFloat(r.getAttribute("x"))),i}}],i&&x(e.prototype,i),t}();function v(t,e){for(var i=0;in){var c=n;n=a,a=c}var h=this.annoCtx.graphics.drawRect(0+t.offsetX,a+t.offsetY,this._getYAxisAnnotationWidth(t),n-a,0,t.fillColor,t.opacity,1,t.borderColor,s);h.node.classList.add("apexcharts-annotation-rect"),h.attr("clip-path","url(#gridRectMask".concat(r.globals.cuid,")")),e.appendChild(h.node),t.id&&h.node.classList.add(t.id)}var d="right"===t.label.position?r.globals.gridWidth:"center"===t.label.position?r.globals.gridWidth/2:0,u=this.annoCtx.graphics.drawText({x:d+t.label.offsetX,y:(null!=a?a:n)+t.label.offsetY-3,text:o,textAnchor:t.label.textAnchor,fontSize:t.label.style.fontSize,fontFamily:t.label.style.fontFamily,fontWeight:t.label.style.fontWeight,foreColor:t.label.style.color,cssClass:"apexcharts-yaxis-annotation-label ".concat(t.label.style.cssClass," ").concat(t.id?t.id:"")});u.attr({rel:i}),e.appendChild(u.node)}},{key:"_getYAxisAnnotationWidth",value:function(t){var e=this.w;return e.globals.gridWidth,(t.width.indexOf("%")>-1?e.globals.gridWidth*parseInt(t.width,10)/100:parseInt(t.width,10))+t.offsetX}},{key:"drawYAxisAnnotations",value:function(){var t=this,e=this.w,i=this.annoCtx.graphics.group({class:"apexcharts-yaxis-annotations"});return e.config.annotations.yaxis.map((function(e,a){t.addYaxisAnnotation(e,i.node,a)})),i}}])&&y(e.prototype,i),t}();function k(t,e){for(var i=0;i1&&n[o].classList.add("apexcharts-element-hidden"),t.globals.delayedElements.push({el:n[o],index:0});this.helpers.annotationsBackground()}}},{key:"drawImageAnnos",value:function(){var t=this;this.w.config.annotations.images.map((function(e,i){t.addImage(e,i)}))}},{key:"drawTextAnnos",value:function(){var t=this;this.w.config.annotations.texts.map((function(e,i){t.addText(e,i)}))}},{key:"addXaxisAnnotation",value:function(t,e,i){this.xAxisAnnotations.addXaxisAnnotation(t,e,i)}},{key:"addYaxisAnnotation",value:function(t,e,i){this.yAxisAnnotations.addYaxisAnnotation(t,e,i)}},{key:"addPointAnnotation",value:function(t,e,i){this.pointsAnnotations.addPointAnnotation(t,e,i)}},{key:"addText",value:function(t,e){var i=t.x,a=t.y,r=t.text,s=t.textAnchor,n=t.foreColor,o=t.fontSize,l=t.fontFamily,c=t.fontWeight,h=t.cssClass,d=t.backgroundColor,u=t.borderWidth,g=t.strokeDashArray,f=t.borderRadius,p=t.borderColor,x=t.appendTo,b=void 0===x?".apexcharts-annotations":x,v=t.paddingLeft,m=void 0===v?4:v,y=t.paddingRight,w=void 0===y?4:y,k=t.paddingBottom,A=void 0===k?2:k,S=t.paddingTop,C=void 0===S?2:S,P=this.w,L=this.graphics.drawText({x:i,y:a,text:r,textAnchor:s||"start",fontSize:o||"12px",fontWeight:c||"regular",fontFamily:l||P.config.chart.fontFamily,foreColor:n||P.config.chart.foreColor,cssClass:h}),O=P.globals.dom.baseEl.querySelector(b);O&&O.appendChild(L.node);var T=L.bbox();if(r){var I=this.graphics.drawRect(T.x-m,T.y-C,T.width+m+w,T.height+A+C,f,d||"transparent",1,u,p,g);O.insertBefore(I.node,L.node)}}},{key:"addImage",value:function(t,e){var i=this.w,a=t.path,r=t.x,s=void 0===r?0:r,n=t.y,o=void 0===n?0:n,l=t.width,c=void 0===l?20:l,h=t.height,d=void 0===h?20:h,u=t.appendTo,g=void 0===u?".apexcharts-annotations":u,f=i.globals.dom.Paper.image(a);f.size(c,d).move(s,o);var p=i.globals.dom.baseEl.querySelector(g);return p&&p.appendChild(f.node),f}},{key:"addXaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"xaxis",contextMethod:i.addXaxisAnnotation}),i}},{key:"addYaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"yaxis",contextMethod:i.addYaxisAnnotation}),i}},{key:"addPointAnnotationExternal",value:function(t,e,i){return void 0===this.invertAxis&&(this.invertAxis=i.w.globals.isBarHorizontal),this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"point",contextMethod:i.addPointAnnotation}),i}},{key:"addAnnotationExternal",value:function(t){var e=t.params,i=t.pushToMemory,a=t.context,s=t.type,n=t.contextMethod,o=a,l=o.w,c=l.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations")),h=c.childNodes.length+1,d=new P,u=Object.assign({},"xaxis"===s?d.xAxisAnnotation:"yaxis"===s?d.yAxisAnnotation:d.pointAnnotation),g=r.extend(u,e);switch(s){case"xaxis":this.addXaxisAnnotation(g,c,h);break;case"yaxis":this.addYaxisAnnotation(g,c,h);break;case"point":this.addPointAnnotation(g,c,h)}var f=l.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations .apexcharts-").concat(s,"-annotation-label[rel='").concat(h,"']")),p=this.helpers.addBackgroundToAnno(f,g);return p&&c.insertBefore(p.node,f),i&&l.globals.memory.methodsToExec.push({context:o,id:g.id?g.id:r.randomId(),method:n,label:"addAnnotation",params:e}),a}},{key:"clearAnnotations",value:function(t){var e=t.w,i=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis-annotations, .apexcharts-xaxis-annotations, .apexcharts-point-annotations");e.globals.memory.methodsToExec.map((function(t,i){"addText"!==t.label&&"addAnnotation"!==t.label||e.globals.memory.methodsToExec.splice(i,1)})),i=r.listToArray(i),Array.prototype.forEach.call(i,(function(t){for(;t.firstChild;)t.removeChild(t.firstChild)}))}},{key:"removeAnnotation",value:function(t,e){var i=t.w,a=i.globals.dom.baseEl.querySelectorAll(".".concat(e));a&&(i.globals.memory.methodsToExec.map((function(t,a){t.id===e&&i.globals.memory.methodsToExec.splice(a,1)})),Array.prototype.forEach.call(a,(function(t){t.parentElement.removeChild(t)})))}}])&&L(e.prototype,i),t}();function T(t){return function(t){if(Array.isArray(t))return I(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,e){if(t){if("string"==typeof t)return I(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?I(t,e):void 0}}(t)||function(){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 I(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);i12?u-12:0===u?12:u;e=(e=(e=(e=e.replace(/(^|[^\\])HH+/g,"$1"+l(u))).replace(/(^|[^\\])H/g,"$1"+u)).replace(/(^|[^\\])hh+/g,"$1"+l(g))).replace(/(^|[^\\])h/g,"$1"+g);var f=a?t.getUTCMinutes():t.getMinutes();e=(e=e.replace(/(^|[^\\])mm+/g,"$1"+l(f))).replace(/(^|[^\\])m/g,"$1"+f);var p=a?t.getUTCSeconds():t.getSeconds();e=(e=e.replace(/(^|[^\\])ss+/g,"$1"+l(p))).replace(/(^|[^\\])s/g,"$1"+p);var x=a?t.getUTCMilliseconds():t.getMilliseconds();e=e.replace(/(^|[^\\])fff+/g,"$1"+l(x,3)),x=Math.round(x/10),e=e.replace(/(^|[^\\])ff/g,"$1"+l(x)),x=Math.round(x/10);var b=u<12?"AM":"PM";e=(e=(e=e.replace(/(^|[^\\])f/g,"$1"+x)).replace(/(^|[^\\])TT+/g,"$1"+b)).replace(/(^|[^\\])T/g,"$1"+b.charAt(0));var v=b.toLowerCase();e=(e=e.replace(/(^|[^\\])tt+/g,"$1"+v)).replace(/(^|[^\\])t/g,"$1"+v.charAt(0));var m=-t.getTimezoneOffset(),y=a||!m?"Z":m>0?"+":"-";if(!a){var w=(m=Math.abs(m))%60;y+=l(Math.floor(m/60))+":"+l(w)}e=e.replace(/(^|[^\\])K/g,"$1"+y);var k=(a?t.getUTCDay():t.getDay())+1;return(e=(e=(e=(e=e.replace(new RegExp(n[0],"g"),n[k])).replace(new RegExp(o[0],"g"),o[k])).replace(new RegExp(r[0],"g"),r[h])).replace(new RegExp(s[0],"g"),s[h])).replace(/\\(.)/g,"$1")}},{key:"getTimeUnitsfromTimestamp",value:function(t,e,i){var a=this.w;void 0!==a.config.xaxis.min&&(t=a.config.xaxis.min),void 0!==a.config.xaxis.max&&(e=a.config.xaxis.max);var r=this.getDate(t),s=this.getDate(e),n=this.formatDate(r,"yyyy MM dd HH mm ss fff").split(" "),o=this.formatDate(s,"yyyy MM dd HH mm ss fff").split(" ");return{minMillisecond:parseInt(n[6],10),maxMillisecond:parseInt(o[6],10),minSecond:parseInt(n[5],10),maxSecond:parseInt(o[5],10),minMinute:parseInt(n[4],10),maxMinute:parseInt(o[4],10),minHour:parseInt(n[3],10),maxHour:parseInt(o[3],10),minDate:parseInt(n[2],10),maxDate:parseInt(o[2],10),minMonth:parseInt(n[1],10)-1,maxMonth:parseInt(o[1],10)-1,minYear:parseInt(n[0],10),maxYear:parseInt(o[0],10)}}},{key:"isLeapYear",value:function(t){return t%4==0&&t%100!=0||t%400==0}},{key:"calculcateLastDaysOfMonth",value:function(t,e,i){return this.determineDaysOfMonths(t,e)-i}},{key:"determineDaysOfYear",value:function(t){var e=365;return this.isLeapYear(t)&&(e=366),e}},{key:"determineRemainingDaysOfYear",value:function(t,e,i){var a=this.daysCntOfYear[e]+i;return e>1&&this.isLeapYear()&&a++,a}},{key:"determineDaysOfMonths",value:function(t,e){var i=30;switch(t=r.monthMod(t),!0){case this.months30.indexOf(t)>-1:2===t&&(i=this.isLeapYear(e)?29:28);break;case this.months31.indexOf(t)>-1:default:i=31}return i}}])&&E(e.prototype,i),t}();function X(t,e){for(var i=0;i0&&i<100?t.toFixed(1):t.toFixed(0)}return e.globals.isBarHorizontal&&e.globals.maxY-e.globals.minYArr<4?t.toFixed(1):t.toFixed(0)}return t},"function"==typeof e.config.tooltip.x.formatter?e.globals.ttKeyFormatter=e.config.tooltip.x.formatter:e.globals.ttKeyFormatter=e.globals.xLabelFormatter,"function"==typeof e.config.xaxis.tooltip.formatter&&(e.globals.xaxisTooltipFormatter=e.config.xaxis.tooltip.formatter),(Array.isArray(e.config.tooltip.y)||void 0!==e.config.tooltip.y.formatter)&&(e.globals.ttVal=e.config.tooltip.y),void 0!==e.config.tooltip.z.formatter&&(e.globals.ttZFormatter=e.config.tooltip.z.formatter),void 0!==e.config.legend.formatter&&(e.globals.legendFormatter=e.config.legend.formatter),e.config.yaxis.forEach((function(i,a){void 0!==i.labels.formatter?e.globals.yLabelFormatters[a]=i.labels.formatter:e.globals.yLabelFormatters[a]=function(r){return e.globals.xyCharts?Array.isArray(r)?r.map((function(e){return t.defaultYFormatter(e,i,a)})):t.defaultYFormatter(r,i,a):r}})),e.globals}},{key:"heatmapLabelFormatters",value:function(){var t=this.w;if("heatmap"===t.config.chart.type){t.globals.yAxisScale[0].result=t.globals.seriesNames.slice();var e=t.globals.seriesNames.reduce((function(t,e){return t.length>e.length?t:e}),0);t.globals.yAxisScale[0].niceMax=e,t.globals.yAxisScale[0].niceMin=e}}}])&&X(e.prototype,i),t}();function Y(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function D(t){for(var e=1;e\n '.concat(r,'\n - \n ').concat(s,"\n ");return'
'+(i||"")+'
'+a+": "+(t.w.globals.comboCharts?"rangeArea"===t.w.config.series[n].type||"rangeBar"===t.w.config.series[n].type?h:"".concat(c,""):h)+"
"},W=function(){function t(e){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.opts=e}var e,i;return e=t,(i=[{key:"line",value:function(){return{chart:{animations:{easing:"swing"}},dataLabels:{enabled:!1},stroke:{width:5,curve:"straight"},markers:{size:0,hover:{sizeOffset:6}},xaxis:{crosshairs:{width:1}}}}},{key:"sparkline",value:function(t){return this.opts.yaxis[0].show=!1,this.opts.yaxis[0].title.text="",this.opts.yaxis[0].axisBorder.show=!1,this.opts.yaxis[0].axisTicks.show=!1,this.opts.yaxis[0].floating=!0,r.extend(t,{grid:{show:!1,padding:{left:0,right:0,top:0,bottom:0}},legend:{show:!1},xaxis:{labels:{show:!1},tooltip:{enabled:!1},axisBorder:{show:!1},axisTicks:{show:!1}},chart:{toolbar:{show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1}})}},{key:"bar",value:function(){return{chart:{stacked:!1,animations:{easing:"swing"}},plotOptions:{bar:{dataLabels:{position:"center"}}},dataLabels:{style:{colors:["#fff"]},background:{enabled:!1}},stroke:{width:0,lineCap:"round"},fill:{opacity:.85},legend:{markers:{shape:"square",radius:2,size:8}},tooltip:{shared:!1,intersect:!0},xaxis:{tooltip:{enabled:!1},tickPlacement:"between",crosshairs:{width:"barWidth",position:"back",fill:{type:"gradient"},dropShadow:{enabled:!1},stroke:{width:0}}}}}},{key:"candlestick",value:function(){var t=this;return{stroke:{width:1,colors:["#333"]},fill:{opacity:1},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,r=e.w;return t._getBoxTooltip(r,i,a,["Open","High","","Low","Close"],"candlestick")}},states:{active:{filter:{type:"none"}}},xaxis:{crosshairs:{width:1}}}}},{key:"boxPlot",value:function(){var t=this;return{chart:{animations:{dynamicAnimation:{enabled:!1}}},stroke:{width:1,colors:["#24292e"]},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,r=e.w;return t._getBoxTooltip(r,i,a,["Minimum","Q1","Median","Q3","Maximum"],"boxPlot")}},markers:{size:5,strokeWidth:1,strokeColors:"#111"},xaxis:{crosshairs:{width:1}}}}},{key:"rangeBar",value:function(){return{chart:{animations:{animateGradually:!1}},stroke:{width:0,lineCap:"square"},plotOptions:{bar:{borderRadius:0,dataLabels:{position:"center"}}},dataLabels:{enabled:!1,formatter:function(t,e){e.ctx;var i=e.seriesIndex,a=e.dataPointIndex,r=e.w,s=function(){var t=r.globals.seriesRangeStart[i][a];return r.globals.seriesRangeEnd[i][a]-t};return r.globals.comboCharts?"rangeBar"===r.config.series[i].type||"rangeArea"===r.config.series[i].type?s():t:s()},background:{enabled:!1},style:{colors:["#fff"]}},markers:{size:10},tooltip:{shared:!1,followCursor:!0,custom:function(t){return t.w.config.plotOptions&&t.w.config.plotOptions.bar&&t.w.config.plotOptions.bar.horizontal?function(t){var e=H(D(D({},t),{},{isTimeline:!0})),i=e.color,a=e.seriesName,r=e.ylabel,s=e.startVal,n=e.endVal;return N(D(D({},t),{},{color:i,seriesName:a,ylabel:r,start:s,end:n}))}(t):function(t){var e=H(t),i=e.color,a=e.seriesName,r=e.ylabel,s=e.start,n=e.end;return N(D(D({},t),{},{color:i,seriesName:a,ylabel:r,start:s,end:n}))}(t)}},xaxis:{tickPlacement:"between",tooltip:{enabled:!1},crosshairs:{stroke:{width:0}}}}}},{key:"dumbbell",value:function(t){var e,i;return null!==(e=t.plotOptions.bar)&&void 0!==e&&e.barHeight||(t.plotOptions.bar.barHeight=2),null!==(i=t.plotOptions.bar)&&void 0!==i&&i.columnWidth||(t.plotOptions.bar.columnWidth=2),t}},{key:"area",value:function(){return{stroke:{width:4,fill:{type:"solid",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}}},fill:{type:"gradient",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}},markers:{size:0,hover:{sizeOffset:6}},tooltip:{followCursor:!1}}}},{key:"rangeArea",value:function(){return{stroke:{curve:"straight",width:0},fill:{type:"solid",opacity:.6},markers:{size:0},states:{hover:{filter:{type:"none"}},active:{filter:{type:"none"}}},tooltip:{intersect:!1,shared:!0,followCursor:!0,custom:function(t){return function(t){var e=H(t),i=e.color,a=e.seriesName,r=e.ylabel,s=e.start,n=e.end;return N(D(D({},t),{},{color:i,seriesName:a,ylabel:r,start:s,end:n}))}(t)}}}}},{key:"brush",value:function(t){return r.extend(t,{chart:{toolbar:{autoSelected:"selection",show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1},stroke:{width:1},tooltip:{enabled:!1},xaxis:{tooltip:{enabled:!1}}})}},{key:"stacked100",value:function(t){t.dataLabels=t.dataLabels||{},t.dataLabels.formatter=t.dataLabels.formatter||void 0;var e=t.dataLabels.formatter;return t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})),"bar"===t.chart.type&&(t.dataLabels.formatter=e||function(t){return"number"==typeof t&&t?t.toFixed(0)+"%":t}),t}},{key:"stackedBars",value:function(){var t=this.bar();return D(D({},t),{},{plotOptions:D(D({},t.plotOptions),{},{bar:D(D({},t.plotOptions.bar),{},{borderRadiusApplication:"end",borderRadiusWhenStacked:"last"})})})}},{key:"convertCatToNumeric",value:function(t){return t.xaxis.convertedCatToNumeric=!0,t}},{key:"convertCatToNumericXaxis",value:function(t,e,i){t.xaxis.type="numeric",t.xaxis.labels=t.xaxis.labels||{},t.xaxis.labels.formatter=t.xaxis.labels.formatter||function(t){return r.isNumber(t)?Math.floor(t):t};var a=t.xaxis.labels.formatter,s=t.xaxis.categories&&t.xaxis.categories.length?t.xaxis.categories:t.labels;return i&&i.length&&(s=i.map((function(t){return Array.isArray(t)?t:String(t)}))),s&&s.length&&(t.xaxis.labels.formatter=function(t){return r.isNumber(t)?a(s[Math.floor(t)-1]):a(t)}),t.xaxis.categories=[],t.labels=[],t.xaxis.tickAmount=t.xaxis.tickAmount||"dataPoints",t}},{key:"bubble",value:function(){return{dataLabels:{style:{colors:["#fff"]}},tooltip:{shared:!1,intersect:!0},xaxis:{crosshairs:{width:0}},fill:{type:"solid",gradient:{shade:"light",inverse:!0,shadeIntensity:.55,opacityFrom:.4,opacityTo:.8}}}}},{key:"scatter",value:function(){return{dataLabels:{enabled:!1},tooltip:{shared:!1,intersect:!0},markers:{size:6,strokeWidth:1,hover:{sizeOffset:2}}}}},{key:"heatmap",value:function(){return{chart:{stacked:!1},fill:{opacity:1},dataLabels:{style:{colors:["#fff"]}},stroke:{colors:["#fff"]},tooltip:{followCursor:!0,marker:{show:!1},x:{show:!1}},legend:{position:"top",markers:{shape:"square",size:10,offsetY:2}},grid:{padding:{right:20}}}}},{key:"treemap",value:function(){return{chart:{zoom:{enabled:!1}},dataLabels:{style:{fontSize:14,fontWeight:600,colors:["#fff"]}},stroke:{show:!0,width:2,colors:["#fff"]},legend:{show:!1},fill:{gradient:{stops:[0,100]}},tooltip:{followCursor:!0,x:{show:!1}},grid:{padding:{left:0,right:0}},xaxis:{crosshairs:{show:!1},tooltip:{enabled:!1}}}}},{key:"pie",value:function(){return{chart:{toolbar:{show:!1}},plotOptions:{pie:{donut:{labels:{show:!1}}}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",stops:[0,100]}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"donut",value:function(){return{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",shadeIntensity:.35,stops:[80,100],opacityFrom:1,opacityTo:1}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"polarArea",value:function(){return this.opts.yaxis[0].tickAmount=this.opts.yaxis[0].tickAmount?this.opts.yaxis[0].tickAmount:6,{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},enabled:!1},stroke:{show:!0,width:2},fill:{opacity:.7},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"radar",value:function(){return this.opts.yaxis[0].labels.offsetY=this.opts.yaxis[0].labels.offsetY?this.opts.yaxis[0].labels.offsetY:6,{dataLabels:{enabled:!1,style:{fontSize:"11px"}},stroke:{width:2},markers:{size:3,strokeWidth:1,strokeOpacity:1},fill:{opacity:.2},tooltip:{shared:!1,intersect:!0,followCursor:!0},grid:{show:!1},xaxis:{labels:{formatter:function(t){return t},style:{colors:["#a8a8a8"],fontSize:"11px"}},tooltip:{enabled:!1},crosshairs:{show:!1}}}}},{key:"radialBar",value:function(){return{chart:{animations:{dynamicAnimation:{enabled:!0,speed:800}},toolbar:{show:!1}},fill:{gradient:{shade:"dark",shadeIntensity:.4,inverseColors:!1,type:"diagonal2",opacityFrom:1,opacityTo:1,stops:[70,98,100]}},legend:{show:!1,position:"right"},tooltip:{enabled:!1,fillSeriesColor:!0}}}},{key:"_getBoxTooltip",value:function(t,e,i,a,r){var s=t.globals.seriesCandleO[e][i],n=t.globals.seriesCandleH[e][i],o=t.globals.seriesCandleM[e][i],l=t.globals.seriesCandleL[e][i],c=t.globals.seriesCandleC[e][i];return t.config.series[e].type&&t.config.series[e].type!==r?'
\n '.concat(t.config.series[e].name?t.config.series[e].name:"series-"+(e+1),": ").concat(t.globals.series[e][i],"\n
"):'
')+"
".concat(a[0],': ')+s+"
"+"
".concat(a[1],': ')+n+"
"+(o?"
".concat(a[2],': ')+o+"
":"")+"
".concat(a[3],': ')+l+"
"+"
".concat(a[4],': ')+c+"
"}}])&&F(e.prototype,i),t}();function j(t){return j="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},j(t)}function B(t,e){for(var i=0;i1&&s.length!==t.yaxis.length&&console.warn("A multi-series logarithmic chart should have equal number of series and y-axes. Please make sure to equalize both."),t}},{key:"extendAnnotations",value:function(t){return void 0===t.annotations&&(t.annotations={},t.annotations.yaxis=[],t.annotations.xaxis=[],t.annotations.points=[]),t=this.extendYAxisAnnotations(t),t=this.extendXAxisAnnotations(t),this.extendPointAnnotations(t)}},{key:"extendYAxisAnnotations",value:function(t){var e=new P;return t.annotations.yaxis=r.extendArray(void 0!==t.annotations.yaxis?t.annotations.yaxis:[],e.yAxisAnnotation),t}},{key:"extendXAxisAnnotations",value:function(t){var e=new P;return t.annotations.xaxis=r.extendArray(void 0!==t.annotations.xaxis?t.annotations.xaxis:[],e.xAxisAnnotation),t}},{key:"extendPointAnnotations",value:function(t){var e=new P;return t.annotations.points=r.extendArray(void 0!==t.annotations.points?t.annotations.points:[],e.pointAnnotation),t}},{key:"checkForDarkTheme",value:function(t){t.theme&&"dark"===t.theme.mode&&(t.tooltip||(t.tooltip={}),"light"!==t.tooltip.theme&&(t.tooltip.theme="dark"),t.chart.foreColor||(t.chart.foreColor="#f6f7f8"),t.chart.background||(t.chart.background="#424242"),t.theme.palette||(t.theme.palette="palette4"))}},{key:"handleUserInputErrors",value:function(t){var e=t;if(e.tooltip.shared&&e.tooltip.intersect)throw new Error("tooltip.shared cannot be enabled when tooltip.intersect is true. Turn off any other option by setting it to false.");if("bar"===e.chart.type&&e.plotOptions.bar.horizontal){if(e.yaxis.length>1)throw new Error("Multiple Y Axis for bars are not supported. Switch to column chart by setting plotOptions.bar.horizontal=false");e.yaxis[0].reversed&&(e.yaxis[0].opposite=!0),e.xaxis.tooltip.enabled=!1,e.yaxis[0].tooltip.enabled=!1,e.chart.zoom.enabled=!1}return"bar"!==e.chart.type&&"rangeBar"!==e.chart.type||e.tooltip.shared&&"barWidth"===e.xaxis.crosshairs.width&&e.series.length>1&&(e.xaxis.crosshairs.width="tickWidth"),"candlestick"!==e.chart.type&&"boxPlot"!==e.chart.type||e.yaxis[0].reversed&&(console.warn("Reversed y-axis in ".concat(e.chart.type," chart is not supported.")),e.yaxis[0].reversed=!1),e}}])&&B(e.prototype,i),t}();function V(t,e){for(var i=0;ir?a:r,n=t.image,o=0,l=0;void 0===t.width&&void 0===t.height?void 0!==i.fill.image.width&&void 0!==i.fill.image.height?(o=i.fill.image.width+1,l=i.fill.image.height):(o=s+1,l=s):(o=t.width,l=t.height);var c=document.createElementNS(e.globals.SVGNS,"pattern");g.setAttrs(c,{id:t.patternID,patternUnits:t.patternUnits?t.patternUnits:"userSpaceOnUse",width:o+"px",height:l+"px"});var h=document.createElementNS(e.globals.SVGNS,"image");c.appendChild(h),h.setAttributeNS(window.SVG.xlink,"href",n),g.setAttrs(h,{x:0,y:0,preserveAspectRatio:"none",width:o+"px",height:l+"px"}),h.style.opacity=t.opacity,e.globals.dom.elDefs.node.appendChild(c)}},{key:"getSeriesIndex",value:function(t){var e=this.w;return("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||"heatmap"===e.config.chart.type||"treemap"===e.config.chart.type?this.seriesIndex=t.seriesNumber:this.seriesIndex=t.seriesNumber%e.globals.series.length,this.seriesIndex}},{key:"fillPath",value:function(t){var e=this.w;this.opts=t;var i,a,s,n=this.w.config;this.seriesIndex=this.getSeriesIndex(t);var o=this.getFillColors()[this.seriesIndex];void 0!==e.globals.seriesColors[this.seriesIndex]&&(o=e.globals.seriesColors[this.seriesIndex]),"function"==typeof o&&(o=o({seriesIndex:this.seriesIndex,dataPointIndex:t.dataPointIndex,value:t.value,w:e}));var l=t.fillType?t.fillType:this.getFillType(this.seriesIndex),c=Array.isArray(n.fill.opacity)?n.fill.opacity[this.seriesIndex]:n.fill.opacity;t.color&&(o=t.color);var h=o;if(-1===o.indexOf("rgb")?o.length<9&&(h=r.hexToRgba(o,c)):o.indexOf("rgba")>-1&&(c=r.getOpacityFromRGBA(o)),t.opacity&&(c=t.opacity),"pattern"===l&&(a=this.handlePatternFill({fillConfig:t.fillConfig,patternFill:a,fillColor:o,fillOpacity:c,defaultColor:h})),"gradient"===l&&(s=this.handleGradientFill({fillConfig:t.fillConfig,fillColor:o,fillOpacity:c,i:this.seriesIndex})),"image"===l){var d=n.fill.image.src,u=t.patternID?t.patternID:"";this.clippedImgArea({opacity:c,image:Array.isArray(d)?t.seriesNumber-1&&(f=r.getOpacityFromRGBA(u));var p=void 0===n.gradient.opacityTo?i:Array.isArray(n.gradient.opacityTo)?n.gradient.opacityTo[s]:n.gradient.opacityTo;if(void 0===n.gradient.gradientToColors||0===n.gradient.gradientToColors.length)o="dark"===n.gradient.shade?h.shadeColor(-1*parseFloat(n.gradient.shadeIntensity),e.indexOf("rgb")>-1?r.rgb2hex(e):e):h.shadeColor(parseFloat(n.gradient.shadeIntensity),e.indexOf("rgb")>-1?r.rgb2hex(e):e);else if(n.gradient.gradientToColors[l.seriesNumber]){var x=n.gradient.gradientToColors[l.seriesNumber];o=x,x.indexOf("rgba")>-1&&(p=r.getOpacityFromRGBA(x))}else o=e;if(n.gradient.gradientFrom&&(u=n.gradient.gradientFrom),n.gradient.gradientTo&&(o=n.gradient.gradientTo),n.gradient.inverseColors){var b=u;u=o,o=b}return u.indexOf("rgb")>-1&&(u=r.rgb2hex(u)),o.indexOf("rgb")>-1&&(o=r.rgb2hex(o)),c.drawGradient(d,u,o,f,p,l.size,n.gradient.stops,n.gradient.colorStops,s)}}])&&Q(e.prototype,i),t}();function tt(t,e){for(var i=0;i0){if(t.globals.markers.size.length4&&void 0!==arguments[4]&&arguments[4],o=this.w,c=e,h=t,d=null,u=new g(this.ctx),f=o.config.markers.discrete&&o.config.markers.discrete.length;if((o.globals.markers.size[e]>0||n||f)&&(d=u.group({class:n||f?"":"apexcharts-series-markers"})).attr("clip-path","url(#gridRectMarkerMask".concat(o.globals.cuid,")")),Array.isArray(h.x))for(var p=0;p0:o.config.markers.size>0)||n||f){r.isNumber(h.y[p])?b+=" w".concat(r.randomId()):b="apexcharts-nullpoint";var v=this.getMarkerConfig({cssClass:b,seriesIndex:e,dataPointIndex:x});o.config.series[c].data[x]&&(o.config.series[c].data[x].fillColor&&(v.pointFillColor=o.config.series[c].data[x].fillColor),o.config.series[c].data[x].strokeColor&&(v.pointStrokeColor=o.config.series[c].data[x].strokeColor)),a&&(v.pSize=a),(h.x[p]<0||h.x[p]>o.globals.gridWidth||h.y[p]<0||h.y[p]>o.globals.gridHeight)&&(v.pSize=0),(s=u.drawMarker(h.x[p],h.y[p],v)).attr("rel",x),s.attr("j",x),s.attr("index",e),s.node.setAttribute("default-marker-size",v.pSize),new l(this.ctx).setSelectionFilter(s,e,x),this.addEvents(s),d&&d.add(s)}else void 0===o.globals.pointsArray[e]&&(o.globals.pointsArray[e]=[]),o.globals.pointsArray[e].push([h.x[p],h.y[p]])}return d}},{key:"getMarkerConfig",value:function(t){var e=t.cssClass,i=t.seriesIndex,a=t.dataPointIndex,r=void 0===a?null:a,s=t.finishRadius,n=void 0===s?null:s,o=this.w,l=this.getMarkerStyle(i),c=o.globals.markers.size[i],h=o.config.markers;return null!==r&&h.discrete.length&&h.discrete.map((function(t){t.seriesIndex===i&&t.dataPointIndex===r&&(l.pointStrokeColor=t.strokeColor,l.pointFillColor=t.fillColor,c=t.size,l.pointShape=t.shape)})),{pSize:null===n?c:n,pRadius:h.radius,width:Array.isArray(h.width)?h.width[i]:h.width,height:Array.isArray(h.height)?h.height[i]:h.height,pointStrokeWidth:Array.isArray(h.strokeWidth)?h.strokeWidth[i]:h.strokeWidth,pointStrokeColor:l.pointStrokeColor,pointFillColor:l.pointFillColor,shape:l.pointShape||(Array.isArray(h.shape)?h.shape[i]:h.shape),class:e,pointStrokeOpacity:Array.isArray(h.strokeOpacity)?h.strokeOpacity[i]:h.strokeOpacity,pointStrokeDashArray:Array.isArray(h.strokeDashArray)?h.strokeDashArray[i]:h.strokeDashArray,pointFillOpacity:Array.isArray(h.fillOpacity)?h.fillOpacity[i]:h.fillOpacity,seriesIndex:i}}},{key:"addEvents",value:function(t){var e=this.w,i=new g(this.ctx);t.node.addEventListener("mouseenter",i.pathMouseEnter.bind(this.ctx,t)),t.node.addEventListener("mouseleave",i.pathMouseLeave.bind(this.ctx,t)),t.node.addEventListener("mousedown",i.pathMouseDown.bind(this.ctx,t)),t.node.addEventListener("click",e.config.markers.onClick),t.node.addEventListener("dblclick",e.config.markers.onDblClick),t.node.addEventListener("touchstart",i.pathMouseDown.bind(this.ctx,t),{passive:!0})}},{key:"getMarkerStyle",value:function(t){var e=this.w,i=e.globals.markers.colors,a=e.config.markers.strokeColor||e.config.markers.strokeColors;return{pointStrokeColor:Array.isArray(a)?a[t]:a,pointFillColor:Array.isArray(i)?i[t]:i}}}],i&&tt(e.prototype,i),t}();function it(t,e){for(var i=0;ix.maxBubbleRadius&&(p=x.maxBubbleRadius)}a.config.chart.animations.enabled||(f=p);var b=n.x[h],v=n.y[h];if(f=f||0,null!==v&&void 0!==a.globals.series[s][d]||(u=!1),u){var m=this.drawPoint(b,v,f,p,s,d,e);c.add(m)}l.add(c)}}},{key:"drawPoint",value:function(t,e,i,a,r,s,o){var c=this.w,h=r,d=new n(this.ctx),u=new l(this.ctx),f=new K(this.ctx),p=new et(this.ctx),x=new g(this.ctx),b=p.getMarkerConfig({cssClass:"apexcharts-marker",seriesIndex:h,dataPointIndex:s,finishRadius:"bubble"===c.config.chart.type||c.globals.comboCharts&&c.config.series[r]&&"bubble"===c.config.series[r].type?a:null});a=b.pSize;var v,m=f.fillPath({seriesNumber:r,dataPointIndex:s,color:b.pointFillColor,patternUnits:"objectBoundingBox",value:c.globals.series[r][o]});if("circle"===b.shape?v=x.drawCircle(i):"square"!==b.shape&&"rect"!==b.shape||(v=x.drawRect(0,0,b.width-b.pointStrokeWidth/2,b.height-b.pointStrokeWidth/2,b.pRadius)),c.config.series[h].data[s]&&c.config.series[h].data[s].fillColor&&(m=c.config.series[h].data[s].fillColor),v.attr({x:t-b.width/2-b.pointStrokeWidth/2,y:e-b.height/2-b.pointStrokeWidth/2,cx:t,cy:e,fill:m,"fill-opacity":b.pointFillOpacity,stroke:b.pointStrokeColor,r:a,"stroke-width":b.pointStrokeWidth,"stroke-dasharray":b.pointStrokeDashArray,"stroke-opacity":b.pointStrokeOpacity}),c.config.chart.dropShadow.enabled){var y=c.config.chart.dropShadow;u.dropShadow(v,y,r)}if(!this.initialAnim||c.globals.dataChanged||c.globals.resized)c.globals.animationEnded=!0;else{var w=c.config.chart.animations.speed;d.animateMarker(v,0,"circle"===b.shape?a:{width:b.width,height:b.height},w,c.globals.easing,(function(){window.setTimeout((function(){d.animationCompleted(v)}),100)}))}if(c.globals.dataChanged&&"circle"===b.shape)if(this.dynamicAnim){var k,A,S,C,P=c.config.chart.animations.dynamicAnimation.speed;null!=(C=c.globals.previousPaths[r]&&c.globals.previousPaths[r][o])&&(k=C.x,A=C.y,S=void 0!==C.r?C.r:a);for(var L=0;Lo.globals.gridHeight+d&&(e=o.globals.gridHeight+d/2),void 0===o.globals.dataLabelsRects[a]&&(o.globals.dataLabelsRects[a]=[]),o.globals.dataLabelsRects[a].push({x:t,y:e,width:h,height:d});var u=o.globals.dataLabelsRects[a].length-2,f=void 0!==o.globals.lastDrawnDataLabelsIndexes[a]?o.globals.lastDrawnDataLabelsIndexes[a][o.globals.lastDrawnDataLabelsIndexes[a].length-1]:0;if(void 0!==o.globals.dataLabelsRects[a][u]){var p=o.globals.dataLabelsRects[a][f];(t>p.x+p.width+2||e>p.y+p.height+2||t+he.globals.gridWidth+b.textRects.width+10)&&(o="");var v=e.globals.dataLabels.style.colors[s];(("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||e.config.dataLabels.distributed)&&(v=e.globals.dataLabels.style.colors[n]),"function"==typeof v&&(v=v({series:e.globals.series,seriesIndex:s,dataPointIndex:n,w:e})),f&&(v=f);var m=u.offsetX,y=u.offsetY;if("bar"!==e.config.chart.type&&"rangeBar"!==e.config.chart.type||(m=0,y=0),b.drawnextLabel){var w=i.drawText({width:100,height:parseInt(u.style.fontSize,10),x:a+m,y:r+y,foreColor:v,textAnchor:c||u.textAnchor,text:o,fontSize:h||u.style.fontSize,fontFamily:u.style.fontFamily,fontWeight:u.style.fontWeight||"normal"});if(w.attr({class:"apexcharts-datalabel",cx:a,cy:r}),u.dropShadow.enabled){var k=u.dropShadow;new l(this.ctx).dropShadow(w,k)}d.add(w),void 0===e.globals.lastDrawnDataLabelsIndexes[s]&&(e.globals.lastDrawnDataLabelsIndexes[s]=[]),e.globals.lastDrawnDataLabelsIndexes[s].push(n)}}}},{key:"addBackgroundToDataLabel",value:function(t,e){var i=this.w,a=i.config.dataLabels.background,r=a.padding,s=a.padding/2,n=e.width,o=e.height,c=new g(this.ctx).drawRect(e.x-r,e.y-s/2,n+2*r,o+s,a.borderRadius,"transparent"===i.config.chart.background?"#fff":i.config.chart.background,a.opacity,a.borderWidth,a.borderColor);return a.dropShadow.enabled&&new l(this.ctx).dropShadow(c,a.dropShadow),c}},{key:"dataLabelsBackground",value:function(){var t=this.w;if("bubble"!==t.config.chart.type)for(var e=t.globals.dom.baseEl.querySelectorAll(".apexcharts-datalabels text"),i=0;i0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w,s=r.clone(a.globals.initialSeries);a.globals.previousPaths=[],i?(a.globals.collapsedSeries=[],a.globals.ancillaryCollapsedSeries=[],a.globals.collapsedSeriesIndices=[],a.globals.ancillaryCollapsedSeriesIndices=[]):s=this.emptyCollapsedSeries(s),a.config.series=s,t&&(e&&(a.globals.zoomed=!1,this.ctx.updateHelpers.revertDefaultAxisMinMax()),this.ctx.updateHelpers._updateSeries(s,a.config.chart.animations.dynamicAnimation.enabled))}},{key:"emptyCollapsedSeries",value:function(t){for(var e=this.w,i=0;i-1&&(t[i].data=[]);return t}},{key:"toggleSeriesOnHover",value:function(t,e){var i=this.w;e||(e=t.target);var a=i.globals.dom.baseEl.querySelectorAll(".apexcharts-series, .apexcharts-datalabels");if("mousemove"===t.type){var r=parseInt(e.getAttribute("rel"),10)-1,s=null,n=null;i.globals.axisCharts||"radialBar"===i.config.chart.type?i.globals.axisCharts?(s=i.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(r,"']")),n=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels[data\\:realIndex='".concat(r,"']"))):s=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(r+1,"']")):s=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(r+1,"'] path"));for(var o=0;o=t.from&&a<=t.to&&r[e].classList.remove(i.legendInactiveClass)}}(a.config.plotOptions.heatmap.colorScale.ranges[n])}else"mouseout"===t.type&&s("remove")}},{key:"getActiveConfigSeriesIndex",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"asc",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],i=this.w,a=0;if(i.config.series.length>1)for(var r=i.config.series.map((function(t,a){return t.data&&t.data.length>0&&-1===i.globals.collapsedSeriesIndices.indexOf(a)&&(!i.globals.comboCharts||0===e.length||e.length&&e.indexOf(i.config.series[a].type)>-1)?a:-1})),s="asc"===t?0:r.length-1;"asc"===t?s=0;"asc"===t?s++:s--)if(-1!==r[s]){a=r[s];break}return a}},{key:"getBarSeriesIndices",value:function(){return this.w.globals.comboCharts?this.w.config.series.map((function(t,e){return"bar"===t.type||"column"===t.type?e:-1})).filter((function(t){return-1!==t})):this.w.config.series.map((function(t,e){return e}))}},{key:"getPreviousPaths",value:function(){var t=this.w;function e(e,i,a){for(var r=e[i].childNodes,s={type:a,paths:[],realIndex:e[i].getAttribute("data:realIndex")},n=0;n0)for(var a=function(e){for(var i=t.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(t.config.chart.type," .apexcharts-series[data\\:realIndex='").concat(e,"'] rect")),a=[],r=function(t){var e=function(e){return i[t].getAttribute(e)},r={x:parseFloat(e("x")),y:parseFloat(e("y")),width:parseFloat(e("width")),height:parseFloat(e("height"))};a.push({rect:r,color:i[t].getAttribute("color")})},s=0;s0)for(var a=0;a0?t:[]}))}}],i&&nt(e.prototype,i),t}();function lt(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);i0&&null!==t[this.activeSeriesIndex].data[0]&&void 0!==t[this.activeSeriesIndex].data[0].x&&null!==t[this.activeSeriesIndex].data[0])return!0}},{key:"isFormat2DArray",value:function(){var t=this.w.config.series.slice(),e=new ot(this.ctx);if(this.activeSeriesIndex=e.getActiveConfigSeriesIndex(),void 0!==t[this.activeSeriesIndex].data&&t[this.activeSeriesIndex].data.length>0&&void 0!==t[this.activeSeriesIndex].data[0]&&null!==t[this.activeSeriesIndex].data[0]&&t[this.activeSeriesIndex].data[0].constructor===Array)return!0}},{key:"handleFormat2DArray",value:function(t,e){for(var i=this.w.config,a=this.w.globals,s="boxPlot"===i.chart.type||"boxPlot"===i.series[e].type,n=0;n=5?this.twoDSeries.push(r.parseNumber(t[e].data[n][4])):this.twoDSeries.push(r.parseNumber(t[e].data[n][1])),a.dataFormatXNumeric=!0),"datetime"===i.xaxis.type){var o=new Date(t[e].data[n][0]);o=new Date(o).getTime(),this.twoDSeriesX.push(o)}else this.twoDSeriesX.push(t[e].data[n][0]);for(var l=0;l-1&&(n=this.activeSeriesIndex);for(var o=0;o1&&void 0!==arguments[1]?arguments[1]:this.ctx,n=this.w.config,o=this.w.globals,l=new M(s),c=n.labels.length>0?n.labels.slice():n.xaxis.categories.slice();if(o.isRangeBar="rangeBar"===n.chart.type&&o.isBarHorizontal,o.hasXaxisGroups="category"===n.xaxis.type&&n.xaxis.group.groups.length>0,o.hasXaxisGroups&&(o.groups=n.xaxis.group.groups),o.hasSeriesGroups=null===(e=t[0])||void 0===e?void 0:e.group,o.hasSeriesGroups){var h=[],d=function(t){if(Array.isArray(t))return lt(t)}(i=new Set(t.map((function(t){return t.group}))))||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(i)||function(t,e){if(t){if("string"==typeof t)return lt(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?lt(t,e):void 0}}(i)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}();t.forEach((function(t,e){var i=d.indexOf(t.group);h[i]||(h[i]=[]),h[i].push(t.name)})),o.seriesGroups=h}for(var u=function(){for(var t=0;t0&&(this.twoDSeriesX=c,o.seriesX.push(this.twoDSeriesX))),o.labels.push(this.twoDSeriesX);var f=t[g].data.map((function(t){return r.parseNumber(t)}));o.series.push(f)}o.seriesZ.push(this.threeDSeries),void 0!==t[g].name?o.seriesNames.push(t[g].name):o.seriesNames.push("series-"+parseInt(g+1,10)),void 0!==t[g].color?o.seriesColors.push(t[g].color):o.seriesColors.push(void 0)}return this.w}},{key:"parseDataNonAxisCharts",value:function(t){var e=this.w.globals,i=this.w.config;e.series=t.slice(),e.seriesNames=i.labels.slice();for(var a=0;a0?i.labels=e.xaxis.categories:e.labels.length>0?i.labels=e.labels.slice():this.fallbackToCategory?(i.labels=i.labels[0],i.seriesRange.length&&(i.seriesRange.map((function(t){t.forEach((function(t){i.labels.indexOf(t.x)<0&&t.x&&i.labels.push(t.x)}))})),i.labels=i.labels.filter((function(t,e,i){return i.indexOf(t)===e}))),e.xaxis.convertedCatToNumeric&&(new W(e).convertCatToNumericXaxis(e,this.ctx,i.seriesX[0]),this._generateExternalLabels(t))):this._generateExternalLabels(t)}},{key:"_generateExternalLabels",value:function(t){var e=this.w.globals,i=this.w.config,a=[];if(e.axisCharts){if(e.series.length>0)if(this.isFormatXY())for(var r=i.series.map((function(t,e){return t.data.filter((function(t,e,i){return i.findIndex((function(e){return e.x===t.x}))===e}))})),s=r.reduce((function(t,e,i,a){return a[t].length>e.length?t:i}),0),n=0;n4&&void 0!==arguments[4]?arguments[4]:[],o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"12px",l=!(arguments.length>6&&void 0!==arguments[6])||arguments[6],c=this.w,h=void 0===t[a]?"":t[a],d=h,u=c.globals.xLabelFormatter,f=c.config.xaxis.labels.formatter,p=!1,x=new z(this.ctx),b=h;l&&(d=x.xLabelFormat(u,h,b,{i:a,dateFormatter:new M(this.ctx).formatDate,w:c}),void 0!==f&&(d=f(h,t[a],{i:a,dateFormatter:new M(this.ctx).formatDate,w:c}))),e.length>0?(r=e[a].unit,s=null,e.forEach((function(t){"month"===t.unit?s="year":"day"===t.unit?s="month":"hour"===t.unit?s="day":"minute"===t.unit&&(s="hour")})),p=s===r,i=e[a].position,d=e[a].value):"datetime"===c.config.xaxis.type&&void 0===f&&(d=""),void 0===d&&(d=""),d=Array.isArray(d)?d:d.toString();var v,m=new g(this.ctx);v=c.globals.rotateXLabels&&l?m.getTextRects(d,parseInt(o,10),null,"rotate(".concat(c.config.xaxis.labels.rotate," 0 0)"),!1):m.getTextRects(d,parseInt(o,10));var y=!c.config.xaxis.labels.showDuplicates&&this.ctx.timeScale;return!Array.isArray(d)&&(0===d.indexOf("NaN")||0===d.toLowerCase().indexOf("invalid")||d.toLowerCase().indexOf("infinity")>=0||n.indexOf(d)>=0&&y)&&(d=""),{x:i,text:d,textRect:v,isBold:p}}},{key:"checkLabelBasedOnTickamount",value:function(t,e,i){var a=this.w,r=a.config.xaxis.tickAmount;return"dataPoints"===r&&(r=Math.round(a.globals.gridWidth/120)),r>i||t%Math.round(i/(r+1))==0||(e.text=""),e}},{key:"checkForOverflowingLabels",value:function(t,e,i,a,r){var s=this.w;if(0===t&&s.globals.skipFirstTimelinelabel&&(e.text=""),t===i-1&&s.globals.skipLastTimelinelabel&&(e.text=""),s.config.xaxis.labels.hideOverlappingLabels&&a.length>0){var n=r[r.length-1];e.x0){!0===o.config.yaxis[r].opposite&&(t+=a.width);for(var h=e;h>=0;h--){var d=c+e/10+o.config.yaxis[r].labels.offsetY-1;o.globals.isBarHorizontal&&(d=s*h),"heatmap"===o.config.chart.type&&(d+=s/2);var u=l.drawLine(t+i.offsetX-a.width+a.offsetX,d+a.offsetY,t+i.offsetX+a.offsetX,d+a.offsetY,a.color);n.add(u),c+=s}}}}],i&&dt(e.prototype,i),t}();function gt(t){return function(t){if(Array.isArray(t))return ft(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,e){if(t){if("string"==typeof t)return ft(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?ft(t,e):void 0}}(t)||function(){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 ft(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);i=10?c.config.chart.toolbar.export.csv.dateFormatter(s):r.isNumber(s)?s:s.split(n).join("")));for(var o=0;o0&&!a.globals.isBarHorizontal&&(this.xaxisLabels=a.globals.timescaleLabels.slice()),a.config.xaxis.overwriteCategories&&(this.xaxisLabels=a.config.xaxis.overwriteCategories),this.drawnLabels=[],this.drawnLabelsRects=[],"top"===a.config.xaxis.position?this.offY=0:this.offY=a.globals.gridHeight+1,this.offY=this.offY+a.config.xaxis.axisBorder.offsetY,this.isCategoryBarHorizontal="bar"===a.config.chart.type&&a.config.plotOptions.bar.horizontal,this.xaxisFontSize=a.config.xaxis.labels.style.fontSize,this.xaxisFontFamily=a.config.xaxis.labels.style.fontFamily,this.xaxisForeColors=a.config.xaxis.labels.style.colors,this.xaxisBorderWidth=a.config.xaxis.axisBorder.width,this.isCategoryBarHorizontal&&(this.xaxisBorderWidth=a.config.yaxis[0].axisBorder.width.toString()),this.xaxisBorderWidth.indexOf("%")>-1?this.xaxisBorderWidth=a.globals.gridWidth*parseInt(this.xaxisBorderWidth,10)/100:this.xaxisBorderWidth=parseInt(this.xaxisBorderWidth,10),this.xaxisBorderHeight=a.config.xaxis.axisBorder.height,this.yaxis=a.config.yaxis[0]}var e,i;return e=t,i=[{key:"drawXaxis",value:function(){var t=this.w,e=new g(this.ctx),i=e.group({class:"apexcharts-xaxis",transform:"translate(".concat(t.config.xaxis.offsetX,", ").concat(t.config.xaxis.offsetY,")")}),a=e.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(t.globals.translateXAxisX,", ").concat(t.globals.translateXAxisY,")")});i.add(a);for(var r=[],s=0;s6&&void 0!==arguments[6]?arguments[6]:{},c=[],h=[],d=this.w,u=l.xaxisFontSize||this.xaxisFontSize,g=l.xaxisFontFamily||this.xaxisFontFamily,f=l.xaxisForeColors||this.xaxisForeColors,p=l.fontWeight||d.config.xaxis.labels.style.fontWeight,x=l.cssClass||d.config.xaxis.labels.style.cssClass,b=d.globals.padHorizontal,v=a.length,m="category"===d.config.xaxis.type?d.globals.dataPoints:v;if(0===m&&v>m&&(m=v),r){var y=m>1?m-1:m;n=d.globals.gridWidth/y,b=b+s(0,n)/2+d.config.xaxis.labels.offsetX}else n=d.globals.gridWidth/m,b=b+s(0,n)+d.config.xaxis.labels.offsetX;for(var w=function(r){var l=b-s(r,n)/2+d.config.xaxis.labels.offsetX;0===r&&1===v&&n/2===b&&1===m&&(l=d.globals.gridWidth/2);var y=o.axesUtils.getLabel(a,d.globals.timescaleLabels,l,r,c,u,t),w=28;if(d.globals.rotateXLabels&&t&&(w=22),d.config.xaxis.title.text&&"top"===d.config.xaxis.position&&(w+=parseFloat(d.config.xaxis.title.style.fontSize)+2),t||(w=w+parseFloat(u)+(d.globals.xAxisLabelsHeight-d.globals.xAxisGroupLabelsHeight)+(d.globals.rotateXLabels?10:0)),y=void 0!==d.config.xaxis.tickAmount&&"dataPoints"!==d.config.xaxis.tickAmount&&"datetime"!==d.config.xaxis.type?o.axesUtils.checkLabelBasedOnTickamount(r,y,v):o.axesUtils.checkForOverflowingLabels(r,y,v,c,h),d.config.xaxis.labels.show){var k=e.drawText({x:y.x,y:o.offY+d.config.xaxis.labels.offsetY+w-("top"===d.config.xaxis.position?d.globals.xAxisHeight+d.config.xaxis.axisTicks.height-2:0),text:y.text,textAnchor:"middle",fontWeight:y.isBold?600:p,fontSize:u,fontFamily:g,foreColor:Array.isArray(f)?t&&d.config.xaxis.convertedCatToNumeric?f[d.globals.minX+r-1]:f[r]:f,isPlainText:!1,cssClass:(t?"apexcharts-xaxis-label ":"apexcharts-xaxis-group-label ")+x});if(i.add(k),k.on("click",(function(t){if("function"==typeof d.config.chart.events.xAxisLabelClick){var e=Object.assign({},d,{labelIndex:r});d.config.chart.events.xAxisLabelClick(t,o.ctx,e)}})),t){var A=document.createElementNS(d.globals.SVGNS,"title");A.textContent=Array.isArray(y.text)?y.text.join(" "):y.text,k.node.appendChild(A),""!==y.text&&(c.push(y.text),h.push(y))}}ra.globals.gridWidth)){var s=this.offY+a.config.xaxis.axisTicks.offsetY;if(e=e+s+a.config.xaxis.axisTicks.height,"top"===a.config.xaxis.position&&(e=s-a.config.xaxis.axisTicks.height),a.config.xaxis.axisTicks.show){var n=new g(this.ctx).drawLine(t+a.config.xaxis.axisTicks.offsetX,s+a.config.xaxis.offsetY,r+a.config.xaxis.axisTicks.offsetX,e+a.config.xaxis.offsetY,a.config.xaxis.axisTicks.color);i.add(n),n.node.classList.add("apexcharts-xaxis-tick")}}}},{key:"getXAxisTicksPositions",value:function(){var t=this.w,e=[],i=this.xaxisLabels.length,a=t.globals.padHorizontal;if(t.globals.timescaleLabels.length>0)for(var r=0;r0){var c=r[r.length-1].getBBox(),h=r[0].getBBox();c.x<-20&&r[r.length-1].parentNode.removeChild(r[r.length-1]),h.x+h.width>t.globals.gridWidth&&!t.globals.isBarHorizontal&&r[0].parentNode.removeChild(r[0]);for(var d=0;d0&&(this.xaxisLabels=i.globals.timescaleLabels.slice())}var e,i;return e=t,i=[{key:"drawGridArea",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w,i=new g(this.ctx);null===t&&(t=i.group({class:"apexcharts-grid"}));var a=i.drawLine(e.globals.padHorizontal,1,e.globals.padHorizontal,e.globals.gridHeight,"transparent"),r=i.drawLine(e.globals.padHorizontal,e.globals.gridHeight,e.globals.gridWidth,e.globals.gridHeight,"transparent");return t.add(r),t.add(a),t}},{key:"drawGrid",value:function(){var t=null;return this.w.globals.axisCharts&&(t=this.renderGrid(),this.drawGridArea(t.el)),t}},{key:"createGridMask",value:function(){var t=this.w,e=t.globals,i=new g(this.ctx),a=Array.isArray(t.config.stroke.width)?0:t.config.stroke.width;if(Array.isArray(t.config.stroke.width)){var r=0;t.config.stroke.width.forEach((function(t){r=Math.max(r,t)})),a=r}e.dom.elGridRectMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMask.setAttribute("id","gridRectMask".concat(e.cuid)),e.dom.elGridRectMarkerMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMarkerMask.setAttribute("id","gridRectMarkerMask".concat(e.cuid)),e.dom.elForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elForecastMask.setAttribute("id","forecastMask".concat(e.cuid)),e.dom.elNonForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elNonForecastMask.setAttribute("id","nonForecastMask".concat(e.cuid));var s=t.config.chart.type,n=0,o=0;("bar"===s||"rangeBar"===s||"candlestick"===s||"boxPlot"===s||t.globals.comboBarCount>0)&&t.globals.isXNumeric&&!t.globals.isBarHorizontal&&(n=t.config.grid.padding.left,o=t.config.grid.padding.right,e.barPadForNumericAxis>n&&(n=e.barPadForNumericAxis,o=e.barPadForNumericAxis)),e.dom.elGridRect=i.drawRect(-a/2-n-2,-a/2,e.gridWidth+a+o+n+4,e.gridHeight+a,0,"#fff");var l=t.globals.markers.largestSize+1;e.dom.elGridRectMarker=i.drawRect(2*-l,2*-l,e.gridWidth+4*l,e.gridHeight+4*l,0,"#fff"),e.dom.elGridRectMask.appendChild(e.dom.elGridRect.node),e.dom.elGridRectMarkerMask.appendChild(e.dom.elGridRectMarker.node);var c=e.dom.baseEl.querySelector("defs");c.appendChild(e.dom.elGridRectMask),c.appendChild(e.dom.elForecastMask),c.appendChild(e.dom.elNonForecastMask),c.appendChild(e.dom.elGridRectMarkerMask)}},{key:"_drawGridLines",value:function(t){var e=t.i,i=t.x1,a=t.y1,r=t.x2,s=t.y2,n=t.xCount,o=t.parent,l=this.w;if(!(0===e&&l.globals.skipFirstTimelinelabel||e===n-1&&l.globals.skipLastTimelinelabel&&!l.config.xaxis.labels.formatter||"radar"===l.config.chart.type)){l.config.grid.xaxis.lines.show&&this._drawGridLine({i:e,x1:i,y1:a,x2:r,y2:s,xCount:n,parent:o});var c=0;if(l.globals.hasXaxisGroups&&"between"===l.config.xaxis.tickPlacement){var h=l.globals.groups;if(h){for(var d=0,u=0;d2));r++);return!t.globals.isBarHorizontal||this.isRangeBar?(i=this.xaxisLabels.length,this.isRangeBar&&(i--,a=t.globals.labels.length,t.config.xaxis.tickAmount&&t.config.xaxis.labels.formatter&&(i=t.config.xaxis.tickAmount)),this._drawXYLines({xCount:i,tickAmount:a})):(i=a,a=t.globals.xTickAmount,this._drawInvertedXYLines({xCount:i,tickAmount:a})),this.drawGridBands(i,a),{el:this.elg,elGridBorders:this.elGridBorders,xAxisTickWidth:t.globals.gridWidth/i}}},{key:"drawGridBands",value:function(t,e){var i=this.w;if(void 0!==i.config.grid.row.colors&&i.config.grid.row.colors.length>0)for(var a=0,r=i.globals.gridHeight/e,s=i.globals.gridWidth,n=0,o=0;n=i.config.grid.row.colors.length&&(o=0),this._drawGridBandRect({c:o,x1:0,y1:a,x2:s,y2:r,type:"row"}),a+=i.globals.gridHeight/e;if(void 0!==i.config.grid.column.colors&&i.config.grid.column.colors.length>0)for(var l=i.globals.isBarHorizontal||"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric?t:t-1,c=i.globals.padHorizontal,h=i.globals.padHorizontal+i.globals.gridWidth/l,d=i.globals.gridHeight,u=0,g=0;u=i.config.grid.column.colors.length&&(g=0),this._drawGridBandRect({c:g,x1:c,y1:0,x2:h,y2:d,type:"column"}),c+=i.globals.gridWidth/l}}],i&&mt(e.prototype,i),t}();function wt(t,e){for(var i=0;i2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,s=arguments.length>4?arguments[4]:void 0,n=this.w,o=Math.abs(e-t);if("dataPoints"===(i=this._adjustTicksForSmallRange(i,a,o))&&(i=n.globals.dataPoints-1),t===Number.MIN_VALUE&&0===e||!r.isNumber(t)&&!r.isNumber(e)||t===Number.MIN_VALUE&&e===-Number.MAX_VALUE)return t=0,e=i,this.linearScale(t,e,i);t>e?(console.warn("axis.min cannot be greater than axis.max"),e=t+.1):t===e&&(t=0===t?0:t-.5,e=0===e?2:e+.5);var l=[];o<1&&s&&("candlestick"===n.config.chart.type||"candlestick"===n.config.series[a].type||"boxPlot"===n.config.chart.type||"boxPlot"===n.config.series[a].type||n.globals.isRangeData)&&(e*=1.01);var c=i+1;c<2?c=2:c>2&&(c-=2);var h=o/c,d=Math.floor(r.log10(h)),u=Math.pow(10,d),g=Math.round(h/u);g<1&&(g=1);var f=g*u,p=f*Math.floor(t/f),x=f*Math.ceil(e/f),b=p;if(s&&o>2){for(;l.push(b),!((b+=f)>x););return{result:l,niceMin:l[0],niceMax:l[l.length-1]}}var v=t;(l=[]).push(v);for(var m=Math.abs(e-t)/i,y=0;y<=i;y++)v+=m,l.push(v);return l[l.length-2]>=e&&l.pop(),{result:l,niceMin:l[0],niceMax:l[l.length-1]}}},{key:"linearScale",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3?arguments[3]:void 0,r=Math.abs(e-t);"dataPoints"===(i=this._adjustTicksForSmallRange(i,a,r))&&(i=this.w.globals.dataPoints-1);var s=r/i;i===Number.MAX_VALUE&&(i=10,s=1);for(var n=[],o=t;i>=0;)n.push(o),o+=s,i-=1;return{result:n,niceMin:n[0],niceMax:n[n.length-1]}}},{key:"logarithmicScaleNice",value:function(t,e,i){e<=0&&(e=Math.max(t,i)),t<=0&&(t=Math.min(e,i));for(var a=[],r=Math.ceil(Math.log(e)/Math.log(i)+1),s=Math.floor(Math.log(t)/Math.log(i));s5)a.allSeriesCollapsed=!1,a.yAxisScale[t]=this.logarithmicScale(e,i,n.logBase),a.yAxisScale[t]=n.forceNiceScale?this.logarithmicScaleNice(e,i,n.logBase):this.logarithmicScale(e,i,n.logBase);else if(i!==-Number.MAX_VALUE&&r.isNumber(i))if(a.allSeriesCollapsed=!1,void 0===n.min&&void 0===n.max||n.forceNiceScale){var l=void 0===s.yaxis[t].max&&void 0===s.yaxis[t].min||s.yaxis[t].forceNiceScale;a.yAxisScale[t]=this.niceScale(e,i,n.tickAmount?n.tickAmount:o<5&&o>1?o+1:5,t,l)}else a.yAxisScale[t]=this.linearScale(e,i,n.tickAmount,t);else a.yAxisScale[t]=this.linearScale(0,5,5)}},{key:"setXScale",value:function(t,e){var i=this.w,a=i.globals,s=i.config.xaxis,n=Math.abs(e-t);return e!==-Number.MAX_VALUE&&r.isNumber(e)?a.xAxisScale=this.linearScale(t,e,s.tickAmount?s.tickAmount:n<5&&n>1?n+1:5,0):a.xAxisScale=this.linearScale(0,5,5),a.xAxisScale}},{key:"setMultipleYScales",value:function(){var t=this,e=this.w.globals,i=this.w.config,a=e.minYArr.concat([]),r=e.maxYArr.concat([]),s=[];i.yaxis.forEach((function(e,n){var o=n;i.series.forEach((function(t,i){t.name===e.seriesName&&(o=i,n!==i?s.push({index:i,similarIndex:n,alreadyExists:!0}):s.push({index:i}))}));var l=a[o],c=r[o];t.setYScaleForIndex(n,l,c)})),this.sameScaleInMultipleAxes(a,r,s)}},{key:"sameScaleInMultipleAxes",value:function(t,e,i){var a=this,r=this.w.config,s=this.w.globals,n=[];i.forEach((function(t){t.alreadyExists&&(void 0===n[t.index]&&(n[t.index]=[]),n[t.index].push(t.index),n[t.index].push(t.similarIndex))})),s.yAxisSameScaleIndices=n,n.forEach((function(t,e){n.forEach((function(i,a){var r,s;e!==a&&(r=t,s=i,r.filter((function(t){return-1!==s.indexOf(t)}))).length>0&&(n[e]=n[e].concat(n[a]))}))}));var o=n.map((function(t){return t.filter((function(e,i){return t.indexOf(e)===i}))})).map((function(t){return t.sort()}));n=n.filter((function(t){return!!t}));var l=o.slice(),c=l.map((function(t){return JSON.stringify(t)}));l=l.filter((function(t,e){return c.indexOf(JSON.stringify(t))===e}));var h=[],d=[];t.forEach((function(t,i){l.forEach((function(a,r){a.indexOf(i)>-1&&(void 0===h[r]&&(h[r]=[],d[r]=[]),h[r].push({key:i,value:t}),d[r].push({key:i,value:e[i]}))}))}));var u=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,Number.MIN_VALUE),g=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,-Number.MAX_VALUE);h.forEach((function(t,e){t.forEach((function(t,i){u[e]=Math.min(t.value,u[e])}))})),d.forEach((function(t,e){t.forEach((function(t,i){g[e]=Math.max(t.value,g[e])}))})),t.forEach((function(t,e){d.forEach((function(t,i){var n=u[i],o=g[i];r.chart.stacked&&(o=0,t.forEach((function(t,e){t.value!==-Number.MAX_VALUE&&(o+=t.value),n!==Number.MIN_VALUE&&(n+=h[i][e].value)}))),t.forEach((function(i,l){t[l].key===e&&(void 0!==r.yaxis[e].min&&(n="function"==typeof r.yaxis[e].min?r.yaxis[e].min(s.minY):r.yaxis[e].min),void 0!==r.yaxis[e].max&&(o="function"==typeof r.yaxis[e].max?r.yaxis[e].max(s.maxY):r.yaxis[e].max),a.setYScaleForIndex(e,n,o))}))}))}))}},{key:"autoScaleY",value:function(t,e,i){t||(t=this);var a=t.w;if(a.globals.isMultipleYAxis||a.globals.collapsedSeries.length)return console.warn("autoScaleYaxis is not supported in a multi-yaxis chart."),e;var r=a.globals.seriesX[0],s=a.config.chart.stacked;return e.forEach((function(t,n){for(var o=0,l=0;l=i.xaxis.min){o=l;break}var c,h,d=a.globals.minYArr[n],u=a.globals.maxYArr[n],g=a.globals.stackedSeriesTotals;a.globals.series.forEach((function(n,l){var f=n[o];s?(f=g[o],c=h=f,g.forEach((function(t,e){r[e]<=i.xaxis.max&&r[e]>=i.xaxis.min&&(t>h&&null!==t&&(h=t),n[e]=i.xaxis.min){var s=t,n=t;a.globals.series.forEach((function(i,a){null!==t&&(s=Math.min(i[e],s),n=Math.max(i[e],n))})),n>h&&null!==n&&(h=n),sd&&(c=d),e.length>1?(e[l].min=void 0===t.min?c:t.min,e[l].max=void 0===t.max?h:t.max):(e[0].min=void 0===t.min?c:t.min,e[0].max=void 0===t.max?h:t.max)}))})),e}}],i&&wt(e.prototype,i),t}();function At(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);i1&&void 0!==arguments[1]?arguments[1]:Number.MAX_VALUE,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:-Number.MAX_VALUE,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.w.config,n=this.w.globals,o=-Number.MAX_VALUE,l=Number.MIN_VALUE;null===a&&(a=t+1);var c=n.series,h=c,d=c;"candlestick"===s.chart.type?(h=n.seriesCandleL,d=n.seriesCandleH):"boxPlot"===s.chart.type?(h=n.seriesCandleO,d=n.seriesCandleC):n.isRangeData&&(h=n.seriesRangeStart,d=n.seriesRangeEnd);for(var u=t;uh[u][g]&&h[u][g]<0&&(l=h[u][g])):n.hasNullValues=!0}}return"rangeBar"===s.chart.type&&n.seriesRangeStart.length&&n.isBarHorizontal&&(l=e),"bar"===s.chart.type&&(l<0&&o<0&&(o=0),l===Number.MIN_VALUE&&(l=0)),{minY:l,maxY:o,lowestY:e,highestY:i}}},{key:"setYRange",value:function(){var t=this.w.globals,e=this.w.config;t.maxY=-Number.MAX_VALUE,t.minY=Number.MIN_VALUE;var i=Number.MAX_VALUE;if(t.isMultipleYAxis)for(var a=0;a=0&&i<=10||void 0!==e.yaxis[0].min||void 0!==e.yaxis[0].max)&&(n=0),t.minY=i-5*n/100,i>0&&t.minY<0&&(t.minY=0),t.maxY=t.maxY+5*n/100}return e.yaxis.forEach((function(e,i){void 0!==e.max&&("number"==typeof e.max?t.maxYArr[i]=e.max:"function"==typeof e.max&&(t.maxYArr[i]=e.max(t.isMultipleYAxis?t.maxYArr[i]:t.maxY)),t.maxY=t.maxYArr[i]),void 0!==e.min&&("number"==typeof e.min?t.minYArr[i]=e.min:"function"==typeof e.min&&(t.minYArr[i]=e.min(t.isMultipleYAxis?t.minYArr[i]===Number.MIN_VALUE?0:t.minYArr[i]:t.minY)),t.minY=t.minYArr[i])})),t.isBarHorizontal&&["min","max"].forEach((function(i){void 0!==e.xaxis[i]&&"number"==typeof e.xaxis[i]&&("min"===i?t.minY=e.xaxis[i]:t.maxY=e.xaxis[i])})),t.isMultipleYAxis?(this.scales.setMultipleYScales(),t.minY=i,t.yAxisScale.forEach((function(e,i){t.minYArr[i]=e.niceMin,t.maxYArr[i]=e.niceMax}))):(this.scales.setYScaleForIndex(0,t.minY,t.maxY),t.minY=t.yAxisScale[0].niceMin,t.maxY=t.yAxisScale[0].niceMax,t.minYArr[0]=t.yAxisScale[0].niceMin,t.maxYArr[0]=t.yAxisScale[0].niceMax),{minY:t.minY,maxY:t.maxY,minYArr:t.minYArr,maxYArr:t.maxYArr,yAxisScale:t.yAxisScale}}},{key:"setXRange",value:function(){var t=this.w.globals,e=this.w.config,i="numeric"===e.xaxis.type||"datetime"===e.xaxis.type||"category"===e.xaxis.type&&!t.noLabelsProvided||t.noLabelsProvided||t.isXNumeric;if(t.isXNumeric&&function(){for(var e=0;et.dataPoints&&0!==t.dataPoints&&(a=t.dataPoints-1)):"dataPoints"===e.xaxis.tickAmount?(t.series.length>1&&(a=t.series[t.maxValsInArrayIndex].length-1),t.isXNumeric&&(a=t.maxX-t.minX-1)):a=e.xaxis.tickAmount,t.xTickAmount=a,void 0!==e.xaxis.max&&"number"==typeof e.xaxis.max&&(t.maxX=e.xaxis.max),void 0!==e.xaxis.min&&"number"==typeof e.xaxis.min&&(t.minX=e.xaxis.min),void 0!==e.xaxis.range&&(t.minX=t.maxX-e.xaxis.range),t.minX!==Number.MAX_VALUE&&t.maxX!==-Number.MAX_VALUE)if(e.xaxis.convertedCatToNumeric&&!t.dataFormatXNumeric){for(var s=[],n=t.minX-1;n0&&(t.xAxisScale=this.scales.linearScale(1,t.labels.length,a-1),t.seriesX=t.labels.slice());i&&(t.labels=t.xAxisScale.result.slice())}return t.isBarHorizontal&&t.labels.length&&(t.xTickAmount=t.labels.length),this._handleSingleDataPoint(),this._getMinXDiff(),{minX:t.minX,maxX:t.maxX}}},{key:"setZRange",value:function(){var t=this.w.globals;if(t.isDataXYZ)for(var e=0;e0){var r=e-a[i-1];r>0&&(t.minXDiff=Math.min(r,t.minXDiff))}})),1!==t.dataPoints&&t.minXDiff!==Number.MAX_VALUE||(t.minXDiff=.5)}))}},{key:"_setStackedMinMax",value:function(){var t=this,e=this.w.globals;if(e.series.length){var i=e.seriesGroups;i.length||(i=[this.w.config.series.map((function(t){return t.name}))]);var a={},s={};i.forEach((function(i){a[i]=[],s[i]=[],t.w.config.series.map((function(t,e){return i.indexOf(t.name)>-1?e:null})).filter((function(t){return null!==t})).forEach((function(t){for(var n=0;n0?a[i][n]+=parseFloat(e.series[t][n])+1e-4:s[i][n]+=parseFloat(e.series[t][n]))}))})),Object.entries(a).forEach((function(t){var i,r,n=(i=t,r=1,function(t){if(Array.isArray(t))return t}(i)||function(t,e){var i=null==t?null:"undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(null!=i){var a,r,s=[],n=!0,o=!1;try{for(i=i.call(t);!(n=(a=i.next()).done)&&(s.push(a.value),!e||s.length!==e);n=!0);}catch(t){o=!0,r=t}finally{try{n||null==i.return||i.return()}finally{if(o)throw r}}return s}}(i,r)||function(t,e){if(t){if("string"==typeof t)return At(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?At(t,e):void 0}}(i,r)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}())[0];a[n].forEach((function(t,i){e.maxY=Math.max(e.maxY,a[n][i]),e.minY=Math.min(e.minY,s[n][i])}))}))}}}],i&&St(e.prototype,i),t}();function Pt(t,e){for(var i=0;i=0;v--)b(v);if(void 0!==i.config.yaxis[t].title.text){var m=a.group({class:"apexcharts-yaxis-title"}),y=0;i.config.yaxis[t].opposite&&(y=i.globals.translateYAxisX[t]);var w=a.drawText({x:y,y:i.globals.gridHeight/2+i.globals.translateY+i.config.yaxis[t].title.offsetY,text:i.config.yaxis[t].title.text,textAnchor:"end",foreColor:i.config.yaxis[t].title.style.color,fontSize:i.config.yaxis[t].title.style.fontSize,fontWeight:i.config.yaxis[t].title.style.fontWeight,fontFamily:i.config.yaxis[t].title.style.fontFamily,cssClass:"apexcharts-yaxis-title-text "+i.config.yaxis[t].title.style.cssClass});m.add(w),l.add(m)}var k=i.config.yaxis[t].axisBorder,A=31+k.offsetX;if(i.config.yaxis[t].opposite&&(A=-31-k.offsetX),k.show){var S=a.drawLine(A,i.globals.translateY+k.offsetY-2,A,i.globals.gridHeight+i.globals.translateY+k.offsetY+2,k.color,0,k.width);l.add(S)}return i.config.yaxis[t].axisTicks.show&&this.axesUtils.drawYAxisTicks(A,h,k,i.config.yaxis[t].axisTicks,t,d,l),l}},{key:"drawYaxisInversed",value:function(t){var e=this.w,i=new g(this.ctx),a=i.group({class:"apexcharts-xaxis apexcharts-yaxis-inversed"}),r=i.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(e.globals.translateXAxisX,", ").concat(e.globals.translateXAxisY,")")});a.add(r);var s=e.globals.yAxisScale[t].result.length-1,n=e.globals.gridWidth/s+.1,o=n+e.config.xaxis.labels.offsetX,l=e.globals.xLabelFormatter,c=e.globals.yAxisScale[t].result.slice(),h=e.globals.timescaleLabels;h.length>0&&(this.xaxisLabels=h.slice(),s=(c=h.slice()).length),c=this.axesUtils.checkForReversedLabels(t,c);var d=h.length;if(e.config.xaxis.labels.show)for(var u=d?0:s;d?u=0;d?u++:u--){var f=c[u];f=l(f,u,e);var p=e.globals.gridWidth+e.globals.padHorizontal-(o-n+e.config.xaxis.labels.offsetX);if(h.length){var x=this.axesUtils.getLabel(c,h,p,u,this.drawnLabels,this.xaxisFontSize);p=x.x,f=x.text,this.drawnLabels.push(x.text),0===u&&e.globals.skipFirstTimelinelabel&&(f=""),u===c.length-1&&e.globals.skipLastTimelinelabel&&(f="")}var b=i.drawText({x:p,y:this.xAxisoffX+e.config.xaxis.labels.offsetY+30-("top"===e.config.xaxis.position?e.globals.xAxisHeight+e.config.xaxis.axisTicks.height-2:0),text:f,textAnchor:"middle",foreColor:Array.isArray(this.xaxisForeColors)?this.xaxisForeColors[t]:this.xaxisForeColors,fontSize:this.xaxisFontSize,fontFamily:this.xaxisFontFamily,fontWeight:e.config.xaxis.labels.style.fontWeight,isPlainText:!1,cssClass:"apexcharts-xaxis-label "+e.config.xaxis.labels.style.cssClass});r.add(b),b.tspan(f);var v=document.createElementNS(e.globals.SVGNS,"title");v.textContent=f,b.node.appendChild(v),o+=n}return this.inversedYAxisTitleText(a),this.inversedYAxisBorder(a),a}},{key:"inversedYAxisBorder",value:function(t){var e=this.w,i=new g(this.ctx),a=e.config.xaxis.axisBorder;if(a.show){var r=0;"bar"===e.config.chart.type&&e.globals.isXNumeric&&(r-=15);var s=i.drawLine(e.globals.padHorizontal+r+a.offsetX,this.xAxisoffX,e.globals.gridWidth,this.xAxisoffX,a.color,0,a.height);this.elgrid&&this.elgrid.elGridBorders&&e.config.grid.show?this.elgrid.elGridBorders.add(s):t.add(s)}}},{key:"inversedYAxisTitleText",value:function(t){var e=this.w,i=new g(this.ctx);if(void 0!==e.config.xaxis.title.text){var a=i.group({class:"apexcharts-xaxis-title apexcharts-yaxis-title-inversed"}),r=i.drawText({x:e.globals.gridWidth/2+e.config.xaxis.title.offsetX,y:this.xAxisoffX+parseFloat(this.xaxisFontSize)+parseFloat(e.config.xaxis.title.style.fontSize)+e.config.xaxis.title.offsetY+20,text:e.config.xaxis.title.text,textAnchor:"middle",fontSize:e.config.xaxis.title.style.fontSize,fontFamily:e.config.xaxis.title.style.fontFamily,fontWeight:e.config.xaxis.title.style.fontWeight,foreColor:e.config.xaxis.title.style.color,cssClass:"apexcharts-xaxis-title-text "+e.config.xaxis.title.style.cssClass});a.add(r),t.add(a)}}},{key:"yAxisTitleRotate",value:function(t,e){var i=this.w,a=new g(this.ctx),r={width:0,height:0},s={width:0,height:0},n=i.globals.dom.baseEl.querySelector(" .apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-texts-g"));null!==n&&(r=n.getBoundingClientRect());var o=i.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-title text"));if(null!==o&&(s=o.getBoundingClientRect()),null!==o){var l=this.xPaddingForYAxisTitle(t,r,s,e);o.setAttribute("x",l.xPos-(e?10:0))}if(null!==o){var c=a.rotateAroundCenter(o);o.setAttribute("transform","rotate(".concat(e?-1*i.config.yaxis[t].title.rotate:i.config.yaxis[t].title.rotate," ").concat(c.x," ").concat(c.y,")"))}}},{key:"xPaddingForYAxisTitle",value:function(t,e,i,a){var r=this.w,s=0,n=0,o=10;return void 0===r.config.yaxis[t].title.text||t<0?{xPos:n,padd:0}:(a?(n=e.width+r.config.yaxis[t].title.offsetX+i.width/2+o/2,0===(s+=1)&&(n-=o/2)):(n=-1*e.width+r.config.yaxis[t].title.offsetX+o/2+i.width/2,r.globals.isBarHorizontal&&(o=25,n=-1*e.width-r.config.yaxis[t].title.offsetX-o)),{xPos:n,padd:o})}},{key:"setYAxisXPosition",value:function(t,e){var i=this.w,a=0,r=0,s=18,n=1;i.config.yaxis.length>1&&(this.multipleYs=!0),i.config.yaxis.map((function(o,l){var c=i.globals.ignoreYAxisIndexes.indexOf(l)>-1||!o.show||o.floating||0===t[l].width,h=t[l].width+e[l].width;o.opposite?i.globals.isBarHorizontal?(r=i.globals.gridWidth+i.globals.translateX-1,i.globals.translateYAxisX[l]=r-o.labels.offsetX):(r=i.globals.gridWidth+i.globals.translateX+n,c||(n=n+h+20),i.globals.translateYAxisX[l]=r-o.labels.offsetX+20):(a=i.globals.translateX-s,c||(s=s+h+20),i.globals.translateYAxisX[l]=a+o.labels.offsetX)}))}},{key:"setYAxisTextAlignments",value:function(){var t=this.w,e=t.globals.dom.baseEl.getElementsByClassName("apexcharts-yaxis");(e=r.listToArray(e)).forEach((function(e,i){var a=t.config.yaxis[i];if(a&&!a.floating&&void 0!==a.labels.align){var s=t.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-texts-g")),n=t.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-label"));n=r.listToArray(n);var o=s.getBoundingClientRect();"left"===a.labels.align?(n.forEach((function(t,e){t.setAttribute("text-anchor","start")})),a.opposite||s.setAttribute("transform","translate(-".concat(o.width,", 0)"))):"center"===a.labels.align?(n.forEach((function(t,e){t.setAttribute("text-anchor","middle")})),s.setAttribute("transform","translate(".concat(o.width/2*(a.opposite?1:-1),", 0)"))):"right"===a.labels.align&&(n.forEach((function(t,e){t.setAttribute("text-anchor","end")})),a.opposite&&s.setAttribute("transform","translate(".concat(o.width,", 0)")))}}))}}])&&Pt(e.prototype,i),t}();function Ot(t,e){for(var i=0;i0&&(e=this.w.config.chart.locales.concat(window.Apex.chart.locales));var i=e.filter((function(e){return e.name===t}))[0];if(!i)throw new Error("Wrong locale name provided. Please make sure you set the correct locale name in options");var a=r.extend(S,i);this.w.globals.locale=a.options}}])&&It(e.prototype,i),t}();function Mt(t,e){for(var i=0;ie.breakpoint?1:e.breakpoint>t.breakpoint?-1:0})).reverse();var n=new G({}),o=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},a=s[0].breakpoint,o=window.innerWidth>0?window.innerWidth:screen.width;if(o>a){var l=p.extendArrayProps(n,i.globals.initialConfig,i);t=r.extend(l,t),t=r.extend(i.config,t),e.overrideResponsiveOptions(t)}else for(var c=0;c0&&"function"==typeof e.config.colors[0]&&(e.globals.colors=e.config.series.map((function(i,a){var r=e.config.colors[a];return r||(r=e.config.colors[0]),"function"==typeof r?(t.isColorFn=!0,r({value:e.globals.axisCharts?e.globals.series[a][0]?e.globals.series[a][0]:0:e.globals.series[a],seriesIndex:a,dataPointIndex:a,w:e})):r})))),e.globals.seriesColors.map((function(t,i){t&&(e.globals.colors[i]=t)})),e.config.theme.monochrome.enabled){var a=[],s=e.globals.series.length;(this.isBarDistributed||this.isHeatmapDistributed)&&(s=e.globals.series[0].length*e.globals.series.length);for(var n=e.config.theme.monochrome.color,o=1/(s/e.config.theme.monochrome.shadeIntensity),l=e.config.theme.monochrome.shadeTo,c=0,h=0;h2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,r=e||a.globals.series.length;if(null===i&&(i=this.isBarDistributed||this.isHeatmapDistributed||"heatmap"===a.config.chart.type&&a.config.plotOptions.heatmap.colorScale.inverse),i&&a.globals.series.length&&(r=a.globals.series[a.globals.maxValsInArrayIndex].length*a.globals.series.length),t.lengtht.length)&&(e=t.length);for(var i=0,a=new Array(e);it.globals.svgWidth&&(this.dCtx.lgRect.width=t.globals.svgWidth/1.5),this.dCtx.lgRect}},{key:"getLargestStringFromMultiArr",value:function(t,e){var i=t;if(this.w.globals.isMultiLineX){var a=e.map((function(t,e){return Array.isArray(t)?t.length:1})),r=Math.max.apply(Math,function(t){return function(t){if(Array.isArray(t))return jt(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,e){if(t){if("string"==typeof t)return jt(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?jt(t,e):void 0}}(t)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}(a));i=e[a.indexOf(r)]}return i}}])&&Bt(e.prototype,i),t}();function Vt(t,e){for(var i=0;i0){var a=this.getxAxisTimeScaleLabelsCoords();t={width:a.width,height:a.height},e.globals.rotateXLabels=!1}else{this.dCtx.lgWidthForSideLegends="left"!==e.config.legend.position&&"right"!==e.config.legend.position||e.config.legend.floating?0:this.dCtx.lgRect.width;var s=e.globals.xLabelFormatter,n=r.getLargestStringFromArr(i),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(n,i);e.globals.isBarHorizontal&&(o=n=e.globals.yAxisScale[0].result.reduce((function(t,e){return t.length>e.length?t:e}),0));var l=new z(this.dCtx.ctx),c=n;n=l.xLabelFormat(s,n,c,{i:void 0,dateFormatter:new M(this.dCtx.ctx).formatDate,w:e}),o=l.xLabelFormat(s,o,c,{i:void 0,dateFormatter:new M(this.dCtx.ctx).formatDate,w:e}),(e.config.xaxis.convertedCatToNumeric&&void 0===n||""===String(n).trim())&&(o=n="1");var h=new g(this.dCtx.ctx),d=h.getTextRects(n,e.config.xaxis.labels.style.fontSize),u=d;if(n!==o&&(u=h.getTextRects(o,e.config.xaxis.labels.style.fontSize)),(t={width:d.width>=u.width?d.width:u.width,height:d.height>=u.height?d.height:u.height}).width*i.length>e.globals.svgWidth-this.dCtx.lgWidthForSideLegends-this.dCtx.yAxisWidth-this.dCtx.gridPad.left-this.dCtx.gridPad.right&&0!==e.config.xaxis.labels.rotate||e.config.xaxis.labels.rotateAlways){if(!e.globals.isBarHorizontal){e.globals.rotateXLabels=!0;var f=function(t){return h.getTextRects(t,e.config.xaxis.labels.style.fontSize,e.config.xaxis.labels.style.fontFamily,"rotate(".concat(e.config.xaxis.labels.rotate," 0 0)"),!1)};d=f(n),n!==o&&(u=f(o)),t.height=(d.height>u.height?d.height:u.height)/1.5,t.width=d.width>u.width?d.width:u.width}}else e.globals.rotateXLabels=!1}return e.config.xaxis.labels.show||(t={width:0,height:0}),{width:t.width,height:t.height}}},{key:"getxAxisGroupLabelsCoords",value:function(){var t,e=this.w;if(!e.globals.hasXaxisGroups)return{width:0,height:0};var i,a=(null===(t=e.config.xaxis.group.style)||void 0===t?void 0:t.fontSize)||e.config.xaxis.labels.style.fontSize,s=e.globals.groups.map((function(t){return t.title})),n=r.getLargestStringFromArr(s),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(n,s),l=new g(this.dCtx.ctx),c=l.getTextRects(n,a),h=c;return n!==o&&(h=l.getTextRects(o,a)),i={width:c.width>=h.width?c.width:h.width,height:c.height>=h.height?c.height:h.height},e.config.xaxis.labels.show||(i={width:0,height:0}),{width:i.width,height:i.height}}},{key:"getxAxisTitleCoords",value:function(){var t=this.w,e=0,i=0;if(void 0!==t.config.xaxis.title.text){var a=new g(this.dCtx.ctx).getTextRects(t.config.xaxis.title.text,t.config.xaxis.title.style.fontSize);e=a.width,i=a.height}return{width:e,height:i}}},{key:"getxAxisTimeScaleLabelsCoords",value:function(){var t,e=this.w;this.dCtx.timescaleLabels=e.globals.timescaleLabels.slice();var i=this.dCtx.timescaleLabels.map((function(t){return t.value})),a=i.reduce((function(t,e){return void 0===t?(console.error("You have possibly supplied invalid Date format. Please supply a valid JavaScript Date"),0):t.length>e.length?t:e}),0);return 1.05*(t=new g(this.dCtx.ctx).getTextRects(a,e.config.xaxis.labels.style.fontSize)).width*i.length>e.globals.gridWidth&&0!==e.config.xaxis.labels.rotate&&(e.globals.overlappingXLabels=!0),t}},{key:"additionalPaddingXLabels",value:function(t){var e=this,i=this.w,a=i.globals,r=i.config,s=r.xaxis.type,n=t.width;a.skipLastTimelinelabel=!1,a.skipFirstTimelinelabel=!1;var o=i.config.yaxis[0].opposite&&i.globals.isBarHorizontal;r.yaxis.forEach((function(t,l){o?(e.dCtx.gridPad.left1&&function(t){return-1!==a.collapsedSeriesIndices.indexOf(t)}(o)||function(t){if(e.dCtx.timescaleLabels&&e.dCtx.timescaleLabels.length){var o=e.dCtx.timescaleLabels[0],l=e.dCtx.timescaleLabels[e.dCtx.timescaleLabels.length-1].position+n/1.75-e.dCtx.yAxisWidthRight,c=o.position-n/1.75+e.dCtx.yAxisWidthLeft,h="right"===i.config.legend.position&&e.dCtx.lgRect.width>0?e.dCtx.lgRect.width:0;l>a.svgWidth-a.translateX-h&&(a.skipLastTimelinelabel=!0),c<-(t.show&&!t.floating||"bar"!==r.chart.type&&"candlestick"!==r.chart.type&&"rangeBar"!==r.chart.type&&"boxPlot"!==r.chart.type?10:n/1.75)&&(a.skipFirstTimelinelabel=!0)}else"datetime"===s?e.dCtx.gridPad.rightString(l.niceMax).length?d:l.niceMax,f=h(u,{seriesIndex:o,dataPointIndex:-1,w:e}),p=f;if(void 0!==f&&0!==f.length||(f=u),e.globals.isBarHorizontal){a=0;var x=e.globals.labels.slice();f=h(f=r.getLargestStringFromArr(x),{seriesIndex:o,dataPointIndex:-1,w:e}),p=t.dCtx.dimHelpers.getLargestStringFromMultiArr(f,x)}var b=new g(t.dCtx.ctx),v="rotate(".concat(n.labels.rotate," 0 0)"),m=b.getTextRects(f,n.labels.style.fontSize,n.labels.style.fontFamily,v,!1),y=m;f!==p&&(y=b.getTextRects(p,n.labels.style.fontSize,n.labels.style.fontFamily,v,!1)),i.push({width:(c>y.width||c>m.width?c:y.width>m.width?y.width:m.width)+a,height:y.height>m.height?y.height:m.height})}else i.push({width:0,height:0})})),i}},{key:"getyAxisTitleCoords",value:function(){var t=this,e=this.w,i=[];return e.config.yaxis.map((function(e,a){if(e.show&&void 0!==e.title.text){var r=new g(t.dCtx.ctx),s="rotate(".concat(e.title.rotate," 0 0)"),n=r.getTextRects(e.title.text,e.title.style.fontSize,e.title.style.fontFamily,s,!1);i.push({width:n.width,height:n.height})}else i.push({width:0,height:0})})),i}},{key:"getTotalYAxisWidth",value:function(){var t=this.w,e=0,i=0,a=0,r=t.globals.yAxisScale.length>1?10:0,s=new ut(this.dCtx.ctx),n=function(n,o){var l=t.config.yaxis[o].floating,c=0;n.width>0&&!l?(c=n.width+r,function(e){return t.globals.ignoreYAxisIndexes.indexOf(e)>-1}(o)&&(c=c-n.width-r)):c=l||s.isYAxisHidden(o)?0:5,t.config.yaxis[o].opposite?a+=c:i+=c,e+=c};return t.globals.yLabelsCoords.map((function(t,e){n(t,e)})),t.globals.yTitleCoords.map((function(t,e){n(t,e)})),t.globals.isBarHorizontal&&!t.config.yaxis[0].floating&&(e=t.globals.yLabelsCoords[0].width+t.globals.yTitleCoords[0].width+15),this.dCtx.yAxisWidthLeft=i,this.dCtx.yAxisWidthRight=a,e}}])&&Ut(e.prototype,i),t}();function Zt(t,e){for(var i=0;i0&&(s=e.globals.comboBarCount),e.globals.collapsedSeries.forEach((function(t){i(t.type)&&(s-=1)})),e.config.chart.stacked&&(s=1),(i(a)||e.globals.comboBarCount>0)&&e.globals.isXNumeric&&!e.globals.isBarHorizontal&&s>0){var n,o,l=Math.abs(e.globals.initialMaxX-e.globals.initialMinX);l<=3&&(l=e.globals.dataPoints),n=l/t,e.globals.minXDiff&&e.globals.minXDiff/n>0&&(o=e.globals.minXDiff/n),o>t/2&&(o/=2),(r=o/s*parseInt(e.config.plotOptions.bar.columnWidth,10)/100)<1&&(r=1),r=r/(s>1?1:1.5)+5,e.globals.barPadForNumericAxis=r}return r}},{key:"gridPadFortitleSubtitle",value:function(){var t=this,e=this.w,i=e.globals,a=this.dCtx.isSparkline||!e.globals.axisCharts?0:10;["title","subtitle"].forEach((function(i){void 0!==e.config[i].text?a+=e.config[i].margin:a+=t.dCtx.isSparkline||!e.globals.axisCharts?0:5})),!e.config.legend.show||"bottom"!==e.config.legend.position||e.config.legend.floating||e.globals.axisCharts||(a+=10);var r=this.dCtx.dimHelpers.getTitleSubtitleCoords("title"),s=this.dCtx.dimHelpers.getTitleSubtitleCoords("subtitle");i.gridHeight=i.gridHeight-r.height-s.height-a,i.translateY=i.translateY+r.height+s.height+a}},{key:"setGridXPosForDualYAxis",value:function(t,e){var i=this.w,a=new ut(this.dCtx.ctx);i.config.yaxis.map((function(r,s){-1!==i.globals.ignoreYAxisIndexes.indexOf(s)||r.floating||a.isYAxisHidden(s)||(r.opposite&&(i.globals.translateX=i.globals.translateX-(e[s].width+t[s].width)-parseInt(i.config.yaxis[s].labels.style.fontSize,10)/1.2-12),i.globals.translateX<2&&(i.globals.translateX=2))}))}}])&&Zt(e.prototype,i),t}();function Jt(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);i0||e.config.markers.size>0)&&Object.entries(this.gridPad).forEach((function(e){var i,a,r=(a=2,function(t){if(Array.isArray(t))return t}(i=e)||function(t,e){var i=null==t?null:"undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(null!=i){var a,r,s=[],n=!0,o=!1;try{for(i=i.call(t);!(n=(a=i.next()).done)&&(s.push(a.value),!e||s.length!==e);n=!0);}catch(t){o=!0,r=t}finally{try{n||null==i.return||i.return()}finally{if(o)throw r}}return s}}(i,a)||function(t,e){if(t){if("string"==typeof t)return Jt(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?Jt(t,e):void 0}}(i,a)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()),s=r[0],n=r[1];t.gridPad[s]=Math.max(n,t.w.globals.markers.largestSize/1.5)})),i.axisCharts?this.setDimensionsForAxisCharts():this.setDimensionsForNonAxisCharts(),this.dimGrid.gridPadFortitleSubtitle(),i.gridHeight=i.gridHeight-this.gridPad.top-this.gridPad.bottom,i.gridWidth=i.gridWidth-this.gridPad.left-this.gridPad.right-this.xPadRight-this.xPadLeft;var a=this.dimGrid.gridPadForColumnsInNumericAxis(i.gridWidth);i.gridWidth=i.gridWidth-2*a,i.translateX=i.translateX+this.gridPad.left+this.xPadLeft+(a>0?a+4:0),i.translateY=i.translateY+this.gridPad.top}},{key:"setDimensionsForAxisCharts",value:function(){var t=this,e=this.w,i=e.globals,a=this.dimYAxis.getyAxisLabelsCoords(),r=this.dimYAxis.getyAxisTitleCoords();e.globals.yLabelsCoords=[],e.globals.yTitleCoords=[],e.config.yaxis.map((function(t,i){e.globals.yLabelsCoords.push({width:a[i].width,index:i}),e.globals.yTitleCoords.push({width:r[i].width,index:i})})),this.yAxisWidth=this.dimYAxis.getTotalYAxisWidth();var s=this.dimXAxis.getxAxisLabelsCoords(),n=this.dimXAxis.getxAxisGroupLabelsCoords(),o=this.dimXAxis.getxAxisTitleCoords();this.conditionalChecksForAxisCoords(s,o,n),i.translateXAxisY=e.globals.rotateXLabels?this.xAxisHeight/8:-4,i.translateXAxisX=e.globals.rotateXLabels&&e.globals.isXNumeric&&e.config.xaxis.labels.rotate<=-45?-this.xAxisWidth/4:0,e.globals.isBarHorizontal&&(i.rotateXLabels=!1,i.translateXAxisY=parseInt(e.config.xaxis.labels.style.fontSize,10)/1.5*-1),i.translateXAxisY=i.translateXAxisY+e.config.xaxis.labels.offsetY,i.translateXAxisX=i.translateXAxisX+e.config.xaxis.labels.offsetX;var l=this.yAxisWidth,c=this.xAxisHeight;i.xAxisLabelsHeight=this.xAxisHeight-o.height,i.xAxisGroupLabelsHeight=i.xAxisLabelsHeight-s.height,i.xAxisLabelsWidth=this.xAxisWidth,i.xAxisHeight=this.xAxisHeight;var h=10;("radar"===e.config.chart.type||this.isSparkline)&&(l=0,c=i.goldenPadding),this.isSparkline&&(this.lgRect={height:0,width:0}),(this.isSparkline||"treemap"===e.config.chart.type)&&(l=0,c=0,h=0),this.isSparkline||this.dimXAxis.additionalPaddingXLabels(s);var d=function(){i.translateX=l,i.gridHeight=i.svgHeight-t.lgRect.height-c-(t.isSparkline||"treemap"===e.config.chart.type?0:e.globals.rotateXLabels?10:15),i.gridWidth=i.svgWidth-l};switch("top"===e.config.xaxis.position&&(h=i.xAxisHeight-e.config.xaxis.axisTicks.height-5),e.config.legend.position){case"bottom":i.translateY=h,d();break;case"top":i.translateY=this.lgRect.height+h,d();break;case"left":i.translateY=h,i.translateX=this.lgRect.width+l,i.gridHeight=i.svgHeight-c-12,i.gridWidth=i.svgWidth-this.lgRect.width-l;break;case"right":i.translateY=h,i.translateX=l,i.gridHeight=i.svgHeight-c-12,i.gridWidth=i.svgWidth-this.lgRect.width-l-5;break;default:throw new Error("Legend position not supported")}this.dimGrid.setGridXPosForDualYAxis(r,a),new Lt(this.ctx).setYAxisXPosition(a,r)}},{key:"setDimensionsForNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=t.config,a=0;t.config.legend.show&&!t.config.legend.floating&&(a=20);var r="pie"===i.chart.type||"polarArea"===i.chart.type||"donut"===i.chart.type?"pie":"radialBar",s=i.plotOptions[r].offsetY,n=i.plotOptions[r].offsetX;if(!i.legend.show||i.legend.floating)return e.gridHeight=e.svgHeight-i.grid.padding.left+i.grid.padding.right,e.gridWidth=e.gridHeight,e.translateY=s,void(e.translateX=n+(e.svgWidth-e.gridWidth)/2);switch(i.legend.position){case"bottom":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=s-10,e.translateX=n+(e.svgWidth-e.gridWidth)/2;break;case"top":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=this.lgRect.height+s+10,e.translateX=n+(e.svgWidth-e.gridWidth)/2;break;case"left":e.gridWidth=e.svgWidth-this.lgRect.width-a,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=s,e.translateX=n+this.lgRect.width+a;break;case"right":e.gridWidth=e.svgWidth-this.lgRect.width-a-5,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=s,e.translateX=n+10;break;default:throw new Error("Legend position not supported")}}},{key:"conditionalChecksForAxisCoords",value:function(t,e,i){var a=this.w,r=a.globals.hasXaxisGroups?2:1,s=i.height+t.height+e.height,n=a.globals.isMultiLineX?1.2:a.globals.LINE_HEIGHT_RATIO,o=a.globals.rotateXLabels?22:10,l=a.globals.rotateXLabels&&"bottom"===a.config.legend.position?10:0;this.xAxisHeight=s*n+r*o+l,this.xAxisWidth=t.width,this.xAxisHeight-e.height>a.config.xaxis.labels.maxHeight&&(this.xAxisHeight=a.config.xaxis.labels.maxHeight),a.config.xaxis.labels.minHeight&&this.xAxisHeighth&&(this.yAxisWidth=h)}}])&&Qt(e.prototype,i),t}();function te(t,e){for(var i=0;i0){for(var n=0;n-1&&(t[a].data=[])})):t.forEach((function(i,a){e.globals.collapsedSeriesIndices.indexOf(a)>-1&&(t[a]=0)})),t}}])&&te(e.prototype,i),t}();function ie(t,e){for(var i=0;i1||!e.axisCharts)&&i.legend.show){for(;e.dom.elLegendWrap.firstChild;)e.dom.elLegendWrap.removeChild(e.dom.elLegendWrap.firstChild);this.drawLegends(),r.isIE11()?document.getElementsByTagName("head")[0].appendChild(this.legendHelpers.getLegendStyles()):this.legendHelpers.appendToForeignObject(),"bottom"===i.legend.position||"top"===i.legend.position?this.legendAlignHorizontal():"right"!==i.legend.position&&"left"!==i.legend.position||this.legendAlignVertical()}}},{key:"drawLegends",value:function(){var t=this,e=this.w,i=e.config.legend.fontFamily,a=e.globals.seriesNames,s=e.globals.colors.slice();if("heatmap"===e.config.chart.type){var n=e.config.plotOptions.heatmap.colorScale.ranges;a=n.map((function(t){return t.name?t.name:t.from+" - "+t.to})),s=n.map((function(t){return t.color}))}else this.isBarsDistributed&&(a=e.globals.labels.slice());e.config.legend.customLegendItems.length&&(a=e.config.legend.customLegendItems);for(var o=e.globals.legendFormatter,l=e.config.legend.inverseOrder,c=l?a.length-1:0;l?c>=0:c<=a.length-1;l?c--:c++){var h=o(a[c],{seriesIndex:c,w:e}),d=!1,u=!1;if(e.globals.collapsedSeries.length>0)for(var f=0;f0)for(var x=0;x0?l-10:0)+(c>0?c-10:0)}a.style.position="absolute",s=s+t+i.config.legend.offsetX,n=n+e+i.config.legend.offsetY,a.style.left=s+"px",a.style.top=n+"px","bottom"===i.config.legend.position?(a.style.top="auto",a.style.bottom=5-i.config.legend.offsetY+"px"):"right"===i.config.legend.position&&(a.style.left="auto",a.style.right=25+i.config.legend.offsetX+"px"),["width","height"].forEach((function(t){a.style[t]&&(a.style[t]=parseInt(i.config.legend[t],10)+"px")}))}},{key:"legendAlignHorizontal",value:function(){var t=this.w;t.globals.dom.elLegendWrap.style.right=0;var e=this.legendHelpers.getLegendBBox(),i=new Kt(this.ctx),a=i.dimHelpers.getTitleSubtitleCoords("title"),r=i.dimHelpers.getTitleSubtitleCoords("subtitle"),s=0;"bottom"===t.config.legend.position?s=-e.clwh/1.8:"top"===t.config.legend.position&&(s=a.height+r.height+t.config.title.margin+t.config.subtitle.margin-10),this.setLegendWrapXY(20,s)}},{key:"legendAlignVertical",value:function(){var t=this.w,e=this.legendHelpers.getLegendBBox(),i=0;"left"===t.config.legend.position&&(i=20),"right"===t.config.legend.position&&(i=t.globals.svgWidth-e.clww-10),this.setLegendWrapXY(i,20)}},{key:"onLegendHovered",value:function(t){var e=this.w,i=t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker");if("heatmap"===e.config.chart.type||this.isBarsDistributed){if(i){var a=parseInt(t.target.getAttribute("rel"),10)-1;this.ctx.events.fireEvent("legendHover",[this.ctx,a,this.w]),new ot(this.ctx).highlightRangeInSeries(t,t.target)}}else!t.target.classList.contains("apexcharts-inactive-legend")&&i&&new ot(this.ctx).toggleSeriesOnHover(t,t.target)}},{key:"onLegendClick",value:function(t){var e=this.w;if(!e.config.legend.customLegendItems.length&&(t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker"))){var i=parseInt(t.target.getAttribute("rel"),10)-1,a="true"===t.target.getAttribute("data:collapsed"),r=this.w.config.chart.events.legendClick;"function"==typeof r&&r(this.ctx,i,this.w),this.ctx.events.fireEvent("legendClick",[this.ctx,i,this.w]);var s=this.w.config.legend.markers.onClick;"function"==typeof s&&t.target.classList.contains("apexcharts-legend-marker")&&(s(this.ctx,i,this.w),this.ctx.events.fireEvent("legendMarkerClick",[this.ctx,i,this.w])),"treemap"!==e.config.chart.type&&"heatmap"!==e.config.chart.type&&!this.isBarsDistributed&&e.config.legend.onItemClick.toggleDataSeries&&this.legendHelpers.toggleDataSeries(i,a)}}}])&&ie(e.prototype,i),t}();var re=i(798),se=i.n(re),ne=i(688),oe=i.n(ne),le=i(149),ce=i.n(le),he=i(323),de=i.n(he),ue=i(686),ge=i.n(ue),fe=i(618),pe=i.n(fe),xe=i(355),be=i.n(xe);function ve(t,e){for(var i=0;i0&&e.height>0&&this.slDraggableRect.selectize({points:"l, r",pointSize:8,pointType:"rect"}).resize({constraint:{minX:0,minY:0,maxX:t.globals.gridWidth,maxY:t.globals.gridHeight}}).on("resizing",this.selectionDragging.bind(this,"resizing"))}}},{key:"preselectedSelection",value:function(){var t=this.w,e=this.xyRatios;if(!t.globals.zoomEnabled)if(void 0!==t.globals.selection&&null!==t.globals.selection)this.drawSelectionRect(t.globals.selection);else if(void 0!==t.config.chart.selection.xaxis.min&&void 0!==t.config.chart.selection.xaxis.max){var i=(t.config.chart.selection.xaxis.min-t.globals.minX)/e.xRatio,a={x:i,y:0,width:t.globals.gridWidth-(t.globals.maxX-t.config.chart.selection.xaxis.max)/e.xRatio-i,height:t.globals.gridHeight,translateX:0,translateY:0,selectionEnabled:!0};this.drawSelectionRect(a),this.makeSelectionRectDraggable(),"function"==typeof t.config.chart.events.selection&&t.config.chart.events.selection(this.ctx,{xaxis:{min:t.config.chart.selection.xaxis.min,max:t.config.chart.selection.xaxis.max},yaxis:{}})}}},{key:"drawSelectionRect",value:function(t){var e=t.x,i=t.y,a=t.width,r=t.height,s=t.translateX,n=void 0===s?0:s,o=t.translateY,l=void 0===o?0:o,c=this.w,h=this.zoomRect,d=this.selectionRect;if(this.dragged||null!==c.globals.selection){var u={transform:"translate("+n+", "+l+")"};c.globals.zoomEnabled&&this.dragged&&(a<0&&(a=1),h.attr({x:e,y:i,width:a,height:r,fill:c.config.chart.zoom.zoomedArea.fill.color,"fill-opacity":c.config.chart.zoom.zoomedArea.fill.opacity,stroke:c.config.chart.zoom.zoomedArea.stroke.color,"stroke-width":c.config.chart.zoom.zoomedArea.stroke.width,"stroke-opacity":c.config.chart.zoom.zoomedArea.stroke.opacity}),g.setAttrs(h.node,u)),c.globals.selectionEnabled&&(d.attr({x:e,y:i,width:a>0?a:0,height:r>0?r:0,fill:c.config.chart.selection.fill.color,"fill-opacity":c.config.chart.selection.fill.opacity,stroke:c.config.chart.selection.stroke.color,"stroke-width":c.config.chart.selection.stroke.width,"stroke-dasharray":c.config.chart.selection.stroke.dashArray,"stroke-opacity":c.config.chart.selection.stroke.opacity}),g.setAttrs(d.node,u))}}},{key:"hideSelectionRect",value:function(t){t&&t.attr({x:0,y:0,width:0,height:0})}},{key:"selectionDrawing",value:function(t){var e,i=t.context,a=t.zoomtype,r=this.w,s=i,n=this.gridRect.getBoundingClientRect(),o=s.startX-1,l=s.startY,c=!1,h=!1,d=s.clientX-n.left-o,u=s.clientY-n.top-l;return Math.abs(d+o)>r.globals.gridWidth?d=r.globals.gridWidth-o:s.clientX-n.left<0&&(d=o),o>s.clientX-n.left&&(c=!0,d=Math.abs(d)),l>s.clientY-n.top&&(h=!0,u=Math.abs(u)),e="x"===a?{x:c?o-d:o,y:0,width:d,height:r.globals.gridHeight}:"y"===a?{x:0,y:h?l-u:l,width:r.globals.gridWidth,height:u}:{x:c?o-d:o,y:h?l-u:l,width:d,height:u},s.drawSelectionRect(e),s.selectionDragging("resizing"),e}},{key:"selectionDragging",value:function(t,e){var i=this,a=this.w,r=this.xyRatios,s=this.selectionRect,n=0;"resizing"===t&&(n=30);var o=function(t){return parseFloat(s.node.getAttribute(t))},l={x:o("x"),y:o("y"),width:o("width"),height:o("height")};a.globals.selection=l,"function"==typeof a.config.chart.events.selection&&a.globals.selectionEnabled&&(clearTimeout(this.w.globals.selectionResizeTimer),this.w.globals.selectionResizeTimer=window.setTimeout((function(){var t=i.gridRect.getBoundingClientRect(),e=s.node.getBoundingClientRect(),n={xaxis:{min:a.globals.xAxisScale.niceMin+(e.left-t.left)*r.xRatio,max:a.globals.xAxisScale.niceMin+(e.right-t.left)*r.xRatio},yaxis:{min:a.globals.yAxisScale[0].niceMin+(t.bottom-e.bottom)*r.yRatio[0],max:a.globals.yAxisScale[0].niceMax-(e.top-t.top)*r.yRatio[0]}};a.config.chart.events.selection(i.ctx,n),a.config.chart.brush.enabled&&void 0!==a.config.chart.events.brushScrolled&&a.config.chart.events.brushScrolled(i.ctx,n)}),n))}},{key:"selectionDrawn",value:function(t){var e=t.context,i=t.zoomtype,a=this.w,s=e,n=this.xyRatios,o=this.ctx.toolbar;if(s.startX>s.endX){var l=s.startX;s.startX=s.endX,s.endX=l}if(s.startY>s.endY){var c=s.startY;s.startY=s.endY,s.endY=c}var h=void 0,d=void 0;a.globals.isRangeBar?(h=a.globals.yAxisScale[0].niceMin+s.startX*n.invertedYRatio,d=a.globals.yAxisScale[0].niceMin+s.endX*n.invertedYRatio):(h=a.globals.xAxisScale.niceMin+s.startX*n.xRatio,d=a.globals.xAxisScale.niceMin+s.endX*n.xRatio);var u=[],g=[];if(a.config.yaxis.forEach((function(t,e){u.push(a.globals.yAxisScale[e].niceMax-n.yRatio[e]*s.startY),g.push(a.globals.yAxisScale[e].niceMax-n.yRatio[e]*s.endY)})),s.dragged&&(s.dragX>10||s.dragY>10)&&h!==d)if(a.globals.zoomEnabled){var f=r.clone(a.globals.initialConfig.yaxis),p=r.clone(a.globals.initialConfig.xaxis);if(a.globals.zoomed=!0,a.config.xaxis.convertedCatToNumeric&&(h=Math.floor(h),d=Math.floor(d),h<1&&(h=1,d=a.globals.dataPoints),d-h<2&&(d=h+1)),"xy"!==i&&"x"!==i||(p={min:h,max:d}),"xy"!==i&&"y"!==i||f.forEach((function(t,e){f[e].min=g[e],f[e].max=u[e]})),a.config.chart.zoom.autoScaleYaxis){var x=new kt(s.ctx);f=x.autoScaleY(s.ctx,f,{xaxis:p})}if(o){var b=o.getBeforeZoomRange(p,f);b&&(p=b.xaxis?b.xaxis:p,f=b.yaxis?b.yaxis:f)}var v={xaxis:p};a.config.chart.group||(v.yaxis=f),s.ctx.updateHelpers._updateOptions(v,!1,s.w.config.chart.animations.dynamicAnimation.enabled),"function"==typeof a.config.chart.events.zoomed&&o.zoomCallback(p,f)}else if(a.globals.selectionEnabled){var m,y=null;m={min:h,max:d},"xy"!==i&&"y"!==i||(y=r.clone(a.config.yaxis)).forEach((function(t,e){y[e].min=g[e],y[e].max=u[e]})),a.globals.selection=s.selection,"function"==typeof a.config.chart.events.selection&&a.config.chart.events.selection(s.ctx,{xaxis:m,yaxis:y})}}},{key:"panDragging",value:function(t){var e=t.context,i=this.w,a=e;if(void 0!==i.globals.lastClientPosition.x){var r=i.globals.lastClientPosition.x-a.clientX,s=i.globals.lastClientPosition.y-a.clientY;Math.abs(r)>Math.abs(s)&&r>0?this.moveDirection="left":Math.abs(r)>Math.abs(s)&&r<0?this.moveDirection="right":Math.abs(s)>Math.abs(r)&&s>0?this.moveDirection="up":Math.abs(s)>Math.abs(r)&&s<0&&(this.moveDirection="down")}i.globals.lastClientPosition={x:a.clientX,y:a.clientY};var n=i.globals.isRangeBar?i.globals.minY:i.globals.minX,o=i.globals.isRangeBar?i.globals.maxY:i.globals.maxX;i.config.xaxis.convertedCatToNumeric||a.panScrolled(n,o)}},{key:"delayedPanScrolled",value:function(){var t=this.w,e=t.globals.minX,i=t.globals.maxX,a=(t.globals.maxX-t.globals.minX)/2;"left"===this.moveDirection?(e=t.globals.minX+a,i=t.globals.maxX+a):"right"===this.moveDirection&&(e=t.globals.minX-a,i=t.globals.maxX-a),e=Math.floor(e),i=Math.floor(i),this.updateScrolledChart({xaxis:{min:e,max:i}},e,i)}},{key:"panScrolled",value:function(t,e){var i=this.w,a=this.xyRatios,s=r.clone(i.globals.initialConfig.yaxis),n=a.xRatio,o=i.globals.minX,l=i.globals.maxX;i.globals.isRangeBar&&(n=a.invertedYRatio,o=i.globals.minY,l=i.globals.maxY),"left"===this.moveDirection?(t=o+i.globals.gridWidth/15*n,e=l+i.globals.gridWidth/15*n):"right"===this.moveDirection&&(t=o-i.globals.gridWidth/15*n,e=l-i.globals.gridWidth/15*n),i.globals.isRangeBar||(ti.globals.initialMaxX)&&(t=o,e=l);var c={min:t,max:e};i.config.chart.zoom.autoScaleYaxis&&(s=new kt(this.ctx).autoScaleY(this.ctx,s,{xaxis:c}));var h={xaxis:{min:t,max:e}};i.config.chart.group||(h.yaxis=s),this.updateScrolledChart(h,t,e)}},{key:"updateScrolledChart",value:function(t,e,i){var a=this.w;this.ctx.updateHelpers._updateOptions(t,!1,!1),"function"==typeof a.config.chart.events.scrolled&&a.config.chart.events.scrolled(this.ctx,{xaxis:{min:e,max:i}})}}])&&we(e.prototype,i),o}(me);function Ce(t){return function(t){if(Array.isArray(t))return Pe(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,e){if(t){if("string"==typeof t)return Pe(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?Pe(t,e):void 0}}(t)||function(){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 Pe(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);il||f>c?(e.classList.remove("hovering-zoom"),e.classList.remove("hovering-pan")):n.globals.zoomEnabled?(e.classList.remove("hovering-pan"),e.classList.add("hovering-zoom")):n.globals.panEnabled&&(e.classList.remove("hovering-zoom"),e.classList.add("hovering-pan"));var p=Math.round(g/h),x=Math.floor(f/d);u&&!n.config.xaxis.convertedCatToNumeric&&(p=Math.ceil(g/h),p-=1);var b=null,v=null,m=[],y=[];if(n.globals.seriesXvalues.forEach((function(t){m.push([t[0]+1e-6].concat(t))})),n.globals.seriesYvalues.forEach((function(t){y.push([t[0]+1e-6].concat(t))})),m=m.map((function(t){return t.filter((function(t){return r.isNumber(t)}))})),y=y.map((function(t){return t.filter((function(t){return r.isNumber(t)}))})),n.globals.isXNumeric){var w=this.ttCtx.getElGrid().getBoundingClientRect(),k=g*(w.width/l),A=f*(w.height/c);b=(v=this.closestInMultiArray(k,A,m,y)).index,p=v.j,null!==b&&(m=n.globals.seriesXvalues[b],p=(v=this.closestInArray(k,m)).index)}return n.globals.capturedSeriesIndex=null===b?-1:b,(!p||p<1)&&(p=0),n.globals.isBarHorizontal?n.globals.capturedDataPointIndex=x:n.globals.capturedDataPointIndex=p,{capturedSeries:b,j:n.globals.isBarHorizontal?x:p,hoverX:g,hoverY:f}}},{key:"closestInMultiArray",value:function(t,e,i,a){var r=this.w,s=0,n=null,o=-1;r.globals.series.length>1?s=this.getFirstActiveXArray(i):n=0;var l=i[s][0],c=Math.abs(t-l);if(i.forEach((function(e){e.forEach((function(e,i){var a=Math.abs(t-e);a0?e:-1})),r=0;r0)for(var a=0;a *")):this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap > *")}},{key:"getAllMarkers",value:function(){var t=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap");(t=Ce(t)).sort((function(t,e){var i=Number(t.getAttribute("data:realIndex")),a=Number(e.getAttribute("data:realIndex"));return ai?-1:0}));var e=[];return t.forEach((function(t){e.push(t.querySelector(".apexcharts-marker"))})),e}},{key:"hasMarkers",value:function(t){return this.getElMarkers(t).length>0}},{key:"getElBars",value:function(){return this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-bar-series, .apexcharts-candlestick-series, .apexcharts-boxPlot-series, .apexcharts-rangebar-series")}},{key:"hasBars",value:function(){return this.getElBars().length>0}},{key:"getHoverMarkerSize",value:function(t){var e=this.w,i=e.config.markers.hover.size;return void 0===i&&(i=e.globals.markers.size[t]+e.config.markers.hover.sizeOffset),i}},{key:"toggleAllTooltipSeriesGroups",value:function(t){var e=this.w,i=this.ttCtx;0===i.allTooltipSeriesGroups.length&&(i.allTooltipSeriesGroups=e.globals.dom.baseEl.querySelectorAll(".apexcharts-tooltip-series-group"));for(var a=i.allTooltipSeriesGroups,r=0;r ').concat(i.attrs.name,""),e+="
".concat(i.val,"
")})),v.innerHTML=t+"",m.innerHTML=e+""};n?l.globals.seriesGoals[e][i]&&Array.isArray(l.globals.seriesGoals[e][i])?y():(v.innerHTML="",m.innerHTML=""):y()}else v.innerHTML="",m.innerHTML="";null!==f&&(a[e].querySelector(".apexcharts-tooltip-text-z-label").innerHTML=l.config.tooltip.z.title,a[e].querySelector(".apexcharts-tooltip-text-z-value").innerHTML=void 0!==f?f:""),n&&p[0]&&(null==h||l.globals.ancillaryCollapsedSeriesIndices.indexOf(e)>-1||l.globals.collapsedSeriesIndices.indexOf(e)>-1?p[0].parentNode.style.display="none":p[0].parentNode.style.display=l.config.tooltip.items.display)}},{key:"toggleActiveInactiveSeries",value:function(t){var e=this.w;if(t)this.tooltipUtil.toggleAllTooltipSeriesGroups("enable");else{this.tooltipUtil.toggleAllTooltipSeriesGroups("disable");var i=e.globals.dom.baseEl.querySelector(".apexcharts-tooltip-series-group");i&&(i.classList.add("apexcharts-active"),i.style.display=e.config.tooltip.items.display)}}},{key:"getValuesToPrint",value:function(t){var e=t.i,i=t.j,a=this.w,r=this.ctx.series.filteredSeriesX(),s="",n="",o=null,l=null,c={series:a.globals.series,seriesIndex:e,dataPointIndex:i,w:a},h=a.globals.ttZFormatter;null===i?l=a.globals.series[e]:a.globals.isXNumeric&&"treemap"!==a.config.chart.type?(s=r[e][i],0===r[e].length&&(s=r[this.tooltipUtil.getFirstActiveXArray(r)][i])):s=void 0!==a.globals.labels[i]?a.globals.labels[i]:"";var d=s;return s=a.globals.isXNumeric&&"datetime"===a.config.xaxis.type?new z(this.ctx).xLabelFormat(a.globals.ttKeyFormatter,d,d,{i:void 0,dateFormatter:new M(this.ctx).formatDate,w:this.w}):a.globals.isBarHorizontal?a.globals.yLabelFormatters[0](d,c):a.globals.xLabelFormatter(d,c),void 0!==a.config.tooltip.x.formatter&&(s=a.globals.ttKeyFormatter(d,c)),a.globals.seriesZ.length>0&&a.globals.seriesZ[e].length>0&&(o=h(a.globals.seriesZ[e][i],a)),n="function"==typeof a.config.xaxis.tooltip.formatter?a.globals.xaxisTooltipFormatter(d,c):s,{val:Array.isArray(l)?l.join(" "):l,xVal:Array.isArray(s)?s.join(" "):s,xAxisTTVal:Array.isArray(n)?n.join(" "):n,zVal:o}}},{key:"handleCustomTooltip",value:function(t){var e=t.i,i=t.j,a=t.y1,r=t.y2,s=t.w,n=this.ttCtx.getElTooltip(),o=s.config.tooltip.custom;Array.isArray(o)&&o[e]&&(o=o[e]),n.innerHTML=o({ctx:this.ctx,series:s.globals.series,seriesIndex:e,dataPointIndex:i,y1:a,y2:r,w:s})}}])&&Me(e.prototype,i),t}();function ze(t,e){for(var i=0;i1&&void 0!==arguments[1]?arguments[1]:null,i=this.ttCtx,a=this.w,r=i.getElXCrosshairs(),s=t-i.xcrosshairsWidth/2,n=a.globals.labels.slice().length;if(null!==e&&(s=a.globals.gridWidth/n*e),null===r||a.globals.isBarHorizontal||(r.setAttribute("x",s),r.setAttribute("x1",s),r.setAttribute("x2",s),r.setAttribute("y2",a.globals.gridHeight),r.classList.add("apexcharts-active")),s<0&&(s=0),s>a.globals.gridWidth&&(s=a.globals.gridWidth),i.isXAxisTooltipEnabled){var o=s;"tickWidth"!==a.config.xaxis.crosshairs.width&&"barWidth"!==a.config.xaxis.crosshairs.width||(o=s+i.xcrosshairsWidth/2),this.moveXAxisTooltip(o)}}},{key:"moveYCrosshairs",value:function(t){var e=this.ttCtx;null!==e.ycrosshairs&&g.setAttrs(e.ycrosshairs,{y1:t,y2:t}),null!==e.ycrosshairsHidden&&g.setAttrs(e.ycrosshairsHidden,{y1:t,y2:t})}},{key:"moveXAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;if(null!==i.xaxisTooltip&&0!==i.xcrosshairsWidth){i.xaxisTooltip.classList.add("apexcharts-active");var a,r=i.xaxisOffY+e.config.xaxis.tooltip.offsetY+e.globals.translateY+1+e.config.xaxis.offsetY;t-=i.xaxisTooltip.getBoundingClientRect().width/2,isNaN(t)||(t+=e.globals.translateX,a=new g(this.ctx).getTextRects(i.xaxisTooltipText.innerHTML),i.xaxisTooltipText.style.minWidth=a.width+"px",i.xaxisTooltip.style.left=t+"px",i.xaxisTooltip.style.top=r+"px")}}},{key:"moveYAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;null===i.yaxisTTEls&&(i.yaxisTTEls=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxistooltip"));var a=parseInt(i.ycrosshairsHidden.getAttribute("y1"),10),r=e.globals.translateY+a,s=i.yaxisTTEls[t].getBoundingClientRect().height,n=e.globals.translateYAxisX[t]-2;e.config.yaxis[t].opposite&&(n-=26),r-=s/2,-1===e.globals.ignoreYAxisIndexes.indexOf(t)?(i.yaxisTTEls[t].classList.add("apexcharts-active"),i.yaxisTTEls[t].style.top=r+"px",i.yaxisTTEls[t].style.left=n+e.config.yaxis[t].tooltip.offsetX+"px"):i.yaxisTTEls[t].classList.remove("apexcharts-active")}},{key:"moveTooltip",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,r=this.ttCtx,s=r.getElTooltip(),n=r.tooltipRect,o=null!==i?parseFloat(i):1,l=parseFloat(t)+o+5,c=parseFloat(e)+o/2;if(l>a.globals.gridWidth/2&&(l=l-n.ttWidth-o-10),l>a.globals.gridWidth-n.ttWidth-10&&(l=a.globals.gridWidth-n.ttWidth),l<-20&&(l=-20),a.config.tooltip.followCursor){var h=r.getElGrid().getBoundingClientRect();(l=r.e.clientX-h.left)>a.globals.gridWidth/2&&(l-=r.tooltipRect.ttWidth),(c=r.e.clientY+a.globals.translateY-h.top)>a.globals.gridHeight/2&&(c-=r.tooltipRect.ttHeight)}else a.globals.isBarHorizontal||n.ttHeight/2+c>a.globals.gridHeight&&(c=a.globals.gridHeight-n.ttHeight+a.globals.translateY);isNaN(l)||(l+=a.globals.translateX,s.style.left=l+"px",s.style.top=c+"px")}},{key:"moveMarkers",value:function(t,e){var i=this.w,a=this.ttCtx;if(i.globals.markers.size[t]>0)for(var r=i.globals.dom.baseEl.querySelectorAll(" .apexcharts-series[data\\:realIndex='".concat(t,"'] .apexcharts-marker")),s=0;s0&&(c.setAttribute("r",o),c.setAttribute("cx",i),c.setAttribute("cy",a)),this.moveXCrosshairs(i),s.fixedTooltip||this.moveTooltip(i,a,o)}}},{key:"moveDynamicPointsOnHover",value:function(t){var e,i=this.ttCtx,a=i.w,r=0,s=0,n=a.globals.pointsArray;e=new ot(this.ctx).getActiveConfigSeriesIndex("asc",["line","area","scatter","bubble"]);var o=i.tooltipUtil.getHoverMarkerSize(e);n[e]&&(r=n[e][t][0],s=n[e][t][1]);var l=i.tooltipUtil.getAllMarkers();if(null!==l)for(var c=0;c0?(l[c]&&l[c].setAttribute("r",o),l[c]&&l[c].setAttribute("cy",d)):l[c]&&l[c].setAttribute("r",0)}}this.moveXCrosshairs(r),i.fixedTooltip||this.moveTooltip(r,s||a.globals.gridHeight,o)}},{key:"moveStickyTooltipOverBars",value:function(t,e){var i=this.w,a=this.ttCtx,r=i.globals.columnSeries?i.globals.columnSeries.length:i.globals.series.length,s=r>=2&&r%2==0?Math.floor(r/2):Math.floor(r/2)+1;i.globals.isBarHorizontal&&(s=new ot(this.ctx).getActiveConfigSeriesIndex("desc")+1);var n=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[rel='".concat(s,"'] path[j='").concat(t,"'], .apexcharts-candlestick-series .apexcharts-series[rel='").concat(s,"'] path[j='").concat(t,"'], .apexcharts-boxPlot-series .apexcharts-series[rel='").concat(s,"'] path[j='").concat(t,"'], .apexcharts-rangebar-series .apexcharts-series[rel='").concat(s,"'] path[j='").concat(t,"']"));n||"number"!=typeof e||(n=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[data\\:realIndex='".concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-candlestick-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-boxPlot-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-rangebar-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"']")));var o=n?parseFloat(n.getAttribute("cx")):0,l=n?parseFloat(n.getAttribute("cy")):0,c=n?parseFloat(n.getAttribute("barWidth")):0,h=a.getElGrid().getBoundingClientRect(),d=n&&(n.classList.contains("apexcharts-candlestick-area")||n.classList.contains("apexcharts-boxPlot-area"));i.globals.isXNumeric?(n&&!d&&(o-=r%2!=0?c/2:0),n&&d&&i.globals.comboCharts&&(o-=c/2)):i.globals.isBarHorizontal||(o=a.xAxisTicksPositions[t-1]+a.dataPointsDividedWidth/2,isNaN(o)&&(o=a.xAxisTicksPositions[t]-a.dataPointsDividedWidth/2)),i.globals.isBarHorizontal?l-=a.tooltipRect.ttHeight:i.config.tooltip.followCursor?l=a.e.clientY-h.top-a.tooltipRect.ttHeight/2:l+a.tooltipRect.ttHeight+15>i.globals.gridHeight&&(l=i.globals.gridHeight),i.globals.isBarHorizontal||this.moveXCrosshairs(o),a.fixedTooltip||this.moveTooltip(o,l||i.globals.gridHeight)}}],i&&ze(e.prototype,i),t}();function De(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);i2&&void 0!==arguments[2]?arguments[2]:null,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,r=this.w;"bubble"!==r.config.chart.type&&this.newPointSize(t,e);var s=e.getAttribute("cx"),n=e.getAttribute("cy");if(null!==i&&null!==a&&(s=i,n=a),this.tooltipPosition.moveXCrosshairs(s),!this.fixedTooltip){if("radar"===r.config.chart.type){var o=this.ttCtx.getElGrid().getBoundingClientRect();s=this.ttCtx.e.clientX-o.left}this.tooltipPosition.moveTooltip(s,n,r.config.markers.hover.size)}}},{key:"enlargePoints",value:function(t){for(var e=this.w,i=this,a=this.ttCtx,r=t,s=e.globals.dom.baseEl.querySelectorAll(".apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker"),n=e.config.markers.hover.size,o=0;o=0?t[e].setAttribute("r",i):t[e].setAttribute("r",0)}}}],i&&Re(e.prototype,i),t}();function He(t,e){for(var i=0;io.globals.gridWidth/2&&(a=h-n.tooltipRect.ttWidth/2+u),n.w.config.tooltip.followCursor){var f=o.globals.dom.elWrap.getBoundingClientRect();a=o.globals.clientX-f.left-(a>o.globals.gridWidth/2?n.tooltipRect.ttWidth:0),r=o.globals.clientY-f.top-(r>o.globals.gridHeight/2?n.tooltipRect.ttHeight:0)}}return{x:a,y:r}}},{key:"handleMarkerTooltip",value:function(t){var e,i,a=t.e,s=t.opt,n=t.x,o=t.y,l=this.w,c=this.ttCtx;if(a.target.classList.contains("apexcharts-marker")){var h=parseInt(s.paths.getAttribute("cx"),10),d=parseInt(s.paths.getAttribute("cy"),10),u=parseFloat(s.paths.getAttribute("val"));if(i=parseInt(s.paths.getAttribute("rel"),10),e=parseInt(s.paths.parentNode.parentNode.parentNode.getAttribute("rel"),10)-1,c.intersect){var g=r.findAncestor(s.paths,"apexcharts-series");g&&(e=parseInt(g.getAttribute("data:realIndex"),10))}if(c.tooltipLabels.drawSeriesTexts({ttItems:s.ttItems,i:e,j:i,shared:!c.showOnIntersect&&l.config.tooltip.shared,e:a}),"mouseup"===a.type&&c.markerClick(a,e,i),l.globals.capturedSeriesIndex=e,l.globals.capturedDataPointIndex=i,n=h,o=d+l.globals.translateY-1.4*c.tooltipRect.ttHeight,c.w.config.tooltip.followCursor){var f=c.getElGrid().getBoundingClientRect();o=c.e.clientY+l.globals.translateY-f.top}u<0&&(o=d),c.marker.enlargeCurrentPoint(i,s.paths,n,o)}return{x:n,y:o}}},{key:"handleBarTooltip",value:function(t){var e,i,a=t.e,r=t.opt,s=this.w,n=this.ttCtx,o=n.getElTooltip(),l=0,c=0,h=0,d=this.getBarTooltipXY({e:a,opt:r});e=d.i;var u=d.barHeight,g=d.j;s.globals.capturedSeriesIndex=e,s.globals.capturedDataPointIndex=g,s.globals.isBarHorizontal&&n.tooltipUtil.hasBars()||!s.config.tooltip.shared?(c=d.x,h=d.y,i=Array.isArray(s.config.stroke.width)?s.config.stroke.width[e]:s.config.stroke.width,l=c):s.globals.comboCharts||s.config.tooltip.shared||(l/=2),isNaN(h)&&(h=s.globals.svgHeight-n.tooltipRect.ttHeight);var f=parseInt(r.paths.parentNode.getAttribute("data:realIndex"),10),p=s.globals.isMultipleYAxis?s.config.yaxis[f]&&s.config.yaxis[f].reversed:s.config.yaxis[0].reversed;if(c+n.tooltipRect.ttWidth>s.globals.gridWidth&&!p?c-=n.tooltipRect.ttWidth:c<0&&(c=0),n.w.config.tooltip.followCursor){var x=n.getElGrid().getBoundingClientRect();h=n.e.clientY-x.top}null===n.tooltip&&(n.tooltip=s.globals.dom.baseEl.querySelector(".apexcharts-tooltip")),s.config.tooltip.shared||(s.globals.comboBarCount>0?n.tooltipPosition.moveXCrosshairs(l+i/2):n.tooltipPosition.moveXCrosshairs(l)),!n.fixedTooltip&&(!s.config.tooltip.shared||s.globals.isBarHorizontal&&n.tooltipUtil.hasBars())&&(p&&(c-=n.tooltipRect.ttWidth)<0&&(c=0),!p||s.globals.isBarHorizontal&&n.tooltipUtil.hasBars()||(h=h+u-2*(s.globals.series[e][g]<0?u:0)),h=h+s.globals.translateY-n.tooltipRect.ttHeight/2,o.style.left=c+s.globals.translateX+"px",o.style.top=h+"px")}},{key:"getBarTooltipXY",value:function(t){var e=t.e,i=t.opt,a=this.w,r=null,s=this.ttCtx,n=0,o=0,l=0,c=0,h=0,d=e.target.classList;if(d.contains("apexcharts-bar-area")||d.contains("apexcharts-candlestick-area")||d.contains("apexcharts-boxPlot-area")||d.contains("apexcharts-rangebar-area")){var u=e.target,g=u.getBoundingClientRect(),f=i.elGrid.getBoundingClientRect(),p=g.height;h=g.height;var x=g.width,b=parseInt(u.getAttribute("cx"),10),v=parseInt(u.getAttribute("cy"),10);c=parseFloat(u.getAttribute("barWidth"));var m="touchmove"===e.type?e.touches[0].clientX:e.clientX;r=parseInt(u.getAttribute("j"),10),n=parseInt(u.parentNode.getAttribute("rel"),10)-1;var y=u.getAttribute("data-range-y1"),w=u.getAttribute("data-range-y2");a.globals.comboCharts&&(n=parseInt(u.parentNode.getAttribute("data:realIndex"),10)),s.tooltipLabels.drawSeriesTexts({ttItems:i.ttItems,i:n,j:r,y1:y?parseInt(y,10):null,y2:w?parseInt(w,10):null,shared:!s.showOnIntersect&&a.config.tooltip.shared,e}),a.config.tooltip.followCursor?a.globals.isBarHorizontal?(o=m-f.left+15,l=v-s.dataPointsDividedHeight+p/2-s.tooltipRect.ttHeight/2):(o=a.globals.isXNumeric?b-x/2:b-s.dataPointsDividedWidth+x/2,l=e.clientY-f.top-s.tooltipRect.ttHeight/2-15):a.globals.isBarHorizontal?((o=b)0&&i.setAttribute("width",e.xcrosshairsWidth)}},{key:"handleYCrosshair",value:function(){var t=this.w,e=this.ttCtx;e.ycrosshairs=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs"),e.ycrosshairsHidden=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs-hidden")}},{key:"drawYaxisTooltipText",value:function(t,e,i){var a=this.ttCtx,r=this.w,s=r.globals.yLabelFormatters[t];if(a.yaxisTooltips[t]){var n=a.getElGrid().getBoundingClientRect(),o=(e-n.top)*i.yRatio[t],l=r.globals.maxYArr[t]-r.globals.minYArr[t],c=r.globals.minYArr[t]+(l-o);a.tooltipPosition.moveYCrosshairs(e-n.top),a.yaxisTooltipText[t].innerHTML=s(c),a.tooltipPosition.moveYAxisTooltip(t)}}}])&&We(e.prototype,i),t}();function Be(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function Ge(t){for(var e=1;e0&&this.addPathsEventListeners(g,h),this.tooltipUtil.hasBars()&&!this.tConfig.shared&&this.addDatapointEventsListeners(h)}}},{key:"drawFixedTooltipRect",value:function(){var t=this.w,e=this.getElTooltip(),i=e.getBoundingClientRect(),a=i.width+10,r=i.height+10,s=this.tConfig.fixed.offsetX,n=this.tConfig.fixed.offsetY,o=this.tConfig.fixed.position.toLowerCase();return o.indexOf("right")>-1&&(s=s+t.globals.svgWidth-a+10),o.indexOf("bottom")>-1&&(n=n+t.globals.svgHeight-r-10),e.style.left=s+"px",e.style.top=n+"px",{x:s,y:n,ttWidth:a,ttHeight:r}}},{key:"addDatapointEventsListeners",value:function(t){var e=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers .apexcharts-marker, .apexcharts-bar-area, .apexcharts-candlestick-area, .apexcharts-boxPlot-area, .apexcharts-rangebar-area");this.addPathsEventListeners(e,t)}},{key:"addPathsEventListeners",value:function(t,e){for(var i=this,a=function(a){var r={paths:t[a],tooltipEl:e.tooltipEl,tooltipY:e.tooltipY,tooltipX:e.tooltipX,elGrid:e.elGrid,hoverArea:e.hoverArea,ttItems:e.ttItems};["mousemove","mouseup","touchmove","mouseout","touchend"].map((function(e){return t[a].addEventListener(e,i.onSeriesHover.bind(i,r),{capture:!1,passive:!0})}))},r=0;r=100?this.seriesHover(t,e):(clearTimeout(this.seriesHoverTimeout),this.seriesHoverTimeout=setTimeout((function(){i.seriesHover(t,e)}),100-a))}},{key:"seriesHover",value:function(t,e){var i=this;this.lastHoverTime=Date.now();var a=[],r=this.w;r.config.chart.group&&(a=this.ctx.getGroupedCharts()),r.globals.axisCharts&&(r.globals.minX===-1/0&&r.globals.maxX===1/0||0===r.globals.dataPoints)||(a.length?a.forEach((function(a){var r=i.getElTooltip(a),s={paths:t.paths,tooltipEl:r,tooltipY:t.tooltipY,tooltipX:t.tooltipX,elGrid:t.elGrid,hoverArea:t.hoverArea,ttItems:a.w.globals.tooltip.ttItems};a.w.globals.minX===i.w.globals.minX&&a.w.globals.maxX===i.w.globals.maxX&&a.w.globals.tooltip.seriesHoverByContext({chartCtx:a,ttCtx:a.w.globals.tooltip,opt:s,e})})):this.seriesHoverByContext({chartCtx:this.ctx,ttCtx:this.w.globals.tooltip,opt:t,e}))}},{key:"seriesHoverByContext",value:function(t){var e=t.chartCtx,i=t.ttCtx,a=t.opt,r=t.e,s=e.w,n=this.getElTooltip();n&&(i.tooltipRect={x:0,y:0,ttWidth:n.getBoundingClientRect().width,ttHeight:n.getBoundingClientRect().height},i.e=r,!i.tooltipUtil.hasBars()||s.globals.comboCharts||i.isBarShared||this.tConfig.onDatasetHover.highlightDataSeries&&new ot(e).toggleSeriesOnHover(r,r.target.parentNode),i.fixedTooltip&&i.drawFixedTooltipRect(),s.globals.axisCharts?i.axisChartsTooltips({e:r,opt:a,tooltipRect:i.tooltipRect}):i.nonAxisChartsTooltips({e:r,opt:a,tooltipRect:i.tooltipRect}))}},{key:"axisChartsTooltips",value:function(t){var e,i,a=t.e,r=t.opt,s=this.w,n=r.elGrid.getBoundingClientRect(),o="touchmove"===a.type?a.touches[0].clientX:a.clientX,l="touchmove"===a.type?a.touches[0].clientY:a.clientY;if(this.clientY=l,this.clientX=o,s.globals.capturedSeriesIndex=-1,s.globals.capturedDataPointIndex=-1,ln.top+n.height)this.handleMouseOut(r);else{if(Array.isArray(this.tConfig.enabledOnSeries)&&!s.config.tooltip.shared){var c=parseInt(r.paths.getAttribute("index"),10);if(this.tConfig.enabledOnSeries.indexOf(c)<0)return void this.handleMouseOut(r)}var h=this.getElTooltip(),d=this.getElXCrosshairs(),u=s.globals.xyCharts||"bar"===s.config.chart.type&&!s.globals.isBarHorizontal&&this.tooltipUtil.hasBars()&&this.tConfig.shared||s.globals.comboCharts&&this.tooltipUtil.hasBars();if("mousemove"===a.type||"touchmove"===a.type||"mouseup"===a.type){if(s.globals.collapsedSeries.length+s.globals.ancillaryCollapsedSeries.length===s.globals.series.length)return;null!==d&&d.classList.add("apexcharts-active");var g=this.yaxisTooltips.filter((function(t){return!0===t}));if(null!==this.ycrosshairs&&g.length&&this.ycrosshairs.classList.add("apexcharts-active"),u&&!this.showOnIntersect)this.handleStickyTooltip(a,o,l,r);else if("heatmap"===s.config.chart.type||"treemap"===s.config.chart.type){var f=this.intersect.handleHeatTreeTooltip({e:a,opt:r,x:e,y:i,type:s.config.chart.type});e=f.x,i=f.y,h.style.left=e+"px",h.style.top=i+"px"}else this.tooltipUtil.hasBars()&&this.intersect.handleBarTooltip({e:a,opt:r}),this.tooltipUtil.hasMarkers()&&this.intersect.handleMarkerTooltip({e:a,opt:r,x:e,y:i});if(this.yaxisTooltips.length)for(var p=0;pl.width)this.handleMouseOut(a);else if(null!==o)this.handleStickyCapturedSeries(t,o,a,n);else if(this.tooltipUtil.isXoverlap(n)||r.globals.isBarHorizontal){var c=r.globals.series.findIndex((function(t,e){return!r.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,c,n,a.ttItems)}}},{key:"handleStickyCapturedSeries",value:function(t,e,i,a){var r=this.w;if(this.tConfig.shared||null!==r.globals.series[e][a]){if(void 0!==r.globals.series[e][a])this.tConfig.shared&&this.tooltipUtil.isXoverlap(a)&&this.tooltipUtil.isInitialSeriesSameLen()?this.create(t,this,e,a,i.ttItems):this.create(t,this,e,a,i.ttItems,!1);else if(this.tooltipUtil.isXoverlap(a)){var s=r.globals.series.findIndex((function(t,e){return!r.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,s,a,i.ttItems)}}else this.handleMouseOut(i)}},{key:"deactivateHoverFilter",value:function(){for(var t=this.w,e=new g(this.ctx),i=t.globals.dom.Paper.select(".apexcharts-bar-area"),a=0;a5&&void 0!==arguments[5]?arguments[5]:null,A=this.w,S=e;"mouseup"===t.type&&this.markerClick(t,i,a),null===k&&(k=this.tConfig.shared);var C=this.tooltipUtil.hasMarkers(i),P=this.tooltipUtil.getElBars();if(A.config.legend.tooltipHoverFormatter){var L=A.config.legend.tooltipHoverFormatter,O=Array.from(this.legendLabels);O.forEach((function(t){var e=t.getAttribute("data:default-text");t.innerHTML=decodeURIComponent(e)}));for(var T=0;T0?S.marker.enlargePoints(a):S.tooltipPosition.moveDynamicPointsOnHover(a);else if(this.tooltipUtil.hasBars()&&(this.barSeriesHeight=this.tooltipUtil.getBarsHeight(P),this.barSeriesHeight>0)){var Y=new g(this.ctx),D=A.globals.dom.Paper.select(".apexcharts-bar-area[j='".concat(a,"']"));this.deactivateHoverFilter(),this.tooltipPosition.moveStickyTooltipOverBars(a,i);for(var R=0;Rr.globals.gridHeight&&(p=r.globals.gridHeight-m)),{bcx:h,bcy:c,dataLabelsX:e,dataLabelsY:p,totalDataLabelsX:a,totalDataLabelsY:i,totalDataLabelsAnchor:"middle"}}},{key:"calculateBarsDataLabelsPosition",value:function(t){var e=this.w,i=t.x,a=t.i,r=t.j,s=t.realIndex,n=t.groupIndex,o=t.bcy,l=t.barHeight,c=t.barWidth,h=t.textRects,d=t.dataLabelsX,u=t.strokeWidth,f=t.dataLabelsConfig,p=t.barDataLabelsConfig,x=t.barTotalDataLabelsConfig,b=t.offX,v=t.offY,m=e.globals.gridHeight/e.globals.dataPoints;c=Math.abs(c);var y,w,k=(o+=-1!==n?n*l:0)-(this.barCtx.isRangeBar?0:m)+l/2+h.height/2+v-3,A="start",S=this.barCtx.series[a][r]<0,C=i;switch(this.barCtx.isReversed&&(C=i+c-(S?2*c:0),i=e.globals.gridWidth-c),p.position){case"center":d=S?C+c/2-b:Math.max(h.width/2,C-c/2)+b;break;case"bottom":d=S?C+c-u-Math.round(h.width/2)-b:C-c+u+Math.round(h.width/2)+b;break;case"top":d=S?C-u+Math.round(h.width/2)-b:C-u-Math.round(h.width/2)+b}if(this.barCtx.lastActiveBarSerieIndex===s&&x.enabled){var P=new g(this.barCtx.ctx).getTextRects(this.getStackedTotalDataLabel({realIndex:s,j:r}),f.fontSize);S?(y=C-u+Math.round(P.width/2)-b-x.offsetX-15,A="end"):y=C-u-Math.round(P.width/2)+b+x.offsetX+15,w=k+x.offsetY}return e.config.chart.stacked||(d<0?d=d+h.width+u:d+h.width/2>e.globals.gridWidth&&(d=e.globals.gridWidth-h.width-u)),{bcx:i,bcy:o,dataLabelsX:d,dataLabelsY:k,totalDataLabelsX:y,totalDataLabelsY:w,totalDataLabelsAnchor:A}}},{key:"drawCalculatedDataLabels",value:function(t){var e=t.x,i=t.y,a=t.val,r=t.i,s=t.j,n=t.textRects,o=t.barHeight,l=t.barWidth,c=t.dataLabelsConfig,h=this.w,d="rotate(0)";"vertical"===h.config.plotOptions.bar.dataLabels.orientation&&(d="rotate(-90, ".concat(e,", ").concat(i,")"));var u=new st(this.barCtx.ctx),f=new g(this.barCtx.ctx),p=c.formatter,x=null,b=h.globals.collapsedSeriesIndices.indexOf(r)>-1;if(c.enabled&&!b){x=f.group({class:"apexcharts-data-labels",transform:d});var v="";void 0!==a&&(v=p(a,Ze(Ze({},h),{},{seriesIndex:r,dataPointIndex:s,w:h}))),!a&&h.config.plotOptions.bar.hideZeroBarsWhenGrouped&&(v="");var m=h.globals.series[r][s]<0,y=h.config.plotOptions.bar.dataLabels.position;"vertical"===h.config.plotOptions.bar.dataLabels.orientation&&("top"===y&&(c.textAnchor=m?"end":"start"),"center"===y&&(c.textAnchor="middle"),"bottom"===y&&(c.textAnchor=m?"end":"start")),this.barCtx.isRangeBar&&this.barCtx.barOptions.dataLabels.hideOverflowingLabels&&lMath.abs(l)&&(v=""):n.height/1.6>Math.abs(o)&&(v=""));var w=Ze({},c);this.barCtx.isHorizontal&&a<0&&("start"===c.textAnchor?w.textAnchor="end":"end"===c.textAnchor&&(w.textAnchor="start")),u.plotDataLabelsText({x:e,y:i,text:v,i:r,j:s,parent:x,dataLabelsConfig:w,alwaysDrawDataLabel:!0,offsetCorrection:!0})}return x}},{key:"drawTotalDataLabels",value:function(t){var e,i=t.x,a=t.y,r=t.val,s=t.realIndex,n=t.textAnchor,o=t.barTotalDataLabelsConfig,l=new g(this.barCtx.ctx);return o.enabled&&void 0!==i&&void 0!==a&&this.barCtx.lastActiveBarSerieIndex===s&&(e=l.drawText({x:i,y:a,foreColor:o.style.color,text:r,textAnchor:n,fontFamily:o.style.fontFamily,fontSize:o.style.fontSize,fontWeight:o.style.fontWeight})),e}}])&&Je(e.prototype,i),t}();function Ke(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function ti(t){for(var e=1;e0&&(this.barCtx.seriesLen=this.barCtx.seriesLen+1,this.barCtx.totalItems+=t[i].length),e.globals.isXNumeric)for(var a=0;ae.globals.minX&&e.globals.seriesX[i][a]0&&(a=l.globals.minXDiff/d),(s=a/this.barCtx.seriesLen*parseInt(this.barCtx.barOptions.columnWidth,10)/100)<1&&(s=1)}-1===String(this.barCtx.barOptions.columnWidth).indexOf("%")&&(s=parseInt(this.barCtx.barOptions.columnWidth,10)),n=l.globals.gridHeight-this.barCtx.baseLineY[this.barCtx.yaxisIndex]-(this.barCtx.isReversed?l.globals.gridHeight:0)+(this.barCtx.isReversed?2*this.barCtx.baseLineY[this.barCtx.yaxisIndex]:0),t=l.globals.padHorizontal+(a-s*this.barCtx.seriesLen)/2}return{x:t,y:e,yDivision:i,xDivision:a,barHeight:r,barWidth:s,zeroH:n,zeroW:o}}},{key:"initializeStackedPrevVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].prevY=[],t[e].prevX=[],t[e].prevYF=[],t[e].prevXF=[],t[e].prevYVal=[],t[e].prevXVal=[]})):(t.prevY=[],t.prevX=[],t.prevYF=[],t.prevXF=[],t.prevYVal=[],t.prevXVal=[])}},{key:"initializeStackedXYVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].xArrj=[],t[e].xArrjF=[],t[e].xArrjVal=[],t[e].yArrj=[],t[e].yArrjF=[],t[e].yArrjVal=[]})):(t.xArrj=[],t.xArrjF=[],t.xArrjVal=[],t.yArrj=[],t.yArrjF=[],t.yArrjVal=[])}},{key:"getPathFillColor",value:function(t,e,i,a){var r,s,n,o,l=this.w,c=new K(this.barCtx.ctx),h=null,d=this.barCtx.barOptions.distributed?i:e;return this.barCtx.barOptions.colors.ranges.length>0&&this.barCtx.barOptions.colors.ranges.map((function(a){t[e][i]>=a.from&&t[e][i]<=a.to&&(h=a.color)})),l.config.series[e].data[i]&&l.config.series[e].data[i].fillColor&&(h=l.config.series[e].data[i].fillColor),c.fillPath({seriesNumber:this.barCtx.barOptions.distributed?d:a,dataPointIndex:i,color:h,value:t[e][i],fillConfig:null===(r=l.config.series[e].data[i])||void 0===r?void 0:r.fill,fillType:null!==(s=l.config.series[e].data[i])&&void 0!==s&&null!==(n=s.fill)&&void 0!==n&&n.type?null===(o=l.config.series[e].data[i])||void 0===o?void 0:o.fill.type:l.config.fill.type})}},{key:"getStrokeWidth",value:function(t,e,i){var a=0,r=this.w;return this.barCtx.series[t][e]?this.barCtx.isNullValue=!1:this.barCtx.isNullValue=!0,r.config.stroke.show&&(this.barCtx.isNullValue||(a=Array.isArray(this.barCtx.strokeWidth)?this.barCtx.strokeWidth[i]:this.barCtx.strokeWidth)),a}},{key:"shouldApplyRadius",value:function(t){var e=this.w,i=!1;return e.config.plotOptions.bar.borderRadius>0&&(e.config.chart.stacked&&"last"===e.config.plotOptions.bar.borderRadiusWhenStacked?this.barCtx.lastActiveBarSerieIndex===t&&(i=!0):i=!0),i}},{key:"barBackground",value:function(t){var e=t.j,i=t.i,a=t.x1,r=t.x2,s=t.y1,n=t.y2,o=t.elSeries,l=this.w,c=new g(this.barCtx.ctx),h=new ot(this.barCtx.ctx).getActiveConfigSeriesIndex();if(this.barCtx.barOptions.colors.backgroundBarColors.length>0&&h===i){e>=this.barCtx.barOptions.colors.backgroundBarColors.length&&(e%=this.barCtx.barOptions.colors.backgroundBarColors.length);var d=this.barCtx.barOptions.colors.backgroundBarColors[e],u=c.drawRect(void 0!==a?a:0,void 0!==s?s:0,void 0!==r?r:l.globals.gridWidth,void 0!==n?n:l.globals.gridHeight,this.barCtx.barOptions.colors.backgroundBarRadius,d,this.barCtx.barOptions.colors.backgroundBarOpacity);o.add(u),u.node.classList.add("apexcharts-backgroundBar")}}},{key:"getColumnPaths",value:function(t){var e,i=t.barWidth,a=t.barXPosition,r=t.y1,s=t.y2,n=t.strokeWidth,o=t.seriesGroup,l=t.realIndex,c=t.i,h=t.j,d=t.w,u=new g(this.barCtx.ctx);(n=Array.isArray(n)?n[l]:n)||(n=0);var f=i,p=a;null!==(e=d.config.series[l].data[h])&&void 0!==e&&e.columnWidthOffset&&(p=a-d.config.series[l].data[h].columnWidthOffset/2,f=i+d.config.series[l].data[h].columnWidthOffset);var x=p,b=p+f;r+=.001,s+=.001;var v=u.move(x,r),m=u.move(x,r),y=u.line(b-n,r);if(d.globals.previousPaths.length>0&&(m=this.barCtx.getPreviousPath(l,h,!1)),v=v+u.line(x,s)+u.line(b-n,s)+u.line(b-n,r)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),m=m+u.line(x,r)+y+y+y+y+y+u.line(x,r)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(v=u.roundPathCorners(v,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&o&&(w=this.barCtx[o]),w.yArrj.push(s),w.yArrjF.push(Math.abs(r-s)),w.yArrjVal.push(this.barCtx.series[c][h])}return{pathTo:v,pathFrom:m}}},{key:"getBarpaths",value:function(t){var e,i=t.barYPosition,a=t.barHeight,r=t.x1,s=t.x2,n=t.strokeWidth,o=t.seriesGroup,l=t.realIndex,c=t.i,h=t.j,d=t.w,u=new g(this.barCtx.ctx);(n=Array.isArray(n)?n[l]:n)||(n=0);var f=i,p=a;null!==(e=d.config.series[l].data[h])&&void 0!==e&&e.barHeightOffset&&(f=i-d.config.series[l].data[h].barHeightOffset/2,p=a+d.config.series[l].data[h].barHeightOffset);var x=f,b=f+p;r+=.001,s+=.001;var v=u.move(r,x),m=u.move(r,x);d.globals.previousPaths.length>0&&(m=this.barCtx.getPreviousPath(l,h,!1));var y=u.line(r,b-n);if(v=v+u.line(s,x)+u.line(s,b-n)+y+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),m=m+u.line(r,x)+y+y+y+y+y+u.line(r,x)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(v=u.roundPathCorners(v,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&o&&(w=this.barCtx[o]),w.xArrj.push(s),w.xArrjF.push(Math.abs(r-s)),w.xArrjVal.push(this.barCtx.series[c][h])}return{pathTo:v,pathFrom:m}}},{key:"checkZeroSeries",value:function(t){for(var e=t.series,i=this.w,a=0;a2&&void 0!==arguments[2]&&!arguments[2]?null:e;return null!=t&&(i=e+t/this.barCtx.invertedYRatio-2*(this.barCtx.isReversed?t/this.barCtx.invertedYRatio:0)),i}},{key:"getYForValue",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&!arguments[2]?null:e;return null!=t&&(i=e-t/this.barCtx.yRatio[this.barCtx.yaxisIndex]+2*(this.barCtx.isReversed?t/this.barCtx.yRatio[this.barCtx.yaxisIndex]:0)),i}},{key:"getGoalValues",value:function(t,e,i,a,r){var s=this,n=this.w,o=[],l=function(a,r){var n;o.push((ei(n={},t,"x"===t?s.getXForValue(a,e,!1):s.getYForValue(a,i,!1)),ei(n,"attrs",r),n))};if(n.globals.seriesGoals[a]&&n.globals.seriesGoals[a][r]&&Array.isArray(n.globals.seriesGoals[a][r])&&n.globals.seriesGoals[a][r].forEach((function(t){l(t.value,t)})),this.barCtx.barOptions.isDumbbell&&n.globals.seriesRange.length){var c=this.barCtx.barOptions.dumbbellColors?this.barCtx.barOptions.dumbbellColors:n.globals.colors,h={strokeHeight:"x"===t?0:n.globals.markers.size[a],strokeWidth:"x"===t?n.globals.markers.size[a]:0,strokeDashArray:0,strokeLineCap:"round",strokeColor:Array.isArray(c[a])?c[a][0]:c[a]};l(n.globals.seriesRangeStart[a][r],h),l(n.globals.seriesRangeEnd[a][r],ti(ti({},h),{},{strokeColor:Array.isArray(c[a])?c[a][1]:c[a]}))}return o}},{key:"drawGoalLine",value:function(t){var e=t.barXPosition,i=t.barYPosition,a=t.goalX,r=t.goalY,s=t.barWidth,n=t.barHeight,o=new g(this.barCtx.ctx),l=o.group({className:"apexcharts-bar-goals-groups"});l.node.classList.add("apexcharts-element-hidden"),this.barCtx.w.globals.delayedElements.push({el:l.node}),l.attr("clip-path","url(#gridRectMarkerMask".concat(this.barCtx.w.globals.cuid,")"));var c=null;return this.barCtx.isHorizontal?Array.isArray(a)&&a.forEach((function(t){var e=void 0!==t.attrs.strokeHeight?t.attrs.strokeHeight:n/2,a=i+e+n/2;c=o.drawLine(t.x,a-2*e,t.x,a,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeWidth?t.attrs.strokeWidth:2,t.attrs.strokeLineCap),l.add(c)})):Array.isArray(r)&&r.forEach((function(t){var i=void 0!==t.attrs.strokeWidth?t.attrs.strokeWidth:s/2,a=e+i+s/2;c=o.drawLine(a-2*i,t.y,a,t.y,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeHeight?t.attrs.strokeHeight:2,t.attrs.strokeLineCap),l.add(c)})),l}}],i&&ii(e.prototype,i),t}();function ri(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function si(t){for(var e=1;ethis.barOptions.dataLabels.maxItems&&console.warn("WARNING: DataLabels are enabled but there are too many to display. This may cause performance issue when rendering.");for(var o=0,l=0;o0&&(this.visibleI=this.visibleI+1);var w=0,k=0;this.yRatio.length>1&&(this.yaxisIndex=m),this.isReversed=i.config.yaxis[this.yaxisIndex]&&i.config.yaxis[this.yaxisIndex].reversed;var A=this.barHelpers.initialPositions();x=A.y,w=A.barHeight,h=A.yDivision,u=A.zeroW,f=A.x,k=A.barWidth,c=A.xDivision,d=A.zeroH,this.horizontal||v.push(f+k/2);for(var S=a.group({class:"apexcharts-datalabels","data:realIndex":m}),C=a.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),P=0;P0&&v.push(f+k/2),b.push(x);var E=this.barHelpers.getPathFillColor(t,o,P,m);this.renderSeries({realIndex:m,pathFill:E,j:P,i:o,pathFrom:O.pathFrom,pathTo:O.pathTo,strokeWidth:L,elSeries:y,x:f,y:x,series:t,barHeight:O.barHeight?O.barHeight:w,barWidth:O.barWidth?O.barWidth:k,elDataLabelsWrap:S,elGoalsMarkers:C,visibleSeries:this.visibleI,type:"bar"})}i.globals.seriesXvalues[m]=v,i.globals.seriesYvalues[m]=b,n.add(y)}return n}},{key:"renderSeries",value:function(t){var e=t.realIndex,i=t.pathFill,a=t.lineFill,r=t.j,s=t.i,n=t.groupIndex,o=t.pathFrom,c=t.pathTo,h=t.strokeWidth,d=t.elSeries,u=t.x,f=t.y,p=t.y1,x=t.y2,b=t.series,v=t.barHeight,m=t.barWidth,y=t.barYPosition,w=t.elDataLabelsWrap,k=t.elGoalsMarkers,A=t.visibleSeries,S=t.type,C=this.w,P=new g(this.ctx);a||(a=this.barOptions.distributed?C.globals.stroke.colors[r]:C.globals.stroke.colors[e]),C.config.series[s].data[r]&&C.config.series[s].data[r].strokeColor&&(a=C.config.series[s].data[r].strokeColor),this.isNullValue&&(i="none");var L=r/C.config.chart.animations.animateGradually.delay*(C.config.chart.animations.speed/C.globals.dataPoints)/2.4,O=P.renderPaths({i:s,j:r,realIndex:e,pathFrom:o,pathTo:c,stroke:a,strokeWidth:h,strokeLineCap:C.config.stroke.lineCap,fill:i,animationDelay:L,initialSpeed:C.config.chart.animations.speed,dataChangeSpeed:C.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(S,"-area")});O.attr("clip-path","url(#gridRectMask".concat(C.globals.cuid,")"));var T=C.config.forecastDataPoints;T.count>0&&r>=C.globals.dataPoints-T.count&&(O.node.setAttribute("stroke-dasharray",T.dashArray),O.node.setAttribute("stroke-width",T.strokeWidth),O.node.setAttribute("fill-opacity",T.fillOpacity)),void 0!==p&&void 0!==x&&(O.attr("data-range-y1",p),O.attr("data-range-y2",x)),new l(this.ctx).setSelectionFilter(O,e,r),d.add(O);var I=new Qe(this).handleBarDataLabels({x:u,y:f,y1:p,y2:x,i:s,j:r,series:b,realIndex:e,groupIndex:n,barHeight:v,barWidth:m,barYPosition:y,renderedPath:O,visibleSeries:A});return null!==I.dataLabels&&w.add(I.dataLabels),I.totalDataLabels&&w.add(I.totalDataLabels),d.add(w),k&&d.add(k),d}},{key:"drawBarPaths",value:function(t){var e,i=t.indexes,a=t.barHeight,r=t.strokeWidth,s=t.zeroW,n=t.x,o=t.y,l=t.yDivision,c=t.elSeries,h=this.w,d=i.i,u=i.j;if(h.globals.isXNumeric)e=(o=(h.globals.seriesX[d][u]-h.globals.minX)/this.invertedXRatio-a)+a*this.visibleI;else if(h.config.plotOptions.bar.hideZeroBarsWhenGrouped){var g=0,f=0;h.globals.seriesPercent.forEach((function(t,e){t[u]&&g++,e0&&(a=this.seriesLen*a/g),e=o+a*this.visibleI,e-=a*f}else e=o+a*this.visibleI;n=this.barHelpers.getXForValue(this.series[d][u],s);var p=this.barHelpers.getBarpaths({barYPosition:e,barHeight:a,x1:s,x2:n,strokeWidth:r,series:this.series,realIndex:i.realIndex,i:d,j:u,w:h});return h.globals.isXNumeric||(o+=l),this.barHelpers.barBackground({j:u,i:d,y1:e-a*this.visibleI,y2:a*this.seriesLen,elSeries:c}),{pathTo:p.pathTo,pathFrom:p.pathFrom,x:n,y:o,goalX:this.barHelpers.getGoalValues("x",s,null,d,u),barYPosition:e,barHeight:a}}},{key:"drawColumnPaths",value:function(t){var e,i=t.indexes,a=t.x,r=t.y,s=t.xDivision,n=t.barWidth,o=t.zeroH,l=t.strokeWidth,c=t.elSeries,h=this.w,d=i.realIndex,u=i.i,g=i.j,f=i.bc;if(h.globals.isXNumeric){var p=d;h.globals.seriesX[d].length||(p=h.globals.maxValsInArrayIndex),h.globals.seriesX[p][g]&&(a=(h.globals.seriesX[p][g]-h.globals.minX)/this.xRatio-n*this.seriesLen/2),e=a+n*this.visibleI}else if(h.config.plotOptions.bar.hideZeroBarsWhenGrouped){var x=0,b=0;h.globals.seriesPercent.forEach((function(t,e){t[g]&&x++,e0&&(n=this.seriesLen*n/x),e=a+n*this.visibleI,e-=n*b}else e=a+n*this.visibleI;r=this.barHelpers.getYForValue(this.series[u][g],o);var v=this.barHelpers.getColumnPaths({barXPosition:e,barWidth:n,y1:o,y2:r,strokeWidth:l,series:this.series,realIndex:i.realIndex,i:u,j:g,w:h});return h.globals.isXNumeric||(a+=s),this.barHelpers.barBackground({bc:f,j:g,i:u,x1:e-l/2-n*this.visibleI,x2:n*this.seriesLen+l/2,elSeries:c}),{pathTo:v.pathTo,pathFrom:v.pathFrom,x:a,y:r,goalY:this.barHelpers.getGoalValues("y",null,o,u,g),barXPosition:e,barWidth:n}}},{key:"getPreviousPath",value:function(t,e){for(var i,a=this.w,r=0;r0&&parseInt(s.realIndex,10)===parseInt(t,10)&&void 0!==a.globals.previousPaths[r].paths[e]&&(i=a.globals.previousPaths[r].paths[e].d)}return i}}])&&oi(e.prototype,i),t}();function ci(t){return ci="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},ci(t)}function hi(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function di(t){for(var e=1;e-1&&(f=e)})),-1!==f&&(i.groupCtx=i[a.globals.seriesGroups[f]]);var p=[],x=[],b=a.globals.comboCharts?e[s]:s;i.yRatio.length>1&&(i.yaxisIndex=b),i.isReversed=a.config.yaxis[i.yaxisIndex]&&a.config.yaxis[i.yaxisIndex].reversed;var v=i.graphics.group({class:"apexcharts-series",seriesName:r.escapeString(a.globals.seriesNames[b]),rel:s+1,"data:realIndex":b});i.ctx.series.addCollapsedClassToSeries(v,b);var m=i.graphics.group({class:"apexcharts-datalabels","data:realIndex":b}),y=i.graphics.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),w=0,k=0,A=i.initialPositions(o,l,h,d,u,g);l=A.y,w=A.barHeight,d=A.yDivision,g=A.zeroW,o=A.x,k=A.barWidth,h=A.xDivision,u=A.zeroH,i.barHelpers.initializeStackedXYVars(i),1===i.groupCtx.prevY.length&&i.groupCtx.prevY[0].every((function(t){return isNaN(t)}))&&(i.groupCtx.prevY[0]=i.groupCtx.prevY[0].map((function(t){return u})),i.groupCtx.prevYF[0]=i.groupCtx.prevYF[0].map((function(t){return 0})));for(var S=0;S1?(i=h.globals.minXDiff/this.xRatio)*parseInt(this.barOptions.columnWidth,10)/100:o*parseInt(h.config.plotOptions.bar.columnWidth,10)/100,null!==(c=h.globals.seriesGroups)&&void 0!==c&&c.length&&(o/=h.globals.seriesGroups.length),-1===String(h.config.plotOptions.bar.columnWidth).indexOf("%")&&(o=parseInt(h.config.plotOptions.bar.columnWidth,10)),r=h.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?h.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),t=h.globals.padHorizontal+(i-o)/2),{x:t,y:e,yDivision:a,xDivision:i,barHeight:n,barWidth:o,zeroH:r,zeroW:s}}},{key:"drawStackedBarPaths",value:function(t){for(var e,i=t.indexes,a=t.barHeight,r=t.strokeWidth,s=t.zeroW,n=t.x,o=t.y,l=t.groupIndex,c=t.seriesGroup,h=t.yDivision,d=t.elSeries,u=this.w,g=o+(-1!==l?l*a:0),f=i.i,p=i.j,x=0,b=0;b0){var m=s;this.groupCtx.prevXVal[v-1][p]<0?m=this.series[f][p]>=0?this.groupCtx.prevX[v-1][p]+x-2*(this.isReversed?x:0):this.groupCtx.prevX[v-1][p]:this.groupCtx.prevXVal[v-1][p]>=0&&(m=this.series[f][p]>=0?this.groupCtx.prevX[v-1][p]:this.groupCtx.prevX[v-1][p]-x+2*(this.isReversed?x:0)),e=m}else e=s;n=null===this.series[f][p]?e:e+this.series[f][p]/this.invertedYRatio-2*(this.isReversed?this.series[f][p]/this.invertedYRatio:0);var y=this.barHelpers.getBarpaths({barYPosition:g,barHeight:a,x1:e,x2:n,strokeWidth:r,series:this.series,realIndex:i.realIndex,seriesGroup:c,i:f,j:p,w:u});return this.barHelpers.barBackground({j:p,i:f,y1:g,y2:a,elSeries:d}),o+=h,{pathTo:y.pathTo,pathFrom:y.pathFrom,goalX:this.barHelpers.getGoalValues("x",s,null,f,p),barYPosition:g,x:n,y:o}}},{key:"drawStackedColumnPaths",value:function(t){var e=t.indexes,i=t.x,a=t.y,r=t.xDivision,s=t.barWidth,n=t.zeroH,o=t.groupIndex,l=t.seriesGroup,c=t.elSeries,h=this.w,d=e.i,u=e.j,g=e.bc;if(h.globals.isXNumeric){var f=h.globals.seriesX[d][u];f||(f=0),i=(f-h.globals.minX)/this.xRatio-s/2,h.globals.seriesGroups.length&&(i=(f-h.globals.minX)/this.xRatio-s/2*h.globals.seriesGroups.length)}for(var p,x=i+(-1!==o?o*s:0),b=0,v=0;v0&&!h.globals.isXNumeric||m>0&&h.globals.isXNumeric&&h.globals.seriesX[d-1][u]===h.globals.seriesX[d][u]){var y,w,k,A=Math.min(this.yRatio.length+1,d+1);if(void 0!==this.groupCtx.prevY[m-1]&&this.groupCtx.prevY[m-1].length)for(var S=1;S=0?k-b+2*(this.isReversed?b:0):k;break}if((null===(O=this.groupCtx.prevYVal[m-P])||void 0===O?void 0:O[u])>=0){w=this.series[d][u]>=0?k:k+b-2*(this.isReversed?b:0);break}}void 0===w&&(w=h.globals.gridHeight),p=null!==(y=this.groupCtx.prevYF[0])&&void 0!==y&&y.every((function(t){return 0===t}))&&this.groupCtx.prevYF.slice(1,m).every((function(t){return t.every((function(t){return isNaN(t)}))}))?n:w}else p=n;a=this.series[d][u]?p-this.series[d][u]/this.yRatio[this.yaxisIndex]+2*(this.isReversed?this.series[d][u]/this.yRatio[this.yaxisIndex]:0):p;var T=this.barHelpers.getColumnPaths({barXPosition:x,barWidth:s,y1:p,y2:a,yRatio:this.yRatio[this.yaxisIndex],strokeWidth:this.strokeWidth,series:this.series,seriesGroup:l,realIndex:e.realIndex,i:d,j:u,w:h});return this.barHelpers.barBackground({bc:g,j:u,i:d,x1:x,x2:s,elSeries:c}),i+=r,{pathTo:T.pathTo,pathFrom:T.pathFrom,goalY:this.barHelpers.getGoalValues("y",null,n,d,u),barXPosition:x,x:h.globals.isXNumeric?i-r:i,y:a}}}])&&gi(e.prototype,i),o}(li);function bi(t){return bi="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},bi(t)}function vi(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function mi(t){for(var e=1;e0&&(a.visibleI=a.visibleI+1),a.yRatio.length>1&&(a.yaxisIndex=m);var w=a.barHelpers.initialPositions();x=w.y,g=w.barHeight,c=w.yDivision,u=w.zeroW,p=w.x,f=w.barWidth,o=w.xDivision,d=w.zeroH,v.push(p+f/2);for(var k=n.group({class:"apexcharts-datalabels","data:realIndex":m}),A=function(i){var r=a.barHelpers.getStrokeWidth(e,i,m),n=null,h={indexes:{i:e,j:i,realIndex:m},x:p,y:x,strokeWidth:r,elSeries:y};n=a.isHorizontal?a.drawHorizontalBoxPaths(mi(mi({},h),{},{yDivision:c,barHeight:g,zeroW:u})):a.drawVerticalBoxPaths(mi(mi({},h),{},{xDivision:o,barWidth:f,zeroH:d})),x=n.y,p=n.x,i>0&&v.push(p+f/2),b.push(x),n.pathTo.forEach((function(o,c){var h=!a.isBoxPlot&&a.candlestickOptions.wick.useFillColor?n.color[c]:s.globals.stroke.colors[e],d=l.fillPath({seriesNumber:m,dataPointIndex:i,color:n.color[c],value:t[e][i]});a.renderSeries({realIndex:m,pathFill:d,lineFill:h,j:i,i:e,pathFrom:n.pathFrom,pathTo:o,strokeWidth:r,elSeries:y,x:p,y:x,series:t,barHeight:g,barWidth:f,elDataLabelsWrap:k,visibleSeries:a.visibleI,type:s.config.chart.type})}))},S=0;Sv.c&&(d=!1);var w=Math.min(v.o,v.c),k=Math.max(v.o,v.c),A=v.m;o.globals.isXNumeric&&(i=(o.globals.seriesX[b][h]-o.globals.minX)/this.xRatio-r/2);var S=i+r*this.visibleI;void 0===this.series[c][h]||null===this.series[c][h]?(w=s,k=s):(w=s-w/x,k=s-k/x,m=s-v.h/x,y=s-v.l/x,A=s-v.m/x);var C=l.move(S,s),P=l.move(S+r/2,w);return o.globals.previousPaths.length>0&&(P=this.getPreviousPath(b,h,!0)),C=this.isBoxPlot?[l.move(S,w)+l.line(S+r/2,w)+l.line(S+r/2,m)+l.line(S+r/4,m)+l.line(S+r-r/4,m)+l.line(S+r/2,m)+l.line(S+r/2,w)+l.line(S+r,w)+l.line(S+r,A)+l.line(S,A)+l.line(S,w+n/2),l.move(S,A)+l.line(S+r,A)+l.line(S+r,k)+l.line(S+r/2,k)+l.line(S+r/2,y)+l.line(S+r-r/4,y)+l.line(S+r/4,y)+l.line(S+r/2,y)+l.line(S+r/2,k)+l.line(S,k)+l.line(S,A)+"z"]:[l.move(S,k)+l.line(S+r/2,k)+l.line(S+r/2,m)+l.line(S+r/2,k)+l.line(S+r,k)+l.line(S+r,w)+l.line(S+r/2,w)+l.line(S+r/2,y)+l.line(S+r/2,w)+l.line(S,w)+l.line(S,k-n/2)],P+=l.move(S,w),o.globals.isXNumeric||(i+=a),{pathTo:C,pathFrom:P,x:i,y:k,barXPosition:S,color:this.isBoxPlot?p:d?[u]:[f]}}},{key:"drawHorizontalBoxPaths",value:function(t){var e=t.indexes,i=(t.x,t.y),a=t.yDivision,r=t.barHeight,s=t.zeroW,n=t.strokeWidth,o=this.w,l=new g(this.ctx),c=e.i,h=e.j,d=this.boxOptions.colors.lower;this.isBoxPlot&&(d=[this.boxOptions.colors.lower,this.boxOptions.colors.upper]);var u=this.invertedYRatio,f=e.realIndex,p=this.getOHLCValue(f,h),x=s,b=s,v=Math.min(p.o,p.c),m=Math.max(p.o,p.c),y=p.m;o.globals.isXNumeric&&(i=(o.globals.seriesX[f][h]-o.globals.minX)/this.invertedXRatio-r/2);var w=i+r*this.visibleI;void 0===this.series[c][h]||null===this.series[c][h]?(v=s,m=s):(v=s+v/u,m=s+m/u,x=s+p.h/u,b=s+p.l/u,y=s+p.m/u);var k=l.move(s,w),A=l.move(v,w+r/2);return o.globals.previousPaths.length>0&&(A=this.getPreviousPath(f,h,!0)),k=[l.move(v,w)+l.line(v,w+r/2)+l.line(x,w+r/2)+l.line(x,w+r/2-r/4)+l.line(x,w+r/2+r/4)+l.line(x,w+r/2)+l.line(v,w+r/2)+l.line(v,w+r)+l.line(y,w+r)+l.line(y,w)+l.line(v+n/2,w),l.move(y,w)+l.line(y,w+r)+l.line(m,w+r)+l.line(m,w+r/2)+l.line(b,w+r/2)+l.line(b,w+r-r/4)+l.line(b,w+r/4)+l.line(b,w+r/2)+l.line(m,w+r/2)+l.line(m,w)+l.line(y,w)+"z"],A+=l.move(v,w),o.globals.isXNumeric||(i+=a),{pathTo:k,pathFrom:A,x:m,y:i,barYPosition:w,color:d}}},{key:"getOHLCValue",value:function(t,e){var i=this.w;return{o:this.isBoxPlot?i.globals.seriesCandleH[t][e]:i.globals.seriesCandleO[t][e],h:this.isBoxPlot?i.globals.seriesCandleO[t][e]:i.globals.seriesCandleH[t][e],m:i.globals.seriesCandleM[t][e],l:this.isBoxPlot?i.globals.seriesCandleC[t][e]:i.globals.seriesCandleL[t][e],c:this.isBoxPlot?i.globals.seriesCandleL[t][e]:i.globals.seriesCandleC[t][e]}}}])&&wi(e.prototype,i),o}(li);function Ci(t){return function(t){if(Array.isArray(t))return Pi(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,e){if(t){if("string"==typeof t)return Pi(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?Pi(t,e):void 0}}(t)||function(){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 Pi(t,e){(null==e||e>t.length)&&(e=t.length);for(var i=0,a=new Array(e);i0&&i.colorScale.ranges.map((function(t,i){t.from<=0&&(e=!0)})),e}},{key:"getShadeColor",value:function(t,e,i,a){var s=this.w,n=1,o=s.config.plotOptions[t].shadeIntensity,l=this.determineColor(t,e,i);s.globals.hasNegs||a?n=s.config.plotOptions[t].reverseNegativeShade?l.percent<0?l.percent/100*(1.25*o):(1-l.percent/100)*(1.25*o):l.percent<=0?1-(1+l.percent/100)*o:(1-l.percent/100)*o:(n=1-l.percent/100,"treemap"===t&&(n=(1-l.percent/100)*(1.25*o)));var c=l.color,h=new r;return s.config.plotOptions[t].enableShades&&(c="dark"===this.w.config.theme.mode?r.hexToRgba(h.shadeColor(-1*n,l.color),s.config.fill.opacity):r.hexToRgba(h.shadeColor(n,l.color),s.config.fill.opacity)),{color:c,colorProps:l}}},{key:"determineColor",value:function(t,e,i){var a=this.w,r=a.globals.series[e][i],s=a.config.plotOptions[t],n=s.colorScale.inverse?i:e;s.distributed&&"treemap"===a.config.chart.type&&(n=i);var o=a.globals.colors[n],l=null,c=Math.min.apply(Math,Ci(a.globals.series[e])),h=Math.max.apply(Math,Ci(a.globals.series[e]));s.distributed||"heatmap"!==t||(c=a.globals.minY,h=a.globals.maxY),void 0!==s.colorScale.min&&(c=s.colorScale.mina.globals.maxY?s.colorScale.max:a.globals.maxY);var d=Math.abs(h)+Math.abs(c),u=100*r/(0===d?d-1e-6:d);return s.colorScale.ranges.length>0&&s.colorScale.ranges.map((function(t,e){if(r>=t.from&&r<=t.to){o=t.color,l=t.foreColor?t.foreColor:null,c=t.from,h=t.to;var i=Math.abs(h)+Math.abs(c);u=100*r/(0===i?i-1e-6:i)}})),{color:o,foreColor:l,percent:u}}},{key:"calculateDataLabels",value:function(t){var e=t.text,i=t.x,a=t.y,r=t.i,s=t.j,n=t.colorProps,o=t.fontSize,l=this.w.config.dataLabels,c=new g(this.ctx),h=new st(this.ctx),d=null;if(l.enabled){d=c.group({class:"apexcharts-data-labels"});var u=l.offsetX,f=l.offsetY,p=i+u,x=a+parseFloat(l.style.fontSize)/3+f;h.plotDataLabelsText({x:p,y:x,text:e,i:r,j:s,color:n.foreColor,parent:d,fontSize:o,dataLabelsConfig:l})}return d}},{key:"addListeners",value:function(t){var e=new g(this.ctx);t.node.addEventListener("mouseenter",e.pathMouseEnter.bind(this,t)),t.node.addEventListener("mouseleave",e.pathMouseLeave.bind(this,t)),t.node.addEventListener("mousedown",e.pathMouseDown.bind(this,t))}}])&&Li(e.prototype,i),t}();function Ti(t,e){for(var i=0;i=0;c?d++:d--){var u=i.group({class:"apexcharts-series apexcharts-heatmap-series",seriesName:r.escapeString(e.globals.seriesNames[d]),rel:d+1,"data:realIndex":d});if(this.ctx.series.addCollapsedClassToSeries(u,d),e.config.chart.dropShadow.enabled){var f=e.config.chart.dropShadow;new l(this.ctx).dropShadow(u,f,d)}for(var p=0,x=e.config.plotOptions.heatmap.shadeIntensity,b=0;b-1&&this.pieClicked(f),i.config.dataLabels.enabled){var A=w.x,S=w.y,C=100*x/this.fullAngle+"%";if(0!==x&&i.config.plotOptions.pie.dataLabels.minAngleToShowLabelthis.fullAngle?e.endAngle=e.endAngle-(a+n):a+n=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle&&(l=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle-.01),Math.ceil(l)>this.fullAngle&&(l-=this.fullAngle);var c=Math.PI*(l-90)/180,h=e.centerX+s*Math.cos(o),d=e.centerY+s*Math.sin(o),u=e.centerX+s*Math.cos(c),g=e.centerY+s*Math.sin(c),f=r.polarToCartesian(e.centerX,e.centerY,e.donutSize,l),p=r.polarToCartesian(e.centerX,e.centerY,e.donutSize,n),x=a>180?1:0,b=["M",h,d,"A",s,s,0,x,1,u,g];return"donut"===e.chartType?[].concat(b,["L",f.x,f.y,"A",e.donutSize,e.donutSize,0,x,0,p.x,p.y,"L",h,d,"z"]).join(" "):"pie"===e.chartType||"polarArea"===e.chartType?[].concat(b,["L",e.centerX,e.centerY,"L",h,d]).join(" "):[].concat(b).join(" ")}},{key:"drawPolarElements",value:function(t){var e=this.w,i=new kt(this.ctx),a=new g(this.ctx),r=new Mi(this.ctx),s=a.group(),n=a.group(),o=i.niceScale(0,Math.ceil(this.maxY),e.config.yaxis[0].tickAmount,0,!0),l=o.result.reverse(),c=o.result.length;this.maxY=o.niceMax;for(var h=e.globals.radialSize,d=h/(c-1),u=0;u1&&t.total.show&&(r=t.total.color);var n=s.globals.dom.baseEl.querySelector(".apexcharts-datalabel-label"),o=s.globals.dom.baseEl.querySelector(".apexcharts-datalabel-value");i=(0,t.value.formatter)(i,s),a||"function"!=typeof t.total.formatter||(i=t.total.formatter(s));var l=e===t.total.label;e=t.name.formatter(e,l,s),null!==n&&(n.textContent=e),null!==o&&(o.textContent=i),null!==n&&(n.style.fill=r)}},{key:"printDataLabelsInner",value:function(t,e){var i=this.w,a=t.getAttribute("data:value"),r=i.globals.seriesNames[parseInt(t.parentNode.getAttribute("rel"),10)-1];i.globals.series.length>1&&this.printInnerLabels(e,r,a,t);var s=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels-group");null!==s&&(s.style.opacity=1)}},{key:"drawSpokes",value:function(t){var e=this,i=this.w,a=new g(this.ctx),s=i.config.plotOptions.polarArea.spokes;if(0!==s.strokeWidth){for(var n=[],o=360/i.globals.series.length,l=0;l1)n&&!e.total.showAlways?l({makeSliceOut:!1,printLabel:!0}):this.printInnerLabels(e,e.total.label,e.total.formatter(r));else if(l({makeSliceOut:!1,printLabel:!0}),!n)if(r.globals.selectedDataPoints.length&&r.globals.series.length>1)if(r.globals.selectedDataPoints[0].length>0){var c=r.globals.selectedDataPoints[0],h=r.globals.dom.baseEl.querySelector(".apexcharts-".concat(this.chartType.toLowerCase(),"-slice-").concat(c));this.printDataLabelsInner(h,e)}else s&&r.globals.selectedDataPoints.length&&0===r.globals.selectedDataPoints[0].length&&(s.style.opacity=0);else s&&r.globals.series.length>1&&(s.style.opacity=0)}}])&&Xi(e.prototype,i),t}();function Yi(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function Di(t){for(var e=1;e0&&(x=e.getPreviousPath(o));for(var b=0;b=10?t.x>0?(i="start",a+=10):t.x<0&&(i="end",a-=10):i="middle",Math.abs(t.y)>=e-10&&(t.y<0?r-=10:t.y>0&&(r+=10)),{textAnchor:i,newX:a,newY:r}}},{key:"getPreviousPath",value:function(t){for(var e=this.w,i=null,a=0;a0&&parseInt(r.realIndex,10)===parseInt(t,10)&&void 0!==e.globals.previousPaths[a].paths[0]&&(i=e.globals.previousPaths[a].paths[0].d)}return i}},{key:"getDataPointsPos",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.dataPointsLen;t=t||[],e=e||[];for(var a=[],r=0;r=360&&(f=360-Math.abs(this.startAngle)-.1);var p=i.drawPath({d:"",stroke:d,strokeWidth:n*parseInt(h.strokeWidth,10)/100,fill:"none",strokeOpacity:h.opacity,classes:"apexcharts-radialbar-area"});if(h.dropShadow.enabled){var x=h.dropShadow;r.dropShadow(p,x)}c.add(p),p.attr("id","apexcharts-radialbarTrack-"+o),this.animatePaths(p,{centerX:t.centerX,centerY:t.centerY,endAngle:f,startAngle:u,size:t.size,i:o,totalItems:2,animBeginArr:0,dur:0,isTrack:!0,easing:e.globals.easing})}return a}},{key:"drawArcs",value:function(t){var e=this.w,i=new g(this.ctx),a=new K(this.ctx),s=new l(this.ctx),n=i.group(),o=this.getStrokeWidth(t);t.size=t.size-o/2;var c=e.config.plotOptions.radialBar.hollow.background,h=t.size-o*t.series.length-this.margin*t.series.length-o*parseInt(e.config.plotOptions.radialBar.track.strokeWidth,10)/100/2,d=h-e.config.plotOptions.radialBar.hollow.margin;void 0!==e.config.plotOptions.radialBar.hollow.image&&(c=this.drawHollowImage(t,n,h,c));var u=this.drawHollow({size:d,centerX:t.centerX,centerY:t.centerY,fill:c||"transparent"});if(e.config.plotOptions.radialBar.hollow.dropShadow.enabled){var f=e.config.plotOptions.radialBar.hollow.dropShadow;s.dropShadow(u,f)}var p=1;!this.radialDataLabels.total.show&&e.globals.series.length>1&&(p=0);var x=null;this.radialDataLabels.show&&(x=this.renderInnerDataLabels(this.radialDataLabels,{hollowSize:h,centerX:t.centerX,centerY:t.centerY,opacity:p})),"back"===e.config.plotOptions.radialBar.hollow.position&&(n.add(u),x&&n.add(x));var b=!1;e.config.plotOptions.radialBar.inverseOrder&&(b=!0);for(var v=b?t.series.length-1:0;b?v>=0:v100?100:t.series[v])/100,S=Math.round(this.totalAngle*A)+this.startAngle,C=void 0;e.globals.dataChanged&&(k=this.startAngle,C=Math.round(this.totalAngle*r.negToZero(e.globals.previousPaths[v])/100)+k),Math.abs(S)+Math.abs(w)>=360&&(S-=.01),Math.abs(C)+Math.abs(k)>=360&&(C-=.01);var P=S-w,L=Array.isArray(e.config.stroke.dashArray)?e.config.stroke.dashArray[v]:e.config.stroke.dashArray,O=i.drawPath({d:"",stroke:y,strokeWidth:o,fill:"none",fillOpacity:e.config.fill.opacity,classes:"apexcharts-radialbar-area apexcharts-radialbar-slice-"+v,strokeDashArray:L});if(g.setAttrs(O.node,{"data:angle":P,"data:value":t.series[v]}),e.config.chart.dropShadow.enabled){var T=e.config.chart.dropShadow;s.dropShadow(O,T,v)}s.setSelectionFilter(O,0,v),this.addListeners(O,this.radialDataLabels),m.add(O),O.attr({index:0,j:v});var I=0;!this.initialAnim||e.globals.resized||e.globals.dataChanged||(I=e.config.chart.animations.speed),e.globals.dataChanged&&(I=e.config.chart.animations.dynamicAnimation.speed),this.animDur=I/(1.2*t.series.length)+this.animDur,this.animBeginArr.push(this.animDur),this.animatePaths(O,{centerX:t.centerX,centerY:t.centerY,endAngle:S,startAngle:w,prevEndAngle:C,prevStartAngle:k,size:t.size,i:v,totalItems:2,animBeginArr:this.animBeginArr,dur:I,shouldSetPrevPaths:!0,easing:e.globals.easing})}return{g:n,elHollow:u,dataLabels:x}}},{key:"drawHollow",value:function(t){var e=new g(this.ctx).drawCircle(2*t.size);return e.attr({class:"apexcharts-radialbar-hollow",cx:t.centerX,cy:t.centerY,r:t.size,fill:t.fill}),e}},{key:"drawHollowImage",value:function(t,e,i,a){var s=this.w,n=new K(this.ctx),o=r.randomId(),l=s.config.plotOptions.radialBar.hollow.image;if(s.config.plotOptions.radialBar.hollow.imageClipped)n.clippedImgArea({width:i,height:i,image:l,patternID:"pattern".concat(s.globals.cuid).concat(o)}),a="url(#pattern".concat(s.globals.cuid).concat(o,")");else{var c=s.config.plotOptions.radialBar.hollow.imageWidth,h=s.config.plotOptions.radialBar.hollow.imageHeight;if(void 0===c&&void 0===h){var d=s.globals.dom.Paper.image(l).loaded((function(e){this.move(t.centerX-e.width/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-e.height/2+s.config.plotOptions.radialBar.hollow.imageOffsetY)}));e.add(d)}else{var u=s.globals.dom.Paper.image(l).loaded((function(e){this.move(t.centerX-c/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-h/2+s.config.plotOptions.radialBar.hollow.imageOffsetY),this.size(c,h)}));e.add(u)}}return a}},{key:"getStrokeWidth",value:function(t){var e=this.w;return t.size*(100-parseInt(e.config.plotOptions.radialBar.hollow.size,10))/100/(t.series.length+1)-this.margin}}])&&Wi(e.prototype,i),o}(zi);function Vi(t){return Vi="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},Vi(t)}function _i(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function Ui(t){for(var e=1;e0&&(this.visibleI=this.visibleI+1);var x=0,b=0;this.yRatio.length>1&&(this.yaxisIndex=f);var v=this.barHelpers.initialPositions();d=v.y,c=v.zeroW,h=v.x,b=v.barWidth,o=v.xDivision,l=v.zeroH;for(var m=a.group({class:"apexcharts-datalabels","data:realIndex":f}),y=a.group({class:"apexcharts-rangebar-goals-markers",style:"pointer-events: none"}),w=0;w0}));return a=l.config.plotOptions.bar.rangeBarGroupRows?r+n*u:r+s*this.visibleI+n*u,g>-1&&!l.config.plotOptions.bar.rangeBarOverlap&&(c=l.globals.seriesRange[e][g].overlaps).indexOf(h)>-1&&(a=(s=o.barHeight/c.length)*this.visibleI+n*(100-parseInt(this.barOptions.barHeight,10))/100/2+s*(this.visibleI+c.indexOf(h))+n*u),{barYPosition:a,barHeight:s}}},{key:"drawRangeColumnPaths",value:function(t){var e=t.indexes,i=t.x,a=(t.strokeWidth,t.xDivision),r=t.barWidth,s=t.zeroH,n=this.w,o=e.i,l=e.j,c=this.yRatio[this.yaxisIndex],h=e.realIndex,d=this.getRangeValue(h,l),u=Math.min(d.start,d.end),g=Math.max(d.start,d.end);n.globals.isXNumeric&&(i=(n.globals.seriesX[o][l]-n.globals.minX)/this.xRatio-r/2);var f=i+r*this.visibleI;void 0===this.series[o][l]||null===this.series[o][l]?u=s:(u=s-u/c,g=s-g/c);var p=Math.abs(g-u),x=this.barHelpers.getColumnPaths({barXPosition:f,barWidth:r,y1:u,y2:g,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,realIndex:e.realIndex,i:h,j:l,w:n});return n.globals.isXNumeric||(i+=a),{pathTo:x.pathTo,pathFrom:x.pathFrom,barHeight:p,x:i,y:g,goalY:this.barHelpers.getGoalValues("y",null,s,o,l),barXPosition:f}}},{key:"drawRangeBarPaths",value:function(t){var e=t.indexes,i=t.y,a=t.y1,r=t.y2,s=t.yDivision,n=t.barHeight,o=t.barYPosition,l=t.zeroW,c=this.w,h=l+a/this.invertedYRatio,d=l+r/this.invertedYRatio,u=Math.abs(d-h),g=this.barHelpers.getBarpaths({barYPosition:o,barHeight:n,x1:h,x2:d,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,i:e.realIndex,realIndex:e.realIndex,j:e.j,w:c});return c.globals.isXNumeric||(i+=s),{pathTo:g.pathTo,pathFrom:g.pathFrom,barWidth:u,x:d,goalX:this.barHelpers.getGoalValues("x",l,null,e.realIndex,e.j),y:i}}},{key:"getRangeValue",value:function(t,e){var i=this.w;return{start:i.globals.seriesRangeStart[t][e],end:i.globals.seriesRangeEnd[t][e]}}}])&&Zi(e.prototype,i),o}(li);function Ki(t,e){for(var i=0;i0&&parseInt(n.realIndex,10)===parseInt(a,10)&&("line"===n.type?(this.lineCtx.appendPathFrom=!1,e=r.globals.previousPaths[s].paths[0].d):"area"===n.type&&(this.lineCtx.appendPathFrom=!1,i=r.globals.previousPaths[s].paths[0].d,r.config.stroke.show&&r.globals.previousPaths[s].paths[1]&&(e=r.globals.previousPaths[s].paths[1].d)))}return{pathFromLine:e,pathFromArea:i}}},{key:"determineFirstPrevY",value:function(t){var e,i=t.i,a=t.series,r=t.prevY,s=t.lineYPosition,n=this.w;if(void 0!==(null===(e=a[i])||void 0===e?void 0:e[0]))r=(s=n.config.chart.stacked&&i>0?this.lineCtx.prevSeriesY[i-1][0]:this.lineCtx.zeroY)-a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]+2*(this.lineCtx.isReversed?a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]:0);else if(n.config.chart.stacked&&i>0&&void 0===a[i][0])for(var o=i-1;o>=0;o--)if(null!==a[o][0]&&void 0!==a[o][0]){r=s=this.lineCtx.prevSeriesY[o][0];break}return{prevY:r,lineYPosition:s}}}])&&Ki(e.prototype,i),t}();function ea(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function ia(t){for(var e=1;e0&&(x=(r.globals.seriesX[d][0]-r.globals.minX)/this.xRatio),f.push(x);var b,v=x,m=void 0,y=v,w=this.zeroY,k=this.zeroY;w=this.lineHelpers.determineFirstPrevY({i:h,series:t,prevY:w,lineYPosition:0}).prevY,u.push(w),b=w,"rangeArea"===n&&(m=k=this.lineHelpers.determineFirstPrevY({i:h,series:a,prevY:k,lineYPosition:0}).prevY);var A={type:n,series:t,realIndex:d,i:h,x,y:1,pX:v,pY:b,pathsFrom:this._calculatePathsFrom({type:n,series:t,i:h,realIndex:d,prevX:y,prevY:w,prevY2:k}),linePaths:[],areaPaths:[],seriesIndex:i,lineYPosition:0,xArrj:f,yArrj:u,seriesRangeEnd:a},S=this._iterateOverDataPoints(ia(ia({},A),{},{iterations:"rangeArea"===n?t[h].length-1:void 0,isRangeStart:!0}));if("rangeArea"===n){var C=this._calculatePathsFrom({series:a,i:h,realIndex:d,prevX:y,prevY:k}),P=this._iterateOverDataPoints(ia(ia({},A),{},{series:a,pY:m,pathsFrom:C,iterations:a[h].length-1,isRangeStart:!1}));S.linePaths[0]=P.linePath+S.linePath,S.pathFromLine=P.pathFromLine+S.pathFromLine}this._handlePaths({type:n,realIndex:d,i:h,paths:S}),this.elSeries.add(this.elPointsMain),this.elSeries.add(this.elDataLabelsWrap),c.push(this.elSeries)}if(r.config.chart.stacked)for(var L=c.length;L>0;L--)o.add(c[L-1]);else for(var O=0;O1&&(this.yaxisIndex=i),this.isReversed=a.config.yaxis[this.yaxisIndex]&&a.config.yaxis[this.yaxisIndex].reversed,this.zeroY=a.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?a.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),this.areaBottomY=this.zeroY,(this.zeroY>a.globals.gridHeight||"end"===a.config.plotOptions.area.fillTo)&&(this.areaBottomY=a.globals.gridHeight),this.categoryAxisCorrection=this.xDivision/2,this.elSeries=s.group({class:"apexcharts-series",seriesName:r.escapeString(a.globals.seriesNames[i])}),this.elPointsMain=s.group({class:"apexcharts-series-markers-wrap","data:realIndex":i}),this.elDataLabelsWrap=s.group({class:"apexcharts-datalabels","data:realIndex":i});var n=t[e].length===a.globals.dataPoints;this.elSeries.attr({"data:longestSeries":n,rel:e+1,"data:realIndex":i}),this.appendPathFrom=!0}},{key:"_calculatePathsFrom",value:function(t){var e,i,a,r,s=t.type,n=t.series,o=t.i,l=t.realIndex,c=t.prevX,h=t.prevY,d=t.prevY2,u=this.w,f=new g(this.ctx);if(null===n[o][0]){for(var p=0;p0){var x=this.lineHelpers.checkPreviousPaths({pathFromLine:a,pathFromArea:r,realIndex:l});a=x.pathFromLine,r=x.pathFromArea}return{prevX:c,prevY:h,linePath:e,areaPath:i,pathFromLine:a,pathFromArea:r}}},{key:"_handlePaths",value:function(t){var e=t.type,i=t.realIndex,a=t.i,r=t.paths,s=this.w,n=new g(this.ctx),o=new K(this.ctx);this.prevSeriesY.push(r.yArrj),s.globals.seriesXvalues[i]=r.xArrj,s.globals.seriesYvalues[i]=r.yArrj;var l=s.config.forecastDataPoints;if(l.count>0&&"rangeArea"!==e){var c=s.globals.seriesXvalues[i][s.globals.seriesXvalues[i].length-l.count-1],h=n.drawRect(c,0,s.globals.gridWidth,s.globals.gridHeight,0);s.globals.dom.elForecastMask.appendChild(h.node);var d=n.drawRect(0,0,c,s.globals.gridHeight,0);s.globals.dom.elNonForecastMask.appendChild(d.node)}this.pointsChart||s.globals.delayedElements.push({el:this.elPointsMain.node,index:i});var u={i:a,realIndex:i,animationDelay:a,initialSpeed:s.config.chart.animations.speed,dataChangeSpeed:s.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(e)};if("area"===e)for(var f=o.fillPath({seriesNumber:i}),p=0;p0&&"rangeArea"!==e){var A=n.renderPaths(w);A.node.setAttribute("stroke-dasharray",l.dashArray),l.strokeWidth&&A.node.setAttribute("stroke-width",l.strokeWidth),this.elSeries.add(A),A.attr("clip-path","url(#forecastMask".concat(s.globals.cuid,")")),k.attr("clip-path","url(#nonForecastMask".concat(s.globals.cuid,")"))}}}}},{key:"_iterateOverDataPoints",value:function(t){var e=t.type,i=t.series,a=t.iterations,s=t.realIndex,n=t.i,o=t.x,l=t.y,c=t.pX,h=t.pY,d=t.pathsFrom,u=t.linePaths,f=t.areaPaths,p=t.seriesIndex,x=t.lineYPosition,b=t.xArrj,v=t.yArrj,m=t.isRangeStart,y=t.seriesRangeEnd,w=this.w,k=new g(this.ctx),A=this.yRatio,S=d.prevY,C=d.linePath,P=d.areaPath,L=d.pathFromLine,O=d.pathFromArea,T=r.isNumber(w.globals.minYArr[s])?w.globals.minYArr[s]:w.globals.minY;a||(a=w.globals.dataPoints>1?w.globals.dataPoints-1:w.globals.dataPoints);for(var I=l,E=0;E0&&w.globals.collapsedSeries.length-1){e--;break}return e>=0?e:0}(n-1)][E+1]:this.zeroY,M?l=x-T/A[this.yaxisIndex]+2*(this.isReversed?T/A[this.yaxisIndex]:0):(l=x-i[n][E+1]/A[this.yaxisIndex]+2*(this.isReversed?i[n][E+1]/A[this.yaxisIndex]:0),"rangeArea"===e&&(I=x-y[n][E+1]/A[this.yaxisIndex]+2*(this.isReversed?y[n][E+1]/A[this.yaxisIndex]:0))),b.push(o),v.push(l);var z=this.lineHelpers.calculatePoints({series:i,x:o,y:l,realIndex:s,i:n,j:E,prevY:S}),Y=this._createPaths({type:e,series:i,i:n,realIndex:s,j:E,x:o,y:l,y2:I,pX:c,pY:h,linePath:C,areaPath:P,linePaths:u,areaPaths:f,seriesIndex:p,isRangeStart:m});f=Y.areaPaths,u=Y.linePaths,c=Y.pX,h=Y.pY,P=Y.areaPath,C=Y.linePath,this.appendPathFrom&&(L+=k.line(o,this.zeroY),O+=k.line(o,this.zeroY)),this.handleNullDataPoints(i,z,n,E,s),this._handleMarkersAndLabels({type:e,pointsPos:z,i:n,j:E,realIndex:s,isRangeStart:m})}return{yArrj:v,xArrj:b,pathFromArea:O,areaPaths:f,pathFromLine:L,linePaths:u,linePath:C,areaPath:P}}},{key:"_handleMarkersAndLabels",value:function(t){var e=t.type,i=t.pointsPos,a=t.isRangeStart,r=t.i,s=t.j,n=t.realIndex,o=this.w,l=new st(this.ctx);if(this.pointsChart)this.scatter.draw(this.elSeries,s,{realIndex:n,pointsPos:i,zRatio:this.zRatio,elParent:this.elPointsMain});else{o.globals.series[r].length>1&&this.elPointsMain.node.classList.add("apexcharts-element-hidden");var c=this.markers.plotChartMarkers(i,n,s+1);null!==c&&this.elPointsMain.add(c)}var h=l.drawDataLabel({type:e,isRangeStart:a,pos:i,i:n,j:s+1});null!==h&&this.elDataLabelsWrap.add(h)}},{key:"_createPaths",value:function(t){var e=t.type,i=t.series,a=t.i,r=t.realIndex,s=t.j,n=t.x,o=t.y,l=t.y2,c=t.pX,h=t.pY,d=t.linePath,u=t.areaPath,f=t.linePaths,p=t.areaPaths,x=t.seriesIndex,b=t.isRangeStart,v=this.w,m=new g(this.ctx),y=v.config.stroke.curve,w=this.areaBottomY;if(Array.isArray(v.config.stroke.curve)&&(y=Array.isArray(x)?v.config.stroke.curve[x[a]]:v.config.stroke.curve[a]),"smooth"===y){var k=.35*(n-c);v.globals.hasNullValues?(null!==i[a][s]&&(null!==i[a][s+1]?(d=m.move(c,h)+m.curve(c+k,h,n-k,o,n+1,o),u=m.move(c+1,h)+m.curve(c+k,h,n-k,o,n+1,o)+m.line(n,w)+m.line(c,w)+"z"):(d=m.move(c,h),u=m.move(c,h)+"z")),f.push(d),p.push(u)):(d+=m.curve(c+k,h,n-k,o,n,o),u+=m.curve(c+k,h,n-k,o,n,o)),c=n,h=o,s===i[a].length-2&&(u=u+m.curve(c,h,n,o,n,w)+m.move(n,o)+"z","rangeArea"===e&&b?d=d+m.curve(c,h,n,o,n,l)+m.move(n,l)+"z":v.globals.hasNullValues||(f.push(d),p.push(u)))}else{if(null===i[a][s+1]){d+=m.move(n,o);var A=v.globals.isXNumeric?(v.globals.seriesX[r][s]-v.globals.minX)/this.xRatio:n-this.xDivision;u=u+m.line(A,w)+m.move(n,o)+"z"}null===i[a][s]&&(d+=m.move(n,o),u+=m.move(n,w)),"stepline"===y?(d=d+m.line(n,null,"H")+m.line(null,o,"V"),u=u+m.line(n,null,"H")+m.line(null,o,"V")):"straight"===y&&(d+=m.line(n,o),u+=m.line(n,o)),s===i[a].length-2&&(u=u+m.line(n,w)+m.move(n,o)+"z","rangeArea"===e&&b?d=d+m.line(n,l)+m.move(n,l)+"z":(f.push(d),p.push(u)))}return{linePaths:f,areaPaths:p,pX:c,pY:h,linePath:d,areaPath:u}}},{key:"handleNullDataPoints",value:function(t,e,i,a,r){var s=this.w;if(null===t[i][a]&&s.config.markers.showNullDataPoints||1===t[i].length){var n=this.markers.plotChartMarkers(e,r,a+1,this.strokeWidth-s.config.markers.strokeWidth/2,!0);null!==n&&this.elPointsMain.add(n)}}}])&&ra(e.prototype,i),t}();function na(t,e){for(var i=0;is-a&&l.width<=n-r){var c=o.rotateAroundCenter(t.node);t.node.setAttribute("transform","rotate(-90 ".concat(c.x," ").concat(c.y,")"))}}},{key:"animateTreemap",value:function(t,e,i,a){var r=new n(this.ctx);r.animateRect(t,{x:e.x,y:e.y,width:e.width,height:e.height},{x:i.x,y:i.y,width:i.width,height:i.height},a,(function(){r.animationCompleted(t)}))}}])&&na(e.prototype,i),t}();function la(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function ca(t){for(var e=1;e5e4&&(a.globals.disableZoomOut=!0);var n=r.getTimeUnitsfromTimestamp(t,e,this.utc),o=a.globals.gridWidth/s,l=o/24,c=l/60,h=c/60,d=Math.floor(24*s),u=Math.floor(1440*s),g=Math.floor(86400*s),f=Math.floor(s),p=Math.floor(s/30),x=Math.floor(s/365),b={minMillisecond:n.minMillisecond,minSecond:n.minSecond,minMinute:n.minMinute,minHour:n.minHour,minDate:n.minDate,minMonth:n.minMonth,minYear:n.minYear},v={firstVal:b,currentMillisecond:b.minMillisecond,currentSecond:b.minSecond,currentMinute:b.minMinute,currentHour:b.minHour,currentMonthDate:b.minDate,currentDate:b.minDate,currentMonth:b.minMonth,currentYear:b.minYear,daysWidthOnXAxis:o,hoursWidthOnXAxis:l,minutesWidthOnXAxis:c,secondsWidthOnXAxis:h,numberOfSeconds:g,numberOfMinutes:u,numberOfHours:d,numberOfDays:f,numberOfMonths:p,numberOfYears:x};switch(this.tickInterval){case"years":this.generateYearScale(v);break;case"months":case"half_year":this.generateMonthScale(v);break;case"months_days":case"months_fortnight":case"days":case"week_days":this.generateDayScale(v);break;case"hours":this.generateHourScale(v);break;case"minutes_fives":case"minutes":this.generateMinuteScale(v);break;case"seconds_tens":case"seconds_fives":case"seconds":this.generateSecondScale(v)}var m=this.timeScaleArray.map((function(t){var e={position:t.position,unit:t.unit,year:t.year,day:t.day?t.day:1,hour:t.hour?t.hour:0,month:t.month+1};return"month"===t.unit?ca(ca({},e),{},{day:1,value:t.value+1}):"day"===t.unit||"hour"===t.unit?ca(ca({},e),{},{value:t.value}):"minute"===t.unit?ca(ca({},e),{},{value:t.value,minute:t.value}):"second"===t.unit?ca(ca({},e),{},{value:t.value,minute:t.minute,second:t.second}):t}));return m.filter((function(t){var e=1,r=Math.ceil(a.globals.gridWidth/120),s=t.value;void 0!==a.config.xaxis.tickAmount&&(r=a.config.xaxis.tickAmount),m.length>r&&(e=Math.floor(m.length/r));var n=!1,o=!1;switch(i.tickInterval){case"years":"year"===t.unit&&(n=!0);break;case"half_year":e=7,"year"===t.unit&&(n=!0);break;case"months":e=1,"year"===t.unit&&(n=!0);break;case"months_fortnight":e=15,"year"!==t.unit&&"month"!==t.unit||(n=!0),30===s&&(o=!0);break;case"months_days":e=10,"month"===t.unit&&(n=!0),30===s&&(o=!0);break;case"week_days":e=8,"month"===t.unit&&(n=!0);break;case"days":e=1,"month"===t.unit&&(n=!0);break;case"hours":"day"===t.unit&&(n=!0);break;case"minutes_fives":case"seconds_fives":s%5!=0&&(o=!0);break;case"seconds_tens":s%10!=0&&(o=!0)}if("hours"===i.tickInterval||"minutes_fives"===i.tickInterval||"seconds_tens"===i.tickInterval||"seconds_fives"===i.tickInterval){if(!o)return!0}else if((s%e==0||n)&&!o)return!0}))}},{key:"recalcDimensionsBasedOnFormat",value:function(t,e){var i=this.w,a=this.formatDates(t),r=this.removeOverlappingTS(a);i.globals.timescaleLabels=r.slice(),new Kt(this.ctx).plotCoords()}},{key:"determineInterval",value:function(t){var e=24*t,i=60*e;switch(!0){case t/365>5:this.tickInterval="years";break;case t>800:this.tickInterval="half_year";break;case t>180:this.tickInterval="months";break;case t>90:this.tickInterval="months_fortnight";break;case t>60:this.tickInterval="months_days";break;case t>30:this.tickInterval="week_days";break;case t>2:this.tickInterval="days";break;case e>2.4:this.tickInterval="hours";break;case i>15:this.tickInterval="minutes_fives";break;case i>5:this.tickInterval="minutes";break;case i>1:this.tickInterval="seconds_tens";break;case 60*i>20:this.tickInterval="seconds_fives";break;default:this.tickInterval="seconds"}}},{key:"generateYearScale",value:function(t){var e=t.firstVal,i=t.currentMonth,a=t.currentYear,s=t.daysWidthOnXAxis,n=t.numberOfYears,o=e.minYear,l=0,c=new M(this.ctx),h="year";if(e.minDate>1||e.minMonth>0){var d=c.determineRemainingDaysOfYear(e.minYear,e.minMonth,e.minDate);l=(c.determineDaysOfYear(e.minYear)-d+1)*s,o=e.minYear+1,this.timeScaleArray.push({position:l,value:o,unit:h,year:o,month:r.monthMod(i+1)})}else 1===e.minDate&&0===e.minMonth&&this.timeScaleArray.push({position:l,value:o,unit:h,year:a,month:r.monthMod(i+1)});for(var u=o,g=l,f=0;f1){c=(h.determineDaysOfMonths(a+1,e.minYear)-i+1)*n,l=r.monthMod(a+1);var g=s+u,f=r.monthMod(l),p=l;0===l&&(d="year",p=g,f=1,g+=u+=1),this.timeScaleArray.push({position:c,value:p,unit:d,year:g,month:f})}else this.timeScaleArray.push({position:c,value:l,unit:d,year:s,month:r.monthMod(a)});for(var x=l+1,b=c,v=0,m=1;vo.determineDaysOfMonths(e+1,i)?(h=1,l="month",g=e+=1,e):e},u=(24-e.minHour)*s,g=c,f=d(h,i,a);0===e.minHour&&1===e.minDate?(u=0,g=r.monthMod(e.minMonth),l="month",h=e.minDate,n++):1!==e.minDate&&0===e.minHour&&0===e.minMinute&&(u=0,c=e.minDate,g=c,f=d(h=c,i,a)),this.timeScaleArray.push({position:u,value:g,unit:l,year:this._getYear(a,f,0),month:r.monthMod(f),day:h});for(var p=u,x=0;xl.determineDaysOfMonths(e+1,s)&&(x=1,e+=1),{month:e,date:x}},d=function(t,e){return t>l.determineDaysOfMonths(e+1,s)?e+=1:e},u=60-(e.minMinute+e.minSecond/60),g=u*n,f=e.minHour+1,p=f+1;60===u&&(g=0,p=(f=e.minHour)+1);var x=i,b=d(x,a);this.timeScaleArray.push({position:g,value:f,unit:c,day:x,hour:p,year:s,month:r.monthMod(b)});for(var v=g,m=0;m=24&&(p=0,c="day",b=h(x+=1,b).month,b=d(x,b));var y=this._getYear(s,b,0);v=60*n+v;var w=0===p?x:p;this.timeScaleArray.push({position:v,value:w,unit:c,hour:p,day:x,year:y,month:r.monthMod(b)}),p++}}},{key:"generateMinuteScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,n=t.currentDate,o=t.currentMonth,l=t.currentYear,c=t.minutesWidthOnXAxis,h=t.secondsWidthOnXAxis,d=t.numberOfMinutes,u=a+1,g=n,f=o,p=l,x=s,b=(60-i-e/1e3)*h,v=0;v=60&&(u=0,24===(x+=1)&&(x=0)),this.timeScaleArray.push({position:b,value:u,unit:"minute",hour:x,minute:u,day:g,year:this._getYear(p,f,0),month:r.monthMod(f)}),b+=c,u++}},{key:"generateSecondScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,n=t.currentDate,o=t.currentMonth,l=t.currentYear,c=t.secondsWidthOnXAxis,h=t.numberOfSeconds,d=i+1,u=a,g=n,f=o,p=l,x=s,b=(1e3-e)/1e3*c,v=0;v=60&&(d=0,++u>=60&&(u=0,24==++x&&(x=0))),this.timeScaleArray.push({position:b,value:d,unit:"second",hour:x,minute:u,second:d,day:g,year:this._getYear(p,f,0),month:r.monthMod(f)}),b+=c,d++}},{key:"createRawDateString",value:function(t,e){var i=t.year;return 0===t.month&&(t.month=1),i+="-"+("0"+t.month.toString()).slice(-2),"day"===t.unit?i+="day"===t.unit?"-"+("0"+e).slice(-2):"-01":i+="-"+("0"+(t.day?t.day:"1")).slice(-2),"hour"===t.unit?i+="hour"===t.unit?"T"+("0"+e).slice(-2):"T00":i+="T"+("0"+(t.hour?t.hour:"0")).slice(-2),"minute"===t.unit?i+=":"+("0"+e).slice(-2):i+=":"+(t.minute?("0"+t.minute).slice(-2):"00"),"second"===t.unit?i+=":"+("0"+e).slice(-2):i+=":00",this.utc&&(i+=".000Z"),i}},{key:"formatDates",value:function(t){var e=this,i=this.w;return t.map((function(t){var a=t.value.toString(),r=new M(e.ctx),s=e.createRawDateString(t,a),n=r.getDate(r.parseDate(s));if(e.utc||(n=r.getDate(r.parseDateWithTimezone(s))),void 0===i.config.xaxis.labels.format){var o="dd MMM",l=i.config.xaxis.labels.datetimeFormatter;"year"===t.unit&&(o=l.year),"month"===t.unit&&(o=l.month),"day"===t.unit&&(o=l.day),"hour"===t.unit&&(o=l.hour),"minute"===t.unit&&(o=l.minute),"second"===t.unit&&(o=l.second),a=r.formatDate(n,o)}else a=r.formatDate(n,i.config.xaxis.labels.format);return{dateString:s,position:t.position,value:a,unit:t.unit,year:t.year,month:t.month}}))}},{key:"removeOverlappingTS",value:function(t){var e,i=this,a=new g(this.ctx),r=!1;t.length>0&&t[0].value&&t.every((function(e){return e.value.length===t[0].value.length}))&&(r=!0,e=a.getTextRects(t[0].value).width);var s=0,n=t.map((function(n,o){if(o>0&&i.w.config.xaxis.labels.hideOverlappingLabels){var l=r?e:a.getTextRects(t[s].value).width,c=t[s].position;return n.position>c+l+10?(s=o,n):null}return n}));return n.filter((function(t){return null!==t}))}},{key:"_getYear",value:function(t,e,i){return t+Math.floor(e/12)+i}}])&&da(e.prototype,i),t}();function ga(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function fa(t){for(var e=1;et.length)&&(e=t.length);for(var i=0,a=new Array(e);i-1,t.xyCharts=["line","area","bar","rangeBar","rangeArea","candlestick","boxPlot","scatter","bubble"].indexOf(i)>-1,t.isBarHorizontal=("bar"===e.chart.type||"rangeBar"===e.chart.type||"boxPlot"===e.chart.type)&&e.plotOptions.bar.horizontal,t.chartClass=".apexcharts"+t.chartID,t.dom.baseEl=this.el,t.dom.elWrap=document.createElement("div"),g.setAttrs(t.dom.elWrap,{id:t.chartClass.substring(1),class:"apexcharts-canvas "+t.chartClass.substring(1)}),this.el.appendChild(t.dom.elWrap),t.dom.Paper=new window.SVG.Doc(t.dom.elWrap),t.dom.Paper.attr({class:"apexcharts-svg","xmlns:data":"ApexChartsNS",transform:"translate(".concat(e.chart.offsetX,", ").concat(e.chart.offsetY,")")}),t.dom.Paper.node.style.background=e.chart.background,this.setSVGDimensions(),t.dom.elLegendForeign=document.createElementNS(t.SVGNS,"foreignObject"),g.setAttrs(t.dom.elLegendForeign,{x:0,y:0,width:t.svgWidth,height:t.svgHeight}),t.dom.elLegendWrap=document.createElement("div"),t.dom.elLegendWrap.classList.add("apexcharts-legend"),t.dom.elLegendWrap.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),t.dom.elLegendForeign.appendChild(t.dom.elLegendWrap),t.dom.Paper.node.appendChild(t.dom.elLegendForeign),t.dom.elGraphical=t.dom.Paper.group().attr({class:"apexcharts-inner apexcharts-graphical"}),t.dom.elDefs=t.dom.Paper.defs(),t.dom.Paper.add(t.dom.elGraphical),t.dom.elGraphical.add(t.dom.elDefs)}},{key:"plotChartType",value:function(t,e){var i=this.w,a=i.config,r=i.globals,s={series:[],i:[]},n={series:[],i:[]},o={series:[],i:[]},l={series:[],i:[]},c={series:[],i:[]},h={series:[],i:[]},d={series:[],i:[]},u={series:[],i:[]},g={series:[],seriesRangeEnd:[],i:[]};r.series.map((function(e,f){var p=0;void 0!==t[f].type?("column"===t[f].type||"bar"===t[f].type?(r.series.length>1&&a.plotOptions.bar.horizontal&&console.warn("Horizontal bars are not supported in a mixed/combo chart. Please turn off `plotOptions.bar.horizontal`"),c.series.push(e),c.i.push(f),p++,i.globals.columnSeries=c.series):"area"===t[f].type?(n.series.push(e),n.i.push(f),p++):"line"===t[f].type?(s.series.push(e),s.i.push(f),p++):"scatter"===t[f].type?(o.series.push(e),o.i.push(f)):"bubble"===t[f].type?(l.series.push(e),l.i.push(f),p++):"candlestick"===t[f].type?(h.series.push(e),h.i.push(f),p++):"boxPlot"===t[f].type?(d.series.push(e),d.i.push(f),p++):"rangeBar"===t[f].type?(u.series.push(e),u.i.push(f),p++):"rangeArea"===t[f].type?(g.series.push(r.seriesRangeStart[f]),g.seriesRangeEnd.push(r.seriesRangeEnd[f]),g.i.push(f),p++):console.warn("You have specified an unrecognized chart type. Available types for this property are line/area/column/bar/scatter/bubble/candlestick/boxPlot/rangeBar/rangeArea"),p>1&&(r.comboCharts=!0)):(s.series.push(e),s.i.push(f))}));var f=new sa(this.ctx,e),p=new Si(this.ctx,e);this.ctx.pie=new zi(this.ctx);var x=new Gi(this.ctx);this.ctx.rangeBar=new Qi(this.ctx,e);var b=new Hi(this.ctx),v=[];if(r.comboCharts){if(n.series.length>0&&v.push(f.draw(n.series,"area",n.i)),c.series.length>0)if(i.config.chart.stacked){var m=new xi(this.ctx,e);v.push(m.draw(c.series,c.i))}else this.ctx.bar=new li(this.ctx,e),v.push(this.ctx.bar.draw(c.series,c.i));if(g.series.length>0&&v.push(f.draw(g.series,"rangeArea",g.i,g.seriesRangeEnd)),s.series.length>0&&v.push(f.draw(s.series,"line",s.i)),h.series.length>0&&v.push(p.draw(h.series,"candlestick",h.i)),d.series.length>0&&v.push(p.draw(d.series,"boxPlot",d.i)),u.series.length>0&&v.push(this.ctx.rangeBar.draw(u.series,u.i)),o.series.length>0){var y=new sa(this.ctx,e,!0);v.push(y.draw(o.series,"scatter",o.i))}if(l.series.length>0){var w=new sa(this.ctx,e,!0);v.push(w.draw(l.series,"bubble",l.i))}}else switch(a.chart.type){case"line":v=f.draw(r.series,"line");break;case"area":v=f.draw(r.series,"area");break;case"bar":a.chart.stacked?v=new xi(this.ctx,e).draw(r.series):(this.ctx.bar=new li(this.ctx,e),v=this.ctx.bar.draw(r.series));break;case"candlestick":v=new Si(this.ctx,e).draw(r.series,"candlestick");break;case"boxPlot":v=new Si(this.ctx,e).draw(r.series,"boxPlot");break;case"rangeBar":v=this.ctx.rangeBar.draw(r.series);break;case"rangeArea":v=f.draw(r.seriesRangeStart,"rangeArea",void 0,r.seriesRangeEnd);break;case"heatmap":v=new Ii(this.ctx,e).draw(r.series);break;case"treemap":v=new oa(this.ctx,e).draw(r.series);break;case"pie":case"donut":case"polarArea":v=this.ctx.pie.draw(r.series);break;case"radialBar":v=x.draw(r.series);break;case"radar":v=b.draw(r.series);break;default:v=f.draw(r.series)}return v}},{key:"setSVGDimensions",value:function(){var t=this.w.globals,e=this.w.config;t.svgWidth=e.chart.width,t.svgHeight=e.chart.height;var i=r.getDimensions(this.el),a=e.chart.width.toString().split(/[0-9]+/g).pop();"%"===a?r.isNumber(i[0])&&(0===i[0].width&&(i=r.getDimensions(this.el.parentNode)),t.svgWidth=i[0]*parseInt(e.chart.width,10)/100):"px"!==a&&""!==a||(t.svgWidth=parseInt(e.chart.width,10));var s=e.chart.height.toString().split(/[0-9]+/g).pop();if("auto"!==t.svgHeight&&""!==t.svgHeight)if("%"===s){var n=r.getDimensions(this.el.parentNode);t.svgHeight=n[1]*parseInt(e.chart.height,10)/100}else t.svgHeight=parseInt(e.chart.height,10);else t.axisCharts?t.svgHeight=t.svgWidth/1.61:t.svgHeight=t.svgWidth/1.2;if(t.svgWidth<0&&(t.svgWidth=0),t.svgHeight<0&&(t.svgHeight=0),g.setAttrs(t.dom.Paper.node,{width:t.svgWidth,height:t.svgHeight}),"%"!==s){var o=e.chart.sparkline.enabled?0:t.axisCharts?e.chart.parentHeightOffset:0;t.dom.Paper.node.parentNode.parentNode.style.minHeight=t.svgHeight+o+"px"}t.dom.elWrap.style.width=t.svgWidth+"px",t.dom.elWrap.style.height=t.svgHeight+"px"}},{key:"shiftGraphPosition",value:function(){var t=this.w.globals,e=t.translateY,i={transform:"translate("+t.translateX+", "+e+")"};g.setAttrs(t.dom.elGraphical.node,i)}},{key:"resizeNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=0,a=t.config.chart.sparkline.enabled?1:15;a+=t.config.grid.padding.bottom,"top"!==t.config.legend.position&&"bottom"!==t.config.legend.position||!t.config.legend.show||t.config.legend.floating||(i=new ae(this.ctx).legendHelpers.getLegendBBox().clwh+10);var s=t.globals.dom.baseEl.querySelector(".apexcharts-radialbar, .apexcharts-pie"),n=2.05*t.globals.radialSize;if(s&&!t.config.chart.sparkline.enabled&&0!==t.config.plotOptions.radialBar.startAngle){var o=r.getBoundingClientRect(s);n=o.bottom;var l=o.bottom-o.top;n=Math.max(2.05*t.globals.radialSize,l)}var c=n+e.translateY+i+a;e.dom.elLegendForeign&&e.dom.elLegendForeign.setAttribute("height",c),t.config.chart.height&&String(t.config.chart.height).indexOf("%")>0||(e.dom.elWrap.style.height=c+"px",g.setAttrs(e.dom.Paper.node,{height:c}),e.dom.Paper.node.parentNode.parentNode.style.minHeight=c+"px")}},{key:"coreCalculations",value:function(){new Ct(this.ctx).init()}},{key:"resetGlobals",value:function(){var t=this,e=function(){return t.w.config.series.map((function(t){return[]}))},i=new _,a=this.w.globals;i.initGlobalVars(a),a.seriesXvalues=e(),a.seriesYvalues=e()}},{key:"isMultipleY",value:function(){if(this.w.config.yaxis.constructor===Array&&this.w.config.yaxis.length>1)return this.w.globals.isMultipleYAxis=!0,!0}},{key:"xySettings",value:function(){var t=null,e=this.w;if(e.globals.axisCharts){if("back"===e.config.xaxis.crosshairs.position&&new Yt(this.ctx).drawXCrosshairs(),"back"===e.config.yaxis[0].crosshairs.position&&new Yt(this.ctx).drawYCrosshairs(),"datetime"===e.config.xaxis.type&&void 0===e.config.xaxis.labels.formatter){this.ctx.timeScale=new ua(this.ctx);var i=[];isFinite(e.globals.minX)&&isFinite(e.globals.maxX)&&!e.globals.isBarHorizontal?i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minX,e.globals.maxX):e.globals.isBarHorizontal&&(i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minY,e.globals.maxY)),this.ctx.timeScale.recalcDimensionsBasedOnFormat(i)}t=new p(this.ctx).getCalculatedRatios()}return t}},{key:"updateSourceChart",value:function(t){this.ctx.w.globals.selection=void 0,this.ctx.updateHelpers._updateOptions({chart:{selection:{xaxis:{min:t.w.globals.minX,max:t.w.globals.maxX}}}},!1,!1)}},{key:"setupBrushHandler",value:function(){var t=this,e=this.w;if(e.config.chart.brush.enabled&&"function"!=typeof e.config.chart.events.selection){var i=e.config.chart.brush.targets||[e.config.chart.brush.target];i.forEach((function(e){var i=ApexCharts.getChartByID(e);i.w.globals.brushSource=t.ctx,"function"!=typeof i.w.config.chart.events.zoomed&&(i.w.config.chart.events.zoomed=function(){t.updateSourceChart(i)}),"function"!=typeof i.w.config.chart.events.scrolled&&(i.w.config.chart.events.scrolled=function(){t.updateSourceChart(i)})})),e.config.chart.events.selection=function(t,a){i.forEach((function(t){var i=ApexCharts.getChartByID(t),s=r.clone(e.config.yaxis);if(e.config.chart.brush.autoScaleYaxis&&1===i.w.globals.series.length){var n=new kt(i);s=n.autoScaleY(i,s,a)}var o=i.w.config.yaxis.reduce((function(t,e,a){return[].concat(function(t){if(Array.isArray(t))return xa(t)}(r=t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(r)||function(t,e){if(t){if("string"==typeof t)return xa(t,e);var i=Object.prototype.toString.call(t).slice(8,-1);return"Object"===i&&t.constructor&&(i=t.constructor.name),"Map"===i||"Set"===i?Array.from(t):"Arguments"===i||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(i)?xa(t,e):void 0}}(r)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}(),[fa(fa({},i.w.config.yaxis[a]),{},{min:s[0].min,max:s[0].max})]);var r}),[]);i.ctx.updateHelpers._updateOptions({xaxis:{min:a.xaxis.min,max:a.xaxis.max},yaxis:o},!1,!1,!1,!1)}))}}}}])&&ba(e.prototype,i),t}();function ma(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function ya(t){for(var e=1;e1&&void 0!==arguments[1]&&arguments[1],a=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],s=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],n=arguments.length>4&&void 0!==arguments[4]&&arguments[4];return new Promise((function(o){var l=[e.ctx];s&&(l=e.ctx.getSyncedCharts()),e.ctx.w.globals.isExecCalled&&(l=[e.ctx],e.ctx.w.globals.isExecCalled=!1),l.forEach((function(s,c){var h=s.w;if(h.globals.shouldAnimate=a,i||(h.globals.resized=!0,h.globals.dataChanged=!0,a&&s.series.getPreviousPaths()),t&&"object"===ka(t)&&(s.config=new G(t),t=p.extendArrayProps(s.config,t,h),s.w.globals.chartID!==e.ctx.w.globals.chartID&&delete t.series,h.config=r.extend(h.config,t),n&&(h.globals.lastXAxis=t.xaxis?r.clone(t.xaxis):[],h.globals.lastYAxis=t.yaxis?r.clone(t.yaxis):[],h.globals.initialConfig=r.extend({},h.config),h.globals.initialSeries=r.clone(h.config.series),t.series))){for(var d=0;d2&&void 0!==arguments[2]&&arguments[2];return new Promise((function(s){var n,o=i.w;return o.globals.shouldAnimate=e,o.globals.dataChanged=!0,e&&i.ctx.series.getPreviousPaths(),o.globals.axisCharts?(0===(n=t.map((function(t,e){return i._extendSeries(t,e)}))).length&&(n=[{data:[]}]),o.config.series=n):o.config.series=t.slice(),a&&(o.globals.initialConfig.series=r.clone(o.config.series),o.globals.initialSeries=r.clone(o.config.series)),i.ctx.update().then((function(){s(i.ctx)}))}))}},{key:"_extendSeries",value:function(t,e){var i=this.w,a=i.config.series[e];return ya(ya({},i.config.series[e]),{},{name:t.name?t.name:a&&a.name,color:t.color?t.color:a&&a.color,type:t.type?t.type:a&&a.type,data:t.data?t.data:a&&a.data})}},{key:"toggleDataPointSelection",value:function(t,e){var i=this.w,a=null,r=".apexcharts-series[data\\:realIndex='".concat(t,"']");return i.globals.axisCharts?a=i.globals.dom.Paper.select("".concat(r," path[j='").concat(e,"'], ").concat(r," circle[j='").concat(e,"'], ").concat(r," rect[j='").concat(e,"']")).members[0]:void 0===e&&(a=i.globals.dom.Paper.select("".concat(r," path[j='").concat(t,"']")).members[0],"pie"!==i.config.chart.type&&"polarArea"!==i.config.chart.type&&"donut"!==i.config.chart.type||this.ctx.pie.pieClicked(t)),a?(new g(this.ctx).pathMouseDown(a,null),a.node?a.node:null):(console.warn("toggleDataPointSelection: Element not found"),null)}},{key:"forceXAxisUpdate",value:function(t){var e=this.w;if(["min","max"].forEach((function(i){void 0!==t.xaxis[i]&&(e.config.xaxis[i]=t.xaxis[i],e.globals.lastXAxis[i]=t.xaxis[i])})),t.xaxis.categories&&t.xaxis.categories.length&&(e.config.xaxis.categories=t.xaxis.categories),e.config.xaxis.convertedCatToNumeric){var i=new W(t);t=i.convertCatToNumericXaxis(t,this.ctx)}return t}},{key:"forceYAxisUpdate",value:function(t){return t.chart&&t.chart.stacked&&"100%"===t.chart.stackType&&(Array.isArray(t.yaxis)?t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})):(t.yaxis.min=0,t.yaxis.max=100)),t}},{key:"revertDefaultAxisMinMax",value:function(t){var e=this,i=this.w,a=i.globals.lastXAxis,r=i.globals.lastYAxis;t&&t.xaxis&&(a=t.xaxis),t&&t.yaxis&&(r=t.yaxis),i.config.xaxis.min=a.min,i.config.xaxis.max=a.max;i.config.yaxis.map((function(t,a){i.globals.zoomed||void 0!==r[a]?function(t){void 0!==r[t]&&(i.config.yaxis[t].min=r[t].min,i.config.yaxis[t].max=r[t].max)}(a):void 0!==e.ctx.opts.yaxis[a]&&(t.min=e.ctx.opts.yaxis[a].min,t.max=e.ctx.opts.yaxis[a].max)}))}}],i&&Aa(e.prototype,i),t}();function Ca(t,e){for(var i=0;i0&&void 0!==arguments[0]?arguments[0]:null,i=this,a=i.w;return new Promise((function(r,s){if(null===i.el)return s(new Error("Not enough data to display or target element not found"));(null===e||a.globals.allSeriesCollapsed)&&i.series.handleNoData(),i.grid=new yt(i);var n=i.grid.drawGrid();if(i.annotations=new O(i),i.annotations.drawImageAnnos(),i.annotations.drawTextAnnos(),"back"===a.config.grid.position&&n&&a.globals.dom.elGraphical.add(n.el),Array.isArray(e.elGraph))for(var o=0;o0&&a.globals.memory.methodsToExec.forEach((function(t){t.method(t.params,!1,t.context)})),a.globals.axisCharts||a.globals.noData||i.core.resizeNonAxisCharts(),r(i)}))}},{key:"destroy",value:function(){var t,e;window.removeEventListener("resize",this.windowResizeHandler),this.el.parentNode,t=this.parentResizeHandler,(e=Ta.get(t))&&(e.disconnect(),Ta.delete(t));var i=this.w.config.chart.id;i&&Apex._chartInstances.forEach((function(t,e){t.id===r.escapeString(i)&&Apex._chartInstances.splice(e,1)})),new Oa(this.ctx).clear({isUpdating:!1})}},{key:"updateOptions",value:function(t){var e=this,i=arguments.length>1&&void 0!==arguments[1]&&arguments[1],a=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],r=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],s=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],n=this.w;return n.globals.selection=void 0,t.series&&(this.series.resetSeries(!1,!0,!1),t.series.length&&t.series[0].data&&(t.series=t.series.map((function(t,i){return e.updateHelpers._extendSeries(t,i)}))),this.updateHelpers.revertDefaultAxisMinMax()),t.xaxis&&(t=this.updateHelpers.forceXAxisUpdate(t)),t.yaxis&&(t=this.updateHelpers.forceYAxisUpdate(t)),n.globals.collapsedSeriesIndices.length>0&&this.series.clearPreviousPaths(),t.theme&&(t=this.theme.updateThemeOptions(t)),this.updateHelpers._updateOptions(t,i,a,r,s)}},{key:"updateSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];return this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(t,e,i)}},{key:"appendSeries",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w.config.series.slice();return a.push(t),this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(a,e,i)}},{key:"appendData",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=this;i.w.globals.dataChanged=!0,i.series.getPreviousPaths();for(var a=i.w.config.series.slice(),s=0;s0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.series.resetSeries(t,e)}},{key:"addEventListener",value:function(t,e){this.events.addEventListener(t,e)}},{key:"removeEventListener",value:function(t,e){this.events.removeEventListener(t,e)}},{key:"addXaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addXaxisAnnotationExternal(t,e,a)}},{key:"addYaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addYaxisAnnotationExternal(t,e,a)}},{key:"addPointAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addPointAnnotationExternal(t,e,a)}},{key:"clearAnnotations",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:void 0,e=this;t&&(e=t),e.annotations.clearAnnotations(e)}},{key:"removeAnnotation",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0,i=this;e&&(i=e),i.annotations.removeAnnotation(i,t)}},{key:"getChartArea",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-inner")}},{key:"getSeriesTotalXRange",value:function(t,e){return this.coreUtils.getSeriesTotalsXRange(t,e)}},{key:"getHighestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new Ct(this.ctx).getMinYMaxY(t).highestY}},{key:"getLowestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new Ct(this.ctx).getMinYMaxY(t).lowestY}},{key:"getSeriesTotal",value:function(){return this.w.globals.seriesTotals}},{key:"toggleDataPointSelection",value:function(t,e){return this.updateHelpers.toggleDataPointSelection(t,e)}},{key:"zoomX",value:function(t,e){this.ctx.toolbar.zoomUpdateOptions(t,e)}},{key:"setLocale",value:function(t){this.localization.setCurrentLocaleValues(t)}},{key:"dataURI",value:function(t){return new xt(this.ctx).dataURI(t)}},{key:"exportToCSV",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return new xt(this.ctx).exportToCSV(t)}},{key:"paper",value:function(){return this.w.globals.dom.Paper}},{key:"_parentResizeCallback",value:function(){this.w.globals.animationEnded&&this.w.config.chart.redrawOnParentResize&&this._windowResize()}},{key:"_windowResize",value:function(){var t=this;clearTimeout(this.w.globals.resizeTimer),this.w.globals.resizeTimer=window.setTimeout((function(){t.w.globals.resized=!0,t.w.globals.dataChanged=!1,t.ctx.update()}),150)}},{key:"_windowResizeHandler",value:function(){var t=this.w.config.chart.redrawOnWindowResize;"function"==typeof t&&(t=t()),t&&this._windowResize()}}],a=[{key:"getChartByID",value:function(t){var e=r.escapeString(t),i=Apex._chartInstances.filter((function(t){return t.id===e}))[0];return i&&i.chart}},{key:"initOnLoad",value:function(){for(var e=document.querySelectorAll("[data-apexcharts]"),i=0;i2?r-2:0),n=2;nt.length)&&(e=t.length);for(var i=0,a=new Array(e);i>16,o=i>>8&255,n=255&i;return"#"+(16777216+65536*(Math.round((a-r)*s)+r)+256*(Math.round((a-o)*s)+o)+(Math.round((a-n)*s)+n)).toString(16).slice(1)}},{key:"shadeColor",value:function(e,i){return t.isColorHex(i)?this.shadeHexColor(e,i):this.shadeRGBColor(e,i)}}],[{key:"bind",value:function(t,e){return function(){return t.apply(e,arguments)}}},{key:"isObject",value:function(t){return t&&"object"===i(t)&&!Array.isArray(t)&&null!=t}},{key:"is",value:function(t,e){return Object.prototype.toString.call(e)==="[object "+t+"]"}},{key:"listToArray",value:function(t){var e,i=[];for(e=0;ee.length?t:e}))),t.length>e.length?t:e}),0)}},{key:"hexToRgba",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"#999999",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:.6;"#"!==t.substring(0,1)&&(t="#999999");var i=t.replace("#","");i=i.match(new RegExp("(.{"+i.length/3+"})","g"));for(var a=0;a1&&void 0!==arguments[1]?arguments[1]:"x",i=t.toString().slice();return i=i.replace(/[` ~!@#$%^&*()|+\=?;:'",.<>{}[\]\\/]/gi,e)}},{key:"negToZero",value:function(t){return t<0?0:t}},{key:"moveIndexInArray",value:function(t,e,i){if(i>=t.length)for(var a=i-t.length+1;a--;)t.push(void 0);return t.splice(i,0,t.splice(e,1)[0]),t}},{key:"extractNumber",value:function(t){return parseFloat(t.replace(/[^\d.]*/g,""))}},{key:"findAncestor",value:function(t,e){for(;(t=t.parentElement)&&!t.classList.contains(e););return t}},{key:"setELstyles",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&(t.style.key=e[i])}},{key:"isNumber",value:function(t){return!isNaN(t)&&parseFloat(Number(t))===t&&!isNaN(parseInt(t,10))}},{key:"isFloat",value:function(t){return Number(t)===t&&t%1!=0}},{key:"isSafari",value:function(){return/^((?!chrome|android).)*safari/i.test(navigator.userAgent)}},{key:"isFirefox",value:function(){return navigator.userAgent.toLowerCase().indexOf("firefox")>-1}},{key:"isIE11",value:function(){if(-1!==window.navigator.userAgent.indexOf("MSIE")||window.navigator.appVersion.indexOf("Trident/")>-1)return!0}},{key:"isIE",value:function(){var t=window.navigator.userAgent,e=t.indexOf("MSIE ");if(e>0)return parseInt(t.substring(e+5,t.indexOf(".",e)),10);if(t.indexOf("Trident/")>0){var i=t.indexOf("rv:");return parseInt(t.substring(i+3,t.indexOf(".",i)),10)}var a=t.indexOf("Edge/");return a>0&&parseInt(t.substring(a+5,t.indexOf(".",a)),10)}}]),t}(),b=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.setEasingFunctions()}return r(t,[{key:"setEasingFunctions",value:function(){var t;if(!this.w.globals.easing){switch(this.w.config.chart.animations.easing){case"linear":t="-";break;case"easein":t="<";break;case"easeout":t=">";break;case"easeinout":default:t="<>";break;case"swing":t=function(t){var e=1.70158;return(t-=1)*t*((e+1)*t+e)+1};break;case"bounce":t=function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375};break;case"elastic":t=function(t){return t===!!t?t:Math.pow(2,-10*t)*Math.sin((t-.075)*(2*Math.PI)/.3)+1}}this.w.globals.easing=t}}},{key:"animateLine",value:function(t,e,i,a){t.attr(e).animate(a).attr(i)}},{key:"animateMarker",value:function(t,e,i,a,s,r){e||(e=0),t.attr({r:e,width:e,height:e}).animate(a,s).attr({r:i,width:i.width,height:i.height}).afterAll((function(){r()}))}},{key:"animateCircle",value:function(t,e,i,a,s){t.attr({r:e.r,cx:e.cx,cy:e.cy}).animate(a,s).attr({r:i.r,cx:i.cx,cy:i.cy})}},{key:"animateRect",value:function(t,e,i,a,s){t.attr(e).animate(a).attr(i).afterAll((function(){return s()}))}},{key:"animatePathsGradually",value:function(t){var e=t.el,i=t.realIndex,a=t.j,s=t.fill,r=t.pathFrom,o=t.pathTo,n=t.speed,l=t.delay,h=this.w,c=0;h.config.chart.animations.animateGradually.enabled&&(c=h.config.chart.animations.animateGradually.delay),h.config.chart.animations.dynamicAnimation.enabled&&h.globals.dataChanged&&"bar"!==h.config.chart.type&&(c=0),this.morphSVG(e,i,a,"line"!==h.config.chart.type||h.globals.comboCharts?s:"stroke",r,o,n,l*c)}},{key:"showDelayedElements",value:function(){this.w.globals.delayedElements.forEach((function(t){t.el.classList.remove("apexcharts-element-hidden")}))}},{key:"animationCompleted",value:function(t){var e=this.w;e.globals.animationEnded||(e.globals.animationEnded=!0,this.showDelayedElements(),"function"==typeof e.config.chart.events.animationEnd&&e.config.chart.events.animationEnd(this.ctx,{el:t,w:e}))}},{key:"morphSVG",value:function(t,e,i,a,s,r,o,n){var l=this,h=this.w;s||(s=t.attr("pathFrom")),r||(r=t.attr("pathTo"));var c=function(t){return"radar"===h.config.chart.type&&(o=1),"M 0 ".concat(h.globals.gridHeight)};(!s||s.indexOf("undefined")>-1||s.indexOf("NaN")>-1)&&(s=c()),(!r||r.indexOf("undefined")>-1||r.indexOf("NaN")>-1)&&(r=c()),h.globals.shouldAnimate||(o=1),t.plot(s).animate(1,h.globals.easing,n).plot(s).animate(o,h.globals.easing,n).plot(r).afterAll((function(){x.isNumber(i)?i===h.globals.series[h.globals.maxValsInArrayIndex].length-2&&h.globals.shouldAnimate&&l.animationCompleted(t):"none"!==a&&h.globals.shouldAnimate&&(!h.globals.comboCharts&&e===h.globals.series.length-1||h.globals.comboCharts)&&l.animationCompleted(t),l.showDelayedElements()}))}}]),t}(),v=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"getDefaultFilter",value:function(t,e){var i=this.w;t.unfilter(!0),(new window.SVG.Filter).size("120%","180%","-5%","-40%"),"none"!==i.config.states.normal.filter?this.applyFilter(t,e,i.config.states.normal.filter.type,i.config.states.normal.filter.value):i.config.chart.dropShadow.enabled&&this.dropShadow(t,i.config.chart.dropShadow,e)}},{key:"addNormalFilter",value:function(t,e){var i=this.w;i.config.chart.dropShadow.enabled&&!t.node.classList.contains("apexcharts-marker")&&this.dropShadow(t,i.config.chart.dropShadow,e)}},{key:"addLightenFilter",value:function(t,e,i){var a=this,s=this.w,r=i.intensity;t.unfilter(!0);new window.SVG.Filter;t.filter((function(t){var i=s.config.chart.dropShadow;(i.enabled?a.addShadow(t,e,i):t).componentTransfer({rgb:{type:"linear",slope:1.5,intercept:r}})})),t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)}},{key:"addDarkenFilter",value:function(t,e,i){var a=this,s=this.w,r=i.intensity;t.unfilter(!0);new window.SVG.Filter;t.filter((function(t){var i=s.config.chart.dropShadow;(i.enabled?a.addShadow(t,e,i):t).componentTransfer({rgb:{type:"linear",slope:r}})})),t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)}},{key:"applyFilter",value:function(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:.5;switch(i){case"none":this.addNormalFilter(t,e);break;case"lighten":this.addLightenFilter(t,e,{intensity:a});break;case"darken":this.addDarkenFilter(t,e,{intensity:a})}}},{key:"addShadow",value:function(t,e,i){var a=i.blur,s=i.top,r=i.left,o=i.color,n=i.opacity,l=t.flood(Array.isArray(o)?o[e]:o,n).composite(t.sourceAlpha,"in").offset(r,s).gaussianBlur(a).merge(t.source);return t.blend(t.source,l)}},{key:"dropShadow",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=e.top,s=e.left,r=e.blur,o=e.color,n=e.opacity,l=e.noUserSpaceOnUse,h=this.w;return t.unfilter(!0),x.isIE()&&"radialBar"===h.config.chart.type||(o=Array.isArray(o)?o[i]:o,t.filter((function(t){var e=null;e=x.isSafari()||x.isFirefox()||x.isIE()?t.flood(o,n).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(r):t.flood(o,n).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(r).merge(t.source),t.blend(t.source,e)})),l||t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)),t}},{key:"setSelectionFilter",value:function(t,e,i){var a=this.w;if(void 0!==a.globals.selectedDataPoints[e]&&a.globals.selectedDataPoints[e].indexOf(i)>-1){t.node.setAttribute("selected",!0);var s=a.config.states.active.filter;"none"!==s&&this.applyFilter(t,e,s.type,s.value)}}},{key:"_scaleFilterSize",value:function(t){!function(e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}({width:"200%",height:"200%",x:"-50%",y:"-50%"})}}]),t}(),m=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"roundPathCorners",value:function(t,e){function i(t,e,i){var s=e.x-t.x,r=e.y-t.y,o=Math.sqrt(s*s+r*r);return a(t,e,Math.min(1,i/o))}function a(t,e,i){return{x:t.x+(e.x-t.x)*i,y:t.y+(e.y-t.y)*i}}function s(t,e){t.length>2&&(t[t.length-2]=e.x,t[t.length-1]=e.y)}function r(t){return{x:parseFloat(t[t.length-2]),y:parseFloat(t[t.length-1])}}t.indexOf("NaN")>-1&&(t="");var o=t.split(/[,\s]/).reduce((function(t,e){var i=e.match("([a-zA-Z])(.+)");return i?(t.push(i[1]),t.push(i[2])):t.push(e),t}),[]).reduce((function(t,e){return parseFloat(e)==e&&t.length?t[t.length-1].push(e):t.push([e]),t}),[]),n=[];if(o.length>1){var l=r(o[0]),h=null;"Z"==o[o.length-1][0]&&o[0].length>2&&(h=["L",l.x,l.y],o[o.length-1]=h),n.push(o[0]);for(var c=1;c2&&"L"==g[0]&&u.length>2&&"L"==u[0]){var p,f,x=r(d),b=r(g),v=r(u);p=i(b,x,e),f=i(b,v,e),s(g,p),g.origPoint=b,n.push(g);var m=a(p,b,.5),y=a(b,f,.5),w=["C",m.x,m.y,y.x,y.y,f.x,f.y];w.origPoint=b,n.push(w)}else n.push(g)}if(h){var k=r(n[n.length-1]);n.push(["Z"]),s(n[0],k)}}else n=o;return n.reduce((function(t,e){return t+e.join(" ")+" "}),"")}},{key:"drawLine",value:function(t,e,i,a){var s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"#a8a8a8",r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,o=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,n=arguments.length>7&&void 0!==arguments[7]?arguments[7]:"butt";return this.w.globals.dom.Paper.line().attr({x1:t,y1:e,x2:i,y2:a,stroke:s,"stroke-dasharray":r,"stroke-width":o,"stroke-linecap":n})}},{key:"drawRect",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"#fefefe",o=arguments.length>6&&void 0!==arguments[6]?arguments[6]:1,n=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,l=arguments.length>8&&void 0!==arguments[8]?arguments[8]:null,h=arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,c=this.w.globals.dom.Paper.rect();return c.attr({x:t,y:e,width:i>0?i:0,height:a>0?a:0,rx:s,ry:s,opacity:o,"stroke-width":null!==n?n:0,stroke:null!==l?l:"none","stroke-dasharray":h}),c.node.setAttribute("fill",r),c}},{key:"drawPolygon",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"#e1e1e1",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none";return this.w.globals.dom.Paper.polygon(t).attr({fill:a,stroke:e,"stroke-width":i})}},{key:"drawCircle",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;t<0&&(t=0);var i=this.w.globals.dom.Paper.circle(2*t);return null!==e&&i.attr(e),i}},{key:"drawPath",value:function(t){var e=t.d,i=void 0===e?"":e,a=t.stroke,s=void 0===a?"#a8a8a8":a,r=t.strokeWidth,o=void 0===r?1:r,n=t.fill,l=t.fillOpacity,h=void 0===l?1:l,c=t.strokeOpacity,d=void 0===c?1:c,g=t.classes,u=t.strokeLinecap,p=void 0===u?null:u,f=t.strokeDashArray,x=void 0===f?0:f,b=this.w;return null===p&&(p=b.config.stroke.lineCap),(i.indexOf("undefined")>-1||i.indexOf("NaN")>-1)&&(i="M 0 ".concat(b.globals.gridHeight)),b.globals.dom.Paper.path(i).attr({fill:n,"fill-opacity":h,stroke:s,"stroke-opacity":d,"stroke-linecap":p,"stroke-width":o,"stroke-dasharray":x,class:g})}},{key:"group",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w.globals.dom.Paper.group();return null!==t&&e.attr(t),e}},{key:"move",value:function(t,e){var i=["M",t,e].join(" ");return i}},{key:"line",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=null;return null===i?a=[" L",t,e].join(" "):"H"===i?a=[" H",t].join(" "):"V"===i&&(a=[" V",e].join(" ")),a}},{key:"curve",value:function(t,e,i,a,s,r){var o=["C",t,e,i,a,s,r].join(" ");return o}},{key:"quadraticCurve",value:function(t,e,i,a){return["Q",t,e,i,a].join(" ")}},{key:"arc",value:function(t,e,i,a,s,r,o){var n="A";arguments.length>7&&void 0!==arguments[7]&&arguments[7]&&(n="a");var l=[n,t,e,i,a,s,r,o].join(" ");return l}},{key:"renderPaths",value:function(t){var i,a=t.j,s=t.realIndex,r=t.pathFrom,o=t.pathTo,n=t.stroke,l=t.strokeWidth,h=t.strokeLinecap,c=t.fill,d=t.animationDelay,g=t.initialSpeed,u=t.dataChangeSpeed,p=t.className,f=t.shouldClipToGrid,x=void 0===f||f,m=t.bindEventsOnPaths,y=void 0===m||m,w=t.drawShadow,k=void 0===w||w,A=this.w,S=new v(this.ctx),C=new b(this.ctx),L=this.w.config.chart.animations.enabled,P=L&&this.w.config.chart.animations.dynamicAnimation.enabled,I=!!(L&&!A.globals.resized||P&&A.globals.dataChanged&&A.globals.shouldAnimate);I?i=r:(i=o,A.globals.animationEnded=!0);var T=A.config.stroke.dashArray,M=0;M=Array.isArray(T)?T[s]:A.config.stroke.dashArray;var X=this.drawPath({d:i,stroke:n,strokeWidth:l,fill:c,fillOpacity:1,classes:p,strokeLinecap:h,strokeDashArray:M});if(X.attr("index",s),x&&X.attr({"clip-path":"url(#gridRectMask".concat(A.globals.cuid,")")}),"none"!==A.config.states.normal.filter.type)S.getDefaultFilter(X,s);else if(A.config.chart.dropShadow.enabled&&k&&(!A.config.chart.dropShadow.enabledOnSeries||A.config.chart.dropShadow.enabledOnSeries&&-1!==A.config.chart.dropShadow.enabledOnSeries.indexOf(s))){var z=A.config.chart.dropShadow;S.dropShadow(X,z,s)}y&&(X.node.addEventListener("mouseenter",this.pathMouseEnter.bind(this,X)),X.node.addEventListener("mouseleave",this.pathMouseLeave.bind(this,X)),X.node.addEventListener("mousedown",this.pathMouseDown.bind(this,X))),X.attr({pathTo:o,pathFrom:r});var E={el:X,j:a,realIndex:s,pathFrom:r,pathTo:o,fill:c,strokeWidth:l,delay:d};return!L||A.globals.resized||A.globals.dataChanged?!A.globals.resized&&A.globals.dataChanged||C.showDelayedElements():C.animatePathsGradually(e(e({},E),{},{speed:g})),A.globals.dataChanged&&P&&I&&C.animatePathsGradually(e(e({},E),{},{speed:u})),X}},{key:"drawPattern",value:function(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"#a8a8a8",s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0;return this.w.globals.dom.Paper.pattern(e,i,(function(r){"horizontalLines"===t?r.line(0,0,i,0).stroke({color:a,width:s+1}):"verticalLines"===t?r.line(0,0,0,e).stroke({color:a,width:s+1}):"slantedLines"===t?r.line(0,0,e,i).stroke({color:a,width:s}):"squares"===t?r.rect(e,i).fill("none").stroke({color:a,width:s}):"circles"===t&&r.circle(e).fill("none").stroke({color:a,width:s})}))}},{key:"drawGradient",value:function(t,e,i,a,s){var r,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:null,n=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,h=arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,c=this.w;e.length<9&&0===e.indexOf("#")&&(e=x.hexToRgba(e,a)),i.length<9&&0===i.indexOf("#")&&(i=x.hexToRgba(i,s));var d=0,g=1,u=1,p=null;null!==n&&(d=void 0!==n[0]?n[0]/100:0,g=void 0!==n[1]?n[1]/100:1,u=void 0!==n[2]?n[2]/100:1,p=void 0!==n[3]?n[3]/100:null);var f=!("donut"!==c.config.chart.type&&"pie"!==c.config.chart.type&&"polarArea"!==c.config.chart.type&&"bubble"!==c.config.chart.type);if(r=null===l||0===l.length?c.globals.dom.Paper.gradient(f?"radial":"linear",(function(t){t.at(d,e,a),t.at(g,i,s),t.at(u,i,s),null!==p&&t.at(p,e,a)})):c.globals.dom.Paper.gradient(f?"radial":"linear",(function(t){(Array.isArray(l[h])?l[h]:l).forEach((function(e){t.at(e.offset/100,e.color,e.opacity)}))})),f){var b=c.globals.gridWidth/2,v=c.globals.gridHeight/2;"bubble"!==c.config.chart.type?r.attr({gradientUnits:"userSpaceOnUse",cx:b,cy:v,r:o}):r.attr({cx:.5,cy:.5,r:.8,fx:.2,fy:.2})}else"vertical"===t?r.from(0,0).to(0,1):"diagonal"===t?r.from(0,0).to(1,1):"horizontal"===t?r.from(0,1).to(1,1):"diagonal2"===t&&r.from(1,0).to(0,1);return r}},{key:"getTextBasedOnMaxWidth",value:function(t){var e=t.text,i=t.maxWidth,a=t.fontSize,s=t.fontFamily,r=this.getTextRects(e,a,s),o=r.width/e.length,n=Math.floor(i/o);return i-1){var n=i.globals.selectedDataPoints[s].indexOf(r);i.globals.selectedDataPoints[s].splice(n,1)}}else{if(!i.config.states.active.allowMultipleDataPointsSelection&&i.globals.selectedDataPoints.length>0){i.globals.selectedDataPoints=[];var l=i.globals.dom.Paper.select(".apexcharts-series path").members,h=i.globals.dom.Paper.select(".apexcharts-series circle, .apexcharts-series rect").members,c=function(t){Array.prototype.forEach.call(t,(function(t){t.node.setAttribute("selected","false"),a.getDefaultFilter(t,s)}))};c(l),c(h)}t.node.setAttribute("selected","true"),o="true",void 0===i.globals.selectedDataPoints[s]&&(i.globals.selectedDataPoints[s]=[]),i.globals.selectedDataPoints[s].push(r)}if("true"===o){var d=i.config.states.active.filter;if("none"!==d)a.applyFilter(t,s,d.type,d.value);else if("none"!==i.config.states.hover.filter&&!i.globals.isTouchDevice){var g=i.config.states.hover.filter;a.applyFilter(t,s,g.type,g.value)}}else if("none"!==i.config.states.active.filter.type)if("none"===i.config.states.hover.filter.type||i.globals.isTouchDevice)a.getDefaultFilter(t,s);else{g=i.config.states.hover.filter;a.applyFilter(t,s,g.type,g.value)}"function"==typeof i.config.chart.events.dataPointSelection&&i.config.chart.events.dataPointSelection(e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:s,dataPointIndex:r,w:i}),e&&this.ctx.events.fireEvent("dataPointSelection",[e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:s,dataPointIndex:r,w:i}])}},{key:"rotateAroundCenter",value:function(t){var e={};return t&&"function"==typeof t.getBBox&&(e=t.getBBox()),{x:e.x+e.width/2,y:e.y+e.height/2}}},{key:"getTextRects",value:function(t,e,i,a){var s=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],r=this.w,o=this.drawText({x:-200,y:-200,text:t,textAnchor:"start",fontSize:e,fontFamily:i,foreColor:"#fff",opacity:0});a&&o.attr("transform",a),r.globals.dom.Paper.add(o);var n=o.bbox();return s||(n=o.node.getBoundingClientRect()),o.remove(),{width:n.width,height:n.height}}},{key:"placeTextWithEllipsis",value:function(t,e,i){if("function"==typeof t.getComputedTextLength&&(t.textContent=e,e.length>0&&t.getComputedTextLength()>=i/1.1)){for(var a=e.length-3;a>0;a-=3)if(t.getSubStringLength(0,a)<=i/1.1)return void(t.textContent=e.substring(0,a)+"...");t.textContent="."}}}],[{key:"setAttrs",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}}]),t}(),y=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"getStackedSeriesTotals",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=this.w,i=[];if(0===e.globals.series.length)return i;for(var a=0;a0&&void 0!==arguments[0]?arguments[0]:null;return null===t?this.w.config.series.reduce((function(t,e){return t+e}),0):this.w.globals.series[t].reduce((function(t,e){return t+e}),0)}},{key:"isSeriesNull",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;return 0===(null===t?this.w.config.series.filter((function(t){return null!==t})):this.w.config.series[t].data.filter((function(t){return null!==t}))).length}},{key:"seriesHaveSameValues",value:function(t){return this.w.globals.series[t].every((function(t,e,i){return t===i[0]}))}},{key:"getCategoryLabels",value:function(t){var e=this.w,i=t.slice();return e.config.xaxis.convertedCatToNumeric&&(i=t.map((function(t,i){return e.config.xaxis.labels.formatter(t-e.globals.minX+1)}))),i}},{key:"getLargestSeries",value:function(){var t=this.w;t.globals.maxValsInArrayIndex=t.globals.series.map((function(t){return t.length})).indexOf(Math.max.apply(Math,t.globals.series.map((function(t){return t.length}))))}},{key:"getLargestMarkerSize",value:function(){var t=this.w,e=0;return t.globals.markers.size.forEach((function(t){e=Math.max(e,t)})),t.config.markers.discrete&&t.config.markers.discrete.length&&t.config.markers.discrete.forEach((function(t){e=Math.max(e,t.size)})),e>0&&(e+=t.config.markers.hover.sizeOffset+1),t.globals.markers.largestSize=e,e}},{key:"getSeriesTotals",value:function(){var t=this.w;t.globals.seriesTotals=t.globals.series.map((function(t,e){var i=0;if(Array.isArray(t))for(var a=0;at&&i.globals.seriesX[s][o]0&&(e=!0),{comboBarCount:i,comboCharts:e}}},{key:"extendArrayProps",value:function(t,e,i){return e.yaxis&&(e=t.extendYAxis(e,i)),e.annotations&&(e.annotations.yaxis&&(e=t.extendYAxisAnnotations(e)),e.annotations.xaxis&&(e=t.extendXAxisAnnotations(e)),e.annotations.points&&(e=t.extendPointAnnotations(e))),e}}]),t}(),w=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e}return r(t,[{key:"setOrientations",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=this.w;if("vertical"===t.label.orientation){var a=null!==e?e:0,s=i.globals.dom.baseEl.querySelector(".apexcharts-xaxis-annotations .apexcharts-xaxis-annotation-label[rel='".concat(a,"']"));if(null!==s){var r=s.getBoundingClientRect();s.setAttribute("x",parseFloat(s.getAttribute("x"))-r.height+4),"top"===t.label.position?s.setAttribute("y",parseFloat(s.getAttribute("y"))+r.width):s.setAttribute("y",parseFloat(s.getAttribute("y"))-r.width);var o=this.annoCtx.graphics.rotateAroundCenter(s),n=o.x,l=o.y;s.setAttribute("transform","rotate(-90 ".concat(n," ").concat(l,")"))}}}},{key:"addBackgroundToAnno",value:function(t,e){var i=this.w;if(!t||void 0===e.label.text||void 0!==e.label.text&&!String(e.label.text).trim())return null;var a=i.globals.dom.baseEl.querySelector(".apexcharts-grid").getBoundingClientRect(),s=t.getBoundingClientRect(),r=e.label.style.padding.left,o=e.label.style.padding.right,n=e.label.style.padding.top,l=e.label.style.padding.bottom;"vertical"===e.label.orientation&&(n=e.label.style.padding.left,l=e.label.style.padding.right,r=e.label.style.padding.top,o=e.label.style.padding.bottom);var h=s.left-a.left-r,c=s.top-a.top-n,d=this.annoCtx.graphics.drawRect(h-i.globals.barPadForNumericAxis,c,s.width+r+o,s.height+n+l,e.label.borderRadius,e.label.style.background,1,e.label.borderWidth,e.label.borderColor,0);return e.id&&d.node.classList.add(e.id),d}},{key:"annotationsBackground",value:function(){var t=this,e=this.w,i=function(i,a,s){var r=e.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations .apexcharts-").concat(s,"-annotation-label[rel='").concat(a,"']"));if(r){var o=r.parentNode,n=t.addBackgroundToAnno(r,i);n&&(o.insertBefore(n.node,r),i.label.mouseEnter&&n.node.addEventListener("mouseenter",i.label.mouseEnter.bind(t,i)),i.label.mouseLeave&&n.node.addEventListener("mouseleave",i.label.mouseLeave.bind(t,i)),i.label.click&&n.node.addEventListener("click",i.label.click.bind(t,i)))}};e.config.annotations.xaxis.map((function(t,e){i(t,e,"xaxis")})),e.config.annotations.yaxis.map((function(t,e){i(t,e,"yaxis")})),e.config.annotations.points.map((function(t,e){i(t,e,"point")}))}},{key:"getY1Y2",value:function(t,e){var i,a="y1"===t?e.y:e.y2,s=this.w;if(this.annoCtx.invertAxis){var r=s.globals.labels.indexOf(a);s.config.xaxis.convertedCatToNumeric&&(r=s.globals.categoryLabels.indexOf(a));var o=s.globals.dom.baseEl.querySelector(".apexcharts-yaxis-texts-g text:nth-child("+(r+1)+")");o&&(i=parseFloat(o.getAttribute("y")))}else{var n;if(s.config.yaxis[e.yAxisIndex].logarithmic)n=(a=new y(this.annoCtx.ctx).getLogVal(a,e.yAxisIndex))/s.globals.yLogRatio[e.yAxisIndex];else n=(a-s.globals.minYArr[e.yAxisIndex])/(s.globals.yRange[e.yAxisIndex]/s.globals.gridHeight);i=s.globals.gridHeight-n,!e.marker||void 0!==e.y&&null!==e.y||(i=0),s.config.yaxis[e.yAxisIndex]&&s.config.yaxis[e.yAxisIndex].reversed&&(i=n)}return"string"==typeof a&&a.indexOf("px")>-1&&(i=parseFloat(a)),i}},{key:"getX1X2",value:function(t,e){var i=this.w,a=this.annoCtx.invertAxis?i.globals.minY:i.globals.minX,s=this.annoCtx.invertAxis?i.globals.maxY:i.globals.maxX,r=this.annoCtx.invertAxis?i.globals.yRange[0]:i.globals.xRange,o=(e.x-a)/(r/i.globals.gridWidth);this.annoCtx.inversedReversedAxis&&(o=(s-e.x)/(r/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(o=this.getStringX(e.x));var n=(e.x2-a)/(r/i.globals.gridWidth);return this.annoCtx.inversedReversedAxis&&(n=(s-e.x2)/(r/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(n=this.getStringX(e.x2)),void 0!==e.x&&null!==e.x||!e.marker||(o=i.globals.gridWidth),"x1"===t&&"string"==typeof e.x&&e.x.indexOf("px")>-1&&(o=parseFloat(e.x)),"x2"===t&&"string"==typeof e.x2&&e.x2.indexOf("px")>-1&&(n=parseFloat(e.x2)),"x1"===t?o:n}},{key:"getStringX",value:function(t){var e=this.w,i=t;e.config.xaxis.convertedCatToNumeric&&e.globals.categoryLabels.length&&(t=e.globals.categoryLabels.indexOf(t)+1);var a=e.globals.labels.indexOf(t),s=e.globals.dom.baseEl.querySelector(".apexcharts-xaxis-texts-g text:nth-child("+(a+1)+")");return s&&(i=parseFloat(s.getAttribute("x"))),i}}]),t}(),k=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e,this.invertAxis=this.annoCtx.invertAxis,this.helpers=new w(this.annoCtx)}return r(t,[{key:"addXaxisAnnotation",value:function(t,e,i){var a,s=this.w,r=this.helpers.getX1X2("x1",t),o=t.label.text,n=t.strokeDashArray;if(x.isNumber(r)){if(null===t.x2||void 0===t.x2){var l=this.annoCtx.graphics.drawLine(r+t.offsetX,0+t.offsetY,r+t.offsetX,s.globals.gridHeight+t.offsetY,t.borderColor,n,t.borderWidth);e.appendChild(l.node),t.id&&l.node.classList.add(t.id)}else{if((a=this.helpers.getX1X2("x2",t))o){var h=o;o=a,a=h}var c=this.annoCtx.graphics.drawRect(0+t.offsetX,a+t.offsetY,this._getYAxisAnnotationWidth(t),o-a,0,t.fillColor,t.opacity,1,t.borderColor,r);c.node.classList.add("apexcharts-annotation-rect"),c.attr("clip-path","url(#gridRectMask".concat(s.globals.cuid,")")),e.appendChild(c.node),t.id&&c.node.classList.add(t.id)}var d="right"===t.label.position?s.globals.gridWidth:"center"===t.label.position?s.globals.gridWidth/2:0,g=this.annoCtx.graphics.drawText({x:d+t.label.offsetX,y:(null!=a?a:o)+t.label.offsetY-3,text:n,textAnchor:t.label.textAnchor,fontSize:t.label.style.fontSize,fontFamily:t.label.style.fontFamily,fontWeight:t.label.style.fontWeight,foreColor:t.label.style.color,cssClass:"apexcharts-yaxis-annotation-label ".concat(t.label.style.cssClass," ").concat(t.id?t.id:"")});g.attr({rel:i}),e.appendChild(g.node)}},{key:"_getYAxisAnnotationWidth",value:function(t){var e=this.w;e.globals.gridWidth;return(t.width.indexOf("%")>-1?e.globals.gridWidth*parseInt(t.width,10)/100:parseInt(t.width,10))+t.offsetX}},{key:"drawYAxisAnnotations",value:function(){var t=this,e=this.w,i=this.annoCtx.graphics.group({class:"apexcharts-yaxis-annotations"});return e.config.annotations.yaxis.map((function(e,a){t.addYaxisAnnotation(e,i.node,a)})),i}}]),t}(),S=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e,this.helpers=new w(this.annoCtx)}return r(t,[{key:"addPointAnnotation",value:function(t,e,i){this.w;var a=this.helpers.getX1X2("x1",t),s=this.helpers.getY1Y2("y1",t);if(x.isNumber(a)){var r={pSize:t.marker.size,pointStrokeWidth:t.marker.strokeWidth,pointFillColor:t.marker.fillColor,pointStrokeColor:t.marker.strokeColor,shape:t.marker.shape,pRadius:t.marker.radius,class:"apexcharts-point-annotation-marker ".concat(t.marker.cssClass," ").concat(t.id?t.id:"")},o=this.annoCtx.graphics.drawMarker(a+t.marker.offsetX,s+t.marker.offsetY,r);e.appendChild(o.node);var n=t.label.text?t.label.text:"",l=this.annoCtx.graphics.drawText({x:a+t.label.offsetX,y:s+t.label.offsetY-t.marker.size-parseFloat(t.label.style.fontSize)/1.6,text:n,textAnchor:t.label.textAnchor,fontSize:t.label.style.fontSize,fontFamily:t.label.style.fontFamily,fontWeight:t.label.style.fontWeight,foreColor:t.label.style.color,cssClass:"apexcharts-point-annotation-label ".concat(t.label.style.cssClass," ").concat(t.id?t.id:"")});if(l.attr({rel:i}),e.appendChild(l.node),t.customSVG.SVG){var h=this.annoCtx.graphics.group({class:"apexcharts-point-annotations-custom-svg "+t.customSVG.cssClass});h.attr({transform:"translate(".concat(a+t.customSVG.offsetX,", ").concat(s+t.customSVG.offsetY,")")}),h.node.innerHTML=t.customSVG.SVG,e.appendChild(h.node)}if(t.image.path){var c=t.image.width?t.image.width:20,d=t.image.height?t.image.height:20;o=this.annoCtx.addImage({x:a+t.image.offsetX-c/2,y:s+t.image.offsetY-d/2,width:c,height:d,path:t.image.path,appendTo:".apexcharts-point-annotations"})}t.mouseEnter&&o.node.addEventListener("mouseenter",t.mouseEnter.bind(this,t)),t.mouseLeave&&o.node.addEventListener("mouseleave",t.mouseLeave.bind(this,t)),t.click&&o.node.addEventListener("click",t.click.bind(this,t))}}},{key:"drawPointAnnotations",value:function(){var t=this,e=this.w,i=this.annoCtx.graphics.group({class:"apexcharts-point-annotations"});return e.config.annotations.points.map((function(e,a){t.addPointAnnotation(e,i.node,a)})),i}}]),t}();var C={name:"en",options:{months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],toolbar:{exportToSVG:"Download SVG",exportToPNG:"Download PNG",exportToCSV:"Download CSV",menu:"Menu",selection:"Selection",selectionZoom:"Selection Zoom",zoomIn:"Zoom In",zoomOut:"Zoom Out",pan:"Panning",reset:"Reset Zoom"}}},L=function(){function t(){a(this,t),this.yAxis={show:!0,showAlways:!1,showForNullSeries:!0,seriesName:void 0,opposite:!1,reversed:!1,logarithmic:!1,logBase:10,tickAmount:void 0,forceNiceScale:!1,max:void 0,min:void 0,floating:!1,decimalsInFloat:void 0,labels:{show:!0,minWidth:0,maxWidth:160,offsetX:0,offsetY:0,align:void 0,rotate:0,padding:20,style:{colors:[],fontSize:"11px",fontWeight:400,fontFamily:void 0,cssClass:""},formatter:void 0},axisBorder:{show:!1,color:"#e0e0e0",width:1,offsetX:0,offsetY:0},axisTicks:{show:!1,color:"#e0e0e0",width:6,offsetX:0,offsetY:0},title:{text:void 0,rotate:-90,offsetY:0,offsetX:0,style:{color:void 0,fontSize:"11px",fontWeight:900,fontFamily:void 0,cssClass:""}},tooltip:{enabled:!1,offsetX:0},crosshairs:{show:!0,position:"front",stroke:{color:"#b6b6b6",width:1,dashArray:0}}},this.pointAnnotation={id:void 0,x:0,y:null,yAxisIndex:0,seriesIndex:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,marker:{size:4,fillColor:"#fff",strokeWidth:2,strokeColor:"#333",shape:"circle",offsetX:0,offsetY:0,radius:2,cssClass:""},label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"middle",offsetX:0,offsetY:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}},customSVG:{SVG:void 0,cssClass:void 0,offsetX:0,offsetY:0},image:{path:void 0,width:20,height:20,offsetX:0,offsetY:0}},this.yAxisAnnotation={id:void 0,y:0,y2:null,strokeDashArray:1,fillColor:"#c2c2c2",borderColor:"#c2c2c2",borderWidth:1,opacity:.3,offsetX:0,offsetY:0,width:"100%",yAxisIndex:0,label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"end",position:"right",offsetX:0,offsetY:-3,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}}},this.xAxisAnnotation={id:void 0,x:0,x2:null,strokeDashArray:1,fillColor:"#c2c2c2",borderColor:"#c2c2c2",borderWidth:1,opacity:.3,offsetX:0,offsetY:0,label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"middle",orientation:"vertical",position:"top",offsetX:0,offsetY:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}}},this.text={x:0,y:0,text:"",textAnchor:"start",foreColor:void 0,fontSize:"13px",fontFamily:void 0,fontWeight:400,appendTo:".apexcharts-annotations",backgroundColor:"transparent",borderColor:"#c2c2c2",borderRadius:0,borderWidth:0,paddingLeft:4,paddingRight:4,paddingTop:2,paddingBottom:2}}return r(t,[{key:"init",value:function(){return{annotations:{yaxis:[this.yAxisAnnotation],xaxis:[this.xAxisAnnotation],points:[this.pointAnnotation],texts:[],images:[],shapes:[]},chart:{animations:{enabled:!0,easing:"easeinout",speed:800,animateGradually:{delay:150,enabled:!0},dynamicAnimation:{enabled:!0,speed:350}},background:"transparent",locales:[C],defaultLocale:"en",dropShadow:{enabled:!1,enabledOnSeries:void 0,top:2,left:2,blur:4,color:"#000",opacity:.35},events:{animationEnd:void 0,beforeMount:void 0,mounted:void 0,updated:void 0,click:void 0,mouseMove:void 0,mouseLeave:void 0,xAxisLabelClick:void 0,legendClick:void 0,markerClick:void 0,selection:void 0,dataPointSelection:void 0,dataPointMouseEnter:void 0,dataPointMouseLeave:void 0,beforeZoom:void 0,beforeResetZoom:void 0,zoomed:void 0,scrolled:void 0,brushScrolled:void 0},foreColor:"#373d3f",fontFamily:"Helvetica, Arial, sans-serif",height:"auto",parentHeightOffset:15,redrawOnParentResize:!0,redrawOnWindowResize:!0,id:void 0,group:void 0,offsetX:0,offsetY:0,selection:{enabled:!1,type:"x",fill:{color:"#24292e",opacity:.1},stroke:{width:1,color:"#24292e",opacity:.4,dashArray:3},xaxis:{min:void 0,max:void 0},yaxis:{min:void 0,max:void 0}},sparkline:{enabled:!1},brush:{enabled:!1,autoScaleYaxis:!0,target:void 0},stacked:!1,stackType:"normal",toolbar:{show:!0,offsetX:0,offsetY:0,tools:{download:!0,selection:!0,zoom:!0,zoomin:!0,zoomout:!0,pan:!0,reset:!0,customIcons:[]},export:{csv:{filename:void 0,columnDelimiter:",",headerCategory:"category",headerValue:"value",dateFormatter:function(t){return new Date(t).toDateString()}},png:{filename:void 0},svg:{filename:void 0}},autoSelected:"zoom"},type:"line",width:"100%",zoom:{enabled:!0,type:"x",autoScaleYaxis:!1,zoomedArea:{fill:{color:"#90CAF9",opacity:.4},stroke:{color:"#0D47A1",opacity:.4,width:1}}}},plotOptions:{area:{fillTo:"origin"},bar:{horizontal:!1,columnWidth:"70%",barHeight:"70%",distributed:!1,borderRadius:0,borderRadiusApplication:"around",borderRadiusWhenStacked:"last",rangeBarOverlap:!0,rangeBarGroupRows:!1,hideZeroBarsWhenGrouped:!1,isDumbbell:!1,dumbbellColors:void 0,colors:{ranges:[],backgroundBarColors:[],backgroundBarOpacity:1,backgroundBarRadius:0},dataLabels:{position:"top",maxItems:100,hideOverflowingLabels:!0,orientation:"horizontal",total:{enabled:!1,formatter:void 0,offsetX:0,offsetY:0,style:{color:"#373d3f",fontSize:"12px",fontFamily:void 0,fontWeight:600}}}},bubble:{zScaling:!0,minBubbleRadius:void 0,maxBubbleRadius:void 0},candlestick:{colors:{upward:"#00B746",downward:"#EF403C"},wick:{useFillColor:!0}},boxPlot:{colors:{upper:"#00E396",lower:"#008FFB"}},heatmap:{radius:2,enableShades:!0,shadeIntensity:.5,reverseNegativeShade:!1,distributed:!1,useFillColorAsStroke:!1,colorScale:{inverse:!1,ranges:[],min:void 0,max:void 0}},treemap:{enableShades:!0,shadeIntensity:.5,distributed:!1,reverseNegativeShade:!1,useFillColorAsStroke:!1,colorScale:{inverse:!1,ranges:[],min:void 0,max:void 0}},radialBar:{inverseOrder:!1,startAngle:0,endAngle:360,offsetX:0,offsetY:0,hollow:{margin:5,size:"50%",background:"transparent",image:void 0,imageWidth:150,imageHeight:150,imageOffsetX:0,imageOffsetY:0,imageClipped:!0,position:"front",dropShadow:{enabled:!1,top:0,left:0,blur:3,color:"#000",opacity:.5}},track:{show:!0,startAngle:void 0,endAngle:void 0,background:"#f2f2f2",strokeWidth:"97%",opacity:1,margin:5,dropShadow:{enabled:!1,top:0,left:0,blur:3,color:"#000",opacity:.5}},dataLabels:{show:!0,name:{show:!0,fontSize:"16px",fontFamily:void 0,fontWeight:600,color:void 0,offsetY:0,formatter:function(t){return t}},value:{show:!0,fontSize:"14px",fontFamily:void 0,fontWeight:400,color:void 0,offsetY:16,formatter:function(t){return t+"%"}},total:{show:!1,label:"Total",fontSize:"16px",fontWeight:600,fontFamily:void 0,color:void 0,formatter:function(t){return t.globals.seriesTotals.reduce((function(t,e){return t+e}),0)/t.globals.series.length+"%"}}}},pie:{customScale:1,offsetX:0,offsetY:0,startAngle:0,endAngle:360,expandOnClick:!0,dataLabels:{offset:0,minAngleToShowLabel:10},donut:{size:"65%",background:"transparent",labels:{show:!1,name:{show:!0,fontSize:"16px",fontFamily:void 0,fontWeight:600,color:void 0,offsetY:-10,formatter:function(t){return t}},value:{show:!0,fontSize:"20px",fontFamily:void 0,fontWeight:400,color:void 0,offsetY:10,formatter:function(t){return t}},total:{show:!1,showAlways:!1,label:"Total",fontSize:"16px",fontWeight:400,fontFamily:void 0,color:void 0,formatter:function(t){return t.globals.seriesTotals.reduce((function(t,e){return t+e}),0)}}}}},polarArea:{rings:{strokeWidth:1,strokeColor:"#e8e8e8"},spokes:{strokeWidth:1,connectorColors:"#e8e8e8"}},radar:{size:void 0,offsetX:0,offsetY:0,polygons:{strokeWidth:1,strokeColors:"#e8e8e8",connectorColors:"#e8e8e8",fill:{colors:void 0}}}},colors:void 0,dataLabels:{enabled:!0,enabledOnSeries:void 0,formatter:function(t){return null!==t?t:""},textAnchor:"middle",distributed:!1,offsetX:0,offsetY:0,style:{fontSize:"12px",fontFamily:void 0,fontWeight:600,colors:void 0},background:{enabled:!0,foreColor:"#fff",borderRadius:2,padding:4,opacity:.9,borderWidth:1,borderColor:"#fff",dropShadow:{enabled:!1,top:1,left:1,blur:1,color:"#000",opacity:.45}},dropShadow:{enabled:!1,top:1,left:1,blur:1,color:"#000",opacity:.45}},fill:{type:"solid",colors:void 0,opacity:.85,gradient:{shade:"dark",type:"horizontal",shadeIntensity:.5,gradientToColors:void 0,inverseColors:!0,opacityFrom:1,opacityTo:1,stops:[0,50,100],colorStops:[]},image:{src:[],width:void 0,height:void 0},pattern:{style:"squares",width:6,height:6,strokeWidth:2}},forecastDataPoints:{count:0,fillOpacity:.5,strokeWidth:void 0,dashArray:4},grid:{show:!0,borderColor:"#e0e0e0",strokeDashArray:0,position:"back",xaxis:{lines:{show:!1}},yaxis:{lines:{show:!0}},row:{colors:void 0,opacity:.5},column:{colors:void 0,opacity:.5},padding:{top:0,right:10,bottom:0,left:12}},labels:[],legend:{show:!0,showForSingleSeries:!1,showForNullSeries:!0,showForZeroSeries:!0,floating:!1,position:"bottom",horizontalAlign:"center",inverseOrder:!1,fontSize:"12px",fontFamily:void 0,fontWeight:400,width:void 0,height:void 0,formatter:void 0,tooltipHoverFormatter:void 0,offsetX:-20,offsetY:4,customLegendItems:[],labels:{colors:void 0,useSeriesColors:!1},markers:{width:12,height:12,strokeWidth:0,fillColors:void 0,strokeColor:"#fff",radius:12,customHTML:void 0,offsetX:0,offsetY:0,onClick:void 0},itemMargin:{horizontal:5,vertical:2},onItemClick:{toggleDataSeries:!0},onItemHover:{highlightDataSeries:!0}},markers:{discrete:[],size:0,colors:void 0,strokeColors:"#fff",strokeWidth:2,strokeOpacity:.9,strokeDashArray:0,fillOpacity:1,shape:"circle",width:8,height:8,radius:2,offsetX:0,offsetY:0,onClick:void 0,onDblClick:void 0,showNullDataPoints:!0,hover:{size:void 0,sizeOffset:3}},noData:{text:void 0,align:"center",verticalAlign:"middle",offsetX:0,offsetY:0,style:{color:void 0,fontSize:"14px",fontFamily:void 0}},responsive:[],series:void 0,states:{normal:{filter:{type:"none",value:0}},hover:{filter:{type:"lighten",value:.1}},active:{allowMultipleDataPointsSelection:!1,filter:{type:"darken",value:.5}}},title:{text:void 0,align:"left",margin:5,offsetX:0,offsetY:0,floating:!1,style:{fontSize:"14px",fontWeight:900,fontFamily:void 0,color:void 0}},subtitle:{text:void 0,align:"left",margin:5,offsetX:0,offsetY:30,floating:!1,style:{fontSize:"12px",fontWeight:400,fontFamily:void 0,color:void 0}},stroke:{show:!0,curve:"smooth",lineCap:"butt",width:2,colors:void 0,dashArray:0,fill:{type:"solid",colors:void 0,opacity:.85,gradient:{shade:"dark",type:"horizontal",shadeIntensity:.5,gradientToColors:void 0,inverseColors:!0,opacityFrom:1,opacityTo:1,stops:[0,50,100],colorStops:[]}}},tooltip:{enabled:!0,enabledOnSeries:void 0,shared:!0,followCursor:!1,intersect:!1,inverseOrder:!1,custom:void 0,fillSeriesColor:!1,theme:"light",cssClass:"",style:{fontSize:"12px",fontFamily:void 0},onDatasetHover:{highlightDataSeries:!1},x:{show:!0,format:"dd MMM",formatter:void 0},y:{formatter:void 0,title:{formatter:function(t){return t?t+": ":""}}},z:{formatter:void 0,title:"Size: "},marker:{show:!0,fillColors:void 0},items:{display:"flex"},fixed:{enabled:!1,position:"topRight",offsetX:0,offsetY:0}},xaxis:{type:"category",categories:[],convertedCatToNumeric:!1,offsetX:0,offsetY:0,overwriteCategories:void 0,labels:{show:!0,rotate:-45,rotateAlways:!1,hideOverlappingLabels:!0,trim:!1,minHeight:void 0,maxHeight:120,showDuplicates:!0,style:{colors:[],fontSize:"12px",fontWeight:400,fontFamily:void 0,cssClass:""},offsetX:0,offsetY:0,format:void 0,formatter:void 0,datetimeUTC:!0,datetimeFormatter:{year:"yyyy",month:"MMM 'yy",day:"dd MMM",hour:"HH:mm",minute:"HH:mm:ss",second:"HH:mm:ss"}},group:{groups:[],style:{colors:[],fontSize:"12px",fontWeight:400,fontFamily:void 0,cssClass:""}},axisBorder:{show:!0,color:"#e0e0e0",width:"100%",height:1,offsetX:0,offsetY:0},axisTicks:{show:!0,color:"#e0e0e0",height:6,offsetX:0,offsetY:0},tickAmount:void 0,tickPlacement:"on",min:void 0,max:void 0,range:void 0,floating:!1,decimalsInFloat:void 0,position:"bottom",title:{text:void 0,offsetX:0,offsetY:0,style:{color:void 0,fontSize:"12px",fontWeight:900,fontFamily:void 0,cssClass:""}},crosshairs:{show:!0,width:1,position:"back",opacity:.9,stroke:{color:"#b6b6b6",width:1,dashArray:3},fill:{type:"solid",color:"#B1B9C4",gradient:{colorFrom:"#D8E3F0",colorTo:"#BED1E6",stops:[0,100],opacityFrom:.4,opacityTo:.5}},dropShadow:{enabled:!1,left:0,top:0,blur:1,opacity:.4}},tooltip:{enabled:!0,offsetY:0,formatter:void 0,style:{fontSize:"12px",fontFamily:void 0}}},yaxis:this.yAxis,theme:{mode:"light",palette:"palette1",monochrome:{enabled:!1,color:"#008FFB",shadeTo:"light",shadeIntensity:.65}}}}}]),t}(),P=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.graphics=new m(this.ctx),this.w.globals.isBarHorizontal&&(this.invertAxis=!0),this.helpers=new w(this),this.xAxisAnnotations=new k(this),this.yAxisAnnotations=new A(this),this.pointsAnnotations=new S(this),this.w.globals.isBarHorizontal&&this.w.config.yaxis[0].reversed&&(this.inversedReversedAxis=!0),this.xDivision=this.w.globals.gridWidth/this.w.globals.dataPoints}return r(t,[{key:"drawAxesAnnotations",value:function(){var t=this.w;if(t.globals.axisCharts){for(var e=this.yAxisAnnotations.drawYAxisAnnotations(),i=this.xAxisAnnotations.drawXAxisAnnotations(),a=this.pointsAnnotations.drawPointAnnotations(),s=t.config.chart.animations.enabled,r=[e,i,a],o=[i.node,e.node,a.node],n=0;n<3;n++)t.globals.dom.elGraphical.add(r[n]),!s||t.globals.resized||t.globals.dataChanged||"scatter"!==t.config.chart.type&&"bubble"!==t.config.chart.type&&t.globals.dataPoints>1&&o[n].classList.add("apexcharts-element-hidden"),t.globals.delayedElements.push({el:o[n],index:0});this.helpers.annotationsBackground()}}},{key:"drawImageAnnos",value:function(){var t=this;this.w.config.annotations.images.map((function(e,i){t.addImage(e,i)}))}},{key:"drawTextAnnos",value:function(){var t=this;this.w.config.annotations.texts.map((function(e,i){t.addText(e,i)}))}},{key:"addXaxisAnnotation",value:function(t,e,i){this.xAxisAnnotations.addXaxisAnnotation(t,e,i)}},{key:"addYaxisAnnotation",value:function(t,e,i){this.yAxisAnnotations.addYaxisAnnotation(t,e,i)}},{key:"addPointAnnotation",value:function(t,e,i){this.pointsAnnotations.addPointAnnotation(t,e,i)}},{key:"addText",value:function(t,e){var i=t.x,a=t.y,s=t.text,r=t.textAnchor,o=t.foreColor,n=t.fontSize,l=t.fontFamily,h=t.fontWeight,c=t.cssClass,d=t.backgroundColor,g=t.borderWidth,u=t.strokeDashArray,p=t.borderRadius,f=t.borderColor,x=t.appendTo,b=void 0===x?".apexcharts-annotations":x,v=t.paddingLeft,m=void 0===v?4:v,y=t.paddingRight,w=void 0===y?4:y,k=t.paddingBottom,A=void 0===k?2:k,S=t.paddingTop,C=void 0===S?2:S,L=this.w,P=this.graphics.drawText({x:i,y:a,text:s,textAnchor:r||"start",fontSize:n||"12px",fontWeight:h||"regular",fontFamily:l||L.config.chart.fontFamily,foreColor:o||L.config.chart.foreColor,cssClass:c}),I=L.globals.dom.baseEl.querySelector(b);I&&I.appendChild(P.node);var T=P.bbox();if(s){var M=this.graphics.drawRect(T.x-m,T.y-C,T.width+m+w,T.height+A+C,p,d||"transparent",1,g,f,u);I.insertBefore(M.node,P.node)}}},{key:"addImage",value:function(t,e){var i=this.w,a=t.path,s=t.x,r=void 0===s?0:s,o=t.y,n=void 0===o?0:o,l=t.width,h=void 0===l?20:l,c=t.height,d=void 0===c?20:c,g=t.appendTo,u=void 0===g?".apexcharts-annotations":g,p=i.globals.dom.Paper.image(a);p.size(h,d).move(r,n);var f=i.globals.dom.baseEl.querySelector(u);return f&&f.appendChild(p.node),p}},{key:"addXaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"xaxis",contextMethod:i.addXaxisAnnotation}),i}},{key:"addYaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"yaxis",contextMethod:i.addYaxisAnnotation}),i}},{key:"addPointAnnotationExternal",value:function(t,e,i){return void 0===this.invertAxis&&(this.invertAxis=i.w.globals.isBarHorizontal),this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"point",contextMethod:i.addPointAnnotation}),i}},{key:"addAnnotationExternal",value:function(t){var e=t.params,i=t.pushToMemory,a=t.context,s=t.type,r=t.contextMethod,o=a,n=o.w,l=n.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations")),h=l.childNodes.length+1,c=new L,d=Object.assign({},"xaxis"===s?c.xAxisAnnotation:"yaxis"===s?c.yAxisAnnotation:c.pointAnnotation),g=x.extend(d,e);switch(s){case"xaxis":this.addXaxisAnnotation(g,l,h);break;case"yaxis":this.addYaxisAnnotation(g,l,h);break;case"point":this.addPointAnnotation(g,l,h)}var u=n.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations .apexcharts-").concat(s,"-annotation-label[rel='").concat(h,"']")),p=this.helpers.addBackgroundToAnno(u,g);return p&&l.insertBefore(p.node,u),i&&n.globals.memory.methodsToExec.push({context:o,id:g.id?g.id:x.randomId(),method:r,label:"addAnnotation",params:e}),a}},{key:"clearAnnotations",value:function(t){var e=t.w,i=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis-annotations, .apexcharts-xaxis-annotations, .apexcharts-point-annotations");e.globals.memory.methodsToExec.map((function(t,i){"addText"!==t.label&&"addAnnotation"!==t.label||e.globals.memory.methodsToExec.splice(i,1)})),i=x.listToArray(i),Array.prototype.forEach.call(i,(function(t){for(;t.firstChild;)t.removeChild(t.firstChild)}))}},{key:"removeAnnotation",value:function(t,e){var i=t.w,a=i.globals.dom.baseEl.querySelectorAll(".".concat(e));a&&(i.globals.memory.methodsToExec.map((function(t,a){t.id===e&&i.globals.memory.methodsToExec.splice(a,1)})),Array.prototype.forEach.call(a,(function(t){t.parentElement.removeChild(t)})))}}]),t}(),I=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.months31=[1,3,5,7,8,10,12],this.months30=[2,4,6,9,11],this.daysCntOfYear=[0,31,59,90,120,151,181,212,243,273,304,334]}return r(t,[{key:"isValidDate",value:function(t){return!isNaN(this.parseDate(t))}},{key:"getTimeStamp",value:function(t){return Date.parse(t)?this.w.config.xaxis.labels.datetimeUTC?new Date(new Date(t).toISOString().substr(0,25)).getTime():new Date(t).getTime():t}},{key:"getDate",value:function(t){return this.w.config.xaxis.labels.datetimeUTC?new Date(new Date(t).toUTCString()):new Date(t)}},{key:"parseDate",value:function(t){var e=Date.parse(t);if(!isNaN(e))return this.getTimeStamp(t);var i=Date.parse(t.replace(/-/g,"/").replace(/[a-z]+/gi," "));return i=this.getTimeStamp(i)}},{key:"parseDateWithTimezone",value:function(t){return Date.parse(t.replace(/-/g,"/").replace(/[a-z]+/gi," "))}},{key:"formatDate",value:function(t,e){var i=this.w.globals.locale,a=this.w.config.xaxis.labels.datetimeUTC,s=["\0"].concat(u(i.months)),r=["\x01"].concat(u(i.shortMonths)),o=["\x02"].concat(u(i.days)),n=["\x03"].concat(u(i.shortDays));function l(t,e){var i=t+"";for(e=e||2;i.length12?g-12:0===g?12:g;e=(e=(e=(e=e.replace(/(^|[^\\])HH+/g,"$1"+l(g))).replace(/(^|[^\\])H/g,"$1"+g)).replace(/(^|[^\\])hh+/g,"$1"+l(p))).replace(/(^|[^\\])h/g,"$1"+p);var f=a?t.getUTCMinutes():t.getMinutes();e=(e=e.replace(/(^|[^\\])mm+/g,"$1"+l(f))).replace(/(^|[^\\])m/g,"$1"+f);var x=a?t.getUTCSeconds():t.getSeconds();e=(e=e.replace(/(^|[^\\])ss+/g,"$1"+l(x))).replace(/(^|[^\\])s/g,"$1"+x);var b=a?t.getUTCMilliseconds():t.getMilliseconds();e=e.replace(/(^|[^\\])fff+/g,"$1"+l(b,3)),b=Math.round(b/10),e=e.replace(/(^|[^\\])ff/g,"$1"+l(b)),b=Math.round(b/10);var v=g<12?"AM":"PM";e=(e=(e=e.replace(/(^|[^\\])f/g,"$1"+b)).replace(/(^|[^\\])TT+/g,"$1"+v)).replace(/(^|[^\\])T/g,"$1"+v.charAt(0));var m=v.toLowerCase();e=(e=e.replace(/(^|[^\\])tt+/g,"$1"+m)).replace(/(^|[^\\])t/g,"$1"+m.charAt(0));var y=-t.getTimezoneOffset(),w=a||!y?"Z":y>0?"+":"-";if(!a){var k=(y=Math.abs(y))%60;w+=l(Math.floor(y/60))+":"+l(k)}e=e.replace(/(^|[^\\])K/g,"$1"+w);var A=(a?t.getUTCDay():t.getDay())+1;return e=(e=(e=(e=(e=e.replace(new RegExp(o[0],"g"),o[A])).replace(new RegExp(n[0],"g"),n[A])).replace(new RegExp(s[0],"g"),s[c])).replace(new RegExp(r[0],"g"),r[c])).replace(/\\(.)/g,"$1")}},{key:"getTimeUnitsfromTimestamp",value:function(t,e,i){var a=this.w;void 0!==a.config.xaxis.min&&(t=a.config.xaxis.min),void 0!==a.config.xaxis.max&&(e=a.config.xaxis.max);var s=this.getDate(t),r=this.getDate(e),o=this.formatDate(s,"yyyy MM dd HH mm ss fff").split(" "),n=this.formatDate(r,"yyyy MM dd HH mm ss fff").split(" ");return{minMillisecond:parseInt(o[6],10),maxMillisecond:parseInt(n[6],10),minSecond:parseInt(o[5],10),maxSecond:parseInt(n[5],10),minMinute:parseInt(o[4],10),maxMinute:parseInt(n[4],10),minHour:parseInt(o[3],10),maxHour:parseInt(n[3],10),minDate:parseInt(o[2],10),maxDate:parseInt(n[2],10),minMonth:parseInt(o[1],10)-1,maxMonth:parseInt(n[1],10)-1,minYear:parseInt(o[0],10),maxYear:parseInt(n[0],10)}}},{key:"isLeapYear",value:function(t){return t%4==0&&t%100!=0||t%400==0}},{key:"calculcateLastDaysOfMonth",value:function(t,e,i){return this.determineDaysOfMonths(t,e)-i}},{key:"determineDaysOfYear",value:function(t){var e=365;return this.isLeapYear(t)&&(e=366),e}},{key:"determineRemainingDaysOfYear",value:function(t,e,i){var a=this.daysCntOfYear[e]+i;return e>1&&this.isLeapYear()&&a++,a}},{key:"determineDaysOfMonths",value:function(t,e){var i=30;switch(t=x.monthMod(t),!0){case this.months30.indexOf(t)>-1:2===t&&(i=this.isLeapYear(e)?29:28);break;case this.months31.indexOf(t)>-1:default:i=31}return i}}]),t}(),T=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.tooltipKeyFormat="dd MMM"}return r(t,[{key:"xLabelFormat",value:function(t,e,i,a){var s=this.w;if("datetime"===s.config.xaxis.type&&void 0===s.config.xaxis.labels.formatter&&void 0===s.config.tooltip.x.formatter){var r=new I(this.ctx);return r.formatDate(r.getDate(e),s.config.tooltip.x.format)}return t(e,i,a)}},{key:"defaultGeneralFormatter",value:function(t){return Array.isArray(t)?t.map((function(t){return t})):t}},{key:"defaultYFormatter",value:function(t,e,i){var a=this.w;return x.isNumber(t)&&(t=0!==a.globals.yValueDecimal?t.toFixed(void 0!==e.decimalsInFloat?e.decimalsInFloat:a.globals.yValueDecimal):a.globals.maxYArr[i]-a.globals.minYArr[i]<5?t.toFixed(1):t.toFixed(0)),t}},{key:"setLabelFormatters",value:function(){var t=this,e=this.w;return e.globals.xaxisTooltipFormatter=function(e){return t.defaultGeneralFormatter(e)},e.globals.ttKeyFormatter=function(e){return t.defaultGeneralFormatter(e)},e.globals.ttZFormatter=function(t){return t},e.globals.legendFormatter=function(e){return t.defaultGeneralFormatter(e)},void 0!==e.config.xaxis.labels.formatter?e.globals.xLabelFormatter=e.config.xaxis.labels.formatter:e.globals.xLabelFormatter=function(t){if(x.isNumber(t)){if(!e.config.xaxis.convertedCatToNumeric&&"numeric"===e.config.xaxis.type){if(x.isNumber(e.config.xaxis.decimalsInFloat))return t.toFixed(e.config.xaxis.decimalsInFloat);var i=e.globals.maxX-e.globals.minX;return i>0&&i<100?t.toFixed(1):t.toFixed(0)}if(e.globals.isBarHorizontal)if(e.globals.maxY-e.globals.minYArr<4)return t.toFixed(1);return t.toFixed(0)}return t},"function"==typeof e.config.tooltip.x.formatter?e.globals.ttKeyFormatter=e.config.tooltip.x.formatter:e.globals.ttKeyFormatter=e.globals.xLabelFormatter,"function"==typeof e.config.xaxis.tooltip.formatter&&(e.globals.xaxisTooltipFormatter=e.config.xaxis.tooltip.formatter),(Array.isArray(e.config.tooltip.y)||void 0!==e.config.tooltip.y.formatter)&&(e.globals.ttVal=e.config.tooltip.y),void 0!==e.config.tooltip.z.formatter&&(e.globals.ttZFormatter=e.config.tooltip.z.formatter),void 0!==e.config.legend.formatter&&(e.globals.legendFormatter=e.config.legend.formatter),e.config.yaxis.forEach((function(i,a){void 0!==i.labels.formatter?e.globals.yLabelFormatters[a]=i.labels.formatter:e.globals.yLabelFormatters[a]=function(s){return e.globals.xyCharts?Array.isArray(s)?s.map((function(e){return t.defaultYFormatter(e,i,a)})):t.defaultYFormatter(s,i,a):s}})),e.globals}},{key:"heatmapLabelFormatters",value:function(){var t=this.w;if("heatmap"===t.config.chart.type){t.globals.yAxisScale[0].result=t.globals.seriesNames.slice();var e=t.globals.seriesNames.reduce((function(t,e){return t.length>e.length?t:e}),0);t.globals.yAxisScale[0].niceMax=e,t.globals.yAxisScale[0].niceMin=e}}}]),t}(),M=function(t){var e,i=t.isTimeline,a=t.ctx,s=t.seriesIndex,r=t.dataPointIndex,o=t.y1,n=t.y2,l=t.w,h=l.globals.seriesRangeStart[s][r],c=l.globals.seriesRangeEnd[s][r],d=l.globals.labels[r],g=l.config.series[s].name?l.config.series[s].name:"",u=l.globals.ttKeyFormatter,p=l.config.tooltip.y.title.formatter,f={w:l,seriesIndex:s,dataPointIndex:r,start:h,end:c};("function"==typeof p&&(g=p(g,f)),null!==(e=l.config.series[s].data[r])&&void 0!==e&&e.x&&(d=l.config.series[s].data[r].x),i)||"datetime"===l.config.xaxis.type&&(d=new T(a).xLabelFormat(l.globals.ttKeyFormatter,d,d,{i:void 0,dateFormatter:new I(a).formatDate,w:l}));"function"==typeof u&&(d=u(d,f)),Number.isFinite(o)&&Number.isFinite(n)&&(h=o,c=n);var x="",b="",v=l.globals.colors[s];if(void 0===l.config.tooltip.x.formatter)if("datetime"===l.config.xaxis.type){var m=new I(a);x=m.formatDate(m.getDate(h),l.config.tooltip.x.format),b=m.formatDate(m.getDate(c),l.config.tooltip.x.format)}else x=h,b=c;else x=l.config.tooltip.x.formatter(h),b=l.config.tooltip.x.formatter(c);return{start:h,end:c,startVal:x,endVal:b,ylabel:d,color:v,seriesName:g}},X=function(t){var e=t.color,i=t.seriesName,a=t.ylabel,s=t.start,r=t.end,o=t.seriesIndex,n=t.dataPointIndex,l=t.ctx.tooltip.tooltipLabels.getFormatters(o);s=l.yLbFormatter(s),r=l.yLbFormatter(r);var h=l.yLbFormatter(t.w.globals.series[o][n]),c='\n '.concat(s,'\n - \n ').concat(r,"\n ");return'
'+(i||"")+'
'+a+": "+(t.w.globals.comboCharts?"rangeArea"===t.w.config.series[o].type||"rangeBar"===t.w.config.series[o].type?c:"".concat(h,""):c)+"
"},z=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"line",value:function(){return{chart:{animations:{easing:"swing"}},dataLabels:{enabled:!1},stroke:{width:5,curve:"straight"},markers:{size:0,hover:{sizeOffset:6}},xaxis:{crosshairs:{width:1}}}}},{key:"sparkline",value:function(t){this.opts.yaxis[0].show=!1,this.opts.yaxis[0].title.text="",this.opts.yaxis[0].axisBorder.show=!1,this.opts.yaxis[0].axisTicks.show=!1,this.opts.yaxis[0].floating=!0;return x.extend(t,{grid:{show:!1,padding:{left:0,right:0,top:0,bottom:0}},legend:{show:!1},xaxis:{labels:{show:!1},tooltip:{enabled:!1},axisBorder:{show:!1},axisTicks:{show:!1}},chart:{toolbar:{show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1}})}},{key:"bar",value:function(){return{chart:{stacked:!1,animations:{easing:"swing"}},plotOptions:{bar:{dataLabels:{position:"center"}}},dataLabels:{style:{colors:["#fff"]},background:{enabled:!1}},stroke:{width:0,lineCap:"round"},fill:{opacity:.85},legend:{markers:{shape:"square",radius:2,size:8}},tooltip:{shared:!1,intersect:!0},xaxis:{tooltip:{enabled:!1},tickPlacement:"between",crosshairs:{width:"barWidth",position:"back",fill:{type:"gradient"},dropShadow:{enabled:!1},stroke:{width:0}}}}}},{key:"candlestick",value:function(){var t=this;return{stroke:{width:1,colors:["#333"]},fill:{opacity:1},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,s=e.w;return t._getBoxTooltip(s,i,a,["Open","High","","Low","Close"],"candlestick")}},states:{active:{filter:{type:"none"}}},xaxis:{crosshairs:{width:1}}}}},{key:"boxPlot",value:function(){var t=this;return{chart:{animations:{dynamicAnimation:{enabled:!1}}},stroke:{width:1,colors:["#24292e"]},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,s=e.w;return t._getBoxTooltip(s,i,a,["Minimum","Q1","Median","Q3","Maximum"],"boxPlot")}},markers:{size:5,strokeWidth:1,strokeColors:"#111"},xaxis:{crosshairs:{width:1}}}}},{key:"rangeBar",value:function(){return{chart:{animations:{animateGradually:!1}},stroke:{width:0,lineCap:"square"},plotOptions:{bar:{borderRadius:0,dataLabels:{position:"center"}}},dataLabels:{enabled:!1,formatter:function(t,e){e.ctx;var i=e.seriesIndex,a=e.dataPointIndex,s=e.w,r=function(){var t=s.globals.seriesRangeStart[i][a];return s.globals.seriesRangeEnd[i][a]-t};return s.globals.comboCharts?"rangeBar"===s.config.series[i].type||"rangeArea"===s.config.series[i].type?r():t:r()},background:{enabled:!1},style:{colors:["#fff"]}},markers:{size:10},tooltip:{shared:!1,followCursor:!0,custom:function(t){return t.w.config.plotOptions&&t.w.config.plotOptions.bar&&t.w.config.plotOptions.bar.horizontal?function(t){var i=M(e(e({},t),{},{isTimeline:!0})),a=i.color,s=i.seriesName,r=i.ylabel,o=i.startVal,n=i.endVal;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t):function(t){var i=M(t),a=i.color,s=i.seriesName,r=i.ylabel,o=i.start,n=i.end;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t)}},xaxis:{tickPlacement:"between",tooltip:{enabled:!1},crosshairs:{stroke:{width:0}}}}}},{key:"dumbbell",value:function(t){var e,i;return null!==(e=t.plotOptions.bar)&&void 0!==e&&e.barHeight||(t.plotOptions.bar.barHeight=2),null!==(i=t.plotOptions.bar)&&void 0!==i&&i.columnWidth||(t.plotOptions.bar.columnWidth=2),t}},{key:"area",value:function(){return{stroke:{width:4,fill:{type:"solid",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}}},fill:{type:"gradient",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}},markers:{size:0,hover:{sizeOffset:6}},tooltip:{followCursor:!1}}}},{key:"rangeArea",value:function(){return{stroke:{curve:"straight",width:0},fill:{type:"solid",opacity:.6},markers:{size:0},states:{hover:{filter:{type:"none"}},active:{filter:{type:"none"}}},tooltip:{intersect:!1,shared:!0,followCursor:!0,custom:function(t){return function(t){var i=M(t),a=i.color,s=i.seriesName,r=i.ylabel,o=i.start,n=i.end;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t)}}}}},{key:"brush",value:function(t){return x.extend(t,{chart:{toolbar:{autoSelected:"selection",show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1},stroke:{width:1},tooltip:{enabled:!1},xaxis:{tooltip:{enabled:!1}}})}},{key:"stacked100",value:function(t){t.dataLabels=t.dataLabels||{},t.dataLabels.formatter=t.dataLabels.formatter||void 0;var e=t.dataLabels.formatter;return t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})),"bar"===t.chart.type&&(t.dataLabels.formatter=e||function(t){return"number"==typeof t&&t?t.toFixed(0)+"%":t}),t}},{key:"stackedBars",value:function(){var t=this.bar();return e(e({},t),{},{plotOptions:e(e({},t.plotOptions),{},{bar:e(e({},t.plotOptions.bar),{},{borderRadiusApplication:"end",borderRadiusWhenStacked:"last"})})})}},{key:"convertCatToNumeric",value:function(t){return t.xaxis.convertedCatToNumeric=!0,t}},{key:"convertCatToNumericXaxis",value:function(t,e,i){t.xaxis.type="numeric",t.xaxis.labels=t.xaxis.labels||{},t.xaxis.labels.formatter=t.xaxis.labels.formatter||function(t){return x.isNumber(t)?Math.floor(t):t};var a=t.xaxis.labels.formatter,s=t.xaxis.categories&&t.xaxis.categories.length?t.xaxis.categories:t.labels;return i&&i.length&&(s=i.map((function(t){return Array.isArray(t)?t:String(t)}))),s&&s.length&&(t.xaxis.labels.formatter=function(t){return x.isNumber(t)?a(s[Math.floor(t)-1]):a(t)}),t.xaxis.categories=[],t.labels=[],t.xaxis.tickAmount=t.xaxis.tickAmount||"dataPoints",t}},{key:"bubble",value:function(){return{dataLabels:{style:{colors:["#fff"]}},tooltip:{shared:!1,intersect:!0},xaxis:{crosshairs:{width:0}},fill:{type:"solid",gradient:{shade:"light",inverse:!0,shadeIntensity:.55,opacityFrom:.4,opacityTo:.8}}}}},{key:"scatter",value:function(){return{dataLabels:{enabled:!1},tooltip:{shared:!1,intersect:!0},markers:{size:6,strokeWidth:1,hover:{sizeOffset:2}}}}},{key:"heatmap",value:function(){return{chart:{stacked:!1},fill:{opacity:1},dataLabels:{style:{colors:["#fff"]}},stroke:{colors:["#fff"]},tooltip:{followCursor:!0,marker:{show:!1},x:{show:!1}},legend:{position:"top",markers:{shape:"square",size:10,offsetY:2}},grid:{padding:{right:20}}}}},{key:"treemap",value:function(){return{chart:{zoom:{enabled:!1}},dataLabels:{style:{fontSize:14,fontWeight:600,colors:["#fff"]}},stroke:{show:!0,width:2,colors:["#fff"]},legend:{show:!1},fill:{gradient:{stops:[0,100]}},tooltip:{followCursor:!0,x:{show:!1}},grid:{padding:{left:0,right:0}},xaxis:{crosshairs:{show:!1},tooltip:{enabled:!1}}}}},{key:"pie",value:function(){return{chart:{toolbar:{show:!1}},plotOptions:{pie:{donut:{labels:{show:!1}}}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",stops:[0,100]}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"donut",value:function(){return{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",shadeIntensity:.35,stops:[80,100],opacityFrom:1,opacityTo:1}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"polarArea",value:function(){return this.opts.yaxis[0].tickAmount=this.opts.yaxis[0].tickAmount?this.opts.yaxis[0].tickAmount:6,{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},enabled:!1},stroke:{show:!0,width:2},fill:{opacity:.7},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"radar",value:function(){return this.opts.yaxis[0].labels.offsetY=this.opts.yaxis[0].labels.offsetY?this.opts.yaxis[0].labels.offsetY:6,{dataLabels:{enabled:!1,style:{fontSize:"11px"}},stroke:{width:2},markers:{size:3,strokeWidth:1,strokeOpacity:1},fill:{opacity:.2},tooltip:{shared:!1,intersect:!0,followCursor:!0},grid:{show:!1},xaxis:{labels:{formatter:function(t){return t},style:{colors:["#a8a8a8"],fontSize:"11px"}},tooltip:{enabled:!1},crosshairs:{show:!1}}}}},{key:"radialBar",value:function(){return{chart:{animations:{dynamicAnimation:{enabled:!0,speed:800}},toolbar:{show:!1}},fill:{gradient:{shade:"dark",shadeIntensity:.4,inverseColors:!1,type:"diagonal2",opacityFrom:1,opacityTo:1,stops:[70,98,100]}},legend:{show:!1,position:"right"},tooltip:{enabled:!1,fillSeriesColor:!0}}}},{key:"_getBoxTooltip",value:function(t,e,i,a,s){var r=t.globals.seriesCandleO[e][i],o=t.globals.seriesCandleH[e][i],n=t.globals.seriesCandleM[e][i],l=t.globals.seriesCandleL[e][i],h=t.globals.seriesCandleC[e][i];return t.config.series[e].type&&t.config.series[e].type!==s?'
\n '.concat(t.config.series[e].name?t.config.series[e].name:"series-"+(e+1),": ").concat(t.globals.series[e][i],"\n
"):'
')+"
".concat(a[0],': ')+r+"
"+"
".concat(a[1],': ')+o+"
"+(n?"
".concat(a[2],': ')+n+"
":"")+"
".concat(a[3],': ')+l+"
"+"
".concat(a[4],': ')+h+"
"}}]),t}(),E=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"init",value:function(t){var e=t.responsiveOverride,a=this.opts,s=new L,r=new z(a);this.chartType=a.chart.type,a=this.extendYAxis(a),a=this.extendAnnotations(a);var o=s.init(),n={};if(a&&"object"===i(a)){var l,h,c,d,g,u,p={};p=-1!==["line","area","bar","candlestick","boxPlot","rangeBar","rangeArea","bubble","scatter","heatmap","treemap","pie","polarArea","donut","radar","radialBar"].indexOf(a.chart.type)?r[a.chart.type]():r.line(),a.chart.stacked&&"bar"===a.chart.type&&(p=r.stackedBars()),null!==(l=a.chart.brush)&&void 0!==l&&l.enabled&&(p=r.brush(p)),a.chart.stacked&&"100%"===a.chart.stackType&&(a=r.stacked100(a)),null!==(h=a.plotOptions)&&void 0!==h&&null!==(c=h.bar)&&void 0!==c&&c.isDumbbell&&(a=r.dumbbell(a)),this.checkForDarkTheme(window.Apex),this.checkForDarkTheme(a),a.xaxis=a.xaxis||window.Apex.xaxis||{},e||(a.xaxis.convertedCatToNumeric=!1),(null!==(d=(a=this.checkForCatToNumericXAxis(this.chartType,p,a)).chart.sparkline)&&void 0!==d&&d.enabled||null!==(g=window.Apex.chart)&&void 0!==g&&null!==(u=g.sparkline)&&void 0!==u&&u.enabled)&&(p=r.sparkline(p)),n=x.extend(o,p)}var f=x.extend(n,window.Apex);return o=x.extend(f,a),o=this.handleUserInputErrors(o)}},{key:"checkForCatToNumericXAxis",value:function(t,e,i){var a,s,r=new z(i),o=("bar"===t||"boxPlot"===t)&&(null===(a=i.plotOptions)||void 0===a||null===(s=a.bar)||void 0===s?void 0:s.horizontal),n="pie"===t||"polarArea"===t||"donut"===t||"radar"===t||"radialBar"===t||"heatmap"===t,l="datetime"!==i.xaxis.type&&"numeric"!==i.xaxis.type,h=i.xaxis.tickPlacement?i.xaxis.tickPlacement:e.xaxis&&e.xaxis.tickPlacement;return o||n||!l||"between"===h||(i=r.convertCatToNumeric(i)),i}},{key:"extendYAxis",value:function(t,e){var i=new L;(void 0===t.yaxis||!t.yaxis||Array.isArray(t.yaxis)&&0===t.yaxis.length)&&(t.yaxis={}),t.yaxis.constructor!==Array&&window.Apex.yaxis&&window.Apex.yaxis.constructor!==Array&&(t.yaxis=x.extend(t.yaxis,window.Apex.yaxis)),t.yaxis.constructor!==Array?t.yaxis=[x.extend(i.yAxis,t.yaxis)]:t.yaxis=x.extendArray(t.yaxis,i.yAxis);var a=!1;t.yaxis.forEach((function(t){t.logarithmic&&(a=!0)}));var s=t.series;return e&&!s&&(s=e.config.series),a&&s.length!==t.yaxis.length&&s.length&&(t.yaxis=s.map((function(e,a){if(e.name||(s[a].name="series-".concat(a+1)),t.yaxis[a])return t.yaxis[a].seriesName=s[a].name,t.yaxis[a];var r=x.extend(i.yAxis,t.yaxis[0]);return r.show=!1,r}))),a&&s.length>1&&s.length!==t.yaxis.length&&console.warn("A multi-series logarithmic chart should have equal number of series and y-axes. Please make sure to equalize both."),t}},{key:"extendAnnotations",value:function(t){return void 0===t.annotations&&(t.annotations={},t.annotations.yaxis=[],t.annotations.xaxis=[],t.annotations.points=[]),t=this.extendYAxisAnnotations(t),t=this.extendXAxisAnnotations(t),t=this.extendPointAnnotations(t)}},{key:"extendYAxisAnnotations",value:function(t){var e=new L;return t.annotations.yaxis=x.extendArray(void 0!==t.annotations.yaxis?t.annotations.yaxis:[],e.yAxisAnnotation),t}},{key:"extendXAxisAnnotations",value:function(t){var e=new L;return t.annotations.xaxis=x.extendArray(void 0!==t.annotations.xaxis?t.annotations.xaxis:[],e.xAxisAnnotation),t}},{key:"extendPointAnnotations",value:function(t){var e=new L;return t.annotations.points=x.extendArray(void 0!==t.annotations.points?t.annotations.points:[],e.pointAnnotation),t}},{key:"checkForDarkTheme",value:function(t){t.theme&&"dark"===t.theme.mode&&(t.tooltip||(t.tooltip={}),"light"!==t.tooltip.theme&&(t.tooltip.theme="dark"),t.chart.foreColor||(t.chart.foreColor="#f6f7f8"),t.chart.background||(t.chart.background="#424242"),t.theme.palette||(t.theme.palette="palette4"))}},{key:"handleUserInputErrors",value:function(t){var e=t;if(e.tooltip.shared&&e.tooltip.intersect)throw new Error("tooltip.shared cannot be enabled when tooltip.intersect is true. Turn off any other option by setting it to false.");if("bar"===e.chart.type&&e.plotOptions.bar.horizontal){if(e.yaxis.length>1)throw new Error("Multiple Y Axis for bars are not supported. Switch to column chart by setting plotOptions.bar.horizontal=false");e.yaxis[0].reversed&&(e.yaxis[0].opposite=!0),e.xaxis.tooltip.enabled=!1,e.yaxis[0].tooltip.enabled=!1,e.chart.zoom.enabled=!1}return"bar"!==e.chart.type&&"rangeBar"!==e.chart.type||e.tooltip.shared&&"barWidth"===e.xaxis.crosshairs.width&&e.series.length>1&&(e.xaxis.crosshairs.width="tickWidth"),"candlestick"!==e.chart.type&&"boxPlot"!==e.chart.type||e.yaxis[0].reversed&&(console.warn("Reversed y-axis in ".concat(e.chart.type," chart is not supported.")),e.yaxis[0].reversed=!1),e}}]),t}(),Y=function(){function t(){a(this,t)}return r(t,[{key:"initGlobalVars",value:function(t){t.series=[],t.seriesCandleO=[],t.seriesCandleH=[],t.seriesCandleM=[],t.seriesCandleL=[],t.seriesCandleC=[],t.seriesRangeStart=[],t.seriesRangeEnd=[],t.seriesRange=[],t.seriesPercent=[],t.seriesGoals=[],t.seriesX=[],t.seriesZ=[],t.seriesNames=[],t.seriesTotals=[],t.seriesLog=[],t.seriesColors=[],t.stackedSeriesTotals=[],t.seriesXvalues=[],t.seriesYvalues=[],t.labels=[],t.hasXaxisGroups=!1,t.groups=[],t.hasSeriesGroups=!1,t.seriesGroups=[],t.categoryLabels=[],t.timescaleLabels=[],t.noLabelsProvided=!1,t.resizeTimer=null,t.selectionResizeTimer=null,t.delayedElements=[],t.pointsArray=[],t.dataLabelsRects=[],t.isXNumeric=!1,t.skipLastTimelinelabel=!1,t.skipFirstTimelinelabel=!1,t.isDataXYZ=!1,t.isMultiLineX=!1,t.isMultipleYAxis=!1,t.maxY=-Number.MAX_VALUE,t.minY=Number.MIN_VALUE,t.minYArr=[],t.maxYArr=[],t.maxX=-Number.MAX_VALUE,t.minX=Number.MAX_VALUE,t.initialMaxX=-Number.MAX_VALUE,t.initialMinX=Number.MAX_VALUE,t.maxDate=0,t.minDate=Number.MAX_VALUE,t.minZ=Number.MAX_VALUE,t.maxZ=-Number.MAX_VALUE,t.minXDiff=Number.MAX_VALUE,t.yAxisScale=[],t.xAxisScale=null,t.xAxisTicksPositions=[],t.yLabelsCoords=[],t.yTitleCoords=[],t.barPadForNumericAxis=0,t.padHorizontal=0,t.xRange=0,t.yRange=[],t.zRange=0,t.dataPoints=0,t.xTickAmount=0}},{key:"globalVars",value:function(t){return{chartID:null,cuid:null,events:{beforeMount:[],mounted:[],updated:[],clicked:[],selection:[],dataPointSelection:[],zoomed:[],scrolled:[]},colors:[],clientX:null,clientY:null,fill:{colors:[]},stroke:{colors:[]},dataLabels:{style:{colors:[]}},radarPolygons:{fill:{colors:[]}},markers:{colors:[],size:t.markers.size,largestSize:0},animationEnded:!1,isTouchDevice:"ontouchstart"in window||navigator.msMaxTouchPoints,isDirty:!1,isExecCalled:!1,initialConfig:null,initialSeries:[],lastXAxis:[],lastYAxis:[],columnSeries:null,labels:[],timescaleLabels:[],noLabelsProvided:!1,allSeriesCollapsed:!1,collapsedSeries:[],collapsedSeriesIndices:[],ancillaryCollapsedSeries:[],ancillaryCollapsedSeriesIndices:[],risingSeries:[],dataFormatXNumeric:!1,capturedSeriesIndex:-1,capturedDataPointIndex:-1,selectedDataPoints:[],goldenPadding:35,invalidLogScale:!1,ignoreYAxisIndexes:[],yAxisSameScaleIndices:[],maxValsInArrayIndex:0,radialSize:0,selection:void 0,zoomEnabled:"zoom"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.zoom&&t.chart.zoom.enabled,panEnabled:"pan"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.pan,selectionEnabled:"selection"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.selection,yaxis:null,mousedown:!1,lastClientPosition:{},visibleXRange:void 0,yValueDecimal:0,total:0,SVGNS:"http://www.w3.org/2000/svg",svgWidth:0,svgHeight:0,noData:!1,locale:{},dom:{},memory:{methodsToExec:[]},shouldAnimate:!0,skipLastTimelinelabel:!1,skipFirstTimelinelabel:!1,delayedElements:[],axisCharts:!0,isDataXYZ:!1,resized:!1,resizeTimer:null,comboCharts:!1,dataChanged:!1,previousPaths:[],allSeriesHasEqualX:!0,pointsArray:[],dataLabelsRects:[],lastDrawnDataLabelsIndexes:[],hasNullValues:!1,easing:null,zoomed:!1,gridWidth:0,gridHeight:0,rotateXLabels:!1,defaultLabels:!1,xLabelFormatter:void 0,yLabelFormatters:[],xaxisTooltipFormatter:void 0,ttKeyFormatter:void 0,ttVal:void 0,ttZFormatter:void 0,LINE_HEIGHT_RATIO:1.618,xAxisLabelsHeight:0,xAxisGroupLabelsHeight:0,xAxisLabelsWidth:0,yAxisLabelsWidth:0,scaleX:1,scaleY:1,translateX:0,translateY:0,translateYAxisX:[],yAxisWidths:[],translateXAxisY:0,translateXAxisX:0,tooltip:null}}},{key:"init",value:function(t){var e=this.globalVars(t);return this.initGlobalVars(e),e.initialConfig=x.extend({},t),e.initialSeries=x.clone(t.series),e.lastXAxis=x.clone(e.initialConfig.xaxis),e.lastYAxis=x.clone(e.initialConfig.yaxis),e}}]),t}(),F=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"init",value:function(){var t=new E(this.opts).init({responsiveOverride:!1});return{config:t,globals:(new Y).init(t)}}}]),t}(),R=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.opts=null,this.seriesIndex=0}return r(t,[{key:"clippedImgArea",value:function(t){var e=this.w,i=e.config,a=parseInt(e.globals.gridWidth,10),s=parseInt(e.globals.gridHeight,10),r=a>s?a:s,o=t.image,n=0,l=0;void 0===t.width&&void 0===t.height?void 0!==i.fill.image.width&&void 0!==i.fill.image.height?(n=i.fill.image.width+1,l=i.fill.image.height):(n=r+1,l=r):(n=t.width,l=t.height);var h=document.createElementNS(e.globals.SVGNS,"pattern");m.setAttrs(h,{id:t.patternID,patternUnits:t.patternUnits?t.patternUnits:"userSpaceOnUse",width:n+"px",height:l+"px"});var c=document.createElementNS(e.globals.SVGNS,"image");h.appendChild(c),c.setAttributeNS(window.SVG.xlink,"href",o),m.setAttrs(c,{x:0,y:0,preserveAspectRatio:"none",width:n+"px",height:l+"px"}),c.style.opacity=t.opacity,e.globals.dom.elDefs.node.appendChild(h)}},{key:"getSeriesIndex",value:function(t){var e=this.w;return("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||"heatmap"===e.config.chart.type||"treemap"===e.config.chart.type?this.seriesIndex=t.seriesNumber:this.seriesIndex=t.seriesNumber%e.globals.series.length,this.seriesIndex}},{key:"fillPath",value:function(t){var e=this.w;this.opts=t;var i,a,s,r=this.w.config;this.seriesIndex=this.getSeriesIndex(t);var o=this.getFillColors()[this.seriesIndex];void 0!==e.globals.seriesColors[this.seriesIndex]&&(o=e.globals.seriesColors[this.seriesIndex]),"function"==typeof o&&(o=o({seriesIndex:this.seriesIndex,dataPointIndex:t.dataPointIndex,value:t.value,w:e}));var n=t.fillType?t.fillType:this.getFillType(this.seriesIndex),l=Array.isArray(r.fill.opacity)?r.fill.opacity[this.seriesIndex]:r.fill.opacity;t.color&&(o=t.color);var h=o;if(-1===o.indexOf("rgb")?o.length<9&&(h=x.hexToRgba(o,l)):o.indexOf("rgba")>-1&&(l=x.getOpacityFromRGBA(o)),t.opacity&&(l=t.opacity),"pattern"===n&&(a=this.handlePatternFill({fillConfig:t.fillConfig,patternFill:a,fillColor:o,fillOpacity:l,defaultColor:h})),"gradient"===n&&(s=this.handleGradientFill({fillConfig:t.fillConfig,fillColor:o,fillOpacity:l,i:this.seriesIndex})),"image"===n){var c=r.fill.image.src,d=t.patternID?t.patternID:"";this.clippedImgArea({opacity:l,image:Array.isArray(c)?t.seriesNumber-1&&(u=x.getOpacityFromRGBA(g));var p=void 0===o.gradient.opacityTo?a:Array.isArray(o.gradient.opacityTo)?o.gradient.opacityTo[r]:o.gradient.opacityTo;if(void 0===o.gradient.gradientToColors||0===o.gradient.gradientToColors.length)n="dark"===o.gradient.shade?c.shadeColor(-1*parseFloat(o.gradient.shadeIntensity),i.indexOf("rgb")>-1?x.rgb2hex(i):i):c.shadeColor(parseFloat(o.gradient.shadeIntensity),i.indexOf("rgb")>-1?x.rgb2hex(i):i);else if(o.gradient.gradientToColors[l.seriesNumber]){var f=o.gradient.gradientToColors[l.seriesNumber];n=f,f.indexOf("rgba")>-1&&(p=x.getOpacityFromRGBA(f))}else n=i;if(o.gradient.gradientFrom&&(g=o.gradient.gradientFrom),o.gradient.gradientTo&&(n=o.gradient.gradientTo),o.gradient.inverseColors){var b=g;g=n,n=b}return g.indexOf("rgb")>-1&&(g=x.rgb2hex(g)),n.indexOf("rgb")>-1&&(n=x.rgb2hex(n)),h.drawGradient(d,g,n,u,p,l.size,o.gradient.stops,o.gradient.colorStops,r)}}]),t}(),D=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"setGlobalMarkerSize",value:function(){var t=this.w;if(t.globals.markers.size=Array.isArray(t.config.markers.size)?t.config.markers.size:[t.config.markers.size],t.globals.markers.size.length>0){if(t.globals.markers.size.length4&&void 0!==arguments[4]&&arguments[4],o=this.w,n=e,l=t,h=null,c=new m(this.ctx),d=o.config.markers.discrete&&o.config.markers.discrete.length;if((o.globals.markers.size[e]>0||r||d)&&(h=c.group({class:r||d?"":"apexcharts-series-markers"})).attr("clip-path","url(#gridRectMarkerMask".concat(o.globals.cuid,")")),Array.isArray(l.x))for(var g=0;g0:o.config.markers.size>0)||r||d){x.isNumber(l.y[g])?p+=" w".concat(x.randomId()):p="apexcharts-nullpoint";var f=this.getMarkerConfig({cssClass:p,seriesIndex:e,dataPointIndex:u});o.config.series[n].data[u]&&(o.config.series[n].data[u].fillColor&&(f.pointFillColor=o.config.series[n].data[u].fillColor),o.config.series[n].data[u].strokeColor&&(f.pointStrokeColor=o.config.series[n].data[u].strokeColor)),a&&(f.pSize=a),(l.x[g]<0||l.x[g]>o.globals.gridWidth||l.y[g]<0||l.y[g]>o.globals.gridHeight)&&(f.pSize=0),(s=c.drawMarker(l.x[g],l.y[g],f)).attr("rel",u),s.attr("j",u),s.attr("index",e),s.node.setAttribute("default-marker-size",f.pSize),new v(this.ctx).setSelectionFilter(s,e,u),this.addEvents(s),h&&h.add(s)}else void 0===o.globals.pointsArray[e]&&(o.globals.pointsArray[e]=[]),o.globals.pointsArray[e].push([l.x[g],l.y[g]])}return h}},{key:"getMarkerConfig",value:function(t){var e=t.cssClass,i=t.seriesIndex,a=t.dataPointIndex,s=void 0===a?null:a,r=t.finishRadius,o=void 0===r?null:r,n=this.w,l=this.getMarkerStyle(i),h=n.globals.markers.size[i],c=n.config.markers;return null!==s&&c.discrete.length&&c.discrete.map((function(t){t.seriesIndex===i&&t.dataPointIndex===s&&(l.pointStrokeColor=t.strokeColor,l.pointFillColor=t.fillColor,h=t.size,l.pointShape=t.shape)})),{pSize:null===o?h:o,pRadius:c.radius,width:Array.isArray(c.width)?c.width[i]:c.width,height:Array.isArray(c.height)?c.height[i]:c.height,pointStrokeWidth:Array.isArray(c.strokeWidth)?c.strokeWidth[i]:c.strokeWidth,pointStrokeColor:l.pointStrokeColor,pointFillColor:l.pointFillColor,shape:l.pointShape||(Array.isArray(c.shape)?c.shape[i]:c.shape),class:e,pointStrokeOpacity:Array.isArray(c.strokeOpacity)?c.strokeOpacity[i]:c.strokeOpacity,pointStrokeDashArray:Array.isArray(c.strokeDashArray)?c.strokeDashArray[i]:c.strokeDashArray,pointFillOpacity:Array.isArray(c.fillOpacity)?c.fillOpacity[i]:c.fillOpacity,seriesIndex:i}}},{key:"addEvents",value:function(t){var e=this.w,i=new m(this.ctx);t.node.addEventListener("mouseenter",i.pathMouseEnter.bind(this.ctx,t)),t.node.addEventListener("mouseleave",i.pathMouseLeave.bind(this.ctx,t)),t.node.addEventListener("mousedown",i.pathMouseDown.bind(this.ctx,t)),t.node.addEventListener("click",e.config.markers.onClick),t.node.addEventListener("dblclick",e.config.markers.onDblClick),t.node.addEventListener("touchstart",i.pathMouseDown.bind(this.ctx,t),{passive:!0})}},{key:"getMarkerStyle",value:function(t){var e=this.w,i=e.globals.markers.colors,a=e.config.markers.strokeColor||e.config.markers.strokeColors;return{pointStrokeColor:Array.isArray(a)?a[t]:a,pointFillColor:Array.isArray(i)?i[t]:i}}}]),t}(),H=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.initialAnim=this.w.config.chart.animations.enabled,this.dynamicAnim=this.initialAnim&&this.w.config.chart.animations.dynamicAnimation.enabled}return r(t,[{key:"draw",value:function(t,e,i){var a=this.w,s=new m(this.ctx),r=i.realIndex,o=i.pointsPos,n=i.zRatio,l=i.elParent,h=s.group({class:"apexcharts-series-markers apexcharts-series-".concat(a.config.chart.type)});if(h.attr("clip-path","url(#gridRectMarkerMask".concat(a.globals.cuid,")")),Array.isArray(o.x))for(var c=0;cf.maxBubbleRadius&&(p=f.maxBubbleRadius)}a.config.chart.animations.enabled||(u=p);var x=o.x[c],b=o.y[c];if(u=u||0,null!==b&&void 0!==a.globals.series[r][d]||(g=!1),g){var v=this.drawPoint(x,b,u,p,r,d,e);h.add(v)}l.add(h)}}},{key:"drawPoint",value:function(t,e,i,a,s,r,o){var n=this.w,l=s,h=new b(this.ctx),c=new v(this.ctx),d=new R(this.ctx),g=new D(this.ctx),u=new m(this.ctx),p=g.getMarkerConfig({cssClass:"apexcharts-marker",seriesIndex:l,dataPointIndex:r,finishRadius:"bubble"===n.config.chart.type||n.globals.comboCharts&&n.config.series[s]&&"bubble"===n.config.series[s].type?a:null});a=p.pSize;var f,x=d.fillPath({seriesNumber:s,dataPointIndex:r,color:p.pointFillColor,patternUnits:"objectBoundingBox",value:n.globals.series[s][o]});if("circle"===p.shape?f=u.drawCircle(i):"square"!==p.shape&&"rect"!==p.shape||(f=u.drawRect(0,0,p.width-p.pointStrokeWidth/2,p.height-p.pointStrokeWidth/2,p.pRadius)),n.config.series[l].data[r]&&n.config.series[l].data[r].fillColor&&(x=n.config.series[l].data[r].fillColor),f.attr({x:t-p.width/2-p.pointStrokeWidth/2,y:e-p.height/2-p.pointStrokeWidth/2,cx:t,cy:e,fill:x,"fill-opacity":p.pointFillOpacity,stroke:p.pointStrokeColor,r:a,"stroke-width":p.pointStrokeWidth,"stroke-dasharray":p.pointStrokeDashArray,"stroke-opacity":p.pointStrokeOpacity}),n.config.chart.dropShadow.enabled){var y=n.config.chart.dropShadow;c.dropShadow(f,y,s)}if(!this.initialAnim||n.globals.dataChanged||n.globals.resized)n.globals.animationEnded=!0;else{var w=n.config.chart.animations.speed;h.animateMarker(f,0,"circle"===p.shape?a:{width:p.width,height:p.height},w,n.globals.easing,(function(){window.setTimeout((function(){h.animationCompleted(f)}),100)}))}if(n.globals.dataChanged&&"circle"===p.shape)if(this.dynamicAnim){var k,A,S,C,L=n.config.chart.animations.dynamicAnimation.speed;null!=(C=n.globals.previousPaths[s]&&n.globals.previousPaths[s][o])&&(k=C.x,A=C.y,S=void 0!==C.r?C.r:a);for(var P=0;Pn.globals.gridHeight+d&&(e=n.globals.gridHeight+d/2),void 0===n.globals.dataLabelsRects[a]&&(n.globals.dataLabelsRects[a]=[]),n.globals.dataLabelsRects[a].push({x:t,y:e,width:c,height:d});var g=n.globals.dataLabelsRects[a].length-2,u=void 0!==n.globals.lastDrawnDataLabelsIndexes[a]?n.globals.lastDrawnDataLabelsIndexes[a][n.globals.lastDrawnDataLabelsIndexes[a].length-1]:0;if(void 0!==n.globals.dataLabelsRects[a][g]){var p=n.globals.dataLabelsRects[a][u];(t>p.x+p.width+2||e>p.y+p.height+2||t+ce.globals.gridWidth+f.textRects.width+10)&&(n="");var x=e.globals.dataLabels.style.colors[r];(("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||e.config.dataLabels.distributed)&&(x=e.globals.dataLabels.style.colors[o]),"function"==typeof x&&(x=x({series:e.globals.series,seriesIndex:r,dataPointIndex:o,w:e})),g&&(x=g);var b=d.offsetX,y=d.offsetY;if("bar"!==e.config.chart.type&&"rangeBar"!==e.config.chart.type||(b=0,y=0),f.drawnextLabel){var w=i.drawText({width:100,height:parseInt(d.style.fontSize,10),x:a+b,y:s+y,foreColor:x,textAnchor:l||d.textAnchor,text:n,fontSize:h||d.style.fontSize,fontFamily:d.style.fontFamily,fontWeight:d.style.fontWeight||"normal"});if(w.attr({class:"apexcharts-datalabel",cx:a,cy:s}),d.dropShadow.enabled){var k=d.dropShadow;new v(this.ctx).dropShadow(w,k)}c.add(w),void 0===e.globals.lastDrawnDataLabelsIndexes[r]&&(e.globals.lastDrawnDataLabelsIndexes[r]=[]),e.globals.lastDrawnDataLabelsIndexes[r].push(o)}}}},{key:"addBackgroundToDataLabel",value:function(t,e){var i=this.w,a=i.config.dataLabels.background,s=a.padding,r=a.padding/2,o=e.width,n=e.height,l=new m(this.ctx).drawRect(e.x-s,e.y-r/2,o+2*s,n+r,a.borderRadius,"transparent"===i.config.chart.background?"#fff":i.config.chart.background,a.opacity,a.borderWidth,a.borderColor);a.dropShadow.enabled&&new v(this.ctx).dropShadow(l,a.dropShadow);return l}},{key:"dataLabelsBackground",value:function(){var t=this.w;if("bubble"!==t.config.chart.type)for(var e=t.globals.dom.baseEl.querySelectorAll(".apexcharts-datalabels text"),i=0;i0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w,s=x.clone(a.globals.initialSeries);a.globals.previousPaths=[],i?(a.globals.collapsedSeries=[],a.globals.ancillaryCollapsedSeries=[],a.globals.collapsedSeriesIndices=[],a.globals.ancillaryCollapsedSeriesIndices=[]):s=this.emptyCollapsedSeries(s),a.config.series=s,t&&(e&&(a.globals.zoomed=!1,this.ctx.updateHelpers.revertDefaultAxisMinMax()),this.ctx.updateHelpers._updateSeries(s,a.config.chart.animations.dynamicAnimation.enabled))}},{key:"emptyCollapsedSeries",value:function(t){for(var e=this.w,i=0;i-1&&(t[i].data=[]);return t}},{key:"toggleSeriesOnHover",value:function(t,e){var i=this.w;e||(e=t.target);var a=i.globals.dom.baseEl.querySelectorAll(".apexcharts-series, .apexcharts-datalabels");if("mousemove"===t.type){var s=parseInt(e.getAttribute("rel"),10)-1,r=null,o=null;i.globals.axisCharts||"radialBar"===i.config.chart.type?i.globals.axisCharts?(r=i.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(s,"']")),o=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels[data\\:realIndex='".concat(s,"']"))):r=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(s+1,"']")):r=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(s+1,"'] path"));for(var n=0;n=t.from&&a<=t.to&&s[e].classList.remove(i.legendInactiveClass)}}(a.config.plotOptions.heatmap.colorScale.ranges[o])}else"mouseout"===t.type&&r("remove")}},{key:"getActiveConfigSeriesIndex",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"asc",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],i=this.w,a=0;if(i.config.series.length>1)for(var s=i.config.series.map((function(t,a){return t.data&&t.data.length>0&&-1===i.globals.collapsedSeriesIndices.indexOf(a)&&(!i.globals.comboCharts||0===e.length||e.length&&e.indexOf(i.config.series[a].type)>-1)?a:-1})),r="asc"===t?0:s.length-1;"asc"===t?r=0;"asc"===t?r++:r--)if(-1!==s[r]){a=s[r];break}return a}},{key:"getBarSeriesIndices",value:function(){return this.w.globals.comboCharts?this.w.config.series.map((function(t,e){return"bar"===t.type||"column"===t.type?e:-1})).filter((function(t){return-1!==t})):this.w.config.series.map((function(t,e){return e}))}},{key:"getPreviousPaths",value:function(){var t=this.w;function e(e,i,a){for(var s=e[i].childNodes,r={type:a,paths:[],realIndex:e[i].getAttribute("data:realIndex")},o=0;o0)for(var a=function(e){for(var i=t.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(t.config.chart.type," .apexcharts-series[data\\:realIndex='").concat(e,"'] rect")),a=[],s=function(t){var e=function(e){return i[t].getAttribute(e)},s={x:parseFloat(e("x")),y:parseFloat(e("y")),width:parseFloat(e("width")),height:parseFloat(e("height"))};a.push({rect:s,color:i[t].getAttribute("color")})},r=0;r0)for(var a=0;a0?t:[]}));return t}}]),t}(),W=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.twoDSeries=[],this.threeDSeries=[],this.twoDSeriesX=[],this.seriesGoals=[],this.coreUtils=new y(this.ctx)}return r(t,[{key:"isMultiFormat",value:function(){return this.isFormatXY()||this.isFormat2DArray()}},{key:"isFormatXY",value:function(){var t=this.w.config.series.slice(),e=new N(this.ctx);if(this.activeSeriesIndex=e.getActiveConfigSeriesIndex(),void 0!==t[this.activeSeriesIndex].data&&t[this.activeSeriesIndex].data.length>0&&null!==t[this.activeSeriesIndex].data[0]&&void 0!==t[this.activeSeriesIndex].data[0].x&&null!==t[this.activeSeriesIndex].data[0])return!0}},{key:"isFormat2DArray",value:function(){var t=this.w.config.series.slice(),e=new N(this.ctx);if(this.activeSeriesIndex=e.getActiveConfigSeriesIndex(),void 0!==t[this.activeSeriesIndex].data&&t[this.activeSeriesIndex].data.length>0&&void 0!==t[this.activeSeriesIndex].data[0]&&null!==t[this.activeSeriesIndex].data[0]&&t[this.activeSeriesIndex].data[0].constructor===Array)return!0}},{key:"handleFormat2DArray",value:function(t,e){for(var i=this.w.config,a=this.w.globals,s="boxPlot"===i.chart.type||"boxPlot"===i.series[e].type,r=0;r=5?this.twoDSeries.push(x.parseNumber(t[e].data[r][4])):this.twoDSeries.push(x.parseNumber(t[e].data[r][1])),a.dataFormatXNumeric=!0),"datetime"===i.xaxis.type){var o=new Date(t[e].data[r][0]);o=new Date(o).getTime(),this.twoDSeriesX.push(o)}else this.twoDSeriesX.push(t[e].data[r][0]);for(var n=0;n-1&&(r=this.activeSeriesIndex);for(var o=0;o1&&void 0!==arguments[1]?arguments[1]:this.ctx,s=this.w.config,r=this.w.globals,o=new I(a),n=s.labels.length>0?s.labels.slice():s.xaxis.categories.slice();if(r.isRangeBar="rangeBar"===s.chart.type&&r.isBarHorizontal,r.hasXaxisGroups="category"===s.xaxis.type&&s.xaxis.group.groups.length>0,r.hasXaxisGroups&&(r.groups=s.xaxis.group.groups),r.hasSeriesGroups=null===(e=t[0])||void 0===e?void 0:e.group,r.hasSeriesGroups){var l=[],h=u(new Set(t.map((function(t){return t.group}))));t.forEach((function(t,e){var i=h.indexOf(t.group);l[i]||(l[i]=[]),l[i].push(t.name)})),r.seriesGroups=l}for(var c=function(){for(var t=0;t0&&(this.twoDSeriesX=n,r.seriesX.push(this.twoDSeriesX))),r.labels.push(this.twoDSeriesX);var g=t[d].data.map((function(t){return x.parseNumber(t)}));r.series.push(g)}r.seriesZ.push(this.threeDSeries),void 0!==t[d].name?r.seriesNames.push(t[d].name):r.seriesNames.push("series-"+parseInt(d+1,10)),void 0!==t[d].color?r.seriesColors.push(t[d].color):r.seriesColors.push(void 0)}return this.w}},{key:"parseDataNonAxisCharts",value:function(t){var e=this.w.globals,i=this.w.config;e.series=t.slice(),e.seriesNames=i.labels.slice();for(var a=0;a0)i.labels=e.xaxis.categories;else if(e.labels.length>0)i.labels=e.labels.slice();else if(this.fallbackToCategory){if(i.labels=i.labels[0],i.seriesRange.length&&(i.seriesRange.map((function(t){t.forEach((function(t){i.labels.indexOf(t.x)<0&&t.x&&i.labels.push(t.x)}))})),i.labels=i.labels.filter((function(t,e,i){return i.indexOf(t)===e}))),e.xaxis.convertedCatToNumeric)new z(e).convertCatToNumericXaxis(e,this.ctx,i.seriesX[0]),this._generateExternalLabels(t)}else this._generateExternalLabels(t)}},{key:"_generateExternalLabels",value:function(t){var e=this.w.globals,i=this.w.config,a=[];if(e.axisCharts){if(e.series.length>0)if(this.isFormatXY())for(var s=i.series.map((function(t,e){return t.data.filter((function(t,e,i){return i.findIndex((function(e){return e.x===t.x}))===e}))})),r=s.reduce((function(t,e,i,a){return a[t].length>e.length?t:i}),0),o=0;o4&&void 0!==arguments[4]?arguments[4]:[],r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"12px",o=!(arguments.length>6&&void 0!==arguments[6])||arguments[6],n=this.w,l=void 0===t[a]?"":t[a],h=l,c=n.globals.xLabelFormatter,d=n.config.xaxis.labels.formatter,g=!1,u=new T(this.ctx),p=l;o&&(h=u.xLabelFormat(c,l,p,{i:a,dateFormatter:new I(this.ctx).formatDate,w:n}),void 0!==d&&(h=d(l,t[a],{i:a,dateFormatter:new I(this.ctx).formatDate,w:n})));var f,x;e.length>0?(f=e[a].unit,x=null,e.forEach((function(t){"month"===t.unit?x="year":"day"===t.unit?x="month":"hour"===t.unit?x="day":"minute"===t.unit&&(x="hour")})),g=x===f,i=e[a].position,h=e[a].value):"datetime"===n.config.xaxis.type&&void 0===d&&(h=""),void 0===h&&(h=""),h=Array.isArray(h)?h:h.toString();var b=new m(this.ctx),v={};v=n.globals.rotateXLabels&&o?b.getTextRects(h,parseInt(r,10),null,"rotate(".concat(n.config.xaxis.labels.rotate," 0 0)"),!1):b.getTextRects(h,parseInt(r,10));var y=!n.config.xaxis.labels.showDuplicates&&this.ctx.timeScale;return!Array.isArray(h)&&(0===h.indexOf("NaN")||0===h.toLowerCase().indexOf("invalid")||h.toLowerCase().indexOf("infinity")>=0||s.indexOf(h)>=0&&y)&&(h=""),{x:i,text:h,textRect:v,isBold:g}}},{key:"checkLabelBasedOnTickamount",value:function(t,e,i){var a=this.w,s=a.config.xaxis.tickAmount;return"dataPoints"===s&&(s=Math.round(a.globals.gridWidth/120)),s>i||t%Math.round(i/(s+1))==0||(e.text=""),e}},{key:"checkForOverflowingLabels",value:function(t,e,i,a,s){var r=this.w;if(0===t&&r.globals.skipFirstTimelinelabel&&(e.text=""),t===i-1&&r.globals.skipLastTimelinelabel&&(e.text=""),r.config.xaxis.labels.hideOverlappingLabels&&a.length>0){var o=s[s.length-1];e.x0){!0===n.config.yaxis[s].opposite&&(t+=a.width);for(var c=e;c>=0;c--){var d=h+e/10+n.config.yaxis[s].labels.offsetY-1;n.globals.isBarHorizontal&&(d=r*c),"heatmap"===n.config.chart.type&&(d+=r/2);var g=l.drawLine(t+i.offsetX-a.width+a.offsetX,d+a.offsetY,t+i.offsetX+a.offsetX,d+a.offsetY,a.color);o.add(g),h+=r}}}}]),t}(),G=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"scaleSvgNode",value:function(t,e){var i=parseFloat(t.getAttributeNS(null,"width")),a=parseFloat(t.getAttributeNS(null,"height"));t.setAttributeNS(null,"width",i*e),t.setAttributeNS(null,"height",a*e),t.setAttributeNS(null,"viewBox","0 0 "+i+" "+a)}},{key:"fixSvgStringForIe11",value:function(t){if(!x.isIE11())return t.replace(/ /g," ");var e=0,i=t.replace(/xmlns="http:\/\/www.w3.org\/2000\/svg"/g,(function(t){return 2===++e?'xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:svgjs="http://svgjs.dev"':t}));return i=(i=i.replace(/xmlns:NS\d+=""/g,"")).replace(/NS\d+:(\w+:\w+=")/g,"$1")}},{key:"getSvgString",value:function(t){null==t&&(t=1);var e=this.w.globals.dom.Paper.svg();if(1!==t){var i=this.w.globals.dom.Paper.node.cloneNode(!0);this.scaleSvgNode(i,t),e=(new XMLSerializer).serializeToString(i)}return this.fixSvgStringForIe11(e)}},{key:"cleanup",value:function(){var t=this.w,e=t.globals.dom.baseEl.getElementsByClassName("apexcharts-xcrosshairs"),i=t.globals.dom.baseEl.getElementsByClassName("apexcharts-ycrosshairs"),a=t.globals.dom.baseEl.querySelectorAll(".apexcharts-zoom-rect, .apexcharts-selection-rect");Array.prototype.forEach.call(a,(function(t){t.setAttribute("width",0)})),e&&e[0]&&(e[0].setAttribute("x",-500),e[0].setAttribute("x1",-500),e[0].setAttribute("x2",-500)),i&&i[0]&&(i[0].setAttribute("y",-100),i[0].setAttribute("y1",-100),i[0].setAttribute("y2",-100))}},{key:"svgUrl",value:function(){this.cleanup();var t=this.getSvgString(),e=new Blob([t],{type:"image/svg+xml;charset=utf-8"});return URL.createObjectURL(e)}},{key:"dataURI",value:function(t){var e=this;return new Promise((function(i){var a=e.w,s=t?t.scale||t.width/a.globals.svgWidth:1;e.cleanup();var r=document.createElement("canvas");r.width=a.globals.svgWidth*s,r.height=parseInt(a.globals.dom.elWrap.style.height,10)*s;var o="transparent"===a.config.chart.background?"#fff":a.config.chart.background,n=r.getContext("2d");n.fillStyle=o,n.fillRect(0,0,r.width*s,r.height*s);var l=e.getSvgString(s);if(window.canvg&&x.isIE11()){var h=window.canvg.Canvg.fromString(n,l,{ignoreClear:!0,ignoreDimensions:!0});h.start();var c=r.msToBlob();h.stop(),i({blob:c})}else{var d="data:image/svg+xml,"+encodeURIComponent(l),g=new Image;g.crossOrigin="anonymous",g.onload=function(){if(n.drawImage(g,0,0),r.msToBlob){var t=r.msToBlob();i({blob:t})}else{var e=r.toDataURL("image/png");i({imgURI:e})}},g.src=d}}))}},{key:"exportToSVG",value:function(){this.triggerDownload(this.svgUrl(),this.w.config.chart.toolbar.export.svg.filename,".svg")}},{key:"exportToPng",value:function(){var t=this;this.dataURI().then((function(e){var i=e.imgURI,a=e.blob;a?navigator.msSaveOrOpenBlob(a,t.w.globals.chartID+".png"):t.triggerDownload(i,t.w.config.chart.toolbar.export.png.filename,".png")}))}},{key:"exportToCSV",value:function(t){var e=this,i=t.series,a=t.fileName,s=t.columnDelimiter,r=void 0===s?",":s,o=t.lineDelimiter,n=void 0===o?"\n":o,l=this.w;i||(i=l.config.series);var h=[],c=[],d="",g=l.globals.series.map((function(t,e){return-1===l.globals.collapsedSeriesIndices.indexOf(e)?t:[]})),p=Math.max.apply(Math,u(i.map((function(t){return t.data?t.data.length:0})))),f=new W(this.ctx),b=new B(this.ctx),v=function(t){var i="";if(l.globals.axisCharts){if("category"===l.config.xaxis.type||l.config.xaxis.convertedCatToNumeric)if(l.globals.isBarHorizontal){var a=l.globals.yLabelFormatters[0],s=new N(e.ctx).getActiveConfigSeriesIndex();i=a(l.globals.labels[t],{seriesIndex:s,dataPointIndex:t,w:l})}else i=b.getLabel(l.globals.labels,l.globals.timescaleLabels,0,t).text;"datetime"===l.config.xaxis.type&&(l.config.xaxis.categories.length?i=l.config.xaxis.categories[t]:l.config.labels.length&&(i=l.config.labels[t]))}else i=l.config.labels[t];return Array.isArray(i)&&(i=i.join(" ")),x.isNumber(i)?i:i.split(r).join("")},m=function(t,e){if(h.length&&0===e&&c.push(h.join(r)),t.data){t.data=t.data.length&&t.data||u(Array(p)).map((function(){return""}));for(var a=0;a=10?l.config.chart.toolbar.export.csv.dateFormatter(s):x.isNumber(s)?s:s.split(r).join("")));for(var o=0;o0&&!s.globals.isBarHorizontal&&(this.xaxisLabels=s.globals.timescaleLabels.slice()),s.config.xaxis.overwriteCategories&&(this.xaxisLabels=s.config.xaxis.overwriteCategories),this.drawnLabels=[],this.drawnLabelsRects=[],"top"===s.config.xaxis.position?this.offY=0:this.offY=s.globals.gridHeight+1,this.offY=this.offY+s.config.xaxis.axisBorder.offsetY,this.isCategoryBarHorizontal="bar"===s.config.chart.type&&s.config.plotOptions.bar.horizontal,this.xaxisFontSize=s.config.xaxis.labels.style.fontSize,this.xaxisFontFamily=s.config.xaxis.labels.style.fontFamily,this.xaxisForeColors=s.config.xaxis.labels.style.colors,this.xaxisBorderWidth=s.config.xaxis.axisBorder.width,this.isCategoryBarHorizontal&&(this.xaxisBorderWidth=s.config.yaxis[0].axisBorder.width.toString()),this.xaxisBorderWidth.indexOf("%")>-1?this.xaxisBorderWidth=s.globals.gridWidth*parseInt(this.xaxisBorderWidth,10)/100:this.xaxisBorderWidth=parseInt(this.xaxisBorderWidth,10),this.xaxisBorderHeight=s.config.xaxis.axisBorder.height,this.yaxis=s.config.yaxis[0]}return r(t,[{key:"drawXaxis",value:function(){var t=this.w,e=new m(this.ctx),i=e.group({class:"apexcharts-xaxis",transform:"translate(".concat(t.config.xaxis.offsetX,", ").concat(t.config.xaxis.offsetY,")")}),a=e.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(t.globals.translateXAxisX,", ").concat(t.globals.translateXAxisY,")")});i.add(a);for(var s=[],r=0;r6&&void 0!==arguments[6]?arguments[6]:{},h=[],c=[],d=this.w,g=l.xaxisFontSize||this.xaxisFontSize,u=l.xaxisFontFamily||this.xaxisFontFamily,p=l.xaxisForeColors||this.xaxisForeColors,f=l.fontWeight||d.config.xaxis.labels.style.fontWeight,x=l.cssClass||d.config.xaxis.labels.style.cssClass,b=d.globals.padHorizontal,v=a.length,m="category"===d.config.xaxis.type?d.globals.dataPoints:v;if(0===m&&v>m&&(m=v),s){var y=m>1?m-1:m;o=d.globals.gridWidth/y,b=b+r(0,o)/2+d.config.xaxis.labels.offsetX}else o=d.globals.gridWidth/m,b=b+r(0,o)+d.config.xaxis.labels.offsetX;for(var w=function(s){var l=b-r(s,o)/2+d.config.xaxis.labels.offsetX;0===s&&1===v&&o/2===b&&1===m&&(l=d.globals.gridWidth/2);var y=n.axesUtils.getLabel(a,d.globals.timescaleLabels,l,s,h,g,t),w=28;d.globals.rotateXLabels&&t&&(w=22),d.config.xaxis.title.text&&"top"===d.config.xaxis.position&&(w+=parseFloat(d.config.xaxis.title.style.fontSize)+2),t||(w=w+parseFloat(g)+(d.globals.xAxisLabelsHeight-d.globals.xAxisGroupLabelsHeight)+(d.globals.rotateXLabels?10:0)),y=void 0!==d.config.xaxis.tickAmount&&"dataPoints"!==d.config.xaxis.tickAmount&&"datetime"!==d.config.xaxis.type?n.axesUtils.checkLabelBasedOnTickamount(s,y,v):n.axesUtils.checkForOverflowingLabels(s,y,v,h,c);if(d.config.xaxis.labels.show){var k=e.drawText({x:y.x,y:n.offY+d.config.xaxis.labels.offsetY+w-("top"===d.config.xaxis.position?d.globals.xAxisHeight+d.config.xaxis.axisTicks.height-2:0),text:y.text,textAnchor:"middle",fontWeight:y.isBold?600:f,fontSize:g,fontFamily:u,foreColor:Array.isArray(p)?t&&d.config.xaxis.convertedCatToNumeric?p[d.globals.minX+s-1]:p[s]:p,isPlainText:!1,cssClass:(t?"apexcharts-xaxis-label ":"apexcharts-xaxis-group-label ")+x});if(i.add(k),k.on("click",(function(t){if("function"==typeof d.config.chart.events.xAxisLabelClick){var e=Object.assign({},d,{labelIndex:s});d.config.chart.events.xAxisLabelClick(t,n.ctx,e)}})),t){var A=document.createElementNS(d.globals.SVGNS,"title");A.textContent=Array.isArray(y.text)?y.text.join(" "):y.text,k.node.appendChild(A),""!==y.text&&(h.push(y.text),c.push(y))}}sa.globals.gridWidth)){var r=this.offY+a.config.xaxis.axisTicks.offsetY;if(e=e+r+a.config.xaxis.axisTicks.height,"top"===a.config.xaxis.position&&(e=r-a.config.xaxis.axisTicks.height),a.config.xaxis.axisTicks.show){var o=new m(this.ctx).drawLine(t+a.config.xaxis.axisTicks.offsetX,r+a.config.xaxis.offsetY,s+a.config.xaxis.axisTicks.offsetX,e+a.config.xaxis.offsetY,a.config.xaxis.axisTicks.color);i.add(o),o.node.classList.add("apexcharts-xaxis-tick")}}}},{key:"getXAxisTicksPositions",value:function(){var t=this.w,e=[],i=this.xaxisLabels.length,a=t.globals.padHorizontal;if(t.globals.timescaleLabels.length>0)for(var s=0;s0){var h=s[s.length-1].getBBox(),c=s[0].getBBox();h.x<-20&&s[s.length-1].parentNode.removeChild(s[s.length-1]),c.x+c.width>t.globals.gridWidth&&!t.globals.isBarHorizontal&&s[0].parentNode.removeChild(s[0]);for(var d=0;d0&&(this.xaxisLabels=i.globals.timescaleLabels.slice())}return r(t,[{key:"drawGridArea",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w,i=new m(this.ctx);null===t&&(t=i.group({class:"apexcharts-grid"}));var a=i.drawLine(e.globals.padHorizontal,1,e.globals.padHorizontal,e.globals.gridHeight,"transparent"),s=i.drawLine(e.globals.padHorizontal,e.globals.gridHeight,e.globals.gridWidth,e.globals.gridHeight,"transparent");return t.add(s),t.add(a),t}},{key:"drawGrid",value:function(){var t=null;return this.w.globals.axisCharts&&(t=this.renderGrid(),this.drawGridArea(t.el)),t}},{key:"createGridMask",value:function(){var t=this.w,e=t.globals,i=new m(this.ctx),a=Array.isArray(t.config.stroke.width)?0:t.config.stroke.width;if(Array.isArray(t.config.stroke.width)){var s=0;t.config.stroke.width.forEach((function(t){s=Math.max(s,t)})),a=s}e.dom.elGridRectMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMask.setAttribute("id","gridRectMask".concat(e.cuid)),e.dom.elGridRectMarkerMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMarkerMask.setAttribute("id","gridRectMarkerMask".concat(e.cuid)),e.dom.elForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elForecastMask.setAttribute("id","forecastMask".concat(e.cuid)),e.dom.elNonForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elNonForecastMask.setAttribute("id","nonForecastMask".concat(e.cuid));var r=t.config.chart.type,o=0,n=0;("bar"===r||"rangeBar"===r||"candlestick"===r||"boxPlot"===r||t.globals.comboBarCount>0)&&t.globals.isXNumeric&&!t.globals.isBarHorizontal&&(o=t.config.grid.padding.left,n=t.config.grid.padding.right,e.barPadForNumericAxis>o&&(o=e.barPadForNumericAxis,n=e.barPadForNumericAxis)),e.dom.elGridRect=i.drawRect(-a/2-o-2,-a/2,e.gridWidth+a+n+o+4,e.gridHeight+a,0,"#fff");var l=t.globals.markers.largestSize+1;e.dom.elGridRectMarker=i.drawRect(2*-l,2*-l,e.gridWidth+4*l,e.gridHeight+4*l,0,"#fff"),e.dom.elGridRectMask.appendChild(e.dom.elGridRect.node),e.dom.elGridRectMarkerMask.appendChild(e.dom.elGridRectMarker.node);var h=e.dom.baseEl.querySelector("defs");h.appendChild(e.dom.elGridRectMask),h.appendChild(e.dom.elForecastMask),h.appendChild(e.dom.elNonForecastMask),h.appendChild(e.dom.elGridRectMarkerMask)}},{key:"_drawGridLines",value:function(t){var e=t.i,i=t.x1,a=t.y1,s=t.x2,r=t.y2,o=t.xCount,n=t.parent,l=this.w;if(!(0===e&&l.globals.skipFirstTimelinelabel||e===o-1&&l.globals.skipLastTimelinelabel&&!l.config.xaxis.labels.formatter||"radar"===l.config.chart.type)){l.config.grid.xaxis.lines.show&&this._drawGridLine({i:e,x1:i,y1:a,x2:s,y2:r,xCount:o,parent:n});var h=0;if(l.globals.hasXaxisGroups&&"between"===l.config.xaxis.tickPlacement){var c=l.globals.groups;if(c){for(var d=0,g=0;d2));s++);return!t.globals.isBarHorizontal||this.isRangeBar?(i=this.xaxisLabels.length,this.isRangeBar&&(i--,a=t.globals.labels.length,t.config.xaxis.tickAmount&&t.config.xaxis.labels.formatter&&(i=t.config.xaxis.tickAmount)),this._drawXYLines({xCount:i,tickAmount:a})):(i=a,a=t.globals.xTickAmount,this._drawInvertedXYLines({xCount:i,tickAmount:a})),this.drawGridBands(i,a),{el:this.elg,elGridBorders:this.elGridBorders,xAxisTickWidth:t.globals.gridWidth/i}}},{key:"drawGridBands",value:function(t,e){var i=this.w;if(void 0!==i.config.grid.row.colors&&i.config.grid.row.colors.length>0)for(var a=0,s=i.globals.gridHeight/e,r=i.globals.gridWidth,o=0,n=0;o=i.config.grid.row.colors.length&&(n=0),this._drawGridBandRect({c:n,x1:0,y1:a,x2:r,y2:s,type:"row"}),a+=i.globals.gridHeight/e;if(void 0!==i.config.grid.column.colors&&i.config.grid.column.colors.length>0)for(var l=i.globals.isBarHorizontal||"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric?t:t-1,h=i.globals.padHorizontal,c=i.globals.padHorizontal+i.globals.gridWidth/l,d=i.globals.gridHeight,g=0,u=0;g=i.config.grid.column.colors.length&&(u=0),this._drawGridBandRect({c:u,x1:h,y1:0,x2:c,y2:d,type:"column"}),h+=i.globals.gridWidth/l}}]),t}(),_=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"niceScale",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,s=arguments.length>4?arguments[4]:void 0,r=this.w,o=Math.abs(e-t);if("dataPoints"===(i=this._adjustTicksForSmallRange(i,a,o))&&(i=r.globals.dataPoints-1),t===Number.MIN_VALUE&&0===e||!x.isNumber(t)&&!x.isNumber(e)||t===Number.MIN_VALUE&&e===-Number.MAX_VALUE)return t=0,e=i,this.linearScale(t,e,i);t>e?(console.warn("axis.min cannot be greater than axis.max"),e=t+.1):t===e&&(t=0===t?0:t-.5,e=0===e?2:e+.5);var n=[];o<1&&s&&("candlestick"===r.config.chart.type||"candlestick"===r.config.series[a].type||"boxPlot"===r.config.chart.type||"boxPlot"===r.config.series[a].type||r.globals.isRangeData)&&(e*=1.01);var l=i+1;l<2?l=2:l>2&&(l-=2);var h=o/l,c=Math.floor(x.log10(h)),d=Math.pow(10,c),g=Math.round(h/d);g<1&&(g=1);var u=g*d,p=u*Math.floor(t/u),f=u*Math.ceil(e/u),b=p;if(s&&o>2){for(;n.push(b),!((b+=u)>f););return{result:n,niceMin:n[0],niceMax:n[n.length-1]}}var v=t;(n=[]).push(v);for(var m=Math.abs(e-t)/i,y=0;y<=i;y++)v+=m,n.push(v);return n[n.length-2]>=e&&n.pop(),{result:n,niceMin:n[0],niceMax:n[n.length-1]}}},{key:"linearScale",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3?arguments[3]:void 0,s=Math.abs(e-t);"dataPoints"===(i=this._adjustTicksForSmallRange(i,a,s))&&(i=this.w.globals.dataPoints-1);var r=s/i;i===Number.MAX_VALUE&&(i=10,r=1);for(var o=[],n=t;i>=0;)o.push(n),n+=r,i-=1;return{result:o,niceMin:o[0],niceMax:o[o.length-1]}}},{key:"logarithmicScaleNice",value:function(t,e,i){e<=0&&(e=Math.max(t,i)),t<=0&&(t=Math.min(e,i));for(var a=[],s=Math.ceil(Math.log(e)/Math.log(i)+1),r=Math.floor(Math.log(t)/Math.log(i));r5)a.allSeriesCollapsed=!1,a.yAxisScale[t]=this.logarithmicScale(e,i,r.logBase),a.yAxisScale[t]=r.forceNiceScale?this.logarithmicScaleNice(e,i,r.logBase):this.logarithmicScale(e,i,r.logBase);else if(i!==-Number.MAX_VALUE&&x.isNumber(i))if(a.allSeriesCollapsed=!1,void 0===r.min&&void 0===r.max||r.forceNiceScale){var n=void 0===s.yaxis[t].max&&void 0===s.yaxis[t].min||s.yaxis[t].forceNiceScale;a.yAxisScale[t]=this.niceScale(e,i,r.tickAmount?r.tickAmount:o<5&&o>1?o+1:5,t,n)}else a.yAxisScale[t]=this.linearScale(e,i,r.tickAmount,t);else a.yAxisScale[t]=this.linearScale(0,5,5)}},{key:"setXScale",value:function(t,e){var i=this.w,a=i.globals,s=i.config.xaxis,r=Math.abs(e-t);return e!==-Number.MAX_VALUE&&x.isNumber(e)?a.xAxisScale=this.linearScale(t,e,s.tickAmount?s.tickAmount:r<5&&r>1?r+1:5,0):a.xAxisScale=this.linearScale(0,5,5),a.xAxisScale}},{key:"setMultipleYScales",value:function(){var t=this,e=this.w.globals,i=this.w.config,a=e.minYArr.concat([]),s=e.maxYArr.concat([]),r=[];i.yaxis.forEach((function(e,o){var n=o;i.series.forEach((function(t,i){t.name===e.seriesName&&(n=i,o!==i?r.push({index:i,similarIndex:o,alreadyExists:!0}):r.push({index:i}))}));var l=a[n],h=s[n];t.setYScaleForIndex(o,l,h)})),this.sameScaleInMultipleAxes(a,s,r)}},{key:"sameScaleInMultipleAxes",value:function(t,e,i){var a=this,s=this.w.config,r=this.w.globals,o=[];i.forEach((function(t){t.alreadyExists&&(void 0===o[t.index]&&(o[t.index]=[]),o[t.index].push(t.index),o[t.index].push(t.similarIndex))})),r.yAxisSameScaleIndices=o,o.forEach((function(t,e){o.forEach((function(i,a){var s,r;e!==a&&(s=t,r=i,s.filter((function(t){return-1!==r.indexOf(t)}))).length>0&&(o[e]=o[e].concat(o[a]))}))}));var n=o.map((function(t){return t.filter((function(e,i){return t.indexOf(e)===i}))})).map((function(t){return t.sort()}));o=o.filter((function(t){return!!t}));var l=n.slice(),h=l.map((function(t){return JSON.stringify(t)}));l=l.filter((function(t,e){return h.indexOf(JSON.stringify(t))===e}));var c=[],d=[];t.forEach((function(t,i){l.forEach((function(a,s){a.indexOf(i)>-1&&(void 0===c[s]&&(c[s]=[],d[s]=[]),c[s].push({key:i,value:t}),d[s].push({key:i,value:e[i]}))}))}));var g=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,Number.MIN_VALUE),u=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,-Number.MAX_VALUE);c.forEach((function(t,e){t.forEach((function(t,i){g[e]=Math.min(t.value,g[e])}))})),d.forEach((function(t,e){t.forEach((function(t,i){u[e]=Math.max(t.value,u[e])}))})),t.forEach((function(t,e){d.forEach((function(t,i){var o=g[i],n=u[i];s.chart.stacked&&(n=0,t.forEach((function(t,e){t.value!==-Number.MAX_VALUE&&(n+=t.value),o!==Number.MIN_VALUE&&(o+=c[i][e].value)}))),t.forEach((function(i,l){t[l].key===e&&(void 0!==s.yaxis[e].min&&(o="function"==typeof s.yaxis[e].min?s.yaxis[e].min(r.minY):s.yaxis[e].min),void 0!==s.yaxis[e].max&&(n="function"==typeof s.yaxis[e].max?s.yaxis[e].max(r.maxY):s.yaxis[e].max),a.setYScaleForIndex(e,o,n))}))}))}))}},{key:"autoScaleY",value:function(t,e,i){t||(t=this);var a=t.w;if(a.globals.isMultipleYAxis||a.globals.collapsedSeries.length)return console.warn("autoScaleYaxis is not supported in a multi-yaxis chart."),e;var s=a.globals.seriesX[0],r=a.config.chart.stacked;return e.forEach((function(t,o){for(var n=0,l=0;l=i.xaxis.min){n=l;break}var h,c,d=a.globals.minYArr[o],g=a.globals.maxYArr[o],u=a.globals.stackedSeriesTotals;a.globals.series.forEach((function(o,l){var p=o[n];r?(p=u[n],h=c=p,u.forEach((function(t,e){s[e]<=i.xaxis.max&&s[e]>=i.xaxis.min&&(t>c&&null!==t&&(c=t),o[e]=i.xaxis.min){var r=t,o=t;a.globals.series.forEach((function(i,a){null!==t&&(r=Math.min(i[e],r),o=Math.max(i[e],o))})),o>c&&null!==o&&(c=o),rd&&(h=d),e.length>1?(e[l].min=void 0===t.min?h:t.min,e[l].max=void 0===t.max?c:t.max):(e[0].min=void 0===t.min?h:t.min,e[0].max=void 0===t.max?c:t.max)}))})),e}}]),t}(),U=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.scales=new _(e)}return r(t,[{key:"init",value:function(){this.setYRange(),this.setXRange(),this.setZRange()}},{key:"getMinYMaxY",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Number.MAX_VALUE,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:-Number.MAX_VALUE,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.w.config,r=this.w.globals,o=-Number.MAX_VALUE,n=Number.MIN_VALUE;null===a&&(a=t+1);var l=r.series,h=l,c=l;"candlestick"===s.chart.type?(h=r.seriesCandleL,c=r.seriesCandleH):"boxPlot"===s.chart.type?(h=r.seriesCandleO,c=r.seriesCandleC):r.isRangeData&&(h=r.seriesRangeStart,c=r.seriesRangeEnd);for(var d=t;dh[d][g]&&h[d][g]<0&&(n=h[d][g])):r.hasNullValues=!0}}return"rangeBar"===s.chart.type&&r.seriesRangeStart.length&&r.isBarHorizontal&&(n=e),"bar"===s.chart.type&&(n<0&&o<0&&(o=0),n===Number.MIN_VALUE&&(n=0)),{minY:n,maxY:o,lowestY:e,highestY:i}}},{key:"setYRange",value:function(){var t=this.w.globals,e=this.w.config;t.maxY=-Number.MAX_VALUE,t.minY=Number.MIN_VALUE;var i=Number.MAX_VALUE;if(t.isMultipleYAxis)for(var a=0;a=0&&i<=10||void 0!==e.yaxis[0].min||void 0!==e.yaxis[0].max)&&(o=0),t.minY=i-5*o/100,i>0&&t.minY<0&&(t.minY=0),t.maxY=t.maxY+5*o/100}if(e.yaxis.forEach((function(e,i){void 0!==e.max&&("number"==typeof e.max?t.maxYArr[i]=e.max:"function"==typeof e.max&&(t.maxYArr[i]=e.max(t.isMultipleYAxis?t.maxYArr[i]:t.maxY)),t.maxY=t.maxYArr[i]),void 0!==e.min&&("number"==typeof e.min?t.minYArr[i]=e.min:"function"==typeof e.min&&(t.minYArr[i]=e.min(t.isMultipleYAxis?t.minYArr[i]===Number.MIN_VALUE?0:t.minYArr[i]:t.minY)),t.minY=t.minYArr[i])})),t.isBarHorizontal){["min","max"].forEach((function(i){void 0!==e.xaxis[i]&&"number"==typeof e.xaxis[i]&&("min"===i?t.minY=e.xaxis[i]:t.maxY=e.xaxis[i])}))}return t.isMultipleYAxis?(this.scales.setMultipleYScales(),t.minY=i,t.yAxisScale.forEach((function(e,i){t.minYArr[i]=e.niceMin,t.maxYArr[i]=e.niceMax}))):(this.scales.setYScaleForIndex(0,t.minY,t.maxY),t.minY=t.yAxisScale[0].niceMin,t.maxY=t.yAxisScale[0].niceMax,t.minYArr[0]=t.yAxisScale[0].niceMin,t.maxYArr[0]=t.yAxisScale[0].niceMax),{minY:t.minY,maxY:t.maxY,minYArr:t.minYArr,maxYArr:t.maxYArr,yAxisScale:t.yAxisScale}}},{key:"setXRange",value:function(){var t=this.w.globals,e=this.w.config,i="numeric"===e.xaxis.type||"datetime"===e.xaxis.type||"category"===e.xaxis.type&&!t.noLabelsProvided||t.noLabelsProvided||t.isXNumeric;if(t.isXNumeric&&function(){for(var e=0;et.dataPoints&&0!==t.dataPoints&&(a=t.dataPoints-1)):"dataPoints"===e.xaxis.tickAmount?(t.series.length>1&&(a=t.series[t.maxValsInArrayIndex].length-1),t.isXNumeric&&(a=t.maxX-t.minX-1)):a=e.xaxis.tickAmount,t.xTickAmount=a,void 0!==e.xaxis.max&&"number"==typeof e.xaxis.max&&(t.maxX=e.xaxis.max),void 0!==e.xaxis.min&&"number"==typeof e.xaxis.min&&(t.minX=e.xaxis.min),void 0!==e.xaxis.range&&(t.minX=t.maxX-e.xaxis.range),t.minX!==Number.MAX_VALUE&&t.maxX!==-Number.MAX_VALUE)if(e.xaxis.convertedCatToNumeric&&!t.dataFormatXNumeric){for(var s=[],r=t.minX-1;r0&&(t.xAxisScale=this.scales.linearScale(1,t.labels.length,a-1),t.seriesX=t.labels.slice());i&&(t.labels=t.xAxisScale.result.slice())}return t.isBarHorizontal&&t.labels.length&&(t.xTickAmount=t.labels.length),this._handleSingleDataPoint(),this._getMinXDiff(),{minX:t.minX,maxX:t.maxX}}},{key:"setZRange",value:function(){var t=this.w.globals;if(t.isDataXYZ)for(var e=0;e0){var s=e-a[i-1];s>0&&(t.minXDiff=Math.min(s,t.minXDiff))}})),1!==t.dataPoints&&t.minXDiff!==Number.MAX_VALUE||(t.minXDiff=.5)}))}},{key:"_setStackedMinMax",value:function(){var t=this,e=this.w.globals;if(e.series.length){var i=e.seriesGroups;i.length||(i=[this.w.config.series.map((function(t){return t.name}))]);var a={},s={};i.forEach((function(i){a[i]=[],s[i]=[],t.w.config.series.map((function(t,e){return i.indexOf(t.name)>-1?e:null})).filter((function(t){return null!==t})).forEach((function(t){for(var r=0;r0?a[i][r]+=parseFloat(e.series[t][r])+1e-4:s[i][r]+=parseFloat(e.series[t][r]))}))})),Object.entries(a).forEach((function(t){var i=g(t,1)[0];a[i].forEach((function(t,r){e.maxY=Math.max(e.maxY,a[i][r]),e.minY=Math.min(e.minY,s[i][r])}))}))}}}]),t}(),q=function(){function t(e,i){a(this,t),this.ctx=e,this.elgrid=i,this.w=e.w;var s=this.w;this.xaxisFontSize=s.config.xaxis.labels.style.fontSize,this.axisFontFamily=s.config.xaxis.labels.style.fontFamily,this.xaxisForeColors=s.config.xaxis.labels.style.colors,this.isCategoryBarHorizontal="bar"===s.config.chart.type&&s.config.plotOptions.bar.horizontal,this.xAxisoffX=0,"bottom"===s.config.xaxis.position&&(this.xAxisoffX=s.globals.gridHeight),this.drawnLabels=[],this.axesUtils=new B(e)}return r(t,[{key:"drawYaxis",value:function(t){var e=this,i=this.w,a=new m(this.ctx),s=i.config.yaxis[t].labels.style,r=s.fontSize,o=s.fontFamily,n=s.fontWeight,l=a.group({class:"apexcharts-yaxis",rel:t,transform:"translate("+i.globals.translateYAxisX[t]+", 0)"});if(this.axesUtils.isYAxisHidden(t))return l;var h=a.group({class:"apexcharts-yaxis-texts-g"});l.add(h);var c=i.globals.yAxisScale[t].result.length-1,d=i.globals.gridHeight/c,g=i.globals.translateY,u=i.globals.yLabelFormatters[t],p=i.globals.yAxisScale[t].result.slice();p=this.axesUtils.checkForReversedLabels(t,p);var f="";if(i.config.yaxis[t].labels.show)for(var x=function(l){var x=p[l];x=u(x,l,i);var b=i.config.yaxis[t].labels.padding;i.config.yaxis[t].opposite&&0!==i.config.yaxis.length&&(b*=-1);var v="end";i.config.yaxis[t].opposite&&(v="start"),"left"===i.config.yaxis[t].labels.align?v="start":"center"===i.config.yaxis[t].labels.align?v="middle":"right"===i.config.yaxis[t].labels.align&&(v="end");var m=e.axesUtils.getYAxisForeColor(s.colors,t),y=a.drawText({x:b,y:g+c/10+i.config.yaxis[t].labels.offsetY+1,text:x,textAnchor:v,fontSize:r,fontFamily:o,fontWeight:n,maxWidth:i.config.yaxis[t].labels.maxWidth,foreColor:Array.isArray(m)?m[l]:m,isPlainText:!1,cssClass:"apexcharts-yaxis-label "+s.cssClass});l===c&&(f=y),h.add(y);var w=document.createElementNS(i.globals.SVGNS,"title");if(w.textContent=Array.isArray(x)?x.join(" "):x,y.node.appendChild(w),0!==i.config.yaxis[t].labels.rotate){var k=a.rotateAroundCenter(f.node),A=a.rotateAroundCenter(y.node);y.node.setAttribute("transform","rotate(".concat(i.config.yaxis[t].labels.rotate," ").concat(k.x," ").concat(A.y,")"))}g+=d},b=c;b>=0;b--)x(b);if(void 0!==i.config.yaxis[t].title.text){var v=a.group({class:"apexcharts-yaxis-title"}),y=0;i.config.yaxis[t].opposite&&(y=i.globals.translateYAxisX[t]);var w=a.drawText({x:y,y:i.globals.gridHeight/2+i.globals.translateY+i.config.yaxis[t].title.offsetY,text:i.config.yaxis[t].title.text,textAnchor:"end",foreColor:i.config.yaxis[t].title.style.color,fontSize:i.config.yaxis[t].title.style.fontSize,fontWeight:i.config.yaxis[t].title.style.fontWeight,fontFamily:i.config.yaxis[t].title.style.fontFamily,cssClass:"apexcharts-yaxis-title-text "+i.config.yaxis[t].title.style.cssClass});v.add(w),l.add(v)}var k=i.config.yaxis[t].axisBorder,A=31+k.offsetX;if(i.config.yaxis[t].opposite&&(A=-31-k.offsetX),k.show){var S=a.drawLine(A,i.globals.translateY+k.offsetY-2,A,i.globals.gridHeight+i.globals.translateY+k.offsetY+2,k.color,0,k.width);l.add(S)}return i.config.yaxis[t].axisTicks.show&&this.axesUtils.drawYAxisTicks(A,c,k,i.config.yaxis[t].axisTicks,t,d,l),l}},{key:"drawYaxisInversed",value:function(t){var e=this.w,i=new m(this.ctx),a=i.group({class:"apexcharts-xaxis apexcharts-yaxis-inversed"}),s=i.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(e.globals.translateXAxisX,", ").concat(e.globals.translateXAxisY,")")});a.add(s);var r=e.globals.yAxisScale[t].result.length-1,o=e.globals.gridWidth/r+.1,n=o+e.config.xaxis.labels.offsetX,l=e.globals.xLabelFormatter,h=e.globals.yAxisScale[t].result.slice(),c=e.globals.timescaleLabels;c.length>0&&(this.xaxisLabels=c.slice(),r=(h=c.slice()).length),h=this.axesUtils.checkForReversedLabels(t,h);var d=c.length;if(e.config.xaxis.labels.show)for(var g=d?0:r;d?g=0;d?g++:g--){var u=h[g];u=l(u,g,e);var p=e.globals.gridWidth+e.globals.padHorizontal-(n-o+e.config.xaxis.labels.offsetX);if(c.length){var f=this.axesUtils.getLabel(h,c,p,g,this.drawnLabels,this.xaxisFontSize);p=f.x,u=f.text,this.drawnLabels.push(f.text),0===g&&e.globals.skipFirstTimelinelabel&&(u=""),g===h.length-1&&e.globals.skipLastTimelinelabel&&(u="")}var x=i.drawText({x:p,y:this.xAxisoffX+e.config.xaxis.labels.offsetY+30-("top"===e.config.xaxis.position?e.globals.xAxisHeight+e.config.xaxis.axisTicks.height-2:0),text:u,textAnchor:"middle",foreColor:Array.isArray(this.xaxisForeColors)?this.xaxisForeColors[t]:this.xaxisForeColors,fontSize:this.xaxisFontSize,fontFamily:this.xaxisFontFamily,fontWeight:e.config.xaxis.labels.style.fontWeight,isPlainText:!1,cssClass:"apexcharts-xaxis-label "+e.config.xaxis.labels.style.cssClass});s.add(x),x.tspan(u);var b=document.createElementNS(e.globals.SVGNS,"title");b.textContent=u,x.node.appendChild(b),n+=o}return this.inversedYAxisTitleText(a),this.inversedYAxisBorder(a),a}},{key:"inversedYAxisBorder",value:function(t){var e=this.w,i=new m(this.ctx),a=e.config.xaxis.axisBorder;if(a.show){var s=0;"bar"===e.config.chart.type&&e.globals.isXNumeric&&(s-=15);var r=i.drawLine(e.globals.padHorizontal+s+a.offsetX,this.xAxisoffX,e.globals.gridWidth,this.xAxisoffX,a.color,0,a.height);this.elgrid&&this.elgrid.elGridBorders&&e.config.grid.show?this.elgrid.elGridBorders.add(r):t.add(r)}}},{key:"inversedYAxisTitleText",value:function(t){var e=this.w,i=new m(this.ctx);if(void 0!==e.config.xaxis.title.text){var a=i.group({class:"apexcharts-xaxis-title apexcharts-yaxis-title-inversed"}),s=i.drawText({x:e.globals.gridWidth/2+e.config.xaxis.title.offsetX,y:this.xAxisoffX+parseFloat(this.xaxisFontSize)+parseFloat(e.config.xaxis.title.style.fontSize)+e.config.xaxis.title.offsetY+20,text:e.config.xaxis.title.text,textAnchor:"middle",fontSize:e.config.xaxis.title.style.fontSize,fontFamily:e.config.xaxis.title.style.fontFamily,fontWeight:e.config.xaxis.title.style.fontWeight,foreColor:e.config.xaxis.title.style.color,cssClass:"apexcharts-xaxis-title-text "+e.config.xaxis.title.style.cssClass});a.add(s),t.add(a)}}},{key:"yAxisTitleRotate",value:function(t,e){var i=this.w,a=new m(this.ctx),s={width:0,height:0},r={width:0,height:0},o=i.globals.dom.baseEl.querySelector(" .apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-texts-g"));null!==o&&(s=o.getBoundingClientRect());var n=i.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-title text"));if(null!==n&&(r=n.getBoundingClientRect()),null!==n){var l=this.xPaddingForYAxisTitle(t,s,r,e);n.setAttribute("x",l.xPos-(e?10:0))}if(null!==n){var h=a.rotateAroundCenter(n);n.setAttribute("transform","rotate(".concat(e?-1*i.config.yaxis[t].title.rotate:i.config.yaxis[t].title.rotate," ").concat(h.x," ").concat(h.y,")"))}}},{key:"xPaddingForYAxisTitle",value:function(t,e,i,a){var s=this.w,r=0,o=0,n=10;return void 0===s.config.yaxis[t].title.text||t<0?{xPos:o,padd:0}:(a?(o=e.width+s.config.yaxis[t].title.offsetX+i.width/2+n/2,0===(r+=1)&&(o-=n/2)):(o=-1*e.width+s.config.yaxis[t].title.offsetX+n/2+i.width/2,s.globals.isBarHorizontal&&(n=25,o=-1*e.width-s.config.yaxis[t].title.offsetX-n)),{xPos:o,padd:n})}},{key:"setYAxisXPosition",value:function(t,e){var i=this.w,a=0,s=0,r=18,o=1;i.config.yaxis.length>1&&(this.multipleYs=!0),i.config.yaxis.map((function(n,l){var h=i.globals.ignoreYAxisIndexes.indexOf(l)>-1||!n.show||n.floating||0===t[l].width,c=t[l].width+e[l].width;n.opposite?i.globals.isBarHorizontal?(s=i.globals.gridWidth+i.globals.translateX-1,i.globals.translateYAxisX[l]=s-n.labels.offsetX):(s=i.globals.gridWidth+i.globals.translateX+o,h||(o=o+c+20),i.globals.translateYAxisX[l]=s-n.labels.offsetX+20):(a=i.globals.translateX-r,h||(r=r+c+20),i.globals.translateYAxisX[l]=a+n.labels.offsetX)}))}},{key:"setYAxisTextAlignments",value:function(){var t=this.w,e=t.globals.dom.baseEl.getElementsByClassName("apexcharts-yaxis");(e=x.listToArray(e)).forEach((function(e,i){var a=t.config.yaxis[i];if(a&&!a.floating&&void 0!==a.labels.align){var s=t.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-texts-g")),r=t.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-label"));r=x.listToArray(r);var o=s.getBoundingClientRect();"left"===a.labels.align?(r.forEach((function(t,e){t.setAttribute("text-anchor","start")})),a.opposite||s.setAttribute("transform","translate(-".concat(o.width,", 0)"))):"center"===a.labels.align?(r.forEach((function(t,e){t.setAttribute("text-anchor","middle")})),s.setAttribute("transform","translate(".concat(o.width/2*(a.opposite?1:-1),", 0)"))):"right"===a.labels.align&&(r.forEach((function(t,e){t.setAttribute("text-anchor","end")})),a.opposite&&s.setAttribute("transform","translate(".concat(o.width,", 0)")))}}))}}]),t}(),Z=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.documentEvent=x.bind(this.documentEvent,this)}return r(t,[{key:"addEventListener",value:function(t,e){var i=this.w;i.globals.events.hasOwnProperty(t)?i.globals.events[t].push(e):i.globals.events[t]=[e]}},{key:"removeEventListener",value:function(t,e){var i=this.w;if(i.globals.events.hasOwnProperty(t)){var a=i.globals.events[t].indexOf(e);-1!==a&&i.globals.events[t].splice(a,1)}}},{key:"fireEvent",value:function(t,e){var i=this.w;if(i.globals.events.hasOwnProperty(t)){e&&e.length||(e=[]);for(var a=i.globals.events[t],s=a.length,r=0;r0&&(e=this.w.config.chart.locales.concat(window.Apex.chart.locales));var i=e.filter((function(e){return e.name===t}))[0];if(!i)throw new Error("Wrong locale name provided. Please make sure you set the correct locale name in options");var a=x.extend(C,i);this.w.globals.locale=a.options}}]),t}(),J=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"drawAxis",value:function(t,e){var i,a,s=this,r=this.w.globals,o=this.w.config,n=new V(this.ctx,e),l=new q(this.ctx,e);r.axisCharts&&"radar"!==t&&(r.isBarHorizontal?(a=l.drawYaxisInversed(0),i=n.drawXaxisInversed(0),r.dom.elGraphical.add(i),r.dom.elGraphical.add(a)):(i=n.drawXaxis(),r.dom.elGraphical.add(i),o.yaxis.map((function(t,e){if(-1===r.ignoreYAxisIndexes.indexOf(e)&&(a=l.drawYaxis(e),r.dom.Paper.add(a),"back"===s.w.config.grid.position)){var i=r.dom.Paper.children()[1];i.remove(),r.dom.Paper.add(i)}}))))}}]),t}(),Q=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"drawXCrosshairs",value:function(){var t=this.w,e=new m(this.ctx),i=new v(this.ctx),a=t.config.xaxis.crosshairs.fill.gradient,s=t.config.xaxis.crosshairs.dropShadow,r=t.config.xaxis.crosshairs.fill.type,o=a.colorFrom,n=a.colorTo,l=a.opacityFrom,h=a.opacityTo,c=a.stops,d=s.enabled,g=s.left,u=s.top,p=s.blur,f=s.color,b=s.opacity,y=t.config.xaxis.crosshairs.fill.color;if(t.config.xaxis.crosshairs.show){"gradient"===r&&(y=e.drawGradient("vertical",o,n,l,h,null,c,null));var w=e.drawRect();1===t.config.xaxis.crosshairs.width&&(w=e.drawLine());var k=t.globals.gridHeight;(!x.isNumber(k)||k<0)&&(k=0);var A=t.config.xaxis.crosshairs.width;(!x.isNumber(A)||A<0)&&(A=0),w.attr({class:"apexcharts-xcrosshairs",x:0,y:0,y2:k,width:A,height:k,fill:y,filter:"none","fill-opacity":t.config.xaxis.crosshairs.opacity,stroke:t.config.xaxis.crosshairs.stroke.color,"stroke-width":t.config.xaxis.crosshairs.stroke.width,"stroke-dasharray":t.config.xaxis.crosshairs.stroke.dashArray}),d&&(w=i.dropShadow(w,{left:g,top:u,blur:p,color:f,opacity:b})),t.globals.dom.elGraphical.add(w)}}},{key:"drawYCrosshairs",value:function(){var t=this.w,e=new m(this.ctx),i=t.config.yaxis[0].crosshairs,a=t.globals.barPadForNumericAxis;if(t.config.yaxis[0].crosshairs.show){var s=e.drawLine(-a,0,t.globals.gridWidth+a,0,i.stroke.color,i.stroke.dashArray,i.stroke.width);s.attr({class:"apexcharts-ycrosshairs"}),t.globals.dom.elGraphical.add(s)}var r=e.drawLine(-a,0,t.globals.gridWidth+a,0,i.stroke.color,0,0);r.attr({class:"apexcharts-ycrosshairs-hidden"}),t.globals.dom.elGraphical.add(r)}}]),t}(),K=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"checkResponsiveConfig",value:function(t){var e=this,i=this.w,a=i.config;if(0!==a.responsive.length){var s=a.responsive.slice();s.sort((function(t,e){return t.breakpoint>e.breakpoint?1:e.breakpoint>t.breakpoint?-1:0})).reverse();var r=new E({}),o=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},a=s[0].breakpoint,o=window.innerWidth>0?window.innerWidth:screen.width;if(o>a){var n=y.extendArrayProps(r,i.globals.initialConfig,i);t=x.extend(n,t),t=x.extend(i.config,t),e.overrideResponsiveOptions(t)}else for(var l=0;l0&&"function"==typeof e.config.colors[0]&&(e.globals.colors=e.config.series.map((function(i,a){var s=e.config.colors[a];return s||(s=e.config.colors[0]),"function"==typeof s?(t.isColorFn=!0,s({value:e.globals.axisCharts?e.globals.series[a][0]?e.globals.series[a][0]:0:e.globals.series[a],seriesIndex:a,dataPointIndex:a,w:e})):s})))),e.globals.seriesColors.map((function(t,i){t&&(e.globals.colors[i]=t)})),e.config.theme.monochrome.enabled){var a=[],s=e.globals.series.length;(this.isBarDistributed||this.isHeatmapDistributed)&&(s=e.globals.series[0].length*e.globals.series.length);for(var r=e.config.theme.monochrome.color,o=1/(s/e.config.theme.monochrome.shadeIntensity),n=e.config.theme.monochrome.shadeTo,l=0,h=0;h2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,s=e||a.globals.series.length;if(null===i&&(i=this.isBarDistributed||this.isHeatmapDistributed||"heatmap"===a.config.chart.type&&a.config.plotOptions.heatmap.colorScale.inverse),i&&a.globals.series.length&&(s=a.globals.series[a.globals.maxValsInArrayIndex].length*a.globals.series.length),t.lengtht.globals.svgWidth&&(this.dCtx.lgRect.width=t.globals.svgWidth/1.5),this.dCtx.lgRect}},{key:"getLargestStringFromMultiArr",value:function(t,e){var i=t;if(this.w.globals.isMultiLineX){var a=e.map((function(t,e){return Array.isArray(t)?t.length:1})),s=Math.max.apply(Math,u(a));i=e[a.indexOf(s)]}return i}}]),t}(),at=function(){function t(e){a(this,t),this.w=e.w,this.dCtx=e}return r(t,[{key:"getxAxisLabelsCoords",value:function(){var t,e=this.w,i=e.globals.labels.slice();if(e.config.xaxis.convertedCatToNumeric&&0===i.length&&(i=e.globals.categoryLabels),e.globals.timescaleLabels.length>0){var a=this.getxAxisTimeScaleLabelsCoords();t={width:a.width,height:a.height},e.globals.rotateXLabels=!1}else{this.dCtx.lgWidthForSideLegends="left"!==e.config.legend.position&&"right"!==e.config.legend.position||e.config.legend.floating?0:this.dCtx.lgRect.width;var s=e.globals.xLabelFormatter,r=x.getLargestStringFromArr(i),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(r,i);e.globals.isBarHorizontal&&(o=r=e.globals.yAxisScale[0].result.reduce((function(t,e){return t.length>e.length?t:e}),0));var n=new T(this.dCtx.ctx),l=r;r=n.xLabelFormat(s,r,l,{i:void 0,dateFormatter:new I(this.dCtx.ctx).formatDate,w:e}),o=n.xLabelFormat(s,o,l,{i:void 0,dateFormatter:new I(this.dCtx.ctx).formatDate,w:e}),(e.config.xaxis.convertedCatToNumeric&&void 0===r||""===String(r).trim())&&(o=r="1");var h=new m(this.dCtx.ctx),c=h.getTextRects(r,e.config.xaxis.labels.style.fontSize),d=c;if(r!==o&&(d=h.getTextRects(o,e.config.xaxis.labels.style.fontSize)),(t={width:c.width>=d.width?c.width:d.width,height:c.height>=d.height?c.height:d.height}).width*i.length>e.globals.svgWidth-this.dCtx.lgWidthForSideLegends-this.dCtx.yAxisWidth-this.dCtx.gridPad.left-this.dCtx.gridPad.right&&0!==e.config.xaxis.labels.rotate||e.config.xaxis.labels.rotateAlways){if(!e.globals.isBarHorizontal){e.globals.rotateXLabels=!0;var g=function(t){return h.getTextRects(t,e.config.xaxis.labels.style.fontSize,e.config.xaxis.labels.style.fontFamily,"rotate(".concat(e.config.xaxis.labels.rotate," 0 0)"),!1)};c=g(r),r!==o&&(d=g(o)),t.height=(c.height>d.height?c.height:d.height)/1.5,t.width=c.width>d.width?c.width:d.width}}else e.globals.rotateXLabels=!1}return e.config.xaxis.labels.show||(t={width:0,height:0}),{width:t.width,height:t.height}}},{key:"getxAxisGroupLabelsCoords",value:function(){var t,e=this.w;if(!e.globals.hasXaxisGroups)return{width:0,height:0};var i,a=(null===(t=e.config.xaxis.group.style)||void 0===t?void 0:t.fontSize)||e.config.xaxis.labels.style.fontSize,s=e.globals.groups.map((function(t){return t.title})),r=x.getLargestStringFromArr(s),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(r,s),n=new m(this.dCtx.ctx),l=n.getTextRects(r,a),h=l;return r!==o&&(h=n.getTextRects(o,a)),i={width:l.width>=h.width?l.width:h.width,height:l.height>=h.height?l.height:h.height},e.config.xaxis.labels.show||(i={width:0,height:0}),{width:i.width,height:i.height}}},{key:"getxAxisTitleCoords",value:function(){var t=this.w,e=0,i=0;if(void 0!==t.config.xaxis.title.text){var a=new m(this.dCtx.ctx).getTextRects(t.config.xaxis.title.text,t.config.xaxis.title.style.fontSize);e=a.width,i=a.height}return{width:e,height:i}}},{key:"getxAxisTimeScaleLabelsCoords",value:function(){var t,e=this.w;this.dCtx.timescaleLabels=e.globals.timescaleLabels.slice();var i=this.dCtx.timescaleLabels.map((function(t){return t.value})),a=i.reduce((function(t,e){return void 0===t?(console.error("You have possibly supplied invalid Date format. Please supply a valid JavaScript Date"),0):t.length>e.length?t:e}),0);return 1.05*(t=new m(this.dCtx.ctx).getTextRects(a,e.config.xaxis.labels.style.fontSize)).width*i.length>e.globals.gridWidth&&0!==e.config.xaxis.labels.rotate&&(e.globals.overlappingXLabels=!0),t}},{key:"additionalPaddingXLabels",value:function(t){var e=this,i=this.w,a=i.globals,s=i.config,r=s.xaxis.type,o=t.width;a.skipLastTimelinelabel=!1,a.skipFirstTimelinelabel=!1;var n=i.config.yaxis[0].opposite&&i.globals.isBarHorizontal,l=function(t,n){s.yaxis.length>1&&function(t){return-1!==a.collapsedSeriesIndices.indexOf(t)}(n)||function(t){if(e.dCtx.timescaleLabels&&e.dCtx.timescaleLabels.length){var n=e.dCtx.timescaleLabels[0],l=e.dCtx.timescaleLabels[e.dCtx.timescaleLabels.length-1].position+o/1.75-e.dCtx.yAxisWidthRight,h=n.position-o/1.75+e.dCtx.yAxisWidthLeft,c="right"===i.config.legend.position&&e.dCtx.lgRect.width>0?e.dCtx.lgRect.width:0;l>a.svgWidth-a.translateX-c&&(a.skipLastTimelinelabel=!0),h<-(t.show&&!t.floating||"bar"!==s.chart.type&&"candlestick"!==s.chart.type&&"rangeBar"!==s.chart.type&&"boxPlot"!==s.chart.type?10:o/1.75)&&(a.skipFirstTimelinelabel=!0)}else"datetime"===r?e.dCtx.gridPad.rightString(n.niceMax).length?c:n.niceMax,g=h(d,{seriesIndex:o,dataPointIndex:-1,w:e}),u=g;if(void 0!==g&&0!==g.length||(g=d),e.globals.isBarHorizontal){a=0;var p=e.globals.labels.slice();g=h(g=x.getLargestStringFromArr(p),{seriesIndex:o,dataPointIndex:-1,w:e}),u=t.dCtx.dimHelpers.getLargestStringFromMultiArr(g,p)}var f=new m(t.dCtx.ctx),b="rotate(".concat(r.labels.rotate," 0 0)"),v=f.getTextRects(g,r.labels.style.fontSize,r.labels.style.fontFamily,b,!1),y=v;g!==u&&(y=f.getTextRects(u,r.labels.style.fontSize,r.labels.style.fontFamily,b,!1)),i.push({width:(l>y.width||l>v.width?l:y.width>v.width?y.width:v.width)+a,height:y.height>v.height?y.height:v.height})}else i.push({width:0,height:0})})),i}},{key:"getyAxisTitleCoords",value:function(){var t=this,e=this.w,i=[];return e.config.yaxis.map((function(e,a){if(e.show&&void 0!==e.title.text){var s=new m(t.dCtx.ctx),r="rotate(".concat(e.title.rotate," 0 0)"),o=s.getTextRects(e.title.text,e.title.style.fontSize,e.title.style.fontFamily,r,!1);i.push({width:o.width,height:o.height})}else i.push({width:0,height:0})})),i}},{key:"getTotalYAxisWidth",value:function(){var t=this.w,e=0,i=0,a=0,s=t.globals.yAxisScale.length>1?10:0,r=new B(this.dCtx.ctx),o=function(o,n){var l=t.config.yaxis[n].floating,h=0;o.width>0&&!l?(h=o.width+s,function(e){return t.globals.ignoreYAxisIndexes.indexOf(e)>-1}(n)&&(h=h-o.width-s)):h=l||r.isYAxisHidden(n)?0:5,t.config.yaxis[n].opposite?a+=h:i+=h,e+=h};return t.globals.yLabelsCoords.map((function(t,e){o(t,e)})),t.globals.yTitleCoords.map((function(t,e){o(t,e)})),t.globals.isBarHorizontal&&!t.config.yaxis[0].floating&&(e=t.globals.yLabelsCoords[0].width+t.globals.yTitleCoords[0].width+15),this.dCtx.yAxisWidthLeft=i,this.dCtx.yAxisWidthRight=a,e}}]),t}(),rt=function(){function t(e){a(this,t),this.w=e.w,this.dCtx=e}return r(t,[{key:"gridPadForColumnsInNumericAxis",value:function(t){var e=this.w;if(e.globals.noData||e.globals.allSeriesCollapsed)return 0;var i=function(t){return"bar"===t||"rangeBar"===t||"candlestick"===t||"boxPlot"===t},a=e.config.chart.type,s=0,r=i(a)?e.config.series.length:1;if(e.globals.comboBarCount>0&&(r=e.globals.comboBarCount),e.globals.collapsedSeries.forEach((function(t){i(t.type)&&(r-=1)})),e.config.chart.stacked&&(r=1),(i(a)||e.globals.comboBarCount>0)&&e.globals.isXNumeric&&!e.globals.isBarHorizontal&&r>0){var o,n,l=Math.abs(e.globals.initialMaxX-e.globals.initialMinX);l<=3&&(l=e.globals.dataPoints),o=l/t,e.globals.minXDiff&&e.globals.minXDiff/o>0&&(n=e.globals.minXDiff/o),n>t/2&&(n/=2),(s=n/r*parseInt(e.config.plotOptions.bar.columnWidth,10)/100)<1&&(s=1),s=s/(r>1?1:1.5)+5,e.globals.barPadForNumericAxis=s}return s}},{key:"gridPadFortitleSubtitle",value:function(){var t=this,e=this.w,i=e.globals,a=this.dCtx.isSparkline||!e.globals.axisCharts?0:10;["title","subtitle"].forEach((function(i){void 0!==e.config[i].text?a+=e.config[i].margin:a+=t.dCtx.isSparkline||!e.globals.axisCharts?0:5})),!e.config.legend.show||"bottom"!==e.config.legend.position||e.config.legend.floating||e.globals.axisCharts||(a+=10);var s=this.dCtx.dimHelpers.getTitleSubtitleCoords("title"),r=this.dCtx.dimHelpers.getTitleSubtitleCoords("subtitle");i.gridHeight=i.gridHeight-s.height-r.height-a,i.translateY=i.translateY+s.height+r.height+a}},{key:"setGridXPosForDualYAxis",value:function(t,e){var i=this.w,a=new B(this.dCtx.ctx);i.config.yaxis.map((function(s,r){-1!==i.globals.ignoreYAxisIndexes.indexOf(r)||s.floating||a.isYAxisHidden(r)||(s.opposite&&(i.globals.translateX=i.globals.translateX-(e[r].width+t[r].width)-parseInt(i.config.yaxis[r].labels.style.fontSize,10)/1.2-12),i.globals.translateX<2&&(i.globals.translateX=2))}))}}]),t}(),ot=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.lgRect={},this.yAxisWidth=0,this.yAxisWidthLeft=0,this.yAxisWidthRight=0,this.xAxisHeight=0,this.isSparkline=this.w.config.chart.sparkline.enabled,this.dimHelpers=new it(this),this.dimYAxis=new st(this),this.dimXAxis=new at(this),this.dimGrid=new rt(this),this.lgWidthForSideLegends=0,this.gridPad=this.w.config.grid.padding,this.xPadRight=0,this.xPadLeft=0}return r(t,[{key:"plotCoords",value:function(){var t=this,e=this.w,i=e.globals;this.lgRect=this.dimHelpers.getLegendsRect(),this.isSparkline&&(e.config.markers.discrete.length>0||e.config.markers.size>0)&&Object.entries(this.gridPad).forEach((function(e){var i=g(e,2),a=i[0],s=i[1];t.gridPad[a]=Math.max(s,t.w.globals.markers.largestSize/1.5)})),i.axisCharts?this.setDimensionsForAxisCharts():this.setDimensionsForNonAxisCharts(),this.dimGrid.gridPadFortitleSubtitle(),i.gridHeight=i.gridHeight-this.gridPad.top-this.gridPad.bottom,i.gridWidth=i.gridWidth-this.gridPad.left-this.gridPad.right-this.xPadRight-this.xPadLeft;var a=this.dimGrid.gridPadForColumnsInNumericAxis(i.gridWidth);i.gridWidth=i.gridWidth-2*a,i.translateX=i.translateX+this.gridPad.left+this.xPadLeft+(a>0?a+4:0),i.translateY=i.translateY+this.gridPad.top}},{key:"setDimensionsForAxisCharts",value:function(){var t=this,e=this.w,i=e.globals,a=this.dimYAxis.getyAxisLabelsCoords(),s=this.dimYAxis.getyAxisTitleCoords();e.globals.yLabelsCoords=[],e.globals.yTitleCoords=[],e.config.yaxis.map((function(t,i){e.globals.yLabelsCoords.push({width:a[i].width,index:i}),e.globals.yTitleCoords.push({width:s[i].width,index:i})})),this.yAxisWidth=this.dimYAxis.getTotalYAxisWidth();var r=this.dimXAxis.getxAxisLabelsCoords(),o=this.dimXAxis.getxAxisGroupLabelsCoords(),n=this.dimXAxis.getxAxisTitleCoords();this.conditionalChecksForAxisCoords(r,n,o),i.translateXAxisY=e.globals.rotateXLabels?this.xAxisHeight/8:-4,i.translateXAxisX=e.globals.rotateXLabels&&e.globals.isXNumeric&&e.config.xaxis.labels.rotate<=-45?-this.xAxisWidth/4:0,e.globals.isBarHorizontal&&(i.rotateXLabels=!1,i.translateXAxisY=parseInt(e.config.xaxis.labels.style.fontSize,10)/1.5*-1),i.translateXAxisY=i.translateXAxisY+e.config.xaxis.labels.offsetY,i.translateXAxisX=i.translateXAxisX+e.config.xaxis.labels.offsetX;var l=this.yAxisWidth,h=this.xAxisHeight;i.xAxisLabelsHeight=this.xAxisHeight-n.height,i.xAxisGroupLabelsHeight=i.xAxisLabelsHeight-r.height,i.xAxisLabelsWidth=this.xAxisWidth,i.xAxisHeight=this.xAxisHeight;var c=10;("radar"===e.config.chart.type||this.isSparkline)&&(l=0,h=i.goldenPadding),this.isSparkline&&(this.lgRect={height:0,width:0}),(this.isSparkline||"treemap"===e.config.chart.type)&&(l=0,h=0,c=0),this.isSparkline||this.dimXAxis.additionalPaddingXLabels(r);var d=function(){i.translateX=l,i.gridHeight=i.svgHeight-t.lgRect.height-h-(t.isSparkline||"treemap"===e.config.chart.type?0:e.globals.rotateXLabels?10:15),i.gridWidth=i.svgWidth-l};switch("top"===e.config.xaxis.position&&(c=i.xAxisHeight-e.config.xaxis.axisTicks.height-5),e.config.legend.position){case"bottom":i.translateY=c,d();break;case"top":i.translateY=this.lgRect.height+c,d();break;case"left":i.translateY=c,i.translateX=this.lgRect.width+l,i.gridHeight=i.svgHeight-h-12,i.gridWidth=i.svgWidth-this.lgRect.width-l;break;case"right":i.translateY=c,i.translateX=l,i.gridHeight=i.svgHeight-h-12,i.gridWidth=i.svgWidth-this.lgRect.width-l-5;break;default:throw new Error("Legend position not supported")}this.dimGrid.setGridXPosForDualYAxis(s,a),new q(this.ctx).setYAxisXPosition(a,s)}},{key:"setDimensionsForNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=t.config,a=0;t.config.legend.show&&!t.config.legend.floating&&(a=20);var s="pie"===i.chart.type||"polarArea"===i.chart.type||"donut"===i.chart.type?"pie":"radialBar",r=i.plotOptions[s].offsetY,o=i.plotOptions[s].offsetX;if(!i.legend.show||i.legend.floating)return e.gridHeight=e.svgHeight-i.grid.padding.left+i.grid.padding.right,e.gridWidth=e.gridHeight,e.translateY=r,void(e.translateX=o+(e.svgWidth-e.gridWidth)/2);switch(i.legend.position){case"bottom":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=r-10,e.translateX=o+(e.svgWidth-e.gridWidth)/2;break;case"top":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=this.lgRect.height+r+10,e.translateX=o+(e.svgWidth-e.gridWidth)/2;break;case"left":e.gridWidth=e.svgWidth-this.lgRect.width-a,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=r,e.translateX=o+this.lgRect.width+a;break;case"right":e.gridWidth=e.svgWidth-this.lgRect.width-a-5,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=r,e.translateX=o+10;break;default:throw new Error("Legend position not supported")}}},{key:"conditionalChecksForAxisCoords",value:function(t,e,i){var a=this.w,s=a.globals.hasXaxisGroups?2:1,r=i.height+t.height+e.height,o=a.globals.isMultiLineX?1.2:a.globals.LINE_HEIGHT_RATIO,n=a.globals.rotateXLabels?22:10,l=a.globals.rotateXLabels&&"bottom"===a.config.legend.position?10:0;this.xAxisHeight=r*o+s*n+l,this.xAxisWidth=t.width,this.xAxisHeight-e.height>a.config.xaxis.labels.maxHeight&&(this.xAxisHeight=a.config.xaxis.labels.maxHeight),a.config.xaxis.labels.minHeight&&this.xAxisHeightc&&(this.yAxisWidth=c)}}]),t}(),nt=function(){function t(e){a(this,t),this.w=e.w,this.lgCtx=e}return r(t,[{key:"getLegendStyles",value:function(){var t=document.createElement("style");t.setAttribute("type","text/css");var e=document.createTextNode("\t\n \t\n .apexcharts-legend {\t\n display: flex;\t\n overflow: auto;\t\n padding: 0 10px;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom, .apexcharts-legend.apx-legend-position-top {\t\n flex-wrap: wrap\t\n }\t\n .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n flex-direction: column;\t\n bottom: 0;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-left, .apexcharts-legend.apx-legend-position-top.apexcharts-align-left, .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n justify-content: flex-start;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-center, .apexcharts-legend.apx-legend-position-top.apexcharts-align-center {\t\n justify-content: center; \t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-right, .apexcharts-legend.apx-legend-position-top.apexcharts-align-right {\t\n justify-content: flex-end;\t\n }\t\n .apexcharts-legend-series {\t\n cursor: pointer;\t\n line-height: normal;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom .apexcharts-legend-series, .apexcharts-legend.apx-legend-position-top .apexcharts-legend-series{\t\n display: flex;\t\n align-items: center;\t\n }\t\n .apexcharts-legend-text {\t\n position: relative;\t\n font-size: 14px;\t\n }\t\n .apexcharts-legend-text *, .apexcharts-legend-marker * {\t\n pointer-events: none;\t\n }\t\n .apexcharts-legend-marker {\t\n position: relative;\t\n display: inline-block;\t\n cursor: pointer;\t\n margin-right: 3px;\t\n border-style: solid;\n }\t\n \t\n .apexcharts-legend.apexcharts-align-right .apexcharts-legend-series, .apexcharts-legend.apexcharts-align-left .apexcharts-legend-series{\t\n display: inline-block;\t\n }\t\n .apexcharts-legend-series.apexcharts-no-click {\t\n cursor: auto;\t\n }\t\n .apexcharts-legend .apexcharts-hidden-zero-series, .apexcharts-legend .apexcharts-hidden-null-series {\t\n display: none !important;\t\n }\t\n .apexcharts-inactive-legend {\t\n opacity: 0.45;\t\n }");return t.appendChild(e),t}},{key:"getLegendBBox",value:function(){var t=this.w.globals.dom.baseEl.querySelector(".apexcharts-legend").getBoundingClientRect(),e=t.width;return{clwh:t.height,clww:e}}},{key:"appendToForeignObject",value:function(){this.w.globals.dom.elLegendForeign.appendChild(this.getLegendStyles())}},{key:"toggleDataSeries",value:function(t,e){var i=this,a=this.w;if(a.globals.axisCharts||"radialBar"===a.config.chart.type){a.globals.resized=!0;var s=null,r=null;if(a.globals.risingSeries=[],a.globals.axisCharts?(s=a.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(t,"']")),r=parseInt(s.getAttribute("data:realIndex"),10)):(s=a.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(t+1,"']")),r=parseInt(s.getAttribute("rel"),10)-1),e)[{cs:a.globals.collapsedSeries,csi:a.globals.collapsedSeriesIndices},{cs:a.globals.ancillaryCollapsedSeries,csi:a.globals.ancillaryCollapsedSeriesIndices}].forEach((function(t){i.riseCollapsedSeries(t.cs,t.csi,r)}));else this.hideSeries({seriesEl:s,realIndex:r})}else{var o=a.globals.dom.Paper.select(" .apexcharts-series[rel='".concat(t+1,"'] path")),n=a.config.chart.type;if("pie"===n||"polarArea"===n||"donut"===n){var l=a.config.plotOptions.pie.donut.labels;new m(this.lgCtx.ctx).pathMouseDown(o.members[0],null),this.lgCtx.ctx.pie.printDataLabelsInner(o.members[0].node,l)}o.fire("click")}}},{key:"hideSeries",value:function(t){var e=t.seriesEl,i=t.realIndex,a=this.w,s=x.clone(a.config.series);if(a.globals.axisCharts){var r=!1;if(a.config.yaxis[i]&&a.config.yaxis[i].show&&a.config.yaxis[i].showAlways&&(r=!0,a.globals.ancillaryCollapsedSeriesIndices.indexOf(i)<0&&(a.globals.ancillaryCollapsedSeries.push({index:i,data:s[i].data.slice(),type:e.parentNode.className.baseVal.split("-")[1]}),a.globals.ancillaryCollapsedSeriesIndices.push(i))),!r){a.globals.collapsedSeries.push({index:i,data:s[i].data.slice(),type:e.parentNode.className.baseVal.split("-")[1]}),a.globals.collapsedSeriesIndices.push(i);var o=a.globals.risingSeries.indexOf(i);a.globals.risingSeries.splice(o,1)}}else a.globals.collapsedSeries.push({index:i,data:s[i]}),a.globals.collapsedSeriesIndices.push(i);for(var n=e.childNodes,l=0;l0){for(var r=0;r-1&&(t[a].data=[])})):t.forEach((function(i,a){e.globals.collapsedSeriesIndices.indexOf(a)>-1&&(t[a]=0)})),t}}]),t}(),lt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.onLegendClick=this.onLegendClick.bind(this),this.onLegendHovered=this.onLegendHovered.bind(this),this.isBarsDistributed="bar"===this.w.config.chart.type&&this.w.config.plotOptions.bar.distributed&&1===this.w.config.series.length,this.legendHelpers=new nt(this)}return r(t,[{key:"init",value:function(){var t=this.w,e=t.globals,i=t.config;if((i.legend.showForSingleSeries&&1===e.series.length||this.isBarsDistributed||e.series.length>1||!e.axisCharts)&&i.legend.show){for(;e.dom.elLegendWrap.firstChild;)e.dom.elLegendWrap.removeChild(e.dom.elLegendWrap.firstChild);this.drawLegends(),x.isIE11()?document.getElementsByTagName("head")[0].appendChild(this.legendHelpers.getLegendStyles()):this.legendHelpers.appendToForeignObject(),"bottom"===i.legend.position||"top"===i.legend.position?this.legendAlignHorizontal():"right"!==i.legend.position&&"left"!==i.legend.position||this.legendAlignVertical()}}},{key:"drawLegends",value:function(){var t=this,e=this.w,i=e.config.legend.fontFamily,a=e.globals.seriesNames,s=e.globals.colors.slice();if("heatmap"===e.config.chart.type){var r=e.config.plotOptions.heatmap.colorScale.ranges;a=r.map((function(t){return t.name?t.name:t.from+" - "+t.to})),s=r.map((function(t){return t.color}))}else this.isBarsDistributed&&(a=e.globals.labels.slice());e.config.legend.customLegendItems.length&&(a=e.config.legend.customLegendItems);for(var o=e.globals.legendFormatter,n=e.config.legend.inverseOrder,l=n?a.length-1:0;n?l>=0:l<=a.length-1;n?l--:l++){var h=o(a[l],{seriesIndex:l,w:e}),c=!1,d=!1;if(e.globals.collapsedSeries.length>0)for(var g=0;g0)for(var u=0;u0?l-10:0)+(h>0?h-10:0)}a.style.position="absolute",r=r+t+i.config.legend.offsetX,o=o+e+i.config.legend.offsetY,a.style.left=r+"px",a.style.top=o+"px","bottom"===i.config.legend.position?(a.style.top="auto",a.style.bottom=5-i.config.legend.offsetY+"px"):"right"===i.config.legend.position&&(a.style.left="auto",a.style.right=25+i.config.legend.offsetX+"px");["width","height"].forEach((function(t){a.style[t]&&(a.style[t]=parseInt(i.config.legend[t],10)+"px")}))}},{key:"legendAlignHorizontal",value:function(){var t=this.w;t.globals.dom.elLegendWrap.style.right=0;var e=this.legendHelpers.getLegendBBox(),i=new ot(this.ctx),a=i.dimHelpers.getTitleSubtitleCoords("title"),s=i.dimHelpers.getTitleSubtitleCoords("subtitle"),r=0;"bottom"===t.config.legend.position?r=-e.clwh/1.8:"top"===t.config.legend.position&&(r=a.height+s.height+t.config.title.margin+t.config.subtitle.margin-10),this.setLegendWrapXY(20,r)}},{key:"legendAlignVertical",value:function(){var t=this.w,e=this.legendHelpers.getLegendBBox(),i=0;"left"===t.config.legend.position&&(i=20),"right"===t.config.legend.position&&(i=t.globals.svgWidth-e.clww-10),this.setLegendWrapXY(i,20)}},{key:"onLegendHovered",value:function(t){var e=this.w,i=t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker");if("heatmap"===e.config.chart.type||this.isBarsDistributed){if(i){var a=parseInt(t.target.getAttribute("rel"),10)-1;this.ctx.events.fireEvent("legendHover",[this.ctx,a,this.w]),new N(this.ctx).highlightRangeInSeries(t,t.target)}}else!t.target.classList.contains("apexcharts-inactive-legend")&&i&&new N(this.ctx).toggleSeriesOnHover(t,t.target)}},{key:"onLegendClick",value:function(t){var e=this.w;if(!e.config.legend.customLegendItems.length&&(t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker"))){var i=parseInt(t.target.getAttribute("rel"),10)-1,a="true"===t.target.getAttribute("data:collapsed"),s=this.w.config.chart.events.legendClick;"function"==typeof s&&s(this.ctx,i,this.w),this.ctx.events.fireEvent("legendClick",[this.ctx,i,this.w]);var r=this.w.config.legend.markers.onClick;"function"==typeof r&&t.target.classList.contains("apexcharts-legend-marker")&&(r(this.ctx,i,this.w),this.ctx.events.fireEvent("legendMarkerClick",[this.ctx,i,this.w])),"treemap"!==e.config.chart.type&&"heatmap"!==e.config.chart.type&&!this.isBarsDistributed&&e.config.legend.onItemClick.toggleDataSeries&&this.legendHelpers.toggleDataSeries(i,a)}}}]),t}(),ht=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w;var i=this.w;this.ev=this.w.config.chart.events,this.selectedClass="apexcharts-selected",this.localeValues=this.w.globals.locale.toolbar,this.minX=i.globals.minX,this.maxX=i.globals.maxX}return r(t,[{key:"createToolbar",value:function(){var t=this,e=this.w,i=function(){return document.createElement("div")},a=i();if(a.setAttribute("class","apexcharts-toolbar"),a.style.top=e.config.chart.toolbar.offsetY+"px",a.style.right=3-e.config.chart.toolbar.offsetX+"px",e.globals.dom.elWrap.appendChild(a),this.elZoom=i(),this.elZoomIn=i(),this.elZoomOut=i(),this.elPan=i(),this.elSelection=i(),this.elZoomReset=i(),this.elMenuIcon=i(),this.elMenu=i(),this.elCustomIcons=[],this.t=e.config.chart.toolbar.tools,Array.isArray(this.t.customIcons))for(var s=0;s\n \n \n\n'),o("zoomOut",this.elZoomOut,'\n \n \n\n');var n=function(i){t.t[i]&&e.config.chart[i].enabled&&r.push({el:"zoom"===i?t.elZoom:t.elSelection,icon:"string"==typeof t.t[i]?t.t[i]:"zoom"===i?'\n \n \n \n':'\n \n \n',title:t.localeValues["zoom"===i?"selectionZoom":"selection"],class:e.globals.isTouchDevice?"apexcharts-element-hidden":"apexcharts-".concat(i,"-icon")})};n("zoom"),n("selection"),this.t.pan&&e.config.chart.zoom.enabled&&r.push({el:this.elPan,icon:"string"==typeof this.t.pan?this.t.pan:'\n \n \n \n \n \n \n \n',title:this.localeValues.pan,class:e.globals.isTouchDevice?"apexcharts-element-hidden":"apexcharts-pan-icon"}),o("reset",this.elZoomReset,'\n \n \n'),this.t.download&&r.push({el:this.elMenuIcon,icon:"string"==typeof this.t.download?this.t.download:'',title:this.localeValues.menu,class:"apexcharts-menu-icon"});for(var l=0;l0&&e.height>0&&this.slDraggableRect.selectize({points:"l, r",pointSize:8,pointType:"rect"}).resize({constraint:{minX:0,minY:0,maxX:t.globals.gridWidth,maxY:t.globals.gridHeight}}).on("resizing",this.selectionDragging.bind(this,"resizing"))}}},{key:"preselectedSelection",value:function(){var t=this.w,e=this.xyRatios;if(!t.globals.zoomEnabled)if(void 0!==t.globals.selection&&null!==t.globals.selection)this.drawSelectionRect(t.globals.selection);else if(void 0!==t.config.chart.selection.xaxis.min&&void 0!==t.config.chart.selection.xaxis.max){var i=(t.config.chart.selection.xaxis.min-t.globals.minX)/e.xRatio,a={x:i,y:0,width:t.globals.gridWidth-(t.globals.maxX-t.config.chart.selection.xaxis.max)/e.xRatio-i,height:t.globals.gridHeight,translateX:0,translateY:0,selectionEnabled:!0};this.drawSelectionRect(a),this.makeSelectionRectDraggable(),"function"==typeof t.config.chart.events.selection&&t.config.chart.events.selection(this.ctx,{xaxis:{min:t.config.chart.selection.xaxis.min,max:t.config.chart.selection.xaxis.max},yaxis:{}})}}},{key:"drawSelectionRect",value:function(t){var e=t.x,i=t.y,a=t.width,s=t.height,r=t.translateX,o=void 0===r?0:r,n=t.translateY,l=void 0===n?0:n,h=this.w,c=this.zoomRect,d=this.selectionRect;if(this.dragged||null!==h.globals.selection){var g={transform:"translate("+o+", "+l+")"};h.globals.zoomEnabled&&this.dragged&&(a<0&&(a=1),c.attr({x:e,y:i,width:a,height:s,fill:h.config.chart.zoom.zoomedArea.fill.color,"fill-opacity":h.config.chart.zoom.zoomedArea.fill.opacity,stroke:h.config.chart.zoom.zoomedArea.stroke.color,"stroke-width":h.config.chart.zoom.zoomedArea.stroke.width,"stroke-opacity":h.config.chart.zoom.zoomedArea.stroke.opacity}),m.setAttrs(c.node,g)),h.globals.selectionEnabled&&(d.attr({x:e,y:i,width:a>0?a:0,height:s>0?s:0,fill:h.config.chart.selection.fill.color,"fill-opacity":h.config.chart.selection.fill.opacity,stroke:h.config.chart.selection.stroke.color,"stroke-width":h.config.chart.selection.stroke.width,"stroke-dasharray":h.config.chart.selection.stroke.dashArray,"stroke-opacity":h.config.chart.selection.stroke.opacity}),m.setAttrs(d.node,g))}}},{key:"hideSelectionRect",value:function(t){t&&t.attr({x:0,y:0,width:0,height:0})}},{key:"selectionDrawing",value:function(t){var e=t.context,i=t.zoomtype,a=this.w,s=e,r=this.gridRect.getBoundingClientRect(),o=s.startX-1,n=s.startY,l=!1,h=!1,c=s.clientX-r.left-o,d=s.clientY-r.top-n,g={};return Math.abs(c+o)>a.globals.gridWidth?c=a.globals.gridWidth-o:s.clientX-r.left<0&&(c=o),o>s.clientX-r.left&&(l=!0,c=Math.abs(c)),n>s.clientY-r.top&&(h=!0,d=Math.abs(d)),g="x"===i?{x:l?o-c:o,y:0,width:c,height:a.globals.gridHeight}:"y"===i?{x:0,y:h?n-d:n,width:a.globals.gridWidth,height:d}:{x:l?o-c:o,y:h?n-d:n,width:c,height:d},s.drawSelectionRect(g),s.selectionDragging("resizing"),g}},{key:"selectionDragging",value:function(t,e){var i=this,a=this.w,s=this.xyRatios,r=this.selectionRect,o=0;"resizing"===t&&(o=30);var n=function(t){return parseFloat(r.node.getAttribute(t))},l={x:n("x"),y:n("y"),width:n("width"),height:n("height")};a.globals.selection=l,"function"==typeof a.config.chart.events.selection&&a.globals.selectionEnabled&&(clearTimeout(this.w.globals.selectionResizeTimer),this.w.globals.selectionResizeTimer=window.setTimeout((function(){var t=i.gridRect.getBoundingClientRect(),e=r.node.getBoundingClientRect(),o={xaxis:{min:a.globals.xAxisScale.niceMin+(e.left-t.left)*s.xRatio,max:a.globals.xAxisScale.niceMin+(e.right-t.left)*s.xRatio},yaxis:{min:a.globals.yAxisScale[0].niceMin+(t.bottom-e.bottom)*s.yRatio[0],max:a.globals.yAxisScale[0].niceMax-(e.top-t.top)*s.yRatio[0]}};a.config.chart.events.selection(i.ctx,o),a.config.chart.brush.enabled&&void 0!==a.config.chart.events.brushScrolled&&a.config.chart.events.brushScrolled(i.ctx,o)}),o))}},{key:"selectionDrawn",value:function(t){var e=t.context,i=t.zoomtype,a=this.w,s=e,r=this.xyRatios,o=this.ctx.toolbar;if(s.startX>s.endX){var n=s.startX;s.startX=s.endX,s.endX=n}if(s.startY>s.endY){var l=s.startY;s.startY=s.endY,s.endY=l}var h=void 0,c=void 0;a.globals.isRangeBar?(h=a.globals.yAxisScale[0].niceMin+s.startX*r.invertedYRatio,c=a.globals.yAxisScale[0].niceMin+s.endX*r.invertedYRatio):(h=a.globals.xAxisScale.niceMin+s.startX*r.xRatio,c=a.globals.xAxisScale.niceMin+s.endX*r.xRatio);var d=[],g=[];if(a.config.yaxis.forEach((function(t,e){d.push(a.globals.yAxisScale[e].niceMax-r.yRatio[e]*s.startY),g.push(a.globals.yAxisScale[e].niceMax-r.yRatio[e]*s.endY)})),s.dragged&&(s.dragX>10||s.dragY>10)&&h!==c)if(a.globals.zoomEnabled){var u=x.clone(a.globals.initialConfig.yaxis),p=x.clone(a.globals.initialConfig.xaxis);if(a.globals.zoomed=!0,a.config.xaxis.convertedCatToNumeric&&(h=Math.floor(h),c=Math.floor(c),h<1&&(h=1,c=a.globals.dataPoints),c-h<2&&(c=h+1)),"xy"!==i&&"x"!==i||(p={min:h,max:c}),"xy"!==i&&"y"!==i||u.forEach((function(t,e){u[e].min=g[e],u[e].max=d[e]})),a.config.chart.zoom.autoScaleYaxis){var f=new _(s.ctx);u=f.autoScaleY(s.ctx,u,{xaxis:p})}if(o){var b=o.getBeforeZoomRange(p,u);b&&(p=b.xaxis?b.xaxis:p,u=b.yaxis?b.yaxis:u)}var v={xaxis:p};a.config.chart.group||(v.yaxis=u),s.ctx.updateHelpers._updateOptions(v,!1,s.w.config.chart.animations.dynamicAnimation.enabled),"function"==typeof a.config.chart.events.zoomed&&o.zoomCallback(p,u)}else if(a.globals.selectionEnabled){var m,y=null;m={min:h,max:c},"xy"!==i&&"y"!==i||(y=x.clone(a.config.yaxis)).forEach((function(t,e){y[e].min=g[e],y[e].max=d[e]})),a.globals.selection=s.selection,"function"==typeof a.config.chart.events.selection&&a.config.chart.events.selection(s.ctx,{xaxis:m,yaxis:y})}}},{key:"panDragging",value:function(t){var e=t.context,i=this.w,a=e;if(void 0!==i.globals.lastClientPosition.x){var s=i.globals.lastClientPosition.x-a.clientX,r=i.globals.lastClientPosition.y-a.clientY;Math.abs(s)>Math.abs(r)&&s>0?this.moveDirection="left":Math.abs(s)>Math.abs(r)&&s<0?this.moveDirection="right":Math.abs(r)>Math.abs(s)&&r>0?this.moveDirection="up":Math.abs(r)>Math.abs(s)&&r<0&&(this.moveDirection="down")}i.globals.lastClientPosition={x:a.clientX,y:a.clientY};var o=i.globals.isRangeBar?i.globals.minY:i.globals.minX,n=i.globals.isRangeBar?i.globals.maxY:i.globals.maxX;i.config.xaxis.convertedCatToNumeric||a.panScrolled(o,n)}},{key:"delayedPanScrolled",value:function(){var t=this.w,e=t.globals.minX,i=t.globals.maxX,a=(t.globals.maxX-t.globals.minX)/2;"left"===this.moveDirection?(e=t.globals.minX+a,i=t.globals.maxX+a):"right"===this.moveDirection&&(e=t.globals.minX-a,i=t.globals.maxX-a),e=Math.floor(e),i=Math.floor(i),this.updateScrolledChart({xaxis:{min:e,max:i}},e,i)}},{key:"panScrolled",value:function(t,e){var i=this.w,a=this.xyRatios,s=x.clone(i.globals.initialConfig.yaxis),r=a.xRatio,o=i.globals.minX,n=i.globals.maxX;i.globals.isRangeBar&&(r=a.invertedYRatio,o=i.globals.minY,n=i.globals.maxY),"left"===this.moveDirection?(t=o+i.globals.gridWidth/15*r,e=n+i.globals.gridWidth/15*r):"right"===this.moveDirection&&(t=o-i.globals.gridWidth/15*r,e=n-i.globals.gridWidth/15*r),i.globals.isRangeBar||(ti.globals.initialMaxX)&&(t=o,e=n);var l={min:t,max:e};i.config.chart.zoom.autoScaleYaxis&&(s=new _(this.ctx).autoScaleY(this.ctx,s,{xaxis:l}));var h={xaxis:{min:t,max:e}};i.config.chart.group||(h.yaxis=s),this.updateScrolledChart(h,t,e)}},{key:"updateScrolledChart",value:function(t,e,i){var a=this.w;this.ctx.updateHelpers._updateOptions(t,!1,!1),"function"==typeof a.config.chart.events.scrolled&&a.config.chart.events.scrolled(this.ctx,{xaxis:{min:e,max:i}})}}]),i}(),dt=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e,this.ctx=e.ctx}return r(t,[{key:"getNearestValues",value:function(t){var e=t.hoverArea,i=t.elGrid,a=t.clientX,s=t.clientY,r=this.w,o=i.getBoundingClientRect(),n=o.width,l=o.height,h=n/(r.globals.dataPoints-1),c=l/r.globals.dataPoints,d=this.hasBars();!r.globals.comboCharts&&!d||r.config.xaxis.convertedCatToNumeric||(h=n/r.globals.dataPoints);var g=a-o.left-r.globals.barPadForNumericAxis,u=s-o.top;g<0||u<0||g>n||u>l?(e.classList.remove("hovering-zoom"),e.classList.remove("hovering-pan")):r.globals.zoomEnabled?(e.classList.remove("hovering-pan"),e.classList.add("hovering-zoom")):r.globals.panEnabled&&(e.classList.remove("hovering-zoom"),e.classList.add("hovering-pan"));var p=Math.round(g/h),f=Math.floor(u/c);d&&!r.config.xaxis.convertedCatToNumeric&&(p=Math.ceil(g/h),p-=1);var b=null,v=null,m=[],y=[];if(r.globals.seriesXvalues.forEach((function(t){m.push([t[0]+1e-6].concat(t))})),r.globals.seriesYvalues.forEach((function(t){y.push([t[0]+1e-6].concat(t))})),m=m.map((function(t){return t.filter((function(t){return x.isNumber(t)}))})),y=y.map((function(t){return t.filter((function(t){return x.isNumber(t)}))})),r.globals.isXNumeric){var w=this.ttCtx.getElGrid().getBoundingClientRect(),k=g*(w.width/n),A=u*(w.height/l);b=(v=this.closestInMultiArray(k,A,m,y)).index,p=v.j,null!==b&&(m=r.globals.seriesXvalues[b],p=(v=this.closestInArray(k,m)).index)}return r.globals.capturedSeriesIndex=null===b?-1:b,(!p||p<1)&&(p=0),r.globals.isBarHorizontal?r.globals.capturedDataPointIndex=f:r.globals.capturedDataPointIndex=p,{capturedSeries:b,j:r.globals.isBarHorizontal?f:p,hoverX:g,hoverY:u}}},{key:"closestInMultiArray",value:function(t,e,i,a){var s=this.w,r=0,o=null,n=-1;s.globals.series.length>1?r=this.getFirstActiveXArray(i):o=0;var l=i[r][0],h=Math.abs(t-l);if(i.forEach((function(e){e.forEach((function(e,i){var a=Math.abs(t-e);a0?e:-1})),s=0;s0)for(var a=0;a *")):this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap > *")}},{key:"getAllMarkers",value:function(){var t=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap");(t=u(t)).sort((function(t,e){var i=Number(t.getAttribute("data:realIndex")),a=Number(e.getAttribute("data:realIndex"));return ai?-1:0}));var e=[];return t.forEach((function(t){e.push(t.querySelector(".apexcharts-marker"))})),e}},{key:"hasMarkers",value:function(t){return this.getElMarkers(t).length>0}},{key:"getElBars",value:function(){return this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-bar-series, .apexcharts-candlestick-series, .apexcharts-boxPlot-series, .apexcharts-rangebar-series")}},{key:"hasBars",value:function(){return this.getElBars().length>0}},{key:"getHoverMarkerSize",value:function(t){var e=this.w,i=e.config.markers.hover.size;return void 0===i&&(i=e.globals.markers.size[t]+e.config.markers.hover.sizeOffset),i}},{key:"toggleAllTooltipSeriesGroups",value:function(t){var e=this.w,i=this.ttCtx;0===i.allTooltipSeriesGroups.length&&(i.allTooltipSeriesGroups=e.globals.dom.baseEl.querySelectorAll(".apexcharts-tooltip-series-group"));for(var a=i.allTooltipSeriesGroups,s=0;s ').concat(i.attrs.name,""),e+="
".concat(i.val,"
")})),v.innerHTML=t+"",m.innerHTML=e+""};o?l.globals.seriesGoals[e][i]&&Array.isArray(l.globals.seriesGoals[e][i])?y():(v.innerHTML="",m.innerHTML=""):y()}else v.innerHTML="",m.innerHTML="";null!==p&&(a[e].querySelector(".apexcharts-tooltip-text-z-label").innerHTML=l.config.tooltip.z.title,a[e].querySelector(".apexcharts-tooltip-text-z-value").innerHTML=void 0!==p?p:"");o&&f[0]&&(null==c||l.globals.ancillaryCollapsedSeriesIndices.indexOf(e)>-1||l.globals.collapsedSeriesIndices.indexOf(e)>-1?f[0].parentNode.style.display="none":f[0].parentNode.style.display=l.config.tooltip.items.display)}},{key:"toggleActiveInactiveSeries",value:function(t){var e=this.w;if(t)this.tooltipUtil.toggleAllTooltipSeriesGroups("enable");else{this.tooltipUtil.toggleAllTooltipSeriesGroups("disable");var i=e.globals.dom.baseEl.querySelector(".apexcharts-tooltip-series-group");i&&(i.classList.add("apexcharts-active"),i.style.display=e.config.tooltip.items.display)}}},{key:"getValuesToPrint",value:function(t){var e=t.i,i=t.j,a=this.w,s=this.ctx.series.filteredSeriesX(),r="",o="",n=null,l=null,h={series:a.globals.series,seriesIndex:e,dataPointIndex:i,w:a},c=a.globals.ttZFormatter;null===i?l=a.globals.series[e]:a.globals.isXNumeric&&"treemap"!==a.config.chart.type?(r=s[e][i],0===s[e].length&&(r=s[this.tooltipUtil.getFirstActiveXArray(s)][i])):r=void 0!==a.globals.labels[i]?a.globals.labels[i]:"";var d=r;a.globals.isXNumeric&&"datetime"===a.config.xaxis.type?r=new T(this.ctx).xLabelFormat(a.globals.ttKeyFormatter,d,d,{i:void 0,dateFormatter:new I(this.ctx).formatDate,w:this.w}):r=a.globals.isBarHorizontal?a.globals.yLabelFormatters[0](d,h):a.globals.xLabelFormatter(d,h);return void 0!==a.config.tooltip.x.formatter&&(r=a.globals.ttKeyFormatter(d,h)),a.globals.seriesZ.length>0&&a.globals.seriesZ[e].length>0&&(n=c(a.globals.seriesZ[e][i],a)),o="function"==typeof a.config.xaxis.tooltip.formatter?a.globals.xaxisTooltipFormatter(d,h):r,{val:Array.isArray(l)?l.join(" "):l,xVal:Array.isArray(r)?r.join(" "):r,xAxisTTVal:Array.isArray(o)?o.join(" "):o,zVal:n}}},{key:"handleCustomTooltip",value:function(t){var e=t.i,i=t.j,a=t.y1,s=t.y2,r=t.w,o=this.ttCtx.getElTooltip(),n=r.config.tooltip.custom;Array.isArray(n)&&n[e]&&(n=n[e]),o.innerHTML=n({ctx:this.ctx,series:r.globals.series,seriesIndex:e,dataPointIndex:i,y1:a,y2:s,w:r})}}]),t}(),ut=function(){function t(e){a(this,t),this.ttCtx=e,this.ctx=e.ctx,this.w=e.w}return r(t,[{key:"moveXCrosshairs",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=this.ttCtx,a=this.w,s=i.getElXCrosshairs(),r=t-i.xcrosshairsWidth/2,o=a.globals.labels.slice().length;if(null!==e&&(r=a.globals.gridWidth/o*e),null===s||a.globals.isBarHorizontal||(s.setAttribute("x",r),s.setAttribute("x1",r),s.setAttribute("x2",r),s.setAttribute("y2",a.globals.gridHeight),s.classList.add("apexcharts-active")),r<0&&(r=0),r>a.globals.gridWidth&&(r=a.globals.gridWidth),i.isXAxisTooltipEnabled){var n=r;"tickWidth"!==a.config.xaxis.crosshairs.width&&"barWidth"!==a.config.xaxis.crosshairs.width||(n=r+i.xcrosshairsWidth/2),this.moveXAxisTooltip(n)}}},{key:"moveYCrosshairs",value:function(t){var e=this.ttCtx;null!==e.ycrosshairs&&m.setAttrs(e.ycrosshairs,{y1:t,y2:t}),null!==e.ycrosshairsHidden&&m.setAttrs(e.ycrosshairsHidden,{y1:t,y2:t})}},{key:"moveXAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;if(null!==i.xaxisTooltip&&0!==i.xcrosshairsWidth){i.xaxisTooltip.classList.add("apexcharts-active");var a=i.xaxisOffY+e.config.xaxis.tooltip.offsetY+e.globals.translateY+1+e.config.xaxis.offsetY;if(t-=i.xaxisTooltip.getBoundingClientRect().width/2,!isNaN(t)){t+=e.globals.translateX;var s;s=new m(this.ctx).getTextRects(i.xaxisTooltipText.innerHTML),i.xaxisTooltipText.style.minWidth=s.width+"px",i.xaxisTooltip.style.left=t+"px",i.xaxisTooltip.style.top=a+"px"}}}},{key:"moveYAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;null===i.yaxisTTEls&&(i.yaxisTTEls=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxistooltip"));var a=parseInt(i.ycrosshairsHidden.getAttribute("y1"),10),s=e.globals.translateY+a,r=i.yaxisTTEls[t].getBoundingClientRect().height,o=e.globals.translateYAxisX[t]-2;e.config.yaxis[t].opposite&&(o-=26),s-=r/2,-1===e.globals.ignoreYAxisIndexes.indexOf(t)?(i.yaxisTTEls[t].classList.add("apexcharts-active"),i.yaxisTTEls[t].style.top=s+"px",i.yaxisTTEls[t].style.left=o+e.config.yaxis[t].tooltip.offsetX+"px"):i.yaxisTTEls[t].classList.remove("apexcharts-active")}},{key:"moveTooltip",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,s=this.ttCtx,r=s.getElTooltip(),o=s.tooltipRect,n=null!==i?parseFloat(i):1,l=parseFloat(t)+n+5,h=parseFloat(e)+n/2;if(l>a.globals.gridWidth/2&&(l=l-o.ttWidth-n-10),l>a.globals.gridWidth-o.ttWidth-10&&(l=a.globals.gridWidth-o.ttWidth),l<-20&&(l=-20),a.config.tooltip.followCursor){var c=s.getElGrid().getBoundingClientRect();(l=s.e.clientX-c.left)>a.globals.gridWidth/2&&(l-=s.tooltipRect.ttWidth),(h=s.e.clientY+a.globals.translateY-c.top)>a.globals.gridHeight/2&&(h-=s.tooltipRect.ttHeight)}else a.globals.isBarHorizontal||o.ttHeight/2+h>a.globals.gridHeight&&(h=a.globals.gridHeight-o.ttHeight+a.globals.translateY);isNaN(l)||(l+=a.globals.translateX,r.style.left=l+"px",r.style.top=h+"px")}},{key:"moveMarkers",value:function(t,e){var i=this.w,a=this.ttCtx;if(i.globals.markers.size[t]>0)for(var s=i.globals.dom.baseEl.querySelectorAll(" .apexcharts-series[data\\:realIndex='".concat(t,"'] .apexcharts-marker")),r=0;r0&&(h.setAttribute("r",n),h.setAttribute("cx",i),h.setAttribute("cy",a)),this.moveXCrosshairs(i),r.fixedTooltip||this.moveTooltip(i,a,n)}}},{key:"moveDynamicPointsOnHover",value:function(t){var e,i=this.ttCtx,a=i.w,s=0,r=0,o=a.globals.pointsArray;e=new N(this.ctx).getActiveConfigSeriesIndex("asc",["line","area","scatter","bubble"]);var n=i.tooltipUtil.getHoverMarkerSize(e);o[e]&&(s=o[e][t][0],r=o[e][t][1]);var l=i.tooltipUtil.getAllMarkers();if(null!==l)for(var h=0;h0?(l[h]&&l[h].setAttribute("r",n),l[h]&&l[h].setAttribute("cy",d)):l[h]&&l[h].setAttribute("r",0)}}this.moveXCrosshairs(s),i.fixedTooltip||this.moveTooltip(s,r||a.globals.gridHeight,n)}},{key:"moveStickyTooltipOverBars",value:function(t,e){var i=this.w,a=this.ttCtx,s=i.globals.columnSeries?i.globals.columnSeries.length:i.globals.series.length,r=s>=2&&s%2==0?Math.floor(s/2):Math.floor(s/2)+1;i.globals.isBarHorizontal&&(r=new N(this.ctx).getActiveConfigSeriesIndex("desc")+1);var o=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[rel='".concat(r,"'] path[j='").concat(t,"'], .apexcharts-candlestick-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"'], .apexcharts-boxPlot-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"'], .apexcharts-rangebar-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"']"));o||"number"!=typeof e||(o=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[data\\:realIndex='".concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-candlestick-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-boxPlot-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-rangebar-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"']")));var n=o?parseFloat(o.getAttribute("cx")):0,l=o?parseFloat(o.getAttribute("cy")):0,h=o?parseFloat(o.getAttribute("barWidth")):0,c=a.getElGrid().getBoundingClientRect(),d=o&&(o.classList.contains("apexcharts-candlestick-area")||o.classList.contains("apexcharts-boxPlot-area"));i.globals.isXNumeric?(o&&!d&&(n-=s%2!=0?h/2:0),o&&d&&i.globals.comboCharts&&(n-=h/2)):i.globals.isBarHorizontal||(n=a.xAxisTicksPositions[t-1]+a.dataPointsDividedWidth/2,isNaN(n)&&(n=a.xAxisTicksPositions[t]-a.dataPointsDividedWidth/2)),i.globals.isBarHorizontal?l-=a.tooltipRect.ttHeight:i.config.tooltip.followCursor?l=a.e.clientY-c.top-a.tooltipRect.ttHeight/2:l+a.tooltipRect.ttHeight+15>i.globals.gridHeight&&(l=i.globals.gridHeight),i.globals.isBarHorizontal||this.moveXCrosshairs(n),a.fixedTooltip||this.moveTooltip(n,l||i.globals.gridHeight)}}]),t}(),pt=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e,this.ctx=e.ctx,this.tooltipPosition=new ut(e)}return r(t,[{key:"drawDynamicPoints",value:function(){var t=this.w,e=new m(this.ctx),i=new D(this.ctx),a=t.globals.dom.baseEl.querySelectorAll(".apexcharts-series");a=u(a),t.config.chart.stacked&&a.sort((function(t,e){return parseFloat(t.getAttribute("data:realIndex"))-parseFloat(e.getAttribute("data:realIndex"))}));for(var s=0;s2&&void 0!==arguments[2]?arguments[2]:null,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.w;"bubble"!==s.config.chart.type&&this.newPointSize(t,e);var r=e.getAttribute("cx"),o=e.getAttribute("cy");if(null!==i&&null!==a&&(r=i,o=a),this.tooltipPosition.moveXCrosshairs(r),!this.fixedTooltip){if("radar"===s.config.chart.type){var n=this.ttCtx.getElGrid().getBoundingClientRect();r=this.ttCtx.e.clientX-n.left}this.tooltipPosition.moveTooltip(r,o,s.config.markers.hover.size)}}},{key:"enlargePoints",value:function(t){for(var e=this.w,i=this,a=this.ttCtx,s=t,r=e.globals.dom.baseEl.querySelectorAll(".apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker"),o=e.config.markers.hover.size,n=0;n=0?t[e].setAttribute("r",i):t[e].setAttribute("r",0)}}}]),t}(),ft=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e}return r(t,[{key:"getAttr",value:function(t,e){return parseFloat(t.target.getAttribute(e))}},{key:"handleHeatTreeTooltip",value:function(t){var e=t.e,i=t.opt,a=t.x,s=t.y,r=t.type,o=this.ttCtx,n=this.w;if(e.target.classList.contains("apexcharts-".concat(r,"-rect"))){var l=this.getAttr(e,"i"),h=this.getAttr(e,"j"),c=this.getAttr(e,"cx"),d=this.getAttr(e,"cy"),g=this.getAttr(e,"width"),u=this.getAttr(e,"height");if(o.tooltipLabels.drawSeriesTexts({ttItems:i.ttItems,i:l,j:h,shared:!1,e:e}),n.globals.capturedSeriesIndex=l,n.globals.capturedDataPointIndex=h,a=c+o.tooltipRect.ttWidth/2+g,s=d+o.tooltipRect.ttHeight/2-u/2,o.tooltipPosition.moveXCrosshairs(c+g/2),a>n.globals.gridWidth/2&&(a=c-o.tooltipRect.ttWidth/2+g),o.w.config.tooltip.followCursor){var p=n.globals.dom.elWrap.getBoundingClientRect();a=n.globals.clientX-p.left-(a>n.globals.gridWidth/2?o.tooltipRect.ttWidth:0),s=n.globals.clientY-p.top-(s>n.globals.gridHeight/2?o.tooltipRect.ttHeight:0)}}return{x:a,y:s}}},{key:"handleMarkerTooltip",value:function(t){var e,i,a=t.e,s=t.opt,r=t.x,o=t.y,n=this.w,l=this.ttCtx;if(a.target.classList.contains("apexcharts-marker")){var h=parseInt(s.paths.getAttribute("cx"),10),c=parseInt(s.paths.getAttribute("cy"),10),d=parseFloat(s.paths.getAttribute("val"));if(i=parseInt(s.paths.getAttribute("rel"),10),e=parseInt(s.paths.parentNode.parentNode.parentNode.getAttribute("rel"),10)-1,l.intersect){var g=x.findAncestor(s.paths,"apexcharts-series");g&&(e=parseInt(g.getAttribute("data:realIndex"),10))}if(l.tooltipLabels.drawSeriesTexts({ttItems:s.ttItems,i:e,j:i,shared:!l.showOnIntersect&&n.config.tooltip.shared,e:a}),"mouseup"===a.type&&l.markerClick(a,e,i),n.globals.capturedSeriesIndex=e,n.globals.capturedDataPointIndex=i,r=h,o=c+n.globals.translateY-1.4*l.tooltipRect.ttHeight,l.w.config.tooltip.followCursor){var u=l.getElGrid().getBoundingClientRect();o=l.e.clientY+n.globals.translateY-u.top}d<0&&(o=c),l.marker.enlargeCurrentPoint(i,s.paths,r,o)}return{x:r,y:o}}},{key:"handleBarTooltip",value:function(t){var e,i,a=t.e,s=t.opt,r=this.w,o=this.ttCtx,n=o.getElTooltip(),l=0,h=0,c=0,d=this.getBarTooltipXY({e:a,opt:s});e=d.i;var g=d.barHeight,u=d.j;r.globals.capturedSeriesIndex=e,r.globals.capturedDataPointIndex=u,r.globals.isBarHorizontal&&o.tooltipUtil.hasBars()||!r.config.tooltip.shared?(h=d.x,c=d.y,i=Array.isArray(r.config.stroke.width)?r.config.stroke.width[e]:r.config.stroke.width,l=h):r.globals.comboCharts||r.config.tooltip.shared||(l/=2),isNaN(c)&&(c=r.globals.svgHeight-o.tooltipRect.ttHeight);var p=parseInt(s.paths.parentNode.getAttribute("data:realIndex"),10),f=r.globals.isMultipleYAxis?r.config.yaxis[p]&&r.config.yaxis[p].reversed:r.config.yaxis[0].reversed;if(h+o.tooltipRect.ttWidth>r.globals.gridWidth&&!f?h-=o.tooltipRect.ttWidth:h<0&&(h=0),o.w.config.tooltip.followCursor){var x=o.getElGrid().getBoundingClientRect();c=o.e.clientY-x.top}null===o.tooltip&&(o.tooltip=r.globals.dom.baseEl.querySelector(".apexcharts-tooltip")),r.config.tooltip.shared||(r.globals.comboBarCount>0?o.tooltipPosition.moveXCrosshairs(l+i/2):o.tooltipPosition.moveXCrosshairs(l)),!o.fixedTooltip&&(!r.config.tooltip.shared||r.globals.isBarHorizontal&&o.tooltipUtil.hasBars())&&(f&&(h-=o.tooltipRect.ttWidth)<0&&(h=0),!f||r.globals.isBarHorizontal&&o.tooltipUtil.hasBars()||(c=c+g-2*(r.globals.series[e][u]<0?g:0)),c=c+r.globals.translateY-o.tooltipRect.ttHeight/2,n.style.left=h+r.globals.translateX+"px",n.style.top=c+"px")}},{key:"getBarTooltipXY",value:function(t){var e=t.e,i=t.opt,a=this.w,s=null,r=this.ttCtx,o=0,n=0,l=0,h=0,c=0,d=e.target.classList;if(d.contains("apexcharts-bar-area")||d.contains("apexcharts-candlestick-area")||d.contains("apexcharts-boxPlot-area")||d.contains("apexcharts-rangebar-area")){var g=e.target,u=g.getBoundingClientRect(),p=i.elGrid.getBoundingClientRect(),f=u.height;c=u.height;var x=u.width,b=parseInt(g.getAttribute("cx"),10),v=parseInt(g.getAttribute("cy"),10);h=parseFloat(g.getAttribute("barWidth"));var m="touchmove"===e.type?e.touches[0].clientX:e.clientX;s=parseInt(g.getAttribute("j"),10),o=parseInt(g.parentNode.getAttribute("rel"),10)-1;var y=g.getAttribute("data-range-y1"),w=g.getAttribute("data-range-y2");a.globals.comboCharts&&(o=parseInt(g.parentNode.getAttribute("data:realIndex"),10)),r.tooltipLabels.drawSeriesTexts({ttItems:i.ttItems,i:o,j:s,y1:y?parseInt(y,10):null,y2:w?parseInt(w,10):null,shared:!r.showOnIntersect&&a.config.tooltip.shared,e:e}),a.config.tooltip.followCursor?a.globals.isBarHorizontal?(n=m-p.left+15,l=v-r.dataPointsDividedHeight+f/2-r.tooltipRect.ttHeight/2):(n=a.globals.isXNumeric?b-x/2:b-r.dataPointsDividedWidth+x/2,l=e.clientY-p.top-r.tooltipRect.ttHeight/2-15):a.globals.isBarHorizontal?((n=b)0&&i.setAttribute("width",e.xcrosshairsWidth)}},{key:"handleYCrosshair",value:function(){var t=this.w,e=this.ttCtx;e.ycrosshairs=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs"),e.ycrosshairsHidden=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs-hidden")}},{key:"drawYaxisTooltipText",value:function(t,e,i){var a=this.ttCtx,s=this.w,r=s.globals.yLabelFormatters[t];if(a.yaxisTooltips[t]){var o=a.getElGrid().getBoundingClientRect(),n=(e-o.top)*i.yRatio[t],l=s.globals.maxYArr[t]-s.globals.minYArr[t],h=s.globals.minYArr[t]+(l-n);a.tooltipPosition.moveYCrosshairs(e-o.top),a.yaxisTooltipText[t].innerHTML=r(h),a.tooltipPosition.moveYAxisTooltip(t)}}}]),t}(),bt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w;var i=this.w;this.tConfig=i.config.tooltip,this.tooltipUtil=new dt(this),this.tooltipLabels=new gt(this),this.tooltipPosition=new ut(this),this.marker=new pt(this),this.intersect=new ft(this),this.axesTooltip=new xt(this),this.showOnIntersect=this.tConfig.intersect,this.showTooltipTitle=this.tConfig.x.show,this.fixedTooltip=this.tConfig.fixed.enabled,this.xaxisTooltip=null,this.yaxisTTEls=null,this.isBarShared=!i.globals.isBarHorizontal&&this.tConfig.shared,this.lastHoverTime=Date.now()}return r(t,[{key:"getElTooltip",value:function(t){return t||(t=this),t.w.globals.dom.baseEl?t.w.globals.dom.baseEl.querySelector(".apexcharts-tooltip"):null}},{key:"getElXCrosshairs",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-xcrosshairs")}},{key:"getElGrid",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-grid")}},{key:"drawTooltip",value:function(t){var e=this.w;this.xyRatios=t,this.isXAxisTooltipEnabled=e.config.xaxis.tooltip.enabled&&e.globals.axisCharts,this.yaxisTooltips=e.config.yaxis.map((function(t,i){return!!(t.show&&t.tooltip.enabled&&e.globals.axisCharts)})),this.allTooltipSeriesGroups=[],e.globals.axisCharts||(this.showTooltipTitle=!1);var i=document.createElement("div");if(i.classList.add("apexcharts-tooltip"),e.config.tooltip.cssClass&&i.classList.add(e.config.tooltip.cssClass),i.classList.add("apexcharts-theme-".concat(this.tConfig.theme)),e.globals.dom.elWrap.appendChild(i),e.globals.axisCharts){this.axesTooltip.drawXaxisTooltip(),this.axesTooltip.drawYaxisTooltip(),this.axesTooltip.setXCrosshairWidth(),this.axesTooltip.handleYCrosshair();var a=new V(this.ctx);this.xAxisTicksPositions=a.getXAxisTicksPositions()}if(!e.globals.comboCharts&&!this.tConfig.intersect&&"rangeBar"!==e.config.chart.type||this.tConfig.shared||(this.showOnIntersect=!0),0!==e.config.markers.size&&0!==e.globals.markers.largestSize||this.marker.drawDynamicPoints(this),e.globals.collapsedSeries.length!==e.globals.series.length){this.dataPointsDividedHeight=e.globals.gridHeight/e.globals.dataPoints,this.dataPointsDividedWidth=e.globals.gridWidth/e.globals.dataPoints,this.showTooltipTitle&&(this.tooltipTitle=document.createElement("div"),this.tooltipTitle.classList.add("apexcharts-tooltip-title"),this.tooltipTitle.style.fontFamily=this.tConfig.style.fontFamily||e.config.chart.fontFamily,this.tooltipTitle.style.fontSize=this.tConfig.style.fontSize,i.appendChild(this.tooltipTitle));var s=e.globals.series.length;(e.globals.xyCharts||e.globals.comboCharts)&&this.tConfig.shared&&(s=this.showOnIntersect?1:e.globals.series.length),this.legendLabels=e.globals.dom.baseEl.querySelectorAll(".apexcharts-legend-text"),this.ttItems=this.createTTElements(s),this.addSVGEvents()}}},{key:"createTTElements",value:function(t){for(var e=this,i=this.w,a=[],s=this.getElTooltip(),r=function(r){var o=document.createElement("div");o.classList.add("apexcharts-tooltip-series-group"),o.style.order=i.config.tooltip.inverseOrder?t-r:r+1,e.tConfig.shared&&e.tConfig.enabledOnSeries&&Array.isArray(e.tConfig.enabledOnSeries)&&e.tConfig.enabledOnSeries.indexOf(r)<0&&o.classList.add("apexcharts-tooltip-series-group-hidden");var n=document.createElement("span");n.classList.add("apexcharts-tooltip-marker"),n.style.backgroundColor=i.globals.colors[r],o.appendChild(n);var l=document.createElement("div");l.classList.add("apexcharts-tooltip-text"),l.style.fontFamily=e.tConfig.style.fontFamily||i.config.chart.fontFamily,l.style.fontSize=e.tConfig.style.fontSize,["y","goals","z"].forEach((function(t){var e=document.createElement("div");e.classList.add("apexcharts-tooltip-".concat(t,"-group"));var i=document.createElement("span");i.classList.add("apexcharts-tooltip-text-".concat(t,"-label")),e.appendChild(i);var a=document.createElement("span");a.classList.add("apexcharts-tooltip-text-".concat(t,"-value")),e.appendChild(a),l.appendChild(e)})),o.appendChild(l),s.appendChild(o),a.push(o)},o=0;o0&&this.addPathsEventListeners(u,c),this.tooltipUtil.hasBars()&&!this.tConfig.shared&&this.addDatapointEventsListeners(c)}}},{key:"drawFixedTooltipRect",value:function(){var t=this.w,e=this.getElTooltip(),i=e.getBoundingClientRect(),a=i.width+10,s=i.height+10,r=this.tConfig.fixed.offsetX,o=this.tConfig.fixed.offsetY,n=this.tConfig.fixed.position.toLowerCase();return n.indexOf("right")>-1&&(r=r+t.globals.svgWidth-a+10),n.indexOf("bottom")>-1&&(o=o+t.globals.svgHeight-s-10),e.style.left=r+"px",e.style.top=o+"px",{x:r,y:o,ttWidth:a,ttHeight:s}}},{key:"addDatapointEventsListeners",value:function(t){var e=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers .apexcharts-marker, .apexcharts-bar-area, .apexcharts-candlestick-area, .apexcharts-boxPlot-area, .apexcharts-rangebar-area");this.addPathsEventListeners(e,t)}},{key:"addPathsEventListeners",value:function(t,e){for(var i=this,a=function(a){var s={paths:t[a],tooltipEl:e.tooltipEl,tooltipY:e.tooltipY,tooltipX:e.tooltipX,elGrid:e.elGrid,hoverArea:e.hoverArea,ttItems:e.ttItems};["mousemove","mouseup","touchmove","mouseout","touchend"].map((function(e){return t[a].addEventListener(e,i.onSeriesHover.bind(i,s),{capture:!1,passive:!0})}))},s=0;s=100?this.seriesHover(t,e):(clearTimeout(this.seriesHoverTimeout),this.seriesHoverTimeout=setTimeout((function(){i.seriesHover(t,e)}),100-a))}},{key:"seriesHover",value:function(t,e){var i=this;this.lastHoverTime=Date.now();var a=[],s=this.w;s.config.chart.group&&(a=this.ctx.getGroupedCharts()),s.globals.axisCharts&&(s.globals.minX===-1/0&&s.globals.maxX===1/0||0===s.globals.dataPoints)||(a.length?a.forEach((function(a){var s=i.getElTooltip(a),r={paths:t.paths,tooltipEl:s,tooltipY:t.tooltipY,tooltipX:t.tooltipX,elGrid:t.elGrid,hoverArea:t.hoverArea,ttItems:a.w.globals.tooltip.ttItems};a.w.globals.minX===i.w.globals.minX&&a.w.globals.maxX===i.w.globals.maxX&&a.w.globals.tooltip.seriesHoverByContext({chartCtx:a,ttCtx:a.w.globals.tooltip,opt:r,e:e})})):this.seriesHoverByContext({chartCtx:this.ctx,ttCtx:this.w.globals.tooltip,opt:t,e:e}))}},{key:"seriesHoverByContext",value:function(t){var e=t.chartCtx,i=t.ttCtx,a=t.opt,s=t.e,r=e.w,o=this.getElTooltip();if(o){if(i.tooltipRect={x:0,y:0,ttWidth:o.getBoundingClientRect().width,ttHeight:o.getBoundingClientRect().height},i.e=s,i.tooltipUtil.hasBars()&&!r.globals.comboCharts&&!i.isBarShared)if(this.tConfig.onDatasetHover.highlightDataSeries)new N(e).toggleSeriesOnHover(s,s.target.parentNode);i.fixedTooltip&&i.drawFixedTooltipRect(),r.globals.axisCharts?i.axisChartsTooltips({e:s,opt:a,tooltipRect:i.tooltipRect}):i.nonAxisChartsTooltips({e:s,opt:a,tooltipRect:i.tooltipRect})}}},{key:"axisChartsTooltips",value:function(t){var e,i,a=t.e,s=t.opt,r=this.w,o=s.elGrid.getBoundingClientRect(),n="touchmove"===a.type?a.touches[0].clientX:a.clientX,l="touchmove"===a.type?a.touches[0].clientY:a.clientY;if(this.clientY=l,this.clientX=n,r.globals.capturedSeriesIndex=-1,r.globals.capturedDataPointIndex=-1,lo.top+o.height)this.handleMouseOut(s);else{if(Array.isArray(this.tConfig.enabledOnSeries)&&!r.config.tooltip.shared){var h=parseInt(s.paths.getAttribute("index"),10);if(this.tConfig.enabledOnSeries.indexOf(h)<0)return void this.handleMouseOut(s)}var c=this.getElTooltip(),d=this.getElXCrosshairs(),g=r.globals.xyCharts||"bar"===r.config.chart.type&&!r.globals.isBarHorizontal&&this.tooltipUtil.hasBars()&&this.tConfig.shared||r.globals.comboCharts&&this.tooltipUtil.hasBars();if("mousemove"===a.type||"touchmove"===a.type||"mouseup"===a.type){if(r.globals.collapsedSeries.length+r.globals.ancillaryCollapsedSeries.length===r.globals.series.length)return;null!==d&&d.classList.add("apexcharts-active");var u=this.yaxisTooltips.filter((function(t){return!0===t}));if(null!==this.ycrosshairs&&u.length&&this.ycrosshairs.classList.add("apexcharts-active"),g&&!this.showOnIntersect)this.handleStickyTooltip(a,n,l,s);else if("heatmap"===r.config.chart.type||"treemap"===r.config.chart.type){var p=this.intersect.handleHeatTreeTooltip({e:a,opt:s,x:e,y:i,type:r.config.chart.type});e=p.x,i=p.y,c.style.left=e+"px",c.style.top=i+"px"}else this.tooltipUtil.hasBars()&&this.intersect.handleBarTooltip({e:a,opt:s}),this.tooltipUtil.hasMarkers()&&this.intersect.handleMarkerTooltip({e:a,opt:s,x:e,y:i});if(this.yaxisTooltips.length)for(var f=0;fl.width)this.handleMouseOut(a);else if(null!==n)this.handleStickyCapturedSeries(t,n,a,o);else if(this.tooltipUtil.isXoverlap(o)||s.globals.isBarHorizontal){var h=s.globals.series.findIndex((function(t,e){return!s.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,h,o,a.ttItems)}}},{key:"handleStickyCapturedSeries",value:function(t,e,i,a){var s=this.w;if(!this.tConfig.shared&&null===s.globals.series[e][a])return void this.handleMouseOut(i);if(void 0!==s.globals.series[e][a])this.tConfig.shared&&this.tooltipUtil.isXoverlap(a)&&this.tooltipUtil.isInitialSeriesSameLen()?this.create(t,this,e,a,i.ttItems):this.create(t,this,e,a,i.ttItems,!1);else if(this.tooltipUtil.isXoverlap(a)){var r=s.globals.series.findIndex((function(t,e){return!s.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,r,a,i.ttItems)}}},{key:"deactivateHoverFilter",value:function(){for(var t=this.w,e=new m(this.ctx),i=t.globals.dom.Paper.select(".apexcharts-bar-area"),a=0;a5&&void 0!==arguments[5]?arguments[5]:null,S=this.w,C=i;"mouseup"===t.type&&this.markerClick(t,a,s),null===A&&(A=this.tConfig.shared);var L=this.tooltipUtil.hasMarkers(a),P=this.tooltipUtil.getElBars();if(S.config.legend.tooltipHoverFormatter){var I=S.config.legend.tooltipHoverFormatter,T=Array.from(this.legendLabels);T.forEach((function(t){var e=t.getAttribute("data:default-text");t.innerHTML=decodeURIComponent(e)}));for(var M=0;M0?C.marker.enlargePoints(s):C.tooltipPosition.moveDynamicPointsOnHover(s);else if(this.tooltipUtil.hasBars()&&(this.barSeriesHeight=this.tooltipUtil.getBarsHeight(P),this.barSeriesHeight>0)){var R=new m(this.ctx),D=S.globals.dom.Paper.select(".apexcharts-bar-area[j='".concat(s,"']"));this.deactivateHoverFilter(),this.tooltipPosition.moveStickyTooltipOverBars(s,a);for(var H=0;Hs.globals.gridHeight&&(p=s.globals.gridHeight-v)),{bcx:c,bcy:h,dataLabelsX:e,dataLabelsY:p,totalDataLabelsX:a,totalDataLabelsY:i,totalDataLabelsAnchor:"middle"}}},{key:"calculateBarsDataLabelsPosition",value:function(t){var e=this.w,i=t.x,a=t.i,s=t.j,r=t.realIndex,o=t.groupIndex,n=t.bcy,l=t.barHeight,h=t.barWidth,c=t.textRects,d=t.dataLabelsX,g=t.strokeWidth,u=t.dataLabelsConfig,p=t.barDataLabelsConfig,f=t.barTotalDataLabelsConfig,x=t.offX,b=t.offY,v=e.globals.gridHeight/e.globals.dataPoints;h=Math.abs(h);var y,w,k=(n+=-1!==o?o*l:0)-(this.barCtx.isRangeBar?0:v)+l/2+c.height/2+b-3,A="start",S=this.barCtx.series[a][s]<0,C=i;switch(this.barCtx.isReversed&&(C=i+h-(S?2*h:0),i=e.globals.gridWidth-h),p.position){case"center":d=S?C+h/2-x:Math.max(c.width/2,C-h/2)+x;break;case"bottom":d=S?C+h-g-Math.round(c.width/2)-x:C-h+g+Math.round(c.width/2)+x;break;case"top":d=S?C-g+Math.round(c.width/2)-x:C-g-Math.round(c.width/2)+x}if(this.barCtx.lastActiveBarSerieIndex===r&&f.enabled){var L=new m(this.barCtx.ctx).getTextRects(this.getStackedTotalDataLabel({realIndex:r,j:s}),u.fontSize);S?(y=C-g+Math.round(L.width/2)-x-f.offsetX-15,A="end"):y=C-g-Math.round(L.width/2)+x+f.offsetX+15,w=k+f.offsetY}return e.config.chart.stacked||(d<0?d=d+c.width+g:d+c.width/2>e.globals.gridWidth&&(d=e.globals.gridWidth-c.width-g)),{bcx:i,bcy:n,dataLabelsX:d,dataLabelsY:k,totalDataLabelsX:y,totalDataLabelsY:w,totalDataLabelsAnchor:A}}},{key:"drawCalculatedDataLabels",value:function(t){var i=t.x,a=t.y,s=t.val,r=t.i,o=t.j,n=t.textRects,l=t.barHeight,h=t.barWidth,c=t.dataLabelsConfig,d=this.w,g="rotate(0)";"vertical"===d.config.plotOptions.bar.dataLabels.orientation&&(g="rotate(-90, ".concat(i,", ").concat(a,")"));var u=new O(this.barCtx.ctx),p=new m(this.barCtx.ctx),f=c.formatter,x=null,b=d.globals.collapsedSeriesIndices.indexOf(r)>-1;if(c.enabled&&!b){x=p.group({class:"apexcharts-data-labels",transform:g});var v="";void 0!==s&&(v=f(s,e(e({},d),{},{seriesIndex:r,dataPointIndex:o,w:d}))),!s&&d.config.plotOptions.bar.hideZeroBarsWhenGrouped&&(v="");var y=d.globals.series[r][o]<0,w=d.config.plotOptions.bar.dataLabels.position;if("vertical"===d.config.plotOptions.bar.dataLabels.orientation&&("top"===w&&(c.textAnchor=y?"end":"start"),"center"===w&&(c.textAnchor="middle"),"bottom"===w&&(c.textAnchor=y?"end":"start")),this.barCtx.isRangeBar&&this.barCtx.barOptions.dataLabels.hideOverflowingLabels)hMath.abs(h)&&(v=""):n.height/1.6>Math.abs(l)&&(v=""));var k=e({},c);this.barCtx.isHorizontal&&s<0&&("start"===c.textAnchor?k.textAnchor="end":"end"===c.textAnchor&&(k.textAnchor="start")),u.plotDataLabelsText({x:i,y:a,text:v,i:r,j:o,parent:x,dataLabelsConfig:k,alwaysDrawDataLabel:!0,offsetCorrection:!0})}return x}},{key:"drawTotalDataLabels",value:function(t){var e,i=t.x,a=t.y,s=t.val,r=t.realIndex,o=t.textAnchor,n=t.barTotalDataLabelsConfig,l=new m(this.barCtx.ctx);return n.enabled&&void 0!==i&&void 0!==a&&this.barCtx.lastActiveBarSerieIndex===r&&(e=l.drawText({x:i,y:a,foreColor:n.style.color,text:s,textAnchor:o,fontFamily:n.style.fontFamily,fontSize:n.style.fontSize,fontWeight:n.style.fontWeight})),e}}]),t}(),mt=function(){function t(e){a(this,t),this.w=e.w,this.barCtx=e}return r(t,[{key:"initVariables",value:function(t){var e=this.w;this.barCtx.series=t,this.barCtx.totalItems=0,this.barCtx.seriesLen=0,this.barCtx.visibleI=-1,this.barCtx.visibleItems=1;for(var i=0;i0&&(this.barCtx.seriesLen=this.barCtx.seriesLen+1,this.barCtx.totalItems+=t[i].length),e.globals.isXNumeric)for(var a=0;ae.globals.minX&&e.globals.seriesX[i][a]0&&(a=l.globals.minXDiff/d),(r=a/this.barCtx.seriesLen*parseInt(this.barCtx.barOptions.columnWidth,10)/100)<1&&(r=1)}-1===String(this.barCtx.barOptions.columnWidth).indexOf("%")&&(r=parseInt(this.barCtx.barOptions.columnWidth,10)),o=l.globals.gridHeight-this.barCtx.baseLineY[this.barCtx.yaxisIndex]-(this.barCtx.isReversed?l.globals.gridHeight:0)+(this.barCtx.isReversed?2*this.barCtx.baseLineY[this.barCtx.yaxisIndex]:0),t=l.globals.padHorizontal+(a-r*this.barCtx.seriesLen)/2}return{x:t,y:e,yDivision:i,xDivision:a,barHeight:s,barWidth:r,zeroH:o,zeroW:n}}},{key:"initializeStackedPrevVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].prevY=[],t[e].prevX=[],t[e].prevYF=[],t[e].prevXF=[],t[e].prevYVal=[],t[e].prevXVal=[]})):(t.prevY=[],t.prevX=[],t.prevYF=[],t.prevXF=[],t.prevYVal=[],t.prevXVal=[])}},{key:"initializeStackedXYVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].xArrj=[],t[e].xArrjF=[],t[e].xArrjVal=[],t[e].yArrj=[],t[e].yArrjF=[],t[e].yArrjVal=[]})):(t.xArrj=[],t.xArrjF=[],t.xArrjVal=[],t.yArrj=[],t.yArrjF=[],t.yArrjVal=[])}},{key:"getPathFillColor",value:function(t,e,i,a){var s,r,o,n,l=this.w,h=new R(this.barCtx.ctx),c=null,d=this.barCtx.barOptions.distributed?i:e;this.barCtx.barOptions.colors.ranges.length>0&&this.barCtx.barOptions.colors.ranges.map((function(a){t[e][i]>=a.from&&t[e][i]<=a.to&&(c=a.color)}));return l.config.series[e].data[i]&&l.config.series[e].data[i].fillColor&&(c=l.config.series[e].data[i].fillColor),h.fillPath({seriesNumber:this.barCtx.barOptions.distributed?d:a,dataPointIndex:i,color:c,value:t[e][i],fillConfig:null===(s=l.config.series[e].data[i])||void 0===s?void 0:s.fill,fillType:null!==(r=l.config.series[e].data[i])&&void 0!==r&&null!==(o=r.fill)&&void 0!==o&&o.type?null===(n=l.config.series[e].data[i])||void 0===n?void 0:n.fill.type:l.config.fill.type})}},{key:"getStrokeWidth",value:function(t,e,i){var a=0,s=this.w;return this.barCtx.series[t][e]?this.barCtx.isNullValue=!1:this.barCtx.isNullValue=!0,s.config.stroke.show&&(this.barCtx.isNullValue||(a=Array.isArray(this.barCtx.strokeWidth)?this.barCtx.strokeWidth[i]:this.barCtx.strokeWidth)),a}},{key:"shouldApplyRadius",value:function(t){var e=this.w,i=!1;return e.config.plotOptions.bar.borderRadius>0&&(e.config.chart.stacked&&"last"===e.config.plotOptions.bar.borderRadiusWhenStacked?this.barCtx.lastActiveBarSerieIndex===t&&(i=!0):i=!0),i}},{key:"barBackground",value:function(t){var e=t.j,i=t.i,a=t.x1,s=t.x2,r=t.y1,o=t.y2,n=t.elSeries,l=this.w,h=new m(this.barCtx.ctx),c=new N(this.barCtx.ctx).getActiveConfigSeriesIndex();if(this.barCtx.barOptions.colors.backgroundBarColors.length>0&&c===i){e>=this.barCtx.barOptions.colors.backgroundBarColors.length&&(e%=this.barCtx.barOptions.colors.backgroundBarColors.length);var d=this.barCtx.barOptions.colors.backgroundBarColors[e],g=h.drawRect(void 0!==a?a:0,void 0!==r?r:0,void 0!==s?s:l.globals.gridWidth,void 0!==o?o:l.globals.gridHeight,this.barCtx.barOptions.colors.backgroundBarRadius,d,this.barCtx.barOptions.colors.backgroundBarOpacity);n.add(g),g.node.classList.add("apexcharts-backgroundBar")}}},{key:"getColumnPaths",value:function(t){var e,i=t.barWidth,a=t.barXPosition,s=t.y1,r=t.y2,o=t.strokeWidth,n=t.seriesGroup,l=t.realIndex,h=t.i,c=t.j,d=t.w,g=new m(this.barCtx.ctx);(o=Array.isArray(o)?o[l]:o)||(o=0);var u=i,p=a;null!==(e=d.config.series[l].data[c])&&void 0!==e&&e.columnWidthOffset&&(p=a-d.config.series[l].data[c].columnWidthOffset/2,u=i+d.config.series[l].data[c].columnWidthOffset);var f=p,x=p+u;s+=.001,r+=.001;var b=g.move(f,s),v=g.move(f,s),y=g.line(x-o,s);if(d.globals.previousPaths.length>0&&(v=this.barCtx.getPreviousPath(l,c,!1)),b=b+g.line(f,r)+g.line(x-o,r)+g.line(x-o,s)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),v=v+g.line(f,s)+y+y+y+y+y+g.line(f,s)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(b=g.roundPathCorners(b,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&n&&(w=this.barCtx[n]),w.yArrj.push(r),w.yArrjF.push(Math.abs(s-r)),w.yArrjVal.push(this.barCtx.series[h][c])}return{pathTo:b,pathFrom:v}}},{key:"getBarpaths",value:function(t){var e,i=t.barYPosition,a=t.barHeight,s=t.x1,r=t.x2,o=t.strokeWidth,n=t.seriesGroup,l=t.realIndex,h=t.i,c=t.j,d=t.w,g=new m(this.barCtx.ctx);(o=Array.isArray(o)?o[l]:o)||(o=0);var u=i,p=a;null!==(e=d.config.series[l].data[c])&&void 0!==e&&e.barHeightOffset&&(u=i-d.config.series[l].data[c].barHeightOffset/2,p=a+d.config.series[l].data[c].barHeightOffset);var f=u,x=u+p;s+=.001,r+=.001;var b=g.move(s,f),v=g.move(s,f);d.globals.previousPaths.length>0&&(v=this.barCtx.getPreviousPath(l,c,!1));var y=g.line(s,x-o);if(b=b+g.line(r,f)+g.line(r,x-o)+y+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),v=v+g.line(s,f)+y+y+y+y+y+g.line(s,f)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(b=g.roundPathCorners(b,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&n&&(w=this.barCtx[n]),w.xArrj.push(r),w.xArrjF.push(Math.abs(s-r)),w.xArrjVal.push(this.barCtx.series[h][c])}return{pathTo:b,pathFrom:v}}},{key:"checkZeroSeries",value:function(t){for(var e=t.series,i=this.w,a=0;a2&&void 0!==arguments[2])||arguments[2]?e:null;return null!=t&&(i=e+t/this.barCtx.invertedYRatio-2*(this.barCtx.isReversed?t/this.barCtx.invertedYRatio:0)),i}},{key:"getYForValue",value:function(t,e){var i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2]?e:null;return null!=t&&(i=e-t/this.barCtx.yRatio[this.barCtx.yaxisIndex]+2*(this.barCtx.isReversed?t/this.barCtx.yRatio[this.barCtx.yaxisIndex]:0)),i}},{key:"getGoalValues",value:function(t,i,a,s,r){var n=this,l=this.w,h=[],c=function(e,s){var r;h.push((o(r={},t,"x"===t?n.getXForValue(e,i,!1):n.getYForValue(e,a,!1)),o(r,"attrs",s),r))};if(l.globals.seriesGoals[s]&&l.globals.seriesGoals[s][r]&&Array.isArray(l.globals.seriesGoals[s][r])&&l.globals.seriesGoals[s][r].forEach((function(t){c(t.value,t)})),this.barCtx.barOptions.isDumbbell&&l.globals.seriesRange.length){var d=this.barCtx.barOptions.dumbbellColors?this.barCtx.barOptions.dumbbellColors:l.globals.colors,g={strokeHeight:"x"===t?0:l.globals.markers.size[s],strokeWidth:"x"===t?l.globals.markers.size[s]:0,strokeDashArray:0,strokeLineCap:"round",strokeColor:Array.isArray(d[s])?d[s][0]:d[s]};c(l.globals.seriesRangeStart[s][r],g),c(l.globals.seriesRangeEnd[s][r],e(e({},g),{},{strokeColor:Array.isArray(d[s])?d[s][1]:d[s]}))}return h}},{key:"drawGoalLine",value:function(t){var e=t.barXPosition,i=t.barYPosition,a=t.goalX,s=t.goalY,r=t.barWidth,o=t.barHeight,n=new m(this.barCtx.ctx),l=n.group({className:"apexcharts-bar-goals-groups"});l.node.classList.add("apexcharts-element-hidden"),this.barCtx.w.globals.delayedElements.push({el:l.node}),l.attr("clip-path","url(#gridRectMarkerMask".concat(this.barCtx.w.globals.cuid,")"));var h=null;return this.barCtx.isHorizontal?Array.isArray(a)&&a.forEach((function(t){var e=void 0!==t.attrs.strokeHeight?t.attrs.strokeHeight:o/2,a=i+e+o/2;h=n.drawLine(t.x,a-2*e,t.x,a,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeWidth?t.attrs.strokeWidth:2,t.attrs.strokeLineCap),l.add(h)})):Array.isArray(s)&&s.forEach((function(t){var i=void 0!==t.attrs.strokeWidth?t.attrs.strokeWidth:r/2,a=e+i+r/2;h=n.drawLine(a-2*i,t.y,a,t.y,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeHeight?t.attrs.strokeHeight:2,t.attrs.strokeLineCap),l.add(h)})),l}}]),t}(),yt=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w;var s=this.w;this.barOptions=s.config.plotOptions.bar,this.isHorizontal=this.barOptions.horizontal,this.strokeWidth=s.config.stroke.width,this.isNullValue=!1,this.isRangeBar=s.globals.seriesRange.length&&this.isHorizontal,this.xyRatios=i,null!==this.xyRatios&&(this.xRatio=i.xRatio,this.initialXRatio=i.initialXRatio,this.yRatio=i.yRatio,this.invertedXRatio=i.invertedXRatio,this.invertedYRatio=i.invertedYRatio,this.baseLineY=i.baseLineY,this.baseLineInvertedY=i.baseLineInvertedY),this.yaxisIndex=0,this.seriesLen=0;var r=new N(this.ctx);this.lastActiveBarSerieIndex=r.getActiveConfigSeriesIndex("desc",["bar","column"]);var o=r.getBarSeriesIndices(),n=new y(this.ctx);this.stackedSeriesTotals=n.getStackedSeriesTotals(this.w.config.series.map((function(t,e){return-1===o.indexOf(e)?e:-1})).filter((function(t){return-1!==t}))),this.barHelpers=new mt(this)}return r(t,[{key:"draw",value:function(t,i){var a=this.w,s=new m(this.ctx),r=new y(this.ctx,a);t=r.getLogSeries(t),this.series=t,this.yRatio=r.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t);var o=s.group({class:"apexcharts-bar-series apexcharts-plot-series"});a.config.dataLabels.enabled&&this.totalItems>this.barOptions.dataLabels.maxItems&&console.warn("WARNING: DataLabels are enabled but there are too many to display. This may cause performance issue when rendering.");for(var n=0,l=0;n0&&(this.visibleI=this.visibleI+1);var k=0,A=0;this.yRatio.length>1&&(this.yaxisIndex=v),this.isReversed=a.config.yaxis[this.yaxisIndex]&&a.config.yaxis[this.yaxisIndex].reversed;var S=this.barHelpers.initialPositions();p=S.y,k=S.barHeight,c=S.yDivision,g=S.zeroW,u=S.x,A=S.barWidth,h=S.xDivision,d=S.zeroH,this.horizontal||b.push(u+A/2);for(var C=s.group({class:"apexcharts-datalabels","data:realIndex":v}),L=s.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),P=0;P0&&b.push(u+A/2),f.push(p);var z=this.barHelpers.getPathFillColor(t,n,P,v);this.renderSeries({realIndex:v,pathFill:z,j:P,i:n,pathFrom:T.pathFrom,pathTo:T.pathTo,strokeWidth:I,elSeries:w,x:u,y:p,series:t,barHeight:T.barHeight?T.barHeight:k,barWidth:T.barWidth?T.barWidth:A,elDataLabelsWrap:C,elGoalsMarkers:L,visibleSeries:this.visibleI,type:"bar"})}a.globals.seriesXvalues[v]=b,a.globals.seriesYvalues[v]=f,o.add(w)}return o}},{key:"renderSeries",value:function(t){var e=t.realIndex,i=t.pathFill,a=t.lineFill,s=t.j,r=t.i,o=t.groupIndex,n=t.pathFrom,l=t.pathTo,h=t.strokeWidth,c=t.elSeries,d=t.x,g=t.y,u=t.y1,p=t.y2,f=t.series,x=t.barHeight,b=t.barWidth,y=t.barYPosition,w=t.elDataLabelsWrap,k=t.elGoalsMarkers,A=t.visibleSeries,S=t.type,C=this.w,L=new m(this.ctx);a||(a=this.barOptions.distributed?C.globals.stroke.colors[s]:C.globals.stroke.colors[e]),C.config.series[r].data[s]&&C.config.series[r].data[s].strokeColor&&(a=C.config.series[r].data[s].strokeColor),this.isNullValue&&(i="none");var P=s/C.config.chart.animations.animateGradually.delay*(C.config.chart.animations.speed/C.globals.dataPoints)/2.4,I=L.renderPaths({i:r,j:s,realIndex:e,pathFrom:n,pathTo:l,stroke:a,strokeWidth:h,strokeLineCap:C.config.stroke.lineCap,fill:i,animationDelay:P,initialSpeed:C.config.chart.animations.speed,dataChangeSpeed:C.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(S,"-area")});I.attr("clip-path","url(#gridRectMask".concat(C.globals.cuid,")"));var T=C.config.forecastDataPoints;T.count>0&&s>=C.globals.dataPoints-T.count&&(I.node.setAttribute("stroke-dasharray",T.dashArray),I.node.setAttribute("stroke-width",T.strokeWidth),I.node.setAttribute("fill-opacity",T.fillOpacity)),void 0!==u&&void 0!==p&&(I.attr("data-range-y1",u),I.attr("data-range-y2",p)),new v(this.ctx).setSelectionFilter(I,e,s),c.add(I);var M=new vt(this).handleBarDataLabels({x:d,y:g,y1:u,y2:p,i:r,j:s,series:f,realIndex:e,groupIndex:o,barHeight:x,barWidth:b,barYPosition:y,renderedPath:I,visibleSeries:A});return null!==M.dataLabels&&w.add(M.dataLabels),M.totalDataLabels&&w.add(M.totalDataLabels),c.add(w),k&&c.add(k),c}},{key:"drawBarPaths",value:function(t){var e,i=t.indexes,a=t.barHeight,s=t.strokeWidth,r=t.zeroW,o=t.x,n=t.y,l=t.yDivision,h=t.elSeries,c=this.w,d=i.i,g=i.j;if(c.globals.isXNumeric)e=(n=(c.globals.seriesX[d][g]-c.globals.minX)/this.invertedXRatio-a)+a*this.visibleI;else if(c.config.plotOptions.bar.hideZeroBarsWhenGrouped){var u=0,p=0;c.globals.seriesPercent.forEach((function(t,e){t[g]&&u++,e0&&(a=this.seriesLen*a/u),e=n+a*this.visibleI,e-=a*p}else e=n+a*this.visibleI;o=this.barHelpers.getXForValue(this.series[d][g],r);var f=this.barHelpers.getBarpaths({barYPosition:e,barHeight:a,x1:r,x2:o,strokeWidth:s,series:this.series,realIndex:i.realIndex,i:d,j:g,w:c});return c.globals.isXNumeric||(n+=l),this.barHelpers.barBackground({j:g,i:d,y1:e-a*this.visibleI,y2:a*this.seriesLen,elSeries:h}),{pathTo:f.pathTo,pathFrom:f.pathFrom,x:o,y:n,goalX:this.barHelpers.getGoalValues("x",r,null,d,g),barYPosition:e,barHeight:a}}},{key:"drawColumnPaths",value:function(t){var e,i=t.indexes,a=t.x,s=t.y,r=t.xDivision,o=t.barWidth,n=t.zeroH,l=t.strokeWidth,h=t.elSeries,c=this.w,d=i.realIndex,g=i.i,u=i.j,p=i.bc;if(c.globals.isXNumeric){var f=d;c.globals.seriesX[d].length||(f=c.globals.maxValsInArrayIndex),c.globals.seriesX[f][u]&&(a=(c.globals.seriesX[f][u]-c.globals.minX)/this.xRatio-o*this.seriesLen/2),e=a+o*this.visibleI}else if(c.config.plotOptions.bar.hideZeroBarsWhenGrouped){var x=0,b=0;c.globals.seriesPercent.forEach((function(t,e){t[u]&&x++,e0&&(o=this.seriesLen*o/x),e=a+o*this.visibleI,e-=o*b}else e=a+o*this.visibleI;s=this.barHelpers.getYForValue(this.series[g][u],n);var v=this.barHelpers.getColumnPaths({barXPosition:e,barWidth:o,y1:n,y2:s,strokeWidth:l,series:this.series,realIndex:i.realIndex,i:g,j:u,w:c});return c.globals.isXNumeric||(a+=r),this.barHelpers.barBackground({bc:p,j:u,i:g,x1:e-l/2-o*this.visibleI,x2:o*this.seriesLen+l/2,elSeries:h}),{pathTo:v.pathTo,pathFrom:v.pathFrom,x:a,y:s,goalY:this.barHelpers.getGoalValues("y",null,n,g,u),barXPosition:e,barWidth:o}}},{key:"getPreviousPath",value:function(t,e){for(var i,a=this.w,s=0;s0&&parseInt(r.realIndex,10)===parseInt(t,10)&&void 0!==a.globals.previousPaths[s].paths[e]&&(i=a.globals.previousPaths[s].paths[e].d)}return i}}]),t}(),wt=function(t){n(s,yt);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i){var a=this,s=this.w;this.graphics=new m(this.ctx),this.bar=new yt(this.ctx,this.xyRatios);var r=new y(this.ctx,s);t=r.getLogSeries(t),this.yRatio=r.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t),"100%"===s.config.chart.stackType&&(t=s.globals.seriesPercent.slice()),this.series=t,this.barHelpers.initializeStackedPrevVars(this);for(var o=this.graphics.group({class:"apexcharts-bar-series apexcharts-plot-series"}),n=0,l=0,h=function(r,h){var c=void 0,d=void 0,g=void 0,u=void 0,p=-1;a.groupCtx=a,s.globals.seriesGroups.forEach((function(t,e){t.indexOf(s.config.series[r].name)>-1&&(p=e)})),-1!==p&&(a.groupCtx=a[s.globals.seriesGroups[p]]);var f=[],b=[],v=s.globals.comboCharts?i[r]:r;a.yRatio.length>1&&(a.yaxisIndex=v),a.isReversed=s.config.yaxis[a.yaxisIndex]&&s.config.yaxis[a.yaxisIndex].reversed;var m=a.graphics.group({class:"apexcharts-series",seriesName:x.escapeString(s.globals.seriesNames[v]),rel:r+1,"data:realIndex":v});a.ctx.series.addCollapsedClassToSeries(m,v);var y=a.graphics.group({class:"apexcharts-datalabels","data:realIndex":v}),w=a.graphics.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),k=0,A=0,S=a.initialPositions(n,l,c,d,g,u);l=S.y,k=S.barHeight,d=S.yDivision,u=S.zeroW,n=S.x,A=S.barWidth,c=S.xDivision,g=S.zeroH,a.barHelpers.initializeStackedXYVars(a),1===a.groupCtx.prevY.length&&a.groupCtx.prevY[0].every((function(t){return isNaN(t)}))&&(a.groupCtx.prevY[0]=a.groupCtx.prevY[0].map((function(t){return g})),a.groupCtx.prevYF[0]=a.groupCtx.prevYF[0].map((function(t){return 0})));for(var C=0;C1?(i=c.globals.minXDiff/this.xRatio)*parseInt(this.barOptions.columnWidth,10)/100:n*parseInt(c.config.plotOptions.bar.columnWidth,10)/100,null!==(h=c.globals.seriesGroups)&&void 0!==h&&h.length&&(n/=c.globals.seriesGroups.length),-1===String(c.config.plotOptions.bar.columnWidth).indexOf("%")&&(n=parseInt(c.config.plotOptions.bar.columnWidth,10)),s=c.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?c.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),t=c.globals.padHorizontal+(i-n)/2);return{x:t,y:e,yDivision:a,xDivision:i,barHeight:o,barWidth:n,zeroH:s,zeroW:r}}},{key:"drawStackedBarPaths",value:function(t){for(var e,i=t.indexes,a=t.barHeight,s=t.strokeWidth,r=t.zeroW,o=t.x,n=t.y,l=t.groupIndex,h=t.seriesGroup,c=t.yDivision,d=t.elSeries,g=this.w,u=n+(-1!==l?l*a:0),p=i.i,f=i.j,x=0,b=0;b0){var m=r;this.groupCtx.prevXVal[v-1][f]<0?m=this.series[p][f]>=0?this.groupCtx.prevX[v-1][f]+x-2*(this.isReversed?x:0):this.groupCtx.prevX[v-1][f]:this.groupCtx.prevXVal[v-1][f]>=0&&(m=this.series[p][f]>=0?this.groupCtx.prevX[v-1][f]:this.groupCtx.prevX[v-1][f]-x+2*(this.isReversed?x:0)),e=m}else e=r;o=null===this.series[p][f]?e:e+this.series[p][f]/this.invertedYRatio-2*(this.isReversed?this.series[p][f]/this.invertedYRatio:0);var y=this.barHelpers.getBarpaths({barYPosition:u,barHeight:a,x1:e,x2:o,strokeWidth:s,series:this.series,realIndex:i.realIndex,seriesGroup:h,i:p,j:f,w:g});return this.barHelpers.barBackground({j:f,i:p,y1:u,y2:a,elSeries:d}),n+=c,{pathTo:y.pathTo,pathFrom:y.pathFrom,goalX:this.barHelpers.getGoalValues("x",r,null,p,f),barYPosition:u,x:o,y:n}}},{key:"drawStackedColumnPaths",value:function(t){var e=t.indexes,i=t.x,a=t.y,s=t.xDivision,r=t.barWidth,o=t.zeroH,n=t.groupIndex,l=t.seriesGroup,h=t.elSeries,c=this.w,d=e.i,g=e.j,u=e.bc;if(c.globals.isXNumeric){var p=c.globals.seriesX[d][g];p||(p=0),i=(p-c.globals.minX)/this.xRatio-r/2,c.globals.seriesGroups.length&&(i=(p-c.globals.minX)/this.xRatio-r/2*c.globals.seriesGroups.length)}for(var f,x=i+(-1!==n?n*r:0),b=0,v=0;v0&&!c.globals.isXNumeric||m>0&&c.globals.isXNumeric&&c.globals.seriesX[d-1][g]===c.globals.seriesX[d][g]){var y,w,k,A=Math.min(this.yRatio.length+1,d+1);if(void 0!==this.groupCtx.prevY[m-1]&&this.groupCtx.prevY[m-1].length)for(var S=1;S=0?k-b+2*(this.isReversed?b:0):k;break}if((null===(I=this.groupCtx.prevYVal[m-L])||void 0===I?void 0:I[g])>=0){w=this.series[d][g]>=0?k:k+b-2*(this.isReversed?b:0);break}}void 0===w&&(w=c.globals.gridHeight),f=null!==(y=this.groupCtx.prevYF[0])&&void 0!==y&&y.every((function(t){return 0===t}))&&this.groupCtx.prevYF.slice(1,m).every((function(t){return t.every((function(t){return isNaN(t)}))}))?o:w}else f=o;a=this.series[d][g]?f-this.series[d][g]/this.yRatio[this.yaxisIndex]+2*(this.isReversed?this.series[d][g]/this.yRatio[this.yaxisIndex]:0):f;var T=this.barHelpers.getColumnPaths({barXPosition:x,barWidth:r,y1:f,y2:a,yRatio:this.yRatio[this.yaxisIndex],strokeWidth:this.strokeWidth,series:this.series,seriesGroup:l,realIndex:e.realIndex,i:d,j:g,w:c});return this.barHelpers.barBackground({bc:u,j:g,i:d,x1:x,x2:r,elSeries:h}),i+=s,{pathTo:T.pathTo,pathFrom:T.pathFrom,goalY:this.barHelpers.getGoalValues("y",null,o,d,g),barXPosition:x,x:c.globals.isXNumeric?i-s:i,y:a}}}]),s}(),kt=function(t){n(s,yt);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i,a){var s=this,r=this.w,o=new m(this.ctx),n=r.globals.comboCharts?i:r.config.chart.type,l=new R(this.ctx);this.candlestickOptions=this.w.config.plotOptions.candlestick,this.boxOptions=this.w.config.plotOptions.boxPlot,this.isHorizontal=r.config.plotOptions.bar.horizontal;var h=new y(this.ctx,r);t=h.getLogSeries(t),this.series=t,this.yRatio=h.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t);for(var c=o.group({class:"apexcharts-".concat(n,"-series apexcharts-plot-series")}),d=function(i){s.isBoxPlot="boxPlot"===r.config.chart.type||"boxPlot"===r.config.series[i].type;var n,h,d,g,u=void 0,p=void 0,f=[],b=[],v=r.globals.comboCharts?a[i]:i,m=o.group({class:"apexcharts-series",seriesName:x.escapeString(r.globals.seriesNames[v]),rel:i+1,"data:realIndex":v});s.ctx.series.addCollapsedClassToSeries(m,v),t[i].length>0&&(s.visibleI=s.visibleI+1);var y,w;s.yRatio.length>1&&(s.yaxisIndex=v);var k=s.barHelpers.initialPositions();p=k.y,y=k.barHeight,h=k.yDivision,g=k.zeroW,u=k.x,w=k.barWidth,n=k.xDivision,d=k.zeroH,b.push(u+w/2);for(var A=o.group({class:"apexcharts-datalabels","data:realIndex":v}),S=function(a){var o=s.barHelpers.getStrokeWidth(i,a,v),c=null,x={indexes:{i:i,j:a,realIndex:v},x:u,y:p,strokeWidth:o,elSeries:m};c=s.isHorizontal?s.drawHorizontalBoxPaths(e(e({},x),{},{yDivision:h,barHeight:y,zeroW:g})):s.drawVerticalBoxPaths(e(e({},x),{},{xDivision:n,barWidth:w,zeroH:d})),p=c.y,u=c.x,a>0&&b.push(u+w/2),f.push(p),c.pathTo.forEach((function(e,n){var h=!s.isBoxPlot&&s.candlestickOptions.wick.useFillColor?c.color[n]:r.globals.stroke.colors[i],d=l.fillPath({seriesNumber:v,dataPointIndex:a,color:c.color[n],value:t[i][a]});s.renderSeries({realIndex:v,pathFill:d,lineFill:h,j:a,i:i,pathFrom:c.pathFrom,pathTo:e,strokeWidth:o,elSeries:m,x:u,y:p,series:t,barHeight:y,barWidth:w,elDataLabelsWrap:A,visibleSeries:s.visibleI,type:r.config.chart.type})}))},C=0;Cb.c&&(d=!1);var w=Math.min(b.o,b.c),k=Math.max(b.o,b.c),A=b.m;n.globals.isXNumeric&&(i=(n.globals.seriesX[x][c]-n.globals.minX)/this.xRatio-s/2);var S=i+s*this.visibleI;void 0===this.series[h][c]||null===this.series[h][c]?(w=r,k=r):(w=r-w/f,k=r-k/f,v=r-b.h/f,y=r-b.l/f,A=r-b.m/f);var C=l.move(S,r),L=l.move(S+s/2,w);return n.globals.previousPaths.length>0&&(L=this.getPreviousPath(x,c,!0)),C=this.isBoxPlot?[l.move(S,w)+l.line(S+s/2,w)+l.line(S+s/2,v)+l.line(S+s/4,v)+l.line(S+s-s/4,v)+l.line(S+s/2,v)+l.line(S+s/2,w)+l.line(S+s,w)+l.line(S+s,A)+l.line(S,A)+l.line(S,w+o/2),l.move(S,A)+l.line(S+s,A)+l.line(S+s,k)+l.line(S+s/2,k)+l.line(S+s/2,y)+l.line(S+s-s/4,y)+l.line(S+s/4,y)+l.line(S+s/2,y)+l.line(S+s/2,k)+l.line(S,k)+l.line(S,A)+"z"]:[l.move(S,k)+l.line(S+s/2,k)+l.line(S+s/2,v)+l.line(S+s/2,k)+l.line(S+s,k)+l.line(S+s,w)+l.line(S+s/2,w)+l.line(S+s/2,y)+l.line(S+s/2,w)+l.line(S,w)+l.line(S,k-o/2)],L+=l.move(S,w),n.globals.isXNumeric||(i+=a),{pathTo:C,pathFrom:L,x:i,y:k,barXPosition:S,color:this.isBoxPlot?p:d?[g]:[u]}}},{key:"drawHorizontalBoxPaths",value:function(t){var e=t.indexes;t.x;var i=t.y,a=t.yDivision,s=t.barHeight,r=t.zeroW,o=t.strokeWidth,n=this.w,l=new m(this.ctx),h=e.i,c=e.j,d=this.boxOptions.colors.lower;this.isBoxPlot&&(d=[this.boxOptions.colors.lower,this.boxOptions.colors.upper]);var g=this.invertedYRatio,u=e.realIndex,p=this.getOHLCValue(u,c),f=r,x=r,b=Math.min(p.o,p.c),v=Math.max(p.o,p.c),y=p.m;n.globals.isXNumeric&&(i=(n.globals.seriesX[u][c]-n.globals.minX)/this.invertedXRatio-s/2);var w=i+s*this.visibleI;void 0===this.series[h][c]||null===this.series[h][c]?(b=r,v=r):(b=r+b/g,v=r+v/g,f=r+p.h/g,x=r+p.l/g,y=r+p.m/g);var k=l.move(r,w),A=l.move(b,w+s/2);return n.globals.previousPaths.length>0&&(A=this.getPreviousPath(u,c,!0)),k=[l.move(b,w)+l.line(b,w+s/2)+l.line(f,w+s/2)+l.line(f,w+s/2-s/4)+l.line(f,w+s/2+s/4)+l.line(f,w+s/2)+l.line(b,w+s/2)+l.line(b,w+s)+l.line(y,w+s)+l.line(y,w)+l.line(b+o/2,w),l.move(y,w)+l.line(y,w+s)+l.line(v,w+s)+l.line(v,w+s/2)+l.line(x,w+s/2)+l.line(x,w+s-s/4)+l.line(x,w+s/4)+l.line(x,w+s/2)+l.line(v,w+s/2)+l.line(v,w)+l.line(y,w)+"z"],A+=l.move(b,w),n.globals.isXNumeric||(i+=a),{pathTo:k,pathFrom:A,x:v,y:i,barYPosition:w,color:d}}},{key:"getOHLCValue",value:function(t,e){var i=this.w;return{o:this.isBoxPlot?i.globals.seriesCandleH[t][e]:i.globals.seriesCandleO[t][e],h:this.isBoxPlot?i.globals.seriesCandleO[t][e]:i.globals.seriesCandleH[t][e],m:i.globals.seriesCandleM[t][e],l:this.isBoxPlot?i.globals.seriesCandleC[t][e]:i.globals.seriesCandleL[t][e],c:this.isBoxPlot?i.globals.seriesCandleL[t][e]:i.globals.seriesCandleC[t][e]}}}]),s}(),At=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"checkColorRange",value:function(){var t=this.w,e=!1,i=t.config.plotOptions[t.config.chart.type];return i.colorScale.ranges.length>0&&i.colorScale.ranges.map((function(t,i){t.from<=0&&(e=!0)})),e}},{key:"getShadeColor",value:function(t,e,i,a){var s=this.w,r=1,o=s.config.plotOptions[t].shadeIntensity,n=this.determineColor(t,e,i);s.globals.hasNegs||a?r=s.config.plotOptions[t].reverseNegativeShade?n.percent<0?n.percent/100*(1.25*o):(1-n.percent/100)*(1.25*o):n.percent<=0?1-(1+n.percent/100)*o:(1-n.percent/100)*o:(r=1-n.percent/100,"treemap"===t&&(r=(1-n.percent/100)*(1.25*o)));var l=n.color,h=new x;return s.config.plotOptions[t].enableShades&&(l="dark"===this.w.config.theme.mode?x.hexToRgba(h.shadeColor(-1*r,n.color),s.config.fill.opacity):x.hexToRgba(h.shadeColor(r,n.color),s.config.fill.opacity)),{color:l,colorProps:n}}},{key:"determineColor",value:function(t,e,i){var a=this.w,s=a.globals.series[e][i],r=a.config.plotOptions[t],o=r.colorScale.inverse?i:e;r.distributed&&"treemap"===a.config.chart.type&&(o=i);var n=a.globals.colors[o],l=null,h=Math.min.apply(Math,u(a.globals.series[e])),c=Math.max.apply(Math,u(a.globals.series[e]));r.distributed||"heatmap"!==t||(h=a.globals.minY,c=a.globals.maxY),void 0!==r.colorScale.min&&(h=r.colorScale.mina.globals.maxY?r.colorScale.max:a.globals.maxY);var d=Math.abs(c)+Math.abs(h),g=100*s/(0===d?d-1e-6:d);r.colorScale.ranges.length>0&&r.colorScale.ranges.map((function(t,e){if(s>=t.from&&s<=t.to){n=t.color,l=t.foreColor?t.foreColor:null,h=t.from,c=t.to;var i=Math.abs(c)+Math.abs(h);g=100*s/(0===i?i-1e-6:i)}}));return{color:n,foreColor:l,percent:g}}},{key:"calculateDataLabels",value:function(t){var e=t.text,i=t.x,a=t.y,s=t.i,r=t.j,o=t.colorProps,n=t.fontSize,l=this.w.config.dataLabels,h=new m(this.ctx),c=new O(this.ctx),d=null;if(l.enabled){d=h.group({class:"apexcharts-data-labels"});var g=l.offsetX,u=l.offsetY,p=i+g,f=a+parseFloat(l.style.fontSize)/3+u;c.plotDataLabelsText({x:p,y:f,text:e,i:s,j:r,color:o.foreColor,parent:d,fontSize:n,dataLabelsConfig:l})}return d}},{key:"addListeners",value:function(t){var e=new m(this.ctx);t.node.addEventListener("mouseenter",e.pathMouseEnter.bind(this,t)),t.node.addEventListener("mouseleave",e.pathMouseLeave.bind(this,t)),t.node.addEventListener("mousedown",e.pathMouseDown.bind(this,t))}}]),t}(),St=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w,this.xRatio=i.xRatio,this.yRatio=i.yRatio,this.dynamicAnim=this.w.config.chart.animations.dynamicAnimation,this.helpers=new At(e),this.rectRadius=this.w.config.plotOptions.heatmap.radius,this.strokeWidth=this.w.config.stroke.show?this.w.config.stroke.width:0}return r(t,[{key:"draw",value:function(t){var e=this.w,i=new m(this.ctx),a=i.group({class:"apexcharts-heatmap"});a.attr("clip-path","url(#gridRectMask".concat(e.globals.cuid,")"));var s=e.globals.gridWidth/e.globals.dataPoints,r=e.globals.gridHeight/e.globals.series.length,o=0,n=!1;this.negRange=this.helpers.checkColorRange();var l=t.slice();e.config.yaxis[0].reversed&&(n=!0,l.reverse());for(var h=n?0:l.length-1;n?h=0;n?h++:h--){var c=i.group({class:"apexcharts-series apexcharts-heatmap-series",seriesName:x.escapeString(e.globals.seriesNames[h]),rel:h+1,"data:realIndex":h});if(this.ctx.series.addCollapsedClassToSeries(c,h),e.config.chart.dropShadow.enabled){var d=e.config.chart.dropShadow;new v(this.ctx).dropShadow(c,d,h)}for(var g=0,u=e.config.plotOptions.heatmap.shadeIntensity,p=0;p-1&&this.pieClicked(d),i.config.dataLabels.enabled){var A=w.x,S=w.y,C=100*u/this.fullAngle+"%";if(0!==u&&i.config.plotOptions.pie.dataLabels.minAngleToShowLabelthis.fullAngle?e.endAngle=e.endAngle-(a+o):a+o=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle&&(n=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle-.01),Math.ceil(n)>this.fullAngle&&(n-=this.fullAngle);var l=Math.PI*(n-90)/180,h=e.centerX+s*Math.cos(o),c=e.centerY+s*Math.sin(o),d=e.centerX+s*Math.cos(l),g=e.centerY+s*Math.sin(l),u=x.polarToCartesian(e.centerX,e.centerY,e.donutSize,n),p=x.polarToCartesian(e.centerX,e.centerY,e.donutSize,r),f=a>180?1:0,b=["M",h,c,"A",s,s,0,f,1,d,g];return"donut"===e.chartType?[].concat(b,["L",u.x,u.y,"A",e.donutSize,e.donutSize,0,f,0,p.x,p.y,"L",h,c,"z"]).join(" "):"pie"===e.chartType||"polarArea"===e.chartType?[].concat(b,["L",e.centerX,e.centerY,"L",h,c]).join(" "):[].concat(b).join(" ")}},{key:"drawPolarElements",value:function(t){var e=this.w,i=new _(this.ctx),a=new m(this.ctx),s=new Ct(this.ctx),r=a.group(),o=a.group(),n=i.niceScale(0,Math.ceil(this.maxY),e.config.yaxis[0].tickAmount,0,!0),l=n.result.reverse(),h=n.result.length;this.maxY=n.niceMax;for(var c=e.globals.radialSize,d=c/(h-1),g=0;g1&&t.total.show&&(s=t.total.color);var o=r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-label"),n=r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-value");i=(0,t.value.formatter)(i,r),a||"function"!=typeof t.total.formatter||(i=t.total.formatter(r));var l=e===t.total.label;e=t.name.formatter(e,l,r),null!==o&&(o.textContent=e),null!==n&&(n.textContent=i),null!==o&&(o.style.fill=s)}},{key:"printDataLabelsInner",value:function(t,e){var i=this.w,a=t.getAttribute("data:value"),s=i.globals.seriesNames[parseInt(t.parentNode.getAttribute("rel"),10)-1];i.globals.series.length>1&&this.printInnerLabels(e,s,a,t);var r=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels-group");null!==r&&(r.style.opacity=1)}},{key:"drawSpokes",value:function(t){var e=this,i=this.w,a=new m(this.ctx),s=i.config.plotOptions.polarArea.spokes;if(0!==s.strokeWidth){for(var r=[],o=360/i.globals.series.length,n=0;n1)o&&!e.total.showAlways?l({makeSliceOut:!1,printLabel:!0}):this.printInnerLabels(e,e.total.label,e.total.formatter(s));else if(l({makeSliceOut:!1,printLabel:!0}),!o)if(s.globals.selectedDataPoints.length&&s.globals.series.length>1)if(s.globals.selectedDataPoints[0].length>0){var h=s.globals.selectedDataPoints[0],c=s.globals.dom.baseEl.querySelector(".apexcharts-".concat(this.chartType.toLowerCase(),"-slice-").concat(h));this.printDataLabelsInner(c,e)}else r&&s.globals.selectedDataPoints.length&&0===s.globals.selectedDataPoints[0].length&&(r.style.opacity=0);else r&&s.globals.series.length>1&&(r.style.opacity=0)}}]),t}(),Pt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.chartType=this.w.config.chart.type,this.initialAnim=this.w.config.chart.animations.enabled,this.dynamicAnim=this.initialAnim&&this.w.config.chart.animations.dynamicAnimation.enabled,this.animDur=0;var i=this.w;this.graphics=new m(this.ctx),this.lineColorArr=void 0!==i.globals.stroke.colors?i.globals.stroke.colors:i.globals.colors,this.defaultSize=i.globals.svgHeight0&&(f=i.getPreviousPath(n));for(var b=0;b=10?t.x>0?(i="start",a+=10):t.x<0&&(i="end",a-=10):i="middle",Math.abs(t.y)>=e-10&&(t.y<0?s-=10:t.y>0&&(s+=10)),{textAnchor:i,newX:a,newY:s}}},{key:"getPreviousPath",value:function(t){for(var e=this.w,i=null,a=0;a0&&parseInt(s.realIndex,10)===parseInt(t,10)&&void 0!==e.globals.previousPaths[a].paths[0]&&(i=e.globals.previousPaths[a].paths[0].d)}return i}},{key:"getDataPointsPos",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.dataPointsLen;t=t||[],e=e||[];for(var a=[],s=0;s=360&&(g=360-Math.abs(this.startAngle)-.1);var u=i.drawPath({d:"",stroke:c,strokeWidth:o*parseInt(h.strokeWidth,10)/100,fill:"none",strokeOpacity:h.opacity,classes:"apexcharts-radialbar-area"});if(h.dropShadow.enabled){var p=h.dropShadow;s.dropShadow(u,p)}l.add(u),u.attr("id","apexcharts-radialbarTrack-"+n),this.animatePaths(u,{centerX:t.centerX,centerY:t.centerY,endAngle:g,startAngle:d,size:t.size,i:n,totalItems:2,animBeginArr:0,dur:0,isTrack:!0,easing:e.globals.easing})}return a}},{key:"drawArcs",value:function(t){var e=this.w,i=new m(this.ctx),a=new R(this.ctx),s=new v(this.ctx),r=i.group(),o=this.getStrokeWidth(t);t.size=t.size-o/2;var n=e.config.plotOptions.radialBar.hollow.background,l=t.size-o*t.series.length-this.margin*t.series.length-o*parseInt(e.config.plotOptions.radialBar.track.strokeWidth,10)/100/2,h=l-e.config.plotOptions.radialBar.hollow.margin;void 0!==e.config.plotOptions.radialBar.hollow.image&&(n=this.drawHollowImage(t,r,l,n));var c=this.drawHollow({size:h,centerX:t.centerX,centerY:t.centerY,fill:n||"transparent"});if(e.config.plotOptions.radialBar.hollow.dropShadow.enabled){var d=e.config.plotOptions.radialBar.hollow.dropShadow;s.dropShadow(c,d)}var g=1;!this.radialDataLabels.total.show&&e.globals.series.length>1&&(g=0);var u=null;this.radialDataLabels.show&&(u=this.renderInnerDataLabels(this.radialDataLabels,{hollowSize:l,centerX:t.centerX,centerY:t.centerY,opacity:g})),"back"===e.config.plotOptions.radialBar.hollow.position&&(r.add(c),u&&r.add(u));var p=!1;e.config.plotOptions.radialBar.inverseOrder&&(p=!0);for(var f=p?t.series.length-1:0;p?f>=0:f100?100:t.series[f])/100,S=Math.round(this.totalAngle*A)+this.startAngle,C=void 0;e.globals.dataChanged&&(k=this.startAngle,C=Math.round(this.totalAngle*x.negToZero(e.globals.previousPaths[f])/100)+k),Math.abs(S)+Math.abs(w)>=360&&(S-=.01),Math.abs(C)+Math.abs(k)>=360&&(C-=.01);var L=S-w,P=Array.isArray(e.config.stroke.dashArray)?e.config.stroke.dashArray[f]:e.config.stroke.dashArray,I=i.drawPath({d:"",stroke:y,strokeWidth:o,fill:"none",fillOpacity:e.config.fill.opacity,classes:"apexcharts-radialbar-area apexcharts-radialbar-slice-"+f,strokeDashArray:P});if(m.setAttrs(I.node,{"data:angle":L,"data:value":t.series[f]}),e.config.chart.dropShadow.enabled){var T=e.config.chart.dropShadow;s.dropShadow(I,T,f)}s.setSelectionFilter(I,0,f),this.addListeners(I,this.radialDataLabels),b.add(I),I.attr({index:0,j:f});var M=0;!this.initialAnim||e.globals.resized||e.globals.dataChanged||(M=e.config.chart.animations.speed),e.globals.dataChanged&&(M=e.config.chart.animations.dynamicAnimation.speed),this.animDur=M/(1.2*t.series.length)+this.animDur,this.animBeginArr.push(this.animDur),this.animatePaths(I,{centerX:t.centerX,centerY:t.centerY,endAngle:S,startAngle:w,prevEndAngle:C,prevStartAngle:k,size:t.size,i:f,totalItems:2,animBeginArr:this.animBeginArr,dur:M,shouldSetPrevPaths:!0,easing:e.globals.easing})}return{g:r,elHollow:c,dataLabels:u}}},{key:"drawHollow",value:function(t){var e=new m(this.ctx).drawCircle(2*t.size);return e.attr({class:"apexcharts-radialbar-hollow",cx:t.centerX,cy:t.centerY,r:t.size,fill:t.fill}),e}},{key:"drawHollowImage",value:function(t,e,i,a){var s=this.w,r=new R(this.ctx),o=x.randomId(),n=s.config.plotOptions.radialBar.hollow.image;if(s.config.plotOptions.radialBar.hollow.imageClipped)r.clippedImgArea({width:i,height:i,image:n,patternID:"pattern".concat(s.globals.cuid).concat(o)}),a="url(#pattern".concat(s.globals.cuid).concat(o,")");else{var l=s.config.plotOptions.radialBar.hollow.imageWidth,h=s.config.plotOptions.radialBar.hollow.imageHeight;if(void 0===l&&void 0===h){var c=s.globals.dom.Paper.image(n).loaded((function(e){this.move(t.centerX-e.width/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-e.height/2+s.config.plotOptions.radialBar.hollow.imageOffsetY)}));e.add(c)}else{var d=s.globals.dom.Paper.image(n).loaded((function(e){this.move(t.centerX-l/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-h/2+s.config.plotOptions.radialBar.hollow.imageOffsetY),this.size(l,h)}));e.add(d)}}return a}},{key:"getStrokeWidth",value:function(t){var e=this.w;return t.size*(100-parseInt(e.config.plotOptions.radialBar.hollow.size,10))/100/(t.series.length+1)-this.margin}}]),i}(),Tt=function(t){n(s,yt);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i){var a=this.w,s=new m(this.ctx);this.rangeBarOptions=this.w.config.plotOptions.rangeBar,this.series=t,this.seriesRangeStart=a.globals.seriesRangeStart,this.seriesRangeEnd=a.globals.seriesRangeEnd,this.barHelpers.initVariables(t);for(var r=s.group({class:"apexcharts-rangebar-series apexcharts-plot-series"}),o=0;o0&&(this.visibleI=this.visibleI+1);var f=0,b=0;this.yRatio.length>1&&(this.yaxisIndex=u);var v=this.barHelpers.initialPositions();d=v.y,h=v.zeroW,c=v.x,b=v.barWidth,n=v.xDivision,l=v.zeroH;for(var y=s.group({class:"apexcharts-datalabels","data:realIndex":u}),w=s.group({class:"apexcharts-rangebar-goals-markers",style:"pointer-events: none"}),k=0;k0}));return a=l.config.plotOptions.bar.rangeBarGroupRows?s+o*g:s+r*this.visibleI+o*g,u>-1&&!l.config.plotOptions.bar.rangeBarOverlap&&(h=l.globals.seriesRange[e][u].overlaps).indexOf(c)>-1&&(a=(r=n.barHeight/h.length)*this.visibleI+o*(100-parseInt(this.barOptions.barHeight,10))/100/2+r*(this.visibleI+h.indexOf(c))+o*g),{barYPosition:a,barHeight:r}}},{key:"drawRangeColumnPaths",value:function(t){var e=t.indexes,i=t.x;t.strokeWidth;var a=t.xDivision,s=t.barWidth,r=t.zeroH,o=this.w,n=e.i,l=e.j,h=this.yRatio[this.yaxisIndex],c=e.realIndex,d=this.getRangeValue(c,l),g=Math.min(d.start,d.end),u=Math.max(d.start,d.end);o.globals.isXNumeric&&(i=(o.globals.seriesX[n][l]-o.globals.minX)/this.xRatio-s/2);var p=i+s*this.visibleI;void 0===this.series[n][l]||null===this.series[n][l]?g=r:(g=r-g/h,u=r-u/h);var f=Math.abs(u-g),x=this.barHelpers.getColumnPaths({barXPosition:p,barWidth:s,y1:g,y2:u,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,realIndex:e.realIndex,i:c,j:l,w:o});return o.globals.isXNumeric||(i+=a),{pathTo:x.pathTo,pathFrom:x.pathFrom,barHeight:f,x:i,y:u,goalY:this.barHelpers.getGoalValues("y",null,r,n,l),barXPosition:p}}},{key:"drawRangeBarPaths",value:function(t){var e=t.indexes,i=t.y,a=t.y1,s=t.y2,r=t.yDivision,o=t.barHeight,n=t.barYPosition,l=t.zeroW,h=this.w,c=l+a/this.invertedYRatio,d=l+s/this.invertedYRatio,g=Math.abs(d-c),u=this.barHelpers.getBarpaths({barYPosition:n,barHeight:o,x1:c,x2:d,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,i:e.realIndex,realIndex:e.realIndex,j:e.j,w:h});return h.globals.isXNumeric||(i+=r),{pathTo:u.pathTo,pathFrom:u.pathFrom,barWidth:g,x:d,goalX:this.barHelpers.getGoalValues("x",l,null,e.realIndex,e.j),y:i}}},{key:"getRangeValue",value:function(t,e){var i=this.w;return{start:i.globals.seriesRangeStart[t][e],end:i.globals.seriesRangeEnd[t][e]}}}]),s}(),Mt=function(){function t(e){a(this,t),this.w=e.w,this.lineCtx=e}return r(t,[{key:"sameValueSeriesFix",value:function(t,e){var i=this.w;if(("gradient"===i.config.fill.type||"gradient"===i.config.fill.type[t])&&new y(this.lineCtx.ctx,i).seriesHaveSameValues(t)){var a=e[t].slice();a[a.length-1]=a[a.length-1]+1e-6,e[t]=a}return e}},{key:"calculatePoints",value:function(t){var e=t.series,i=t.realIndex,a=t.x,s=t.y,r=t.i,o=t.j,n=t.prevY,l=this.w,h=[],c=[];if(0===o){var d=this.lineCtx.categoryAxisCorrection+l.config.markers.offsetX;l.globals.isXNumeric&&(d=(l.globals.seriesX[i][0]-l.globals.minX)/this.lineCtx.xRatio+l.config.markers.offsetX),h.push(d),c.push(x.isNumber(e[r][0])?n+l.config.markers.offsetY:null),h.push(a+l.config.markers.offsetX),c.push(x.isNumber(e[r][o+1])?s+l.config.markers.offsetY:null)}else h.push(a+l.config.markers.offsetX),c.push(x.isNumber(e[r][o+1])?s+l.config.markers.offsetY:null);return{x:h,y:c}}},{key:"checkPreviousPaths",value:function(t){for(var e=t.pathFromLine,i=t.pathFromArea,a=t.realIndex,s=this.w,r=0;r0&&parseInt(o.realIndex,10)===parseInt(a,10)&&("line"===o.type?(this.lineCtx.appendPathFrom=!1,e=s.globals.previousPaths[r].paths[0].d):"area"===o.type&&(this.lineCtx.appendPathFrom=!1,i=s.globals.previousPaths[r].paths[0].d,s.config.stroke.show&&s.globals.previousPaths[r].paths[1]&&(e=s.globals.previousPaths[r].paths[1].d)))}return{pathFromLine:e,pathFromArea:i}}},{key:"determineFirstPrevY",value:function(t){var e,i=t.i,a=t.series,s=t.prevY,r=t.lineYPosition,o=this.w;if(void 0!==(null===(e=a[i])||void 0===e?void 0:e[0]))s=(r=o.config.chart.stacked&&i>0?this.lineCtx.prevSeriesY[i-1][0]:this.lineCtx.zeroY)-a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]+2*(this.lineCtx.isReversed?a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]:0);else if(o.config.chart.stacked&&i>0&&void 0===a[i][0])for(var n=i-1;n>=0;n--)if(null!==a[n][0]&&void 0!==a[n][0]){s=r=this.lineCtx.prevSeriesY[n][0];break}return{prevY:s,lineYPosition:r}}}]),t}(),Xt=function(){function t(e,i,s){a(this,t),this.ctx=e,this.w=e.w,this.xyRatios=i,this.pointsChart=!("bubble"!==this.w.config.chart.type&&"scatter"!==this.w.config.chart.type)||s,this.scatter=new H(this.ctx),this.noNegatives=this.w.globals.minX===Number.MAX_VALUE,this.lineHelpers=new Mt(this),this.markers=new D(this.ctx),this.prevSeriesY=[],this.categoryAxisCorrection=0,this.yaxisIndex=0}return r(t,[{key:"draw",value:function(t,i,a,s){var r=this.w,o=new m(this.ctx),n=r.globals.comboCharts?i:r.config.chart.type,l=o.group({class:"apexcharts-".concat(n,"-series apexcharts-plot-series")}),h=new y(this.ctx,r);this.yRatio=this.xyRatios.yRatio,this.zRatio=this.xyRatios.zRatio,this.xRatio=this.xyRatios.xRatio,this.baseLineY=this.xyRatios.baseLineY,t=h.getLogSeries(t),this.yRatio=h.getLogYRatios(this.yRatio);for(var c=[],d=0;d0&&(f=(r.globals.seriesX[g][0]-r.globals.minX)/this.xRatio),p.push(f);var x,b=f,v=void 0,w=b,k=this.zeroY,A=this.zeroY;k=this.lineHelpers.determineFirstPrevY({i:d,series:t,prevY:k,lineYPosition:0}).prevY,u.push(k),x=k;"rangeArea"===n&&(v=A=this.lineHelpers.determineFirstPrevY({i:d,series:s,prevY:A,lineYPosition:0}).prevY);var S={type:n,series:t,realIndex:g,i:d,x:f,y:1,pX:b,pY:x,pathsFrom:this._calculatePathsFrom({type:n,series:t,i:d,realIndex:g,prevX:w,prevY:k,prevY2:A}),linePaths:[],areaPaths:[],seriesIndex:a,lineYPosition:0,xArrj:p,yArrj:u,seriesRangeEnd:s},C=this._iterateOverDataPoints(e(e({},S),{},{iterations:"rangeArea"===n?t[d].length-1:void 0,isRangeStart:!0}));if("rangeArea"===n){var L=this._calculatePathsFrom({series:s,i:d,realIndex:g,prevX:w,prevY:A}),P=this._iterateOverDataPoints(e(e({},S),{},{series:s,pY:v,pathsFrom:L,iterations:s[d].length-1,isRangeStart:!1}));C.linePaths[0]=P.linePath+C.linePath,C.pathFromLine=P.pathFromLine+C.pathFromLine}this._handlePaths({type:n,realIndex:g,i:d,paths:C}),this.elSeries.add(this.elPointsMain),this.elSeries.add(this.elDataLabelsWrap),c.push(this.elSeries)}if(r.config.chart.stacked)for(var I=c.length;I>0;I--)l.add(c[I-1]);else for(var T=0;T1&&(this.yaxisIndex=i),this.isReversed=a.config.yaxis[this.yaxisIndex]&&a.config.yaxis[this.yaxisIndex].reversed,this.zeroY=a.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?a.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),this.areaBottomY=this.zeroY,(this.zeroY>a.globals.gridHeight||"end"===a.config.plotOptions.area.fillTo)&&(this.areaBottomY=a.globals.gridHeight),this.categoryAxisCorrection=this.xDivision/2,this.elSeries=s.group({class:"apexcharts-series",seriesName:x.escapeString(a.globals.seriesNames[i])}),this.elPointsMain=s.group({class:"apexcharts-series-markers-wrap","data:realIndex":i}),this.elDataLabelsWrap=s.group({class:"apexcharts-datalabels","data:realIndex":i});var r=t[e].length===a.globals.dataPoints;this.elSeries.attr({"data:longestSeries":r,rel:e+1,"data:realIndex":i}),this.appendPathFrom=!0}},{key:"_calculatePathsFrom",value:function(t){var e,i,a,s,r=t.type,o=t.series,n=t.i,l=t.realIndex,h=t.prevX,c=t.prevY,d=t.prevY2,g=this.w,u=new m(this.ctx);if(null===o[n][0]){for(var p=0;p0){var f=this.lineHelpers.checkPreviousPaths({pathFromLine:a,pathFromArea:s,realIndex:l});a=f.pathFromLine,s=f.pathFromArea}return{prevX:h,prevY:c,linePath:e,areaPath:i,pathFromLine:a,pathFromArea:s}}},{key:"_handlePaths",value:function(t){var i=t.type,a=t.realIndex,s=t.i,r=t.paths,o=this.w,n=new m(this.ctx),l=new R(this.ctx);this.prevSeriesY.push(r.yArrj),o.globals.seriesXvalues[a]=r.xArrj,o.globals.seriesYvalues[a]=r.yArrj;var h=o.config.forecastDataPoints;if(h.count>0&&"rangeArea"!==i){var c=o.globals.seriesXvalues[a][o.globals.seriesXvalues[a].length-h.count-1],d=n.drawRect(c,0,o.globals.gridWidth,o.globals.gridHeight,0);o.globals.dom.elForecastMask.appendChild(d.node);var g=n.drawRect(0,0,c,o.globals.gridHeight,0);o.globals.dom.elNonForecastMask.appendChild(g.node)}this.pointsChart||o.globals.delayedElements.push({el:this.elPointsMain.node,index:a});var u={i:s,realIndex:a,animationDelay:s,initialSpeed:o.config.chart.animations.speed,dataChangeSpeed:o.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(i)};if("area"===i)for(var p=l.fillPath({seriesNumber:a}),f=0;f0&&"rangeArea"!==i){var S=n.renderPaths(k);S.node.setAttribute("stroke-dasharray",h.dashArray),h.strokeWidth&&S.node.setAttribute("stroke-width",h.strokeWidth),this.elSeries.add(S),S.attr("clip-path","url(#forecastMask".concat(o.globals.cuid,")")),A.attr("clip-path","url(#nonForecastMask".concat(o.globals.cuid,")"))}}}}},{key:"_iterateOverDataPoints",value:function(t){var e=t.type,i=t.series,a=t.iterations,s=t.realIndex,r=t.i,o=t.x,n=t.y,l=t.pX,h=t.pY,c=t.pathsFrom,d=t.linePaths,g=t.areaPaths,u=t.seriesIndex,p=t.lineYPosition,f=t.xArrj,b=t.yArrj,v=t.isRangeStart,y=t.seriesRangeEnd,w=this.w,k=new m(this.ctx),A=this.yRatio,S=c.prevY,C=c.linePath,L=c.areaPath,P=c.pathFromLine,I=c.pathFromArea,T=x.isNumber(w.globals.minYArr[s])?w.globals.minYArr[s]:w.globals.minY;a||(a=w.globals.dataPoints>1?w.globals.dataPoints-1:w.globals.dataPoints);for(var M=n,X=0;X0&&w.globals.collapsedSeries.length-1){e--;break}return e>=0?e:0}(r-1)][X+1]}else p=this.zeroY;else p=this.zeroY;z?n=p-T/A[this.yaxisIndex]+2*(this.isReversed?T/A[this.yaxisIndex]:0):(n=p-i[r][X+1]/A[this.yaxisIndex]+2*(this.isReversed?i[r][X+1]/A[this.yaxisIndex]:0),"rangeArea"===e&&(M=p-y[r][X+1]/A[this.yaxisIndex]+2*(this.isReversed?y[r][X+1]/A[this.yaxisIndex]:0))),f.push(o),b.push(n);var Y=this.lineHelpers.calculatePoints({series:i,x:o,y:n,realIndex:s,i:r,j:X,prevY:S}),F=this._createPaths({type:e,series:i,i:r,realIndex:s,j:X,x:o,y:n,y2:M,pX:l,pY:h,linePath:C,areaPath:L,linePaths:d,areaPaths:g,seriesIndex:u,isRangeStart:v});g=F.areaPaths,d=F.linePaths,l=F.pX,h=F.pY,L=F.areaPath,C=F.linePath,this.appendPathFrom&&(P+=k.line(o,this.zeroY),I+=k.line(o,this.zeroY)),this.handleNullDataPoints(i,Y,r,X,s),this._handleMarkersAndLabels({type:e,pointsPos:Y,i:r,j:X,realIndex:s,isRangeStart:v})}return{yArrj:b,xArrj:f,pathFromArea:I,areaPaths:g,pathFromLine:P,linePaths:d,linePath:C,areaPath:L}}},{key:"_handleMarkersAndLabels",value:function(t){var e=t.type,i=t.pointsPos,a=t.isRangeStart,s=t.i,r=t.j,o=t.realIndex,n=this.w,l=new O(this.ctx);if(this.pointsChart)this.scatter.draw(this.elSeries,r,{realIndex:o,pointsPos:i,zRatio:this.zRatio,elParent:this.elPointsMain});else{n.globals.series[s].length>1&&this.elPointsMain.node.classList.add("apexcharts-element-hidden");var h=this.markers.plotChartMarkers(i,o,r+1);null!==h&&this.elPointsMain.add(h)}var c=l.drawDataLabel({type:e,isRangeStart:a,pos:i,i:o,j:r+1});null!==c&&this.elDataLabelsWrap.add(c)}},{key:"_createPaths",value:function(t){var e=t.type,i=t.series,a=t.i,s=t.realIndex,r=t.j,o=t.x,n=t.y,l=t.y2,h=t.pX,c=t.pY,d=t.linePath,g=t.areaPath,u=t.linePaths,p=t.areaPaths,f=t.seriesIndex,x=t.isRangeStart,b=this.w,v=new m(this.ctx),y=b.config.stroke.curve,w=this.areaBottomY;if(Array.isArray(b.config.stroke.curve)&&(y=Array.isArray(f)?b.config.stroke.curve[f[a]]:b.config.stroke.curve[a]),"smooth"===y){var k=.35*(o-h);b.globals.hasNullValues?(null!==i[a][r]&&(null!==i[a][r+1]?(d=v.move(h,c)+v.curve(h+k,c,o-k,n,o+1,n),g=v.move(h+1,c)+v.curve(h+k,c,o-k,n,o+1,n)+v.line(o,w)+v.line(h,w)+"z"):(d=v.move(h,c),g=v.move(h,c)+"z")),u.push(d),p.push(g)):(d+=v.curve(h+k,c,o-k,n,o,n),g+=v.curve(h+k,c,o-k,n,o,n)),h=o,c=n,r===i[a].length-2&&(g=g+v.curve(h,c,o,n,o,w)+v.move(o,n)+"z","rangeArea"===e&&x?d=d+v.curve(h,c,o,n,o,l)+v.move(o,l)+"z":b.globals.hasNullValues||(u.push(d),p.push(g)))}else{if(null===i[a][r+1]){d+=v.move(o,n);var A=b.globals.isXNumeric?(b.globals.seriesX[s][r]-b.globals.minX)/this.xRatio:o-this.xDivision;g=g+v.line(A,w)+v.move(o,n)+"z"}null===i[a][r]&&(d+=v.move(o,n),g+=v.move(o,w)),"stepline"===y?(d=d+v.line(o,null,"H")+v.line(null,n,"V"),g=g+v.line(o,null,"H")+v.line(null,n,"V")):"straight"===y&&(d+=v.line(o,n),g+=v.line(o,n)),r===i[a].length-2&&(g=g+v.line(o,w)+v.move(o,n)+"z","rangeArea"===e&&x?d=d+v.line(o,l)+v.move(o,l)+"z":(u.push(d),p.push(g)))}return{linePaths:u,areaPaths:p,pX:h,pY:c,linePath:d,areaPath:g}}},{key:"handleNullDataPoints",value:function(t,e,i,a,s){var r=this.w;if(null===t[i][a]&&r.config.markers.showNullDataPoints||1===t[i].length){var o=this.markers.plotChartMarkers(e,s,a+1,this.strokeWidth-r.config.markers.strokeWidth/2,!0);null!==o&&this.elPointsMain.add(o)}}}]),t}();window.TreemapSquared={},window.TreemapSquared.generate=function(){function t(e,i,a,s){this.xoffset=e,this.yoffset=i,this.height=s,this.width=a,this.shortestEdge=function(){return Math.min(this.height,this.width)},this.getCoordinates=function(t){var e,i=[],a=this.xoffset,s=this.yoffset,o=r(t)/this.height,n=r(t)/this.width;if(this.width>=this.height)for(e=0;e=this.height){var a=e/this.height,s=this.width-a;i=new t(this.xoffset+a,this.yoffset,s,this.height)}else{var r=e/this.width,o=this.height-r;i=new t(this.xoffset,this.yoffset+r,this.width,o)}return i}}function e(e,a,s,o,n){o=void 0===o?0:o,n=void 0===n?0:n;var l=i(function(t,e){var i,a=[],s=e/r(t);for(i=0;i=o}(e,l=t[0],n)?(e.push(l),i(t.slice(1),e,s,o)):(h=s.cutArea(r(e),o),o.push(s.getCoordinates(e)),i(t,[],h,o)),o;o.push(s.getCoordinates(e))}function a(t,e){var i=Math.min.apply(Math,t),a=Math.max.apply(Math,t),s=r(t);return Math.max(Math.pow(e,2)*a/Math.pow(s,2),Math.pow(s,2)/(Math.pow(e,2)*i))}function s(t){return t&&t.constructor===Array}function r(t){var e,i=0;for(e=0;er-a&&l.width<=o-s){var h=n.rotateAroundCenter(t.node);t.node.setAttribute("transform","rotate(-90 ".concat(h.x," ").concat(h.y,")"))}}},{key:"animateTreemap",value:function(t,e,i,a){var s=new b(this.ctx);s.animateRect(t,{x:e.x,y:e.y,width:e.width,height:e.height},{x:i.x,y:i.y,width:i.width,height:i.height},a,(function(){s.animationCompleted(t)}))}}]),t}(),Ft=86400,Rt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.timeScaleArray=[],this.utc=this.w.config.xaxis.labels.datetimeUTC}return r(t,[{key:"calculateTimeScaleTicks",value:function(t,i){var a=this,s=this.w;if(s.globals.allSeriesCollapsed)return s.globals.labels=[],s.globals.timescaleLabels=[],[];var r=new I(this.ctx),o=(i-t)/864e5;this.determineInterval(o),s.globals.disableZoomIn=!1,s.globals.disableZoomOut=!1,o<.00011574074074074075?s.globals.disableZoomIn=!0:o>5e4&&(s.globals.disableZoomOut=!0);var n=r.getTimeUnitsfromTimestamp(t,i,this.utc),l=s.globals.gridWidth/o,h=l/24,c=h/60,d=c/60,g=Math.floor(24*o),u=Math.floor(1440*o),p=Math.floor(o*Ft),f=Math.floor(o),x=Math.floor(o/30),b=Math.floor(o/365),v={minMillisecond:n.minMillisecond,minSecond:n.minSecond,minMinute:n.minMinute,minHour:n.minHour,minDate:n.minDate,minMonth:n.minMonth,minYear:n.minYear},m={firstVal:v,currentMillisecond:v.minMillisecond,currentSecond:v.minSecond,currentMinute:v.minMinute,currentHour:v.minHour,currentMonthDate:v.minDate,currentDate:v.minDate,currentMonth:v.minMonth,currentYear:v.minYear,daysWidthOnXAxis:l,hoursWidthOnXAxis:h,minutesWidthOnXAxis:c,secondsWidthOnXAxis:d,numberOfSeconds:p,numberOfMinutes:u,numberOfHours:g,numberOfDays:f,numberOfMonths:x,numberOfYears:b};switch(this.tickInterval){case"years":this.generateYearScale(m);break;case"months":case"half_year":this.generateMonthScale(m);break;case"months_days":case"months_fortnight":case"days":case"week_days":this.generateDayScale(m);break;case"hours":this.generateHourScale(m);break;case"minutes_fives":case"minutes":this.generateMinuteScale(m);break;case"seconds_tens":case"seconds_fives":case"seconds":this.generateSecondScale(m)}var y=this.timeScaleArray.map((function(t){var i={position:t.position,unit:t.unit,year:t.year,day:t.day?t.day:1,hour:t.hour?t.hour:0,month:t.month+1};return"month"===t.unit?e(e({},i),{},{day:1,value:t.value+1}):"day"===t.unit||"hour"===t.unit?e(e({},i),{},{value:t.value}):"minute"===t.unit?e(e({},i),{},{value:t.value,minute:t.value}):"second"===t.unit?e(e({},i),{},{value:t.value,minute:t.minute,second:t.second}):t}));return y.filter((function(t){var e=1,i=Math.ceil(s.globals.gridWidth/120),r=t.value;void 0!==s.config.xaxis.tickAmount&&(i=s.config.xaxis.tickAmount),y.length>i&&(e=Math.floor(y.length/i));var o=!1,n=!1;switch(a.tickInterval){case"years":"year"===t.unit&&(o=!0);break;case"half_year":e=7,"year"===t.unit&&(o=!0);break;case"months":e=1,"year"===t.unit&&(o=!0);break;case"months_fortnight":e=15,"year"!==t.unit&&"month"!==t.unit||(o=!0),30===r&&(n=!0);break;case"months_days":e=10,"month"===t.unit&&(o=!0),30===r&&(n=!0);break;case"week_days":e=8,"month"===t.unit&&(o=!0);break;case"days":e=1,"month"===t.unit&&(o=!0);break;case"hours":"day"===t.unit&&(o=!0);break;case"minutes_fives":case"seconds_fives":r%5!=0&&(n=!0);break;case"seconds_tens":r%10!=0&&(n=!0)}if("hours"===a.tickInterval||"minutes_fives"===a.tickInterval||"seconds_tens"===a.tickInterval||"seconds_fives"===a.tickInterval){if(!n)return!0}else if((r%e==0||o)&&!n)return!0}))}},{key:"recalcDimensionsBasedOnFormat",value:function(t,e){var i=this.w,a=this.formatDates(t),s=this.removeOverlappingTS(a);i.globals.timescaleLabels=s.slice(),new ot(this.ctx).plotCoords()}},{key:"determineInterval",value:function(t){var e=24*t,i=60*e;switch(!0){case t/365>5:this.tickInterval="years";break;case t>800:this.tickInterval="half_year";break;case t>180:this.tickInterval="months";break;case t>90:this.tickInterval="months_fortnight";break;case t>60:this.tickInterval="months_days";break;case t>30:this.tickInterval="week_days";break;case t>2:this.tickInterval="days";break;case e>2.4:this.tickInterval="hours";break;case i>15:this.tickInterval="minutes_fives";break;case i>5:this.tickInterval="minutes";break;case i>1:this.tickInterval="seconds_tens";break;case 60*i>20:this.tickInterval="seconds_fives";break;default:this.tickInterval="seconds"}}},{key:"generateYearScale",value:function(t){var e=t.firstVal,i=t.currentMonth,a=t.currentYear,s=t.daysWidthOnXAxis,r=t.numberOfYears,o=e.minYear,n=0,l=new I(this.ctx),h="year";if(e.minDate>1||e.minMonth>0){var c=l.determineRemainingDaysOfYear(e.minYear,e.minMonth,e.minDate);n=(l.determineDaysOfYear(e.minYear)-c+1)*s,o=e.minYear+1,this.timeScaleArray.push({position:n,value:o,unit:h,year:o,month:x.monthMod(i+1)})}else 1===e.minDate&&0===e.minMonth&&this.timeScaleArray.push({position:n,value:o,unit:h,year:a,month:x.monthMod(i+1)});for(var d=o,g=n,u=0;u1){l=(h.determineDaysOfMonths(a+1,e.minYear)-i+1)*r,n=x.monthMod(a+1);var g=s+d,u=x.monthMod(n),p=n;0===n&&(c="year",p=g,u=1,g+=d+=1),this.timeScaleArray.push({position:l,value:p,unit:c,year:g,month:u})}else this.timeScaleArray.push({position:l,value:n,unit:c,year:s,month:x.monthMod(a)});for(var f=n+1,b=l,v=0,m=1;vo.determineDaysOfMonths(e+1,i)?(h=1,n="month",g=e+=1,e):e},d=(24-e.minHour)*s,g=l,u=c(h,i,a);0===e.minHour&&1===e.minDate?(d=0,g=x.monthMod(e.minMonth),n="month",h=e.minDate,r++):1!==e.minDate&&0===e.minHour&&0===e.minMinute&&(d=0,l=e.minDate,g=l,u=c(h=l,i,a)),this.timeScaleArray.push({position:d,value:g,unit:n,year:this._getYear(a,u,0),month:x.monthMod(u),day:h});for(var p=d,f=0;fn.determineDaysOfMonths(e+1,s)&&(f=1,e+=1),{month:e,date:f}},c=function(t,e){return t>n.determineDaysOfMonths(e+1,s)?e+=1:e},d=60-(e.minMinute+e.minSecond/60),g=d*r,u=e.minHour+1,p=u+1;60===d&&(g=0,p=(u=e.minHour)+1);var f=i,b=c(f,a);this.timeScaleArray.push({position:g,value:u,unit:l,day:f,hour:p,year:s,month:x.monthMod(b)});for(var v=g,m=0;m=24)p=0,l="day",b=h(f+=1,b).month,b=c(f,b);var y=this._getYear(s,b,0);v=60*r+v;var w=0===p?f:p;this.timeScaleArray.push({position:v,value:w,unit:l,hour:p,day:f,year:y,month:x.monthMod(b)}),p++}}},{key:"generateMinuteScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,r=t.currentDate,o=t.currentMonth,n=t.currentYear,l=t.minutesWidthOnXAxis,h=t.secondsWidthOnXAxis,c=t.numberOfMinutes,d=a+1,g=r,u=o,p=n,f=s,b=(60-i-e/1e3)*h,v=0;v=60&&(d=0,24===(f+=1)&&(f=0)),this.timeScaleArray.push({position:b,value:d,unit:"minute",hour:f,minute:d,day:g,year:this._getYear(p,u,0),month:x.monthMod(u)}),b+=l,d++}},{key:"generateSecondScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,r=t.currentDate,o=t.currentMonth,n=t.currentYear,l=t.secondsWidthOnXAxis,h=t.numberOfSeconds,c=i+1,d=a,g=r,u=o,p=n,f=s,b=(1e3-e)/1e3*l,v=0;v=60&&(c=0,++d>=60&&(d=0,24===++f&&(f=0))),this.timeScaleArray.push({position:b,value:c,unit:"second",hour:f,minute:d,second:c,day:g,year:this._getYear(p,u,0),month:x.monthMod(u)}),b+=l,c++}},{key:"createRawDateString",value:function(t,e){var i=t.year;return 0===t.month&&(t.month=1),i+="-"+("0"+t.month.toString()).slice(-2),"day"===t.unit?i+="day"===t.unit?"-"+("0"+e).slice(-2):"-01":i+="-"+("0"+(t.day?t.day:"1")).slice(-2),"hour"===t.unit?i+="hour"===t.unit?"T"+("0"+e).slice(-2):"T00":i+="T"+("0"+(t.hour?t.hour:"0")).slice(-2),"minute"===t.unit?i+=":"+("0"+e).slice(-2):i+=":"+(t.minute?("0"+t.minute).slice(-2):"00"),"second"===t.unit?i+=":"+("0"+e).slice(-2):i+=":00",this.utc&&(i+=".000Z"),i}},{key:"formatDates",value:function(t){var e=this,i=this.w;return t.map((function(t){var a=t.value.toString(),s=new I(e.ctx),r=e.createRawDateString(t,a),o=s.getDate(s.parseDate(r));if(e.utc||(o=s.getDate(s.parseDateWithTimezone(r))),void 0===i.config.xaxis.labels.format){var n="dd MMM",l=i.config.xaxis.labels.datetimeFormatter;"year"===t.unit&&(n=l.year),"month"===t.unit&&(n=l.month),"day"===t.unit&&(n=l.day),"hour"===t.unit&&(n=l.hour),"minute"===t.unit&&(n=l.minute),"second"===t.unit&&(n=l.second),a=s.formatDate(o,n)}else a=s.formatDate(o,i.config.xaxis.labels.format);return{dateString:r,position:t.position,value:a,unit:t.unit,year:t.year,month:t.month}}))}},{key:"removeOverlappingTS",value:function(t){var e,i=this,a=new m(this.ctx),s=!1;t.length>0&&t[0].value&&t.every((function(e){return e.value.length===t[0].value.length}))&&(s=!0,e=a.getTextRects(t[0].value).width);var r=0,o=t.map((function(o,n){if(n>0&&i.w.config.xaxis.labels.hideOverlappingLabels){var l=s?e:a.getTextRects(t[r].value).width,h=t[r].position;return o.position>h+l+10?(r=n,o):null}return o}));return o=o.filter((function(t){return null!==t}))}},{key:"_getYear",value:function(t,e,i){return t+Math.floor(e/12)+i}}]),t}(),Dt=function(){function t(e,i){a(this,t),this.ctx=i,this.w=i.w,this.el=e}return r(t,[{key:"setupElements",value:function(){var t=this.w.globals,e=this.w.config,i=e.chart.type;t.axisCharts=["line","area","bar","rangeBar","rangeArea","candlestick","boxPlot","scatter","bubble","radar","heatmap","treemap"].indexOf(i)>-1,t.xyCharts=["line","area","bar","rangeBar","rangeArea","candlestick","boxPlot","scatter","bubble"].indexOf(i)>-1,t.isBarHorizontal=("bar"===e.chart.type||"rangeBar"===e.chart.type||"boxPlot"===e.chart.type)&&e.plotOptions.bar.horizontal,t.chartClass=".apexcharts"+t.chartID,t.dom.baseEl=this.el,t.dom.elWrap=document.createElement("div"),m.setAttrs(t.dom.elWrap,{id:t.chartClass.substring(1),class:"apexcharts-canvas "+t.chartClass.substring(1)}),this.el.appendChild(t.dom.elWrap),t.dom.Paper=new window.SVG.Doc(t.dom.elWrap),t.dom.Paper.attr({class:"apexcharts-svg","xmlns:data":"ApexChartsNS",transform:"translate(".concat(e.chart.offsetX,", ").concat(e.chart.offsetY,")")}),t.dom.Paper.node.style.background=e.chart.background,this.setSVGDimensions(),t.dom.elLegendForeign=document.createElementNS(t.SVGNS,"foreignObject"),m.setAttrs(t.dom.elLegendForeign,{x:0,y:0,width:t.svgWidth,height:t.svgHeight}),t.dom.elLegendWrap=document.createElement("div"),t.dom.elLegendWrap.classList.add("apexcharts-legend"),t.dom.elLegendWrap.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),t.dom.elLegendForeign.appendChild(t.dom.elLegendWrap),t.dom.Paper.node.appendChild(t.dom.elLegendForeign),t.dom.elGraphical=t.dom.Paper.group().attr({class:"apexcharts-inner apexcharts-graphical"}),t.dom.elDefs=t.dom.Paper.defs(),t.dom.Paper.add(t.dom.elGraphical),t.dom.elGraphical.add(t.dom.elDefs)}},{key:"plotChartType",value:function(t,e){var i=this.w,a=i.config,s=i.globals,r={series:[],i:[]},o={series:[],i:[]},n={series:[],i:[]},l={series:[],i:[]},h={series:[],i:[]},c={series:[],i:[]},d={series:[],i:[]},g={series:[],i:[]},u={series:[],seriesRangeEnd:[],i:[]};s.series.map((function(e,p){var f=0;void 0!==t[p].type?("column"===t[p].type||"bar"===t[p].type?(s.series.length>1&&a.plotOptions.bar.horizontal&&console.warn("Horizontal bars are not supported in a mixed/combo chart. Please turn off `plotOptions.bar.horizontal`"),h.series.push(e),h.i.push(p),f++,i.globals.columnSeries=h.series):"area"===t[p].type?(o.series.push(e),o.i.push(p),f++):"line"===t[p].type?(r.series.push(e),r.i.push(p),f++):"scatter"===t[p].type?(n.series.push(e),n.i.push(p)):"bubble"===t[p].type?(l.series.push(e),l.i.push(p),f++):"candlestick"===t[p].type?(c.series.push(e),c.i.push(p),f++):"boxPlot"===t[p].type?(d.series.push(e),d.i.push(p),f++):"rangeBar"===t[p].type?(g.series.push(e),g.i.push(p),f++):"rangeArea"===t[p].type?(u.series.push(s.seriesRangeStart[p]),u.seriesRangeEnd.push(s.seriesRangeEnd[p]),u.i.push(p),f++):console.warn("You have specified an unrecognized chart type. Available types for this property are line/area/column/bar/scatter/bubble/candlestick/boxPlot/rangeBar/rangeArea"),f>1&&(s.comboCharts=!0)):(r.series.push(e),r.i.push(p))}));var p=new Xt(this.ctx,e),f=new kt(this.ctx,e);this.ctx.pie=new Lt(this.ctx);var x=new It(this.ctx);this.ctx.rangeBar=new Tt(this.ctx,e);var b=new Pt(this.ctx),v=[];if(s.comboCharts){if(o.series.length>0&&v.push(p.draw(o.series,"area",o.i)),h.series.length>0)if(i.config.chart.stacked){var m=new wt(this.ctx,e);v.push(m.draw(h.series,h.i))}else this.ctx.bar=new yt(this.ctx,e),v.push(this.ctx.bar.draw(h.series,h.i));if(u.series.length>0&&v.push(p.draw(u.series,"rangeArea",u.i,u.seriesRangeEnd)),r.series.length>0&&v.push(p.draw(r.series,"line",r.i)),c.series.length>0&&v.push(f.draw(c.series,"candlestick",c.i)),d.series.length>0&&v.push(f.draw(d.series,"boxPlot",d.i)),g.series.length>0&&v.push(this.ctx.rangeBar.draw(g.series,g.i)),n.series.length>0){var y=new Xt(this.ctx,e,!0);v.push(y.draw(n.series,"scatter",n.i))}if(l.series.length>0){var w=new Xt(this.ctx,e,!0);v.push(w.draw(l.series,"bubble",l.i))}}else switch(a.chart.type){case"line":v=p.draw(s.series,"line");break;case"area":v=p.draw(s.series,"area");break;case"bar":if(a.chart.stacked)v=new wt(this.ctx,e).draw(s.series);else this.ctx.bar=new yt(this.ctx,e),v=this.ctx.bar.draw(s.series);break;case"candlestick":v=new kt(this.ctx,e).draw(s.series,"candlestick");break;case"boxPlot":v=new kt(this.ctx,e).draw(s.series,"boxPlot");break;case"rangeBar":v=this.ctx.rangeBar.draw(s.series);break;case"rangeArea":v=p.draw(s.seriesRangeStart,"rangeArea",void 0,s.seriesRangeEnd);break;case"heatmap":v=new St(this.ctx,e).draw(s.series);break;case"treemap":v=new Yt(this.ctx,e).draw(s.series);break;case"pie":case"donut":case"polarArea":v=this.ctx.pie.draw(s.series);break;case"radialBar":v=x.draw(s.series);break;case"radar":v=b.draw(s.series);break;default:v=p.draw(s.series)}return v}},{key:"setSVGDimensions",value:function(){var t=this.w.globals,e=this.w.config;t.svgWidth=e.chart.width,t.svgHeight=e.chart.height;var i=x.getDimensions(this.el),a=e.chart.width.toString().split(/[0-9]+/g).pop();"%"===a?x.isNumber(i[0])&&(0===i[0].width&&(i=x.getDimensions(this.el.parentNode)),t.svgWidth=i[0]*parseInt(e.chart.width,10)/100):"px"!==a&&""!==a||(t.svgWidth=parseInt(e.chart.width,10));var s=e.chart.height.toString().split(/[0-9]+/g).pop();if("auto"!==t.svgHeight&&""!==t.svgHeight)if("%"===s){var r=x.getDimensions(this.el.parentNode);t.svgHeight=r[1]*parseInt(e.chart.height,10)/100}else t.svgHeight=parseInt(e.chart.height,10);else t.axisCharts?t.svgHeight=t.svgWidth/1.61:t.svgHeight=t.svgWidth/1.2;if(t.svgWidth<0&&(t.svgWidth=0),t.svgHeight<0&&(t.svgHeight=0),m.setAttrs(t.dom.Paper.node,{width:t.svgWidth,height:t.svgHeight}),"%"!==s){var o=e.chart.sparkline.enabled?0:t.axisCharts?e.chart.parentHeightOffset:0;t.dom.Paper.node.parentNode.parentNode.style.minHeight=t.svgHeight+o+"px"}t.dom.elWrap.style.width=t.svgWidth+"px",t.dom.elWrap.style.height=t.svgHeight+"px"}},{key:"shiftGraphPosition",value:function(){var t=this.w.globals,e=t.translateY,i={transform:"translate("+t.translateX+", "+e+")"};m.setAttrs(t.dom.elGraphical.node,i)}},{key:"resizeNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=0,a=t.config.chart.sparkline.enabled?1:15;a+=t.config.grid.padding.bottom,"top"!==t.config.legend.position&&"bottom"!==t.config.legend.position||!t.config.legend.show||t.config.legend.floating||(i=new lt(this.ctx).legendHelpers.getLegendBBox().clwh+10);var s=t.globals.dom.baseEl.querySelector(".apexcharts-radialbar, .apexcharts-pie"),r=2.05*t.globals.radialSize;if(s&&!t.config.chart.sparkline.enabled&&0!==t.config.plotOptions.radialBar.startAngle){var o=x.getBoundingClientRect(s);r=o.bottom;var n=o.bottom-o.top;r=Math.max(2.05*t.globals.radialSize,n)}var l=r+e.translateY+i+a;e.dom.elLegendForeign&&e.dom.elLegendForeign.setAttribute("height",l),t.config.chart.height&&String(t.config.chart.height).indexOf("%")>0||(e.dom.elWrap.style.height=l+"px",m.setAttrs(e.dom.Paper.node,{height:l}),e.dom.Paper.node.parentNode.parentNode.style.minHeight=l+"px")}},{key:"coreCalculations",value:function(){new U(this.ctx).init()}},{key:"resetGlobals",value:function(){var t=this,e=function(){return t.w.config.series.map((function(t){return[]}))},i=new Y,a=this.w.globals;i.initGlobalVars(a),a.seriesXvalues=e(),a.seriesYvalues=e()}},{key:"isMultipleY",value:function(){if(this.w.config.yaxis.constructor===Array&&this.w.config.yaxis.length>1)return this.w.globals.isMultipleYAxis=!0,!0}},{key:"xySettings",value:function(){var t=null,e=this.w;if(e.globals.axisCharts){if("back"===e.config.xaxis.crosshairs.position)new Q(this.ctx).drawXCrosshairs();if("back"===e.config.yaxis[0].crosshairs.position)new Q(this.ctx).drawYCrosshairs();if("datetime"===e.config.xaxis.type&&void 0===e.config.xaxis.labels.formatter){this.ctx.timeScale=new Rt(this.ctx);var i=[];isFinite(e.globals.minX)&&isFinite(e.globals.maxX)&&!e.globals.isBarHorizontal?i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minX,e.globals.maxX):e.globals.isBarHorizontal&&(i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minY,e.globals.maxY)),this.ctx.timeScale.recalcDimensionsBasedOnFormat(i)}t=new y(this.ctx).getCalculatedRatios()}return t}},{key:"updateSourceChart",value:function(t){this.ctx.w.globals.selection=void 0,this.ctx.updateHelpers._updateOptions({chart:{selection:{xaxis:{min:t.w.globals.minX,max:t.w.globals.maxX}}}},!1,!1)}},{key:"setupBrushHandler",value:function(){var t=this,i=this.w;if(i.config.chart.brush.enabled&&"function"!=typeof i.config.chart.events.selection){var a=i.config.chart.brush.targets||[i.config.chart.brush.target];a.forEach((function(e){var i=ApexCharts.getChartByID(e);i.w.globals.brushSource=t.ctx,"function"!=typeof i.w.config.chart.events.zoomed&&(i.w.config.chart.events.zoomed=function(){t.updateSourceChart(i)}),"function"!=typeof i.w.config.chart.events.scrolled&&(i.w.config.chart.events.scrolled=function(){t.updateSourceChart(i)})})),i.config.chart.events.selection=function(t,s){a.forEach((function(t){var a=ApexCharts.getChartByID(t),r=x.clone(i.config.yaxis);if(i.config.chart.brush.autoScaleYaxis&&1===a.w.globals.series.length){var o=new _(a);r=o.autoScaleY(a,r,s)}var n=a.w.config.yaxis.reduce((function(t,i,s){return[].concat(u(t),[e(e({},a.w.config.yaxis[s]),{},{min:r[0].min,max:r[0].max})])}),[]);a.ctx.updateHelpers._updateOptions({xaxis:{min:s.xaxis.min,max:s.xaxis.max},yaxis:n},!1,!1,!1,!1)}))}}}}]),t}(),Ht=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"_updateOptions",value:function(t){var e=this,a=arguments.length>1&&void 0!==arguments[1]&&arguments[1],s=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],r=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],o=arguments.length>4&&void 0!==arguments[4]&&arguments[4];return new Promise((function(n){var l=[e.ctx];r&&(l=e.ctx.getSyncedCharts()),e.ctx.w.globals.isExecCalled&&(l=[e.ctx],e.ctx.w.globals.isExecCalled=!1),l.forEach((function(r,h){var c=r.w;if(c.globals.shouldAnimate=s,a||(c.globals.resized=!0,c.globals.dataChanged=!0,s&&r.series.getPreviousPaths()),t&&"object"===i(t)&&(r.config=new E(t),t=y.extendArrayProps(r.config,t,c),r.w.globals.chartID!==e.ctx.w.globals.chartID&&delete t.series,c.config=x.extend(c.config,t),o&&(c.globals.lastXAxis=t.xaxis?x.clone(t.xaxis):[],c.globals.lastYAxis=t.yaxis?x.clone(t.yaxis):[],c.globals.initialConfig=x.extend({},c.config),c.globals.initialSeries=x.clone(c.config.series),t.series))){for(var d=0;d2&&void 0!==arguments[2]&&arguments[2];return new Promise((function(s){var r,o=i.w;return o.globals.shouldAnimate=e,o.globals.dataChanged=!0,e&&i.ctx.series.getPreviousPaths(),o.globals.axisCharts?(0===(r=t.map((function(t,e){return i._extendSeries(t,e)}))).length&&(r=[{data:[]}]),o.config.series=r):o.config.series=t.slice(),a&&(o.globals.initialConfig.series=x.clone(o.config.series),o.globals.initialSeries=x.clone(o.config.series)),i.ctx.update().then((function(){s(i.ctx)}))}))}},{key:"_extendSeries",value:function(t,i){var a=this.w,s=a.config.series[i];return e(e({},a.config.series[i]),{},{name:t.name?t.name:s&&s.name,color:t.color?t.color:s&&s.color,type:t.type?t.type:s&&s.type,data:t.data?t.data:s&&s.data})}},{key:"toggleDataPointSelection",value:function(t,e){var i=this.w,a=null,s=".apexcharts-series[data\\:realIndex='".concat(t,"']");return i.globals.axisCharts?a=i.globals.dom.Paper.select("".concat(s," path[j='").concat(e,"'], ").concat(s," circle[j='").concat(e,"'], ").concat(s," rect[j='").concat(e,"']")).members[0]:void 0===e&&(a=i.globals.dom.Paper.select("".concat(s," path[j='").concat(t,"']")).members[0],"pie"!==i.config.chart.type&&"polarArea"!==i.config.chart.type&&"donut"!==i.config.chart.type||this.ctx.pie.pieClicked(t)),a?(new m(this.ctx).pathMouseDown(a,null),a.node?a.node:null):(console.warn("toggleDataPointSelection: Element not found"),null)}},{key:"forceXAxisUpdate",value:function(t){var e=this.w;if(["min","max"].forEach((function(i){void 0!==t.xaxis[i]&&(e.config.xaxis[i]=t.xaxis[i],e.globals.lastXAxis[i]=t.xaxis[i])})),t.xaxis.categories&&t.xaxis.categories.length&&(e.config.xaxis.categories=t.xaxis.categories),e.config.xaxis.convertedCatToNumeric){var i=new z(t);t=i.convertCatToNumericXaxis(t,this.ctx)}return t}},{key:"forceYAxisUpdate",value:function(t){return t.chart&&t.chart.stacked&&"100%"===t.chart.stackType&&(Array.isArray(t.yaxis)?t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})):(t.yaxis.min=0,t.yaxis.max=100)),t}},{key:"revertDefaultAxisMinMax",value:function(t){var e=this,i=this.w,a=i.globals.lastXAxis,s=i.globals.lastYAxis;t&&t.xaxis&&(a=t.xaxis),t&&t.yaxis&&(s=t.yaxis),i.config.xaxis.min=a.min,i.config.xaxis.max=a.max;var r=function(t){void 0!==s[t]&&(i.config.yaxis[t].min=s[t].min,i.config.yaxis[t].max=s[t].max)};i.config.yaxis.map((function(t,a){i.globals.zoomed||void 0!==s[a]?r(a):void 0!==e.ctx.opts.yaxis[a]&&(t.min=e.ctx.opts.yaxis[a].min,t.max=e.ctx.opts.yaxis[a].max)}))}}]),t}();zt="undefined"!=typeof window?window:void 0,Et=function(t,e){var a=(void 0!==this?this:t).SVG=function(t){if(a.supported)return t=new a.Doc(t),a.parser.draw||a.prepare(),t};if(a.ns="http://www.w3.org/2000/svg",a.xmlns="http://www.w3.org/2000/xmlns/",a.xlink="http://www.w3.org/1999/xlink",a.svgjs="http://svgjs.dev",a.supported=!0,!a.supported)return!1;a.did=1e3,a.eid=function(t){return"Svgjs"+d(t)+a.did++},a.create=function(t){var i=e.createElementNS(this.ns,t);return i.setAttribute("id",this.eid(t)),i},a.extend=function(){var t,e;e=(t=[].slice.call(arguments)).pop();for(var i=t.length-1;i>=0;i--)if(t[i])for(var s in e)t[i].prototype[s]=e[s];a.Set&&a.Set.inherit&&a.Set.inherit()},a.invent=function(t){var e="function"==typeof t.create?t.create:function(){this.constructor.call(this,a.create(t.create))};return t.inherit&&(e.prototype=new t.inherit),t.extend&&a.extend(e,t.extend),t.construct&&a.extend(t.parent||a.Container,t.construct),e},a.adopt=function(e){return e?e.instance?e.instance:((i="svg"==e.nodeName?e.parentNode instanceof t.SVGElement?new a.Nested:new a.Doc:"linearGradient"==e.nodeName?new a.Gradient("linear"):"radialGradient"==e.nodeName?new a.Gradient("radial"):a[d(e.nodeName)]?new(a[d(e.nodeName)]):new a.Element(e)).type=e.nodeName,i.node=e,e.instance=i,i instanceof a.Doc&&i.namespace().defs(),i.setData(JSON.parse(e.getAttribute("svgjs:data"))||{}),i):null;var i},a.prepare=function(){var t=e.getElementsByTagName("body")[0],i=(t?new a.Doc(t):a.adopt(e.documentElement).nested()).size(2,0);a.parser={body:t||e.documentElement,draw:i.style("opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden").node,poly:i.polyline().node,path:i.path().node,native:a.create("svg")}},a.parser={native:a.create("svg")},e.addEventListener("DOMContentLoaded",(function(){a.parser.draw||a.prepare()}),!1),a.regex={numberAndUnit:/^([+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?)([a-z%]*)$/i,hex:/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i,rgb:/rgb\((\d+),(\d+),(\d+)\)/,reference:/#([a-z0-9\-_]+)/i,transforms:/\)\s*,?\s*/,whitespace:/\s/g,isHex:/^#[a-f0-9]{3,6}$/i,isRgb:/^rgb\(/,isCss:/[^:]+:[^;]+;?/,isBlank:/^(\s+)?$/,isNumber:/^[+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i,isPercent:/^-?[\d\.]+%$/,isImage:/\.(jpg|jpeg|png|gif|svg)(\?[^=]+.*)?/i,delimiter:/[\s,]+/,hyphen:/([^e])\-/gi,pathLetters:/[MLHVCSQTAZ]/gi,isPathLetter:/[MLHVCSQTAZ]/i,numbersWithDots:/((\d?\.\d+(?:e[+-]?\d+)?)((?:\.\d+(?:e[+-]?\d+)?)+))+/gi,dots:/\./g},a.utils={map:function(t,e){for(var i=t.length,a=[],s=0;s1?1:t,new a.Color({r:~~(this.r+(this.destination.r-this.r)*t),g:~~(this.g+(this.destination.g-this.g)*t),b:~~(this.b+(this.destination.b-this.b)*t)})):this}}),a.Color.test=function(t){return t+="",a.regex.isHex.test(t)||a.regex.isRgb.test(t)},a.Color.isRgb=function(t){return t&&"number"==typeof t.r&&"number"==typeof t.g&&"number"==typeof t.b},a.Color.isColor=function(t){return a.Color.isRgb(t)||a.Color.test(t)},a.Array=function(t,e){0==(t=(t||[]).valueOf()).length&&e&&(t=e.valueOf()),this.value=this.parse(t)},a.extend(a.Array,{toString:function(){return this.value.join(" ")},valueOf:function(){return this.value},parse:function(t){return t=t.valueOf(),Array.isArray(t)?t:this.split(t)}}),a.PointArray=function(t,e){a.Array.call(this,t,e||[[0,0]])},a.PointArray.prototype=new a.Array,a.PointArray.prototype.constructor=a.PointArray;for(var s={M:function(t,e,i){return e.x=i.x=t[0],e.y=i.y=t[1],["M",e.x,e.y]},L:function(t,e){return e.x=t[0],e.y=t[1],["L",t[0],t[1]]},H:function(t,e){return e.x=t[0],["H",t[0]]},V:function(t,e){return e.y=t[0],["V",t[0]]},C:function(t,e){return e.x=t[4],e.y=t[5],["C",t[0],t[1],t[2],t[3],t[4],t[5]]},Q:function(t,e){return e.x=t[2],e.y=t[3],["Q",t[0],t[1],t[2],t[3]]},Z:function(t,e,i){return e.x=i.x,e.y=i.y,["Z"]}},r="mlhvqtcsaz".split(""),o=0,n=r.length;ol);return r},bbox:function(){return a.parser.draw||a.prepare(),a.parser.path.setAttribute("d",this.toString()),a.parser.path.getBBox()}}),a.Number=a.invent({create:function(t,e){this.value=0,this.unit=e||"","number"==typeof t?this.value=isNaN(t)?0:isFinite(t)?t:t<0?-34e37:34e37:"string"==typeof t?(e=t.match(a.regex.numberAndUnit))&&(this.value=parseFloat(e[1]),"%"==e[5]?this.value/=100:"s"==e[5]&&(this.value*=1e3),this.unit=e[5]):t instanceof a.Number&&(this.value=t.valueOf(),this.unit=t.unit)},extend:{toString:function(){return("%"==this.unit?~~(1e8*this.value)/1e6:"s"==this.unit?this.value/1e3:this.value)+this.unit},toJSON:function(){return this.toString()},valueOf:function(){return this.value},plus:function(t){return t=new a.Number(t),new a.Number(this+t,this.unit||t.unit)},minus:function(t){return t=new a.Number(t),new a.Number(this-t,this.unit||t.unit)},times:function(t){return t=new a.Number(t),new a.Number(this*t,this.unit||t.unit)},divide:function(t){return t=new a.Number(t),new a.Number(this/t,this.unit||t.unit)},to:function(t){var e=new a.Number(this);return"string"==typeof t&&(e.unit=t),e},morph:function(t){return this.destination=new a.Number(t),t.relative&&(this.destination.value+=this.value),this},at:function(t){return this.destination?new a.Number(this.destination).minus(this).times(t).plus(this):this}}}),a.Element=a.invent({create:function(t){this._stroke=a.defaults.attrs.stroke,this._event=null,this.dom={},(this.node=t)&&(this.type=t.nodeName,this.node.instance=this,this._stroke=t.getAttribute("stroke")||this._stroke)},extend:{x:function(t){return this.attr("x",t)},y:function(t){return this.attr("y",t)},cx:function(t){return null==t?this.x()+this.width()/2:this.x(t-this.width()/2)},cy:function(t){return null==t?this.y()+this.height()/2:this.y(t-this.height()/2)},move:function(t,e){return this.x(t).y(e)},center:function(t,e){return this.cx(t).cy(e)},width:function(t){return this.attr("width",t)},height:function(t){return this.attr("height",t)},size:function(t,e){var i=u(this,t,e);return this.width(new a.Number(i.width)).height(new a.Number(i.height))},clone:function(t){this.writeDataToDom();var e=x(this.node.cloneNode(!0));return t?t.add(e):this.after(e),e},remove:function(){return this.parent()&&this.parent().removeElement(this),this},replace:function(t){return this.after(t).remove(),t},addTo:function(t){return t.put(this)},putIn:function(t){return t.add(this)},id:function(t){return this.attr("id",t)},show:function(){return this.style("display","")},hide:function(){return this.style("display","none")},visible:function(){return"none"!=this.style("display")},toString:function(){return this.attr("id")},classes:function(){var t=this.attr("class");return null==t?[]:t.trim().split(a.regex.delimiter)},hasClass:function(t){return-1!=this.classes().indexOf(t)},addClass:function(t){if(!this.hasClass(t)){var e=this.classes();e.push(t),this.attr("class",e.join(" "))}return this},removeClass:function(t){return this.hasClass(t)&&this.attr("class",this.classes().filter((function(e){return e!=t})).join(" ")),this},toggleClass:function(t){return this.hasClass(t)?this.removeClass(t):this.addClass(t)},reference:function(t){return a.get(this.attr(t))},parent:function(e){var i=this;if(!i.node.parentNode)return null;if(i=a.adopt(i.node.parentNode),!e)return i;for(;i&&i.node instanceof t.SVGElement;){if("string"==typeof e?i.matches(e):i instanceof e)return i;if(!i.node.parentNode||"#document"==i.node.parentNode.nodeName)return null;i=a.adopt(i.node.parentNode)}},doc:function(){return this instanceof a.Doc?this:this.parent(a.Doc)},parents:function(t){var e=[],i=this;do{if(!(i=i.parent(t))||!i.node)break;e.push(i)}while(i.parent);return e},matches:function(t){return function(t,e){return(t.matches||t.matchesSelector||t.msMatchesSelector||t.mozMatchesSelector||t.webkitMatchesSelector||t.oMatchesSelector).call(t,e)}(this.node,t)},native:function(){return this.node},svg:function(t){var i=e.createElement("svg");if(!(t&&this instanceof a.Parent))return i.appendChild(t=e.createElement("svg")),this.writeDataToDom(),t.appendChild(this.node.cloneNode(!0)),i.innerHTML.replace(/^/,"").replace(/<\/svg>$/,"");i.innerHTML=""+t.replace(/\n/,"").replace(/<([\w:-]+)([^<]+?)\/>/g,"<$1$2>")+"";for(var s=0,r=i.firstChild.childNodes.length;s":function(t){return-Math.cos(t*Math.PI)/2+.5},">":function(t){return Math.sin(t*Math.PI/2)},"<":function(t){return 1-Math.cos(t*Math.PI/2)}},a.morph=function(t){return function(e,i){return new a.MorphObj(e,i).at(t)}},a.Situation=a.invent({create:function(t){this.init=!1,this.reversed=!1,this.reversing=!1,this.duration=new a.Number(t.duration).valueOf(),this.delay=new a.Number(t.delay).valueOf(),this.start=+new Date+this.delay,this.finish=this.start+this.duration,this.ease=t.ease,this.loop=0,this.loops=!1,this.animations={},this.attrs={},this.styles={},this.transforms=[],this.once={}}}),a.FX=a.invent({create:function(t){this._target=t,this.situations=[],this.active=!1,this.situation=null,this.paused=!1,this.lastPos=0,this.pos=0,this.absPos=0,this._speed=1},extend:{animate:function(t,e,s){"object"===i(t)&&(e=t.ease,s=t.delay,t=t.duration);var r=new a.Situation({duration:t||1e3,delay:s||0,ease:a.easing[e||"-"]||e});return this.queue(r),this},target:function(t){return t&&t instanceof a.Element?(this._target=t,this):this._target},timeToAbsPos:function(t){return(t-this.situation.start)/(this.situation.duration/this._speed)},absPosToTime:function(t){return this.situation.duration/this._speed*t+this.situation.start},startAnimFrame:function(){this.stopAnimFrame(),this.animationFrame=t.requestAnimationFrame(function(){this.step()}.bind(this))},stopAnimFrame:function(){t.cancelAnimationFrame(this.animationFrame)},start:function(){return!this.active&&this.situation&&(this.active=!0,this.startCurrent()),this},startCurrent:function(){return this.situation.start=+new Date+this.situation.delay/this._speed,this.situation.finish=this.situation.start+this.situation.duration/this._speed,this.initAnimations().step()},queue:function(t){return("function"==typeof t||t instanceof a.Situation)&&this.situations.push(t),this.situation||(this.situation=this.situations.shift()),this},dequeue:function(){return this.stop(),this.situation=this.situations.shift(),this.situation&&(this.situation instanceof a.Situation?this.start():this.situation.call(this)),this},initAnimations:function(){var t,e=this.situation;if(e.init)return this;for(var i in e.animations){t=this.target()[i](),Array.isArray(t)||(t=[t]),Array.isArray(e.animations[i])||(e.animations[i]=[e.animations[i]]);for(var s=t.length;s--;)e.animations[i][s]instanceof a.Number&&(t[s]=new a.Number(t[s])),e.animations[i][s]=t[s].morph(e.animations[i][s])}for(var i in e.attrs)e.attrs[i]=new a.MorphObj(this.target().attr(i),e.attrs[i]);for(var i in e.styles)e.styles[i]=new a.MorphObj(this.target().style(i),e.styles[i]);return e.initialTransformation=this.target().matrixify(),e.init=!0,this},clearQueue:function(){return this.situations=[],this},clearCurrent:function(){return this.situation=null,this},stop:function(t,e){var i=this.active;return this.active=!1,e&&this.clearQueue(),t&&this.situation&&(!i&&this.startCurrent(),this.atEnd()),this.stopAnimFrame(),this.clearCurrent()},after:function(t){var e=this.last();return this.target().on("finished.fx",(function i(a){a.detail.situation==e&&(t.call(this,e),this.off("finished.fx",i))})),this._callStart()},during:function(t){var e=this.last(),i=function(i){i.detail.situation==e&&t.call(this,i.detail.pos,a.morph(i.detail.pos),i.detail.eased,e)};return this.target().off("during.fx",i).on("during.fx",i),this.after((function(){this.off("during.fx",i)})),this._callStart()},afterAll:function(t){var e=function e(i){t.call(this),this.off("allfinished.fx",e)};return this.target().off("allfinished.fx",e).on("allfinished.fx",e),this._callStart()},last:function(){return this.situations.length?this.situations[this.situations.length-1]:this.situation},add:function(t,e,i){return this.last()[i||"animations"][t]=e,this._callStart()},step:function(t){var e,i,a;t||(this.absPos=this.timeToAbsPos(+new Date)),!1!==this.situation.loops?(e=Math.max(this.absPos,0),i=Math.floor(e),!0===this.situation.loops||ithis.lastPos&&r<=s&&(this.situation.once[r].call(this.target(),this.pos,s),delete this.situation.once[r]);return this.active&&this.target().fire("during",{pos:this.pos,eased:s,fx:this,situation:this.situation}),this.situation?(this.eachAt(),1==this.pos&&!this.situation.reversed||this.situation.reversed&&0==this.pos?(this.stopAnimFrame(),this.target().fire("finished",{fx:this,situation:this.situation}),this.situations.length||(this.target().fire("allfinished"),this.situations.length||(this.target().off(".fx"),this.active=!1)),this.active?this.dequeue():this.clearCurrent()):!this.paused&&this.active&&this.startAnimFrame(),this.lastPos=s,this):this},eachAt:function(){var t,e=this,i=this.target(),s=this.situation;for(var r in s.animations)t=[].concat(s.animations[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i[r].apply(i,t);for(var r in s.attrs)t=[r].concat(s.attrs[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i.attr.apply(i,t);for(var r in s.styles)t=[r].concat(s.styles[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i.style.apply(i,t);if(s.transforms.length){t=s.initialTransformation,r=0;for(var o=s.transforms.length;r=0;--s)this[v[s]]=null!=t[v[s]]?t[v[s]]:e[v[s]]},extend:{extract:function(){var t=p(this,0,1);p(this,1,0);var e=180/Math.PI*Math.atan2(t.y,t.x)-90;return{x:this.e,y:this.f,transformedX:(this.e*Math.cos(e*Math.PI/180)+this.f*Math.sin(e*Math.PI/180))/Math.sqrt(this.a*this.a+this.b*this.b),transformedY:(this.f*Math.cos(e*Math.PI/180)+this.e*Math.sin(-e*Math.PI/180))/Math.sqrt(this.c*this.c+this.d*this.d),rotation:e,a:this.a,b:this.b,c:this.c,d:this.d,e:this.e,f:this.f,matrix:new a.Matrix(this)}},clone:function(){return new a.Matrix(this)},morph:function(t){return this.destination=new a.Matrix(t),this},multiply:function(t){return new a.Matrix(this.native().multiply(function(t){return t instanceof a.Matrix||(t=new a.Matrix(t)),t}(t).native()))},inverse:function(){return new a.Matrix(this.native().inverse())},translate:function(t,e){return new a.Matrix(this.native().translate(t||0,e||0))},native:function(){for(var t=a.parser.native.createSVGMatrix(),e=v.length-1;e>=0;e--)t[v[e]]=this[v[e]];return t},toString:function(){return"matrix("+b(this.a)+","+b(this.b)+","+b(this.c)+","+b(this.d)+","+b(this.e)+","+b(this.f)+")"}},parent:a.Element,construct:{ctm:function(){return new a.Matrix(this.node.getCTM())},screenCTM:function(){if(this instanceof a.Nested){var t=this.rect(1,1),e=t.node.getScreenCTM();return t.remove(),new a.Matrix(e)}return new a.Matrix(this.node.getScreenCTM())}}}),a.Point=a.invent({create:function(t,e){var a;a=Array.isArray(t)?{x:t[0],y:t[1]}:"object"===i(t)?{x:t.x,y:t.y}:null!=t?{x:t,y:null!=e?e:t}:{x:0,y:0},this.x=a.x,this.y=a.y},extend:{clone:function(){return new a.Point(this)},morph:function(t,e){return this.destination=new a.Point(t,e),this}}}),a.extend(a.Element,{point:function(t,e){return new a.Point(t,e).transform(this.screenCTM().inverse())}}),a.extend(a.Element,{attr:function(t,e,s){if(null==t){for(t={},s=(e=this.node.attributes).length-1;s>=0;s--)t[e[s].nodeName]=a.regex.isNumber.test(e[s].nodeValue)?parseFloat(e[s].nodeValue):e[s].nodeValue;return t}if("object"===i(t))for(var r in t)this.attr(r,t[r]);else if(null===e)this.node.removeAttribute(t);else{if(null==e)return null==(e=this.node.getAttribute(t))?a.defaults.attrs[t]:a.regex.isNumber.test(e)?parseFloat(e):e;"stroke-width"==t?this.attr("stroke",parseFloat(e)>0?this._stroke:null):"stroke"==t&&(this._stroke=e),"fill"!=t&&"stroke"!=t||(a.regex.isImage.test(e)&&(e=this.doc().defs().image(e,0,0)),e instanceof a.Image&&(e=this.doc().defs().pattern(0,0,(function(){this.add(e)})))),"number"==typeof e?e=new a.Number(e):a.Color.isColor(e)?e=new a.Color(e):Array.isArray(e)&&(e=new a.Array(e)),"leading"==t?this.leading&&this.leading(e):"string"==typeof s?this.node.setAttributeNS(s,t,e.toString()):this.node.setAttribute(t,e.toString()),!this.rebuild||"font-size"!=t&&"x"!=t||this.rebuild(t,e)}return this}}),a.extend(a.Element,{transform:function(t,e){var s;return"object"!==i(t)?(s=new a.Matrix(this).extract(),"string"==typeof t?s[t]:s):(s=new a.Matrix(this),e=!!e||!!t.relative,null!=t.a&&(s=e?s.multiply(new a.Matrix(t)):new a.Matrix(t)),this.attr("transform",s))}}),a.extend(a.Element,{untransform:function(){return this.attr("transform",null)},matrixify:function(){return(this.attr("transform")||"").split(a.regex.transforms).slice(0,-1).map((function(t){var e=t.trim().split("(");return[e[0],e[1].split(a.regex.delimiter).map((function(t){return parseFloat(t)}))]})).reduce((function(t,e){return"matrix"==e[0]?t.multiply(f(e[1])):t[e[0]].apply(t,e[1])}),new a.Matrix)},toParent:function(t){if(this==t)return this;var e=this.screenCTM(),i=t.screenCTM().inverse();return this.addTo(t).untransform().transform(i.multiply(e)),this},toDoc:function(){return this.toParent(this.doc())}}),a.Transformation=a.invent({create:function(t,e){if(arguments.length>1&&"boolean"!=typeof e)return this.constructor.call(this,[].slice.call(arguments));if(Array.isArray(t))for(var a=0,s=this.arguments.length;a=0},index:function(t){return[].slice.call(this.node.childNodes).indexOf(t.node)},get:function(t){return a.adopt(this.node.childNodes[t])},first:function(){return this.get(0)},last:function(){return this.get(this.node.childNodes.length-1)},each:function(t,e){for(var i=this.children(),s=0,r=i.length;s=0;i--)e.childNodes[i]instanceof t.SVGElement&&x(e.childNodes[i]);return a.adopt(e).id(a.eid(e.nodeName))}function b(t){return Math.abs(t)>1e-37?t:0}["fill","stroke"].forEach((function(t){var e={};e[t]=function(e){if(void 0===e)return this;if("string"==typeof e||a.Color.isRgb(e)||e&&"function"==typeof e.fill)this.attr(t,e);else for(var i=l[t].length-1;i>=0;i--)null!=e[l[t][i]]&&this.attr(l.prefix(t,l[t][i]),e[l[t][i]]);return this},a.extend(a.Element,a.FX,e)})),a.extend(a.Element,a.FX,{translate:function(t,e){return this.transform({x:t,y:e})},matrix:function(t){return this.attr("transform",new a.Matrix(6==arguments.length?[].slice.call(arguments):t))},opacity:function(t){return this.attr("opacity",t)},dx:function(t){return this.x(new a.Number(t).plus(this instanceof a.FX?0:this.x()),!0)},dy:function(t){return this.y(new a.Number(t).plus(this instanceof a.FX?0:this.y()),!0)}}),a.extend(a.Path,{length:function(){return this.node.getTotalLength()},pointAt:function(t){return this.node.getPointAtLength(t)}}),a.Set=a.invent({create:function(t){Array.isArray(t)?this.members=t:this.clear()},extend:{add:function(){for(var t=[].slice.call(arguments),e=0,i=t.length;e-1&&this.members.splice(e,1),this},each:function(t){for(var e=0,i=this.members.length;e=0},index:function(t){return this.members.indexOf(t)},get:function(t){return this.members[t]},first:function(){return this.get(0)},last:function(){return this.get(this.members.length-1)},valueOf:function(){return this.members}},construct:{set:function(t){return new a.Set(t)}}}),a.FX.Set=a.invent({create:function(t){this.set=t}}),a.Set.inherit=function(){var t=[];for(var e in a.Shape.prototype)"function"==typeof a.Shape.prototype[e]&&"function"!=typeof a.Set.prototype[e]&&t.push(e);for(var e in t.forEach((function(t){a.Set.prototype[t]=function(){for(var e=0,i=this.members.length;e=0;t--)delete this.memory()[arguments[t]];return this},memory:function(){return this._memory||(this._memory={})}}),a.get=function(t){var i=e.getElementById(function(t){var e=(t||"").toString().match(a.regex.reference);if(e)return e[1]}(t)||t);return a.adopt(i)},a.select=function(t,i){return new a.Set(a.utils.map((i||e).querySelectorAll(t),(function(t){return a.adopt(t)})))},a.extend(a.Parent,{select:function(t){return a.select(t,this.node)}});var v="abcdef".split("");if("function"!=typeof t.CustomEvent){var m=function(t,i){i=i||{bubbles:!1,cancelable:!1,detail:void 0};var a=e.createEvent("CustomEvent");return a.initCustomEvent(t,i.bubbles,i.cancelable,i.detail),a};m.prototype=t.Event.prototype,a.CustomEvent=m}else a.CustomEvent=t.CustomEvent;return a},"function"==typeof define&&define.amd?define((function(){return Et(zt,zt.document)})):"object"===("undefined"==typeof exports?"undefined":i(exports))&&"undefined"!=typeof module?module.exports=zt.document?Et(zt,zt.document):function(t){return Et(t,t.document)}:zt.SVG=Et(zt,zt.document), -/*! svg.filter.js - v2.0.2 - 2016-02-24 -* https://github.com/wout/svg.filter.js -* Copyright (c) 2016 Wout Fierens; Licensed MIT */ -function(){SVG.Filter=SVG.invent({create:"filter",inherit:SVG.Parent,extend:{source:"SourceGraphic",sourceAlpha:"SourceAlpha",background:"BackgroundImage",backgroundAlpha:"BackgroundAlpha",fill:"FillPaint",stroke:"StrokePaint",autoSetIn:!0,put:function(t,e){return this.add(t,e),!t.attr("in")&&this.autoSetIn&&t.attr("in",this.source),t.attr("result")||t.attr("result",t),t},blend:function(t,e,i){return this.put(new SVG.BlendEffect(t,e,i))},colorMatrix:function(t,e){return this.put(new SVG.ColorMatrixEffect(t,e))},convolveMatrix:function(t){return this.put(new SVG.ConvolveMatrixEffect(t))},componentTransfer:function(t){return this.put(new SVG.ComponentTransferEffect(t))},composite:function(t,e,i){return this.put(new SVG.CompositeEffect(t,e,i))},flood:function(t,e){return this.put(new SVG.FloodEffect(t,e))},offset:function(t,e){return this.put(new SVG.OffsetEffect(t,e))},image:function(t){return this.put(new SVG.ImageEffect(t))},merge:function(){var t=[void 0];for(var e in arguments)t.push(arguments[e]);return this.put(new(SVG.MergeEffect.bind.apply(SVG.MergeEffect,t)))},gaussianBlur:function(t,e){return this.put(new SVG.GaussianBlurEffect(t,e))},morphology:function(t,e){return this.put(new SVG.MorphologyEffect(t,e))},diffuseLighting:function(t,e,i){return this.put(new SVG.DiffuseLightingEffect(t,e,i))},displacementMap:function(t,e,i,a,s){return this.put(new SVG.DisplacementMapEffect(t,e,i,a,s))},specularLighting:function(t,e,i,a){return this.put(new SVG.SpecularLightingEffect(t,e,i,a))},tile:function(){return this.put(new SVG.TileEffect)},turbulence:function(t,e,i,a,s){return this.put(new SVG.TurbulenceEffect(t,e,i,a,s))},toString:function(){return"url(#"+this.attr("id")+")"}}}),SVG.extend(SVG.Defs,{filter:function(t){var e=this.put(new SVG.Filter);return"function"==typeof t&&t.call(e,e),e}}),SVG.extend(SVG.Container,{filter:function(t){return this.defs().filter(t)}}),SVG.extend(SVG.Element,SVG.G,SVG.Nested,{filter:function(t){return this.filterer=t instanceof SVG.Element?t:this.doc().filter(t),this.doc()&&this.filterer.doc()!==this.doc()&&this.doc().defs().add(this.filterer),this.attr("filter",this.filterer),this.filterer},unfilter:function(t){return this.filterer&&!0===t&&this.filterer.remove(),delete this.filterer,this.attr("filter",null)}}),SVG.Effect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}}),SVG.ParentEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Parent,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}});var t={blend:function(t,e){return this.parent()&&this.parent().blend(this,t,e)},colorMatrix:function(t,e){return this.parent()&&this.parent().colorMatrix(t,e).in(this)},convolveMatrix:function(t){return this.parent()&&this.parent().convolveMatrix(t).in(this)},componentTransfer:function(t){return this.parent()&&this.parent().componentTransfer(t).in(this)},composite:function(t,e){return this.parent()&&this.parent().composite(this,t,e)},flood:function(t,e){return this.parent()&&this.parent().flood(t,e)},offset:function(t,e){return this.parent()&&this.parent().offset(t,e).in(this)},image:function(t){return this.parent()&&this.parent().image(t)},merge:function(){return this.parent()&&this.parent().merge.apply(this.parent(),[this].concat(arguments))},gaussianBlur:function(t,e){return this.parent()&&this.parent().gaussianBlur(t,e).in(this)},morphology:function(t,e){return this.parent()&&this.parent().morphology(t,e).in(this)},diffuseLighting:function(t,e,i){return this.parent()&&this.parent().diffuseLighting(t,e,i).in(this)},displacementMap:function(t,e,i,a){return this.parent()&&this.parent().displacementMap(this,t,e,i,a)},specularLighting:function(t,e,i,a){return this.parent()&&this.parent().specularLighting(t,e,i,a).in(this)},tile:function(){return this.parent()&&this.parent().tile().in(this)},turbulence:function(t,e,i,a,s){return this.parent()&&this.parent().turbulence(t,e,i,a,s).in(this)}};SVG.extend(SVG.Effect,t),SVG.extend(SVG.ParentEffect,t),SVG.ChildEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){this.attr("in",t)}}});var e={blend:function(t,e,i){this.attr({in:t,in2:e,mode:i||"normal"})},colorMatrix:function(t,e){"matrix"==t&&(e=s(e)),this.attr({type:t,values:void 0===e?null:e})},convolveMatrix:function(t){t=s(t),this.attr({order:Math.sqrt(t.split(" ").length),kernelMatrix:t})},composite:function(t,e,i){this.attr({in:t,in2:e,operator:i})},flood:function(t,e){this.attr("flood-color",t),null!=e&&this.attr("flood-opacity",e)},offset:function(t,e){this.attr({dx:t,dy:e})},image:function(t){this.attr("href",t,SVG.xlink)},displacementMap:function(t,e,i,a,s){this.attr({in:t,in2:e,scale:i,xChannelSelector:a,yChannelSelector:s})},gaussianBlur:function(t,e){null!=t||null!=e?this.attr("stdDeviation",function(t){if(!Array.isArray(t))return t;for(var e=0,i=t.length,a=[];e1&&(I*=a=Math.sqrt(a),T*=a);s=(new SVG.Matrix).rotate(M).scale(1/I,1/T).rotate(-M),F=F.transform(s),R=R.transform(s),r=[R.x-F.x,R.y-F.y],n=r[0]*r[0]+r[1]*r[1],o=Math.sqrt(n),r[0]/=o,r[1]/=o,l=n<4?Math.sqrt(1-n/4):0,X===z&&(l*=-1);h=new SVG.Point((R.x+F.x)/2+l*-r[1],(R.y+F.y)/2+l*r[0]),c=new SVG.Point(F.x-h.x,F.y-h.y),d=new SVG.Point(R.x-h.x,R.y-h.y),g=Math.acos(c.x/Math.sqrt(c.x*c.x+c.y*c.y)),c.y<0&&(g*=-1);u=Math.acos(d.x/Math.sqrt(d.x*d.x+d.y*d.y)),d.y<0&&(u*=-1);z&&g>u&&(u+=2*Math.PI);!z&&gr.maxX-e.width&&(o=(a=r.maxX-e.width)-this.startPoints.box.x),null!=r.minY&&sr.maxY-e.height&&(n=(s=r.maxY-e.height)-this.startPoints.box.y),null!=r.snapToGrid&&(a-=a%r.snapToGrid,s-=s%r.snapToGrid,o-=o%r.snapToGrid,n-=n%r.snapToGrid),this.el instanceof SVG.G?this.el.matrix(this.startPoints.transform).transform({x:o,y:n},!0):this.el.move(a,s));return i},t.prototype.end=function(t){var e=this.drag(t);this.el.fire("dragend",{event:t,p:e,m:this.m,handler:this}),SVG.off(window,"mousemove.drag"),SVG.off(window,"touchmove.drag"),SVG.off(window,"mouseup.drag"),SVG.off(window,"touchend.drag")},SVG.extend(SVG.Element,{draggable:function(e,i){"function"!=typeof e&&"object"!=typeof e||(i=e,e=!0);var a=this.remember("_draggable")||new t(this);return(e=void 0===e||e)?a.init(i||{},e):(this.off("mousedown.drag"),this.off("touchstart.drag")),this}})}.call(void 0),function(){function t(t){this.el=t,t.remember("_selectHandler",this),this.pointSelection={isSelected:!1},this.rectSelection={isSelected:!1},this.pointsList={lt:[0,0],rt:["width",0],rb:["width","height"],lb:[0,"height"],t:["width",0],r:["width","height"],b:["width","height"],l:[0,"height"]},this.pointCoord=function(t,e,i){var a="string"!=typeof t?t:e[t];return i?a/2:a},this.pointCoords=function(t,e){var i=this.pointsList[t];return{x:this.pointCoord(i[0],e,"t"===t||"b"===t),y:this.pointCoord(i[1],e,"r"===t||"l"===t)}}}t.prototype.init=function(t,e){var i=this.el.bbox();this.options={};var a=this.el.selectize.defaults.points;for(var s in this.el.selectize.defaults)this.options[s]=this.el.selectize.defaults[s],void 0!==e[s]&&(this.options[s]=e[s]);var r=["points","pointsExclude"];for(var s in r){var o=this.options[r[s]];"string"==typeof o?o=o.length>0?o.split(/\s*,\s*/i):[]:"boolean"==typeof o&&"points"===r[s]&&(o=o?a:[]),this.options[r[s]]=o}this.options.points=[a,this.options.points].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)>-1}))})),this.options.points=[this.options.points,this.options.pointsExclude].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)<0}))})),this.parent=this.el.parent(),this.nested=this.nested||this.parent.group(),this.nested.matrix(new SVG.Matrix(this.el).translate(i.x,i.y)),this.options.deepSelect&&-1!==["line","polyline","polygon"].indexOf(this.el.type)?this.selectPoints(t):this.selectRect(t),this.observe(),this.cleanup()},t.prototype.selectPoints=function(t){return this.pointSelection.isSelected=t,this.pointSelection.set||(this.pointSelection.set=this.parent.set(),this.drawPoints()),this},t.prototype.getPointArray=function(){var t=this.el.bbox();return this.el.array().valueOf().map((function(e){return[e[0]-t.x,e[1]-t.y]}))},t.prototype.drawPoints=function(){for(var t=this,e=this.getPointArray(),i=0,a=e.length;i0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y+i[1]).size(this.parameters.box.width-i[0],this.parameters.box.height-i[1])}};break;case"rt":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).size(this.parameters.box.width+i[0],this.parameters.box.height-i[1])}};break;case"rb":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x,this.parameters.box.y).size(this.parameters.box.width+i[0],this.parameters.box.height+i[1])}};break;case"lb":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).size(this.parameters.box.width-i[0],this.parameters.box.height+i[1])}};break;case"t":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).height(this.parameters.box.height-i[1])}};break;case"r":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).width(this.parameters.box.width+i[0])}};break;case"b":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).height(this.parameters.box.height+i[1])}};break;case"l":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).width(this.parameters.box.width-i[0])}};break;case"rot":this.calc=function(t,e){var i=t+this.parameters.p.x,a=e+this.parameters.p.y,s=Math.atan2(this.parameters.p.y-this.parameters.box.y-this.parameters.box.height/2,this.parameters.p.x-this.parameters.box.x-this.parameters.box.width/2),r=Math.atan2(a-this.parameters.box.y-this.parameters.box.height/2,i-this.parameters.box.x-this.parameters.box.width/2),o=this.parameters.rotation+180*(r-s)/Math.PI+this.options.snapToAngle/2;this.el.center(this.parameters.box.cx,this.parameters.box.cy).rotate(o-o%this.options.snapToAngle,this.parameters.box.cx,this.parameters.box.cy)};break;case"point":this.calc=function(t,e){var i=this.snapToGrid(t,e,this.parameters.pointCoords[0],this.parameters.pointCoords[1]),a=this.el.array().valueOf();a[this.parameters.i][0]=this.parameters.pointCoords[0]+i[0],a[this.parameters.i][1]=this.parameters.pointCoords[1]+i[1],this.el.plot(a)}}this.el.fire("resizestart",{dx:this.parameters.x,dy:this.parameters.y,event:t}),SVG.on(window,"touchmove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"touchend.resize",(function(){e.done()})),SVG.on(window,"mousemove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"mouseup.resize",(function(){e.done()}))},t.prototype.update=function(t){if(t){var e=this._extractPosition(t),i=this.transformPoint(e.x,e.y),a=i.x-this.parameters.p.x,s=i.y-this.parameters.p.y;this.lastUpdateCall=[a,s],this.calc(a,s),this.el.fire("resizing",{dx:a,dy:s,event:t})}else this.lastUpdateCall&&this.calc(this.lastUpdateCall[0],this.lastUpdateCall[1])},t.prototype.done=function(){this.lastUpdateCall=null,SVG.off(window,"mousemove.resize"),SVG.off(window,"mouseup.resize"),SVG.off(window,"touchmove.resize"),SVG.off(window,"touchend.resize"),this.el.fire("resizedone")},t.prototype.snapToGrid=function(t,e,i,a){var s;return void 0!==a?s=[(i+t)%this.options.snapToGrid,(a+e)%this.options.snapToGrid]:(i=null==i?3:i,s=[(this.parameters.box.x+t+(1&i?0:this.parameters.box.width))%this.options.snapToGrid,(this.parameters.box.y+e+(2&i?0:this.parameters.box.height))%this.options.snapToGrid]),t<0&&(s[0]-=this.options.snapToGrid),e<0&&(s[1]-=this.options.snapToGrid),t-=Math.abs(s[0])o.maxX&&(t=o.maxX-s),void 0!==o.minY&&r+eo.maxY&&(e=o.maxY-r),[t,e]},t.prototype.checkAspectRatio=function(t,e){if(!this.options.saveAspectRatio)return t;var i=t.slice(),a=this.parameters.box.width/this.parameters.box.height,s=this.parameters.box.width+t[0],r=this.parameters.box.height-t[1],o=s/r;return oa&&(i[0]=this.parameters.box.width-r*a,e&&(i[0]=-i[0])),i},SVG.extend(SVG.Element,{resize:function(e){return(this.remember("_resizeHandler")||new t(this)).init(e||{}),this}}),SVG.Element.prototype.resize.defaults={snapToAngle:.1,snapToGrid:1,constraint:{},saveAspectRatio:!1}}).call(this)}(),void 0===window.Apex&&(window.Apex={});var Ot=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"initModules",value:function(){this.ctx.publicMethods=["updateOptions","updateSeries","appendData","appendSeries","toggleSeries","showSeries","hideSeries","setLocale","resetSeries","zoomX","toggleDataPointSelection","dataURI","exportToCSV","addXaxisAnnotation","addYaxisAnnotation","addPointAnnotation","clearAnnotations","removeAnnotation","paper","destroy"],this.ctx.eventList=["click","mousedown","mousemove","mouseleave","touchstart","touchmove","touchleave","mouseup","touchend"],this.ctx.animations=new b(this.ctx),this.ctx.axes=new J(this.ctx),this.ctx.core=new Dt(this.ctx.el,this.ctx),this.ctx.config=new E({}),this.ctx.data=new W(this.ctx),this.ctx.grid=new j(this.ctx),this.ctx.graphics=new m(this.ctx),this.ctx.coreUtils=new y(this.ctx),this.ctx.crosshairs=new Q(this.ctx),this.ctx.events=new Z(this.ctx),this.ctx.exports=new G(this.ctx),this.ctx.localization=new $(this.ctx),this.ctx.options=new L,this.ctx.responsive=new K(this.ctx),this.ctx.series=new N(this.ctx),this.ctx.theme=new tt(this.ctx),this.ctx.formatters=new T(this.ctx),this.ctx.titleSubtitle=new et(this.ctx),this.ctx.legend=new lt(this.ctx),this.ctx.toolbar=new ht(this.ctx),this.ctx.tooltip=new bt(this.ctx),this.ctx.dimensions=new ot(this.ctx),this.ctx.updateHelpers=new Ht(this.ctx),this.ctx.zoomPanSelection=new ct(this.ctx),this.ctx.w.globals.tooltip=new bt(this.ctx)}}]),t}(),Nt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"clear",value:function(t){var e=t.isUpdating;this.ctx.zoomPanSelection&&this.ctx.zoomPanSelection.destroy(),this.ctx.toolbar&&this.ctx.toolbar.destroy(),this.ctx.animations=null,this.ctx.axes=null,this.ctx.annotations=null,this.ctx.core=null,this.ctx.data=null,this.ctx.grid=null,this.ctx.series=null,this.ctx.responsive=null,this.ctx.theme=null,this.ctx.formatters=null,this.ctx.titleSubtitle=null,this.ctx.legend=null,this.ctx.dimensions=null,this.ctx.options=null,this.ctx.crosshairs=null,this.ctx.zoomPanSelection=null,this.ctx.updateHelpers=null,this.ctx.toolbar=null,this.ctx.localization=null,this.ctx.w.globals.tooltip=null,this.clearDomElements({isUpdating:e})}},{key:"killSVG",value:function(t){t.each((function(t,e){this.removeClass("*"),this.off(),this.stop()}),!0),t.ungroup(),t.clear()}},{key:"clearDomElements",value:function(t){var e=this,i=t.isUpdating,a=this.w.globals.dom.Paper.node;a.parentNode&&a.parentNode.parentNode&&!i&&(a.parentNode.parentNode.style.minHeight="unset");var s=this.w.globals.dom.baseEl;s&&this.ctx.eventList.forEach((function(t){s.removeEventListener(t,e.ctx.events.documentEvent)}));var r=this.w.globals.dom;if(null!==this.ctx.el)for(;this.ctx.el.firstChild;)this.ctx.el.removeChild(this.ctx.el.firstChild);this.killSVG(r.Paper),r.Paper.remove(),r.elWrap=null,r.elGraphical=null,r.elLegendWrap=null,r.elLegendForeign=null,r.baseEl=null,r.elGridRect=null,r.elGridRectMask=null,r.elGridRectMarkerMask=null,r.elForecastMask=null,r.elNonForecastMask=null,r.elDefs=null}}]),t}(),Wt=new WeakMap;var Bt=function(){function t(e,i){a(this,t),this.opts=i,this.ctx=this,this.w=new F(i).init(),this.el=e,this.w.globals.cuid=x.randomId(),this.w.globals.chartID=this.w.config.chart.id?x.escapeString(this.w.config.chart.id):this.w.globals.cuid,new Ot(this).initModules(),this.create=x.bind(this.create,this),this.windowResizeHandler=this._windowResizeHandler.bind(this),this.parentResizeHandler=this._parentResizeCallback.bind(this)}return r(t,[{key:"render",value:function(){var t=this;return new Promise((function(e,i){if(null!==t.el){void 0===Apex._chartInstances&&(Apex._chartInstances=[]),t.w.config.chart.id&&Apex._chartInstances.push({id:t.w.globals.chartID,group:t.w.config.chart.group,chart:t}),t.setLocale(t.w.config.chart.defaultLocale);var a=t.w.config.chart.events.beforeMount;if("function"==typeof a&&a(t,t.w),t.events.fireEvent("beforeMount",[t,t.w]),window.addEventListener("resize",t.windowResizeHandler),function(t,e){var i=!1;if(t.nodeType!==Node.DOCUMENT_FRAGMENT_NODE){var a=t.getBoundingClientRect();"none"!==t.style.display&&0!==a.width||(i=!0)}var s=new ResizeObserver((function(a){i&&e.call(t,a),i=!0}));t.nodeType===Node.DOCUMENT_FRAGMENT_NODE?Array.from(t.children).forEach((function(t){return s.observe(t)})):s.observe(t),Wt.set(e,s)}(t.el.parentNode,t.parentResizeHandler),!t.css){var s=t.el.getRootNode&&t.el.getRootNode(),r=x.is("ShadowRoot",s),o=t.el.ownerDocument,n=o.getElementById("apexcharts-css");!r&&n||(t.css=document.createElement("style"),t.css.id="apexcharts-css",t.css.textContent='@keyframes opaque {\n 0% {\n opacity: 0\n }\n\n to {\n opacity: 1\n }\n}\n\n@keyframes resizeanim {\n 0%,to {\n opacity: 0\n }\n}\n\n.apexcharts-canvas {\n position: relative;\n user-select: none\n}\n\n.apexcharts-canvas ::-webkit-scrollbar {\n -webkit-appearance: none;\n width: 6px\n}\n\n.apexcharts-canvas ::-webkit-scrollbar-thumb {\n border-radius: 4px;\n background-color: rgba(0,0,0,.5);\n box-shadow: 0 0 1px rgba(255,255,255,.5);\n -webkit-box-shadow: 0 0 1px rgba(255,255,255,.5)\n}\n\n.apexcharts-inner {\n position: relative\n}\n\n.apexcharts-text tspan {\n font-family: inherit\n}\n\n.legend-mouseover-inactive {\n transition: .15s ease all;\n opacity: .2\n}\n\n.apexcharts-legend-text {\n padding-left: 15px;\n margin-left: -15px;\n}\n\n.apexcharts-series-collapsed {\n opacity: 0\n}\n\n.apexcharts-tooltip {\n border-radius: 5px;\n box-shadow: 2px 2px 6px -4px #999;\n cursor: default;\n font-size: 14px;\n left: 62px;\n opacity: 0;\n pointer-events: none;\n position: absolute;\n top: 20px;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n white-space: nowrap;\n z-index: 12;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-theme-light {\n border: 1px solid #e3e3e3;\n background: rgba(255,255,255,.96)\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark {\n color: #fff;\n background: rgba(30,30,30,.8)\n}\n\n.apexcharts-tooltip * {\n font-family: inherit\n}\n\n.apexcharts-tooltip-title {\n padding: 6px;\n font-size: 15px;\n margin-bottom: 4px\n}\n\n.apexcharts-tooltip.apexcharts-theme-light .apexcharts-tooltip-title {\n background: #eceff1;\n border-bottom: 1px solid #ddd\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark .apexcharts-tooltip-title {\n background: rgba(0,0,0,.7);\n border-bottom: 1px solid #333\n}\n\n.apexcharts-tooltip-text-goals-value,.apexcharts-tooltip-text-y-value,.apexcharts-tooltip-text-z-value {\n display: inline-block;\n margin-left: 5px;\n font-weight: 600\n}\n\n.apexcharts-tooltip-text-goals-label:empty,.apexcharts-tooltip-text-goals-value:empty,.apexcharts-tooltip-text-y-label:empty,.apexcharts-tooltip-text-y-value:empty,.apexcharts-tooltip-text-z-value:empty,.apexcharts-tooltip-title:empty {\n display: none\n}\n\n.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n padding: 6px 0 5px\n}\n\n.apexcharts-tooltip-goals-group,.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n display: flex\n}\n\n.apexcharts-tooltip-text-goals-label:not(:empty),.apexcharts-tooltip-text-goals-value:not(:empty) {\n margin-top: -6px\n}\n\n.apexcharts-tooltip-marker {\n width: 12px;\n height: 12px;\n position: relative;\n top: 0;\n margin-right: 10px;\n border-radius: 50%\n}\n\n.apexcharts-tooltip-series-group {\n padding: 0 10px;\n display: none;\n text-align: left;\n justify-content: left;\n align-items: center\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-marker {\n opacity: 1\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active,.apexcharts-tooltip-series-group:last-child {\n padding-bottom: 4px\n}\n\n.apexcharts-tooltip-series-group-hidden {\n opacity: 0;\n height: 0;\n line-height: 0;\n padding: 0!important\n}\n\n.apexcharts-tooltip-y-group {\n padding: 6px 0 5px\n}\n\n.apexcharts-custom-tooltip,.apexcharts-tooltip-box {\n padding: 4px 8px\n}\n\n.apexcharts-tooltip-boxPlot {\n display: flex;\n flex-direction: column-reverse\n}\n\n.apexcharts-tooltip-box>div {\n margin: 4px 0\n}\n\n.apexcharts-tooltip-box span.value {\n font-weight: 700\n}\n\n.apexcharts-tooltip-rangebar {\n padding: 5px 8px\n}\n\n.apexcharts-tooltip-rangebar .category {\n font-weight: 600;\n color: #777\n}\n\n.apexcharts-tooltip-rangebar .series-name {\n font-weight: 700;\n display: block;\n margin-bottom: 5px\n}\n\n.apexcharts-xaxistooltip,.apexcharts-yaxistooltip {\n opacity: 0;\n pointer-events: none;\n color: #373d3f;\n font-size: 13px;\n text-align: center;\n border-radius: 2px;\n position: absolute;\n z-index: 10;\n background: #eceff1;\n border: 1px solid #90a4ae\n}\n\n.apexcharts-xaxistooltip {\n padding: 9px 10px;\n transition: .15s ease all\n}\n\n.apexcharts-xaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-xaxistooltip:after,.apexcharts-xaxistooltip:before {\n left: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-xaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-left: -6px\n}\n\n.apexcharts-xaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-left: -7px\n}\n\n.apexcharts-xaxistooltip-bottom:after,.apexcharts-xaxistooltip-bottom:before {\n bottom: 100%\n}\n\n.apexcharts-xaxistooltip-top:after,.apexcharts-xaxistooltip-top:before {\n top: 100%\n}\n\n.apexcharts-xaxistooltip-bottom:after {\n border-bottom-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-bottom:before {\n border-bottom-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:before {\n border-bottom-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip-top:after {\n border-top-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-top:before {\n border-top-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-top.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-top.apexcharts-theme-dark:before {\n border-top-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-yaxistooltip {\n padding: 4px 10px\n}\n\n.apexcharts-yaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-yaxistooltip:after,.apexcharts-yaxistooltip:before {\n top: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-yaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-top: -6px\n}\n\n.apexcharts-yaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-top: -7px\n}\n\n.apexcharts-yaxistooltip-left:after,.apexcharts-yaxistooltip-left:before {\n left: 100%\n}\n\n.apexcharts-yaxistooltip-right:after,.apexcharts-yaxistooltip-right:before {\n right: 100%\n}\n\n.apexcharts-yaxistooltip-left:after {\n border-left-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-left:before {\n border-left-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-left.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-left.apexcharts-theme-dark:before {\n border-left-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip-right:after {\n border-right-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-right:before {\n border-right-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-right.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-right.apexcharts-theme-dark:before {\n border-right-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip.apexcharts-active {\n opacity: 1\n}\n\n.apexcharts-yaxistooltip-hidden {\n display: none\n}\n\n.apexcharts-xcrosshairs,.apexcharts-ycrosshairs {\n pointer-events: none;\n opacity: 0;\n transition: .15s ease all\n}\n\n.apexcharts-xcrosshairs.apexcharts-active,.apexcharts-ycrosshairs.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-ycrosshairs-hidden {\n opacity: 0\n}\n\n.apexcharts-selection-rect {\n cursor: move\n}\n\n.svg_select_boundingRect,.svg_select_points_rot {\n pointer-events: none;\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_boundingRect,.apexcharts-selection-rect+g .svg_select_points_rot {\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_points_l,.apexcharts-selection-rect+g .svg_select_points_r {\n cursor: ew-resize;\n opacity: 1;\n visibility: visible\n}\n\n.svg_select_points {\n fill: #efefef;\n stroke: #333;\n rx: 2\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-zoom {\n cursor: crosshair\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-pan {\n cursor: move\n}\n\n.apexcharts-menu-icon,.apexcharts-pan-icon,.apexcharts-reset-icon,.apexcharts-selection-icon,.apexcharts-toolbar-custom-icon,.apexcharts-zoom-icon,.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n cursor: pointer;\n width: 20px;\n height: 20px;\n line-height: 24px;\n color: #6e8192;\n text-align: center\n}\n\n.apexcharts-menu-icon svg,.apexcharts-reset-icon svg,.apexcharts-zoom-icon svg,.apexcharts-zoomin-icon svg,.apexcharts-zoomout-icon svg {\n fill: #6e8192\n}\n\n.apexcharts-selection-icon svg {\n fill: #444;\n transform: scale(.76)\n}\n\n.apexcharts-theme-dark .apexcharts-menu-icon svg,.apexcharts-theme-dark .apexcharts-pan-icon svg,.apexcharts-theme-dark .apexcharts-reset-icon svg,.apexcharts-theme-dark .apexcharts-selection-icon svg,.apexcharts-theme-dark .apexcharts-toolbar-custom-icon svg,.apexcharts-theme-dark .apexcharts-zoom-icon svg,.apexcharts-theme-dark .apexcharts-zoomin-icon svg,.apexcharts-theme-dark .apexcharts-zoomout-icon svg {\n fill: #f3f4f5\n}\n\n.apexcharts-canvas .apexcharts-reset-zoom-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-selection-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-zoom-icon.apexcharts-selected svg {\n fill: #008ffb\n}\n\n.apexcharts-theme-light .apexcharts-menu-icon:hover svg,.apexcharts-theme-light .apexcharts-reset-icon:hover svg,.apexcharts-theme-light .apexcharts-selection-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoom-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoomin-icon:hover svg,.apexcharts-theme-light .apexcharts-zoomout-icon:hover svg {\n fill: #333\n}\n\n.apexcharts-menu-icon,.apexcharts-selection-icon {\n position: relative\n}\n\n.apexcharts-reset-icon {\n margin-left: 5px\n}\n\n.apexcharts-menu-icon,.apexcharts-reset-icon,.apexcharts-zoom-icon {\n transform: scale(.85)\n}\n\n.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n transform: scale(.7)\n}\n\n.apexcharts-zoomout-icon {\n margin-right: 3px\n}\n\n.apexcharts-pan-icon {\n transform: scale(.62);\n position: relative;\n left: 1px;\n top: 0\n}\n\n.apexcharts-pan-icon svg {\n fill: #fff;\n stroke: #6e8192;\n stroke-width: 2\n}\n\n.apexcharts-pan-icon.apexcharts-selected svg {\n stroke: #008ffb\n}\n\n.apexcharts-pan-icon:not(.apexcharts-selected):hover svg {\n stroke: #333\n}\n\n.apexcharts-toolbar {\n position: absolute;\n z-index: 11;\n max-width: 176px;\n text-align: right;\n border-radius: 3px;\n padding: 0 6px 2px;\n display: flex;\n justify-content: space-between;\n align-items: center\n}\n\n.apexcharts-menu {\n background: #fff;\n position: absolute;\n top: 100%;\n border: 1px solid #ddd;\n border-radius: 3px;\n padding: 3px;\n right: 10px;\n opacity: 0;\n min-width: 110px;\n transition: .15s ease all;\n pointer-events: none\n}\n\n.apexcharts-menu.apexcharts-menu-open {\n opacity: 1;\n pointer-events: all;\n transition: .15s ease all\n}\n\n.apexcharts-menu-item {\n padding: 6px 7px;\n font-size: 12px;\n cursor: pointer\n}\n\n.apexcharts-theme-light .apexcharts-menu-item:hover {\n background: #eee\n}\n\n.apexcharts-theme-dark .apexcharts-menu {\n background: rgba(0,0,0,.7);\n color: #fff\n}\n\n@media screen and (min-width:768px) {\n .apexcharts-canvas:hover .apexcharts-toolbar {\n opacity: 1\n }\n}\n\n.apexcharts-canvas .apexcharts-element-hidden,.apexcharts-datalabel.apexcharts-element-hidden,.apexcharts-hide .apexcharts-series-points {\n opacity: 0\n}\n\n.apexcharts-datalabel,.apexcharts-datalabel-label,.apexcharts-datalabel-value,.apexcharts-datalabels,.apexcharts-pie-label {\n cursor: default;\n pointer-events: none\n}\n\n.apexcharts-pie-label-delay {\n opacity: 0;\n animation-name: opaque;\n animation-duration: .3s;\n animation-fill-mode: forwards;\n animation-timing-function: ease\n}\n\n.apexcharts-annotation-rect,.apexcharts-area-series .apexcharts-area,.apexcharts-area-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-gridline,.apexcharts-line,.apexcharts-line-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-point-annotation-label,.apexcharts-radar-series path,.apexcharts-radar-series polygon,.apexcharts-toolbar svg,.apexcharts-tooltip .apexcharts-marker,.apexcharts-xaxis-annotation-label,.apexcharts-yaxis-annotation-label,.apexcharts-zoom-rect {\n pointer-events: none\n}\n\n.apexcharts-marker {\n transition: .15s ease all\n}\n\n.resize-triggers {\n animation: 1ms resizeanim;\n visibility: hidden;\n opacity: 0;\n height: 100%;\n width: 100%;\n overflow: hidden\n}\n\n.contract-trigger:before,.resize-triggers,.resize-triggers>div {\n content: " ";\n display: block;\n position: absolute;\n top: 0;\n left: 0\n}\n\n.resize-triggers>div {\n height: 100%;\n width: 100%;\n background: #eee;\n overflow: auto\n}\n\n.contract-trigger:before {\n overflow: hidden;\n width: 200%;\n height: 200%\n}\n',r?s.prepend(t.css):o.head.appendChild(t.css))}var l=t.create(t.w.config.series,{});if(!l)return e(t);t.mount(l).then((function(){"function"==typeof t.w.config.chart.events.mounted&&t.w.config.chart.events.mounted(t,t.w),t.events.fireEvent("mounted",[t,t.w]),e(l)})).catch((function(t){i(t)}))}else i(new Error("Element not found"))}))}},{key:"create",value:function(t,e){var i=this.w;new Ot(this).initModules();var a=this.w.globals;(a.noData=!1,a.animationEnded=!1,this.responsive.checkResponsiveConfig(e),i.config.xaxis.convertedCatToNumeric)&&new z(i.config).convertCatToNumericXaxis(i.config,this.ctx);if(null===this.el)return a.animationEnded=!0,null;if(this.core.setupElements(),"treemap"===i.config.chart.type&&(i.config.grid.show=!1,i.config.yaxis[0].show=!1),0===a.svgWidth)return a.animationEnded=!0,null;var s=y.checkComboSeries(t);a.comboCharts=s.comboCharts,a.comboBarCount=s.comboBarCount;var r=t.every((function(t){return t.data&&0===t.data.length}));(0===t.length||r)&&this.series.handleNoData(),this.events.setupEventHandlers(),this.data.parseData(t),this.theme.init(),new D(this).setGlobalMarkerSize(),this.formatters.setLabelFormatters(),this.titleSubtitle.draw(),a.noData&&a.collapsedSeries.length!==a.series.length&&!i.config.legend.showForSingleSeries||this.legend.init(),this.series.hasAllSeriesEqualX(),a.axisCharts&&(this.core.coreCalculations(),"category"!==i.config.xaxis.type&&this.formatters.setLabelFormatters(),this.ctx.toolbar.minX=i.globals.minX,this.ctx.toolbar.maxX=i.globals.maxX),this.formatters.heatmapLabelFormatters(),new y(this).getLargestMarkerSize(),this.dimensions.plotCoords();var o=this.core.xySettings();this.grid.createGridMask();var n=this.core.plotChartType(t,o),l=new O(this);return l.bringForward(),i.config.dataLabels.background.enabled&&l.dataLabelsBackground(),this.core.shiftGraphPosition(),{elGraph:n,xyRatios:o,dimensions:{plot:{left:i.globals.translateX,top:i.globals.translateY,width:i.globals.gridWidth,height:i.globals.gridHeight}}}}},{key:"mount",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,i=this,a=i.w;return new Promise((function(s,r){if(null===i.el)return r(new Error("Not enough data to display or target element not found"));(null===e||a.globals.allSeriesCollapsed)&&i.series.handleNoData(),i.grid=new j(i);var o=i.grid.drawGrid();if(i.annotations=new P(i),i.annotations.drawImageAnnos(),i.annotations.drawTextAnnos(),"back"===a.config.grid.position&&o&&a.globals.dom.elGraphical.add(o.el),Array.isArray(e.elGraph))for(var n=0;n0&&a.globals.memory.methodsToExec.forEach((function(t){t.method(t.params,!1,t.context)})),a.globals.axisCharts||a.globals.noData||i.core.resizeNonAxisCharts(),s(i)}))}},{key:"destroy",value:function(){var t,e;window.removeEventListener("resize",this.windowResizeHandler),this.el.parentNode,t=this.parentResizeHandler,(e=Wt.get(t))&&(e.disconnect(),Wt.delete(t));var i=this.w.config.chart.id;i&&Apex._chartInstances.forEach((function(t,e){t.id===x.escapeString(i)&&Apex._chartInstances.splice(e,1)})),new Nt(this.ctx).clear({isUpdating:!1})}},{key:"updateOptions",value:function(t){var e=this,i=arguments.length>1&&void 0!==arguments[1]&&arguments[1],a=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],s=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],r=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],o=this.w;return o.globals.selection=void 0,t.series&&(this.series.resetSeries(!1,!0,!1),t.series.length&&t.series[0].data&&(t.series=t.series.map((function(t,i){return e.updateHelpers._extendSeries(t,i)}))),this.updateHelpers.revertDefaultAxisMinMax()),t.xaxis&&(t=this.updateHelpers.forceXAxisUpdate(t)),t.yaxis&&(t=this.updateHelpers.forceYAxisUpdate(t)),o.globals.collapsedSeriesIndices.length>0&&this.series.clearPreviousPaths(),t.theme&&(t=this.theme.updateThemeOptions(t)),this.updateHelpers._updateOptions(t,i,a,s,r)}},{key:"updateSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];return this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(t,e,i)}},{key:"appendSeries",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w.config.series.slice();return a.push(t),this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(a,e,i)}},{key:"appendData",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=this;i.w.globals.dataChanged=!0,i.series.getPreviousPaths();for(var a=i.w.config.series.slice(),s=0;s0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.series.resetSeries(t,e)}},{key:"addEventListener",value:function(t,e){this.events.addEventListener(t,e)}},{key:"removeEventListener",value:function(t,e){this.events.removeEventListener(t,e)}},{key:"addXaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addXaxisAnnotationExternal(t,e,a)}},{key:"addYaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addYaxisAnnotationExternal(t,e,a)}},{key:"addPointAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addPointAnnotationExternal(t,e,a)}},{key:"clearAnnotations",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:void 0,e=this;t&&(e=t),e.annotations.clearAnnotations(e)}},{key:"removeAnnotation",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0,i=this;e&&(i=e),i.annotations.removeAnnotation(i,t)}},{key:"getChartArea",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-inner")}},{key:"getSeriesTotalXRange",value:function(t,e){return this.coreUtils.getSeriesTotalsXRange(t,e)}},{key:"getHighestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new U(this.ctx).getMinYMaxY(t).highestY}},{key:"getLowestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new U(this.ctx).getMinYMaxY(t).lowestY}},{key:"getSeriesTotal",value:function(){return this.w.globals.seriesTotals}},{key:"toggleDataPointSelection",value:function(t,e){return this.updateHelpers.toggleDataPointSelection(t,e)}},{key:"zoomX",value:function(t,e){this.ctx.toolbar.zoomUpdateOptions(t,e)}},{key:"setLocale",value:function(t){this.localization.setCurrentLocaleValues(t)}},{key:"dataURI",value:function(t){return new G(this.ctx).dataURI(t)}},{key:"exportToCSV",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return new G(this.ctx).exportToCSV(t)}},{key:"paper",value:function(){return this.w.globals.dom.Paper}},{key:"_parentResizeCallback",value:function(){this.w.globals.animationEnded&&this.w.config.chart.redrawOnParentResize&&this._windowResize()}},{key:"_windowResize",value:function(){var t=this;clearTimeout(this.w.globals.resizeTimer),this.w.globals.resizeTimer=window.setTimeout((function(){t.w.globals.resized=!0,t.w.globals.dataChanged=!1,t.ctx.update()}),150)}},{key:"_windowResizeHandler",value:function(){var t=this.w.config.chart.redrawOnWindowResize;"function"==typeof t&&(t=t()),t&&this._windowResize()}}],[{key:"getChartByID",value:function(t){var e=x.escapeString(t),i=Apex._chartInstances.filter((function(t){return t.id===e}))[0];return i&&i.chart}},{key:"initOnLoad",value:function(){for(var e=document.querySelectorAll("[data-apexcharts]"),i=0;i2?s-2:0),o=2;odiv { - margin: 4px 0 -} - -.apexcharts-tooltip-box span.value { - font-weight: 700 -} - -.apexcharts-tooltip-rangebar { - padding: 5px 8px -} - -.apexcharts-tooltip-rangebar .category { - font-weight: 600; - color: #777 -} - -.apexcharts-tooltip-rangebar .series-name { - font-weight: 700; - display: block; - margin-bottom: 5px -} - -.apexcharts-xaxistooltip,.apexcharts-yaxistooltip { - opacity: 0; - pointer-events: none; - color: #373d3f; - font-size: 13px; - text-align: center; - border-radius: 2px; - position: absolute; - z-index: 10; - background: #eceff1; - border: 1px solid #90a4ae -} - -.apexcharts-xaxistooltip { - padding: 9px 10px; - transition: .15s ease all -} - -.apexcharts-xaxistooltip.apexcharts-theme-dark { - background: rgba(0,0,0,.7); - border: 1px solid rgba(0,0,0,.5); - color: #fff -} - -.apexcharts-xaxistooltip:after,.apexcharts-xaxistooltip:before { - left: 50%; - border: solid transparent; - content: " "; - height: 0; - width: 0; - position: absolute; - pointer-events: none -} - -.apexcharts-xaxistooltip:after { - border-color: transparent; - border-width: 6px; - margin-left: -6px -} - -.apexcharts-xaxistooltip:before { - border-color: transparent; - border-width: 7px; - margin-left: -7px -} - -.apexcharts-xaxistooltip-bottom:after,.apexcharts-xaxistooltip-bottom:before { - bottom: 100% -} - -.apexcharts-xaxistooltip-top:after,.apexcharts-xaxistooltip-top:before { - top: 100% -} - -.apexcharts-xaxistooltip-bottom:after { - border-bottom-color: #eceff1 -} - -.apexcharts-xaxistooltip-bottom:before { - border-bottom-color: #90a4ae -} - -.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:before { - border-bottom-color: rgba(0,0,0,.5) -} - -.apexcharts-xaxistooltip-top:after { - border-top-color: #eceff1 -} - -.apexcharts-xaxistooltip-top:before { - border-top-color: #90a4ae -} - -.apexcharts-xaxistooltip-top.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-top.apexcharts-theme-dark:before { - border-top-color: rgba(0,0,0,.5) -} - -.apexcharts-xaxistooltip.apexcharts-active { - opacity: 1; - transition: .15s ease all -} - -.apexcharts-yaxistooltip { - padding: 4px 10px -} - -.apexcharts-yaxistooltip.apexcharts-theme-dark { - background: rgba(0,0,0,.7); - border: 1px solid rgba(0,0,0,.5); - color: #fff -} - -.apexcharts-yaxistooltip:after,.apexcharts-yaxistooltip:before { - top: 50%; - border: solid transparent; - content: " "; - height: 0; - width: 0; - position: absolute; - pointer-events: none -} - -.apexcharts-yaxistooltip:after { - border-color: transparent; - border-width: 6px; - margin-top: -6px -} - -.apexcharts-yaxistooltip:before { - border-color: transparent; - border-width: 7px; - margin-top: -7px -} - -.apexcharts-yaxistooltip-left:after,.apexcharts-yaxistooltip-left:before { - left: 100% -} - -.apexcharts-yaxistooltip-right:after,.apexcharts-yaxistooltip-right:before { - right: 100% -} - -.apexcharts-yaxistooltip-left:after { - border-left-color: #eceff1 -} - -.apexcharts-yaxistooltip-left:before { - border-left-color: #90a4ae -} - -.apexcharts-yaxistooltip-left.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-left.apexcharts-theme-dark:before { - border-left-color: rgba(0,0,0,.5) -} - -.apexcharts-yaxistooltip-right:after { - border-right-color: #eceff1 -} - -.apexcharts-yaxistooltip-right:before { - border-right-color: #90a4ae -} - -.apexcharts-yaxistooltip-right.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-right.apexcharts-theme-dark:before { - border-right-color: rgba(0,0,0,.5) -} - -.apexcharts-yaxistooltip.apexcharts-active { - opacity: 1 -} - -.apexcharts-yaxistooltip-hidden { - display: none -} - -.apexcharts-xcrosshairs,.apexcharts-ycrosshairs { - pointer-events: none; - opacity: 0; - transition: .15s ease all -} - -.apexcharts-xcrosshairs.apexcharts-active,.apexcharts-ycrosshairs.apexcharts-active { - opacity: 1; - transition: .15s ease all -} - -.apexcharts-ycrosshairs-hidden { - opacity: 0 -} - -.apexcharts-selection-rect { - cursor: move -} - -.svg_select_boundingRect,.svg_select_points_rot { - pointer-events: none; - opacity: 0; - visibility: hidden -} - -.apexcharts-selection-rect+g .svg_select_boundingRect,.apexcharts-selection-rect+g .svg_select_points_rot { - opacity: 0; - visibility: hidden -} - -.apexcharts-selection-rect+g .svg_select_points_l,.apexcharts-selection-rect+g .svg_select_points_r { - cursor: ew-resize; - opacity: 1; - visibility: visible -} - -.svg_select_points { - fill: #efefef; - stroke: #333; - rx: 2 -} - -.apexcharts-svg.apexcharts-zoomable.hovering-zoom { - cursor: crosshair -} - -.apexcharts-svg.apexcharts-zoomable.hovering-pan { - cursor: move -} - -.apexcharts-menu-icon,.apexcharts-pan-icon,.apexcharts-reset-icon,.apexcharts-selection-icon,.apexcharts-toolbar-custom-icon,.apexcharts-zoom-icon,.apexcharts-zoomin-icon,.apexcharts-zoomout-icon { - cursor: pointer; - width: 20px; - height: 20px; - line-height: 24px; - color: #6e8192; - text-align: center -} - -.apexcharts-menu-icon svg,.apexcharts-reset-icon svg,.apexcharts-zoom-icon svg,.apexcharts-zoomin-icon svg,.apexcharts-zoomout-icon svg { - fill: #6e8192 -} - -.apexcharts-selection-icon svg { - fill: #444; - transform: scale(.76) -} - -.apexcharts-theme-dark .apexcharts-menu-icon svg,.apexcharts-theme-dark .apexcharts-pan-icon svg,.apexcharts-theme-dark .apexcharts-reset-icon svg,.apexcharts-theme-dark .apexcharts-selection-icon svg,.apexcharts-theme-dark .apexcharts-toolbar-custom-icon svg,.apexcharts-theme-dark .apexcharts-zoom-icon svg,.apexcharts-theme-dark .apexcharts-zoomin-icon svg,.apexcharts-theme-dark .apexcharts-zoomout-icon svg { - fill: #f3f4f5 -} - -.apexcharts-canvas .apexcharts-reset-zoom-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-selection-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-zoom-icon.apexcharts-selected svg { - fill: #008ffb -} - -.apexcharts-theme-light .apexcharts-menu-icon:hover svg,.apexcharts-theme-light .apexcharts-reset-icon:hover svg,.apexcharts-theme-light .apexcharts-selection-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoom-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoomin-icon:hover svg,.apexcharts-theme-light .apexcharts-zoomout-icon:hover svg { - fill: #333 -} - -.apexcharts-menu-icon,.apexcharts-selection-icon { - position: relative -} - -.apexcharts-reset-icon { - margin-left: 5px -} - -.apexcharts-menu-icon,.apexcharts-reset-icon,.apexcharts-zoom-icon { - transform: scale(.85) -} - -.apexcharts-zoomin-icon,.apexcharts-zoomout-icon { - transform: scale(.7) -} - -.apexcharts-zoomout-icon { - margin-right: 3px -} - -.apexcharts-pan-icon { - transform: scale(.62); - position: relative; - left: 1px; - top: 0 -} - -.apexcharts-pan-icon svg { - fill: #fff; - stroke: #6e8192; - stroke-width: 2 -} - -.apexcharts-pan-icon.apexcharts-selected svg { - stroke: #008ffb -} - -.apexcharts-pan-icon:not(.apexcharts-selected):hover svg { - stroke: #333 -} - -.apexcharts-toolbar { - position: absolute; - z-index: 11; - max-width: 176px; - text-align: right; - border-radius: 3px; - padding: 0 6px 2px; - display: flex; - justify-content: space-between; - align-items: center -} - -.apexcharts-menu { - background: #fff; - position: absolute; - top: 100%; - border: 1px solid #ddd; - border-radius: 3px; - padding: 3px; - right: 10px; - opacity: 0; - min-width: 110px; - transition: .15s ease all; - pointer-events: none -} - -.apexcharts-menu.apexcharts-menu-open { - opacity: 1; - pointer-events: all; - transition: .15s ease all -} - -.apexcharts-menu-item { - padding: 6px 7px; - font-size: 12px; - cursor: pointer -} - -.apexcharts-theme-light .apexcharts-menu-item:hover { - background: #eee -} - -.apexcharts-theme-dark .apexcharts-menu { - background: rgba(0,0,0,.7); - color: #fff -} - -@media screen and (min-width:768px) { - .apexcharts-canvas:hover .apexcharts-toolbar { - opacity: 1 - } -} - -.apexcharts-canvas .apexcharts-element-hidden,.apexcharts-datalabel.apexcharts-element-hidden,.apexcharts-hide .apexcharts-series-points { - opacity: 0 -} - -.apexcharts-datalabel,.apexcharts-datalabel-label,.apexcharts-datalabel-value,.apexcharts-datalabels,.apexcharts-pie-label { - cursor: default; - pointer-events: none -} - -.apexcharts-pie-label-delay { - opacity: 0; - animation-name: opaque; - animation-duration: .3s; - animation-fill-mode: forwards; - animation-timing-function: ease -} - -.apexcharts-annotation-rect,.apexcharts-area-series .apexcharts-area,.apexcharts-area-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-gridline,.apexcharts-line,.apexcharts-line-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-point-annotation-label,.apexcharts-radar-series path,.apexcharts-radar-series polygon,.apexcharts-toolbar svg,.apexcharts-tooltip .apexcharts-marker,.apexcharts-xaxis-annotation-label,.apexcharts-yaxis-annotation-label,.apexcharts-zoom-rect { - pointer-events: none -} - -.apexcharts-marker { - transition: .15s ease all -} - -.resize-triggers { - animation: 1ms resizeanim; - visibility: hidden; - opacity: 0; - height: 100%; - width: 100%; - overflow: hidden -} - -.contract-trigger:before,.resize-triggers,.resize-triggers>div { - content: " "; - display: block; - position: absolute; - top: 0; - left: 0 -} - -.resize-triggers>div { - height: 100%; - width: 100%; - background: #eee; - overflow: auto -} - -.contract-trigger:before { - overflow: hidden; - width: 200%; - height: 200% -} diff --git a/cp/public/assets/libs/apexcharts/dist/apexcharts.esm.js b/cp/public/assets/libs/apexcharts/dist/apexcharts.esm.js deleted file mode 100644 index 2d84b22..0000000 --- a/cp/public/assets/libs/apexcharts/dist/apexcharts.esm.js +++ /dev/null @@ -1,14 +0,0 @@ -/*! - * ApexCharts v3.40.0 - * (c) 2018-2023 ApexCharts - * Released under the MIT License. - */ -function t(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function e(e){for(var i=1;it.length)&&(e=t.length);for(var i=0,a=new Array(e);i>16,o=i>>8&255,n=255&i;return"#"+(16777216+65536*(Math.round((a-r)*s)+r)+256*(Math.round((a-o)*s)+o)+(Math.round((a-n)*s)+n)).toString(16).slice(1)}},{key:"shadeColor",value:function(e,i){return t.isColorHex(i)?this.shadeHexColor(e,i):this.shadeRGBColor(e,i)}}],[{key:"bind",value:function(t,e){return function(){return t.apply(e,arguments)}}},{key:"isObject",value:function(t){return t&&"object"===i(t)&&!Array.isArray(t)&&null!=t}},{key:"is",value:function(t,e){return Object.prototype.toString.call(e)==="[object "+t+"]"}},{key:"listToArray",value:function(t){var e,i=[];for(e=0;ee.length?t:e}))),t.length>e.length?t:e}),0)}},{key:"hexToRgba",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"#999999",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:.6;"#"!==t.substring(0,1)&&(t="#999999");var i=t.replace("#","");i=i.match(new RegExp("(.{"+i.length/3+"})","g"));for(var a=0;a1&&void 0!==arguments[1]?arguments[1]:"x",i=t.toString().slice();return i=i.replace(/[` ~!@#$%^&*()|+\=?;:'",.<>{}[\]\\/]/gi,e)}},{key:"negToZero",value:function(t){return t<0?0:t}},{key:"moveIndexInArray",value:function(t,e,i){if(i>=t.length)for(var a=i-t.length+1;a--;)t.push(void 0);return t.splice(i,0,t.splice(e,1)[0]),t}},{key:"extractNumber",value:function(t){return parseFloat(t.replace(/[^\d.]*/g,""))}},{key:"findAncestor",value:function(t,e){for(;(t=t.parentElement)&&!t.classList.contains(e););return t}},{key:"setELstyles",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&(t.style.key=e[i])}},{key:"isNumber",value:function(t){return!isNaN(t)&&parseFloat(Number(t))===t&&!isNaN(parseInt(t,10))}},{key:"isFloat",value:function(t){return Number(t)===t&&t%1!=0}},{key:"isSafari",value:function(){return/^((?!chrome|android).)*safari/i.test(navigator.userAgent)}},{key:"isFirefox",value:function(){return navigator.userAgent.toLowerCase().indexOf("firefox")>-1}},{key:"isIE11",value:function(){if(-1!==window.navigator.userAgent.indexOf("MSIE")||window.navigator.appVersion.indexOf("Trident/")>-1)return!0}},{key:"isIE",value:function(){var t=window.navigator.userAgent,e=t.indexOf("MSIE ");if(e>0)return parseInt(t.substring(e+5,t.indexOf(".",e)),10);if(t.indexOf("Trident/")>0){var i=t.indexOf("rv:");return parseInt(t.substring(i+3,t.indexOf(".",i)),10)}var a=t.indexOf("Edge/");return a>0&&parseInt(t.substring(a+5,t.indexOf(".",a)),10)}}]),t}(),b=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.setEasingFunctions()}return r(t,[{key:"setEasingFunctions",value:function(){var t;if(!this.w.globals.easing){switch(this.w.config.chart.animations.easing){case"linear":t="-";break;case"easein":t="<";break;case"easeout":t=">";break;case"easeinout":default:t="<>";break;case"swing":t=function(t){var e=1.70158;return(t-=1)*t*((e+1)*t+e)+1};break;case"bounce":t=function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375};break;case"elastic":t=function(t){return t===!!t?t:Math.pow(2,-10*t)*Math.sin((t-.075)*(2*Math.PI)/.3)+1}}this.w.globals.easing=t}}},{key:"animateLine",value:function(t,e,i,a){t.attr(e).animate(a).attr(i)}},{key:"animateMarker",value:function(t,e,i,a,s,r){e||(e=0),t.attr({r:e,width:e,height:e}).animate(a,s).attr({r:i,width:i.width,height:i.height}).afterAll((function(){r()}))}},{key:"animateCircle",value:function(t,e,i,a,s){t.attr({r:e.r,cx:e.cx,cy:e.cy}).animate(a,s).attr({r:i.r,cx:i.cx,cy:i.cy})}},{key:"animateRect",value:function(t,e,i,a,s){t.attr(e).animate(a).attr(i).afterAll((function(){return s()}))}},{key:"animatePathsGradually",value:function(t){var e=t.el,i=t.realIndex,a=t.j,s=t.fill,r=t.pathFrom,o=t.pathTo,n=t.speed,l=t.delay,h=this.w,c=0;h.config.chart.animations.animateGradually.enabled&&(c=h.config.chart.animations.animateGradually.delay),h.config.chart.animations.dynamicAnimation.enabled&&h.globals.dataChanged&&"bar"!==h.config.chart.type&&(c=0),this.morphSVG(e,i,a,"line"!==h.config.chart.type||h.globals.comboCharts?s:"stroke",r,o,n,l*c)}},{key:"showDelayedElements",value:function(){this.w.globals.delayedElements.forEach((function(t){t.el.classList.remove("apexcharts-element-hidden")}))}},{key:"animationCompleted",value:function(t){var e=this.w;e.globals.animationEnded||(e.globals.animationEnded=!0,this.showDelayedElements(),"function"==typeof e.config.chart.events.animationEnd&&e.config.chart.events.animationEnd(this.ctx,{el:t,w:e}))}},{key:"morphSVG",value:function(t,e,i,a,s,r,o,n){var l=this,h=this.w;s||(s=t.attr("pathFrom")),r||(r=t.attr("pathTo"));var c=function(t){return"radar"===h.config.chart.type&&(o=1),"M 0 ".concat(h.globals.gridHeight)};(!s||s.indexOf("undefined")>-1||s.indexOf("NaN")>-1)&&(s=c()),(!r||r.indexOf("undefined")>-1||r.indexOf("NaN")>-1)&&(r=c()),h.globals.shouldAnimate||(o=1),t.plot(s).animate(1,h.globals.easing,n).plot(s).animate(o,h.globals.easing,n).plot(r).afterAll((function(){x.isNumber(i)?i===h.globals.series[h.globals.maxValsInArrayIndex].length-2&&h.globals.shouldAnimate&&l.animationCompleted(t):"none"!==a&&h.globals.shouldAnimate&&(!h.globals.comboCharts&&e===h.globals.series.length-1||h.globals.comboCharts)&&l.animationCompleted(t),l.showDelayedElements()}))}}]),t}(),v=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"getDefaultFilter",value:function(t,e){var i=this.w;t.unfilter(!0),(new window.SVG.Filter).size("120%","180%","-5%","-40%"),"none"!==i.config.states.normal.filter?this.applyFilter(t,e,i.config.states.normal.filter.type,i.config.states.normal.filter.value):i.config.chart.dropShadow.enabled&&this.dropShadow(t,i.config.chart.dropShadow,e)}},{key:"addNormalFilter",value:function(t,e){var i=this.w;i.config.chart.dropShadow.enabled&&!t.node.classList.contains("apexcharts-marker")&&this.dropShadow(t,i.config.chart.dropShadow,e)}},{key:"addLightenFilter",value:function(t,e,i){var a=this,s=this.w,r=i.intensity;t.unfilter(!0);new window.SVG.Filter;t.filter((function(t){var i=s.config.chart.dropShadow;(i.enabled?a.addShadow(t,e,i):t).componentTransfer({rgb:{type:"linear",slope:1.5,intercept:r}})})),t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)}},{key:"addDarkenFilter",value:function(t,e,i){var a=this,s=this.w,r=i.intensity;t.unfilter(!0);new window.SVG.Filter;t.filter((function(t){var i=s.config.chart.dropShadow;(i.enabled?a.addShadow(t,e,i):t).componentTransfer({rgb:{type:"linear",slope:r}})})),t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)}},{key:"applyFilter",value:function(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:.5;switch(i){case"none":this.addNormalFilter(t,e);break;case"lighten":this.addLightenFilter(t,e,{intensity:a});break;case"darken":this.addDarkenFilter(t,e,{intensity:a})}}},{key:"addShadow",value:function(t,e,i){var a=i.blur,s=i.top,r=i.left,o=i.color,n=i.opacity,l=t.flood(Array.isArray(o)?o[e]:o,n).composite(t.sourceAlpha,"in").offset(r,s).gaussianBlur(a).merge(t.source);return t.blend(t.source,l)}},{key:"dropShadow",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=e.top,s=e.left,r=e.blur,o=e.color,n=e.opacity,l=e.noUserSpaceOnUse,h=this.w;return t.unfilter(!0),x.isIE()&&"radialBar"===h.config.chart.type||(o=Array.isArray(o)?o[i]:o,t.filter((function(t){var e=null;e=x.isSafari()||x.isFirefox()||x.isIE()?t.flood(o,n).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(r):t.flood(o,n).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(r).merge(t.source),t.blend(t.source,e)})),l||t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)),t}},{key:"setSelectionFilter",value:function(t,e,i){var a=this.w;if(void 0!==a.globals.selectedDataPoints[e]&&a.globals.selectedDataPoints[e].indexOf(i)>-1){t.node.setAttribute("selected",!0);var s=a.config.states.active.filter;"none"!==s&&this.applyFilter(t,e,s.type,s.value)}}},{key:"_scaleFilterSize",value:function(t){!function(e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}({width:"200%",height:"200%",x:"-50%",y:"-50%"})}}]),t}(),m=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"roundPathCorners",value:function(t,e){function i(t,e,i){var s=e.x-t.x,r=e.y-t.y,o=Math.sqrt(s*s+r*r);return a(t,e,Math.min(1,i/o))}function a(t,e,i){return{x:t.x+(e.x-t.x)*i,y:t.y+(e.y-t.y)*i}}function s(t,e){t.length>2&&(t[t.length-2]=e.x,t[t.length-1]=e.y)}function r(t){return{x:parseFloat(t[t.length-2]),y:parseFloat(t[t.length-1])}}t.indexOf("NaN")>-1&&(t="");var o=t.split(/[,\s]/).reduce((function(t,e){var i=e.match("([a-zA-Z])(.+)");return i?(t.push(i[1]),t.push(i[2])):t.push(e),t}),[]).reduce((function(t,e){return parseFloat(e)==e&&t.length?t[t.length-1].push(e):t.push([e]),t}),[]),n=[];if(o.length>1){var l=r(o[0]),h=null;"Z"==o[o.length-1][0]&&o[0].length>2&&(h=["L",l.x,l.y],o[o.length-1]=h),n.push(o[0]);for(var c=1;c2&&"L"==g[0]&&u.length>2&&"L"==u[0]){var p,f,x=r(d),b=r(g),v=r(u);p=i(b,x,e),f=i(b,v,e),s(g,p),g.origPoint=b,n.push(g);var m=a(p,b,.5),y=a(b,f,.5),w=["C",m.x,m.y,y.x,y.y,f.x,f.y];w.origPoint=b,n.push(w)}else n.push(g)}if(h){var k=r(n[n.length-1]);n.push(["Z"]),s(n[0],k)}}else n=o;return n.reduce((function(t,e){return t+e.join(" ")+" "}),"")}},{key:"drawLine",value:function(t,e,i,a){var s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"#a8a8a8",r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,o=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,n=arguments.length>7&&void 0!==arguments[7]?arguments[7]:"butt";return this.w.globals.dom.Paper.line().attr({x1:t,y1:e,x2:i,y2:a,stroke:s,"stroke-dasharray":r,"stroke-width":o,"stroke-linecap":n})}},{key:"drawRect",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"#fefefe",o=arguments.length>6&&void 0!==arguments[6]?arguments[6]:1,n=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,l=arguments.length>8&&void 0!==arguments[8]?arguments[8]:null,h=arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,c=this.w.globals.dom.Paper.rect();return c.attr({x:t,y:e,width:i>0?i:0,height:a>0?a:0,rx:s,ry:s,opacity:o,"stroke-width":null!==n?n:0,stroke:null!==l?l:"none","stroke-dasharray":h}),c.node.setAttribute("fill",r),c}},{key:"drawPolygon",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"#e1e1e1",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none";return this.w.globals.dom.Paper.polygon(t).attr({fill:a,stroke:e,"stroke-width":i})}},{key:"drawCircle",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;t<0&&(t=0);var i=this.w.globals.dom.Paper.circle(2*t);return null!==e&&i.attr(e),i}},{key:"drawPath",value:function(t){var e=t.d,i=void 0===e?"":e,a=t.stroke,s=void 0===a?"#a8a8a8":a,r=t.strokeWidth,o=void 0===r?1:r,n=t.fill,l=t.fillOpacity,h=void 0===l?1:l,c=t.strokeOpacity,d=void 0===c?1:c,g=t.classes,u=t.strokeLinecap,p=void 0===u?null:u,f=t.strokeDashArray,x=void 0===f?0:f,b=this.w;return null===p&&(p=b.config.stroke.lineCap),(i.indexOf("undefined")>-1||i.indexOf("NaN")>-1)&&(i="M 0 ".concat(b.globals.gridHeight)),b.globals.dom.Paper.path(i).attr({fill:n,"fill-opacity":h,stroke:s,"stroke-opacity":d,"stroke-linecap":p,"stroke-width":o,"stroke-dasharray":x,class:g})}},{key:"group",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w.globals.dom.Paper.group();return null!==t&&e.attr(t),e}},{key:"move",value:function(t,e){var i=["M",t,e].join(" ");return i}},{key:"line",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=null;return null===i?a=[" L",t,e].join(" "):"H"===i?a=[" H",t].join(" "):"V"===i&&(a=[" V",e].join(" ")),a}},{key:"curve",value:function(t,e,i,a,s,r){var o=["C",t,e,i,a,s,r].join(" ");return o}},{key:"quadraticCurve",value:function(t,e,i,a){return["Q",t,e,i,a].join(" ")}},{key:"arc",value:function(t,e,i,a,s,r,o){var n="A";arguments.length>7&&void 0!==arguments[7]&&arguments[7]&&(n="a");var l=[n,t,e,i,a,s,r,o].join(" ");return l}},{key:"renderPaths",value:function(t){var i,a=t.j,s=t.realIndex,r=t.pathFrom,o=t.pathTo,n=t.stroke,l=t.strokeWidth,h=t.strokeLinecap,c=t.fill,d=t.animationDelay,g=t.initialSpeed,u=t.dataChangeSpeed,p=t.className,f=t.shouldClipToGrid,x=void 0===f||f,m=t.bindEventsOnPaths,y=void 0===m||m,w=t.drawShadow,k=void 0===w||w,A=this.w,S=new v(this.ctx),C=new b(this.ctx),L=this.w.config.chart.animations.enabled,P=L&&this.w.config.chart.animations.dynamicAnimation.enabled,I=!!(L&&!A.globals.resized||P&&A.globals.dataChanged&&A.globals.shouldAnimate);I?i=r:(i=o,A.globals.animationEnded=!0);var T=A.config.stroke.dashArray,M=0;M=Array.isArray(T)?T[s]:A.config.stroke.dashArray;var X=this.drawPath({d:i,stroke:n,strokeWidth:l,fill:c,fillOpacity:1,classes:p,strokeLinecap:h,strokeDashArray:M});if(X.attr("index",s),x&&X.attr({"clip-path":"url(#gridRectMask".concat(A.globals.cuid,")")}),"none"!==A.config.states.normal.filter.type)S.getDefaultFilter(X,s);else if(A.config.chart.dropShadow.enabled&&k&&(!A.config.chart.dropShadow.enabledOnSeries||A.config.chart.dropShadow.enabledOnSeries&&-1!==A.config.chart.dropShadow.enabledOnSeries.indexOf(s))){var z=A.config.chart.dropShadow;S.dropShadow(X,z,s)}y&&(X.node.addEventListener("mouseenter",this.pathMouseEnter.bind(this,X)),X.node.addEventListener("mouseleave",this.pathMouseLeave.bind(this,X)),X.node.addEventListener("mousedown",this.pathMouseDown.bind(this,X))),X.attr({pathTo:o,pathFrom:r});var E={el:X,j:a,realIndex:s,pathFrom:r,pathTo:o,fill:c,strokeWidth:l,delay:d};return!L||A.globals.resized||A.globals.dataChanged?!A.globals.resized&&A.globals.dataChanged||C.showDelayedElements():C.animatePathsGradually(e(e({},E),{},{speed:g})),A.globals.dataChanged&&P&&I&&C.animatePathsGradually(e(e({},E),{},{speed:u})),X}},{key:"drawPattern",value:function(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"#a8a8a8",s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0;return this.w.globals.dom.Paper.pattern(e,i,(function(r){"horizontalLines"===t?r.line(0,0,i,0).stroke({color:a,width:s+1}):"verticalLines"===t?r.line(0,0,0,e).stroke({color:a,width:s+1}):"slantedLines"===t?r.line(0,0,e,i).stroke({color:a,width:s}):"squares"===t?r.rect(e,i).fill("none").stroke({color:a,width:s}):"circles"===t&&r.circle(e).fill("none").stroke({color:a,width:s})}))}},{key:"drawGradient",value:function(t,e,i,a,s){var r,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:null,n=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,h=arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,c=this.w;e.length<9&&0===e.indexOf("#")&&(e=x.hexToRgba(e,a)),i.length<9&&0===i.indexOf("#")&&(i=x.hexToRgba(i,s));var d=0,g=1,u=1,p=null;null!==n&&(d=void 0!==n[0]?n[0]/100:0,g=void 0!==n[1]?n[1]/100:1,u=void 0!==n[2]?n[2]/100:1,p=void 0!==n[3]?n[3]/100:null);var f=!("donut"!==c.config.chart.type&&"pie"!==c.config.chart.type&&"polarArea"!==c.config.chart.type&&"bubble"!==c.config.chart.type);if(r=null===l||0===l.length?c.globals.dom.Paper.gradient(f?"radial":"linear",(function(t){t.at(d,e,a),t.at(g,i,s),t.at(u,i,s),null!==p&&t.at(p,e,a)})):c.globals.dom.Paper.gradient(f?"radial":"linear",(function(t){(Array.isArray(l[h])?l[h]:l).forEach((function(e){t.at(e.offset/100,e.color,e.opacity)}))})),f){var b=c.globals.gridWidth/2,v=c.globals.gridHeight/2;"bubble"!==c.config.chart.type?r.attr({gradientUnits:"userSpaceOnUse",cx:b,cy:v,r:o}):r.attr({cx:.5,cy:.5,r:.8,fx:.2,fy:.2})}else"vertical"===t?r.from(0,0).to(0,1):"diagonal"===t?r.from(0,0).to(1,1):"horizontal"===t?r.from(0,1).to(1,1):"diagonal2"===t&&r.from(1,0).to(0,1);return r}},{key:"getTextBasedOnMaxWidth",value:function(t){var e=t.text,i=t.maxWidth,a=t.fontSize,s=t.fontFamily,r=this.getTextRects(e,a,s),o=r.width/e.length,n=Math.floor(i/o);return i-1){var n=i.globals.selectedDataPoints[s].indexOf(r);i.globals.selectedDataPoints[s].splice(n,1)}}else{if(!i.config.states.active.allowMultipleDataPointsSelection&&i.globals.selectedDataPoints.length>0){i.globals.selectedDataPoints=[];var l=i.globals.dom.Paper.select(".apexcharts-series path").members,h=i.globals.dom.Paper.select(".apexcharts-series circle, .apexcharts-series rect").members,c=function(t){Array.prototype.forEach.call(t,(function(t){t.node.setAttribute("selected","false"),a.getDefaultFilter(t,s)}))};c(l),c(h)}t.node.setAttribute("selected","true"),o="true",void 0===i.globals.selectedDataPoints[s]&&(i.globals.selectedDataPoints[s]=[]),i.globals.selectedDataPoints[s].push(r)}if("true"===o){var d=i.config.states.active.filter;if("none"!==d)a.applyFilter(t,s,d.type,d.value);else if("none"!==i.config.states.hover.filter&&!i.globals.isTouchDevice){var g=i.config.states.hover.filter;a.applyFilter(t,s,g.type,g.value)}}else if("none"!==i.config.states.active.filter.type)if("none"===i.config.states.hover.filter.type||i.globals.isTouchDevice)a.getDefaultFilter(t,s);else{g=i.config.states.hover.filter;a.applyFilter(t,s,g.type,g.value)}"function"==typeof i.config.chart.events.dataPointSelection&&i.config.chart.events.dataPointSelection(e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:s,dataPointIndex:r,w:i}),e&&this.ctx.events.fireEvent("dataPointSelection",[e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:s,dataPointIndex:r,w:i}])}},{key:"rotateAroundCenter",value:function(t){var e={};return t&&"function"==typeof t.getBBox&&(e=t.getBBox()),{x:e.x+e.width/2,y:e.y+e.height/2}}},{key:"getTextRects",value:function(t,e,i,a){var s=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],r=this.w,o=this.drawText({x:-200,y:-200,text:t,textAnchor:"start",fontSize:e,fontFamily:i,foreColor:"#fff",opacity:0});a&&o.attr("transform",a),r.globals.dom.Paper.add(o);var n=o.bbox();return s||(n=o.node.getBoundingClientRect()),o.remove(),{width:n.width,height:n.height}}},{key:"placeTextWithEllipsis",value:function(t,e,i){if("function"==typeof t.getComputedTextLength&&(t.textContent=e,e.length>0&&t.getComputedTextLength()>=i/1.1)){for(var a=e.length-3;a>0;a-=3)if(t.getSubStringLength(0,a)<=i/1.1)return void(t.textContent=e.substring(0,a)+"...");t.textContent="."}}}],[{key:"setAttrs",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}}]),t}(),y=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"getStackedSeriesTotals",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=this.w,i=[];if(0===e.globals.series.length)return i;for(var a=0;a0&&void 0!==arguments[0]?arguments[0]:null;return null===t?this.w.config.series.reduce((function(t,e){return t+e}),0):this.w.globals.series[t].reduce((function(t,e){return t+e}),0)}},{key:"isSeriesNull",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;return 0===(null===t?this.w.config.series.filter((function(t){return null!==t})):this.w.config.series[t].data.filter((function(t){return null!==t}))).length}},{key:"seriesHaveSameValues",value:function(t){return this.w.globals.series[t].every((function(t,e,i){return t===i[0]}))}},{key:"getCategoryLabels",value:function(t){var e=this.w,i=t.slice();return e.config.xaxis.convertedCatToNumeric&&(i=t.map((function(t,i){return e.config.xaxis.labels.formatter(t-e.globals.minX+1)}))),i}},{key:"getLargestSeries",value:function(){var t=this.w;t.globals.maxValsInArrayIndex=t.globals.series.map((function(t){return t.length})).indexOf(Math.max.apply(Math,t.globals.series.map((function(t){return t.length}))))}},{key:"getLargestMarkerSize",value:function(){var t=this.w,e=0;return t.globals.markers.size.forEach((function(t){e=Math.max(e,t)})),t.config.markers.discrete&&t.config.markers.discrete.length&&t.config.markers.discrete.forEach((function(t){e=Math.max(e,t.size)})),e>0&&(e+=t.config.markers.hover.sizeOffset+1),t.globals.markers.largestSize=e,e}},{key:"getSeriesTotals",value:function(){var t=this.w;t.globals.seriesTotals=t.globals.series.map((function(t,e){var i=0;if(Array.isArray(t))for(var a=0;at&&i.globals.seriesX[s][o]0&&(e=!0),{comboBarCount:i,comboCharts:e}}},{key:"extendArrayProps",value:function(t,e,i){return e.yaxis&&(e=t.extendYAxis(e,i)),e.annotations&&(e.annotations.yaxis&&(e=t.extendYAxisAnnotations(e)),e.annotations.xaxis&&(e=t.extendXAxisAnnotations(e)),e.annotations.points&&(e=t.extendPointAnnotations(e))),e}}]),t}(),w=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e}return r(t,[{key:"setOrientations",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=this.w;if("vertical"===t.label.orientation){var a=null!==e?e:0,s=i.globals.dom.baseEl.querySelector(".apexcharts-xaxis-annotations .apexcharts-xaxis-annotation-label[rel='".concat(a,"']"));if(null!==s){var r=s.getBoundingClientRect();s.setAttribute("x",parseFloat(s.getAttribute("x"))-r.height+4),"top"===t.label.position?s.setAttribute("y",parseFloat(s.getAttribute("y"))+r.width):s.setAttribute("y",parseFloat(s.getAttribute("y"))-r.width);var o=this.annoCtx.graphics.rotateAroundCenter(s),n=o.x,l=o.y;s.setAttribute("transform","rotate(-90 ".concat(n," ").concat(l,")"))}}}},{key:"addBackgroundToAnno",value:function(t,e){var i=this.w;if(!t||void 0===e.label.text||void 0!==e.label.text&&!String(e.label.text).trim())return null;var a=i.globals.dom.baseEl.querySelector(".apexcharts-grid").getBoundingClientRect(),s=t.getBoundingClientRect(),r=e.label.style.padding.left,o=e.label.style.padding.right,n=e.label.style.padding.top,l=e.label.style.padding.bottom;"vertical"===e.label.orientation&&(n=e.label.style.padding.left,l=e.label.style.padding.right,r=e.label.style.padding.top,o=e.label.style.padding.bottom);var h=s.left-a.left-r,c=s.top-a.top-n,d=this.annoCtx.graphics.drawRect(h-i.globals.barPadForNumericAxis,c,s.width+r+o,s.height+n+l,e.label.borderRadius,e.label.style.background,1,e.label.borderWidth,e.label.borderColor,0);return e.id&&d.node.classList.add(e.id),d}},{key:"annotationsBackground",value:function(){var t=this,e=this.w,i=function(i,a,s){var r=e.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations .apexcharts-").concat(s,"-annotation-label[rel='").concat(a,"']"));if(r){var o=r.parentNode,n=t.addBackgroundToAnno(r,i);n&&(o.insertBefore(n.node,r),i.label.mouseEnter&&n.node.addEventListener("mouseenter",i.label.mouseEnter.bind(t,i)),i.label.mouseLeave&&n.node.addEventListener("mouseleave",i.label.mouseLeave.bind(t,i)),i.label.click&&n.node.addEventListener("click",i.label.click.bind(t,i)))}};e.config.annotations.xaxis.map((function(t,e){i(t,e,"xaxis")})),e.config.annotations.yaxis.map((function(t,e){i(t,e,"yaxis")})),e.config.annotations.points.map((function(t,e){i(t,e,"point")}))}},{key:"getY1Y2",value:function(t,e){var i,a="y1"===t?e.y:e.y2,s=this.w;if(this.annoCtx.invertAxis){var r=s.globals.labels.indexOf(a);s.config.xaxis.convertedCatToNumeric&&(r=s.globals.categoryLabels.indexOf(a));var o=s.globals.dom.baseEl.querySelector(".apexcharts-yaxis-texts-g text:nth-child("+(r+1)+")");o&&(i=parseFloat(o.getAttribute("y")))}else{var n;if(s.config.yaxis[e.yAxisIndex].logarithmic)n=(a=new y(this.annoCtx.ctx).getLogVal(a,e.yAxisIndex))/s.globals.yLogRatio[e.yAxisIndex];else n=(a-s.globals.minYArr[e.yAxisIndex])/(s.globals.yRange[e.yAxisIndex]/s.globals.gridHeight);i=s.globals.gridHeight-n,!e.marker||void 0!==e.y&&null!==e.y||(i=0),s.config.yaxis[e.yAxisIndex]&&s.config.yaxis[e.yAxisIndex].reversed&&(i=n)}return"string"==typeof a&&a.indexOf("px")>-1&&(i=parseFloat(a)),i}},{key:"getX1X2",value:function(t,e){var i=this.w,a=this.annoCtx.invertAxis?i.globals.minY:i.globals.minX,s=this.annoCtx.invertAxis?i.globals.maxY:i.globals.maxX,r=this.annoCtx.invertAxis?i.globals.yRange[0]:i.globals.xRange,o=(e.x-a)/(r/i.globals.gridWidth);this.annoCtx.inversedReversedAxis&&(o=(s-e.x)/(r/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(o=this.getStringX(e.x));var n=(e.x2-a)/(r/i.globals.gridWidth);return this.annoCtx.inversedReversedAxis&&(n=(s-e.x2)/(r/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(n=this.getStringX(e.x2)),void 0!==e.x&&null!==e.x||!e.marker||(o=i.globals.gridWidth),"x1"===t&&"string"==typeof e.x&&e.x.indexOf("px")>-1&&(o=parseFloat(e.x)),"x2"===t&&"string"==typeof e.x2&&e.x2.indexOf("px")>-1&&(n=parseFloat(e.x2)),"x1"===t?o:n}},{key:"getStringX",value:function(t){var e=this.w,i=t;e.config.xaxis.convertedCatToNumeric&&e.globals.categoryLabels.length&&(t=e.globals.categoryLabels.indexOf(t)+1);var a=e.globals.labels.indexOf(t),s=e.globals.dom.baseEl.querySelector(".apexcharts-xaxis-texts-g text:nth-child("+(a+1)+")");return s&&(i=parseFloat(s.getAttribute("x"))),i}}]),t}(),k=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e,this.invertAxis=this.annoCtx.invertAxis,this.helpers=new w(this.annoCtx)}return r(t,[{key:"addXaxisAnnotation",value:function(t,e,i){var a,s=this.w,r=this.helpers.getX1X2("x1",t),o=t.label.text,n=t.strokeDashArray;if(x.isNumber(r)){if(null===t.x2||void 0===t.x2){var l=this.annoCtx.graphics.drawLine(r+t.offsetX,0+t.offsetY,r+t.offsetX,s.globals.gridHeight+t.offsetY,t.borderColor,n,t.borderWidth);e.appendChild(l.node),t.id&&l.node.classList.add(t.id)}else{if((a=this.helpers.getX1X2("x2",t))o){var h=o;o=a,a=h}var c=this.annoCtx.graphics.drawRect(0+t.offsetX,a+t.offsetY,this._getYAxisAnnotationWidth(t),o-a,0,t.fillColor,t.opacity,1,t.borderColor,r);c.node.classList.add("apexcharts-annotation-rect"),c.attr("clip-path","url(#gridRectMask".concat(s.globals.cuid,")")),e.appendChild(c.node),t.id&&c.node.classList.add(t.id)}var d="right"===t.label.position?s.globals.gridWidth:"center"===t.label.position?s.globals.gridWidth/2:0,g=this.annoCtx.graphics.drawText({x:d+t.label.offsetX,y:(null!=a?a:o)+t.label.offsetY-3,text:n,textAnchor:t.label.textAnchor,fontSize:t.label.style.fontSize,fontFamily:t.label.style.fontFamily,fontWeight:t.label.style.fontWeight,foreColor:t.label.style.color,cssClass:"apexcharts-yaxis-annotation-label ".concat(t.label.style.cssClass," ").concat(t.id?t.id:"")});g.attr({rel:i}),e.appendChild(g.node)}},{key:"_getYAxisAnnotationWidth",value:function(t){var e=this.w;e.globals.gridWidth;return(t.width.indexOf("%")>-1?e.globals.gridWidth*parseInt(t.width,10)/100:parseInt(t.width,10))+t.offsetX}},{key:"drawYAxisAnnotations",value:function(){var t=this,e=this.w,i=this.annoCtx.graphics.group({class:"apexcharts-yaxis-annotations"});return e.config.annotations.yaxis.map((function(e,a){t.addYaxisAnnotation(e,i.node,a)})),i}}]),t}(),S=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e,this.helpers=new w(this.annoCtx)}return r(t,[{key:"addPointAnnotation",value:function(t,e,i){this.w;var a=this.helpers.getX1X2("x1",t),s=this.helpers.getY1Y2("y1",t);if(x.isNumber(a)){var r={pSize:t.marker.size,pointStrokeWidth:t.marker.strokeWidth,pointFillColor:t.marker.fillColor,pointStrokeColor:t.marker.strokeColor,shape:t.marker.shape,pRadius:t.marker.radius,class:"apexcharts-point-annotation-marker ".concat(t.marker.cssClass," ").concat(t.id?t.id:"")},o=this.annoCtx.graphics.drawMarker(a+t.marker.offsetX,s+t.marker.offsetY,r);e.appendChild(o.node);var n=t.label.text?t.label.text:"",l=this.annoCtx.graphics.drawText({x:a+t.label.offsetX,y:s+t.label.offsetY-t.marker.size-parseFloat(t.label.style.fontSize)/1.6,text:n,textAnchor:t.label.textAnchor,fontSize:t.label.style.fontSize,fontFamily:t.label.style.fontFamily,fontWeight:t.label.style.fontWeight,foreColor:t.label.style.color,cssClass:"apexcharts-point-annotation-label ".concat(t.label.style.cssClass," ").concat(t.id?t.id:"")});if(l.attr({rel:i}),e.appendChild(l.node),t.customSVG.SVG){var h=this.annoCtx.graphics.group({class:"apexcharts-point-annotations-custom-svg "+t.customSVG.cssClass});h.attr({transform:"translate(".concat(a+t.customSVG.offsetX,", ").concat(s+t.customSVG.offsetY,")")}),h.node.innerHTML=t.customSVG.SVG,e.appendChild(h.node)}if(t.image.path){var c=t.image.width?t.image.width:20,d=t.image.height?t.image.height:20;o=this.annoCtx.addImage({x:a+t.image.offsetX-c/2,y:s+t.image.offsetY-d/2,width:c,height:d,path:t.image.path,appendTo:".apexcharts-point-annotations"})}t.mouseEnter&&o.node.addEventListener("mouseenter",t.mouseEnter.bind(this,t)),t.mouseLeave&&o.node.addEventListener("mouseleave",t.mouseLeave.bind(this,t)),t.click&&o.node.addEventListener("click",t.click.bind(this,t))}}},{key:"drawPointAnnotations",value:function(){var t=this,e=this.w,i=this.annoCtx.graphics.group({class:"apexcharts-point-annotations"});return e.config.annotations.points.map((function(e,a){t.addPointAnnotation(e,i.node,a)})),i}}]),t}();var C={name:"en",options:{months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],toolbar:{exportToSVG:"Download SVG",exportToPNG:"Download PNG",exportToCSV:"Download CSV",menu:"Menu",selection:"Selection",selectionZoom:"Selection Zoom",zoomIn:"Zoom In",zoomOut:"Zoom Out",pan:"Panning",reset:"Reset Zoom"}}},L=function(){function t(){a(this,t),this.yAxis={show:!0,showAlways:!1,showForNullSeries:!0,seriesName:void 0,opposite:!1,reversed:!1,logarithmic:!1,logBase:10,tickAmount:void 0,forceNiceScale:!1,max:void 0,min:void 0,floating:!1,decimalsInFloat:void 0,labels:{show:!0,minWidth:0,maxWidth:160,offsetX:0,offsetY:0,align:void 0,rotate:0,padding:20,style:{colors:[],fontSize:"11px",fontWeight:400,fontFamily:void 0,cssClass:""},formatter:void 0},axisBorder:{show:!1,color:"#e0e0e0",width:1,offsetX:0,offsetY:0},axisTicks:{show:!1,color:"#e0e0e0",width:6,offsetX:0,offsetY:0},title:{text:void 0,rotate:-90,offsetY:0,offsetX:0,style:{color:void 0,fontSize:"11px",fontWeight:900,fontFamily:void 0,cssClass:""}},tooltip:{enabled:!1,offsetX:0},crosshairs:{show:!0,position:"front",stroke:{color:"#b6b6b6",width:1,dashArray:0}}},this.pointAnnotation={id:void 0,x:0,y:null,yAxisIndex:0,seriesIndex:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,marker:{size:4,fillColor:"#fff",strokeWidth:2,strokeColor:"#333",shape:"circle",offsetX:0,offsetY:0,radius:2,cssClass:""},label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"middle",offsetX:0,offsetY:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}},customSVG:{SVG:void 0,cssClass:void 0,offsetX:0,offsetY:0},image:{path:void 0,width:20,height:20,offsetX:0,offsetY:0}},this.yAxisAnnotation={id:void 0,y:0,y2:null,strokeDashArray:1,fillColor:"#c2c2c2",borderColor:"#c2c2c2",borderWidth:1,opacity:.3,offsetX:0,offsetY:0,width:"100%",yAxisIndex:0,label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"end",position:"right",offsetX:0,offsetY:-3,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}}},this.xAxisAnnotation={id:void 0,x:0,x2:null,strokeDashArray:1,fillColor:"#c2c2c2",borderColor:"#c2c2c2",borderWidth:1,opacity:.3,offsetX:0,offsetY:0,label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"middle",orientation:"vertical",position:"top",offsetX:0,offsetY:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}}},this.text={x:0,y:0,text:"",textAnchor:"start",foreColor:void 0,fontSize:"13px",fontFamily:void 0,fontWeight:400,appendTo:".apexcharts-annotations",backgroundColor:"transparent",borderColor:"#c2c2c2",borderRadius:0,borderWidth:0,paddingLeft:4,paddingRight:4,paddingTop:2,paddingBottom:2}}return r(t,[{key:"init",value:function(){return{annotations:{yaxis:[this.yAxisAnnotation],xaxis:[this.xAxisAnnotation],points:[this.pointAnnotation],texts:[],images:[],shapes:[]},chart:{animations:{enabled:!0,easing:"easeinout",speed:800,animateGradually:{delay:150,enabled:!0},dynamicAnimation:{enabled:!0,speed:350}},background:"transparent",locales:[C],defaultLocale:"en",dropShadow:{enabled:!1,enabledOnSeries:void 0,top:2,left:2,blur:4,color:"#000",opacity:.35},events:{animationEnd:void 0,beforeMount:void 0,mounted:void 0,updated:void 0,click:void 0,mouseMove:void 0,mouseLeave:void 0,xAxisLabelClick:void 0,legendClick:void 0,markerClick:void 0,selection:void 0,dataPointSelection:void 0,dataPointMouseEnter:void 0,dataPointMouseLeave:void 0,beforeZoom:void 0,beforeResetZoom:void 0,zoomed:void 0,scrolled:void 0,brushScrolled:void 0},foreColor:"#373d3f",fontFamily:"Helvetica, Arial, sans-serif",height:"auto",parentHeightOffset:15,redrawOnParentResize:!0,redrawOnWindowResize:!0,id:void 0,group:void 0,offsetX:0,offsetY:0,selection:{enabled:!1,type:"x",fill:{color:"#24292e",opacity:.1},stroke:{width:1,color:"#24292e",opacity:.4,dashArray:3},xaxis:{min:void 0,max:void 0},yaxis:{min:void 0,max:void 0}},sparkline:{enabled:!1},brush:{enabled:!1,autoScaleYaxis:!0,target:void 0},stacked:!1,stackType:"normal",toolbar:{show:!0,offsetX:0,offsetY:0,tools:{download:!0,selection:!0,zoom:!0,zoomin:!0,zoomout:!0,pan:!0,reset:!0,customIcons:[]},export:{csv:{filename:void 0,columnDelimiter:",",headerCategory:"category",headerValue:"value",dateFormatter:function(t){return new Date(t).toDateString()}},png:{filename:void 0},svg:{filename:void 0}},autoSelected:"zoom"},type:"line",width:"100%",zoom:{enabled:!0,type:"x",autoScaleYaxis:!1,zoomedArea:{fill:{color:"#90CAF9",opacity:.4},stroke:{color:"#0D47A1",opacity:.4,width:1}}}},plotOptions:{area:{fillTo:"origin"},bar:{horizontal:!1,columnWidth:"70%",barHeight:"70%",distributed:!1,borderRadius:0,borderRadiusApplication:"around",borderRadiusWhenStacked:"last",rangeBarOverlap:!0,rangeBarGroupRows:!1,hideZeroBarsWhenGrouped:!1,isDumbbell:!1,dumbbellColors:void 0,colors:{ranges:[],backgroundBarColors:[],backgroundBarOpacity:1,backgroundBarRadius:0},dataLabels:{position:"top",maxItems:100,hideOverflowingLabels:!0,orientation:"horizontal",total:{enabled:!1,formatter:void 0,offsetX:0,offsetY:0,style:{color:"#373d3f",fontSize:"12px",fontFamily:void 0,fontWeight:600}}}},bubble:{zScaling:!0,minBubbleRadius:void 0,maxBubbleRadius:void 0},candlestick:{colors:{upward:"#00B746",downward:"#EF403C"},wick:{useFillColor:!0}},boxPlot:{colors:{upper:"#00E396",lower:"#008FFB"}},heatmap:{radius:2,enableShades:!0,shadeIntensity:.5,reverseNegativeShade:!1,distributed:!1,useFillColorAsStroke:!1,colorScale:{inverse:!1,ranges:[],min:void 0,max:void 0}},treemap:{enableShades:!0,shadeIntensity:.5,distributed:!1,reverseNegativeShade:!1,useFillColorAsStroke:!1,colorScale:{inverse:!1,ranges:[],min:void 0,max:void 0}},radialBar:{inverseOrder:!1,startAngle:0,endAngle:360,offsetX:0,offsetY:0,hollow:{margin:5,size:"50%",background:"transparent",image:void 0,imageWidth:150,imageHeight:150,imageOffsetX:0,imageOffsetY:0,imageClipped:!0,position:"front",dropShadow:{enabled:!1,top:0,left:0,blur:3,color:"#000",opacity:.5}},track:{show:!0,startAngle:void 0,endAngle:void 0,background:"#f2f2f2",strokeWidth:"97%",opacity:1,margin:5,dropShadow:{enabled:!1,top:0,left:0,blur:3,color:"#000",opacity:.5}},dataLabels:{show:!0,name:{show:!0,fontSize:"16px",fontFamily:void 0,fontWeight:600,color:void 0,offsetY:0,formatter:function(t){return t}},value:{show:!0,fontSize:"14px",fontFamily:void 0,fontWeight:400,color:void 0,offsetY:16,formatter:function(t){return t+"%"}},total:{show:!1,label:"Total",fontSize:"16px",fontWeight:600,fontFamily:void 0,color:void 0,formatter:function(t){return t.globals.seriesTotals.reduce((function(t,e){return t+e}),0)/t.globals.series.length+"%"}}}},pie:{customScale:1,offsetX:0,offsetY:0,startAngle:0,endAngle:360,expandOnClick:!0,dataLabels:{offset:0,minAngleToShowLabel:10},donut:{size:"65%",background:"transparent",labels:{show:!1,name:{show:!0,fontSize:"16px",fontFamily:void 0,fontWeight:600,color:void 0,offsetY:-10,formatter:function(t){return t}},value:{show:!0,fontSize:"20px",fontFamily:void 0,fontWeight:400,color:void 0,offsetY:10,formatter:function(t){return t}},total:{show:!1,showAlways:!1,label:"Total",fontSize:"16px",fontWeight:400,fontFamily:void 0,color:void 0,formatter:function(t){return t.globals.seriesTotals.reduce((function(t,e){return t+e}),0)}}}}},polarArea:{rings:{strokeWidth:1,strokeColor:"#e8e8e8"},spokes:{strokeWidth:1,connectorColors:"#e8e8e8"}},radar:{size:void 0,offsetX:0,offsetY:0,polygons:{strokeWidth:1,strokeColors:"#e8e8e8",connectorColors:"#e8e8e8",fill:{colors:void 0}}}},colors:void 0,dataLabels:{enabled:!0,enabledOnSeries:void 0,formatter:function(t){return null!==t?t:""},textAnchor:"middle",distributed:!1,offsetX:0,offsetY:0,style:{fontSize:"12px",fontFamily:void 0,fontWeight:600,colors:void 0},background:{enabled:!0,foreColor:"#fff",borderRadius:2,padding:4,opacity:.9,borderWidth:1,borderColor:"#fff",dropShadow:{enabled:!1,top:1,left:1,blur:1,color:"#000",opacity:.45}},dropShadow:{enabled:!1,top:1,left:1,blur:1,color:"#000",opacity:.45}},fill:{type:"solid",colors:void 0,opacity:.85,gradient:{shade:"dark",type:"horizontal",shadeIntensity:.5,gradientToColors:void 0,inverseColors:!0,opacityFrom:1,opacityTo:1,stops:[0,50,100],colorStops:[]},image:{src:[],width:void 0,height:void 0},pattern:{style:"squares",width:6,height:6,strokeWidth:2}},forecastDataPoints:{count:0,fillOpacity:.5,strokeWidth:void 0,dashArray:4},grid:{show:!0,borderColor:"#e0e0e0",strokeDashArray:0,position:"back",xaxis:{lines:{show:!1}},yaxis:{lines:{show:!0}},row:{colors:void 0,opacity:.5},column:{colors:void 0,opacity:.5},padding:{top:0,right:10,bottom:0,left:12}},labels:[],legend:{show:!0,showForSingleSeries:!1,showForNullSeries:!0,showForZeroSeries:!0,floating:!1,position:"bottom",horizontalAlign:"center",inverseOrder:!1,fontSize:"12px",fontFamily:void 0,fontWeight:400,width:void 0,height:void 0,formatter:void 0,tooltipHoverFormatter:void 0,offsetX:-20,offsetY:4,customLegendItems:[],labels:{colors:void 0,useSeriesColors:!1},markers:{width:12,height:12,strokeWidth:0,fillColors:void 0,strokeColor:"#fff",radius:12,customHTML:void 0,offsetX:0,offsetY:0,onClick:void 0},itemMargin:{horizontal:5,vertical:2},onItemClick:{toggleDataSeries:!0},onItemHover:{highlightDataSeries:!0}},markers:{discrete:[],size:0,colors:void 0,strokeColors:"#fff",strokeWidth:2,strokeOpacity:.9,strokeDashArray:0,fillOpacity:1,shape:"circle",width:8,height:8,radius:2,offsetX:0,offsetY:0,onClick:void 0,onDblClick:void 0,showNullDataPoints:!0,hover:{size:void 0,sizeOffset:3}},noData:{text:void 0,align:"center",verticalAlign:"middle",offsetX:0,offsetY:0,style:{color:void 0,fontSize:"14px",fontFamily:void 0}},responsive:[],series:void 0,states:{normal:{filter:{type:"none",value:0}},hover:{filter:{type:"lighten",value:.1}},active:{allowMultipleDataPointsSelection:!1,filter:{type:"darken",value:.5}}},title:{text:void 0,align:"left",margin:5,offsetX:0,offsetY:0,floating:!1,style:{fontSize:"14px",fontWeight:900,fontFamily:void 0,color:void 0}},subtitle:{text:void 0,align:"left",margin:5,offsetX:0,offsetY:30,floating:!1,style:{fontSize:"12px",fontWeight:400,fontFamily:void 0,color:void 0}},stroke:{show:!0,curve:"smooth",lineCap:"butt",width:2,colors:void 0,dashArray:0,fill:{type:"solid",colors:void 0,opacity:.85,gradient:{shade:"dark",type:"horizontal",shadeIntensity:.5,gradientToColors:void 0,inverseColors:!0,opacityFrom:1,opacityTo:1,stops:[0,50,100],colorStops:[]}}},tooltip:{enabled:!0,enabledOnSeries:void 0,shared:!0,followCursor:!1,intersect:!1,inverseOrder:!1,custom:void 0,fillSeriesColor:!1,theme:"light",cssClass:"",style:{fontSize:"12px",fontFamily:void 0},onDatasetHover:{highlightDataSeries:!1},x:{show:!0,format:"dd MMM",formatter:void 0},y:{formatter:void 0,title:{formatter:function(t){return t?t+": ":""}}},z:{formatter:void 0,title:"Size: "},marker:{show:!0,fillColors:void 0},items:{display:"flex"},fixed:{enabled:!1,position:"topRight",offsetX:0,offsetY:0}},xaxis:{type:"category",categories:[],convertedCatToNumeric:!1,offsetX:0,offsetY:0,overwriteCategories:void 0,labels:{show:!0,rotate:-45,rotateAlways:!1,hideOverlappingLabels:!0,trim:!1,minHeight:void 0,maxHeight:120,showDuplicates:!0,style:{colors:[],fontSize:"12px",fontWeight:400,fontFamily:void 0,cssClass:""},offsetX:0,offsetY:0,format:void 0,formatter:void 0,datetimeUTC:!0,datetimeFormatter:{year:"yyyy",month:"MMM 'yy",day:"dd MMM",hour:"HH:mm",minute:"HH:mm:ss",second:"HH:mm:ss"}},group:{groups:[],style:{colors:[],fontSize:"12px",fontWeight:400,fontFamily:void 0,cssClass:""}},axisBorder:{show:!0,color:"#e0e0e0",width:"100%",height:1,offsetX:0,offsetY:0},axisTicks:{show:!0,color:"#e0e0e0",height:6,offsetX:0,offsetY:0},tickAmount:void 0,tickPlacement:"on",min:void 0,max:void 0,range:void 0,floating:!1,decimalsInFloat:void 0,position:"bottom",title:{text:void 0,offsetX:0,offsetY:0,style:{color:void 0,fontSize:"12px",fontWeight:900,fontFamily:void 0,cssClass:""}},crosshairs:{show:!0,width:1,position:"back",opacity:.9,stroke:{color:"#b6b6b6",width:1,dashArray:3},fill:{type:"solid",color:"#B1B9C4",gradient:{colorFrom:"#D8E3F0",colorTo:"#BED1E6",stops:[0,100],opacityFrom:.4,opacityTo:.5}},dropShadow:{enabled:!1,left:0,top:0,blur:1,opacity:.4}},tooltip:{enabled:!0,offsetY:0,formatter:void 0,style:{fontSize:"12px",fontFamily:void 0}}},yaxis:this.yAxis,theme:{mode:"light",palette:"palette1",monochrome:{enabled:!1,color:"#008FFB",shadeTo:"light",shadeIntensity:.65}}}}}]),t}(),P=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.graphics=new m(this.ctx),this.w.globals.isBarHorizontal&&(this.invertAxis=!0),this.helpers=new w(this),this.xAxisAnnotations=new k(this),this.yAxisAnnotations=new A(this),this.pointsAnnotations=new S(this),this.w.globals.isBarHorizontal&&this.w.config.yaxis[0].reversed&&(this.inversedReversedAxis=!0),this.xDivision=this.w.globals.gridWidth/this.w.globals.dataPoints}return r(t,[{key:"drawAxesAnnotations",value:function(){var t=this.w;if(t.globals.axisCharts){for(var e=this.yAxisAnnotations.drawYAxisAnnotations(),i=this.xAxisAnnotations.drawXAxisAnnotations(),a=this.pointsAnnotations.drawPointAnnotations(),s=t.config.chart.animations.enabled,r=[e,i,a],o=[i.node,e.node,a.node],n=0;n<3;n++)t.globals.dom.elGraphical.add(r[n]),!s||t.globals.resized||t.globals.dataChanged||"scatter"!==t.config.chart.type&&"bubble"!==t.config.chart.type&&t.globals.dataPoints>1&&o[n].classList.add("apexcharts-element-hidden"),t.globals.delayedElements.push({el:o[n],index:0});this.helpers.annotationsBackground()}}},{key:"drawImageAnnos",value:function(){var t=this;this.w.config.annotations.images.map((function(e,i){t.addImage(e,i)}))}},{key:"drawTextAnnos",value:function(){var t=this;this.w.config.annotations.texts.map((function(e,i){t.addText(e,i)}))}},{key:"addXaxisAnnotation",value:function(t,e,i){this.xAxisAnnotations.addXaxisAnnotation(t,e,i)}},{key:"addYaxisAnnotation",value:function(t,e,i){this.yAxisAnnotations.addYaxisAnnotation(t,e,i)}},{key:"addPointAnnotation",value:function(t,e,i){this.pointsAnnotations.addPointAnnotation(t,e,i)}},{key:"addText",value:function(t,e){var i=t.x,a=t.y,s=t.text,r=t.textAnchor,o=t.foreColor,n=t.fontSize,l=t.fontFamily,h=t.fontWeight,c=t.cssClass,d=t.backgroundColor,g=t.borderWidth,u=t.strokeDashArray,p=t.borderRadius,f=t.borderColor,x=t.appendTo,b=void 0===x?".apexcharts-annotations":x,v=t.paddingLeft,m=void 0===v?4:v,y=t.paddingRight,w=void 0===y?4:y,k=t.paddingBottom,A=void 0===k?2:k,S=t.paddingTop,C=void 0===S?2:S,L=this.w,P=this.graphics.drawText({x:i,y:a,text:s,textAnchor:r||"start",fontSize:n||"12px",fontWeight:h||"regular",fontFamily:l||L.config.chart.fontFamily,foreColor:o||L.config.chart.foreColor,cssClass:c}),I=L.globals.dom.baseEl.querySelector(b);I&&I.appendChild(P.node);var T=P.bbox();if(s){var M=this.graphics.drawRect(T.x-m,T.y-C,T.width+m+w,T.height+A+C,p,d||"transparent",1,g,f,u);I.insertBefore(M.node,P.node)}}},{key:"addImage",value:function(t,e){var i=this.w,a=t.path,s=t.x,r=void 0===s?0:s,o=t.y,n=void 0===o?0:o,l=t.width,h=void 0===l?20:l,c=t.height,d=void 0===c?20:c,g=t.appendTo,u=void 0===g?".apexcharts-annotations":g,p=i.globals.dom.Paper.image(a);p.size(h,d).move(r,n);var f=i.globals.dom.baseEl.querySelector(u);return f&&f.appendChild(p.node),p}},{key:"addXaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"xaxis",contextMethod:i.addXaxisAnnotation}),i}},{key:"addYaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"yaxis",contextMethod:i.addYaxisAnnotation}),i}},{key:"addPointAnnotationExternal",value:function(t,e,i){return void 0===this.invertAxis&&(this.invertAxis=i.w.globals.isBarHorizontal),this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"point",contextMethod:i.addPointAnnotation}),i}},{key:"addAnnotationExternal",value:function(t){var e=t.params,i=t.pushToMemory,a=t.context,s=t.type,r=t.contextMethod,o=a,n=o.w,l=n.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations")),h=l.childNodes.length+1,c=new L,d=Object.assign({},"xaxis"===s?c.xAxisAnnotation:"yaxis"===s?c.yAxisAnnotation:c.pointAnnotation),g=x.extend(d,e);switch(s){case"xaxis":this.addXaxisAnnotation(g,l,h);break;case"yaxis":this.addYaxisAnnotation(g,l,h);break;case"point":this.addPointAnnotation(g,l,h)}var u=n.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations .apexcharts-").concat(s,"-annotation-label[rel='").concat(h,"']")),p=this.helpers.addBackgroundToAnno(u,g);return p&&l.insertBefore(p.node,u),i&&n.globals.memory.methodsToExec.push({context:o,id:g.id?g.id:x.randomId(),method:r,label:"addAnnotation",params:e}),a}},{key:"clearAnnotations",value:function(t){var e=t.w,i=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis-annotations, .apexcharts-xaxis-annotations, .apexcharts-point-annotations");e.globals.memory.methodsToExec.map((function(t,i){"addText"!==t.label&&"addAnnotation"!==t.label||e.globals.memory.methodsToExec.splice(i,1)})),i=x.listToArray(i),Array.prototype.forEach.call(i,(function(t){for(;t.firstChild;)t.removeChild(t.firstChild)}))}},{key:"removeAnnotation",value:function(t,e){var i=t.w,a=i.globals.dom.baseEl.querySelectorAll(".".concat(e));a&&(i.globals.memory.methodsToExec.map((function(t,a){t.id===e&&i.globals.memory.methodsToExec.splice(a,1)})),Array.prototype.forEach.call(a,(function(t){t.parentElement.removeChild(t)})))}}]),t}(),I=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.months31=[1,3,5,7,8,10,12],this.months30=[2,4,6,9,11],this.daysCntOfYear=[0,31,59,90,120,151,181,212,243,273,304,334]}return r(t,[{key:"isValidDate",value:function(t){return!isNaN(this.parseDate(t))}},{key:"getTimeStamp",value:function(t){return Date.parse(t)?this.w.config.xaxis.labels.datetimeUTC?new Date(new Date(t).toISOString().substr(0,25)).getTime():new Date(t).getTime():t}},{key:"getDate",value:function(t){return this.w.config.xaxis.labels.datetimeUTC?new Date(new Date(t).toUTCString()):new Date(t)}},{key:"parseDate",value:function(t){var e=Date.parse(t);if(!isNaN(e))return this.getTimeStamp(t);var i=Date.parse(t.replace(/-/g,"/").replace(/[a-z]+/gi," "));return i=this.getTimeStamp(i)}},{key:"parseDateWithTimezone",value:function(t){return Date.parse(t.replace(/-/g,"/").replace(/[a-z]+/gi," "))}},{key:"formatDate",value:function(t,e){var i=this.w.globals.locale,a=this.w.config.xaxis.labels.datetimeUTC,s=["\0"].concat(u(i.months)),r=["\x01"].concat(u(i.shortMonths)),o=["\x02"].concat(u(i.days)),n=["\x03"].concat(u(i.shortDays));function l(t,e){var i=t+"";for(e=e||2;i.length12?g-12:0===g?12:g;e=(e=(e=(e=e.replace(/(^|[^\\])HH+/g,"$1"+l(g))).replace(/(^|[^\\])H/g,"$1"+g)).replace(/(^|[^\\])hh+/g,"$1"+l(p))).replace(/(^|[^\\])h/g,"$1"+p);var f=a?t.getUTCMinutes():t.getMinutes();e=(e=e.replace(/(^|[^\\])mm+/g,"$1"+l(f))).replace(/(^|[^\\])m/g,"$1"+f);var x=a?t.getUTCSeconds():t.getSeconds();e=(e=e.replace(/(^|[^\\])ss+/g,"$1"+l(x))).replace(/(^|[^\\])s/g,"$1"+x);var b=a?t.getUTCMilliseconds():t.getMilliseconds();e=e.replace(/(^|[^\\])fff+/g,"$1"+l(b,3)),b=Math.round(b/10),e=e.replace(/(^|[^\\])ff/g,"$1"+l(b)),b=Math.round(b/10);var v=g<12?"AM":"PM";e=(e=(e=e.replace(/(^|[^\\])f/g,"$1"+b)).replace(/(^|[^\\])TT+/g,"$1"+v)).replace(/(^|[^\\])T/g,"$1"+v.charAt(0));var m=v.toLowerCase();e=(e=e.replace(/(^|[^\\])tt+/g,"$1"+m)).replace(/(^|[^\\])t/g,"$1"+m.charAt(0));var y=-t.getTimezoneOffset(),w=a||!y?"Z":y>0?"+":"-";if(!a){var k=(y=Math.abs(y))%60;w+=l(Math.floor(y/60))+":"+l(k)}e=e.replace(/(^|[^\\])K/g,"$1"+w);var A=(a?t.getUTCDay():t.getDay())+1;return e=(e=(e=(e=(e=e.replace(new RegExp(o[0],"g"),o[A])).replace(new RegExp(n[0],"g"),n[A])).replace(new RegExp(s[0],"g"),s[c])).replace(new RegExp(r[0],"g"),r[c])).replace(/\\(.)/g,"$1")}},{key:"getTimeUnitsfromTimestamp",value:function(t,e,i){var a=this.w;void 0!==a.config.xaxis.min&&(t=a.config.xaxis.min),void 0!==a.config.xaxis.max&&(e=a.config.xaxis.max);var s=this.getDate(t),r=this.getDate(e),o=this.formatDate(s,"yyyy MM dd HH mm ss fff").split(" "),n=this.formatDate(r,"yyyy MM dd HH mm ss fff").split(" ");return{minMillisecond:parseInt(o[6],10),maxMillisecond:parseInt(n[6],10),minSecond:parseInt(o[5],10),maxSecond:parseInt(n[5],10),minMinute:parseInt(o[4],10),maxMinute:parseInt(n[4],10),minHour:parseInt(o[3],10),maxHour:parseInt(n[3],10),minDate:parseInt(o[2],10),maxDate:parseInt(n[2],10),minMonth:parseInt(o[1],10)-1,maxMonth:parseInt(n[1],10)-1,minYear:parseInt(o[0],10),maxYear:parseInt(n[0],10)}}},{key:"isLeapYear",value:function(t){return t%4==0&&t%100!=0||t%400==0}},{key:"calculcateLastDaysOfMonth",value:function(t,e,i){return this.determineDaysOfMonths(t,e)-i}},{key:"determineDaysOfYear",value:function(t){var e=365;return this.isLeapYear(t)&&(e=366),e}},{key:"determineRemainingDaysOfYear",value:function(t,e,i){var a=this.daysCntOfYear[e]+i;return e>1&&this.isLeapYear()&&a++,a}},{key:"determineDaysOfMonths",value:function(t,e){var i=30;switch(t=x.monthMod(t),!0){case this.months30.indexOf(t)>-1:2===t&&(i=this.isLeapYear(e)?29:28);break;case this.months31.indexOf(t)>-1:default:i=31}return i}}]),t}(),T=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.tooltipKeyFormat="dd MMM"}return r(t,[{key:"xLabelFormat",value:function(t,e,i,a){var s=this.w;if("datetime"===s.config.xaxis.type&&void 0===s.config.xaxis.labels.formatter&&void 0===s.config.tooltip.x.formatter){var r=new I(this.ctx);return r.formatDate(r.getDate(e),s.config.tooltip.x.format)}return t(e,i,a)}},{key:"defaultGeneralFormatter",value:function(t){return Array.isArray(t)?t.map((function(t){return t})):t}},{key:"defaultYFormatter",value:function(t,e,i){var a=this.w;return x.isNumber(t)&&(t=0!==a.globals.yValueDecimal?t.toFixed(void 0!==e.decimalsInFloat?e.decimalsInFloat:a.globals.yValueDecimal):a.globals.maxYArr[i]-a.globals.minYArr[i]<5?t.toFixed(1):t.toFixed(0)),t}},{key:"setLabelFormatters",value:function(){var t=this,e=this.w;return e.globals.xaxisTooltipFormatter=function(e){return t.defaultGeneralFormatter(e)},e.globals.ttKeyFormatter=function(e){return t.defaultGeneralFormatter(e)},e.globals.ttZFormatter=function(t){return t},e.globals.legendFormatter=function(e){return t.defaultGeneralFormatter(e)},void 0!==e.config.xaxis.labels.formatter?e.globals.xLabelFormatter=e.config.xaxis.labels.formatter:e.globals.xLabelFormatter=function(t){if(x.isNumber(t)){if(!e.config.xaxis.convertedCatToNumeric&&"numeric"===e.config.xaxis.type){if(x.isNumber(e.config.xaxis.decimalsInFloat))return t.toFixed(e.config.xaxis.decimalsInFloat);var i=e.globals.maxX-e.globals.minX;return i>0&&i<100?t.toFixed(1):t.toFixed(0)}if(e.globals.isBarHorizontal)if(e.globals.maxY-e.globals.minYArr<4)return t.toFixed(1);return t.toFixed(0)}return t},"function"==typeof e.config.tooltip.x.formatter?e.globals.ttKeyFormatter=e.config.tooltip.x.formatter:e.globals.ttKeyFormatter=e.globals.xLabelFormatter,"function"==typeof e.config.xaxis.tooltip.formatter&&(e.globals.xaxisTooltipFormatter=e.config.xaxis.tooltip.formatter),(Array.isArray(e.config.tooltip.y)||void 0!==e.config.tooltip.y.formatter)&&(e.globals.ttVal=e.config.tooltip.y),void 0!==e.config.tooltip.z.formatter&&(e.globals.ttZFormatter=e.config.tooltip.z.formatter),void 0!==e.config.legend.formatter&&(e.globals.legendFormatter=e.config.legend.formatter),e.config.yaxis.forEach((function(i,a){void 0!==i.labels.formatter?e.globals.yLabelFormatters[a]=i.labels.formatter:e.globals.yLabelFormatters[a]=function(s){return e.globals.xyCharts?Array.isArray(s)?s.map((function(e){return t.defaultYFormatter(e,i,a)})):t.defaultYFormatter(s,i,a):s}})),e.globals}},{key:"heatmapLabelFormatters",value:function(){var t=this.w;if("heatmap"===t.config.chart.type){t.globals.yAxisScale[0].result=t.globals.seriesNames.slice();var e=t.globals.seriesNames.reduce((function(t,e){return t.length>e.length?t:e}),0);t.globals.yAxisScale[0].niceMax=e,t.globals.yAxisScale[0].niceMin=e}}}]),t}(),M=function(t){var e,i=t.isTimeline,a=t.ctx,s=t.seriesIndex,r=t.dataPointIndex,o=t.y1,n=t.y2,l=t.w,h=l.globals.seriesRangeStart[s][r],c=l.globals.seriesRangeEnd[s][r],d=l.globals.labels[r],g=l.config.series[s].name?l.config.series[s].name:"",u=l.globals.ttKeyFormatter,p=l.config.tooltip.y.title.formatter,f={w:l,seriesIndex:s,dataPointIndex:r,start:h,end:c};("function"==typeof p&&(g=p(g,f)),null!==(e=l.config.series[s].data[r])&&void 0!==e&&e.x&&(d=l.config.series[s].data[r].x),i)||"datetime"===l.config.xaxis.type&&(d=new T(a).xLabelFormat(l.globals.ttKeyFormatter,d,d,{i:void 0,dateFormatter:new I(a).formatDate,w:l}));"function"==typeof u&&(d=u(d,f)),Number.isFinite(o)&&Number.isFinite(n)&&(h=o,c=n);var x="",b="",v=l.globals.colors[s];if(void 0===l.config.tooltip.x.formatter)if("datetime"===l.config.xaxis.type){var m=new I(a);x=m.formatDate(m.getDate(h),l.config.tooltip.x.format),b=m.formatDate(m.getDate(c),l.config.tooltip.x.format)}else x=h,b=c;else x=l.config.tooltip.x.formatter(h),b=l.config.tooltip.x.formatter(c);return{start:h,end:c,startVal:x,endVal:b,ylabel:d,color:v,seriesName:g}},X=function(t){var e=t.color,i=t.seriesName,a=t.ylabel,s=t.start,r=t.end,o=t.seriesIndex,n=t.dataPointIndex,l=t.ctx.tooltip.tooltipLabels.getFormatters(o);s=l.yLbFormatter(s),r=l.yLbFormatter(r);var h=l.yLbFormatter(t.w.globals.series[o][n]),c='\n '.concat(s,'\n - \n ').concat(r,"\n ");return'
'+(i||"")+'
'+a+": "+(t.w.globals.comboCharts?"rangeArea"===t.w.config.series[o].type||"rangeBar"===t.w.config.series[o].type?c:"".concat(h,""):c)+"
"},z=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"line",value:function(){return{chart:{animations:{easing:"swing"}},dataLabels:{enabled:!1},stroke:{width:5,curve:"straight"},markers:{size:0,hover:{sizeOffset:6}},xaxis:{crosshairs:{width:1}}}}},{key:"sparkline",value:function(t){this.opts.yaxis[0].show=!1,this.opts.yaxis[0].title.text="",this.opts.yaxis[0].axisBorder.show=!1,this.opts.yaxis[0].axisTicks.show=!1,this.opts.yaxis[0].floating=!0;return x.extend(t,{grid:{show:!1,padding:{left:0,right:0,top:0,bottom:0}},legend:{show:!1},xaxis:{labels:{show:!1},tooltip:{enabled:!1},axisBorder:{show:!1},axisTicks:{show:!1}},chart:{toolbar:{show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1}})}},{key:"bar",value:function(){return{chart:{stacked:!1,animations:{easing:"swing"}},plotOptions:{bar:{dataLabels:{position:"center"}}},dataLabels:{style:{colors:["#fff"]},background:{enabled:!1}},stroke:{width:0,lineCap:"round"},fill:{opacity:.85},legend:{markers:{shape:"square",radius:2,size:8}},tooltip:{shared:!1,intersect:!0},xaxis:{tooltip:{enabled:!1},tickPlacement:"between",crosshairs:{width:"barWidth",position:"back",fill:{type:"gradient"},dropShadow:{enabled:!1},stroke:{width:0}}}}}},{key:"candlestick",value:function(){var t=this;return{stroke:{width:1,colors:["#333"]},fill:{opacity:1},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,s=e.w;return t._getBoxTooltip(s,i,a,["Open","High","","Low","Close"],"candlestick")}},states:{active:{filter:{type:"none"}}},xaxis:{crosshairs:{width:1}}}}},{key:"boxPlot",value:function(){var t=this;return{chart:{animations:{dynamicAnimation:{enabled:!1}}},stroke:{width:1,colors:["#24292e"]},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,s=e.w;return t._getBoxTooltip(s,i,a,["Minimum","Q1","Median","Q3","Maximum"],"boxPlot")}},markers:{size:5,strokeWidth:1,strokeColors:"#111"},xaxis:{crosshairs:{width:1}}}}},{key:"rangeBar",value:function(){return{chart:{animations:{animateGradually:!1}},stroke:{width:0,lineCap:"square"},plotOptions:{bar:{borderRadius:0,dataLabels:{position:"center"}}},dataLabels:{enabled:!1,formatter:function(t,e){e.ctx;var i=e.seriesIndex,a=e.dataPointIndex,s=e.w,r=function(){var t=s.globals.seriesRangeStart[i][a];return s.globals.seriesRangeEnd[i][a]-t};return s.globals.comboCharts?"rangeBar"===s.config.series[i].type||"rangeArea"===s.config.series[i].type?r():t:r()},background:{enabled:!1},style:{colors:["#fff"]}},markers:{size:10},tooltip:{shared:!1,followCursor:!0,custom:function(t){return t.w.config.plotOptions&&t.w.config.plotOptions.bar&&t.w.config.plotOptions.bar.horizontal?function(t){var i=M(e(e({},t),{},{isTimeline:!0})),a=i.color,s=i.seriesName,r=i.ylabel,o=i.startVal,n=i.endVal;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t):function(t){var i=M(t),a=i.color,s=i.seriesName,r=i.ylabel,o=i.start,n=i.end;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t)}},xaxis:{tickPlacement:"between",tooltip:{enabled:!1},crosshairs:{stroke:{width:0}}}}}},{key:"dumbbell",value:function(t){var e,i;return null!==(e=t.plotOptions.bar)&&void 0!==e&&e.barHeight||(t.plotOptions.bar.barHeight=2),null!==(i=t.plotOptions.bar)&&void 0!==i&&i.columnWidth||(t.plotOptions.bar.columnWidth=2),t}},{key:"area",value:function(){return{stroke:{width:4,fill:{type:"solid",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}}},fill:{type:"gradient",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}},markers:{size:0,hover:{sizeOffset:6}},tooltip:{followCursor:!1}}}},{key:"rangeArea",value:function(){return{stroke:{curve:"straight",width:0},fill:{type:"solid",opacity:.6},markers:{size:0},states:{hover:{filter:{type:"none"}},active:{filter:{type:"none"}}},tooltip:{intersect:!1,shared:!0,followCursor:!0,custom:function(t){return function(t){var i=M(t),a=i.color,s=i.seriesName,r=i.ylabel,o=i.start,n=i.end;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t)}}}}},{key:"brush",value:function(t){return x.extend(t,{chart:{toolbar:{autoSelected:"selection",show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1},stroke:{width:1},tooltip:{enabled:!1},xaxis:{tooltip:{enabled:!1}}})}},{key:"stacked100",value:function(t){t.dataLabels=t.dataLabels||{},t.dataLabels.formatter=t.dataLabels.formatter||void 0;var e=t.dataLabels.formatter;return t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})),"bar"===t.chart.type&&(t.dataLabels.formatter=e||function(t){return"number"==typeof t&&t?t.toFixed(0)+"%":t}),t}},{key:"stackedBars",value:function(){var t=this.bar();return e(e({},t),{},{plotOptions:e(e({},t.plotOptions),{},{bar:e(e({},t.plotOptions.bar),{},{borderRadiusApplication:"end",borderRadiusWhenStacked:"last"})})})}},{key:"convertCatToNumeric",value:function(t){return t.xaxis.convertedCatToNumeric=!0,t}},{key:"convertCatToNumericXaxis",value:function(t,e,i){t.xaxis.type="numeric",t.xaxis.labels=t.xaxis.labels||{},t.xaxis.labels.formatter=t.xaxis.labels.formatter||function(t){return x.isNumber(t)?Math.floor(t):t};var a=t.xaxis.labels.formatter,s=t.xaxis.categories&&t.xaxis.categories.length?t.xaxis.categories:t.labels;return i&&i.length&&(s=i.map((function(t){return Array.isArray(t)?t:String(t)}))),s&&s.length&&(t.xaxis.labels.formatter=function(t){return x.isNumber(t)?a(s[Math.floor(t)-1]):a(t)}),t.xaxis.categories=[],t.labels=[],t.xaxis.tickAmount=t.xaxis.tickAmount||"dataPoints",t}},{key:"bubble",value:function(){return{dataLabels:{style:{colors:["#fff"]}},tooltip:{shared:!1,intersect:!0},xaxis:{crosshairs:{width:0}},fill:{type:"solid",gradient:{shade:"light",inverse:!0,shadeIntensity:.55,opacityFrom:.4,opacityTo:.8}}}}},{key:"scatter",value:function(){return{dataLabels:{enabled:!1},tooltip:{shared:!1,intersect:!0},markers:{size:6,strokeWidth:1,hover:{sizeOffset:2}}}}},{key:"heatmap",value:function(){return{chart:{stacked:!1},fill:{opacity:1},dataLabels:{style:{colors:["#fff"]}},stroke:{colors:["#fff"]},tooltip:{followCursor:!0,marker:{show:!1},x:{show:!1}},legend:{position:"top",markers:{shape:"square",size:10,offsetY:2}},grid:{padding:{right:20}}}}},{key:"treemap",value:function(){return{chart:{zoom:{enabled:!1}},dataLabels:{style:{fontSize:14,fontWeight:600,colors:["#fff"]}},stroke:{show:!0,width:2,colors:["#fff"]},legend:{show:!1},fill:{gradient:{stops:[0,100]}},tooltip:{followCursor:!0,x:{show:!1}},grid:{padding:{left:0,right:0}},xaxis:{crosshairs:{show:!1},tooltip:{enabled:!1}}}}},{key:"pie",value:function(){return{chart:{toolbar:{show:!1}},plotOptions:{pie:{donut:{labels:{show:!1}}}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",stops:[0,100]}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"donut",value:function(){return{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",shadeIntensity:.35,stops:[80,100],opacityFrom:1,opacityTo:1}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"polarArea",value:function(){return this.opts.yaxis[0].tickAmount=this.opts.yaxis[0].tickAmount?this.opts.yaxis[0].tickAmount:6,{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},enabled:!1},stroke:{show:!0,width:2},fill:{opacity:.7},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"radar",value:function(){return this.opts.yaxis[0].labels.offsetY=this.opts.yaxis[0].labels.offsetY?this.opts.yaxis[0].labels.offsetY:6,{dataLabels:{enabled:!1,style:{fontSize:"11px"}},stroke:{width:2},markers:{size:3,strokeWidth:1,strokeOpacity:1},fill:{opacity:.2},tooltip:{shared:!1,intersect:!0,followCursor:!0},grid:{show:!1},xaxis:{labels:{formatter:function(t){return t},style:{colors:["#a8a8a8"],fontSize:"11px"}},tooltip:{enabled:!1},crosshairs:{show:!1}}}}},{key:"radialBar",value:function(){return{chart:{animations:{dynamicAnimation:{enabled:!0,speed:800}},toolbar:{show:!1}},fill:{gradient:{shade:"dark",shadeIntensity:.4,inverseColors:!1,type:"diagonal2",opacityFrom:1,opacityTo:1,stops:[70,98,100]}},legend:{show:!1,position:"right"},tooltip:{enabled:!1,fillSeriesColor:!0}}}},{key:"_getBoxTooltip",value:function(t,e,i,a,s){var r=t.globals.seriesCandleO[e][i],o=t.globals.seriesCandleH[e][i],n=t.globals.seriesCandleM[e][i],l=t.globals.seriesCandleL[e][i],h=t.globals.seriesCandleC[e][i];return t.config.series[e].type&&t.config.series[e].type!==s?'
\n '.concat(t.config.series[e].name?t.config.series[e].name:"series-"+(e+1),": ").concat(t.globals.series[e][i],"\n
"):'
')+"
".concat(a[0],': ')+r+"
"+"
".concat(a[1],': ')+o+"
"+(n?"
".concat(a[2],': ')+n+"
":"")+"
".concat(a[3],': ')+l+"
"+"
".concat(a[4],': ')+h+"
"}}]),t}(),E=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"init",value:function(t){var e=t.responsiveOverride,a=this.opts,s=new L,r=new z(a);this.chartType=a.chart.type,a=this.extendYAxis(a),a=this.extendAnnotations(a);var o=s.init(),n={};if(a&&"object"===i(a)){var l,h,c,d,g,u,p={};p=-1!==["line","area","bar","candlestick","boxPlot","rangeBar","rangeArea","bubble","scatter","heatmap","treemap","pie","polarArea","donut","radar","radialBar"].indexOf(a.chart.type)?r[a.chart.type]():r.line(),a.chart.stacked&&"bar"===a.chart.type&&(p=r.stackedBars()),null!==(l=a.chart.brush)&&void 0!==l&&l.enabled&&(p=r.brush(p)),a.chart.stacked&&"100%"===a.chart.stackType&&(a=r.stacked100(a)),null!==(h=a.plotOptions)&&void 0!==h&&null!==(c=h.bar)&&void 0!==c&&c.isDumbbell&&(a=r.dumbbell(a)),this.checkForDarkTheme(window.Apex),this.checkForDarkTheme(a),a.xaxis=a.xaxis||window.Apex.xaxis||{},e||(a.xaxis.convertedCatToNumeric=!1),(null!==(d=(a=this.checkForCatToNumericXAxis(this.chartType,p,a)).chart.sparkline)&&void 0!==d&&d.enabled||null!==(g=window.Apex.chart)&&void 0!==g&&null!==(u=g.sparkline)&&void 0!==u&&u.enabled)&&(p=r.sparkline(p)),n=x.extend(o,p)}var f=x.extend(n,window.Apex);return o=x.extend(f,a),o=this.handleUserInputErrors(o)}},{key:"checkForCatToNumericXAxis",value:function(t,e,i){var a,s,r=new z(i),o=("bar"===t||"boxPlot"===t)&&(null===(a=i.plotOptions)||void 0===a||null===(s=a.bar)||void 0===s?void 0:s.horizontal),n="pie"===t||"polarArea"===t||"donut"===t||"radar"===t||"radialBar"===t||"heatmap"===t,l="datetime"!==i.xaxis.type&&"numeric"!==i.xaxis.type,h=i.xaxis.tickPlacement?i.xaxis.tickPlacement:e.xaxis&&e.xaxis.tickPlacement;return o||n||!l||"between"===h||(i=r.convertCatToNumeric(i)),i}},{key:"extendYAxis",value:function(t,e){var i=new L;(void 0===t.yaxis||!t.yaxis||Array.isArray(t.yaxis)&&0===t.yaxis.length)&&(t.yaxis={}),t.yaxis.constructor!==Array&&window.Apex.yaxis&&window.Apex.yaxis.constructor!==Array&&(t.yaxis=x.extend(t.yaxis,window.Apex.yaxis)),t.yaxis.constructor!==Array?t.yaxis=[x.extend(i.yAxis,t.yaxis)]:t.yaxis=x.extendArray(t.yaxis,i.yAxis);var a=!1;t.yaxis.forEach((function(t){t.logarithmic&&(a=!0)}));var s=t.series;return e&&!s&&(s=e.config.series),a&&s.length!==t.yaxis.length&&s.length&&(t.yaxis=s.map((function(e,a){if(e.name||(s[a].name="series-".concat(a+1)),t.yaxis[a])return t.yaxis[a].seriesName=s[a].name,t.yaxis[a];var r=x.extend(i.yAxis,t.yaxis[0]);return r.show=!1,r}))),a&&s.length>1&&s.length!==t.yaxis.length&&console.warn("A multi-series logarithmic chart should have equal number of series and y-axes. Please make sure to equalize both."),t}},{key:"extendAnnotations",value:function(t){return void 0===t.annotations&&(t.annotations={},t.annotations.yaxis=[],t.annotations.xaxis=[],t.annotations.points=[]),t=this.extendYAxisAnnotations(t),t=this.extendXAxisAnnotations(t),t=this.extendPointAnnotations(t)}},{key:"extendYAxisAnnotations",value:function(t){var e=new L;return t.annotations.yaxis=x.extendArray(void 0!==t.annotations.yaxis?t.annotations.yaxis:[],e.yAxisAnnotation),t}},{key:"extendXAxisAnnotations",value:function(t){var e=new L;return t.annotations.xaxis=x.extendArray(void 0!==t.annotations.xaxis?t.annotations.xaxis:[],e.xAxisAnnotation),t}},{key:"extendPointAnnotations",value:function(t){var e=new L;return t.annotations.points=x.extendArray(void 0!==t.annotations.points?t.annotations.points:[],e.pointAnnotation),t}},{key:"checkForDarkTheme",value:function(t){t.theme&&"dark"===t.theme.mode&&(t.tooltip||(t.tooltip={}),"light"!==t.tooltip.theme&&(t.tooltip.theme="dark"),t.chart.foreColor||(t.chart.foreColor="#f6f7f8"),t.chart.background||(t.chart.background="#424242"),t.theme.palette||(t.theme.palette="palette4"))}},{key:"handleUserInputErrors",value:function(t){var e=t;if(e.tooltip.shared&&e.tooltip.intersect)throw new Error("tooltip.shared cannot be enabled when tooltip.intersect is true. Turn off any other option by setting it to false.");if("bar"===e.chart.type&&e.plotOptions.bar.horizontal){if(e.yaxis.length>1)throw new Error("Multiple Y Axis for bars are not supported. Switch to column chart by setting plotOptions.bar.horizontal=false");e.yaxis[0].reversed&&(e.yaxis[0].opposite=!0),e.xaxis.tooltip.enabled=!1,e.yaxis[0].tooltip.enabled=!1,e.chart.zoom.enabled=!1}return"bar"!==e.chart.type&&"rangeBar"!==e.chart.type||e.tooltip.shared&&"barWidth"===e.xaxis.crosshairs.width&&e.series.length>1&&(e.xaxis.crosshairs.width="tickWidth"),"candlestick"!==e.chart.type&&"boxPlot"!==e.chart.type||e.yaxis[0].reversed&&(console.warn("Reversed y-axis in ".concat(e.chart.type," chart is not supported.")),e.yaxis[0].reversed=!1),e}}]),t}(),Y=function(){function t(){a(this,t)}return r(t,[{key:"initGlobalVars",value:function(t){t.series=[],t.seriesCandleO=[],t.seriesCandleH=[],t.seriesCandleM=[],t.seriesCandleL=[],t.seriesCandleC=[],t.seriesRangeStart=[],t.seriesRangeEnd=[],t.seriesRange=[],t.seriesPercent=[],t.seriesGoals=[],t.seriesX=[],t.seriesZ=[],t.seriesNames=[],t.seriesTotals=[],t.seriesLog=[],t.seriesColors=[],t.stackedSeriesTotals=[],t.seriesXvalues=[],t.seriesYvalues=[],t.labels=[],t.hasXaxisGroups=!1,t.groups=[],t.hasSeriesGroups=!1,t.seriesGroups=[],t.categoryLabels=[],t.timescaleLabels=[],t.noLabelsProvided=!1,t.resizeTimer=null,t.selectionResizeTimer=null,t.delayedElements=[],t.pointsArray=[],t.dataLabelsRects=[],t.isXNumeric=!1,t.skipLastTimelinelabel=!1,t.skipFirstTimelinelabel=!1,t.isDataXYZ=!1,t.isMultiLineX=!1,t.isMultipleYAxis=!1,t.maxY=-Number.MAX_VALUE,t.minY=Number.MIN_VALUE,t.minYArr=[],t.maxYArr=[],t.maxX=-Number.MAX_VALUE,t.minX=Number.MAX_VALUE,t.initialMaxX=-Number.MAX_VALUE,t.initialMinX=Number.MAX_VALUE,t.maxDate=0,t.minDate=Number.MAX_VALUE,t.minZ=Number.MAX_VALUE,t.maxZ=-Number.MAX_VALUE,t.minXDiff=Number.MAX_VALUE,t.yAxisScale=[],t.xAxisScale=null,t.xAxisTicksPositions=[],t.yLabelsCoords=[],t.yTitleCoords=[],t.barPadForNumericAxis=0,t.padHorizontal=0,t.xRange=0,t.yRange=[],t.zRange=0,t.dataPoints=0,t.xTickAmount=0}},{key:"globalVars",value:function(t){return{chartID:null,cuid:null,events:{beforeMount:[],mounted:[],updated:[],clicked:[],selection:[],dataPointSelection:[],zoomed:[],scrolled:[]},colors:[],clientX:null,clientY:null,fill:{colors:[]},stroke:{colors:[]},dataLabels:{style:{colors:[]}},radarPolygons:{fill:{colors:[]}},markers:{colors:[],size:t.markers.size,largestSize:0},animationEnded:!1,isTouchDevice:"ontouchstart"in window||navigator.msMaxTouchPoints,isDirty:!1,isExecCalled:!1,initialConfig:null,initialSeries:[],lastXAxis:[],lastYAxis:[],columnSeries:null,labels:[],timescaleLabels:[],noLabelsProvided:!1,allSeriesCollapsed:!1,collapsedSeries:[],collapsedSeriesIndices:[],ancillaryCollapsedSeries:[],ancillaryCollapsedSeriesIndices:[],risingSeries:[],dataFormatXNumeric:!1,capturedSeriesIndex:-1,capturedDataPointIndex:-1,selectedDataPoints:[],goldenPadding:35,invalidLogScale:!1,ignoreYAxisIndexes:[],yAxisSameScaleIndices:[],maxValsInArrayIndex:0,radialSize:0,selection:void 0,zoomEnabled:"zoom"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.zoom&&t.chart.zoom.enabled,panEnabled:"pan"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.pan,selectionEnabled:"selection"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.selection,yaxis:null,mousedown:!1,lastClientPosition:{},visibleXRange:void 0,yValueDecimal:0,total:0,SVGNS:"http://www.w3.org/2000/svg",svgWidth:0,svgHeight:0,noData:!1,locale:{},dom:{},memory:{methodsToExec:[]},shouldAnimate:!0,skipLastTimelinelabel:!1,skipFirstTimelinelabel:!1,delayedElements:[],axisCharts:!0,isDataXYZ:!1,resized:!1,resizeTimer:null,comboCharts:!1,dataChanged:!1,previousPaths:[],allSeriesHasEqualX:!0,pointsArray:[],dataLabelsRects:[],lastDrawnDataLabelsIndexes:[],hasNullValues:!1,easing:null,zoomed:!1,gridWidth:0,gridHeight:0,rotateXLabels:!1,defaultLabels:!1,xLabelFormatter:void 0,yLabelFormatters:[],xaxisTooltipFormatter:void 0,ttKeyFormatter:void 0,ttVal:void 0,ttZFormatter:void 0,LINE_HEIGHT_RATIO:1.618,xAxisLabelsHeight:0,xAxisGroupLabelsHeight:0,xAxisLabelsWidth:0,yAxisLabelsWidth:0,scaleX:1,scaleY:1,translateX:0,translateY:0,translateYAxisX:[],yAxisWidths:[],translateXAxisY:0,translateXAxisX:0,tooltip:null}}},{key:"init",value:function(t){var e=this.globalVars(t);return this.initGlobalVars(e),e.initialConfig=x.extend({},t),e.initialSeries=x.clone(t.series),e.lastXAxis=x.clone(e.initialConfig.xaxis),e.lastYAxis=x.clone(e.initialConfig.yaxis),e}}]),t}(),F=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"init",value:function(){var t=new E(this.opts).init({responsiveOverride:!1});return{config:t,globals:(new Y).init(t)}}}]),t}(),R=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.opts=null,this.seriesIndex=0}return r(t,[{key:"clippedImgArea",value:function(t){var e=this.w,i=e.config,a=parseInt(e.globals.gridWidth,10),s=parseInt(e.globals.gridHeight,10),r=a>s?a:s,o=t.image,n=0,l=0;void 0===t.width&&void 0===t.height?void 0!==i.fill.image.width&&void 0!==i.fill.image.height?(n=i.fill.image.width+1,l=i.fill.image.height):(n=r+1,l=r):(n=t.width,l=t.height);var h=document.createElementNS(e.globals.SVGNS,"pattern");m.setAttrs(h,{id:t.patternID,patternUnits:t.patternUnits?t.patternUnits:"userSpaceOnUse",width:n+"px",height:l+"px"});var c=document.createElementNS(e.globals.SVGNS,"image");h.appendChild(c),c.setAttributeNS(window.SVG.xlink,"href",o),m.setAttrs(c,{x:0,y:0,preserveAspectRatio:"none",width:n+"px",height:l+"px"}),c.style.opacity=t.opacity,e.globals.dom.elDefs.node.appendChild(h)}},{key:"getSeriesIndex",value:function(t){var e=this.w;return("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||"heatmap"===e.config.chart.type||"treemap"===e.config.chart.type?this.seriesIndex=t.seriesNumber:this.seriesIndex=t.seriesNumber%e.globals.series.length,this.seriesIndex}},{key:"fillPath",value:function(t){var e=this.w;this.opts=t;var i,a,s,r=this.w.config;this.seriesIndex=this.getSeriesIndex(t);var o=this.getFillColors()[this.seriesIndex];void 0!==e.globals.seriesColors[this.seriesIndex]&&(o=e.globals.seriesColors[this.seriesIndex]),"function"==typeof o&&(o=o({seriesIndex:this.seriesIndex,dataPointIndex:t.dataPointIndex,value:t.value,w:e}));var n=t.fillType?t.fillType:this.getFillType(this.seriesIndex),l=Array.isArray(r.fill.opacity)?r.fill.opacity[this.seriesIndex]:r.fill.opacity;t.color&&(o=t.color);var h=o;if(-1===o.indexOf("rgb")?o.length<9&&(h=x.hexToRgba(o,l)):o.indexOf("rgba")>-1&&(l=x.getOpacityFromRGBA(o)),t.opacity&&(l=t.opacity),"pattern"===n&&(a=this.handlePatternFill({fillConfig:t.fillConfig,patternFill:a,fillColor:o,fillOpacity:l,defaultColor:h})),"gradient"===n&&(s=this.handleGradientFill({fillConfig:t.fillConfig,fillColor:o,fillOpacity:l,i:this.seriesIndex})),"image"===n){var c=r.fill.image.src,d=t.patternID?t.patternID:"";this.clippedImgArea({opacity:l,image:Array.isArray(c)?t.seriesNumber-1&&(u=x.getOpacityFromRGBA(g));var p=void 0===o.gradient.opacityTo?a:Array.isArray(o.gradient.opacityTo)?o.gradient.opacityTo[r]:o.gradient.opacityTo;if(void 0===o.gradient.gradientToColors||0===o.gradient.gradientToColors.length)n="dark"===o.gradient.shade?c.shadeColor(-1*parseFloat(o.gradient.shadeIntensity),i.indexOf("rgb")>-1?x.rgb2hex(i):i):c.shadeColor(parseFloat(o.gradient.shadeIntensity),i.indexOf("rgb")>-1?x.rgb2hex(i):i);else if(o.gradient.gradientToColors[l.seriesNumber]){var f=o.gradient.gradientToColors[l.seriesNumber];n=f,f.indexOf("rgba")>-1&&(p=x.getOpacityFromRGBA(f))}else n=i;if(o.gradient.gradientFrom&&(g=o.gradient.gradientFrom),o.gradient.gradientTo&&(n=o.gradient.gradientTo),o.gradient.inverseColors){var b=g;g=n,n=b}return g.indexOf("rgb")>-1&&(g=x.rgb2hex(g)),n.indexOf("rgb")>-1&&(n=x.rgb2hex(n)),h.drawGradient(d,g,n,u,p,l.size,o.gradient.stops,o.gradient.colorStops,r)}}]),t}(),D=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"setGlobalMarkerSize",value:function(){var t=this.w;if(t.globals.markers.size=Array.isArray(t.config.markers.size)?t.config.markers.size:[t.config.markers.size],t.globals.markers.size.length>0){if(t.globals.markers.size.length4&&void 0!==arguments[4]&&arguments[4],o=this.w,n=e,l=t,h=null,c=new m(this.ctx),d=o.config.markers.discrete&&o.config.markers.discrete.length;if((o.globals.markers.size[e]>0||r||d)&&(h=c.group({class:r||d?"":"apexcharts-series-markers"})).attr("clip-path","url(#gridRectMarkerMask".concat(o.globals.cuid,")")),Array.isArray(l.x))for(var g=0;g0:o.config.markers.size>0)||r||d){x.isNumber(l.y[g])?p+=" w".concat(x.randomId()):p="apexcharts-nullpoint";var f=this.getMarkerConfig({cssClass:p,seriesIndex:e,dataPointIndex:u});o.config.series[n].data[u]&&(o.config.series[n].data[u].fillColor&&(f.pointFillColor=o.config.series[n].data[u].fillColor),o.config.series[n].data[u].strokeColor&&(f.pointStrokeColor=o.config.series[n].data[u].strokeColor)),a&&(f.pSize=a),(l.x[g]<0||l.x[g]>o.globals.gridWidth||l.y[g]<0||l.y[g]>o.globals.gridHeight)&&(f.pSize=0),(s=c.drawMarker(l.x[g],l.y[g],f)).attr("rel",u),s.attr("j",u),s.attr("index",e),s.node.setAttribute("default-marker-size",f.pSize),new v(this.ctx).setSelectionFilter(s,e,u),this.addEvents(s),h&&h.add(s)}else void 0===o.globals.pointsArray[e]&&(o.globals.pointsArray[e]=[]),o.globals.pointsArray[e].push([l.x[g],l.y[g]])}return h}},{key:"getMarkerConfig",value:function(t){var e=t.cssClass,i=t.seriesIndex,a=t.dataPointIndex,s=void 0===a?null:a,r=t.finishRadius,o=void 0===r?null:r,n=this.w,l=this.getMarkerStyle(i),h=n.globals.markers.size[i],c=n.config.markers;return null!==s&&c.discrete.length&&c.discrete.map((function(t){t.seriesIndex===i&&t.dataPointIndex===s&&(l.pointStrokeColor=t.strokeColor,l.pointFillColor=t.fillColor,h=t.size,l.pointShape=t.shape)})),{pSize:null===o?h:o,pRadius:c.radius,width:Array.isArray(c.width)?c.width[i]:c.width,height:Array.isArray(c.height)?c.height[i]:c.height,pointStrokeWidth:Array.isArray(c.strokeWidth)?c.strokeWidth[i]:c.strokeWidth,pointStrokeColor:l.pointStrokeColor,pointFillColor:l.pointFillColor,shape:l.pointShape||(Array.isArray(c.shape)?c.shape[i]:c.shape),class:e,pointStrokeOpacity:Array.isArray(c.strokeOpacity)?c.strokeOpacity[i]:c.strokeOpacity,pointStrokeDashArray:Array.isArray(c.strokeDashArray)?c.strokeDashArray[i]:c.strokeDashArray,pointFillOpacity:Array.isArray(c.fillOpacity)?c.fillOpacity[i]:c.fillOpacity,seriesIndex:i}}},{key:"addEvents",value:function(t){var e=this.w,i=new m(this.ctx);t.node.addEventListener("mouseenter",i.pathMouseEnter.bind(this.ctx,t)),t.node.addEventListener("mouseleave",i.pathMouseLeave.bind(this.ctx,t)),t.node.addEventListener("mousedown",i.pathMouseDown.bind(this.ctx,t)),t.node.addEventListener("click",e.config.markers.onClick),t.node.addEventListener("dblclick",e.config.markers.onDblClick),t.node.addEventListener("touchstart",i.pathMouseDown.bind(this.ctx,t),{passive:!0})}},{key:"getMarkerStyle",value:function(t){var e=this.w,i=e.globals.markers.colors,a=e.config.markers.strokeColor||e.config.markers.strokeColors;return{pointStrokeColor:Array.isArray(a)?a[t]:a,pointFillColor:Array.isArray(i)?i[t]:i}}}]),t}(),H=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.initialAnim=this.w.config.chart.animations.enabled,this.dynamicAnim=this.initialAnim&&this.w.config.chart.animations.dynamicAnimation.enabled}return r(t,[{key:"draw",value:function(t,e,i){var a=this.w,s=new m(this.ctx),r=i.realIndex,o=i.pointsPos,n=i.zRatio,l=i.elParent,h=s.group({class:"apexcharts-series-markers apexcharts-series-".concat(a.config.chart.type)});if(h.attr("clip-path","url(#gridRectMarkerMask".concat(a.globals.cuid,")")),Array.isArray(o.x))for(var c=0;cf.maxBubbleRadius&&(p=f.maxBubbleRadius)}a.config.chart.animations.enabled||(u=p);var x=o.x[c],b=o.y[c];if(u=u||0,null!==b&&void 0!==a.globals.series[r][d]||(g=!1),g){var v=this.drawPoint(x,b,u,p,r,d,e);h.add(v)}l.add(h)}}},{key:"drawPoint",value:function(t,e,i,a,s,r,o){var n=this.w,l=s,h=new b(this.ctx),c=new v(this.ctx),d=new R(this.ctx),g=new D(this.ctx),u=new m(this.ctx),p=g.getMarkerConfig({cssClass:"apexcharts-marker",seriesIndex:l,dataPointIndex:r,finishRadius:"bubble"===n.config.chart.type||n.globals.comboCharts&&n.config.series[s]&&"bubble"===n.config.series[s].type?a:null});a=p.pSize;var f,x=d.fillPath({seriesNumber:s,dataPointIndex:r,color:p.pointFillColor,patternUnits:"objectBoundingBox",value:n.globals.series[s][o]});if("circle"===p.shape?f=u.drawCircle(i):"square"!==p.shape&&"rect"!==p.shape||(f=u.drawRect(0,0,p.width-p.pointStrokeWidth/2,p.height-p.pointStrokeWidth/2,p.pRadius)),n.config.series[l].data[r]&&n.config.series[l].data[r].fillColor&&(x=n.config.series[l].data[r].fillColor),f.attr({x:t-p.width/2-p.pointStrokeWidth/2,y:e-p.height/2-p.pointStrokeWidth/2,cx:t,cy:e,fill:x,"fill-opacity":p.pointFillOpacity,stroke:p.pointStrokeColor,r:a,"stroke-width":p.pointStrokeWidth,"stroke-dasharray":p.pointStrokeDashArray,"stroke-opacity":p.pointStrokeOpacity}),n.config.chart.dropShadow.enabled){var y=n.config.chart.dropShadow;c.dropShadow(f,y,s)}if(!this.initialAnim||n.globals.dataChanged||n.globals.resized)n.globals.animationEnded=!0;else{var w=n.config.chart.animations.speed;h.animateMarker(f,0,"circle"===p.shape?a:{width:p.width,height:p.height},w,n.globals.easing,(function(){window.setTimeout((function(){h.animationCompleted(f)}),100)}))}if(n.globals.dataChanged&&"circle"===p.shape)if(this.dynamicAnim){var k,A,S,C,L=n.config.chart.animations.dynamicAnimation.speed;null!=(C=n.globals.previousPaths[s]&&n.globals.previousPaths[s][o])&&(k=C.x,A=C.y,S=void 0!==C.r?C.r:a);for(var P=0;Pn.globals.gridHeight+d&&(e=n.globals.gridHeight+d/2),void 0===n.globals.dataLabelsRects[a]&&(n.globals.dataLabelsRects[a]=[]),n.globals.dataLabelsRects[a].push({x:t,y:e,width:c,height:d});var g=n.globals.dataLabelsRects[a].length-2,u=void 0!==n.globals.lastDrawnDataLabelsIndexes[a]?n.globals.lastDrawnDataLabelsIndexes[a][n.globals.lastDrawnDataLabelsIndexes[a].length-1]:0;if(void 0!==n.globals.dataLabelsRects[a][g]){var p=n.globals.dataLabelsRects[a][u];(t>p.x+p.width+2||e>p.y+p.height+2||t+ce.globals.gridWidth+f.textRects.width+10)&&(n="");var x=e.globals.dataLabels.style.colors[r];(("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||e.config.dataLabels.distributed)&&(x=e.globals.dataLabels.style.colors[o]),"function"==typeof x&&(x=x({series:e.globals.series,seriesIndex:r,dataPointIndex:o,w:e})),g&&(x=g);var b=d.offsetX,y=d.offsetY;if("bar"!==e.config.chart.type&&"rangeBar"!==e.config.chart.type||(b=0,y=0),f.drawnextLabel){var w=i.drawText({width:100,height:parseInt(d.style.fontSize,10),x:a+b,y:s+y,foreColor:x,textAnchor:l||d.textAnchor,text:n,fontSize:h||d.style.fontSize,fontFamily:d.style.fontFamily,fontWeight:d.style.fontWeight||"normal"});if(w.attr({class:"apexcharts-datalabel",cx:a,cy:s}),d.dropShadow.enabled){var k=d.dropShadow;new v(this.ctx).dropShadow(w,k)}c.add(w),void 0===e.globals.lastDrawnDataLabelsIndexes[r]&&(e.globals.lastDrawnDataLabelsIndexes[r]=[]),e.globals.lastDrawnDataLabelsIndexes[r].push(o)}}}},{key:"addBackgroundToDataLabel",value:function(t,e){var i=this.w,a=i.config.dataLabels.background,s=a.padding,r=a.padding/2,o=e.width,n=e.height,l=new m(this.ctx).drawRect(e.x-s,e.y-r/2,o+2*s,n+r,a.borderRadius,"transparent"===i.config.chart.background?"#fff":i.config.chart.background,a.opacity,a.borderWidth,a.borderColor);a.dropShadow.enabled&&new v(this.ctx).dropShadow(l,a.dropShadow);return l}},{key:"dataLabelsBackground",value:function(){var t=this.w;if("bubble"!==t.config.chart.type)for(var e=t.globals.dom.baseEl.querySelectorAll(".apexcharts-datalabels text"),i=0;i0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w,s=x.clone(a.globals.initialSeries);a.globals.previousPaths=[],i?(a.globals.collapsedSeries=[],a.globals.ancillaryCollapsedSeries=[],a.globals.collapsedSeriesIndices=[],a.globals.ancillaryCollapsedSeriesIndices=[]):s=this.emptyCollapsedSeries(s),a.config.series=s,t&&(e&&(a.globals.zoomed=!1,this.ctx.updateHelpers.revertDefaultAxisMinMax()),this.ctx.updateHelpers._updateSeries(s,a.config.chart.animations.dynamicAnimation.enabled))}},{key:"emptyCollapsedSeries",value:function(t){for(var e=this.w,i=0;i-1&&(t[i].data=[]);return t}},{key:"toggleSeriesOnHover",value:function(t,e){var i=this.w;e||(e=t.target);var a=i.globals.dom.baseEl.querySelectorAll(".apexcharts-series, .apexcharts-datalabels");if("mousemove"===t.type){var s=parseInt(e.getAttribute("rel"),10)-1,r=null,o=null;i.globals.axisCharts||"radialBar"===i.config.chart.type?i.globals.axisCharts?(r=i.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(s,"']")),o=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels[data\\:realIndex='".concat(s,"']"))):r=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(s+1,"']")):r=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(s+1,"'] path"));for(var n=0;n=t.from&&a<=t.to&&s[e].classList.remove(i.legendInactiveClass)}}(a.config.plotOptions.heatmap.colorScale.ranges[o])}else"mouseout"===t.type&&r("remove")}},{key:"getActiveConfigSeriesIndex",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"asc",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],i=this.w,a=0;if(i.config.series.length>1)for(var s=i.config.series.map((function(t,a){return t.data&&t.data.length>0&&-1===i.globals.collapsedSeriesIndices.indexOf(a)&&(!i.globals.comboCharts||0===e.length||e.length&&e.indexOf(i.config.series[a].type)>-1)?a:-1})),r="asc"===t?0:s.length-1;"asc"===t?r=0;"asc"===t?r++:r--)if(-1!==s[r]){a=s[r];break}return a}},{key:"getBarSeriesIndices",value:function(){return this.w.globals.comboCharts?this.w.config.series.map((function(t,e){return"bar"===t.type||"column"===t.type?e:-1})).filter((function(t){return-1!==t})):this.w.config.series.map((function(t,e){return e}))}},{key:"getPreviousPaths",value:function(){var t=this.w;function e(e,i,a){for(var s=e[i].childNodes,r={type:a,paths:[],realIndex:e[i].getAttribute("data:realIndex")},o=0;o0)for(var a=function(e){for(var i=t.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(t.config.chart.type," .apexcharts-series[data\\:realIndex='").concat(e,"'] rect")),a=[],s=function(t){var e=function(e){return i[t].getAttribute(e)},s={x:parseFloat(e("x")),y:parseFloat(e("y")),width:parseFloat(e("width")),height:parseFloat(e("height"))};a.push({rect:s,color:i[t].getAttribute("color")})},r=0;r0)for(var a=0;a0?t:[]}));return t}}]),t}(),W=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.twoDSeries=[],this.threeDSeries=[],this.twoDSeriesX=[],this.seriesGoals=[],this.coreUtils=new y(this.ctx)}return r(t,[{key:"isMultiFormat",value:function(){return this.isFormatXY()||this.isFormat2DArray()}},{key:"isFormatXY",value:function(){var t=this.w.config.series.slice(),e=new N(this.ctx);if(this.activeSeriesIndex=e.getActiveConfigSeriesIndex(),void 0!==t[this.activeSeriesIndex].data&&t[this.activeSeriesIndex].data.length>0&&null!==t[this.activeSeriesIndex].data[0]&&void 0!==t[this.activeSeriesIndex].data[0].x&&null!==t[this.activeSeriesIndex].data[0])return!0}},{key:"isFormat2DArray",value:function(){var t=this.w.config.series.slice(),e=new N(this.ctx);if(this.activeSeriesIndex=e.getActiveConfigSeriesIndex(),void 0!==t[this.activeSeriesIndex].data&&t[this.activeSeriesIndex].data.length>0&&void 0!==t[this.activeSeriesIndex].data[0]&&null!==t[this.activeSeriesIndex].data[0]&&t[this.activeSeriesIndex].data[0].constructor===Array)return!0}},{key:"handleFormat2DArray",value:function(t,e){for(var i=this.w.config,a=this.w.globals,s="boxPlot"===i.chart.type||"boxPlot"===i.series[e].type,r=0;r=5?this.twoDSeries.push(x.parseNumber(t[e].data[r][4])):this.twoDSeries.push(x.parseNumber(t[e].data[r][1])),a.dataFormatXNumeric=!0),"datetime"===i.xaxis.type){var o=new Date(t[e].data[r][0]);o=new Date(o).getTime(),this.twoDSeriesX.push(o)}else this.twoDSeriesX.push(t[e].data[r][0]);for(var n=0;n-1&&(r=this.activeSeriesIndex);for(var o=0;o1&&void 0!==arguments[1]?arguments[1]:this.ctx,s=this.w.config,r=this.w.globals,o=new I(a),n=s.labels.length>0?s.labels.slice():s.xaxis.categories.slice();if(r.isRangeBar="rangeBar"===s.chart.type&&r.isBarHorizontal,r.hasXaxisGroups="category"===s.xaxis.type&&s.xaxis.group.groups.length>0,r.hasXaxisGroups&&(r.groups=s.xaxis.group.groups),r.hasSeriesGroups=null===(e=t[0])||void 0===e?void 0:e.group,r.hasSeriesGroups){var l=[],h=u(new Set(t.map((function(t){return t.group}))));t.forEach((function(t,e){var i=h.indexOf(t.group);l[i]||(l[i]=[]),l[i].push(t.name)})),r.seriesGroups=l}for(var c=function(){for(var t=0;t0&&(this.twoDSeriesX=n,r.seriesX.push(this.twoDSeriesX))),r.labels.push(this.twoDSeriesX);var g=t[d].data.map((function(t){return x.parseNumber(t)}));r.series.push(g)}r.seriesZ.push(this.threeDSeries),void 0!==t[d].name?r.seriesNames.push(t[d].name):r.seriesNames.push("series-"+parseInt(d+1,10)),void 0!==t[d].color?r.seriesColors.push(t[d].color):r.seriesColors.push(void 0)}return this.w}},{key:"parseDataNonAxisCharts",value:function(t){var e=this.w.globals,i=this.w.config;e.series=t.slice(),e.seriesNames=i.labels.slice();for(var a=0;a0)i.labels=e.xaxis.categories;else if(e.labels.length>0)i.labels=e.labels.slice();else if(this.fallbackToCategory){if(i.labels=i.labels[0],i.seriesRange.length&&(i.seriesRange.map((function(t){t.forEach((function(t){i.labels.indexOf(t.x)<0&&t.x&&i.labels.push(t.x)}))})),i.labels=i.labels.filter((function(t,e,i){return i.indexOf(t)===e}))),e.xaxis.convertedCatToNumeric)new z(e).convertCatToNumericXaxis(e,this.ctx,i.seriesX[0]),this._generateExternalLabels(t)}else this._generateExternalLabels(t)}},{key:"_generateExternalLabels",value:function(t){var e=this.w.globals,i=this.w.config,a=[];if(e.axisCharts){if(e.series.length>0)if(this.isFormatXY())for(var s=i.series.map((function(t,e){return t.data.filter((function(t,e,i){return i.findIndex((function(e){return e.x===t.x}))===e}))})),r=s.reduce((function(t,e,i,a){return a[t].length>e.length?t:i}),0),o=0;o4&&void 0!==arguments[4]?arguments[4]:[],r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"12px",o=!(arguments.length>6&&void 0!==arguments[6])||arguments[6],n=this.w,l=void 0===t[a]?"":t[a],h=l,c=n.globals.xLabelFormatter,d=n.config.xaxis.labels.formatter,g=!1,u=new T(this.ctx),p=l;o&&(h=u.xLabelFormat(c,l,p,{i:a,dateFormatter:new I(this.ctx).formatDate,w:n}),void 0!==d&&(h=d(l,t[a],{i:a,dateFormatter:new I(this.ctx).formatDate,w:n})));var f,x;e.length>0?(f=e[a].unit,x=null,e.forEach((function(t){"month"===t.unit?x="year":"day"===t.unit?x="month":"hour"===t.unit?x="day":"minute"===t.unit&&(x="hour")})),g=x===f,i=e[a].position,h=e[a].value):"datetime"===n.config.xaxis.type&&void 0===d&&(h=""),void 0===h&&(h=""),h=Array.isArray(h)?h:h.toString();var b=new m(this.ctx),v={};v=n.globals.rotateXLabels&&o?b.getTextRects(h,parseInt(r,10),null,"rotate(".concat(n.config.xaxis.labels.rotate," 0 0)"),!1):b.getTextRects(h,parseInt(r,10));var y=!n.config.xaxis.labels.showDuplicates&&this.ctx.timeScale;return!Array.isArray(h)&&(0===h.indexOf("NaN")||0===h.toLowerCase().indexOf("invalid")||h.toLowerCase().indexOf("infinity")>=0||s.indexOf(h)>=0&&y)&&(h=""),{x:i,text:h,textRect:v,isBold:g}}},{key:"checkLabelBasedOnTickamount",value:function(t,e,i){var a=this.w,s=a.config.xaxis.tickAmount;return"dataPoints"===s&&(s=Math.round(a.globals.gridWidth/120)),s>i||t%Math.round(i/(s+1))==0||(e.text=""),e}},{key:"checkForOverflowingLabels",value:function(t,e,i,a,s){var r=this.w;if(0===t&&r.globals.skipFirstTimelinelabel&&(e.text=""),t===i-1&&r.globals.skipLastTimelinelabel&&(e.text=""),r.config.xaxis.labels.hideOverlappingLabels&&a.length>0){var o=s[s.length-1];e.x0){!0===n.config.yaxis[s].opposite&&(t+=a.width);for(var c=e;c>=0;c--){var d=h+e/10+n.config.yaxis[s].labels.offsetY-1;n.globals.isBarHorizontal&&(d=r*c),"heatmap"===n.config.chart.type&&(d+=r/2);var g=l.drawLine(t+i.offsetX-a.width+a.offsetX,d+a.offsetY,t+i.offsetX+a.offsetX,d+a.offsetY,a.color);o.add(g),h+=r}}}}]),t}(),G=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"scaleSvgNode",value:function(t,e){var i=parseFloat(t.getAttributeNS(null,"width")),a=parseFloat(t.getAttributeNS(null,"height"));t.setAttributeNS(null,"width",i*e),t.setAttributeNS(null,"height",a*e),t.setAttributeNS(null,"viewBox","0 0 "+i+" "+a)}},{key:"fixSvgStringForIe11",value:function(t){if(!x.isIE11())return t.replace(/ /g," ");var e=0,i=t.replace(/xmlns="http:\/\/www.w3.org\/2000\/svg"/g,(function(t){return 2===++e?'xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:svgjs="http://svgjs.dev"':t}));return i=(i=i.replace(/xmlns:NS\d+=""/g,"")).replace(/NS\d+:(\w+:\w+=")/g,"$1")}},{key:"getSvgString",value:function(t){null==t&&(t=1);var e=this.w.globals.dom.Paper.svg();if(1!==t){var i=this.w.globals.dom.Paper.node.cloneNode(!0);this.scaleSvgNode(i,t),e=(new XMLSerializer).serializeToString(i)}return this.fixSvgStringForIe11(e)}},{key:"cleanup",value:function(){var t=this.w,e=t.globals.dom.baseEl.getElementsByClassName("apexcharts-xcrosshairs"),i=t.globals.dom.baseEl.getElementsByClassName("apexcharts-ycrosshairs"),a=t.globals.dom.baseEl.querySelectorAll(".apexcharts-zoom-rect, .apexcharts-selection-rect");Array.prototype.forEach.call(a,(function(t){t.setAttribute("width",0)})),e&&e[0]&&(e[0].setAttribute("x",-500),e[0].setAttribute("x1",-500),e[0].setAttribute("x2",-500)),i&&i[0]&&(i[0].setAttribute("y",-100),i[0].setAttribute("y1",-100),i[0].setAttribute("y2",-100))}},{key:"svgUrl",value:function(){this.cleanup();var t=this.getSvgString(),e=new Blob([t],{type:"image/svg+xml;charset=utf-8"});return URL.createObjectURL(e)}},{key:"dataURI",value:function(t){var e=this;return new Promise((function(i){var a=e.w,s=t?t.scale||t.width/a.globals.svgWidth:1;e.cleanup();var r=document.createElement("canvas");r.width=a.globals.svgWidth*s,r.height=parseInt(a.globals.dom.elWrap.style.height,10)*s;var o="transparent"===a.config.chart.background?"#fff":a.config.chart.background,n=r.getContext("2d");n.fillStyle=o,n.fillRect(0,0,r.width*s,r.height*s);var l=e.getSvgString(s);if(window.canvg&&x.isIE11()){var h=window.canvg.Canvg.fromString(n,l,{ignoreClear:!0,ignoreDimensions:!0});h.start();var c=r.msToBlob();h.stop(),i({blob:c})}else{var d="data:image/svg+xml,"+encodeURIComponent(l),g=new Image;g.crossOrigin="anonymous",g.onload=function(){if(n.drawImage(g,0,0),r.msToBlob){var t=r.msToBlob();i({blob:t})}else{var e=r.toDataURL("image/png");i({imgURI:e})}},g.src=d}}))}},{key:"exportToSVG",value:function(){this.triggerDownload(this.svgUrl(),this.w.config.chart.toolbar.export.svg.filename,".svg")}},{key:"exportToPng",value:function(){var t=this;this.dataURI().then((function(e){var i=e.imgURI,a=e.blob;a?navigator.msSaveOrOpenBlob(a,t.w.globals.chartID+".png"):t.triggerDownload(i,t.w.config.chart.toolbar.export.png.filename,".png")}))}},{key:"exportToCSV",value:function(t){var e=this,i=t.series,a=t.fileName,s=t.columnDelimiter,r=void 0===s?",":s,o=t.lineDelimiter,n=void 0===o?"\n":o,l=this.w;i||(i=l.config.series);var h=[],c=[],d="",g=l.globals.series.map((function(t,e){return-1===l.globals.collapsedSeriesIndices.indexOf(e)?t:[]})),p=Math.max.apply(Math,u(i.map((function(t){return t.data?t.data.length:0})))),f=new W(this.ctx),b=new B(this.ctx),v=function(t){var i="";if(l.globals.axisCharts){if("category"===l.config.xaxis.type||l.config.xaxis.convertedCatToNumeric)if(l.globals.isBarHorizontal){var a=l.globals.yLabelFormatters[0],s=new N(e.ctx).getActiveConfigSeriesIndex();i=a(l.globals.labels[t],{seriesIndex:s,dataPointIndex:t,w:l})}else i=b.getLabel(l.globals.labels,l.globals.timescaleLabels,0,t).text;"datetime"===l.config.xaxis.type&&(l.config.xaxis.categories.length?i=l.config.xaxis.categories[t]:l.config.labels.length&&(i=l.config.labels[t]))}else i=l.config.labels[t];return Array.isArray(i)&&(i=i.join(" ")),x.isNumber(i)?i:i.split(r).join("")},m=function(t,e){if(h.length&&0===e&&c.push(h.join(r)),t.data){t.data=t.data.length&&t.data||u(Array(p)).map((function(){return""}));for(var a=0;a=10?l.config.chart.toolbar.export.csv.dateFormatter(s):x.isNumber(s)?s:s.split(r).join("")));for(var o=0;o0&&!s.globals.isBarHorizontal&&(this.xaxisLabels=s.globals.timescaleLabels.slice()),s.config.xaxis.overwriteCategories&&(this.xaxisLabels=s.config.xaxis.overwriteCategories),this.drawnLabels=[],this.drawnLabelsRects=[],"top"===s.config.xaxis.position?this.offY=0:this.offY=s.globals.gridHeight+1,this.offY=this.offY+s.config.xaxis.axisBorder.offsetY,this.isCategoryBarHorizontal="bar"===s.config.chart.type&&s.config.plotOptions.bar.horizontal,this.xaxisFontSize=s.config.xaxis.labels.style.fontSize,this.xaxisFontFamily=s.config.xaxis.labels.style.fontFamily,this.xaxisForeColors=s.config.xaxis.labels.style.colors,this.xaxisBorderWidth=s.config.xaxis.axisBorder.width,this.isCategoryBarHorizontal&&(this.xaxisBorderWidth=s.config.yaxis[0].axisBorder.width.toString()),this.xaxisBorderWidth.indexOf("%")>-1?this.xaxisBorderWidth=s.globals.gridWidth*parseInt(this.xaxisBorderWidth,10)/100:this.xaxisBorderWidth=parseInt(this.xaxisBorderWidth,10),this.xaxisBorderHeight=s.config.xaxis.axisBorder.height,this.yaxis=s.config.yaxis[0]}return r(t,[{key:"drawXaxis",value:function(){var t=this.w,e=new m(this.ctx),i=e.group({class:"apexcharts-xaxis",transform:"translate(".concat(t.config.xaxis.offsetX,", ").concat(t.config.xaxis.offsetY,")")}),a=e.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(t.globals.translateXAxisX,", ").concat(t.globals.translateXAxisY,")")});i.add(a);for(var s=[],r=0;r6&&void 0!==arguments[6]?arguments[6]:{},h=[],c=[],d=this.w,g=l.xaxisFontSize||this.xaxisFontSize,u=l.xaxisFontFamily||this.xaxisFontFamily,p=l.xaxisForeColors||this.xaxisForeColors,f=l.fontWeight||d.config.xaxis.labels.style.fontWeight,x=l.cssClass||d.config.xaxis.labels.style.cssClass,b=d.globals.padHorizontal,v=a.length,m="category"===d.config.xaxis.type?d.globals.dataPoints:v;if(0===m&&v>m&&(m=v),s){var y=m>1?m-1:m;o=d.globals.gridWidth/y,b=b+r(0,o)/2+d.config.xaxis.labels.offsetX}else o=d.globals.gridWidth/m,b=b+r(0,o)+d.config.xaxis.labels.offsetX;for(var w=function(s){var l=b-r(s,o)/2+d.config.xaxis.labels.offsetX;0===s&&1===v&&o/2===b&&1===m&&(l=d.globals.gridWidth/2);var y=n.axesUtils.getLabel(a,d.globals.timescaleLabels,l,s,h,g,t),w=28;d.globals.rotateXLabels&&t&&(w=22),d.config.xaxis.title.text&&"top"===d.config.xaxis.position&&(w+=parseFloat(d.config.xaxis.title.style.fontSize)+2),t||(w=w+parseFloat(g)+(d.globals.xAxisLabelsHeight-d.globals.xAxisGroupLabelsHeight)+(d.globals.rotateXLabels?10:0)),y=void 0!==d.config.xaxis.tickAmount&&"dataPoints"!==d.config.xaxis.tickAmount&&"datetime"!==d.config.xaxis.type?n.axesUtils.checkLabelBasedOnTickamount(s,y,v):n.axesUtils.checkForOverflowingLabels(s,y,v,h,c);if(d.config.xaxis.labels.show){var k=e.drawText({x:y.x,y:n.offY+d.config.xaxis.labels.offsetY+w-("top"===d.config.xaxis.position?d.globals.xAxisHeight+d.config.xaxis.axisTicks.height-2:0),text:y.text,textAnchor:"middle",fontWeight:y.isBold?600:f,fontSize:g,fontFamily:u,foreColor:Array.isArray(p)?t&&d.config.xaxis.convertedCatToNumeric?p[d.globals.minX+s-1]:p[s]:p,isPlainText:!1,cssClass:(t?"apexcharts-xaxis-label ":"apexcharts-xaxis-group-label ")+x});if(i.add(k),k.on("click",(function(t){if("function"==typeof d.config.chart.events.xAxisLabelClick){var e=Object.assign({},d,{labelIndex:s});d.config.chart.events.xAxisLabelClick(t,n.ctx,e)}})),t){var A=document.createElementNS(d.globals.SVGNS,"title");A.textContent=Array.isArray(y.text)?y.text.join(" "):y.text,k.node.appendChild(A),""!==y.text&&(h.push(y.text),c.push(y))}}sa.globals.gridWidth)){var r=this.offY+a.config.xaxis.axisTicks.offsetY;if(e=e+r+a.config.xaxis.axisTicks.height,"top"===a.config.xaxis.position&&(e=r-a.config.xaxis.axisTicks.height),a.config.xaxis.axisTicks.show){var o=new m(this.ctx).drawLine(t+a.config.xaxis.axisTicks.offsetX,r+a.config.xaxis.offsetY,s+a.config.xaxis.axisTicks.offsetX,e+a.config.xaxis.offsetY,a.config.xaxis.axisTicks.color);i.add(o),o.node.classList.add("apexcharts-xaxis-tick")}}}},{key:"getXAxisTicksPositions",value:function(){var t=this.w,e=[],i=this.xaxisLabels.length,a=t.globals.padHorizontal;if(t.globals.timescaleLabels.length>0)for(var s=0;s0){var h=s[s.length-1].getBBox(),c=s[0].getBBox();h.x<-20&&s[s.length-1].parentNode.removeChild(s[s.length-1]),c.x+c.width>t.globals.gridWidth&&!t.globals.isBarHorizontal&&s[0].parentNode.removeChild(s[0]);for(var d=0;d0&&(this.xaxisLabels=i.globals.timescaleLabels.slice())}return r(t,[{key:"drawGridArea",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w,i=new m(this.ctx);null===t&&(t=i.group({class:"apexcharts-grid"}));var a=i.drawLine(e.globals.padHorizontal,1,e.globals.padHorizontal,e.globals.gridHeight,"transparent"),s=i.drawLine(e.globals.padHorizontal,e.globals.gridHeight,e.globals.gridWidth,e.globals.gridHeight,"transparent");return t.add(s),t.add(a),t}},{key:"drawGrid",value:function(){var t=null;return this.w.globals.axisCharts&&(t=this.renderGrid(),this.drawGridArea(t.el)),t}},{key:"createGridMask",value:function(){var t=this.w,e=t.globals,i=new m(this.ctx),a=Array.isArray(t.config.stroke.width)?0:t.config.stroke.width;if(Array.isArray(t.config.stroke.width)){var s=0;t.config.stroke.width.forEach((function(t){s=Math.max(s,t)})),a=s}e.dom.elGridRectMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMask.setAttribute("id","gridRectMask".concat(e.cuid)),e.dom.elGridRectMarkerMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMarkerMask.setAttribute("id","gridRectMarkerMask".concat(e.cuid)),e.dom.elForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elForecastMask.setAttribute("id","forecastMask".concat(e.cuid)),e.dom.elNonForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elNonForecastMask.setAttribute("id","nonForecastMask".concat(e.cuid));var r=t.config.chart.type,o=0,n=0;("bar"===r||"rangeBar"===r||"candlestick"===r||"boxPlot"===r||t.globals.comboBarCount>0)&&t.globals.isXNumeric&&!t.globals.isBarHorizontal&&(o=t.config.grid.padding.left,n=t.config.grid.padding.right,e.barPadForNumericAxis>o&&(o=e.barPadForNumericAxis,n=e.barPadForNumericAxis)),e.dom.elGridRect=i.drawRect(-a/2-o-2,-a/2,e.gridWidth+a+n+o+4,e.gridHeight+a,0,"#fff");var l=t.globals.markers.largestSize+1;e.dom.elGridRectMarker=i.drawRect(2*-l,2*-l,e.gridWidth+4*l,e.gridHeight+4*l,0,"#fff"),e.dom.elGridRectMask.appendChild(e.dom.elGridRect.node),e.dom.elGridRectMarkerMask.appendChild(e.dom.elGridRectMarker.node);var h=e.dom.baseEl.querySelector("defs");h.appendChild(e.dom.elGridRectMask),h.appendChild(e.dom.elForecastMask),h.appendChild(e.dom.elNonForecastMask),h.appendChild(e.dom.elGridRectMarkerMask)}},{key:"_drawGridLines",value:function(t){var e=t.i,i=t.x1,a=t.y1,s=t.x2,r=t.y2,o=t.xCount,n=t.parent,l=this.w;if(!(0===e&&l.globals.skipFirstTimelinelabel||e===o-1&&l.globals.skipLastTimelinelabel&&!l.config.xaxis.labels.formatter||"radar"===l.config.chart.type)){l.config.grid.xaxis.lines.show&&this._drawGridLine({i:e,x1:i,y1:a,x2:s,y2:r,xCount:o,parent:n});var h=0;if(l.globals.hasXaxisGroups&&"between"===l.config.xaxis.tickPlacement){var c=l.globals.groups;if(c){for(var d=0,g=0;d2));s++);return!t.globals.isBarHorizontal||this.isRangeBar?(i=this.xaxisLabels.length,this.isRangeBar&&(i--,a=t.globals.labels.length,t.config.xaxis.tickAmount&&t.config.xaxis.labels.formatter&&(i=t.config.xaxis.tickAmount)),this._drawXYLines({xCount:i,tickAmount:a})):(i=a,a=t.globals.xTickAmount,this._drawInvertedXYLines({xCount:i,tickAmount:a})),this.drawGridBands(i,a),{el:this.elg,elGridBorders:this.elGridBorders,xAxisTickWidth:t.globals.gridWidth/i}}},{key:"drawGridBands",value:function(t,e){var i=this.w;if(void 0!==i.config.grid.row.colors&&i.config.grid.row.colors.length>0)for(var a=0,s=i.globals.gridHeight/e,r=i.globals.gridWidth,o=0,n=0;o=i.config.grid.row.colors.length&&(n=0),this._drawGridBandRect({c:n,x1:0,y1:a,x2:r,y2:s,type:"row"}),a+=i.globals.gridHeight/e;if(void 0!==i.config.grid.column.colors&&i.config.grid.column.colors.length>0)for(var l=i.globals.isBarHorizontal||"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric?t:t-1,h=i.globals.padHorizontal,c=i.globals.padHorizontal+i.globals.gridWidth/l,d=i.globals.gridHeight,g=0,u=0;g=i.config.grid.column.colors.length&&(u=0),this._drawGridBandRect({c:u,x1:h,y1:0,x2:c,y2:d,type:"column"}),h+=i.globals.gridWidth/l}}]),t}(),_=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"niceScale",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,s=arguments.length>4?arguments[4]:void 0,r=this.w,o=Math.abs(e-t);if("dataPoints"===(i=this._adjustTicksForSmallRange(i,a,o))&&(i=r.globals.dataPoints-1),t===Number.MIN_VALUE&&0===e||!x.isNumber(t)&&!x.isNumber(e)||t===Number.MIN_VALUE&&e===-Number.MAX_VALUE)return t=0,e=i,this.linearScale(t,e,i);t>e?(console.warn("axis.min cannot be greater than axis.max"),e=t+.1):t===e&&(t=0===t?0:t-.5,e=0===e?2:e+.5);var n=[];o<1&&s&&("candlestick"===r.config.chart.type||"candlestick"===r.config.series[a].type||"boxPlot"===r.config.chart.type||"boxPlot"===r.config.series[a].type||r.globals.isRangeData)&&(e*=1.01);var l=i+1;l<2?l=2:l>2&&(l-=2);var h=o/l,c=Math.floor(x.log10(h)),d=Math.pow(10,c),g=Math.round(h/d);g<1&&(g=1);var u=g*d,p=u*Math.floor(t/u),f=u*Math.ceil(e/u),b=p;if(s&&o>2){for(;n.push(b),!((b+=u)>f););return{result:n,niceMin:n[0],niceMax:n[n.length-1]}}var v=t;(n=[]).push(v);for(var m=Math.abs(e-t)/i,y=0;y<=i;y++)v+=m,n.push(v);return n[n.length-2]>=e&&n.pop(),{result:n,niceMin:n[0],niceMax:n[n.length-1]}}},{key:"linearScale",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3?arguments[3]:void 0,s=Math.abs(e-t);"dataPoints"===(i=this._adjustTicksForSmallRange(i,a,s))&&(i=this.w.globals.dataPoints-1);var r=s/i;i===Number.MAX_VALUE&&(i=10,r=1);for(var o=[],n=t;i>=0;)o.push(n),n+=r,i-=1;return{result:o,niceMin:o[0],niceMax:o[o.length-1]}}},{key:"logarithmicScaleNice",value:function(t,e,i){e<=0&&(e=Math.max(t,i)),t<=0&&(t=Math.min(e,i));for(var a=[],s=Math.ceil(Math.log(e)/Math.log(i)+1),r=Math.floor(Math.log(t)/Math.log(i));r5)a.allSeriesCollapsed=!1,a.yAxisScale[t]=this.logarithmicScale(e,i,r.logBase),a.yAxisScale[t]=r.forceNiceScale?this.logarithmicScaleNice(e,i,r.logBase):this.logarithmicScale(e,i,r.logBase);else if(i!==-Number.MAX_VALUE&&x.isNumber(i))if(a.allSeriesCollapsed=!1,void 0===r.min&&void 0===r.max||r.forceNiceScale){var n=void 0===s.yaxis[t].max&&void 0===s.yaxis[t].min||s.yaxis[t].forceNiceScale;a.yAxisScale[t]=this.niceScale(e,i,r.tickAmount?r.tickAmount:o<5&&o>1?o+1:5,t,n)}else a.yAxisScale[t]=this.linearScale(e,i,r.tickAmount,t);else a.yAxisScale[t]=this.linearScale(0,5,5)}},{key:"setXScale",value:function(t,e){var i=this.w,a=i.globals,s=i.config.xaxis,r=Math.abs(e-t);return e!==-Number.MAX_VALUE&&x.isNumber(e)?a.xAxisScale=this.linearScale(t,e,s.tickAmount?s.tickAmount:r<5&&r>1?r+1:5,0):a.xAxisScale=this.linearScale(0,5,5),a.xAxisScale}},{key:"setMultipleYScales",value:function(){var t=this,e=this.w.globals,i=this.w.config,a=e.minYArr.concat([]),s=e.maxYArr.concat([]),r=[];i.yaxis.forEach((function(e,o){var n=o;i.series.forEach((function(t,i){t.name===e.seriesName&&(n=i,o!==i?r.push({index:i,similarIndex:o,alreadyExists:!0}):r.push({index:i}))}));var l=a[n],h=s[n];t.setYScaleForIndex(o,l,h)})),this.sameScaleInMultipleAxes(a,s,r)}},{key:"sameScaleInMultipleAxes",value:function(t,e,i){var a=this,s=this.w.config,r=this.w.globals,o=[];i.forEach((function(t){t.alreadyExists&&(void 0===o[t.index]&&(o[t.index]=[]),o[t.index].push(t.index),o[t.index].push(t.similarIndex))})),r.yAxisSameScaleIndices=o,o.forEach((function(t,e){o.forEach((function(i,a){var s,r;e!==a&&(s=t,r=i,s.filter((function(t){return-1!==r.indexOf(t)}))).length>0&&(o[e]=o[e].concat(o[a]))}))}));var n=o.map((function(t){return t.filter((function(e,i){return t.indexOf(e)===i}))})).map((function(t){return t.sort()}));o=o.filter((function(t){return!!t}));var l=n.slice(),h=l.map((function(t){return JSON.stringify(t)}));l=l.filter((function(t,e){return h.indexOf(JSON.stringify(t))===e}));var c=[],d=[];t.forEach((function(t,i){l.forEach((function(a,s){a.indexOf(i)>-1&&(void 0===c[s]&&(c[s]=[],d[s]=[]),c[s].push({key:i,value:t}),d[s].push({key:i,value:e[i]}))}))}));var g=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,Number.MIN_VALUE),u=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,-Number.MAX_VALUE);c.forEach((function(t,e){t.forEach((function(t,i){g[e]=Math.min(t.value,g[e])}))})),d.forEach((function(t,e){t.forEach((function(t,i){u[e]=Math.max(t.value,u[e])}))})),t.forEach((function(t,e){d.forEach((function(t,i){var o=g[i],n=u[i];s.chart.stacked&&(n=0,t.forEach((function(t,e){t.value!==-Number.MAX_VALUE&&(n+=t.value),o!==Number.MIN_VALUE&&(o+=c[i][e].value)}))),t.forEach((function(i,l){t[l].key===e&&(void 0!==s.yaxis[e].min&&(o="function"==typeof s.yaxis[e].min?s.yaxis[e].min(r.minY):s.yaxis[e].min),void 0!==s.yaxis[e].max&&(n="function"==typeof s.yaxis[e].max?s.yaxis[e].max(r.maxY):s.yaxis[e].max),a.setYScaleForIndex(e,o,n))}))}))}))}},{key:"autoScaleY",value:function(t,e,i){t||(t=this);var a=t.w;if(a.globals.isMultipleYAxis||a.globals.collapsedSeries.length)return console.warn("autoScaleYaxis is not supported in a multi-yaxis chart."),e;var s=a.globals.seriesX[0],r=a.config.chart.stacked;return e.forEach((function(t,o){for(var n=0,l=0;l=i.xaxis.min){n=l;break}var h,c,d=a.globals.minYArr[o],g=a.globals.maxYArr[o],u=a.globals.stackedSeriesTotals;a.globals.series.forEach((function(o,l){var p=o[n];r?(p=u[n],h=c=p,u.forEach((function(t,e){s[e]<=i.xaxis.max&&s[e]>=i.xaxis.min&&(t>c&&null!==t&&(c=t),o[e]=i.xaxis.min){var r=t,o=t;a.globals.series.forEach((function(i,a){null!==t&&(r=Math.min(i[e],r),o=Math.max(i[e],o))})),o>c&&null!==o&&(c=o),rd&&(h=d),e.length>1?(e[l].min=void 0===t.min?h:t.min,e[l].max=void 0===t.max?c:t.max):(e[0].min=void 0===t.min?h:t.min,e[0].max=void 0===t.max?c:t.max)}))})),e}}]),t}(),U=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.scales=new _(e)}return r(t,[{key:"init",value:function(){this.setYRange(),this.setXRange(),this.setZRange()}},{key:"getMinYMaxY",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Number.MAX_VALUE,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:-Number.MAX_VALUE,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.w.config,r=this.w.globals,o=-Number.MAX_VALUE,n=Number.MIN_VALUE;null===a&&(a=t+1);var l=r.series,h=l,c=l;"candlestick"===s.chart.type?(h=r.seriesCandleL,c=r.seriesCandleH):"boxPlot"===s.chart.type?(h=r.seriesCandleO,c=r.seriesCandleC):r.isRangeData&&(h=r.seriesRangeStart,c=r.seriesRangeEnd);for(var d=t;dh[d][g]&&h[d][g]<0&&(n=h[d][g])):r.hasNullValues=!0}}return"rangeBar"===s.chart.type&&r.seriesRangeStart.length&&r.isBarHorizontal&&(n=e),"bar"===s.chart.type&&(n<0&&o<0&&(o=0),n===Number.MIN_VALUE&&(n=0)),{minY:n,maxY:o,lowestY:e,highestY:i}}},{key:"setYRange",value:function(){var t=this.w.globals,e=this.w.config;t.maxY=-Number.MAX_VALUE,t.minY=Number.MIN_VALUE;var i=Number.MAX_VALUE;if(t.isMultipleYAxis)for(var a=0;a=0&&i<=10||void 0!==e.yaxis[0].min||void 0!==e.yaxis[0].max)&&(o=0),t.minY=i-5*o/100,i>0&&t.minY<0&&(t.minY=0),t.maxY=t.maxY+5*o/100}if(e.yaxis.forEach((function(e,i){void 0!==e.max&&("number"==typeof e.max?t.maxYArr[i]=e.max:"function"==typeof e.max&&(t.maxYArr[i]=e.max(t.isMultipleYAxis?t.maxYArr[i]:t.maxY)),t.maxY=t.maxYArr[i]),void 0!==e.min&&("number"==typeof e.min?t.minYArr[i]=e.min:"function"==typeof e.min&&(t.minYArr[i]=e.min(t.isMultipleYAxis?t.minYArr[i]===Number.MIN_VALUE?0:t.minYArr[i]:t.minY)),t.minY=t.minYArr[i])})),t.isBarHorizontal){["min","max"].forEach((function(i){void 0!==e.xaxis[i]&&"number"==typeof e.xaxis[i]&&("min"===i?t.minY=e.xaxis[i]:t.maxY=e.xaxis[i])}))}return t.isMultipleYAxis?(this.scales.setMultipleYScales(),t.minY=i,t.yAxisScale.forEach((function(e,i){t.minYArr[i]=e.niceMin,t.maxYArr[i]=e.niceMax}))):(this.scales.setYScaleForIndex(0,t.minY,t.maxY),t.minY=t.yAxisScale[0].niceMin,t.maxY=t.yAxisScale[0].niceMax,t.minYArr[0]=t.yAxisScale[0].niceMin,t.maxYArr[0]=t.yAxisScale[0].niceMax),{minY:t.minY,maxY:t.maxY,minYArr:t.minYArr,maxYArr:t.maxYArr,yAxisScale:t.yAxisScale}}},{key:"setXRange",value:function(){var t=this.w.globals,e=this.w.config,i="numeric"===e.xaxis.type||"datetime"===e.xaxis.type||"category"===e.xaxis.type&&!t.noLabelsProvided||t.noLabelsProvided||t.isXNumeric;if(t.isXNumeric&&function(){for(var e=0;et.dataPoints&&0!==t.dataPoints&&(a=t.dataPoints-1)):"dataPoints"===e.xaxis.tickAmount?(t.series.length>1&&(a=t.series[t.maxValsInArrayIndex].length-1),t.isXNumeric&&(a=t.maxX-t.minX-1)):a=e.xaxis.tickAmount,t.xTickAmount=a,void 0!==e.xaxis.max&&"number"==typeof e.xaxis.max&&(t.maxX=e.xaxis.max),void 0!==e.xaxis.min&&"number"==typeof e.xaxis.min&&(t.minX=e.xaxis.min),void 0!==e.xaxis.range&&(t.minX=t.maxX-e.xaxis.range),t.minX!==Number.MAX_VALUE&&t.maxX!==-Number.MAX_VALUE)if(e.xaxis.convertedCatToNumeric&&!t.dataFormatXNumeric){for(var s=[],r=t.minX-1;r0&&(t.xAxisScale=this.scales.linearScale(1,t.labels.length,a-1),t.seriesX=t.labels.slice());i&&(t.labels=t.xAxisScale.result.slice())}return t.isBarHorizontal&&t.labels.length&&(t.xTickAmount=t.labels.length),this._handleSingleDataPoint(),this._getMinXDiff(),{minX:t.minX,maxX:t.maxX}}},{key:"setZRange",value:function(){var t=this.w.globals;if(t.isDataXYZ)for(var e=0;e0){var s=e-a[i-1];s>0&&(t.minXDiff=Math.min(s,t.minXDiff))}})),1!==t.dataPoints&&t.minXDiff!==Number.MAX_VALUE||(t.minXDiff=.5)}))}},{key:"_setStackedMinMax",value:function(){var t=this,e=this.w.globals;if(e.series.length){var i=e.seriesGroups;i.length||(i=[this.w.config.series.map((function(t){return t.name}))]);var a={},s={};i.forEach((function(i){a[i]=[],s[i]=[],t.w.config.series.map((function(t,e){return i.indexOf(t.name)>-1?e:null})).filter((function(t){return null!==t})).forEach((function(t){for(var r=0;r0?a[i][r]+=parseFloat(e.series[t][r])+1e-4:s[i][r]+=parseFloat(e.series[t][r]))}))})),Object.entries(a).forEach((function(t){var i=g(t,1)[0];a[i].forEach((function(t,r){e.maxY=Math.max(e.maxY,a[i][r]),e.minY=Math.min(e.minY,s[i][r])}))}))}}}]),t}(),q=function(){function t(e,i){a(this,t),this.ctx=e,this.elgrid=i,this.w=e.w;var s=this.w;this.xaxisFontSize=s.config.xaxis.labels.style.fontSize,this.axisFontFamily=s.config.xaxis.labels.style.fontFamily,this.xaxisForeColors=s.config.xaxis.labels.style.colors,this.isCategoryBarHorizontal="bar"===s.config.chart.type&&s.config.plotOptions.bar.horizontal,this.xAxisoffX=0,"bottom"===s.config.xaxis.position&&(this.xAxisoffX=s.globals.gridHeight),this.drawnLabels=[],this.axesUtils=new B(e)}return r(t,[{key:"drawYaxis",value:function(t){var e=this,i=this.w,a=new m(this.ctx),s=i.config.yaxis[t].labels.style,r=s.fontSize,o=s.fontFamily,n=s.fontWeight,l=a.group({class:"apexcharts-yaxis",rel:t,transform:"translate("+i.globals.translateYAxisX[t]+", 0)"});if(this.axesUtils.isYAxisHidden(t))return l;var h=a.group({class:"apexcharts-yaxis-texts-g"});l.add(h);var c=i.globals.yAxisScale[t].result.length-1,d=i.globals.gridHeight/c,g=i.globals.translateY,u=i.globals.yLabelFormatters[t],p=i.globals.yAxisScale[t].result.slice();p=this.axesUtils.checkForReversedLabels(t,p);var f="";if(i.config.yaxis[t].labels.show)for(var x=function(l){var x=p[l];x=u(x,l,i);var b=i.config.yaxis[t].labels.padding;i.config.yaxis[t].opposite&&0!==i.config.yaxis.length&&(b*=-1);var v="end";i.config.yaxis[t].opposite&&(v="start"),"left"===i.config.yaxis[t].labels.align?v="start":"center"===i.config.yaxis[t].labels.align?v="middle":"right"===i.config.yaxis[t].labels.align&&(v="end");var m=e.axesUtils.getYAxisForeColor(s.colors,t),y=a.drawText({x:b,y:g+c/10+i.config.yaxis[t].labels.offsetY+1,text:x,textAnchor:v,fontSize:r,fontFamily:o,fontWeight:n,maxWidth:i.config.yaxis[t].labels.maxWidth,foreColor:Array.isArray(m)?m[l]:m,isPlainText:!1,cssClass:"apexcharts-yaxis-label "+s.cssClass});l===c&&(f=y),h.add(y);var w=document.createElementNS(i.globals.SVGNS,"title");if(w.textContent=Array.isArray(x)?x.join(" "):x,y.node.appendChild(w),0!==i.config.yaxis[t].labels.rotate){var k=a.rotateAroundCenter(f.node),A=a.rotateAroundCenter(y.node);y.node.setAttribute("transform","rotate(".concat(i.config.yaxis[t].labels.rotate," ").concat(k.x," ").concat(A.y,")"))}g+=d},b=c;b>=0;b--)x(b);if(void 0!==i.config.yaxis[t].title.text){var v=a.group({class:"apexcharts-yaxis-title"}),y=0;i.config.yaxis[t].opposite&&(y=i.globals.translateYAxisX[t]);var w=a.drawText({x:y,y:i.globals.gridHeight/2+i.globals.translateY+i.config.yaxis[t].title.offsetY,text:i.config.yaxis[t].title.text,textAnchor:"end",foreColor:i.config.yaxis[t].title.style.color,fontSize:i.config.yaxis[t].title.style.fontSize,fontWeight:i.config.yaxis[t].title.style.fontWeight,fontFamily:i.config.yaxis[t].title.style.fontFamily,cssClass:"apexcharts-yaxis-title-text "+i.config.yaxis[t].title.style.cssClass});v.add(w),l.add(v)}var k=i.config.yaxis[t].axisBorder,A=31+k.offsetX;if(i.config.yaxis[t].opposite&&(A=-31-k.offsetX),k.show){var S=a.drawLine(A,i.globals.translateY+k.offsetY-2,A,i.globals.gridHeight+i.globals.translateY+k.offsetY+2,k.color,0,k.width);l.add(S)}return i.config.yaxis[t].axisTicks.show&&this.axesUtils.drawYAxisTicks(A,c,k,i.config.yaxis[t].axisTicks,t,d,l),l}},{key:"drawYaxisInversed",value:function(t){var e=this.w,i=new m(this.ctx),a=i.group({class:"apexcharts-xaxis apexcharts-yaxis-inversed"}),s=i.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(e.globals.translateXAxisX,", ").concat(e.globals.translateXAxisY,")")});a.add(s);var r=e.globals.yAxisScale[t].result.length-1,o=e.globals.gridWidth/r+.1,n=o+e.config.xaxis.labels.offsetX,l=e.globals.xLabelFormatter,h=e.globals.yAxisScale[t].result.slice(),c=e.globals.timescaleLabels;c.length>0&&(this.xaxisLabels=c.slice(),r=(h=c.slice()).length),h=this.axesUtils.checkForReversedLabels(t,h);var d=c.length;if(e.config.xaxis.labels.show)for(var g=d?0:r;d?g=0;d?g++:g--){var u=h[g];u=l(u,g,e);var p=e.globals.gridWidth+e.globals.padHorizontal-(n-o+e.config.xaxis.labels.offsetX);if(c.length){var f=this.axesUtils.getLabel(h,c,p,g,this.drawnLabels,this.xaxisFontSize);p=f.x,u=f.text,this.drawnLabels.push(f.text),0===g&&e.globals.skipFirstTimelinelabel&&(u=""),g===h.length-1&&e.globals.skipLastTimelinelabel&&(u="")}var x=i.drawText({x:p,y:this.xAxisoffX+e.config.xaxis.labels.offsetY+30-("top"===e.config.xaxis.position?e.globals.xAxisHeight+e.config.xaxis.axisTicks.height-2:0),text:u,textAnchor:"middle",foreColor:Array.isArray(this.xaxisForeColors)?this.xaxisForeColors[t]:this.xaxisForeColors,fontSize:this.xaxisFontSize,fontFamily:this.xaxisFontFamily,fontWeight:e.config.xaxis.labels.style.fontWeight,isPlainText:!1,cssClass:"apexcharts-xaxis-label "+e.config.xaxis.labels.style.cssClass});s.add(x),x.tspan(u);var b=document.createElementNS(e.globals.SVGNS,"title");b.textContent=u,x.node.appendChild(b),n+=o}return this.inversedYAxisTitleText(a),this.inversedYAxisBorder(a),a}},{key:"inversedYAxisBorder",value:function(t){var e=this.w,i=new m(this.ctx),a=e.config.xaxis.axisBorder;if(a.show){var s=0;"bar"===e.config.chart.type&&e.globals.isXNumeric&&(s-=15);var r=i.drawLine(e.globals.padHorizontal+s+a.offsetX,this.xAxisoffX,e.globals.gridWidth,this.xAxisoffX,a.color,0,a.height);this.elgrid&&this.elgrid.elGridBorders&&e.config.grid.show?this.elgrid.elGridBorders.add(r):t.add(r)}}},{key:"inversedYAxisTitleText",value:function(t){var e=this.w,i=new m(this.ctx);if(void 0!==e.config.xaxis.title.text){var a=i.group({class:"apexcharts-xaxis-title apexcharts-yaxis-title-inversed"}),s=i.drawText({x:e.globals.gridWidth/2+e.config.xaxis.title.offsetX,y:this.xAxisoffX+parseFloat(this.xaxisFontSize)+parseFloat(e.config.xaxis.title.style.fontSize)+e.config.xaxis.title.offsetY+20,text:e.config.xaxis.title.text,textAnchor:"middle",fontSize:e.config.xaxis.title.style.fontSize,fontFamily:e.config.xaxis.title.style.fontFamily,fontWeight:e.config.xaxis.title.style.fontWeight,foreColor:e.config.xaxis.title.style.color,cssClass:"apexcharts-xaxis-title-text "+e.config.xaxis.title.style.cssClass});a.add(s),t.add(a)}}},{key:"yAxisTitleRotate",value:function(t,e){var i=this.w,a=new m(this.ctx),s={width:0,height:0},r={width:0,height:0},o=i.globals.dom.baseEl.querySelector(" .apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-texts-g"));null!==o&&(s=o.getBoundingClientRect());var n=i.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-title text"));if(null!==n&&(r=n.getBoundingClientRect()),null!==n){var l=this.xPaddingForYAxisTitle(t,s,r,e);n.setAttribute("x",l.xPos-(e?10:0))}if(null!==n){var h=a.rotateAroundCenter(n);n.setAttribute("transform","rotate(".concat(e?-1*i.config.yaxis[t].title.rotate:i.config.yaxis[t].title.rotate," ").concat(h.x," ").concat(h.y,")"))}}},{key:"xPaddingForYAxisTitle",value:function(t,e,i,a){var s=this.w,r=0,o=0,n=10;return void 0===s.config.yaxis[t].title.text||t<0?{xPos:o,padd:0}:(a?(o=e.width+s.config.yaxis[t].title.offsetX+i.width/2+n/2,0===(r+=1)&&(o-=n/2)):(o=-1*e.width+s.config.yaxis[t].title.offsetX+n/2+i.width/2,s.globals.isBarHorizontal&&(n=25,o=-1*e.width-s.config.yaxis[t].title.offsetX-n)),{xPos:o,padd:n})}},{key:"setYAxisXPosition",value:function(t,e){var i=this.w,a=0,s=0,r=18,o=1;i.config.yaxis.length>1&&(this.multipleYs=!0),i.config.yaxis.map((function(n,l){var h=i.globals.ignoreYAxisIndexes.indexOf(l)>-1||!n.show||n.floating||0===t[l].width,c=t[l].width+e[l].width;n.opposite?i.globals.isBarHorizontal?(s=i.globals.gridWidth+i.globals.translateX-1,i.globals.translateYAxisX[l]=s-n.labels.offsetX):(s=i.globals.gridWidth+i.globals.translateX+o,h||(o=o+c+20),i.globals.translateYAxisX[l]=s-n.labels.offsetX+20):(a=i.globals.translateX-r,h||(r=r+c+20),i.globals.translateYAxisX[l]=a+n.labels.offsetX)}))}},{key:"setYAxisTextAlignments",value:function(){var t=this.w,e=t.globals.dom.baseEl.getElementsByClassName("apexcharts-yaxis");(e=x.listToArray(e)).forEach((function(e,i){var a=t.config.yaxis[i];if(a&&!a.floating&&void 0!==a.labels.align){var s=t.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-texts-g")),r=t.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-label"));r=x.listToArray(r);var o=s.getBoundingClientRect();"left"===a.labels.align?(r.forEach((function(t,e){t.setAttribute("text-anchor","start")})),a.opposite||s.setAttribute("transform","translate(-".concat(o.width,", 0)"))):"center"===a.labels.align?(r.forEach((function(t,e){t.setAttribute("text-anchor","middle")})),s.setAttribute("transform","translate(".concat(o.width/2*(a.opposite?1:-1),", 0)"))):"right"===a.labels.align&&(r.forEach((function(t,e){t.setAttribute("text-anchor","end")})),a.opposite&&s.setAttribute("transform","translate(".concat(o.width,", 0)")))}}))}}]),t}(),Z=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.documentEvent=x.bind(this.documentEvent,this)}return r(t,[{key:"addEventListener",value:function(t,e){var i=this.w;i.globals.events.hasOwnProperty(t)?i.globals.events[t].push(e):i.globals.events[t]=[e]}},{key:"removeEventListener",value:function(t,e){var i=this.w;if(i.globals.events.hasOwnProperty(t)){var a=i.globals.events[t].indexOf(e);-1!==a&&i.globals.events[t].splice(a,1)}}},{key:"fireEvent",value:function(t,e){var i=this.w;if(i.globals.events.hasOwnProperty(t)){e&&e.length||(e=[]);for(var a=i.globals.events[t],s=a.length,r=0;r0&&(e=this.w.config.chart.locales.concat(window.Apex.chart.locales));var i=e.filter((function(e){return e.name===t}))[0];if(!i)throw new Error("Wrong locale name provided. Please make sure you set the correct locale name in options");var a=x.extend(C,i);this.w.globals.locale=a.options}}]),t}(),J=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"drawAxis",value:function(t,e){var i,a,s=this,r=this.w.globals,o=this.w.config,n=new V(this.ctx,e),l=new q(this.ctx,e);r.axisCharts&&"radar"!==t&&(r.isBarHorizontal?(a=l.drawYaxisInversed(0),i=n.drawXaxisInversed(0),r.dom.elGraphical.add(i),r.dom.elGraphical.add(a)):(i=n.drawXaxis(),r.dom.elGraphical.add(i),o.yaxis.map((function(t,e){if(-1===r.ignoreYAxisIndexes.indexOf(e)&&(a=l.drawYaxis(e),r.dom.Paper.add(a),"back"===s.w.config.grid.position)){var i=r.dom.Paper.children()[1];i.remove(),r.dom.Paper.add(i)}}))))}}]),t}(),Q=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"drawXCrosshairs",value:function(){var t=this.w,e=new m(this.ctx),i=new v(this.ctx),a=t.config.xaxis.crosshairs.fill.gradient,s=t.config.xaxis.crosshairs.dropShadow,r=t.config.xaxis.crosshairs.fill.type,o=a.colorFrom,n=a.colorTo,l=a.opacityFrom,h=a.opacityTo,c=a.stops,d=s.enabled,g=s.left,u=s.top,p=s.blur,f=s.color,b=s.opacity,y=t.config.xaxis.crosshairs.fill.color;if(t.config.xaxis.crosshairs.show){"gradient"===r&&(y=e.drawGradient("vertical",o,n,l,h,null,c,null));var w=e.drawRect();1===t.config.xaxis.crosshairs.width&&(w=e.drawLine());var k=t.globals.gridHeight;(!x.isNumber(k)||k<0)&&(k=0);var A=t.config.xaxis.crosshairs.width;(!x.isNumber(A)||A<0)&&(A=0),w.attr({class:"apexcharts-xcrosshairs",x:0,y:0,y2:k,width:A,height:k,fill:y,filter:"none","fill-opacity":t.config.xaxis.crosshairs.opacity,stroke:t.config.xaxis.crosshairs.stroke.color,"stroke-width":t.config.xaxis.crosshairs.stroke.width,"stroke-dasharray":t.config.xaxis.crosshairs.stroke.dashArray}),d&&(w=i.dropShadow(w,{left:g,top:u,blur:p,color:f,opacity:b})),t.globals.dom.elGraphical.add(w)}}},{key:"drawYCrosshairs",value:function(){var t=this.w,e=new m(this.ctx),i=t.config.yaxis[0].crosshairs,a=t.globals.barPadForNumericAxis;if(t.config.yaxis[0].crosshairs.show){var s=e.drawLine(-a,0,t.globals.gridWidth+a,0,i.stroke.color,i.stroke.dashArray,i.stroke.width);s.attr({class:"apexcharts-ycrosshairs"}),t.globals.dom.elGraphical.add(s)}var r=e.drawLine(-a,0,t.globals.gridWidth+a,0,i.stroke.color,0,0);r.attr({class:"apexcharts-ycrosshairs-hidden"}),t.globals.dom.elGraphical.add(r)}}]),t}(),K=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"checkResponsiveConfig",value:function(t){var e=this,i=this.w,a=i.config;if(0!==a.responsive.length){var s=a.responsive.slice();s.sort((function(t,e){return t.breakpoint>e.breakpoint?1:e.breakpoint>t.breakpoint?-1:0})).reverse();var r=new E({}),o=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},a=s[0].breakpoint,o=window.innerWidth>0?window.innerWidth:screen.width;if(o>a){var n=y.extendArrayProps(r,i.globals.initialConfig,i);t=x.extend(n,t),t=x.extend(i.config,t),e.overrideResponsiveOptions(t)}else for(var l=0;l0&&"function"==typeof e.config.colors[0]&&(e.globals.colors=e.config.series.map((function(i,a){var s=e.config.colors[a];return s||(s=e.config.colors[0]),"function"==typeof s?(t.isColorFn=!0,s({value:e.globals.axisCharts?e.globals.series[a][0]?e.globals.series[a][0]:0:e.globals.series[a],seriesIndex:a,dataPointIndex:a,w:e})):s})))),e.globals.seriesColors.map((function(t,i){t&&(e.globals.colors[i]=t)})),e.config.theme.monochrome.enabled){var a=[],s=e.globals.series.length;(this.isBarDistributed||this.isHeatmapDistributed)&&(s=e.globals.series[0].length*e.globals.series.length);for(var r=e.config.theme.monochrome.color,o=1/(s/e.config.theme.monochrome.shadeIntensity),n=e.config.theme.monochrome.shadeTo,l=0,h=0;h2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,s=e||a.globals.series.length;if(null===i&&(i=this.isBarDistributed||this.isHeatmapDistributed||"heatmap"===a.config.chart.type&&a.config.plotOptions.heatmap.colorScale.inverse),i&&a.globals.series.length&&(s=a.globals.series[a.globals.maxValsInArrayIndex].length*a.globals.series.length),t.lengtht.globals.svgWidth&&(this.dCtx.lgRect.width=t.globals.svgWidth/1.5),this.dCtx.lgRect}},{key:"getLargestStringFromMultiArr",value:function(t,e){var i=t;if(this.w.globals.isMultiLineX){var a=e.map((function(t,e){return Array.isArray(t)?t.length:1})),s=Math.max.apply(Math,u(a));i=e[a.indexOf(s)]}return i}}]),t}(),at=function(){function t(e){a(this,t),this.w=e.w,this.dCtx=e}return r(t,[{key:"getxAxisLabelsCoords",value:function(){var t,e=this.w,i=e.globals.labels.slice();if(e.config.xaxis.convertedCatToNumeric&&0===i.length&&(i=e.globals.categoryLabels),e.globals.timescaleLabels.length>0){var a=this.getxAxisTimeScaleLabelsCoords();t={width:a.width,height:a.height},e.globals.rotateXLabels=!1}else{this.dCtx.lgWidthForSideLegends="left"!==e.config.legend.position&&"right"!==e.config.legend.position||e.config.legend.floating?0:this.dCtx.lgRect.width;var s=e.globals.xLabelFormatter,r=x.getLargestStringFromArr(i),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(r,i);e.globals.isBarHorizontal&&(o=r=e.globals.yAxisScale[0].result.reduce((function(t,e){return t.length>e.length?t:e}),0));var n=new T(this.dCtx.ctx),l=r;r=n.xLabelFormat(s,r,l,{i:void 0,dateFormatter:new I(this.dCtx.ctx).formatDate,w:e}),o=n.xLabelFormat(s,o,l,{i:void 0,dateFormatter:new I(this.dCtx.ctx).formatDate,w:e}),(e.config.xaxis.convertedCatToNumeric&&void 0===r||""===String(r).trim())&&(o=r="1");var h=new m(this.dCtx.ctx),c=h.getTextRects(r,e.config.xaxis.labels.style.fontSize),d=c;if(r!==o&&(d=h.getTextRects(o,e.config.xaxis.labels.style.fontSize)),(t={width:c.width>=d.width?c.width:d.width,height:c.height>=d.height?c.height:d.height}).width*i.length>e.globals.svgWidth-this.dCtx.lgWidthForSideLegends-this.dCtx.yAxisWidth-this.dCtx.gridPad.left-this.dCtx.gridPad.right&&0!==e.config.xaxis.labels.rotate||e.config.xaxis.labels.rotateAlways){if(!e.globals.isBarHorizontal){e.globals.rotateXLabels=!0;var g=function(t){return h.getTextRects(t,e.config.xaxis.labels.style.fontSize,e.config.xaxis.labels.style.fontFamily,"rotate(".concat(e.config.xaxis.labels.rotate," 0 0)"),!1)};c=g(r),r!==o&&(d=g(o)),t.height=(c.height>d.height?c.height:d.height)/1.5,t.width=c.width>d.width?c.width:d.width}}else e.globals.rotateXLabels=!1}return e.config.xaxis.labels.show||(t={width:0,height:0}),{width:t.width,height:t.height}}},{key:"getxAxisGroupLabelsCoords",value:function(){var t,e=this.w;if(!e.globals.hasXaxisGroups)return{width:0,height:0};var i,a=(null===(t=e.config.xaxis.group.style)||void 0===t?void 0:t.fontSize)||e.config.xaxis.labels.style.fontSize,s=e.globals.groups.map((function(t){return t.title})),r=x.getLargestStringFromArr(s),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(r,s),n=new m(this.dCtx.ctx),l=n.getTextRects(r,a),h=l;return r!==o&&(h=n.getTextRects(o,a)),i={width:l.width>=h.width?l.width:h.width,height:l.height>=h.height?l.height:h.height},e.config.xaxis.labels.show||(i={width:0,height:0}),{width:i.width,height:i.height}}},{key:"getxAxisTitleCoords",value:function(){var t=this.w,e=0,i=0;if(void 0!==t.config.xaxis.title.text){var a=new m(this.dCtx.ctx).getTextRects(t.config.xaxis.title.text,t.config.xaxis.title.style.fontSize);e=a.width,i=a.height}return{width:e,height:i}}},{key:"getxAxisTimeScaleLabelsCoords",value:function(){var t,e=this.w;this.dCtx.timescaleLabels=e.globals.timescaleLabels.slice();var i=this.dCtx.timescaleLabels.map((function(t){return t.value})),a=i.reduce((function(t,e){return void 0===t?(console.error("You have possibly supplied invalid Date format. Please supply a valid JavaScript Date"),0):t.length>e.length?t:e}),0);return 1.05*(t=new m(this.dCtx.ctx).getTextRects(a,e.config.xaxis.labels.style.fontSize)).width*i.length>e.globals.gridWidth&&0!==e.config.xaxis.labels.rotate&&(e.globals.overlappingXLabels=!0),t}},{key:"additionalPaddingXLabels",value:function(t){var e=this,i=this.w,a=i.globals,s=i.config,r=s.xaxis.type,o=t.width;a.skipLastTimelinelabel=!1,a.skipFirstTimelinelabel=!1;var n=i.config.yaxis[0].opposite&&i.globals.isBarHorizontal,l=function(t,n){s.yaxis.length>1&&function(t){return-1!==a.collapsedSeriesIndices.indexOf(t)}(n)||function(t){if(e.dCtx.timescaleLabels&&e.dCtx.timescaleLabels.length){var n=e.dCtx.timescaleLabels[0],l=e.dCtx.timescaleLabels[e.dCtx.timescaleLabels.length-1].position+o/1.75-e.dCtx.yAxisWidthRight,h=n.position-o/1.75+e.dCtx.yAxisWidthLeft,c="right"===i.config.legend.position&&e.dCtx.lgRect.width>0?e.dCtx.lgRect.width:0;l>a.svgWidth-a.translateX-c&&(a.skipLastTimelinelabel=!0),h<-(t.show&&!t.floating||"bar"!==s.chart.type&&"candlestick"!==s.chart.type&&"rangeBar"!==s.chart.type&&"boxPlot"!==s.chart.type?10:o/1.75)&&(a.skipFirstTimelinelabel=!0)}else"datetime"===r?e.dCtx.gridPad.rightString(n.niceMax).length?c:n.niceMax,g=h(d,{seriesIndex:o,dataPointIndex:-1,w:e}),u=g;if(void 0!==g&&0!==g.length||(g=d),e.globals.isBarHorizontal){a=0;var p=e.globals.labels.slice();g=h(g=x.getLargestStringFromArr(p),{seriesIndex:o,dataPointIndex:-1,w:e}),u=t.dCtx.dimHelpers.getLargestStringFromMultiArr(g,p)}var f=new m(t.dCtx.ctx),b="rotate(".concat(r.labels.rotate," 0 0)"),v=f.getTextRects(g,r.labels.style.fontSize,r.labels.style.fontFamily,b,!1),y=v;g!==u&&(y=f.getTextRects(u,r.labels.style.fontSize,r.labels.style.fontFamily,b,!1)),i.push({width:(l>y.width||l>v.width?l:y.width>v.width?y.width:v.width)+a,height:y.height>v.height?y.height:v.height})}else i.push({width:0,height:0})})),i}},{key:"getyAxisTitleCoords",value:function(){var t=this,e=this.w,i=[];return e.config.yaxis.map((function(e,a){if(e.show&&void 0!==e.title.text){var s=new m(t.dCtx.ctx),r="rotate(".concat(e.title.rotate," 0 0)"),o=s.getTextRects(e.title.text,e.title.style.fontSize,e.title.style.fontFamily,r,!1);i.push({width:o.width,height:o.height})}else i.push({width:0,height:0})})),i}},{key:"getTotalYAxisWidth",value:function(){var t=this.w,e=0,i=0,a=0,s=t.globals.yAxisScale.length>1?10:0,r=new B(this.dCtx.ctx),o=function(o,n){var l=t.config.yaxis[n].floating,h=0;o.width>0&&!l?(h=o.width+s,function(e){return t.globals.ignoreYAxisIndexes.indexOf(e)>-1}(n)&&(h=h-o.width-s)):h=l||r.isYAxisHidden(n)?0:5,t.config.yaxis[n].opposite?a+=h:i+=h,e+=h};return t.globals.yLabelsCoords.map((function(t,e){o(t,e)})),t.globals.yTitleCoords.map((function(t,e){o(t,e)})),t.globals.isBarHorizontal&&!t.config.yaxis[0].floating&&(e=t.globals.yLabelsCoords[0].width+t.globals.yTitleCoords[0].width+15),this.dCtx.yAxisWidthLeft=i,this.dCtx.yAxisWidthRight=a,e}}]),t}(),rt=function(){function t(e){a(this,t),this.w=e.w,this.dCtx=e}return r(t,[{key:"gridPadForColumnsInNumericAxis",value:function(t){var e=this.w;if(e.globals.noData||e.globals.allSeriesCollapsed)return 0;var i=function(t){return"bar"===t||"rangeBar"===t||"candlestick"===t||"boxPlot"===t},a=e.config.chart.type,s=0,r=i(a)?e.config.series.length:1;if(e.globals.comboBarCount>0&&(r=e.globals.comboBarCount),e.globals.collapsedSeries.forEach((function(t){i(t.type)&&(r-=1)})),e.config.chart.stacked&&(r=1),(i(a)||e.globals.comboBarCount>0)&&e.globals.isXNumeric&&!e.globals.isBarHorizontal&&r>0){var o,n,l=Math.abs(e.globals.initialMaxX-e.globals.initialMinX);l<=3&&(l=e.globals.dataPoints),o=l/t,e.globals.minXDiff&&e.globals.minXDiff/o>0&&(n=e.globals.minXDiff/o),n>t/2&&(n/=2),(s=n/r*parseInt(e.config.plotOptions.bar.columnWidth,10)/100)<1&&(s=1),s=s/(r>1?1:1.5)+5,e.globals.barPadForNumericAxis=s}return s}},{key:"gridPadFortitleSubtitle",value:function(){var t=this,e=this.w,i=e.globals,a=this.dCtx.isSparkline||!e.globals.axisCharts?0:10;["title","subtitle"].forEach((function(i){void 0!==e.config[i].text?a+=e.config[i].margin:a+=t.dCtx.isSparkline||!e.globals.axisCharts?0:5})),!e.config.legend.show||"bottom"!==e.config.legend.position||e.config.legend.floating||e.globals.axisCharts||(a+=10);var s=this.dCtx.dimHelpers.getTitleSubtitleCoords("title"),r=this.dCtx.dimHelpers.getTitleSubtitleCoords("subtitle");i.gridHeight=i.gridHeight-s.height-r.height-a,i.translateY=i.translateY+s.height+r.height+a}},{key:"setGridXPosForDualYAxis",value:function(t,e){var i=this.w,a=new B(this.dCtx.ctx);i.config.yaxis.map((function(s,r){-1!==i.globals.ignoreYAxisIndexes.indexOf(r)||s.floating||a.isYAxisHidden(r)||(s.opposite&&(i.globals.translateX=i.globals.translateX-(e[r].width+t[r].width)-parseInt(i.config.yaxis[r].labels.style.fontSize,10)/1.2-12),i.globals.translateX<2&&(i.globals.translateX=2))}))}}]),t}(),ot=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.lgRect={},this.yAxisWidth=0,this.yAxisWidthLeft=0,this.yAxisWidthRight=0,this.xAxisHeight=0,this.isSparkline=this.w.config.chart.sparkline.enabled,this.dimHelpers=new it(this),this.dimYAxis=new st(this),this.dimXAxis=new at(this),this.dimGrid=new rt(this),this.lgWidthForSideLegends=0,this.gridPad=this.w.config.grid.padding,this.xPadRight=0,this.xPadLeft=0}return r(t,[{key:"plotCoords",value:function(){var t=this,e=this.w,i=e.globals;this.lgRect=this.dimHelpers.getLegendsRect(),this.isSparkline&&(e.config.markers.discrete.length>0||e.config.markers.size>0)&&Object.entries(this.gridPad).forEach((function(e){var i=g(e,2),a=i[0],s=i[1];t.gridPad[a]=Math.max(s,t.w.globals.markers.largestSize/1.5)})),i.axisCharts?this.setDimensionsForAxisCharts():this.setDimensionsForNonAxisCharts(),this.dimGrid.gridPadFortitleSubtitle(),i.gridHeight=i.gridHeight-this.gridPad.top-this.gridPad.bottom,i.gridWidth=i.gridWidth-this.gridPad.left-this.gridPad.right-this.xPadRight-this.xPadLeft;var a=this.dimGrid.gridPadForColumnsInNumericAxis(i.gridWidth);i.gridWidth=i.gridWidth-2*a,i.translateX=i.translateX+this.gridPad.left+this.xPadLeft+(a>0?a+4:0),i.translateY=i.translateY+this.gridPad.top}},{key:"setDimensionsForAxisCharts",value:function(){var t=this,e=this.w,i=e.globals,a=this.dimYAxis.getyAxisLabelsCoords(),s=this.dimYAxis.getyAxisTitleCoords();e.globals.yLabelsCoords=[],e.globals.yTitleCoords=[],e.config.yaxis.map((function(t,i){e.globals.yLabelsCoords.push({width:a[i].width,index:i}),e.globals.yTitleCoords.push({width:s[i].width,index:i})})),this.yAxisWidth=this.dimYAxis.getTotalYAxisWidth();var r=this.dimXAxis.getxAxisLabelsCoords(),o=this.dimXAxis.getxAxisGroupLabelsCoords(),n=this.dimXAxis.getxAxisTitleCoords();this.conditionalChecksForAxisCoords(r,n,o),i.translateXAxisY=e.globals.rotateXLabels?this.xAxisHeight/8:-4,i.translateXAxisX=e.globals.rotateXLabels&&e.globals.isXNumeric&&e.config.xaxis.labels.rotate<=-45?-this.xAxisWidth/4:0,e.globals.isBarHorizontal&&(i.rotateXLabels=!1,i.translateXAxisY=parseInt(e.config.xaxis.labels.style.fontSize,10)/1.5*-1),i.translateXAxisY=i.translateXAxisY+e.config.xaxis.labels.offsetY,i.translateXAxisX=i.translateXAxisX+e.config.xaxis.labels.offsetX;var l=this.yAxisWidth,h=this.xAxisHeight;i.xAxisLabelsHeight=this.xAxisHeight-n.height,i.xAxisGroupLabelsHeight=i.xAxisLabelsHeight-r.height,i.xAxisLabelsWidth=this.xAxisWidth,i.xAxisHeight=this.xAxisHeight;var c=10;("radar"===e.config.chart.type||this.isSparkline)&&(l=0,h=i.goldenPadding),this.isSparkline&&(this.lgRect={height:0,width:0}),(this.isSparkline||"treemap"===e.config.chart.type)&&(l=0,h=0,c=0),this.isSparkline||this.dimXAxis.additionalPaddingXLabels(r);var d=function(){i.translateX=l,i.gridHeight=i.svgHeight-t.lgRect.height-h-(t.isSparkline||"treemap"===e.config.chart.type?0:e.globals.rotateXLabels?10:15),i.gridWidth=i.svgWidth-l};switch("top"===e.config.xaxis.position&&(c=i.xAxisHeight-e.config.xaxis.axisTicks.height-5),e.config.legend.position){case"bottom":i.translateY=c,d();break;case"top":i.translateY=this.lgRect.height+c,d();break;case"left":i.translateY=c,i.translateX=this.lgRect.width+l,i.gridHeight=i.svgHeight-h-12,i.gridWidth=i.svgWidth-this.lgRect.width-l;break;case"right":i.translateY=c,i.translateX=l,i.gridHeight=i.svgHeight-h-12,i.gridWidth=i.svgWidth-this.lgRect.width-l-5;break;default:throw new Error("Legend position not supported")}this.dimGrid.setGridXPosForDualYAxis(s,a),new q(this.ctx).setYAxisXPosition(a,s)}},{key:"setDimensionsForNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=t.config,a=0;t.config.legend.show&&!t.config.legend.floating&&(a=20);var s="pie"===i.chart.type||"polarArea"===i.chart.type||"donut"===i.chart.type?"pie":"radialBar",r=i.plotOptions[s].offsetY,o=i.plotOptions[s].offsetX;if(!i.legend.show||i.legend.floating)return e.gridHeight=e.svgHeight-i.grid.padding.left+i.grid.padding.right,e.gridWidth=e.gridHeight,e.translateY=r,void(e.translateX=o+(e.svgWidth-e.gridWidth)/2);switch(i.legend.position){case"bottom":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=r-10,e.translateX=o+(e.svgWidth-e.gridWidth)/2;break;case"top":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=this.lgRect.height+r+10,e.translateX=o+(e.svgWidth-e.gridWidth)/2;break;case"left":e.gridWidth=e.svgWidth-this.lgRect.width-a,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=r,e.translateX=o+this.lgRect.width+a;break;case"right":e.gridWidth=e.svgWidth-this.lgRect.width-a-5,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=r,e.translateX=o+10;break;default:throw new Error("Legend position not supported")}}},{key:"conditionalChecksForAxisCoords",value:function(t,e,i){var a=this.w,s=a.globals.hasXaxisGroups?2:1,r=i.height+t.height+e.height,o=a.globals.isMultiLineX?1.2:a.globals.LINE_HEIGHT_RATIO,n=a.globals.rotateXLabels?22:10,l=a.globals.rotateXLabels&&"bottom"===a.config.legend.position?10:0;this.xAxisHeight=r*o+s*n+l,this.xAxisWidth=t.width,this.xAxisHeight-e.height>a.config.xaxis.labels.maxHeight&&(this.xAxisHeight=a.config.xaxis.labels.maxHeight),a.config.xaxis.labels.minHeight&&this.xAxisHeightc&&(this.yAxisWidth=c)}}]),t}(),nt=function(){function t(e){a(this,t),this.w=e.w,this.lgCtx=e}return r(t,[{key:"getLegendStyles",value:function(){var t=document.createElement("style");t.setAttribute("type","text/css");var e=document.createTextNode("\t\n \t\n .apexcharts-legend {\t\n display: flex;\t\n overflow: auto;\t\n padding: 0 10px;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom, .apexcharts-legend.apx-legend-position-top {\t\n flex-wrap: wrap\t\n }\t\n .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n flex-direction: column;\t\n bottom: 0;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-left, .apexcharts-legend.apx-legend-position-top.apexcharts-align-left, .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n justify-content: flex-start;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-center, .apexcharts-legend.apx-legend-position-top.apexcharts-align-center {\t\n justify-content: center; \t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-right, .apexcharts-legend.apx-legend-position-top.apexcharts-align-right {\t\n justify-content: flex-end;\t\n }\t\n .apexcharts-legend-series {\t\n cursor: pointer;\t\n line-height: normal;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom .apexcharts-legend-series, .apexcharts-legend.apx-legend-position-top .apexcharts-legend-series{\t\n display: flex;\t\n align-items: center;\t\n }\t\n .apexcharts-legend-text {\t\n position: relative;\t\n font-size: 14px;\t\n }\t\n .apexcharts-legend-text *, .apexcharts-legend-marker * {\t\n pointer-events: none;\t\n }\t\n .apexcharts-legend-marker {\t\n position: relative;\t\n display: inline-block;\t\n cursor: pointer;\t\n margin-right: 3px;\t\n border-style: solid;\n }\t\n \t\n .apexcharts-legend.apexcharts-align-right .apexcharts-legend-series, .apexcharts-legend.apexcharts-align-left .apexcharts-legend-series{\t\n display: inline-block;\t\n }\t\n .apexcharts-legend-series.apexcharts-no-click {\t\n cursor: auto;\t\n }\t\n .apexcharts-legend .apexcharts-hidden-zero-series, .apexcharts-legend .apexcharts-hidden-null-series {\t\n display: none !important;\t\n }\t\n .apexcharts-inactive-legend {\t\n opacity: 0.45;\t\n }");return t.appendChild(e),t}},{key:"getLegendBBox",value:function(){var t=this.w.globals.dom.baseEl.querySelector(".apexcharts-legend").getBoundingClientRect(),e=t.width;return{clwh:t.height,clww:e}}},{key:"appendToForeignObject",value:function(){this.w.globals.dom.elLegendForeign.appendChild(this.getLegendStyles())}},{key:"toggleDataSeries",value:function(t,e){var i=this,a=this.w;if(a.globals.axisCharts||"radialBar"===a.config.chart.type){a.globals.resized=!0;var s=null,r=null;if(a.globals.risingSeries=[],a.globals.axisCharts?(s=a.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(t,"']")),r=parseInt(s.getAttribute("data:realIndex"),10)):(s=a.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(t+1,"']")),r=parseInt(s.getAttribute("rel"),10)-1),e)[{cs:a.globals.collapsedSeries,csi:a.globals.collapsedSeriesIndices},{cs:a.globals.ancillaryCollapsedSeries,csi:a.globals.ancillaryCollapsedSeriesIndices}].forEach((function(t){i.riseCollapsedSeries(t.cs,t.csi,r)}));else this.hideSeries({seriesEl:s,realIndex:r})}else{var o=a.globals.dom.Paper.select(" .apexcharts-series[rel='".concat(t+1,"'] path")),n=a.config.chart.type;if("pie"===n||"polarArea"===n||"donut"===n){var l=a.config.plotOptions.pie.donut.labels;new m(this.lgCtx.ctx).pathMouseDown(o.members[0],null),this.lgCtx.ctx.pie.printDataLabelsInner(o.members[0].node,l)}o.fire("click")}}},{key:"hideSeries",value:function(t){var e=t.seriesEl,i=t.realIndex,a=this.w,s=x.clone(a.config.series);if(a.globals.axisCharts){var r=!1;if(a.config.yaxis[i]&&a.config.yaxis[i].show&&a.config.yaxis[i].showAlways&&(r=!0,a.globals.ancillaryCollapsedSeriesIndices.indexOf(i)<0&&(a.globals.ancillaryCollapsedSeries.push({index:i,data:s[i].data.slice(),type:e.parentNode.className.baseVal.split("-")[1]}),a.globals.ancillaryCollapsedSeriesIndices.push(i))),!r){a.globals.collapsedSeries.push({index:i,data:s[i].data.slice(),type:e.parentNode.className.baseVal.split("-")[1]}),a.globals.collapsedSeriesIndices.push(i);var o=a.globals.risingSeries.indexOf(i);a.globals.risingSeries.splice(o,1)}}else a.globals.collapsedSeries.push({index:i,data:s[i]}),a.globals.collapsedSeriesIndices.push(i);for(var n=e.childNodes,l=0;l0){for(var r=0;r-1&&(t[a].data=[])})):t.forEach((function(i,a){e.globals.collapsedSeriesIndices.indexOf(a)>-1&&(t[a]=0)})),t}}]),t}(),lt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.onLegendClick=this.onLegendClick.bind(this),this.onLegendHovered=this.onLegendHovered.bind(this),this.isBarsDistributed="bar"===this.w.config.chart.type&&this.w.config.plotOptions.bar.distributed&&1===this.w.config.series.length,this.legendHelpers=new nt(this)}return r(t,[{key:"init",value:function(){var t=this.w,e=t.globals,i=t.config;if((i.legend.showForSingleSeries&&1===e.series.length||this.isBarsDistributed||e.series.length>1||!e.axisCharts)&&i.legend.show){for(;e.dom.elLegendWrap.firstChild;)e.dom.elLegendWrap.removeChild(e.dom.elLegendWrap.firstChild);this.drawLegends(),x.isIE11()?document.getElementsByTagName("head")[0].appendChild(this.legendHelpers.getLegendStyles()):this.legendHelpers.appendToForeignObject(),"bottom"===i.legend.position||"top"===i.legend.position?this.legendAlignHorizontal():"right"!==i.legend.position&&"left"!==i.legend.position||this.legendAlignVertical()}}},{key:"drawLegends",value:function(){var t=this,e=this.w,i=e.config.legend.fontFamily,a=e.globals.seriesNames,s=e.globals.colors.slice();if("heatmap"===e.config.chart.type){var r=e.config.plotOptions.heatmap.colorScale.ranges;a=r.map((function(t){return t.name?t.name:t.from+" - "+t.to})),s=r.map((function(t){return t.color}))}else this.isBarsDistributed&&(a=e.globals.labels.slice());e.config.legend.customLegendItems.length&&(a=e.config.legend.customLegendItems);for(var o=e.globals.legendFormatter,n=e.config.legend.inverseOrder,l=n?a.length-1:0;n?l>=0:l<=a.length-1;n?l--:l++){var h=o(a[l],{seriesIndex:l,w:e}),c=!1,d=!1;if(e.globals.collapsedSeries.length>0)for(var g=0;g0)for(var u=0;u0?l-10:0)+(h>0?h-10:0)}a.style.position="absolute",r=r+t+i.config.legend.offsetX,o=o+e+i.config.legend.offsetY,a.style.left=r+"px",a.style.top=o+"px","bottom"===i.config.legend.position?(a.style.top="auto",a.style.bottom=5-i.config.legend.offsetY+"px"):"right"===i.config.legend.position&&(a.style.left="auto",a.style.right=25+i.config.legend.offsetX+"px");["width","height"].forEach((function(t){a.style[t]&&(a.style[t]=parseInt(i.config.legend[t],10)+"px")}))}},{key:"legendAlignHorizontal",value:function(){var t=this.w;t.globals.dom.elLegendWrap.style.right=0;var e=this.legendHelpers.getLegendBBox(),i=new ot(this.ctx),a=i.dimHelpers.getTitleSubtitleCoords("title"),s=i.dimHelpers.getTitleSubtitleCoords("subtitle"),r=0;"bottom"===t.config.legend.position?r=-e.clwh/1.8:"top"===t.config.legend.position&&(r=a.height+s.height+t.config.title.margin+t.config.subtitle.margin-10),this.setLegendWrapXY(20,r)}},{key:"legendAlignVertical",value:function(){var t=this.w,e=this.legendHelpers.getLegendBBox(),i=0;"left"===t.config.legend.position&&(i=20),"right"===t.config.legend.position&&(i=t.globals.svgWidth-e.clww-10),this.setLegendWrapXY(i,20)}},{key:"onLegendHovered",value:function(t){var e=this.w,i=t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker");if("heatmap"===e.config.chart.type||this.isBarsDistributed){if(i){var a=parseInt(t.target.getAttribute("rel"),10)-1;this.ctx.events.fireEvent("legendHover",[this.ctx,a,this.w]),new N(this.ctx).highlightRangeInSeries(t,t.target)}}else!t.target.classList.contains("apexcharts-inactive-legend")&&i&&new N(this.ctx).toggleSeriesOnHover(t,t.target)}},{key:"onLegendClick",value:function(t){var e=this.w;if(!e.config.legend.customLegendItems.length&&(t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker"))){var i=parseInt(t.target.getAttribute("rel"),10)-1,a="true"===t.target.getAttribute("data:collapsed"),s=this.w.config.chart.events.legendClick;"function"==typeof s&&s(this.ctx,i,this.w),this.ctx.events.fireEvent("legendClick",[this.ctx,i,this.w]);var r=this.w.config.legend.markers.onClick;"function"==typeof r&&t.target.classList.contains("apexcharts-legend-marker")&&(r(this.ctx,i,this.w),this.ctx.events.fireEvent("legendMarkerClick",[this.ctx,i,this.w])),"treemap"!==e.config.chart.type&&"heatmap"!==e.config.chart.type&&!this.isBarsDistributed&&e.config.legend.onItemClick.toggleDataSeries&&this.legendHelpers.toggleDataSeries(i,a)}}}]),t}(),ht=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w;var i=this.w;this.ev=this.w.config.chart.events,this.selectedClass="apexcharts-selected",this.localeValues=this.w.globals.locale.toolbar,this.minX=i.globals.minX,this.maxX=i.globals.maxX}return r(t,[{key:"createToolbar",value:function(){var t=this,e=this.w,i=function(){return document.createElement("div")},a=i();if(a.setAttribute("class","apexcharts-toolbar"),a.style.top=e.config.chart.toolbar.offsetY+"px",a.style.right=3-e.config.chart.toolbar.offsetX+"px",e.globals.dom.elWrap.appendChild(a),this.elZoom=i(),this.elZoomIn=i(),this.elZoomOut=i(),this.elPan=i(),this.elSelection=i(),this.elZoomReset=i(),this.elMenuIcon=i(),this.elMenu=i(),this.elCustomIcons=[],this.t=e.config.chart.toolbar.tools,Array.isArray(this.t.customIcons))for(var s=0;s\n \n \n\n'),o("zoomOut",this.elZoomOut,'\n \n \n\n');var n=function(i){t.t[i]&&e.config.chart[i].enabled&&r.push({el:"zoom"===i?t.elZoom:t.elSelection,icon:"string"==typeof t.t[i]?t.t[i]:"zoom"===i?'\n \n \n \n':'\n \n \n',title:t.localeValues["zoom"===i?"selectionZoom":"selection"],class:e.globals.isTouchDevice?"apexcharts-element-hidden":"apexcharts-".concat(i,"-icon")})};n("zoom"),n("selection"),this.t.pan&&e.config.chart.zoom.enabled&&r.push({el:this.elPan,icon:"string"==typeof this.t.pan?this.t.pan:'\n \n \n \n \n \n \n \n',title:this.localeValues.pan,class:e.globals.isTouchDevice?"apexcharts-element-hidden":"apexcharts-pan-icon"}),o("reset",this.elZoomReset,'\n \n \n'),this.t.download&&r.push({el:this.elMenuIcon,icon:"string"==typeof this.t.download?this.t.download:'',title:this.localeValues.menu,class:"apexcharts-menu-icon"});for(var l=0;l0&&e.height>0&&this.slDraggableRect.selectize({points:"l, r",pointSize:8,pointType:"rect"}).resize({constraint:{minX:0,minY:0,maxX:t.globals.gridWidth,maxY:t.globals.gridHeight}}).on("resizing",this.selectionDragging.bind(this,"resizing"))}}},{key:"preselectedSelection",value:function(){var t=this.w,e=this.xyRatios;if(!t.globals.zoomEnabled)if(void 0!==t.globals.selection&&null!==t.globals.selection)this.drawSelectionRect(t.globals.selection);else if(void 0!==t.config.chart.selection.xaxis.min&&void 0!==t.config.chart.selection.xaxis.max){var i=(t.config.chart.selection.xaxis.min-t.globals.minX)/e.xRatio,a={x:i,y:0,width:t.globals.gridWidth-(t.globals.maxX-t.config.chart.selection.xaxis.max)/e.xRatio-i,height:t.globals.gridHeight,translateX:0,translateY:0,selectionEnabled:!0};this.drawSelectionRect(a),this.makeSelectionRectDraggable(),"function"==typeof t.config.chart.events.selection&&t.config.chart.events.selection(this.ctx,{xaxis:{min:t.config.chart.selection.xaxis.min,max:t.config.chart.selection.xaxis.max},yaxis:{}})}}},{key:"drawSelectionRect",value:function(t){var e=t.x,i=t.y,a=t.width,s=t.height,r=t.translateX,o=void 0===r?0:r,n=t.translateY,l=void 0===n?0:n,h=this.w,c=this.zoomRect,d=this.selectionRect;if(this.dragged||null!==h.globals.selection){var g={transform:"translate("+o+", "+l+")"};h.globals.zoomEnabled&&this.dragged&&(a<0&&(a=1),c.attr({x:e,y:i,width:a,height:s,fill:h.config.chart.zoom.zoomedArea.fill.color,"fill-opacity":h.config.chart.zoom.zoomedArea.fill.opacity,stroke:h.config.chart.zoom.zoomedArea.stroke.color,"stroke-width":h.config.chart.zoom.zoomedArea.stroke.width,"stroke-opacity":h.config.chart.zoom.zoomedArea.stroke.opacity}),m.setAttrs(c.node,g)),h.globals.selectionEnabled&&(d.attr({x:e,y:i,width:a>0?a:0,height:s>0?s:0,fill:h.config.chart.selection.fill.color,"fill-opacity":h.config.chart.selection.fill.opacity,stroke:h.config.chart.selection.stroke.color,"stroke-width":h.config.chart.selection.stroke.width,"stroke-dasharray":h.config.chart.selection.stroke.dashArray,"stroke-opacity":h.config.chart.selection.stroke.opacity}),m.setAttrs(d.node,g))}}},{key:"hideSelectionRect",value:function(t){t&&t.attr({x:0,y:0,width:0,height:0})}},{key:"selectionDrawing",value:function(t){var e=t.context,i=t.zoomtype,a=this.w,s=e,r=this.gridRect.getBoundingClientRect(),o=s.startX-1,n=s.startY,l=!1,h=!1,c=s.clientX-r.left-o,d=s.clientY-r.top-n,g={};return Math.abs(c+o)>a.globals.gridWidth?c=a.globals.gridWidth-o:s.clientX-r.left<0&&(c=o),o>s.clientX-r.left&&(l=!0,c=Math.abs(c)),n>s.clientY-r.top&&(h=!0,d=Math.abs(d)),g="x"===i?{x:l?o-c:o,y:0,width:c,height:a.globals.gridHeight}:"y"===i?{x:0,y:h?n-d:n,width:a.globals.gridWidth,height:d}:{x:l?o-c:o,y:h?n-d:n,width:c,height:d},s.drawSelectionRect(g),s.selectionDragging("resizing"),g}},{key:"selectionDragging",value:function(t,e){var i=this,a=this.w,s=this.xyRatios,r=this.selectionRect,o=0;"resizing"===t&&(o=30);var n=function(t){return parseFloat(r.node.getAttribute(t))},l={x:n("x"),y:n("y"),width:n("width"),height:n("height")};a.globals.selection=l,"function"==typeof a.config.chart.events.selection&&a.globals.selectionEnabled&&(clearTimeout(this.w.globals.selectionResizeTimer),this.w.globals.selectionResizeTimer=window.setTimeout((function(){var t=i.gridRect.getBoundingClientRect(),e=r.node.getBoundingClientRect(),o={xaxis:{min:a.globals.xAxisScale.niceMin+(e.left-t.left)*s.xRatio,max:a.globals.xAxisScale.niceMin+(e.right-t.left)*s.xRatio},yaxis:{min:a.globals.yAxisScale[0].niceMin+(t.bottom-e.bottom)*s.yRatio[0],max:a.globals.yAxisScale[0].niceMax-(e.top-t.top)*s.yRatio[0]}};a.config.chart.events.selection(i.ctx,o),a.config.chart.brush.enabled&&void 0!==a.config.chart.events.brushScrolled&&a.config.chart.events.brushScrolled(i.ctx,o)}),o))}},{key:"selectionDrawn",value:function(t){var e=t.context,i=t.zoomtype,a=this.w,s=e,r=this.xyRatios,o=this.ctx.toolbar;if(s.startX>s.endX){var n=s.startX;s.startX=s.endX,s.endX=n}if(s.startY>s.endY){var l=s.startY;s.startY=s.endY,s.endY=l}var h=void 0,c=void 0;a.globals.isRangeBar?(h=a.globals.yAxisScale[0].niceMin+s.startX*r.invertedYRatio,c=a.globals.yAxisScale[0].niceMin+s.endX*r.invertedYRatio):(h=a.globals.xAxisScale.niceMin+s.startX*r.xRatio,c=a.globals.xAxisScale.niceMin+s.endX*r.xRatio);var d=[],g=[];if(a.config.yaxis.forEach((function(t,e){d.push(a.globals.yAxisScale[e].niceMax-r.yRatio[e]*s.startY),g.push(a.globals.yAxisScale[e].niceMax-r.yRatio[e]*s.endY)})),s.dragged&&(s.dragX>10||s.dragY>10)&&h!==c)if(a.globals.zoomEnabled){var u=x.clone(a.globals.initialConfig.yaxis),p=x.clone(a.globals.initialConfig.xaxis);if(a.globals.zoomed=!0,a.config.xaxis.convertedCatToNumeric&&(h=Math.floor(h),c=Math.floor(c),h<1&&(h=1,c=a.globals.dataPoints),c-h<2&&(c=h+1)),"xy"!==i&&"x"!==i||(p={min:h,max:c}),"xy"!==i&&"y"!==i||u.forEach((function(t,e){u[e].min=g[e],u[e].max=d[e]})),a.config.chart.zoom.autoScaleYaxis){var f=new _(s.ctx);u=f.autoScaleY(s.ctx,u,{xaxis:p})}if(o){var b=o.getBeforeZoomRange(p,u);b&&(p=b.xaxis?b.xaxis:p,u=b.yaxis?b.yaxis:u)}var v={xaxis:p};a.config.chart.group||(v.yaxis=u),s.ctx.updateHelpers._updateOptions(v,!1,s.w.config.chart.animations.dynamicAnimation.enabled),"function"==typeof a.config.chart.events.zoomed&&o.zoomCallback(p,u)}else if(a.globals.selectionEnabled){var m,y=null;m={min:h,max:c},"xy"!==i&&"y"!==i||(y=x.clone(a.config.yaxis)).forEach((function(t,e){y[e].min=g[e],y[e].max=d[e]})),a.globals.selection=s.selection,"function"==typeof a.config.chart.events.selection&&a.config.chart.events.selection(s.ctx,{xaxis:m,yaxis:y})}}},{key:"panDragging",value:function(t){var e=t.context,i=this.w,a=e;if(void 0!==i.globals.lastClientPosition.x){var s=i.globals.lastClientPosition.x-a.clientX,r=i.globals.lastClientPosition.y-a.clientY;Math.abs(s)>Math.abs(r)&&s>0?this.moveDirection="left":Math.abs(s)>Math.abs(r)&&s<0?this.moveDirection="right":Math.abs(r)>Math.abs(s)&&r>0?this.moveDirection="up":Math.abs(r)>Math.abs(s)&&r<0&&(this.moveDirection="down")}i.globals.lastClientPosition={x:a.clientX,y:a.clientY};var o=i.globals.isRangeBar?i.globals.minY:i.globals.minX,n=i.globals.isRangeBar?i.globals.maxY:i.globals.maxX;i.config.xaxis.convertedCatToNumeric||a.panScrolled(o,n)}},{key:"delayedPanScrolled",value:function(){var t=this.w,e=t.globals.minX,i=t.globals.maxX,a=(t.globals.maxX-t.globals.minX)/2;"left"===this.moveDirection?(e=t.globals.minX+a,i=t.globals.maxX+a):"right"===this.moveDirection&&(e=t.globals.minX-a,i=t.globals.maxX-a),e=Math.floor(e),i=Math.floor(i),this.updateScrolledChart({xaxis:{min:e,max:i}},e,i)}},{key:"panScrolled",value:function(t,e){var i=this.w,a=this.xyRatios,s=x.clone(i.globals.initialConfig.yaxis),r=a.xRatio,o=i.globals.minX,n=i.globals.maxX;i.globals.isRangeBar&&(r=a.invertedYRatio,o=i.globals.minY,n=i.globals.maxY),"left"===this.moveDirection?(t=o+i.globals.gridWidth/15*r,e=n+i.globals.gridWidth/15*r):"right"===this.moveDirection&&(t=o-i.globals.gridWidth/15*r,e=n-i.globals.gridWidth/15*r),i.globals.isRangeBar||(ti.globals.initialMaxX)&&(t=o,e=n);var l={min:t,max:e};i.config.chart.zoom.autoScaleYaxis&&(s=new _(this.ctx).autoScaleY(this.ctx,s,{xaxis:l}));var h={xaxis:{min:t,max:e}};i.config.chart.group||(h.yaxis=s),this.updateScrolledChart(h,t,e)}},{key:"updateScrolledChart",value:function(t,e,i){var a=this.w;this.ctx.updateHelpers._updateOptions(t,!1,!1),"function"==typeof a.config.chart.events.scrolled&&a.config.chart.events.scrolled(this.ctx,{xaxis:{min:e,max:i}})}}]),i}(),dt=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e,this.ctx=e.ctx}return r(t,[{key:"getNearestValues",value:function(t){var e=t.hoverArea,i=t.elGrid,a=t.clientX,s=t.clientY,r=this.w,o=i.getBoundingClientRect(),n=o.width,l=o.height,h=n/(r.globals.dataPoints-1),c=l/r.globals.dataPoints,d=this.hasBars();!r.globals.comboCharts&&!d||r.config.xaxis.convertedCatToNumeric||(h=n/r.globals.dataPoints);var g=a-o.left-r.globals.barPadForNumericAxis,u=s-o.top;g<0||u<0||g>n||u>l?(e.classList.remove("hovering-zoom"),e.classList.remove("hovering-pan")):r.globals.zoomEnabled?(e.classList.remove("hovering-pan"),e.classList.add("hovering-zoom")):r.globals.panEnabled&&(e.classList.remove("hovering-zoom"),e.classList.add("hovering-pan"));var p=Math.round(g/h),f=Math.floor(u/c);d&&!r.config.xaxis.convertedCatToNumeric&&(p=Math.ceil(g/h),p-=1);var b=null,v=null,m=[],y=[];if(r.globals.seriesXvalues.forEach((function(t){m.push([t[0]+1e-6].concat(t))})),r.globals.seriesYvalues.forEach((function(t){y.push([t[0]+1e-6].concat(t))})),m=m.map((function(t){return t.filter((function(t){return x.isNumber(t)}))})),y=y.map((function(t){return t.filter((function(t){return x.isNumber(t)}))})),r.globals.isXNumeric){var w=this.ttCtx.getElGrid().getBoundingClientRect(),k=g*(w.width/n),A=u*(w.height/l);b=(v=this.closestInMultiArray(k,A,m,y)).index,p=v.j,null!==b&&(m=r.globals.seriesXvalues[b],p=(v=this.closestInArray(k,m)).index)}return r.globals.capturedSeriesIndex=null===b?-1:b,(!p||p<1)&&(p=0),r.globals.isBarHorizontal?r.globals.capturedDataPointIndex=f:r.globals.capturedDataPointIndex=p,{capturedSeries:b,j:r.globals.isBarHorizontal?f:p,hoverX:g,hoverY:u}}},{key:"closestInMultiArray",value:function(t,e,i,a){var s=this.w,r=0,o=null,n=-1;s.globals.series.length>1?r=this.getFirstActiveXArray(i):o=0;var l=i[r][0],h=Math.abs(t-l);if(i.forEach((function(e){e.forEach((function(e,i){var a=Math.abs(t-e);a0?e:-1})),s=0;s0)for(var a=0;a *")):this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap > *")}},{key:"getAllMarkers",value:function(){var t=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap");(t=u(t)).sort((function(t,e){var i=Number(t.getAttribute("data:realIndex")),a=Number(e.getAttribute("data:realIndex"));return ai?-1:0}));var e=[];return t.forEach((function(t){e.push(t.querySelector(".apexcharts-marker"))})),e}},{key:"hasMarkers",value:function(t){return this.getElMarkers(t).length>0}},{key:"getElBars",value:function(){return this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-bar-series, .apexcharts-candlestick-series, .apexcharts-boxPlot-series, .apexcharts-rangebar-series")}},{key:"hasBars",value:function(){return this.getElBars().length>0}},{key:"getHoverMarkerSize",value:function(t){var e=this.w,i=e.config.markers.hover.size;return void 0===i&&(i=e.globals.markers.size[t]+e.config.markers.hover.sizeOffset),i}},{key:"toggleAllTooltipSeriesGroups",value:function(t){var e=this.w,i=this.ttCtx;0===i.allTooltipSeriesGroups.length&&(i.allTooltipSeriesGroups=e.globals.dom.baseEl.querySelectorAll(".apexcharts-tooltip-series-group"));for(var a=i.allTooltipSeriesGroups,s=0;s ').concat(i.attrs.name,""),e+="
".concat(i.val,"
")})),v.innerHTML=t+"",m.innerHTML=e+""};o?l.globals.seriesGoals[e][i]&&Array.isArray(l.globals.seriesGoals[e][i])?y():(v.innerHTML="",m.innerHTML=""):y()}else v.innerHTML="",m.innerHTML="";null!==p&&(a[e].querySelector(".apexcharts-tooltip-text-z-label").innerHTML=l.config.tooltip.z.title,a[e].querySelector(".apexcharts-tooltip-text-z-value").innerHTML=void 0!==p?p:"");o&&f[0]&&(null==c||l.globals.ancillaryCollapsedSeriesIndices.indexOf(e)>-1||l.globals.collapsedSeriesIndices.indexOf(e)>-1?f[0].parentNode.style.display="none":f[0].parentNode.style.display=l.config.tooltip.items.display)}},{key:"toggleActiveInactiveSeries",value:function(t){var e=this.w;if(t)this.tooltipUtil.toggleAllTooltipSeriesGroups("enable");else{this.tooltipUtil.toggleAllTooltipSeriesGroups("disable");var i=e.globals.dom.baseEl.querySelector(".apexcharts-tooltip-series-group");i&&(i.classList.add("apexcharts-active"),i.style.display=e.config.tooltip.items.display)}}},{key:"getValuesToPrint",value:function(t){var e=t.i,i=t.j,a=this.w,s=this.ctx.series.filteredSeriesX(),r="",o="",n=null,l=null,h={series:a.globals.series,seriesIndex:e,dataPointIndex:i,w:a},c=a.globals.ttZFormatter;null===i?l=a.globals.series[e]:a.globals.isXNumeric&&"treemap"!==a.config.chart.type?(r=s[e][i],0===s[e].length&&(r=s[this.tooltipUtil.getFirstActiveXArray(s)][i])):r=void 0!==a.globals.labels[i]?a.globals.labels[i]:"";var d=r;a.globals.isXNumeric&&"datetime"===a.config.xaxis.type?r=new T(this.ctx).xLabelFormat(a.globals.ttKeyFormatter,d,d,{i:void 0,dateFormatter:new I(this.ctx).formatDate,w:this.w}):r=a.globals.isBarHorizontal?a.globals.yLabelFormatters[0](d,h):a.globals.xLabelFormatter(d,h);return void 0!==a.config.tooltip.x.formatter&&(r=a.globals.ttKeyFormatter(d,h)),a.globals.seriesZ.length>0&&a.globals.seriesZ[e].length>0&&(n=c(a.globals.seriesZ[e][i],a)),o="function"==typeof a.config.xaxis.tooltip.formatter?a.globals.xaxisTooltipFormatter(d,h):r,{val:Array.isArray(l)?l.join(" "):l,xVal:Array.isArray(r)?r.join(" "):r,xAxisTTVal:Array.isArray(o)?o.join(" "):o,zVal:n}}},{key:"handleCustomTooltip",value:function(t){var e=t.i,i=t.j,a=t.y1,s=t.y2,r=t.w,o=this.ttCtx.getElTooltip(),n=r.config.tooltip.custom;Array.isArray(n)&&n[e]&&(n=n[e]),o.innerHTML=n({ctx:this.ctx,series:r.globals.series,seriesIndex:e,dataPointIndex:i,y1:a,y2:s,w:r})}}]),t}(),ut=function(){function t(e){a(this,t),this.ttCtx=e,this.ctx=e.ctx,this.w=e.w}return r(t,[{key:"moveXCrosshairs",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=this.ttCtx,a=this.w,s=i.getElXCrosshairs(),r=t-i.xcrosshairsWidth/2,o=a.globals.labels.slice().length;if(null!==e&&(r=a.globals.gridWidth/o*e),null===s||a.globals.isBarHorizontal||(s.setAttribute("x",r),s.setAttribute("x1",r),s.setAttribute("x2",r),s.setAttribute("y2",a.globals.gridHeight),s.classList.add("apexcharts-active")),r<0&&(r=0),r>a.globals.gridWidth&&(r=a.globals.gridWidth),i.isXAxisTooltipEnabled){var n=r;"tickWidth"!==a.config.xaxis.crosshairs.width&&"barWidth"!==a.config.xaxis.crosshairs.width||(n=r+i.xcrosshairsWidth/2),this.moveXAxisTooltip(n)}}},{key:"moveYCrosshairs",value:function(t){var e=this.ttCtx;null!==e.ycrosshairs&&m.setAttrs(e.ycrosshairs,{y1:t,y2:t}),null!==e.ycrosshairsHidden&&m.setAttrs(e.ycrosshairsHidden,{y1:t,y2:t})}},{key:"moveXAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;if(null!==i.xaxisTooltip&&0!==i.xcrosshairsWidth){i.xaxisTooltip.classList.add("apexcharts-active");var a=i.xaxisOffY+e.config.xaxis.tooltip.offsetY+e.globals.translateY+1+e.config.xaxis.offsetY;if(t-=i.xaxisTooltip.getBoundingClientRect().width/2,!isNaN(t)){t+=e.globals.translateX;var s;s=new m(this.ctx).getTextRects(i.xaxisTooltipText.innerHTML),i.xaxisTooltipText.style.minWidth=s.width+"px",i.xaxisTooltip.style.left=t+"px",i.xaxisTooltip.style.top=a+"px"}}}},{key:"moveYAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;null===i.yaxisTTEls&&(i.yaxisTTEls=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxistooltip"));var a=parseInt(i.ycrosshairsHidden.getAttribute("y1"),10),s=e.globals.translateY+a,r=i.yaxisTTEls[t].getBoundingClientRect().height,o=e.globals.translateYAxisX[t]-2;e.config.yaxis[t].opposite&&(o-=26),s-=r/2,-1===e.globals.ignoreYAxisIndexes.indexOf(t)?(i.yaxisTTEls[t].classList.add("apexcharts-active"),i.yaxisTTEls[t].style.top=s+"px",i.yaxisTTEls[t].style.left=o+e.config.yaxis[t].tooltip.offsetX+"px"):i.yaxisTTEls[t].classList.remove("apexcharts-active")}},{key:"moveTooltip",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,s=this.ttCtx,r=s.getElTooltip(),o=s.tooltipRect,n=null!==i?parseFloat(i):1,l=parseFloat(t)+n+5,h=parseFloat(e)+n/2;if(l>a.globals.gridWidth/2&&(l=l-o.ttWidth-n-10),l>a.globals.gridWidth-o.ttWidth-10&&(l=a.globals.gridWidth-o.ttWidth),l<-20&&(l=-20),a.config.tooltip.followCursor){var c=s.getElGrid().getBoundingClientRect();(l=s.e.clientX-c.left)>a.globals.gridWidth/2&&(l-=s.tooltipRect.ttWidth),(h=s.e.clientY+a.globals.translateY-c.top)>a.globals.gridHeight/2&&(h-=s.tooltipRect.ttHeight)}else a.globals.isBarHorizontal||o.ttHeight/2+h>a.globals.gridHeight&&(h=a.globals.gridHeight-o.ttHeight+a.globals.translateY);isNaN(l)||(l+=a.globals.translateX,r.style.left=l+"px",r.style.top=h+"px")}},{key:"moveMarkers",value:function(t,e){var i=this.w,a=this.ttCtx;if(i.globals.markers.size[t]>0)for(var s=i.globals.dom.baseEl.querySelectorAll(" .apexcharts-series[data\\:realIndex='".concat(t,"'] .apexcharts-marker")),r=0;r0&&(h.setAttribute("r",n),h.setAttribute("cx",i),h.setAttribute("cy",a)),this.moveXCrosshairs(i),r.fixedTooltip||this.moveTooltip(i,a,n)}}},{key:"moveDynamicPointsOnHover",value:function(t){var e,i=this.ttCtx,a=i.w,s=0,r=0,o=a.globals.pointsArray;e=new N(this.ctx).getActiveConfigSeriesIndex("asc",["line","area","scatter","bubble"]);var n=i.tooltipUtil.getHoverMarkerSize(e);o[e]&&(s=o[e][t][0],r=o[e][t][1]);var l=i.tooltipUtil.getAllMarkers();if(null!==l)for(var h=0;h0?(l[h]&&l[h].setAttribute("r",n),l[h]&&l[h].setAttribute("cy",d)):l[h]&&l[h].setAttribute("r",0)}}this.moveXCrosshairs(s),i.fixedTooltip||this.moveTooltip(s,r||a.globals.gridHeight,n)}},{key:"moveStickyTooltipOverBars",value:function(t,e){var i=this.w,a=this.ttCtx,s=i.globals.columnSeries?i.globals.columnSeries.length:i.globals.series.length,r=s>=2&&s%2==0?Math.floor(s/2):Math.floor(s/2)+1;i.globals.isBarHorizontal&&(r=new N(this.ctx).getActiveConfigSeriesIndex("desc")+1);var o=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[rel='".concat(r,"'] path[j='").concat(t,"'], .apexcharts-candlestick-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"'], .apexcharts-boxPlot-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"'], .apexcharts-rangebar-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"']"));o||"number"!=typeof e||(o=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[data\\:realIndex='".concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-candlestick-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-boxPlot-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-rangebar-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"']")));var n=o?parseFloat(o.getAttribute("cx")):0,l=o?parseFloat(o.getAttribute("cy")):0,h=o?parseFloat(o.getAttribute("barWidth")):0,c=a.getElGrid().getBoundingClientRect(),d=o&&(o.classList.contains("apexcharts-candlestick-area")||o.classList.contains("apexcharts-boxPlot-area"));i.globals.isXNumeric?(o&&!d&&(n-=s%2!=0?h/2:0),o&&d&&i.globals.comboCharts&&(n-=h/2)):i.globals.isBarHorizontal||(n=a.xAxisTicksPositions[t-1]+a.dataPointsDividedWidth/2,isNaN(n)&&(n=a.xAxisTicksPositions[t]-a.dataPointsDividedWidth/2)),i.globals.isBarHorizontal?l-=a.tooltipRect.ttHeight:i.config.tooltip.followCursor?l=a.e.clientY-c.top-a.tooltipRect.ttHeight/2:l+a.tooltipRect.ttHeight+15>i.globals.gridHeight&&(l=i.globals.gridHeight),i.globals.isBarHorizontal||this.moveXCrosshairs(n),a.fixedTooltip||this.moveTooltip(n,l||i.globals.gridHeight)}}]),t}(),pt=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e,this.ctx=e.ctx,this.tooltipPosition=new ut(e)}return r(t,[{key:"drawDynamicPoints",value:function(){var t=this.w,e=new m(this.ctx),i=new D(this.ctx),a=t.globals.dom.baseEl.querySelectorAll(".apexcharts-series");a=u(a),t.config.chart.stacked&&a.sort((function(t,e){return parseFloat(t.getAttribute("data:realIndex"))-parseFloat(e.getAttribute("data:realIndex"))}));for(var s=0;s2&&void 0!==arguments[2]?arguments[2]:null,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.w;"bubble"!==s.config.chart.type&&this.newPointSize(t,e);var r=e.getAttribute("cx"),o=e.getAttribute("cy");if(null!==i&&null!==a&&(r=i,o=a),this.tooltipPosition.moveXCrosshairs(r),!this.fixedTooltip){if("radar"===s.config.chart.type){var n=this.ttCtx.getElGrid().getBoundingClientRect();r=this.ttCtx.e.clientX-n.left}this.tooltipPosition.moveTooltip(r,o,s.config.markers.hover.size)}}},{key:"enlargePoints",value:function(t){for(var e=this.w,i=this,a=this.ttCtx,s=t,r=e.globals.dom.baseEl.querySelectorAll(".apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker"),o=e.config.markers.hover.size,n=0;n=0?t[e].setAttribute("r",i):t[e].setAttribute("r",0)}}}]),t}(),ft=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e}return r(t,[{key:"getAttr",value:function(t,e){return parseFloat(t.target.getAttribute(e))}},{key:"handleHeatTreeTooltip",value:function(t){var e=t.e,i=t.opt,a=t.x,s=t.y,r=t.type,o=this.ttCtx,n=this.w;if(e.target.classList.contains("apexcharts-".concat(r,"-rect"))){var l=this.getAttr(e,"i"),h=this.getAttr(e,"j"),c=this.getAttr(e,"cx"),d=this.getAttr(e,"cy"),g=this.getAttr(e,"width"),u=this.getAttr(e,"height");if(o.tooltipLabels.drawSeriesTexts({ttItems:i.ttItems,i:l,j:h,shared:!1,e:e}),n.globals.capturedSeriesIndex=l,n.globals.capturedDataPointIndex=h,a=c+o.tooltipRect.ttWidth/2+g,s=d+o.tooltipRect.ttHeight/2-u/2,o.tooltipPosition.moveXCrosshairs(c+g/2),a>n.globals.gridWidth/2&&(a=c-o.tooltipRect.ttWidth/2+g),o.w.config.tooltip.followCursor){var p=n.globals.dom.elWrap.getBoundingClientRect();a=n.globals.clientX-p.left-(a>n.globals.gridWidth/2?o.tooltipRect.ttWidth:0),s=n.globals.clientY-p.top-(s>n.globals.gridHeight/2?o.tooltipRect.ttHeight:0)}}return{x:a,y:s}}},{key:"handleMarkerTooltip",value:function(t){var e,i,a=t.e,s=t.opt,r=t.x,o=t.y,n=this.w,l=this.ttCtx;if(a.target.classList.contains("apexcharts-marker")){var h=parseInt(s.paths.getAttribute("cx"),10),c=parseInt(s.paths.getAttribute("cy"),10),d=parseFloat(s.paths.getAttribute("val"));if(i=parseInt(s.paths.getAttribute("rel"),10),e=parseInt(s.paths.parentNode.parentNode.parentNode.getAttribute("rel"),10)-1,l.intersect){var g=x.findAncestor(s.paths,"apexcharts-series");g&&(e=parseInt(g.getAttribute("data:realIndex"),10))}if(l.tooltipLabels.drawSeriesTexts({ttItems:s.ttItems,i:e,j:i,shared:!l.showOnIntersect&&n.config.tooltip.shared,e:a}),"mouseup"===a.type&&l.markerClick(a,e,i),n.globals.capturedSeriesIndex=e,n.globals.capturedDataPointIndex=i,r=h,o=c+n.globals.translateY-1.4*l.tooltipRect.ttHeight,l.w.config.tooltip.followCursor){var u=l.getElGrid().getBoundingClientRect();o=l.e.clientY+n.globals.translateY-u.top}d<0&&(o=c),l.marker.enlargeCurrentPoint(i,s.paths,r,o)}return{x:r,y:o}}},{key:"handleBarTooltip",value:function(t){var e,i,a=t.e,s=t.opt,r=this.w,o=this.ttCtx,n=o.getElTooltip(),l=0,h=0,c=0,d=this.getBarTooltipXY({e:a,opt:s});e=d.i;var g=d.barHeight,u=d.j;r.globals.capturedSeriesIndex=e,r.globals.capturedDataPointIndex=u,r.globals.isBarHorizontal&&o.tooltipUtil.hasBars()||!r.config.tooltip.shared?(h=d.x,c=d.y,i=Array.isArray(r.config.stroke.width)?r.config.stroke.width[e]:r.config.stroke.width,l=h):r.globals.comboCharts||r.config.tooltip.shared||(l/=2),isNaN(c)&&(c=r.globals.svgHeight-o.tooltipRect.ttHeight);var p=parseInt(s.paths.parentNode.getAttribute("data:realIndex"),10),f=r.globals.isMultipleYAxis?r.config.yaxis[p]&&r.config.yaxis[p].reversed:r.config.yaxis[0].reversed;if(h+o.tooltipRect.ttWidth>r.globals.gridWidth&&!f?h-=o.tooltipRect.ttWidth:h<0&&(h=0),o.w.config.tooltip.followCursor){var x=o.getElGrid().getBoundingClientRect();c=o.e.clientY-x.top}null===o.tooltip&&(o.tooltip=r.globals.dom.baseEl.querySelector(".apexcharts-tooltip")),r.config.tooltip.shared||(r.globals.comboBarCount>0?o.tooltipPosition.moveXCrosshairs(l+i/2):o.tooltipPosition.moveXCrosshairs(l)),!o.fixedTooltip&&(!r.config.tooltip.shared||r.globals.isBarHorizontal&&o.tooltipUtil.hasBars())&&(f&&(h-=o.tooltipRect.ttWidth)<0&&(h=0),!f||r.globals.isBarHorizontal&&o.tooltipUtil.hasBars()||(c=c+g-2*(r.globals.series[e][u]<0?g:0)),c=c+r.globals.translateY-o.tooltipRect.ttHeight/2,n.style.left=h+r.globals.translateX+"px",n.style.top=c+"px")}},{key:"getBarTooltipXY",value:function(t){var e=t.e,i=t.opt,a=this.w,s=null,r=this.ttCtx,o=0,n=0,l=0,h=0,c=0,d=e.target.classList;if(d.contains("apexcharts-bar-area")||d.contains("apexcharts-candlestick-area")||d.contains("apexcharts-boxPlot-area")||d.contains("apexcharts-rangebar-area")){var g=e.target,u=g.getBoundingClientRect(),p=i.elGrid.getBoundingClientRect(),f=u.height;c=u.height;var x=u.width,b=parseInt(g.getAttribute("cx"),10),v=parseInt(g.getAttribute("cy"),10);h=parseFloat(g.getAttribute("barWidth"));var m="touchmove"===e.type?e.touches[0].clientX:e.clientX;s=parseInt(g.getAttribute("j"),10),o=parseInt(g.parentNode.getAttribute("rel"),10)-1;var y=g.getAttribute("data-range-y1"),w=g.getAttribute("data-range-y2");a.globals.comboCharts&&(o=parseInt(g.parentNode.getAttribute("data:realIndex"),10)),r.tooltipLabels.drawSeriesTexts({ttItems:i.ttItems,i:o,j:s,y1:y?parseInt(y,10):null,y2:w?parseInt(w,10):null,shared:!r.showOnIntersect&&a.config.tooltip.shared,e:e}),a.config.tooltip.followCursor?a.globals.isBarHorizontal?(n=m-p.left+15,l=v-r.dataPointsDividedHeight+f/2-r.tooltipRect.ttHeight/2):(n=a.globals.isXNumeric?b-x/2:b-r.dataPointsDividedWidth+x/2,l=e.clientY-p.top-r.tooltipRect.ttHeight/2-15):a.globals.isBarHorizontal?((n=b)0&&i.setAttribute("width",e.xcrosshairsWidth)}},{key:"handleYCrosshair",value:function(){var t=this.w,e=this.ttCtx;e.ycrosshairs=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs"),e.ycrosshairsHidden=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs-hidden")}},{key:"drawYaxisTooltipText",value:function(t,e,i){var a=this.ttCtx,s=this.w,r=s.globals.yLabelFormatters[t];if(a.yaxisTooltips[t]){var o=a.getElGrid().getBoundingClientRect(),n=(e-o.top)*i.yRatio[t],l=s.globals.maxYArr[t]-s.globals.minYArr[t],h=s.globals.minYArr[t]+(l-n);a.tooltipPosition.moveYCrosshairs(e-o.top),a.yaxisTooltipText[t].innerHTML=r(h),a.tooltipPosition.moveYAxisTooltip(t)}}}]),t}(),bt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w;var i=this.w;this.tConfig=i.config.tooltip,this.tooltipUtil=new dt(this),this.tooltipLabels=new gt(this),this.tooltipPosition=new ut(this),this.marker=new pt(this),this.intersect=new ft(this),this.axesTooltip=new xt(this),this.showOnIntersect=this.tConfig.intersect,this.showTooltipTitle=this.tConfig.x.show,this.fixedTooltip=this.tConfig.fixed.enabled,this.xaxisTooltip=null,this.yaxisTTEls=null,this.isBarShared=!i.globals.isBarHorizontal&&this.tConfig.shared,this.lastHoverTime=Date.now()}return r(t,[{key:"getElTooltip",value:function(t){return t||(t=this),t.w.globals.dom.baseEl?t.w.globals.dom.baseEl.querySelector(".apexcharts-tooltip"):null}},{key:"getElXCrosshairs",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-xcrosshairs")}},{key:"getElGrid",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-grid")}},{key:"drawTooltip",value:function(t){var e=this.w;this.xyRatios=t,this.isXAxisTooltipEnabled=e.config.xaxis.tooltip.enabled&&e.globals.axisCharts,this.yaxisTooltips=e.config.yaxis.map((function(t,i){return!!(t.show&&t.tooltip.enabled&&e.globals.axisCharts)})),this.allTooltipSeriesGroups=[],e.globals.axisCharts||(this.showTooltipTitle=!1);var i=document.createElement("div");if(i.classList.add("apexcharts-tooltip"),e.config.tooltip.cssClass&&i.classList.add(e.config.tooltip.cssClass),i.classList.add("apexcharts-theme-".concat(this.tConfig.theme)),e.globals.dom.elWrap.appendChild(i),e.globals.axisCharts){this.axesTooltip.drawXaxisTooltip(),this.axesTooltip.drawYaxisTooltip(),this.axesTooltip.setXCrosshairWidth(),this.axesTooltip.handleYCrosshair();var a=new V(this.ctx);this.xAxisTicksPositions=a.getXAxisTicksPositions()}if(!e.globals.comboCharts&&!this.tConfig.intersect&&"rangeBar"!==e.config.chart.type||this.tConfig.shared||(this.showOnIntersect=!0),0!==e.config.markers.size&&0!==e.globals.markers.largestSize||this.marker.drawDynamicPoints(this),e.globals.collapsedSeries.length!==e.globals.series.length){this.dataPointsDividedHeight=e.globals.gridHeight/e.globals.dataPoints,this.dataPointsDividedWidth=e.globals.gridWidth/e.globals.dataPoints,this.showTooltipTitle&&(this.tooltipTitle=document.createElement("div"),this.tooltipTitle.classList.add("apexcharts-tooltip-title"),this.tooltipTitle.style.fontFamily=this.tConfig.style.fontFamily||e.config.chart.fontFamily,this.tooltipTitle.style.fontSize=this.tConfig.style.fontSize,i.appendChild(this.tooltipTitle));var s=e.globals.series.length;(e.globals.xyCharts||e.globals.comboCharts)&&this.tConfig.shared&&(s=this.showOnIntersect?1:e.globals.series.length),this.legendLabels=e.globals.dom.baseEl.querySelectorAll(".apexcharts-legend-text"),this.ttItems=this.createTTElements(s),this.addSVGEvents()}}},{key:"createTTElements",value:function(t){for(var e=this,i=this.w,a=[],s=this.getElTooltip(),r=function(r){var o=document.createElement("div");o.classList.add("apexcharts-tooltip-series-group"),o.style.order=i.config.tooltip.inverseOrder?t-r:r+1,e.tConfig.shared&&e.tConfig.enabledOnSeries&&Array.isArray(e.tConfig.enabledOnSeries)&&e.tConfig.enabledOnSeries.indexOf(r)<0&&o.classList.add("apexcharts-tooltip-series-group-hidden");var n=document.createElement("span");n.classList.add("apexcharts-tooltip-marker"),n.style.backgroundColor=i.globals.colors[r],o.appendChild(n);var l=document.createElement("div");l.classList.add("apexcharts-tooltip-text"),l.style.fontFamily=e.tConfig.style.fontFamily||i.config.chart.fontFamily,l.style.fontSize=e.tConfig.style.fontSize,["y","goals","z"].forEach((function(t){var e=document.createElement("div");e.classList.add("apexcharts-tooltip-".concat(t,"-group"));var i=document.createElement("span");i.classList.add("apexcharts-tooltip-text-".concat(t,"-label")),e.appendChild(i);var a=document.createElement("span");a.classList.add("apexcharts-tooltip-text-".concat(t,"-value")),e.appendChild(a),l.appendChild(e)})),o.appendChild(l),s.appendChild(o),a.push(o)},o=0;o0&&this.addPathsEventListeners(u,c),this.tooltipUtil.hasBars()&&!this.tConfig.shared&&this.addDatapointEventsListeners(c)}}},{key:"drawFixedTooltipRect",value:function(){var t=this.w,e=this.getElTooltip(),i=e.getBoundingClientRect(),a=i.width+10,s=i.height+10,r=this.tConfig.fixed.offsetX,o=this.tConfig.fixed.offsetY,n=this.tConfig.fixed.position.toLowerCase();return n.indexOf("right")>-1&&(r=r+t.globals.svgWidth-a+10),n.indexOf("bottom")>-1&&(o=o+t.globals.svgHeight-s-10),e.style.left=r+"px",e.style.top=o+"px",{x:r,y:o,ttWidth:a,ttHeight:s}}},{key:"addDatapointEventsListeners",value:function(t){var e=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers .apexcharts-marker, .apexcharts-bar-area, .apexcharts-candlestick-area, .apexcharts-boxPlot-area, .apexcharts-rangebar-area");this.addPathsEventListeners(e,t)}},{key:"addPathsEventListeners",value:function(t,e){for(var i=this,a=function(a){var s={paths:t[a],tooltipEl:e.tooltipEl,tooltipY:e.tooltipY,tooltipX:e.tooltipX,elGrid:e.elGrid,hoverArea:e.hoverArea,ttItems:e.ttItems};["mousemove","mouseup","touchmove","mouseout","touchend"].map((function(e){return t[a].addEventListener(e,i.onSeriesHover.bind(i,s),{capture:!1,passive:!0})}))},s=0;s=100?this.seriesHover(t,e):(clearTimeout(this.seriesHoverTimeout),this.seriesHoverTimeout=setTimeout((function(){i.seriesHover(t,e)}),100-a))}},{key:"seriesHover",value:function(t,e){var i=this;this.lastHoverTime=Date.now();var a=[],s=this.w;s.config.chart.group&&(a=this.ctx.getGroupedCharts()),s.globals.axisCharts&&(s.globals.minX===-1/0&&s.globals.maxX===1/0||0===s.globals.dataPoints)||(a.length?a.forEach((function(a){var s=i.getElTooltip(a),r={paths:t.paths,tooltipEl:s,tooltipY:t.tooltipY,tooltipX:t.tooltipX,elGrid:t.elGrid,hoverArea:t.hoverArea,ttItems:a.w.globals.tooltip.ttItems};a.w.globals.minX===i.w.globals.minX&&a.w.globals.maxX===i.w.globals.maxX&&a.w.globals.tooltip.seriesHoverByContext({chartCtx:a,ttCtx:a.w.globals.tooltip,opt:r,e:e})})):this.seriesHoverByContext({chartCtx:this.ctx,ttCtx:this.w.globals.tooltip,opt:t,e:e}))}},{key:"seriesHoverByContext",value:function(t){var e=t.chartCtx,i=t.ttCtx,a=t.opt,s=t.e,r=e.w,o=this.getElTooltip();if(o){if(i.tooltipRect={x:0,y:0,ttWidth:o.getBoundingClientRect().width,ttHeight:o.getBoundingClientRect().height},i.e=s,i.tooltipUtil.hasBars()&&!r.globals.comboCharts&&!i.isBarShared)if(this.tConfig.onDatasetHover.highlightDataSeries)new N(e).toggleSeriesOnHover(s,s.target.parentNode);i.fixedTooltip&&i.drawFixedTooltipRect(),r.globals.axisCharts?i.axisChartsTooltips({e:s,opt:a,tooltipRect:i.tooltipRect}):i.nonAxisChartsTooltips({e:s,opt:a,tooltipRect:i.tooltipRect})}}},{key:"axisChartsTooltips",value:function(t){var e,i,a=t.e,s=t.opt,r=this.w,o=s.elGrid.getBoundingClientRect(),n="touchmove"===a.type?a.touches[0].clientX:a.clientX,l="touchmove"===a.type?a.touches[0].clientY:a.clientY;if(this.clientY=l,this.clientX=n,r.globals.capturedSeriesIndex=-1,r.globals.capturedDataPointIndex=-1,lo.top+o.height)this.handleMouseOut(s);else{if(Array.isArray(this.tConfig.enabledOnSeries)&&!r.config.tooltip.shared){var h=parseInt(s.paths.getAttribute("index"),10);if(this.tConfig.enabledOnSeries.indexOf(h)<0)return void this.handleMouseOut(s)}var c=this.getElTooltip(),d=this.getElXCrosshairs(),g=r.globals.xyCharts||"bar"===r.config.chart.type&&!r.globals.isBarHorizontal&&this.tooltipUtil.hasBars()&&this.tConfig.shared||r.globals.comboCharts&&this.tooltipUtil.hasBars();if("mousemove"===a.type||"touchmove"===a.type||"mouseup"===a.type){if(r.globals.collapsedSeries.length+r.globals.ancillaryCollapsedSeries.length===r.globals.series.length)return;null!==d&&d.classList.add("apexcharts-active");var u=this.yaxisTooltips.filter((function(t){return!0===t}));if(null!==this.ycrosshairs&&u.length&&this.ycrosshairs.classList.add("apexcharts-active"),g&&!this.showOnIntersect)this.handleStickyTooltip(a,n,l,s);else if("heatmap"===r.config.chart.type||"treemap"===r.config.chart.type){var p=this.intersect.handleHeatTreeTooltip({e:a,opt:s,x:e,y:i,type:r.config.chart.type});e=p.x,i=p.y,c.style.left=e+"px",c.style.top=i+"px"}else this.tooltipUtil.hasBars()&&this.intersect.handleBarTooltip({e:a,opt:s}),this.tooltipUtil.hasMarkers()&&this.intersect.handleMarkerTooltip({e:a,opt:s,x:e,y:i});if(this.yaxisTooltips.length)for(var f=0;fl.width)this.handleMouseOut(a);else if(null!==n)this.handleStickyCapturedSeries(t,n,a,o);else if(this.tooltipUtil.isXoverlap(o)||s.globals.isBarHorizontal){var h=s.globals.series.findIndex((function(t,e){return!s.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,h,o,a.ttItems)}}},{key:"handleStickyCapturedSeries",value:function(t,e,i,a){var s=this.w;if(!this.tConfig.shared&&null===s.globals.series[e][a])return void this.handleMouseOut(i);if(void 0!==s.globals.series[e][a])this.tConfig.shared&&this.tooltipUtil.isXoverlap(a)&&this.tooltipUtil.isInitialSeriesSameLen()?this.create(t,this,e,a,i.ttItems):this.create(t,this,e,a,i.ttItems,!1);else if(this.tooltipUtil.isXoverlap(a)){var r=s.globals.series.findIndex((function(t,e){return!s.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,r,a,i.ttItems)}}},{key:"deactivateHoverFilter",value:function(){for(var t=this.w,e=new m(this.ctx),i=t.globals.dom.Paper.select(".apexcharts-bar-area"),a=0;a5&&void 0!==arguments[5]?arguments[5]:null,S=this.w,C=i;"mouseup"===t.type&&this.markerClick(t,a,s),null===A&&(A=this.tConfig.shared);var L=this.tooltipUtil.hasMarkers(a),P=this.tooltipUtil.getElBars();if(S.config.legend.tooltipHoverFormatter){var I=S.config.legend.tooltipHoverFormatter,T=Array.from(this.legendLabels);T.forEach((function(t){var e=t.getAttribute("data:default-text");t.innerHTML=decodeURIComponent(e)}));for(var M=0;M0?C.marker.enlargePoints(s):C.tooltipPosition.moveDynamicPointsOnHover(s);else if(this.tooltipUtil.hasBars()&&(this.barSeriesHeight=this.tooltipUtil.getBarsHeight(P),this.barSeriesHeight>0)){var R=new m(this.ctx),D=S.globals.dom.Paper.select(".apexcharts-bar-area[j='".concat(s,"']"));this.deactivateHoverFilter(),this.tooltipPosition.moveStickyTooltipOverBars(s,a);for(var H=0;Hs.globals.gridHeight&&(p=s.globals.gridHeight-v)),{bcx:c,bcy:h,dataLabelsX:e,dataLabelsY:p,totalDataLabelsX:a,totalDataLabelsY:i,totalDataLabelsAnchor:"middle"}}},{key:"calculateBarsDataLabelsPosition",value:function(t){var e=this.w,i=t.x,a=t.i,s=t.j,r=t.realIndex,o=t.groupIndex,n=t.bcy,l=t.barHeight,h=t.barWidth,c=t.textRects,d=t.dataLabelsX,g=t.strokeWidth,u=t.dataLabelsConfig,p=t.barDataLabelsConfig,f=t.barTotalDataLabelsConfig,x=t.offX,b=t.offY,v=e.globals.gridHeight/e.globals.dataPoints;h=Math.abs(h);var y,w,k=(n+=-1!==o?o*l:0)-(this.barCtx.isRangeBar?0:v)+l/2+c.height/2+b-3,A="start",S=this.barCtx.series[a][s]<0,C=i;switch(this.barCtx.isReversed&&(C=i+h-(S?2*h:0),i=e.globals.gridWidth-h),p.position){case"center":d=S?C+h/2-x:Math.max(c.width/2,C-h/2)+x;break;case"bottom":d=S?C+h-g-Math.round(c.width/2)-x:C-h+g+Math.round(c.width/2)+x;break;case"top":d=S?C-g+Math.round(c.width/2)-x:C-g-Math.round(c.width/2)+x}if(this.barCtx.lastActiveBarSerieIndex===r&&f.enabled){var L=new m(this.barCtx.ctx).getTextRects(this.getStackedTotalDataLabel({realIndex:r,j:s}),u.fontSize);S?(y=C-g+Math.round(L.width/2)-x-f.offsetX-15,A="end"):y=C-g-Math.round(L.width/2)+x+f.offsetX+15,w=k+f.offsetY}return e.config.chart.stacked||(d<0?d=d+c.width+g:d+c.width/2>e.globals.gridWidth&&(d=e.globals.gridWidth-c.width-g)),{bcx:i,bcy:n,dataLabelsX:d,dataLabelsY:k,totalDataLabelsX:y,totalDataLabelsY:w,totalDataLabelsAnchor:A}}},{key:"drawCalculatedDataLabels",value:function(t){var i=t.x,a=t.y,s=t.val,r=t.i,o=t.j,n=t.textRects,l=t.barHeight,h=t.barWidth,c=t.dataLabelsConfig,d=this.w,g="rotate(0)";"vertical"===d.config.plotOptions.bar.dataLabels.orientation&&(g="rotate(-90, ".concat(i,", ").concat(a,")"));var u=new O(this.barCtx.ctx),p=new m(this.barCtx.ctx),f=c.formatter,x=null,b=d.globals.collapsedSeriesIndices.indexOf(r)>-1;if(c.enabled&&!b){x=p.group({class:"apexcharts-data-labels",transform:g});var v="";void 0!==s&&(v=f(s,e(e({},d),{},{seriesIndex:r,dataPointIndex:o,w:d}))),!s&&d.config.plotOptions.bar.hideZeroBarsWhenGrouped&&(v="");var y=d.globals.series[r][o]<0,w=d.config.plotOptions.bar.dataLabels.position;if("vertical"===d.config.plotOptions.bar.dataLabels.orientation&&("top"===w&&(c.textAnchor=y?"end":"start"),"center"===w&&(c.textAnchor="middle"),"bottom"===w&&(c.textAnchor=y?"end":"start")),this.barCtx.isRangeBar&&this.barCtx.barOptions.dataLabels.hideOverflowingLabels)hMath.abs(h)&&(v=""):n.height/1.6>Math.abs(l)&&(v=""));var k=e({},c);this.barCtx.isHorizontal&&s<0&&("start"===c.textAnchor?k.textAnchor="end":"end"===c.textAnchor&&(k.textAnchor="start")),u.plotDataLabelsText({x:i,y:a,text:v,i:r,j:o,parent:x,dataLabelsConfig:k,alwaysDrawDataLabel:!0,offsetCorrection:!0})}return x}},{key:"drawTotalDataLabels",value:function(t){var e,i=t.x,a=t.y,s=t.val,r=t.realIndex,o=t.textAnchor,n=t.barTotalDataLabelsConfig,l=new m(this.barCtx.ctx);return n.enabled&&void 0!==i&&void 0!==a&&this.barCtx.lastActiveBarSerieIndex===r&&(e=l.drawText({x:i,y:a,foreColor:n.style.color,text:s,textAnchor:o,fontFamily:n.style.fontFamily,fontSize:n.style.fontSize,fontWeight:n.style.fontWeight})),e}}]),t}(),mt=function(){function t(e){a(this,t),this.w=e.w,this.barCtx=e}return r(t,[{key:"initVariables",value:function(t){var e=this.w;this.barCtx.series=t,this.barCtx.totalItems=0,this.barCtx.seriesLen=0,this.barCtx.visibleI=-1,this.barCtx.visibleItems=1;for(var i=0;i0&&(this.barCtx.seriesLen=this.barCtx.seriesLen+1,this.barCtx.totalItems+=t[i].length),e.globals.isXNumeric)for(var a=0;ae.globals.minX&&e.globals.seriesX[i][a]0&&(a=l.globals.minXDiff/d),(r=a/this.barCtx.seriesLen*parseInt(this.barCtx.barOptions.columnWidth,10)/100)<1&&(r=1)}-1===String(this.barCtx.barOptions.columnWidth).indexOf("%")&&(r=parseInt(this.barCtx.barOptions.columnWidth,10)),o=l.globals.gridHeight-this.barCtx.baseLineY[this.barCtx.yaxisIndex]-(this.barCtx.isReversed?l.globals.gridHeight:0)+(this.barCtx.isReversed?2*this.barCtx.baseLineY[this.barCtx.yaxisIndex]:0),t=l.globals.padHorizontal+(a-r*this.barCtx.seriesLen)/2}return{x:t,y:e,yDivision:i,xDivision:a,barHeight:s,barWidth:r,zeroH:o,zeroW:n}}},{key:"initializeStackedPrevVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].prevY=[],t[e].prevX=[],t[e].prevYF=[],t[e].prevXF=[],t[e].prevYVal=[],t[e].prevXVal=[]})):(t.prevY=[],t.prevX=[],t.prevYF=[],t.prevXF=[],t.prevYVal=[],t.prevXVal=[])}},{key:"initializeStackedXYVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].xArrj=[],t[e].xArrjF=[],t[e].xArrjVal=[],t[e].yArrj=[],t[e].yArrjF=[],t[e].yArrjVal=[]})):(t.xArrj=[],t.xArrjF=[],t.xArrjVal=[],t.yArrj=[],t.yArrjF=[],t.yArrjVal=[])}},{key:"getPathFillColor",value:function(t,e,i,a){var s,r,o,n,l=this.w,h=new R(this.barCtx.ctx),c=null,d=this.barCtx.barOptions.distributed?i:e;this.barCtx.barOptions.colors.ranges.length>0&&this.barCtx.barOptions.colors.ranges.map((function(a){t[e][i]>=a.from&&t[e][i]<=a.to&&(c=a.color)}));return l.config.series[e].data[i]&&l.config.series[e].data[i].fillColor&&(c=l.config.series[e].data[i].fillColor),h.fillPath({seriesNumber:this.barCtx.barOptions.distributed?d:a,dataPointIndex:i,color:c,value:t[e][i],fillConfig:null===(s=l.config.series[e].data[i])||void 0===s?void 0:s.fill,fillType:null!==(r=l.config.series[e].data[i])&&void 0!==r&&null!==(o=r.fill)&&void 0!==o&&o.type?null===(n=l.config.series[e].data[i])||void 0===n?void 0:n.fill.type:l.config.fill.type})}},{key:"getStrokeWidth",value:function(t,e,i){var a=0,s=this.w;return this.barCtx.series[t][e]?this.barCtx.isNullValue=!1:this.barCtx.isNullValue=!0,s.config.stroke.show&&(this.barCtx.isNullValue||(a=Array.isArray(this.barCtx.strokeWidth)?this.barCtx.strokeWidth[i]:this.barCtx.strokeWidth)),a}},{key:"shouldApplyRadius",value:function(t){var e=this.w,i=!1;return e.config.plotOptions.bar.borderRadius>0&&(e.config.chart.stacked&&"last"===e.config.plotOptions.bar.borderRadiusWhenStacked?this.barCtx.lastActiveBarSerieIndex===t&&(i=!0):i=!0),i}},{key:"barBackground",value:function(t){var e=t.j,i=t.i,a=t.x1,s=t.x2,r=t.y1,o=t.y2,n=t.elSeries,l=this.w,h=new m(this.barCtx.ctx),c=new N(this.barCtx.ctx).getActiveConfigSeriesIndex();if(this.barCtx.barOptions.colors.backgroundBarColors.length>0&&c===i){e>=this.barCtx.barOptions.colors.backgroundBarColors.length&&(e%=this.barCtx.barOptions.colors.backgroundBarColors.length);var d=this.barCtx.barOptions.colors.backgroundBarColors[e],g=h.drawRect(void 0!==a?a:0,void 0!==r?r:0,void 0!==s?s:l.globals.gridWidth,void 0!==o?o:l.globals.gridHeight,this.barCtx.barOptions.colors.backgroundBarRadius,d,this.barCtx.barOptions.colors.backgroundBarOpacity);n.add(g),g.node.classList.add("apexcharts-backgroundBar")}}},{key:"getColumnPaths",value:function(t){var e,i=t.barWidth,a=t.barXPosition,s=t.y1,r=t.y2,o=t.strokeWidth,n=t.seriesGroup,l=t.realIndex,h=t.i,c=t.j,d=t.w,g=new m(this.barCtx.ctx);(o=Array.isArray(o)?o[l]:o)||(o=0);var u=i,p=a;null!==(e=d.config.series[l].data[c])&&void 0!==e&&e.columnWidthOffset&&(p=a-d.config.series[l].data[c].columnWidthOffset/2,u=i+d.config.series[l].data[c].columnWidthOffset);var f=p,x=p+u;s+=.001,r+=.001;var b=g.move(f,s),v=g.move(f,s),y=g.line(x-o,s);if(d.globals.previousPaths.length>0&&(v=this.barCtx.getPreviousPath(l,c,!1)),b=b+g.line(f,r)+g.line(x-o,r)+g.line(x-o,s)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),v=v+g.line(f,s)+y+y+y+y+y+g.line(f,s)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(b=g.roundPathCorners(b,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&n&&(w=this.barCtx[n]),w.yArrj.push(r),w.yArrjF.push(Math.abs(s-r)),w.yArrjVal.push(this.barCtx.series[h][c])}return{pathTo:b,pathFrom:v}}},{key:"getBarpaths",value:function(t){var e,i=t.barYPosition,a=t.barHeight,s=t.x1,r=t.x2,o=t.strokeWidth,n=t.seriesGroup,l=t.realIndex,h=t.i,c=t.j,d=t.w,g=new m(this.barCtx.ctx);(o=Array.isArray(o)?o[l]:o)||(o=0);var u=i,p=a;null!==(e=d.config.series[l].data[c])&&void 0!==e&&e.barHeightOffset&&(u=i-d.config.series[l].data[c].barHeightOffset/2,p=a+d.config.series[l].data[c].barHeightOffset);var f=u,x=u+p;s+=.001,r+=.001;var b=g.move(s,f),v=g.move(s,f);d.globals.previousPaths.length>0&&(v=this.barCtx.getPreviousPath(l,c,!1));var y=g.line(s,x-o);if(b=b+g.line(r,f)+g.line(r,x-o)+y+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),v=v+g.line(s,f)+y+y+y+y+y+g.line(s,f)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(b=g.roundPathCorners(b,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&n&&(w=this.barCtx[n]),w.xArrj.push(r),w.xArrjF.push(Math.abs(s-r)),w.xArrjVal.push(this.barCtx.series[h][c])}return{pathTo:b,pathFrom:v}}},{key:"checkZeroSeries",value:function(t){for(var e=t.series,i=this.w,a=0;a2&&void 0!==arguments[2])||arguments[2]?e:null;return null!=t&&(i=e+t/this.barCtx.invertedYRatio-2*(this.barCtx.isReversed?t/this.barCtx.invertedYRatio:0)),i}},{key:"getYForValue",value:function(t,e){var i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2]?e:null;return null!=t&&(i=e-t/this.barCtx.yRatio[this.barCtx.yaxisIndex]+2*(this.barCtx.isReversed?t/this.barCtx.yRatio[this.barCtx.yaxisIndex]:0)),i}},{key:"getGoalValues",value:function(t,i,a,s,r){var n=this,l=this.w,h=[],c=function(e,s){var r;h.push((o(r={},t,"x"===t?n.getXForValue(e,i,!1):n.getYForValue(e,a,!1)),o(r,"attrs",s),r))};if(l.globals.seriesGoals[s]&&l.globals.seriesGoals[s][r]&&Array.isArray(l.globals.seriesGoals[s][r])&&l.globals.seriesGoals[s][r].forEach((function(t){c(t.value,t)})),this.barCtx.barOptions.isDumbbell&&l.globals.seriesRange.length){var d=this.barCtx.barOptions.dumbbellColors?this.barCtx.barOptions.dumbbellColors:l.globals.colors,g={strokeHeight:"x"===t?0:l.globals.markers.size[s],strokeWidth:"x"===t?l.globals.markers.size[s]:0,strokeDashArray:0,strokeLineCap:"round",strokeColor:Array.isArray(d[s])?d[s][0]:d[s]};c(l.globals.seriesRangeStart[s][r],g),c(l.globals.seriesRangeEnd[s][r],e(e({},g),{},{strokeColor:Array.isArray(d[s])?d[s][1]:d[s]}))}return h}},{key:"drawGoalLine",value:function(t){var e=t.barXPosition,i=t.barYPosition,a=t.goalX,s=t.goalY,r=t.barWidth,o=t.barHeight,n=new m(this.barCtx.ctx),l=n.group({className:"apexcharts-bar-goals-groups"});l.node.classList.add("apexcharts-element-hidden"),this.barCtx.w.globals.delayedElements.push({el:l.node}),l.attr("clip-path","url(#gridRectMarkerMask".concat(this.barCtx.w.globals.cuid,")"));var h=null;return this.barCtx.isHorizontal?Array.isArray(a)&&a.forEach((function(t){var e=void 0!==t.attrs.strokeHeight?t.attrs.strokeHeight:o/2,a=i+e+o/2;h=n.drawLine(t.x,a-2*e,t.x,a,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeWidth?t.attrs.strokeWidth:2,t.attrs.strokeLineCap),l.add(h)})):Array.isArray(s)&&s.forEach((function(t){var i=void 0!==t.attrs.strokeWidth?t.attrs.strokeWidth:r/2,a=e+i+r/2;h=n.drawLine(a-2*i,t.y,a,t.y,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeHeight?t.attrs.strokeHeight:2,t.attrs.strokeLineCap),l.add(h)})),l}}]),t}(),yt=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w;var s=this.w;this.barOptions=s.config.plotOptions.bar,this.isHorizontal=this.barOptions.horizontal,this.strokeWidth=s.config.stroke.width,this.isNullValue=!1,this.isRangeBar=s.globals.seriesRange.length&&this.isHorizontal,this.xyRatios=i,null!==this.xyRatios&&(this.xRatio=i.xRatio,this.initialXRatio=i.initialXRatio,this.yRatio=i.yRatio,this.invertedXRatio=i.invertedXRatio,this.invertedYRatio=i.invertedYRatio,this.baseLineY=i.baseLineY,this.baseLineInvertedY=i.baseLineInvertedY),this.yaxisIndex=0,this.seriesLen=0;var r=new N(this.ctx);this.lastActiveBarSerieIndex=r.getActiveConfigSeriesIndex("desc",["bar","column"]);var o=r.getBarSeriesIndices(),n=new y(this.ctx);this.stackedSeriesTotals=n.getStackedSeriesTotals(this.w.config.series.map((function(t,e){return-1===o.indexOf(e)?e:-1})).filter((function(t){return-1!==t}))),this.barHelpers=new mt(this)}return r(t,[{key:"draw",value:function(t,i){var a=this.w,s=new m(this.ctx),r=new y(this.ctx,a);t=r.getLogSeries(t),this.series=t,this.yRatio=r.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t);var o=s.group({class:"apexcharts-bar-series apexcharts-plot-series"});a.config.dataLabels.enabled&&this.totalItems>this.barOptions.dataLabels.maxItems&&console.warn("WARNING: DataLabels are enabled but there are too many to display. This may cause performance issue when rendering.");for(var n=0,l=0;n0&&(this.visibleI=this.visibleI+1);var k=0,A=0;this.yRatio.length>1&&(this.yaxisIndex=v),this.isReversed=a.config.yaxis[this.yaxisIndex]&&a.config.yaxis[this.yaxisIndex].reversed;var S=this.barHelpers.initialPositions();p=S.y,k=S.barHeight,c=S.yDivision,g=S.zeroW,u=S.x,A=S.barWidth,h=S.xDivision,d=S.zeroH,this.horizontal||b.push(u+A/2);for(var C=s.group({class:"apexcharts-datalabels","data:realIndex":v}),L=s.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),P=0;P0&&b.push(u+A/2),f.push(p);var z=this.barHelpers.getPathFillColor(t,n,P,v);this.renderSeries({realIndex:v,pathFill:z,j:P,i:n,pathFrom:T.pathFrom,pathTo:T.pathTo,strokeWidth:I,elSeries:w,x:u,y:p,series:t,barHeight:T.barHeight?T.barHeight:k,barWidth:T.barWidth?T.barWidth:A,elDataLabelsWrap:C,elGoalsMarkers:L,visibleSeries:this.visibleI,type:"bar"})}a.globals.seriesXvalues[v]=b,a.globals.seriesYvalues[v]=f,o.add(w)}return o}},{key:"renderSeries",value:function(t){var e=t.realIndex,i=t.pathFill,a=t.lineFill,s=t.j,r=t.i,o=t.groupIndex,n=t.pathFrom,l=t.pathTo,h=t.strokeWidth,c=t.elSeries,d=t.x,g=t.y,u=t.y1,p=t.y2,f=t.series,x=t.barHeight,b=t.barWidth,y=t.barYPosition,w=t.elDataLabelsWrap,k=t.elGoalsMarkers,A=t.visibleSeries,S=t.type,C=this.w,L=new m(this.ctx);a||(a=this.barOptions.distributed?C.globals.stroke.colors[s]:C.globals.stroke.colors[e]),C.config.series[r].data[s]&&C.config.series[r].data[s].strokeColor&&(a=C.config.series[r].data[s].strokeColor),this.isNullValue&&(i="none");var P=s/C.config.chart.animations.animateGradually.delay*(C.config.chart.animations.speed/C.globals.dataPoints)/2.4,I=L.renderPaths({i:r,j:s,realIndex:e,pathFrom:n,pathTo:l,stroke:a,strokeWidth:h,strokeLineCap:C.config.stroke.lineCap,fill:i,animationDelay:P,initialSpeed:C.config.chart.animations.speed,dataChangeSpeed:C.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(S,"-area")});I.attr("clip-path","url(#gridRectMask".concat(C.globals.cuid,")"));var T=C.config.forecastDataPoints;T.count>0&&s>=C.globals.dataPoints-T.count&&(I.node.setAttribute("stroke-dasharray",T.dashArray),I.node.setAttribute("stroke-width",T.strokeWidth),I.node.setAttribute("fill-opacity",T.fillOpacity)),void 0!==u&&void 0!==p&&(I.attr("data-range-y1",u),I.attr("data-range-y2",p)),new v(this.ctx).setSelectionFilter(I,e,s),c.add(I);var M=new vt(this).handleBarDataLabels({x:d,y:g,y1:u,y2:p,i:r,j:s,series:f,realIndex:e,groupIndex:o,barHeight:x,barWidth:b,barYPosition:y,renderedPath:I,visibleSeries:A});return null!==M.dataLabels&&w.add(M.dataLabels),M.totalDataLabels&&w.add(M.totalDataLabels),c.add(w),k&&c.add(k),c}},{key:"drawBarPaths",value:function(t){var e,i=t.indexes,a=t.barHeight,s=t.strokeWidth,r=t.zeroW,o=t.x,n=t.y,l=t.yDivision,h=t.elSeries,c=this.w,d=i.i,g=i.j;if(c.globals.isXNumeric)e=(n=(c.globals.seriesX[d][g]-c.globals.minX)/this.invertedXRatio-a)+a*this.visibleI;else if(c.config.plotOptions.bar.hideZeroBarsWhenGrouped){var u=0,p=0;c.globals.seriesPercent.forEach((function(t,e){t[g]&&u++,e0&&(a=this.seriesLen*a/u),e=n+a*this.visibleI,e-=a*p}else e=n+a*this.visibleI;o=this.barHelpers.getXForValue(this.series[d][g],r);var f=this.barHelpers.getBarpaths({barYPosition:e,barHeight:a,x1:r,x2:o,strokeWidth:s,series:this.series,realIndex:i.realIndex,i:d,j:g,w:c});return c.globals.isXNumeric||(n+=l),this.barHelpers.barBackground({j:g,i:d,y1:e-a*this.visibleI,y2:a*this.seriesLen,elSeries:h}),{pathTo:f.pathTo,pathFrom:f.pathFrom,x:o,y:n,goalX:this.barHelpers.getGoalValues("x",r,null,d,g),barYPosition:e,barHeight:a}}},{key:"drawColumnPaths",value:function(t){var e,i=t.indexes,a=t.x,s=t.y,r=t.xDivision,o=t.barWidth,n=t.zeroH,l=t.strokeWidth,h=t.elSeries,c=this.w,d=i.realIndex,g=i.i,u=i.j,p=i.bc;if(c.globals.isXNumeric){var f=d;c.globals.seriesX[d].length||(f=c.globals.maxValsInArrayIndex),c.globals.seriesX[f][u]&&(a=(c.globals.seriesX[f][u]-c.globals.minX)/this.xRatio-o*this.seriesLen/2),e=a+o*this.visibleI}else if(c.config.plotOptions.bar.hideZeroBarsWhenGrouped){var x=0,b=0;c.globals.seriesPercent.forEach((function(t,e){t[u]&&x++,e0&&(o=this.seriesLen*o/x),e=a+o*this.visibleI,e-=o*b}else e=a+o*this.visibleI;s=this.barHelpers.getYForValue(this.series[g][u],n);var v=this.barHelpers.getColumnPaths({barXPosition:e,barWidth:o,y1:n,y2:s,strokeWidth:l,series:this.series,realIndex:i.realIndex,i:g,j:u,w:c});return c.globals.isXNumeric||(a+=r),this.barHelpers.barBackground({bc:p,j:u,i:g,x1:e-l/2-o*this.visibleI,x2:o*this.seriesLen+l/2,elSeries:h}),{pathTo:v.pathTo,pathFrom:v.pathFrom,x:a,y:s,goalY:this.barHelpers.getGoalValues("y",null,n,g,u),barXPosition:e,barWidth:o}}},{key:"getPreviousPath",value:function(t,e){for(var i,a=this.w,s=0;s0&&parseInt(r.realIndex,10)===parseInt(t,10)&&void 0!==a.globals.previousPaths[s].paths[e]&&(i=a.globals.previousPaths[s].paths[e].d)}return i}}]),t}(),wt=function(t){n(s,yt);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i){var a=this,s=this.w;this.graphics=new m(this.ctx),this.bar=new yt(this.ctx,this.xyRatios);var r=new y(this.ctx,s);t=r.getLogSeries(t),this.yRatio=r.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t),"100%"===s.config.chart.stackType&&(t=s.globals.seriesPercent.slice()),this.series=t,this.barHelpers.initializeStackedPrevVars(this);for(var o=this.graphics.group({class:"apexcharts-bar-series apexcharts-plot-series"}),n=0,l=0,h=function(r,h){var c=void 0,d=void 0,g=void 0,u=void 0,p=-1;a.groupCtx=a,s.globals.seriesGroups.forEach((function(t,e){t.indexOf(s.config.series[r].name)>-1&&(p=e)})),-1!==p&&(a.groupCtx=a[s.globals.seriesGroups[p]]);var f=[],b=[],v=s.globals.comboCharts?i[r]:r;a.yRatio.length>1&&(a.yaxisIndex=v),a.isReversed=s.config.yaxis[a.yaxisIndex]&&s.config.yaxis[a.yaxisIndex].reversed;var m=a.graphics.group({class:"apexcharts-series",seriesName:x.escapeString(s.globals.seriesNames[v]),rel:r+1,"data:realIndex":v});a.ctx.series.addCollapsedClassToSeries(m,v);var y=a.graphics.group({class:"apexcharts-datalabels","data:realIndex":v}),w=a.graphics.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),k=0,A=0,S=a.initialPositions(n,l,c,d,g,u);l=S.y,k=S.barHeight,d=S.yDivision,u=S.zeroW,n=S.x,A=S.barWidth,c=S.xDivision,g=S.zeroH,a.barHelpers.initializeStackedXYVars(a),1===a.groupCtx.prevY.length&&a.groupCtx.prevY[0].every((function(t){return isNaN(t)}))&&(a.groupCtx.prevY[0]=a.groupCtx.prevY[0].map((function(t){return g})),a.groupCtx.prevYF[0]=a.groupCtx.prevYF[0].map((function(t){return 0})));for(var C=0;C1?(i=c.globals.minXDiff/this.xRatio)*parseInt(this.barOptions.columnWidth,10)/100:n*parseInt(c.config.plotOptions.bar.columnWidth,10)/100,null!==(h=c.globals.seriesGroups)&&void 0!==h&&h.length&&(n/=c.globals.seriesGroups.length),-1===String(c.config.plotOptions.bar.columnWidth).indexOf("%")&&(n=parseInt(c.config.plotOptions.bar.columnWidth,10)),s=c.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?c.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),t=c.globals.padHorizontal+(i-n)/2);return{x:t,y:e,yDivision:a,xDivision:i,barHeight:o,barWidth:n,zeroH:s,zeroW:r}}},{key:"drawStackedBarPaths",value:function(t){for(var e,i=t.indexes,a=t.barHeight,s=t.strokeWidth,r=t.zeroW,o=t.x,n=t.y,l=t.groupIndex,h=t.seriesGroup,c=t.yDivision,d=t.elSeries,g=this.w,u=n+(-1!==l?l*a:0),p=i.i,f=i.j,x=0,b=0;b0){var m=r;this.groupCtx.prevXVal[v-1][f]<0?m=this.series[p][f]>=0?this.groupCtx.prevX[v-1][f]+x-2*(this.isReversed?x:0):this.groupCtx.prevX[v-1][f]:this.groupCtx.prevXVal[v-1][f]>=0&&(m=this.series[p][f]>=0?this.groupCtx.prevX[v-1][f]:this.groupCtx.prevX[v-1][f]-x+2*(this.isReversed?x:0)),e=m}else e=r;o=null===this.series[p][f]?e:e+this.series[p][f]/this.invertedYRatio-2*(this.isReversed?this.series[p][f]/this.invertedYRatio:0);var y=this.barHelpers.getBarpaths({barYPosition:u,barHeight:a,x1:e,x2:o,strokeWidth:s,series:this.series,realIndex:i.realIndex,seriesGroup:h,i:p,j:f,w:g});return this.barHelpers.barBackground({j:f,i:p,y1:u,y2:a,elSeries:d}),n+=c,{pathTo:y.pathTo,pathFrom:y.pathFrom,goalX:this.barHelpers.getGoalValues("x",r,null,p,f),barYPosition:u,x:o,y:n}}},{key:"drawStackedColumnPaths",value:function(t){var e=t.indexes,i=t.x,a=t.y,s=t.xDivision,r=t.barWidth,o=t.zeroH,n=t.groupIndex,l=t.seriesGroup,h=t.elSeries,c=this.w,d=e.i,g=e.j,u=e.bc;if(c.globals.isXNumeric){var p=c.globals.seriesX[d][g];p||(p=0),i=(p-c.globals.minX)/this.xRatio-r/2,c.globals.seriesGroups.length&&(i=(p-c.globals.minX)/this.xRatio-r/2*c.globals.seriesGroups.length)}for(var f,x=i+(-1!==n?n*r:0),b=0,v=0;v0&&!c.globals.isXNumeric||m>0&&c.globals.isXNumeric&&c.globals.seriesX[d-1][g]===c.globals.seriesX[d][g]){var y,w,k,A=Math.min(this.yRatio.length+1,d+1);if(void 0!==this.groupCtx.prevY[m-1]&&this.groupCtx.prevY[m-1].length)for(var S=1;S=0?k-b+2*(this.isReversed?b:0):k;break}if((null===(I=this.groupCtx.prevYVal[m-L])||void 0===I?void 0:I[g])>=0){w=this.series[d][g]>=0?k:k+b-2*(this.isReversed?b:0);break}}void 0===w&&(w=c.globals.gridHeight),f=null!==(y=this.groupCtx.prevYF[0])&&void 0!==y&&y.every((function(t){return 0===t}))&&this.groupCtx.prevYF.slice(1,m).every((function(t){return t.every((function(t){return isNaN(t)}))}))?o:w}else f=o;a=this.series[d][g]?f-this.series[d][g]/this.yRatio[this.yaxisIndex]+2*(this.isReversed?this.series[d][g]/this.yRatio[this.yaxisIndex]:0):f;var T=this.barHelpers.getColumnPaths({barXPosition:x,barWidth:r,y1:f,y2:a,yRatio:this.yRatio[this.yaxisIndex],strokeWidth:this.strokeWidth,series:this.series,seriesGroup:l,realIndex:e.realIndex,i:d,j:g,w:c});return this.barHelpers.barBackground({bc:u,j:g,i:d,x1:x,x2:r,elSeries:h}),i+=s,{pathTo:T.pathTo,pathFrom:T.pathFrom,goalY:this.barHelpers.getGoalValues("y",null,o,d,g),barXPosition:x,x:c.globals.isXNumeric?i-s:i,y:a}}}]),s}(),kt=function(t){n(s,yt);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i,a){var s=this,r=this.w,o=new m(this.ctx),n=r.globals.comboCharts?i:r.config.chart.type,l=new R(this.ctx);this.candlestickOptions=this.w.config.plotOptions.candlestick,this.boxOptions=this.w.config.plotOptions.boxPlot,this.isHorizontal=r.config.plotOptions.bar.horizontal;var h=new y(this.ctx,r);t=h.getLogSeries(t),this.series=t,this.yRatio=h.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t);for(var c=o.group({class:"apexcharts-".concat(n,"-series apexcharts-plot-series")}),d=function(i){s.isBoxPlot="boxPlot"===r.config.chart.type||"boxPlot"===r.config.series[i].type;var n,h,d,g,u=void 0,p=void 0,f=[],b=[],v=r.globals.comboCharts?a[i]:i,m=o.group({class:"apexcharts-series",seriesName:x.escapeString(r.globals.seriesNames[v]),rel:i+1,"data:realIndex":v});s.ctx.series.addCollapsedClassToSeries(m,v),t[i].length>0&&(s.visibleI=s.visibleI+1);var y,w;s.yRatio.length>1&&(s.yaxisIndex=v);var k=s.barHelpers.initialPositions();p=k.y,y=k.barHeight,h=k.yDivision,g=k.zeroW,u=k.x,w=k.barWidth,n=k.xDivision,d=k.zeroH,b.push(u+w/2);for(var A=o.group({class:"apexcharts-datalabels","data:realIndex":v}),S=function(a){var o=s.barHelpers.getStrokeWidth(i,a,v),c=null,x={indexes:{i:i,j:a,realIndex:v},x:u,y:p,strokeWidth:o,elSeries:m};c=s.isHorizontal?s.drawHorizontalBoxPaths(e(e({},x),{},{yDivision:h,barHeight:y,zeroW:g})):s.drawVerticalBoxPaths(e(e({},x),{},{xDivision:n,barWidth:w,zeroH:d})),p=c.y,u=c.x,a>0&&b.push(u+w/2),f.push(p),c.pathTo.forEach((function(e,n){var h=!s.isBoxPlot&&s.candlestickOptions.wick.useFillColor?c.color[n]:r.globals.stroke.colors[i],d=l.fillPath({seriesNumber:v,dataPointIndex:a,color:c.color[n],value:t[i][a]});s.renderSeries({realIndex:v,pathFill:d,lineFill:h,j:a,i:i,pathFrom:c.pathFrom,pathTo:e,strokeWidth:o,elSeries:m,x:u,y:p,series:t,barHeight:y,barWidth:w,elDataLabelsWrap:A,visibleSeries:s.visibleI,type:r.config.chart.type})}))},C=0;Cb.c&&(d=!1);var w=Math.min(b.o,b.c),k=Math.max(b.o,b.c),A=b.m;n.globals.isXNumeric&&(i=(n.globals.seriesX[x][c]-n.globals.minX)/this.xRatio-s/2);var S=i+s*this.visibleI;void 0===this.series[h][c]||null===this.series[h][c]?(w=r,k=r):(w=r-w/f,k=r-k/f,v=r-b.h/f,y=r-b.l/f,A=r-b.m/f);var C=l.move(S,r),L=l.move(S+s/2,w);return n.globals.previousPaths.length>0&&(L=this.getPreviousPath(x,c,!0)),C=this.isBoxPlot?[l.move(S,w)+l.line(S+s/2,w)+l.line(S+s/2,v)+l.line(S+s/4,v)+l.line(S+s-s/4,v)+l.line(S+s/2,v)+l.line(S+s/2,w)+l.line(S+s,w)+l.line(S+s,A)+l.line(S,A)+l.line(S,w+o/2),l.move(S,A)+l.line(S+s,A)+l.line(S+s,k)+l.line(S+s/2,k)+l.line(S+s/2,y)+l.line(S+s-s/4,y)+l.line(S+s/4,y)+l.line(S+s/2,y)+l.line(S+s/2,k)+l.line(S,k)+l.line(S,A)+"z"]:[l.move(S,k)+l.line(S+s/2,k)+l.line(S+s/2,v)+l.line(S+s/2,k)+l.line(S+s,k)+l.line(S+s,w)+l.line(S+s/2,w)+l.line(S+s/2,y)+l.line(S+s/2,w)+l.line(S,w)+l.line(S,k-o/2)],L+=l.move(S,w),n.globals.isXNumeric||(i+=a),{pathTo:C,pathFrom:L,x:i,y:k,barXPosition:S,color:this.isBoxPlot?p:d?[g]:[u]}}},{key:"drawHorizontalBoxPaths",value:function(t){var e=t.indexes;t.x;var i=t.y,a=t.yDivision,s=t.barHeight,r=t.zeroW,o=t.strokeWidth,n=this.w,l=new m(this.ctx),h=e.i,c=e.j,d=this.boxOptions.colors.lower;this.isBoxPlot&&(d=[this.boxOptions.colors.lower,this.boxOptions.colors.upper]);var g=this.invertedYRatio,u=e.realIndex,p=this.getOHLCValue(u,c),f=r,x=r,b=Math.min(p.o,p.c),v=Math.max(p.o,p.c),y=p.m;n.globals.isXNumeric&&(i=(n.globals.seriesX[u][c]-n.globals.minX)/this.invertedXRatio-s/2);var w=i+s*this.visibleI;void 0===this.series[h][c]||null===this.series[h][c]?(b=r,v=r):(b=r+b/g,v=r+v/g,f=r+p.h/g,x=r+p.l/g,y=r+p.m/g);var k=l.move(r,w),A=l.move(b,w+s/2);return n.globals.previousPaths.length>0&&(A=this.getPreviousPath(u,c,!0)),k=[l.move(b,w)+l.line(b,w+s/2)+l.line(f,w+s/2)+l.line(f,w+s/2-s/4)+l.line(f,w+s/2+s/4)+l.line(f,w+s/2)+l.line(b,w+s/2)+l.line(b,w+s)+l.line(y,w+s)+l.line(y,w)+l.line(b+o/2,w),l.move(y,w)+l.line(y,w+s)+l.line(v,w+s)+l.line(v,w+s/2)+l.line(x,w+s/2)+l.line(x,w+s-s/4)+l.line(x,w+s/4)+l.line(x,w+s/2)+l.line(v,w+s/2)+l.line(v,w)+l.line(y,w)+"z"],A+=l.move(b,w),n.globals.isXNumeric||(i+=a),{pathTo:k,pathFrom:A,x:v,y:i,barYPosition:w,color:d}}},{key:"getOHLCValue",value:function(t,e){var i=this.w;return{o:this.isBoxPlot?i.globals.seriesCandleH[t][e]:i.globals.seriesCandleO[t][e],h:this.isBoxPlot?i.globals.seriesCandleO[t][e]:i.globals.seriesCandleH[t][e],m:i.globals.seriesCandleM[t][e],l:this.isBoxPlot?i.globals.seriesCandleC[t][e]:i.globals.seriesCandleL[t][e],c:this.isBoxPlot?i.globals.seriesCandleL[t][e]:i.globals.seriesCandleC[t][e]}}}]),s}(),At=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"checkColorRange",value:function(){var t=this.w,e=!1,i=t.config.plotOptions[t.config.chart.type];return i.colorScale.ranges.length>0&&i.colorScale.ranges.map((function(t,i){t.from<=0&&(e=!0)})),e}},{key:"getShadeColor",value:function(t,e,i,a){var s=this.w,r=1,o=s.config.plotOptions[t].shadeIntensity,n=this.determineColor(t,e,i);s.globals.hasNegs||a?r=s.config.plotOptions[t].reverseNegativeShade?n.percent<0?n.percent/100*(1.25*o):(1-n.percent/100)*(1.25*o):n.percent<=0?1-(1+n.percent/100)*o:(1-n.percent/100)*o:(r=1-n.percent/100,"treemap"===t&&(r=(1-n.percent/100)*(1.25*o)));var l=n.color,h=new x;return s.config.plotOptions[t].enableShades&&(l="dark"===this.w.config.theme.mode?x.hexToRgba(h.shadeColor(-1*r,n.color),s.config.fill.opacity):x.hexToRgba(h.shadeColor(r,n.color),s.config.fill.opacity)),{color:l,colorProps:n}}},{key:"determineColor",value:function(t,e,i){var a=this.w,s=a.globals.series[e][i],r=a.config.plotOptions[t],o=r.colorScale.inverse?i:e;r.distributed&&"treemap"===a.config.chart.type&&(o=i);var n=a.globals.colors[o],l=null,h=Math.min.apply(Math,u(a.globals.series[e])),c=Math.max.apply(Math,u(a.globals.series[e]));r.distributed||"heatmap"!==t||(h=a.globals.minY,c=a.globals.maxY),void 0!==r.colorScale.min&&(h=r.colorScale.mina.globals.maxY?r.colorScale.max:a.globals.maxY);var d=Math.abs(c)+Math.abs(h),g=100*s/(0===d?d-1e-6:d);r.colorScale.ranges.length>0&&r.colorScale.ranges.map((function(t,e){if(s>=t.from&&s<=t.to){n=t.color,l=t.foreColor?t.foreColor:null,h=t.from,c=t.to;var i=Math.abs(c)+Math.abs(h);g=100*s/(0===i?i-1e-6:i)}}));return{color:n,foreColor:l,percent:g}}},{key:"calculateDataLabels",value:function(t){var e=t.text,i=t.x,a=t.y,s=t.i,r=t.j,o=t.colorProps,n=t.fontSize,l=this.w.config.dataLabels,h=new m(this.ctx),c=new O(this.ctx),d=null;if(l.enabled){d=h.group({class:"apexcharts-data-labels"});var g=l.offsetX,u=l.offsetY,p=i+g,f=a+parseFloat(l.style.fontSize)/3+u;c.plotDataLabelsText({x:p,y:f,text:e,i:s,j:r,color:o.foreColor,parent:d,fontSize:n,dataLabelsConfig:l})}return d}},{key:"addListeners",value:function(t){var e=new m(this.ctx);t.node.addEventListener("mouseenter",e.pathMouseEnter.bind(this,t)),t.node.addEventListener("mouseleave",e.pathMouseLeave.bind(this,t)),t.node.addEventListener("mousedown",e.pathMouseDown.bind(this,t))}}]),t}(),St=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w,this.xRatio=i.xRatio,this.yRatio=i.yRatio,this.dynamicAnim=this.w.config.chart.animations.dynamicAnimation,this.helpers=new At(e),this.rectRadius=this.w.config.plotOptions.heatmap.radius,this.strokeWidth=this.w.config.stroke.show?this.w.config.stroke.width:0}return r(t,[{key:"draw",value:function(t){var e=this.w,i=new m(this.ctx),a=i.group({class:"apexcharts-heatmap"});a.attr("clip-path","url(#gridRectMask".concat(e.globals.cuid,")"));var s=e.globals.gridWidth/e.globals.dataPoints,r=e.globals.gridHeight/e.globals.series.length,o=0,n=!1;this.negRange=this.helpers.checkColorRange();var l=t.slice();e.config.yaxis[0].reversed&&(n=!0,l.reverse());for(var h=n?0:l.length-1;n?h=0;n?h++:h--){var c=i.group({class:"apexcharts-series apexcharts-heatmap-series",seriesName:x.escapeString(e.globals.seriesNames[h]),rel:h+1,"data:realIndex":h});if(this.ctx.series.addCollapsedClassToSeries(c,h),e.config.chart.dropShadow.enabled){var d=e.config.chart.dropShadow;new v(this.ctx).dropShadow(c,d,h)}for(var g=0,u=e.config.plotOptions.heatmap.shadeIntensity,p=0;p-1&&this.pieClicked(d),i.config.dataLabels.enabled){var A=w.x,S=w.y,C=100*u/this.fullAngle+"%";if(0!==u&&i.config.plotOptions.pie.dataLabels.minAngleToShowLabelthis.fullAngle?e.endAngle=e.endAngle-(a+o):a+o=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle&&(n=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle-.01),Math.ceil(n)>this.fullAngle&&(n-=this.fullAngle);var l=Math.PI*(n-90)/180,h=e.centerX+s*Math.cos(o),c=e.centerY+s*Math.sin(o),d=e.centerX+s*Math.cos(l),g=e.centerY+s*Math.sin(l),u=x.polarToCartesian(e.centerX,e.centerY,e.donutSize,n),p=x.polarToCartesian(e.centerX,e.centerY,e.donutSize,r),f=a>180?1:0,b=["M",h,c,"A",s,s,0,f,1,d,g];return"donut"===e.chartType?[].concat(b,["L",u.x,u.y,"A",e.donutSize,e.donutSize,0,f,0,p.x,p.y,"L",h,c,"z"]).join(" "):"pie"===e.chartType||"polarArea"===e.chartType?[].concat(b,["L",e.centerX,e.centerY,"L",h,c]).join(" "):[].concat(b).join(" ")}},{key:"drawPolarElements",value:function(t){var e=this.w,i=new _(this.ctx),a=new m(this.ctx),s=new Ct(this.ctx),r=a.group(),o=a.group(),n=i.niceScale(0,Math.ceil(this.maxY),e.config.yaxis[0].tickAmount,0,!0),l=n.result.reverse(),h=n.result.length;this.maxY=n.niceMax;for(var c=e.globals.radialSize,d=c/(h-1),g=0;g1&&t.total.show&&(s=t.total.color);var o=r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-label"),n=r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-value");i=(0,t.value.formatter)(i,r),a||"function"!=typeof t.total.formatter||(i=t.total.formatter(r));var l=e===t.total.label;e=t.name.formatter(e,l,r),null!==o&&(o.textContent=e),null!==n&&(n.textContent=i),null!==o&&(o.style.fill=s)}},{key:"printDataLabelsInner",value:function(t,e){var i=this.w,a=t.getAttribute("data:value"),s=i.globals.seriesNames[parseInt(t.parentNode.getAttribute("rel"),10)-1];i.globals.series.length>1&&this.printInnerLabels(e,s,a,t);var r=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels-group");null!==r&&(r.style.opacity=1)}},{key:"drawSpokes",value:function(t){var e=this,i=this.w,a=new m(this.ctx),s=i.config.plotOptions.polarArea.spokes;if(0!==s.strokeWidth){for(var r=[],o=360/i.globals.series.length,n=0;n1)o&&!e.total.showAlways?l({makeSliceOut:!1,printLabel:!0}):this.printInnerLabels(e,e.total.label,e.total.formatter(s));else if(l({makeSliceOut:!1,printLabel:!0}),!o)if(s.globals.selectedDataPoints.length&&s.globals.series.length>1)if(s.globals.selectedDataPoints[0].length>0){var h=s.globals.selectedDataPoints[0],c=s.globals.dom.baseEl.querySelector(".apexcharts-".concat(this.chartType.toLowerCase(),"-slice-").concat(h));this.printDataLabelsInner(c,e)}else r&&s.globals.selectedDataPoints.length&&0===s.globals.selectedDataPoints[0].length&&(r.style.opacity=0);else r&&s.globals.series.length>1&&(r.style.opacity=0)}}]),t}(),Pt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.chartType=this.w.config.chart.type,this.initialAnim=this.w.config.chart.animations.enabled,this.dynamicAnim=this.initialAnim&&this.w.config.chart.animations.dynamicAnimation.enabled,this.animDur=0;var i=this.w;this.graphics=new m(this.ctx),this.lineColorArr=void 0!==i.globals.stroke.colors?i.globals.stroke.colors:i.globals.colors,this.defaultSize=i.globals.svgHeight0&&(f=i.getPreviousPath(n));for(var b=0;b=10?t.x>0?(i="start",a+=10):t.x<0&&(i="end",a-=10):i="middle",Math.abs(t.y)>=e-10&&(t.y<0?s-=10:t.y>0&&(s+=10)),{textAnchor:i,newX:a,newY:s}}},{key:"getPreviousPath",value:function(t){for(var e=this.w,i=null,a=0;a0&&parseInt(s.realIndex,10)===parseInt(t,10)&&void 0!==e.globals.previousPaths[a].paths[0]&&(i=e.globals.previousPaths[a].paths[0].d)}return i}},{key:"getDataPointsPos",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.dataPointsLen;t=t||[],e=e||[];for(var a=[],s=0;s=360&&(g=360-Math.abs(this.startAngle)-.1);var u=i.drawPath({d:"",stroke:c,strokeWidth:o*parseInt(h.strokeWidth,10)/100,fill:"none",strokeOpacity:h.opacity,classes:"apexcharts-radialbar-area"});if(h.dropShadow.enabled){var p=h.dropShadow;s.dropShadow(u,p)}l.add(u),u.attr("id","apexcharts-radialbarTrack-"+n),this.animatePaths(u,{centerX:t.centerX,centerY:t.centerY,endAngle:g,startAngle:d,size:t.size,i:n,totalItems:2,animBeginArr:0,dur:0,isTrack:!0,easing:e.globals.easing})}return a}},{key:"drawArcs",value:function(t){var e=this.w,i=new m(this.ctx),a=new R(this.ctx),s=new v(this.ctx),r=i.group(),o=this.getStrokeWidth(t);t.size=t.size-o/2;var n=e.config.plotOptions.radialBar.hollow.background,l=t.size-o*t.series.length-this.margin*t.series.length-o*parseInt(e.config.plotOptions.radialBar.track.strokeWidth,10)/100/2,h=l-e.config.plotOptions.radialBar.hollow.margin;void 0!==e.config.plotOptions.radialBar.hollow.image&&(n=this.drawHollowImage(t,r,l,n));var c=this.drawHollow({size:h,centerX:t.centerX,centerY:t.centerY,fill:n||"transparent"});if(e.config.plotOptions.radialBar.hollow.dropShadow.enabled){var d=e.config.plotOptions.radialBar.hollow.dropShadow;s.dropShadow(c,d)}var g=1;!this.radialDataLabels.total.show&&e.globals.series.length>1&&(g=0);var u=null;this.radialDataLabels.show&&(u=this.renderInnerDataLabels(this.radialDataLabels,{hollowSize:l,centerX:t.centerX,centerY:t.centerY,opacity:g})),"back"===e.config.plotOptions.radialBar.hollow.position&&(r.add(c),u&&r.add(u));var p=!1;e.config.plotOptions.radialBar.inverseOrder&&(p=!0);for(var f=p?t.series.length-1:0;p?f>=0:f100?100:t.series[f])/100,S=Math.round(this.totalAngle*A)+this.startAngle,C=void 0;e.globals.dataChanged&&(k=this.startAngle,C=Math.round(this.totalAngle*x.negToZero(e.globals.previousPaths[f])/100)+k),Math.abs(S)+Math.abs(w)>=360&&(S-=.01),Math.abs(C)+Math.abs(k)>=360&&(C-=.01);var L=S-w,P=Array.isArray(e.config.stroke.dashArray)?e.config.stroke.dashArray[f]:e.config.stroke.dashArray,I=i.drawPath({d:"",stroke:y,strokeWidth:o,fill:"none",fillOpacity:e.config.fill.opacity,classes:"apexcharts-radialbar-area apexcharts-radialbar-slice-"+f,strokeDashArray:P});if(m.setAttrs(I.node,{"data:angle":L,"data:value":t.series[f]}),e.config.chart.dropShadow.enabled){var T=e.config.chart.dropShadow;s.dropShadow(I,T,f)}s.setSelectionFilter(I,0,f),this.addListeners(I,this.radialDataLabels),b.add(I),I.attr({index:0,j:f});var M=0;!this.initialAnim||e.globals.resized||e.globals.dataChanged||(M=e.config.chart.animations.speed),e.globals.dataChanged&&(M=e.config.chart.animations.dynamicAnimation.speed),this.animDur=M/(1.2*t.series.length)+this.animDur,this.animBeginArr.push(this.animDur),this.animatePaths(I,{centerX:t.centerX,centerY:t.centerY,endAngle:S,startAngle:w,prevEndAngle:C,prevStartAngle:k,size:t.size,i:f,totalItems:2,animBeginArr:this.animBeginArr,dur:M,shouldSetPrevPaths:!0,easing:e.globals.easing})}return{g:r,elHollow:c,dataLabels:u}}},{key:"drawHollow",value:function(t){var e=new m(this.ctx).drawCircle(2*t.size);return e.attr({class:"apexcharts-radialbar-hollow",cx:t.centerX,cy:t.centerY,r:t.size,fill:t.fill}),e}},{key:"drawHollowImage",value:function(t,e,i,a){var s=this.w,r=new R(this.ctx),o=x.randomId(),n=s.config.plotOptions.radialBar.hollow.image;if(s.config.plotOptions.radialBar.hollow.imageClipped)r.clippedImgArea({width:i,height:i,image:n,patternID:"pattern".concat(s.globals.cuid).concat(o)}),a="url(#pattern".concat(s.globals.cuid).concat(o,")");else{var l=s.config.plotOptions.radialBar.hollow.imageWidth,h=s.config.plotOptions.radialBar.hollow.imageHeight;if(void 0===l&&void 0===h){var c=s.globals.dom.Paper.image(n).loaded((function(e){this.move(t.centerX-e.width/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-e.height/2+s.config.plotOptions.radialBar.hollow.imageOffsetY)}));e.add(c)}else{var d=s.globals.dom.Paper.image(n).loaded((function(e){this.move(t.centerX-l/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-h/2+s.config.plotOptions.radialBar.hollow.imageOffsetY),this.size(l,h)}));e.add(d)}}return a}},{key:"getStrokeWidth",value:function(t){var e=this.w;return t.size*(100-parseInt(e.config.plotOptions.radialBar.hollow.size,10))/100/(t.series.length+1)-this.margin}}]),i}(),Tt=function(t){n(s,yt);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i){var a=this.w,s=new m(this.ctx);this.rangeBarOptions=this.w.config.plotOptions.rangeBar,this.series=t,this.seriesRangeStart=a.globals.seriesRangeStart,this.seriesRangeEnd=a.globals.seriesRangeEnd,this.barHelpers.initVariables(t);for(var r=s.group({class:"apexcharts-rangebar-series apexcharts-plot-series"}),o=0;o0&&(this.visibleI=this.visibleI+1);var f=0,b=0;this.yRatio.length>1&&(this.yaxisIndex=u);var v=this.barHelpers.initialPositions();d=v.y,h=v.zeroW,c=v.x,b=v.barWidth,n=v.xDivision,l=v.zeroH;for(var y=s.group({class:"apexcharts-datalabels","data:realIndex":u}),w=s.group({class:"apexcharts-rangebar-goals-markers",style:"pointer-events: none"}),k=0;k0}));return a=l.config.plotOptions.bar.rangeBarGroupRows?s+o*g:s+r*this.visibleI+o*g,u>-1&&!l.config.plotOptions.bar.rangeBarOverlap&&(h=l.globals.seriesRange[e][u].overlaps).indexOf(c)>-1&&(a=(r=n.barHeight/h.length)*this.visibleI+o*(100-parseInt(this.barOptions.barHeight,10))/100/2+r*(this.visibleI+h.indexOf(c))+o*g),{barYPosition:a,barHeight:r}}},{key:"drawRangeColumnPaths",value:function(t){var e=t.indexes,i=t.x;t.strokeWidth;var a=t.xDivision,s=t.barWidth,r=t.zeroH,o=this.w,n=e.i,l=e.j,h=this.yRatio[this.yaxisIndex],c=e.realIndex,d=this.getRangeValue(c,l),g=Math.min(d.start,d.end),u=Math.max(d.start,d.end);o.globals.isXNumeric&&(i=(o.globals.seriesX[n][l]-o.globals.minX)/this.xRatio-s/2);var p=i+s*this.visibleI;void 0===this.series[n][l]||null===this.series[n][l]?g=r:(g=r-g/h,u=r-u/h);var f=Math.abs(u-g),x=this.barHelpers.getColumnPaths({barXPosition:p,barWidth:s,y1:g,y2:u,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,realIndex:e.realIndex,i:c,j:l,w:o});return o.globals.isXNumeric||(i+=a),{pathTo:x.pathTo,pathFrom:x.pathFrom,barHeight:f,x:i,y:u,goalY:this.barHelpers.getGoalValues("y",null,r,n,l),barXPosition:p}}},{key:"drawRangeBarPaths",value:function(t){var e=t.indexes,i=t.y,a=t.y1,s=t.y2,r=t.yDivision,o=t.barHeight,n=t.barYPosition,l=t.zeroW,h=this.w,c=l+a/this.invertedYRatio,d=l+s/this.invertedYRatio,g=Math.abs(d-c),u=this.barHelpers.getBarpaths({barYPosition:n,barHeight:o,x1:c,x2:d,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,i:e.realIndex,realIndex:e.realIndex,j:e.j,w:h});return h.globals.isXNumeric||(i+=r),{pathTo:u.pathTo,pathFrom:u.pathFrom,barWidth:g,x:d,goalX:this.barHelpers.getGoalValues("x",l,null,e.realIndex,e.j),y:i}}},{key:"getRangeValue",value:function(t,e){var i=this.w;return{start:i.globals.seriesRangeStart[t][e],end:i.globals.seriesRangeEnd[t][e]}}}]),s}(),Mt=function(){function t(e){a(this,t),this.w=e.w,this.lineCtx=e}return r(t,[{key:"sameValueSeriesFix",value:function(t,e){var i=this.w;if(("gradient"===i.config.fill.type||"gradient"===i.config.fill.type[t])&&new y(this.lineCtx.ctx,i).seriesHaveSameValues(t)){var a=e[t].slice();a[a.length-1]=a[a.length-1]+1e-6,e[t]=a}return e}},{key:"calculatePoints",value:function(t){var e=t.series,i=t.realIndex,a=t.x,s=t.y,r=t.i,o=t.j,n=t.prevY,l=this.w,h=[],c=[];if(0===o){var d=this.lineCtx.categoryAxisCorrection+l.config.markers.offsetX;l.globals.isXNumeric&&(d=(l.globals.seriesX[i][0]-l.globals.minX)/this.lineCtx.xRatio+l.config.markers.offsetX),h.push(d),c.push(x.isNumber(e[r][0])?n+l.config.markers.offsetY:null),h.push(a+l.config.markers.offsetX),c.push(x.isNumber(e[r][o+1])?s+l.config.markers.offsetY:null)}else h.push(a+l.config.markers.offsetX),c.push(x.isNumber(e[r][o+1])?s+l.config.markers.offsetY:null);return{x:h,y:c}}},{key:"checkPreviousPaths",value:function(t){for(var e=t.pathFromLine,i=t.pathFromArea,a=t.realIndex,s=this.w,r=0;r0&&parseInt(o.realIndex,10)===parseInt(a,10)&&("line"===o.type?(this.lineCtx.appendPathFrom=!1,e=s.globals.previousPaths[r].paths[0].d):"area"===o.type&&(this.lineCtx.appendPathFrom=!1,i=s.globals.previousPaths[r].paths[0].d,s.config.stroke.show&&s.globals.previousPaths[r].paths[1]&&(e=s.globals.previousPaths[r].paths[1].d)))}return{pathFromLine:e,pathFromArea:i}}},{key:"determineFirstPrevY",value:function(t){var e,i=t.i,a=t.series,s=t.prevY,r=t.lineYPosition,o=this.w;if(void 0!==(null===(e=a[i])||void 0===e?void 0:e[0]))s=(r=o.config.chart.stacked&&i>0?this.lineCtx.prevSeriesY[i-1][0]:this.lineCtx.zeroY)-a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]+2*(this.lineCtx.isReversed?a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]:0);else if(o.config.chart.stacked&&i>0&&void 0===a[i][0])for(var n=i-1;n>=0;n--)if(null!==a[n][0]&&void 0!==a[n][0]){s=r=this.lineCtx.prevSeriesY[n][0];break}return{prevY:s,lineYPosition:r}}}]),t}(),Xt=function(){function t(e,i,s){a(this,t),this.ctx=e,this.w=e.w,this.xyRatios=i,this.pointsChart=!("bubble"!==this.w.config.chart.type&&"scatter"!==this.w.config.chart.type)||s,this.scatter=new H(this.ctx),this.noNegatives=this.w.globals.minX===Number.MAX_VALUE,this.lineHelpers=new Mt(this),this.markers=new D(this.ctx),this.prevSeriesY=[],this.categoryAxisCorrection=0,this.yaxisIndex=0}return r(t,[{key:"draw",value:function(t,i,a,s){var r=this.w,o=new m(this.ctx),n=r.globals.comboCharts?i:r.config.chart.type,l=o.group({class:"apexcharts-".concat(n,"-series apexcharts-plot-series")}),h=new y(this.ctx,r);this.yRatio=this.xyRatios.yRatio,this.zRatio=this.xyRatios.zRatio,this.xRatio=this.xyRatios.xRatio,this.baseLineY=this.xyRatios.baseLineY,t=h.getLogSeries(t),this.yRatio=h.getLogYRatios(this.yRatio);for(var c=[],d=0;d0&&(f=(r.globals.seriesX[g][0]-r.globals.minX)/this.xRatio),p.push(f);var x,b=f,v=void 0,w=b,k=this.zeroY,A=this.zeroY;k=this.lineHelpers.determineFirstPrevY({i:d,series:t,prevY:k,lineYPosition:0}).prevY,u.push(k),x=k;"rangeArea"===n&&(v=A=this.lineHelpers.determineFirstPrevY({i:d,series:s,prevY:A,lineYPosition:0}).prevY);var S={type:n,series:t,realIndex:g,i:d,x:f,y:1,pX:b,pY:x,pathsFrom:this._calculatePathsFrom({type:n,series:t,i:d,realIndex:g,prevX:w,prevY:k,prevY2:A}),linePaths:[],areaPaths:[],seriesIndex:a,lineYPosition:0,xArrj:p,yArrj:u,seriesRangeEnd:s},C=this._iterateOverDataPoints(e(e({},S),{},{iterations:"rangeArea"===n?t[d].length-1:void 0,isRangeStart:!0}));if("rangeArea"===n){var L=this._calculatePathsFrom({series:s,i:d,realIndex:g,prevX:w,prevY:A}),P=this._iterateOverDataPoints(e(e({},S),{},{series:s,pY:v,pathsFrom:L,iterations:s[d].length-1,isRangeStart:!1}));C.linePaths[0]=P.linePath+C.linePath,C.pathFromLine=P.pathFromLine+C.pathFromLine}this._handlePaths({type:n,realIndex:g,i:d,paths:C}),this.elSeries.add(this.elPointsMain),this.elSeries.add(this.elDataLabelsWrap),c.push(this.elSeries)}if(r.config.chart.stacked)for(var I=c.length;I>0;I--)l.add(c[I-1]);else for(var T=0;T1&&(this.yaxisIndex=i),this.isReversed=a.config.yaxis[this.yaxisIndex]&&a.config.yaxis[this.yaxisIndex].reversed,this.zeroY=a.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?a.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),this.areaBottomY=this.zeroY,(this.zeroY>a.globals.gridHeight||"end"===a.config.plotOptions.area.fillTo)&&(this.areaBottomY=a.globals.gridHeight),this.categoryAxisCorrection=this.xDivision/2,this.elSeries=s.group({class:"apexcharts-series",seriesName:x.escapeString(a.globals.seriesNames[i])}),this.elPointsMain=s.group({class:"apexcharts-series-markers-wrap","data:realIndex":i}),this.elDataLabelsWrap=s.group({class:"apexcharts-datalabels","data:realIndex":i});var r=t[e].length===a.globals.dataPoints;this.elSeries.attr({"data:longestSeries":r,rel:e+1,"data:realIndex":i}),this.appendPathFrom=!0}},{key:"_calculatePathsFrom",value:function(t){var e,i,a,s,r=t.type,o=t.series,n=t.i,l=t.realIndex,h=t.prevX,c=t.prevY,d=t.prevY2,g=this.w,u=new m(this.ctx);if(null===o[n][0]){for(var p=0;p0){var f=this.lineHelpers.checkPreviousPaths({pathFromLine:a,pathFromArea:s,realIndex:l});a=f.pathFromLine,s=f.pathFromArea}return{prevX:h,prevY:c,linePath:e,areaPath:i,pathFromLine:a,pathFromArea:s}}},{key:"_handlePaths",value:function(t){var i=t.type,a=t.realIndex,s=t.i,r=t.paths,o=this.w,n=new m(this.ctx),l=new R(this.ctx);this.prevSeriesY.push(r.yArrj),o.globals.seriesXvalues[a]=r.xArrj,o.globals.seriesYvalues[a]=r.yArrj;var h=o.config.forecastDataPoints;if(h.count>0&&"rangeArea"!==i){var c=o.globals.seriesXvalues[a][o.globals.seriesXvalues[a].length-h.count-1],d=n.drawRect(c,0,o.globals.gridWidth,o.globals.gridHeight,0);o.globals.dom.elForecastMask.appendChild(d.node);var g=n.drawRect(0,0,c,o.globals.gridHeight,0);o.globals.dom.elNonForecastMask.appendChild(g.node)}this.pointsChart||o.globals.delayedElements.push({el:this.elPointsMain.node,index:a});var u={i:s,realIndex:a,animationDelay:s,initialSpeed:o.config.chart.animations.speed,dataChangeSpeed:o.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(i)};if("area"===i)for(var p=l.fillPath({seriesNumber:a}),f=0;f0&&"rangeArea"!==i){var S=n.renderPaths(k);S.node.setAttribute("stroke-dasharray",h.dashArray),h.strokeWidth&&S.node.setAttribute("stroke-width",h.strokeWidth),this.elSeries.add(S),S.attr("clip-path","url(#forecastMask".concat(o.globals.cuid,")")),A.attr("clip-path","url(#nonForecastMask".concat(o.globals.cuid,")"))}}}}},{key:"_iterateOverDataPoints",value:function(t){var e=t.type,i=t.series,a=t.iterations,s=t.realIndex,r=t.i,o=t.x,n=t.y,l=t.pX,h=t.pY,c=t.pathsFrom,d=t.linePaths,g=t.areaPaths,u=t.seriesIndex,p=t.lineYPosition,f=t.xArrj,b=t.yArrj,v=t.isRangeStart,y=t.seriesRangeEnd,w=this.w,k=new m(this.ctx),A=this.yRatio,S=c.prevY,C=c.linePath,L=c.areaPath,P=c.pathFromLine,I=c.pathFromArea,T=x.isNumber(w.globals.minYArr[s])?w.globals.minYArr[s]:w.globals.minY;a||(a=w.globals.dataPoints>1?w.globals.dataPoints-1:w.globals.dataPoints);for(var M=n,X=0;X0&&w.globals.collapsedSeries.length-1){e--;break}return e>=0?e:0}(r-1)][X+1]}else p=this.zeroY;else p=this.zeroY;z?n=p-T/A[this.yaxisIndex]+2*(this.isReversed?T/A[this.yaxisIndex]:0):(n=p-i[r][X+1]/A[this.yaxisIndex]+2*(this.isReversed?i[r][X+1]/A[this.yaxisIndex]:0),"rangeArea"===e&&(M=p-y[r][X+1]/A[this.yaxisIndex]+2*(this.isReversed?y[r][X+1]/A[this.yaxisIndex]:0))),f.push(o),b.push(n);var Y=this.lineHelpers.calculatePoints({series:i,x:o,y:n,realIndex:s,i:r,j:X,prevY:S}),F=this._createPaths({type:e,series:i,i:r,realIndex:s,j:X,x:o,y:n,y2:M,pX:l,pY:h,linePath:C,areaPath:L,linePaths:d,areaPaths:g,seriesIndex:u,isRangeStart:v});g=F.areaPaths,d=F.linePaths,l=F.pX,h=F.pY,L=F.areaPath,C=F.linePath,this.appendPathFrom&&(P+=k.line(o,this.zeroY),I+=k.line(o,this.zeroY)),this.handleNullDataPoints(i,Y,r,X,s),this._handleMarkersAndLabels({type:e,pointsPos:Y,i:r,j:X,realIndex:s,isRangeStart:v})}return{yArrj:b,xArrj:f,pathFromArea:I,areaPaths:g,pathFromLine:P,linePaths:d,linePath:C,areaPath:L}}},{key:"_handleMarkersAndLabels",value:function(t){var e=t.type,i=t.pointsPos,a=t.isRangeStart,s=t.i,r=t.j,o=t.realIndex,n=this.w,l=new O(this.ctx);if(this.pointsChart)this.scatter.draw(this.elSeries,r,{realIndex:o,pointsPos:i,zRatio:this.zRatio,elParent:this.elPointsMain});else{n.globals.series[s].length>1&&this.elPointsMain.node.classList.add("apexcharts-element-hidden");var h=this.markers.plotChartMarkers(i,o,r+1);null!==h&&this.elPointsMain.add(h)}var c=l.drawDataLabel({type:e,isRangeStart:a,pos:i,i:o,j:r+1});null!==c&&this.elDataLabelsWrap.add(c)}},{key:"_createPaths",value:function(t){var e=t.type,i=t.series,a=t.i,s=t.realIndex,r=t.j,o=t.x,n=t.y,l=t.y2,h=t.pX,c=t.pY,d=t.linePath,g=t.areaPath,u=t.linePaths,p=t.areaPaths,f=t.seriesIndex,x=t.isRangeStart,b=this.w,v=new m(this.ctx),y=b.config.stroke.curve,w=this.areaBottomY;if(Array.isArray(b.config.stroke.curve)&&(y=Array.isArray(f)?b.config.stroke.curve[f[a]]:b.config.stroke.curve[a]),"smooth"===y){var k=.35*(o-h);b.globals.hasNullValues?(null!==i[a][r]&&(null!==i[a][r+1]?(d=v.move(h,c)+v.curve(h+k,c,o-k,n,o+1,n),g=v.move(h+1,c)+v.curve(h+k,c,o-k,n,o+1,n)+v.line(o,w)+v.line(h,w)+"z"):(d=v.move(h,c),g=v.move(h,c)+"z")),u.push(d),p.push(g)):(d+=v.curve(h+k,c,o-k,n,o,n),g+=v.curve(h+k,c,o-k,n,o,n)),h=o,c=n,r===i[a].length-2&&(g=g+v.curve(h,c,o,n,o,w)+v.move(o,n)+"z","rangeArea"===e&&x?d=d+v.curve(h,c,o,n,o,l)+v.move(o,l)+"z":b.globals.hasNullValues||(u.push(d),p.push(g)))}else{if(null===i[a][r+1]){d+=v.move(o,n);var A=b.globals.isXNumeric?(b.globals.seriesX[s][r]-b.globals.minX)/this.xRatio:o-this.xDivision;g=g+v.line(A,w)+v.move(o,n)+"z"}null===i[a][r]&&(d+=v.move(o,n),g+=v.move(o,w)),"stepline"===y?(d=d+v.line(o,null,"H")+v.line(null,n,"V"),g=g+v.line(o,null,"H")+v.line(null,n,"V")):"straight"===y&&(d+=v.line(o,n),g+=v.line(o,n)),r===i[a].length-2&&(g=g+v.line(o,w)+v.move(o,n)+"z","rangeArea"===e&&x?d=d+v.line(o,l)+v.move(o,l)+"z":(u.push(d),p.push(g)))}return{linePaths:u,areaPaths:p,pX:h,pY:c,linePath:d,areaPath:g}}},{key:"handleNullDataPoints",value:function(t,e,i,a,s){var r=this.w;if(null===t[i][a]&&r.config.markers.showNullDataPoints||1===t[i].length){var o=this.markers.plotChartMarkers(e,s,a+1,this.strokeWidth-r.config.markers.strokeWidth/2,!0);null!==o&&this.elPointsMain.add(o)}}}]),t}();window.TreemapSquared={},window.TreemapSquared.generate=function(){function t(e,i,a,s){this.xoffset=e,this.yoffset=i,this.height=s,this.width=a,this.shortestEdge=function(){return Math.min(this.height,this.width)},this.getCoordinates=function(t){var e,i=[],a=this.xoffset,s=this.yoffset,o=r(t)/this.height,n=r(t)/this.width;if(this.width>=this.height)for(e=0;e=this.height){var a=e/this.height,s=this.width-a;i=new t(this.xoffset+a,this.yoffset,s,this.height)}else{var r=e/this.width,o=this.height-r;i=new t(this.xoffset,this.yoffset+r,this.width,o)}return i}}function e(e,a,s,o,n){o=void 0===o?0:o,n=void 0===n?0:n;var l=i(function(t,e){var i,a=[],s=e/r(t);for(i=0;i=o}(e,l=t[0],n)?(e.push(l),i(t.slice(1),e,s,o)):(h=s.cutArea(r(e),o),o.push(s.getCoordinates(e)),i(t,[],h,o)),o;o.push(s.getCoordinates(e))}function a(t,e){var i=Math.min.apply(Math,t),a=Math.max.apply(Math,t),s=r(t);return Math.max(Math.pow(e,2)*a/Math.pow(s,2),Math.pow(s,2)/(Math.pow(e,2)*i))}function s(t){return t&&t.constructor===Array}function r(t){var e,i=0;for(e=0;er-a&&l.width<=o-s){var h=n.rotateAroundCenter(t.node);t.node.setAttribute("transform","rotate(-90 ".concat(h.x," ").concat(h.y,")"))}}},{key:"animateTreemap",value:function(t,e,i,a){var s=new b(this.ctx);s.animateRect(t,{x:e.x,y:e.y,width:e.width,height:e.height},{x:i.x,y:i.y,width:i.width,height:i.height},a,(function(){s.animationCompleted(t)}))}}]),t}(),Ft=86400,Rt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.timeScaleArray=[],this.utc=this.w.config.xaxis.labels.datetimeUTC}return r(t,[{key:"calculateTimeScaleTicks",value:function(t,i){var a=this,s=this.w;if(s.globals.allSeriesCollapsed)return s.globals.labels=[],s.globals.timescaleLabels=[],[];var r=new I(this.ctx),o=(i-t)/864e5;this.determineInterval(o),s.globals.disableZoomIn=!1,s.globals.disableZoomOut=!1,o<.00011574074074074075?s.globals.disableZoomIn=!0:o>5e4&&(s.globals.disableZoomOut=!0);var n=r.getTimeUnitsfromTimestamp(t,i,this.utc),l=s.globals.gridWidth/o,h=l/24,c=h/60,d=c/60,g=Math.floor(24*o),u=Math.floor(1440*o),p=Math.floor(o*Ft),f=Math.floor(o),x=Math.floor(o/30),b=Math.floor(o/365),v={minMillisecond:n.minMillisecond,minSecond:n.minSecond,minMinute:n.minMinute,minHour:n.minHour,minDate:n.minDate,minMonth:n.minMonth,minYear:n.minYear},m={firstVal:v,currentMillisecond:v.minMillisecond,currentSecond:v.minSecond,currentMinute:v.minMinute,currentHour:v.minHour,currentMonthDate:v.minDate,currentDate:v.minDate,currentMonth:v.minMonth,currentYear:v.minYear,daysWidthOnXAxis:l,hoursWidthOnXAxis:h,minutesWidthOnXAxis:c,secondsWidthOnXAxis:d,numberOfSeconds:p,numberOfMinutes:u,numberOfHours:g,numberOfDays:f,numberOfMonths:x,numberOfYears:b};switch(this.tickInterval){case"years":this.generateYearScale(m);break;case"months":case"half_year":this.generateMonthScale(m);break;case"months_days":case"months_fortnight":case"days":case"week_days":this.generateDayScale(m);break;case"hours":this.generateHourScale(m);break;case"minutes_fives":case"minutes":this.generateMinuteScale(m);break;case"seconds_tens":case"seconds_fives":case"seconds":this.generateSecondScale(m)}var y=this.timeScaleArray.map((function(t){var i={position:t.position,unit:t.unit,year:t.year,day:t.day?t.day:1,hour:t.hour?t.hour:0,month:t.month+1};return"month"===t.unit?e(e({},i),{},{day:1,value:t.value+1}):"day"===t.unit||"hour"===t.unit?e(e({},i),{},{value:t.value}):"minute"===t.unit?e(e({},i),{},{value:t.value,minute:t.value}):"second"===t.unit?e(e({},i),{},{value:t.value,minute:t.minute,second:t.second}):t}));return y.filter((function(t){var e=1,i=Math.ceil(s.globals.gridWidth/120),r=t.value;void 0!==s.config.xaxis.tickAmount&&(i=s.config.xaxis.tickAmount),y.length>i&&(e=Math.floor(y.length/i));var o=!1,n=!1;switch(a.tickInterval){case"years":"year"===t.unit&&(o=!0);break;case"half_year":e=7,"year"===t.unit&&(o=!0);break;case"months":e=1,"year"===t.unit&&(o=!0);break;case"months_fortnight":e=15,"year"!==t.unit&&"month"!==t.unit||(o=!0),30===r&&(n=!0);break;case"months_days":e=10,"month"===t.unit&&(o=!0),30===r&&(n=!0);break;case"week_days":e=8,"month"===t.unit&&(o=!0);break;case"days":e=1,"month"===t.unit&&(o=!0);break;case"hours":"day"===t.unit&&(o=!0);break;case"minutes_fives":case"seconds_fives":r%5!=0&&(n=!0);break;case"seconds_tens":r%10!=0&&(n=!0)}if("hours"===a.tickInterval||"minutes_fives"===a.tickInterval||"seconds_tens"===a.tickInterval||"seconds_fives"===a.tickInterval){if(!n)return!0}else if((r%e==0||o)&&!n)return!0}))}},{key:"recalcDimensionsBasedOnFormat",value:function(t,e){var i=this.w,a=this.formatDates(t),s=this.removeOverlappingTS(a);i.globals.timescaleLabels=s.slice(),new ot(this.ctx).plotCoords()}},{key:"determineInterval",value:function(t){var e=24*t,i=60*e;switch(!0){case t/365>5:this.tickInterval="years";break;case t>800:this.tickInterval="half_year";break;case t>180:this.tickInterval="months";break;case t>90:this.tickInterval="months_fortnight";break;case t>60:this.tickInterval="months_days";break;case t>30:this.tickInterval="week_days";break;case t>2:this.tickInterval="days";break;case e>2.4:this.tickInterval="hours";break;case i>15:this.tickInterval="minutes_fives";break;case i>5:this.tickInterval="minutes";break;case i>1:this.tickInterval="seconds_tens";break;case 60*i>20:this.tickInterval="seconds_fives";break;default:this.tickInterval="seconds"}}},{key:"generateYearScale",value:function(t){var e=t.firstVal,i=t.currentMonth,a=t.currentYear,s=t.daysWidthOnXAxis,r=t.numberOfYears,o=e.minYear,n=0,l=new I(this.ctx),h="year";if(e.minDate>1||e.minMonth>0){var c=l.determineRemainingDaysOfYear(e.minYear,e.minMonth,e.minDate);n=(l.determineDaysOfYear(e.minYear)-c+1)*s,o=e.minYear+1,this.timeScaleArray.push({position:n,value:o,unit:h,year:o,month:x.monthMod(i+1)})}else 1===e.minDate&&0===e.minMonth&&this.timeScaleArray.push({position:n,value:o,unit:h,year:a,month:x.monthMod(i+1)});for(var d=o,g=n,u=0;u1){l=(h.determineDaysOfMonths(a+1,e.minYear)-i+1)*r,n=x.monthMod(a+1);var g=s+d,u=x.monthMod(n),p=n;0===n&&(c="year",p=g,u=1,g+=d+=1),this.timeScaleArray.push({position:l,value:p,unit:c,year:g,month:u})}else this.timeScaleArray.push({position:l,value:n,unit:c,year:s,month:x.monthMod(a)});for(var f=n+1,b=l,v=0,m=1;vo.determineDaysOfMonths(e+1,i)?(h=1,n="month",g=e+=1,e):e},d=(24-e.minHour)*s,g=l,u=c(h,i,a);0===e.minHour&&1===e.minDate?(d=0,g=x.monthMod(e.minMonth),n="month",h=e.minDate,r++):1!==e.minDate&&0===e.minHour&&0===e.minMinute&&(d=0,l=e.minDate,g=l,u=c(h=l,i,a)),this.timeScaleArray.push({position:d,value:g,unit:n,year:this._getYear(a,u,0),month:x.monthMod(u),day:h});for(var p=d,f=0;fn.determineDaysOfMonths(e+1,s)&&(f=1,e+=1),{month:e,date:f}},c=function(t,e){return t>n.determineDaysOfMonths(e+1,s)?e+=1:e},d=60-(e.minMinute+e.minSecond/60),g=d*r,u=e.minHour+1,p=u+1;60===d&&(g=0,p=(u=e.minHour)+1);var f=i,b=c(f,a);this.timeScaleArray.push({position:g,value:u,unit:l,day:f,hour:p,year:s,month:x.monthMod(b)});for(var v=g,m=0;m=24)p=0,l="day",b=h(f+=1,b).month,b=c(f,b);var y=this._getYear(s,b,0);v=60*r+v;var w=0===p?f:p;this.timeScaleArray.push({position:v,value:w,unit:l,hour:p,day:f,year:y,month:x.monthMod(b)}),p++}}},{key:"generateMinuteScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,r=t.currentDate,o=t.currentMonth,n=t.currentYear,l=t.minutesWidthOnXAxis,h=t.secondsWidthOnXAxis,c=t.numberOfMinutes,d=a+1,g=r,u=o,p=n,f=s,b=(60-i-e/1e3)*h,v=0;v=60&&(d=0,24===(f+=1)&&(f=0)),this.timeScaleArray.push({position:b,value:d,unit:"minute",hour:f,minute:d,day:g,year:this._getYear(p,u,0),month:x.monthMod(u)}),b+=l,d++}},{key:"generateSecondScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,r=t.currentDate,o=t.currentMonth,n=t.currentYear,l=t.secondsWidthOnXAxis,h=t.numberOfSeconds,c=i+1,d=a,g=r,u=o,p=n,f=s,b=(1e3-e)/1e3*l,v=0;v=60&&(c=0,++d>=60&&(d=0,24===++f&&(f=0))),this.timeScaleArray.push({position:b,value:c,unit:"second",hour:f,minute:d,second:c,day:g,year:this._getYear(p,u,0),month:x.monthMod(u)}),b+=l,c++}},{key:"createRawDateString",value:function(t,e){var i=t.year;return 0===t.month&&(t.month=1),i+="-"+("0"+t.month.toString()).slice(-2),"day"===t.unit?i+="day"===t.unit?"-"+("0"+e).slice(-2):"-01":i+="-"+("0"+(t.day?t.day:"1")).slice(-2),"hour"===t.unit?i+="hour"===t.unit?"T"+("0"+e).slice(-2):"T00":i+="T"+("0"+(t.hour?t.hour:"0")).slice(-2),"minute"===t.unit?i+=":"+("0"+e).slice(-2):i+=":"+(t.minute?("0"+t.minute).slice(-2):"00"),"second"===t.unit?i+=":"+("0"+e).slice(-2):i+=":00",this.utc&&(i+=".000Z"),i}},{key:"formatDates",value:function(t){var e=this,i=this.w;return t.map((function(t){var a=t.value.toString(),s=new I(e.ctx),r=e.createRawDateString(t,a),o=s.getDate(s.parseDate(r));if(e.utc||(o=s.getDate(s.parseDateWithTimezone(r))),void 0===i.config.xaxis.labels.format){var n="dd MMM",l=i.config.xaxis.labels.datetimeFormatter;"year"===t.unit&&(n=l.year),"month"===t.unit&&(n=l.month),"day"===t.unit&&(n=l.day),"hour"===t.unit&&(n=l.hour),"minute"===t.unit&&(n=l.minute),"second"===t.unit&&(n=l.second),a=s.formatDate(o,n)}else a=s.formatDate(o,i.config.xaxis.labels.format);return{dateString:r,position:t.position,value:a,unit:t.unit,year:t.year,month:t.month}}))}},{key:"removeOverlappingTS",value:function(t){var e,i=this,a=new m(this.ctx),s=!1;t.length>0&&t[0].value&&t.every((function(e){return e.value.length===t[0].value.length}))&&(s=!0,e=a.getTextRects(t[0].value).width);var r=0,o=t.map((function(o,n){if(n>0&&i.w.config.xaxis.labels.hideOverlappingLabels){var l=s?e:a.getTextRects(t[r].value).width,h=t[r].position;return o.position>h+l+10?(r=n,o):null}return o}));return o=o.filter((function(t){return null!==t}))}},{key:"_getYear",value:function(t,e,i){return t+Math.floor(e/12)+i}}]),t}(),Dt=function(){function t(e,i){a(this,t),this.ctx=i,this.w=i.w,this.el=e}return r(t,[{key:"setupElements",value:function(){var t=this.w.globals,e=this.w.config,i=e.chart.type;t.axisCharts=["line","area","bar","rangeBar","rangeArea","candlestick","boxPlot","scatter","bubble","radar","heatmap","treemap"].indexOf(i)>-1,t.xyCharts=["line","area","bar","rangeBar","rangeArea","candlestick","boxPlot","scatter","bubble"].indexOf(i)>-1,t.isBarHorizontal=("bar"===e.chart.type||"rangeBar"===e.chart.type||"boxPlot"===e.chart.type)&&e.plotOptions.bar.horizontal,t.chartClass=".apexcharts"+t.chartID,t.dom.baseEl=this.el,t.dom.elWrap=document.createElement("div"),m.setAttrs(t.dom.elWrap,{id:t.chartClass.substring(1),class:"apexcharts-canvas "+t.chartClass.substring(1)}),this.el.appendChild(t.dom.elWrap),t.dom.Paper=new window.SVG.Doc(t.dom.elWrap),t.dom.Paper.attr({class:"apexcharts-svg","xmlns:data":"ApexChartsNS",transform:"translate(".concat(e.chart.offsetX,", ").concat(e.chart.offsetY,")")}),t.dom.Paper.node.style.background=e.chart.background,this.setSVGDimensions(),t.dom.elLegendForeign=document.createElementNS(t.SVGNS,"foreignObject"),m.setAttrs(t.dom.elLegendForeign,{x:0,y:0,width:t.svgWidth,height:t.svgHeight}),t.dom.elLegendWrap=document.createElement("div"),t.dom.elLegendWrap.classList.add("apexcharts-legend"),t.dom.elLegendWrap.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),t.dom.elLegendForeign.appendChild(t.dom.elLegendWrap),t.dom.Paper.node.appendChild(t.dom.elLegendForeign),t.dom.elGraphical=t.dom.Paper.group().attr({class:"apexcharts-inner apexcharts-graphical"}),t.dom.elDefs=t.dom.Paper.defs(),t.dom.Paper.add(t.dom.elGraphical),t.dom.elGraphical.add(t.dom.elDefs)}},{key:"plotChartType",value:function(t,e){var i=this.w,a=i.config,s=i.globals,r={series:[],i:[]},o={series:[],i:[]},n={series:[],i:[]},l={series:[],i:[]},h={series:[],i:[]},c={series:[],i:[]},d={series:[],i:[]},g={series:[],i:[]},u={series:[],seriesRangeEnd:[],i:[]};s.series.map((function(e,p){var f=0;void 0!==t[p].type?("column"===t[p].type||"bar"===t[p].type?(s.series.length>1&&a.plotOptions.bar.horizontal&&console.warn("Horizontal bars are not supported in a mixed/combo chart. Please turn off `plotOptions.bar.horizontal`"),h.series.push(e),h.i.push(p),f++,i.globals.columnSeries=h.series):"area"===t[p].type?(o.series.push(e),o.i.push(p),f++):"line"===t[p].type?(r.series.push(e),r.i.push(p),f++):"scatter"===t[p].type?(n.series.push(e),n.i.push(p)):"bubble"===t[p].type?(l.series.push(e),l.i.push(p),f++):"candlestick"===t[p].type?(c.series.push(e),c.i.push(p),f++):"boxPlot"===t[p].type?(d.series.push(e),d.i.push(p),f++):"rangeBar"===t[p].type?(g.series.push(e),g.i.push(p),f++):"rangeArea"===t[p].type?(u.series.push(s.seriesRangeStart[p]),u.seriesRangeEnd.push(s.seriesRangeEnd[p]),u.i.push(p),f++):console.warn("You have specified an unrecognized chart type. Available types for this property are line/area/column/bar/scatter/bubble/candlestick/boxPlot/rangeBar/rangeArea"),f>1&&(s.comboCharts=!0)):(r.series.push(e),r.i.push(p))}));var p=new Xt(this.ctx,e),f=new kt(this.ctx,e);this.ctx.pie=new Lt(this.ctx);var x=new It(this.ctx);this.ctx.rangeBar=new Tt(this.ctx,e);var b=new Pt(this.ctx),v=[];if(s.comboCharts){if(o.series.length>0&&v.push(p.draw(o.series,"area",o.i)),h.series.length>0)if(i.config.chart.stacked){var m=new wt(this.ctx,e);v.push(m.draw(h.series,h.i))}else this.ctx.bar=new yt(this.ctx,e),v.push(this.ctx.bar.draw(h.series,h.i));if(u.series.length>0&&v.push(p.draw(u.series,"rangeArea",u.i,u.seriesRangeEnd)),r.series.length>0&&v.push(p.draw(r.series,"line",r.i)),c.series.length>0&&v.push(f.draw(c.series,"candlestick",c.i)),d.series.length>0&&v.push(f.draw(d.series,"boxPlot",d.i)),g.series.length>0&&v.push(this.ctx.rangeBar.draw(g.series,g.i)),n.series.length>0){var y=new Xt(this.ctx,e,!0);v.push(y.draw(n.series,"scatter",n.i))}if(l.series.length>0){var w=new Xt(this.ctx,e,!0);v.push(w.draw(l.series,"bubble",l.i))}}else switch(a.chart.type){case"line":v=p.draw(s.series,"line");break;case"area":v=p.draw(s.series,"area");break;case"bar":if(a.chart.stacked)v=new wt(this.ctx,e).draw(s.series);else this.ctx.bar=new yt(this.ctx,e),v=this.ctx.bar.draw(s.series);break;case"candlestick":v=new kt(this.ctx,e).draw(s.series,"candlestick");break;case"boxPlot":v=new kt(this.ctx,e).draw(s.series,"boxPlot");break;case"rangeBar":v=this.ctx.rangeBar.draw(s.series);break;case"rangeArea":v=p.draw(s.seriesRangeStart,"rangeArea",void 0,s.seriesRangeEnd);break;case"heatmap":v=new St(this.ctx,e).draw(s.series);break;case"treemap":v=new Yt(this.ctx,e).draw(s.series);break;case"pie":case"donut":case"polarArea":v=this.ctx.pie.draw(s.series);break;case"radialBar":v=x.draw(s.series);break;case"radar":v=b.draw(s.series);break;default:v=p.draw(s.series)}return v}},{key:"setSVGDimensions",value:function(){var t=this.w.globals,e=this.w.config;t.svgWidth=e.chart.width,t.svgHeight=e.chart.height;var i=x.getDimensions(this.el),a=e.chart.width.toString().split(/[0-9]+/g).pop();"%"===a?x.isNumber(i[0])&&(0===i[0].width&&(i=x.getDimensions(this.el.parentNode)),t.svgWidth=i[0]*parseInt(e.chart.width,10)/100):"px"!==a&&""!==a||(t.svgWidth=parseInt(e.chart.width,10));var s=e.chart.height.toString().split(/[0-9]+/g).pop();if("auto"!==t.svgHeight&&""!==t.svgHeight)if("%"===s){var r=x.getDimensions(this.el.parentNode);t.svgHeight=r[1]*parseInt(e.chart.height,10)/100}else t.svgHeight=parseInt(e.chart.height,10);else t.axisCharts?t.svgHeight=t.svgWidth/1.61:t.svgHeight=t.svgWidth/1.2;if(t.svgWidth<0&&(t.svgWidth=0),t.svgHeight<0&&(t.svgHeight=0),m.setAttrs(t.dom.Paper.node,{width:t.svgWidth,height:t.svgHeight}),"%"!==s){var o=e.chart.sparkline.enabled?0:t.axisCharts?e.chart.parentHeightOffset:0;t.dom.Paper.node.parentNode.parentNode.style.minHeight=t.svgHeight+o+"px"}t.dom.elWrap.style.width=t.svgWidth+"px",t.dom.elWrap.style.height=t.svgHeight+"px"}},{key:"shiftGraphPosition",value:function(){var t=this.w.globals,e=t.translateY,i={transform:"translate("+t.translateX+", "+e+")"};m.setAttrs(t.dom.elGraphical.node,i)}},{key:"resizeNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=0,a=t.config.chart.sparkline.enabled?1:15;a+=t.config.grid.padding.bottom,"top"!==t.config.legend.position&&"bottom"!==t.config.legend.position||!t.config.legend.show||t.config.legend.floating||(i=new lt(this.ctx).legendHelpers.getLegendBBox().clwh+10);var s=t.globals.dom.baseEl.querySelector(".apexcharts-radialbar, .apexcharts-pie"),r=2.05*t.globals.radialSize;if(s&&!t.config.chart.sparkline.enabled&&0!==t.config.plotOptions.radialBar.startAngle){var o=x.getBoundingClientRect(s);r=o.bottom;var n=o.bottom-o.top;r=Math.max(2.05*t.globals.radialSize,n)}var l=r+e.translateY+i+a;e.dom.elLegendForeign&&e.dom.elLegendForeign.setAttribute("height",l),t.config.chart.height&&String(t.config.chart.height).indexOf("%")>0||(e.dom.elWrap.style.height=l+"px",m.setAttrs(e.dom.Paper.node,{height:l}),e.dom.Paper.node.parentNode.parentNode.style.minHeight=l+"px")}},{key:"coreCalculations",value:function(){new U(this.ctx).init()}},{key:"resetGlobals",value:function(){var t=this,e=function(){return t.w.config.series.map((function(t){return[]}))},i=new Y,a=this.w.globals;i.initGlobalVars(a),a.seriesXvalues=e(),a.seriesYvalues=e()}},{key:"isMultipleY",value:function(){if(this.w.config.yaxis.constructor===Array&&this.w.config.yaxis.length>1)return this.w.globals.isMultipleYAxis=!0,!0}},{key:"xySettings",value:function(){var t=null,e=this.w;if(e.globals.axisCharts){if("back"===e.config.xaxis.crosshairs.position)new Q(this.ctx).drawXCrosshairs();if("back"===e.config.yaxis[0].crosshairs.position)new Q(this.ctx).drawYCrosshairs();if("datetime"===e.config.xaxis.type&&void 0===e.config.xaxis.labels.formatter){this.ctx.timeScale=new Rt(this.ctx);var i=[];isFinite(e.globals.minX)&&isFinite(e.globals.maxX)&&!e.globals.isBarHorizontal?i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minX,e.globals.maxX):e.globals.isBarHorizontal&&(i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minY,e.globals.maxY)),this.ctx.timeScale.recalcDimensionsBasedOnFormat(i)}t=new y(this.ctx).getCalculatedRatios()}return t}},{key:"updateSourceChart",value:function(t){this.ctx.w.globals.selection=void 0,this.ctx.updateHelpers._updateOptions({chart:{selection:{xaxis:{min:t.w.globals.minX,max:t.w.globals.maxX}}}},!1,!1)}},{key:"setupBrushHandler",value:function(){var t=this,i=this.w;if(i.config.chart.brush.enabled&&"function"!=typeof i.config.chart.events.selection){var a=i.config.chart.brush.targets||[i.config.chart.brush.target];a.forEach((function(e){var i=ApexCharts.getChartByID(e);i.w.globals.brushSource=t.ctx,"function"!=typeof i.w.config.chart.events.zoomed&&(i.w.config.chart.events.zoomed=function(){t.updateSourceChart(i)}),"function"!=typeof i.w.config.chart.events.scrolled&&(i.w.config.chart.events.scrolled=function(){t.updateSourceChart(i)})})),i.config.chart.events.selection=function(t,s){a.forEach((function(t){var a=ApexCharts.getChartByID(t),r=x.clone(i.config.yaxis);if(i.config.chart.brush.autoScaleYaxis&&1===a.w.globals.series.length){var o=new _(a);r=o.autoScaleY(a,r,s)}var n=a.w.config.yaxis.reduce((function(t,i,s){return[].concat(u(t),[e(e({},a.w.config.yaxis[s]),{},{min:r[0].min,max:r[0].max})])}),[]);a.ctx.updateHelpers._updateOptions({xaxis:{min:s.xaxis.min,max:s.xaxis.max},yaxis:n},!1,!1,!1,!1)}))}}}}]),t}(),Ht=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"_updateOptions",value:function(t){var e=this,a=arguments.length>1&&void 0!==arguments[1]&&arguments[1],s=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],r=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],o=arguments.length>4&&void 0!==arguments[4]&&arguments[4];return new Promise((function(n){var l=[e.ctx];r&&(l=e.ctx.getSyncedCharts()),e.ctx.w.globals.isExecCalled&&(l=[e.ctx],e.ctx.w.globals.isExecCalled=!1),l.forEach((function(r,h){var c=r.w;if(c.globals.shouldAnimate=s,a||(c.globals.resized=!0,c.globals.dataChanged=!0,s&&r.series.getPreviousPaths()),t&&"object"===i(t)&&(r.config=new E(t),t=y.extendArrayProps(r.config,t,c),r.w.globals.chartID!==e.ctx.w.globals.chartID&&delete t.series,c.config=x.extend(c.config,t),o&&(c.globals.lastXAxis=t.xaxis?x.clone(t.xaxis):[],c.globals.lastYAxis=t.yaxis?x.clone(t.yaxis):[],c.globals.initialConfig=x.extend({},c.config),c.globals.initialSeries=x.clone(c.config.series),t.series))){for(var d=0;d2&&void 0!==arguments[2]&&arguments[2];return new Promise((function(s){var r,o=i.w;return o.globals.shouldAnimate=e,o.globals.dataChanged=!0,e&&i.ctx.series.getPreviousPaths(),o.globals.axisCharts?(0===(r=t.map((function(t,e){return i._extendSeries(t,e)}))).length&&(r=[{data:[]}]),o.config.series=r):o.config.series=t.slice(),a&&(o.globals.initialConfig.series=x.clone(o.config.series),o.globals.initialSeries=x.clone(o.config.series)),i.ctx.update().then((function(){s(i.ctx)}))}))}},{key:"_extendSeries",value:function(t,i){var a=this.w,s=a.config.series[i];return e(e({},a.config.series[i]),{},{name:t.name?t.name:s&&s.name,color:t.color?t.color:s&&s.color,type:t.type?t.type:s&&s.type,data:t.data?t.data:s&&s.data})}},{key:"toggleDataPointSelection",value:function(t,e){var i=this.w,a=null,s=".apexcharts-series[data\\:realIndex='".concat(t,"']");return i.globals.axisCharts?a=i.globals.dom.Paper.select("".concat(s," path[j='").concat(e,"'], ").concat(s," circle[j='").concat(e,"'], ").concat(s," rect[j='").concat(e,"']")).members[0]:void 0===e&&(a=i.globals.dom.Paper.select("".concat(s," path[j='").concat(t,"']")).members[0],"pie"!==i.config.chart.type&&"polarArea"!==i.config.chart.type&&"donut"!==i.config.chart.type||this.ctx.pie.pieClicked(t)),a?(new m(this.ctx).pathMouseDown(a,null),a.node?a.node:null):(console.warn("toggleDataPointSelection: Element not found"),null)}},{key:"forceXAxisUpdate",value:function(t){var e=this.w;if(["min","max"].forEach((function(i){void 0!==t.xaxis[i]&&(e.config.xaxis[i]=t.xaxis[i],e.globals.lastXAxis[i]=t.xaxis[i])})),t.xaxis.categories&&t.xaxis.categories.length&&(e.config.xaxis.categories=t.xaxis.categories),e.config.xaxis.convertedCatToNumeric){var i=new z(t);t=i.convertCatToNumericXaxis(t,this.ctx)}return t}},{key:"forceYAxisUpdate",value:function(t){return t.chart&&t.chart.stacked&&"100%"===t.chart.stackType&&(Array.isArray(t.yaxis)?t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})):(t.yaxis.min=0,t.yaxis.max=100)),t}},{key:"revertDefaultAxisMinMax",value:function(t){var e=this,i=this.w,a=i.globals.lastXAxis,s=i.globals.lastYAxis;t&&t.xaxis&&(a=t.xaxis),t&&t.yaxis&&(s=t.yaxis),i.config.xaxis.min=a.min,i.config.xaxis.max=a.max;var r=function(t){void 0!==s[t]&&(i.config.yaxis[t].min=s[t].min,i.config.yaxis[t].max=s[t].max)};i.config.yaxis.map((function(t,a){i.globals.zoomed||void 0!==s[a]?r(a):void 0!==e.ctx.opts.yaxis[a]&&(t.min=e.ctx.opts.yaxis[a].min,t.max=e.ctx.opts.yaxis[a].max)}))}}]),t}();zt="undefined"!=typeof window?window:void 0,Et=function(t,e){var a=(void 0!==this?this:t).SVG=function(t){if(a.supported)return t=new a.Doc(t),a.parser.draw||a.prepare(),t};if(a.ns="http://www.w3.org/2000/svg",a.xmlns="http://www.w3.org/2000/xmlns/",a.xlink="http://www.w3.org/1999/xlink",a.svgjs="http://svgjs.dev",a.supported=!0,!a.supported)return!1;a.did=1e3,a.eid=function(t){return"Svgjs"+d(t)+a.did++},a.create=function(t){var i=e.createElementNS(this.ns,t);return i.setAttribute("id",this.eid(t)),i},a.extend=function(){var t,e;e=(t=[].slice.call(arguments)).pop();for(var i=t.length-1;i>=0;i--)if(t[i])for(var s in e)t[i].prototype[s]=e[s];a.Set&&a.Set.inherit&&a.Set.inherit()},a.invent=function(t){var e="function"==typeof t.create?t.create:function(){this.constructor.call(this,a.create(t.create))};return t.inherit&&(e.prototype=new t.inherit),t.extend&&a.extend(e,t.extend),t.construct&&a.extend(t.parent||a.Container,t.construct),e},a.adopt=function(e){return e?e.instance?e.instance:((i="svg"==e.nodeName?e.parentNode instanceof t.SVGElement?new a.Nested:new a.Doc:"linearGradient"==e.nodeName?new a.Gradient("linear"):"radialGradient"==e.nodeName?new a.Gradient("radial"):a[d(e.nodeName)]?new(a[d(e.nodeName)]):new a.Element(e)).type=e.nodeName,i.node=e,e.instance=i,i instanceof a.Doc&&i.namespace().defs(),i.setData(JSON.parse(e.getAttribute("svgjs:data"))||{}),i):null;var i},a.prepare=function(){var t=e.getElementsByTagName("body")[0],i=(t?new a.Doc(t):a.adopt(e.documentElement).nested()).size(2,0);a.parser={body:t||e.documentElement,draw:i.style("opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden").node,poly:i.polyline().node,path:i.path().node,native:a.create("svg")}},a.parser={native:a.create("svg")},e.addEventListener("DOMContentLoaded",(function(){a.parser.draw||a.prepare()}),!1),a.regex={numberAndUnit:/^([+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?)([a-z%]*)$/i,hex:/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i,rgb:/rgb\((\d+),(\d+),(\d+)\)/,reference:/#([a-z0-9\-_]+)/i,transforms:/\)\s*,?\s*/,whitespace:/\s/g,isHex:/^#[a-f0-9]{3,6}$/i,isRgb:/^rgb\(/,isCss:/[^:]+:[^;]+;?/,isBlank:/^(\s+)?$/,isNumber:/^[+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i,isPercent:/^-?[\d\.]+%$/,isImage:/\.(jpg|jpeg|png|gif|svg)(\?[^=]+.*)?/i,delimiter:/[\s,]+/,hyphen:/([^e])\-/gi,pathLetters:/[MLHVCSQTAZ]/gi,isPathLetter:/[MLHVCSQTAZ]/i,numbersWithDots:/((\d?\.\d+(?:e[+-]?\d+)?)((?:\.\d+(?:e[+-]?\d+)?)+))+/gi,dots:/\./g},a.utils={map:function(t,e){for(var i=t.length,a=[],s=0;s1?1:t,new a.Color({r:~~(this.r+(this.destination.r-this.r)*t),g:~~(this.g+(this.destination.g-this.g)*t),b:~~(this.b+(this.destination.b-this.b)*t)})):this}}),a.Color.test=function(t){return t+="",a.regex.isHex.test(t)||a.regex.isRgb.test(t)},a.Color.isRgb=function(t){return t&&"number"==typeof t.r&&"number"==typeof t.g&&"number"==typeof t.b},a.Color.isColor=function(t){return a.Color.isRgb(t)||a.Color.test(t)},a.Array=function(t,e){0==(t=(t||[]).valueOf()).length&&e&&(t=e.valueOf()),this.value=this.parse(t)},a.extend(a.Array,{toString:function(){return this.value.join(" ")},valueOf:function(){return this.value},parse:function(t){return t=t.valueOf(),Array.isArray(t)?t:this.split(t)}}),a.PointArray=function(t,e){a.Array.call(this,t,e||[[0,0]])},a.PointArray.prototype=new a.Array,a.PointArray.prototype.constructor=a.PointArray;for(var s={M:function(t,e,i){return e.x=i.x=t[0],e.y=i.y=t[1],["M",e.x,e.y]},L:function(t,e){return e.x=t[0],e.y=t[1],["L",t[0],t[1]]},H:function(t,e){return e.x=t[0],["H",t[0]]},V:function(t,e){return e.y=t[0],["V",t[0]]},C:function(t,e){return e.x=t[4],e.y=t[5],["C",t[0],t[1],t[2],t[3],t[4],t[5]]},Q:function(t,e){return e.x=t[2],e.y=t[3],["Q",t[0],t[1],t[2],t[3]]},Z:function(t,e,i){return e.x=i.x,e.y=i.y,["Z"]}},r="mlhvqtcsaz".split(""),o=0,n=r.length;ol);return r},bbox:function(){return a.parser.draw||a.prepare(),a.parser.path.setAttribute("d",this.toString()),a.parser.path.getBBox()}}),a.Number=a.invent({create:function(t,e){this.value=0,this.unit=e||"","number"==typeof t?this.value=isNaN(t)?0:isFinite(t)?t:t<0?-34e37:34e37:"string"==typeof t?(e=t.match(a.regex.numberAndUnit))&&(this.value=parseFloat(e[1]),"%"==e[5]?this.value/=100:"s"==e[5]&&(this.value*=1e3),this.unit=e[5]):t instanceof a.Number&&(this.value=t.valueOf(),this.unit=t.unit)},extend:{toString:function(){return("%"==this.unit?~~(1e8*this.value)/1e6:"s"==this.unit?this.value/1e3:this.value)+this.unit},toJSON:function(){return this.toString()},valueOf:function(){return this.value},plus:function(t){return t=new a.Number(t),new a.Number(this+t,this.unit||t.unit)},minus:function(t){return t=new a.Number(t),new a.Number(this-t,this.unit||t.unit)},times:function(t){return t=new a.Number(t),new a.Number(this*t,this.unit||t.unit)},divide:function(t){return t=new a.Number(t),new a.Number(this/t,this.unit||t.unit)},to:function(t){var e=new a.Number(this);return"string"==typeof t&&(e.unit=t),e},morph:function(t){return this.destination=new a.Number(t),t.relative&&(this.destination.value+=this.value),this},at:function(t){return this.destination?new a.Number(this.destination).minus(this).times(t).plus(this):this}}}),a.Element=a.invent({create:function(t){this._stroke=a.defaults.attrs.stroke,this._event=null,this.dom={},(this.node=t)&&(this.type=t.nodeName,this.node.instance=this,this._stroke=t.getAttribute("stroke")||this._stroke)},extend:{x:function(t){return this.attr("x",t)},y:function(t){return this.attr("y",t)},cx:function(t){return null==t?this.x()+this.width()/2:this.x(t-this.width()/2)},cy:function(t){return null==t?this.y()+this.height()/2:this.y(t-this.height()/2)},move:function(t,e){return this.x(t).y(e)},center:function(t,e){return this.cx(t).cy(e)},width:function(t){return this.attr("width",t)},height:function(t){return this.attr("height",t)},size:function(t,e){var i=u(this,t,e);return this.width(new a.Number(i.width)).height(new a.Number(i.height))},clone:function(t){this.writeDataToDom();var e=x(this.node.cloneNode(!0));return t?t.add(e):this.after(e),e},remove:function(){return this.parent()&&this.parent().removeElement(this),this},replace:function(t){return this.after(t).remove(),t},addTo:function(t){return t.put(this)},putIn:function(t){return t.add(this)},id:function(t){return this.attr("id",t)},show:function(){return this.style("display","")},hide:function(){return this.style("display","none")},visible:function(){return"none"!=this.style("display")},toString:function(){return this.attr("id")},classes:function(){var t=this.attr("class");return null==t?[]:t.trim().split(a.regex.delimiter)},hasClass:function(t){return-1!=this.classes().indexOf(t)},addClass:function(t){if(!this.hasClass(t)){var e=this.classes();e.push(t),this.attr("class",e.join(" "))}return this},removeClass:function(t){return this.hasClass(t)&&this.attr("class",this.classes().filter((function(e){return e!=t})).join(" ")),this},toggleClass:function(t){return this.hasClass(t)?this.removeClass(t):this.addClass(t)},reference:function(t){return a.get(this.attr(t))},parent:function(e){var i=this;if(!i.node.parentNode)return null;if(i=a.adopt(i.node.parentNode),!e)return i;for(;i&&i.node instanceof t.SVGElement;){if("string"==typeof e?i.matches(e):i instanceof e)return i;if(!i.node.parentNode||"#document"==i.node.parentNode.nodeName)return null;i=a.adopt(i.node.parentNode)}},doc:function(){return this instanceof a.Doc?this:this.parent(a.Doc)},parents:function(t){var e=[],i=this;do{if(!(i=i.parent(t))||!i.node)break;e.push(i)}while(i.parent);return e},matches:function(t){return function(t,e){return(t.matches||t.matchesSelector||t.msMatchesSelector||t.mozMatchesSelector||t.webkitMatchesSelector||t.oMatchesSelector).call(t,e)}(this.node,t)},native:function(){return this.node},svg:function(t){var i=e.createElement("svg");if(!(t&&this instanceof a.Parent))return i.appendChild(t=e.createElement("svg")),this.writeDataToDom(),t.appendChild(this.node.cloneNode(!0)),i.innerHTML.replace(/^/,"").replace(/<\/svg>$/,"");i.innerHTML=""+t.replace(/\n/,"").replace(/<([\w:-]+)([^<]+?)\/>/g,"<$1$2>")+"";for(var s=0,r=i.firstChild.childNodes.length;s":function(t){return-Math.cos(t*Math.PI)/2+.5},">":function(t){return Math.sin(t*Math.PI/2)},"<":function(t){return 1-Math.cos(t*Math.PI/2)}},a.morph=function(t){return function(e,i){return new a.MorphObj(e,i).at(t)}},a.Situation=a.invent({create:function(t){this.init=!1,this.reversed=!1,this.reversing=!1,this.duration=new a.Number(t.duration).valueOf(),this.delay=new a.Number(t.delay).valueOf(),this.start=+new Date+this.delay,this.finish=this.start+this.duration,this.ease=t.ease,this.loop=0,this.loops=!1,this.animations={},this.attrs={},this.styles={},this.transforms=[],this.once={}}}),a.FX=a.invent({create:function(t){this._target=t,this.situations=[],this.active=!1,this.situation=null,this.paused=!1,this.lastPos=0,this.pos=0,this.absPos=0,this._speed=1},extend:{animate:function(t,e,s){"object"===i(t)&&(e=t.ease,s=t.delay,t=t.duration);var r=new a.Situation({duration:t||1e3,delay:s||0,ease:a.easing[e||"-"]||e});return this.queue(r),this},target:function(t){return t&&t instanceof a.Element?(this._target=t,this):this._target},timeToAbsPos:function(t){return(t-this.situation.start)/(this.situation.duration/this._speed)},absPosToTime:function(t){return this.situation.duration/this._speed*t+this.situation.start},startAnimFrame:function(){this.stopAnimFrame(),this.animationFrame=t.requestAnimationFrame(function(){this.step()}.bind(this))},stopAnimFrame:function(){t.cancelAnimationFrame(this.animationFrame)},start:function(){return!this.active&&this.situation&&(this.active=!0,this.startCurrent()),this},startCurrent:function(){return this.situation.start=+new Date+this.situation.delay/this._speed,this.situation.finish=this.situation.start+this.situation.duration/this._speed,this.initAnimations().step()},queue:function(t){return("function"==typeof t||t instanceof a.Situation)&&this.situations.push(t),this.situation||(this.situation=this.situations.shift()),this},dequeue:function(){return this.stop(),this.situation=this.situations.shift(),this.situation&&(this.situation instanceof a.Situation?this.start():this.situation.call(this)),this},initAnimations:function(){var t,e=this.situation;if(e.init)return this;for(var i in e.animations){t=this.target()[i](),Array.isArray(t)||(t=[t]),Array.isArray(e.animations[i])||(e.animations[i]=[e.animations[i]]);for(var s=t.length;s--;)e.animations[i][s]instanceof a.Number&&(t[s]=new a.Number(t[s])),e.animations[i][s]=t[s].morph(e.animations[i][s])}for(var i in e.attrs)e.attrs[i]=new a.MorphObj(this.target().attr(i),e.attrs[i]);for(var i in e.styles)e.styles[i]=new a.MorphObj(this.target().style(i),e.styles[i]);return e.initialTransformation=this.target().matrixify(),e.init=!0,this},clearQueue:function(){return this.situations=[],this},clearCurrent:function(){return this.situation=null,this},stop:function(t,e){var i=this.active;return this.active=!1,e&&this.clearQueue(),t&&this.situation&&(!i&&this.startCurrent(),this.atEnd()),this.stopAnimFrame(),this.clearCurrent()},after:function(t){var e=this.last();return this.target().on("finished.fx",(function i(a){a.detail.situation==e&&(t.call(this,e),this.off("finished.fx",i))})),this._callStart()},during:function(t){var e=this.last(),i=function(i){i.detail.situation==e&&t.call(this,i.detail.pos,a.morph(i.detail.pos),i.detail.eased,e)};return this.target().off("during.fx",i).on("during.fx",i),this.after((function(){this.off("during.fx",i)})),this._callStart()},afterAll:function(t){var e=function e(i){t.call(this),this.off("allfinished.fx",e)};return this.target().off("allfinished.fx",e).on("allfinished.fx",e),this._callStart()},last:function(){return this.situations.length?this.situations[this.situations.length-1]:this.situation},add:function(t,e,i){return this.last()[i||"animations"][t]=e,this._callStart()},step:function(t){var e,i,a;t||(this.absPos=this.timeToAbsPos(+new Date)),!1!==this.situation.loops?(e=Math.max(this.absPos,0),i=Math.floor(e),!0===this.situation.loops||ithis.lastPos&&r<=s&&(this.situation.once[r].call(this.target(),this.pos,s),delete this.situation.once[r]);return this.active&&this.target().fire("during",{pos:this.pos,eased:s,fx:this,situation:this.situation}),this.situation?(this.eachAt(),1==this.pos&&!this.situation.reversed||this.situation.reversed&&0==this.pos?(this.stopAnimFrame(),this.target().fire("finished",{fx:this,situation:this.situation}),this.situations.length||(this.target().fire("allfinished"),this.situations.length||(this.target().off(".fx"),this.active=!1)),this.active?this.dequeue():this.clearCurrent()):!this.paused&&this.active&&this.startAnimFrame(),this.lastPos=s,this):this},eachAt:function(){var t,e=this,i=this.target(),s=this.situation;for(var r in s.animations)t=[].concat(s.animations[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i[r].apply(i,t);for(var r in s.attrs)t=[r].concat(s.attrs[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i.attr.apply(i,t);for(var r in s.styles)t=[r].concat(s.styles[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i.style.apply(i,t);if(s.transforms.length){t=s.initialTransformation,r=0;for(var o=s.transforms.length;r=0;--s)this[v[s]]=null!=t[v[s]]?t[v[s]]:e[v[s]]},extend:{extract:function(){var t=p(this,0,1);p(this,1,0);var e=180/Math.PI*Math.atan2(t.y,t.x)-90;return{x:this.e,y:this.f,transformedX:(this.e*Math.cos(e*Math.PI/180)+this.f*Math.sin(e*Math.PI/180))/Math.sqrt(this.a*this.a+this.b*this.b),transformedY:(this.f*Math.cos(e*Math.PI/180)+this.e*Math.sin(-e*Math.PI/180))/Math.sqrt(this.c*this.c+this.d*this.d),rotation:e,a:this.a,b:this.b,c:this.c,d:this.d,e:this.e,f:this.f,matrix:new a.Matrix(this)}},clone:function(){return new a.Matrix(this)},morph:function(t){return this.destination=new a.Matrix(t),this},multiply:function(t){return new a.Matrix(this.native().multiply(function(t){return t instanceof a.Matrix||(t=new a.Matrix(t)),t}(t).native()))},inverse:function(){return new a.Matrix(this.native().inverse())},translate:function(t,e){return new a.Matrix(this.native().translate(t||0,e||0))},native:function(){for(var t=a.parser.native.createSVGMatrix(),e=v.length-1;e>=0;e--)t[v[e]]=this[v[e]];return t},toString:function(){return"matrix("+b(this.a)+","+b(this.b)+","+b(this.c)+","+b(this.d)+","+b(this.e)+","+b(this.f)+")"}},parent:a.Element,construct:{ctm:function(){return new a.Matrix(this.node.getCTM())},screenCTM:function(){if(this instanceof a.Nested){var t=this.rect(1,1),e=t.node.getScreenCTM();return t.remove(),new a.Matrix(e)}return new a.Matrix(this.node.getScreenCTM())}}}),a.Point=a.invent({create:function(t,e){var a;a=Array.isArray(t)?{x:t[0],y:t[1]}:"object"===i(t)?{x:t.x,y:t.y}:null!=t?{x:t,y:null!=e?e:t}:{x:0,y:0},this.x=a.x,this.y=a.y},extend:{clone:function(){return new a.Point(this)},morph:function(t,e){return this.destination=new a.Point(t,e),this}}}),a.extend(a.Element,{point:function(t,e){return new a.Point(t,e).transform(this.screenCTM().inverse())}}),a.extend(a.Element,{attr:function(t,e,s){if(null==t){for(t={},s=(e=this.node.attributes).length-1;s>=0;s--)t[e[s].nodeName]=a.regex.isNumber.test(e[s].nodeValue)?parseFloat(e[s].nodeValue):e[s].nodeValue;return t}if("object"===i(t))for(var r in t)this.attr(r,t[r]);else if(null===e)this.node.removeAttribute(t);else{if(null==e)return null==(e=this.node.getAttribute(t))?a.defaults.attrs[t]:a.regex.isNumber.test(e)?parseFloat(e):e;"stroke-width"==t?this.attr("stroke",parseFloat(e)>0?this._stroke:null):"stroke"==t&&(this._stroke=e),"fill"!=t&&"stroke"!=t||(a.regex.isImage.test(e)&&(e=this.doc().defs().image(e,0,0)),e instanceof a.Image&&(e=this.doc().defs().pattern(0,0,(function(){this.add(e)})))),"number"==typeof e?e=new a.Number(e):a.Color.isColor(e)?e=new a.Color(e):Array.isArray(e)&&(e=new a.Array(e)),"leading"==t?this.leading&&this.leading(e):"string"==typeof s?this.node.setAttributeNS(s,t,e.toString()):this.node.setAttribute(t,e.toString()),!this.rebuild||"font-size"!=t&&"x"!=t||this.rebuild(t,e)}return this}}),a.extend(a.Element,{transform:function(t,e){var s;return"object"!==i(t)?(s=new a.Matrix(this).extract(),"string"==typeof t?s[t]:s):(s=new a.Matrix(this),e=!!e||!!t.relative,null!=t.a&&(s=e?s.multiply(new a.Matrix(t)):new a.Matrix(t)),this.attr("transform",s))}}),a.extend(a.Element,{untransform:function(){return this.attr("transform",null)},matrixify:function(){return(this.attr("transform")||"").split(a.regex.transforms).slice(0,-1).map((function(t){var e=t.trim().split("(");return[e[0],e[1].split(a.regex.delimiter).map((function(t){return parseFloat(t)}))]})).reduce((function(t,e){return"matrix"==e[0]?t.multiply(f(e[1])):t[e[0]].apply(t,e[1])}),new a.Matrix)},toParent:function(t){if(this==t)return this;var e=this.screenCTM(),i=t.screenCTM().inverse();return this.addTo(t).untransform().transform(i.multiply(e)),this},toDoc:function(){return this.toParent(this.doc())}}),a.Transformation=a.invent({create:function(t,e){if(arguments.length>1&&"boolean"!=typeof e)return this.constructor.call(this,[].slice.call(arguments));if(Array.isArray(t))for(var a=0,s=this.arguments.length;a=0},index:function(t){return[].slice.call(this.node.childNodes).indexOf(t.node)},get:function(t){return a.adopt(this.node.childNodes[t])},first:function(){return this.get(0)},last:function(){return this.get(this.node.childNodes.length-1)},each:function(t,e){for(var i=this.children(),s=0,r=i.length;s=0;i--)e.childNodes[i]instanceof t.SVGElement&&x(e.childNodes[i]);return a.adopt(e).id(a.eid(e.nodeName))}function b(t){return Math.abs(t)>1e-37?t:0}["fill","stroke"].forEach((function(t){var e={};e[t]=function(e){if(void 0===e)return this;if("string"==typeof e||a.Color.isRgb(e)||e&&"function"==typeof e.fill)this.attr(t,e);else for(var i=l[t].length-1;i>=0;i--)null!=e[l[t][i]]&&this.attr(l.prefix(t,l[t][i]),e[l[t][i]]);return this},a.extend(a.Element,a.FX,e)})),a.extend(a.Element,a.FX,{translate:function(t,e){return this.transform({x:t,y:e})},matrix:function(t){return this.attr("transform",new a.Matrix(6==arguments.length?[].slice.call(arguments):t))},opacity:function(t){return this.attr("opacity",t)},dx:function(t){return this.x(new a.Number(t).plus(this instanceof a.FX?0:this.x()),!0)},dy:function(t){return this.y(new a.Number(t).plus(this instanceof a.FX?0:this.y()),!0)}}),a.extend(a.Path,{length:function(){return this.node.getTotalLength()},pointAt:function(t){return this.node.getPointAtLength(t)}}),a.Set=a.invent({create:function(t){Array.isArray(t)?this.members=t:this.clear()},extend:{add:function(){for(var t=[].slice.call(arguments),e=0,i=t.length;e-1&&this.members.splice(e,1),this},each:function(t){for(var e=0,i=this.members.length;e=0},index:function(t){return this.members.indexOf(t)},get:function(t){return this.members[t]},first:function(){return this.get(0)},last:function(){return this.get(this.members.length-1)},valueOf:function(){return this.members}},construct:{set:function(t){return new a.Set(t)}}}),a.FX.Set=a.invent({create:function(t){this.set=t}}),a.Set.inherit=function(){var t=[];for(var e in a.Shape.prototype)"function"==typeof a.Shape.prototype[e]&&"function"!=typeof a.Set.prototype[e]&&t.push(e);for(var e in t.forEach((function(t){a.Set.prototype[t]=function(){for(var e=0,i=this.members.length;e=0;t--)delete this.memory()[arguments[t]];return this},memory:function(){return this._memory||(this._memory={})}}),a.get=function(t){var i=e.getElementById(function(t){var e=(t||"").toString().match(a.regex.reference);if(e)return e[1]}(t)||t);return a.adopt(i)},a.select=function(t,i){return new a.Set(a.utils.map((i||e).querySelectorAll(t),(function(t){return a.adopt(t)})))},a.extend(a.Parent,{select:function(t){return a.select(t,this.node)}});var v="abcdef".split("");if("function"!=typeof t.CustomEvent){var m=function(t,i){i=i||{bubbles:!1,cancelable:!1,detail:void 0};var a=e.createEvent("CustomEvent");return a.initCustomEvent(t,i.bubbles,i.cancelable,i.detail),a};m.prototype=t.Event.prototype,a.CustomEvent=m}else a.CustomEvent=t.CustomEvent;return a},"function"==typeof define&&define.amd?define((function(){return Et(zt,zt.document)})):"object"===("undefined"==typeof exports?"undefined":i(exports))&&"undefined"!=typeof module?module.exports=zt.document?Et(zt,zt.document):function(t){return Et(t,t.document)}:zt.SVG=Et(zt,zt.document), -/*! svg.filter.js - v2.0.2 - 2016-02-24 -* https://github.com/wout/svg.filter.js -* Copyright (c) 2016 Wout Fierens; Licensed MIT */ -function(){SVG.Filter=SVG.invent({create:"filter",inherit:SVG.Parent,extend:{source:"SourceGraphic",sourceAlpha:"SourceAlpha",background:"BackgroundImage",backgroundAlpha:"BackgroundAlpha",fill:"FillPaint",stroke:"StrokePaint",autoSetIn:!0,put:function(t,e){return this.add(t,e),!t.attr("in")&&this.autoSetIn&&t.attr("in",this.source),t.attr("result")||t.attr("result",t),t},blend:function(t,e,i){return this.put(new SVG.BlendEffect(t,e,i))},colorMatrix:function(t,e){return this.put(new SVG.ColorMatrixEffect(t,e))},convolveMatrix:function(t){return this.put(new SVG.ConvolveMatrixEffect(t))},componentTransfer:function(t){return this.put(new SVG.ComponentTransferEffect(t))},composite:function(t,e,i){return this.put(new SVG.CompositeEffect(t,e,i))},flood:function(t,e){return this.put(new SVG.FloodEffect(t,e))},offset:function(t,e){return this.put(new SVG.OffsetEffect(t,e))},image:function(t){return this.put(new SVG.ImageEffect(t))},merge:function(){var t=[void 0];for(var e in arguments)t.push(arguments[e]);return this.put(new(SVG.MergeEffect.bind.apply(SVG.MergeEffect,t)))},gaussianBlur:function(t,e){return this.put(new SVG.GaussianBlurEffect(t,e))},morphology:function(t,e){return this.put(new SVG.MorphologyEffect(t,e))},diffuseLighting:function(t,e,i){return this.put(new SVG.DiffuseLightingEffect(t,e,i))},displacementMap:function(t,e,i,a,s){return this.put(new SVG.DisplacementMapEffect(t,e,i,a,s))},specularLighting:function(t,e,i,a){return this.put(new SVG.SpecularLightingEffect(t,e,i,a))},tile:function(){return this.put(new SVG.TileEffect)},turbulence:function(t,e,i,a,s){return this.put(new SVG.TurbulenceEffect(t,e,i,a,s))},toString:function(){return"url(#"+this.attr("id")+")"}}}),SVG.extend(SVG.Defs,{filter:function(t){var e=this.put(new SVG.Filter);return"function"==typeof t&&t.call(e,e),e}}),SVG.extend(SVG.Container,{filter:function(t){return this.defs().filter(t)}}),SVG.extend(SVG.Element,SVG.G,SVG.Nested,{filter:function(t){return this.filterer=t instanceof SVG.Element?t:this.doc().filter(t),this.doc()&&this.filterer.doc()!==this.doc()&&this.doc().defs().add(this.filterer),this.attr("filter",this.filterer),this.filterer},unfilter:function(t){return this.filterer&&!0===t&&this.filterer.remove(),delete this.filterer,this.attr("filter",null)}}),SVG.Effect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}}),SVG.ParentEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Parent,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}});var t={blend:function(t,e){return this.parent()&&this.parent().blend(this,t,e)},colorMatrix:function(t,e){return this.parent()&&this.parent().colorMatrix(t,e).in(this)},convolveMatrix:function(t){return this.parent()&&this.parent().convolveMatrix(t).in(this)},componentTransfer:function(t){return this.parent()&&this.parent().componentTransfer(t).in(this)},composite:function(t,e){return this.parent()&&this.parent().composite(this,t,e)},flood:function(t,e){return this.parent()&&this.parent().flood(t,e)},offset:function(t,e){return this.parent()&&this.parent().offset(t,e).in(this)},image:function(t){return this.parent()&&this.parent().image(t)},merge:function(){return this.parent()&&this.parent().merge.apply(this.parent(),[this].concat(arguments))},gaussianBlur:function(t,e){return this.parent()&&this.parent().gaussianBlur(t,e).in(this)},morphology:function(t,e){return this.parent()&&this.parent().morphology(t,e).in(this)},diffuseLighting:function(t,e,i){return this.parent()&&this.parent().diffuseLighting(t,e,i).in(this)},displacementMap:function(t,e,i,a){return this.parent()&&this.parent().displacementMap(this,t,e,i,a)},specularLighting:function(t,e,i,a){return this.parent()&&this.parent().specularLighting(t,e,i,a).in(this)},tile:function(){return this.parent()&&this.parent().tile().in(this)},turbulence:function(t,e,i,a,s){return this.parent()&&this.parent().turbulence(t,e,i,a,s).in(this)}};SVG.extend(SVG.Effect,t),SVG.extend(SVG.ParentEffect,t),SVG.ChildEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){this.attr("in",t)}}});var e={blend:function(t,e,i){this.attr({in:t,in2:e,mode:i||"normal"})},colorMatrix:function(t,e){"matrix"==t&&(e=s(e)),this.attr({type:t,values:void 0===e?null:e})},convolveMatrix:function(t){t=s(t),this.attr({order:Math.sqrt(t.split(" ").length),kernelMatrix:t})},composite:function(t,e,i){this.attr({in:t,in2:e,operator:i})},flood:function(t,e){this.attr("flood-color",t),null!=e&&this.attr("flood-opacity",e)},offset:function(t,e){this.attr({dx:t,dy:e})},image:function(t){this.attr("href",t,SVG.xlink)},displacementMap:function(t,e,i,a,s){this.attr({in:t,in2:e,scale:i,xChannelSelector:a,yChannelSelector:s})},gaussianBlur:function(t,e){null!=t||null!=e?this.attr("stdDeviation",function(t){if(!Array.isArray(t))return t;for(var e=0,i=t.length,a=[];e1&&(I*=a=Math.sqrt(a),T*=a);s=(new SVG.Matrix).rotate(M).scale(1/I,1/T).rotate(-M),F=F.transform(s),R=R.transform(s),r=[R.x-F.x,R.y-F.y],n=r[0]*r[0]+r[1]*r[1],o=Math.sqrt(n),r[0]/=o,r[1]/=o,l=n<4?Math.sqrt(1-n/4):0,X===z&&(l*=-1);h=new SVG.Point((R.x+F.x)/2+l*-r[1],(R.y+F.y)/2+l*r[0]),c=new SVG.Point(F.x-h.x,F.y-h.y),d=new SVG.Point(R.x-h.x,R.y-h.y),g=Math.acos(c.x/Math.sqrt(c.x*c.x+c.y*c.y)),c.y<0&&(g*=-1);u=Math.acos(d.x/Math.sqrt(d.x*d.x+d.y*d.y)),d.y<0&&(u*=-1);z&&g>u&&(u+=2*Math.PI);!z&&gr.maxX-e.width&&(o=(a=r.maxX-e.width)-this.startPoints.box.x),null!=r.minY&&sr.maxY-e.height&&(n=(s=r.maxY-e.height)-this.startPoints.box.y),null!=r.snapToGrid&&(a-=a%r.snapToGrid,s-=s%r.snapToGrid,o-=o%r.snapToGrid,n-=n%r.snapToGrid),this.el instanceof SVG.G?this.el.matrix(this.startPoints.transform).transform({x:o,y:n},!0):this.el.move(a,s));return i},t.prototype.end=function(t){var e=this.drag(t);this.el.fire("dragend",{event:t,p:e,m:this.m,handler:this}),SVG.off(window,"mousemove.drag"),SVG.off(window,"touchmove.drag"),SVG.off(window,"mouseup.drag"),SVG.off(window,"touchend.drag")},SVG.extend(SVG.Element,{draggable:function(e,i){"function"!=typeof e&&"object"!=typeof e||(i=e,e=!0);var a=this.remember("_draggable")||new t(this);return(e=void 0===e||e)?a.init(i||{},e):(this.off("mousedown.drag"),this.off("touchstart.drag")),this}})}.call(void 0),function(){function t(t){this.el=t,t.remember("_selectHandler",this),this.pointSelection={isSelected:!1},this.rectSelection={isSelected:!1},this.pointsList={lt:[0,0],rt:["width",0],rb:["width","height"],lb:[0,"height"],t:["width",0],r:["width","height"],b:["width","height"],l:[0,"height"]},this.pointCoord=function(t,e,i){var a="string"!=typeof t?t:e[t];return i?a/2:a},this.pointCoords=function(t,e){var i=this.pointsList[t];return{x:this.pointCoord(i[0],e,"t"===t||"b"===t),y:this.pointCoord(i[1],e,"r"===t||"l"===t)}}}t.prototype.init=function(t,e){var i=this.el.bbox();this.options={};var a=this.el.selectize.defaults.points;for(var s in this.el.selectize.defaults)this.options[s]=this.el.selectize.defaults[s],void 0!==e[s]&&(this.options[s]=e[s]);var r=["points","pointsExclude"];for(var s in r){var o=this.options[r[s]];"string"==typeof o?o=o.length>0?o.split(/\s*,\s*/i):[]:"boolean"==typeof o&&"points"===r[s]&&(o=o?a:[]),this.options[r[s]]=o}this.options.points=[a,this.options.points].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)>-1}))})),this.options.points=[this.options.points,this.options.pointsExclude].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)<0}))})),this.parent=this.el.parent(),this.nested=this.nested||this.parent.group(),this.nested.matrix(new SVG.Matrix(this.el).translate(i.x,i.y)),this.options.deepSelect&&-1!==["line","polyline","polygon"].indexOf(this.el.type)?this.selectPoints(t):this.selectRect(t),this.observe(),this.cleanup()},t.prototype.selectPoints=function(t){return this.pointSelection.isSelected=t,this.pointSelection.set||(this.pointSelection.set=this.parent.set(),this.drawPoints()),this},t.prototype.getPointArray=function(){var t=this.el.bbox();return this.el.array().valueOf().map((function(e){return[e[0]-t.x,e[1]-t.y]}))},t.prototype.drawPoints=function(){for(var t=this,e=this.getPointArray(),i=0,a=e.length;i0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y+i[1]).size(this.parameters.box.width-i[0],this.parameters.box.height-i[1])}};break;case"rt":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).size(this.parameters.box.width+i[0],this.parameters.box.height-i[1])}};break;case"rb":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x,this.parameters.box.y).size(this.parameters.box.width+i[0],this.parameters.box.height+i[1])}};break;case"lb":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).size(this.parameters.box.width-i[0],this.parameters.box.height+i[1])}};break;case"t":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).height(this.parameters.box.height-i[1])}};break;case"r":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).width(this.parameters.box.width+i[0])}};break;case"b":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).height(this.parameters.box.height+i[1])}};break;case"l":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).width(this.parameters.box.width-i[0])}};break;case"rot":this.calc=function(t,e){var i=t+this.parameters.p.x,a=e+this.parameters.p.y,s=Math.atan2(this.parameters.p.y-this.parameters.box.y-this.parameters.box.height/2,this.parameters.p.x-this.parameters.box.x-this.parameters.box.width/2),r=Math.atan2(a-this.parameters.box.y-this.parameters.box.height/2,i-this.parameters.box.x-this.parameters.box.width/2),o=this.parameters.rotation+180*(r-s)/Math.PI+this.options.snapToAngle/2;this.el.center(this.parameters.box.cx,this.parameters.box.cy).rotate(o-o%this.options.snapToAngle,this.parameters.box.cx,this.parameters.box.cy)};break;case"point":this.calc=function(t,e){var i=this.snapToGrid(t,e,this.parameters.pointCoords[0],this.parameters.pointCoords[1]),a=this.el.array().valueOf();a[this.parameters.i][0]=this.parameters.pointCoords[0]+i[0],a[this.parameters.i][1]=this.parameters.pointCoords[1]+i[1],this.el.plot(a)}}this.el.fire("resizestart",{dx:this.parameters.x,dy:this.parameters.y,event:t}),SVG.on(window,"touchmove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"touchend.resize",(function(){e.done()})),SVG.on(window,"mousemove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"mouseup.resize",(function(){e.done()}))},t.prototype.update=function(t){if(t){var e=this._extractPosition(t),i=this.transformPoint(e.x,e.y),a=i.x-this.parameters.p.x,s=i.y-this.parameters.p.y;this.lastUpdateCall=[a,s],this.calc(a,s),this.el.fire("resizing",{dx:a,dy:s,event:t})}else this.lastUpdateCall&&this.calc(this.lastUpdateCall[0],this.lastUpdateCall[1])},t.prototype.done=function(){this.lastUpdateCall=null,SVG.off(window,"mousemove.resize"),SVG.off(window,"mouseup.resize"),SVG.off(window,"touchmove.resize"),SVG.off(window,"touchend.resize"),this.el.fire("resizedone")},t.prototype.snapToGrid=function(t,e,i,a){var s;return void 0!==a?s=[(i+t)%this.options.snapToGrid,(a+e)%this.options.snapToGrid]:(i=null==i?3:i,s=[(this.parameters.box.x+t+(1&i?0:this.parameters.box.width))%this.options.snapToGrid,(this.parameters.box.y+e+(2&i?0:this.parameters.box.height))%this.options.snapToGrid]),t<0&&(s[0]-=this.options.snapToGrid),e<0&&(s[1]-=this.options.snapToGrid),t-=Math.abs(s[0])o.maxX&&(t=o.maxX-s),void 0!==o.minY&&r+eo.maxY&&(e=o.maxY-r),[t,e]},t.prototype.checkAspectRatio=function(t,e){if(!this.options.saveAspectRatio)return t;var i=t.slice(),a=this.parameters.box.width/this.parameters.box.height,s=this.parameters.box.width+t[0],r=this.parameters.box.height-t[1],o=s/r;return oa&&(i[0]=this.parameters.box.width-r*a,e&&(i[0]=-i[0])),i},SVG.extend(SVG.Element,{resize:function(e){return(this.remember("_resizeHandler")||new t(this)).init(e||{}),this}}),SVG.Element.prototype.resize.defaults={snapToAngle:.1,snapToGrid:1,constraint:{},saveAspectRatio:!1}}).call(this)}(),void 0===window.Apex&&(window.Apex={});var Ot=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"initModules",value:function(){this.ctx.publicMethods=["updateOptions","updateSeries","appendData","appendSeries","toggleSeries","showSeries","hideSeries","setLocale","resetSeries","zoomX","toggleDataPointSelection","dataURI","exportToCSV","addXaxisAnnotation","addYaxisAnnotation","addPointAnnotation","clearAnnotations","removeAnnotation","paper","destroy"],this.ctx.eventList=["click","mousedown","mousemove","mouseleave","touchstart","touchmove","touchleave","mouseup","touchend"],this.ctx.animations=new b(this.ctx),this.ctx.axes=new J(this.ctx),this.ctx.core=new Dt(this.ctx.el,this.ctx),this.ctx.config=new E({}),this.ctx.data=new W(this.ctx),this.ctx.grid=new j(this.ctx),this.ctx.graphics=new m(this.ctx),this.ctx.coreUtils=new y(this.ctx),this.ctx.crosshairs=new Q(this.ctx),this.ctx.events=new Z(this.ctx),this.ctx.exports=new G(this.ctx),this.ctx.localization=new $(this.ctx),this.ctx.options=new L,this.ctx.responsive=new K(this.ctx),this.ctx.series=new N(this.ctx),this.ctx.theme=new tt(this.ctx),this.ctx.formatters=new T(this.ctx),this.ctx.titleSubtitle=new et(this.ctx),this.ctx.legend=new lt(this.ctx),this.ctx.toolbar=new ht(this.ctx),this.ctx.tooltip=new bt(this.ctx),this.ctx.dimensions=new ot(this.ctx),this.ctx.updateHelpers=new Ht(this.ctx),this.ctx.zoomPanSelection=new ct(this.ctx),this.ctx.w.globals.tooltip=new bt(this.ctx)}}]),t}(),Nt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"clear",value:function(t){var e=t.isUpdating;this.ctx.zoomPanSelection&&this.ctx.zoomPanSelection.destroy(),this.ctx.toolbar&&this.ctx.toolbar.destroy(),this.ctx.animations=null,this.ctx.axes=null,this.ctx.annotations=null,this.ctx.core=null,this.ctx.data=null,this.ctx.grid=null,this.ctx.series=null,this.ctx.responsive=null,this.ctx.theme=null,this.ctx.formatters=null,this.ctx.titleSubtitle=null,this.ctx.legend=null,this.ctx.dimensions=null,this.ctx.options=null,this.ctx.crosshairs=null,this.ctx.zoomPanSelection=null,this.ctx.updateHelpers=null,this.ctx.toolbar=null,this.ctx.localization=null,this.ctx.w.globals.tooltip=null,this.clearDomElements({isUpdating:e})}},{key:"killSVG",value:function(t){t.each((function(t,e){this.removeClass("*"),this.off(),this.stop()}),!0),t.ungroup(),t.clear()}},{key:"clearDomElements",value:function(t){var e=this,i=t.isUpdating,a=this.w.globals.dom.Paper.node;a.parentNode&&a.parentNode.parentNode&&!i&&(a.parentNode.parentNode.style.minHeight="unset");var s=this.w.globals.dom.baseEl;s&&this.ctx.eventList.forEach((function(t){s.removeEventListener(t,e.ctx.events.documentEvent)}));var r=this.w.globals.dom;if(null!==this.ctx.el)for(;this.ctx.el.firstChild;)this.ctx.el.removeChild(this.ctx.el.firstChild);this.killSVG(r.Paper),r.Paper.remove(),r.elWrap=null,r.elGraphical=null,r.elLegendWrap=null,r.elLegendForeign=null,r.baseEl=null,r.elGridRect=null,r.elGridRectMask=null,r.elGridRectMarkerMask=null,r.elForecastMask=null,r.elNonForecastMask=null,r.elDefs=null}}]),t}(),Wt=new WeakMap;var Bt=function(){function t(e,i){a(this,t),this.opts=i,this.ctx=this,this.w=new F(i).init(),this.el=e,this.w.globals.cuid=x.randomId(),this.w.globals.chartID=this.w.config.chart.id?x.escapeString(this.w.config.chart.id):this.w.globals.cuid,new Ot(this).initModules(),this.create=x.bind(this.create,this),this.windowResizeHandler=this._windowResizeHandler.bind(this),this.parentResizeHandler=this._parentResizeCallback.bind(this)}return r(t,[{key:"render",value:function(){var t=this;return new Promise((function(e,i){if(null!==t.el){void 0===Apex._chartInstances&&(Apex._chartInstances=[]),t.w.config.chart.id&&Apex._chartInstances.push({id:t.w.globals.chartID,group:t.w.config.chart.group,chart:t}),t.setLocale(t.w.config.chart.defaultLocale);var a=t.w.config.chart.events.beforeMount;if("function"==typeof a&&a(t,t.w),t.events.fireEvent("beforeMount",[t,t.w]),window.addEventListener("resize",t.windowResizeHandler),function(t,e){var i=!1;if(t.nodeType!==Node.DOCUMENT_FRAGMENT_NODE){var a=t.getBoundingClientRect();"none"!==t.style.display&&0!==a.width||(i=!0)}var s=new ResizeObserver((function(a){i&&e.call(t,a),i=!0}));t.nodeType===Node.DOCUMENT_FRAGMENT_NODE?Array.from(t.children).forEach((function(t){return s.observe(t)})):s.observe(t),Wt.set(e,s)}(t.el.parentNode,t.parentResizeHandler),!t.css){var s=t.el.getRootNode&&t.el.getRootNode(),r=x.is("ShadowRoot",s),o=t.el.ownerDocument,n=o.getElementById("apexcharts-css");!r&&n||(t.css=document.createElement("style"),t.css.id="apexcharts-css",t.css.textContent='@keyframes opaque {\n 0% {\n opacity: 0\n }\n\n to {\n opacity: 1\n }\n}\n\n@keyframes resizeanim {\n 0%,to {\n opacity: 0\n }\n}\n\n.apexcharts-canvas {\n position: relative;\n user-select: none\n}\n\n.apexcharts-canvas ::-webkit-scrollbar {\n -webkit-appearance: none;\n width: 6px\n}\n\n.apexcharts-canvas ::-webkit-scrollbar-thumb {\n border-radius: 4px;\n background-color: rgba(0,0,0,.5);\n box-shadow: 0 0 1px rgba(255,255,255,.5);\n -webkit-box-shadow: 0 0 1px rgba(255,255,255,.5)\n}\n\n.apexcharts-inner {\n position: relative\n}\n\n.apexcharts-text tspan {\n font-family: inherit\n}\n\n.legend-mouseover-inactive {\n transition: .15s ease all;\n opacity: .2\n}\n\n.apexcharts-legend-text {\n padding-left: 15px;\n margin-left: -15px;\n}\n\n.apexcharts-series-collapsed {\n opacity: 0\n}\n\n.apexcharts-tooltip {\n border-radius: 5px;\n box-shadow: 2px 2px 6px -4px #999;\n cursor: default;\n font-size: 14px;\n left: 62px;\n opacity: 0;\n pointer-events: none;\n position: absolute;\n top: 20px;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n white-space: nowrap;\n z-index: 12;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-theme-light {\n border: 1px solid #e3e3e3;\n background: rgba(255,255,255,.96)\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark {\n color: #fff;\n background: rgba(30,30,30,.8)\n}\n\n.apexcharts-tooltip * {\n font-family: inherit\n}\n\n.apexcharts-tooltip-title {\n padding: 6px;\n font-size: 15px;\n margin-bottom: 4px\n}\n\n.apexcharts-tooltip.apexcharts-theme-light .apexcharts-tooltip-title {\n background: #eceff1;\n border-bottom: 1px solid #ddd\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark .apexcharts-tooltip-title {\n background: rgba(0,0,0,.7);\n border-bottom: 1px solid #333\n}\n\n.apexcharts-tooltip-text-goals-value,.apexcharts-tooltip-text-y-value,.apexcharts-tooltip-text-z-value {\n display: inline-block;\n margin-left: 5px;\n font-weight: 600\n}\n\n.apexcharts-tooltip-text-goals-label:empty,.apexcharts-tooltip-text-goals-value:empty,.apexcharts-tooltip-text-y-label:empty,.apexcharts-tooltip-text-y-value:empty,.apexcharts-tooltip-text-z-value:empty,.apexcharts-tooltip-title:empty {\n display: none\n}\n\n.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n padding: 6px 0 5px\n}\n\n.apexcharts-tooltip-goals-group,.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n display: flex\n}\n\n.apexcharts-tooltip-text-goals-label:not(:empty),.apexcharts-tooltip-text-goals-value:not(:empty) {\n margin-top: -6px\n}\n\n.apexcharts-tooltip-marker {\n width: 12px;\n height: 12px;\n position: relative;\n top: 0;\n margin-right: 10px;\n border-radius: 50%\n}\n\n.apexcharts-tooltip-series-group {\n padding: 0 10px;\n display: none;\n text-align: left;\n justify-content: left;\n align-items: center\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-marker {\n opacity: 1\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active,.apexcharts-tooltip-series-group:last-child {\n padding-bottom: 4px\n}\n\n.apexcharts-tooltip-series-group-hidden {\n opacity: 0;\n height: 0;\n line-height: 0;\n padding: 0!important\n}\n\n.apexcharts-tooltip-y-group {\n padding: 6px 0 5px\n}\n\n.apexcharts-custom-tooltip,.apexcharts-tooltip-box {\n padding: 4px 8px\n}\n\n.apexcharts-tooltip-boxPlot {\n display: flex;\n flex-direction: column-reverse\n}\n\n.apexcharts-tooltip-box>div {\n margin: 4px 0\n}\n\n.apexcharts-tooltip-box span.value {\n font-weight: 700\n}\n\n.apexcharts-tooltip-rangebar {\n padding: 5px 8px\n}\n\n.apexcharts-tooltip-rangebar .category {\n font-weight: 600;\n color: #777\n}\n\n.apexcharts-tooltip-rangebar .series-name {\n font-weight: 700;\n display: block;\n margin-bottom: 5px\n}\n\n.apexcharts-xaxistooltip,.apexcharts-yaxistooltip {\n opacity: 0;\n pointer-events: none;\n color: #373d3f;\n font-size: 13px;\n text-align: center;\n border-radius: 2px;\n position: absolute;\n z-index: 10;\n background: #eceff1;\n border: 1px solid #90a4ae\n}\n\n.apexcharts-xaxistooltip {\n padding: 9px 10px;\n transition: .15s ease all\n}\n\n.apexcharts-xaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-xaxistooltip:after,.apexcharts-xaxistooltip:before {\n left: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-xaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-left: -6px\n}\n\n.apexcharts-xaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-left: -7px\n}\n\n.apexcharts-xaxistooltip-bottom:after,.apexcharts-xaxistooltip-bottom:before {\n bottom: 100%\n}\n\n.apexcharts-xaxistooltip-top:after,.apexcharts-xaxistooltip-top:before {\n top: 100%\n}\n\n.apexcharts-xaxistooltip-bottom:after {\n border-bottom-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-bottom:before {\n border-bottom-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:before {\n border-bottom-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip-top:after {\n border-top-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-top:before {\n border-top-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-top.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-top.apexcharts-theme-dark:before {\n border-top-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-yaxistooltip {\n padding: 4px 10px\n}\n\n.apexcharts-yaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-yaxistooltip:after,.apexcharts-yaxistooltip:before {\n top: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-yaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-top: -6px\n}\n\n.apexcharts-yaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-top: -7px\n}\n\n.apexcharts-yaxistooltip-left:after,.apexcharts-yaxistooltip-left:before {\n left: 100%\n}\n\n.apexcharts-yaxistooltip-right:after,.apexcharts-yaxistooltip-right:before {\n right: 100%\n}\n\n.apexcharts-yaxistooltip-left:after {\n border-left-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-left:before {\n border-left-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-left.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-left.apexcharts-theme-dark:before {\n border-left-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip-right:after {\n border-right-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-right:before {\n border-right-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-right.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-right.apexcharts-theme-dark:before {\n border-right-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip.apexcharts-active {\n opacity: 1\n}\n\n.apexcharts-yaxistooltip-hidden {\n display: none\n}\n\n.apexcharts-xcrosshairs,.apexcharts-ycrosshairs {\n pointer-events: none;\n opacity: 0;\n transition: .15s ease all\n}\n\n.apexcharts-xcrosshairs.apexcharts-active,.apexcharts-ycrosshairs.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-ycrosshairs-hidden {\n opacity: 0\n}\n\n.apexcharts-selection-rect {\n cursor: move\n}\n\n.svg_select_boundingRect,.svg_select_points_rot {\n pointer-events: none;\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_boundingRect,.apexcharts-selection-rect+g .svg_select_points_rot {\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_points_l,.apexcharts-selection-rect+g .svg_select_points_r {\n cursor: ew-resize;\n opacity: 1;\n visibility: visible\n}\n\n.svg_select_points {\n fill: #efefef;\n stroke: #333;\n rx: 2\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-zoom {\n cursor: crosshair\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-pan {\n cursor: move\n}\n\n.apexcharts-menu-icon,.apexcharts-pan-icon,.apexcharts-reset-icon,.apexcharts-selection-icon,.apexcharts-toolbar-custom-icon,.apexcharts-zoom-icon,.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n cursor: pointer;\n width: 20px;\n height: 20px;\n line-height: 24px;\n color: #6e8192;\n text-align: center\n}\n\n.apexcharts-menu-icon svg,.apexcharts-reset-icon svg,.apexcharts-zoom-icon svg,.apexcharts-zoomin-icon svg,.apexcharts-zoomout-icon svg {\n fill: #6e8192\n}\n\n.apexcharts-selection-icon svg {\n fill: #444;\n transform: scale(.76)\n}\n\n.apexcharts-theme-dark .apexcharts-menu-icon svg,.apexcharts-theme-dark .apexcharts-pan-icon svg,.apexcharts-theme-dark .apexcharts-reset-icon svg,.apexcharts-theme-dark .apexcharts-selection-icon svg,.apexcharts-theme-dark .apexcharts-toolbar-custom-icon svg,.apexcharts-theme-dark .apexcharts-zoom-icon svg,.apexcharts-theme-dark .apexcharts-zoomin-icon svg,.apexcharts-theme-dark .apexcharts-zoomout-icon svg {\n fill: #f3f4f5\n}\n\n.apexcharts-canvas .apexcharts-reset-zoom-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-selection-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-zoom-icon.apexcharts-selected svg {\n fill: #008ffb\n}\n\n.apexcharts-theme-light .apexcharts-menu-icon:hover svg,.apexcharts-theme-light .apexcharts-reset-icon:hover svg,.apexcharts-theme-light .apexcharts-selection-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoom-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoomin-icon:hover svg,.apexcharts-theme-light .apexcharts-zoomout-icon:hover svg {\n fill: #333\n}\n\n.apexcharts-menu-icon,.apexcharts-selection-icon {\n position: relative\n}\n\n.apexcharts-reset-icon {\n margin-left: 5px\n}\n\n.apexcharts-menu-icon,.apexcharts-reset-icon,.apexcharts-zoom-icon {\n transform: scale(.85)\n}\n\n.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n transform: scale(.7)\n}\n\n.apexcharts-zoomout-icon {\n margin-right: 3px\n}\n\n.apexcharts-pan-icon {\n transform: scale(.62);\n position: relative;\n left: 1px;\n top: 0\n}\n\n.apexcharts-pan-icon svg {\n fill: #fff;\n stroke: #6e8192;\n stroke-width: 2\n}\n\n.apexcharts-pan-icon.apexcharts-selected svg {\n stroke: #008ffb\n}\n\n.apexcharts-pan-icon:not(.apexcharts-selected):hover svg {\n stroke: #333\n}\n\n.apexcharts-toolbar {\n position: absolute;\n z-index: 11;\n max-width: 176px;\n text-align: right;\n border-radius: 3px;\n padding: 0 6px 2px;\n display: flex;\n justify-content: space-between;\n align-items: center\n}\n\n.apexcharts-menu {\n background: #fff;\n position: absolute;\n top: 100%;\n border: 1px solid #ddd;\n border-radius: 3px;\n padding: 3px;\n right: 10px;\n opacity: 0;\n min-width: 110px;\n transition: .15s ease all;\n pointer-events: none\n}\n\n.apexcharts-menu.apexcharts-menu-open {\n opacity: 1;\n pointer-events: all;\n transition: .15s ease all\n}\n\n.apexcharts-menu-item {\n padding: 6px 7px;\n font-size: 12px;\n cursor: pointer\n}\n\n.apexcharts-theme-light .apexcharts-menu-item:hover {\n background: #eee\n}\n\n.apexcharts-theme-dark .apexcharts-menu {\n background: rgba(0,0,0,.7);\n color: #fff\n}\n\n@media screen and (min-width:768px) {\n .apexcharts-canvas:hover .apexcharts-toolbar {\n opacity: 1\n }\n}\n\n.apexcharts-canvas .apexcharts-element-hidden,.apexcharts-datalabel.apexcharts-element-hidden,.apexcharts-hide .apexcharts-series-points {\n opacity: 0\n}\n\n.apexcharts-datalabel,.apexcharts-datalabel-label,.apexcharts-datalabel-value,.apexcharts-datalabels,.apexcharts-pie-label {\n cursor: default;\n pointer-events: none\n}\n\n.apexcharts-pie-label-delay {\n opacity: 0;\n animation-name: opaque;\n animation-duration: .3s;\n animation-fill-mode: forwards;\n animation-timing-function: ease\n}\n\n.apexcharts-annotation-rect,.apexcharts-area-series .apexcharts-area,.apexcharts-area-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-gridline,.apexcharts-line,.apexcharts-line-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-point-annotation-label,.apexcharts-radar-series path,.apexcharts-radar-series polygon,.apexcharts-toolbar svg,.apexcharts-tooltip .apexcharts-marker,.apexcharts-xaxis-annotation-label,.apexcharts-yaxis-annotation-label,.apexcharts-zoom-rect {\n pointer-events: none\n}\n\n.apexcharts-marker {\n transition: .15s ease all\n}\n\n.resize-triggers {\n animation: 1ms resizeanim;\n visibility: hidden;\n opacity: 0;\n height: 100%;\n width: 100%;\n overflow: hidden\n}\n\n.contract-trigger:before,.resize-triggers,.resize-triggers>div {\n content: " ";\n display: block;\n position: absolute;\n top: 0;\n left: 0\n}\n\n.resize-triggers>div {\n height: 100%;\n width: 100%;\n background: #eee;\n overflow: auto\n}\n\n.contract-trigger:before {\n overflow: hidden;\n width: 200%;\n height: 200%\n}\n',r?s.prepend(t.css):o.head.appendChild(t.css))}var l=t.create(t.w.config.series,{});if(!l)return e(t);t.mount(l).then((function(){"function"==typeof t.w.config.chart.events.mounted&&t.w.config.chart.events.mounted(t,t.w),t.events.fireEvent("mounted",[t,t.w]),e(l)})).catch((function(t){i(t)}))}else i(new Error("Element not found"))}))}},{key:"create",value:function(t,e){var i=this.w;new Ot(this).initModules();var a=this.w.globals;(a.noData=!1,a.animationEnded=!1,this.responsive.checkResponsiveConfig(e),i.config.xaxis.convertedCatToNumeric)&&new z(i.config).convertCatToNumericXaxis(i.config,this.ctx);if(null===this.el)return a.animationEnded=!0,null;if(this.core.setupElements(),"treemap"===i.config.chart.type&&(i.config.grid.show=!1,i.config.yaxis[0].show=!1),0===a.svgWidth)return a.animationEnded=!0,null;var s=y.checkComboSeries(t);a.comboCharts=s.comboCharts,a.comboBarCount=s.comboBarCount;var r=t.every((function(t){return t.data&&0===t.data.length}));(0===t.length||r)&&this.series.handleNoData(),this.events.setupEventHandlers(),this.data.parseData(t),this.theme.init(),new D(this).setGlobalMarkerSize(),this.formatters.setLabelFormatters(),this.titleSubtitle.draw(),a.noData&&a.collapsedSeries.length!==a.series.length&&!i.config.legend.showForSingleSeries||this.legend.init(),this.series.hasAllSeriesEqualX(),a.axisCharts&&(this.core.coreCalculations(),"category"!==i.config.xaxis.type&&this.formatters.setLabelFormatters(),this.ctx.toolbar.minX=i.globals.minX,this.ctx.toolbar.maxX=i.globals.maxX),this.formatters.heatmapLabelFormatters(),new y(this).getLargestMarkerSize(),this.dimensions.plotCoords();var o=this.core.xySettings();this.grid.createGridMask();var n=this.core.plotChartType(t,o),l=new O(this);return l.bringForward(),i.config.dataLabels.background.enabled&&l.dataLabelsBackground(),this.core.shiftGraphPosition(),{elGraph:n,xyRatios:o,dimensions:{plot:{left:i.globals.translateX,top:i.globals.translateY,width:i.globals.gridWidth,height:i.globals.gridHeight}}}}},{key:"mount",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,i=this,a=i.w;return new Promise((function(s,r){if(null===i.el)return r(new Error("Not enough data to display or target element not found"));(null===e||a.globals.allSeriesCollapsed)&&i.series.handleNoData(),i.grid=new j(i);var o=i.grid.drawGrid();if(i.annotations=new P(i),i.annotations.drawImageAnnos(),i.annotations.drawTextAnnos(),"back"===a.config.grid.position&&o&&a.globals.dom.elGraphical.add(o.el),Array.isArray(e.elGraph))for(var n=0;n0&&a.globals.memory.methodsToExec.forEach((function(t){t.method(t.params,!1,t.context)})),a.globals.axisCharts||a.globals.noData||i.core.resizeNonAxisCharts(),s(i)}))}},{key:"destroy",value:function(){var t,e;window.removeEventListener("resize",this.windowResizeHandler),this.el.parentNode,t=this.parentResizeHandler,(e=Wt.get(t))&&(e.disconnect(),Wt.delete(t));var i=this.w.config.chart.id;i&&Apex._chartInstances.forEach((function(t,e){t.id===x.escapeString(i)&&Apex._chartInstances.splice(e,1)})),new Nt(this.ctx).clear({isUpdating:!1})}},{key:"updateOptions",value:function(t){var e=this,i=arguments.length>1&&void 0!==arguments[1]&&arguments[1],a=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],s=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],r=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],o=this.w;return o.globals.selection=void 0,t.series&&(this.series.resetSeries(!1,!0,!1),t.series.length&&t.series[0].data&&(t.series=t.series.map((function(t,i){return e.updateHelpers._extendSeries(t,i)}))),this.updateHelpers.revertDefaultAxisMinMax()),t.xaxis&&(t=this.updateHelpers.forceXAxisUpdate(t)),t.yaxis&&(t=this.updateHelpers.forceYAxisUpdate(t)),o.globals.collapsedSeriesIndices.length>0&&this.series.clearPreviousPaths(),t.theme&&(t=this.theme.updateThemeOptions(t)),this.updateHelpers._updateOptions(t,i,a,s,r)}},{key:"updateSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];return this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(t,e,i)}},{key:"appendSeries",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w.config.series.slice();return a.push(t),this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(a,e,i)}},{key:"appendData",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=this;i.w.globals.dataChanged=!0,i.series.getPreviousPaths();for(var a=i.w.config.series.slice(),s=0;s0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.series.resetSeries(t,e)}},{key:"addEventListener",value:function(t,e){this.events.addEventListener(t,e)}},{key:"removeEventListener",value:function(t,e){this.events.removeEventListener(t,e)}},{key:"addXaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addXaxisAnnotationExternal(t,e,a)}},{key:"addYaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addYaxisAnnotationExternal(t,e,a)}},{key:"addPointAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addPointAnnotationExternal(t,e,a)}},{key:"clearAnnotations",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:void 0,e=this;t&&(e=t),e.annotations.clearAnnotations(e)}},{key:"removeAnnotation",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0,i=this;e&&(i=e),i.annotations.removeAnnotation(i,t)}},{key:"getChartArea",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-inner")}},{key:"getSeriesTotalXRange",value:function(t,e){return this.coreUtils.getSeriesTotalsXRange(t,e)}},{key:"getHighestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new U(this.ctx).getMinYMaxY(t).highestY}},{key:"getLowestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new U(this.ctx).getMinYMaxY(t).lowestY}},{key:"getSeriesTotal",value:function(){return this.w.globals.seriesTotals}},{key:"toggleDataPointSelection",value:function(t,e){return this.updateHelpers.toggleDataPointSelection(t,e)}},{key:"zoomX",value:function(t,e){this.ctx.toolbar.zoomUpdateOptions(t,e)}},{key:"setLocale",value:function(t){this.localization.setCurrentLocaleValues(t)}},{key:"dataURI",value:function(t){return new G(this.ctx).dataURI(t)}},{key:"exportToCSV",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return new G(this.ctx).exportToCSV(t)}},{key:"paper",value:function(){return this.w.globals.dom.Paper}},{key:"_parentResizeCallback",value:function(){this.w.globals.animationEnded&&this.w.config.chart.redrawOnParentResize&&this._windowResize()}},{key:"_windowResize",value:function(){var t=this;clearTimeout(this.w.globals.resizeTimer),this.w.globals.resizeTimer=window.setTimeout((function(){t.w.globals.resized=!0,t.w.globals.dataChanged=!1,t.ctx.update()}),150)}},{key:"_windowResizeHandler",value:function(){var t=this.w.config.chart.redrawOnWindowResize;"function"==typeof t&&(t=t()),t&&this._windowResize()}}],[{key:"getChartByID",value:function(t){var e=x.escapeString(t),i=Apex._chartInstances.filter((function(t){return t.id===e}))[0];return i&&i.chart}},{key:"initOnLoad",value:function(){for(var e=document.querySelectorAll("[data-apexcharts]"),i=0;i2?s-2:0),o=2;o arr.length) len = arr.length; - - for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; - - return arr2; - } - - 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 _nonIterableRest() { - throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); - } - - /* - ** Generic functions which are not dependent on ApexCharts - */ - var Utils$1 = /*#__PURE__*/function () { - function Utils() { - _classCallCheck(this, Utils); - } - - _createClass(Utils, [{ - key: "shadeRGBColor", - value: function shadeRGBColor(percent, color) { - var f = color.split(','), - t = percent < 0 ? 0 : 255, - p = percent < 0 ? percent * -1 : percent, - R = parseInt(f[0].slice(4), 10), - G = parseInt(f[1], 10), - B = parseInt(f[2], 10); - return 'rgb(' + (Math.round((t - R) * p) + R) + ',' + (Math.round((t - G) * p) + G) + ',' + (Math.round((t - B) * p) + B) + ')'; - } - }, { - key: "shadeHexColor", - value: function shadeHexColor(percent, color) { - var f = parseInt(color.slice(1), 16), - t = percent < 0 ? 0 : 255, - p = percent < 0 ? percent * -1 : percent, - R = f >> 16, - G = f >> 8 & 0x00ff, - B = f & 0x0000ff; - return '#' + (0x1000000 + (Math.round((t - R) * p) + R) * 0x10000 + (Math.round((t - G) * p) + G) * 0x100 + (Math.round((t - B) * p) + B)).toString(16).slice(1); - } // beautiful color shading blending code - // http://stackoverflow.com/questions/5560248/programmatically-lighten-or-darken-a-hex-color-or-rgb-and-blend-colors - - }, { - key: "shadeColor", - value: function shadeColor(p, color) { - if (Utils.isColorHex(color)) { - return this.shadeHexColor(p, color); - } else { - return this.shadeRGBColor(p, color); - } - } - }], [{ - key: "bind", - value: function bind(fn, me) { - return function () { - return fn.apply(me, arguments); - }; - } - }, { - key: "isObject", - value: function isObject(item) { - return item && _typeof(item) === 'object' && !Array.isArray(item) && item != null; - } // Type checking that works across different window objects - - }, { - key: "is", - value: function is(type, val) { - return Object.prototype.toString.call(val) === '[object ' + type + ']'; - } - }, { - key: "listToArray", - value: function listToArray(list) { - var i, - array = []; - - for (i = 0; i < list.length; i++) { - array[i] = list[i]; - } - - return array; - } // to extend defaults with user options - // credit: http://stackoverflow.com/questions/27936772/deep-object-merging-in-es6-es7#answer-34749873 - - }, { - key: "extend", - value: function extend(target, source) { - var _this = this; - - if (typeof Object.assign !== 'function') { - - (function () { - Object.assign = function (target) { - - if (target === undefined || target === null) { - throw new TypeError('Cannot convert undefined or null to object'); - } - - var output = Object(target); - - for (var index = 1; index < arguments.length; index++) { - var _source = arguments[index]; - - if (_source !== undefined && _source !== null) { - for (var nextKey in _source) { - if (_source.hasOwnProperty(nextKey)) { - output[nextKey] = _source[nextKey]; - } - } - } - } - - return output; - }; - })(); - } - - var output = Object.assign({}, target); - - if (this.isObject(target) && this.isObject(source)) { - Object.keys(source).forEach(function (key) { - if (_this.isObject(source[key])) { - if (!(key in target)) { - Object.assign(output, _defineProperty({}, key, source[key])); - } else { - output[key] = _this.extend(target[key], source[key]); - } - } else { - Object.assign(output, _defineProperty({}, key, source[key])); - } - }); - } - - return output; - } - }, { - key: "extendArray", - value: function extendArray(arrToExtend, resultArr) { - var extendedArr = []; - arrToExtend.map(function (item) { - extendedArr.push(Utils.extend(resultArr, item)); - }); - arrToExtend = extendedArr; - return arrToExtend; - } // If month counter exceeds 12, it starts again from 1 - - }, { - key: "monthMod", - value: function monthMod(month) { - return month % 12; - } - }, { - key: "clone", - value: function clone(source) { - if (Utils.is('Array', source)) { - var cloneResult = []; - - for (var i = 0; i < source.length; i++) { - cloneResult[i] = this.clone(source[i]); - } - - return cloneResult; - } else if (Utils.is('Null', source)) { - // fixes an issue where null values were converted to {} - return null; - } else if (Utils.is('Date', source)) { - return source; - } else if (_typeof(source) === 'object') { - var _cloneResult = {}; - - for (var prop in source) { - if (source.hasOwnProperty(prop)) { - _cloneResult[prop] = this.clone(source[prop]); - } - } - - return _cloneResult; - } else { - return source; - } - } - }, { - key: "log10", - value: function log10(x) { - return Math.log(x) / Math.LN10; - } - }, { - key: "roundToBase10", - value: function roundToBase10(x) { - return Math.pow(10, Math.floor(Math.log10(x))); - } - }, { - key: "roundToBase", - value: function roundToBase(x, base) { - return Math.pow(base, Math.floor(Math.log(x) / Math.log(base))); - } - }, { - key: "parseNumber", - value: function parseNumber(val) { - if (val === null) return val; - return parseFloat(val); - } - }, { - key: "randomId", - value: function randomId() { - return (Math.random() + 1).toString(36).substring(4); - } - }, { - key: "noExponents", - value: function noExponents(val) { - var data = String(val).split(/[eE]/); - if (data.length === 1) return data[0]; - var z = '', - sign = val < 0 ? '-' : '', - str = data[0].replace('.', ''), - mag = Number(data[1]) + 1; - - if (mag < 0) { - z = sign + '0.'; - - while (mag++) { - z += '0'; - } - - return z + str.replace(/^-/, ''); - } - - mag -= str.length; - - while (mag--) { - z += '0'; - } - - return str + z; - } - }, { - key: "getDimensions", - value: function getDimensions(el) { - var computedStyle = getComputedStyle(el, null); - var elementHeight = el.clientHeight; - var elementWidth = el.clientWidth; - elementHeight -= parseFloat(computedStyle.paddingTop) + parseFloat(computedStyle.paddingBottom); - elementWidth -= parseFloat(computedStyle.paddingLeft) + parseFloat(computedStyle.paddingRight); - return [elementWidth, elementHeight]; - } - }, { - key: "getBoundingClientRect", - value: function getBoundingClientRect(element) { - var rect = element.getBoundingClientRect(); - return { - top: rect.top, - right: rect.right, - bottom: rect.bottom, - left: rect.left, - width: element.clientWidth, - height: element.clientHeight, - x: rect.left, - y: rect.top - }; - } - }, { - key: "getLargestStringFromArr", - value: function getLargestStringFromArr(arr) { - return arr.reduce(function (a, b) { - if (Array.isArray(b)) { - b = b.reduce(function (aa, bb) { - return aa.length > bb.length ? aa : bb; - }); - } - - return a.length > b.length ? a : b; - }, 0); - } // http://stackoverflow.com/questions/5623838/rgb-to-hex-and-hex-to-rgb#answer-12342275 - - }, { - key: "hexToRgba", - value: function hexToRgba() { - var hex = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '#999999'; - var opacity = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0.6; - - if (hex.substring(0, 1) !== '#') { - hex = '#999999'; - } - - var h = hex.replace('#', ''); - h = h.match(new RegExp('(.{' + h.length / 3 + '})', 'g')); - - for (var i = 0; i < h.length; i++) { - h[i] = parseInt(h[i].length === 1 ? h[i] + h[i] : h[i], 16); - } - - if (typeof opacity !== 'undefined') h.push(opacity); - return 'rgba(' + h.join(',') + ')'; - } - }, { - key: "getOpacityFromRGBA", - value: function getOpacityFromRGBA(rgba) { - return parseFloat(rgba.replace(/^.*,(.+)\)/, '$1')); - } - }, { - key: "rgb2hex", - value: function rgb2hex(rgb) { - rgb = rgb.match(/^rgba?[\s+]?\([\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?/i); - return rgb && rgb.length === 4 ? '#' + ('0' + parseInt(rgb[1], 10).toString(16)).slice(-2) + ('0' + parseInt(rgb[2], 10).toString(16)).slice(-2) + ('0' + parseInt(rgb[3], 10).toString(16)).slice(-2) : ''; - } - }, { - key: "isColorHex", - value: function isColorHex(color) { - return /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)|(^#[0-9A-F]{8}$)/i.test(color); - } - }, { - key: "getPolygonPos", - value: function getPolygonPos(size, dataPointsLen) { - var dotsArray = []; - var angle = Math.PI * 2 / dataPointsLen; - - for (var i = 0; i < dataPointsLen; i++) { - var curPos = {}; - curPos.x = size * Math.sin(i * angle); - curPos.y = -size * Math.cos(i * angle); - dotsArray.push(curPos); - } - - return dotsArray; - } - }, { - key: "polarToCartesian", - value: function polarToCartesian(centerX, centerY, radius, angleInDegrees) { - var angleInRadians = (angleInDegrees - 90) * Math.PI / 180.0; - return { - x: centerX + radius * Math.cos(angleInRadians), - y: centerY + radius * Math.sin(angleInRadians) - }; - } - }, { - key: "escapeString", - value: function escapeString(str) { - var escapeWith = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'x'; - var newStr = str.toString().slice(); - newStr = newStr.replace(/[` ~!@#$%^&*()|+\=?;:'",.<>{}[\]\\/]/gi, escapeWith); - return newStr; - } - }, { - key: "negToZero", - value: function negToZero(val) { - return val < 0 ? 0 : val; - } - }, { - key: "moveIndexInArray", - value: function moveIndexInArray(arr, old_index, new_index) { - if (new_index >= arr.length) { - var k = new_index - arr.length + 1; - - while (k--) { - arr.push(undefined); - } - } - - arr.splice(new_index, 0, arr.splice(old_index, 1)[0]); - return arr; - } - }, { - key: "extractNumber", - value: function extractNumber(s) { - return parseFloat(s.replace(/[^\d.]*/g, '')); - } - }, { - key: "findAncestor", - value: function findAncestor(el, cls) { - while ((el = el.parentElement) && !el.classList.contains(cls)) { - } - - return el; - } - }, { - key: "setELstyles", - value: function setELstyles(el, styles) { - for (var key in styles) { - if (styles.hasOwnProperty(key)) { - el.style.key = styles[key]; - } - } - } - }, { - key: "isNumber", - value: function isNumber(value) { - return !isNaN(value) && parseFloat(Number(value)) === value && !isNaN(parseInt(value, 10)); - } - }, { - key: "isFloat", - value: function isFloat(n) { - return Number(n) === n && n % 1 !== 0; - } - }, { - key: "isSafari", - value: function isSafari() { - return /^((?!chrome|android).)*safari/i.test(navigator.userAgent); - } - }, { - key: "isFirefox", - value: function isFirefox() { - return navigator.userAgent.toLowerCase().indexOf('firefox') > -1; - } - }, { - key: "isIE11", - value: function isIE11() { - if (window.navigator.userAgent.indexOf('MSIE') !== -1 || window.navigator.appVersion.indexOf('Trident/') > -1) { - return true; - } - } - }, { - key: "isIE", - value: function isIE() { - var ua = window.navigator.userAgent; - var msie = ua.indexOf('MSIE '); - - if (msie > 0) { - // IE 10 or older => return version number - return parseInt(ua.substring(msie + 5, ua.indexOf('.', msie)), 10); - } - - var trident = ua.indexOf('Trident/'); - - if (trident > 0) { - // IE 11 => return version number - var rv = ua.indexOf('rv:'); - return parseInt(ua.substring(rv + 3, ua.indexOf('.', rv)), 10); - } - - var edge = ua.indexOf('Edge/'); - - if (edge > 0) { - // Edge (IE 12+) => return version number - return parseInt(ua.substring(edge + 5, ua.indexOf('.', edge)), 10); - } // other browser - - - return false; - } - }]); - - return Utils; - }(); - - /** - * ApexCharts Animation Class. - * - * @module Animations - **/ - - var Animations = /*#__PURE__*/function () { - function Animations(ctx) { - _classCallCheck(this, Animations); - - this.ctx = ctx; - this.w = ctx.w; - this.setEasingFunctions(); - } - - _createClass(Animations, [{ - key: "setEasingFunctions", - value: function setEasingFunctions() { - var easing; - if (this.w.globals.easing) return; - var userDefinedEasing = this.w.config.chart.animations.easing; - - switch (userDefinedEasing) { - case 'linear': - { - easing = '-'; - break; - } - - case 'easein': - { - easing = '<'; - break; - } - - case 'easeout': - { - easing = '>'; - break; - } - - case 'easeinout': - { - easing = '<>'; - break; - } - - case 'swing': - { - easing = function easing(pos) { - var s = 1.70158; - var ret = (pos -= 1) * pos * ((s + 1) * pos + s) + 1; - return ret; - }; - - break; - } - - case 'bounce': - { - easing = function easing(pos) { - var ret = ''; - - if (pos < 1 / 2.75) { - ret = 7.5625 * pos * pos; - } else if (pos < 2 / 2.75) { - ret = 7.5625 * (pos -= 1.5 / 2.75) * pos + 0.75; - } else if (pos < 2.5 / 2.75) { - ret = 7.5625 * (pos -= 2.25 / 2.75) * pos + 0.9375; - } else { - ret = 7.5625 * (pos -= 2.625 / 2.75) * pos + 0.984375; - } - - return ret; - }; - - break; - } - - case 'elastic': - { - easing = function easing(pos) { - if (pos === !!pos) return pos; - return Math.pow(2, -10 * pos) * Math.sin((pos - 0.075) * (2 * Math.PI) / 0.3) + 1; - }; - - break; - } - - default: - { - easing = '<>'; - } - } - - this.w.globals.easing = easing; - } - }, { - key: "animateLine", - value: function animateLine(el, from, to, speed) { - el.attr(from).animate(speed).attr(to); - } - /* - ** Animate radius of a circle element - */ - - }, { - key: "animateMarker", - value: function animateMarker(el, from, to, speed, easing, cb) { - if (!from) from = 0; - el.attr({ - r: from, - width: from, - height: from - }).animate(speed, easing).attr({ - r: to, - width: to.width, - height: to.height - }).afterAll(function () { - cb(); - }); - } - /* - ** Animate radius and position of a circle element - */ - - }, { - key: "animateCircle", - value: function animateCircle(el, from, to, speed, easing) { - el.attr({ - r: from.r, - cx: from.cx, - cy: from.cy - }).animate(speed, easing).attr({ - r: to.r, - cx: to.cx, - cy: to.cy - }); - } - /* - ** Animate rect properties - */ - - }, { - key: "animateRect", - value: function animateRect(el, from, to, speed, fn) { - el.attr(from).animate(speed).attr(to).afterAll(function () { - return fn(); - }); - } - }, { - key: "animatePathsGradually", - value: function animatePathsGradually(params) { - var el = params.el, - realIndex = params.realIndex, - j = params.j, - fill = params.fill, - pathFrom = params.pathFrom, - pathTo = params.pathTo, - speed = params.speed, - delay = params.delay; - var me = this; - var w = this.w; - var delayFactor = 0; - - if (w.config.chart.animations.animateGradually.enabled) { - delayFactor = w.config.chart.animations.animateGradually.delay; - } - - if (w.config.chart.animations.dynamicAnimation.enabled && w.globals.dataChanged && w.config.chart.type !== 'bar') { - // disabled due to this bug - https://github.com/apexcharts/vue-apexcharts/issues/75 - delayFactor = 0; - } - - me.morphSVG(el, realIndex, j, w.config.chart.type === 'line' && !w.globals.comboCharts ? 'stroke' : fill, pathFrom, pathTo, speed, delay * delayFactor); - } - }, { - key: "showDelayedElements", - value: function showDelayedElements() { - this.w.globals.delayedElements.forEach(function (d) { - var ele = d.el; - ele.classList.remove('apexcharts-element-hidden'); - }); - } - }, { - key: "animationCompleted", - value: function animationCompleted(el) { - var w = this.w; - if (w.globals.animationEnded) return; - w.globals.animationEnded = true; - this.showDelayedElements(); - - if (typeof w.config.chart.events.animationEnd === 'function') { - w.config.chart.events.animationEnd(this.ctx, { - el: el, - w: w - }); - } - } // SVG.js animation for morphing one path to another - - }, { - key: "morphSVG", - value: function morphSVG(el, realIndex, j, fill, pathFrom, pathTo, speed, delay) { - var _this = this; - - var w = this.w; - - if (!pathFrom) { - pathFrom = el.attr('pathFrom'); - } - - if (!pathTo) { - pathTo = el.attr('pathTo'); - } - - var disableAnimationForCorrupPath = function disableAnimationForCorrupPath(path) { - if (w.config.chart.type === 'radar') { - // radar chart drops the path to bottom and hence a corrup path looks ugly - // therefore, disable animation for such a case - speed = 1; - } - - return "M 0 ".concat(w.globals.gridHeight); - }; - - if (!pathFrom || pathFrom.indexOf('undefined') > -1 || pathFrom.indexOf('NaN') > -1) { - pathFrom = disableAnimationForCorrupPath(); - } - - if (!pathTo || pathTo.indexOf('undefined') > -1 || pathTo.indexOf('NaN') > -1) { - pathTo = disableAnimationForCorrupPath(); - } - - if (!w.globals.shouldAnimate) { - speed = 1; - } - - el.plot(pathFrom).animate(1, w.globals.easing, delay).plot(pathFrom).animate(speed, w.globals.easing, delay).plot(pathTo).afterAll(function () { - // a flag to indicate that the original mount function can return true now as animation finished here - if (Utils$1.isNumber(j)) { - if (j === w.globals.series[w.globals.maxValsInArrayIndex].length - 2 && w.globals.shouldAnimate) { - _this.animationCompleted(el); - } - } else if (fill !== 'none' && w.globals.shouldAnimate) { - if (!w.globals.comboCharts && realIndex === w.globals.series.length - 1 || w.globals.comboCharts) { - _this.animationCompleted(el); - } - } - - _this.showDelayedElements(); - }); - } - }]); - - return Animations; - }(); - - /** - * ApexCharts Filters Class for setting hover/active states on the paths. - * - * @module Formatters - **/ - - var Filters = /*#__PURE__*/function () { - function Filters(ctx) { - _classCallCheck(this, Filters); - - this.ctx = ctx; - this.w = ctx.w; - } // create a re-usable filter which can be appended other filter effects and applied to multiple elements - - - _createClass(Filters, [{ - key: "getDefaultFilter", - value: function getDefaultFilter(el, i) { - var w = this.w; - el.unfilter(true); - var filter = new window.SVG.Filter(); - filter.size('120%', '180%', '-5%', '-40%'); - - if (w.config.states.normal.filter !== 'none') { - this.applyFilter(el, i, w.config.states.normal.filter.type, w.config.states.normal.filter.value); - } else { - if (w.config.chart.dropShadow.enabled) { - this.dropShadow(el, w.config.chart.dropShadow, i); - } - } - } - }, { - key: "addNormalFilter", - value: function addNormalFilter(el, i) { - var w = this.w; // revert shadow if it was there - // but, ignore marker as marker don't have dropshadow yet - - if (w.config.chart.dropShadow.enabled && !el.node.classList.contains('apexcharts-marker')) { - this.dropShadow(el, w.config.chart.dropShadow, i); - } - } // appends dropShadow to the filter object which can be chained with other filter effects - - }, { - key: "addLightenFilter", - value: function addLightenFilter(el, i, attrs) { - var _this = this; - - var w = this.w; - var intensity = attrs.intensity; - el.unfilter(true); - var filter = new window.SVG.Filter(); - el.filter(function (add) { - var shadowAttr = w.config.chart.dropShadow; - - if (shadowAttr.enabled) { - filter = _this.addShadow(add, i, shadowAttr); - } else { - filter = add; - } - - filter.componentTransfer({ - rgb: { - type: 'linear', - slope: 1.5, - intercept: intensity - } - }); - }); - el.filterer.node.setAttribute('filterUnits', 'userSpaceOnUse'); - - this._scaleFilterSize(el.filterer.node); - } // appends dropShadow to the filter object which can be chained with other filter effects - - }, { - key: "addDarkenFilter", - value: function addDarkenFilter(el, i, attrs) { - var _this2 = this; - - var w = this.w; - var intensity = attrs.intensity; - el.unfilter(true); - var filter = new window.SVG.Filter(); - el.filter(function (add) { - var shadowAttr = w.config.chart.dropShadow; - - if (shadowAttr.enabled) { - filter = _this2.addShadow(add, i, shadowAttr); - } else { - filter = add; - } - - filter.componentTransfer({ - rgb: { - type: 'linear', - slope: intensity - } - }); - }); - el.filterer.node.setAttribute('filterUnits', 'userSpaceOnUse'); - - this._scaleFilterSize(el.filterer.node); - } - }, { - key: "applyFilter", - value: function applyFilter(el, i, filter) { - var intensity = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0.5; - - switch (filter) { - case 'none': - { - this.addNormalFilter(el, i); - break; - } - - case 'lighten': - { - this.addLightenFilter(el, i, { - intensity: intensity - }); - break; - } - - case 'darken': - { - this.addDarkenFilter(el, i, { - intensity: intensity - }); - break; - } - } - } // appends dropShadow to the filter object which can be chained with other filter effects - - }, { - key: "addShadow", - value: function addShadow(add, i, attrs) { - var blur = attrs.blur, - top = attrs.top, - left = attrs.left, - color = attrs.color, - opacity = attrs.opacity; - var shadowBlur = add.flood(Array.isArray(color) ? color[i] : color, opacity).composite(add.sourceAlpha, 'in').offset(left, top).gaussianBlur(blur).merge(add.source); - return add.blend(add.source, shadowBlur); - } // directly adds dropShadow to the element and returns the same element. - // the only way it is different from the addShadow() function is that addShadow is chainable to other filters, while this function discards all filters and add dropShadow - - }, { - key: "dropShadow", - value: function dropShadow(el, attrs) { - var i = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; - var top = attrs.top, - left = attrs.left, - blur = attrs.blur, - color = attrs.color, - opacity = attrs.opacity, - noUserSpaceOnUse = attrs.noUserSpaceOnUse; - var w = this.w; - el.unfilter(true); - - if (Utils$1.isIE() && w.config.chart.type === 'radialBar') { - // in radialbar charts, dropshadow is clipping actual drawing in IE - return el; - } - - color = Array.isArray(color) ? color[i] : color; - el.filter(function (add) { - var shadowBlur = null; - - if (Utils$1.isSafari() || Utils$1.isFirefox() || Utils$1.isIE()) { - // safari/firefox/IE have some alternative way to use this filter - shadowBlur = add.flood(color, opacity).composite(add.sourceAlpha, 'in').offset(left, top).gaussianBlur(blur); - } else { - shadowBlur = add.flood(color, opacity).composite(add.sourceAlpha, 'in').offset(left, top).gaussianBlur(blur).merge(add.source); - } - - add.blend(add.source, shadowBlur); - }); - - if (!noUserSpaceOnUse) { - el.filterer.node.setAttribute('filterUnits', 'userSpaceOnUse'); - } - - this._scaleFilterSize(el.filterer.node); - - return el; - } - }, { - key: "setSelectionFilter", - value: function setSelectionFilter(el, realIndex, dataPointIndex) { - var w = this.w; - - if (typeof w.globals.selectedDataPoints[realIndex] !== 'undefined') { - if (w.globals.selectedDataPoints[realIndex].indexOf(dataPointIndex) > -1) { - el.node.setAttribute('selected', true); - var activeFilter = w.config.states.active.filter; - - if (activeFilter !== 'none') { - this.applyFilter(el, realIndex, activeFilter.type, activeFilter.value); - } - } - } - } - }, { - key: "_scaleFilterSize", - value: function _scaleFilterSize(el) { - var setAttributes = function setAttributes(attrs) { - for (var key in attrs) { - if (attrs.hasOwnProperty(key)) { - el.setAttribute(key, attrs[key]); - } - } - }; - - setAttributes({ - width: '200%', - height: '200%', - x: '-50%', - y: '-50%' - }); - } - }]); - - return Filters; - }(); - - /** - * ApexCharts Graphics Class for all drawing operations. - * - * @module Graphics - **/ - - var Graphics = /*#__PURE__*/function () { - function Graphics(ctx) { - _classCallCheck(this, Graphics); - - this.ctx = ctx; - this.w = ctx.w; - } - /***************************************************************************** - * * - * SVG Path Rounding Function * - * Copyright (C) 2014 Yona Appletree * - * * - * Licensed under the Apache License, Version 2.0 (the "License"); * - * you may not use this file except in compliance with the License. * - * You may obtain a copy of the License at * - * * - * http://www.apache.org/licenses/LICENSE-2.0 * - * * - * Unless required by applicable law or agreed to in writing, software * - * distributed under the License is distributed on an "AS IS" BASIS, * - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * - * See the License for the specific language governing permissions and * - * limitations under the License. * - * * - *****************************************************************************/ - - /** - * SVG Path rounding function. Takes an input path string and outputs a path - * string where all line-line corners have been rounded. Only supports absolute - * commands at the moment. - * - * @param pathString The SVG input path - * @param radius The amount to round the corners, either a value in the SVG - * coordinate space, or, if useFractionalRadius is true, a value - * from 0 to 1. - * @returns A new SVG path string with the rounding - */ - - - _createClass(Graphics, [{ - key: "roundPathCorners", - value: function roundPathCorners(pathString, radius) { - if (pathString.indexOf('NaN') > -1) pathString = ''; - - function moveTowardsLength(movingPoint, targetPoint, amount) { - var width = targetPoint.x - movingPoint.x; - var height = targetPoint.y - movingPoint.y; - var distance = Math.sqrt(width * width + height * height); - return moveTowardsFractional(movingPoint, targetPoint, Math.min(1, amount / distance)); - } - - function moveTowardsFractional(movingPoint, targetPoint, fraction) { - return { - x: movingPoint.x + (targetPoint.x - movingPoint.x) * fraction, - y: movingPoint.y + (targetPoint.y - movingPoint.y) * fraction - }; - } // Adjusts the ending position of a command - - - function adjustCommand(cmd, newPoint) { - if (cmd.length > 2) { - cmd[cmd.length - 2] = newPoint.x; - cmd[cmd.length - 1] = newPoint.y; - } - } // Gives an {x, y} object for a command's ending position - - - function pointForCommand(cmd) { - return { - x: parseFloat(cmd[cmd.length - 2]), - y: parseFloat(cmd[cmd.length - 1]) - }; - } // Split apart the path, handing concatonated letters and numbers - - - var pathParts = pathString.split(/[,\s]/).reduce(function (parts, part) { - var match = part.match('([a-zA-Z])(.+)'); - - if (match) { - parts.push(match[1]); - parts.push(match[2]); - } else { - parts.push(part); - } - - return parts; - }, []); // Group the commands with their arguments for easier handling - - var commands = pathParts.reduce(function (commands, part) { - if (parseFloat(part) == part && commands.length) { - commands[commands.length - 1].push(part); - } else { - commands.push([part]); - } - - return commands; - }, []); // The resulting commands, also grouped - - var resultCommands = []; - - if (commands.length > 1) { - var startPoint = pointForCommand(commands[0]); // Handle the close path case with a "virtual" closing line - - var virtualCloseLine = null; - - if (commands[commands.length - 1][0] == 'Z' && commands[0].length > 2) { - virtualCloseLine = ['L', startPoint.x, startPoint.y]; - commands[commands.length - 1] = virtualCloseLine; - } // We always use the first command (but it may be mutated) - - - resultCommands.push(commands[0]); - - for (var cmdIndex = 1; cmdIndex < commands.length; cmdIndex++) { - var prevCmd = resultCommands[resultCommands.length - 1]; - var curCmd = commands[cmdIndex]; // Handle closing case - - var nextCmd = curCmd == virtualCloseLine ? commands[1] : commands[cmdIndex + 1]; // Nasty logic to decide if this path is a candidite. - - if (nextCmd && prevCmd && prevCmd.length > 2 && curCmd[0] == 'L' && nextCmd.length > 2 && nextCmd[0] == 'L') { - // Calc the points we're dealing with - var prevPoint = pointForCommand(prevCmd); - var curPoint = pointForCommand(curCmd); - var nextPoint = pointForCommand(nextCmd); // The start and end of the cuve are just our point moved towards the previous and next points, respectivly - - var curveStart, curveEnd; - curveStart = moveTowardsLength(curPoint, prevPoint, radius); - curveEnd = moveTowardsLength(curPoint, nextPoint, radius); // Adjust the current command and add it - - adjustCommand(curCmd, curveStart); - curCmd.origPoint = curPoint; - resultCommands.push(curCmd); // The curve control points are halfway between the start/end of the curve and - // the original point - - var startControl = moveTowardsFractional(curveStart, curPoint, 0.5); - var endControl = moveTowardsFractional(curPoint, curveEnd, 0.5); // Create the curve - - var curveCmd = ['C', startControl.x, startControl.y, endControl.x, endControl.y, curveEnd.x, curveEnd.y]; // Save the original point for fractional calculations - - curveCmd.origPoint = curPoint; - resultCommands.push(curveCmd); - } else { - // Pass through commands that don't qualify - resultCommands.push(curCmd); - } - } // Fix up the starting point and restore the close path if the path was orignally closed - - - if (virtualCloseLine) { - var newStartPoint = pointForCommand(resultCommands[resultCommands.length - 1]); - resultCommands.push(['Z']); - adjustCommand(resultCommands[0], newStartPoint); - } - } else { - resultCommands = commands; - } - - return resultCommands.reduce(function (str, c) { - return str + c.join(' ') + ' '; - }, ''); - } - }, { - key: "drawLine", - value: function drawLine(x1, y1, x2, y2) { - var lineColor = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : '#a8a8a8'; - var dashArray = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 0; - var strokeWidth = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : null; - var strokeLineCap = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : 'butt'; - var w = this.w; - var line = w.globals.dom.Paper.line().attr({ - x1: x1, - y1: y1, - x2: x2, - y2: y2, - stroke: lineColor, - 'stroke-dasharray': dashArray, - 'stroke-width': strokeWidth, - 'stroke-linecap': strokeLineCap - }); - return line; - } - }, { - key: "drawRect", - value: function drawRect() { - var x1 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; - var y1 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; - var x2 = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; - var y2 = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; - var radius = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0; - var color = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : '#fefefe'; - var opacity = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : 1; - var strokeWidth = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : null; - var strokeColor = arguments.length > 8 && arguments[8] !== undefined ? arguments[8] : null; - var strokeDashArray = arguments.length > 9 && arguments[9] !== undefined ? arguments[9] : 0; - var w = this.w; - var rect = w.globals.dom.Paper.rect(); - rect.attr({ - x: x1, - y: y1, - width: x2 > 0 ? x2 : 0, - height: y2 > 0 ? y2 : 0, - rx: radius, - ry: radius, - opacity: opacity, - 'stroke-width': strokeWidth !== null ? strokeWidth : 0, - stroke: strokeColor !== null ? strokeColor : 'none', - 'stroke-dasharray': strokeDashArray - }); // fix apexcharts.js#1410 - - rect.node.setAttribute('fill', color); - return rect; - } - }, { - key: "drawPolygon", - value: function drawPolygon(polygonString) { - var stroke = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '#e1e1e1'; - var strokeWidth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1; - var fill = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'none'; - var w = this.w; - var polygon = w.globals.dom.Paper.polygon(polygonString).attr({ - fill: fill, - stroke: stroke, - 'stroke-width': strokeWidth - }); - return polygon; - } - }, { - key: "drawCircle", - value: function drawCircle(radius) { - var attrs = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - var w = this.w; - if (radius < 0) radius = 0; - var c = w.globals.dom.Paper.circle(radius * 2); - - if (attrs !== null) { - c.attr(attrs); - } - - return c; - } - }, { - key: "drawPath", - value: function drawPath(_ref) { - var _ref$d = _ref.d, - d = _ref$d === void 0 ? '' : _ref$d, - _ref$stroke = _ref.stroke, - stroke = _ref$stroke === void 0 ? '#a8a8a8' : _ref$stroke, - _ref$strokeWidth = _ref.strokeWidth, - strokeWidth = _ref$strokeWidth === void 0 ? 1 : _ref$strokeWidth, - fill = _ref.fill, - _ref$fillOpacity = _ref.fillOpacity, - fillOpacity = _ref$fillOpacity === void 0 ? 1 : _ref$fillOpacity, - _ref$strokeOpacity = _ref.strokeOpacity, - strokeOpacity = _ref$strokeOpacity === void 0 ? 1 : _ref$strokeOpacity, - classes = _ref.classes, - _ref$strokeLinecap = _ref.strokeLinecap, - strokeLinecap = _ref$strokeLinecap === void 0 ? null : _ref$strokeLinecap, - _ref$strokeDashArray = _ref.strokeDashArray, - strokeDashArray = _ref$strokeDashArray === void 0 ? 0 : _ref$strokeDashArray; - var w = this.w; - - if (strokeLinecap === null) { - strokeLinecap = w.config.stroke.lineCap; - } - - if (d.indexOf('undefined') > -1 || d.indexOf('NaN') > -1) { - d = "M 0 ".concat(w.globals.gridHeight); - } - - var p = w.globals.dom.Paper.path(d).attr({ - fill: fill, - 'fill-opacity': fillOpacity, - stroke: stroke, - 'stroke-opacity': strokeOpacity, - 'stroke-linecap': strokeLinecap, - 'stroke-width': strokeWidth, - 'stroke-dasharray': strokeDashArray, - class: classes - }); - return p; - } - }, { - key: "group", - value: function group() { - var attrs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - var w = this.w; - var g = w.globals.dom.Paper.group(); - - if (attrs !== null) { - g.attr(attrs); - } - - return g; - } - }, { - key: "move", - value: function move(x, y) { - var move = ['M', x, y].join(' '); - return move; - } - }, { - key: "line", - value: function line(x, y) { - var hORv = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - var line = null; - - if (hORv === null) { - line = [' L', x, y].join(' '); - } else if (hORv === 'H') { - line = [' H', x].join(' '); - } else if (hORv === 'V') { - line = [' V', y].join(' '); - } - - return line; - } - }, { - key: "curve", - value: function curve(x1, y1, x2, y2, x, y) { - var curve = ['C', x1, y1, x2, y2, x, y].join(' '); - return curve; - } - }, { - key: "quadraticCurve", - value: function quadraticCurve(x1, y1, x, y) { - var curve = ['Q', x1, y1, x, y].join(' '); - return curve; - } - }, { - key: "arc", - value: function arc(rx, ry, axisRotation, largeArcFlag, sweepFlag, x, y) { - var relative = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : false; - var coord = 'A'; - if (relative) coord = 'a'; - var arc = [coord, rx, ry, axisRotation, largeArcFlag, sweepFlag, x, y].join(' '); - return arc; - } - /** - * @memberof Graphics - * @param {object} - * i = series's index - * realIndex = realIndex is series's actual index when it was drawn time. After several redraws, the iterating "i" may change in loops, but realIndex doesn't - * pathFrom = existing pathFrom to animateTo - * pathTo = new Path to which d attr will be animated from pathFrom to pathTo - * stroke = line Color - * strokeWidth = width of path Line - * fill = it can be gradient, single color, pattern or image - * animationDelay = how much to delay when starting animation (in milliseconds) - * dataChangeSpeed = for dynamic animations, when data changes - * className = class attribute to add - * @return {object} svg.js path object - **/ - - }, { - key: "renderPaths", - value: function renderPaths(_ref2) { - var j = _ref2.j, - realIndex = _ref2.realIndex, - pathFrom = _ref2.pathFrom, - pathTo = _ref2.pathTo, - stroke = _ref2.stroke, - strokeWidth = _ref2.strokeWidth, - strokeLinecap = _ref2.strokeLinecap, - fill = _ref2.fill, - animationDelay = _ref2.animationDelay, - initialSpeed = _ref2.initialSpeed, - dataChangeSpeed = _ref2.dataChangeSpeed, - className = _ref2.className, - _ref2$shouldClipToGri = _ref2.shouldClipToGrid, - shouldClipToGrid = _ref2$shouldClipToGri === void 0 ? true : _ref2$shouldClipToGri, - _ref2$bindEventsOnPat = _ref2.bindEventsOnPaths, - bindEventsOnPaths = _ref2$bindEventsOnPat === void 0 ? true : _ref2$bindEventsOnPat, - _ref2$drawShadow = _ref2.drawShadow, - drawShadow = _ref2$drawShadow === void 0 ? true : _ref2$drawShadow; - var w = this.w; - var filters = new Filters(this.ctx); - var anim = new Animations(this.ctx); - var initialAnim = this.w.config.chart.animations.enabled; - var dynamicAnim = initialAnim && this.w.config.chart.animations.dynamicAnimation.enabled; - var d; - var shouldAnimate = !!(initialAnim && !w.globals.resized || dynamicAnim && w.globals.dataChanged && w.globals.shouldAnimate); - - if (shouldAnimate) { - d = pathFrom; - } else { - d = pathTo; - w.globals.animationEnded = true; - } - - var strokeDashArrayOpt = w.config.stroke.dashArray; - var strokeDashArray = 0; - - if (Array.isArray(strokeDashArrayOpt)) { - strokeDashArray = strokeDashArrayOpt[realIndex]; - } else { - strokeDashArray = w.config.stroke.dashArray; - } - - var el = this.drawPath({ - d: d, - stroke: stroke, - strokeWidth: strokeWidth, - fill: fill, - fillOpacity: 1, - classes: className, - strokeLinecap: strokeLinecap, - strokeDashArray: strokeDashArray - }); - el.attr('index', realIndex); - - if (shouldClipToGrid) { - el.attr({ - 'clip-path': "url(#gridRectMask".concat(w.globals.cuid, ")") - }); - } // const defaultFilter = el.filterer - - - if (w.config.states.normal.filter.type !== 'none') { - filters.getDefaultFilter(el, realIndex); - } else { - if (w.config.chart.dropShadow.enabled && drawShadow) { - if (!w.config.chart.dropShadow.enabledOnSeries || w.config.chart.dropShadow.enabledOnSeries && w.config.chart.dropShadow.enabledOnSeries.indexOf(realIndex) !== -1) { - var shadow = w.config.chart.dropShadow; - filters.dropShadow(el, shadow, realIndex); - } - } - } - - if (bindEventsOnPaths) { - el.node.addEventListener('mouseenter', this.pathMouseEnter.bind(this, el)); - el.node.addEventListener('mouseleave', this.pathMouseLeave.bind(this, el)); - el.node.addEventListener('mousedown', this.pathMouseDown.bind(this, el)); - } - - el.attr({ - pathTo: pathTo, - pathFrom: pathFrom - }); - var defaultAnimateOpts = { - el: el, - j: j, - realIndex: realIndex, - pathFrom: pathFrom, - pathTo: pathTo, - fill: fill, - strokeWidth: strokeWidth, - delay: animationDelay - }; - - if (initialAnim && !w.globals.resized && !w.globals.dataChanged) { - anim.animatePathsGradually(_objectSpread2(_objectSpread2({}, defaultAnimateOpts), {}, { - speed: initialSpeed - })); - } else { - if (w.globals.resized || !w.globals.dataChanged) { - anim.showDelayedElements(); - } - } - - if (w.globals.dataChanged && dynamicAnim && shouldAnimate) { - anim.animatePathsGradually(_objectSpread2(_objectSpread2({}, defaultAnimateOpts), {}, { - speed: dataChangeSpeed - })); - } - - return el; - } - }, { - key: "drawPattern", - value: function drawPattern(style, width, height) { - var stroke = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : '#a8a8a8'; - var strokeWidth = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 0; - var w = this.w; - var p = w.globals.dom.Paper.pattern(width, height, function (add) { - if (style === 'horizontalLines') { - add.line(0, 0, height, 0).stroke({ - color: stroke, - width: strokeWidth + 1 - }); - } else if (style === 'verticalLines') { - add.line(0, 0, 0, width).stroke({ - color: stroke, - width: strokeWidth + 1 - }); - } else if (style === 'slantedLines') { - add.line(0, 0, width, height).stroke({ - color: stroke, - width: strokeWidth - }); - } else if (style === 'squares') { - add.rect(width, height).fill('none').stroke({ - color: stroke, - width: strokeWidth - }); - } else if (style === 'circles') { - add.circle(width).fill('none').stroke({ - color: stroke, - width: strokeWidth - }); - } - }); - return p; - } - }, { - key: "drawGradient", - value: function drawGradient(style, gfrom, gto, opacityFrom, opacityTo) { - var size = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : null; - var stops = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : null; - var colorStops = arguments.length > 7 && arguments[7] !== undefined ? arguments[7] : null; - var i = arguments.length > 8 && arguments[8] !== undefined ? arguments[8] : 0; - var w = this.w; - var g; - - if (gfrom.length < 9 && gfrom.indexOf('#') === 0) { - // if the hex contains alpha and is of 9 digit, skip the opacity - gfrom = Utils$1.hexToRgba(gfrom, opacityFrom); - } - - if (gto.length < 9 && gto.indexOf('#') === 0) { - gto = Utils$1.hexToRgba(gto, opacityTo); - } - - var stop1 = 0; - var stop2 = 1; - var stop3 = 1; - var stop4 = null; - - if (stops !== null) { - stop1 = typeof stops[0] !== 'undefined' ? stops[0] / 100 : 0; - stop2 = typeof stops[1] !== 'undefined' ? stops[1] / 100 : 1; - stop3 = typeof stops[2] !== 'undefined' ? stops[2] / 100 : 1; - stop4 = typeof stops[3] !== 'undefined' ? stops[3] / 100 : null; - } - - var radial = !!(w.config.chart.type === 'donut' || w.config.chart.type === 'pie' || w.config.chart.type === 'polarArea' || w.config.chart.type === 'bubble'); - - if (colorStops === null || colorStops.length === 0) { - g = w.globals.dom.Paper.gradient(radial ? 'radial' : 'linear', function (stop) { - stop.at(stop1, gfrom, opacityFrom); - stop.at(stop2, gto, opacityTo); - stop.at(stop3, gto, opacityTo); - - if (stop4 !== null) { - stop.at(stop4, gfrom, opacityFrom); - } - }); - } else { - g = w.globals.dom.Paper.gradient(radial ? 'radial' : 'linear', function (stop) { - var gradientStops = Array.isArray(colorStops[i]) ? colorStops[i] : colorStops; - gradientStops.forEach(function (s) { - stop.at(s.offset / 100, s.color, s.opacity); - }); - }); - } - - if (!radial) { - if (style === 'vertical') { - g.from(0, 0).to(0, 1); - } else if (style === 'diagonal') { - g.from(0, 0).to(1, 1); - } else if (style === 'horizontal') { - g.from(0, 1).to(1, 1); - } else if (style === 'diagonal2') { - g.from(1, 0).to(0, 1); - } - } else { - var offx = w.globals.gridWidth / 2; - var offy = w.globals.gridHeight / 2; - - if (w.config.chart.type !== 'bubble') { - g.attr({ - gradientUnits: 'userSpaceOnUse', - cx: offx, - cy: offy, - r: size - }); - } else { - g.attr({ - cx: 0.5, - cy: 0.5, - r: 0.8, - fx: 0.2, - fy: 0.2 - }); - } - } - - return g; - } - }, { - key: "getTextBasedOnMaxWidth", - value: function getTextBasedOnMaxWidth(_ref3) { - var text = _ref3.text, - maxWidth = _ref3.maxWidth, - fontSize = _ref3.fontSize, - fontFamily = _ref3.fontFamily; - var tRects = this.getTextRects(text, fontSize, fontFamily); - var wordWidth = tRects.width / text.length; - var wordsBasedOnWidth = Math.floor(maxWidth / wordWidth); - - if (maxWidth < tRects.width) { - return text.slice(0, wordsBasedOnWidth - 3) + '...'; - } - - return text; - } - }, { - key: "drawText", - value: function drawText(_ref4) { - var _this = this; - - var x = _ref4.x, - y = _ref4.y, - text = _ref4.text, - textAnchor = _ref4.textAnchor, - fontSize = _ref4.fontSize, - fontFamily = _ref4.fontFamily, - fontWeight = _ref4.fontWeight, - foreColor = _ref4.foreColor, - opacity = _ref4.opacity, - maxWidth = _ref4.maxWidth, - _ref4$cssClass = _ref4.cssClass, - cssClass = _ref4$cssClass === void 0 ? '' : _ref4$cssClass, - _ref4$isPlainText = _ref4.isPlainText, - isPlainText = _ref4$isPlainText === void 0 ? true : _ref4$isPlainText; - var w = this.w; - if (typeof text === 'undefined') text = ''; - var truncatedText = text; - - if (!textAnchor) { - textAnchor = 'start'; - } - - if (!foreColor || !foreColor.length) { - foreColor = w.config.chart.foreColor; - } - - fontFamily = fontFamily || w.config.chart.fontFamily; - fontSize = fontSize || '11px'; - fontWeight = fontWeight || 'regular'; - var commonProps = { - maxWidth: maxWidth, - fontSize: fontSize, - fontFamily: fontFamily - }; - var elText; - - if (Array.isArray(text)) { - elText = w.globals.dom.Paper.text(function (add) { - for (var i = 0; i < text.length; i++) { - truncatedText = text[i]; - - if (maxWidth) { - truncatedText = _this.getTextBasedOnMaxWidth(_objectSpread2({ - text: text[i] - }, commonProps)); - } - - i === 0 ? add.tspan(truncatedText) : add.tspan(truncatedText).newLine(); - } - }); - } else { - if (maxWidth) { - truncatedText = this.getTextBasedOnMaxWidth(_objectSpread2({ - text: text - }, commonProps)); - } - - elText = isPlainText ? w.globals.dom.Paper.plain(text) : w.globals.dom.Paper.text(function (add) { - return add.tspan(truncatedText); - }); - } - - elText.attr({ - x: x, - y: y, - 'text-anchor': textAnchor, - 'dominant-baseline': 'auto', - 'font-size': fontSize, - 'font-family': fontFamily, - 'font-weight': fontWeight, - fill: foreColor, - class: 'apexcharts-text ' + cssClass - }); - elText.node.style.fontFamily = fontFamily; - elText.node.style.opacity = opacity; - return elText; - } - }, { - key: "drawMarker", - value: function drawMarker(x, y, opts) { - x = x || 0; - var size = opts.pSize || 0; - var elPoint = null; - - if (opts.shape === 'square' || opts.shape === 'rect') { - var radius = opts.pRadius === undefined ? size / 2 : opts.pRadius; - - if (y === null || !size) { - size = 0; - radius = 0; - } - - var nSize = size * 1.2 + radius; - var p = this.drawRect(nSize, nSize, nSize, nSize, radius); - p.attr({ - x: x - nSize / 2, - y: y - nSize / 2, - cx: x, - cy: y, - class: opts.class ? opts.class : '', - fill: opts.pointFillColor, - 'fill-opacity': opts.pointFillOpacity ? opts.pointFillOpacity : 1, - stroke: opts.pointStrokeColor, - 'stroke-width': opts.pointStrokeWidth ? opts.pointStrokeWidth : 0, - 'stroke-opacity': opts.pointStrokeOpacity ? opts.pointStrokeOpacity : 1 - }); - elPoint = p; - } else if (opts.shape === 'circle' || !opts.shape) { - if (!Utils$1.isNumber(y)) { - size = 0; - y = 0; - } // let nSize = size - opts.pRadius / 2 < 0 ? 0 : size - opts.pRadius / 2 - - - elPoint = this.drawCircle(size, { - cx: x, - cy: y, - class: opts.class ? opts.class : '', - stroke: opts.pointStrokeColor, - fill: opts.pointFillColor, - 'fill-opacity': opts.pointFillOpacity ? opts.pointFillOpacity : 1, - 'stroke-width': opts.pointStrokeWidth ? opts.pointStrokeWidth : 0, - 'stroke-opacity': opts.pointStrokeOpacity ? opts.pointStrokeOpacity : 1 - }); - } - - return elPoint; - } - }, { - key: "pathMouseEnter", - value: function pathMouseEnter(path, e) { - var w = this.w; - var filters = new Filters(this.ctx); - var i = parseInt(path.node.getAttribute('index'), 10); - var j = parseInt(path.node.getAttribute('j'), 10); - - if (typeof w.config.chart.events.dataPointMouseEnter === 'function') { - w.config.chart.events.dataPointMouseEnter(e, this.ctx, { - seriesIndex: i, - dataPointIndex: j, - w: w - }); - } - - this.ctx.events.fireEvent('dataPointMouseEnter', [e, this.ctx, { - seriesIndex: i, - dataPointIndex: j, - w: w - }]); - - if (w.config.states.active.filter.type !== 'none') { - if (path.node.getAttribute('selected') === 'true') { - return; - } - } - - if (w.config.states.hover.filter.type !== 'none') { - if (!w.globals.isTouchDevice) { - var hoverFilter = w.config.states.hover.filter; - filters.applyFilter(path, i, hoverFilter.type, hoverFilter.value); - } - } - } - }, { - key: "pathMouseLeave", - value: function pathMouseLeave(path, e) { - var w = this.w; - var filters = new Filters(this.ctx); - var i = parseInt(path.node.getAttribute('index'), 10); - var j = parseInt(path.node.getAttribute('j'), 10); - - if (typeof w.config.chart.events.dataPointMouseLeave === 'function') { - w.config.chart.events.dataPointMouseLeave(e, this.ctx, { - seriesIndex: i, - dataPointIndex: j, - w: w - }); - } - - this.ctx.events.fireEvent('dataPointMouseLeave', [e, this.ctx, { - seriesIndex: i, - dataPointIndex: j, - w: w - }]); - - if (w.config.states.active.filter.type !== 'none') { - if (path.node.getAttribute('selected') === 'true') { - return; - } - } - - if (w.config.states.hover.filter.type !== 'none') { - filters.getDefaultFilter(path, i); - } - } - }, { - key: "pathMouseDown", - value: function pathMouseDown(path, e) { - var w = this.w; - var filters = new Filters(this.ctx); - var i = parseInt(path.node.getAttribute('index'), 10); - var j = parseInt(path.node.getAttribute('j'), 10); - var selected = 'false'; - - if (path.node.getAttribute('selected') === 'true') { - path.node.setAttribute('selected', 'false'); - - if (w.globals.selectedDataPoints[i].indexOf(j) > -1) { - var index = w.globals.selectedDataPoints[i].indexOf(j); - w.globals.selectedDataPoints[i].splice(index, 1); - } - } else { - if (!w.config.states.active.allowMultipleDataPointsSelection && w.globals.selectedDataPoints.length > 0) { - w.globals.selectedDataPoints = []; - var elPaths = w.globals.dom.Paper.select('.apexcharts-series path').members; - var elCircles = w.globals.dom.Paper.select('.apexcharts-series circle, .apexcharts-series rect').members; - - var deSelect = function deSelect(els) { - Array.prototype.forEach.call(els, function (el) { - el.node.setAttribute('selected', 'false'); - filters.getDefaultFilter(el, i); - }); - }; - - deSelect(elPaths); - deSelect(elCircles); - } - - path.node.setAttribute('selected', 'true'); - selected = 'true'; - - if (typeof w.globals.selectedDataPoints[i] === 'undefined') { - w.globals.selectedDataPoints[i] = []; - } - - w.globals.selectedDataPoints[i].push(j); - } - - if (selected === 'true') { - var activeFilter = w.config.states.active.filter; - - if (activeFilter !== 'none') { - filters.applyFilter(path, i, activeFilter.type, activeFilter.value); - } else { - // Reapply the hover filter in case it was removed by `deselect`when there is no active filter and it is not a touch device - if (w.config.states.hover.filter !== 'none') { - if (!w.globals.isTouchDevice) { - var hoverFilter = w.config.states.hover.filter; - filters.applyFilter(path, i, hoverFilter.type, hoverFilter.value); - } - } - } - } else { - // If the item was deselected, apply hover state filter if it is not a touch device - if (w.config.states.active.filter.type !== 'none') { - if (w.config.states.hover.filter.type !== 'none' && !w.globals.isTouchDevice) { - var hoverFilter = w.config.states.hover.filter; - filters.applyFilter(path, i, hoverFilter.type, hoverFilter.value); - } else { - filters.getDefaultFilter(path, i); - } - } - } - - if (typeof w.config.chart.events.dataPointSelection === 'function') { - w.config.chart.events.dataPointSelection(e, this.ctx, { - selectedDataPoints: w.globals.selectedDataPoints, - seriesIndex: i, - dataPointIndex: j, - w: w - }); - } - - if (e) { - this.ctx.events.fireEvent('dataPointSelection', [e, this.ctx, { - selectedDataPoints: w.globals.selectedDataPoints, - seriesIndex: i, - dataPointIndex: j, - w: w - }]); - } - } - }, { - key: "rotateAroundCenter", - value: function rotateAroundCenter(el) { - var coord = {}; - - if (el && typeof el.getBBox === 'function') { - coord = el.getBBox(); - } - - var x = coord.x + coord.width / 2; - var y = coord.y + coord.height / 2; - return { - x: x, - y: y - }; - } - }, { - key: "getTextRects", - value: function getTextRects(text, fontSize, fontFamily, transform) { - var useBBox = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; - var w = this.w; - var virtualText = this.drawText({ - x: -200, - y: -200, - text: text, - textAnchor: 'start', - fontSize: fontSize, - fontFamily: fontFamily, - foreColor: '#fff', - opacity: 0 - }); - - if (transform) { - virtualText.attr('transform', transform); - } - - w.globals.dom.Paper.add(virtualText); - var rect = virtualText.bbox(); - - if (!useBBox) { - rect = virtualText.node.getBoundingClientRect(); - } - - virtualText.remove(); - return { - width: rect.width, - height: rect.height - }; - } - /** - * append ... to long text - * http://stackoverflow.com/questions/9241315/trimming-text-to-a-given-pixel-width-in-svg - * @memberof Graphics - **/ - - }, { - key: "placeTextWithEllipsis", - value: function placeTextWithEllipsis(textObj, textString, width) { - if (typeof textObj.getComputedTextLength !== 'function') return; - textObj.textContent = textString; - - if (textString.length > 0) { - // ellipsis is needed - if (textObj.getComputedTextLength() >= width / 1.1) { - for (var x = textString.length - 3; x > 0; x -= 3) { - if (textObj.getSubStringLength(0, x) <= width / 1.1) { - textObj.textContent = textString.substring(0, x) + '...'; - return; - } - } - - textObj.textContent = '.'; // can't place at all - } - } - } - }], [{ - key: "setAttrs", - value: function setAttrs(el, attrs) { - for (var key in attrs) { - if (attrs.hasOwnProperty(key)) { - el.setAttribute(key, attrs[key]); - } - } - } - }]); - - return Graphics; - }(); - - /* - ** Util functions which are dependent on ApexCharts instance - */ - var CoreUtils = /*#__PURE__*/function () { - function CoreUtils(ctx) { - _classCallCheck(this, CoreUtils); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(CoreUtils, [{ - key: "getStackedSeriesTotals", - value: - /** - * @memberof CoreUtils - * returns the sum of all individual values in a multiple stacked series - * Eg. w.globals.series = [[32,33,43,12], [2,3,5,1]] - * @return [34,36,48,13] - **/ - function getStackedSeriesTotals() { - var excludedSeriesIndices = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; - var w = this.w; - var total = []; - if (w.globals.series.length === 0) return total; - - for (var i = 0; i < w.globals.series[w.globals.maxValsInArrayIndex].length; i++) { - var t = 0; - - for (var j = 0; j < w.globals.series.length; j++) { - if (typeof w.globals.series[j][i] !== 'undefined' && excludedSeriesIndices.indexOf(j) === -1) { - t += w.globals.series[j][i]; - } - } - - total.push(t); - } - - return total; - } // get total of the all values inside all series - - }, { - key: "getSeriesTotalByIndex", - value: function getSeriesTotalByIndex() { - var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - - if (index === null) { - // non-plot chart types - pie / donut / circle - return this.w.config.series.reduce(function (acc, cur) { - return acc + cur; - }, 0); - } else { - // axis charts - supporting multiple series - return this.w.globals.series[index].reduce(function (acc, cur) { - return acc + cur; - }, 0); - } - } - }, { - key: "isSeriesNull", - value: function isSeriesNull() { - var index = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - var r = []; - - if (index === null) { - // non-plot chart types - pie / donut / circle - r = this.w.config.series.filter(function (d) { - return d !== null; - }); - } else { - // axis charts - supporting multiple series - r = this.w.config.series[index].data.filter(function (d) { - return d !== null; - }); - } - - return r.length === 0; - } - }, { - key: "seriesHaveSameValues", - value: function seriesHaveSameValues(index) { - return this.w.globals.series[index].every(function (val, i, arr) { - return val === arr[0]; - }); - } - }, { - key: "getCategoryLabels", - value: function getCategoryLabels(labels) { - var w = this.w; - var catLabels = labels.slice(); - - if (w.config.xaxis.convertedCatToNumeric) { - catLabels = labels.map(function (i, li) { - return w.config.xaxis.labels.formatter(i - w.globals.minX + 1); - }); - } - - return catLabels; - } // maxValsInArrayIndex is the index of series[] which has the largest number of items - - }, { - key: "getLargestSeries", - value: function getLargestSeries() { - var w = this.w; - w.globals.maxValsInArrayIndex = w.globals.series.map(function (a) { - return a.length; - }).indexOf(Math.max.apply(Math, w.globals.series.map(function (a) { - return a.length; - }))); - } - }, { - key: "getLargestMarkerSize", - value: function getLargestMarkerSize() { - var w = this.w; - var size = 0; - w.globals.markers.size.forEach(function (m) { - size = Math.max(size, m); - }); - - if (w.config.markers.discrete && w.config.markers.discrete.length) { - w.config.markers.discrete.forEach(function (m) { - size = Math.max(size, m.size); - }); - } - - if (size > 0) { - size += w.config.markers.hover.sizeOffset + 1; - } - - w.globals.markers.largestSize = size; - return size; - } - /** - * @memberof Core - * returns the sum of all values in a series - * Eg. w.globals.series = [[32,33,43,12], [2,3,5,1]] - * @return [120, 11] - **/ - - }, { - key: "getSeriesTotals", - value: function getSeriesTotals() { - var w = this.w; - w.globals.seriesTotals = w.globals.series.map(function (ser, index) { - var total = 0; - - if (Array.isArray(ser)) { - for (var j = 0; j < ser.length; j++) { - total += ser[j]; - } - } else { - // for pie/donuts/gauges - total += ser; - } - - return total; - }); - } - }, { - key: "getSeriesTotalsXRange", - value: function getSeriesTotalsXRange(minX, maxX) { - var w = this.w; - var seriesTotalsXRange = w.globals.series.map(function (ser, index) { - var total = 0; - - for (var j = 0; j < ser.length; j++) { - if (w.globals.seriesX[index][j] > minX && w.globals.seriesX[index][j] < maxX) { - total += ser[j]; - } - } - - return total; - }); - return seriesTotalsXRange; - } - /** - * @memberof CoreUtils - * returns the percentage value of all individual values which can be used in a 100% stacked series - * Eg. w.globals.series = [[32, 33, 43, 12], [2, 3, 5, 1]] - * @return [[94.11, 91.66, 89.58, 92.30], [5.88, 8.33, 10.41, 7.7]] - **/ - - }, { - key: "getPercentSeries", - value: function getPercentSeries() { - var w = this.w; - w.globals.seriesPercent = w.globals.series.map(function (ser, index) { - var seriesPercent = []; - - if (Array.isArray(ser)) { - for (var j = 0; j < ser.length; j++) { - var total = w.globals.stackedSeriesTotals[j]; - var percent = 0; - - if (total) { - percent = 100 * ser[j] / total; - } - - seriesPercent.push(percent); - } - } else { - var _total = w.globals.seriesTotals.reduce(function (acc, val) { - return acc + val; - }, 0); - - var _percent = 100 * ser / _total; - - seriesPercent.push(_percent); - } - - return seriesPercent; - }); - } - }, { - key: "getCalculatedRatios", - value: function getCalculatedRatios() { - var gl = this.w.globals; - var yRatio = []; - var invertedYRatio = 0; - var xRatio = 0; - var initialXRatio = 0; - var invertedXRatio = 0; - var zRatio = 0; - var baseLineY = []; - var baseLineInvertedY = 0.1; - var baseLineX = 0; - gl.yRange = []; - - if (gl.isMultipleYAxis) { - for (var i = 0; i < gl.minYArr.length; i++) { - gl.yRange.push(Math.abs(gl.minYArr[i] - gl.maxYArr[i])); - baseLineY.push(0); - } - } else { - gl.yRange.push(Math.abs(gl.minY - gl.maxY)); - } - - gl.xRange = Math.abs(gl.maxX - gl.minX); - gl.zRange = Math.abs(gl.maxZ - gl.minZ); // multiple y axis - - for (var _i = 0; _i < gl.yRange.length; _i++) { - yRatio.push(gl.yRange[_i] / gl.gridHeight); - } - - xRatio = gl.xRange / gl.gridWidth; - initialXRatio = Math.abs(gl.initialMaxX - gl.initialMinX) / gl.gridWidth; - invertedYRatio = gl.yRange / gl.gridWidth; - invertedXRatio = gl.xRange / gl.gridHeight; - zRatio = gl.zRange / gl.gridHeight * 16; - - if (!zRatio) { - zRatio = 1; - } - - if (gl.minY !== Number.MIN_VALUE && Math.abs(gl.minY) !== 0) { - // Negative numbers present in series - gl.hasNegs = true; - } - - if (gl.isMultipleYAxis) { - baseLineY = []; // baseline variables is the 0 of the yaxis which will be needed when there are negatives - - for (var _i2 = 0; _i2 < yRatio.length; _i2++) { - baseLineY.push(-gl.minYArr[_i2] / yRatio[_i2]); - } - } else { - baseLineY.push(-gl.minY / yRatio[0]); - - if (gl.minY !== Number.MIN_VALUE && Math.abs(gl.minY) !== 0) { - baseLineInvertedY = -gl.minY / invertedYRatio; // this is for bar chart - - baseLineX = gl.minX / xRatio; - } - } - - return { - yRatio: yRatio, - invertedYRatio: invertedYRatio, - zRatio: zRatio, - xRatio: xRatio, - initialXRatio: initialXRatio, - invertedXRatio: invertedXRatio, - baseLineInvertedY: baseLineInvertedY, - baseLineY: baseLineY, - baseLineX: baseLineX - }; - } - }, { - key: "getLogSeries", - value: function getLogSeries(series) { - var _this = this; - - var w = this.w; - w.globals.seriesLog = series.map(function (s, i) { - if (w.config.yaxis[i] && w.config.yaxis[i].logarithmic) { - return s.map(function (d) { - if (d === null) return null; - return _this.getLogVal(w.config.yaxis[i].logBase, d, i); - }); - } else { - return s; - } - }); - return w.globals.invalidLogScale ? series : w.globals.seriesLog; - } - }, { - key: "getBaseLog", - value: function getBaseLog(base, value) { - return Math.log(value) / Math.log(base); - } - }, { - key: "getLogVal", - value: function getLogVal(b, d, yIndex) { - if (d === 0) { - return 0; - } - - var w = this.w; - var min_log_val = w.globals.minYArr[yIndex] === 0 ? -1 // make sure we dont calculate log of 0 - : this.getBaseLog(b, w.globals.minYArr[yIndex]); - var max_log_val = w.globals.maxYArr[yIndex] === 0 ? 0 // make sure we dont calculate log of 0 - : this.getBaseLog(b, w.globals.maxYArr[yIndex]); - var number_of_height_levels = max_log_val - min_log_val; - if (d < 1) return d / number_of_height_levels; - var log_height_value = this.getBaseLog(b, d) - min_log_val; - return log_height_value / number_of_height_levels; - } - }, { - key: "getLogYRatios", - value: function getLogYRatios(yRatio) { - var _this2 = this; - - var w = this.w; - var gl = this.w.globals; - gl.yLogRatio = yRatio.slice(); - gl.logYRange = gl.yRange.map(function (yRange, i) { - if (w.config.yaxis[i] && _this2.w.config.yaxis[i].logarithmic) { - var maxY = -Number.MAX_VALUE; - var minY = Number.MIN_VALUE; - var range = 1; - gl.seriesLog.forEach(function (s, si) { - s.forEach(function (v) { - if (w.config.yaxis[si] && w.config.yaxis[si].logarithmic) { - maxY = Math.max(v, maxY); - minY = Math.min(v, minY); - } - }); - }); - range = Math.pow(gl.yRange[i], Math.abs(minY - maxY) / gl.yRange[i]); - gl.yLogRatio[i] = range / gl.gridHeight; - return range; - } - }); - return gl.invalidLogScale ? yRatio.slice() : gl.yLogRatio; - } // Some config objects can be array - and we need to extend them correctly - - }], [{ - key: "checkComboSeries", - value: function checkComboSeries(series) { - var comboCharts = false; - var comboBarCount = 0; - var comboCount = 0; // if user specified a type in series too, turn on comboCharts flag - - if (series.length && typeof series[0].type !== 'undefined') { - series.forEach(function (s) { - if (s.type === 'bar' || s.type === 'column' || s.type === 'candlestick' || s.type === 'boxPlot') { - comboBarCount++; - } - - if (typeof s.type !== 'undefined') { - comboCount++; - } - }); - } - - if (comboCount > 0) { - comboCharts = true; - } - - return { - comboBarCount: comboBarCount, - comboCharts: comboCharts - }; - } - }, { - key: "extendArrayProps", - value: function extendArrayProps(configInstance, options, w) { - if (options.yaxis) { - options = configInstance.extendYAxis(options, w); - } - - if (options.annotations) { - if (options.annotations.yaxis) { - options = configInstance.extendYAxisAnnotations(options); - } - - if (options.annotations.xaxis) { - options = configInstance.extendXAxisAnnotations(options); - } - - if (options.annotations.points) { - options = configInstance.extendPointAnnotations(options); - } - } - - return options; - } - }]); - - return CoreUtils; - }(); - - var Helpers$4 = /*#__PURE__*/function () { - function Helpers(annoCtx) { - _classCallCheck(this, Helpers); - - this.w = annoCtx.w; - this.annoCtx = annoCtx; - } - - _createClass(Helpers, [{ - key: "setOrientations", - value: function setOrientations(anno) { - var annoIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - var w = this.w; - - if (anno.label.orientation === 'vertical') { - var i = annoIndex !== null ? annoIndex : 0; - var xAnno = w.globals.dom.baseEl.querySelector(".apexcharts-xaxis-annotations .apexcharts-xaxis-annotation-label[rel='".concat(i, "']")); - - if (xAnno !== null) { - var xAnnoCoord = xAnno.getBoundingClientRect(); - xAnno.setAttribute('x', parseFloat(xAnno.getAttribute('x')) - xAnnoCoord.height + 4); - - if (anno.label.position === 'top') { - xAnno.setAttribute('y', parseFloat(xAnno.getAttribute('y')) + xAnnoCoord.width); - } else { - xAnno.setAttribute('y', parseFloat(xAnno.getAttribute('y')) - xAnnoCoord.width); - } - - var annoRotatingCenter = this.annoCtx.graphics.rotateAroundCenter(xAnno); - var x = annoRotatingCenter.x; - var y = annoRotatingCenter.y; - xAnno.setAttribute('transform', "rotate(-90 ".concat(x, " ").concat(y, ")")); - } - } - } - }, { - key: "addBackgroundToAnno", - value: function addBackgroundToAnno(annoEl, anno) { - var w = this.w; - if (!annoEl || typeof anno.label.text === 'undefined' || typeof anno.label.text !== 'undefined' && !String(anno.label.text).trim()) return null; - var elGridRect = w.globals.dom.baseEl.querySelector('.apexcharts-grid').getBoundingClientRect(); - var coords = annoEl.getBoundingClientRect(); - var pleft = anno.label.style.padding.left; - var pright = anno.label.style.padding.right; - var ptop = anno.label.style.padding.top; - var pbottom = anno.label.style.padding.bottom; - - if (anno.label.orientation === 'vertical') { - ptop = anno.label.style.padding.left; - pbottom = anno.label.style.padding.right; - pleft = anno.label.style.padding.top; - pright = anno.label.style.padding.bottom; - } - - var x1 = coords.left - elGridRect.left - pleft; - var y1 = coords.top - elGridRect.top - ptop; - var elRect = this.annoCtx.graphics.drawRect(x1 - w.globals.barPadForNumericAxis, y1, coords.width + pleft + pright, coords.height + ptop + pbottom, anno.label.borderRadius, anno.label.style.background, 1, anno.label.borderWidth, anno.label.borderColor, 0); - - if (anno.id) { - // don't escapeString for this ID as it causes duplicate rects - elRect.node.classList.add(anno.id); - } - - return elRect; - } - }, { - key: "annotationsBackground", - value: function annotationsBackground() { - var _this = this; - - var w = this.w; - - var add = function add(anno, i, type) { - var annoLabel = w.globals.dom.baseEl.querySelector(".apexcharts-".concat(type, "-annotations .apexcharts-").concat(type, "-annotation-label[rel='").concat(i, "']")); - - if (annoLabel) { - var parent = annoLabel.parentNode; - - var elRect = _this.addBackgroundToAnno(annoLabel, anno); - - if (elRect) { - parent.insertBefore(elRect.node, annoLabel); - - if (anno.label.mouseEnter) { - elRect.node.addEventListener('mouseenter', anno.label.mouseEnter.bind(_this, anno)); - } - - if (anno.label.mouseLeave) { - elRect.node.addEventListener('mouseleave', anno.label.mouseLeave.bind(_this, anno)); - } - - if (anno.label.click) { - elRect.node.addEventListener('click', anno.label.click.bind(_this, anno)); - } - } - } - }; - - w.config.annotations.xaxis.map(function (anno, i) { - add(anno, i, 'xaxis'); - }); - w.config.annotations.yaxis.map(function (anno, i) { - add(anno, i, 'yaxis'); - }); - w.config.annotations.points.map(function (anno, i) { - add(anno, i, 'point'); - }); - } - }, { - key: "getY1Y2", - value: function getY1Y2(type, anno) { - var y = type === 'y1' ? anno.y : anno.y2; - var yP; - var w = this.w; - - if (this.annoCtx.invertAxis) { - var catIndex = w.globals.labels.indexOf(y); - - if (w.config.xaxis.convertedCatToNumeric) { - catIndex = w.globals.categoryLabels.indexOf(y); - } - - var xLabel = w.globals.dom.baseEl.querySelector('.apexcharts-yaxis-texts-g text:nth-child(' + (catIndex + 1) + ')'); - - if (xLabel) { - yP = parseFloat(xLabel.getAttribute('y')); - } - } else { - var yPos; - - if (w.config.yaxis[anno.yAxisIndex].logarithmic) { - var coreUtils = new CoreUtils(this.annoCtx.ctx); - y = coreUtils.getLogVal(y, anno.yAxisIndex); - yPos = y / w.globals.yLogRatio[anno.yAxisIndex]; - } else { - yPos = (y - w.globals.minYArr[anno.yAxisIndex]) / (w.globals.yRange[anno.yAxisIndex] / w.globals.gridHeight); - } - - yP = w.globals.gridHeight - yPos; - - if (anno.marker && (anno.y === undefined || anno.y === null)) { - // point annotation - yP = 0; - } - - if (w.config.yaxis[anno.yAxisIndex] && w.config.yaxis[anno.yAxisIndex].reversed) { - yP = yPos; - } - } - - if (typeof y === 'string' && y.indexOf('px') > -1) { - yP = parseFloat(y); - } - - return yP; - } - }, { - key: "getX1X2", - value: function getX1X2(type, anno) { - var w = this.w; - var min = this.annoCtx.invertAxis ? w.globals.minY : w.globals.minX; - var max = this.annoCtx.invertAxis ? w.globals.maxY : w.globals.maxX; - var range = this.annoCtx.invertAxis ? w.globals.yRange[0] : w.globals.xRange; - var x1 = (anno.x - min) / (range / w.globals.gridWidth); - - if (this.annoCtx.inversedReversedAxis) { - x1 = (max - anno.x) / (range / w.globals.gridWidth); - } - - if ((w.config.xaxis.type === 'category' || w.config.xaxis.convertedCatToNumeric) && !this.annoCtx.invertAxis && !w.globals.dataFormatXNumeric) { - x1 = this.getStringX(anno.x); - } - - var x2 = (anno.x2 - min) / (range / w.globals.gridWidth); - - if (this.annoCtx.inversedReversedAxis) { - x2 = (max - anno.x2) / (range / w.globals.gridWidth); - } - - if ((w.config.xaxis.type === 'category' || w.config.xaxis.convertedCatToNumeric) && !this.annoCtx.invertAxis && !w.globals.dataFormatXNumeric) { - x2 = this.getStringX(anno.x2); - } - - if ((anno.x === undefined || anno.x === null) && anno.marker) { - // point annotation in a horizontal chart - x1 = w.globals.gridWidth; - } - - if (type === 'x1' && typeof anno.x === 'string' && anno.x.indexOf('px') > -1) { - x1 = parseFloat(anno.x); - } - - if (type === 'x2' && typeof anno.x2 === 'string' && anno.x2.indexOf('px') > -1) { - x2 = parseFloat(anno.x2); - } - - return type === 'x1' ? x1 : x2; - } - }, { - key: "getStringX", - value: function getStringX(x) { - var w = this.w; - var rX = x; - - if (w.config.xaxis.convertedCatToNumeric && w.globals.categoryLabels.length) { - x = w.globals.categoryLabels.indexOf(x) + 1; - } - - var catIndex = w.globals.labels.indexOf(x); - var xLabel = w.globals.dom.baseEl.querySelector('.apexcharts-xaxis-texts-g text:nth-child(' + (catIndex + 1) + ')'); - - if (xLabel) { - rX = parseFloat(xLabel.getAttribute('x')); - } - - return rX; - } - }]); - - return Helpers; - }(); - - var XAnnotations = /*#__PURE__*/function () { - function XAnnotations(annoCtx) { - _classCallCheck(this, XAnnotations); - - this.w = annoCtx.w; - this.annoCtx = annoCtx; - this.invertAxis = this.annoCtx.invertAxis; - this.helpers = new Helpers$4(this.annoCtx); - } - - _createClass(XAnnotations, [{ - key: "addXaxisAnnotation", - value: function addXaxisAnnotation(anno, parent, index) { - var w = this.w; - var x1 = this.helpers.getX1X2('x1', anno); - var x2; - var text = anno.label.text; - var strokeDashArray = anno.strokeDashArray; - if (!Utils$1.isNumber(x1)) return; - - if (anno.x2 === null || typeof anno.x2 === 'undefined') { - var line = this.annoCtx.graphics.drawLine(x1 + anno.offsetX, // x1 - 0 + anno.offsetY, // y1 - x1 + anno.offsetX, // x2 - w.globals.gridHeight + anno.offsetY, // y2 - anno.borderColor, // lineColor - strokeDashArray, //dashArray - anno.borderWidth); - parent.appendChild(line.node); - - if (anno.id) { - line.node.classList.add(anno.id); - } - } else { - x2 = this.helpers.getX1X2('x2', anno); - - if (x2 < x1) { - var temp = x1; - x1 = x2; - x2 = temp; - } - - var rect = this.annoCtx.graphics.drawRect(x1 + anno.offsetX, // x1 - 0 + anno.offsetY, // y1 - x2 - x1, // x2 - w.globals.gridHeight + anno.offsetY, // y2 - 0, // radius - anno.fillColor, // color - anno.opacity, // opacity, - 1, // strokeWidth - anno.borderColor, // strokeColor - strokeDashArray // stokeDashArray - ); - rect.node.classList.add('apexcharts-annotation-rect'); - rect.attr('clip-path', "url(#gridRectMask".concat(w.globals.cuid, ")")); - parent.appendChild(rect.node); - - if (anno.id) { - rect.node.classList.add(anno.id); - } - } - - var textRects = this.annoCtx.graphics.getTextRects(text, parseFloat(anno.label.style.fontSize)); - var textY = anno.label.position === 'top' ? 4 : anno.label.position === 'center' ? w.globals.gridHeight / 2 + (anno.label.orientation === 'vertical' ? textRects.width / 2 : 0) : w.globals.gridHeight; - var elText = this.annoCtx.graphics.drawText({ - x: x1 + anno.label.offsetX, - y: textY + anno.label.offsetY - (anno.label.orientation === 'vertical' ? anno.label.position === 'top' ? textRects.width / 2 - 12 : -textRects.width / 2 : 0), - text: text, - textAnchor: anno.label.textAnchor, - fontSize: anno.label.style.fontSize, - fontFamily: anno.label.style.fontFamily, - fontWeight: anno.label.style.fontWeight, - foreColor: anno.label.style.color, - cssClass: "apexcharts-xaxis-annotation-label ".concat(anno.label.style.cssClass, " ").concat(anno.id ? anno.id : '') - }); - elText.attr({ - rel: index - }); - parent.appendChild(elText.node); // after placing the annotations on svg, set any vertically placed annotations - - this.annoCtx.helpers.setOrientations(anno, index); - } - }, { - key: "drawXAxisAnnotations", - value: function drawXAxisAnnotations() { - var _this = this; - - var w = this.w; - var elg = this.annoCtx.graphics.group({ - class: 'apexcharts-xaxis-annotations' - }); - w.config.annotations.xaxis.map(function (anno, index) { - _this.addXaxisAnnotation(anno, elg.node, index); - }); - return elg; - } - }]); - - return XAnnotations; - }(); - - var YAnnotations = /*#__PURE__*/function () { - function YAnnotations(annoCtx) { - _classCallCheck(this, YAnnotations); - - this.w = annoCtx.w; - this.annoCtx = annoCtx; - this.helpers = new Helpers$4(this.annoCtx); - } - - _createClass(YAnnotations, [{ - key: "addYaxisAnnotation", - value: function addYaxisAnnotation(anno, parent, index) { - var w = this.w; - var strokeDashArray = anno.strokeDashArray; - var y1 = this.helpers.getY1Y2('y1', anno); - var y2; - var text = anno.label.text; - - if (anno.y2 === null || typeof anno.y2 === 'undefined') { - var line = this.annoCtx.graphics.drawLine(0 + anno.offsetX, // x1 - y1 + anno.offsetY, // y1 - this._getYAxisAnnotationWidth(anno), // x2 - y1 + anno.offsetY, // y2 - anno.borderColor, // lineColor - strokeDashArray, // dashArray - anno.borderWidth); - parent.appendChild(line.node); - - if (anno.id) { - line.node.classList.add(anno.id); - } - } else { - y2 = this.helpers.getY1Y2('y2', anno); - - if (y2 > y1) { - var temp = y1; - y1 = y2; - y2 = temp; - } - - var rect = this.annoCtx.graphics.drawRect(0 + anno.offsetX, // x1 - y2 + anno.offsetY, // y1 - this._getYAxisAnnotationWidth(anno), // x2 - y1 - y2, // y2 - 0, // radius - anno.fillColor, // color - anno.opacity, // opacity, - 1, // strokeWidth - anno.borderColor, // strokeColor - strokeDashArray // stokeDashArray - ); - rect.node.classList.add('apexcharts-annotation-rect'); - rect.attr('clip-path', "url(#gridRectMask".concat(w.globals.cuid, ")")); - parent.appendChild(rect.node); - - if (anno.id) { - rect.node.classList.add(anno.id); - } - } - - var textX = anno.label.position === 'right' ? w.globals.gridWidth : anno.label.position === 'center' ? w.globals.gridWidth / 2 : 0; - var elText = this.annoCtx.graphics.drawText({ - x: textX + anno.label.offsetX, - y: (y2 != null ? y2 : y1) + anno.label.offsetY - 3, - text: text, - textAnchor: anno.label.textAnchor, - fontSize: anno.label.style.fontSize, - fontFamily: anno.label.style.fontFamily, - fontWeight: anno.label.style.fontWeight, - foreColor: anno.label.style.color, - cssClass: "apexcharts-yaxis-annotation-label ".concat(anno.label.style.cssClass, " ").concat(anno.id ? anno.id : '') - }); - elText.attr({ - rel: index - }); - parent.appendChild(elText.node); - } - }, { - key: "_getYAxisAnnotationWidth", - value: function _getYAxisAnnotationWidth(anno) { - // issue apexcharts.js#2009 - var w = this.w; - var width = w.globals.gridWidth; - - if (anno.width.indexOf('%') > -1) { - width = w.globals.gridWidth * parseInt(anno.width, 10) / 100; - } else { - width = parseInt(anno.width, 10); - } - - return width + anno.offsetX; - } - }, { - key: "drawYAxisAnnotations", - value: function drawYAxisAnnotations() { - var _this = this; - - var w = this.w; - var elg = this.annoCtx.graphics.group({ - class: 'apexcharts-yaxis-annotations' - }); - w.config.annotations.yaxis.map(function (anno, index) { - _this.addYaxisAnnotation(anno, elg.node, index); - }); - return elg; - } - }]); - - return YAnnotations; - }(); - - var PointAnnotations = /*#__PURE__*/function () { - function PointAnnotations(annoCtx) { - _classCallCheck(this, PointAnnotations); - - this.w = annoCtx.w; - this.annoCtx = annoCtx; - this.helpers = new Helpers$4(this.annoCtx); - } - - _createClass(PointAnnotations, [{ - key: "addPointAnnotation", - value: function addPointAnnotation(anno, parent, index) { - this.w; - var x = this.helpers.getX1X2('x1', anno); - var y = this.helpers.getY1Y2('y1', anno); - if (!Utils$1.isNumber(x)) return; - var optsPoints = { - pSize: anno.marker.size, - pointStrokeWidth: anno.marker.strokeWidth, - pointFillColor: anno.marker.fillColor, - pointStrokeColor: anno.marker.strokeColor, - shape: anno.marker.shape, - pRadius: anno.marker.radius, - class: "apexcharts-point-annotation-marker ".concat(anno.marker.cssClass, " ").concat(anno.id ? anno.id : '') - }; - var point = this.annoCtx.graphics.drawMarker(x + anno.marker.offsetX, y + anno.marker.offsetY, optsPoints); - parent.appendChild(point.node); - var text = anno.label.text ? anno.label.text : ''; - var elText = this.annoCtx.graphics.drawText({ - x: x + anno.label.offsetX, - y: y + anno.label.offsetY - anno.marker.size - parseFloat(anno.label.style.fontSize) / 1.6, - text: text, - textAnchor: anno.label.textAnchor, - fontSize: anno.label.style.fontSize, - fontFamily: anno.label.style.fontFamily, - fontWeight: anno.label.style.fontWeight, - foreColor: anno.label.style.color, - cssClass: "apexcharts-point-annotation-label ".concat(anno.label.style.cssClass, " ").concat(anno.id ? anno.id : '') - }); - elText.attr({ - rel: index - }); - parent.appendChild(elText.node); // TODO: deprecate this as we will use custom - - if (anno.customSVG.SVG) { - var g = this.annoCtx.graphics.group({ - class: 'apexcharts-point-annotations-custom-svg ' + anno.customSVG.cssClass - }); - g.attr({ - transform: "translate(".concat(x + anno.customSVG.offsetX, ", ").concat(y + anno.customSVG.offsetY, ")") - }); - g.node.innerHTML = anno.customSVG.SVG; - parent.appendChild(g.node); - } - - if (anno.image.path) { - var imgWidth = anno.image.width ? anno.image.width : 20; - var imgHeight = anno.image.height ? anno.image.height : 20; - point = this.annoCtx.addImage({ - x: x + anno.image.offsetX - imgWidth / 2, - y: y + anno.image.offsetY - imgHeight / 2, - width: imgWidth, - height: imgHeight, - path: anno.image.path, - appendTo: '.apexcharts-point-annotations' - }); - } - - if (anno.mouseEnter) { - point.node.addEventListener('mouseenter', anno.mouseEnter.bind(this, anno)); - } - - if (anno.mouseLeave) { - point.node.addEventListener('mouseleave', anno.mouseLeave.bind(this, anno)); - } - - if (anno.click) { - point.node.addEventListener('click', anno.click.bind(this, anno)); - } - } - }, { - key: "drawPointAnnotations", - value: function drawPointAnnotations() { - var _this = this; - - var w = this.w; - var elg = this.annoCtx.graphics.group({ - class: 'apexcharts-point-annotations' - }); - w.config.annotations.points.map(function (anno, index) { - _this.addPointAnnotation(anno, elg.node, index); - }); - return elg; - } - }]); - - return PointAnnotations; - }(); - - const name = "en"; - const options = { - months: [ - "January", - "February", - "March", - "April", - "May", - "June", - "July", - "August", - "September", - "October", - "November", - "December" - ], - shortMonths: [ - "Jan", - "Feb", - "Mar", - "Apr", - "May", - "Jun", - "Jul", - "Aug", - "Sep", - "Oct", - "Nov", - "Dec" - ], - days: [ - "Sunday", - "Monday", - "Tuesday", - "Wednesday", - "Thursday", - "Friday", - "Saturday" - ], - shortDays: [ - "Sun", - "Mon", - "Tue", - "Wed", - "Thu", - "Fri", - "Sat" - ], - toolbar: { - exportToSVG: "Download SVG", - exportToPNG: "Download PNG", - exportToCSV: "Download CSV", - menu: "Menu", - selection: "Selection", - selectionZoom: "Selection Zoom", - zoomIn: "Zoom In", - zoomOut: "Zoom Out", - pan: "Panning", - reset: "Reset Zoom" - } - }; - var en = { - name: name, - options: options - }; - - var Options = /*#__PURE__*/function () { - function Options() { - _classCallCheck(this, Options); - - this.yAxis = { - show: true, - showAlways: false, - showForNullSeries: true, - seriesName: undefined, - opposite: false, - reversed: false, - logarithmic: false, - logBase: 10, - tickAmount: undefined, - forceNiceScale: false, - max: undefined, - min: undefined, - floating: false, - decimalsInFloat: undefined, - labels: { - show: true, - minWidth: 0, - maxWidth: 160, - offsetX: 0, - offsetY: 0, - align: undefined, - rotate: 0, - padding: 20, - style: { - colors: [], - fontSize: '11px', - fontWeight: 400, - fontFamily: undefined, - cssClass: '' - }, - formatter: undefined - }, - axisBorder: { - show: false, - color: '#e0e0e0', - width: 1, - offsetX: 0, - offsetY: 0 - }, - axisTicks: { - show: false, - color: '#e0e0e0', - width: 6, - offsetX: 0, - offsetY: 0 - }, - title: { - text: undefined, - rotate: -90, - offsetY: 0, - offsetX: 0, - style: { - color: undefined, - fontSize: '11px', - fontWeight: 900, - fontFamily: undefined, - cssClass: '' - } - }, - tooltip: { - enabled: false, - offsetX: 0 - }, - crosshairs: { - show: true, - position: 'front', - stroke: { - color: '#b6b6b6', - width: 1, - dashArray: 0 - } - } - }; - this.pointAnnotation = { - id: undefined, - x: 0, - y: null, - yAxisIndex: 0, - seriesIndex: 0, - mouseEnter: undefined, - mouseLeave: undefined, - click: undefined, - marker: { - size: 4, - fillColor: '#fff', - strokeWidth: 2, - strokeColor: '#333', - shape: 'circle', - offsetX: 0, - offsetY: 0, - radius: 2, - cssClass: '' - }, - label: { - borderColor: '#c2c2c2', - borderWidth: 1, - borderRadius: 2, - text: undefined, - textAnchor: 'middle', - offsetX: 0, - offsetY: 0, - mouseEnter: undefined, - mouseLeave: undefined, - click: undefined, - style: { - background: '#fff', - color: undefined, - fontSize: '11px', - fontFamily: undefined, - fontWeight: 400, - cssClass: '', - padding: { - left: 5, - right: 5, - top: 2, - bottom: 2 - } - } - }, - customSVG: { - // this will be deprecated in the next major version as it is going to be replaced with a better alternative below - SVG: undefined, - cssClass: undefined, - offsetX: 0, - offsetY: 0 - }, - image: { - path: undefined, - width: 20, - height: 20, - offsetX: 0, - offsetY: 0 - } - }; - this.yAxisAnnotation = { - id: undefined, - y: 0, - y2: null, - strokeDashArray: 1, - fillColor: '#c2c2c2', - borderColor: '#c2c2c2', - borderWidth: 1, - opacity: 0.3, - offsetX: 0, - offsetY: 0, - width: '100%', - yAxisIndex: 0, - label: { - borderColor: '#c2c2c2', - borderWidth: 1, - borderRadius: 2, - text: undefined, - textAnchor: 'end', - position: 'right', - offsetX: 0, - offsetY: -3, - mouseEnter: undefined, - mouseLeave: undefined, - click: undefined, - style: { - background: '#fff', - color: undefined, - fontSize: '11px', - fontFamily: undefined, - fontWeight: 400, - cssClass: '', - padding: { - left: 5, - right: 5, - top: 2, - bottom: 2 - } - } - } - }; - this.xAxisAnnotation = { - id: undefined, - x: 0, - x2: null, - strokeDashArray: 1, - fillColor: '#c2c2c2', - borderColor: '#c2c2c2', - borderWidth: 1, - opacity: 0.3, - offsetX: 0, - offsetY: 0, - label: { - borderColor: '#c2c2c2', - borderWidth: 1, - borderRadius: 2, - text: undefined, - textAnchor: 'middle', - orientation: 'vertical', - position: 'top', - offsetX: 0, - offsetY: 0, - mouseEnter: undefined, - mouseLeave: undefined, - click: undefined, - style: { - background: '#fff', - color: undefined, - fontSize: '11px', - fontFamily: undefined, - fontWeight: 400, - cssClass: '', - padding: { - left: 5, - right: 5, - top: 2, - bottom: 2 - } - } - } - }; - this.text = { - x: 0, - y: 0, - text: '', - textAnchor: 'start', - foreColor: undefined, - fontSize: '13px', - fontFamily: undefined, - fontWeight: 400, - appendTo: '.apexcharts-annotations', - backgroundColor: 'transparent', - borderColor: '#c2c2c2', - borderRadius: 0, - borderWidth: 0, - paddingLeft: 4, - paddingRight: 4, - paddingTop: 2, - paddingBottom: 2 - }; - } - - _createClass(Options, [{ - key: "init", - value: function init() { - return { - annotations: { - yaxis: [this.yAxisAnnotation], - xaxis: [this.xAxisAnnotation], - points: [this.pointAnnotation], - texts: [], - images: [], - shapes: [] - }, - chart: { - animations: { - enabled: true, - easing: 'easeinout', - // linear, easeout, easein, easeinout, swing, bounce, elastic - speed: 800, - animateGradually: { - delay: 150, - enabled: true - }, - dynamicAnimation: { - enabled: true, - speed: 350 - } - }, - background: 'transparent', - locales: [en], - defaultLocale: 'en', - dropShadow: { - enabled: false, - enabledOnSeries: undefined, - top: 2, - left: 2, - blur: 4, - color: '#000', - opacity: 0.35 - }, - events: { - animationEnd: undefined, - beforeMount: undefined, - mounted: undefined, - updated: undefined, - click: undefined, - mouseMove: undefined, - mouseLeave: undefined, - xAxisLabelClick: undefined, - legendClick: undefined, - markerClick: undefined, - selection: undefined, - dataPointSelection: undefined, - dataPointMouseEnter: undefined, - dataPointMouseLeave: undefined, - beforeZoom: undefined, - beforeResetZoom: undefined, - zoomed: undefined, - scrolled: undefined, - brushScrolled: undefined - }, - foreColor: '#373d3f', - fontFamily: 'Helvetica, Arial, sans-serif', - height: 'auto', - parentHeightOffset: 15, - redrawOnParentResize: true, - redrawOnWindowResize: true, - id: undefined, - group: undefined, - offsetX: 0, - offsetY: 0, - selection: { - enabled: false, - type: 'x', - // selectedPoints: undefined, // default datapoints that should be selected automatically - fill: { - color: '#24292e', - opacity: 0.1 - }, - stroke: { - width: 1, - color: '#24292e', - opacity: 0.4, - dashArray: 3 - }, - xaxis: { - min: undefined, - max: undefined - }, - yaxis: { - min: undefined, - max: undefined - } - }, - sparkline: { - enabled: false - }, - brush: { - enabled: false, - autoScaleYaxis: true, - target: undefined - }, - stacked: false, - stackType: 'normal', - toolbar: { - show: true, - offsetX: 0, - offsetY: 0, - tools: { - download: true, - selection: true, - zoom: true, - zoomin: true, - zoomout: true, - pan: true, - reset: true, - customIcons: [] - }, - export: { - csv: { - filename: undefined, - columnDelimiter: ',', - headerCategory: 'category', - headerValue: 'value', - dateFormatter: function dateFormatter(timestamp) { - return new Date(timestamp).toDateString(); - } - }, - png: { - filename: undefined - }, - svg: { - filename: undefined - } - }, - autoSelected: 'zoom' // accepts -> zoom, pan, selection - - }, - type: 'line', - width: '100%', - zoom: { - enabled: true, - type: 'x', - autoScaleYaxis: false, - zoomedArea: { - fill: { - color: '#90CAF9', - opacity: 0.4 - }, - stroke: { - color: '#0D47A1', - opacity: 0.4, - width: 1 - } - } - } - }, - plotOptions: { - area: { - fillTo: 'origin' - }, - bar: { - horizontal: false, - columnWidth: '70%', - // should be in percent 0 - 100 - barHeight: '70%', - // should be in percent 0 - 100 - distributed: false, - borderRadius: 0, - borderRadiusApplication: 'around', - // [around, end] - borderRadiusWhenStacked: 'last', - // [all, last] - rangeBarOverlap: true, - rangeBarGroupRows: false, - hideZeroBarsWhenGrouped: false, - isDumbbell: false, - dumbbellColors: undefined, - colors: { - ranges: [], - backgroundBarColors: [], - backgroundBarOpacity: 1, - backgroundBarRadius: 0 - }, - dataLabels: { - position: 'top', - // top, center, bottom - maxItems: 100, - hideOverflowingLabels: true, - orientation: 'horizontal', - total: { - enabled: false, - formatter: undefined, - offsetX: 0, - offsetY: 0, - style: { - color: '#373d3f', - fontSize: '12px', - fontFamily: undefined, - fontWeight: 600 - } - } - } - }, - bubble: { - zScaling: true, - minBubbleRadius: undefined, - maxBubbleRadius: undefined - }, - candlestick: { - colors: { - upward: '#00B746', - downward: '#EF403C' - }, - wick: { - useFillColor: true - } - }, - boxPlot: { - colors: { - upper: '#00E396', - lower: '#008FFB' - } - }, - heatmap: { - radius: 2, - enableShades: true, - shadeIntensity: 0.5, - reverseNegativeShade: false, - distributed: false, - useFillColorAsStroke: false, - colorScale: { - inverse: false, - ranges: [], - min: undefined, - max: undefined - } - }, - treemap: { - enableShades: true, - shadeIntensity: 0.5, - distributed: false, - reverseNegativeShade: false, - useFillColorAsStroke: false, - colorScale: { - inverse: false, - ranges: [], - min: undefined, - max: undefined - } - }, - radialBar: { - inverseOrder: false, - startAngle: 0, - endAngle: 360, - offsetX: 0, - offsetY: 0, - hollow: { - margin: 5, - size: '50%', - background: 'transparent', - image: undefined, - imageWidth: 150, - imageHeight: 150, - imageOffsetX: 0, - imageOffsetY: 0, - imageClipped: true, - position: 'front', - dropShadow: { - enabled: false, - top: 0, - left: 0, - blur: 3, - color: '#000', - opacity: 0.5 - } - }, - track: { - show: true, - startAngle: undefined, - endAngle: undefined, - background: '#f2f2f2', - strokeWidth: '97%', - opacity: 1, - margin: 5, - // margin is in pixels - dropShadow: { - enabled: false, - top: 0, - left: 0, - blur: 3, - color: '#000', - opacity: 0.5 - } - }, - dataLabels: { - show: true, - name: { - show: true, - fontSize: '16px', - fontFamily: undefined, - fontWeight: 600, - color: undefined, - offsetY: 0, - formatter: function formatter(val) { - return val; - } - }, - value: { - show: true, - fontSize: '14px', - fontFamily: undefined, - fontWeight: 400, - color: undefined, - offsetY: 16, - formatter: function formatter(val) { - return val + '%'; - } - }, - total: { - show: false, - label: 'Total', - fontSize: '16px', - fontWeight: 600, - fontFamily: undefined, - color: undefined, - formatter: function formatter(w) { - return w.globals.seriesTotals.reduce(function (a, b) { - return a + b; - }, 0) / w.globals.series.length + '%'; - } - } - } - }, - pie: { - customScale: 1, - offsetX: 0, - offsetY: 0, - startAngle: 0, - endAngle: 360, - expandOnClick: true, - dataLabels: { - // These are the percentage values which are displayed on slice - offset: 0, - // offset by which labels will move outside - minAngleToShowLabel: 10 - }, - donut: { - size: '65%', - background: 'transparent', - labels: { - // These are the inner labels appearing inside donut - show: false, - name: { - show: true, - fontSize: '16px', - fontFamily: undefined, - fontWeight: 600, - color: undefined, - offsetY: -10, - formatter: function formatter(val) { - return val; - } - }, - value: { - show: true, - fontSize: '20px', - fontFamily: undefined, - fontWeight: 400, - color: undefined, - offsetY: 10, - formatter: function formatter(val) { - return val; - } - }, - total: { - show: false, - showAlways: false, - label: 'Total', - fontSize: '16px', - fontWeight: 400, - fontFamily: undefined, - color: undefined, - formatter: function formatter(w) { - return w.globals.seriesTotals.reduce(function (a, b) { - return a + b; - }, 0); - } - } - } - } - }, - polarArea: { - rings: { - strokeWidth: 1, - strokeColor: '#e8e8e8' - }, - spokes: { - strokeWidth: 1, - connectorColors: '#e8e8e8' - } - }, - radar: { - size: undefined, - offsetX: 0, - offsetY: 0, - polygons: { - // strokeColor: '#e8e8e8', // should be deprecated in the minor version i.e 3.2 - strokeWidth: 1, - strokeColors: '#e8e8e8', - connectorColors: '#e8e8e8', - fill: { - colors: undefined - } - } - } - }, - colors: undefined, - dataLabels: { - enabled: true, - enabledOnSeries: undefined, - formatter: function formatter(val) { - return val !== null ? val : ''; - }, - textAnchor: 'middle', - distributed: false, - offsetX: 0, - offsetY: 0, - style: { - fontSize: '12px', - fontFamily: undefined, - fontWeight: 600, - colors: undefined - }, - background: { - enabled: true, - foreColor: '#fff', - borderRadius: 2, - padding: 4, - opacity: 0.9, - borderWidth: 1, - borderColor: '#fff', - dropShadow: { - enabled: false, - top: 1, - left: 1, - blur: 1, - color: '#000', - opacity: 0.45 - } - }, - dropShadow: { - enabled: false, - top: 1, - left: 1, - blur: 1, - color: '#000', - opacity: 0.45 - } - }, - fill: { - type: 'solid', - colors: undefined, - // array of colors - opacity: 0.85, - gradient: { - shade: 'dark', - type: 'horizontal', - shadeIntensity: 0.5, - gradientToColors: undefined, - inverseColors: true, - opacityFrom: 1, - opacityTo: 1, - stops: [0, 50, 100], - colorStops: [] - }, - image: { - src: [], - width: undefined, - // optional - height: undefined // optional - - }, - pattern: { - style: 'squares', - // String | Array of Strings - width: 6, - height: 6, - strokeWidth: 2 - } - }, - forecastDataPoints: { - count: 0, - fillOpacity: 0.5, - strokeWidth: undefined, - dashArray: 4 - }, - grid: { - show: true, - borderColor: '#e0e0e0', - strokeDashArray: 0, - position: 'back', - xaxis: { - lines: { - show: false - } - }, - yaxis: { - lines: { - show: true - } - }, - row: { - colors: undefined, - // takes as array which will be repeated on rows - opacity: 0.5 - }, - column: { - colors: undefined, - // takes an array which will be repeated on columns - opacity: 0.5 - }, - padding: { - top: 0, - right: 10, - bottom: 0, - left: 12 - } - }, - labels: [], - legend: { - show: true, - showForSingleSeries: false, - showForNullSeries: true, - showForZeroSeries: true, - floating: false, - position: 'bottom', - // whether to position legends in 1 of 4 - // direction - top, bottom, left, right - horizontalAlign: 'center', - // when position top/bottom, you can specify whether to align legends left, right or center - inverseOrder: false, - fontSize: '12px', - fontFamily: undefined, - fontWeight: 400, - width: undefined, - height: undefined, - formatter: undefined, - tooltipHoverFormatter: undefined, - offsetX: -20, - offsetY: 4, - customLegendItems: [], - labels: { - colors: undefined, - useSeriesColors: false - }, - markers: { - width: 12, - height: 12, - strokeWidth: 0, - fillColors: undefined, - strokeColor: '#fff', - radius: 12, - customHTML: undefined, - offsetX: 0, - offsetY: 0, - onClick: undefined - }, - itemMargin: { - horizontal: 5, - vertical: 2 - }, - onItemClick: { - toggleDataSeries: true - }, - onItemHover: { - highlightDataSeries: true - } - }, - markers: { - discrete: [], - size: 0, - colors: undefined, - //strokeColor: '#fff', // TODO: deprecate in major version 4.0 - strokeColors: '#fff', - strokeWidth: 2, - strokeOpacity: 0.9, - strokeDashArray: 0, - fillOpacity: 1, - shape: 'circle', - width: 8, - // only applicable when shape is rect/square - height: 8, - // only applicable when shape is rect/square - radius: 2, - offsetX: 0, - offsetY: 0, - onClick: undefined, - onDblClick: undefined, - showNullDataPoints: true, - hover: { - size: undefined, - sizeOffset: 3 - } - }, - noData: { - text: undefined, - align: 'center', - verticalAlign: 'middle', - offsetX: 0, - offsetY: 0, - style: { - color: undefined, - fontSize: '14px', - fontFamily: undefined - } - }, - responsive: [], - // breakpoints should follow ascending order 400, then 700, then 1000 - series: undefined, - states: { - normal: { - filter: { - type: 'none', - value: 0 - } - }, - hover: { - filter: { - type: 'lighten', - value: 0.1 - } - }, - active: { - allowMultipleDataPointsSelection: false, - filter: { - type: 'darken', - value: 0.5 - } - } - }, - title: { - text: undefined, - align: 'left', - margin: 5, - offsetX: 0, - offsetY: 0, - floating: false, - style: { - fontSize: '14px', - fontWeight: 900, - fontFamily: undefined, - color: undefined - } - }, - subtitle: { - text: undefined, - align: 'left', - margin: 5, - offsetX: 0, - offsetY: 30, - floating: false, - style: { - fontSize: '12px', - fontWeight: 400, - fontFamily: undefined, - color: undefined - } - }, - stroke: { - show: true, - curve: 'smooth', - // "smooth" / "straight" / "stepline" - lineCap: 'butt', - // round, butt , square - width: 2, - colors: undefined, - // array of colors - dashArray: 0, - // single value or array of values - fill: { - type: 'solid', - colors: undefined, - // array of colors - opacity: 0.85, - gradient: { - shade: 'dark', - type: 'horizontal', - shadeIntensity: 0.5, - gradientToColors: undefined, - inverseColors: true, - opacityFrom: 1, - opacityTo: 1, - stops: [0, 50, 100], - colorStops: [] - } - } - }, - tooltip: { - enabled: true, - enabledOnSeries: undefined, - shared: true, - followCursor: false, - // when disabled, the tooltip will show on top of the series instead of mouse position - intersect: false, - // when enabled, tooltip will only show when user directly hovers over point - inverseOrder: false, - custom: undefined, - fillSeriesColor: false, - theme: 'light', - cssClass: '', - style: { - fontSize: '12px', - fontFamily: undefined - }, - onDatasetHover: { - highlightDataSeries: false - }, - x: { - // x value - show: true, - format: 'dd MMM', - // dd/MM, dd MMM yy, dd MMM yyyy - formatter: undefined // a custom user supplied formatter function - - }, - y: { - formatter: undefined, - title: { - formatter: function formatter(seriesName) { - return seriesName ? seriesName + ': ' : ''; - } - } - }, - z: { - formatter: undefined, - title: 'Size: ' - }, - marker: { - show: true, - fillColors: undefined - }, - items: { - display: 'flex' - }, - fixed: { - enabled: false, - position: 'topRight', - // topRight, topLeft, bottomRight, bottomLeft - offsetX: 0, - offsetY: 0 - } - }, - xaxis: { - type: 'category', - categories: [], - convertedCatToNumeric: false, - // internal property which should not be altered outside - offsetX: 0, - offsetY: 0, - overwriteCategories: undefined, - labels: { - show: true, - rotate: -45, - rotateAlways: false, - hideOverlappingLabels: true, - trim: false, - minHeight: undefined, - maxHeight: 120, - showDuplicates: true, - style: { - colors: [], - fontSize: '12px', - fontWeight: 400, - fontFamily: undefined, - cssClass: '' - }, - offsetX: 0, - offsetY: 0, - format: undefined, - formatter: undefined, - // custom formatter function which will override format - datetimeUTC: true, - datetimeFormatter: { - year: 'yyyy', - month: "MMM 'yy", - day: 'dd MMM', - hour: 'HH:mm', - minute: 'HH:mm:ss', - second: 'HH:mm:ss' - } - }, - group: { - groups: [], - style: { - colors: [], - fontSize: '12px', - fontWeight: 400, - fontFamily: undefined, - cssClass: '' - } - }, - axisBorder: { - show: true, - color: '#e0e0e0', - width: '100%', - height: 1, - offsetX: 0, - offsetY: 0 - }, - axisTicks: { - show: true, - color: '#e0e0e0', - height: 6, - offsetX: 0, - offsetY: 0 - }, - tickAmount: undefined, - tickPlacement: 'on', - min: undefined, - max: undefined, - range: undefined, - floating: false, - decimalsInFloat: undefined, - position: 'bottom', - title: { - text: undefined, - offsetX: 0, - offsetY: 0, - style: { - color: undefined, - fontSize: '12px', - fontWeight: 900, - fontFamily: undefined, - cssClass: '' - } - }, - crosshairs: { - show: true, - width: 1, - // tickWidth/barWidth or an integer - position: 'back', - opacity: 0.9, - stroke: { - color: '#b6b6b6', - width: 1, - dashArray: 3 - }, - fill: { - type: 'solid', - // solid, gradient - color: '#B1B9C4', - gradient: { - colorFrom: '#D8E3F0', - colorTo: '#BED1E6', - stops: [0, 100], - opacityFrom: 0.4, - opacityTo: 0.5 - } - }, - dropShadow: { - enabled: false, - left: 0, - top: 0, - blur: 1, - opacity: 0.4 - } - }, - tooltip: { - enabled: true, - offsetY: 0, - formatter: undefined, - style: { - fontSize: '12px', - fontFamily: undefined - } - } - }, - yaxis: this.yAxis, - theme: { - mode: 'light', - palette: 'palette1', - // If defined, it will overwrite globals.colors variable - monochrome: { - // monochrome allows you to select just 1 color and fill out the rest with light/dark shade (intensity can be selected) - enabled: false, - color: '#008FFB', - shadeTo: 'light', - shadeIntensity: 0.65 - } - } - }; - } - }]); - - return Options; - }(); - - /** - * ApexCharts Annotations Class for drawing lines/rects on both xaxis and yaxis. - * - * @module Annotations - **/ - - var Annotations = /*#__PURE__*/function () { - function Annotations(ctx) { - _classCallCheck(this, Annotations); - - this.ctx = ctx; - this.w = ctx.w; - this.graphics = new Graphics(this.ctx); - - if (this.w.globals.isBarHorizontal) { - this.invertAxis = true; - } - - this.helpers = new Helpers$4(this); - this.xAxisAnnotations = new XAnnotations(this); - this.yAxisAnnotations = new YAnnotations(this); - this.pointsAnnotations = new PointAnnotations(this); - - if (this.w.globals.isBarHorizontal && this.w.config.yaxis[0].reversed) { - this.inversedReversedAxis = true; - } - - this.xDivision = this.w.globals.gridWidth / this.w.globals.dataPoints; - } - - _createClass(Annotations, [{ - key: "drawAxesAnnotations", - value: function drawAxesAnnotations() { - var w = this.w; - - if (w.globals.axisCharts) { - var yAnnotations = this.yAxisAnnotations.drawYAxisAnnotations(); - var xAnnotations = this.xAxisAnnotations.drawXAxisAnnotations(); - var pointAnnotations = this.pointsAnnotations.drawPointAnnotations(); - var initialAnim = w.config.chart.animations.enabled; - var annoArray = [yAnnotations, xAnnotations, pointAnnotations]; - var annoElArray = [xAnnotations.node, yAnnotations.node, pointAnnotations.node]; - - for (var i = 0; i < 3; i++) { - w.globals.dom.elGraphical.add(annoArray[i]); - - if (initialAnim && !w.globals.resized && !w.globals.dataChanged) { - // fixes apexcharts/apexcharts.js#685 - if (w.config.chart.type !== 'scatter' && w.config.chart.type !== 'bubble' && w.globals.dataPoints > 1) { - annoElArray[i].classList.add('apexcharts-element-hidden'); - } - } - - w.globals.delayedElements.push({ - el: annoElArray[i], - index: 0 - }); - } // background sizes needs to be calculated after text is drawn, so calling them last - - - this.helpers.annotationsBackground(); - } - } - }, { - key: "drawImageAnnos", - value: function drawImageAnnos() { - var _this = this; - - var w = this.w; - w.config.annotations.images.map(function (s, index) { - _this.addImage(s, index); - }); - } - }, { - key: "drawTextAnnos", - value: function drawTextAnnos() { - var _this2 = this; - - var w = this.w; - w.config.annotations.texts.map(function (t, index) { - _this2.addText(t, index); - }); - } - }, { - key: "addXaxisAnnotation", - value: function addXaxisAnnotation(anno, parent, index) { - this.xAxisAnnotations.addXaxisAnnotation(anno, parent, index); - } - }, { - key: "addYaxisAnnotation", - value: function addYaxisAnnotation(anno, parent, index) { - this.yAxisAnnotations.addYaxisAnnotation(anno, parent, index); - } - }, { - key: "addPointAnnotation", - value: function addPointAnnotation(anno, parent, index) { - this.pointsAnnotations.addPointAnnotation(anno, parent, index); - } - }, { - key: "addText", - value: function addText(params, index) { - var x = params.x, - y = params.y, - text = params.text, - textAnchor = params.textAnchor, - foreColor = params.foreColor, - fontSize = params.fontSize, - fontFamily = params.fontFamily, - fontWeight = params.fontWeight, - cssClass = params.cssClass, - backgroundColor = params.backgroundColor, - borderWidth = params.borderWidth, - strokeDashArray = params.strokeDashArray, - borderRadius = params.borderRadius, - borderColor = params.borderColor, - _params$appendTo = params.appendTo, - appendTo = _params$appendTo === void 0 ? '.apexcharts-annotations' : _params$appendTo, - _params$paddingLeft = params.paddingLeft, - paddingLeft = _params$paddingLeft === void 0 ? 4 : _params$paddingLeft, - _params$paddingRight = params.paddingRight, - paddingRight = _params$paddingRight === void 0 ? 4 : _params$paddingRight, - _params$paddingBottom = params.paddingBottom, - paddingBottom = _params$paddingBottom === void 0 ? 2 : _params$paddingBottom, - _params$paddingTop = params.paddingTop, - paddingTop = _params$paddingTop === void 0 ? 2 : _params$paddingTop; - var w = this.w; - var elText = this.graphics.drawText({ - x: x, - y: y, - text: text, - textAnchor: textAnchor || 'start', - fontSize: fontSize || '12px', - fontWeight: fontWeight || 'regular', - fontFamily: fontFamily || w.config.chart.fontFamily, - foreColor: foreColor || w.config.chart.foreColor, - cssClass: 'apexcharts-text ' + cssClass ? cssClass : '' - }); - var parent = w.globals.dom.baseEl.querySelector(appendTo); - - if (parent) { - parent.appendChild(elText.node); - } - - var textRect = elText.bbox(); - - if (text) { - var elRect = this.graphics.drawRect(textRect.x - paddingLeft, textRect.y - paddingTop, textRect.width + paddingLeft + paddingRight, textRect.height + paddingBottom + paddingTop, borderRadius, backgroundColor ? backgroundColor : 'transparent', 1, borderWidth, borderColor, strokeDashArray); - parent.insertBefore(elRect.node, elText.node); - } - } - }, { - key: "addImage", - value: function addImage(params, index) { - var w = this.w; - var path = params.path, - _params$x = params.x, - x = _params$x === void 0 ? 0 : _params$x, - _params$y = params.y, - y = _params$y === void 0 ? 0 : _params$y, - _params$width = params.width, - width = _params$width === void 0 ? 20 : _params$width, - _params$height = params.height, - height = _params$height === void 0 ? 20 : _params$height, - _params$appendTo2 = params.appendTo, - appendTo = _params$appendTo2 === void 0 ? '.apexcharts-annotations' : _params$appendTo2; - var img = w.globals.dom.Paper.image(path); - img.size(width, height).move(x, y); - var parent = w.globals.dom.baseEl.querySelector(appendTo); - - if (parent) { - parent.appendChild(img.node); - } - - return img; - } // The addXaxisAnnotation method requires a parent class, and user calling this method externally on the chart instance may not specify parent, hence a different method - - }, { - key: "addXaxisAnnotationExternal", - value: function addXaxisAnnotationExternal(params, pushToMemory, context) { - this.addAnnotationExternal({ - params: params, - pushToMemory: pushToMemory, - context: context, - type: 'xaxis', - contextMethod: context.addXaxisAnnotation - }); - return context; - } - }, { - key: "addYaxisAnnotationExternal", - value: function addYaxisAnnotationExternal(params, pushToMemory, context) { - this.addAnnotationExternal({ - params: params, - pushToMemory: pushToMemory, - context: context, - type: 'yaxis', - contextMethod: context.addYaxisAnnotation - }); - return context; - } - }, { - key: "addPointAnnotationExternal", - value: function addPointAnnotationExternal(params, pushToMemory, context) { - if (typeof this.invertAxis === 'undefined') { - this.invertAxis = context.w.globals.isBarHorizontal; - } - - this.addAnnotationExternal({ - params: params, - pushToMemory: pushToMemory, - context: context, - type: 'point', - contextMethod: context.addPointAnnotation - }); - return context; - } - }, { - key: "addAnnotationExternal", - value: function addAnnotationExternal(_ref) { - var params = _ref.params, - pushToMemory = _ref.pushToMemory, - context = _ref.context, - type = _ref.type, - contextMethod = _ref.contextMethod; - var me = context; - var w = me.w; - var parent = w.globals.dom.baseEl.querySelector(".apexcharts-".concat(type, "-annotations")); - var index = parent.childNodes.length + 1; - var options = new Options(); - var axesAnno = Object.assign({}, type === 'xaxis' ? options.xAxisAnnotation : type === 'yaxis' ? options.yAxisAnnotation : options.pointAnnotation); - var anno = Utils$1.extend(axesAnno, params); - - switch (type) { - case 'xaxis': - this.addXaxisAnnotation(anno, parent, index); - break; - - case 'yaxis': - this.addYaxisAnnotation(anno, parent, index); - break; - - case 'point': - this.addPointAnnotation(anno, parent, index); - break; - } // add background - - - var axesAnnoLabel = w.globals.dom.baseEl.querySelector(".apexcharts-".concat(type, "-annotations .apexcharts-").concat(type, "-annotation-label[rel='").concat(index, "']")); - var elRect = this.helpers.addBackgroundToAnno(axesAnnoLabel, anno); - - if (elRect) { - parent.insertBefore(elRect.node, axesAnnoLabel); - } - - if (pushToMemory) { - w.globals.memory.methodsToExec.push({ - context: me, - id: anno.id ? anno.id : Utils$1.randomId(), - method: contextMethod, - label: 'addAnnotation', - params: params - }); - } - - return context; - } - }, { - key: "clearAnnotations", - value: function clearAnnotations(ctx) { - var w = ctx.w; - var annos = w.globals.dom.baseEl.querySelectorAll('.apexcharts-yaxis-annotations, .apexcharts-xaxis-annotations, .apexcharts-point-annotations'); // annotations added externally should be cleared out too - - w.globals.memory.methodsToExec.map(function (m, i) { - if (m.label === 'addText' || m.label === 'addAnnotation') { - w.globals.memory.methodsToExec.splice(i, 1); - } - }); - annos = Utils$1.listToArray(annos); // delete the DOM elements - - Array.prototype.forEach.call(annos, function (a) { - while (a.firstChild) { - a.removeChild(a.firstChild); - } - }); - } - }, { - key: "removeAnnotation", - value: function removeAnnotation(ctx, id) { - var w = ctx.w; - var annos = w.globals.dom.baseEl.querySelectorAll(".".concat(id)); - - if (annos) { - w.globals.memory.methodsToExec.map(function (m, i) { - if (m.id === id) { - w.globals.memory.methodsToExec.splice(i, 1); - } - }); - Array.prototype.forEach.call(annos, function (a) { - a.parentElement.removeChild(a); - }); - } - } - }]); - - return Annotations; - }(); - - /** - * DateTime Class to manipulate datetime values. - * - * @module DateTime - **/ - - var DateTime = /*#__PURE__*/function () { - function DateTime(ctx) { - _classCallCheck(this, DateTime); - - this.ctx = ctx; - this.w = ctx.w; - this.months31 = [1, 3, 5, 7, 8, 10, 12]; - this.months30 = [2, 4, 6, 9, 11]; - this.daysCntOfYear = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334]; - } - - _createClass(DateTime, [{ - key: "isValidDate", - value: function isValidDate(date) { - return !isNaN(this.parseDate(date)); - } - }, { - key: "getTimeStamp", - value: function getTimeStamp(dateStr) { - if (!Date.parse(dateStr)) { - return dateStr; - } - - var utc = this.w.config.xaxis.labels.datetimeUTC; - return !utc ? new Date(dateStr).getTime() : new Date(new Date(dateStr).toISOString().substr(0, 25)).getTime(); - } - }, { - key: "getDate", - value: function getDate(timestamp) { - var utc = this.w.config.xaxis.labels.datetimeUTC; - return utc ? new Date(new Date(timestamp).toUTCString()) : new Date(timestamp); - } - }, { - key: "parseDate", - value: function parseDate(dateStr) { - var parsed = Date.parse(dateStr); - - if (!isNaN(parsed)) { - return this.getTimeStamp(dateStr); - } - - var output = Date.parse(dateStr.replace(/-/g, '/').replace(/[a-z]+/gi, ' ')); - output = this.getTimeStamp(output); - return output; - } // This fixes the difference of x-axis labels between chrome/safari - // Fixes #1726, #1544, #1485, #1255 - - }, { - key: "parseDateWithTimezone", - value: function parseDateWithTimezone(dateStr) { - return Date.parse(dateStr.replace(/-/g, '/').replace(/[a-z]+/gi, ' ')); - } // http://stackoverflow.com/questions/14638018/current-time-formatting-with-javascript#answer-14638191 - - }, { - key: "formatDate", - value: function formatDate(date, format) { - var locale = this.w.globals.locale; - var utc = this.w.config.xaxis.labels.datetimeUTC; - var MMMM = ['\x00'].concat(_toConsumableArray(locale.months)); - var MMM = ['\x01'].concat(_toConsumableArray(locale.shortMonths)); - var dddd = ['\x02'].concat(_toConsumableArray(locale.days)); - var ddd = ['\x03'].concat(_toConsumableArray(locale.shortDays)); - - function ii(i, len) { - var s = i + ''; - len = len || 2; - - while (s.length < len) { - s = '0' + s; - } - - return s; - } - - var y = utc ? date.getUTCFullYear() : date.getFullYear(); - format = format.replace(/(^|[^\\])yyyy+/g, '$1' + y); - format = format.replace(/(^|[^\\])yy/g, '$1' + y.toString().substr(2, 2)); - format = format.replace(/(^|[^\\])y/g, '$1' + y); - var M = (utc ? date.getUTCMonth() : date.getMonth()) + 1; - format = format.replace(/(^|[^\\])MMMM+/g, '$1' + MMMM[0]); - format = format.replace(/(^|[^\\])MMM/g, '$1' + MMM[0]); - format = format.replace(/(^|[^\\])MM/g, '$1' + ii(M)); - format = format.replace(/(^|[^\\])M/g, '$1' + M); - var d = utc ? date.getUTCDate() : date.getDate(); - format = format.replace(/(^|[^\\])dddd+/g, '$1' + dddd[0]); - format = format.replace(/(^|[^\\])ddd/g, '$1' + ddd[0]); - format = format.replace(/(^|[^\\])dd/g, '$1' + ii(d)); - format = format.replace(/(^|[^\\])d/g, '$1' + d); - var H = utc ? date.getUTCHours() : date.getHours(); - format = format.replace(/(^|[^\\])HH+/g, '$1' + ii(H)); - format = format.replace(/(^|[^\\])H/g, '$1' + H); - var h = H > 12 ? H - 12 : H === 0 ? 12 : H; - format = format.replace(/(^|[^\\])hh+/g, '$1' + ii(h)); - format = format.replace(/(^|[^\\])h/g, '$1' + h); - var m = utc ? date.getUTCMinutes() : date.getMinutes(); - format = format.replace(/(^|[^\\])mm+/g, '$1' + ii(m)); - format = format.replace(/(^|[^\\])m/g, '$1' + m); - var s = utc ? date.getUTCSeconds() : date.getSeconds(); - format = format.replace(/(^|[^\\])ss+/g, '$1' + ii(s)); - format = format.replace(/(^|[^\\])s/g, '$1' + s); - var f = utc ? date.getUTCMilliseconds() : date.getMilliseconds(); - format = format.replace(/(^|[^\\])fff+/g, '$1' + ii(f, 3)); - f = Math.round(f / 10); - format = format.replace(/(^|[^\\])ff/g, '$1' + ii(f)); - f = Math.round(f / 10); - format = format.replace(/(^|[^\\])f/g, '$1' + f); - var T = H < 12 ? 'AM' : 'PM'; - format = format.replace(/(^|[^\\])TT+/g, '$1' + T); - format = format.replace(/(^|[^\\])T/g, '$1' + T.charAt(0)); - var t = T.toLowerCase(); - format = format.replace(/(^|[^\\])tt+/g, '$1' + t); - format = format.replace(/(^|[^\\])t/g, '$1' + t.charAt(0)); - var tz = -date.getTimezoneOffset(); - var K = utc || !tz ? 'Z' : tz > 0 ? '+' : '-'; - - if (!utc) { - tz = Math.abs(tz); - var tzHrs = Math.floor(tz / 60); - var tzMin = tz % 60; - K += ii(tzHrs) + ':' + ii(tzMin); - } - - format = format.replace(/(^|[^\\])K/g, '$1' + K); - var day = (utc ? date.getUTCDay() : date.getDay()) + 1; - format = format.replace(new RegExp(dddd[0], 'g'), dddd[day]); - format = format.replace(new RegExp(ddd[0], 'g'), ddd[day]); - format = format.replace(new RegExp(MMMM[0], 'g'), MMMM[M]); - format = format.replace(new RegExp(MMM[0], 'g'), MMM[M]); - format = format.replace(/\\(.)/g, '$1'); - return format; - } - }, { - key: "getTimeUnitsfromTimestamp", - value: function getTimeUnitsfromTimestamp(minX, maxX, utc) { - var w = this.w; - - if (w.config.xaxis.min !== undefined) { - minX = w.config.xaxis.min; - } - - if (w.config.xaxis.max !== undefined) { - maxX = w.config.xaxis.max; - } - - var tsMin = this.getDate(minX); - var tsMax = this.getDate(maxX); - var minD = this.formatDate(tsMin, 'yyyy MM dd HH mm ss fff').split(' '); - var maxD = this.formatDate(tsMax, 'yyyy MM dd HH mm ss fff').split(' '); - return { - minMillisecond: parseInt(minD[6], 10), - maxMillisecond: parseInt(maxD[6], 10), - minSecond: parseInt(minD[5], 10), - maxSecond: parseInt(maxD[5], 10), - minMinute: parseInt(minD[4], 10), - maxMinute: parseInt(maxD[4], 10), - minHour: parseInt(minD[3], 10), - maxHour: parseInt(maxD[3], 10), - minDate: parseInt(minD[2], 10), - maxDate: parseInt(maxD[2], 10), - minMonth: parseInt(minD[1], 10) - 1, - maxMonth: parseInt(maxD[1], 10) - 1, - minYear: parseInt(minD[0], 10), - maxYear: parseInt(maxD[0], 10) - }; - } - }, { - key: "isLeapYear", - value: function isLeapYear(year) { - return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0; - } - }, { - key: "calculcateLastDaysOfMonth", - value: function calculcateLastDaysOfMonth(month, year, subtract) { - var days = this.determineDaysOfMonths(month, year); // whatever days we get, subtract the number of days asked - - return days - subtract; - } - }, { - key: "determineDaysOfYear", - value: function determineDaysOfYear(year) { - var days = 365; - - if (this.isLeapYear(year)) { - days = 366; - } - - return days; - } - }, { - key: "determineRemainingDaysOfYear", - value: function determineRemainingDaysOfYear(year, month, date) { - var dayOfYear = this.daysCntOfYear[month] + date; - if (month > 1 && this.isLeapYear()) dayOfYear++; - return dayOfYear; - } - }, { - key: "determineDaysOfMonths", - value: function determineDaysOfMonths(month, year) { - var days = 30; - month = Utils$1.monthMod(month); - - switch (true) { - case this.months30.indexOf(month) > -1: - if (month === 2) { - if (this.isLeapYear(year)) { - days = 29; - } else { - days = 28; - } - } - - break; - - case this.months31.indexOf(month) > -1: - days = 31; - break; - - default: - days = 31; - break; - } - - return days; - } - }]); - - return DateTime; - }(); - - /** - * ApexCharts Formatter Class for setting value formatters for axes as well as tooltips. - * - * @module Formatters - **/ - - var Formatters = /*#__PURE__*/function () { - function Formatters(ctx) { - _classCallCheck(this, Formatters); - - this.ctx = ctx; - this.w = ctx.w; - this.tooltipKeyFormat = 'dd MMM'; - } - - _createClass(Formatters, [{ - key: "xLabelFormat", - value: function xLabelFormat(fn, val, timestamp, opts) { - var w = this.w; - - if (w.config.xaxis.type === 'datetime') { - if (w.config.xaxis.labels.formatter === undefined) { - // if user has not specified a custom formatter, use the default tooltip.x.format - if (w.config.tooltip.x.formatter === undefined) { - var datetimeObj = new DateTime(this.ctx); - return datetimeObj.formatDate(datetimeObj.getDate(val), w.config.tooltip.x.format); - } - } - } - - return fn(val, timestamp, opts); - } - }, { - key: "defaultGeneralFormatter", - value: function defaultGeneralFormatter(val) { - if (Array.isArray(val)) { - return val.map(function (v) { - return v; - }); - } else { - return val; - } - } - }, { - key: "defaultYFormatter", - value: function defaultYFormatter(v, yaxe, i) { - var w = this.w; - - if (Utils$1.isNumber(v)) { - if (w.globals.yValueDecimal !== 0) { - v = v.toFixed(yaxe.decimalsInFloat !== undefined ? yaxe.decimalsInFloat : w.globals.yValueDecimal); - } else if (w.globals.maxYArr[i] - w.globals.minYArr[i] < 5) { - v = v.toFixed(1); - } else { - v = v.toFixed(0); - } - } - - return v; - } - }, { - key: "setLabelFormatters", - value: function setLabelFormatters() { - var _this = this; - - var w = this.w; - - w.globals.xaxisTooltipFormatter = function (val) { - return _this.defaultGeneralFormatter(val); - }; - - w.globals.ttKeyFormatter = function (val) { - return _this.defaultGeneralFormatter(val); - }; - - w.globals.ttZFormatter = function (val) { - return val; - }; - - w.globals.legendFormatter = function (val) { - return _this.defaultGeneralFormatter(val); - }; // formatter function will always overwrite format property - - - if (w.config.xaxis.labels.formatter !== undefined) { - w.globals.xLabelFormatter = w.config.xaxis.labels.formatter; - } else { - w.globals.xLabelFormatter = function (val) { - if (Utils$1.isNumber(val)) { - if (!w.config.xaxis.convertedCatToNumeric && w.config.xaxis.type === 'numeric') { - if (Utils$1.isNumber(w.config.xaxis.decimalsInFloat)) { - return val.toFixed(w.config.xaxis.decimalsInFloat); - } else { - var diff = w.globals.maxX - w.globals.minX; - - if (diff > 0 && diff < 100) { - return val.toFixed(1); - } - - return val.toFixed(0); - } - } - - if (w.globals.isBarHorizontal) { - var range = w.globals.maxY - w.globals.minYArr; - - if (range < 4) { - return val.toFixed(1); - } - } - - return val.toFixed(0); - } - - return val; - }; - } - - if (typeof w.config.tooltip.x.formatter === 'function') { - w.globals.ttKeyFormatter = w.config.tooltip.x.formatter; - } else { - w.globals.ttKeyFormatter = w.globals.xLabelFormatter; - } - - if (typeof w.config.xaxis.tooltip.formatter === 'function') { - w.globals.xaxisTooltipFormatter = w.config.xaxis.tooltip.formatter; - } - - if (Array.isArray(w.config.tooltip.y)) { - w.globals.ttVal = w.config.tooltip.y; - } else { - if (w.config.tooltip.y.formatter !== undefined) { - w.globals.ttVal = w.config.tooltip.y; - } - } - - if (w.config.tooltip.z.formatter !== undefined) { - w.globals.ttZFormatter = w.config.tooltip.z.formatter; - } // legend formatter - if user wants to append any global values of series to legend text - - - if (w.config.legend.formatter !== undefined) { - w.globals.legendFormatter = w.config.legend.formatter; - } // formatter function will always overwrite format property - - - w.config.yaxis.forEach(function (yaxe, i) { - if (yaxe.labels.formatter !== undefined) { - w.globals.yLabelFormatters[i] = yaxe.labels.formatter; - } else { - w.globals.yLabelFormatters[i] = function (val) { - if (!w.globals.xyCharts) return val; - - if (Array.isArray(val)) { - return val.map(function (v) { - return _this.defaultYFormatter(v, yaxe, i); - }); - } else { - return _this.defaultYFormatter(val, yaxe, i); - } - }; - } - }); - return w.globals; - } - }, { - key: "heatmapLabelFormatters", - value: function heatmapLabelFormatters() { - var w = this.w; - - if (w.config.chart.type === 'heatmap') { - w.globals.yAxisScale[0].result = w.globals.seriesNames.slice(); // get the longest string from the labels array and also apply label formatter to it - - var longest = w.globals.seriesNames.reduce(function (a, b) { - return a.length > b.length ? a : b; - }, 0); - w.globals.yAxisScale[0].niceMax = longest; - w.globals.yAxisScale[0].niceMin = longest; - } - } - }]); - - return Formatters; - }(); - - /** - * ApexCharts Default Class for setting default options for all chart types. - * - * @module Defaults - **/ - - var getRangeValues = function getRangeValues(_ref) { - var _w$config$series$seri; - - var isTimeline = _ref.isTimeline, - ctx = _ref.ctx, - seriesIndex = _ref.seriesIndex, - dataPointIndex = _ref.dataPointIndex, - y1 = _ref.y1, - y2 = _ref.y2, - w = _ref.w; - var start = w.globals.seriesRangeStart[seriesIndex][dataPointIndex]; - var end = w.globals.seriesRangeEnd[seriesIndex][dataPointIndex]; - var ylabel = w.globals.labels[dataPointIndex]; - var seriesName = w.config.series[seriesIndex].name ? w.config.series[seriesIndex].name : ''; - var yLbFormatter = w.globals.ttKeyFormatter; - var yLbTitleFormatter = w.config.tooltip.y.title.formatter; - var opts = { - w: w, - seriesIndex: seriesIndex, - dataPointIndex: dataPointIndex, - start: start, - end: end - }; - - if (typeof yLbTitleFormatter === 'function') { - seriesName = yLbTitleFormatter(seriesName, opts); - } - - if ((_w$config$series$seri = w.config.series[seriesIndex].data[dataPointIndex]) !== null && _w$config$series$seri !== void 0 && _w$config$series$seri.x) { - ylabel = w.config.series[seriesIndex].data[dataPointIndex].x; - } - - if (!isTimeline) { - if (w.config.xaxis.type === 'datetime') { - var xFormat = new Formatters(ctx); - ylabel = xFormat.xLabelFormat(w.globals.ttKeyFormatter, ylabel, ylabel, { - i: undefined, - dateFormatter: new DateTime(ctx).formatDate, - w: w - }); - } - } - - if (typeof yLbFormatter === 'function') { - ylabel = yLbFormatter(ylabel, opts); - } - - if (Number.isFinite(y1) && Number.isFinite(y2)) { - start = y1; - end = y2; - } - - var startVal = ''; - var endVal = ''; - var color = w.globals.colors[seriesIndex]; - - if (w.config.tooltip.x.formatter === undefined) { - if (w.config.xaxis.type === 'datetime') { - var datetimeObj = new DateTime(ctx); - startVal = datetimeObj.formatDate(datetimeObj.getDate(start), w.config.tooltip.x.format); - endVal = datetimeObj.formatDate(datetimeObj.getDate(end), w.config.tooltip.x.format); - } else { - startVal = start; - endVal = end; - } - } else { - startVal = w.config.tooltip.x.formatter(start); - endVal = w.config.tooltip.x.formatter(end); - } - - return { - start: start, - end: end, - startVal: startVal, - endVal: endVal, - ylabel: ylabel, - color: color, - seriesName: seriesName - }; - }; - - var buildRangeTooltipHTML = function buildRangeTooltipHTML(opts) { - var color = opts.color, - seriesName = opts.seriesName, - ylabel = opts.ylabel, - start = opts.start, - end = opts.end, - seriesIndex = opts.seriesIndex, - dataPointIndex = opts.dataPointIndex; - var formatter = opts.ctx.tooltip.tooltipLabels.getFormatters(seriesIndex); - start = formatter.yLbFormatter(start); - end = formatter.yLbFormatter(end); - var val = formatter.yLbFormatter(opts.w.globals.series[seriesIndex][dataPointIndex]); - var valueHTML = ''; - var rangeValues = "\n ".concat(start, "\n - \n ").concat(end, "\n "); - - if (opts.w.globals.comboCharts) { - if (opts.w.config.series[seriesIndex].type === 'rangeArea' || opts.w.config.series[seriesIndex].type === 'rangeBar') { - valueHTML = rangeValues; - } else { - valueHTML = "".concat(val, ""); - } - } else { - valueHTML = rangeValues; - } - - return '
' + '
' + (seriesName ? seriesName : '') + '
' + '
' + ylabel + ': ' + valueHTML + '
' + '
'; - }; - - var Defaults = /*#__PURE__*/function () { - function Defaults(opts) { - _classCallCheck(this, Defaults); - - this.opts = opts; - } - - _createClass(Defaults, [{ - key: "line", - value: function line() { - return { - chart: { - animations: { - easing: 'swing' - } - }, - dataLabels: { - enabled: false - }, - stroke: { - width: 5, - curve: 'straight' - }, - markers: { - size: 0, - hover: { - sizeOffset: 6 - } - }, - xaxis: { - crosshairs: { - width: 1 - } - } - }; - } - }, { - key: "sparkline", - value: function sparkline(defaults) { - this.opts.yaxis[0].show = false; - this.opts.yaxis[0].title.text = ''; - this.opts.yaxis[0].axisBorder.show = false; - this.opts.yaxis[0].axisTicks.show = false; - this.opts.yaxis[0].floating = true; - var ret = { - grid: { - show: false, - padding: { - left: 0, - right: 0, - top: 0, - bottom: 0 - } - }, - legend: { - show: false - }, - xaxis: { - labels: { - show: false - }, - tooltip: { - enabled: false - }, - axisBorder: { - show: false - }, - axisTicks: { - show: false - } - }, - chart: { - toolbar: { - show: false - }, - zoom: { - enabled: false - } - }, - dataLabels: { - enabled: false - } - }; - return Utils$1.extend(defaults, ret); - } - }, { - key: "bar", - value: function bar() { - return { - chart: { - stacked: false, - animations: { - easing: 'swing' - } - }, - plotOptions: { - bar: { - dataLabels: { - position: 'center' - } - } - }, - dataLabels: { - style: { - colors: ['#fff'] - }, - background: { - enabled: false - } - }, - stroke: { - width: 0, - lineCap: 'round' - }, - fill: { - opacity: 0.85 - }, - legend: { - markers: { - shape: 'square', - radius: 2, - size: 8 - } - }, - tooltip: { - shared: false, - intersect: true - }, - xaxis: { - tooltip: { - enabled: false - }, - tickPlacement: 'between', - crosshairs: { - width: 'barWidth', - position: 'back', - fill: { - type: 'gradient' - }, - dropShadow: { - enabled: false - }, - stroke: { - width: 0 - } - } - } - }; - } - }, { - key: "candlestick", - value: function candlestick() { - var _this = this; - - return { - stroke: { - width: 1, - colors: ['#333'] - }, - fill: { - opacity: 1 - }, - dataLabels: { - enabled: false - }, - tooltip: { - shared: true, - custom: function custom(_ref2) { - var seriesIndex = _ref2.seriesIndex, - dataPointIndex = _ref2.dataPointIndex, - w = _ref2.w; - return _this._getBoxTooltip(w, seriesIndex, dataPointIndex, ['Open', 'High', '', 'Low', 'Close'], 'candlestick'); - } - }, - states: { - active: { - filter: { - type: 'none' - } - } - }, - xaxis: { - crosshairs: { - width: 1 - } - } - }; - } - }, { - key: "boxPlot", - value: function boxPlot() { - var _this2 = this; - - return { - chart: { - animations: { - dynamicAnimation: { - enabled: false - } - } - }, - stroke: { - width: 1, - colors: ['#24292e'] - }, - dataLabels: { - enabled: false - }, - tooltip: { - shared: true, - custom: function custom(_ref3) { - var seriesIndex = _ref3.seriesIndex, - dataPointIndex = _ref3.dataPointIndex, - w = _ref3.w; - return _this2._getBoxTooltip(w, seriesIndex, dataPointIndex, ['Minimum', 'Q1', 'Median', 'Q3', 'Maximum'], 'boxPlot'); - } - }, - markers: { - size: 5, - strokeWidth: 1, - strokeColors: '#111' - }, - xaxis: { - crosshairs: { - width: 1 - } - } - }; - } - }, { - key: "rangeBar", - value: function rangeBar() { - var handleTimelineTooltip = function handleTimelineTooltip(opts) { - var _getRangeValues = getRangeValues(_objectSpread2(_objectSpread2({}, opts), {}, { - isTimeline: true - })), - color = _getRangeValues.color, - seriesName = _getRangeValues.seriesName, - ylabel = _getRangeValues.ylabel, - startVal = _getRangeValues.startVal, - endVal = _getRangeValues.endVal; - - return buildRangeTooltipHTML(_objectSpread2(_objectSpread2({}, opts), {}, { - color: color, - seriesName: seriesName, - ylabel: ylabel, - start: startVal, - end: endVal - })); - }; - - var handleRangeColumnTooltip = function handleRangeColumnTooltip(opts) { - var _getRangeValues2 = getRangeValues(opts), - color = _getRangeValues2.color, - seriesName = _getRangeValues2.seriesName, - ylabel = _getRangeValues2.ylabel, - start = _getRangeValues2.start, - end = _getRangeValues2.end; - - return buildRangeTooltipHTML(_objectSpread2(_objectSpread2({}, opts), {}, { - color: color, - seriesName: seriesName, - ylabel: ylabel, - start: start, - end: end - })); - }; - - return { - chart: { - animations: { - animateGradually: false - } - }, - stroke: { - width: 0, - lineCap: 'square' - }, - plotOptions: { - bar: { - borderRadius: 0, - dataLabels: { - position: 'center' - } - } - }, - dataLabels: { - enabled: false, - formatter: function formatter(val, _ref4) { - _ref4.ctx; - var seriesIndex = _ref4.seriesIndex, - dataPointIndex = _ref4.dataPointIndex, - w = _ref4.w; - - var getVal = function getVal() { - var start = w.globals.seriesRangeStart[seriesIndex][dataPointIndex]; - var end = w.globals.seriesRangeEnd[seriesIndex][dataPointIndex]; - return end - start; - }; - - if (w.globals.comboCharts) { - if (w.config.series[seriesIndex].type === 'rangeBar' || w.config.series[seriesIndex].type === 'rangeArea') { - return getVal(); - } else { - return val; - } - } else { - return getVal(); - } - }, - background: { - enabled: false - }, - style: { - colors: ['#fff'] - } - }, - markers: { - size: 10 - }, - tooltip: { - shared: false, - followCursor: true, - custom: function custom(opts) { - if (opts.w.config.plotOptions && opts.w.config.plotOptions.bar && opts.w.config.plotOptions.bar.horizontal) { - return handleTimelineTooltip(opts); - } else { - return handleRangeColumnTooltip(opts); - } - } - }, - xaxis: { - tickPlacement: 'between', - tooltip: { - enabled: false - }, - crosshairs: { - stroke: { - width: 0 - } - } - } - }; - } - }, { - key: "dumbbell", - value: function dumbbell(opts) { - var _opts$plotOptions$bar, _opts$plotOptions$bar2; - - if (!((_opts$plotOptions$bar = opts.plotOptions.bar) !== null && _opts$plotOptions$bar !== void 0 && _opts$plotOptions$bar.barHeight)) { - opts.plotOptions.bar.barHeight = 2; - } - - if (!((_opts$plotOptions$bar2 = opts.plotOptions.bar) !== null && _opts$plotOptions$bar2 !== void 0 && _opts$plotOptions$bar2.columnWidth)) { - opts.plotOptions.bar.columnWidth = 2; - } - - return opts; - } - }, { - key: "area", - value: function area() { - return { - stroke: { - width: 4, - fill: { - type: 'solid', - gradient: { - inverseColors: false, - shade: 'light', - type: 'vertical', - opacityFrom: 0.65, - opacityTo: 0.5, - stops: [0, 100, 100] - } - } - }, - fill: { - type: 'gradient', - gradient: { - inverseColors: false, - shade: 'light', - type: 'vertical', - opacityFrom: 0.65, - opacityTo: 0.5, - stops: [0, 100, 100] - } - }, - markers: { - size: 0, - hover: { - sizeOffset: 6 - } - }, - tooltip: { - followCursor: false - } - }; - } - }, { - key: "rangeArea", - value: function rangeArea() { - var handleRangeAreaTooltip = function handleRangeAreaTooltip(opts) { - var _getRangeValues3 = getRangeValues(opts), - color = _getRangeValues3.color, - seriesName = _getRangeValues3.seriesName, - ylabel = _getRangeValues3.ylabel, - start = _getRangeValues3.start, - end = _getRangeValues3.end; - - return buildRangeTooltipHTML(_objectSpread2(_objectSpread2({}, opts), {}, { - color: color, - seriesName: seriesName, - ylabel: ylabel, - start: start, - end: end - })); - }; - - return { - stroke: { - curve: 'straight', - width: 0 - }, - fill: { - type: 'solid', - opacity: 0.6 - }, - markers: { - size: 0 - }, - states: { - hover: { - filter: { - type: 'none' - } - }, - active: { - filter: { - type: 'none' - } - } - }, - tooltip: { - intersect: false, - shared: true, - followCursor: true, - custom: function custom(opts) { - return handleRangeAreaTooltip(opts); - } - } - }; - } - }, { - key: "brush", - value: function brush(defaults) { - var ret = { - chart: { - toolbar: { - autoSelected: 'selection', - show: false - }, - zoom: { - enabled: false - } - }, - dataLabels: { - enabled: false - }, - stroke: { - width: 1 - }, - tooltip: { - enabled: false - }, - xaxis: { - tooltip: { - enabled: false - } - } - }; - return Utils$1.extend(defaults, ret); - } - }, { - key: "stacked100", - value: function stacked100(opts) { - opts.dataLabels = opts.dataLabels || {}; - opts.dataLabels.formatter = opts.dataLabels.formatter || undefined; - var existingDataLabelFormatter = opts.dataLabels.formatter; - opts.yaxis.forEach(function (yaxe, index) { - opts.yaxis[index].min = 0; - opts.yaxis[index].max = 100; - }); - var isBar = opts.chart.type === 'bar'; - - if (isBar) { - opts.dataLabels.formatter = existingDataLabelFormatter || function (val) { - if (typeof val === 'number') { - return val ? val.toFixed(0) + '%' : val; - } - - return val; - }; - } - - return opts; - } - }, { - key: "stackedBars", - value: function stackedBars() { - var barDefaults = this.bar(); - return _objectSpread2(_objectSpread2({}, barDefaults), {}, { - plotOptions: _objectSpread2(_objectSpread2({}, barDefaults.plotOptions), {}, { - bar: _objectSpread2(_objectSpread2({}, barDefaults.plotOptions.bar), {}, { - borderRadiusApplication: 'end', - borderRadiusWhenStacked: 'last' - }) - }) - }); - } // This function removes the left and right spacing in chart for line/area/scatter if xaxis type = category for those charts by converting xaxis = numeric. Numeric/Datetime xaxis prevents the unnecessary spacing in the left/right of the chart area - - }, { - key: "convertCatToNumeric", - value: function convertCatToNumeric(opts) { - opts.xaxis.convertedCatToNumeric = true; - return opts; - } - }, { - key: "convertCatToNumericXaxis", - value: function convertCatToNumericXaxis(opts, ctx, cats) { - opts.xaxis.type = 'numeric'; - opts.xaxis.labels = opts.xaxis.labels || {}; - - opts.xaxis.labels.formatter = opts.xaxis.labels.formatter || function (val) { - return Utils$1.isNumber(val) ? Math.floor(val) : val; - }; - - var defaultFormatter = opts.xaxis.labels.formatter; - var labels = opts.xaxis.categories && opts.xaxis.categories.length ? opts.xaxis.categories : opts.labels; - - if (cats && cats.length) { - labels = cats.map(function (c) { - return Array.isArray(c) ? c : String(c); - }); - } - - if (labels && labels.length) { - opts.xaxis.labels.formatter = function (val) { - return Utils$1.isNumber(val) ? defaultFormatter(labels[Math.floor(val) - 1]) : defaultFormatter(val); - }; - } - - opts.xaxis.categories = []; - opts.labels = []; - opts.xaxis.tickAmount = opts.xaxis.tickAmount || 'dataPoints'; - return opts; - } - }, { - key: "bubble", - value: function bubble() { - return { - dataLabels: { - style: { - colors: ['#fff'] - } - }, - tooltip: { - shared: false, - intersect: true - }, - xaxis: { - crosshairs: { - width: 0 - } - }, - fill: { - type: 'solid', - gradient: { - shade: 'light', - inverse: true, - shadeIntensity: 0.55, - opacityFrom: 0.4, - opacityTo: 0.8 - } - } - }; - } - }, { - key: "scatter", - value: function scatter() { - return { - dataLabels: { - enabled: false - }, - tooltip: { - shared: false, - intersect: true - }, - markers: { - size: 6, - strokeWidth: 1, - hover: { - sizeOffset: 2 - } - } - }; - } - }, { - key: "heatmap", - value: function heatmap() { - return { - chart: { - stacked: false - }, - fill: { - opacity: 1 - }, - dataLabels: { - style: { - colors: ['#fff'] - } - }, - stroke: { - colors: ['#fff'] - }, - tooltip: { - followCursor: true, - marker: { - show: false - }, - x: { - show: false - } - }, - legend: { - position: 'top', - markers: { - shape: 'square', - size: 10, - offsetY: 2 - } - }, - grid: { - padding: { - right: 20 - } - } - }; - } - }, { - key: "treemap", - value: function treemap() { - return { - chart: { - zoom: { - enabled: false - } - }, - dataLabels: { - style: { - fontSize: 14, - fontWeight: 600, - colors: ['#fff'] - } - }, - stroke: { - show: true, - width: 2, - colors: ['#fff'] - }, - legend: { - show: false - }, - fill: { - gradient: { - stops: [0, 100] - } - }, - tooltip: { - followCursor: true, - x: { - show: false - } - }, - grid: { - padding: { - left: 0, - right: 0 - } - }, - xaxis: { - crosshairs: { - show: false - }, - tooltip: { - enabled: false - } - } - }; - } - }, { - key: "pie", - value: function pie() { - return { - chart: { - toolbar: { - show: false - } - }, - plotOptions: { - pie: { - donut: { - labels: { - show: false - } - } - } - }, - dataLabels: { - formatter: function formatter(val) { - return val.toFixed(1) + '%'; - }, - style: { - colors: ['#fff'] - }, - background: { - enabled: false - }, - dropShadow: { - enabled: true - } - }, - stroke: { - colors: ['#fff'] - }, - fill: { - opacity: 1, - gradient: { - shade: 'light', - stops: [0, 100] - } - }, - tooltip: { - theme: 'dark', - fillSeriesColor: true - }, - legend: { - position: 'right' - } - }; - } - }, { - key: "donut", - value: function donut() { - return { - chart: { - toolbar: { - show: false - } - }, - dataLabels: { - formatter: function formatter(val) { - return val.toFixed(1) + '%'; - }, - style: { - colors: ['#fff'] - }, - background: { - enabled: false - }, - dropShadow: { - enabled: true - } - }, - stroke: { - colors: ['#fff'] - }, - fill: { - opacity: 1, - gradient: { - shade: 'light', - shadeIntensity: 0.35, - stops: [80, 100], - opacityFrom: 1, - opacityTo: 1 - } - }, - tooltip: { - theme: 'dark', - fillSeriesColor: true - }, - legend: { - position: 'right' - } - }; - } - }, { - key: "polarArea", - value: function polarArea() { - this.opts.yaxis[0].tickAmount = this.opts.yaxis[0].tickAmount ? this.opts.yaxis[0].tickAmount : 6; - return { - chart: { - toolbar: { - show: false - } - }, - dataLabels: { - formatter: function formatter(val) { - return val.toFixed(1) + '%'; - }, - enabled: false - }, - stroke: { - show: true, - width: 2 - }, - fill: { - opacity: 0.7 - }, - tooltip: { - theme: 'dark', - fillSeriesColor: true - }, - legend: { - position: 'right' - } - }; - } - }, { - key: "radar", - value: function radar() { - this.opts.yaxis[0].labels.offsetY = this.opts.yaxis[0].labels.offsetY ? this.opts.yaxis[0].labels.offsetY : 6; - return { - dataLabels: { - enabled: false, - style: { - fontSize: '11px' - } - }, - stroke: { - width: 2 - }, - markers: { - size: 3, - strokeWidth: 1, - strokeOpacity: 1 - }, - fill: { - opacity: 0.2 - }, - tooltip: { - shared: false, - intersect: true, - followCursor: true - }, - grid: { - show: false - }, - xaxis: { - labels: { - formatter: function formatter(val) { - return val; - }, - style: { - colors: ['#a8a8a8'], - fontSize: '11px' - } - }, - tooltip: { - enabled: false - }, - crosshairs: { - show: false - } - } - }; - } - }, { - key: "radialBar", - value: function radialBar() { - return { - chart: { - animations: { - dynamicAnimation: { - enabled: true, - speed: 800 - } - }, - toolbar: { - show: false - } - }, - fill: { - gradient: { - shade: 'dark', - shadeIntensity: 0.4, - inverseColors: false, - type: 'diagonal2', - opacityFrom: 1, - opacityTo: 1, - stops: [70, 98, 100] - } - }, - legend: { - show: false, - position: 'right' - }, - tooltip: { - enabled: false, - fillSeriesColor: true - } - }; - } - }, { - key: "_getBoxTooltip", - value: function _getBoxTooltip(w, seriesIndex, dataPointIndex, labels, chartType) { - var o = w.globals.seriesCandleO[seriesIndex][dataPointIndex]; - var h = w.globals.seriesCandleH[seriesIndex][dataPointIndex]; - var m = w.globals.seriesCandleM[seriesIndex][dataPointIndex]; - var l = w.globals.seriesCandleL[seriesIndex][dataPointIndex]; - var c = w.globals.seriesCandleC[seriesIndex][dataPointIndex]; - - if (w.config.series[seriesIndex].type && w.config.series[seriesIndex].type !== chartType) { - return "
\n ".concat(w.config.series[seriesIndex].name ? w.config.series[seriesIndex].name : 'series-' + (seriesIndex + 1), ": ").concat(w.globals.series[seriesIndex][dataPointIndex], "\n
"); - } else { - return "
") + "
".concat(labels[0], ": ") + o + '
' + "
".concat(labels[1], ": ") + h + '
' + (m ? "
".concat(labels[2], ": ") + m + '
' : '') + "
".concat(labels[3], ": ") + l + '
' + "
".concat(labels[4], ": ") + c + '
' + '
'; - } - } - }]); - - return Defaults; - }(); - - /** - * ApexCharts Config Class for extending user options with pre-defined ApexCharts config. - * - * @module Config - **/ - - var Config = /*#__PURE__*/function () { - function Config(opts) { - _classCallCheck(this, Config); - - this.opts = opts; - } - - _createClass(Config, [{ - key: "init", - value: function init(_ref) { - var responsiveOverride = _ref.responsiveOverride; - var opts = this.opts; - var options = new Options(); - var defaults = new Defaults(opts); - this.chartType = opts.chart.type; - opts = this.extendYAxis(opts); - opts = this.extendAnnotations(opts); - var config = options.init(); - var newDefaults = {}; - - if (opts && _typeof(opts) === 'object') { - var _opts$chart$brush, _opts$plotOptions, _opts$plotOptions$bar, _opts$chart$sparkline, _window$Apex$chart, _window$Apex$chart$sp; - - var chartDefaults = {}; - var chartTypes = ['line', 'area', 'bar', 'candlestick', 'boxPlot', 'rangeBar', 'rangeArea', 'bubble', 'scatter', 'heatmap', 'treemap', 'pie', 'polarArea', 'donut', 'radar', 'radialBar']; - - if (chartTypes.indexOf(opts.chart.type) !== -1) { - chartDefaults = defaults[opts.chart.type](); - } else { - chartDefaults = defaults.line(); - } - - if (opts.chart.stacked && opts.chart.type === 'bar') { - chartDefaults = defaults.stackedBars(); - } - - if ((_opts$chart$brush = opts.chart.brush) !== null && _opts$chart$brush !== void 0 && _opts$chart$brush.enabled) { - chartDefaults = defaults.brush(chartDefaults); - } - - if (opts.chart.stacked && opts.chart.stackType === '100%') { - opts = defaults.stacked100(opts); - } - - if ((_opts$plotOptions = opts.plotOptions) !== null && _opts$plotOptions !== void 0 && (_opts$plotOptions$bar = _opts$plotOptions.bar) !== null && _opts$plotOptions$bar !== void 0 && _opts$plotOptions$bar.isDumbbell) { - opts = defaults.dumbbell(opts); - } // If user has specified a dark theme, make the tooltip dark too - - - this.checkForDarkTheme(window.Apex); // check global window Apex options - - this.checkForDarkTheme(opts); // check locally passed options - - opts.xaxis = opts.xaxis || window.Apex.xaxis || {}; // an important boolean needs to be set here - // otherwise all the charts will have this flag set to true window.Apex.xaxis is set globally - - if (!responsiveOverride) { - opts.xaxis.convertedCatToNumeric = false; - } - - opts = this.checkForCatToNumericXAxis(this.chartType, chartDefaults, opts); - - if ((_opts$chart$sparkline = opts.chart.sparkline) !== null && _opts$chart$sparkline !== void 0 && _opts$chart$sparkline.enabled || (_window$Apex$chart = window.Apex.chart) !== null && _window$Apex$chart !== void 0 && (_window$Apex$chart$sp = _window$Apex$chart.sparkline) !== null && _window$Apex$chart$sp !== void 0 && _window$Apex$chart$sp.enabled) { - chartDefaults = defaults.sparkline(chartDefaults); - } - - newDefaults = Utils$1.extend(config, chartDefaults); - } // config should cascade in this fashion - // default-config < global-apex-variable-config < user-defined-config - // get GLOBALLY defined options and merge with the default config - - - var mergedWithDefaultConfig = Utils$1.extend(newDefaults, window.Apex); // get the merged config and extend with user defined config - - config = Utils$1.extend(mergedWithDefaultConfig, opts); // some features are not supported. those mismatches should be handled - - config = this.handleUserInputErrors(config); - return config; - } - }, { - key: "checkForCatToNumericXAxis", - value: function checkForCatToNumericXAxis(chartType, chartDefaults, opts) { - var _opts$plotOptions2, _opts$plotOptions2$ba; - - var defaults = new Defaults(opts); - var isBarHorizontal = (chartType === 'bar' || chartType === 'boxPlot') && ((_opts$plotOptions2 = opts.plotOptions) === null || _opts$plotOptions2 === void 0 ? void 0 : (_opts$plotOptions2$ba = _opts$plotOptions2.bar) === null || _opts$plotOptions2$ba === void 0 ? void 0 : _opts$plotOptions2$ba.horizontal); - var unsupportedZoom = chartType === 'pie' || chartType === 'polarArea' || chartType === 'donut' || chartType === 'radar' || chartType === 'radialBar' || chartType === 'heatmap'; - var notNumericXAxis = opts.xaxis.type !== 'datetime' && opts.xaxis.type !== 'numeric'; - var tickPlacement = opts.xaxis.tickPlacement ? opts.xaxis.tickPlacement : chartDefaults.xaxis && chartDefaults.xaxis.tickPlacement; - - if (!isBarHorizontal && !unsupportedZoom && notNumericXAxis && tickPlacement !== 'between') { - opts = defaults.convertCatToNumeric(opts); - } - - return opts; - } - }, { - key: "extendYAxis", - value: function extendYAxis(opts, w) { - var options = new Options(); - - if (typeof opts.yaxis === 'undefined' || !opts.yaxis || Array.isArray(opts.yaxis) && opts.yaxis.length === 0) { - opts.yaxis = {}; - } // extend global yaxis config (only if object is provided / not an array) - - - if (opts.yaxis.constructor !== Array && window.Apex.yaxis && window.Apex.yaxis.constructor !== Array) { - opts.yaxis = Utils$1.extend(opts.yaxis, window.Apex.yaxis); - } // as we can't extend nested object's array with extend, we need to do it first - // user can provide either an array or object in yaxis config - - - if (opts.yaxis.constructor !== Array) { - // convert the yaxis to array if user supplied object - opts.yaxis = [Utils$1.extend(options.yAxis, opts.yaxis)]; - } else { - opts.yaxis = Utils$1.extendArray(opts.yaxis, options.yAxis); - } - - var isLogY = false; - opts.yaxis.forEach(function (y) { - if (y.logarithmic) { - isLogY = true; - } - }); - var series = opts.series; - - if (w && !series) { - series = w.config.series; - } // A logarithmic chart works correctly when each series has a corresponding y-axis - // If this is not the case, we manually create yaxis for multi-series log chart - - - if (isLogY && series.length !== opts.yaxis.length && series.length) { - opts.yaxis = series.map(function (s, i) { - if (!s.name) { - series[i].name = "series-".concat(i + 1); - } - - if (opts.yaxis[i]) { - opts.yaxis[i].seriesName = series[i].name; - return opts.yaxis[i]; - } else { - var newYaxis = Utils$1.extend(options.yAxis, opts.yaxis[0]); - newYaxis.show = false; - return newYaxis; - } - }); - } - - if (isLogY && series.length > 1 && series.length !== opts.yaxis.length) { - console.warn('A multi-series logarithmic chart should have equal number of series and y-axes. Please make sure to equalize both.'); - } - - return opts; - } // annotations also accepts array, so we need to extend them manually - - }, { - key: "extendAnnotations", - value: function extendAnnotations(opts) { - if (typeof opts.annotations === 'undefined') { - opts.annotations = {}; - opts.annotations.yaxis = []; - opts.annotations.xaxis = []; - opts.annotations.points = []; - } - - opts = this.extendYAxisAnnotations(opts); - opts = this.extendXAxisAnnotations(opts); - opts = this.extendPointAnnotations(opts); - return opts; - } - }, { - key: "extendYAxisAnnotations", - value: function extendYAxisAnnotations(opts) { - var options = new Options(); - opts.annotations.yaxis = Utils$1.extendArray(typeof opts.annotations.yaxis !== 'undefined' ? opts.annotations.yaxis : [], options.yAxisAnnotation); - return opts; - } - }, { - key: "extendXAxisAnnotations", - value: function extendXAxisAnnotations(opts) { - var options = new Options(); - opts.annotations.xaxis = Utils$1.extendArray(typeof opts.annotations.xaxis !== 'undefined' ? opts.annotations.xaxis : [], options.xAxisAnnotation); - return opts; - } - }, { - key: "extendPointAnnotations", - value: function extendPointAnnotations(opts) { - var options = new Options(); - opts.annotations.points = Utils$1.extendArray(typeof opts.annotations.points !== 'undefined' ? opts.annotations.points : [], options.pointAnnotation); - return opts; - } - }, { - key: "checkForDarkTheme", - value: function checkForDarkTheme(opts) { - if (opts.theme && opts.theme.mode === 'dark') { - if (!opts.tooltip) { - opts.tooltip = {}; - } - - if (opts.tooltip.theme !== 'light') { - opts.tooltip.theme = 'dark'; - } - - if (!opts.chart.foreColor) { - opts.chart.foreColor = '#f6f7f8'; - } - - if (!opts.chart.background) { - opts.chart.background = '#424242'; - } - - if (!opts.theme.palette) { - opts.theme.palette = 'palette4'; - } - } - } - }, { - key: "handleUserInputErrors", - value: function handleUserInputErrors(opts) { - var config = opts; // conflicting tooltip option. intersect makes sure to focus on 1 point at a time. Shared cannot be used along with it - - if (config.tooltip.shared && config.tooltip.intersect) { - throw new Error('tooltip.shared cannot be enabled when tooltip.intersect is true. Turn off any other option by setting it to false.'); - } - - if (config.chart.type === 'bar' && config.plotOptions.bar.horizontal) { - // No multiple yaxis for bars - if (config.yaxis.length > 1) { - throw new Error('Multiple Y Axis for bars are not supported. Switch to column chart by setting plotOptions.bar.horizontal=false'); - } // if yaxis is reversed in horizontal bar chart, you should draw the y-axis on right side - - - if (config.yaxis[0].reversed) { - config.yaxis[0].opposite = true; - } - - config.xaxis.tooltip.enabled = false; // no xaxis tooltip for horizontal bar - - config.yaxis[0].tooltip.enabled = false; // no xaxis tooltip for horizontal bar - - config.chart.zoom.enabled = false; // no zooming for horz bars - } - - if (config.chart.type === 'bar' || config.chart.type === 'rangeBar') { - if (config.tooltip.shared) { - if (config.xaxis.crosshairs.width === 'barWidth' && config.series.length > 1) { - config.xaxis.crosshairs.width = 'tickWidth'; - } - } - } - - if (config.chart.type === 'candlestick' || config.chart.type === 'boxPlot') { - if (config.yaxis[0].reversed) { - console.warn("Reversed y-axis in ".concat(config.chart.type, " chart is not supported.")); - config.yaxis[0].reversed = false; - } - } - - return config; - } - }]); - - return Config; - }(); - - var Globals = /*#__PURE__*/function () { - function Globals() { - _classCallCheck(this, Globals); - } - - _createClass(Globals, [{ - key: "initGlobalVars", - value: function initGlobalVars(gl) { - gl.series = []; // the MAIN series array (y values) - - gl.seriesCandleO = []; - gl.seriesCandleH = []; - gl.seriesCandleM = []; - gl.seriesCandleL = []; - gl.seriesCandleC = []; - gl.seriesRangeStart = []; - gl.seriesRangeEnd = []; - gl.seriesRange = []; - gl.seriesPercent = []; - gl.seriesGoals = []; - gl.seriesX = []; - gl.seriesZ = []; - gl.seriesNames = []; - gl.seriesTotals = []; - gl.seriesLog = []; - gl.seriesColors = []; - gl.stackedSeriesTotals = []; - gl.seriesXvalues = []; // we will need this in tooltip (it's x position) - // when we will have unequal x values, we will need - // some way to get x value depending on mouse pointer - - gl.seriesYvalues = []; // we will need this when deciding which series - // user hovered on - - gl.labels = []; - gl.hasXaxisGroups = false; - gl.groups = []; - gl.hasSeriesGroups = false; - gl.seriesGroups = []; - gl.categoryLabels = []; - gl.timescaleLabels = []; - gl.noLabelsProvided = false; - gl.resizeTimer = null; - gl.selectionResizeTimer = null; - gl.delayedElements = []; - gl.pointsArray = []; - gl.dataLabelsRects = []; - gl.isXNumeric = false; - gl.skipLastTimelinelabel = false; - gl.skipFirstTimelinelabel = false; - gl.isDataXYZ = false; - gl.isMultiLineX = false; - gl.isMultipleYAxis = false; - gl.maxY = -Number.MAX_VALUE; - gl.minY = Number.MIN_VALUE; - gl.minYArr = []; - gl.maxYArr = []; - gl.maxX = -Number.MAX_VALUE; - gl.minX = Number.MAX_VALUE; - gl.initialMaxX = -Number.MAX_VALUE; - gl.initialMinX = Number.MAX_VALUE; - gl.maxDate = 0; - gl.minDate = Number.MAX_VALUE; - gl.minZ = Number.MAX_VALUE; - gl.maxZ = -Number.MAX_VALUE; - gl.minXDiff = Number.MAX_VALUE; - gl.yAxisScale = []; - gl.xAxisScale = null; - gl.xAxisTicksPositions = []; - gl.yLabelsCoords = []; - gl.yTitleCoords = []; - gl.barPadForNumericAxis = 0; - gl.padHorizontal = 0; - gl.xRange = 0; - gl.yRange = []; - gl.zRange = 0; - gl.dataPoints = 0; - gl.xTickAmount = 0; - } - }, { - key: "globalVars", - value: function globalVars(config) { - return { - chartID: null, - // chart ID - apexcharts-cuid - cuid: null, - // chart ID - random numbers excluding "apexcharts" part - events: { - beforeMount: [], - mounted: [], - updated: [], - clicked: [], - selection: [], - dataPointSelection: [], - zoomed: [], - scrolled: [] - }, - colors: [], - clientX: null, - clientY: null, - fill: { - colors: [] - }, - stroke: { - colors: [] - }, - dataLabels: { - style: { - colors: [] - } - }, - radarPolygons: { - fill: { - colors: [] - } - }, - markers: { - colors: [], - size: config.markers.size, - largestSize: 0 - }, - animationEnded: false, - isTouchDevice: 'ontouchstart' in window || navigator.msMaxTouchPoints, - isDirty: false, - // chart has been updated after the initial render. This is different than dataChanged property. isDirty means user manually called some method to update - isExecCalled: false, - // whether user updated the chart through the exec method - initialConfig: null, - // we will store the first config user has set to go back when user finishes interactions like zooming and come out of it - initialSeries: [], - lastXAxis: [], - lastYAxis: [], - columnSeries: null, - labels: [], - // store the text to draw on x axis - // Don't mutate the labels, many things including tooltips depends on it! - timescaleLabels: [], - // store the timescaleLabels Labels in another variable - noLabelsProvided: false, - // if user didn't provide any categories/labels or x values, fallback to 1,2,3,4... - allSeriesCollapsed: false, - collapsedSeries: [], - // when user collapses a series, it goes into this array - collapsedSeriesIndices: [], - // this stores the index of the collapsedSeries instead of whole object for quick access - ancillaryCollapsedSeries: [], - // when user collapses an "alwaysVisible" series, it goes into this array - ancillaryCollapsedSeriesIndices: [], - // this stores the index of the ancillaryCollapsedSeries whose y-axis is always visible - risingSeries: [], - // when user re-opens a collapsed series, it goes here - dataFormatXNumeric: false, - // boolean value to indicate user has passed numeric x values - capturedSeriesIndex: -1, - capturedDataPointIndex: -1, - selectedDataPoints: [], - goldenPadding: 35, - // this value is used at a lot of places for spacing purpose - invalidLogScale: false, - // if a user enabled log scale but the data provided is not valid to generate a log scale, turn on this flag - ignoreYAxisIndexes: [], - // when series are being collapsed in multiple y axes, ignore certain index - yAxisSameScaleIndices: [], - maxValsInArrayIndex: 0, - radialSize: 0, - selection: undefined, - zoomEnabled: config.chart.toolbar.autoSelected === 'zoom' && config.chart.toolbar.tools.zoom && config.chart.zoom.enabled, - panEnabled: config.chart.toolbar.autoSelected === 'pan' && config.chart.toolbar.tools.pan, - selectionEnabled: config.chart.toolbar.autoSelected === 'selection' && config.chart.toolbar.tools.selection, - yaxis: null, - mousedown: false, - lastClientPosition: {}, - // don't reset this variable this the chart is destroyed. It is used to detect right or left mousemove in panning - visibleXRange: undefined, - yValueDecimal: 0, - // are there floating numbers in the series. If yes, this represent the len of the decimals - total: 0, - SVGNS: 'http://www.w3.org/2000/svg', - // svg namespace - svgWidth: 0, - // the whole svg width - svgHeight: 0, - // the whole svg height - noData: false, - // whether there is any data to display or not - locale: {}, - // the current locale values will be preserved here for global access - dom: {}, - // for storing all dom nodes in this particular property - memory: { - methodsToExec: [] - }, - shouldAnimate: true, - skipLastTimelinelabel: false, - // when last label is cropped, skip drawing it - skipFirstTimelinelabel: false, - // when first label is cropped, skip drawing it - delayedElements: [], - // element which appear after animation has finished - axisCharts: true, - // chart type = line or area or bar - // (refer them also as plot charts in the code) - isDataXYZ: false, - // bool: data was provided in a {[x,y,z]} pattern - resized: false, - // bool: user has resized - resizeTimer: null, - // timeout function to make a small delay before - // drawing when user resized - comboCharts: false, - // bool: whether it's a combination of line/column - dataChanged: false, - // bool: has data changed dynamically - previousPaths: [], - // array: when data is changed, it will animate from - // previous paths - allSeriesHasEqualX: true, - pointsArray: [], - // store the points positions here to draw later on hover - // format is - [[x,y],[x,y]... [x,y]] - dataLabelsRects: [], - // store the positions of datalabels to prevent collision - lastDrawnDataLabelsIndexes: [], - hasNullValues: false, - // bool: whether series contains null values - easing: null, - // function: animation effect to apply - zoomed: false, - // whether user has zoomed or not - gridWidth: 0, - // drawable width of actual graphs (series paths) - gridHeight: 0, - // drawable height of actual graphs (series paths) - rotateXLabels: false, - defaultLabels: false, - xLabelFormatter: undefined, - // formatter for x axis labels - yLabelFormatters: [], - xaxisTooltipFormatter: undefined, - // formatter for x axis tooltip - ttKeyFormatter: undefined, - ttVal: undefined, - ttZFormatter: undefined, - LINE_HEIGHT_RATIO: 1.618, - xAxisLabelsHeight: 0, - xAxisGroupLabelsHeight: 0, - xAxisLabelsWidth: 0, - yAxisLabelsWidth: 0, - scaleX: 1, - scaleY: 1, - translateX: 0, - translateY: 0, - translateYAxisX: [], - yAxisWidths: [], - translateXAxisY: 0, - translateXAxisX: 0, - tooltip: null - }; - } - }, { - key: "init", - value: function init(config) { - var globals = this.globalVars(config); - this.initGlobalVars(globals); - globals.initialConfig = Utils$1.extend({}, config); - globals.initialSeries = Utils$1.clone(config.series); - globals.lastXAxis = Utils$1.clone(globals.initialConfig.xaxis); - globals.lastYAxis = Utils$1.clone(globals.initialConfig.yaxis); - return globals; - } - }]); - - return Globals; - }(); - - /** - * ApexCharts Base Class for extending user options with pre-defined ApexCharts config. - * - * @module Base - **/ - - var Base = /*#__PURE__*/function () { - function Base(opts) { - _classCallCheck(this, Base); - - this.opts = opts; - } - - _createClass(Base, [{ - key: "init", - value: function init() { - var config = new Config(this.opts).init({ - responsiveOverride: false - }); - var globals = new Globals().init(config); - var w = { - config: config, - globals: globals - }; - return w; - } - }]); - - return Base; - }(); - - /** - * ApexCharts Fill Class for setting fill options of the paths. - * - * @module Fill - **/ - - var Fill = /*#__PURE__*/function () { - function Fill(ctx) { - _classCallCheck(this, Fill); - - this.ctx = ctx; - this.w = ctx.w; - this.opts = null; - this.seriesIndex = 0; - } - - _createClass(Fill, [{ - key: "clippedImgArea", - value: function clippedImgArea(params) { - var w = this.w; - var cnf = w.config; - var svgW = parseInt(w.globals.gridWidth, 10); - var svgH = parseInt(w.globals.gridHeight, 10); - var size = svgW > svgH ? svgW : svgH; - var fillImg = params.image; - var imgWidth = 0; - var imgHeight = 0; - - if (typeof params.width === 'undefined' && typeof params.height === 'undefined') { - if (cnf.fill.image.width !== undefined && cnf.fill.image.height !== undefined) { - imgWidth = cnf.fill.image.width + 1; - imgHeight = cnf.fill.image.height; - } else { - imgWidth = size + 1; - imgHeight = size; - } - } else { - imgWidth = params.width; - imgHeight = params.height; - } - - var elPattern = document.createElementNS(w.globals.SVGNS, 'pattern'); - Graphics.setAttrs(elPattern, { - id: params.patternID, - patternUnits: params.patternUnits ? params.patternUnits : 'userSpaceOnUse', - width: imgWidth + 'px', - height: imgHeight + 'px' - }); - var elImage = document.createElementNS(w.globals.SVGNS, 'image'); - elPattern.appendChild(elImage); - elImage.setAttributeNS(window.SVG.xlink, 'href', fillImg); - Graphics.setAttrs(elImage, { - x: 0, - y: 0, - preserveAspectRatio: 'none', - width: imgWidth + 'px', - height: imgHeight + 'px' - }); - elImage.style.opacity = params.opacity; - w.globals.dom.elDefs.node.appendChild(elPattern); - } - }, { - key: "getSeriesIndex", - value: function getSeriesIndex(opts) { - var w = this.w; - - if ((w.config.chart.type === 'bar' || w.config.chart.type === 'rangeBar') && w.config.plotOptions.bar.distributed || w.config.chart.type === 'heatmap' || w.config.chart.type === 'treemap') { - this.seriesIndex = opts.seriesNumber; - } else { - this.seriesIndex = opts.seriesNumber % w.globals.series.length; - } - - return this.seriesIndex; - } - }, { - key: "fillPath", - value: function fillPath(opts) { - var w = this.w; - this.opts = opts; - var cnf = this.w.config; - var pathFill; - var patternFill, gradientFill; - this.seriesIndex = this.getSeriesIndex(opts); - var fillColors = this.getFillColors(); - var fillColor = fillColors[this.seriesIndex]; //override fillcolor if user inputted color with data - - if (w.globals.seriesColors[this.seriesIndex] !== undefined) { - fillColor = w.globals.seriesColors[this.seriesIndex]; - } - - if (typeof fillColor === 'function') { - fillColor = fillColor({ - seriesIndex: this.seriesIndex, - dataPointIndex: opts.dataPointIndex, - value: opts.value, - w: w - }); - } - - var fillType = opts.fillType ? opts.fillType : this.getFillType(this.seriesIndex); - var fillOpacity = Array.isArray(cnf.fill.opacity) ? cnf.fill.opacity[this.seriesIndex] : cnf.fill.opacity; - - if (opts.color) { - fillColor = opts.color; - } - - var defaultColor = fillColor; - - if (fillColor.indexOf('rgb') === -1) { - if (fillColor.length < 9) { - // if the hex contains alpha and is of 9 digit, skip the opacity - defaultColor = Utils$1.hexToRgba(fillColor, fillOpacity); - } - } else { - if (fillColor.indexOf('rgba') > -1) { - fillOpacity = Utils$1.getOpacityFromRGBA(fillColor); - } - } - - if (opts.opacity) fillOpacity = opts.opacity; - - if (fillType === 'pattern') { - patternFill = this.handlePatternFill({ - fillConfig: opts.fillConfig, - patternFill: patternFill, - fillColor: fillColor, - fillOpacity: fillOpacity, - defaultColor: defaultColor - }); - } - - if (fillType === 'gradient') { - gradientFill = this.handleGradientFill({ - fillConfig: opts.fillConfig, - fillColor: fillColor, - fillOpacity: fillOpacity, - i: this.seriesIndex - }); - } - - if (fillType === 'image') { - var imgSrc = cnf.fill.image.src; - var patternID = opts.patternID ? opts.patternID : ''; - this.clippedImgArea({ - opacity: fillOpacity, - image: Array.isArray(imgSrc) ? opts.seriesNumber < imgSrc.length ? imgSrc[opts.seriesNumber] : imgSrc[0] : imgSrc, - width: opts.width ? opts.width : undefined, - height: opts.height ? opts.height : undefined, - patternUnits: opts.patternUnits, - patternID: "pattern".concat(w.globals.cuid).concat(opts.seriesNumber + 1).concat(patternID) - }); - pathFill = "url(#pattern".concat(w.globals.cuid).concat(opts.seriesNumber + 1).concat(patternID, ")"); - } else if (fillType === 'gradient') { - pathFill = gradientFill; - } else if (fillType === 'pattern') { - pathFill = patternFill; - } else { - pathFill = defaultColor; - } // override pattern/gradient if opts.solid is true - - - if (opts.solid) { - pathFill = defaultColor; - } - - return pathFill; - } - }, { - key: "getFillType", - value: function getFillType(seriesIndex) { - var w = this.w; - - if (Array.isArray(w.config.fill.type)) { - return w.config.fill.type[seriesIndex]; - } else { - return w.config.fill.type; - } - } - }, { - key: "getFillColors", - value: function getFillColors() { - var w = this.w; - var cnf = w.config; - var opts = this.opts; - var fillColors = []; - - if (w.globals.comboCharts) { - if (w.config.series[this.seriesIndex].type === 'line') { - if (Array.isArray(w.globals.stroke.colors)) { - fillColors = w.globals.stroke.colors; - } else { - fillColors.push(w.globals.stroke.colors); - } - } else { - if (Array.isArray(w.globals.fill.colors)) { - fillColors = w.globals.fill.colors; - } else { - fillColors.push(w.globals.fill.colors); - } - } - } else { - if (cnf.chart.type === 'line') { - if (Array.isArray(w.globals.stroke.colors)) { - fillColors = w.globals.stroke.colors; - } else { - fillColors.push(w.globals.stroke.colors); - } - } else { - if (Array.isArray(w.globals.fill.colors)) { - fillColors = w.globals.fill.colors; - } else { - fillColors.push(w.globals.fill.colors); - } - } - } // colors passed in arguments - - - if (typeof opts.fillColors !== 'undefined') { - fillColors = []; - - if (Array.isArray(opts.fillColors)) { - fillColors = opts.fillColors.slice(); - } else { - fillColors.push(opts.fillColors); - } - } - - return fillColors; - } - }, { - key: "handlePatternFill", - value: function handlePatternFill(_ref) { - var fillConfig = _ref.fillConfig, - patternFill = _ref.patternFill, - fillColor = _ref.fillColor, - fillOpacity = _ref.fillOpacity, - defaultColor = _ref.defaultColor; - var fillCnf = this.w.config.fill; - - if (fillConfig) { - fillCnf = fillConfig; - } - - var opts = this.opts; - var graphics = new Graphics(this.ctx); - var patternStrokeWidth = Array.isArray(fillCnf.pattern.strokeWidth) ? fillCnf.pattern.strokeWidth[this.seriesIndex] : fillCnf.pattern.strokeWidth; - var patternLineColor = fillColor; - - if (Array.isArray(fillCnf.pattern.style)) { - if (typeof fillCnf.pattern.style[opts.seriesNumber] !== 'undefined') { - var pf = graphics.drawPattern(fillCnf.pattern.style[opts.seriesNumber], fillCnf.pattern.width, fillCnf.pattern.height, patternLineColor, patternStrokeWidth, fillOpacity); - patternFill = pf; - } else { - patternFill = defaultColor; - } - } else { - patternFill = graphics.drawPattern(fillCnf.pattern.style, fillCnf.pattern.width, fillCnf.pattern.height, patternLineColor, patternStrokeWidth, fillOpacity); - } - - return patternFill; - } - }, { - key: "handleGradientFill", - value: function handleGradientFill(_ref2) { - var fillColor = _ref2.fillColor, - fillOpacity = _ref2.fillOpacity, - fillConfig = _ref2.fillConfig, - i = _ref2.i; - var fillCnf = this.w.config.fill; - - if (fillConfig) { - fillCnf = _objectSpread2(_objectSpread2({}, fillCnf), fillConfig); - } - - var opts = this.opts; - var graphics = new Graphics(this.ctx); - var utils = new Utils$1(); - var type = fillCnf.gradient.type; - var gradientFrom = fillColor; - var gradientTo; - var opacityFrom = fillCnf.gradient.opacityFrom === undefined ? fillOpacity : Array.isArray(fillCnf.gradient.opacityFrom) ? fillCnf.gradient.opacityFrom[i] : fillCnf.gradient.opacityFrom; - - if (gradientFrom.indexOf('rgba') > -1) { - opacityFrom = Utils$1.getOpacityFromRGBA(gradientFrom); - } - - var opacityTo = fillCnf.gradient.opacityTo === undefined ? fillOpacity : Array.isArray(fillCnf.gradient.opacityTo) ? fillCnf.gradient.opacityTo[i] : fillCnf.gradient.opacityTo; - - if (fillCnf.gradient.gradientToColors === undefined || fillCnf.gradient.gradientToColors.length === 0) { - if (fillCnf.gradient.shade === 'dark') { - gradientTo = utils.shadeColor(parseFloat(fillCnf.gradient.shadeIntensity) * -1, fillColor.indexOf('rgb') > -1 ? Utils$1.rgb2hex(fillColor) : fillColor); - } else { - gradientTo = utils.shadeColor(parseFloat(fillCnf.gradient.shadeIntensity), fillColor.indexOf('rgb') > -1 ? Utils$1.rgb2hex(fillColor) : fillColor); - } - } else { - if (fillCnf.gradient.gradientToColors[opts.seriesNumber]) { - var gToColor = fillCnf.gradient.gradientToColors[opts.seriesNumber]; - gradientTo = gToColor; - - if (gToColor.indexOf('rgba') > -1) { - opacityTo = Utils$1.getOpacityFromRGBA(gToColor); - } - } else { - gradientTo = fillColor; - } - } - - if (fillCnf.gradient.gradientFrom) { - gradientFrom = fillCnf.gradient.gradientFrom; - } - - if (fillCnf.gradient.gradientTo) { - gradientTo = fillCnf.gradient.gradientTo; - } - - if (fillCnf.gradient.inverseColors) { - var t = gradientFrom; - gradientFrom = gradientTo; - gradientTo = t; - } - - if (gradientFrom.indexOf('rgb') > -1) { - gradientFrom = Utils$1.rgb2hex(gradientFrom); - } - - if (gradientTo.indexOf('rgb') > -1) { - gradientTo = Utils$1.rgb2hex(gradientTo); - } - - return graphics.drawGradient(type, gradientFrom, gradientTo, opacityFrom, opacityTo, opts.size, fillCnf.gradient.stops, fillCnf.gradient.colorStops, i); - } - }]); - - return Fill; - }(); - - /** - * ApexCharts Markers Class for drawing points on y values in axes charts. - * - * @module Markers - **/ - - var Markers = /*#__PURE__*/function () { - function Markers(ctx, opts) { - _classCallCheck(this, Markers); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(Markers, [{ - key: "setGlobalMarkerSize", - value: function setGlobalMarkerSize() { - var w = this.w; - w.globals.markers.size = Array.isArray(w.config.markers.size) ? w.config.markers.size : [w.config.markers.size]; - - if (w.globals.markers.size.length > 0) { - if (w.globals.markers.size.length < w.globals.series.length + 1) { - for (var i = 0; i <= w.globals.series.length; i++) { - if (typeof w.globals.markers.size[i] === 'undefined') { - w.globals.markers.size.push(w.globals.markers.size[0]); - } - } - } - } else { - w.globals.markers.size = w.config.series.map(function (s) { - return w.config.markers.size; - }); - } - } - }, { - key: "plotChartMarkers", - value: function plotChartMarkers(pointsPos, seriesIndex, j, pSize) { - var alwaysDrawMarker = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; - var w = this.w; - var i = seriesIndex; - var p = pointsPos; - var elPointsWrap = null; - var graphics = new Graphics(this.ctx); - var point; - var hasDiscreteMarkers = w.config.markers.discrete && w.config.markers.discrete.length; - - if (w.globals.markers.size[seriesIndex] > 0 || alwaysDrawMarker || hasDiscreteMarkers) { - elPointsWrap = graphics.group({ - class: alwaysDrawMarker || hasDiscreteMarkers ? '' : 'apexcharts-series-markers' - }); - elPointsWrap.attr('clip-path', "url(#gridRectMarkerMask".concat(w.globals.cuid, ")")); - } - - if (Array.isArray(p.x)) { - for (var q = 0; q < p.x.length; q++) { - var dataPointIndex = j; // a small hack as we have 2 points for the first val to connect it - - if (j === 1 && q === 0) dataPointIndex = 0; - if (j === 1 && q === 1) dataPointIndex = 1; - var PointClasses = 'apexcharts-marker'; - - if ((w.config.chart.type === 'line' || w.config.chart.type === 'area') && !w.globals.comboCharts && !w.config.tooltip.intersect) { - PointClasses += ' no-pointer-events'; - } - - var shouldMarkerDraw = Array.isArray(w.config.markers.size) ? w.globals.markers.size[seriesIndex] > 0 : w.config.markers.size > 0; - - if (shouldMarkerDraw || alwaysDrawMarker || hasDiscreteMarkers) { - if (Utils$1.isNumber(p.y[q])) { - PointClasses += " w".concat(Utils$1.randomId()); - } else { - PointClasses = 'apexcharts-nullpoint'; - } - - var opts = this.getMarkerConfig({ - cssClass: PointClasses, - seriesIndex: seriesIndex, - dataPointIndex: dataPointIndex - }); - - if (w.config.series[i].data[dataPointIndex]) { - if (w.config.series[i].data[dataPointIndex].fillColor) { - opts.pointFillColor = w.config.series[i].data[dataPointIndex].fillColor; - } - - if (w.config.series[i].data[dataPointIndex].strokeColor) { - opts.pointStrokeColor = w.config.series[i].data[dataPointIndex].strokeColor; - } - } - - if (pSize) { - opts.pSize = pSize; - } - - if (p.x[q] < 0 || p.x[q] > w.globals.gridWidth || p.y[q] < 0 || p.y[q] > w.globals.gridHeight) { - opts.pSize = 0; - } - - point = graphics.drawMarker(p.x[q], p.y[q], opts); - point.attr('rel', dataPointIndex); - point.attr('j', dataPointIndex); - point.attr('index', seriesIndex); - point.node.setAttribute('default-marker-size', opts.pSize); - var filters = new Filters(this.ctx); - filters.setSelectionFilter(point, seriesIndex, dataPointIndex); - this.addEvents(point); - - if (elPointsWrap) { - elPointsWrap.add(point); - } - } else { - // dynamic array creation - multidimensional - if (typeof w.globals.pointsArray[seriesIndex] === 'undefined') w.globals.pointsArray[seriesIndex] = []; - w.globals.pointsArray[seriesIndex].push([p.x[q], p.y[q]]); - } - } - } - - return elPointsWrap; - } - }, { - key: "getMarkerConfig", - value: function getMarkerConfig(_ref) { - var cssClass = _ref.cssClass, - seriesIndex = _ref.seriesIndex, - _ref$dataPointIndex = _ref.dataPointIndex, - dataPointIndex = _ref$dataPointIndex === void 0 ? null : _ref$dataPointIndex, - _ref$finishRadius = _ref.finishRadius, - finishRadius = _ref$finishRadius === void 0 ? null : _ref$finishRadius; - var w = this.w; - var pStyle = this.getMarkerStyle(seriesIndex); - var pSize = w.globals.markers.size[seriesIndex]; - var m = w.config.markers; // discrete markers is an option where user can specify a particular marker with different shape, size and color - - if (dataPointIndex !== null && m.discrete.length) { - m.discrete.map(function (marker) { - if (marker.seriesIndex === seriesIndex && marker.dataPointIndex === dataPointIndex) { - pStyle.pointStrokeColor = marker.strokeColor; - pStyle.pointFillColor = marker.fillColor; - pSize = marker.size; - pStyle.pointShape = marker.shape; - } - }); - } - - return { - pSize: finishRadius === null ? pSize : finishRadius, - pRadius: m.radius, - width: Array.isArray(m.width) ? m.width[seriesIndex] : m.width, - height: Array.isArray(m.height) ? m.height[seriesIndex] : m.height, - pointStrokeWidth: Array.isArray(m.strokeWidth) ? m.strokeWidth[seriesIndex] : m.strokeWidth, - pointStrokeColor: pStyle.pointStrokeColor, - pointFillColor: pStyle.pointFillColor, - shape: pStyle.pointShape || (Array.isArray(m.shape) ? m.shape[seriesIndex] : m.shape), - class: cssClass, - pointStrokeOpacity: Array.isArray(m.strokeOpacity) ? m.strokeOpacity[seriesIndex] : m.strokeOpacity, - pointStrokeDashArray: Array.isArray(m.strokeDashArray) ? m.strokeDashArray[seriesIndex] : m.strokeDashArray, - pointFillOpacity: Array.isArray(m.fillOpacity) ? m.fillOpacity[seriesIndex] : m.fillOpacity, - seriesIndex: seriesIndex - }; - } - }, { - key: "addEvents", - value: function addEvents(circle) { - var w = this.w; - var graphics = new Graphics(this.ctx); - circle.node.addEventListener('mouseenter', graphics.pathMouseEnter.bind(this.ctx, circle)); - circle.node.addEventListener('mouseleave', graphics.pathMouseLeave.bind(this.ctx, circle)); - circle.node.addEventListener('mousedown', graphics.pathMouseDown.bind(this.ctx, circle)); - circle.node.addEventListener('click', w.config.markers.onClick); - circle.node.addEventListener('dblclick', w.config.markers.onDblClick); - circle.node.addEventListener('touchstart', graphics.pathMouseDown.bind(this.ctx, circle), { - passive: true - }); - } - }, { - key: "getMarkerStyle", - value: function getMarkerStyle(seriesIndex) { - var w = this.w; - var colors = w.globals.markers.colors; - var strokeColors = w.config.markers.strokeColor || w.config.markers.strokeColors; - var pointStrokeColor = Array.isArray(strokeColors) ? strokeColors[seriesIndex] : strokeColors; - var pointFillColor = Array.isArray(colors) ? colors[seriesIndex] : colors; - return { - pointStrokeColor: pointStrokeColor, - pointFillColor: pointFillColor - }; - } - }]); - - return Markers; - }(); - - /** - * ApexCharts Scatter Class. - * This Class also handles bubbles chart as currently there is no major difference in drawing them, - * @module Scatter - **/ - - var Scatter = /*#__PURE__*/function () { - function Scatter(ctx) { - _classCallCheck(this, Scatter); - - this.ctx = ctx; - this.w = ctx.w; - this.initialAnim = this.w.config.chart.animations.enabled; - this.dynamicAnim = this.initialAnim && this.w.config.chart.animations.dynamicAnimation.enabled; - } - - _createClass(Scatter, [{ - key: "draw", - value: function draw(elSeries, j, opts) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var realIndex = opts.realIndex; - var pointsPos = opts.pointsPos; - var zRatio = opts.zRatio; - var elPointsMain = opts.elParent; - var elPointsWrap = graphics.group({ - class: "apexcharts-series-markers apexcharts-series-".concat(w.config.chart.type) - }); - elPointsWrap.attr('clip-path', "url(#gridRectMarkerMask".concat(w.globals.cuid, ")")); - - if (Array.isArray(pointsPos.x)) { - for (var q = 0; q < pointsPos.x.length; q++) { - var dataPointIndex = j + 1; - var shouldDraw = true; // a small hack as we have 2 points for the first val to connect it - - if (j === 0 && q === 0) dataPointIndex = 0; - if (j === 0 && q === 1) dataPointIndex = 1; - var radius = 0; - var finishRadius = w.globals.markers.size[realIndex]; - - if (zRatio !== Infinity) { - // means we have a bubble - var bubble = w.config.plotOptions.bubble; - finishRadius = w.globals.seriesZ[realIndex][dataPointIndex]; - - if (bubble.zScaling) { - finishRadius /= zRatio; - } - - if (bubble.minBubbleRadius && finishRadius < bubble.minBubbleRadius) { - finishRadius = bubble.minBubbleRadius; - } - - if (bubble.maxBubbleRadius && finishRadius > bubble.maxBubbleRadius) { - finishRadius = bubble.maxBubbleRadius; - } - } - - if (!w.config.chart.animations.enabled) { - radius = finishRadius; - } - - var x = pointsPos.x[q]; - var y = pointsPos.y[q]; - radius = radius || 0; - - if (y === null || typeof w.globals.series[realIndex][dataPointIndex] === 'undefined') { - shouldDraw = false; - } - - if (shouldDraw) { - var point = this.drawPoint(x, y, radius, finishRadius, realIndex, dataPointIndex, j); - elPointsWrap.add(point); - } - - elPointsMain.add(elPointsWrap); - } - } - } - }, { - key: "drawPoint", - value: function drawPoint(x, y, radius, finishRadius, realIndex, dataPointIndex, j) { - var w = this.w; - var i = realIndex; - var anim = new Animations(this.ctx); - var filters = new Filters(this.ctx); - var fill = new Fill(this.ctx); - var markers = new Markers(this.ctx); - var graphics = new Graphics(this.ctx); - var markerConfig = markers.getMarkerConfig({ - cssClass: 'apexcharts-marker', - seriesIndex: i, - dataPointIndex: dataPointIndex, - finishRadius: w.config.chart.type === 'bubble' || w.globals.comboCharts && w.config.series[realIndex] && w.config.series[realIndex].type === 'bubble' ? finishRadius : null - }); - finishRadius = markerConfig.pSize; - var pathFillCircle = fill.fillPath({ - seriesNumber: realIndex, - dataPointIndex: dataPointIndex, - color: markerConfig.pointFillColor, - patternUnits: 'objectBoundingBox', - value: w.globals.series[realIndex][j] - }); - var el; - - if (markerConfig.shape === 'circle') { - el = graphics.drawCircle(radius); - } else if (markerConfig.shape === 'square' || markerConfig.shape === 'rect') { - el = graphics.drawRect(0, 0, markerConfig.width - markerConfig.pointStrokeWidth / 2, markerConfig.height - markerConfig.pointStrokeWidth / 2, markerConfig.pRadius); - } - - if (w.config.series[i].data[dataPointIndex]) { - if (w.config.series[i].data[dataPointIndex].fillColor) { - pathFillCircle = w.config.series[i].data[dataPointIndex].fillColor; - } - } - - el.attr({ - x: x - markerConfig.width / 2 - markerConfig.pointStrokeWidth / 2, - y: y - markerConfig.height / 2 - markerConfig.pointStrokeWidth / 2, - cx: x, - cy: y, - fill: pathFillCircle, - 'fill-opacity': markerConfig.pointFillOpacity, - stroke: markerConfig.pointStrokeColor, - r: finishRadius, - 'stroke-width': markerConfig.pointStrokeWidth, - 'stroke-dasharray': markerConfig.pointStrokeDashArray, - 'stroke-opacity': markerConfig.pointStrokeOpacity - }); - - if (w.config.chart.dropShadow.enabled) { - var dropShadow = w.config.chart.dropShadow; - filters.dropShadow(el, dropShadow, realIndex); - } - - if (this.initialAnim && !w.globals.dataChanged && !w.globals.resized) { - var speed = w.config.chart.animations.speed; - anim.animateMarker(el, 0, markerConfig.shape === 'circle' ? finishRadius : { - width: markerConfig.width, - height: markerConfig.height - }, speed, w.globals.easing, function () { - window.setTimeout(function () { - anim.animationCompleted(el); - }, 100); - }); - } else { - w.globals.animationEnded = true; - } - - if (w.globals.dataChanged && markerConfig.shape === 'circle') { - if (this.dynamicAnim) { - var _speed = w.config.chart.animations.dynamicAnimation.speed; - var prevX, prevY, prevR; - var prevPathJ = null; - prevPathJ = w.globals.previousPaths[realIndex] && w.globals.previousPaths[realIndex][j]; - - if (typeof prevPathJ !== 'undefined' && prevPathJ !== null) { - // series containing less elements will ignore these values and revert to 0 - prevX = prevPathJ.x; - prevY = prevPathJ.y; - prevR = typeof prevPathJ.r !== 'undefined' ? prevPathJ.r : finishRadius; - } - - for (var cs = 0; cs < w.globals.collapsedSeries.length; cs++) { - if (w.globals.collapsedSeries[cs].index === realIndex) { - _speed = 1; - finishRadius = 0; - } - } - - if (x === 0 && y === 0) finishRadius = 0; - anim.animateCircle(el, { - cx: prevX, - cy: prevY, - r: prevR - }, { - cx: x, - cy: y, - r: finishRadius - }, _speed, w.globals.easing); - } else { - el.attr({ - r: finishRadius - }); - } - } - - el.attr({ - rel: dataPointIndex, - j: dataPointIndex, - index: realIndex, - 'default-marker-size': finishRadius - }); - filters.setSelectionFilter(el, realIndex, dataPointIndex); - markers.addEvents(el); - el.node.classList.add('apexcharts-marker'); - return el; - } - }, { - key: "centerTextInBubble", - value: function centerTextInBubble(y) { - var w = this.w; - y = y + parseInt(w.config.dataLabels.style.fontSize, 10) / 4; - return { - y: y - }; - } - }]); - - return Scatter; - }(); - - /** - * ApexCharts DataLabels Class for drawing dataLabels on Axes based Charts. - * - * @module DataLabels - **/ - - var DataLabels = /*#__PURE__*/function () { - function DataLabels(ctx) { - _classCallCheck(this, DataLabels); - - this.ctx = ctx; - this.w = ctx.w; - } // When there are many datalabels to be printed, and some of them overlaps each other in the same series, this method will take care of that - // Also, when datalabels exceeds the drawable area and get clipped off, we need to adjust and move some pixels to make them visible again - - - _createClass(DataLabels, [{ - key: "dataLabelsCorrection", - value: function dataLabelsCorrection(x, y, val, i, dataPointIndex, alwaysDrawDataLabel, fontSize) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var drawnextLabel = false; // - - var textRects = graphics.getTextRects(val, fontSize); - var width = textRects.width; - var height = textRects.height; - if (y < 0) y = 0; - if (y > w.globals.gridHeight + height) y = w.globals.gridHeight + height / 2; // first value in series, so push an empty array - - if (typeof w.globals.dataLabelsRects[i] === 'undefined') w.globals.dataLabelsRects[i] = []; // then start pushing actual rects in that sub-array - - w.globals.dataLabelsRects[i].push({ - x: x, - y: y, - width: width, - height: height - }); - var len = w.globals.dataLabelsRects[i].length - 2; - var lastDrawnIndex = typeof w.globals.lastDrawnDataLabelsIndexes[i] !== 'undefined' ? w.globals.lastDrawnDataLabelsIndexes[i][w.globals.lastDrawnDataLabelsIndexes[i].length - 1] : 0; - - if (typeof w.globals.dataLabelsRects[i][len] !== 'undefined') { - var lastDataLabelRect = w.globals.dataLabelsRects[i][lastDrawnIndex]; - - if ( // next label forward and x not intersecting - x > lastDataLabelRect.x + lastDataLabelRect.width + 2 || y > lastDataLabelRect.y + lastDataLabelRect.height + 2 || x + width < lastDataLabelRect.x // next label is going to be drawn backwards - ) { - // the 2 indexes don't override, so OK to draw next label - drawnextLabel = true; - } - } - - if (dataPointIndex === 0 || alwaysDrawDataLabel) { - drawnextLabel = true; - } - - return { - x: x, - y: y, - textRects: textRects, - drawnextLabel: drawnextLabel - }; - } - }, { - key: "drawDataLabel", - value: function drawDataLabel(_ref) { - var _this = this; - - var type = _ref.type, - pos = _ref.pos, - i = _ref.i, - j = _ref.j, - isRangeStart = _ref.isRangeStart, - _ref$strokeWidth = _ref.strokeWidth, - strokeWidth = _ref$strokeWidth === void 0 ? 2 : _ref$strokeWidth; - // this method handles line, area, bubble, scatter charts as those charts contains markers/points which have pre-defined x/y positions - // all other charts like radar / bars / heatmaps will define their own drawDataLabel routine - var w = this.w; - var graphics = new Graphics(this.ctx); - var dataLabelsConfig = w.config.dataLabels; - var x = 0; - var y = 0; - var dataPointIndex = j; - var elDataLabelsWrap = null; - - if (!dataLabelsConfig.enabled || !Array.isArray(pos.x)) { - return elDataLabelsWrap; - } - - elDataLabelsWrap = graphics.group({ - class: 'apexcharts-data-labels' - }); - - for (var q = 0; q < pos.x.length; q++) { - x = pos.x[q] + dataLabelsConfig.offsetX; - y = pos.y[q] + dataLabelsConfig.offsetY + strokeWidth; - - if (!isNaN(x)) { - // a small hack as we have 2 points for the first val to connect it - if (j === 1 && q === 0) dataPointIndex = 0; - if (j === 1 && q === 1) dataPointIndex = 1; - var val = w.globals.series[i][dataPointIndex]; - - if (type === 'rangeArea') { - if (isRangeStart) { - val = w.globals.seriesRangeStart[i][dataPointIndex]; - } else { - val = w.globals.seriesRangeEnd[i][dataPointIndex]; - } - } - - var text = ''; - - var getText = function getText(v) { - return w.config.dataLabels.formatter(v, { - ctx: _this.ctx, - seriesIndex: i, - dataPointIndex: dataPointIndex, - w: w - }); - }; - - if (w.config.chart.type === 'bubble') { - val = w.globals.seriesZ[i][dataPointIndex]; - text = getText(val); - y = pos.y[q]; - var scatter = new Scatter(this.ctx); - var centerTextInBubbleCoords = scatter.centerTextInBubble(y, i, dataPointIndex); - y = centerTextInBubbleCoords.y; - } else { - if (typeof val !== 'undefined') { - text = getText(val); - } - } - - this.plotDataLabelsText({ - x: x, - y: y, - text: text, - i: i, - j: dataPointIndex, - parent: elDataLabelsWrap, - offsetCorrection: true, - dataLabelsConfig: w.config.dataLabels - }); - } - } - - return elDataLabelsWrap; - } - }, { - key: "plotDataLabelsText", - value: function plotDataLabelsText(opts) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var x = opts.x, - y = opts.y, - i = opts.i, - j = opts.j, - text = opts.text, - textAnchor = opts.textAnchor, - fontSize = opts.fontSize, - parent = opts.parent, - dataLabelsConfig = opts.dataLabelsConfig, - color = opts.color, - alwaysDrawDataLabel = opts.alwaysDrawDataLabel, - offsetCorrection = opts.offsetCorrection; - - if (Array.isArray(w.config.dataLabels.enabledOnSeries)) { - if (w.config.dataLabels.enabledOnSeries.indexOf(i) < 0) { - return; - } - } - - var correctedLabels = { - x: x, - y: y, - drawnextLabel: true, - textRects: null - }; - - if (offsetCorrection) { - correctedLabels = this.dataLabelsCorrection(x, y, text, i, j, alwaysDrawDataLabel, parseInt(dataLabelsConfig.style.fontSize, 10)); - } // when zoomed, we don't need to correct labels offsets, - // but if normally, labels get cropped, correct them - - - if (!w.globals.zoomed) { - x = correctedLabels.x; - y = correctedLabels.y; - } - - if (correctedLabels.textRects) { - // fixes #2264 - if (x < -10 - correctedLabels.textRects.width || x > w.globals.gridWidth + correctedLabels.textRects.width + 10) { - // datalabels fall outside drawing area, so draw a blank label - text = ''; - } - } - - var dataLabelColor = w.globals.dataLabels.style.colors[i]; - - if ((w.config.chart.type === 'bar' || w.config.chart.type === 'rangeBar') && w.config.plotOptions.bar.distributed || w.config.dataLabels.distributed) { - dataLabelColor = w.globals.dataLabels.style.colors[j]; - } - - if (typeof dataLabelColor === 'function') { - dataLabelColor = dataLabelColor({ - series: w.globals.series, - seriesIndex: i, - dataPointIndex: j, - w: w - }); - } - - if (color) { - dataLabelColor = color; - } - - var offX = dataLabelsConfig.offsetX; - var offY = dataLabelsConfig.offsetY; - - if (w.config.chart.type === 'bar' || w.config.chart.type === 'rangeBar') { - // for certain chart types, we handle offsets while calculating datalabels pos - // why? because bars/column may have negative values and based on that - // offsets becomes reversed - offX = 0; - offY = 0; - } - - if (correctedLabels.drawnextLabel) { - var dataLabelText = graphics.drawText({ - width: 100, - height: parseInt(dataLabelsConfig.style.fontSize, 10), - x: x + offX, - y: y + offY, - foreColor: dataLabelColor, - textAnchor: textAnchor || dataLabelsConfig.textAnchor, - text: text, - fontSize: fontSize || dataLabelsConfig.style.fontSize, - fontFamily: dataLabelsConfig.style.fontFamily, - fontWeight: dataLabelsConfig.style.fontWeight || 'normal' - }); - dataLabelText.attr({ - class: 'apexcharts-datalabel', - cx: x, - cy: y - }); - - if (dataLabelsConfig.dropShadow.enabled) { - var textShadow = dataLabelsConfig.dropShadow; - var filters = new Filters(this.ctx); - filters.dropShadow(dataLabelText, textShadow); - } - - parent.add(dataLabelText); - - if (typeof w.globals.lastDrawnDataLabelsIndexes[i] === 'undefined') { - w.globals.lastDrawnDataLabelsIndexes[i] = []; - } - - w.globals.lastDrawnDataLabelsIndexes[i].push(j); - } - } - }, { - key: "addBackgroundToDataLabel", - value: function addBackgroundToDataLabel(el, coords) { - var w = this.w; - var bCnf = w.config.dataLabels.background; - var paddingH = bCnf.padding; - var paddingV = bCnf.padding / 2; - var width = coords.width; - var height = coords.height; - var graphics = new Graphics(this.ctx); - var elRect = graphics.drawRect(coords.x - paddingH, coords.y - paddingV / 2, width + paddingH * 2, height + paddingV, bCnf.borderRadius, w.config.chart.background === 'transparent' ? '#fff' : w.config.chart.background, bCnf.opacity, bCnf.borderWidth, bCnf.borderColor); - - if (bCnf.dropShadow.enabled) { - var filters = new Filters(this.ctx); - filters.dropShadow(elRect, bCnf.dropShadow); - } - - return elRect; - } - }, { - key: "dataLabelsBackground", - value: function dataLabelsBackground() { - var w = this.w; - if (w.config.chart.type === 'bubble') return; - var elDataLabels = w.globals.dom.baseEl.querySelectorAll('.apexcharts-datalabels text'); - - for (var i = 0; i < elDataLabels.length; i++) { - var el = elDataLabels[i]; - var coords = el.getBBox(); - var elRect = null; - - if (coords.width && coords.height) { - elRect = this.addBackgroundToDataLabel(el, coords); - } - - if (elRect) { - el.parentNode.insertBefore(elRect.node, el); - var background = el.getAttribute('fill'); - var shouldAnim = w.config.chart.animations.enabled && !w.globals.resized && !w.globals.dataChanged; - - if (shouldAnim) { - elRect.animate().attr({ - fill: background - }); - } else { - elRect.attr({ - fill: background - }); - } - - el.setAttribute('fill', w.config.dataLabels.background.foreColor); - } - } - } - }, { - key: "bringForward", - value: function bringForward() { - var w = this.w; - var elDataLabelsNodes = w.globals.dom.baseEl.querySelectorAll('.apexcharts-datalabels'); - var elSeries = w.globals.dom.baseEl.querySelector('.apexcharts-plot-series:last-child'); - - for (var i = 0; i < elDataLabelsNodes.length; i++) { - if (elSeries) { - elSeries.insertBefore(elDataLabelsNodes[i], elSeries.nextSibling); - } - } - } - }]); - - return DataLabels; - }(); - - /** - * ApexCharts Series Class for interaction with the Series of the chart. - * - * @module Series - **/ - - var Series = /*#__PURE__*/function () { - function Series(ctx) { - _classCallCheck(this, Series); - - this.ctx = ctx; - this.w = ctx.w; - this.legendInactiveClass = 'legend-mouseover-inactive'; - } - - _createClass(Series, [{ - key: "getAllSeriesEls", - value: function getAllSeriesEls() { - return this.w.globals.dom.baseEl.getElementsByClassName("apexcharts-series"); - } - }, { - key: "getSeriesByName", - value: function getSeriesByName(seriesName) { - return this.w.globals.dom.baseEl.querySelector(".apexcharts-inner .apexcharts-series[seriesName='".concat(Utils$1.escapeString(seriesName), "']")); - } - }, { - key: "isSeriesHidden", - value: function isSeriesHidden(seriesName) { - var targetElement = this.getSeriesByName(seriesName); - var realIndex = parseInt(targetElement.getAttribute('data:realIndex'), 10); - var isHidden = targetElement.classList.contains('apexcharts-series-collapsed'); - return { - isHidden: isHidden, - realIndex: realIndex - }; - } - }, { - key: "addCollapsedClassToSeries", - value: function addCollapsedClassToSeries(elSeries, index) { - var w = this.w; - - function iterateOnAllCollapsedSeries(series) { - for (var cs = 0; cs < series.length; cs++) { - if (series[cs].index === index) { - elSeries.node.classList.add('apexcharts-series-collapsed'); - } - } - } - - iterateOnAllCollapsedSeries(w.globals.collapsedSeries); - iterateOnAllCollapsedSeries(w.globals.ancillaryCollapsedSeries); - } - }, { - key: "toggleSeries", - value: function toggleSeries(seriesName) { - var isSeriesHidden = this.isSeriesHidden(seriesName); - this.ctx.legend.legendHelpers.toggleDataSeries(isSeriesHidden.realIndex, isSeriesHidden.isHidden); - return isSeriesHidden.isHidden; - } - }, { - key: "showSeries", - value: function showSeries(seriesName) { - var isSeriesHidden = this.isSeriesHidden(seriesName); - - if (isSeriesHidden.isHidden) { - this.ctx.legend.legendHelpers.toggleDataSeries(isSeriesHidden.realIndex, true); - } - } - }, { - key: "hideSeries", - value: function hideSeries(seriesName) { - var isSeriesHidden = this.isSeriesHidden(seriesName); - - if (!isSeriesHidden.isHidden) { - this.ctx.legend.legendHelpers.toggleDataSeries(isSeriesHidden.realIndex, false); - } - } - }, { - key: "resetSeries", - value: function resetSeries() { - var shouldUpdateChart = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; - var shouldResetZoom = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - var shouldResetCollapsed = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; - var w = this.w; - var series = Utils$1.clone(w.globals.initialSeries); - w.globals.previousPaths = []; - - if (shouldResetCollapsed) { - w.globals.collapsedSeries = []; - w.globals.ancillaryCollapsedSeries = []; - w.globals.collapsedSeriesIndices = []; - w.globals.ancillaryCollapsedSeriesIndices = []; - } else { - series = this.emptyCollapsedSeries(series); - } - - w.config.series = series; - - if (shouldUpdateChart) { - if (shouldResetZoom) { - w.globals.zoomed = false; - this.ctx.updateHelpers.revertDefaultAxisMinMax(); - } - - this.ctx.updateHelpers._updateSeries(series, w.config.chart.animations.dynamicAnimation.enabled); - } - } - }, { - key: "emptyCollapsedSeries", - value: function emptyCollapsedSeries(series) { - var w = this.w; - - for (var i = 0; i < series.length; i++) { - if (w.globals.collapsedSeriesIndices.indexOf(i) > -1) { - series[i].data = []; - } - } - - return series; - } - }, { - key: "toggleSeriesOnHover", - value: function toggleSeriesOnHover(e, targetElement) { - var w = this.w; - if (!targetElement) targetElement = e.target; - var allSeriesEls = w.globals.dom.baseEl.querySelectorAll(".apexcharts-series, .apexcharts-datalabels"); - - if (e.type === 'mousemove') { - var seriesCnt = parseInt(targetElement.getAttribute('rel'), 10) - 1; - var seriesEl = null; - var dataLabelEl = null; - - if (w.globals.axisCharts || w.config.chart.type === 'radialBar') { - if (w.globals.axisCharts) { - seriesEl = w.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(seriesCnt, "']")); - dataLabelEl = w.globals.dom.baseEl.querySelector(".apexcharts-datalabels[data\\:realIndex='".concat(seriesCnt, "']")); - } else { - seriesEl = w.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(seriesCnt + 1, "']")); - } - } else { - seriesEl = w.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(seriesCnt + 1, "'] path")); - } - - for (var se = 0; se < allSeriesEls.length; se++) { - allSeriesEls[se].classList.add(this.legendInactiveClass); - } - - if (seriesEl !== null) { - if (!w.globals.axisCharts) { - seriesEl.parentNode.classList.remove(this.legendInactiveClass); - } - - seriesEl.classList.remove(this.legendInactiveClass); - - if (dataLabelEl !== null) { - dataLabelEl.classList.remove(this.legendInactiveClass); - } - } - } else if (e.type === 'mouseout') { - for (var _se = 0; _se < allSeriesEls.length; _se++) { - allSeriesEls[_se].classList.remove(this.legendInactiveClass); - } - } - } - }, { - key: "highlightRangeInSeries", - value: function highlightRangeInSeries(e, targetElement) { - var _this = this; - - var w = this.w; - var allHeatMapElements = w.globals.dom.baseEl.getElementsByClassName('apexcharts-heatmap-rect'); - - var activeInactive = function activeInactive(action) { - for (var i = 0; i < allHeatMapElements.length; i++) { - allHeatMapElements[i].classList[action](_this.legendInactiveClass); - } - }; - - var removeInactiveClassFromHoveredRange = function removeInactiveClassFromHoveredRange(range) { - for (var i = 0; i < allHeatMapElements.length; i++) { - var val = parseInt(allHeatMapElements[i].getAttribute('val'), 10); - - if (val >= range.from && val <= range.to) { - allHeatMapElements[i].classList.remove(_this.legendInactiveClass); - } - } - }; - - if (e.type === 'mousemove') { - var seriesCnt = parseInt(targetElement.getAttribute('rel'), 10) - 1; - activeInactive('add'); - var range = w.config.plotOptions.heatmap.colorScale.ranges[seriesCnt]; - removeInactiveClassFromHoveredRange(range); - } else if (e.type === 'mouseout') { - activeInactive('remove'); - } - } - }, { - key: "getActiveConfigSeriesIndex", - value: function getActiveConfigSeriesIndex() { - var order = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'asc'; - var chartTypes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; - var w = this.w; - var activeIndex = 0; - - if (w.config.series.length > 1) { - // active series flag is required to know if user has not deactivated via legend click - var activeSeriesIndex = w.config.series.map(function (s, index) { - var checkChartType = function checkChartType() { - if (w.globals.comboCharts) { - return chartTypes.length === 0 || chartTypes.length && chartTypes.indexOf(w.config.series[index].type) > -1; - } - - return true; - }; - - var hasData = s.data && s.data.length > 0 && w.globals.collapsedSeriesIndices.indexOf(index) === -1; - return hasData && checkChartType() ? index : -1; - }); - - for (var a = order === 'asc' ? 0 : activeSeriesIndex.length - 1; order === 'asc' ? a < activeSeriesIndex.length : a >= 0; order === 'asc' ? a++ : a--) { - if (activeSeriesIndex[a] !== -1) { - activeIndex = activeSeriesIndex[a]; - break; - } - } - } - - return activeIndex; - } - }, { - key: "getBarSeriesIndices", - value: function getBarSeriesIndices() { - var w = this.w; - - if (w.globals.comboCharts) { - return this.w.config.series.map(function (s, i) { - return s.type === 'bar' || s.type === 'column' ? i : -1; - }).filter(function (i) { - return i !== -1; - }); - } - - return this.w.config.series.map(function (s, i) { - return i; - }); - } - }, { - key: "getPreviousPaths", - value: function getPreviousPaths() { - var w = this.w; - w.globals.previousPaths = []; - - function pushPaths(seriesEls, i, type) { - var paths = seriesEls[i].childNodes; - var dArr = { - type: type, - paths: [], - realIndex: seriesEls[i].getAttribute('data:realIndex') - }; - - for (var j = 0; j < paths.length; j++) { - if (paths[j].hasAttribute('pathTo')) { - var d = paths[j].getAttribute('pathTo'); - dArr.paths.push({ - d: d - }); - } - } - - w.globals.previousPaths.push(dArr); - } - - var getPaths = function getPaths(chartType) { - return w.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(chartType, "-series .apexcharts-series")); - }; - - var chartTypes = ['line', 'area', 'bar', 'rangebar', 'rangeArea', 'candlestick', 'radar']; - chartTypes.forEach(function (type) { - var paths = getPaths(type); - - for (var p = 0; p < paths.length; p++) { - pushPaths(paths, p, type); - } - }); - this.handlePrevBubbleScatterPaths('bubble'); - this.handlePrevBubbleScatterPaths('scatter'); - var heatTreeSeries = w.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(w.config.chart.type, " .apexcharts-series")); - - if (heatTreeSeries.length > 0) { - var _loop = function _loop(h) { - var seriesEls = w.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(w.config.chart.type, " .apexcharts-series[data\\:realIndex='").concat(h, "'] rect")); - var dArr = []; - - var _loop2 = function _loop2(i) { - var getAttr = function getAttr(x) { - return seriesEls[i].getAttribute(x); - }; - - var rect = { - x: parseFloat(getAttr('x')), - y: parseFloat(getAttr('y')), - width: parseFloat(getAttr('width')), - height: parseFloat(getAttr('height')) - }; - dArr.push({ - rect: rect, - color: seriesEls[i].getAttribute('color') - }); - }; - - for (var i = 0; i < seriesEls.length; i++) { - _loop2(i); - } - - w.globals.previousPaths.push(dArr); - }; - - for (var h = 0; h < heatTreeSeries.length; h++) { - _loop(h); - } - } - - if (!w.globals.axisCharts) { - // for non-axis charts (i.e., circular charts, pathFrom is not usable. We need whole series) - w.globals.previousPaths = w.globals.series; - } - } - }, { - key: "handlePrevBubbleScatterPaths", - value: function handlePrevBubbleScatterPaths(type) { - var w = this.w; - var paths = w.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(type, "-series .apexcharts-series")); - - if (paths.length > 0) { - for (var s = 0; s < paths.length; s++) { - var seriesEls = w.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(type, "-series .apexcharts-series[data\\:realIndex='").concat(s, "'] circle")); - var dArr = []; - - for (var i = 0; i < seriesEls.length; i++) { - dArr.push({ - x: seriesEls[i].getAttribute('cx'), - y: seriesEls[i].getAttribute('cy'), - r: seriesEls[i].getAttribute('r') - }); - } - - w.globals.previousPaths.push(dArr); - } - } - } - }, { - key: "clearPreviousPaths", - value: function clearPreviousPaths() { - var w = this.w; - w.globals.previousPaths = []; - w.globals.allSeriesCollapsed = false; - } - }, { - key: "handleNoData", - value: function handleNoData() { - var w = this.w; - var me = this; - var noDataOpts = w.config.noData; - var graphics = new Graphics(me.ctx); - var x = w.globals.svgWidth / 2; - var y = w.globals.svgHeight / 2; - var textAnchor = 'middle'; - w.globals.noData = true; - w.globals.animationEnded = true; - - if (noDataOpts.align === 'left') { - x = 10; - textAnchor = 'start'; - } else if (noDataOpts.align === 'right') { - x = w.globals.svgWidth - 10; - textAnchor = 'end'; - } - - if (noDataOpts.verticalAlign === 'top') { - y = 50; - } else if (noDataOpts.verticalAlign === 'bottom') { - y = w.globals.svgHeight - 50; - } - - x = x + noDataOpts.offsetX; - y = y + parseInt(noDataOpts.style.fontSize, 10) + 2 + noDataOpts.offsetY; - - if (noDataOpts.text !== undefined && noDataOpts.text !== '') { - var titleText = graphics.drawText({ - x: x, - y: y, - text: noDataOpts.text, - textAnchor: textAnchor, - fontSize: noDataOpts.style.fontSize, - fontFamily: noDataOpts.style.fontFamily, - foreColor: noDataOpts.style.color, - opacity: 1, - class: 'apexcharts-text-nodata' - }); - w.globals.dom.Paper.add(titleText); - } - } // When user clicks on legends, the collapsed series is filled with [0,0,0,...,0] - // This is because we don't want to alter the series' length as it is used at many places - - }, { - key: "setNullSeriesToZeroValues", - value: function setNullSeriesToZeroValues(series) { - var w = this.w; - - for (var sl = 0; sl < series.length; sl++) { - if (series[sl].length === 0) { - for (var j = 0; j < series[w.globals.maxValsInArrayIndex].length; j++) { - series[sl].push(0); - } - } - } - - return series; - } - }, { - key: "hasAllSeriesEqualX", - value: function hasAllSeriesEqualX() { - var equalLen = true; - var w = this.w; - var filteredSerX = this.filteredSeriesX(); - - for (var i = 0; i < filteredSerX.length - 1; i++) { - if (filteredSerX[i][0] !== filteredSerX[i + 1][0]) { - equalLen = false; - break; - } - } - - w.globals.allSeriesHasEqualX = equalLen; - return equalLen; - } - }, { - key: "filteredSeriesX", - value: function filteredSeriesX() { - var w = this.w; - var filteredSeriesX = w.globals.seriesX.map(function (ser) { - return ser.length > 0 ? ser : []; - }); - return filteredSeriesX; - } - }]); - - return Series; - }(); - - var Data = /*#__PURE__*/function () { - function Data(ctx) { - _classCallCheck(this, Data); - - this.ctx = ctx; - this.w = ctx.w; - this.twoDSeries = []; - this.threeDSeries = []; - this.twoDSeriesX = []; - this.seriesGoals = []; - this.coreUtils = new CoreUtils(this.ctx); - } - - _createClass(Data, [{ - key: "isMultiFormat", - value: function isMultiFormat() { - return this.isFormatXY() || this.isFormat2DArray(); - } // given format is [{x, y}, {x, y}] - - }, { - key: "isFormatXY", - value: function isFormatXY() { - var series = this.w.config.series.slice(); - var sr = new Series(this.ctx); - this.activeSeriesIndex = sr.getActiveConfigSeriesIndex(); - - if (typeof series[this.activeSeriesIndex].data !== 'undefined' && series[this.activeSeriesIndex].data.length > 0 && series[this.activeSeriesIndex].data[0] !== null && typeof series[this.activeSeriesIndex].data[0].x !== 'undefined' && series[this.activeSeriesIndex].data[0] !== null) { - return true; - } - } // given format is [[x, y], [x, y]] - - }, { - key: "isFormat2DArray", - value: function isFormat2DArray() { - var series = this.w.config.series.slice(); - var sr = new Series(this.ctx); - this.activeSeriesIndex = sr.getActiveConfigSeriesIndex(); - - if (typeof series[this.activeSeriesIndex].data !== 'undefined' && series[this.activeSeriesIndex].data.length > 0 && typeof series[this.activeSeriesIndex].data[0] !== 'undefined' && series[this.activeSeriesIndex].data[0] !== null && series[this.activeSeriesIndex].data[0].constructor === Array) { - return true; - } - } - }, { - key: "handleFormat2DArray", - value: function handleFormat2DArray(ser, i) { - var cnf = this.w.config; - var gl = this.w.globals; - var isBoxPlot = cnf.chart.type === 'boxPlot' || cnf.series[i].type === 'boxPlot'; - - for (var j = 0; j < ser[i].data.length; j++) { - if (typeof ser[i].data[j][1] !== 'undefined') { - if (Array.isArray(ser[i].data[j][1]) && ser[i].data[j][1].length === 4 && !isBoxPlot) { - // candlestick nested ohlc format - this.twoDSeries.push(Utils$1.parseNumber(ser[i].data[j][1][3])); - } else if (ser[i].data[j].length >= 5) { - // candlestick non-nested ohlc format - this.twoDSeries.push(Utils$1.parseNumber(ser[i].data[j][4])); - } else { - this.twoDSeries.push(Utils$1.parseNumber(ser[i].data[j][1])); - } - - gl.dataFormatXNumeric = true; - } - - if (cnf.xaxis.type === 'datetime') { - // if timestamps are provided and xaxis type is datetime, - var ts = new Date(ser[i].data[j][0]); - ts = new Date(ts).getTime(); - this.twoDSeriesX.push(ts); - } else { - this.twoDSeriesX.push(ser[i].data[j][0]); - } - } - - for (var _j = 0; _j < ser[i].data.length; _j++) { - if (typeof ser[i].data[_j][2] !== 'undefined') { - this.threeDSeries.push(ser[i].data[_j][2]); - gl.isDataXYZ = true; - } - } - } - }, { - key: "handleFormatXY", - value: function handleFormatXY(ser, i) { - var cnf = this.w.config; - var gl = this.w.globals; - var dt = new DateTime(this.ctx); - var activeI = i; - - if (gl.collapsedSeriesIndices.indexOf(i) > -1) { - // fix #368 - activeI = this.activeSeriesIndex; - } // get series - - - for (var j = 0; j < ser[i].data.length; j++) { - if (typeof ser[i].data[j].y !== 'undefined') { - if (Array.isArray(ser[i].data[j].y)) { - this.twoDSeries.push(Utils$1.parseNumber(ser[i].data[j].y[ser[i].data[j].y.length - 1])); - } else { - this.twoDSeries.push(Utils$1.parseNumber(ser[i].data[j].y)); - } - } - - if (typeof ser[i].data[j].goals !== 'undefined' && Array.isArray(ser[i].data[j].goals)) { - if (typeof this.seriesGoals[i] === 'undefined') { - this.seriesGoals[i] = []; - } - - this.seriesGoals[i].push(ser[i].data[j].goals); - } else { - if (typeof this.seriesGoals[i] === 'undefined') { - this.seriesGoals[i] = []; - } - - this.seriesGoals[i].push(null); - } - } // get seriesX - - - for (var _j2 = 0; _j2 < ser[activeI].data.length; _j2++) { - var isXString = typeof ser[activeI].data[_j2].x === 'string'; - var isXArr = Array.isArray(ser[activeI].data[_j2].x); - var isXDate = !isXArr && !!dt.isValidDate(ser[activeI].data[_j2].x.toString()); - - if (isXString || isXDate) { - // user supplied '01/01/2017' or a date string (a JS date object is not supported) - if (isXString || cnf.xaxis.convertedCatToNumeric) { - var isRangeColumn = gl.isBarHorizontal && gl.isRangeData; - - if (cnf.xaxis.type === 'datetime' && !isRangeColumn) { - this.twoDSeriesX.push(dt.parseDate(ser[activeI].data[_j2].x)); - } else { - // a category and not a numeric x value - this.fallbackToCategory = true; - this.twoDSeriesX.push(ser[activeI].data[_j2].x); - } - } else { - if (cnf.xaxis.type === 'datetime') { - this.twoDSeriesX.push(dt.parseDate(ser[activeI].data[_j2].x.toString())); - } else { - gl.dataFormatXNumeric = true; - gl.isXNumeric = true; - this.twoDSeriesX.push(parseFloat(ser[activeI].data[_j2].x)); - } - } - } else if (isXArr) { - // a multiline label described in array format - this.fallbackToCategory = true; - this.twoDSeriesX.push(ser[activeI].data[_j2].x); - } else { - // a numeric value in x property - gl.isXNumeric = true; - gl.dataFormatXNumeric = true; - this.twoDSeriesX.push(ser[activeI].data[_j2].x); - } - } - - if (ser[i].data[0] && typeof ser[i].data[0].z !== 'undefined') { - for (var t = 0; t < ser[i].data.length; t++) { - this.threeDSeries.push(ser[i].data[t].z); - } - - gl.isDataXYZ = true; - } - } - }, { - key: "handleRangeData", - value: function handleRangeData(ser, i) { - var gl = this.w.globals; - var range = {}; - - if (this.isFormat2DArray()) { - range = this.handleRangeDataFormat('array', ser, i); - } else if (this.isFormatXY()) { - range = this.handleRangeDataFormat('xy', ser, i); - } - - gl.seriesRangeStart.push(range.start); - gl.seriesRangeEnd.push(range.end); - gl.seriesRange.push(range.rangeUniques); // check for overlaps to avoid clashes in a timeline chart - - gl.seriesRange.forEach(function (sr, si) { - if (sr) { - sr.forEach(function (sarr, sarri) { - sarr.y.forEach(function (arr, arri) { - for (var sri = 0; sri < sarr.y.length; sri++) { - if (arri !== sri) { - var range1y1 = arr.y1; - var range1y2 = arr.y2; - var range2y1 = sarr.y[sri].y1; - var range2y2 = sarr.y[sri].y2; - - if (range1y1 <= range2y2 && range2y1 <= range1y2) { - if (sarr.overlaps.indexOf(arr.rangeName) < 0) { - sarr.overlaps.push(arr.rangeName); - } - - if (sarr.overlaps.indexOf(sarr.y[sri].rangeName) < 0) { - sarr.overlaps.push(sarr.y[sri].rangeName); - } - } - } - } - }); - }); - } - }); - return range; - } - }, { - key: "handleCandleStickBoxData", - value: function handleCandleStickBoxData(ser, i) { - var gl = this.w.globals; - var ohlc = {}; - - if (this.isFormat2DArray()) { - ohlc = this.handleCandleStickBoxDataFormat('array', ser, i); - } else if (this.isFormatXY()) { - ohlc = this.handleCandleStickBoxDataFormat('xy', ser, i); - } - - gl.seriesCandleO[i] = ohlc.o; - gl.seriesCandleH[i] = ohlc.h; - gl.seriesCandleM[i] = ohlc.m; - gl.seriesCandleL[i] = ohlc.l; - gl.seriesCandleC[i] = ohlc.c; - return ohlc; - } - }, { - key: "handleRangeDataFormat", - value: function handleRangeDataFormat(format, ser, i) { - var rangeStart = []; - var rangeEnd = []; - var uniqueKeys = ser[i].data.filter(function (thing, index, self) { - return index === self.findIndex(function (t) { - return t.x === thing.x; - }); - }).map(function (r, index) { - return { - x: r.x, - overlaps: [], - y: [] - }; - }); - - if (format === 'array') { - for (var j = 0; j < ser[i].data.length; j++) { - if (Array.isArray(ser[i].data[j])) { - rangeStart.push(ser[i].data[j][1][0]); - rangeEnd.push(ser[i].data[j][1][1]); - } else { - rangeStart.push(ser[i].data[j]); - rangeEnd.push(ser[i].data[j]); - } - } - } else if (format === 'xy') { - var _loop = function _loop(_j3) { - var isDataPoint2D = Array.isArray(ser[i].data[_j3].y); - var id = Utils$1.randomId(); - var x = ser[i].data[_j3].x; - var y = { - y1: isDataPoint2D ? ser[i].data[_j3].y[0] : ser[i].data[_j3].y, - y2: isDataPoint2D ? ser[i].data[_j3].y[1] : ser[i].data[_j3].y, - rangeName: id - }; // mutating config object by adding a new property - // TODO: As this is specifically for timeline rangebar charts, update the docs mentioning the series only supports xy format - - ser[i].data[_j3].rangeName = id; - var uI = uniqueKeys.findIndex(function (t) { - return t.x === x; - }); - uniqueKeys[uI].y.push(y); - rangeStart.push(y.y1); - rangeEnd.push(y.y2); - }; - - for (var _j3 = 0; _j3 < ser[i].data.length; _j3++) { - _loop(_j3); - } - } - - return { - start: rangeStart, - end: rangeEnd, - rangeUniques: uniqueKeys - }; - } - }, { - key: "handleCandleStickBoxDataFormat", - value: function handleCandleStickBoxDataFormat(format, ser, i) { - var w = this.w; - var isBoxPlot = w.config.chart.type === 'boxPlot' || w.config.series[i].type === 'boxPlot'; - var serO = []; - var serH = []; - var serM = []; - var serL = []; - var serC = []; - - if (format === 'array') { - if (isBoxPlot && ser[i].data[0].length === 6 || !isBoxPlot && ser[i].data[0].length === 5) { - for (var j = 0; j < ser[i].data.length; j++) { - serO.push(ser[i].data[j][1]); - serH.push(ser[i].data[j][2]); - - if (isBoxPlot) { - serM.push(ser[i].data[j][3]); - serL.push(ser[i].data[j][4]); - serC.push(ser[i].data[j][5]); - } else { - serL.push(ser[i].data[j][3]); - serC.push(ser[i].data[j][4]); - } - } - } else { - for (var _j4 = 0; _j4 < ser[i].data.length; _j4++) { - if (Array.isArray(ser[i].data[_j4][1])) { - serO.push(ser[i].data[_j4][1][0]); - serH.push(ser[i].data[_j4][1][1]); - - if (isBoxPlot) { - serM.push(ser[i].data[_j4][1][2]); - serL.push(ser[i].data[_j4][1][3]); - serC.push(ser[i].data[_j4][1][4]); - } else { - serL.push(ser[i].data[_j4][1][2]); - serC.push(ser[i].data[_j4][1][3]); - } - } - } - } - } else if (format === 'xy') { - for (var _j5 = 0; _j5 < ser[i].data.length; _j5++) { - if (Array.isArray(ser[i].data[_j5].y)) { - serO.push(ser[i].data[_j5].y[0]); - serH.push(ser[i].data[_j5].y[1]); - - if (isBoxPlot) { - serM.push(ser[i].data[_j5].y[2]); - serL.push(ser[i].data[_j5].y[3]); - serC.push(ser[i].data[_j5].y[4]); - } else { - serL.push(ser[i].data[_j5].y[2]); - serC.push(ser[i].data[_j5].y[3]); - } - } - } - } - - return { - o: serO, - h: serH, - m: serM, - l: serL, - c: serC - }; - } - }, { - key: "parseDataAxisCharts", - value: function parseDataAxisCharts(ser) { - var _ser$, - _this = this; - - var ctx = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.ctx; - var cnf = this.w.config; - var gl = this.w.globals; - var dt = new DateTime(ctx); - var xlabels = cnf.labels.length > 0 ? cnf.labels.slice() : cnf.xaxis.categories.slice(); - gl.isRangeBar = cnf.chart.type === 'rangeBar' && gl.isBarHorizontal; - gl.hasXaxisGroups = cnf.xaxis.type === 'category' && cnf.xaxis.group.groups.length > 0; - - if (gl.hasXaxisGroups) { - gl.groups = cnf.xaxis.group.groups; - } - - gl.hasSeriesGroups = (_ser$ = ser[0]) === null || _ser$ === void 0 ? void 0 : _ser$.group; - - if (gl.hasSeriesGroups) { - var buckets = []; - - var groups = _toConsumableArray(new Set(ser.map(function (s) { - return s.group; - }))); - - ser.forEach(function (s, i) { - var index = groups.indexOf(s.group); - if (!buckets[index]) buckets[index] = []; - buckets[index].push(s.name); - }); - gl.seriesGroups = buckets; - } - - var handleDates = function handleDates() { - for (var j = 0; j < xlabels.length; j++) { - if (typeof xlabels[j] === 'string') { - // user provided date strings - var isDate = dt.isValidDate(xlabels[j]); - - if (isDate) { - _this.twoDSeriesX.push(dt.parseDate(xlabels[j])); - } else { - throw new Error('You have provided invalid Date format. Please provide a valid JavaScript Date'); - } - } else { - // user provided timestamps - _this.twoDSeriesX.push(xlabels[j]); - } - } - }; - - for (var i = 0; i < ser.length; i++) { - this.twoDSeries = []; - this.twoDSeriesX = []; - this.threeDSeries = []; - - if (typeof ser[i].data === 'undefined') { - console.error("It is a possibility that you may have not included 'data' property in series."); - return; - } - - if (cnf.chart.type === 'rangeBar' || cnf.chart.type === 'rangeArea' || ser[i].type === 'rangeBar' || ser[i].type === 'rangeArea') { - gl.isRangeData = true; - - if (gl.isComboCharts) { - if (ser[i].type === 'rangeBar' || ser[i].type === 'rangeArea') { - this.handleRangeData(ser, i); - } - } else if (cnf.chart.type === 'rangeBar' || cnf.chart.type === 'rangeArea') { - this.handleRangeData(ser, i); - } - } - - if (this.isMultiFormat()) { - if (this.isFormat2DArray()) { - this.handleFormat2DArray(ser, i); - } else if (this.isFormatXY()) { - this.handleFormatXY(ser, i); - } - - if (cnf.chart.type === 'candlestick' || ser[i].type === 'candlestick' || cnf.chart.type === 'boxPlot' || ser[i].type === 'boxPlot') { - this.handleCandleStickBoxData(ser, i); - } - - gl.series.push(this.twoDSeries); - gl.labels.push(this.twoDSeriesX); - gl.seriesX.push(this.twoDSeriesX); - gl.seriesGoals = this.seriesGoals; - - if (i === this.activeSeriesIndex && !this.fallbackToCategory) { - gl.isXNumeric = true; - } - } else { - if (cnf.xaxis.type === 'datetime') { - // user didn't supplied [{x,y}] or [[x,y]], but single array in data. - // Also labels/categories were supplied differently - gl.isXNumeric = true; - handleDates(); - gl.seriesX.push(this.twoDSeriesX); - } else if (cnf.xaxis.type === 'numeric') { - gl.isXNumeric = true; - - if (xlabels.length > 0) { - this.twoDSeriesX = xlabels; - gl.seriesX.push(this.twoDSeriesX); - } - } - - gl.labels.push(this.twoDSeriesX); - var singleArray = ser[i].data.map(function (d) { - return Utils$1.parseNumber(d); - }); - gl.series.push(singleArray); - } - - gl.seriesZ.push(this.threeDSeries); - - if (ser[i].name !== undefined) { - gl.seriesNames.push(ser[i].name); - } else { - gl.seriesNames.push('series-' + parseInt(i + 1, 10)); - } // overrided default color if user inputs color with series data - - - if (ser[i].color !== undefined) { - gl.seriesColors.push(ser[i].color); - } else { - gl.seriesColors.push(undefined); - } - } - - return this.w; - } - }, { - key: "parseDataNonAxisCharts", - value: function parseDataNonAxisCharts(ser) { - var gl = this.w.globals; - var cnf = this.w.config; - gl.series = ser.slice(); - gl.seriesNames = cnf.labels.slice(); - - for (var i = 0; i < gl.series.length; i++) { - if (gl.seriesNames[i] === undefined) { - gl.seriesNames.push('series-' + (i + 1)); - } - } - - return this.w; - } - /** User possibly set string categories in xaxis.categories or labels prop - * Or didn't set xaxis labels at all - in which case we manually do it. - * If user passed series data as [[3, 2], [4, 5]] or [{ x: 3, y: 55 }], - * this shouldn't be called - * @param {array} ser - the series which user passed to the config - */ - - }, { - key: "handleExternalLabelsData", - value: function handleExternalLabelsData(ser) { - var cnf = this.w.config; - var gl = this.w.globals; - - if (cnf.xaxis.categories.length > 0) { - // user provided labels in xaxis.category prop - gl.labels = cnf.xaxis.categories; - } else if (cnf.labels.length > 0) { - // user provided labels in labels props - gl.labels = cnf.labels.slice(); - } else if (this.fallbackToCategory) { - // user provided labels in x prop in [{ x: 3, y: 55 }] data, and those labels are already stored in gl.labels[0], so just re-arrange the gl.labels array - gl.labels = gl.labels[0]; - - if (gl.seriesRange.length) { - gl.seriesRange.map(function (srt) { - srt.forEach(function (sr) { - if (gl.labels.indexOf(sr.x) < 0 && sr.x) { - gl.labels.push(sr.x); - } - }); - }); - gl.labels = gl.labels.filter(function (elem, pos, arr) { - return arr.indexOf(elem) === pos; - }); - } - - if (cnf.xaxis.convertedCatToNumeric) { - var defaults = new Defaults(cnf); - defaults.convertCatToNumericXaxis(cnf, this.ctx, gl.seriesX[0]); - - this._generateExternalLabels(ser); - } - } else { - this._generateExternalLabels(ser); - } - } - }, { - key: "_generateExternalLabels", - value: function _generateExternalLabels(ser) { - var gl = this.w.globals; - var cnf = this.w.config; // user didn't provided any labels, fallback to 1-2-3-4-5 - - var labelArr = []; - - if (gl.axisCharts) { - if (gl.series.length > 0) { - if (this.isFormatXY()) { - // in case there is a combo chart (boxplot/scatter) - // and there are duplicated x values, we need to eliminate duplicates - var seriesDataFiltered = cnf.series.map(function (serie, s) { - return serie.data.filter(function (v, i, a) { - return a.findIndex(function (t) { - return t.x === v.x; - }) === i; - }); - }); - var len = seriesDataFiltered.reduce(function (p, c, i, a) { - return a[p].length > c.length ? p : i; - }, 0); - - for (var i = 0; i < seriesDataFiltered[len].length; i++) { - labelArr.push(i + 1); - } - } else { - for (var _i = 0; _i < gl.series[gl.maxValsInArrayIndex].length; _i++) { - labelArr.push(_i + 1); - } - } - } - - gl.seriesX = []; // create gl.seriesX as it will be used in calculations of x positions - - for (var _i2 = 0; _i2 < ser.length; _i2++) { - gl.seriesX.push(labelArr); - } // turn on the isXNumeric flag to allow minX and maxX to function properly - - - gl.isXNumeric = true; - } // no series to pull labels from, put a 0-10 series - // possibly, user collapsed all series. Hence we can't work with above calc - - - if (labelArr.length === 0) { - labelArr = gl.axisCharts ? [] : gl.series.map(function (gls, glsi) { - return glsi + 1; - }); - - for (var _i3 = 0; _i3 < ser.length; _i3++) { - gl.seriesX.push(labelArr); - } - } // Finally, pass the labelArr in gl.labels which will be printed on x-axis - - - gl.labels = labelArr; - - if (cnf.xaxis.convertedCatToNumeric) { - gl.categoryLabels = labelArr.map(function (l) { - return cnf.xaxis.labels.formatter(l); - }); - } // Turn on this global flag to indicate no labels were provided by user - - - gl.noLabelsProvided = true; - } // Segregate user provided data into appropriate vars - - }, { - key: "parseData", - value: function parseData(ser) { - var w = this.w; - var cnf = w.config; - var gl = w.globals; - this.excludeCollapsedSeriesInYAxis(); // If we detected string in X prop of series, we fallback to category x-axis - - this.fallbackToCategory = false; - this.ctx.core.resetGlobals(); - this.ctx.core.isMultipleY(); - - if (gl.axisCharts) { - // axisCharts includes line / area / column / scatter - this.parseDataAxisCharts(ser); - this.coreUtils.getLargestSeries(); - } else { - // non-axis charts are pie / donut - this.parseDataNonAxisCharts(ser); - } // set Null values to 0 in all series when user hides/shows some series - - - if (cnf.chart.type === 'bar' && cnf.chart.stacked) { - var series = new Series(this.ctx); - gl.series = series.setNullSeriesToZeroValues(gl.series); - } - - this.coreUtils.getSeriesTotals(); - - if (gl.axisCharts) { - gl.stackedSeriesTotals = this.coreUtils.getStackedSeriesTotals(); - } - - this.coreUtils.getPercentSeries(); - - if (!gl.dataFormatXNumeric && (!gl.isXNumeric || cnf.xaxis.type === 'numeric' && cnf.labels.length === 0 && cnf.xaxis.categories.length === 0)) { - // x-axis labels couldn't be detected; hence try searching every option in config - this.handleExternalLabelsData(ser); - } // check for multiline xaxis - - - var catLabels = this.coreUtils.getCategoryLabels(gl.labels); - - for (var l = 0; l < catLabels.length; l++) { - if (Array.isArray(catLabels[l])) { - gl.isMultiLineX = true; - break; - } - } - } - }, { - key: "excludeCollapsedSeriesInYAxis", - value: function excludeCollapsedSeriesInYAxis() { - var _this2 = this; - - var w = this.w; - w.globals.ignoreYAxisIndexes = w.globals.collapsedSeries.map(function (collapsed, i) { - // fix issue #1215 - // if stacked, not returning collapsed.index to preserve yaxis - if (_this2.w.globals.isMultipleYAxis && !w.config.chart.stacked) { - return collapsed.index; - } - }); - } - }]); - - return Data; - }(); - - var AxesUtils = /*#__PURE__*/function () { - function AxesUtils(ctx) { - _classCallCheck(this, AxesUtils); - - this.ctx = ctx; - this.w = ctx.w; - } // Based on the formatter function, get the label text and position - - - _createClass(AxesUtils, [{ - key: "getLabel", - value: function getLabel(labels, timescaleLabels, x, i) { - var drawnLabels = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : []; - var fontSize = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : '12px'; - var isLeafGroup = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : true; - var w = this.w; - var rawLabel = typeof labels[i] === 'undefined' ? '' : labels[i]; - var label = rawLabel; - var xlbFormatter = w.globals.xLabelFormatter; - var customFormatter = w.config.xaxis.labels.formatter; - var isBold = false; - var xFormat = new Formatters(this.ctx); - var timestamp = rawLabel; - - if (isLeafGroup) { - label = xFormat.xLabelFormat(xlbFormatter, rawLabel, timestamp, { - i: i, - dateFormatter: new DateTime(this.ctx).formatDate, - w: w - }); - - if (customFormatter !== undefined) { - label = customFormatter(rawLabel, labels[i], { - i: i, - dateFormatter: new DateTime(this.ctx).formatDate, - w: w - }); - } - } - - var determineHighestUnit = function determineHighestUnit(unit) { - var highestUnit = null; - timescaleLabels.forEach(function (t) { - if (t.unit === 'month') { - highestUnit = 'year'; - } else if (t.unit === 'day') { - highestUnit = 'month'; - } else if (t.unit === 'hour') { - highestUnit = 'day'; - } else if (t.unit === 'minute') { - highestUnit = 'hour'; - } - }); - return highestUnit === unit; - }; - - if (timescaleLabels.length > 0) { - isBold = determineHighestUnit(timescaleLabels[i].unit); - x = timescaleLabels[i].position; - label = timescaleLabels[i].value; - } else { - if (w.config.xaxis.type === 'datetime' && customFormatter === undefined) { - label = ''; - } - } - - if (typeof label === 'undefined') label = ''; - label = Array.isArray(label) ? label : label.toString(); - var graphics = new Graphics(this.ctx); - var textRect = {}; - - if (w.globals.rotateXLabels && isLeafGroup) { - textRect = graphics.getTextRects(label, parseInt(fontSize, 10), null, "rotate(".concat(w.config.xaxis.labels.rotate, " 0 0)"), false); - } else { - textRect = graphics.getTextRects(label, parseInt(fontSize, 10)); - } - - var allowDuplicatesInTimeScale = !w.config.xaxis.labels.showDuplicates && this.ctx.timeScale; - - if (!Array.isArray(label) && (label.indexOf('NaN') === 0 || label.toLowerCase().indexOf('invalid') === 0 || label.toLowerCase().indexOf('infinity') >= 0 || drawnLabels.indexOf(label) >= 0 && allowDuplicatesInTimeScale)) { - label = ''; - } - - return { - x: x, - text: label, - textRect: textRect, - isBold: isBold - }; - } - }, { - key: "checkLabelBasedOnTickamount", - value: function checkLabelBasedOnTickamount(i, label, labelsLen) { - var w = this.w; - var ticks = w.config.xaxis.tickAmount; - if (ticks === 'dataPoints') ticks = Math.round(w.globals.gridWidth / 120); - if (ticks > labelsLen) return label; - var tickMultiple = Math.round(labelsLen / (ticks + 1)); - - if (i % tickMultiple === 0) { - return label; - } else { - label.text = ''; - } - - return label; - } - }, { - key: "checkForOverflowingLabels", - value: function checkForOverflowingLabels(i, label, labelsLen, drawnLabels, drawnLabelsRects) { - var w = this.w; - - if (i === 0) { - // check if first label is being truncated - if (w.globals.skipFirstTimelinelabel) { - label.text = ''; - } - } - - if (i === labelsLen - 1) { - // check if last label is being truncated - if (w.globals.skipLastTimelinelabel) { - label.text = ''; - } - } - - if (w.config.xaxis.labels.hideOverlappingLabels && drawnLabels.length > 0) { - var prev = drawnLabelsRects[drawnLabelsRects.length - 1]; - - if (label.x < prev.textRect.width / (w.globals.rotateXLabels ? Math.abs(w.config.xaxis.labels.rotate) / 12 : 1.01) + prev.x) { - label.text = ''; - } - } - - return label; - } - }, { - key: "checkForReversedLabels", - value: function checkForReversedLabels(i, labels) { - var w = this.w; - - if (w.config.yaxis[i] && w.config.yaxis[i].reversed) { - labels.reverse(); - } - - return labels; - } - }, { - key: "isYAxisHidden", - value: function isYAxisHidden(index) { - var w = this.w; - var coreUtils = new CoreUtils(this.ctx); - return !w.config.yaxis[index].show || !w.config.yaxis[index].showForNullSeries && coreUtils.isSeriesNull(index) && w.globals.collapsedSeriesIndices.indexOf(index) === -1; - } // get the label color for y-axis - // realIndex is the actual series index, while i is the tick Index - - }, { - key: "getYAxisForeColor", - value: function getYAxisForeColor(yColors, realIndex) { - var w = this.w; - - if (Array.isArray(yColors) && w.globals.yAxisScale[realIndex]) { - this.ctx.theme.pushExtraColors(yColors, w.globals.yAxisScale[realIndex].result.length, false); - } - - return yColors; - } - }, { - key: "drawYAxisTicks", - value: function drawYAxisTicks(x, tickAmount, axisBorder, axisTicks, realIndex, labelsDivider, elYaxis) { - var w = this.w; - var graphics = new Graphics(this.ctx); // initial label position = 0; - - var t = w.globals.translateY; - - if (axisTicks.show && tickAmount > 0) { - if (w.config.yaxis[realIndex].opposite === true) x = x + axisTicks.width; - - for (var i = tickAmount; i >= 0; i--) { - var tY = t + tickAmount / 10 + w.config.yaxis[realIndex].labels.offsetY - 1; - - if (w.globals.isBarHorizontal) { - tY = labelsDivider * i; - } - - if (w.config.chart.type === 'heatmap') { - tY = tY + labelsDivider / 2; - } - - var elTick = graphics.drawLine(x + axisBorder.offsetX - axisTicks.width + axisTicks.offsetX, tY + axisTicks.offsetY, x + axisBorder.offsetX + axisTicks.offsetX, tY + axisTicks.offsetY, axisTicks.color); - elYaxis.add(elTick); - t = t + labelsDivider; - } - } - } - }]); - - return AxesUtils; - }(); - - var Exports = /*#__PURE__*/function () { - function Exports(ctx) { - _classCallCheck(this, Exports); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(Exports, [{ - key: "scaleSvgNode", - value: function scaleSvgNode(svg, scale) { - // get current both width and height of the svg - var svgWidth = parseFloat(svg.getAttributeNS(null, 'width')); - var svgHeight = parseFloat(svg.getAttributeNS(null, 'height')); // set new width and height based on the scale - - svg.setAttributeNS(null, 'width', svgWidth * scale); - svg.setAttributeNS(null, 'height', svgHeight * scale); - svg.setAttributeNS(null, 'viewBox', '0 0 ' + svgWidth + ' ' + svgHeight); - } - }, { - key: "fixSvgStringForIe11", - value: function fixSvgStringForIe11(svgData) { - // IE11 generates broken SVG that we have to fix by using regex - if (!Utils$1.isIE11()) { - // not IE11 - noop - return svgData.replace(/ /g, ' '); - } // replace second occurrence of "xmlns" attribute with "xmlns:xlink" with correct url + add xmlns:svgjs - - - var nXmlnsSeen = 0; - var result = svgData.replace(/xmlns="http:\/\/www.w3.org\/2000\/svg"/g, function (match) { - nXmlnsSeen++; - return nXmlnsSeen === 2 ? 'xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:svgjs="http://svgjs.dev"' : match; - }); // remove the invalid empty namespace declarations - - result = result.replace(/xmlns:NS\d+=""/g, ''); // remove these broken namespaces from attributes - - result = result.replace(/NS\d+:(\w+:\w+=")/g, '$1'); - return result; - } - }, { - key: "getSvgString", - value: function getSvgString(scale) { - if (scale == undefined) { - scale = 1; // if no scale is specified, don't scale... - } - - var svgString = this.w.globals.dom.Paper.svg(); // in case the scale is different than 1, the svg needs to be rescaled - - if (scale !== 1) { - // clone the svg node so it remains intact in the UI - var svgNode = this.w.globals.dom.Paper.node.cloneNode(true); // scale the image - - this.scaleSvgNode(svgNode, scale); // get the string representation of the svgNode - - svgString = new XMLSerializer().serializeToString(svgNode); - } - - return this.fixSvgStringForIe11(svgString); - } - }, { - key: "cleanup", - value: function cleanup() { - var w = this.w; // hide some elements to avoid printing them on exported svg - - var xcrosshairs = w.globals.dom.baseEl.getElementsByClassName('apexcharts-xcrosshairs'); - var ycrosshairs = w.globals.dom.baseEl.getElementsByClassName('apexcharts-ycrosshairs'); - var zoomSelectionRects = w.globals.dom.baseEl.querySelectorAll('.apexcharts-zoom-rect, .apexcharts-selection-rect'); - Array.prototype.forEach.call(zoomSelectionRects, function (z) { - z.setAttribute('width', 0); - }); - - if (xcrosshairs && xcrosshairs[0]) { - xcrosshairs[0].setAttribute('x', -500); - xcrosshairs[0].setAttribute('x1', -500); - xcrosshairs[0].setAttribute('x2', -500); - } - - if (ycrosshairs && ycrosshairs[0]) { - ycrosshairs[0].setAttribute('y', -100); - ycrosshairs[0].setAttribute('y1', -100); - ycrosshairs[0].setAttribute('y2', -100); - } - } - }, { - key: "svgUrl", - value: function svgUrl() { - this.cleanup(); - var svgData = this.getSvgString(); - var svgBlob = new Blob([svgData], { - type: 'image/svg+xml;charset=utf-8' - }); - return URL.createObjectURL(svgBlob); - } - }, { - key: "dataURI", - value: function dataURI(options) { - var _this = this; - - return new Promise(function (resolve) { - var w = _this.w; - var scale = options ? options.scale || options.width / w.globals.svgWidth : 1; - - _this.cleanup(); - - var canvas = document.createElement('canvas'); - canvas.width = w.globals.svgWidth * scale; - canvas.height = parseInt(w.globals.dom.elWrap.style.height, 10) * scale; // because of resizeNonAxisCharts - - var canvasBg = w.config.chart.background === 'transparent' ? '#fff' : w.config.chart.background; - var ctx = canvas.getContext('2d'); - ctx.fillStyle = canvasBg; - ctx.fillRect(0, 0, canvas.width * scale, canvas.height * scale); - - var svgData = _this.getSvgString(scale); - - if (window.canvg && Utils$1.isIE11()) { - // use canvg as a polyfill to workaround ie11 considering a canvas with loaded svg 'unsafe' - // without ignoreClear we lose our background color; without ignoreDimensions some grid lines become invisible - var v = window.canvg.Canvg.fromString(ctx, svgData, { - ignoreClear: true, - ignoreDimensions: true - }); // render the svg to canvas - - v.start(); - var blob = canvas.msToBlob(); // dispose - missing this will cause a memory leak - - v.stop(); - resolve({ - blob: blob - }); - } else { - var svgUrl = 'data:image/svg+xml,' + encodeURIComponent(svgData); - var img = new Image(); - img.crossOrigin = 'anonymous'; - - img.onload = function () { - ctx.drawImage(img, 0, 0); - - if (canvas.msToBlob) { - // IE and Edge can't navigate to data urls, so we return the blob instead - var _blob = canvas.msToBlob(); - - resolve({ - blob: _blob - }); - } else { - var imgURI = canvas.toDataURL('image/png'); - resolve({ - imgURI: imgURI - }); - } - }; - - img.src = svgUrl; - } - }); - } - }, { - key: "exportToSVG", - value: function exportToSVG() { - this.triggerDownload(this.svgUrl(), this.w.config.chart.toolbar.export.svg.filename, '.svg'); - } - }, { - key: "exportToPng", - value: function exportToPng() { - var _this2 = this; - - this.dataURI().then(function (_ref) { - var imgURI = _ref.imgURI, - blob = _ref.blob; - - if (blob) { - navigator.msSaveOrOpenBlob(blob, _this2.w.globals.chartID + '.png'); - } else { - _this2.triggerDownload(imgURI, _this2.w.config.chart.toolbar.export.png.filename, '.png'); - } - }); - } - }, { - key: "exportToCSV", - value: function exportToCSV(_ref2) { - var _this3 = this; - - var series = _ref2.series, - fileName = _ref2.fileName, - _ref2$columnDelimiter = _ref2.columnDelimiter, - columnDelimiter = _ref2$columnDelimiter === void 0 ? ',' : _ref2$columnDelimiter, - _ref2$lineDelimiter = _ref2.lineDelimiter, - lineDelimiter = _ref2$lineDelimiter === void 0 ? '\n' : _ref2$lineDelimiter; - var w = this.w; - if (!series) series = w.config.series; - var columns = []; - var rows = []; - var result = ''; - var universalBOM = "\uFEFF"; - var gSeries = w.globals.series.map(function (s, i) { - return w.globals.collapsedSeriesIndices.indexOf(i) === -1 ? s : []; - }); - - var isTimeStamp = function isTimeStamp(num) { - return w.config.xaxis.type === 'datetime' && String(num).length >= 10; - }; - - var seriesMaxDataLength = Math.max.apply(Math, _toConsumableArray(series.map(function (s) { - return s.data ? s.data.length : 0; - }))); - var dataFormat = new Data(this.ctx); - var axesUtils = new AxesUtils(this.ctx); - - var getCat = function getCat(i) { - var cat = ''; // pie / donut/ radial - - if (!w.globals.axisCharts) { - cat = w.config.labels[i]; - } else { - // xy charts - // non datetime - if (w.config.xaxis.type === 'category' || w.config.xaxis.convertedCatToNumeric) { - if (w.globals.isBarHorizontal) { - var lbFormatter = w.globals.yLabelFormatters[0]; - var sr = new Series(_this3.ctx); - var activeSeries = sr.getActiveConfigSeriesIndex(); - cat = lbFormatter(w.globals.labels[i], { - seriesIndex: activeSeries, - dataPointIndex: i, - w: w - }); - } else { - cat = axesUtils.getLabel(w.globals.labels, w.globals.timescaleLabels, 0, i).text; - } - } // datetime, but labels specified in categories or labels - - - if (w.config.xaxis.type === 'datetime') { - if (w.config.xaxis.categories.length) { - cat = w.config.xaxis.categories[i]; - } else if (w.config.labels.length) { - cat = w.config.labels[i]; - } - } - } - - if (Array.isArray(cat)) { - cat = cat.join(' '); - } - - return Utils$1.isNumber(cat) ? cat : cat.split(columnDelimiter).join(''); - }; // Fix https://github.com/apexcharts/apexcharts.js/issues/3365 - - - var getEmptyDataForCsvColumn = function getEmptyDataForCsvColumn() { - return _toConsumableArray(Array(seriesMaxDataLength)).map(function () { - return ''; - }); - }; - - var handleAxisRowsColumns = function handleAxisRowsColumns(s, sI) { - if (columns.length && sI === 0) { - // It's the first series. Go ahead and create the first row with header information. - rows.push(columns.join(columnDelimiter)); - } - - if (s.data) { - // Use the data we have, or generate a properly sized empty array with empty data if some data is missing. - s.data = s.data.length && s.data || getEmptyDataForCsvColumn(); - - for (var i = 0; i < s.data.length; i++) { - // Reset the columns array so that we can start building columns for this row. - columns = []; - var cat = getCat(i); - - if (!cat) { - if (dataFormat.isFormatXY()) { - cat = series[sI].data[i].x; - } else if (dataFormat.isFormat2DArray()) { - cat = series[sI].data[i] ? series[sI].data[i][0] : ''; - } - } - - if (sI === 0) { - // It's the first series. Also handle the category. - columns.push(isTimeStamp(cat) ? w.config.chart.toolbar.export.csv.dateFormatter(cat) : Utils$1.isNumber(cat) ? cat : cat.split(columnDelimiter).join('')); - - for (var ci = 0; ci < w.globals.series.length; ci++) { - if (dataFormat.isFormatXY()) { - columns.push(series[ci].data[i].y); - } else { - columns.push(gSeries[ci][i]); - } - } - } - - if (w.config.chart.type === 'candlestick' || s.type && s.type === 'candlestick') { - columns.pop(); - columns.push(w.globals.seriesCandleO[sI][i]); - columns.push(w.globals.seriesCandleH[sI][i]); - columns.push(w.globals.seriesCandleL[sI][i]); - columns.push(w.globals.seriesCandleC[sI][i]); - } - - if (w.config.chart.type === 'boxPlot' || s.type && s.type === 'boxPlot') { - columns.pop(); - columns.push(w.globals.seriesCandleO[sI][i]); - columns.push(w.globals.seriesCandleH[sI][i]); - columns.push(w.globals.seriesCandleM[sI][i]); - columns.push(w.globals.seriesCandleL[sI][i]); - columns.push(w.globals.seriesCandleC[sI][i]); - } - - if (w.config.chart.type === 'rangeBar') { - columns.pop(); - columns.push(w.globals.seriesRangeStart[sI][i]); - columns.push(w.globals.seriesRangeEnd[sI][i]); - } - - if (columns.length) { - rows.push(columns.join(columnDelimiter)); - } - } - } - }; - - columns.push(w.config.chart.toolbar.export.csv.headerCategory); - - if (w.config.chart.type === 'boxPlot') { - columns.push('minimum'); - columns.push('q1'); - columns.push('median'); - columns.push('q3'); - columns.push('maximum'); - } else if (w.config.chart.type === 'candlestick') { - columns.push('open'); - columns.push('high'); - columns.push('low'); - columns.push('close'); - } else if (w.config.chart.type === 'rangeBar') { - columns.push('minimum'); - columns.push('maximum'); - } else { - series.map(function (s, sI) { - var sname = s.name ? s.name : "series-".concat(sI); - - if (w.globals.axisCharts) { - columns.push(sname.split(columnDelimiter).join('') ? sname.split(columnDelimiter).join('') : "series-".concat(sI)); - } - }); - } - - if (!w.globals.axisCharts) { - columns.push(w.config.chart.toolbar.export.csv.headerValue); - rows.push(columns.join(columnDelimiter)); - } - - series.map(function (s, sI) { - if (w.globals.axisCharts) { - handleAxisRowsColumns(s, sI); - } else { - columns = []; - columns.push(w.globals.labels[sI].split(columnDelimiter).join('')); - columns.push(gSeries[sI]); - rows.push(columns.join(columnDelimiter)); - } - }); - result += rows.join(lineDelimiter); - this.triggerDownload('data:text/csv; charset=utf-8,' + encodeURIComponent(universalBOM + result), fileName ? fileName : w.config.chart.toolbar.export.csv.filename, '.csv'); - } - }, { - key: "triggerDownload", - value: function triggerDownload(href, filename, ext) { - var downloadLink = document.createElement('a'); - downloadLink.href = href; - downloadLink.download = (filename ? filename : this.w.globals.chartID) + ext; - document.body.appendChild(downloadLink); - downloadLink.click(); - document.body.removeChild(downloadLink); - } - }]); - - return Exports; - }(); - - /** - * ApexCharts XAxis Class for drawing X-Axis. - * - * @module XAxis - **/ - - var XAxis = /*#__PURE__*/function () { - function XAxis(ctx, elgrid) { - _classCallCheck(this, XAxis); - - this.ctx = ctx; - this.elgrid = elgrid; - this.w = ctx.w; - var w = this.w; - this.axesUtils = new AxesUtils(ctx); - this.xaxisLabels = w.globals.labels.slice(); - - if (w.globals.timescaleLabels.length > 0 && !w.globals.isBarHorizontal) { - // timeline labels are there and chart is not rangeabr timeline - this.xaxisLabels = w.globals.timescaleLabels.slice(); - } - - if (w.config.xaxis.overwriteCategories) { - this.xaxisLabels = w.config.xaxis.overwriteCategories; - } - - this.drawnLabels = []; - this.drawnLabelsRects = []; - - if (w.config.xaxis.position === 'top') { - this.offY = 0; - } else { - this.offY = w.globals.gridHeight + 1; - } - - this.offY = this.offY + w.config.xaxis.axisBorder.offsetY; - this.isCategoryBarHorizontal = w.config.chart.type === 'bar' && w.config.plotOptions.bar.horizontal; - this.xaxisFontSize = w.config.xaxis.labels.style.fontSize; - this.xaxisFontFamily = w.config.xaxis.labels.style.fontFamily; - this.xaxisForeColors = w.config.xaxis.labels.style.colors; - this.xaxisBorderWidth = w.config.xaxis.axisBorder.width; - - if (this.isCategoryBarHorizontal) { - this.xaxisBorderWidth = w.config.yaxis[0].axisBorder.width.toString(); - } - - if (this.xaxisBorderWidth.indexOf('%') > -1) { - this.xaxisBorderWidth = w.globals.gridWidth * parseInt(this.xaxisBorderWidth, 10) / 100; - } else { - this.xaxisBorderWidth = parseInt(this.xaxisBorderWidth, 10); - } - - this.xaxisBorderHeight = w.config.xaxis.axisBorder.height; // For bars, we will only consider single y xais, - // as we are not providing multiple yaxis for bar charts - - this.yaxis = w.config.yaxis[0]; - } - - _createClass(XAxis, [{ - key: "drawXaxis", - value: function drawXaxis() { - var w = this.w; - var graphics = new Graphics(this.ctx); - var elXaxis = graphics.group({ - class: 'apexcharts-xaxis', - transform: "translate(".concat(w.config.xaxis.offsetX, ", ").concat(w.config.xaxis.offsetY, ")") - }); - var elXaxisTexts = graphics.group({ - class: 'apexcharts-xaxis-texts-g', - transform: "translate(".concat(w.globals.translateXAxisX, ", ").concat(w.globals.translateXAxisY, ")") - }); - elXaxis.add(elXaxisTexts); - var labels = []; - - for (var i = 0; i < this.xaxisLabels.length; i++) { - labels.push(this.xaxisLabels[i]); - } - - this.drawXAxisLabelAndGroup(true, graphics, elXaxisTexts, labels, w.globals.isXNumeric, function (i, colWidth) { - return colWidth; - }); - - if (w.globals.hasXaxisGroups) { - var labelsGroup = w.globals.groups; - labels = []; - - for (var _i = 0; _i < labelsGroup.length; _i++) { - labels.push(labelsGroup[_i].title); - } - - var overwriteStyles = {}; - - if (w.config.xaxis.group.style) { - overwriteStyles.xaxisFontSize = w.config.xaxis.group.style.fontSize; - overwriteStyles.xaxisFontFamily = w.config.xaxis.group.style.fontFamily; - overwriteStyles.xaxisForeColors = w.config.xaxis.group.style.colors; - overwriteStyles.fontWeight = w.config.xaxis.group.style.fontWeight; - overwriteStyles.cssClass = w.config.xaxis.group.style.cssClass; - } - - this.drawXAxisLabelAndGroup(false, graphics, elXaxisTexts, labels, false, function (i, colWidth) { - return labelsGroup[i].cols * colWidth; - }, overwriteStyles); - } - - if (w.config.xaxis.title.text !== undefined) { - var elXaxisTitle = graphics.group({ - class: 'apexcharts-xaxis-title' - }); - var elXAxisTitleText = graphics.drawText({ - x: w.globals.gridWidth / 2 + w.config.xaxis.title.offsetX, - y: this.offY + parseFloat(this.xaxisFontSize) + (w.config.xaxis.position === 'bottom' ? w.globals.xAxisLabelsHeight : -w.globals.xAxisLabelsHeight - 10) + w.config.xaxis.title.offsetY, - text: w.config.xaxis.title.text, - textAnchor: 'middle', - fontSize: w.config.xaxis.title.style.fontSize, - fontFamily: w.config.xaxis.title.style.fontFamily, - fontWeight: w.config.xaxis.title.style.fontWeight, - foreColor: w.config.xaxis.title.style.color, - cssClass: 'apexcharts-xaxis-title-text ' + w.config.xaxis.title.style.cssClass - }); - elXaxisTitle.add(elXAxisTitleText); - elXaxis.add(elXaxisTitle); - } - - if (w.config.xaxis.axisBorder.show) { - var offX = w.globals.barPadForNumericAxis; - var elHorzLine = graphics.drawLine(w.globals.padHorizontal + w.config.xaxis.axisBorder.offsetX - offX, this.offY, this.xaxisBorderWidth + offX, this.offY, w.config.xaxis.axisBorder.color, 0, this.xaxisBorderHeight); - - if (this.elgrid && this.elgrid.elGridBorders && w.config.grid.show) { - this.elgrid.elGridBorders.add(elHorzLine); - } else { - elXaxis.add(elHorzLine); - } - } - - return elXaxis; - } - }, { - key: "drawXAxisLabelAndGroup", - value: function drawXAxisLabelAndGroup(isLeafGroup, graphics, elXaxisTexts, labels, isXNumeric, colWidthCb) { - var _this = this; - - var overwriteStyles = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : {}; - var drawnLabels = []; - var drawnLabelsRects = []; - var w = this.w; - var xaxisFontSize = overwriteStyles.xaxisFontSize || this.xaxisFontSize; - var xaxisFontFamily = overwriteStyles.xaxisFontFamily || this.xaxisFontFamily; - var xaxisForeColors = overwriteStyles.xaxisForeColors || this.xaxisForeColors; - var fontWeight = overwriteStyles.fontWeight || w.config.xaxis.labels.style.fontWeight; - var cssClass = overwriteStyles.cssClass || w.config.xaxis.labels.style.cssClass; - var colWidth; // initial x Position (keep adding column width in the loop) - - var xPos = w.globals.padHorizontal; - var labelsLen = labels.length; - /** - * labelsLen can be different (whether you are drawing x-axis labels or x-axis group labels) - * hence, we introduce dataPoints to be consistent. - * Also, in datetime/numeric xaxis, dataPoints can be misleading, so we resort to labelsLen for such xaxis type - */ - - var dataPoints = w.config.xaxis.type === 'category' ? w.globals.dataPoints : labelsLen; // when all series are collapsed, fixes #3381 - - if (dataPoints === 0 && labelsLen > dataPoints) dataPoints = labelsLen; - - if (isXNumeric) { - var len = dataPoints > 1 ? dataPoints - 1 : dataPoints; - colWidth = w.globals.gridWidth / len; - xPos = xPos + colWidthCb(0, colWidth) / 2 + w.config.xaxis.labels.offsetX; - } else { - colWidth = w.globals.gridWidth / dataPoints; - xPos = xPos + colWidthCb(0, colWidth) + w.config.xaxis.labels.offsetX; - } - - var _loop = function _loop(i) { - var x = xPos - colWidthCb(i, colWidth) / 2 + w.config.xaxis.labels.offsetX; - - if (i === 0 && labelsLen === 1 && colWidth / 2 === xPos && dataPoints === 1) { - // single datapoint - x = w.globals.gridWidth / 2; - } - - var label = _this.axesUtils.getLabel(labels, w.globals.timescaleLabels, x, i, drawnLabels, xaxisFontSize, isLeafGroup); - - var offsetYCorrection = 28; - - if (w.globals.rotateXLabels && isLeafGroup) { - offsetYCorrection = 22; - } - - if (w.config.xaxis.title.text && w.config.xaxis.position === 'top') { - offsetYCorrection += parseFloat(w.config.xaxis.title.style.fontSize) + 2; - } - - if (!isLeafGroup) { - offsetYCorrection = offsetYCorrection + parseFloat(xaxisFontSize) + (w.globals.xAxisLabelsHeight - w.globals.xAxisGroupLabelsHeight) + (w.globals.rotateXLabels ? 10 : 0); - } - - var isCategoryTickAmounts = typeof w.config.xaxis.tickAmount !== 'undefined' && w.config.xaxis.tickAmount !== 'dataPoints' && w.config.xaxis.type !== 'datetime'; - - if (isCategoryTickAmounts) { - label = _this.axesUtils.checkLabelBasedOnTickamount(i, label, labelsLen); - } else { - label = _this.axesUtils.checkForOverflowingLabels(i, label, labelsLen, drawnLabels, drawnLabelsRects); - } - - var getCatForeColor = function getCatForeColor() { - return isLeafGroup && w.config.xaxis.convertedCatToNumeric ? xaxisForeColors[w.globals.minX + i - 1] : xaxisForeColors[i]; - }; - - if (w.config.xaxis.labels.show) { - var elText = graphics.drawText({ - x: label.x, - y: _this.offY + w.config.xaxis.labels.offsetY + offsetYCorrection - (w.config.xaxis.position === 'top' ? w.globals.xAxisHeight + w.config.xaxis.axisTicks.height - 2 : 0), - text: label.text, - textAnchor: 'middle', - fontWeight: label.isBold ? 600 : fontWeight, - fontSize: xaxisFontSize, - fontFamily: xaxisFontFamily, - foreColor: Array.isArray(xaxisForeColors) ? getCatForeColor() : xaxisForeColors, - isPlainText: false, - cssClass: (isLeafGroup ? 'apexcharts-xaxis-label ' : 'apexcharts-xaxis-group-label ') + cssClass - }); - elXaxisTexts.add(elText); - elText.on('click', function (e) { - if (typeof w.config.chart.events.xAxisLabelClick === 'function') { - var opts = Object.assign({}, w, { - labelIndex: i - }); - w.config.chart.events.xAxisLabelClick(e, _this.ctx, opts); - } - }); - - if (isLeafGroup) { - var elTooltipTitle = document.createElementNS(w.globals.SVGNS, 'title'); - elTooltipTitle.textContent = Array.isArray(label.text) ? label.text.join(' ') : label.text; - elText.node.appendChild(elTooltipTitle); - - if (label.text !== '') { - drawnLabels.push(label.text); - drawnLabelsRects.push(label); - } - } - } - - if (i < labelsLen - 1) { - xPos = xPos + colWidthCb(i + 1, colWidth); - } - }; - - for (var i = 0; i <= labelsLen - 1; i++) { - _loop(i); - } - } // this actually becomes the vertical axis (for bar charts) - - }, { - key: "drawXaxisInversed", - value: function drawXaxisInversed(realIndex) { - var _this2 = this; - - var w = this.w; - var graphics = new Graphics(this.ctx); - var translateYAxisX = w.config.yaxis[0].opposite ? w.globals.translateYAxisX[realIndex] : 0; - var elYaxis = graphics.group({ - class: 'apexcharts-yaxis apexcharts-xaxis-inversed', - rel: realIndex - }); - var elYaxisTexts = graphics.group({ - class: 'apexcharts-yaxis-texts-g apexcharts-xaxis-inversed-texts-g', - transform: 'translate(' + translateYAxisX + ', 0)' - }); - elYaxis.add(elYaxisTexts); - var colHeight; // initial x Position (keep adding column width in the loop) - - var yPos; - var labels = []; - - if (w.config.yaxis[realIndex].show) { - for (var i = 0; i < this.xaxisLabels.length; i++) { - labels.push(this.xaxisLabels[i]); - } - } - - colHeight = w.globals.gridHeight / labels.length; - yPos = -(colHeight / 2.2); - var lbFormatter = w.globals.yLabelFormatters[0]; - var ylabels = w.config.yaxis[0].labels; - - if (ylabels.show) { - var _loop2 = function _loop2(_i2) { - var label = typeof labels[_i2] === 'undefined' ? '' : labels[_i2]; - label = lbFormatter(label, { - seriesIndex: realIndex, - dataPointIndex: _i2, - w: w - }); - - var yColors = _this2.axesUtils.getYAxisForeColor(ylabels.style.colors, realIndex); - - var getForeColor = function getForeColor() { - return Array.isArray(yColors) ? yColors[_i2] : yColors; - }; - - var multiY = 0; - - if (Array.isArray(label)) { - multiY = label.length / 2 * parseInt(ylabels.style.fontSize, 10); - } - - var offsetX = ylabels.offsetX - 15; - var textAnchor = 'end'; - - if (_this2.yaxis.opposite) { - textAnchor = 'start'; - } - - if (w.config.yaxis[0].labels.align === 'left') { - offsetX = ylabels.offsetX; - textAnchor = 'start'; - } else if (w.config.yaxis[0].labels.align === 'center') { - offsetX = ylabels.offsetX; - textAnchor = 'middle'; - } else if (w.config.yaxis[0].labels.align === 'right') { - textAnchor = 'end'; - } - - var elLabel = graphics.drawText({ - x: offsetX, - y: yPos + colHeight + ylabels.offsetY - multiY, - text: label, - textAnchor: textAnchor, - foreColor: getForeColor(), - fontSize: ylabels.style.fontSize, - fontFamily: ylabels.style.fontFamily, - fontWeight: ylabels.style.fontWeight, - isPlainText: false, - cssClass: 'apexcharts-yaxis-label ' + ylabels.style.cssClass, - maxWidth: ylabels.maxWidth - }); - elYaxisTexts.add(elLabel); - elLabel.on('click', function (e) { - if (typeof w.config.chart.events.xAxisLabelClick === 'function') { - var opts = Object.assign({}, w, { - labelIndex: _i2 - }); - w.config.chart.events.xAxisLabelClick(e, _this2.ctx, opts); - } - }); - var elTooltipTitle = document.createElementNS(w.globals.SVGNS, 'title'); - elTooltipTitle.textContent = Array.isArray(label) ? label.join(' ') : label; - elLabel.node.appendChild(elTooltipTitle); - - if (w.config.yaxis[realIndex].labels.rotate !== 0) { - var labelRotatingCenter = graphics.rotateAroundCenter(elLabel.node); - elLabel.node.setAttribute('transform', "rotate(".concat(w.config.yaxis[realIndex].labels.rotate, " 0 ").concat(labelRotatingCenter.y, ")")); - } - - yPos = yPos + colHeight; - }; - - for (var _i2 = 0; _i2 <= labels.length - 1; _i2++) { - _loop2(_i2); - } - } - - if (w.config.yaxis[0].title.text !== undefined) { - var elXaxisTitle = graphics.group({ - class: 'apexcharts-yaxis-title apexcharts-xaxis-title-inversed', - transform: 'translate(' + translateYAxisX + ', 0)' - }); - var elXAxisTitleText = graphics.drawText({ - x: w.config.yaxis[0].title.offsetX, - y: w.globals.gridHeight / 2 + w.config.yaxis[0].title.offsetY, - text: w.config.yaxis[0].title.text, - textAnchor: 'middle', - foreColor: w.config.yaxis[0].title.style.color, - fontSize: w.config.yaxis[0].title.style.fontSize, - fontWeight: w.config.yaxis[0].title.style.fontWeight, - fontFamily: w.config.yaxis[0].title.style.fontFamily, - cssClass: 'apexcharts-yaxis-title-text ' + w.config.yaxis[0].title.style.cssClass - }); - elXaxisTitle.add(elXAxisTitleText); - elYaxis.add(elXaxisTitle); - } - - var offX = 0; - - if (this.isCategoryBarHorizontal && w.config.yaxis[0].opposite) { - offX = w.globals.gridWidth; - } - - var axisBorder = w.config.xaxis.axisBorder; - - if (axisBorder.show) { - var elVerticalLine = graphics.drawLine(w.globals.padHorizontal + axisBorder.offsetX + offX, 1 + axisBorder.offsetY, w.globals.padHorizontal + axisBorder.offsetX + offX, w.globals.gridHeight + axisBorder.offsetY, axisBorder.color, 0); - - if (this.elgrid && this.elgrid.elGridBorders && w.config.grid.show) { - this.elgrid.elGridBorders.add(elVerticalLine); - } else { - elYaxis.add(elVerticalLine); - } - } - - if (w.config.yaxis[0].axisTicks.show) { - this.axesUtils.drawYAxisTicks(offX, labels.length, w.config.yaxis[0].axisBorder, w.config.yaxis[0].axisTicks, 0, colHeight, elYaxis); - } - - return elYaxis; - } - }, { - key: "drawXaxisTicks", - value: function drawXaxisTicks(x1, y2, appendToElement) { - var w = this.w; - var x2 = x1; - if (x1 < 0 || x1 - 2 > w.globals.gridWidth) return; - var y1 = this.offY + w.config.xaxis.axisTicks.offsetY; - y2 = y2 + y1 + w.config.xaxis.axisTicks.height; - - if (w.config.xaxis.position === 'top') { - y2 = y1 - w.config.xaxis.axisTicks.height; - } - - if (w.config.xaxis.axisTicks.show) { - var graphics = new Graphics(this.ctx); - var line = graphics.drawLine(x1 + w.config.xaxis.axisTicks.offsetX, y1 + w.config.xaxis.offsetY, x2 + w.config.xaxis.axisTicks.offsetX, y2 + w.config.xaxis.offsetY, w.config.xaxis.axisTicks.color); // we are not returning anything, but appending directly to the element passed in param - - appendToElement.add(line); - line.node.classList.add('apexcharts-xaxis-tick'); - } - } - }, { - key: "getXAxisTicksPositions", - value: function getXAxisTicksPositions() { - var w = this.w; - var xAxisTicksPositions = []; - var xCount = this.xaxisLabels.length; - var x1 = w.globals.padHorizontal; - - if (w.globals.timescaleLabels.length > 0) { - for (var i = 0; i < xCount; i++) { - x1 = this.xaxisLabels[i].position; - xAxisTicksPositions.push(x1); - } - } else { - var xCountForCategoryCharts = xCount; - - for (var _i3 = 0; _i3 < xCountForCategoryCharts; _i3++) { - var x1Count = xCountForCategoryCharts; - - if (w.globals.isXNumeric && w.config.chart.type !== 'bar') { - x1Count -= 1; - } - - x1 = x1 + w.globals.gridWidth / x1Count; - xAxisTicksPositions.push(x1); - } - } - - return xAxisTicksPositions; - } // to rotate x-axis labels or to put ... for longer text in xaxis - - }, { - key: "xAxisLabelCorrections", - value: function xAxisLabelCorrections() { - var w = this.w; - var graphics = new Graphics(this.ctx); - var xAxis = w.globals.dom.baseEl.querySelector('.apexcharts-xaxis-texts-g'); - var xAxisTexts = w.globals.dom.baseEl.querySelectorAll('.apexcharts-xaxis-texts-g text:not(.apexcharts-xaxis-group-label)'); - var yAxisTextsInversed = w.globals.dom.baseEl.querySelectorAll('.apexcharts-yaxis-inversed text'); - var xAxisTextsInversed = w.globals.dom.baseEl.querySelectorAll('.apexcharts-xaxis-inversed-texts-g text tspan'); - - if (w.globals.rotateXLabels || w.config.xaxis.labels.rotateAlways) { - for (var xat = 0; xat < xAxisTexts.length; xat++) { - var textRotatingCenter = graphics.rotateAroundCenter(xAxisTexts[xat]); - textRotatingCenter.y = textRotatingCenter.y - 1; // + tickWidth/4; - - textRotatingCenter.x = textRotatingCenter.x + 1; - xAxisTexts[xat].setAttribute('transform', "rotate(".concat(w.config.xaxis.labels.rotate, " ").concat(textRotatingCenter.x, " ").concat(textRotatingCenter.y, ")")); - xAxisTexts[xat].setAttribute('text-anchor', "end"); - var offsetHeight = 10; - xAxis.setAttribute('transform', "translate(0, ".concat(-offsetHeight, ")")); - var tSpan = xAxisTexts[xat].childNodes; - - if (w.config.xaxis.labels.trim) { - Array.prototype.forEach.call(tSpan, function (ts) { - graphics.placeTextWithEllipsis(ts, ts.textContent, w.globals.xAxisLabelsHeight - (w.config.legend.position === 'bottom' ? 20 : 10)); - }); - } - } - } else { - (function () { - var width = w.globals.gridWidth / (w.globals.labels.length + 1); - - for (var _xat = 0; _xat < xAxisTexts.length; _xat++) { - var _tSpan = xAxisTexts[_xat].childNodes; - - if (w.config.xaxis.labels.trim && w.config.xaxis.type !== 'datetime') { - Array.prototype.forEach.call(_tSpan, function (ts) { - graphics.placeTextWithEllipsis(ts, ts.textContent, width); - }); - } - } - })(); - } - - if (yAxisTextsInversed.length > 0) { - // truncate rotated y axis in bar chart (x axis) - var firstLabelPosX = yAxisTextsInversed[yAxisTextsInversed.length - 1].getBBox(); - var lastLabelPosX = yAxisTextsInversed[0].getBBox(); - - if (firstLabelPosX.x < -20) { - yAxisTextsInversed[yAxisTextsInversed.length - 1].parentNode.removeChild(yAxisTextsInversed[yAxisTextsInversed.length - 1]); - } - - if (lastLabelPosX.x + lastLabelPosX.width > w.globals.gridWidth && !w.globals.isBarHorizontal) { - yAxisTextsInversed[0].parentNode.removeChild(yAxisTextsInversed[0]); - } // truncate rotated x axis in bar chart (y axis) - - - for (var _xat2 = 0; _xat2 < xAxisTextsInversed.length; _xat2++) { - graphics.placeTextWithEllipsis(xAxisTextsInversed[_xat2], xAxisTextsInversed[_xat2].textContent, w.config.yaxis[0].labels.maxWidth - (w.config.yaxis[0].title.text ? parseFloat(w.config.yaxis[0].title.style.fontSize) * 2 : 0) - 15); - } - } - } // renderXAxisBands() { - // let w = this.w; - // let plotBand = document.createElementNS(w.globals.SVGNS, 'rect') - // w.globals.dom.elGraphical.add(plotBand) - // } - - }]); - - return XAxis; - }(); - - /** - * ApexCharts Grid Class for drawing Cartesian Grid. - * - * @module Grid - **/ - - var Grid = /*#__PURE__*/function () { - function Grid(ctx) { - _classCallCheck(this, Grid); - - this.ctx = ctx; - this.w = ctx.w; - var w = this.w; - this.xaxisLabels = w.globals.labels.slice(); - this.axesUtils = new AxesUtils(ctx); - this.isRangeBar = w.globals.seriesRange.length; - - if (w.globals.timescaleLabels.length > 0) { - // timescaleLabels labels are there - this.xaxisLabels = w.globals.timescaleLabels.slice(); - } - } // when using sparklines or when showing no grid, we need to have a grid area which is reused at many places for other calculations as well - - - _createClass(Grid, [{ - key: "drawGridArea", - value: function drawGridArea() { - var elGrid = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - var w = this.w; - var graphics = new Graphics(this.ctx); - - if (elGrid === null) { - elGrid = graphics.group({ - class: 'apexcharts-grid' - }); - } - - var elVerticalLine = graphics.drawLine(w.globals.padHorizontal, 1, w.globals.padHorizontal, w.globals.gridHeight, 'transparent'); - var elHorzLine = graphics.drawLine(w.globals.padHorizontal, w.globals.gridHeight, w.globals.gridWidth, w.globals.gridHeight, 'transparent'); - elGrid.add(elHorzLine); - elGrid.add(elVerticalLine); - return elGrid; - } - }, { - key: "drawGrid", - value: function drawGrid() { - var gl = this.w.globals; - var elgrid = null; - - if (gl.axisCharts) { - // grid is drawn after xaxis and yaxis are drawn - elgrid = this.renderGrid(); - this.drawGridArea(elgrid.el); - } - - return elgrid; - } // This mask will clip off overflowing graphics from the drawable area - - }, { - key: "createGridMask", - value: function createGridMask() { - var w = this.w; - var gl = w.globals; - var graphics = new Graphics(this.ctx); - var strokeSize = Array.isArray(w.config.stroke.width) ? 0 : w.config.stroke.width; - - if (Array.isArray(w.config.stroke.width)) { - var strokeMaxSize = 0; - w.config.stroke.width.forEach(function (m) { - strokeMaxSize = Math.max(strokeMaxSize, m); - }); - strokeSize = strokeMaxSize; - } - - gl.dom.elGridRectMask = document.createElementNS(gl.SVGNS, 'clipPath'); - gl.dom.elGridRectMask.setAttribute('id', "gridRectMask".concat(gl.cuid)); - gl.dom.elGridRectMarkerMask = document.createElementNS(gl.SVGNS, 'clipPath'); - gl.dom.elGridRectMarkerMask.setAttribute('id', "gridRectMarkerMask".concat(gl.cuid)); - gl.dom.elForecastMask = document.createElementNS(gl.SVGNS, 'clipPath'); - gl.dom.elForecastMask.setAttribute('id', "forecastMask".concat(gl.cuid)); - gl.dom.elNonForecastMask = document.createElementNS(gl.SVGNS, 'clipPath'); - gl.dom.elNonForecastMask.setAttribute('id', "nonForecastMask".concat(gl.cuid)); // let barHalfWidth = 0 - - var type = w.config.chart.type; - var hasBar = type === 'bar' || type === 'rangeBar' || type === 'candlestick' || type === 'boxPlot' || w.globals.comboBarCount > 0; - var barWidthLeft = 0; - var barWidthRight = 0; - - if (hasBar && w.globals.isXNumeric && !w.globals.isBarHorizontal) { - barWidthLeft = w.config.grid.padding.left; - barWidthRight = w.config.grid.padding.right; - - if (gl.barPadForNumericAxis > barWidthLeft) { - barWidthLeft = gl.barPadForNumericAxis; - barWidthRight = gl.barPadForNumericAxis; - } - } - - gl.dom.elGridRect = graphics.drawRect(-strokeSize / 2 - barWidthLeft - 2, -strokeSize / 2, gl.gridWidth + strokeSize + barWidthRight + barWidthLeft + 4, gl.gridHeight + strokeSize, 0, '#fff'); - var markerSize = w.globals.markers.largestSize + 1; - gl.dom.elGridRectMarker = graphics.drawRect(-markerSize * 2, -markerSize * 2, gl.gridWidth + markerSize * 4, gl.gridHeight + markerSize * 4, 0, '#fff'); - gl.dom.elGridRectMask.appendChild(gl.dom.elGridRect.node); - gl.dom.elGridRectMarkerMask.appendChild(gl.dom.elGridRectMarker.node); - var defs = gl.dom.baseEl.querySelector('defs'); - defs.appendChild(gl.dom.elGridRectMask); - defs.appendChild(gl.dom.elForecastMask); - defs.appendChild(gl.dom.elNonForecastMask); - defs.appendChild(gl.dom.elGridRectMarkerMask); - } - }, { - key: "_drawGridLines", - value: function _drawGridLines(_ref) { - var i = _ref.i, - x1 = _ref.x1, - y1 = _ref.y1, - x2 = _ref.x2, - y2 = _ref.y2, - xCount = _ref.xCount, - parent = _ref.parent; - var w = this.w; - - var shouldDraw = function shouldDraw() { - if (i === 0 && w.globals.skipFirstTimelinelabel) { - return false; - } - - if (i === xCount - 1 && w.globals.skipLastTimelinelabel && !w.config.xaxis.labels.formatter) { - return false; - } - - if (w.config.chart.type === 'radar') { - return false; - } - - return true; - }; - - if (shouldDraw()) { - if (w.config.grid.xaxis.lines.show) { - this._drawGridLine({ - i: i, - x1: x1, - y1: y1, - x2: x2, - y2: y2, - xCount: xCount, - parent: parent - }); - } - - var y_2 = 0; - - if (w.globals.hasXaxisGroups && w.config.xaxis.tickPlacement === 'between') { - var groups = w.globals.groups; - - if (groups) { - var gacc = 0; - - for (var gi = 0; gacc < i && gi < groups.length; gi++) { - gacc += groups[gi].cols; - } - - if (gacc === i) { - y_2 = w.globals.xAxisLabelsHeight * 0.6; - } - } - } - - var xAxis = new XAxis(this.ctx); - xAxis.drawXaxisTicks(x1, y_2, w.globals.dom.elGraphical); - } - } - }, { - key: "_drawGridLine", - value: function _drawGridLine(_ref2) { - var i = _ref2.i, - x1 = _ref2.x1, - y1 = _ref2.y1, - x2 = _ref2.x2, - y2 = _ref2.y2, - xCount = _ref2.xCount, - parent = _ref2.parent; - var w = this.w; - var excludeBorders = false; - var isHorzLine = parent.node.classList.contains('apexcharts-gridlines-horizontal'); - var strokeDashArray = w.config.grid.strokeDashArray; - var offX = w.globals.barPadForNumericAxis; - - if (y1 === 0 && y2 === 0 || x1 === 0 && x2 === 0) { - excludeBorders = true; - } - - if (y1 === w.globals.gridHeight && y2 === w.globals.gridHeight) { - excludeBorders = true; - } - - if (w.globals.isBarHorizontal && (i === 0 || i === xCount - 1)) { - excludeBorders = true; - } - - var graphics = new Graphics(this); - var line = graphics.drawLine(x1 - (isHorzLine ? offX : 0), y1, x2 + (isHorzLine ? offX : 0), y2, w.config.grid.borderColor, strokeDashArray); - line.node.classList.add('apexcharts-gridline'); - - if (excludeBorders && w.config.grid.show) { - this.elGridBorders.add(line); - } else { - parent.add(line); - } - } - }, { - key: "_drawGridBandRect", - value: function _drawGridBandRect(_ref3) { - var c = _ref3.c, - x1 = _ref3.x1, - y1 = _ref3.y1, - x2 = _ref3.x2, - y2 = _ref3.y2, - type = _ref3.type; - var w = this.w; - var graphics = new Graphics(this.ctx); - var offX = w.globals.barPadForNumericAxis; - if (type === 'column' && w.config.xaxis.type === 'datetime') return; - var color = w.config.grid[type].colors[c]; - var rect = graphics.drawRect(x1 - (type === 'row' ? offX : 0), y1, x2 + (type === 'row' ? offX * 2 : 0), y2, 0, color, w.config.grid[type].opacity); - this.elg.add(rect); - rect.attr('clip-path', "url(#gridRectMask".concat(w.globals.cuid, ")")); - rect.node.classList.add("apexcharts-grid-".concat(type)); - } - }, { - key: "_drawXYLines", - value: function _drawXYLines(_ref4) { - var _this = this; - - var xCount = _ref4.xCount, - tickAmount = _ref4.tickAmount; - var w = this.w; - - var datetimeLines = function datetimeLines(_ref5) { - var xC = _ref5.xC, - x1 = _ref5.x1, - y1 = _ref5.y1, - x2 = _ref5.x2, - y2 = _ref5.y2; - - for (var i = 0; i < xC; i++) { - x1 = _this.xaxisLabels[i].position; - x2 = _this.xaxisLabels[i].position; - - _this._drawGridLines({ - i: i, - x1: x1, - y1: y1, - x2: x2, - y2: y2, - xCount: xCount, - parent: _this.elgridLinesV - }); - } - }; - - var categoryLines = function categoryLines(_ref6) { - var xC = _ref6.xC, - x1 = _ref6.x1, - y1 = _ref6.y1, - x2 = _ref6.x2, - y2 = _ref6.y2; - - for (var i = 0; i < xC + (w.globals.isXNumeric ? 0 : 1); i++) { - if (i === 0 && xC === 1 && w.globals.dataPoints === 1) { - // single datapoint - x1 = w.globals.gridWidth / 2; - x2 = x1; - } - - _this._drawGridLines({ - i: i, - x1: x1, - y1: y1, - x2: x2, - y2: y2, - xCount: xCount, - parent: _this.elgridLinesV - }); - - x1 = x1 + w.globals.gridWidth / (w.globals.isXNumeric ? xC - 1 : xC); - x2 = x1; - } - }; // draw vertical lines - - - if (w.config.grid.xaxis.lines.show || w.config.xaxis.axisTicks.show) { - var x1 = w.globals.padHorizontal; - var y1 = 0; - var x2; - var y2 = w.globals.gridHeight; - - if (w.globals.timescaleLabels.length) { - datetimeLines({ - xC: xCount, - x1: x1, - y1: y1, - x2: x2, - y2: y2 - }); - } else { - if (w.globals.isXNumeric) { - xCount = w.globals.xAxisScale.result.length; - } - - categoryLines({ - xC: xCount, - x1: x1, - y1: y1, - x2: x2, - y2: y2 - }); - } - } // draw horizontal lines - - - if (w.config.grid.yaxis.lines.show) { - var _x = 0; - var _y = 0; - var _y2 = 0; - var _x2 = w.globals.gridWidth; - var tA = tickAmount + 1; - - if (this.isRangeBar) { - tA = w.globals.labels.length; - } - - for (var i = 0; i < tA + (this.isRangeBar ? 1 : 0); i++) { - this._drawGridLine({ - i: i, - xCount: tA + (this.isRangeBar ? 1 : 0), - x1: _x, - y1: _y, - x2: _x2, - y2: _y2, - parent: this.elgridLinesH - }); - - _y = _y + w.globals.gridHeight / (this.isRangeBar ? tA : tickAmount); - _y2 = _y; - } - } - } - }, { - key: "_drawInvertedXYLines", - value: function _drawInvertedXYLines(_ref7) { - var xCount = _ref7.xCount; - var w = this.w; // draw vertical lines - - if (w.config.grid.xaxis.lines.show || w.config.xaxis.axisTicks.show) { - var x1 = w.globals.padHorizontal; - var y1 = 0; - var x2; - var y2 = w.globals.gridHeight; - - for (var i = 0; i < xCount + 1; i++) { - if (w.config.grid.xaxis.lines.show) { - this._drawGridLine({ - i: i, - xCount: xCount + 1, - x1: x1, - y1: y1, - x2: x2, - y2: y2, - parent: this.elgridLinesV - }); - } - - var xAxis = new XAxis(this.ctx); - xAxis.drawXaxisTicks(x1, 0, w.globals.dom.elGraphical); - x1 = x1 + w.globals.gridWidth / xCount + 0.3; - x2 = x1; - } - } // draw horizontal lines - - - if (w.config.grid.yaxis.lines.show) { - var _x3 = 0; - var _y3 = 0; - var _y4 = 0; - var _x4 = w.globals.gridWidth; - - for (var _i = 0; _i < w.globals.dataPoints + 1; _i++) { - this._drawGridLine({ - i: _i, - xCount: w.globals.dataPoints + 1, - x1: _x3, - y1: _y3, - x2: _x4, - y2: _y4, - parent: this.elgridLinesH - }); - - _y3 = _y3 + w.globals.gridHeight / w.globals.dataPoints; - _y4 = _y3; - } - } - } // actual grid rendering - - }, { - key: "renderGrid", - value: function renderGrid() { - var w = this.w; - var graphics = new Graphics(this.ctx); - this.elg = graphics.group({ - class: 'apexcharts-grid' - }); - this.elgridLinesH = graphics.group({ - class: 'apexcharts-gridlines-horizontal' - }); - this.elgridLinesV = graphics.group({ - class: 'apexcharts-gridlines-vertical' - }); - this.elGridBorders = graphics.group({ - class: 'apexcharts-grid-borders' - }); - this.elg.add(this.elgridLinesH); - this.elg.add(this.elgridLinesV); - - if (!w.config.grid.show) { - this.elgridLinesV.hide(); - this.elgridLinesH.hide(); - this.elGridBorders.hide(); - } - - var yTickAmount = w.globals.yAxisScale.length ? w.globals.yAxisScale[0].result.length - 1 : 5; - - for (var i = 0; i < w.globals.series.length; i++) { - if (typeof w.globals.yAxisScale[i] !== 'undefined') { - yTickAmount = w.globals.yAxisScale[i].result.length - 1; - } - - if (yTickAmount > 2) break; - } - - var xCount; - - if (!w.globals.isBarHorizontal || this.isRangeBar) { - xCount = this.xaxisLabels.length; - - if (this.isRangeBar) { - xCount--; - yTickAmount = w.globals.labels.length; - - if (w.config.xaxis.tickAmount && w.config.xaxis.labels.formatter) { - xCount = w.config.xaxis.tickAmount; - } - } - - this._drawXYLines({ - xCount: xCount, - tickAmount: yTickAmount - }); - } else { - xCount = yTickAmount; // for horizontal bar chart, get the xaxis tickamount - - yTickAmount = w.globals.xTickAmount; - - this._drawInvertedXYLines({ - xCount: xCount, - tickAmount: yTickAmount - }); - } - - this.drawGridBands(xCount, yTickAmount); - return { - el: this.elg, - elGridBorders: this.elGridBorders, - xAxisTickWidth: w.globals.gridWidth / xCount - }; - } - }, { - key: "drawGridBands", - value: function drawGridBands(xCount, tickAmount) { - var w = this.w; // rows background bands - - if (w.config.grid.row.colors !== undefined && w.config.grid.row.colors.length > 0) { - var x1 = 0; - var y1 = 0; - var y2 = w.globals.gridHeight / tickAmount; - var x2 = w.globals.gridWidth; - - for (var i = 0, c = 0; i < tickAmount; i++, c++) { - if (c >= w.config.grid.row.colors.length) { - c = 0; - } - - this._drawGridBandRect({ - c: c, - x1: x1, - y1: y1, - x2: x2, - y2: y2, - type: 'row' - }); - - y1 = y1 + w.globals.gridHeight / tickAmount; - } - } // columns background bands - - - if (w.config.grid.column.colors !== undefined && w.config.grid.column.colors.length > 0) { - var xc = !w.globals.isBarHorizontal && (w.config.xaxis.type === 'category' || w.config.xaxis.convertedCatToNumeric) ? xCount - 1 : xCount; - var _x5 = w.globals.padHorizontal; - var _y5 = 0; - - var _x6 = w.globals.padHorizontal + w.globals.gridWidth / xc; - - var _y6 = w.globals.gridHeight; - - for (var _i2 = 0, _c = 0; _i2 < xCount; _i2++, _c++) { - if (_c >= w.config.grid.column.colors.length) { - _c = 0; - } - - this._drawGridBandRect({ - c: _c, - x1: _x5, - y1: _y5, - x2: _x6, - y2: _y6, - type: 'column' - }); - - _x5 = _x5 + w.globals.gridWidth / xc; - } - } - } - }]); - - return Grid; - }(); - - var Range$1 = /*#__PURE__*/function () { - function Range(ctx) { - _classCallCheck(this, Range); - - this.ctx = ctx; - this.w = ctx.w; - } // http://stackoverflow.com/questions/326679/choosing-an-attractive-linear-scale-for-a-graphs-y-axiss - // This routine creates the Y axis values for a graph. - - - _createClass(Range, [{ - key: "niceScale", - value: function niceScale(yMin, yMax) { - var ticks = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 10; - var index = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0; - var NO_MIN_MAX_PROVIDED = arguments.length > 4 ? arguments[4] : undefined; - var w = this.w; // Determine Range - - var range = Math.abs(yMax - yMin); - ticks = this._adjustTicksForSmallRange(ticks, index, range); - - if (ticks === 'dataPoints') { - ticks = w.globals.dataPoints - 1; - } - - if (yMin === Number.MIN_VALUE && yMax === 0 || !Utils$1.isNumber(yMin) && !Utils$1.isNumber(yMax) || yMin === Number.MIN_VALUE && yMax === -Number.MAX_VALUE) { - // when all values are 0 - yMin = 0; - yMax = ticks; - var linearScale = this.linearScale(yMin, yMax, ticks); - return linearScale; - } - - if (yMin > yMax) { - // if somehow due to some wrong config, user sent max less than min, - // adjust the min/max again - console.warn('axis.min cannot be greater than axis.max'); - yMax = yMin + 0.1; - } else if (yMin === yMax) { - // If yMin and yMax are identical, then - // adjust the yMin and yMax values to actually - // make a graph. Also avoids division by zero errors. - yMin = yMin === 0 ? 0 : yMin - 0.5; // some small value - - yMax = yMax === 0 ? 2 : yMax + 0.5; // some small value - } // Calculate Min amd Max graphical labels and graph - // increments. The number of ticks defaults to - // 10 which is the SUGGESTED value. Any tick value - // entered is used as a suggested value which is - // adjusted to be a 'pretty' value. - // - // Output will be an array of the Y axis values that - // encompass the Y values. - - - var result = []; - - if (range < 1 && NO_MIN_MAX_PROVIDED && (w.config.chart.type === 'candlestick' || w.config.series[index].type === 'candlestick' || w.config.chart.type === 'boxPlot' || w.config.series[index].type === 'boxPlot' || w.globals.isRangeData)) { - /* fix https://github.com/apexcharts/apexcharts.js/issues/430 */ - yMax = yMax * 1.01; - } - - var tiks = ticks + 1; // Adjust ticks if needed - - if (tiks < 2) { - tiks = 2; - } else if (tiks > 2) { - tiks -= 2; - } // Get raw step value - - - var tempStep = range / tiks; // Calculate pretty step value - - var mag = Math.floor(Utils$1.log10(tempStep)); - var magPow = Math.pow(10, mag); - var magMsd = Math.round(tempStep / magPow); - - if (magMsd < 1) { - magMsd = 1; - } - - var stepSize = magMsd * magPow; // build Y label array. - // Lower and upper bounds calculations - - var lb = stepSize * Math.floor(yMin / stepSize); - var ub = stepSize * Math.ceil(yMax / stepSize); // Build array - - var val = lb; - - if (NO_MIN_MAX_PROVIDED && range > 2) { - while (1) { - result.push(val); - val += stepSize; - - if (val > ub) { - break; - } - } - - return { - result: result, - niceMin: result[0], - niceMax: result[result.length - 1] - }; - } else { - result = []; - var v = yMin; - result.push(v); - var valuesDivider = Math.abs(yMax - yMin) / ticks; - - for (var i = 0; i <= ticks; i++) { - v = v + valuesDivider; - result.push(v); - } - - if (result[result.length - 2] >= yMax) { - result.pop(); - } - - return { - result: result, - niceMin: result[0], - niceMax: result[result.length - 1] - }; - } - } - }, { - key: "linearScale", - value: function linearScale(yMin, yMax) { - var ticks = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 10; - var index = arguments.length > 3 ? arguments[3] : undefined; - var range = Math.abs(yMax - yMin); - ticks = this._adjustTicksForSmallRange(ticks, index, range); - - if (ticks === 'dataPoints') { - ticks = this.w.globals.dataPoints - 1; - } - - var step = range / ticks; - - if (ticks === Number.MAX_VALUE) { - ticks = 10; - step = 1; - } - - var result = []; - var v = yMin; - - while (ticks >= 0) { - result.push(v); - v = v + step; - ticks -= 1; - } - - return { - result: result, - niceMin: result[0], - niceMax: result[result.length - 1] - }; - } - }, { - key: "logarithmicScaleNice", - value: function logarithmicScaleNice(yMin, yMax, base) { - // Basic validation to avoid for loop starting at -inf. - if (yMax <= 0) yMax = Math.max(yMin, base); - if (yMin <= 0) yMin = Math.min(yMax, base); - var logs = []; - var logMax = Math.ceil(Math.log(yMax) / Math.log(base) + 1); // Get powers of base for our max and min - - var logMin = Math.floor(Math.log(yMin) / Math.log(base)); - - for (var i = logMin; i < logMax; i++) { - logs.push(Math.pow(base, i)); - } - - return { - result: logs, - niceMin: logs[0], - niceMax: logs[logs.length - 1] - }; - } - }, { - key: "logarithmicScale", - value: function logarithmicScale(yMin, yMax, base) { - // Basic validation to avoid for loop starting at -inf. - if (yMax <= 0) yMax = Math.max(yMin, base); - if (yMin <= 0) yMin = Math.min(yMax, base); - var logs = []; // Get the logarithmic range. - - var logMax = Math.log(yMax) / Math.log(base); - var logMin = Math.log(yMin) / Math.log(base); // Get the exact logarithmic range. - // (This is the exact number of multiples of the base there are between yMin and yMax). - - var logRange = logMax - logMin; // Round the logarithmic range to get the number of ticks we will create. - // If the chosen min/max values are multiples of each other WRT the base, this will be neat. - // If the chosen min/max aren't, we will at least still provide USEFUL ticks. - - var ticks = Math.round(logRange); // Get the logarithmic spacing between ticks. - - var logTickSpacing = logRange / ticks; // Create as many ticks as there is range in the logs. - - for (var i = 0, logTick = logMin; i < ticks; i++, logTick += logTickSpacing) { - logs.push(Math.pow(base, logTick)); - } // Add a final tick at the yMax. - - - logs.push(Math.pow(base, logMax)); - return { - result: logs, - niceMin: yMin, - niceMax: yMax - }; - } - }, { - key: "_adjustTicksForSmallRange", - value: function _adjustTicksForSmallRange(ticks, index, range) { - var newTicks = ticks; - - if (typeof index !== 'undefined' && this.w.config.yaxis[index].labels.formatter && this.w.config.yaxis[index].tickAmount === undefined) { - var formattedVal = Number(this.w.config.yaxis[index].labels.formatter(1)); - - if (Utils$1.isNumber(formattedVal) && this.w.globals.yValueDecimal === 0) { - newTicks = Math.ceil(range); - } - } - - return newTicks < ticks ? newTicks : ticks; - } - }, { - key: "setYScaleForIndex", - value: function setYScaleForIndex(index, minY, maxY) { - var gl = this.w.globals; - var cnf = this.w.config; - var y = gl.isBarHorizontal ? cnf.xaxis : cnf.yaxis[index]; - - if (typeof gl.yAxisScale[index] === 'undefined') { - gl.yAxisScale[index] = []; - } - - var diff = Math.abs(maxY - minY); - - if (y.logarithmic && diff <= 5) { - gl.invalidLogScale = true; - } - - if (y.logarithmic && diff > 5) { - gl.allSeriesCollapsed = false; - gl.yAxisScale[index] = this.logarithmicScale(minY, maxY, y.logBase); - gl.yAxisScale[index] = y.forceNiceScale ? this.logarithmicScaleNice(minY, maxY, y.logBase) : this.logarithmicScale(minY, maxY, y.logBase); - } else { - if (maxY === -Number.MAX_VALUE || !Utils$1.isNumber(maxY)) { - // no data in the chart. Either all series collapsed or user passed a blank array - gl.yAxisScale[index] = this.linearScale(0, 5, 5); - } else { - // there is some data. Turn off the allSeriesCollapsed flag - gl.allSeriesCollapsed = false; - - if ((y.min !== undefined || y.max !== undefined) && !y.forceNiceScale) { - // fix https://github.com/apexcharts/apexcharts.js/issues/492 - gl.yAxisScale[index] = this.linearScale(minY, maxY, y.tickAmount, index); - } else { - var noMinMaxProvided = cnf.yaxis[index].max === undefined && cnf.yaxis[index].min === undefined || cnf.yaxis[index].forceNiceScale; - gl.yAxisScale[index] = this.niceScale(minY, maxY, y.tickAmount ? y.tickAmount : diff < 5 && diff > 1 ? diff + 1 : 5, index, // fix https://github.com/apexcharts/apexcharts.js/issues/397 - noMinMaxProvided); - } - } - } - } - }, { - key: "setXScale", - value: function setXScale(minX, maxX) { - var w = this.w; - var gl = w.globals; - var x = w.config.xaxis; - var diff = Math.abs(maxX - minX); - - if (maxX === -Number.MAX_VALUE || !Utils$1.isNumber(maxX)) { - // no data in the chart. Either all series collapsed or user passed a blank array - gl.xAxisScale = this.linearScale(0, 5, 5); - } else { - gl.xAxisScale = this.linearScale(minX, maxX, x.tickAmount ? x.tickAmount : diff < 5 && diff > 1 ? diff + 1 : 5, 0); - } - - return gl.xAxisScale; - } - }, { - key: "setMultipleYScales", - value: function setMultipleYScales() { - var _this = this; - - var gl = this.w.globals; - var cnf = this.w.config; - var minYArr = gl.minYArr.concat([]); - var maxYArr = gl.maxYArr.concat([]); - var scalesIndices = []; // here, we loop through the yaxis array and find the item which has "seriesName" property - - cnf.yaxis.forEach(function (yaxe, i) { - var index = i; - cnf.series.forEach(function (s, si) { - // if seriesName matches and that series is not collapsed, we use that scale - // fix issue #1215 - // proceed even if si is in gl.collapsedSeriesIndices - if (s.name === yaxe.seriesName) { - index = si; - - if (i !== si) { - scalesIndices.push({ - index: si, - similarIndex: i, - alreadyExists: true - }); - } else { - scalesIndices.push({ - index: si - }); - } - } - }); - var minY = minYArr[index]; - var maxY = maxYArr[index]; - - _this.setYScaleForIndex(i, minY, maxY); - }); - this.sameScaleInMultipleAxes(minYArr, maxYArr, scalesIndices); - } - }, { - key: "sameScaleInMultipleAxes", - value: function sameScaleInMultipleAxes(minYArr, maxYArr, scalesIndices) { - var _this2 = this; - - var cnf = this.w.config; - var gl = this.w.globals; // we got the scalesIndices array in the above code, but we need to filter out the items which doesn't have same scales - - var similarIndices = []; - scalesIndices.forEach(function (scale) { - if (scale.alreadyExists) { - if (typeof similarIndices[scale.index] === 'undefined') { - similarIndices[scale.index] = []; - } - - similarIndices[scale.index].push(scale.index); - similarIndices[scale.index].push(scale.similarIndex); - } - }); - - function intersect(a, b) { - return a.filter(function (value) { - return b.indexOf(value) !== -1; - }); - } - - gl.yAxisSameScaleIndices = similarIndices; - similarIndices.forEach(function (si, i) { - similarIndices.forEach(function (sj, j) { - if (i !== j) { - if (intersect(si, sj).length > 0) { - similarIndices[i] = similarIndices[i].concat(similarIndices[j]); - } - } - }); - }); // then, we remove duplicates from the similarScale array - - var uniqueSimilarIndices = similarIndices.map(function (item) { - return item.filter(function (i, pos) { - return item.indexOf(i) === pos; - }); - }); // sort further to remove whole duplicate arrays later - - var sortedIndices = uniqueSimilarIndices.map(function (s) { - return s.sort(); - }); // remove undefined items - - similarIndices = similarIndices.filter(function (s) { - return !!s; - }); - var indices = sortedIndices.slice(); - var stringIndices = indices.map(function (ind) { - return JSON.stringify(ind); - }); - indices = indices.filter(function (ind, p) { - return stringIndices.indexOf(JSON.stringify(ind)) === p; - }); - var sameScaleMinYArr = []; - var sameScaleMaxYArr = []; - minYArr.forEach(function (minYValue, yi) { - indices.forEach(function (scale, i) { - // we compare only the yIndex which exists in the indices array - if (scale.indexOf(yi) > -1) { - if (typeof sameScaleMinYArr[i] === 'undefined') { - sameScaleMinYArr[i] = []; - sameScaleMaxYArr[i] = []; - } - - sameScaleMinYArr[i].push({ - key: yi, - value: minYValue - }); - sameScaleMaxYArr[i].push({ - key: yi, - value: maxYArr[yi] - }); - } - }); - }); - var sameScaleMin = Array.apply(null, Array(indices.length)).map(Number.prototype.valueOf, Number.MIN_VALUE); - var sameScaleMax = Array.apply(null, Array(indices.length)).map(Number.prototype.valueOf, -Number.MAX_VALUE); - sameScaleMinYArr.forEach(function (s, i) { - s.forEach(function (sc, j) { - sameScaleMin[i] = Math.min(sc.value, sameScaleMin[i]); - }); - }); - sameScaleMaxYArr.forEach(function (s, i) { - s.forEach(function (sc, j) { - sameScaleMax[i] = Math.max(sc.value, sameScaleMax[i]); - }); - }); - minYArr.forEach(function (min, i) { - sameScaleMaxYArr.forEach(function (s, si) { - var minY = sameScaleMin[si]; - var maxY = sameScaleMax[si]; - - if (cnf.chart.stacked) { - // for stacked charts, we need to add the values - maxY = 0; - s.forEach(function (ind, k) { - // fix incorrectly adjust y scale issue #1215 - if (ind.value !== -Number.MAX_VALUE) { - maxY += ind.value; - } - - if (minY !== Number.MIN_VALUE) { - minY += sameScaleMinYArr[si][k].value; - } - }); - } - - s.forEach(function (ind, k) { - if (s[k].key === i) { - if (cnf.yaxis[i].min !== undefined) { - if (typeof cnf.yaxis[i].min === 'function') { - minY = cnf.yaxis[i].min(gl.minY); - } else { - minY = cnf.yaxis[i].min; - } - } - - if (cnf.yaxis[i].max !== undefined) { - if (typeof cnf.yaxis[i].max === 'function') { - maxY = cnf.yaxis[i].max(gl.maxY); - } else { - maxY = cnf.yaxis[i].max; - } - } - - _this2.setYScaleForIndex(i, minY, maxY); - } - }); - }); - }); - } // experimental feature which scales the y-axis to a min/max based on x-axis range - - }, { - key: "autoScaleY", - value: function autoScaleY(ctx, yaxis, e) { - if (!ctx) { - ctx = this; - } - - var w = ctx.w; - - if (w.globals.isMultipleYAxis || w.globals.collapsedSeries.length) { - // The autoScale option for multiple y-axis is turned off as it leads to buggy behavior. - // Also, when a series is collapsed, it results in incorrect behavior. Hence turned it off for that too - fixes apexcharts.js#795 - console.warn('autoScaleYaxis is not supported in a multi-yaxis chart.'); - return yaxis; - } - - var seriesX = w.globals.seriesX[0]; - var isStacked = w.config.chart.stacked; - yaxis.forEach(function (yaxe, yi) { - var firstXIndex = 0; - - for (var xi = 0; xi < seriesX.length; xi++) { - if (seriesX[xi] >= e.xaxis.min) { - firstXIndex = xi; - break; - } - } - - var initialMin = w.globals.minYArr[yi]; - var initialMax = w.globals.maxYArr[yi]; - var min, max; - var stackedSer = w.globals.stackedSeriesTotals; - w.globals.series.forEach(function (serie, sI) { - var firstValue = serie[firstXIndex]; - - if (isStacked) { - firstValue = stackedSer[firstXIndex]; - min = max = firstValue; - stackedSer.forEach(function (y, yI) { - if (seriesX[yI] <= e.xaxis.max && seriesX[yI] >= e.xaxis.min) { - if (y > max && y !== null) max = y; - if (serie[yI] < min && serie[yI] !== null) min = serie[yI]; - } - }); - } else { - min = max = firstValue; - serie.forEach(function (y, yI) { - if (seriesX[yI] <= e.xaxis.max && seriesX[yI] >= e.xaxis.min) { - var valMin = y; - var valMax = y; - w.globals.series.forEach(function (wS, wSI) { - if (y !== null) { - valMin = Math.min(wS[yI], valMin); - valMax = Math.max(wS[yI], valMax); - } - }); - if (valMax > max && valMax !== null) max = valMax; - if (valMin < min && valMin !== null) min = valMin; - } - }); - } - - if (min === undefined && max === undefined) { - min = initialMin; - max = initialMax; - } - - min *= min < 0 ? 1.1 : 0.9; - max *= max < 0 ? 0.9 : 1.1; - - if (min === 0 && max === 0) { - min = -1; - max = 1; - } - - if (max < 0 && max < initialMax) { - max = initialMax; - } - - if (min < 0 && min > initialMin) { - min = initialMin; - } - - if (yaxis.length > 1) { - yaxis[sI].min = yaxe.min === undefined ? min : yaxe.min; - yaxis[sI].max = yaxe.max === undefined ? max : yaxe.max; - } else { - yaxis[0].min = yaxe.min === undefined ? min : yaxe.min; - yaxis[0].max = yaxe.max === undefined ? max : yaxe.max; - } - }); - }); - return yaxis; - } - }]); - - return Range; - }(); - - /** - * Range is used to generates values between min and max. - * - * @module Range - **/ - - var Range = /*#__PURE__*/function () { - function Range(ctx) { - _classCallCheck(this, Range); - - this.ctx = ctx; - this.w = ctx.w; - this.scales = new Range$1(ctx); - } - - _createClass(Range, [{ - key: "init", - value: function init() { - this.setYRange(); - this.setXRange(); - this.setZRange(); - } - }, { - key: "getMinYMaxY", - value: function getMinYMaxY(startingIndex) { - var lowestY = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Number.MAX_VALUE; - var highestY = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : -Number.MAX_VALUE; - var len = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - var cnf = this.w.config; - var gl = this.w.globals; - var maxY = -Number.MAX_VALUE; - var minY = Number.MIN_VALUE; - - if (len === null) { - len = startingIndex + 1; - } - - var series = gl.series; - var seriesMin = series; - var seriesMax = series; - - if (cnf.chart.type === 'candlestick') { - seriesMin = gl.seriesCandleL; - seriesMax = gl.seriesCandleH; - } else if (cnf.chart.type === 'boxPlot') { - seriesMin = gl.seriesCandleO; - seriesMax = gl.seriesCandleC; - } else if (gl.isRangeData) { - seriesMin = gl.seriesRangeStart; - seriesMax = gl.seriesRangeEnd; - } - - for (var i = startingIndex; i < len; i++) { - gl.dataPoints = Math.max(gl.dataPoints, series[i].length); - - if (gl.categoryLabels.length) { - gl.dataPoints = gl.categoryLabels.filter(function (label) { - return typeof label !== 'undefined'; - }).length; - } - - for (var j = 0; j < gl.series[i].length; j++) { - var val = series[i][j]; - - if (val !== null && Utils$1.isNumber(val)) { - if (typeof seriesMax[i][j] !== 'undefined') { - maxY = Math.max(maxY, seriesMax[i][j]); - lowestY = Math.min(lowestY, seriesMax[i][j]); - } - - if (typeof seriesMin[i][j] !== 'undefined') { - lowestY = Math.min(lowestY, seriesMin[i][j]); - highestY = Math.max(highestY, seriesMin[i][j]); - } - - if (this.w.config.chart.type === 'candlestick' || this.w.config.chart.type === 'boxPlot' || this.w.config.chart.type !== 'rangeArea' || this.w.config.chart.type !== 'rangeBar') { - if (this.w.config.chart.type === 'candlestick' || this.w.config.chart.type === 'boxPlot') { - if (typeof gl.seriesCandleC[i][j] !== 'undefined') { - maxY = Math.max(maxY, gl.seriesCandleO[i][j]); - maxY = Math.max(maxY, gl.seriesCandleH[i][j]); - maxY = Math.max(maxY, gl.seriesCandleL[i][j]); - maxY = Math.max(maxY, gl.seriesCandleC[i][j]); - - if (this.w.config.chart.type === 'boxPlot') { - maxY = Math.max(maxY, gl.seriesCandleM[i][j]); - } - } - } // there is a combo chart and the specified series in not either candlestick, boxplot, or rangeArea/rangeBar; find the max there - - - if (cnf.series[i].type && (cnf.series[i].type !== 'candlestick' || cnf.series[i].type !== 'boxPlot' || cnf.series[i].type !== 'rangeArea' || cnf.series[i].type !== 'rangeBar')) { - maxY = Math.max(maxY, gl.series[i][j]); - lowestY = Math.min(lowestY, gl.series[i][j]); - } - - highestY = maxY; - } - - if (gl.seriesGoals[i] && gl.seriesGoals[i][j] && Array.isArray(gl.seriesGoals[i][j])) { - gl.seriesGoals[i][j].forEach(function (g) { - if (minY !== Number.MIN_VALUE) { - minY = Math.min(minY, g.value); - lowestY = minY; - } - - maxY = Math.max(maxY, g.value); - highestY = maxY; - }); - } - - if (Utils$1.isFloat(val)) { - val = Utils$1.noExponents(val); - gl.yValueDecimal = Math.max(gl.yValueDecimal, val.toString().split('.')[1].length); - } - - if (minY > seriesMin[i][j] && seriesMin[i][j] < 0) { - minY = seriesMin[i][j]; - } - } else { - gl.hasNullValues = true; - } - } - } - - if (cnf.chart.type === 'rangeBar' && gl.seriesRangeStart.length && gl.isBarHorizontal) { - minY = lowestY; - } - - if (cnf.chart.type === 'bar') { - if (minY < 0 && maxY < 0) { - // all negative values in a bar chart, hence make the max to 0 - maxY = 0; - } - - if (minY === Number.MIN_VALUE) { - minY = 0; - } - } - - return { - minY: minY, - maxY: maxY, - lowestY: lowestY, - highestY: highestY - }; - } - }, { - key: "setYRange", - value: function setYRange() { - var gl = this.w.globals; - var cnf = this.w.config; - gl.maxY = -Number.MAX_VALUE; - gl.minY = Number.MIN_VALUE; - var lowestYInAllSeries = Number.MAX_VALUE; - - if (gl.isMultipleYAxis) { - // we need to get minY and maxY for multiple y axis - for (var i = 0; i < gl.series.length; i++) { - var minYMaxYArr = this.getMinYMaxY(i, lowestYInAllSeries, null, i + 1); - gl.minYArr.push(minYMaxYArr.minY); - gl.maxYArr.push(minYMaxYArr.maxY); - lowestYInAllSeries = minYMaxYArr.lowestY; - } - } // and then, get the minY and maxY from all series - - - var minYMaxY = this.getMinYMaxY(0, lowestYInAllSeries, null, gl.series.length); - gl.minY = minYMaxY.minY; - gl.maxY = minYMaxY.maxY; - lowestYInAllSeries = minYMaxY.lowestY; - - if (cnf.chart.stacked) { - this._setStackedMinMax(); - } // if the numbers are too big, reduce the range - // for eg, if number is between 100000-110000, putting 0 as the lowest value is not so good idea. So change the gl.minY for line/area/candlesticks/boxPlot - - - if (cnf.chart.type === 'line' || cnf.chart.type === 'area' || cnf.chart.type === 'candlestick' || cnf.chart.type === 'boxPlot' || cnf.chart.type === 'rangeBar' && !gl.isBarHorizontal) { - if (gl.minY === Number.MIN_VALUE && lowestYInAllSeries !== -Number.MAX_VALUE && lowestYInAllSeries !== gl.maxY // single value possibility - ) { - var diff = gl.maxY - lowestYInAllSeries; - - if (lowestYInAllSeries >= 0 && lowestYInAllSeries <= 10 || cnf.yaxis[0].min !== undefined || cnf.yaxis[0].max !== undefined) { - // if minY is already 0/low value, we don't want to go negatives here - so this check is essential. - diff = 0; - } - - gl.minY = lowestYInAllSeries - diff * 5 / 100; - /* fix https://github.com/apexcharts/apexcharts.js/issues/614 */ - - /* fix https://github.com/apexcharts/apexcharts.js/issues/968 */ - - if (lowestYInAllSeries > 0 && gl.minY < 0) { - gl.minY = 0; - } - /* fix https://github.com/apexcharts/apexcharts.js/issues/426 */ - - - gl.maxY = gl.maxY + diff * 5 / 100; - } - } - - cnf.yaxis.forEach(function (yaxe, index) { - // override all min/max values by user defined values (y axis) - if (yaxe.max !== undefined) { - if (typeof yaxe.max === 'number') { - gl.maxYArr[index] = yaxe.max; - } else if (typeof yaxe.max === 'function') { - // fixes apexcharts.js/issues/2098 - gl.maxYArr[index] = yaxe.max(gl.isMultipleYAxis ? gl.maxYArr[index] : gl.maxY); - } // gl.maxY is for single y-axis chart, it will be ignored in multi-yaxis - - - gl.maxY = gl.maxYArr[index]; - } - - if (yaxe.min !== undefined) { - if (typeof yaxe.min === 'number') { - gl.minYArr[index] = yaxe.min; - } else if (typeof yaxe.min === 'function') { - // fixes apexcharts.js/issues/2098 - gl.minYArr[index] = yaxe.min(gl.isMultipleYAxis ? gl.minYArr[index] === Number.MIN_VALUE ? 0 : gl.minYArr[index] : gl.minY); - } // gl.minY is for single y-axis chart, it will be ignored in multi-yaxis - - - gl.minY = gl.minYArr[index]; - } - }); // for horizontal bar charts, we need to check xaxis min/max as user may have specified there - - if (gl.isBarHorizontal) { - var minmax = ['min', 'max']; - minmax.forEach(function (m) { - if (cnf.xaxis[m] !== undefined && typeof cnf.xaxis[m] === 'number') { - m === 'min' ? gl.minY = cnf.xaxis[m] : gl.maxY = cnf.xaxis[m]; - } - }); - } // for multi y-axis we need different scales for each - - - if (gl.isMultipleYAxis) { - this.scales.setMultipleYScales(); - gl.minY = lowestYInAllSeries; - gl.yAxisScale.forEach(function (scale, i) { - gl.minYArr[i] = scale.niceMin; - gl.maxYArr[i] = scale.niceMax; - }); - } else { - this.scales.setYScaleForIndex(0, gl.minY, gl.maxY); - gl.minY = gl.yAxisScale[0].niceMin; - gl.maxY = gl.yAxisScale[0].niceMax; - gl.minYArr[0] = gl.yAxisScale[0].niceMin; - gl.maxYArr[0] = gl.yAxisScale[0].niceMax; - } - - return { - minY: gl.minY, - maxY: gl.maxY, - minYArr: gl.minYArr, - maxYArr: gl.maxYArr, - yAxisScale: gl.yAxisScale - }; - } - }, { - key: "setXRange", - value: function setXRange() { - var gl = this.w.globals; - var cnf = this.w.config; - var isXNumeric = cnf.xaxis.type === 'numeric' || cnf.xaxis.type === 'datetime' || cnf.xaxis.type === 'category' && !gl.noLabelsProvided || gl.noLabelsProvided || gl.isXNumeric; - - var getInitialMinXMaxX = function getInitialMinXMaxX() { - for (var i = 0; i < gl.series.length; i++) { - if (gl.labels[i]) { - for (var j = 0; j < gl.labels[i].length; j++) { - if (gl.labels[i][j] !== null && Utils$1.isNumber(gl.labels[i][j])) { - gl.maxX = Math.max(gl.maxX, gl.labels[i][j]); - gl.initialMaxX = Math.max(gl.maxX, gl.labels[i][j]); - gl.minX = Math.min(gl.minX, gl.labels[i][j]); - gl.initialMinX = Math.min(gl.minX, gl.labels[i][j]); - } - } - } - } - }; // minX maxX starts here - - - if (gl.isXNumeric) { - getInitialMinXMaxX(); - } - - if (gl.noLabelsProvided) { - if (cnf.xaxis.categories.length === 0) { - gl.maxX = gl.labels[gl.labels.length - 1]; - gl.initialMaxX = gl.labels[gl.labels.length - 1]; - gl.minX = 1; - gl.initialMinX = 1; - } - } - - if (gl.isXNumeric || gl.noLabelsProvided || gl.dataFormatXNumeric) { - var ticks; - - if (cnf.xaxis.tickAmount === undefined) { - ticks = Math.round(gl.svgWidth / 150); // no labels provided and total number of dataPoints is less than 30 - - if (cnf.xaxis.type === 'numeric' && gl.dataPoints < 30) { - ticks = gl.dataPoints - 1; - } // this check is for when ticks exceeds total datapoints and that would result in duplicate labels - - - if (ticks > gl.dataPoints && gl.dataPoints !== 0) { - ticks = gl.dataPoints - 1; - } - } else if (cnf.xaxis.tickAmount === 'dataPoints') { - if (gl.series.length > 1) { - ticks = gl.series[gl.maxValsInArrayIndex].length - 1; - } - - if (gl.isXNumeric) { - ticks = gl.maxX - gl.minX - 1; - } - } else { - ticks = cnf.xaxis.tickAmount; - } - - gl.xTickAmount = ticks; // override all min/max values by user defined values (x axis) - - if (cnf.xaxis.max !== undefined && typeof cnf.xaxis.max === 'number') { - gl.maxX = cnf.xaxis.max; - } - - if (cnf.xaxis.min !== undefined && typeof cnf.xaxis.min === 'number') { - gl.minX = cnf.xaxis.min; - } // if range is provided, adjust the new minX - - - if (cnf.xaxis.range !== undefined) { - gl.minX = gl.maxX - cnf.xaxis.range; - } - - if (gl.minX !== Number.MAX_VALUE && gl.maxX !== -Number.MAX_VALUE) { - if (cnf.xaxis.convertedCatToNumeric && !gl.dataFormatXNumeric) { - var catScale = []; - - for (var i = gl.minX - 1; i < gl.maxX; i++) { - catScale.push(i + 1); - } - - gl.xAxisScale = { - result: catScale, - niceMin: catScale[0], - niceMax: catScale[catScale.length - 1] - }; - } else { - gl.xAxisScale = this.scales.setXScale(gl.minX, gl.maxX); - } - } else { - gl.xAxisScale = this.scales.linearScale(1, ticks, ticks); - - if (gl.noLabelsProvided && gl.labels.length > 0) { - gl.xAxisScale = this.scales.linearScale(1, gl.labels.length, ticks - 1); // this is the only place seriesX is again mutated - - gl.seriesX = gl.labels.slice(); - } - } // we will still store these labels as the count for this will be different (to draw grid and labels placement) - - - if (isXNumeric) { - gl.labels = gl.xAxisScale.result.slice(); - } - } - - if (gl.isBarHorizontal && gl.labels.length) { - gl.xTickAmount = gl.labels.length; - } // single dataPoint - - - this._handleSingleDataPoint(); // minimum x difference to calculate bar width in numeric bars - - - this._getMinXDiff(); - - return { - minX: gl.minX, - maxX: gl.maxX - }; - } - }, { - key: "setZRange", - value: function setZRange() { - // minZ, maxZ starts here - var gl = this.w.globals; - if (!gl.isDataXYZ) return; - - for (var i = 0; i < gl.series.length; i++) { - if (typeof gl.seriesZ[i] !== 'undefined') { - for (var j = 0; j < gl.seriesZ[i].length; j++) { - if (gl.seriesZ[i][j] !== null && Utils$1.isNumber(gl.seriesZ[i][j])) { - gl.maxZ = Math.max(gl.maxZ, gl.seriesZ[i][j]); - gl.minZ = Math.min(gl.minZ, gl.seriesZ[i][j]); - } - } - } - } - } - }, { - key: "_handleSingleDataPoint", - value: function _handleSingleDataPoint() { - var gl = this.w.globals; - var cnf = this.w.config; - - if (gl.minX === gl.maxX) { - var datetimeObj = new DateTime(this.ctx); - - if (cnf.xaxis.type === 'datetime') { - var newMinX = datetimeObj.getDate(gl.minX); - - if (cnf.xaxis.labels.datetimeUTC) { - newMinX.setUTCDate(newMinX.getUTCDate() - 2); - } else { - newMinX.setDate(newMinX.getDate() - 2); - } - - gl.minX = new Date(newMinX).getTime(); - var newMaxX = datetimeObj.getDate(gl.maxX); - - if (cnf.xaxis.labels.datetimeUTC) { - newMaxX.setUTCDate(newMaxX.getUTCDate() + 2); - } else { - newMaxX.setDate(newMaxX.getDate() + 2); - } - - gl.maxX = new Date(newMaxX).getTime(); - } else if (cnf.xaxis.type === 'numeric' || cnf.xaxis.type === 'category' && !gl.noLabelsProvided) { - gl.minX = gl.minX - 2; - gl.initialMinX = gl.minX; - gl.maxX = gl.maxX + 2; - gl.initialMaxX = gl.maxX; - } - } - } - }, { - key: "_getMinXDiff", - value: function _getMinXDiff() { - var gl = this.w.globals; - - if (gl.isXNumeric) { - // get the least x diff if numeric x axis is present - gl.seriesX.forEach(function (sX, i) { - if (sX.length === 1) { - // a small hack to prevent overlapping multiple bars when there is just 1 datapoint in bar series. - // fix #811 - sX.push(gl.seriesX[gl.maxValsInArrayIndex][gl.seriesX[gl.maxValsInArrayIndex].length - 1]); - } // fix #983 (clone the array to avoid side effects) - - - var seriesX = sX.slice(); - seriesX.sort(function (a, b) { - return a - b; - }); - seriesX.forEach(function (s, j) { - if (j > 0) { - var xDiff = s - seriesX[j - 1]; - - if (xDiff > 0) { - gl.minXDiff = Math.min(xDiff, gl.minXDiff); - } - } - }); - - if (gl.dataPoints === 1 || gl.minXDiff === Number.MAX_VALUE) { - // fixes apexcharts.js #1221 - gl.minXDiff = 0.5; - } - }); - } - } - }, { - key: "_setStackedMinMax", - value: function _setStackedMinMax() { - var _this = this; - - var gl = this.w.globals; // for stacked charts, we calculate each series's parallel values. i.e, series[0][j] + series[1][j] .... [series[i.length][j]] and get the max out of it - - if (!gl.series.length) return; - var seriesGroups = gl.seriesGroups; - - if (!seriesGroups.length) { - seriesGroups = [this.w.config.series.map(function (serie) { - return serie.name; - })]; - } - - var stackedPoss = {}; - var stackedNegs = {}; - seriesGroups.forEach(function (group) { - stackedPoss[group] = []; - stackedNegs[group] = []; - - var indicesOfSeriesInGroup = _this.w.config.series.map(function (serie, si) { - return group.indexOf(serie.name) > -1 ? si : null; - }).filter(function (f) { - return f !== null; - }); - - indicesOfSeriesInGroup.forEach(function (i) { - for (var j = 0; j < gl.series[gl.maxValsInArrayIndex].length; j++) { - if (typeof stackedPoss[group][j] === 'undefined') { - stackedPoss[group][j] = 0; - stackedNegs[group][j] = 0; - } - - if (gl.series[i][j] !== null && Utils$1.isNumber(gl.series[i][j])) { - gl.series[i][j] > 0 ? stackedPoss[group][j] += parseFloat(gl.series[i][j]) + 0.0001 : stackedNegs[group][j] += parseFloat(gl.series[i][j]); - } - } - }); - }); - Object.entries(stackedPoss).forEach(function (_ref) { - var _ref2 = _slicedToArray(_ref, 1), - key = _ref2[0]; - - stackedPoss[key].forEach(function (_, stgi) { - gl.maxY = Math.max(gl.maxY, stackedPoss[key][stgi]); - gl.minY = Math.min(gl.minY, stackedNegs[key][stgi]); - }); - }); - } - }]); - - return Range; - }(); - - /** - * ApexCharts YAxis Class for drawing Y-Axis. - * - * @module YAxis - **/ - - var YAxis = /*#__PURE__*/function () { - function YAxis(ctx, elgrid) { - _classCallCheck(this, YAxis); - - this.ctx = ctx; - this.elgrid = elgrid; - this.w = ctx.w; - var w = this.w; - this.xaxisFontSize = w.config.xaxis.labels.style.fontSize; - this.axisFontFamily = w.config.xaxis.labels.style.fontFamily; - this.xaxisForeColors = w.config.xaxis.labels.style.colors; - this.isCategoryBarHorizontal = w.config.chart.type === 'bar' && w.config.plotOptions.bar.horizontal; - this.xAxisoffX = 0; - - if (w.config.xaxis.position === 'bottom') { - this.xAxisoffX = w.globals.gridHeight; - } - - this.drawnLabels = []; - this.axesUtils = new AxesUtils(ctx); - } - - _createClass(YAxis, [{ - key: "drawYaxis", - value: function drawYaxis(realIndex) { - var _this = this; - - var w = this.w; - var graphics = new Graphics(this.ctx); - var yaxisStyle = w.config.yaxis[realIndex].labels.style; - var yaxisFontSize = yaxisStyle.fontSize; - var yaxisFontFamily = yaxisStyle.fontFamily; - var yaxisFontWeight = yaxisStyle.fontWeight; - var elYaxis = graphics.group({ - class: 'apexcharts-yaxis', - rel: realIndex, - transform: 'translate(' + w.globals.translateYAxisX[realIndex] + ', 0)' - }); - - if (this.axesUtils.isYAxisHidden(realIndex)) { - return elYaxis; - } - - var elYaxisTexts = graphics.group({ - class: 'apexcharts-yaxis-texts-g' - }); - elYaxis.add(elYaxisTexts); - var tickAmount = w.globals.yAxisScale[realIndex].result.length - 1; // labelsDivider is simply svg height/number of ticks - - var labelsDivider = w.globals.gridHeight / tickAmount; // initial label position = 0; - - var l = w.globals.translateY; - var lbFormatter = w.globals.yLabelFormatters[realIndex]; - var labels = w.globals.yAxisScale[realIndex].result.slice(); - labels = this.axesUtils.checkForReversedLabels(realIndex, labels); - var firstLabel = ''; - - if (w.config.yaxis[realIndex].labels.show) { - var _loop = function _loop(i) { - var val = labels[i]; - val = lbFormatter(val, i, w); - var xPad = w.config.yaxis[realIndex].labels.padding; - - if (w.config.yaxis[realIndex].opposite && w.config.yaxis.length !== 0) { - xPad = xPad * -1; - } - - var textAnchor = 'end'; - - if (w.config.yaxis[realIndex].opposite) { - textAnchor = 'start'; - } - - if (w.config.yaxis[realIndex].labels.align === 'left') { - textAnchor = 'start'; - } else if (w.config.yaxis[realIndex].labels.align === 'center') { - textAnchor = 'middle'; - } else if (w.config.yaxis[realIndex].labels.align === 'right') { - textAnchor = 'end'; - } - - var yColors = _this.axesUtils.getYAxisForeColor(yaxisStyle.colors, realIndex); - - var getForeColor = function getForeColor() { - return Array.isArray(yColors) ? yColors[i] : yColors; - }; - - var label = graphics.drawText({ - x: xPad, - y: l + tickAmount / 10 + w.config.yaxis[realIndex].labels.offsetY + 1, - text: val, - textAnchor: textAnchor, - fontSize: yaxisFontSize, - fontFamily: yaxisFontFamily, - fontWeight: yaxisFontWeight, - maxWidth: w.config.yaxis[realIndex].labels.maxWidth, - foreColor: getForeColor(), - isPlainText: false, - cssClass: 'apexcharts-yaxis-label ' + yaxisStyle.cssClass - }); - - if (i === tickAmount) { - firstLabel = label; - } - - elYaxisTexts.add(label); - var elTooltipTitle = document.createElementNS(w.globals.SVGNS, 'title'); - elTooltipTitle.textContent = Array.isArray(val) ? val.join(' ') : val; - label.node.appendChild(elTooltipTitle); - - if (w.config.yaxis[realIndex].labels.rotate !== 0) { - var firstabelRotatingCenter = graphics.rotateAroundCenter(firstLabel.node); - var labelRotatingCenter = graphics.rotateAroundCenter(label.node); - label.node.setAttribute('transform', "rotate(".concat(w.config.yaxis[realIndex].labels.rotate, " ").concat(firstabelRotatingCenter.x, " ").concat(labelRotatingCenter.y, ")")); - } - - l = l + labelsDivider; - }; - - for (var i = tickAmount; i >= 0; i--) { - _loop(i); - } - } - - if (w.config.yaxis[realIndex].title.text !== undefined) { - var elYaxisTitle = graphics.group({ - class: 'apexcharts-yaxis-title' - }); - var _x = 0; - - if (w.config.yaxis[realIndex].opposite) { - _x = w.globals.translateYAxisX[realIndex]; - } - - var elYAxisTitleText = graphics.drawText({ - x: _x, - y: w.globals.gridHeight / 2 + w.globals.translateY + w.config.yaxis[realIndex].title.offsetY, - text: w.config.yaxis[realIndex].title.text, - textAnchor: 'end', - foreColor: w.config.yaxis[realIndex].title.style.color, - fontSize: w.config.yaxis[realIndex].title.style.fontSize, - fontWeight: w.config.yaxis[realIndex].title.style.fontWeight, - fontFamily: w.config.yaxis[realIndex].title.style.fontFamily, - cssClass: 'apexcharts-yaxis-title-text ' + w.config.yaxis[realIndex].title.style.cssClass - }); - elYaxisTitle.add(elYAxisTitleText); - elYaxis.add(elYaxisTitle); - } - - var axisBorder = w.config.yaxis[realIndex].axisBorder; - var x = 31 + axisBorder.offsetX; - - if (w.config.yaxis[realIndex].opposite) { - x = -31 - axisBorder.offsetX; - } - - if (axisBorder.show) { - var elVerticalLine = graphics.drawLine(x, w.globals.translateY + axisBorder.offsetY - 2, x, w.globals.gridHeight + w.globals.translateY + axisBorder.offsetY + 2, axisBorder.color, 0, axisBorder.width); - elYaxis.add(elVerticalLine); - } - - if (w.config.yaxis[realIndex].axisTicks.show) { - this.axesUtils.drawYAxisTicks(x, tickAmount, axisBorder, w.config.yaxis[realIndex].axisTicks, realIndex, labelsDivider, elYaxis); - } - - return elYaxis; - } // This actually becomes horizontal axis (for bar charts) - - }, { - key: "drawYaxisInversed", - value: function drawYaxisInversed(realIndex) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var elXaxis = graphics.group({ - class: 'apexcharts-xaxis apexcharts-yaxis-inversed' - }); - var elXaxisTexts = graphics.group({ - class: 'apexcharts-xaxis-texts-g', - transform: "translate(".concat(w.globals.translateXAxisX, ", ").concat(w.globals.translateXAxisY, ")") - }); - elXaxis.add(elXaxisTexts); - var tickAmount = w.globals.yAxisScale[realIndex].result.length - 1; // labelsDivider is simply svg width/number of ticks - - var labelsDivider = w.globals.gridWidth / tickAmount + 0.1; // initial label position; - - var l = labelsDivider + w.config.xaxis.labels.offsetX; - var lbFormatter = w.globals.xLabelFormatter; - var labels = w.globals.yAxisScale[realIndex].result.slice(); - var timescaleLabels = w.globals.timescaleLabels; - - if (timescaleLabels.length > 0) { - this.xaxisLabels = timescaleLabels.slice(); - labels = timescaleLabels.slice(); - tickAmount = labels.length; - } - - labels = this.axesUtils.checkForReversedLabels(realIndex, labels); - var tl = timescaleLabels.length; - - if (w.config.xaxis.labels.show) { - for (var i = tl ? 0 : tickAmount; tl ? i < tl : i >= 0; tl ? i++ : i--) { - var val = labels[i]; - val = lbFormatter(val, i, w); - var x = w.globals.gridWidth + w.globals.padHorizontal - (l - labelsDivider + w.config.xaxis.labels.offsetX); - - if (timescaleLabels.length) { - var label = this.axesUtils.getLabel(labels, timescaleLabels, x, i, this.drawnLabels, this.xaxisFontSize); - x = label.x; - val = label.text; - this.drawnLabels.push(label.text); - - if (i === 0 && w.globals.skipFirstTimelinelabel) { - val = ''; - } - - if (i === labels.length - 1 && w.globals.skipLastTimelinelabel) { - val = ''; - } - } - - var elTick = graphics.drawText({ - x: x, - y: this.xAxisoffX + w.config.xaxis.labels.offsetY + 30 - (w.config.xaxis.position === 'top' ? w.globals.xAxisHeight + w.config.xaxis.axisTicks.height - 2 : 0), - text: val, - textAnchor: 'middle', - foreColor: Array.isArray(this.xaxisForeColors) ? this.xaxisForeColors[realIndex] : this.xaxisForeColors, - fontSize: this.xaxisFontSize, - fontFamily: this.xaxisFontFamily, - fontWeight: w.config.xaxis.labels.style.fontWeight, - isPlainText: false, - cssClass: 'apexcharts-xaxis-label ' + w.config.xaxis.labels.style.cssClass - }); - elXaxisTexts.add(elTick); - elTick.tspan(val); - var elTooltipTitle = document.createElementNS(w.globals.SVGNS, 'title'); - elTooltipTitle.textContent = val; - elTick.node.appendChild(elTooltipTitle); - l = l + labelsDivider; - } - } - - this.inversedYAxisTitleText(elXaxis); - this.inversedYAxisBorder(elXaxis); - return elXaxis; - } - }, { - key: "inversedYAxisBorder", - value: function inversedYAxisBorder(parent) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var axisBorder = w.config.xaxis.axisBorder; - - if (axisBorder.show) { - var lineCorrection = 0; - - if (w.config.chart.type === 'bar' && w.globals.isXNumeric) { - lineCorrection = lineCorrection - 15; - } - - var elHorzLine = graphics.drawLine(w.globals.padHorizontal + lineCorrection + axisBorder.offsetX, this.xAxisoffX, w.globals.gridWidth, this.xAxisoffX, axisBorder.color, 0, axisBorder.height); // in horizontal bars, we append axisBorder to elGridBorders element to avoid z-index issues - - if (this.elgrid && this.elgrid.elGridBorders && w.config.grid.show) { - this.elgrid.elGridBorders.add(elHorzLine); - } else { - parent.add(elHorzLine); - } - } - } - }, { - key: "inversedYAxisTitleText", - value: function inversedYAxisTitleText(parent) { - var w = this.w; - var graphics = new Graphics(this.ctx); - - if (w.config.xaxis.title.text !== undefined) { - var elYaxisTitle = graphics.group({ - class: 'apexcharts-xaxis-title apexcharts-yaxis-title-inversed' - }); - var elYAxisTitleText = graphics.drawText({ - x: w.globals.gridWidth / 2 + w.config.xaxis.title.offsetX, - y: this.xAxisoffX + parseFloat(this.xaxisFontSize) + parseFloat(w.config.xaxis.title.style.fontSize) + w.config.xaxis.title.offsetY + 20, - text: w.config.xaxis.title.text, - textAnchor: 'middle', - fontSize: w.config.xaxis.title.style.fontSize, - fontFamily: w.config.xaxis.title.style.fontFamily, - fontWeight: w.config.xaxis.title.style.fontWeight, - foreColor: w.config.xaxis.title.style.color, - cssClass: 'apexcharts-xaxis-title-text ' + w.config.xaxis.title.style.cssClass - }); - elYaxisTitle.add(elYAxisTitleText); - parent.add(elYaxisTitle); - } - } - }, { - key: "yAxisTitleRotate", - value: function yAxisTitleRotate(realIndex, yAxisOpposite) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var yAxisLabelsCoord = { - width: 0, - height: 0 - }; - var yAxisTitleCoord = { - width: 0, - height: 0 - }; - var elYAxisLabelsWrap = w.globals.dom.baseEl.querySelector(" .apexcharts-yaxis[rel='".concat(realIndex, "'] .apexcharts-yaxis-texts-g")); - - if (elYAxisLabelsWrap !== null) { - yAxisLabelsCoord = elYAxisLabelsWrap.getBoundingClientRect(); - } - - var yAxisTitle = w.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(realIndex, "'] .apexcharts-yaxis-title text")); - - if (yAxisTitle !== null) { - yAxisTitleCoord = yAxisTitle.getBoundingClientRect(); - } - - if (yAxisTitle !== null) { - var x = this.xPaddingForYAxisTitle(realIndex, yAxisLabelsCoord, yAxisTitleCoord, yAxisOpposite); - yAxisTitle.setAttribute('x', x.xPos - (yAxisOpposite ? 10 : 0)); - } - - if (yAxisTitle !== null) { - var titleRotatingCenter = graphics.rotateAroundCenter(yAxisTitle); - yAxisTitle.setAttribute('transform', "rotate(".concat(yAxisOpposite ? w.config.yaxis[realIndex].title.rotate * -1 : w.config.yaxis[realIndex].title.rotate, " ").concat(titleRotatingCenter.x, " ").concat(titleRotatingCenter.y, ")")); - } - } - }, { - key: "xPaddingForYAxisTitle", - value: function xPaddingForYAxisTitle(realIndex, yAxisLabelsCoord, yAxisTitleCoord, yAxisOpposite) { - var w = this.w; - var oppositeAxisCount = 0; - var x = 0; - var padd = 10; - - if (w.config.yaxis[realIndex].title.text === undefined || realIndex < 0) { - return { - xPos: x, - padd: 0 - }; - } - - if (yAxisOpposite) { - x = yAxisLabelsCoord.width + w.config.yaxis[realIndex].title.offsetX + yAxisTitleCoord.width / 2 + padd / 2; - oppositeAxisCount += 1; - - if (oppositeAxisCount === 0) { - x = x - padd / 2; - } - } else { - x = yAxisLabelsCoord.width * -1 + w.config.yaxis[realIndex].title.offsetX + padd / 2 + yAxisTitleCoord.width / 2; - - if (w.globals.isBarHorizontal) { - padd = 25; - x = yAxisLabelsCoord.width * -1 - w.config.yaxis[realIndex].title.offsetX - padd; - } - } - - return { - xPos: x, - padd: padd - }; - } // sets the x position of the y-axis by counting the labels width, title width and any offset - - }, { - key: "setYAxisXPosition", - value: function setYAxisXPosition(yaxisLabelCoords, yTitleCoords) { - var w = this.w; - var xLeft = 0; - var xRight = 0; - var leftOffsetX = 18; - var rightOffsetX = 1; - - if (w.config.yaxis.length > 1) { - this.multipleYs = true; - } - - w.config.yaxis.map(function (yaxe, index) { - var shouldNotDrawAxis = w.globals.ignoreYAxisIndexes.indexOf(index) > -1 || !yaxe.show || yaxe.floating || yaxisLabelCoords[index].width === 0; - var axisWidth = yaxisLabelCoords[index].width + yTitleCoords[index].width; - - if (!yaxe.opposite) { - xLeft = w.globals.translateX - leftOffsetX; - - if (!shouldNotDrawAxis) { - leftOffsetX = leftOffsetX + axisWidth + 20; - } - - w.globals.translateYAxisX[index] = xLeft + yaxe.labels.offsetX; - } else { - if (w.globals.isBarHorizontal) { - xRight = w.globals.gridWidth + w.globals.translateX - 1; - w.globals.translateYAxisX[index] = xRight - yaxe.labels.offsetX; - } else { - xRight = w.globals.gridWidth + w.globals.translateX + rightOffsetX; - - if (!shouldNotDrawAxis) { - rightOffsetX = rightOffsetX + axisWidth + 20; - } - - w.globals.translateYAxisX[index] = xRight - yaxe.labels.offsetX + 20; - } - } - }); - } - }, { - key: "setYAxisTextAlignments", - value: function setYAxisTextAlignments() { - var w = this.w; - var yaxis = w.globals.dom.baseEl.getElementsByClassName("apexcharts-yaxis"); - yaxis = Utils$1.listToArray(yaxis); - yaxis.forEach(function (y, index) { - var yaxe = w.config.yaxis[index]; // proceed only if user has specified alignment - - if (yaxe && !yaxe.floating && yaxe.labels.align !== undefined) { - var yAxisInner = w.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(index, "'] .apexcharts-yaxis-texts-g")); - var yAxisTexts = w.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis[rel='".concat(index, "'] .apexcharts-yaxis-label")); - yAxisTexts = Utils$1.listToArray(yAxisTexts); - var rect = yAxisInner.getBoundingClientRect(); - - if (yaxe.labels.align === 'left') { - yAxisTexts.forEach(function (label, lI) { - label.setAttribute('text-anchor', 'start'); - }); - - if (!yaxe.opposite) { - yAxisInner.setAttribute('transform', "translate(-".concat(rect.width, ", 0)")); - } - } else if (yaxe.labels.align === 'center') { - yAxisTexts.forEach(function (label, lI) { - label.setAttribute('text-anchor', 'middle'); - }); - yAxisInner.setAttribute('transform', "translate(".concat(rect.width / 2 * (!yaxe.opposite ? -1 : 1), ", 0)")); - } else if (yaxe.labels.align === 'right') { - yAxisTexts.forEach(function (label, lI) { - label.setAttribute('text-anchor', 'end'); - }); - - if (yaxe.opposite) { - yAxisInner.setAttribute('transform', "translate(".concat(rect.width, ", 0)")); - } - } - } - }); - } - }]); - - return YAxis; - }(); - - var Events = /*#__PURE__*/function () { - function Events(ctx) { - _classCallCheck(this, Events); - - this.ctx = ctx; - this.w = ctx.w; - this.documentEvent = Utils$1.bind(this.documentEvent, this); - } - - _createClass(Events, [{ - key: "addEventListener", - value: function addEventListener(name, handler) { - var w = this.w; - - if (w.globals.events.hasOwnProperty(name)) { - w.globals.events[name].push(handler); - } else { - w.globals.events[name] = [handler]; - } - } - }, { - key: "removeEventListener", - value: function removeEventListener(name, handler) { - var w = this.w; - - if (!w.globals.events.hasOwnProperty(name)) { - return; - } - - var index = w.globals.events[name].indexOf(handler); - - if (index !== -1) { - w.globals.events[name].splice(index, 1); - } - } - }, { - key: "fireEvent", - value: function fireEvent(name, args) { - var w = this.w; - - if (!w.globals.events.hasOwnProperty(name)) { - return; - } - - if (!args || !args.length) { - args = []; - } - - var evs = w.globals.events[name]; - var l = evs.length; - - for (var i = 0; i < l; i++) { - evs[i].apply(null, args); - } - } - }, { - key: "setupEventHandlers", - value: function setupEventHandlers() { - var _this = this; - - var w = this.w; - var me = this.ctx; - var clickableArea = w.globals.dom.baseEl.querySelector(w.globals.chartClass); - this.ctx.eventList.forEach(function (event) { - clickableArea.addEventListener(event, function (e) { - var opts = Object.assign({}, w, { - seriesIndex: w.globals.capturedSeriesIndex, - dataPointIndex: w.globals.capturedDataPointIndex - }); - - if (e.type === 'mousemove' || e.type === 'touchmove') { - if (typeof w.config.chart.events.mouseMove === 'function') { - w.config.chart.events.mouseMove(e, me, opts); - } - } else if (e.type === 'mouseleave' || e.type === 'touchleave') { - if (typeof w.config.chart.events.mouseLeave === 'function') { - w.config.chart.events.mouseLeave(e, me, opts); - } - } else if (e.type === 'mouseup' && e.which === 1 || e.type === 'touchend') { - if (typeof w.config.chart.events.click === 'function') { - w.config.chart.events.click(e, me, opts); - } - - me.ctx.events.fireEvent('click', [e, me, opts]); - } - }, { - capture: false, - passive: true - }); - }); - this.ctx.eventList.forEach(function (event) { - w.globals.dom.baseEl.addEventListener(event, _this.documentEvent, { - passive: true - }); - }); - this.ctx.core.setupBrushHandler(); - } - }, { - key: "documentEvent", - value: function documentEvent(e) { - var w = this.w; - var target = e.target.className; - - if (e.type === 'click') { - var elMenu = w.globals.dom.baseEl.querySelector('.apexcharts-menu'); - - if (elMenu && elMenu.classList.contains('apexcharts-menu-open') && target !== 'apexcharts-menu-icon') { - elMenu.classList.remove('apexcharts-menu-open'); - } - } - - w.globals.clientX = e.type === 'touchmove' ? e.touches[0].clientX : e.clientX; - w.globals.clientY = e.type === 'touchmove' ? e.touches[0].clientY : e.clientY; - } - }]); - - return Events; - }(); - - var Localization = /*#__PURE__*/function () { - function Localization(ctx) { - _classCallCheck(this, Localization); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(Localization, [{ - key: "setCurrentLocaleValues", - value: function setCurrentLocaleValues(localeName) { - var locales = this.w.config.chart.locales; // check if user has specified locales in global Apex variable - // if yes - then extend those with local chart's locale - - if (window.Apex.chart && window.Apex.chart.locales && window.Apex.chart.locales.length > 0) { - locales = this.w.config.chart.locales.concat(window.Apex.chart.locales); - } // find the locale from the array of locales which user has set (either by chart.defaultLocale or by calling setLocale() method.) - - - var selectedLocale = locales.filter(function (c) { - return c.name === localeName; - })[0]; - - if (selectedLocale) { - // create a complete locale object by extending defaults so you don't get undefined errors. - var ret = Utils$1.extend(en, selectedLocale); // store these locale options in global var for ease access - - this.w.globals.locale = ret.options; - } else { - throw new Error('Wrong locale name provided. Please make sure you set the correct locale name in options'); - } - } - }]); - - return Localization; - }(); - - var Axes = /*#__PURE__*/function () { - function Axes(ctx) { - _classCallCheck(this, Axes); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(Axes, [{ - key: "drawAxis", - value: function drawAxis(type, elgrid) { - var _this = this; - - var gl = this.w.globals; - var cnf = this.w.config; - var xAxis = new XAxis(this.ctx, elgrid); - var yAxis = new YAxis(this.ctx, elgrid); - - if (gl.axisCharts && type !== 'radar') { - var elXaxis, elYaxis; - - if (gl.isBarHorizontal) { - elYaxis = yAxis.drawYaxisInversed(0); - elXaxis = xAxis.drawXaxisInversed(0); - gl.dom.elGraphical.add(elXaxis); - gl.dom.elGraphical.add(elYaxis); - } else { - elXaxis = xAxis.drawXaxis(); - gl.dom.elGraphical.add(elXaxis); - cnf.yaxis.map(function (yaxe, index) { - if (gl.ignoreYAxisIndexes.indexOf(index) === -1) { - elYaxis = yAxis.drawYaxis(index); - gl.dom.Paper.add(elYaxis); - - if (_this.w.config.grid.position === 'back') { - var inner = gl.dom.Paper.children()[1]; - inner.remove(); - gl.dom.Paper.add(inner); - } - } - }); - } - } - } - }]); - - return Axes; - }(); - - var Crosshairs = /*#__PURE__*/function () { - function Crosshairs(ctx) { - _classCallCheck(this, Crosshairs); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(Crosshairs, [{ - key: "drawXCrosshairs", - value: function drawXCrosshairs() { - var w = this.w; - var graphics = new Graphics(this.ctx); - var filters = new Filters(this.ctx); - var crosshairGradient = w.config.xaxis.crosshairs.fill.gradient; - var crosshairShadow = w.config.xaxis.crosshairs.dropShadow; - var fillType = w.config.xaxis.crosshairs.fill.type; - var gradientFrom = crosshairGradient.colorFrom; - var gradientTo = crosshairGradient.colorTo; - var opacityFrom = crosshairGradient.opacityFrom; - var opacityTo = crosshairGradient.opacityTo; - var stops = crosshairGradient.stops; - var shadow = 'none'; - var dropShadow = crosshairShadow.enabled; - var shadowLeft = crosshairShadow.left; - var shadowTop = crosshairShadow.top; - var shadowBlur = crosshairShadow.blur; - var shadowColor = crosshairShadow.color; - var shadowOpacity = crosshairShadow.opacity; - var xcrosshairsFill = w.config.xaxis.crosshairs.fill.color; - - if (w.config.xaxis.crosshairs.show) { - if (fillType === 'gradient') { - xcrosshairsFill = graphics.drawGradient('vertical', gradientFrom, gradientTo, opacityFrom, opacityTo, null, stops, null); - } - - var xcrosshairs = graphics.drawRect(); - - if (w.config.xaxis.crosshairs.width === 1) { - // to prevent drawing 2 lines, convert rect to line - xcrosshairs = graphics.drawLine(); - } - - var gridHeight = w.globals.gridHeight; - - if (!Utils$1.isNumber(gridHeight) || gridHeight < 0) { - gridHeight = 0; - } - - var crosshairsWidth = w.config.xaxis.crosshairs.width; - - if (!Utils$1.isNumber(crosshairsWidth) || crosshairsWidth < 0) { - crosshairsWidth = 0; - } - - xcrosshairs.attr({ - class: 'apexcharts-xcrosshairs', - x: 0, - y: 0, - y2: gridHeight, - width: crosshairsWidth, - height: gridHeight, - fill: xcrosshairsFill, - filter: shadow, - 'fill-opacity': w.config.xaxis.crosshairs.opacity, - stroke: w.config.xaxis.crosshairs.stroke.color, - 'stroke-width': w.config.xaxis.crosshairs.stroke.width, - 'stroke-dasharray': w.config.xaxis.crosshairs.stroke.dashArray - }); - - if (dropShadow) { - xcrosshairs = filters.dropShadow(xcrosshairs, { - left: shadowLeft, - top: shadowTop, - blur: shadowBlur, - color: shadowColor, - opacity: shadowOpacity - }); - } - - w.globals.dom.elGraphical.add(xcrosshairs); - } - } - }, { - key: "drawYCrosshairs", - value: function drawYCrosshairs() { - var w = this.w; - var graphics = new Graphics(this.ctx); - var crosshair = w.config.yaxis[0].crosshairs; - var offX = w.globals.barPadForNumericAxis; - - if (w.config.yaxis[0].crosshairs.show) { - var ycrosshairs = graphics.drawLine(-offX, 0, w.globals.gridWidth + offX, 0, crosshair.stroke.color, crosshair.stroke.dashArray, crosshair.stroke.width); - ycrosshairs.attr({ - class: 'apexcharts-ycrosshairs' - }); - w.globals.dom.elGraphical.add(ycrosshairs); - } // draw an invisible crosshair to help in positioning the yaxis tooltip - - - var ycrosshairsHidden = graphics.drawLine(-offX, 0, w.globals.gridWidth + offX, 0, crosshair.stroke.color, 0, 0); - ycrosshairsHidden.attr({ - class: 'apexcharts-ycrosshairs-hidden' - }); - w.globals.dom.elGraphical.add(ycrosshairsHidden); - } - }]); - - return Crosshairs; - }(); - - /** - * ApexCharts Responsive Class to override options for different screen sizes. - * - * @module Responsive - **/ - - var Responsive = /*#__PURE__*/function () { - function Responsive(ctx) { - _classCallCheck(this, Responsive); - - this.ctx = ctx; - this.w = ctx.w; - } // the opts parameter if not null has to be set overriding everything - // as the opts is set by user externally - - - _createClass(Responsive, [{ - key: "checkResponsiveConfig", - value: function checkResponsiveConfig(opts) { - var _this = this; - - var w = this.w; - var cnf = w.config; // check if responsive config exists - - if (cnf.responsive.length === 0) return; - var res = cnf.responsive.slice(); - res.sort(function (a, b) { - return a.breakpoint > b.breakpoint ? 1 : b.breakpoint > a.breakpoint ? -1 : 0; - }).reverse(); - var config = new Config({}); - - var iterateResponsiveOptions = function iterateResponsiveOptions() { - var newOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var largestBreakpoint = res[0].breakpoint; - var width = window.innerWidth > 0 ? window.innerWidth : screen.width; - - if (width > largestBreakpoint) { - var options = CoreUtils.extendArrayProps(config, w.globals.initialConfig, w); - newOptions = Utils$1.extend(options, newOptions); - newOptions = Utils$1.extend(w.config, newOptions); - - _this.overrideResponsiveOptions(newOptions); - } else { - for (var i = 0; i < res.length; i++) { - if (width < res[i].breakpoint) { - newOptions = CoreUtils.extendArrayProps(config, res[i].options, w); - newOptions = Utils$1.extend(w.config, newOptions); - - _this.overrideResponsiveOptions(newOptions); - } - } - } - }; - - if (opts) { - var options = CoreUtils.extendArrayProps(config, opts, w); - options = Utils$1.extend(w.config, options); - options = Utils$1.extend(options, opts); - iterateResponsiveOptions(options); - } else { - iterateResponsiveOptions({}); - } - } - }, { - key: "overrideResponsiveOptions", - value: function overrideResponsiveOptions(newOptions) { - var newConfig = new Config(newOptions).init({ - responsiveOverride: true - }); - this.w.config = newConfig; - } - }]); - - return Responsive; - }(); - - /** - * ApexCharts Theme Class for setting the colors and palettes. - * - * @module Theme - **/ - - var Theme = /*#__PURE__*/function () { - function Theme(ctx) { - _classCallCheck(this, Theme); - - this.ctx = ctx; - this.colors = []; - this.w = ctx.w; - var w = this.w; - this.isColorFn = false; - this.isHeatmapDistributed = w.config.chart.type === 'treemap' && w.config.plotOptions.treemap.distributed || w.config.chart.type === 'heatmap' && w.config.plotOptions.heatmap.distributed; - this.isBarDistributed = w.config.plotOptions.bar.distributed && (w.config.chart.type === 'bar' || w.config.chart.type === 'rangeBar'); - } - - _createClass(Theme, [{ - key: "init", - value: function init() { - this.setDefaultColors(); - } - }, { - key: "setDefaultColors", - value: function setDefaultColors() { - var _this = this; - - var w = this.w; - var utils = new Utils$1(); - w.globals.dom.elWrap.classList.add("apexcharts-theme-".concat(w.config.theme.mode)); - - if (w.config.colors === undefined) { - w.globals.colors = this.predefined(); - } else { - w.globals.colors = w.config.colors; // if user provided a function in colors, we need to eval here - - if (Array.isArray(w.config.colors) && w.config.colors.length > 0 && typeof w.config.colors[0] === 'function') { - w.globals.colors = w.config.series.map(function (s, i) { - var c = w.config.colors[i]; - if (!c) c = w.config.colors[0]; - - if (typeof c === 'function') { - _this.isColorFn = true; - return c({ - value: w.globals.axisCharts ? w.globals.series[i][0] ? w.globals.series[i][0] : 0 : w.globals.series[i], - seriesIndex: i, - dataPointIndex: i, - w: w - }); - } - - return c; - }); - } - } // user defined colors in series array - - - w.globals.seriesColors.map(function (c, i) { - if (c) { - w.globals.colors[i] = c; - } - }); - - if (w.config.theme.monochrome.enabled) { - var monoArr = []; - var glsCnt = w.globals.series.length; - - if (this.isBarDistributed || this.isHeatmapDistributed) { - glsCnt = w.globals.series[0].length * w.globals.series.length; - } - - var mainColor = w.config.theme.monochrome.color; - var part = 1 / (glsCnt / w.config.theme.monochrome.shadeIntensity); - var shade = w.config.theme.monochrome.shadeTo; - var percent = 0; - - for (var gsl = 0; gsl < glsCnt; gsl++) { - var newColor = void 0; - - if (shade === 'dark') { - newColor = utils.shadeColor(percent * -1, mainColor); - percent = percent + part; - } else { - newColor = utils.shadeColor(percent, mainColor); - percent = percent + part; - } - - monoArr.push(newColor); - } - - w.globals.colors = monoArr.slice(); - } - - var defaultColors = w.globals.colors.slice(); // if user specified fewer colors than no. of series, push the same colors again - - this.pushExtraColors(w.globals.colors); - var colorTypes = ['fill', 'stroke']; - colorTypes.forEach(function (c) { - if (w.config[c].colors === undefined) { - w.globals[c].colors = _this.isColorFn ? w.config.colors : defaultColors; - } else { - w.globals[c].colors = w.config[c].colors.slice(); - } - - _this.pushExtraColors(w.globals[c].colors); - }); - - if (w.config.dataLabels.style.colors === undefined) { - w.globals.dataLabels.style.colors = defaultColors; - } else { - w.globals.dataLabels.style.colors = w.config.dataLabels.style.colors.slice(); - } - - this.pushExtraColors(w.globals.dataLabels.style.colors, 50); - - if (w.config.plotOptions.radar.polygons.fill.colors === undefined) { - w.globals.radarPolygons.fill.colors = [w.config.theme.mode === 'dark' ? '#424242' : 'none']; - } else { - w.globals.radarPolygons.fill.colors = w.config.plotOptions.radar.polygons.fill.colors.slice(); - } - - this.pushExtraColors(w.globals.radarPolygons.fill.colors, 20); // The point colors - - if (w.config.markers.colors === undefined) { - w.globals.markers.colors = defaultColors; - } else { - w.globals.markers.colors = w.config.markers.colors.slice(); - } - - this.pushExtraColors(w.globals.markers.colors); - } // When the number of colors provided is less than the number of series, this method - // will push same colors to the list - // params: - // distributed is only valid for distributed column/bar charts - - }, { - key: "pushExtraColors", - value: function pushExtraColors(colorSeries, length) { - var distributed = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - var w = this.w; - var len = length || w.globals.series.length; - - if (distributed === null) { - distributed = this.isBarDistributed || this.isHeatmapDistributed || w.config.chart.type === 'heatmap' && w.config.plotOptions.heatmap.colorScale.inverse; - } - - if (distributed && w.globals.series.length) { - len = w.globals.series[w.globals.maxValsInArrayIndex].length * w.globals.series.length; - } - - if (colorSeries.length < len) { - var diff = len - colorSeries.length; - - for (var i = 0; i < diff; i++) { - colorSeries.push(colorSeries[i]); - } - } - } - }, { - key: "updateThemeOptions", - value: function updateThemeOptions(options) { - options.chart = options.chart || {}; - options.tooltip = options.tooltip || {}; - var mode = options.theme.mode || 'light'; - var palette = options.theme.palette ? options.theme.palette : mode === 'dark' ? 'palette4' : 'palette1'; - var foreColor = options.chart.foreColor ? options.chart.foreColor : mode === 'dark' ? '#f6f7f8' : '#373d3f'; - options.tooltip.theme = mode; - options.chart.foreColor = foreColor; - options.theme.palette = palette; - return options; - } - }, { - key: "predefined", - value: function predefined() { - var palette = this.w.config.theme.palette; // D6E3F8, FCEFEF, DCE0D9, A5978B, EDDDD4, D6E3F8, FEF5EF - - switch (palette) { - case 'palette1': - this.colors = ['#008FFB', '#00E396', '#FEB019', '#FF4560', '#775DD0']; - break; - - case 'palette2': - this.colors = ['#3f51b5', '#03a9f4', '#4caf50', '#f9ce1d', '#FF9800']; - break; - - case 'palette3': - this.colors = ['#33b2df', '#546E7A', '#d4526e', '#13d8aa', '#A5978B']; - break; - - case 'palette4': - this.colors = ['#4ecdc4', '#c7f464', '#81D4FA', '#fd6a6a', '#546E7A']; - break; - - case 'palette5': - this.colors = ['#2b908f', '#f9a3a4', '#90ee7e', '#fa4443', '#69d2e7']; - break; - - case 'palette6': - this.colors = ['#449DD1', '#F86624', '#EA3546', '#662E9B', '#C5D86D']; - break; - - case 'palette7': - this.colors = ['#D7263D', '#1B998B', '#2E294E', '#F46036', '#E2C044']; - break; - - case 'palette8': - this.colors = ['#662E9B', '#F86624', '#F9C80E', '#EA3546', '#43BCCD']; - break; - - case 'palette9': - this.colors = ['#5C4742', '#A5978B', '#8D5B4C', '#5A2A27', '#C4BBAF']; - break; - - case 'palette10': - this.colors = ['#A300D6', '#7D02EB', '#5653FE', '#2983FF', '#00B1F2']; - break; - - default: - this.colors = ['#008FFB', '#00E396', '#FEB019', '#FF4560', '#775DD0']; - break; - } - - return this.colors; - } - }]); - - return Theme; - }(); - - var TitleSubtitle = /*#__PURE__*/function () { - function TitleSubtitle(ctx) { - _classCallCheck(this, TitleSubtitle); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(TitleSubtitle, [{ - key: "draw", - value: function draw() { - this.drawTitleSubtitle('title'); - this.drawTitleSubtitle('subtitle'); - } - }, { - key: "drawTitleSubtitle", - value: function drawTitleSubtitle(type) { - var w = this.w; - var tsConfig = type === 'title' ? w.config.title : w.config.subtitle; - var x = w.globals.svgWidth / 2; - var y = tsConfig.offsetY; - var textAnchor = 'middle'; - - if (tsConfig.align === 'left') { - x = 10; - textAnchor = 'start'; - } else if (tsConfig.align === 'right') { - x = w.globals.svgWidth - 10; - textAnchor = 'end'; - } - - x = x + tsConfig.offsetX; - y = y + parseInt(tsConfig.style.fontSize, 10) + tsConfig.margin / 2; - - if (tsConfig.text !== undefined) { - var graphics = new Graphics(this.ctx); - var titleText = graphics.drawText({ - x: x, - y: y, - text: tsConfig.text, - textAnchor: textAnchor, - fontSize: tsConfig.style.fontSize, - fontFamily: tsConfig.style.fontFamily, - fontWeight: tsConfig.style.fontWeight, - foreColor: tsConfig.style.color, - opacity: 1 - }); - titleText.node.setAttribute('class', "apexcharts-".concat(type, "-text")); - w.globals.dom.Paper.add(titleText); - } - } - }]); - - return TitleSubtitle; - }(); - - var Helpers$3 = /*#__PURE__*/function () { - function Helpers(dCtx) { - _classCallCheck(this, Helpers); - - this.w = dCtx.w; - this.dCtx = dCtx; - } - /** - * Get Chart Title/Subtitle Dimensions - * @memberof Dimensions - * @return {{width, height}} - **/ - - - _createClass(Helpers, [{ - key: "getTitleSubtitleCoords", - value: function getTitleSubtitleCoords(type) { - var w = this.w; - var width = 0; - var height = 0; - var floating = type === 'title' ? w.config.title.floating : w.config.subtitle.floating; - var el = w.globals.dom.baseEl.querySelector(".apexcharts-".concat(type, "-text")); - - if (el !== null && !floating) { - var coord = el.getBoundingClientRect(); - width = coord.width; - height = w.globals.axisCharts ? coord.height + 5 : coord.height; - } - - return { - width: width, - height: height - }; - } - }, { - key: "getLegendsRect", - value: function getLegendsRect() { - var w = this.w; - var elLegendWrap = w.globals.dom.elLegendWrap; - - if (!w.config.legend.height && (w.config.legend.position === 'top' || w.config.legend.position === 'bottom')) { - // avoid legend to take up all the space - elLegendWrap.style.maxHeight = w.globals.svgHeight / 2 + 'px'; - } - - var lgRect = Object.assign({}, Utils$1.getBoundingClientRect(elLegendWrap)); - - if (elLegendWrap !== null && !w.config.legend.floating && w.config.legend.show) { - this.dCtx.lgRect = { - x: lgRect.x, - y: lgRect.y, - height: lgRect.height, - width: lgRect.height === 0 ? 0 : lgRect.width - }; - } else { - this.dCtx.lgRect = { - x: 0, - y: 0, - height: 0, - width: 0 - }; - } // if legend takes up all of the chart space, we need to restrict it. - - - if (w.config.legend.position === 'left' || w.config.legend.position === 'right') { - if (this.dCtx.lgRect.width * 1.5 > w.globals.svgWidth) { - this.dCtx.lgRect.width = w.globals.svgWidth / 1.5; - } - } - - return this.dCtx.lgRect; - } - }, { - key: "getLargestStringFromMultiArr", - value: function getLargestStringFromMultiArr(val, arr) { - var w = this.w; - var valArr = val; - - if (w.globals.isMultiLineX) { - // if the xaxis labels has multiline texts (array) - var maxArrs = arr.map(function (xl, idx) { - return Array.isArray(xl) ? xl.length : 1; - }); - var maxArrLen = Math.max.apply(Math, _toConsumableArray(maxArrs)); - var maxArrIndex = maxArrs.indexOf(maxArrLen); - valArr = arr[maxArrIndex]; - } - - return valArr; - } - }]); - - return Helpers; - }(); - - var DimXAxis = /*#__PURE__*/function () { - function DimXAxis(dCtx) { - _classCallCheck(this, DimXAxis); - - this.w = dCtx.w; - this.dCtx = dCtx; - } - /** - * Get X Axis Dimensions - * @memberof Dimensions - * @return {{width, height}} - **/ - - - _createClass(DimXAxis, [{ - key: "getxAxisLabelsCoords", - value: function getxAxisLabelsCoords() { - var w = this.w; - var xaxisLabels = w.globals.labels.slice(); - - if (w.config.xaxis.convertedCatToNumeric && xaxisLabels.length === 0) { - xaxisLabels = w.globals.categoryLabels; - } - - var rect; - - if (w.globals.timescaleLabels.length > 0) { - var coords = this.getxAxisTimeScaleLabelsCoords(); - rect = { - width: coords.width, - height: coords.height - }; - w.globals.rotateXLabels = false; - } else { - this.dCtx.lgWidthForSideLegends = (w.config.legend.position === 'left' || w.config.legend.position === 'right') && !w.config.legend.floating ? this.dCtx.lgRect.width : 0; // get the longest string from the labels array and also apply label formatter - - var xlbFormatter = w.globals.xLabelFormatter; // prevent changing xaxisLabels to avoid issues in multi-yaxes - fix #522 - - var val = Utils$1.getLargestStringFromArr(xaxisLabels); - var valArr = this.dCtx.dimHelpers.getLargestStringFromMultiArr(val, xaxisLabels); // the labels gets changed for bar charts - - if (w.globals.isBarHorizontal) { - val = w.globals.yAxisScale[0].result.reduce(function (a, b) { - return a.length > b.length ? a : b; - }, 0); - valArr = val; - } - - var xFormat = new Formatters(this.dCtx.ctx); - var timestamp = val; - val = xFormat.xLabelFormat(xlbFormatter, val, timestamp, { - i: undefined, - dateFormatter: new DateTime(this.dCtx.ctx).formatDate, - w: w - }); - valArr = xFormat.xLabelFormat(xlbFormatter, valArr, timestamp, { - i: undefined, - dateFormatter: new DateTime(this.dCtx.ctx).formatDate, - w: w - }); - - if (w.config.xaxis.convertedCatToNumeric && typeof val === 'undefined' || String(val).trim() === '') { - val = '1'; - valArr = val; - } - - var graphics = new Graphics(this.dCtx.ctx); - var xLabelrect = graphics.getTextRects(val, w.config.xaxis.labels.style.fontSize); - var xArrLabelrect = xLabelrect; - - if (val !== valArr) { - xArrLabelrect = graphics.getTextRects(valArr, w.config.xaxis.labels.style.fontSize); - } - - rect = { - width: xLabelrect.width >= xArrLabelrect.width ? xLabelrect.width : xArrLabelrect.width, - height: xLabelrect.height >= xArrLabelrect.height ? xLabelrect.height : xArrLabelrect.height - }; - - if (rect.width * xaxisLabels.length > w.globals.svgWidth - this.dCtx.lgWidthForSideLegends - this.dCtx.yAxisWidth - this.dCtx.gridPad.left - this.dCtx.gridPad.right && w.config.xaxis.labels.rotate !== 0 || w.config.xaxis.labels.rotateAlways) { - if (!w.globals.isBarHorizontal) { - w.globals.rotateXLabels = true; - - var getRotatedTextRects = function getRotatedTextRects(text) { - return graphics.getTextRects(text, w.config.xaxis.labels.style.fontSize, w.config.xaxis.labels.style.fontFamily, "rotate(".concat(w.config.xaxis.labels.rotate, " 0 0)"), false); - }; - - xLabelrect = getRotatedTextRects(val); - - if (val !== valArr) { - xArrLabelrect = getRotatedTextRects(valArr); - } - - rect.height = (xLabelrect.height > xArrLabelrect.height ? xLabelrect.height : xArrLabelrect.height) / 1.5; - rect.width = xLabelrect.width > xArrLabelrect.width ? xLabelrect.width : xArrLabelrect.width; - } - } else { - w.globals.rotateXLabels = false; - } - } - - if (!w.config.xaxis.labels.show) { - rect = { - width: 0, - height: 0 - }; - } - - return { - width: rect.width, - height: rect.height - }; - } - /** - * Get X Axis Label Group height - * @memberof Dimensions - * @return {{width, height}} - */ - - }, { - key: "getxAxisGroupLabelsCoords", - value: function getxAxisGroupLabelsCoords() { - var _w$config$xaxis$group; - - var w = this.w; - - if (!w.globals.hasXaxisGroups) { - return { - width: 0, - height: 0 - }; - } - - var fontSize = ((_w$config$xaxis$group = w.config.xaxis.group.style) === null || _w$config$xaxis$group === void 0 ? void 0 : _w$config$xaxis$group.fontSize) || w.config.xaxis.labels.style.fontSize; - var xaxisLabels = w.globals.groups.map(function (g) { - return g.title; - }); - var rect; // prevent changing xaxisLabels to avoid issues in multi-yaxes - fix #522 - - var val = Utils$1.getLargestStringFromArr(xaxisLabels); - var valArr = this.dCtx.dimHelpers.getLargestStringFromMultiArr(val, xaxisLabels); - var graphics = new Graphics(this.dCtx.ctx); - var xLabelrect = graphics.getTextRects(val, fontSize); - var xArrLabelrect = xLabelrect; - - if (val !== valArr) { - xArrLabelrect = graphics.getTextRects(valArr, fontSize); - } - - rect = { - width: xLabelrect.width >= xArrLabelrect.width ? xLabelrect.width : xArrLabelrect.width, - height: xLabelrect.height >= xArrLabelrect.height ? xLabelrect.height : xArrLabelrect.height - }; - - if (!w.config.xaxis.labels.show) { - rect = { - width: 0, - height: 0 - }; - } - - return { - width: rect.width, - height: rect.height - }; - } - /** - * Get X Axis Title Dimensions - * @memberof Dimensions - * @return {{width, height}} - **/ - - }, { - key: "getxAxisTitleCoords", - value: function getxAxisTitleCoords() { - var w = this.w; - var width = 0; - var height = 0; - - if (w.config.xaxis.title.text !== undefined) { - var graphics = new Graphics(this.dCtx.ctx); - var rect = graphics.getTextRects(w.config.xaxis.title.text, w.config.xaxis.title.style.fontSize); - width = rect.width; - height = rect.height; - } - - return { - width: width, - height: height - }; - } - }, { - key: "getxAxisTimeScaleLabelsCoords", - value: function getxAxisTimeScaleLabelsCoords() { - var w = this.w; - var rect; - this.dCtx.timescaleLabels = w.globals.timescaleLabels.slice(); - var labels = this.dCtx.timescaleLabels.map(function (label) { - return label.value; - }); // get the longest string from the labels array and also apply label formatter to it - - var val = labels.reduce(function (a, b) { - // if undefined, maybe user didn't pass the datetime(x) values - if (typeof a === 'undefined') { - console.error('You have possibly supplied invalid Date format. Please supply a valid JavaScript Date'); - return 0; - } else { - return a.length > b.length ? a : b; - } - }, 0); - var graphics = new Graphics(this.dCtx.ctx); - rect = graphics.getTextRects(val, w.config.xaxis.labels.style.fontSize); - var totalWidthRotated = rect.width * 1.05 * labels.length; - - if (totalWidthRotated > w.globals.gridWidth && w.config.xaxis.labels.rotate !== 0) { - w.globals.overlappingXLabels = true; - } - - return rect; - } // In certain cases, the last labels gets cropped in xaxis. - // Hence, we add some additional padding based on the label length to avoid the last label being cropped or we don't draw it at all - - }, { - key: "additionalPaddingXLabels", - value: function additionalPaddingXLabels(xaxisLabelCoords) { - var _this = this; - - var w = this.w; - var gl = w.globals; - var cnf = w.config; - var xtype = cnf.xaxis.type; - var lbWidth = xaxisLabelCoords.width; - gl.skipLastTimelinelabel = false; - gl.skipFirstTimelinelabel = false; - var isBarOpposite = w.config.yaxis[0].opposite && w.globals.isBarHorizontal; - - var isCollapsed = function isCollapsed(i) { - return gl.collapsedSeriesIndices.indexOf(i) !== -1; - }; - - var rightPad = function rightPad(yaxe) { - if (_this.dCtx.timescaleLabels && _this.dCtx.timescaleLabels.length) { - // for timeline labels, we take the last label and check if it exceeds gridWidth - var firstimescaleLabel = _this.dCtx.timescaleLabels[0]; - var lastTimescaleLabel = _this.dCtx.timescaleLabels[_this.dCtx.timescaleLabels.length - 1]; - var lastLabelPosition = lastTimescaleLabel.position + lbWidth / 1.75 - _this.dCtx.yAxisWidthRight; - var firstLabelPosition = firstimescaleLabel.position - lbWidth / 1.75 + _this.dCtx.yAxisWidthLeft; - var lgRightRectWidth = w.config.legend.position === 'right' && _this.dCtx.lgRect.width > 0 ? _this.dCtx.lgRect.width : 0; - - if (lastLabelPosition > gl.svgWidth - gl.translateX - lgRightRectWidth) { - gl.skipLastTimelinelabel = true; - } - - if (firstLabelPosition < -((!yaxe.show || yaxe.floating) && (cnf.chart.type === 'bar' || cnf.chart.type === 'candlestick' || cnf.chart.type === 'rangeBar' || cnf.chart.type === 'boxPlot') ? lbWidth / 1.75 : 10)) { - gl.skipFirstTimelinelabel = true; - } - } else if (xtype === 'datetime') { - // If user has enabled DateTime, but uses own's formatter - if (_this.dCtx.gridPad.right < lbWidth && !gl.rotateXLabels) { - gl.skipLastTimelinelabel = true; - } - } else if (xtype !== 'datetime') { - if (_this.dCtx.gridPad.right < lbWidth / 2 - _this.dCtx.yAxisWidthRight && !gl.rotateXLabels && !w.config.xaxis.labels.trim && (w.config.xaxis.tickPlacement !== 'between' || w.globals.isBarHorizontal)) { - _this.dCtx.xPadRight = lbWidth / 2 + 1; - } - } - }; - - var padYAxe = function padYAxe(yaxe, i) { - if (cnf.yaxis.length > 1 && isCollapsed(i)) return; - rightPad(yaxe); - }; - - cnf.yaxis.forEach(function (yaxe, i) { - if (isBarOpposite) { - if (_this.dCtx.gridPad.left < lbWidth) { - _this.dCtx.xPadLeft = lbWidth / 2 + 1; - } - - _this.dCtx.xPadRight = lbWidth / 2 + 1; - } else { - padYAxe(yaxe, i); - } - }); - } - }]); - - return DimXAxis; - }(); - - var DimYAxis = /*#__PURE__*/function () { - function DimYAxis(dCtx) { - _classCallCheck(this, DimYAxis); - - this.w = dCtx.w; - this.dCtx = dCtx; - } - /** - * Get Y Axis Dimensions - * @memberof Dimensions - * @return {{width, height}} - **/ - - - _createClass(DimYAxis, [{ - key: "getyAxisLabelsCoords", - value: function getyAxisLabelsCoords() { - var _this = this; - - var w = this.w; - var width = 0; - var height = 0; - var ret = []; - var labelPad = 10; - var axesUtils = new AxesUtils(this.dCtx.ctx); - w.config.yaxis.map(function (yaxe, index) { - var yS = w.globals.yAxisScale[index]; - var yAxisMinWidth = 0; - if (!axesUtils.isYAxisHidden(index) && yaxe.labels.show && yaxe.labels.minWidth !== undefined) yAxisMinWidth = yaxe.labels.minWidth; - - if (!axesUtils.isYAxisHidden(index) && yaxe.labels.show && yS.result.length) { - var lbFormatter = w.globals.yLabelFormatters[index]; - var minV = yS.niceMin === Number.MIN_VALUE ? 0 : yS.niceMin; - var longestStr = String(minV).length > String(yS.niceMax).length ? minV : yS.niceMax; // the second parameter -1 is the index of tick which user can use in the formatter - - var val = lbFormatter(longestStr, { - seriesIndex: index, - dataPointIndex: -1, - w: w - }); - var valArr = val; // if user has specified a custom formatter, and the result is null or empty, we need to discard the formatter and take the value as it is. - - if (typeof val === 'undefined' || val.length === 0) { - val = longestStr; - } - - if (w.globals.isBarHorizontal) { - labelPad = 0; - var barYaxisLabels = w.globals.labels.slice(); // get the longest string from the labels array and also apply label formatter to it - - val = Utils$1.getLargestStringFromArr(barYaxisLabels); - val = lbFormatter(val, { - seriesIndex: index, - dataPointIndex: -1, - w: w - }); - valArr = _this.dCtx.dimHelpers.getLargestStringFromMultiArr(val, barYaxisLabels); - } - - var graphics = new Graphics(_this.dCtx.ctx); - var rotateStr = 'rotate('.concat(yaxe.labels.rotate, ' 0 0)'); - var rect = graphics.getTextRects(val, yaxe.labels.style.fontSize, yaxe.labels.style.fontFamily, rotateStr, false); - var arrLabelrect = rect; - - if (val !== valArr) { - arrLabelrect = graphics.getTextRects(valArr, yaxe.labels.style.fontSize, yaxe.labels.style.fontFamily, rotateStr, false); - } - - ret.push({ - width: (yAxisMinWidth > arrLabelrect.width || yAxisMinWidth > rect.width ? yAxisMinWidth : arrLabelrect.width > rect.width ? arrLabelrect.width : rect.width) + labelPad, - height: arrLabelrect.height > rect.height ? arrLabelrect.height : rect.height - }); - } else { - ret.push({ - width: width, - height: height - }); - } - }); - return ret; - } - /** - * Get Y Axis Dimensions - * @memberof Dimensions - * @return {{width, height}} - **/ - - }, { - key: "getyAxisTitleCoords", - value: function getyAxisTitleCoords() { - var _this2 = this; - - var w = this.w; - var ret = []; - w.config.yaxis.map(function (yaxe, index) { - if (yaxe.show && yaxe.title.text !== undefined) { - var graphics = new Graphics(_this2.dCtx.ctx); - var rotateStr = 'rotate('.concat(yaxe.title.rotate, ' 0 0)'); - var rect = graphics.getTextRects(yaxe.title.text, yaxe.title.style.fontSize, yaxe.title.style.fontFamily, rotateStr, false); - ret.push({ - width: rect.width, - height: rect.height - }); - } else { - ret.push({ - width: 0, - height: 0 - }); - } - }); - return ret; - } - }, { - key: "getTotalYAxisWidth", - value: function getTotalYAxisWidth() { - var w = this.w; - var yAxisWidth = 0; - var yAxisWidthLeft = 0; - var yAxisWidthRight = 0; - var padding = w.globals.yAxisScale.length > 1 ? 10 : 0; - var axesUtils = new AxesUtils(this.dCtx.ctx); - - var isHiddenYAxis = function isHiddenYAxis(index) { - return w.globals.ignoreYAxisIndexes.indexOf(index) > -1; - }; - - var padForLabelTitle = function padForLabelTitle(coord, index) { - var floating = w.config.yaxis[index].floating; - var width = 0; - - if (coord.width > 0 && !floating) { - width = coord.width + padding; - - if (isHiddenYAxis(index)) { - width = width - coord.width - padding; - } - } else { - width = floating || axesUtils.isYAxisHidden(index) ? 0 : 5; - } - - w.config.yaxis[index].opposite ? yAxisWidthRight = yAxisWidthRight + width : yAxisWidthLeft = yAxisWidthLeft + width; - yAxisWidth = yAxisWidth + width; - }; - - w.globals.yLabelsCoords.map(function (yLabelCoord, index) { - padForLabelTitle(yLabelCoord, index); - }); - w.globals.yTitleCoords.map(function (yTitleCoord, index) { - padForLabelTitle(yTitleCoord, index); - }); - - if (w.globals.isBarHorizontal && !w.config.yaxis[0].floating) { - yAxisWidth = w.globals.yLabelsCoords[0].width + w.globals.yTitleCoords[0].width + 15; - } - - this.dCtx.yAxisWidthLeft = yAxisWidthLeft; - this.dCtx.yAxisWidthRight = yAxisWidthRight; - return yAxisWidth; - } - }]); - - return DimYAxis; - }(); - - var DimGrid = /*#__PURE__*/function () { - function DimGrid(dCtx) { - _classCallCheck(this, DimGrid); - - this.w = dCtx.w; - this.dCtx = dCtx; - } - - _createClass(DimGrid, [{ - key: "gridPadForColumnsInNumericAxis", - value: function gridPadForColumnsInNumericAxis(gridWidth) { - var w = this.w; - - if (w.globals.noData || w.globals.allSeriesCollapsed) { - return 0; - } - - var hasBar = function hasBar(type) { - return type === 'bar' || type === 'rangeBar' || type === 'candlestick' || type === 'boxPlot'; - }; - - var type = w.config.chart.type; - var barWidth = 0; - var seriesLen = hasBar(type) ? w.config.series.length : 1; - - if (w.globals.comboBarCount > 0) { - seriesLen = w.globals.comboBarCount; - } - - w.globals.collapsedSeries.forEach(function (c) { - if (hasBar(c.type)) { - seriesLen = seriesLen - 1; - } - }); - - if (w.config.chart.stacked) { - seriesLen = 1; - } - - var barsPresent = hasBar(type) || w.globals.comboBarCount > 0; - - if (barsPresent && w.globals.isXNumeric && !w.globals.isBarHorizontal && seriesLen > 0) { - var xRatio = 0; - var xRange = Math.abs(w.globals.initialMaxX - w.globals.initialMinX); - - if (xRange <= 3) { - xRange = w.globals.dataPoints; - } - - xRatio = xRange / gridWidth; - var xDivision; // max barwidth should be equal to minXDiff to avoid overlap - - if (w.globals.minXDiff && w.globals.minXDiff / xRatio > 0) { - xDivision = w.globals.minXDiff / xRatio; - } - - if (xDivision > gridWidth / 2) { - xDivision = xDivision / 2; - } - - barWidth = xDivision / seriesLen * parseInt(w.config.plotOptions.bar.columnWidth, 10) / 100; - - if (barWidth < 1) { - barWidth = 1; - } - - barWidth = barWidth / (seriesLen > 1 ? 1 : 1.5) + 5; - w.globals.barPadForNumericAxis = barWidth; - } - - return barWidth; - } - }, { - key: "gridPadFortitleSubtitle", - value: function gridPadFortitleSubtitle() { - var _this = this; - - var w = this.w; - var gl = w.globals; - var gridShrinkOffset = this.dCtx.isSparkline || !w.globals.axisCharts ? 0 : 10; - var titleSubtitle = ['title', 'subtitle']; - titleSubtitle.forEach(function (t) { - if (w.config[t].text !== undefined) { - gridShrinkOffset += w.config[t].margin; - } else { - gridShrinkOffset += _this.dCtx.isSparkline || !w.globals.axisCharts ? 0 : 5; - } - }); - - if (w.config.legend.show && w.config.legend.position === 'bottom' && !w.config.legend.floating && !w.globals.axisCharts) { - gridShrinkOffset += 10; - } - - var titleCoords = this.dCtx.dimHelpers.getTitleSubtitleCoords('title'); - var subtitleCoords = this.dCtx.dimHelpers.getTitleSubtitleCoords('subtitle'); - gl.gridHeight = gl.gridHeight - titleCoords.height - subtitleCoords.height - gridShrinkOffset; - gl.translateY = gl.translateY + titleCoords.height + subtitleCoords.height + gridShrinkOffset; - } - }, { - key: "setGridXPosForDualYAxis", - value: function setGridXPosForDualYAxis(yTitleCoords, yaxisLabelCoords) { - var w = this.w; - var axesUtils = new AxesUtils(this.dCtx.ctx); - w.config.yaxis.map(function (yaxe, index) { - if (w.globals.ignoreYAxisIndexes.indexOf(index) === -1 && !yaxe.floating && !axesUtils.isYAxisHidden(index)) { - if (yaxe.opposite) { - w.globals.translateX = w.globals.translateX - (yaxisLabelCoords[index].width + yTitleCoords[index].width) - parseInt(w.config.yaxis[index].labels.style.fontSize, 10) / 1.2 - 12; - } // fixes apexcharts.js#1599 - - - if (w.globals.translateX < 2) { - w.globals.translateX = 2; - } - } - }); - } - }]); - - return DimGrid; - }(); - - /** - * ApexCharts Dimensions Class for calculating rects of all elements that are drawn and will be drawn. - * - * @module Dimensions - **/ - - var Dimensions = /*#__PURE__*/function () { - function Dimensions(ctx) { - _classCallCheck(this, Dimensions); - - this.ctx = ctx; - this.w = ctx.w; - this.lgRect = {}; - this.yAxisWidth = 0; - this.yAxisWidthLeft = 0; - this.yAxisWidthRight = 0; - this.xAxisHeight = 0; - this.isSparkline = this.w.config.chart.sparkline.enabled; - this.dimHelpers = new Helpers$3(this); - this.dimYAxis = new DimYAxis(this); - this.dimXAxis = new DimXAxis(this); - this.dimGrid = new DimGrid(this); - this.lgWidthForSideLegends = 0; - this.gridPad = this.w.config.grid.padding; - this.xPadRight = 0; - this.xPadLeft = 0; - } - /** - * @memberof Dimensions - * @param {object} w - chart context - **/ - - - _createClass(Dimensions, [{ - key: "plotCoords", - value: function plotCoords() { - var _this = this; - - var w = this.w; - var gl = w.globals; - this.lgRect = this.dimHelpers.getLegendsRect(); - - if (this.isSparkline && (w.config.markers.discrete.length > 0 || w.config.markers.size > 0)) { - Object.entries(this.gridPad).forEach(function (_ref) { - var _ref2 = _slicedToArray(_ref, 2), - k = _ref2[0], - v = _ref2[1]; - - _this.gridPad[k] = Math.max(v, _this.w.globals.markers.largestSize / 1.5); - }); - } - - if (gl.axisCharts) { - // for line / area / scatter / column - this.setDimensionsForAxisCharts(); - } else { - // for pie / donuts / circle - this.setDimensionsForNonAxisCharts(); - } - - this.dimGrid.gridPadFortitleSubtitle(); // after calculating everything, apply padding set by user - - gl.gridHeight = gl.gridHeight - this.gridPad.top - this.gridPad.bottom; - gl.gridWidth = gl.gridWidth - this.gridPad.left - this.gridPad.right - this.xPadRight - this.xPadLeft; - var barWidth = this.dimGrid.gridPadForColumnsInNumericAxis(gl.gridWidth); - gl.gridWidth = gl.gridWidth - barWidth * 2; - gl.translateX = gl.translateX + this.gridPad.left + this.xPadLeft + (barWidth > 0 ? barWidth + 4 : 0); - gl.translateY = gl.translateY + this.gridPad.top; - } - }, { - key: "setDimensionsForAxisCharts", - value: function setDimensionsForAxisCharts() { - var _this2 = this; - - var w = this.w; - var gl = w.globals; - var yaxisLabelCoords = this.dimYAxis.getyAxisLabelsCoords(); - var yTitleCoords = this.dimYAxis.getyAxisTitleCoords(); - w.globals.yLabelsCoords = []; - w.globals.yTitleCoords = []; - w.config.yaxis.map(function (yaxe, index) { - // store the labels and titles coords in global vars - w.globals.yLabelsCoords.push({ - width: yaxisLabelCoords[index].width, - index: index - }); - w.globals.yTitleCoords.push({ - width: yTitleCoords[index].width, - index: index - }); - }); - this.yAxisWidth = this.dimYAxis.getTotalYAxisWidth(); - var xaxisLabelCoords = this.dimXAxis.getxAxisLabelsCoords(); - var xaxisGroupLabelCoords = this.dimXAxis.getxAxisGroupLabelsCoords(); - var xtitleCoords = this.dimXAxis.getxAxisTitleCoords(); - this.conditionalChecksForAxisCoords(xaxisLabelCoords, xtitleCoords, xaxisGroupLabelCoords); - gl.translateXAxisY = w.globals.rotateXLabels ? this.xAxisHeight / 8 : -4; - gl.translateXAxisX = w.globals.rotateXLabels && w.globals.isXNumeric && w.config.xaxis.labels.rotate <= -45 ? -this.xAxisWidth / 4 : 0; - - if (w.globals.isBarHorizontal) { - gl.rotateXLabels = false; - gl.translateXAxisY = -1 * (parseInt(w.config.xaxis.labels.style.fontSize, 10) / 1.5); - } - - gl.translateXAxisY = gl.translateXAxisY + w.config.xaxis.labels.offsetY; - gl.translateXAxisX = gl.translateXAxisX + w.config.xaxis.labels.offsetX; - var yAxisWidth = this.yAxisWidth; - var xAxisHeight = this.xAxisHeight; - gl.xAxisLabelsHeight = this.xAxisHeight - xtitleCoords.height; - gl.xAxisGroupLabelsHeight = gl.xAxisLabelsHeight - xaxisLabelCoords.height; - gl.xAxisLabelsWidth = this.xAxisWidth; - gl.xAxisHeight = this.xAxisHeight; - var translateY = 10; - - if (w.config.chart.type === 'radar' || this.isSparkline) { - yAxisWidth = 0; - xAxisHeight = gl.goldenPadding; - } - - if (this.isSparkline) { - this.lgRect = { - height: 0, - width: 0 - }; - } - - if (this.isSparkline || w.config.chart.type === 'treemap') { - yAxisWidth = 0; - xAxisHeight = 0; - translateY = 0; - } - - if (!this.isSparkline) { - this.dimXAxis.additionalPaddingXLabels(xaxisLabelCoords); - } - - var legendTopBottom = function legendTopBottom() { - gl.translateX = yAxisWidth; - gl.gridHeight = gl.svgHeight - _this2.lgRect.height - xAxisHeight - (!_this2.isSparkline && w.config.chart.type !== 'treemap' ? w.globals.rotateXLabels ? 10 : 15 : 0); - gl.gridWidth = gl.svgWidth - yAxisWidth; - }; - - if (w.config.xaxis.position === 'top') translateY = gl.xAxisHeight - w.config.xaxis.axisTicks.height - 5; - - switch (w.config.legend.position) { - case 'bottom': - gl.translateY = translateY; - legendTopBottom(); - break; - - case 'top': - gl.translateY = this.lgRect.height + translateY; - legendTopBottom(); - break; - - case 'left': - gl.translateY = translateY; - gl.translateX = this.lgRect.width + yAxisWidth; - gl.gridHeight = gl.svgHeight - xAxisHeight - 12; - gl.gridWidth = gl.svgWidth - this.lgRect.width - yAxisWidth; - break; - - case 'right': - gl.translateY = translateY; - gl.translateX = yAxisWidth; - gl.gridHeight = gl.svgHeight - xAxisHeight - 12; - gl.gridWidth = gl.svgWidth - this.lgRect.width - yAxisWidth - 5; - break; - - default: - throw new Error('Legend position not supported'); - } - - this.dimGrid.setGridXPosForDualYAxis(yTitleCoords, yaxisLabelCoords); // after drawing everything, set the Y axis positions - - var objyAxis = new YAxis(this.ctx); - objyAxis.setYAxisXPosition(yaxisLabelCoords, yTitleCoords); - } - }, { - key: "setDimensionsForNonAxisCharts", - value: function setDimensionsForNonAxisCharts() { - var w = this.w; - var gl = w.globals; - var cnf = w.config; - var xPad = 0; - - if (w.config.legend.show && !w.config.legend.floating) { - xPad = 20; - } - - var type = cnf.chart.type === 'pie' || cnf.chart.type === 'polarArea' || cnf.chart.type === 'donut' ? 'pie' : 'radialBar'; - var offY = cnf.plotOptions[type].offsetY; - var offX = cnf.plotOptions[type].offsetX; - - if (!cnf.legend.show || cnf.legend.floating) { - gl.gridHeight = gl.svgHeight - cnf.grid.padding.left + cnf.grid.padding.right; - gl.gridWidth = gl.gridHeight; - gl.translateY = offY; - gl.translateX = offX + (gl.svgWidth - gl.gridWidth) / 2; - return; - } - - switch (cnf.legend.position) { - case 'bottom': - gl.gridHeight = gl.svgHeight - this.lgRect.height - gl.goldenPadding; - gl.gridWidth = gl.svgWidth; - gl.translateY = offY - 10; - gl.translateX = offX + (gl.svgWidth - gl.gridWidth) / 2; - break; - - case 'top': - gl.gridHeight = gl.svgHeight - this.lgRect.height - gl.goldenPadding; - gl.gridWidth = gl.svgWidth; - gl.translateY = this.lgRect.height + offY + 10; - gl.translateX = offX + (gl.svgWidth - gl.gridWidth) / 2; - break; - - case 'left': - gl.gridWidth = gl.svgWidth - this.lgRect.width - xPad; - gl.gridHeight = cnf.chart.height !== 'auto' ? gl.svgHeight : gl.gridWidth; - gl.translateY = offY; - gl.translateX = offX + this.lgRect.width + xPad; - break; - - case 'right': - gl.gridWidth = gl.svgWidth - this.lgRect.width - xPad - 5; - gl.gridHeight = cnf.chart.height !== 'auto' ? gl.svgHeight : gl.gridWidth; - gl.translateY = offY; - gl.translateX = offX + 10; - break; - - default: - throw new Error('Legend position not supported'); - } - } - }, { - key: "conditionalChecksForAxisCoords", - value: function conditionalChecksForAxisCoords(xaxisLabelCoords, xtitleCoords, xaxisGroupLabelCoords) { - var w = this.w; - var xAxisNum = w.globals.hasXaxisGroups ? 2 : 1; - var baseXAxisHeight = xaxisGroupLabelCoords.height + xaxisLabelCoords.height + xtitleCoords.height; - var xAxisHeightMultiplicate = w.globals.isMultiLineX ? 1.2 : w.globals.LINE_HEIGHT_RATIO; - var rotatedXAxisOffset = w.globals.rotateXLabels ? 22 : 10; - var rotatedXAxisLegendOffset = w.globals.rotateXLabels && w.config.legend.position === 'bottom'; - var additionalOffset = rotatedXAxisLegendOffset ? 10 : 0; - this.xAxisHeight = baseXAxisHeight * xAxisHeightMultiplicate + xAxisNum * rotatedXAxisOffset + additionalOffset; - this.xAxisWidth = xaxisLabelCoords.width; - - if (this.xAxisHeight - xtitleCoords.height > w.config.xaxis.labels.maxHeight) { - this.xAxisHeight = w.config.xaxis.labels.maxHeight; - } - - if (w.config.xaxis.labels.minHeight && this.xAxisHeight < w.config.xaxis.labels.minHeight) { - this.xAxisHeight = w.config.xaxis.labels.minHeight; - } - - if (w.config.xaxis.floating) { - this.xAxisHeight = 0; - } - - var minYAxisWidth = 0; - var maxYAxisWidth = 0; - w.config.yaxis.forEach(function (y) { - minYAxisWidth += y.labels.minWidth; - maxYAxisWidth += y.labels.maxWidth; - }); - - if (this.yAxisWidth < minYAxisWidth) { - this.yAxisWidth = minYAxisWidth; - } - - if (this.yAxisWidth > maxYAxisWidth) { - this.yAxisWidth = maxYAxisWidth; - } - } - }]); - - return Dimensions; - }(); - - var Helpers$2 = /*#__PURE__*/function () { - function Helpers(lgCtx) { - _classCallCheck(this, Helpers); - - this.w = lgCtx.w; - this.lgCtx = lgCtx; - } - - _createClass(Helpers, [{ - key: "getLegendStyles", - value: function getLegendStyles() { - var stylesheet = document.createElement('style'); - stylesheet.setAttribute('type', 'text/css'); - var text = "\t\n \t\n .apexcharts-legend {\t\n display: flex;\t\n overflow: auto;\t\n padding: 0 10px;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom, .apexcharts-legend.apx-legend-position-top {\t\n flex-wrap: wrap\t\n }\t\n .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n flex-direction: column;\t\n bottom: 0;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-left, .apexcharts-legend.apx-legend-position-top.apexcharts-align-left, .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n justify-content: flex-start;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-center, .apexcharts-legend.apx-legend-position-top.apexcharts-align-center {\t\n justify-content: center; \t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-right, .apexcharts-legend.apx-legend-position-top.apexcharts-align-right {\t\n justify-content: flex-end;\t\n }\t\n .apexcharts-legend-series {\t\n cursor: pointer;\t\n line-height: normal;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom .apexcharts-legend-series, .apexcharts-legend.apx-legend-position-top .apexcharts-legend-series{\t\n display: flex;\t\n align-items: center;\t\n }\t\n .apexcharts-legend-text {\t\n position: relative;\t\n font-size: 14px;\t\n }\t\n .apexcharts-legend-text *, .apexcharts-legend-marker * {\t\n pointer-events: none;\t\n }\t\n .apexcharts-legend-marker {\t\n position: relative;\t\n display: inline-block;\t\n cursor: pointer;\t\n margin-right: 3px;\t\n border-style: solid;\n }\t\n \t\n .apexcharts-legend.apexcharts-align-right .apexcharts-legend-series, .apexcharts-legend.apexcharts-align-left .apexcharts-legend-series{\t\n display: inline-block;\t\n }\t\n .apexcharts-legend-series.apexcharts-no-click {\t\n cursor: auto;\t\n }\t\n .apexcharts-legend .apexcharts-hidden-zero-series, .apexcharts-legend .apexcharts-hidden-null-series {\t\n display: none !important;\t\n }\t\n .apexcharts-inactive-legend {\t\n opacity: 0.45;\t\n }"; - var rules = document.createTextNode(text); - stylesheet.appendChild(rules); - return stylesheet; - } - }, { - key: "getLegendBBox", - value: function getLegendBBox() { - var w = this.w; - var currLegendsWrap = w.globals.dom.baseEl.querySelector('.apexcharts-legend'); - var currLegendsWrapRect = currLegendsWrap.getBoundingClientRect(); - var currLegendsWrapWidth = currLegendsWrapRect.width; - var currLegendsWrapHeight = currLegendsWrapRect.height; - return { - clwh: currLegendsWrapHeight, - clww: currLegendsWrapWidth - }; - } - }, { - key: "appendToForeignObject", - value: function appendToForeignObject() { - var gl = this.w.globals; - gl.dom.elLegendForeign.appendChild(this.getLegendStyles()); - } - }, { - key: "toggleDataSeries", - value: function toggleDataSeries(seriesCnt, isHidden) { - var _this = this; - - var w = this.w; - - if (w.globals.axisCharts || w.config.chart.type === 'radialBar') { - w.globals.resized = true; // we don't want initial animations again - - var seriesEl = null; - var realIndex = null; // yes, make it null. 1 series will rise at a time - - w.globals.risingSeries = []; - - if (w.globals.axisCharts) { - seriesEl = w.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(seriesCnt, "']")); - realIndex = parseInt(seriesEl.getAttribute('data:realIndex'), 10); - } else { - seriesEl = w.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(seriesCnt + 1, "']")); - realIndex = parseInt(seriesEl.getAttribute('rel'), 10) - 1; - } - - if (isHidden) { - var seriesToMakeVisible = [{ - cs: w.globals.collapsedSeries, - csi: w.globals.collapsedSeriesIndices - }, { - cs: w.globals.ancillaryCollapsedSeries, - csi: w.globals.ancillaryCollapsedSeriesIndices - }]; - seriesToMakeVisible.forEach(function (r) { - _this.riseCollapsedSeries(r.cs, r.csi, realIndex); - }); - } else { - this.hideSeries({ - seriesEl: seriesEl, - realIndex: realIndex - }); - } - } else { - // for non-axis charts i.e pie / donuts - var _seriesEl = w.globals.dom.Paper.select(" .apexcharts-series[rel='".concat(seriesCnt + 1, "'] path")); - - var type = w.config.chart.type; - - if (type === 'pie' || type === 'polarArea' || type === 'donut') { - var dataLabels = w.config.plotOptions.pie.donut.labels; - var graphics = new Graphics(this.lgCtx.ctx); - graphics.pathMouseDown(_seriesEl.members[0], null); - this.lgCtx.ctx.pie.printDataLabelsInner(_seriesEl.members[0].node, dataLabels); - } - - _seriesEl.fire('click'); - } - } - }, { - key: "hideSeries", - value: function hideSeries(_ref) { - var seriesEl = _ref.seriesEl, - realIndex = _ref.realIndex; - var w = this.w; - var series = Utils$1.clone(w.config.series); - - if (w.globals.axisCharts) { - var shouldNotHideYAxis = false; - - if (w.config.yaxis[realIndex] && w.config.yaxis[realIndex].show && w.config.yaxis[realIndex].showAlways) { - shouldNotHideYAxis = true; - - if (w.globals.ancillaryCollapsedSeriesIndices.indexOf(realIndex) < 0) { - w.globals.ancillaryCollapsedSeries.push({ - index: realIndex, - data: series[realIndex].data.slice(), - type: seriesEl.parentNode.className.baseVal.split('-')[1] - }); - w.globals.ancillaryCollapsedSeriesIndices.push(realIndex); - } - } - - if (!shouldNotHideYAxis) { - w.globals.collapsedSeries.push({ - index: realIndex, - data: series[realIndex].data.slice(), - type: seriesEl.parentNode.className.baseVal.split('-')[1] - }); - w.globals.collapsedSeriesIndices.push(realIndex); - var removeIndexOfRising = w.globals.risingSeries.indexOf(realIndex); - w.globals.risingSeries.splice(removeIndexOfRising, 1); - } - } else { - w.globals.collapsedSeries.push({ - index: realIndex, - data: series[realIndex] - }); - w.globals.collapsedSeriesIndices.push(realIndex); - } - - var seriesChildren = seriesEl.childNodes; - - for (var sc = 0; sc < seriesChildren.length; sc++) { - if (seriesChildren[sc].classList.contains('apexcharts-series-markers-wrap')) { - if (seriesChildren[sc].classList.contains('apexcharts-hide')) { - seriesChildren[sc].classList.remove('apexcharts-hide'); - } else { - seriesChildren[sc].classList.add('apexcharts-hide'); - } - } - } - - w.globals.allSeriesCollapsed = w.globals.collapsedSeries.length === w.config.series.length; - series = this._getSeriesBasedOnCollapsedState(series); - - this.lgCtx.ctx.updateHelpers._updateSeries(series, w.config.chart.animations.dynamicAnimation.enabled); - } - }, { - key: "riseCollapsedSeries", - value: function riseCollapsedSeries(collapsedSeries, seriesIndices, realIndex) { - var w = this.w; - var series = Utils$1.clone(w.config.series); - - if (collapsedSeries.length > 0) { - for (var c = 0; c < collapsedSeries.length; c++) { - if (collapsedSeries[c].index === realIndex) { - if (w.globals.axisCharts) { - series[realIndex].data = collapsedSeries[c].data.slice(); - collapsedSeries.splice(c, 1); - seriesIndices.splice(c, 1); - w.globals.risingSeries.push(realIndex); - } else { - series[realIndex] = collapsedSeries[c].data; - collapsedSeries.splice(c, 1); - seriesIndices.splice(c, 1); - w.globals.risingSeries.push(realIndex); - } - } - } - - series = this._getSeriesBasedOnCollapsedState(series); - - this.lgCtx.ctx.updateHelpers._updateSeries(series, w.config.chart.animations.dynamicAnimation.enabled); - } - } - }, { - key: "_getSeriesBasedOnCollapsedState", - value: function _getSeriesBasedOnCollapsedState(series) { - var w = this.w; - - if (w.globals.axisCharts) { - series.forEach(function (s, sI) { - if (w.globals.collapsedSeriesIndices.indexOf(sI) > -1) { - series[sI].data = []; - } - }); - } else { - series.forEach(function (s, sI) { - if (w.globals.collapsedSeriesIndices.indexOf(sI) > -1) { - series[sI] = 0; - } - }); - } - - return series; - } - }]); - - return Helpers; - }(); - - /** - * ApexCharts Legend Class to draw legend. - * - * @module Legend - **/ - - var Legend = /*#__PURE__*/function () { - function Legend(ctx) { - _classCallCheck(this, Legend); - - this.ctx = ctx; - this.w = ctx.w; - this.onLegendClick = this.onLegendClick.bind(this); - this.onLegendHovered = this.onLegendHovered.bind(this); - this.isBarsDistributed = this.w.config.chart.type === 'bar' && this.w.config.plotOptions.bar.distributed && this.w.config.series.length === 1; - this.legendHelpers = new Helpers$2(this); - } - - _createClass(Legend, [{ - key: "init", - value: function init() { - var w = this.w; - var gl = w.globals; - var cnf = w.config; - var showLegendAlways = cnf.legend.showForSingleSeries && gl.series.length === 1 || this.isBarsDistributed || gl.series.length > 1; - - if ((showLegendAlways || !gl.axisCharts) && cnf.legend.show) { - while (gl.dom.elLegendWrap.firstChild) { - gl.dom.elLegendWrap.removeChild(gl.dom.elLegendWrap.firstChild); - } - - this.drawLegends(); - - if (!Utils$1.isIE11()) { - this.legendHelpers.appendToForeignObject(); - } else { - // IE11 doesn't supports foreignObject, hence append it to - document.getElementsByTagName('head')[0].appendChild(this.legendHelpers.getLegendStyles()); - } - - if (cnf.legend.position === 'bottom' || cnf.legend.position === 'top') { - this.legendAlignHorizontal(); - } else if (cnf.legend.position === 'right' || cnf.legend.position === 'left') { - this.legendAlignVertical(); - } - } - } - }, { - key: "drawLegends", - value: function drawLegends() { - var me = this; - var w = this.w; - var fontFamily = w.config.legend.fontFamily; - var legendNames = w.globals.seriesNames; - var fillcolor = w.globals.colors.slice(); - - if (w.config.chart.type === 'heatmap') { - var ranges = w.config.plotOptions.heatmap.colorScale.ranges; - legendNames = ranges.map(function (colorScale) { - return colorScale.name ? colorScale.name : colorScale.from + ' - ' + colorScale.to; - }); - fillcolor = ranges.map(function (color) { - return color.color; - }); - } else if (this.isBarsDistributed) { - legendNames = w.globals.labels.slice(); - } - - if (w.config.legend.customLegendItems.length) { - legendNames = w.config.legend.customLegendItems; - } - - var legendFormatter = w.globals.legendFormatter; - var isLegendInversed = w.config.legend.inverseOrder; - - for (var i = isLegendInversed ? legendNames.length - 1 : 0; isLegendInversed ? i >= 0 : i <= legendNames.length - 1; isLegendInversed ? i-- : i++) { - var text = legendFormatter(legendNames[i], { - seriesIndex: i, - w: w - }); - var collapsedSeries = false; - var ancillaryCollapsedSeries = false; - - if (w.globals.collapsedSeries.length > 0) { - for (var c = 0; c < w.globals.collapsedSeries.length; c++) { - if (w.globals.collapsedSeries[c].index === i) { - collapsedSeries = true; - } - } - } - - if (w.globals.ancillaryCollapsedSeriesIndices.length > 0) { - for (var _c = 0; _c < w.globals.ancillaryCollapsedSeriesIndices.length; _c++) { - if (w.globals.ancillaryCollapsedSeriesIndices[_c] === i) { - ancillaryCollapsedSeries = true; - } - } - } - - var elMarker = document.createElement('span'); - elMarker.classList.add('apexcharts-legend-marker'); - var mOffsetX = w.config.legend.markers.offsetX; - var mOffsetY = w.config.legend.markers.offsetY; - var mHeight = w.config.legend.markers.height; - var mWidth = w.config.legend.markers.width; - var mBorderWidth = w.config.legend.markers.strokeWidth; - var mBorderColor = w.config.legend.markers.strokeColor; - var mBorderRadius = w.config.legend.markers.radius; - var mStyle = elMarker.style; - mStyle.background = fillcolor[i]; - mStyle.color = fillcolor[i]; - mStyle.setProperty('background', fillcolor[i], 'important'); // override fill color with custom legend.markers.fillColors - - if (w.config.legend.markers.fillColors && w.config.legend.markers.fillColors[i]) { - mStyle.background = w.config.legend.markers.fillColors[i]; - } // override with data color - - - if (w.globals.seriesColors[i] !== undefined) { - mStyle.background = w.globals.seriesColors[i]; - mStyle.color = w.globals.seriesColors[i]; - } - - mStyle.height = Array.isArray(mHeight) ? parseFloat(mHeight[i]) + 'px' : parseFloat(mHeight) + 'px'; - mStyle.width = Array.isArray(mWidth) ? parseFloat(mWidth[i]) + 'px' : parseFloat(mWidth) + 'px'; - mStyle.left = (Array.isArray(mOffsetX) ? parseFloat(mOffsetX[i]) : parseFloat(mOffsetX)) + 'px'; - mStyle.top = (Array.isArray(mOffsetY) ? parseFloat(mOffsetY[i]) : parseFloat(mOffsetY)) + 'px'; - mStyle.borderWidth = Array.isArray(mBorderWidth) ? mBorderWidth[i] : mBorderWidth; - mStyle.borderColor = Array.isArray(mBorderColor) ? mBorderColor[i] : mBorderColor; - mStyle.borderRadius = Array.isArray(mBorderRadius) ? parseFloat(mBorderRadius[i]) + 'px' : parseFloat(mBorderRadius) + 'px'; - - if (w.config.legend.markers.customHTML) { - if (Array.isArray(w.config.legend.markers.customHTML)) { - if (w.config.legend.markers.customHTML[i]) { - elMarker.innerHTML = w.config.legend.markers.customHTML[i](); - } - } else { - elMarker.innerHTML = w.config.legend.markers.customHTML(); - } - } - - Graphics.setAttrs(elMarker, { - rel: i + 1, - 'data:collapsed': collapsedSeries || ancillaryCollapsedSeries - }); - - if (collapsedSeries || ancillaryCollapsedSeries) { - elMarker.classList.add('apexcharts-inactive-legend'); - } - - var elLegend = document.createElement('div'); - var elLegendText = document.createElement('span'); - elLegendText.classList.add('apexcharts-legend-text'); - elLegendText.innerHTML = Array.isArray(text) ? text.join(' ') : text; - var textColor = w.config.legend.labels.useSeriesColors ? w.globals.colors[i] : w.config.legend.labels.colors; - - if (!textColor) { - textColor = w.config.chart.foreColor; - } - - elLegendText.style.color = textColor; - elLegendText.style.fontSize = parseFloat(w.config.legend.fontSize) + 'px'; - elLegendText.style.fontWeight = w.config.legend.fontWeight; - elLegendText.style.fontFamily = fontFamily || w.config.chart.fontFamily; - Graphics.setAttrs(elLegendText, { - rel: i + 1, - i: i, - 'data:default-text': encodeURIComponent(text), - 'data:collapsed': collapsedSeries || ancillaryCollapsedSeries - }); - elLegend.appendChild(elMarker); - elLegend.appendChild(elLegendText); - var coreUtils = new CoreUtils(this.ctx); - - if (!w.config.legend.showForZeroSeries) { - var total = coreUtils.getSeriesTotalByIndex(i); - - if (total === 0 && coreUtils.seriesHaveSameValues(i) && !coreUtils.isSeriesNull(i) && w.globals.collapsedSeriesIndices.indexOf(i) === -1 && w.globals.ancillaryCollapsedSeriesIndices.indexOf(i) === -1) { - elLegend.classList.add('apexcharts-hidden-zero-series'); - } - } - - if (!w.config.legend.showForNullSeries) { - if (coreUtils.isSeriesNull(i) && w.globals.collapsedSeriesIndices.indexOf(i) === -1 && w.globals.ancillaryCollapsedSeriesIndices.indexOf(i) === -1) { - elLegend.classList.add('apexcharts-hidden-null-series'); - } - } - - w.globals.dom.elLegendWrap.appendChild(elLegend); - w.globals.dom.elLegendWrap.classList.add("apexcharts-align-".concat(w.config.legend.horizontalAlign)); - w.globals.dom.elLegendWrap.classList.add('apx-legend-position-' + w.config.legend.position); - elLegend.classList.add('apexcharts-legend-series'); - elLegend.style.margin = "".concat(w.config.legend.itemMargin.vertical, "px ").concat(w.config.legend.itemMargin.horizontal, "px"); - w.globals.dom.elLegendWrap.style.width = w.config.legend.width ? w.config.legend.width + 'px' : ''; - w.globals.dom.elLegendWrap.style.height = w.config.legend.height ? w.config.legend.height + 'px' : ''; - Graphics.setAttrs(elLegend, { - rel: i + 1, - seriesName: Utils$1.escapeString(legendNames[i]), - 'data:collapsed': collapsedSeries || ancillaryCollapsedSeries - }); - - if (collapsedSeries || ancillaryCollapsedSeries) { - elLegend.classList.add('apexcharts-inactive-legend'); - } - - if (!w.config.legend.onItemClick.toggleDataSeries) { - elLegend.classList.add('apexcharts-no-click'); - } - } - - w.globals.dom.elWrap.addEventListener('click', me.onLegendClick, true); - - if (w.config.legend.onItemHover.highlightDataSeries && w.config.legend.customLegendItems.length === 0) { - w.globals.dom.elWrap.addEventListener('mousemove', me.onLegendHovered, true); - w.globals.dom.elWrap.addEventListener('mouseout', me.onLegendHovered, true); - } - } - }, { - key: "setLegendWrapXY", - value: function setLegendWrapXY(offsetX, offsetY) { - var w = this.w; - var elLegendWrap = w.globals.dom.elLegendWrap; - var legendRect = elLegendWrap.getBoundingClientRect(); - var x = 0; - var y = 0; - - if (w.config.legend.position === 'bottom') { - y = y + (w.globals.svgHeight - legendRect.height / 2); - } else if (w.config.legend.position === 'top') { - var dim = new Dimensions(this.ctx); - var titleH = dim.dimHelpers.getTitleSubtitleCoords('title').height; - var subtitleH = dim.dimHelpers.getTitleSubtitleCoords('subtitle').height; - y = y + (titleH > 0 ? titleH - 10 : 0) + (subtitleH > 0 ? subtitleH - 10 : 0); - } - - elLegendWrap.style.position = 'absolute'; - x = x + offsetX + w.config.legend.offsetX; - y = y + offsetY + w.config.legend.offsetY; - elLegendWrap.style.left = x + 'px'; - elLegendWrap.style.top = y + 'px'; - - if (w.config.legend.position === 'bottom') { - elLegendWrap.style.top = 'auto'; - elLegendWrap.style.bottom = 5 - w.config.legend.offsetY + 'px'; - } else if (w.config.legend.position === 'right') { - elLegendWrap.style.left = 'auto'; - elLegendWrap.style.right = 25 + w.config.legend.offsetX + 'px'; - } - - var fixedHeigthWidth = ['width', 'height']; - fixedHeigthWidth.forEach(function (hw) { - if (elLegendWrap.style[hw]) { - elLegendWrap.style[hw] = parseInt(w.config.legend[hw], 10) + 'px'; - } - }); - } - }, { - key: "legendAlignHorizontal", - value: function legendAlignHorizontal() { - var w = this.w; - var elLegendWrap = w.globals.dom.elLegendWrap; - elLegendWrap.style.right = 0; - var lRect = this.legendHelpers.getLegendBBox(); - var dimensions = new Dimensions(this.ctx); - var titleRect = dimensions.dimHelpers.getTitleSubtitleCoords('title'); - var subtitleRect = dimensions.dimHelpers.getTitleSubtitleCoords('subtitle'); - var offsetX = 20; - var offsetY = 0; // the whole legend box is set to bottom - - if (w.config.legend.position === 'bottom') { - offsetY = -lRect.clwh / 1.8; - } else if (w.config.legend.position === 'top') { - offsetY = titleRect.height + subtitleRect.height + w.config.title.margin + w.config.subtitle.margin - 10; - } - - this.setLegendWrapXY(offsetX, offsetY); - } - }, { - key: "legendAlignVertical", - value: function legendAlignVertical() { - var w = this.w; - var lRect = this.legendHelpers.getLegendBBox(); - var offsetY = 20; - var offsetX = 0; - - if (w.config.legend.position === 'left') { - offsetX = 20; - } - - if (w.config.legend.position === 'right') { - offsetX = w.globals.svgWidth - lRect.clww - 10; - } - - this.setLegendWrapXY(offsetX, offsetY); - } - }, { - key: "onLegendHovered", - value: function onLegendHovered(e) { - var w = this.w; - var hoverOverLegend = e.target.classList.contains('apexcharts-legend-text') || e.target.classList.contains('apexcharts-legend-marker'); - - if (w.config.chart.type !== 'heatmap' && !this.isBarsDistributed) { - if (!e.target.classList.contains('apexcharts-inactive-legend') && hoverOverLegend) { - var series = new Series(this.ctx); - series.toggleSeriesOnHover(e, e.target); - } - } else { - // for heatmap handling - if (hoverOverLegend) { - var seriesCnt = parseInt(e.target.getAttribute('rel'), 10) - 1; - this.ctx.events.fireEvent('legendHover', [this.ctx, seriesCnt, this.w]); - - var _series = new Series(this.ctx); - - _series.highlightRangeInSeries(e, e.target); - } - } - } - }, { - key: "onLegendClick", - value: function onLegendClick(e) { - var w = this.w; - if (w.config.legend.customLegendItems.length) return; - - if (e.target.classList.contains('apexcharts-legend-text') || e.target.classList.contains('apexcharts-legend-marker')) { - var seriesCnt = parseInt(e.target.getAttribute('rel'), 10) - 1; - var isHidden = e.target.getAttribute('data:collapsed') === 'true'; - var legendClick = this.w.config.chart.events.legendClick; - - if (typeof legendClick === 'function') { - legendClick(this.ctx, seriesCnt, this.w); - } - - this.ctx.events.fireEvent('legendClick', [this.ctx, seriesCnt, this.w]); - var markerClick = this.w.config.legend.markers.onClick; - - if (typeof markerClick === 'function' && e.target.classList.contains('apexcharts-legend-marker')) { - markerClick(this.ctx, seriesCnt, this.w); - this.ctx.events.fireEvent('legendMarkerClick', [this.ctx, seriesCnt, this.w]); - } // for now - just prevent click on heatmap legend - and allow hover only - - - var clickAllowed = w.config.chart.type !== 'treemap' && w.config.chart.type !== 'heatmap' && !this.isBarsDistributed; - - if (clickAllowed && w.config.legend.onItemClick.toggleDataSeries) { - this.legendHelpers.toggleDataSeries(seriesCnt, isHidden); - } - } - } - }]); - - return Legend; - }(); - - var icoPan = "\n \n \n \n \n \n \n \n"; - - var icoZoom = "\n \n \n \n"; - - var icoReset = "\n \n \n"; - - var icoZoomIn = "\n \n \n\n"; - - var icoZoomOut = "\n \n \n\n"; - - var icoSelect = "\n \n \n"; - - var icoMenu = ""; - - /** - * ApexCharts Toolbar Class for creating toolbar in axis based charts. - * - * @module Toolbar - **/ - - var Toolbar = /*#__PURE__*/function () { - function Toolbar(ctx) { - _classCallCheck(this, Toolbar); - - this.ctx = ctx; - this.w = ctx.w; - var w = this.w; - this.ev = this.w.config.chart.events; - this.selectedClass = 'apexcharts-selected'; - this.localeValues = this.w.globals.locale.toolbar; - this.minX = w.globals.minX; - this.maxX = w.globals.maxX; - } - - _createClass(Toolbar, [{ - key: "createToolbar", - value: function createToolbar() { - var _this = this; - - var w = this.w; - - var createDiv = function createDiv() { - return document.createElement('div'); - }; - - var elToolbarWrap = createDiv(); - elToolbarWrap.setAttribute('class', 'apexcharts-toolbar'); - elToolbarWrap.style.top = w.config.chart.toolbar.offsetY + 'px'; - elToolbarWrap.style.right = -w.config.chart.toolbar.offsetX + 3 + 'px'; - w.globals.dom.elWrap.appendChild(elToolbarWrap); - this.elZoom = createDiv(); - this.elZoomIn = createDiv(); - this.elZoomOut = createDiv(); - this.elPan = createDiv(); - this.elSelection = createDiv(); - this.elZoomReset = createDiv(); - this.elMenuIcon = createDiv(); - this.elMenu = createDiv(); - this.elCustomIcons = []; - this.t = w.config.chart.toolbar.tools; - - if (Array.isArray(this.t.customIcons)) { - for (var i = 0; i < this.t.customIcons.length; i++) { - this.elCustomIcons.push(createDiv()); - } - } - - var toolbarControls = []; - - var appendZoomControl = function appendZoomControl(type, el, ico) { - var tool = type.toLowerCase(); - - if (_this.t[tool] && w.config.chart.zoom.enabled) { - toolbarControls.push({ - el: el, - icon: typeof _this.t[tool] === 'string' ? _this.t[tool] : ico, - title: _this.localeValues[type], - class: "apexcharts-".concat(tool, "-icon") - }); - } - }; - - appendZoomControl('zoomIn', this.elZoomIn, icoZoomIn); - appendZoomControl('zoomOut', this.elZoomOut, icoZoomOut); - - var zoomSelectionCtrls = function zoomSelectionCtrls(z) { - if (_this.t[z] && w.config.chart[z].enabled) { - toolbarControls.push({ - el: z === 'zoom' ? _this.elZoom : _this.elSelection, - icon: typeof _this.t[z] === 'string' ? _this.t[z] : z === 'zoom' ? icoZoom : icoSelect, - title: _this.localeValues[z === 'zoom' ? 'selectionZoom' : 'selection'], - class: w.globals.isTouchDevice ? 'apexcharts-element-hidden' : "apexcharts-".concat(z, "-icon") - }); - } - }; - - zoomSelectionCtrls('zoom'); - zoomSelectionCtrls('selection'); - - if (this.t.pan && w.config.chart.zoom.enabled) { - toolbarControls.push({ - el: this.elPan, - icon: typeof this.t.pan === 'string' ? this.t.pan : icoPan, - title: this.localeValues.pan, - class: w.globals.isTouchDevice ? 'apexcharts-element-hidden' : 'apexcharts-pan-icon' - }); - } - - appendZoomControl('reset', this.elZoomReset, icoReset); - - if (this.t.download) { - toolbarControls.push({ - el: this.elMenuIcon, - icon: typeof this.t.download === 'string' ? this.t.download : icoMenu, - title: this.localeValues.menu, - class: 'apexcharts-menu-icon' - }); - } - - for (var _i = 0; _i < this.elCustomIcons.length; _i++) { - toolbarControls.push({ - el: this.elCustomIcons[_i], - icon: this.t.customIcons[_i].icon, - title: this.t.customIcons[_i].title, - index: this.t.customIcons[_i].index, - class: 'apexcharts-toolbar-custom-icon ' + this.t.customIcons[_i].class - }); - } - - toolbarControls.forEach(function (t, index) { - if (t.index) { - Utils$1.moveIndexInArray(toolbarControls, index, t.index); - } - }); - - for (var _i2 = 0; _i2 < toolbarControls.length; _i2++) { - Graphics.setAttrs(toolbarControls[_i2].el, { - class: toolbarControls[_i2].class, - title: toolbarControls[_i2].title - }); - toolbarControls[_i2].el.innerHTML = toolbarControls[_i2].icon; - elToolbarWrap.appendChild(toolbarControls[_i2].el); - } - - this._createHamburgerMenu(elToolbarWrap); - - if (w.globals.zoomEnabled) { - this.elZoom.classList.add(this.selectedClass); - } else if (w.globals.panEnabled) { - this.elPan.classList.add(this.selectedClass); - } else if (w.globals.selectionEnabled) { - this.elSelection.classList.add(this.selectedClass); - } - - this.addToolbarEventListeners(); - } - }, { - key: "_createHamburgerMenu", - value: function _createHamburgerMenu(parent) { - this.elMenuItems = []; - parent.appendChild(this.elMenu); - Graphics.setAttrs(this.elMenu, { - class: 'apexcharts-menu' - }); - var menuItems = [{ - name: 'exportSVG', - title: this.localeValues.exportToSVG - }, { - name: 'exportPNG', - title: this.localeValues.exportToPNG - }, { - name: 'exportCSV', - title: this.localeValues.exportToCSV - }]; - - if (!this.w.globals.allSeriesHasEqualX) { - // if it is a multi series, and all series have variable x values, export CSV won't work - menuItems.splice(2, 1); - } - - for (var i = 0; i < menuItems.length; i++) { - this.elMenuItems.push(document.createElement('div')); - this.elMenuItems[i].innerHTML = menuItems[i].title; - Graphics.setAttrs(this.elMenuItems[i], { - class: "apexcharts-menu-item ".concat(menuItems[i].name), - title: menuItems[i].title - }); - this.elMenu.appendChild(this.elMenuItems[i]); - } - } - }, { - key: "addToolbarEventListeners", - value: function addToolbarEventListeners() { - var _this2 = this; - - this.elZoomReset.addEventListener('click', this.handleZoomReset.bind(this)); - this.elSelection.addEventListener('click', this.toggleZoomSelection.bind(this, 'selection')); - this.elZoom.addEventListener('click', this.toggleZoomSelection.bind(this, 'zoom')); - this.elZoomIn.addEventListener('click', this.handleZoomIn.bind(this)); - this.elZoomOut.addEventListener('click', this.handleZoomOut.bind(this)); - this.elPan.addEventListener('click', this.togglePanning.bind(this)); - this.elMenuIcon.addEventListener('click', this.toggleMenu.bind(this)); - this.elMenuItems.forEach(function (m) { - if (m.classList.contains('exportSVG')) { - m.addEventListener('click', _this2.handleDownload.bind(_this2, 'svg')); - } else if (m.classList.contains('exportPNG')) { - m.addEventListener('click', _this2.handleDownload.bind(_this2, 'png')); - } else if (m.classList.contains('exportCSV')) { - m.addEventListener('click', _this2.handleDownload.bind(_this2, 'csv')); - } - }); - - for (var i = 0; i < this.t.customIcons.length; i++) { - this.elCustomIcons[i].addEventListener('click', this.t.customIcons[i].click.bind(this, this.ctx, this.ctx.w)); - } - } - }, { - key: "toggleZoomSelection", - value: function toggleZoomSelection(type) { - var charts = this.ctx.getSyncedCharts(); - charts.forEach(function (ch) { - ch.ctx.toolbar.toggleOtherControls(); - var el = type === 'selection' ? ch.ctx.toolbar.elSelection : ch.ctx.toolbar.elZoom; - var enabledType = type === 'selection' ? 'selectionEnabled' : 'zoomEnabled'; - ch.w.globals[enabledType] = !ch.w.globals[enabledType]; - - if (!el.classList.contains(ch.ctx.toolbar.selectedClass)) { - el.classList.add(ch.ctx.toolbar.selectedClass); - } else { - el.classList.remove(ch.ctx.toolbar.selectedClass); - } - }); - } - }, { - key: "getToolbarIconsReference", - value: function getToolbarIconsReference() { - var w = this.w; - - if (!this.elZoom) { - this.elZoom = w.globals.dom.baseEl.querySelector('.apexcharts-zoom-icon'); - } - - if (!this.elPan) { - this.elPan = w.globals.dom.baseEl.querySelector('.apexcharts-pan-icon'); - } - - if (!this.elSelection) { - this.elSelection = w.globals.dom.baseEl.querySelector('.apexcharts-selection-icon'); - } - } - }, { - key: "enableZoomPanFromToolbar", - value: function enableZoomPanFromToolbar(type) { - this.toggleOtherControls(); - type === 'pan' ? this.w.globals.panEnabled = true : this.w.globals.zoomEnabled = true; - var el = type === 'pan' ? this.elPan : this.elZoom; - var el2 = type === 'pan' ? this.elZoom : this.elPan; - - if (el) { - el.classList.add(this.selectedClass); - } - - if (el2) { - el2.classList.remove(this.selectedClass); - } - } - }, { - key: "togglePanning", - value: function togglePanning() { - var charts = this.ctx.getSyncedCharts(); - charts.forEach(function (ch) { - ch.ctx.toolbar.toggleOtherControls(); - ch.w.globals.panEnabled = !ch.w.globals.panEnabled; - - if (!ch.ctx.toolbar.elPan.classList.contains(ch.ctx.toolbar.selectedClass)) { - ch.ctx.toolbar.elPan.classList.add(ch.ctx.toolbar.selectedClass); - } else { - ch.ctx.toolbar.elPan.classList.remove(ch.ctx.toolbar.selectedClass); - } - }); - } - }, { - key: "toggleOtherControls", - value: function toggleOtherControls() { - var _this3 = this; - - var w = this.w; - w.globals.panEnabled = false; - w.globals.zoomEnabled = false; - w.globals.selectionEnabled = false; - this.getToolbarIconsReference(); - var toggleEls = [this.elPan, this.elSelection, this.elZoom]; - toggleEls.forEach(function (el) { - if (el) { - el.classList.remove(_this3.selectedClass); - } - }); - } - }, { - key: "handleZoomIn", - value: function handleZoomIn() { - var w = this.w; - - if (w.globals.isRangeBar) { - this.minX = w.globals.minY; - this.maxX = w.globals.maxY; - } - - var centerX = (this.minX + this.maxX) / 2; - var newMinX = (this.minX + centerX) / 2; - var newMaxX = (this.maxX + centerX) / 2; - - var newMinXMaxX = this._getNewMinXMaxX(newMinX, newMaxX); - - if (!w.globals.disableZoomIn) { - this.zoomUpdateOptions(newMinXMaxX.minX, newMinXMaxX.maxX); - } - } - }, { - key: "handleZoomOut", - value: function handleZoomOut() { - var w = this.w; - - if (w.globals.isRangeBar) { - this.minX = w.globals.minY; - this.maxX = w.globals.maxY; - } // avoid zooming out beyond 1000 which may result in NaN values being printed on x-axis - - - if (w.config.xaxis.type === 'datetime' && new Date(this.minX).getUTCFullYear() < 1000) { - return; - } - - var centerX = (this.minX + this.maxX) / 2; - var newMinX = this.minX - (centerX - this.minX); - var newMaxX = this.maxX - (centerX - this.maxX); - - var newMinXMaxX = this._getNewMinXMaxX(newMinX, newMaxX); - - if (!w.globals.disableZoomOut) { - this.zoomUpdateOptions(newMinXMaxX.minX, newMinXMaxX.maxX); - } - } - }, { - key: "_getNewMinXMaxX", - value: function _getNewMinXMaxX(newMinX, newMaxX) { - var shouldFloor = this.w.config.xaxis.convertedCatToNumeric; - return { - minX: shouldFloor ? Math.floor(newMinX) : newMinX, - maxX: shouldFloor ? Math.floor(newMaxX) : newMaxX - }; - } - }, { - key: "zoomUpdateOptions", - value: function zoomUpdateOptions(newMinX, newMaxX) { - var w = this.w; - - if (newMinX === undefined && newMaxX === undefined) { - this.handleZoomReset(); - return; - } - - if (w.config.xaxis.convertedCatToNumeric) { - // in category charts, avoid zooming out beyond min and max - if (newMinX < 1) { - newMinX = 1; - newMaxX = w.globals.dataPoints; - } - - if (newMaxX - newMinX < 2) { - return; - } - } - - var xaxis = { - min: newMinX, - max: newMaxX - }; - var beforeZoomRange = this.getBeforeZoomRange(xaxis); - - if (beforeZoomRange) { - xaxis = beforeZoomRange.xaxis; - } - - var options = { - xaxis: xaxis - }; - var yaxis = Utils$1.clone(w.globals.initialConfig.yaxis); - - if (w.config.chart.zoom.autoScaleYaxis) { - var scale = new Range$1(this.ctx); - yaxis = scale.autoScaleY(this.ctx, yaxis, { - xaxis: xaxis - }); - } - - if (!w.config.chart.group) { - // if chart in a group, prevent yaxis update here - // fix issue #650 - options.yaxis = yaxis; - } - - this.w.globals.zoomed = true; - - this.ctx.updateHelpers._updateOptions(options, false, this.w.config.chart.animations.dynamicAnimation.enabled); - - this.zoomCallback(xaxis, yaxis); - } - }, { - key: "zoomCallback", - value: function zoomCallback(xaxis, yaxis) { - if (typeof this.ev.zoomed === 'function') { - this.ev.zoomed(this.ctx, { - xaxis: xaxis, - yaxis: yaxis - }); - } - } - }, { - key: "getBeforeZoomRange", - value: function getBeforeZoomRange(xaxis, yaxis) { - var newRange = null; - - if (typeof this.ev.beforeZoom === 'function') { - newRange = this.ev.beforeZoom(this, { - xaxis: xaxis, - yaxis: yaxis - }); - } - - return newRange; - } - }, { - key: "toggleMenu", - value: function toggleMenu() { - var _this4 = this; - - window.setTimeout(function () { - if (_this4.elMenu.classList.contains('apexcharts-menu-open')) { - _this4.elMenu.classList.remove('apexcharts-menu-open'); - } else { - _this4.elMenu.classList.add('apexcharts-menu-open'); - } - }, 0); - } - }, { - key: "handleDownload", - value: function handleDownload(type) { - var w = this.w; - var exprt = new Exports(this.ctx); - - switch (type) { - case 'svg': - exprt.exportToSVG(this.ctx); - break; - - case 'png': - exprt.exportToPng(this.ctx); - break; - - case 'csv': - exprt.exportToCSV({ - series: w.config.series, - columnDelimiter: w.config.chart.toolbar.export.csv.columnDelimiter - }); - break; - } - } - }, { - key: "handleZoomReset", - value: function handleZoomReset(e) { - var charts = this.ctx.getSyncedCharts(); - charts.forEach(function (ch) { - var w = ch.w; // forget lastXAxis min/max as reset button isn't resetting the x-axis completely if zoomX is called before - - w.globals.lastXAxis.min = undefined; - w.globals.lastXAxis.max = undefined; - ch.updateHelpers.revertDefaultAxisMinMax(); - - if (typeof w.config.chart.events.beforeResetZoom === 'function') { - // here, user get an option to control xaxis and yaxis when resetZoom is called - // at this point, whatever is returned from w.config.chart.events.beforeResetZoom - // is set as the new xaxis/yaxis min/max - var resetZoomRange = w.config.chart.events.beforeResetZoom(ch, w); - - if (resetZoomRange) { - ch.updateHelpers.revertDefaultAxisMinMax(resetZoomRange); - } - } - - if (typeof w.config.chart.events.zoomed === 'function') { - ch.ctx.toolbar.zoomCallback({ - min: w.config.xaxis.min, - max: w.config.xaxis.max - }); - } - - w.globals.zoomed = false; // if user has some series collapsed before hitting zoom reset button, - // those series should stay collapsed - - var series = ch.ctx.series.emptyCollapsedSeries(Utils$1.clone(w.globals.initialSeries)); - - ch.updateHelpers._updateSeries(series, w.config.chart.animations.dynamicAnimation.enabled); - }); - } - }, { - key: "destroy", - value: function destroy() { - this.elZoom = null; - this.elZoomIn = null; - this.elZoomOut = null; - this.elPan = null; - this.elSelection = null; - this.elZoomReset = null; - this.elMenuIcon = null; - } - }]); - - return Toolbar; - }(); - - /** - * ApexCharts Zoom Class for handling zooming and panning on axes based charts. - * - * @module ZoomPanSelection - **/ - - var ZoomPanSelection = /*#__PURE__*/function (_Toolbar) { - _inherits(ZoomPanSelection, _Toolbar); - - var _super = _createSuper(ZoomPanSelection); - - function ZoomPanSelection(ctx) { - var _this; - - _classCallCheck(this, ZoomPanSelection); - - _this = _super.call(this, ctx); - _this.ctx = ctx; - _this.w = ctx.w; - _this.dragged = false; - _this.graphics = new Graphics(_this.ctx); - _this.eventList = ['mousedown', 'mouseleave', 'mousemove', 'touchstart', 'touchmove', 'mouseup', 'touchend']; - _this.clientX = 0; - _this.clientY = 0; - _this.startX = 0; - _this.endX = 0; - _this.dragX = 0; - _this.startY = 0; - _this.endY = 0; - _this.dragY = 0; - _this.moveDirection = 'none'; - return _this; - } - - _createClass(ZoomPanSelection, [{ - key: "init", - value: function init(_ref) { - var _this2 = this; - - var xyRatios = _ref.xyRatios; - var w = this.w; - var me = this; - this.xyRatios = xyRatios; - this.zoomRect = this.graphics.drawRect(0, 0, 0, 0); - this.selectionRect = this.graphics.drawRect(0, 0, 0, 0); - this.gridRect = w.globals.dom.baseEl.querySelector('.apexcharts-grid'); - this.zoomRect.node.classList.add('apexcharts-zoom-rect'); - this.selectionRect.node.classList.add('apexcharts-selection-rect'); - w.globals.dom.elGraphical.add(this.zoomRect); - w.globals.dom.elGraphical.add(this.selectionRect); - - if (w.config.chart.selection.type === 'x') { - this.slDraggableRect = this.selectionRect.draggable({ - minX: 0, - minY: 0, - maxX: w.globals.gridWidth, - maxY: w.globals.gridHeight - }).on('dragmove', this.selectionDragging.bind(this, 'dragging')); - } else if (w.config.chart.selection.type === 'y') { - this.slDraggableRect = this.selectionRect.draggable({ - minX: 0, - maxX: w.globals.gridWidth - }).on('dragmove', this.selectionDragging.bind(this, 'dragging')); - } else { - this.slDraggableRect = this.selectionRect.draggable().on('dragmove', this.selectionDragging.bind(this, 'dragging')); - } - - this.preselectedSelection(); - this.hoverArea = w.globals.dom.baseEl.querySelector("".concat(w.globals.chartClass, " .apexcharts-svg")); - this.hoverArea.classList.add('apexcharts-zoomable'); - this.eventList.forEach(function (event) { - _this2.hoverArea.addEventListener(event, me.svgMouseEvents.bind(me, xyRatios), { - capture: false, - passive: true - }); - }); - } // remove the event listeners which were previously added on hover area - - }, { - key: "destroy", - value: function destroy() { - if (this.slDraggableRect) { - this.slDraggableRect.draggable(false); - this.slDraggableRect.off(); - this.selectionRect.off(); - } - - this.selectionRect = null; - this.zoomRect = null; - this.gridRect = null; - } - }, { - key: "svgMouseEvents", - value: function svgMouseEvents(xyRatios, e) { - var w = this.w; - var me = this; - var toolbar = this.ctx.toolbar; - var zoomtype = w.globals.zoomEnabled ? w.config.chart.zoom.type : w.config.chart.selection.type; - var autoSelected = w.config.chart.toolbar.autoSelected; - - if (e.shiftKey) { - this.shiftWasPressed = true; - toolbar.enableZoomPanFromToolbar(autoSelected === 'pan' ? 'zoom' : 'pan'); - } else { - if (this.shiftWasPressed) { - toolbar.enableZoomPanFromToolbar(autoSelected); - this.shiftWasPressed = false; - } - } - - if (!e.target) return; - var tc = e.target.classList; - var pc; - - if (e.target.parentNode && e.target.parentNode !== null) { - pc = e.target.parentNode.classList; - } - - var falsePositives = tc.contains('apexcharts-selection-rect') || tc.contains('apexcharts-legend-marker') || tc.contains('apexcharts-legend-text') || pc && pc.contains('apexcharts-toolbar'); - if (falsePositives) return; - me.clientX = e.type === 'touchmove' || e.type === 'touchstart' ? e.touches[0].clientX : e.type === 'touchend' ? e.changedTouches[0].clientX : e.clientX; - me.clientY = e.type === 'touchmove' || e.type === 'touchstart' ? e.touches[0].clientY : e.type === 'touchend' ? e.changedTouches[0].clientY : e.clientY; - - if (e.type === 'mousedown' && e.which === 1) { - var gridRectDim = me.gridRect.getBoundingClientRect(); - me.startX = me.clientX - gridRectDim.left; - me.startY = me.clientY - gridRectDim.top; - me.dragged = false; - me.w.globals.mousedown = true; - } - - if (e.type === 'mousemove' && e.which === 1 || e.type === 'touchmove') { - me.dragged = true; - - if (w.globals.panEnabled) { - w.globals.selection = null; - - if (me.w.globals.mousedown) { - me.panDragging({ - context: me, - zoomtype: zoomtype, - xyRatios: xyRatios - }); - } - } else { - if (me.w.globals.mousedown && w.globals.zoomEnabled || me.w.globals.mousedown && w.globals.selectionEnabled) { - me.selection = me.selectionDrawing({ - context: me, - zoomtype: zoomtype - }); - } - } - } - - if (e.type === 'mouseup' || e.type === 'touchend' || e.type === 'mouseleave') { - // we will be calling getBoundingClientRect on each mousedown/mousemove/mouseup - var _gridRectDim = me.gridRect.getBoundingClientRect(); - - if (me.w.globals.mousedown) { - // user released the drag, now do all the calculations - me.endX = me.clientX - _gridRectDim.left; - me.endY = me.clientY - _gridRectDim.top; - me.dragX = Math.abs(me.endX - me.startX); - me.dragY = Math.abs(me.endY - me.startY); - - if (w.globals.zoomEnabled || w.globals.selectionEnabled) { - me.selectionDrawn({ - context: me, - zoomtype: zoomtype - }); - } - - if (w.globals.panEnabled && w.config.xaxis.convertedCatToNumeric) { - me.delayedPanScrolled(); - } - } - - if (w.globals.zoomEnabled) { - me.hideSelectionRect(this.selectionRect); - } - - me.dragged = false; - me.w.globals.mousedown = false; - } - - this.makeSelectionRectDraggable(); - } - }, { - key: "makeSelectionRectDraggable", - value: function makeSelectionRectDraggable() { - var w = this.w; - if (!this.selectionRect) return; - var rectDim = this.selectionRect.node.getBoundingClientRect(); - - if (rectDim.width > 0 && rectDim.height > 0) { - this.slDraggableRect.selectize({ - points: 'l, r', - pointSize: 8, - pointType: 'rect' - }).resize({ - constraint: { - minX: 0, - minY: 0, - maxX: w.globals.gridWidth, - maxY: w.globals.gridHeight - } - }).on('resizing', this.selectionDragging.bind(this, 'resizing')); - } - } - }, { - key: "preselectedSelection", - value: function preselectedSelection() { - var w = this.w; - var xyRatios = this.xyRatios; - - if (!w.globals.zoomEnabled) { - if (typeof w.globals.selection !== 'undefined' && w.globals.selection !== null) { - this.drawSelectionRect(w.globals.selection); - } else { - if (w.config.chart.selection.xaxis.min !== undefined && w.config.chart.selection.xaxis.max !== undefined) { - var x = (w.config.chart.selection.xaxis.min - w.globals.minX) / xyRatios.xRatio; - var width = w.globals.gridWidth - (w.globals.maxX - w.config.chart.selection.xaxis.max) / xyRatios.xRatio - x; - var selectionRect = { - x: x, - y: 0, - width: width, - height: w.globals.gridHeight, - translateX: 0, - translateY: 0, - selectionEnabled: true - }; - this.drawSelectionRect(selectionRect); - this.makeSelectionRectDraggable(); - - if (typeof w.config.chart.events.selection === 'function') { - w.config.chart.events.selection(this.ctx, { - xaxis: { - min: w.config.chart.selection.xaxis.min, - max: w.config.chart.selection.xaxis.max - }, - yaxis: {} - }); - } - } - } - } - } - }, { - key: "drawSelectionRect", - value: function drawSelectionRect(_ref2) { - var x = _ref2.x, - y = _ref2.y, - width = _ref2.width, - height = _ref2.height, - _ref2$translateX = _ref2.translateX, - translateX = _ref2$translateX === void 0 ? 0 : _ref2$translateX, - _ref2$translateY = _ref2.translateY, - translateY = _ref2$translateY === void 0 ? 0 : _ref2$translateY; - var w = this.w; - var zoomRect = this.zoomRect; - var selectionRect = this.selectionRect; - - if (this.dragged || w.globals.selection !== null) { - var scalingAttrs = { - transform: 'translate(' + translateX + ', ' + translateY + ')' - }; // change styles based on zoom or selection - // zoom is Enabled and user has dragged, so draw blue rect - - if (w.globals.zoomEnabled && this.dragged) { - if (width < 0) width = 1; // fixes apexcharts.js#1168 - - zoomRect.attr({ - x: x, - y: y, - width: width, - height: height, - fill: w.config.chart.zoom.zoomedArea.fill.color, - 'fill-opacity': w.config.chart.zoom.zoomedArea.fill.opacity, - stroke: w.config.chart.zoom.zoomedArea.stroke.color, - 'stroke-width': w.config.chart.zoom.zoomedArea.stroke.width, - 'stroke-opacity': w.config.chart.zoom.zoomedArea.stroke.opacity - }); - Graphics.setAttrs(zoomRect.node, scalingAttrs); - } // selection is enabled - - - if (w.globals.selectionEnabled) { - selectionRect.attr({ - x: x, - y: y, - width: width > 0 ? width : 0, - height: height > 0 ? height : 0, - fill: w.config.chart.selection.fill.color, - 'fill-opacity': w.config.chart.selection.fill.opacity, - stroke: w.config.chart.selection.stroke.color, - 'stroke-width': w.config.chart.selection.stroke.width, - 'stroke-dasharray': w.config.chart.selection.stroke.dashArray, - 'stroke-opacity': w.config.chart.selection.stroke.opacity - }); - Graphics.setAttrs(selectionRect.node, scalingAttrs); - } - } - } - }, { - key: "hideSelectionRect", - value: function hideSelectionRect(rect) { - if (rect) { - rect.attr({ - x: 0, - y: 0, - width: 0, - height: 0 - }); - } - } - }, { - key: "selectionDrawing", - value: function selectionDrawing(_ref3) { - var context = _ref3.context, - zoomtype = _ref3.zoomtype; - var w = this.w; - var me = context; - var gridRectDim = this.gridRect.getBoundingClientRect(); - var startX = me.startX - 1; - var startY = me.startY; - var inversedX = false; - var inversedY = false; - var selectionWidth = me.clientX - gridRectDim.left - startX; - var selectionHeight = me.clientY - gridRectDim.top - startY; - var selectionRect = {}; - - if (Math.abs(selectionWidth + startX) > w.globals.gridWidth) { - // user dragged the mouse outside drawing area to the right - selectionWidth = w.globals.gridWidth - startX; - } else if (me.clientX - gridRectDim.left < 0) { - // user dragged the mouse outside drawing area to the left - selectionWidth = startX; - } // inverse selection X - - - if (startX > me.clientX - gridRectDim.left) { - inversedX = true; - selectionWidth = Math.abs(selectionWidth); - } // inverse selection Y - - - if (startY > me.clientY - gridRectDim.top) { - inversedY = true; - selectionHeight = Math.abs(selectionHeight); - } - - if (zoomtype === 'x') { - selectionRect = { - x: inversedX ? startX - selectionWidth : startX, - y: 0, - width: selectionWidth, - height: w.globals.gridHeight - }; - } else if (zoomtype === 'y') { - selectionRect = { - x: 0, - y: inversedY ? startY - selectionHeight : startY, - width: w.globals.gridWidth, - height: selectionHeight - }; - } else { - selectionRect = { - x: inversedX ? startX - selectionWidth : startX, - y: inversedY ? startY - selectionHeight : startY, - width: selectionWidth, - height: selectionHeight - }; - } - - me.drawSelectionRect(selectionRect); - me.selectionDragging('resizing'); - return selectionRect; - } - }, { - key: "selectionDragging", - value: function selectionDragging(type, e) { - var _this3 = this; - - var w = this.w; - var xyRatios = this.xyRatios; - var selRect = this.selectionRect; - var timerInterval = 0; - - if (type === 'resizing') { - timerInterval = 30; - } // update selection when selection rect is dragged - - - var getSelAttr = function getSelAttr(attr) { - return parseFloat(selRect.node.getAttribute(attr)); - }; - - var draggedProps = { - x: getSelAttr('x'), - y: getSelAttr('y'), - width: getSelAttr('width'), - height: getSelAttr('height') - }; - w.globals.selection = draggedProps; // update selection ends - - if (typeof w.config.chart.events.selection === 'function' && w.globals.selectionEnabled) { - // a small debouncer is required when resizing to avoid freezing the chart - clearTimeout(this.w.globals.selectionResizeTimer); - this.w.globals.selectionResizeTimer = window.setTimeout(function () { - var gridRectDim = _this3.gridRect.getBoundingClientRect(); - - var selectionRect = selRect.node.getBoundingClientRect(); - var minX = w.globals.xAxisScale.niceMin + (selectionRect.left - gridRectDim.left) * xyRatios.xRatio; - var maxX = w.globals.xAxisScale.niceMin + (selectionRect.right - gridRectDim.left) * xyRatios.xRatio; - var minY = w.globals.yAxisScale[0].niceMin + (gridRectDim.bottom - selectionRect.bottom) * xyRatios.yRatio[0]; - var maxY = w.globals.yAxisScale[0].niceMax - (selectionRect.top - gridRectDim.top) * xyRatios.yRatio[0]; - var xyAxis = { - xaxis: { - min: minX, - max: maxX - }, - yaxis: { - min: minY, - max: maxY - } - }; - w.config.chart.events.selection(_this3.ctx, xyAxis); - - if (w.config.chart.brush.enabled && w.config.chart.events.brushScrolled !== undefined) { - w.config.chart.events.brushScrolled(_this3.ctx, xyAxis); - } - }, timerInterval); - } - } - }, { - key: "selectionDrawn", - value: function selectionDrawn(_ref4) { - var context = _ref4.context, - zoomtype = _ref4.zoomtype; - var w = this.w; - var me = context; - var xyRatios = this.xyRatios; - var toolbar = this.ctx.toolbar; - - if (me.startX > me.endX) { - var tempX = me.startX; - me.startX = me.endX; - me.endX = tempX; - } - - if (me.startY > me.endY) { - var tempY = me.startY; - me.startY = me.endY; - me.endY = tempY; - } - - var xLowestValue = undefined; - var xHighestValue = undefined; - - if (!w.globals.isRangeBar) { - xLowestValue = w.globals.xAxisScale.niceMin + me.startX * xyRatios.xRatio; - xHighestValue = w.globals.xAxisScale.niceMin + me.endX * xyRatios.xRatio; - } else { - xLowestValue = w.globals.yAxisScale[0].niceMin + me.startX * xyRatios.invertedYRatio; - xHighestValue = w.globals.yAxisScale[0].niceMin + me.endX * xyRatios.invertedYRatio; - } // TODO: we will consider the 1st y axis values here for getting highest and lowest y - - - var yHighestValue = []; - var yLowestValue = []; - w.config.yaxis.forEach(function (yaxe, index) { - yHighestValue.push(w.globals.yAxisScale[index].niceMax - xyRatios.yRatio[index] * me.startY); - yLowestValue.push(w.globals.yAxisScale[index].niceMax - xyRatios.yRatio[index] * me.endY); - }); - - if (me.dragged && (me.dragX > 10 || me.dragY > 10) && xLowestValue !== xHighestValue) { - if (w.globals.zoomEnabled) { - var yaxis = Utils$1.clone(w.globals.initialConfig.yaxis); - var xaxis = Utils$1.clone(w.globals.initialConfig.xaxis); - w.globals.zoomed = true; - - if (w.config.xaxis.convertedCatToNumeric) { - xLowestValue = Math.floor(xLowestValue); - xHighestValue = Math.floor(xHighestValue); - - if (xLowestValue < 1) { - xLowestValue = 1; - xHighestValue = w.globals.dataPoints; - } - - if (xHighestValue - xLowestValue < 2) { - xHighestValue = xLowestValue + 1; - } - } - - if (zoomtype === 'xy' || zoomtype === 'x') { - xaxis = { - min: xLowestValue, - max: xHighestValue - }; - } - - if (zoomtype === 'xy' || zoomtype === 'y') { - yaxis.forEach(function (yaxe, index) { - yaxis[index].min = yLowestValue[index]; - yaxis[index].max = yHighestValue[index]; - }); - } - - if (w.config.chart.zoom.autoScaleYaxis) { - var scale = new Range$1(me.ctx); - yaxis = scale.autoScaleY(me.ctx, yaxis, { - xaxis: xaxis - }); - } - - if (toolbar) { - var beforeZoomRange = toolbar.getBeforeZoomRange(xaxis, yaxis); - - if (beforeZoomRange) { - xaxis = beforeZoomRange.xaxis ? beforeZoomRange.xaxis : xaxis; - yaxis = beforeZoomRange.yaxis ? beforeZoomRange.yaxis : yaxis; - } - } - - var options = { - xaxis: xaxis - }; - - if (!w.config.chart.group) { - // if chart in a group, prevent yaxis update here - // fix issue #650 - options.yaxis = yaxis; - } - - me.ctx.updateHelpers._updateOptions(options, false, me.w.config.chart.animations.dynamicAnimation.enabled); - - if (typeof w.config.chart.events.zoomed === 'function') { - toolbar.zoomCallback(xaxis, yaxis); - } - } else if (w.globals.selectionEnabled) { - var _yaxis = null; - var _xaxis = null; - _xaxis = { - min: xLowestValue, - max: xHighestValue - }; - - if (zoomtype === 'xy' || zoomtype === 'y') { - _yaxis = Utils$1.clone(w.config.yaxis); - - _yaxis.forEach(function (yaxe, index) { - _yaxis[index].min = yLowestValue[index]; - _yaxis[index].max = yHighestValue[index]; - }); - } - - w.globals.selection = me.selection; - - if (typeof w.config.chart.events.selection === 'function') { - w.config.chart.events.selection(me.ctx, { - xaxis: _xaxis, - yaxis: _yaxis - }); - } - } - } - } - }, { - key: "panDragging", - value: function panDragging(_ref5) { - var context = _ref5.context; - var w = this.w; - var me = context; // check to make sure there is data to compare against - - if (typeof w.globals.lastClientPosition.x !== 'undefined') { - // get the change from last position to this position - var deltaX = w.globals.lastClientPosition.x - me.clientX; - var deltaY = w.globals.lastClientPosition.y - me.clientY; // check which direction had the highest amplitude and then figure out direction by checking if the value is greater or less than zero - - if (Math.abs(deltaX) > Math.abs(deltaY) && deltaX > 0) { - this.moveDirection = 'left'; - } else if (Math.abs(deltaX) > Math.abs(deltaY) && deltaX < 0) { - this.moveDirection = 'right'; - } else if (Math.abs(deltaY) > Math.abs(deltaX) && deltaY > 0) { - this.moveDirection = 'up'; - } else if (Math.abs(deltaY) > Math.abs(deltaX) && deltaY < 0) { - this.moveDirection = 'down'; - } - } // set the new last position to the current for next time (to get the position of drag) - - - w.globals.lastClientPosition = { - x: me.clientX, - y: me.clientY - }; - var xLowestValue = w.globals.isRangeBar ? w.globals.minY : w.globals.minX; - var xHighestValue = w.globals.isRangeBar ? w.globals.maxY : w.globals.maxX; // on a category, we don't pan continuosly as it causes bugs - - if (!w.config.xaxis.convertedCatToNumeric) { - me.panScrolled(xLowestValue, xHighestValue); - } - } - }, { - key: "delayedPanScrolled", - value: function delayedPanScrolled() { - var w = this.w; - var newMinX = w.globals.minX; - var newMaxX = w.globals.maxX; - var centerX = (w.globals.maxX - w.globals.minX) / 2; - - if (this.moveDirection === 'left') { - newMinX = w.globals.minX + centerX; - newMaxX = w.globals.maxX + centerX; - } else if (this.moveDirection === 'right') { - newMinX = w.globals.minX - centerX; - newMaxX = w.globals.maxX - centerX; - } - - newMinX = Math.floor(newMinX); - newMaxX = Math.floor(newMaxX); - this.updateScrolledChart({ - xaxis: { - min: newMinX, - max: newMaxX - } - }, newMinX, newMaxX); - } - }, { - key: "panScrolled", - value: function panScrolled(xLowestValue, xHighestValue) { - var w = this.w; - var xyRatios = this.xyRatios; - var yaxis = Utils$1.clone(w.globals.initialConfig.yaxis); - var xRatio = xyRatios.xRatio; - var minX = w.globals.minX; - var maxX = w.globals.maxX; - - if (w.globals.isRangeBar) { - xRatio = xyRatios.invertedYRatio; - minX = w.globals.minY; - maxX = w.globals.maxY; - } - - if (this.moveDirection === 'left') { - xLowestValue = minX + w.globals.gridWidth / 15 * xRatio; - xHighestValue = maxX + w.globals.gridWidth / 15 * xRatio; - } else if (this.moveDirection === 'right') { - xLowestValue = minX - w.globals.gridWidth / 15 * xRatio; - xHighestValue = maxX - w.globals.gridWidth / 15 * xRatio; - } - - if (!w.globals.isRangeBar) { - if (xLowestValue < w.globals.initialMinX || xHighestValue > w.globals.initialMaxX) { - xLowestValue = minX; - xHighestValue = maxX; - } - } - - var xaxis = { - min: xLowestValue, - max: xHighestValue - }; - - if (w.config.chart.zoom.autoScaleYaxis) { - var scale = new Range$1(this.ctx); - yaxis = scale.autoScaleY(this.ctx, yaxis, { - xaxis: xaxis - }); - } - - var options = { - xaxis: { - min: xLowestValue, - max: xHighestValue - } - }; - - if (!w.config.chart.group) { - // if chart in a group, prevent yaxis update here - // fix issue #650 - options.yaxis = yaxis; - } - - this.updateScrolledChart(options, xLowestValue, xHighestValue); - } - }, { - key: "updateScrolledChart", - value: function updateScrolledChart(options, xLowestValue, xHighestValue) { - var w = this.w; - - this.ctx.updateHelpers._updateOptions(options, false, false); - - if (typeof w.config.chart.events.scrolled === 'function') { - w.config.chart.events.scrolled(this.ctx, { - xaxis: { - min: xLowestValue, - max: xHighestValue - } - }); - } - } - }]); - - return ZoomPanSelection; - }(Toolbar); - - /** - * ApexCharts Tooltip.Utils Class to support Tooltip functionality. - * - * @module Tooltip.Utils - **/ - - var Utils = /*#__PURE__*/function () { - function Utils(tooltipContext) { - _classCallCheck(this, Utils); - - this.w = tooltipContext.w; - this.ttCtx = tooltipContext; - this.ctx = tooltipContext.ctx; - } - /** - ** When hovering over series, you need to capture which series is being hovered on. - ** This function will return both capturedseries index as well as inner index of that series - * @memberof Utils - * @param {object} - * - hoverArea = the rect on which user hovers - * - elGrid = dimensions of the hover rect (it can be different than hoverarea) - */ - - - _createClass(Utils, [{ - key: "getNearestValues", - value: function getNearestValues(_ref) { - var hoverArea = _ref.hoverArea, - elGrid = _ref.elGrid, - clientX = _ref.clientX, - clientY = _ref.clientY; - var w = this.w; - var seriesBound = elGrid.getBoundingClientRect(); - var hoverWidth = seriesBound.width; - var hoverHeight = seriesBound.height; - var xDivisor = hoverWidth / (w.globals.dataPoints - 1); - var yDivisor = hoverHeight / w.globals.dataPoints; - var hasBars = this.hasBars(); - - if ((w.globals.comboCharts || hasBars) && !w.config.xaxis.convertedCatToNumeric) { - xDivisor = hoverWidth / w.globals.dataPoints; - } - - var hoverX = clientX - seriesBound.left - w.globals.barPadForNumericAxis; - var hoverY = clientY - seriesBound.top; - var notInRect = hoverX < 0 || hoverY < 0 || hoverX > hoverWidth || hoverY > hoverHeight; - - if (notInRect) { - hoverArea.classList.remove('hovering-zoom'); - hoverArea.classList.remove('hovering-pan'); - } else { - if (w.globals.zoomEnabled) { - hoverArea.classList.remove('hovering-pan'); - hoverArea.classList.add('hovering-zoom'); - } else if (w.globals.panEnabled) { - hoverArea.classList.remove('hovering-zoom'); - hoverArea.classList.add('hovering-pan'); - } - } - - var j = Math.round(hoverX / xDivisor); - var jHorz = Math.floor(hoverY / yDivisor); - - if (hasBars && !w.config.xaxis.convertedCatToNumeric) { - j = Math.ceil(hoverX / xDivisor); - j = j - 1; - } - - var capturedSeries = null; - var closest = null; - var seriesXValArr = []; - var seriesYValArr = []; //add extra values to show markers for the first points. Included both axes to avoid incorrect positioning of the marker - - w.globals.seriesXvalues.forEach(function (value) { - seriesXValArr.push([value[0] + 0.000001].concat(value)); - }); - w.globals.seriesYvalues.forEach(function (value) { - seriesYValArr.push([value[0] + 0.000001].concat(value)); - }); - seriesXValArr = seriesXValArr.map(function (seriesXVal) { - return seriesXVal.filter(function (s) { - return Utils$1.isNumber(s); - }); - }); - seriesYValArr = seriesYValArr.map(function (seriesYVal) { - return seriesYVal.filter(function (s) { - return Utils$1.isNumber(s); - }); - }); // if X axis type is not category and tooltip is not shared, then we need to find the cursor position and get the nearest value - - if (w.globals.isXNumeric) { - // Change origin of cursor position so that we can compute the relative nearest point to the cursor on our chart - // we only need to scale because all points are relative to the bounds.left and bounds.top => origin is virtually (0, 0) - var chartGridEl = this.ttCtx.getElGrid(); - var chartGridElBoundingRect = chartGridEl.getBoundingClientRect(); - var transformedHoverX = hoverX * (chartGridElBoundingRect.width / hoverWidth); - var transformedHoverY = hoverY * (chartGridElBoundingRect.height / hoverHeight); - closest = this.closestInMultiArray(transformedHoverX, transformedHoverY, seriesXValArr, seriesYValArr); - capturedSeries = closest.index; - j = closest.j; - - if (capturedSeries !== null) { - // initial push, it should be a little smaller than the 1st val - seriesXValArr = w.globals.seriesXvalues[capturedSeries]; - closest = this.closestInArray(transformedHoverX, seriesXValArr); - j = closest.index; - } - } - - w.globals.capturedSeriesIndex = capturedSeries === null ? -1 : capturedSeries; - if (!j || j < 1) j = 0; - - if (w.globals.isBarHorizontal) { - w.globals.capturedDataPointIndex = jHorz; - } else { - w.globals.capturedDataPointIndex = j; - } - - return { - capturedSeries: capturedSeries, - j: w.globals.isBarHorizontal ? jHorz : j, - hoverX: hoverX, - hoverY: hoverY - }; - } - }, { - key: "closestInMultiArray", - value: function closestInMultiArray(hoverX, hoverY, Xarrays, Yarrays) { - var w = this.w; - var activeIndex = 0; - var currIndex = null; - var j = -1; - - if (w.globals.series.length > 1) { - activeIndex = this.getFirstActiveXArray(Xarrays); - } else { - currIndex = 0; - } - - var currX = Xarrays[activeIndex][0]; - var diffX = Math.abs(hoverX - currX); // find nearest point on x-axis - - Xarrays.forEach(function (arrX) { - arrX.forEach(function (x, iX) { - var newDiff = Math.abs(hoverX - x); - - if (newDiff < diffX) { - diffX = newDiff; - j = iX; - } - }); - }); - - if (j !== -1) { - // find nearest graph on y-axis relevanted to nearest point on x-axis - var currY = Yarrays[activeIndex][j]; - var diffY = Math.abs(hoverY - currY); - currIndex = activeIndex; - Yarrays.forEach(function (arrY, iAY) { - var newDiff = Math.abs(hoverY - arrY[j]); - - if (newDiff < diffY) { - diffY = newDiff; - currIndex = iAY; - } - }); - } - - return { - index: currIndex, - j: j - }; - } - }, { - key: "getFirstActiveXArray", - value: function getFirstActiveXArray(Xarrays) { - var w = this.w; - var activeIndex = 0; - var firstActiveSeriesIndex = Xarrays.map(function (xarr, index) { - return xarr.length > 0 ? index : -1; - }); - - for (var a = 0; a < firstActiveSeriesIndex.length; a++) { - if (firstActiveSeriesIndex[a] !== -1 && w.globals.collapsedSeriesIndices.indexOf(a) === -1 && w.globals.ancillaryCollapsedSeriesIndices.indexOf(a) === -1) { - activeIndex = firstActiveSeriesIndex[a]; - break; - } - } - - return activeIndex; - } - }, { - key: "closestInArray", - value: function closestInArray(val, arr) { - var curr = arr[0]; - var currIndex = null; - var diff = Math.abs(val - curr); - - for (var i = 0; i < arr.length; i++) { - var newdiff = Math.abs(val - arr[i]); - - if (newdiff < diff) { - diff = newdiff; - currIndex = i; - } - } - - return { - index: currIndex - }; - } - /** - * When there are multiple series, it is possible to have different x values for each series. - * But it may be possible in those multiple series, that there is same x value for 2 or more - * series. - * @memberof Utils - * @param {int} - * - j = is the inner index of series -> (series[i][j]) - * @return {bool} - */ - - }, { - key: "isXoverlap", - value: function isXoverlap(j) { - var w = this.w; - var xSameForAllSeriesJArr = []; - var seriesX = w.globals.seriesX.filter(function (s) { - return typeof s[0] !== 'undefined'; - }); - - if (seriesX.length > 0) { - for (var i = 0; i < seriesX.length - 1; i++) { - if (typeof seriesX[i][j] !== 'undefined' && typeof seriesX[i + 1][j] !== 'undefined') { - if (seriesX[i][j] !== seriesX[i + 1][j]) { - xSameForAllSeriesJArr.push('unEqual'); - } - } - } - } - - if (xSameForAllSeriesJArr.length === 0) { - return true; - } - - return false; - } - }, { - key: "isInitialSeriesSameLen", - value: function isInitialSeriesSameLen() { - var sameLen = true; - var initialSeries = this.w.globals.initialSeries; - - for (var i = 0; i < initialSeries.length - 1; i++) { - if (initialSeries[i].data.length !== initialSeries[i + 1].data.length) { - sameLen = false; - break; - } - } - - return sameLen; - } - }, { - key: "getBarsHeight", - value: function getBarsHeight(allbars) { - var bars = _toConsumableArray(allbars); - - var totalHeight = bars.reduce(function (acc, bar) { - return acc + bar.getBBox().height; - }, 0); - return totalHeight; - } - }, { - key: "getElMarkers", - value: function getElMarkers(capturedSeries) { - // The selector .apexcharts-series-markers-wrap > * includes marker groups for which the - // .apexcharts-series-markers class is not added due to null values or discrete markers - if (typeof capturedSeries == 'number') { - return this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series[data\\:realIndex='".concat(capturedSeries, "'] .apexcharts-series-markers-wrap > *")); - } - - return this.w.globals.dom.baseEl.querySelectorAll('.apexcharts-series-markers-wrap > *'); - } - }, { - key: "getAllMarkers", - value: function getAllMarkers() { - // first get all marker parents. This parent class contains series-index - // which helps to sort the markers as they are dynamic - var markersWraps = this.w.globals.dom.baseEl.querySelectorAll('.apexcharts-series-markers-wrap'); - markersWraps = _toConsumableArray(markersWraps); - markersWraps.sort(function (a, b) { - var indexA = Number(a.getAttribute('data:realIndex')); - var indexB = Number(b.getAttribute('data:realIndex')); - return indexB < indexA ? 1 : indexB > indexA ? -1 : 0; - }); - var markers = []; - markersWraps.forEach(function (m) { - markers.push(m.querySelector('.apexcharts-marker')); - }); - return markers; - } - }, { - key: "hasMarkers", - value: function hasMarkers(capturedSeries) { - var markers = this.getElMarkers(capturedSeries); - return markers.length > 0; - } - }, { - key: "getElBars", - value: function getElBars() { - return this.w.globals.dom.baseEl.querySelectorAll('.apexcharts-bar-series, .apexcharts-candlestick-series, .apexcharts-boxPlot-series, .apexcharts-rangebar-series'); - } - }, { - key: "hasBars", - value: function hasBars() { - var bars = this.getElBars(); - return bars.length > 0; - } - }, { - key: "getHoverMarkerSize", - value: function getHoverMarkerSize(index) { - var w = this.w; - var hoverSize = w.config.markers.hover.size; - - if (hoverSize === undefined) { - hoverSize = w.globals.markers.size[index] + w.config.markers.hover.sizeOffset; - } - - return hoverSize; - } - }, { - key: "toggleAllTooltipSeriesGroups", - value: function toggleAllTooltipSeriesGroups(state) { - var w = this.w; - var ttCtx = this.ttCtx; - - if (ttCtx.allTooltipSeriesGroups.length === 0) { - ttCtx.allTooltipSeriesGroups = w.globals.dom.baseEl.querySelectorAll('.apexcharts-tooltip-series-group'); - } - - var allTooltipSeriesGroups = ttCtx.allTooltipSeriesGroups; - - for (var i = 0; i < allTooltipSeriesGroups.length; i++) { - if (state === 'enable') { - allTooltipSeriesGroups[i].classList.add('apexcharts-active'); - allTooltipSeriesGroups[i].style.display = w.config.tooltip.items.display; - } else { - allTooltipSeriesGroups[i].classList.remove('apexcharts-active'); - allTooltipSeriesGroups[i].style.display = 'none'; - } - } - } - }]); - - return Utils; - }(); - - /** - * ApexCharts Tooltip.Labels Class to draw texts on the tooltip. - * This file deals with printing actual text on the tooltip. - * - * @module Tooltip.Labels - **/ - - var Labels = /*#__PURE__*/function () { - function Labels(tooltipContext) { - _classCallCheck(this, Labels); - - this.w = tooltipContext.w; - this.ctx = tooltipContext.ctx; - this.ttCtx = tooltipContext; - this.tooltipUtil = new Utils(tooltipContext); - } - - _createClass(Labels, [{ - key: "drawSeriesTexts", - value: function drawSeriesTexts(_ref) { - var _ref$shared = _ref.shared, - shared = _ref$shared === void 0 ? true : _ref$shared, - ttItems = _ref.ttItems, - _ref$i = _ref.i, - i = _ref$i === void 0 ? 0 : _ref$i, - _ref$j = _ref.j, - j = _ref$j === void 0 ? null : _ref$j, - y1 = _ref.y1, - y2 = _ref.y2, - e = _ref.e; - var w = this.w; - - if (w.config.tooltip.custom !== undefined) { - this.handleCustomTooltip({ - i: i, - j: j, - y1: y1, - y2: y2, - w: w - }); - } else { - this.toggleActiveInactiveSeries(shared); - } - - var values = this.getValuesToPrint({ - i: i, - j: j - }); - this.printLabels({ - i: i, - j: j, - values: values, - ttItems: ttItems, - shared: shared, - e: e - }); // Re-calculate tooltip dimensions now that we have drawn the text - - var tooltipEl = this.ttCtx.getElTooltip(); - this.ttCtx.tooltipRect.ttWidth = tooltipEl.getBoundingClientRect().width; - this.ttCtx.tooltipRect.ttHeight = tooltipEl.getBoundingClientRect().height; - } - }, { - key: "printLabels", - value: function printLabels(_ref2) { - var _this = this; - - var i = _ref2.i, - j = _ref2.j, - values = _ref2.values, - ttItems = _ref2.ttItems, - shared = _ref2.shared, - e = _ref2.e; - var w = this.w; - var val; - var goalVals = []; - - var hasGoalValues = function hasGoalValues(gi) { - return w.globals.seriesGoals[gi] && w.globals.seriesGoals[gi][j] && Array.isArray(w.globals.seriesGoals[gi][j]); - }; - - var xVal = values.xVal, - zVal = values.zVal, - xAxisTTVal = values.xAxisTTVal; - var seriesName = ''; - var pColor = w.globals.colors[i]; // The pColor here is for the markers inside tooltip - - if (j !== null && w.config.plotOptions.bar.distributed) { - pColor = w.globals.colors[j]; - } - - var _loop = function _loop(t, inverset) { - var f = _this.getFormatters(i); - - seriesName = _this.getSeriesName({ - fn: f.yLbTitleFormatter, - index: i, - seriesIndex: i, - j: j - }); - - if (w.config.chart.type === 'treemap') { - seriesName = f.yLbTitleFormatter(String(w.config.series[i].data[j].x), { - series: w.globals.series, - seriesIndex: i, - dataPointIndex: j, - w: w - }); - } - - var tIndex = w.config.tooltip.inverseOrder ? inverset : t; - - if (w.globals.axisCharts) { - var getValBySeriesIndex = function getValBySeriesIndex(index) { - if (w.globals.isRangeData) { - var _w$globals$seriesRang, _w$globals$seriesRang2, _w$globals$seriesRang3, _w$globals$seriesRang4; - - return f.yLbFormatter((_w$globals$seriesRang = w.globals.seriesRangeStart) === null || _w$globals$seriesRang === void 0 ? void 0 : (_w$globals$seriesRang2 = _w$globals$seriesRang[index]) === null || _w$globals$seriesRang2 === void 0 ? void 0 : _w$globals$seriesRang2[j], { - series: w.globals.seriesRangeStart, - seriesIndex: index, - dataPointIndex: j, - w: w - }) + ' - ' + f.yLbFormatter((_w$globals$seriesRang3 = w.globals.seriesRangeEnd) === null || _w$globals$seriesRang3 === void 0 ? void 0 : (_w$globals$seriesRang4 = _w$globals$seriesRang3[index]) === null || _w$globals$seriesRang4 === void 0 ? void 0 : _w$globals$seriesRang4[j], { - series: w.globals.seriesRangeEnd, - seriesIndex: index, - dataPointIndex: j, - w: w - }); - } - - return f.yLbFormatter(w.globals.series[index][j], { - series: w.globals.series, - seriesIndex: index, - dataPointIndex: j, - w: w - }); - }; - - if (shared) { - f = _this.getFormatters(tIndex); - seriesName = _this.getSeriesName({ - fn: f.yLbTitleFormatter, - index: tIndex, - seriesIndex: i, - j: j - }); - pColor = w.globals.colors[tIndex]; - val = getValBySeriesIndex(tIndex); - - if (hasGoalValues(tIndex)) { - goalVals = w.globals.seriesGoals[tIndex][j].map(function (goal) { - return { - attrs: goal, - val: f.yLbFormatter(goal.value, { - seriesIndex: tIndex, - dataPointIndex: j, - w: w - }) - }; - }); - } - } else { - var _e$target; - - // get a color from a hover area (if it's a line pattern then get from a first line) - var targetFill = e === null || e === void 0 ? void 0 : (_e$target = e.target) === null || _e$target === void 0 ? void 0 : _e$target.getAttribute('fill'); - - if (targetFill) { - pColor = targetFill.indexOf('url') !== -1 ? document.querySelector(targetFill.substr(4).slice(0, -1)).childNodes[0].getAttribute('stroke') : targetFill; - } - - val = getValBySeriesIndex(i); - - if (hasGoalValues(i) && Array.isArray(w.globals.seriesGoals[i][j])) { - goalVals = w.globals.seriesGoals[i][j].map(function (goal) { - return { - attrs: goal, - val: f.yLbFormatter(goal.value, { - seriesIndex: i, - dataPointIndex: j, - w: w - }) - }; - }); - } - } - } // for pie / donuts - - - if (j === null) { - val = f.yLbFormatter(w.globals.series[i], _objectSpread2(_objectSpread2({}, w), {}, { - seriesIndex: i, - dataPointIndex: i - })); - } - - _this.DOMHandling({ - i: i, - t: tIndex, - j: j, - ttItems: ttItems, - values: { - val: val, - goalVals: goalVals, - xVal: xVal, - xAxisTTVal: xAxisTTVal, - zVal: zVal - }, - seriesName: seriesName, - shared: shared, - pColor: pColor - }); - }; - - for (var t = 0, inverset = w.globals.series.length - 1; t < w.globals.series.length; t++, inverset--) { - _loop(t, inverset); - } - } - }, { - key: "getFormatters", - value: function getFormatters(i) { - var w = this.w; - var yLbFormatter = w.globals.yLabelFormatters[i]; - var yLbTitleFormatter; - - if (w.globals.ttVal !== undefined) { - if (Array.isArray(w.globals.ttVal)) { - yLbFormatter = w.globals.ttVal[i] && w.globals.ttVal[i].formatter; - yLbTitleFormatter = w.globals.ttVal[i] && w.globals.ttVal[i].title && w.globals.ttVal[i].title.formatter; - } else { - yLbFormatter = w.globals.ttVal.formatter; - - if (typeof w.globals.ttVal.title.formatter === 'function') { - yLbTitleFormatter = w.globals.ttVal.title.formatter; - } - } - } else { - yLbTitleFormatter = w.config.tooltip.y.title.formatter; - } - - if (typeof yLbFormatter !== 'function') { - if (w.globals.yLabelFormatters[0]) { - yLbFormatter = w.globals.yLabelFormatters[0]; - } else { - yLbFormatter = function yLbFormatter(label) { - return label; - }; - } - } - - if (typeof yLbTitleFormatter !== 'function') { - yLbTitleFormatter = function yLbTitleFormatter(label) { - return label; - }; - } - - return { - yLbFormatter: yLbFormatter, - yLbTitleFormatter: yLbTitleFormatter - }; - } - }, { - key: "getSeriesName", - value: function getSeriesName(_ref3) { - var fn = _ref3.fn, - index = _ref3.index, - seriesIndex = _ref3.seriesIndex, - j = _ref3.j; - var w = this.w; - return fn(String(w.globals.seriesNames[index]), { - series: w.globals.series, - seriesIndex: seriesIndex, - dataPointIndex: j, - w: w - }); - } - }, { - key: "DOMHandling", - value: function DOMHandling(_ref4) { - _ref4.i; - var t = _ref4.t, - j = _ref4.j, - ttItems = _ref4.ttItems, - values = _ref4.values, - seriesName = _ref4.seriesName, - shared = _ref4.shared, - pColor = _ref4.pColor; - var w = this.w; - var ttCtx = this.ttCtx; - var val = values.val, - goalVals = values.goalVals, - xVal = values.xVal, - xAxisTTVal = values.xAxisTTVal, - zVal = values.zVal; - var ttItemsChildren = null; - ttItemsChildren = ttItems[t].children; - - if (w.config.tooltip.fillSeriesColor) { - ttItems[t].style.backgroundColor = pColor; - ttItemsChildren[0].style.display = 'none'; - } - - if (ttCtx.showTooltipTitle) { - if (ttCtx.tooltipTitle === null) { - // get it once if null, and store it in class property - ttCtx.tooltipTitle = w.globals.dom.baseEl.querySelector('.apexcharts-tooltip-title'); - } - - ttCtx.tooltipTitle.innerHTML = xVal; - } // if xaxis tooltip is constructed, we need to replace the innerHTML - - - if (ttCtx.isXAxisTooltipEnabled) { - ttCtx.xaxisTooltipText.innerHTML = xAxisTTVal !== '' ? xAxisTTVal : xVal; - } - - var ttYLabel = ttItems[t].querySelector('.apexcharts-tooltip-text-y-label'); - - if (ttYLabel) { - ttYLabel.innerHTML = seriesName ? seriesName : ''; - } - - var ttYVal = ttItems[t].querySelector('.apexcharts-tooltip-text-y-value'); - - if (ttYVal) { - ttYVal.innerHTML = typeof val !== 'undefined' ? val : ''; - } - - if (ttItemsChildren[0] && ttItemsChildren[0].classList.contains('apexcharts-tooltip-marker')) { - if (w.config.tooltip.marker.fillColors && Array.isArray(w.config.tooltip.marker.fillColors)) { - pColor = w.config.tooltip.marker.fillColors[t]; - } - - ttItemsChildren[0].style.backgroundColor = pColor; - } - - if (!w.config.tooltip.marker.show) { - ttItemsChildren[0].style.display = 'none'; - } - - var ttGLabel = ttItems[t].querySelector('.apexcharts-tooltip-text-goals-label'); - var ttGVal = ttItems[t].querySelector('.apexcharts-tooltip-text-goals-value'); - - if (goalVals.length && w.globals.seriesGoals[t]) { - var createGoalsHtml = function createGoalsHtml() { - var gLabels = '
'; - var gVals = '
'; - goalVals.forEach(function (goal, gi) { - gLabels += "
").concat(goal.attrs.name, "
"); - gVals += "
".concat(goal.val, "
"); - }); - ttGLabel.innerHTML = gLabels + "
"; - ttGVal.innerHTML = gVals + "
"; - }; - - if (shared) { - if (w.globals.seriesGoals[t][j] && Array.isArray(w.globals.seriesGoals[t][j])) { - createGoalsHtml(); - } else { - ttGLabel.innerHTML = ''; - ttGVal.innerHTML = ''; - } - } else { - createGoalsHtml(); - } - } else { - ttGLabel.innerHTML = ''; - ttGVal.innerHTML = ''; - } - - if (zVal !== null) { - var ttZLabel = ttItems[t].querySelector('.apexcharts-tooltip-text-z-label'); - ttZLabel.innerHTML = w.config.tooltip.z.title; - var ttZVal = ttItems[t].querySelector('.apexcharts-tooltip-text-z-value'); - ttZVal.innerHTML = typeof zVal !== 'undefined' ? zVal : ''; - } - - if (shared && ttItemsChildren[0]) { - // hide when no Val or series collapsed - if (typeof val === 'undefined' || val === null || w.globals.ancillaryCollapsedSeriesIndices.indexOf(t) > -1 || w.globals.collapsedSeriesIndices.indexOf(t) > -1) { - ttItemsChildren[0].parentNode.style.display = 'none'; - } else { - ttItemsChildren[0].parentNode.style.display = w.config.tooltip.items.display; - } - } - } - }, { - key: "toggleActiveInactiveSeries", - value: function toggleActiveInactiveSeries(shared) { - var w = this.w; - - if (shared) { - // make all tooltips active - this.tooltipUtil.toggleAllTooltipSeriesGroups('enable'); - } else { - // disable all tooltip text groups - this.tooltipUtil.toggleAllTooltipSeriesGroups('disable'); // enable the first tooltip text group - - var firstTooltipSeriesGroup = w.globals.dom.baseEl.querySelector('.apexcharts-tooltip-series-group'); - - if (firstTooltipSeriesGroup) { - firstTooltipSeriesGroup.classList.add('apexcharts-active'); - firstTooltipSeriesGroup.style.display = w.config.tooltip.items.display; - } - } - } - }, { - key: "getValuesToPrint", - value: function getValuesToPrint(_ref5) { - var i = _ref5.i, - j = _ref5.j; - var w = this.w; - var filteredSeriesX = this.ctx.series.filteredSeriesX(); - var xVal = ''; - var xAxisTTVal = ''; - var zVal = null; - var val = null; - var customFormatterOpts = { - series: w.globals.series, - seriesIndex: i, - dataPointIndex: j, - w: w - }; - var zFormatter = w.globals.ttZFormatter; - - if (j === null) { - val = w.globals.series[i]; - } else { - if (w.globals.isXNumeric && w.config.chart.type !== 'treemap') { - xVal = filteredSeriesX[i][j]; - - if (filteredSeriesX[i].length === 0) { - // a series (possibly the first one) might be collapsed, so get the next active index - var firstActiveSeriesIndex = this.tooltipUtil.getFirstActiveXArray(filteredSeriesX); - xVal = filteredSeriesX[firstActiveSeriesIndex][j]; - } - } else { - xVal = typeof w.globals.labels[j] !== 'undefined' ? w.globals.labels[j] : ''; - } - } - - var bufferXVal = xVal; - - if (w.globals.isXNumeric && w.config.xaxis.type === 'datetime') { - var xFormat = new Formatters(this.ctx); - xVal = xFormat.xLabelFormat(w.globals.ttKeyFormatter, bufferXVal, bufferXVal, { - i: undefined, - dateFormatter: new DateTime(this.ctx).formatDate, - w: this.w - }); - } else { - if (w.globals.isBarHorizontal) { - xVal = w.globals.yLabelFormatters[0](bufferXVal, customFormatterOpts); - } else { - xVal = w.globals.xLabelFormatter(bufferXVal, customFormatterOpts); - } - } // override default x-axis formatter with tooltip formatter - - - if (w.config.tooltip.x.formatter !== undefined) { - xVal = w.globals.ttKeyFormatter(bufferXVal, customFormatterOpts); - } - - if (w.globals.seriesZ.length > 0 && w.globals.seriesZ[i].length > 0) { - zVal = zFormatter(w.globals.seriesZ[i][j], w); - } - - if (typeof w.config.xaxis.tooltip.formatter === 'function') { - xAxisTTVal = w.globals.xaxisTooltipFormatter(bufferXVal, customFormatterOpts); - } else { - xAxisTTVal = xVal; - } - - return { - val: Array.isArray(val) ? val.join(' ') : val, - xVal: Array.isArray(xVal) ? xVal.join(' ') : xVal, - xAxisTTVal: Array.isArray(xAxisTTVal) ? xAxisTTVal.join(' ') : xAxisTTVal, - zVal: zVal - }; - } - }, { - key: "handleCustomTooltip", - value: function handleCustomTooltip(_ref6) { - var i = _ref6.i, - j = _ref6.j, - y1 = _ref6.y1, - y2 = _ref6.y2, - w = _ref6.w; - var tooltipEl = this.ttCtx.getElTooltip(); - var fn = w.config.tooltip.custom; - - if (Array.isArray(fn) && fn[i]) { - fn = fn[i]; - } // override everything with a custom html tooltip and replace it - - - tooltipEl.innerHTML = fn({ - ctx: this.ctx, - series: w.globals.series, - seriesIndex: i, - dataPointIndex: j, - y1: y1, - y2: y2, - w: w - }); - } - }]); - - return Labels; - }(); - - /** - * ApexCharts Tooltip.Position Class to move the tooltip based on x and y position. - * - * @module Tooltip.Position - **/ - - var Position = /*#__PURE__*/function () { - function Position(tooltipContext) { - _classCallCheck(this, Position); - - this.ttCtx = tooltipContext; - this.ctx = tooltipContext.ctx; - this.w = tooltipContext.w; - } - /** - * This will move the crosshair (the vertical/horz line that moves along with mouse) - * Along with this, this function also calls the xaxisMove function - * @memberof Position - * @param {int} - cx = point's x position, wherever point's x is, you need to move crosshair - */ - - - _createClass(Position, [{ - key: "moveXCrosshairs", - value: function moveXCrosshairs(cx) { - var j = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - var ttCtx = this.ttCtx; - var w = this.w; - var xcrosshairs = ttCtx.getElXCrosshairs(); - var x = cx - ttCtx.xcrosshairsWidth / 2; - var tickAmount = w.globals.labels.slice().length; - - if (j !== null) { - x = w.globals.gridWidth / tickAmount * j; - } - - if (xcrosshairs !== null && !w.globals.isBarHorizontal) { - xcrosshairs.setAttribute('x', x); - xcrosshairs.setAttribute('x1', x); - xcrosshairs.setAttribute('x2', x); - xcrosshairs.setAttribute('y2', w.globals.gridHeight); - xcrosshairs.classList.add('apexcharts-active'); - } - - if (x < 0) { - x = 0; - } - - if (x > w.globals.gridWidth) { - x = w.globals.gridWidth; - } - - if (ttCtx.isXAxisTooltipEnabled) { - var tx = x; - - if (w.config.xaxis.crosshairs.width === 'tickWidth' || w.config.xaxis.crosshairs.width === 'barWidth') { - tx = x + ttCtx.xcrosshairsWidth / 2; - } - - this.moveXAxisTooltip(tx); - } - } - /** - * This will move the crosshair (the vertical/horz line that moves along with mouse) - * Along with this, this function also calls the xaxisMove function - * @memberof Position - * @param {int} - cx = point's x position, wherever point's x is, you need to move crosshair - */ - - }, { - key: "moveYCrosshairs", - value: function moveYCrosshairs(cy) { - var ttCtx = this.ttCtx; - - if (ttCtx.ycrosshairs !== null) { - Graphics.setAttrs(ttCtx.ycrosshairs, { - y1: cy, - y2: cy - }); - } - - if (ttCtx.ycrosshairsHidden !== null) { - Graphics.setAttrs(ttCtx.ycrosshairsHidden, { - y1: cy, - y2: cy - }); - } - } - /** - ** AxisTooltip is the small rectangle which appears on x axis with x value, when user moves - * @memberof Position - * @param {int} - cx = point's x position, wherever point's x is, you need to move - */ - - }, { - key: "moveXAxisTooltip", - value: function moveXAxisTooltip(cx) { - var w = this.w; - var ttCtx = this.ttCtx; - - if (ttCtx.xaxisTooltip !== null && ttCtx.xcrosshairsWidth !== 0) { - ttCtx.xaxisTooltip.classList.add('apexcharts-active'); - var cy = ttCtx.xaxisOffY + w.config.xaxis.tooltip.offsetY + w.globals.translateY + 1 + w.config.xaxis.offsetY; - var xaxisTTText = ttCtx.xaxisTooltip.getBoundingClientRect(); - var xaxisTTTextWidth = xaxisTTText.width; - cx = cx - xaxisTTTextWidth / 2; - - if (!isNaN(cx)) { - cx = cx + w.globals.translateX; - var textRect = 0; - var graphics = new Graphics(this.ctx); - textRect = graphics.getTextRects(ttCtx.xaxisTooltipText.innerHTML); - ttCtx.xaxisTooltipText.style.minWidth = textRect.width + 'px'; - ttCtx.xaxisTooltip.style.left = cx + 'px'; - ttCtx.xaxisTooltip.style.top = cy + 'px'; - } - } - } - }, { - key: "moveYAxisTooltip", - value: function moveYAxisTooltip(index) { - var w = this.w; - var ttCtx = this.ttCtx; - - if (ttCtx.yaxisTTEls === null) { - ttCtx.yaxisTTEls = w.globals.dom.baseEl.querySelectorAll('.apexcharts-yaxistooltip'); - } - - var ycrosshairsHiddenRectY1 = parseInt(ttCtx.ycrosshairsHidden.getAttribute('y1'), 10); - var cy = w.globals.translateY + ycrosshairsHiddenRectY1; - var yAxisTTRect = ttCtx.yaxisTTEls[index].getBoundingClientRect(); - var yAxisTTHeight = yAxisTTRect.height; - var cx = w.globals.translateYAxisX[index] - 2; - - if (w.config.yaxis[index].opposite) { - cx = cx - 26; - } - - cy = cy - yAxisTTHeight / 2; - - if (w.globals.ignoreYAxisIndexes.indexOf(index) === -1) { - ttCtx.yaxisTTEls[index].classList.add('apexcharts-active'); - ttCtx.yaxisTTEls[index].style.top = cy + 'px'; - ttCtx.yaxisTTEls[index].style.left = cx + w.config.yaxis[index].tooltip.offsetX + 'px'; - } else { - ttCtx.yaxisTTEls[index].classList.remove('apexcharts-active'); - } - } - /** - ** moves the whole tooltip by changing x, y attrs - * @memberof Position - * @param {int} - cx = point's x position, wherever point's x is, you need to move tooltip - * @param {int} - cy = point's y position, wherever point's y is, you need to move tooltip - * @param {int} - r = point's radius - */ - - }, { - key: "moveTooltip", - value: function moveTooltip(cx, cy) { - var r = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - var w = this.w; - var ttCtx = this.ttCtx; - var tooltipEl = ttCtx.getElTooltip(); - var tooltipRect = ttCtx.tooltipRect; - var pointR = r !== null ? parseFloat(r) : 1; - var x = parseFloat(cx) + pointR + 5; - var y = parseFloat(cy) + pointR / 2; // - tooltipRect.ttHeight / 2 - - if (x > w.globals.gridWidth / 2) { - x = x - tooltipRect.ttWidth - pointR - 10; - } - - if (x > w.globals.gridWidth - tooltipRect.ttWidth - 10) { - x = w.globals.gridWidth - tooltipRect.ttWidth; - } - - if (x < -20) { - x = -20; - } - - if (w.config.tooltip.followCursor) { - var elGrid = ttCtx.getElGrid(); - var seriesBound = elGrid.getBoundingClientRect(); - x = ttCtx.e.clientX - seriesBound.left; - - if (x > w.globals.gridWidth / 2) { - x = x - ttCtx.tooltipRect.ttWidth; - } - - y = ttCtx.e.clientY + w.globals.translateY - seriesBound.top; - - if (y > w.globals.gridHeight / 2) { - y = y - ttCtx.tooltipRect.ttHeight; - } - } else { - if (!w.globals.isBarHorizontal) { - if (tooltipRect.ttHeight / 2 + y > w.globals.gridHeight) { - y = w.globals.gridHeight - tooltipRect.ttHeight + w.globals.translateY; - } - } - } - - if (!isNaN(x)) { - x = x + w.globals.translateX; - tooltipEl.style.left = x + 'px'; - tooltipEl.style.top = y + 'px'; - } - } - }, { - key: "moveMarkers", - value: function moveMarkers(i, j) { - var w = this.w; - var ttCtx = this.ttCtx; - - if (w.globals.markers.size[i] > 0) { - var allPoints = w.globals.dom.baseEl.querySelectorAll(" .apexcharts-series[data\\:realIndex='".concat(i, "'] .apexcharts-marker")); - - for (var p = 0; p < allPoints.length; p++) { - if (parseInt(allPoints[p].getAttribute('rel'), 10) === j) { - ttCtx.marker.resetPointsSize(); - ttCtx.marker.enlargeCurrentPoint(j, allPoints[p]); - } - } - } else { - ttCtx.marker.resetPointsSize(); - this.moveDynamicPointOnHover(j, i); - } - } // This function is used when you need to show markers/points only on hover - - // DIFFERENT X VALUES in multiple series - - }, { - key: "moveDynamicPointOnHover", - value: function moveDynamicPointOnHover(j, capturedSeries) { - var w = this.w; - var ttCtx = this.ttCtx; - var cx = 0; - var cy = 0; - var pointsArr = w.globals.pointsArray; - var hoverSize = ttCtx.tooltipUtil.getHoverMarkerSize(capturedSeries); - var serType = w.config.series[capturedSeries].type; - - if (serType && (serType === 'column' || serType === 'candlestick' || serType === 'boxPlot')) { - // fix error mentioned in #811 - return; - } - - cx = pointsArr[capturedSeries][j][0]; - cy = pointsArr[capturedSeries][j][1] ? pointsArr[capturedSeries][j][1] : 0; - var point = w.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(capturedSeries, "'] .apexcharts-series-markers circle")); - - if (point && cy < w.globals.gridHeight && cy > 0) { - point.setAttribute('r', hoverSize); - point.setAttribute('cx', cx); - point.setAttribute('cy', cy); - } // point.style.opacity = w.config.markers.hover.opacity - - - this.moveXCrosshairs(cx); - - if (!ttCtx.fixedTooltip) { - this.moveTooltip(cx, cy, hoverSize); - } - } // This function is used when you need to show markers/points only on hover - - // SAME X VALUES in multiple series - - }, { - key: "moveDynamicPointsOnHover", - value: function moveDynamicPointsOnHover(j) { - var ttCtx = this.ttCtx; - var w = ttCtx.w; - var cx = 0; - var cy = 0; - var activeSeries = 0; - var pointsArr = w.globals.pointsArray; - var series = new Series(this.ctx); - activeSeries = series.getActiveConfigSeriesIndex('asc', ['line', 'area', 'scatter', 'bubble']); - var hoverSize = ttCtx.tooltipUtil.getHoverMarkerSize(activeSeries); - - if (pointsArr[activeSeries]) { - cx = pointsArr[activeSeries][j][0]; - cy = pointsArr[activeSeries][j][1]; - } - - var points = ttCtx.tooltipUtil.getAllMarkers(); - - if (points !== null) { - for (var p = 0; p < w.globals.series.length; p++) { - var pointArr = pointsArr[p]; - - if (w.globals.comboCharts) { - // in a combo chart, if column charts are present, markers will not match with the number of series, hence this patch to push a null value in points array - if (typeof pointArr === 'undefined') { - // nodelist to array - points.splice(p, 0, null); - } - } - - if (pointArr && pointArr.length) { - var pcy = pointsArr[p][j][1]; - var pcy2 = void 0; - points[p].setAttribute('cx', cx); - - if (w.config.chart.type === 'rangeArea' && !w.globals.comboCharts) { - var rangeStartIndex = j + w.globals.series[p].length; - pcy2 = pointsArr[p][rangeStartIndex][1]; - var pcyDiff = Math.abs(pcy - pcy2) / 2; - pcy = pcy - pcyDiff; - } - - if (pcy !== null && !isNaN(pcy) && pcy < w.globals.gridHeight + hoverSize && pcy + hoverSize > 0) { - points[p] && points[p].setAttribute('r', hoverSize); - points[p] && points[p].setAttribute('cy', pcy); - } else { - points[p] && points[p].setAttribute('r', 0); - } - } - } - } - - this.moveXCrosshairs(cx); - - if (!ttCtx.fixedTooltip) { - this.moveTooltip(cx, cy || w.globals.gridHeight, hoverSize); - } - } - }, { - key: "moveStickyTooltipOverBars", - value: function moveStickyTooltipOverBars(j, capturedSeries) { - var w = this.w; - var ttCtx = this.ttCtx; - var barLen = w.globals.columnSeries ? w.globals.columnSeries.length : w.globals.series.length; - var i = barLen >= 2 && barLen % 2 === 0 ? Math.floor(barLen / 2) : Math.floor(barLen / 2) + 1; - - if (w.globals.isBarHorizontal) { - var series = new Series(this.ctx); - i = series.getActiveConfigSeriesIndex('desc') + 1; - } - - var jBar = w.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[rel='".concat(i, "'] path[j='").concat(j, "'], .apexcharts-candlestick-series .apexcharts-series[rel='").concat(i, "'] path[j='").concat(j, "'], .apexcharts-boxPlot-series .apexcharts-series[rel='").concat(i, "'] path[j='").concat(j, "'], .apexcharts-rangebar-series .apexcharts-series[rel='").concat(i, "'] path[j='").concat(j, "']")); - - if (!jBar && typeof capturedSeries === 'number') { - // Try with captured series index - jBar = w.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[data\\:realIndex='".concat(capturedSeries, "'] path[j='").concat(j, "'],\n .apexcharts-candlestick-series .apexcharts-series[data\\:realIndex='").concat(capturedSeries, "'] path[j='").concat(j, "'],\n .apexcharts-boxPlot-series .apexcharts-series[data\\:realIndex='").concat(capturedSeries, "'] path[j='").concat(j, "'],\n .apexcharts-rangebar-series .apexcharts-series[data\\:realIndex='").concat(capturedSeries, "'] path[j='").concat(j, "']")); - } - - var bcx = jBar ? parseFloat(jBar.getAttribute('cx')) : 0; - var bcy = jBar ? parseFloat(jBar.getAttribute('cy')) : 0; - var bw = jBar ? parseFloat(jBar.getAttribute('barWidth')) : 0; - var elGrid = ttCtx.getElGrid(); - var seriesBound = elGrid.getBoundingClientRect(); - var isBoxOrCandle = jBar && (jBar.classList.contains('apexcharts-candlestick-area') || jBar.classList.contains('apexcharts-boxPlot-area')); - - if (w.globals.isXNumeric) { - if (jBar && !isBoxOrCandle) { - bcx = bcx - (barLen % 2 !== 0 ? bw / 2 : 0); - } - - if (jBar && // fixes apexcharts.js#2354 - isBoxOrCandle && w.globals.comboCharts) { - bcx = bcx - bw / 2; - } - } else { - if (!w.globals.isBarHorizontal) { - bcx = ttCtx.xAxisTicksPositions[j - 1] + ttCtx.dataPointsDividedWidth / 2; - - if (isNaN(bcx)) { - bcx = ttCtx.xAxisTicksPositions[j] - ttCtx.dataPointsDividedWidth / 2; - } - } - } - - if (!w.globals.isBarHorizontal) { - if (w.config.tooltip.followCursor) { - bcy = ttCtx.e.clientY - seriesBound.top - ttCtx.tooltipRect.ttHeight / 2; - } else { - if (bcy + ttCtx.tooltipRect.ttHeight + 15 > w.globals.gridHeight) { - bcy = w.globals.gridHeight; - } - } - } else { - bcy = bcy - ttCtx.tooltipRect.ttHeight; - } - - if (!w.globals.isBarHorizontal) { - this.moveXCrosshairs(bcx); - } - - if (!ttCtx.fixedTooltip) { - this.moveTooltip(bcx, bcy || w.globals.gridHeight); - } - } - }]); - - return Position; - }(); - - /** - * ApexCharts Tooltip.Marker Class to draw texts on the tooltip. - * This file deals with the markers that appear near tooltip in line/area charts. - * These markers helps the user to associate the data-points and the values - * that are shown in the tooltip - * - * @module Tooltip.Marker - **/ - - var Marker = /*#__PURE__*/function () { - function Marker(tooltipContext) { - _classCallCheck(this, Marker); - - this.w = tooltipContext.w; - this.ttCtx = tooltipContext; - this.ctx = tooltipContext.ctx; - this.tooltipPosition = new Position(tooltipContext); - } - - _createClass(Marker, [{ - key: "drawDynamicPoints", - value: function drawDynamicPoints() { - var w = this.w; - var graphics = new Graphics(this.ctx); - var marker = new Markers(this.ctx); - var elsSeries = w.globals.dom.baseEl.querySelectorAll('.apexcharts-series'); - elsSeries = _toConsumableArray(elsSeries); - - if (w.config.chart.stacked) { - elsSeries.sort(function (a, b) { - return parseFloat(a.getAttribute('data:realIndex')) - parseFloat(b.getAttribute('data:realIndex')); - }); - } - - for (var i = 0; i < elsSeries.length; i++) { - var pointsMain = elsSeries[i].querySelector(".apexcharts-series-markers-wrap"); - - if (pointsMain !== null) { - // it can be null as we have tooltips in donut/bar charts - var point = void 0; - var PointClasses = "apexcharts-marker w".concat((Math.random() + 1).toString(36).substring(4)); - - if ((w.config.chart.type === 'line' || w.config.chart.type === 'area') && !w.globals.comboCharts && !w.config.tooltip.intersect) { - PointClasses += ' no-pointer-events'; - } - - var elPointOptions = marker.getMarkerConfig({ - cssClass: PointClasses, - seriesIndex: Number(pointsMain.getAttribute('data:realIndex')) // fixes apexcharts/apexcharts.js #1427 - - }); - point = graphics.drawMarker(0, 0, elPointOptions); - point.node.setAttribute('default-marker-size', 0); - var elPointsG = document.createElementNS(w.globals.SVGNS, 'g'); - elPointsG.classList.add('apexcharts-series-markers'); - elPointsG.appendChild(point.node); - pointsMain.appendChild(elPointsG); - } - } - } - }, { - key: "enlargeCurrentPoint", - value: function enlargeCurrentPoint(rel, point) { - var x = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - var y = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - var w = this.w; - - if (w.config.chart.type !== 'bubble') { - this.newPointSize(rel, point); - } - - var cx = point.getAttribute('cx'); - var cy = point.getAttribute('cy'); - - if (x !== null && y !== null) { - cx = x; - cy = y; - } - - this.tooltipPosition.moveXCrosshairs(cx); - - if (!this.fixedTooltip) { - if (w.config.chart.type === 'radar') { - var elGrid = this.ttCtx.getElGrid(); - var seriesBound = elGrid.getBoundingClientRect(); - cx = this.ttCtx.e.clientX - seriesBound.left; - } - - this.tooltipPosition.moveTooltip(cx, cy, w.config.markers.hover.size); - } - } - }, { - key: "enlargePoints", - value: function enlargePoints(j) { - var w = this.w; - var me = this; - var ttCtx = this.ttCtx; - var col = j; - var points = w.globals.dom.baseEl.querySelectorAll('.apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker'); - var newSize = w.config.markers.hover.size; - - for (var p = 0; p < points.length; p++) { - var rel = points[p].getAttribute('rel'); - var index = points[p].getAttribute('index'); - - if (newSize === undefined) { - newSize = w.globals.markers.size[index] + w.config.markers.hover.sizeOffset; - } - - if (col === parseInt(rel, 10)) { - me.newPointSize(col, points[p]); - var cx = points[p].getAttribute('cx'); - var cy = points[p].getAttribute('cy'); - me.tooltipPosition.moveXCrosshairs(cx); - - if (!ttCtx.fixedTooltip) { - me.tooltipPosition.moveTooltip(cx, cy, newSize); - } - } else { - me.oldPointSize(points[p]); - } - } - } - }, { - key: "newPointSize", - value: function newPointSize(rel, point) { - var w = this.w; - var newSize = w.config.markers.hover.size; - var elPoint = rel === 0 ? point.parentNode.firstChild : point.parentNode.lastChild; - - if (elPoint.getAttribute('default-marker-size') !== '0') { - var index = parseInt(elPoint.getAttribute('index'), 10); - - if (newSize === undefined) { - newSize = w.globals.markers.size[index] + w.config.markers.hover.sizeOffset; - } - - if (newSize < 0) newSize = 0; - elPoint.setAttribute('r', newSize); - } - } - }, { - key: "oldPointSize", - value: function oldPointSize(point) { - var size = parseFloat(point.getAttribute('default-marker-size')); - point.setAttribute('r', size); - } - }, { - key: "resetPointsSize", - value: function resetPointsSize() { - var w = this.w; - var points = w.globals.dom.baseEl.querySelectorAll('.apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker'); - - for (var p = 0; p < points.length; p++) { - var size = parseFloat(points[p].getAttribute('default-marker-size')); - - if (Utils$1.isNumber(size) && size >= 0) { - points[p].setAttribute('r', size); - } else { - points[p].setAttribute('r', 0); - } - } - } - }]); - - return Marker; - }(); - - /** - * ApexCharts Tooltip.Intersect Class. - * This file deals with functions related to intersecting tooltips - * (tooltips that appear when user hovers directly over a data-point whether) - * - * @module Tooltip.Intersect - **/ - - var Intersect = /*#__PURE__*/function () { - function Intersect(tooltipContext) { - _classCallCheck(this, Intersect); - - this.w = tooltipContext.w; - this.ttCtx = tooltipContext; - } // a helper function to get an element's attribute value - - - _createClass(Intersect, [{ - key: "getAttr", - value: function getAttr(e, attr) { - return parseFloat(e.target.getAttribute(attr)); - } // handle tooltip for heatmaps and treemaps - - }, { - key: "handleHeatTreeTooltip", - value: function handleHeatTreeTooltip(_ref) { - var e = _ref.e, - opt = _ref.opt, - x = _ref.x, - y = _ref.y, - type = _ref.type; - var ttCtx = this.ttCtx; - var w = this.w; - - if (e.target.classList.contains("apexcharts-".concat(type, "-rect"))) { - var i = this.getAttr(e, 'i'); - var j = this.getAttr(e, 'j'); - var cx = this.getAttr(e, 'cx'); - var cy = this.getAttr(e, 'cy'); - var width = this.getAttr(e, 'width'); - var height = this.getAttr(e, 'height'); - ttCtx.tooltipLabels.drawSeriesTexts({ - ttItems: opt.ttItems, - i: i, - j: j, - shared: false, - e: e - }); - w.globals.capturedSeriesIndex = i; - w.globals.capturedDataPointIndex = j; - x = cx + ttCtx.tooltipRect.ttWidth / 2 + width; - y = cy + ttCtx.tooltipRect.ttHeight / 2 - height / 2; - ttCtx.tooltipPosition.moveXCrosshairs(cx + width / 2); - - if (x > w.globals.gridWidth / 2) { - x = cx - ttCtx.tooltipRect.ttWidth / 2 + width; - } - - if (ttCtx.w.config.tooltip.followCursor) { - var seriesBound = w.globals.dom.elWrap.getBoundingClientRect(); - x = w.globals.clientX - seriesBound.left - (x > w.globals.gridWidth / 2 ? ttCtx.tooltipRect.ttWidth : 0); - y = w.globals.clientY - seriesBound.top - (y > w.globals.gridHeight / 2 ? ttCtx.tooltipRect.ttHeight : 0); - } - } - - return { - x: x, - y: y - }; - } - /** - * handle tooltips for line/area/scatter charts where tooltip.intersect is true - * when user hovers over the marker directly, this function is executed - */ - - }, { - key: "handleMarkerTooltip", - value: function handleMarkerTooltip(_ref2) { - var e = _ref2.e, - opt = _ref2.opt, - x = _ref2.x, - y = _ref2.y; - var w = this.w; - var ttCtx = this.ttCtx; - var i; - var j; - - if (e.target.classList.contains('apexcharts-marker')) { - var cx = parseInt(opt.paths.getAttribute('cx'), 10); - var cy = parseInt(opt.paths.getAttribute('cy'), 10); - var val = parseFloat(opt.paths.getAttribute('val')); - j = parseInt(opt.paths.getAttribute('rel'), 10); - i = parseInt(opt.paths.parentNode.parentNode.parentNode.getAttribute('rel'), 10) - 1; - - if (ttCtx.intersect) { - var el = Utils$1.findAncestor(opt.paths, 'apexcharts-series'); - - if (el) { - i = parseInt(el.getAttribute('data:realIndex'), 10); - } - } - - ttCtx.tooltipLabels.drawSeriesTexts({ - ttItems: opt.ttItems, - i: i, - j: j, - shared: ttCtx.showOnIntersect ? false : w.config.tooltip.shared, - e: e - }); - - if (e.type === 'mouseup') { - ttCtx.markerClick(e, i, j); - } - - w.globals.capturedSeriesIndex = i; - w.globals.capturedDataPointIndex = j; - x = cx; - y = cy + w.globals.translateY - ttCtx.tooltipRect.ttHeight * 1.4; - - if (ttCtx.w.config.tooltip.followCursor) { - var elGrid = ttCtx.getElGrid(); - var seriesBound = elGrid.getBoundingClientRect(); - y = ttCtx.e.clientY + w.globals.translateY - seriesBound.top; - } - - if (val < 0) { - y = cy; - } - - ttCtx.marker.enlargeCurrentPoint(j, opt.paths, x, y); - } - - return { - x: x, - y: y - }; - } - /** - * handle tooltips for bar/column charts - */ - - }, { - key: "handleBarTooltip", - value: function handleBarTooltip(_ref3) { - var e = _ref3.e, - opt = _ref3.opt; - var w = this.w; - var ttCtx = this.ttCtx; - var tooltipEl = ttCtx.getElTooltip(); - var bx = 0; - var x = 0; - var y = 0; - var i = 0; - var strokeWidth; - var barXY = this.getBarTooltipXY({ - e: e, - opt: opt - }); - i = barXY.i; - var barHeight = barXY.barHeight; - var j = barXY.j; - w.globals.capturedSeriesIndex = i; - w.globals.capturedDataPointIndex = j; - - if (w.globals.isBarHorizontal && ttCtx.tooltipUtil.hasBars() || !w.config.tooltip.shared) { - x = barXY.x; - y = barXY.y; - strokeWidth = Array.isArray(w.config.stroke.width) ? w.config.stroke.width[i] : w.config.stroke.width; - bx = x; - } else { - if (!w.globals.comboCharts && !w.config.tooltip.shared) { - // todo: re-check this condition as it's always 0 - bx = bx / 2; - } - } // y is NaN, make it touch the bottom of grid area - - - if (isNaN(y)) { - y = w.globals.svgHeight - ttCtx.tooltipRect.ttHeight; - } - - var seriesIndex = parseInt(opt.paths.parentNode.getAttribute('data:realIndex'), 10); - var isReversed = w.globals.isMultipleYAxis ? w.config.yaxis[seriesIndex] && w.config.yaxis[seriesIndex].reversed : w.config.yaxis[0].reversed; - - if (x + ttCtx.tooltipRect.ttWidth > w.globals.gridWidth && !isReversed) { - x = x - ttCtx.tooltipRect.ttWidth; - } else if (x < 0) { - x = 0; - } - - if (ttCtx.w.config.tooltip.followCursor) { - var elGrid = ttCtx.getElGrid(); - var seriesBound = elGrid.getBoundingClientRect(); - y = ttCtx.e.clientY - seriesBound.top; - } // if tooltip is still null, querySelector - - - if (ttCtx.tooltip === null) { - ttCtx.tooltip = w.globals.dom.baseEl.querySelector('.apexcharts-tooltip'); - } - - if (!w.config.tooltip.shared) { - if (w.globals.comboBarCount > 0) { - ttCtx.tooltipPosition.moveXCrosshairs(bx + strokeWidth / 2); - } else { - ttCtx.tooltipPosition.moveXCrosshairs(bx); - } - } // move tooltip here - - - if (!ttCtx.fixedTooltip && (!w.config.tooltip.shared || w.globals.isBarHorizontal && ttCtx.tooltipUtil.hasBars())) { - if (isReversed) { - x = x - ttCtx.tooltipRect.ttWidth; - - if (x < 0) { - x = 0; - } - } - - if (isReversed && !(w.globals.isBarHorizontal && ttCtx.tooltipUtil.hasBars())) { - y = y + barHeight - (w.globals.series[i][j] < 0 ? barHeight : 0) * 2; - } - - y = y + w.globals.translateY - ttCtx.tooltipRect.ttHeight / 2; - tooltipEl.style.left = x + w.globals.translateX + 'px'; - tooltipEl.style.top = y + 'px'; - } - } - }, { - key: "getBarTooltipXY", - value: function getBarTooltipXY(_ref4) { - var e = _ref4.e, - opt = _ref4.opt; - var w = this.w; - var j = null; - var ttCtx = this.ttCtx; - var i = 0; - var x = 0; - var y = 0; - var barWidth = 0; - var barHeight = 0; - var cl = e.target.classList; - - if (cl.contains('apexcharts-bar-area') || cl.contains('apexcharts-candlestick-area') || cl.contains('apexcharts-boxPlot-area') || cl.contains('apexcharts-rangebar-area')) { - var bar = e.target; - var barRect = bar.getBoundingClientRect(); - var seriesBound = opt.elGrid.getBoundingClientRect(); - var bh = barRect.height; - barHeight = barRect.height; - var bw = barRect.width; - var cx = parseInt(bar.getAttribute('cx'), 10); - var cy = parseInt(bar.getAttribute('cy'), 10); - barWidth = parseFloat(bar.getAttribute('barWidth')); - var clientX = e.type === 'touchmove' ? e.touches[0].clientX : e.clientX; - j = parseInt(bar.getAttribute('j'), 10); - i = parseInt(bar.parentNode.getAttribute('rel'), 10) - 1; - var y1 = bar.getAttribute('data-range-y1'); - var y2 = bar.getAttribute('data-range-y2'); - - if (w.globals.comboCharts) { - i = parseInt(bar.parentNode.getAttribute('data:realIndex'), 10); - } // if (w.config.tooltip.shared) { - // this check not needed at the moment - // const yDivisor = w.globals.gridHeight / (w.globals.series.length) - // const hoverY = ttCtx.clientY - ttCtx.seriesBound.top - // j = Math.ceil(hoverY / yDivisor) - // } - - - ttCtx.tooltipLabels.drawSeriesTexts({ - ttItems: opt.ttItems, - i: i, - j: j, - y1: y1 ? parseInt(y1, 10) : null, - y2: y2 ? parseInt(y2, 10) : null, - shared: ttCtx.showOnIntersect ? false : w.config.tooltip.shared, - e: e - }); - - if (w.config.tooltip.followCursor) { - if (w.globals.isBarHorizontal) { - x = clientX - seriesBound.left + 15; - y = cy - ttCtx.dataPointsDividedHeight + bh / 2 - ttCtx.tooltipRect.ttHeight / 2; - } else { - if (w.globals.isXNumeric) { - x = cx - bw / 2; - } else { - x = cx - ttCtx.dataPointsDividedWidth + bw / 2; - } - - y = e.clientY - seriesBound.top - ttCtx.tooltipRect.ttHeight / 2 - 15; - } - } else { - if (w.globals.isBarHorizontal) { - x = cx; - - if (x < ttCtx.xyRatios.baseLineInvertedY) { - x = cx - ttCtx.tooltipRect.ttWidth; - } - - y = cy - ttCtx.dataPointsDividedHeight + bh / 2 - ttCtx.tooltipRect.ttHeight / 2; - } else { - // if columns - if (w.globals.isXNumeric) { - x = cx - bw / 2; - } else { - x = cx - ttCtx.dataPointsDividedWidth + bw / 2; - } - - y = cy; // - ttCtx.tooltipRect.ttHeight / 2 + 10 - } - } - } - - return { - x: x, - y: y, - barHeight: barHeight, - barWidth: barWidth, - i: i, - j: j - }; - } - }]); - - return Intersect; - }(); - - /** - * ApexCharts Tooltip.AxesTooltip Class. - * This file deals with the x-axis and y-axis tooltips. - * - * @module Tooltip.AxesTooltip - **/ - var AxesTooltip = /*#__PURE__*/function () { - function AxesTooltip(tooltipContext) { - _classCallCheck(this, AxesTooltip); - - this.w = tooltipContext.w; - this.ttCtx = tooltipContext; - } - /** - * This method adds the secondary tooltip which appears below x axis - * @memberof Tooltip - **/ - - - _createClass(AxesTooltip, [{ - key: "drawXaxisTooltip", - value: function drawXaxisTooltip() { - var w = this.w; - var ttCtx = this.ttCtx; - var isBottom = w.config.xaxis.position === 'bottom'; - ttCtx.xaxisOffY = isBottom ? w.globals.gridHeight + 1 : -w.globals.xAxisHeight - w.config.xaxis.axisTicks.height + 3; - var tooltipCssClass = isBottom ? 'apexcharts-xaxistooltip apexcharts-xaxistooltip-bottom' : 'apexcharts-xaxistooltip apexcharts-xaxistooltip-top'; - var renderTo = w.globals.dom.elWrap; - - if (ttCtx.isXAxisTooltipEnabled) { - var xaxisTooltip = w.globals.dom.baseEl.querySelector('.apexcharts-xaxistooltip'); - - if (xaxisTooltip === null) { - ttCtx.xaxisTooltip = document.createElement('div'); - ttCtx.xaxisTooltip.setAttribute('class', tooltipCssClass + ' apexcharts-theme-' + w.config.tooltip.theme); - renderTo.appendChild(ttCtx.xaxisTooltip); - ttCtx.xaxisTooltipText = document.createElement('div'); - ttCtx.xaxisTooltipText.classList.add('apexcharts-xaxistooltip-text'); - ttCtx.xaxisTooltipText.style.fontFamily = w.config.xaxis.tooltip.style.fontFamily || w.config.chart.fontFamily; - ttCtx.xaxisTooltipText.style.fontSize = w.config.xaxis.tooltip.style.fontSize; - ttCtx.xaxisTooltip.appendChild(ttCtx.xaxisTooltipText); - } - } - } - /** - * This method adds the secondary tooltip which appears below x axis - * @memberof Tooltip - **/ - - }, { - key: "drawYaxisTooltip", - value: function drawYaxisTooltip() { - var w = this.w; - var ttCtx = this.ttCtx; - - var _loop = function _loop(i) { - var isRight = w.config.yaxis[i].opposite || w.config.yaxis[i].crosshairs.opposite; - ttCtx.yaxisOffX = isRight ? w.globals.gridWidth + 1 : 1; - var tooltipCssClass = isRight ? "apexcharts-yaxistooltip apexcharts-yaxistooltip-".concat(i, " apexcharts-yaxistooltip-right") : "apexcharts-yaxistooltip apexcharts-yaxistooltip-".concat(i, " apexcharts-yaxistooltip-left"); - w.globals.yAxisSameScaleIndices.map(function (samescales, ssi) { - samescales.map(function (s, si) { - if (si === i) { - tooltipCssClass += w.config.yaxis[si].show ? " " : " apexcharts-yaxistooltip-hidden"; - } - }); - }); - var renderTo = w.globals.dom.elWrap; - var yaxisTooltip = w.globals.dom.baseEl.querySelector(".apexcharts-yaxistooltip apexcharts-yaxistooltip-".concat(i)); - - if (yaxisTooltip === null) { - ttCtx.yaxisTooltip = document.createElement('div'); - ttCtx.yaxisTooltip.setAttribute('class', tooltipCssClass + ' apexcharts-theme-' + w.config.tooltip.theme); - renderTo.appendChild(ttCtx.yaxisTooltip); - if (i === 0) ttCtx.yaxisTooltipText = []; - ttCtx.yaxisTooltipText[i] = document.createElement('div'); - ttCtx.yaxisTooltipText[i].classList.add('apexcharts-yaxistooltip-text'); - ttCtx.yaxisTooltip.appendChild(ttCtx.yaxisTooltipText[i]); - } - }; - - for (var i = 0; i < w.config.yaxis.length; i++) { - _loop(i); - } - } - /** - * @memberof Tooltip - **/ - - }, { - key: "setXCrosshairWidth", - value: function setXCrosshairWidth() { - var w = this.w; - var ttCtx = this.ttCtx; // set xcrosshairs width - - var xcrosshairs = ttCtx.getElXCrosshairs(); - ttCtx.xcrosshairsWidth = parseInt(w.config.xaxis.crosshairs.width, 10); - - if (!w.globals.comboCharts) { - if (w.config.xaxis.crosshairs.width === 'tickWidth') { - var count = w.globals.labels.length; - ttCtx.xcrosshairsWidth = w.globals.gridWidth / count; - } else if (w.config.xaxis.crosshairs.width === 'barWidth') { - var bar = w.globals.dom.baseEl.querySelector('.apexcharts-bar-area'); - - if (bar !== null) { - var barWidth = parseFloat(bar.getAttribute('barWidth')); - ttCtx.xcrosshairsWidth = barWidth; - } else { - ttCtx.xcrosshairsWidth = 1; - } - } - } else { - var _bar = w.globals.dom.baseEl.querySelector('.apexcharts-bar-area'); - - if (_bar !== null && w.config.xaxis.crosshairs.width === 'barWidth') { - var _barWidth = parseFloat(_bar.getAttribute('barWidth')); - - ttCtx.xcrosshairsWidth = _barWidth; - } else { - if (w.config.xaxis.crosshairs.width === 'tickWidth') { - var _count = w.globals.labels.length; - ttCtx.xcrosshairsWidth = w.globals.gridWidth / _count; - } - } - } - - if (w.globals.isBarHorizontal) { - ttCtx.xcrosshairsWidth = 0; - } - - if (xcrosshairs !== null && ttCtx.xcrosshairsWidth > 0) { - xcrosshairs.setAttribute('width', ttCtx.xcrosshairsWidth); - } - } - }, { - key: "handleYCrosshair", - value: function handleYCrosshair() { - var w = this.w; - var ttCtx = this.ttCtx; // set ycrosshairs height - - ttCtx.ycrosshairs = w.globals.dom.baseEl.querySelector('.apexcharts-ycrosshairs'); - ttCtx.ycrosshairsHidden = w.globals.dom.baseEl.querySelector('.apexcharts-ycrosshairs-hidden'); - } - }, { - key: "drawYaxisTooltipText", - value: function drawYaxisTooltipText(index, clientY, xyRatios) { - var ttCtx = this.ttCtx; - var w = this.w; - var lbFormatter = w.globals.yLabelFormatters[index]; - - if (ttCtx.yaxisTooltips[index]) { - var elGrid = ttCtx.getElGrid(); - var seriesBound = elGrid.getBoundingClientRect(); - var hoverY = (clientY - seriesBound.top) * xyRatios.yRatio[index]; - var height = w.globals.maxYArr[index] - w.globals.minYArr[index]; - var val = w.globals.minYArr[index] + (height - hoverY); - ttCtx.tooltipPosition.moveYCrosshairs(clientY - seriesBound.top); - ttCtx.yaxisTooltipText[index].innerHTML = lbFormatter(val); - ttCtx.tooltipPosition.moveYAxisTooltip(index); - } - } - }]); - - return AxesTooltip; - }(); - - /** - * ApexCharts Core Tooltip Class to handle the tooltip generation. - * - * @module Tooltip - **/ - - var Tooltip = /*#__PURE__*/function () { - function Tooltip(ctx) { - _classCallCheck(this, Tooltip); - - this.ctx = ctx; - this.w = ctx.w; - var w = this.w; - this.tConfig = w.config.tooltip; - this.tooltipUtil = new Utils(this); - this.tooltipLabels = new Labels(this); - this.tooltipPosition = new Position(this); - this.marker = new Marker(this); - this.intersect = new Intersect(this); - this.axesTooltip = new AxesTooltip(this); - this.showOnIntersect = this.tConfig.intersect; - this.showTooltipTitle = this.tConfig.x.show; - this.fixedTooltip = this.tConfig.fixed.enabled; - this.xaxisTooltip = null; - this.yaxisTTEls = null; - this.isBarShared = !w.globals.isBarHorizontal && this.tConfig.shared; - this.lastHoverTime = Date.now(); - } - - _createClass(Tooltip, [{ - key: "getElTooltip", - value: function getElTooltip(ctx) { - if (!ctx) ctx = this; - if (!ctx.w.globals.dom.baseEl) return null; - return ctx.w.globals.dom.baseEl.querySelector('.apexcharts-tooltip'); - } - }, { - key: "getElXCrosshairs", - value: function getElXCrosshairs() { - return this.w.globals.dom.baseEl.querySelector('.apexcharts-xcrosshairs'); - } - }, { - key: "getElGrid", - value: function getElGrid() { - return this.w.globals.dom.baseEl.querySelector('.apexcharts-grid'); - } - }, { - key: "drawTooltip", - value: function drawTooltip(xyRatios) { - var w = this.w; - this.xyRatios = xyRatios; - this.isXAxisTooltipEnabled = w.config.xaxis.tooltip.enabled && w.globals.axisCharts; - this.yaxisTooltips = w.config.yaxis.map(function (y, i) { - return y.show && y.tooltip.enabled && w.globals.axisCharts ? true : false; - }); - this.allTooltipSeriesGroups = []; - - if (!w.globals.axisCharts) { - this.showTooltipTitle = false; - } - - var tooltipEl = document.createElement('div'); - tooltipEl.classList.add('apexcharts-tooltip'); - - if (w.config.tooltip.cssClass) { - tooltipEl.classList.add(w.config.tooltip.cssClass); - } - - tooltipEl.classList.add("apexcharts-theme-".concat(this.tConfig.theme)); - w.globals.dom.elWrap.appendChild(tooltipEl); - - if (w.globals.axisCharts) { - this.axesTooltip.drawXaxisTooltip(); - this.axesTooltip.drawYaxisTooltip(); - this.axesTooltip.setXCrosshairWidth(); - this.axesTooltip.handleYCrosshair(); - var xAxis = new XAxis(this.ctx); - this.xAxisTicksPositions = xAxis.getXAxisTicksPositions(); - } // we forcefully set intersect true for these conditions - - - if ((w.globals.comboCharts || this.tConfig.intersect || w.config.chart.type === 'rangeBar') && !this.tConfig.shared) { - this.showOnIntersect = true; - } - - if (w.config.markers.size === 0 || w.globals.markers.largestSize === 0) { - // when user don't want to show points all the time, but only on when hovering on series - this.marker.drawDynamicPoints(this); - } // no visible series, exit - - - if (w.globals.collapsedSeries.length === w.globals.series.length) return; - this.dataPointsDividedHeight = w.globals.gridHeight / w.globals.dataPoints; - this.dataPointsDividedWidth = w.globals.gridWidth / w.globals.dataPoints; - - if (this.showTooltipTitle) { - this.tooltipTitle = document.createElement('div'); - this.tooltipTitle.classList.add('apexcharts-tooltip-title'); - this.tooltipTitle.style.fontFamily = this.tConfig.style.fontFamily || w.config.chart.fontFamily; - this.tooltipTitle.style.fontSize = this.tConfig.style.fontSize; - tooltipEl.appendChild(this.tooltipTitle); - } - - var ttItemsCnt = w.globals.series.length; // whether shared or not, default is shared - - if ((w.globals.xyCharts || w.globals.comboCharts) && this.tConfig.shared) { - if (!this.showOnIntersect) { - ttItemsCnt = w.globals.series.length; - } else { - ttItemsCnt = 1; - } - } - - this.legendLabels = w.globals.dom.baseEl.querySelectorAll('.apexcharts-legend-text'); - this.ttItems = this.createTTElements(ttItemsCnt); - this.addSVGEvents(); - } - }, { - key: "createTTElements", - value: function createTTElements(ttItemsCnt) { - var _this = this; - - var w = this.w; - var ttItems = []; - var tooltipEl = this.getElTooltip(); - - var _loop = function _loop(i) { - var gTxt = document.createElement('div'); - gTxt.classList.add('apexcharts-tooltip-series-group'); - gTxt.style.order = w.config.tooltip.inverseOrder ? ttItemsCnt - i : i + 1; - - if (_this.tConfig.shared && _this.tConfig.enabledOnSeries && Array.isArray(_this.tConfig.enabledOnSeries)) { - if (_this.tConfig.enabledOnSeries.indexOf(i) < 0) { - gTxt.classList.add('apexcharts-tooltip-series-group-hidden'); - } - } - - var point = document.createElement('span'); - point.classList.add('apexcharts-tooltip-marker'); - point.style.backgroundColor = w.globals.colors[i]; - gTxt.appendChild(point); - var gYZ = document.createElement('div'); - gYZ.classList.add('apexcharts-tooltip-text'); - gYZ.style.fontFamily = _this.tConfig.style.fontFamily || w.config.chart.fontFamily; - gYZ.style.fontSize = _this.tConfig.style.fontSize; - ['y', 'goals', 'z'].forEach(function (g) { - var gValText = document.createElement('div'); - gValText.classList.add("apexcharts-tooltip-".concat(g, "-group")); - var txtLabel = document.createElement('span'); - txtLabel.classList.add("apexcharts-tooltip-text-".concat(g, "-label")); - gValText.appendChild(txtLabel); - var txtValue = document.createElement('span'); - txtValue.classList.add("apexcharts-tooltip-text-".concat(g, "-value")); - gValText.appendChild(txtValue); - gYZ.appendChild(gValText); - }); - gTxt.appendChild(gYZ); - tooltipEl.appendChild(gTxt); - ttItems.push(gTxt); - }; - - for (var i = 0; i < ttItemsCnt; i++) { - _loop(i); - } - - return ttItems; - } - }, { - key: "addSVGEvents", - value: function addSVGEvents() { - var w = this.w; - var type = w.config.chart.type; - var tooltipEl = this.getElTooltip(); - var commonBar = !!(type === 'bar' || type === 'candlestick' || type === 'boxPlot' || type === 'rangeBar'); - var chartWithmarkers = type === 'area' || type === 'line' || type === 'scatter' || type === 'bubble' || type === 'radar'; - var hoverArea = w.globals.dom.Paper.node; - var elGrid = this.getElGrid(); - - if (elGrid) { - this.seriesBound = elGrid.getBoundingClientRect(); - } - - var tooltipY = []; - var tooltipX = []; - var seriesHoverParams = { - hoverArea: hoverArea, - elGrid: elGrid, - tooltipEl: tooltipEl, - tooltipY: tooltipY, - tooltipX: tooltipX, - ttItems: this.ttItems - }; - var points; - - if (w.globals.axisCharts) { - if (chartWithmarkers) { - points = w.globals.dom.baseEl.querySelectorAll(".apexcharts-series[data\\:longestSeries='true'] .apexcharts-marker"); - } else if (commonBar) { - points = w.globals.dom.baseEl.querySelectorAll('.apexcharts-series .apexcharts-bar-area, .apexcharts-series .apexcharts-candlestick-area, .apexcharts-series .apexcharts-boxPlot-area, .apexcharts-series .apexcharts-rangebar-area'); - } else if (type === 'heatmap' || type === 'treemap') { - points = w.globals.dom.baseEl.querySelectorAll('.apexcharts-series .apexcharts-heatmap, .apexcharts-series .apexcharts-treemap'); - } - - if (points && points.length) { - for (var p = 0; p < points.length; p++) { - tooltipY.push(points[p].getAttribute('cy')); - tooltipX.push(points[p].getAttribute('cx')); - } - } - } - - var validSharedChartTypes = w.globals.xyCharts && !this.showOnIntersect || w.globals.comboCharts && !this.showOnIntersect || commonBar && this.tooltipUtil.hasBars() && this.tConfig.shared; - - if (validSharedChartTypes) { - this.addPathsEventListeners([hoverArea], seriesHoverParams); - } else if (commonBar && !w.globals.comboCharts || chartWithmarkers && this.showOnIntersect) { - this.addDatapointEventsListeners(seriesHoverParams); - } else if (!w.globals.axisCharts || type === 'heatmap' || type === 'treemap') { - var seriesAll = w.globals.dom.baseEl.querySelectorAll('.apexcharts-series'); - this.addPathsEventListeners(seriesAll, seriesHoverParams); - } - - if (this.showOnIntersect) { - var lineAreaPoints = w.globals.dom.baseEl.querySelectorAll('.apexcharts-line-series .apexcharts-marker, .apexcharts-area-series .apexcharts-marker'); - - if (lineAreaPoints.length > 0) { - // if we find any lineSeries, addEventListeners for them - this.addPathsEventListeners(lineAreaPoints, seriesHoverParams); - } // combo charts may have bars, so add event listeners here too - - - if (this.tooltipUtil.hasBars() && !this.tConfig.shared) { - this.addDatapointEventsListeners(seriesHoverParams); - } - } - } - }, { - key: "drawFixedTooltipRect", - value: function drawFixedTooltipRect() { - var w = this.w; - var tooltipEl = this.getElTooltip(); - var tooltipRect = tooltipEl.getBoundingClientRect(); - var ttWidth = tooltipRect.width + 10; - var ttHeight = tooltipRect.height + 10; - var x = this.tConfig.fixed.offsetX; - var y = this.tConfig.fixed.offsetY; - var fixed = this.tConfig.fixed.position.toLowerCase(); - - if (fixed.indexOf('right') > -1) { - x = x + w.globals.svgWidth - ttWidth + 10; - } - - if (fixed.indexOf('bottom') > -1) { - y = y + w.globals.svgHeight - ttHeight - 10; - } - - tooltipEl.style.left = x + 'px'; - tooltipEl.style.top = y + 'px'; - return { - x: x, - y: y, - ttWidth: ttWidth, - ttHeight: ttHeight - }; - } - }, { - key: "addDatapointEventsListeners", - value: function addDatapointEventsListeners(seriesHoverParams) { - var w = this.w; - var points = w.globals.dom.baseEl.querySelectorAll('.apexcharts-series-markers .apexcharts-marker, .apexcharts-bar-area, .apexcharts-candlestick-area, .apexcharts-boxPlot-area, .apexcharts-rangebar-area'); - this.addPathsEventListeners(points, seriesHoverParams); - } - }, { - key: "addPathsEventListeners", - value: function addPathsEventListeners(paths, opts) { - var self = this; - - var _loop2 = function _loop2(p) { - var extendedOpts = { - paths: paths[p], - tooltipEl: opts.tooltipEl, - tooltipY: opts.tooltipY, - tooltipX: opts.tooltipX, - elGrid: opts.elGrid, - hoverArea: opts.hoverArea, - ttItems: opts.ttItems - }; - var events = ['mousemove', 'mouseup', 'touchmove', 'mouseout', 'touchend']; - events.map(function (ev) { - return paths[p].addEventListener(ev, self.onSeriesHover.bind(self, extendedOpts), { - capture: false, - passive: true - }); - }); - }; - - for (var p = 0; p < paths.length; p++) { - _loop2(p); - } - } - /* - ** Check to see if the tooltips should be updated based on a mouse / touch event - */ - - }, { - key: "onSeriesHover", - value: function onSeriesHover(opt, e) { - var _this2 = this; - - // If a user is moving their mouse quickly, don't bother updating the tooltip every single frame - var targetDelay = 100; - var timeSinceLastUpdate = Date.now() - this.lastHoverTime; - - if (timeSinceLastUpdate >= targetDelay) { - // The tooltip was last updated over 100ms ago - redraw it even if the user is still moving their - // mouse so they get some feedback that their moves are being registered - this.seriesHover(opt, e); - } else { - // The tooltip was last updated less than 100ms ago - // Cancel any other delayed draw, so we don't show stale data - clearTimeout(this.seriesHoverTimeout); // Schedule the next draw so that it happens about 100ms after the last update - - this.seriesHoverTimeout = setTimeout(function () { - _this2.seriesHover(opt, e); - }, targetDelay - timeSinceLastUpdate); - } - } - /* - ** The actual series hover function - */ - - }, { - key: "seriesHover", - value: function seriesHover(opt, e) { - var _this3 = this; - - this.lastHoverTime = Date.now(); - var chartGroups = []; - var w = this.w; // if user has more than one charts in group, we need to sync - - if (w.config.chart.group) { - chartGroups = this.ctx.getGroupedCharts(); - } - - if (w.globals.axisCharts && (w.globals.minX === -Infinity && w.globals.maxX === Infinity || w.globals.dataPoints === 0)) { - return; - } - - if (chartGroups.length) { - chartGroups.forEach(function (ch) { - var tooltipEl = _this3.getElTooltip(ch); - - var newOpts = { - paths: opt.paths, - tooltipEl: tooltipEl, - tooltipY: opt.tooltipY, - tooltipX: opt.tooltipX, - elGrid: opt.elGrid, - hoverArea: opt.hoverArea, - ttItems: ch.w.globals.tooltip.ttItems - }; // all the charts should have the same minX and maxX (same xaxis) for multiple tooltips to work correctly - - if (ch.w.globals.minX === _this3.w.globals.minX && ch.w.globals.maxX === _this3.w.globals.maxX) { - ch.w.globals.tooltip.seriesHoverByContext({ - chartCtx: ch, - ttCtx: ch.w.globals.tooltip, - opt: newOpts, - e: e - }); - } - }); - } else { - this.seriesHoverByContext({ - chartCtx: this.ctx, - ttCtx: this.w.globals.tooltip, - opt: opt, - e: e - }); - } - } - }, { - key: "seriesHoverByContext", - value: function seriesHoverByContext(_ref) { - var chartCtx = _ref.chartCtx, - ttCtx = _ref.ttCtx, - opt = _ref.opt, - e = _ref.e; - var w = chartCtx.w; - var tooltipEl = this.getElTooltip(); - if (!tooltipEl) return; // tooltipRect is calculated on every mousemove, because the text is dynamic - - ttCtx.tooltipRect = { - x: 0, - y: 0, - ttWidth: tooltipEl.getBoundingClientRect().width, - ttHeight: tooltipEl.getBoundingClientRect().height - }; - ttCtx.e = e; // highlight the current hovered bars - - if (ttCtx.tooltipUtil.hasBars() && !w.globals.comboCharts && !ttCtx.isBarShared) { - if (this.tConfig.onDatasetHover.highlightDataSeries) { - var series = new Series(chartCtx); - series.toggleSeriesOnHover(e, e.target.parentNode); - } - } - - if (ttCtx.fixedTooltip) { - ttCtx.drawFixedTooltipRect(); - } - - if (w.globals.axisCharts) { - ttCtx.axisChartsTooltips({ - e: e, - opt: opt, - tooltipRect: ttCtx.tooltipRect - }); - } else { - // non-plot charts i.e pie/donut/circle - ttCtx.nonAxisChartsTooltips({ - e: e, - opt: opt, - tooltipRect: ttCtx.tooltipRect - }); - } - } // tooltip handling for line/area/bar/columns/scatter - - }, { - key: "axisChartsTooltips", - value: function axisChartsTooltips(_ref2) { - var e = _ref2.e, - opt = _ref2.opt; - var w = this.w; - var x, y; - var seriesBound = opt.elGrid.getBoundingClientRect(); - var clientX = e.type === 'touchmove' ? e.touches[0].clientX : e.clientX; - var clientY = e.type === 'touchmove' ? e.touches[0].clientY : e.clientY; - this.clientY = clientY; - this.clientX = clientX; - w.globals.capturedSeriesIndex = -1; - w.globals.capturedDataPointIndex = -1; - - if (clientY < seriesBound.top || clientY > seriesBound.top + seriesBound.height) { - this.handleMouseOut(opt); - return; - } - - if (Array.isArray(this.tConfig.enabledOnSeries) && !w.config.tooltip.shared) { - var index = parseInt(opt.paths.getAttribute('index'), 10); - - if (this.tConfig.enabledOnSeries.indexOf(index) < 0) { - this.handleMouseOut(opt); - return; - } - } - - var tooltipEl = this.getElTooltip(); - var xcrosshairs = this.getElXCrosshairs(); - var isStickyTooltip = w.globals.xyCharts || w.config.chart.type === 'bar' && !w.globals.isBarHorizontal && this.tooltipUtil.hasBars() && this.tConfig.shared || w.globals.comboCharts && this.tooltipUtil.hasBars(); - - if (e.type === 'mousemove' || e.type === 'touchmove' || e.type === 'mouseup') { - // there is no series to hover over - if (w.globals.collapsedSeries.length + w.globals.ancillaryCollapsedSeries.length === w.globals.series.length) { - return; - } - - if (xcrosshairs !== null) { - xcrosshairs.classList.add('apexcharts-active'); - } - - var hasYAxisTooltip = this.yaxisTooltips.filter(function (b) { - return b === true; - }); - - if (this.ycrosshairs !== null && hasYAxisTooltip.length) { - this.ycrosshairs.classList.add('apexcharts-active'); - } - - if (isStickyTooltip && !this.showOnIntersect) { - this.handleStickyTooltip(e, clientX, clientY, opt); - } else { - if (w.config.chart.type === 'heatmap' || w.config.chart.type === 'treemap') { - var markerXY = this.intersect.handleHeatTreeTooltip({ - e: e, - opt: opt, - x: x, - y: y, - type: w.config.chart.type - }); - x = markerXY.x; - y = markerXY.y; - tooltipEl.style.left = x + 'px'; - tooltipEl.style.top = y + 'px'; - } else { - if (this.tooltipUtil.hasBars()) { - this.intersect.handleBarTooltip({ - e: e, - opt: opt - }); - } - - if (this.tooltipUtil.hasMarkers()) { - // intersect - line/area/scatter/bubble - this.intersect.handleMarkerTooltip({ - e: e, - opt: opt, - x: x, - y: y - }); - } - } - } - - if (this.yaxisTooltips.length) { - for (var yt = 0; yt < w.config.yaxis.length; yt++) { - this.axesTooltip.drawYaxisTooltipText(yt, clientY, this.xyRatios); - } - } - - opt.tooltipEl.classList.add('apexcharts-active'); - } else if (e.type === 'mouseout' || e.type === 'touchend') { - this.handleMouseOut(opt); - } - } // tooltip handling for pie/donuts - - }, { - key: "nonAxisChartsTooltips", - value: function nonAxisChartsTooltips(_ref3) { - var e = _ref3.e, - opt = _ref3.opt, - tooltipRect = _ref3.tooltipRect; - var w = this.w; - var rel = opt.paths.getAttribute('rel'); - var tooltipEl = this.getElTooltip(); - var seriesBound = w.globals.dom.elWrap.getBoundingClientRect(); - - if (e.type === 'mousemove' || e.type === 'touchmove') { - tooltipEl.classList.add('apexcharts-active'); - this.tooltipLabels.drawSeriesTexts({ - ttItems: opt.ttItems, - i: parseInt(rel, 10) - 1, - shared: false - }); - var x = w.globals.clientX - seriesBound.left - tooltipRect.ttWidth / 2; - var y = w.globals.clientY - seriesBound.top - tooltipRect.ttHeight - 10; - tooltipEl.style.left = x + 'px'; - tooltipEl.style.top = y + 'px'; - - if (w.config.legend.tooltipHoverFormatter) { - var legendFormatter = w.config.legend.tooltipHoverFormatter; - var i = rel - 1; - var legendName = this.legendLabels[i].getAttribute('data:default-text'); - var text = legendFormatter(legendName, { - seriesIndex: i, - dataPointIndex: i, - w: w - }); - this.legendLabels[i].innerHTML = text; - } - } else if (e.type === 'mouseout' || e.type === 'touchend') { - tooltipEl.classList.remove('apexcharts-active'); - - if (w.config.legend.tooltipHoverFormatter) { - this.legendLabels.forEach(function (l) { - var defaultText = l.getAttribute('data:default-text'); - l.innerHTML = decodeURIComponent(defaultText); - }); - } - } - } - }, { - key: "handleStickyTooltip", - value: function handleStickyTooltip(e, clientX, clientY, opt) { - var w = this.w; - var capj = this.tooltipUtil.getNearestValues({ - context: this, - hoverArea: opt.hoverArea, - elGrid: opt.elGrid, - clientX: clientX, - clientY: clientY - }); - var j = capj.j; - var capturedSeries = capj.capturedSeries; - if (w.globals.collapsedSeriesIndices.includes(capturedSeries)) capturedSeries = null; - var bounds = opt.elGrid.getBoundingClientRect(); - - if (capj.hoverX < 0 || capj.hoverX > bounds.width) { - this.handleMouseOut(opt); - return; - } - - if (capturedSeries !== null) { - this.handleStickyCapturedSeries(e, capturedSeries, opt, j); - } else { - // couldn't capture any series. check if shared X is same, - // if yes, draw a grouped tooltip - if (this.tooltipUtil.isXoverlap(j) || w.globals.isBarHorizontal) { - var firstVisibleSeries = w.globals.series.findIndex(function (s, i) { - return !w.globals.collapsedSeriesIndices.includes(i); - }); - this.create(e, this, firstVisibleSeries, j, opt.ttItems); - } - } - } - }, { - key: "handleStickyCapturedSeries", - value: function handleStickyCapturedSeries(e, capturedSeries, opt, j) { - var w = this.w; - - if (!this.tConfig.shared) { - var ignoreNull = w.globals.series[capturedSeries][j] === null; - - if (ignoreNull) { - this.handleMouseOut(opt); - return; - } - } - - if (typeof w.globals.series[capturedSeries][j] !== 'undefined') { - if (this.tConfig.shared && this.tooltipUtil.isXoverlap(j) && this.tooltipUtil.isInitialSeriesSameLen()) { - this.create(e, this, capturedSeries, j, opt.ttItems); - } else { - this.create(e, this, capturedSeries, j, opt.ttItems, false); - } - } else { - if (this.tooltipUtil.isXoverlap(j)) { - var firstVisibleSeries = w.globals.series.findIndex(function (s, i) { - return !w.globals.collapsedSeriesIndices.includes(i); - }); - this.create(e, this, firstVisibleSeries, j, opt.ttItems); - } - } - } - }, { - key: "deactivateHoverFilter", - value: function deactivateHoverFilter() { - var w = this.w; - var graphics = new Graphics(this.ctx); - var allPaths = w.globals.dom.Paper.select(".apexcharts-bar-area"); - - for (var b = 0; b < allPaths.length; b++) { - graphics.pathMouseLeave(allPaths[b]); - } - } - }, { - key: "handleMouseOut", - value: function handleMouseOut(opt) { - var w = this.w; - var xcrosshairs = this.getElXCrosshairs(); - opt.tooltipEl.classList.remove('apexcharts-active'); - this.deactivateHoverFilter(); - - if (w.config.chart.type !== 'bubble') { - this.marker.resetPointsSize(); - } - - if (xcrosshairs !== null) { - xcrosshairs.classList.remove('apexcharts-active'); - } - - if (this.ycrosshairs !== null) { - this.ycrosshairs.classList.remove('apexcharts-active'); - } - - if (this.isXAxisTooltipEnabled) { - this.xaxisTooltip.classList.remove('apexcharts-active'); - } - - if (this.yaxisTooltips.length) { - if (this.yaxisTTEls === null) { - this.yaxisTTEls = w.globals.dom.baseEl.querySelectorAll('.apexcharts-yaxistooltip'); - } - - for (var i = 0; i < this.yaxisTTEls.length; i++) { - this.yaxisTTEls[i].classList.remove('apexcharts-active'); - } - } - - if (w.config.legend.tooltipHoverFormatter) { - this.legendLabels.forEach(function (l) { - var defaultText = l.getAttribute('data:default-text'); - l.innerHTML = decodeURIComponent(defaultText); - }); - } - } - }, { - key: "markerClick", - value: function markerClick(e, seriesIndex, dataPointIndex) { - var w = this.w; - - if (typeof w.config.chart.events.markerClick === 'function') { - w.config.chart.events.markerClick(e, this.ctx, { - seriesIndex: seriesIndex, - dataPointIndex: dataPointIndex, - w: w - }); - } - - this.ctx.events.fireEvent('markerClick', [e, this.ctx, { - seriesIndex: seriesIndex, - dataPointIndex: dataPointIndex, - w: w - }]); - } - }, { - key: "create", - value: function create(e, context, capturedSeries, j, ttItems) { - var _w$globals$seriesRang, _w$globals$seriesRang2, _w$globals$seriesRang3, _w$globals$seriesRang4, _w$globals$seriesRang5, _w$globals$seriesRang6, _w$globals$seriesRang7, _w$globals$seriesRang8, _w$globals$seriesRang9, _w$globals$seriesRang10, _w$globals$seriesRang11, _w$globals$seriesRang12, _w$globals$seriesRang13, _w$globals$seriesRang14, _w$globals$seriesRang15, _w$globals$seriesRang16; - - var shared = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : null; - var w = this.w; - var ttCtx = context; - - if (e.type === 'mouseup') { - this.markerClick(e, capturedSeries, j); - } - - if (shared === null) shared = this.tConfig.shared; - var hasMarkers = this.tooltipUtil.hasMarkers(capturedSeries); - var bars = this.tooltipUtil.getElBars(); - - if (w.config.legend.tooltipHoverFormatter) { - var legendFormatter = w.config.legend.tooltipHoverFormatter; - var els = Array.from(this.legendLabels); // reset all legend values first - - els.forEach(function (l) { - var legendName = l.getAttribute('data:default-text'); - l.innerHTML = decodeURIComponent(legendName); - }); // for irregular time series - - for (var i = 0; i < els.length; i++) { - var l = els[i]; - var lsIndex = parseInt(l.getAttribute('i'), 10); - var legendName = decodeURIComponent(l.getAttribute('data:default-text')); - var text = legendFormatter(legendName, { - seriesIndex: shared ? lsIndex : capturedSeries, - dataPointIndex: j, - w: w - }); - - if (!shared) { - l.innerHTML = lsIndex === capturedSeries ? text : legendName; - - if (capturedSeries === lsIndex) { - break; - } - } else { - l.innerHTML = w.globals.collapsedSeriesIndices.indexOf(lsIndex) < 0 ? text : legendName; - } - } - } - - var commonSeriesTextsParams = _objectSpread2(_objectSpread2({ - ttItems: ttItems, - i: capturedSeries, - j: j - }, typeof ((_w$globals$seriesRang = w.globals.seriesRange) === null || _w$globals$seriesRang === void 0 ? void 0 : (_w$globals$seriesRang2 = _w$globals$seriesRang[capturedSeries]) === null || _w$globals$seriesRang2 === void 0 ? void 0 : (_w$globals$seriesRang3 = _w$globals$seriesRang2[j]) === null || _w$globals$seriesRang3 === void 0 ? void 0 : (_w$globals$seriesRang4 = _w$globals$seriesRang3.y[0]) === null || _w$globals$seriesRang4 === void 0 ? void 0 : _w$globals$seriesRang4.y1) !== 'undefined' && { - y1: (_w$globals$seriesRang5 = w.globals.seriesRange) === null || _w$globals$seriesRang5 === void 0 ? void 0 : (_w$globals$seriesRang6 = _w$globals$seriesRang5[capturedSeries]) === null || _w$globals$seriesRang6 === void 0 ? void 0 : (_w$globals$seriesRang7 = _w$globals$seriesRang6[j]) === null || _w$globals$seriesRang7 === void 0 ? void 0 : (_w$globals$seriesRang8 = _w$globals$seriesRang7.y[0]) === null || _w$globals$seriesRang8 === void 0 ? void 0 : _w$globals$seriesRang8.y1 - }), typeof ((_w$globals$seriesRang9 = w.globals.seriesRange) === null || _w$globals$seriesRang9 === void 0 ? void 0 : (_w$globals$seriesRang10 = _w$globals$seriesRang9[capturedSeries]) === null || _w$globals$seriesRang10 === void 0 ? void 0 : (_w$globals$seriesRang11 = _w$globals$seriesRang10[j]) === null || _w$globals$seriesRang11 === void 0 ? void 0 : (_w$globals$seriesRang12 = _w$globals$seriesRang11.y[0]) === null || _w$globals$seriesRang12 === void 0 ? void 0 : _w$globals$seriesRang12.y2) !== 'undefined' && { - y2: (_w$globals$seriesRang13 = w.globals.seriesRange) === null || _w$globals$seriesRang13 === void 0 ? void 0 : (_w$globals$seriesRang14 = _w$globals$seriesRang13[capturedSeries]) === null || _w$globals$seriesRang14 === void 0 ? void 0 : (_w$globals$seriesRang15 = _w$globals$seriesRang14[j]) === null || _w$globals$seriesRang15 === void 0 ? void 0 : (_w$globals$seriesRang16 = _w$globals$seriesRang15.y[0]) === null || _w$globals$seriesRang16 === void 0 ? void 0 : _w$globals$seriesRang16.y2 - }); - - if (shared) { - ttCtx.tooltipLabels.drawSeriesTexts(_objectSpread2(_objectSpread2({}, commonSeriesTextsParams), {}, { - shared: this.showOnIntersect ? false : this.tConfig.shared - })); - - if (hasMarkers) { - if (w.globals.markers.largestSize > 0) { - ttCtx.marker.enlargePoints(j); - } else { - ttCtx.tooltipPosition.moveDynamicPointsOnHover(j); - } - } else if (this.tooltipUtil.hasBars()) { - this.barSeriesHeight = this.tooltipUtil.getBarsHeight(bars); - - if (this.barSeriesHeight > 0) { - // hover state, activate snap filter - var graphics = new Graphics(this.ctx); - var paths = w.globals.dom.Paper.select(".apexcharts-bar-area[j='".concat(j, "']")); // de-activate first - - this.deactivateHoverFilter(); - this.tooltipPosition.moveStickyTooltipOverBars(j, capturedSeries); - - for (var b = 0; b < paths.length; b++) { - graphics.pathMouseEnter(paths[b]); - } - } - } - } else { - ttCtx.tooltipLabels.drawSeriesTexts(_objectSpread2({ - shared: false - }, commonSeriesTextsParams)); - - if (this.tooltipUtil.hasBars()) { - ttCtx.tooltipPosition.moveStickyTooltipOverBars(j, capturedSeries); - } - - if (hasMarkers) { - ttCtx.tooltipPosition.moveMarkers(capturedSeries, j); - } - } - } - }]); - - return Tooltip; - }(); - - var BarDataLabels = /*#__PURE__*/function () { - function BarDataLabels(barCtx) { - _classCallCheck(this, BarDataLabels); - - this.w = barCtx.w; - this.barCtx = barCtx; - this.totalFormatter = this.w.config.plotOptions.bar.dataLabels.total.formatter; - - if (!this.totalFormatter) { - this.totalFormatter = this.w.config.dataLabels.formatter; - } - } - /** handleBarDataLabels is used to calculate the positions for the data-labels - * It also sets the element's data attr for bars and calls drawCalculatedBarDataLabels() - * After calculating, it also calls the function to draw data labels - * @memberof Bar - * @param {object} {barProps} most of the bar properties used throughout the bar - * drawing function - * @return {object} dataLabels node-element which you can append later - **/ - - - _createClass(BarDataLabels, [{ - key: "handleBarDataLabels", - value: function handleBarDataLabels(opts) { - var x = opts.x, - y = opts.y, - y1 = opts.y1, - y2 = opts.y2, - i = opts.i, - j = opts.j, - realIndex = opts.realIndex, - groupIndex = opts.groupIndex, - series = opts.series, - barHeight = opts.barHeight, - barWidth = opts.barWidth, - barYPosition = opts.barYPosition, - visibleSeries = opts.visibleSeries, - renderedPath = opts.renderedPath; - var w = this.w; - var graphics = new Graphics(this.barCtx.ctx); - var strokeWidth = Array.isArray(this.barCtx.strokeWidth) ? this.barCtx.strokeWidth[realIndex] : this.barCtx.strokeWidth; - var bcx = x + parseFloat(barWidth * visibleSeries); - var bcy = y + parseFloat(barHeight * visibleSeries); - - if (w.globals.isXNumeric && !w.globals.isBarHorizontal) { - bcx = x + parseFloat(barWidth * (visibleSeries + 1)); - bcy = y + parseFloat(barHeight * (visibleSeries + 1)) - strokeWidth; - } - - var dataLabels = null; - var totalDataLabels = null; - var dataLabelsX = x; - var dataLabelsY = y; - var dataLabelsPos = {}; - var dataLabelsConfig = w.config.dataLabels; - var barDataLabelsConfig = this.barCtx.barOptions.dataLabels; - var barTotalDataLabelsConfig = this.barCtx.barOptions.dataLabels.total; - - if (typeof barYPosition !== 'undefined' && this.barCtx.isRangeBar) { - bcy = barYPosition; - dataLabelsY = barYPosition; - } - - var offX = dataLabelsConfig.offsetX; - var offY = dataLabelsConfig.offsetY; - var textRects = { - width: 0, - height: 0 - }; - - if (w.config.dataLabels.enabled) { - var yLabel = this.barCtx.series[i][j]; - textRects = graphics.getTextRects(w.globals.yLabelFormatters[0](yLabel), parseFloat(dataLabelsConfig.style.fontSize)); - } - - var params = { - x: x, - y: y, - i: i, - j: j, - realIndex: realIndex, - groupIndex: !!groupIndex ? groupIndex : -1, - renderedPath: renderedPath, - bcx: bcx, - bcy: bcy, - barHeight: barHeight, - barWidth: barWidth, - textRects: textRects, - strokeWidth: strokeWidth, - dataLabelsX: dataLabelsX, - dataLabelsY: dataLabelsY, - dataLabelsConfig: dataLabelsConfig, - barDataLabelsConfig: barDataLabelsConfig, - barTotalDataLabelsConfig: barTotalDataLabelsConfig, - offX: offX, - offY: offY - }; - - if (this.barCtx.isHorizontal) { - dataLabelsPos = this.calculateBarsDataLabelsPosition(params); - } else { - dataLabelsPos = this.calculateColumnsDataLabelsPosition(params); - } - - renderedPath.attr({ - cy: dataLabelsPos.bcy, - cx: dataLabelsPos.bcx, - j: j, - val: series[i][j], - barHeight: barHeight, - barWidth: barWidth - }); - dataLabels = this.drawCalculatedDataLabels({ - x: dataLabelsPos.dataLabelsX, - y: dataLabelsPos.dataLabelsY, - val: this.barCtx.isRangeBar ? [y1, y2] : series[i][j], - i: realIndex, - j: j, - barWidth: barWidth, - barHeight: barHeight, - textRects: textRects, - dataLabelsConfig: dataLabelsConfig - }); - - if (w.config.chart.stacked && barTotalDataLabelsConfig.enabled) { - totalDataLabels = this.drawTotalDataLabels({ - x: dataLabelsPos.totalDataLabelsX, - y: dataLabelsPos.totalDataLabelsY, - realIndex: realIndex, - textAnchor: dataLabelsPos.totalDataLabelsAnchor, - val: this.getStackedTotalDataLabel({ - realIndex: realIndex, - j: j - }), - dataLabelsConfig: dataLabelsConfig, - barTotalDataLabelsConfig: barTotalDataLabelsConfig - }); - } - - return { - dataLabels: dataLabels, - totalDataLabels: totalDataLabels - }; - } - }, { - key: "getStackedTotalDataLabel", - value: function getStackedTotalDataLabel(_ref) { - var realIndex = _ref.realIndex, - j = _ref.j; - var w = this.w; - var val = this.barCtx.stackedSeriesTotals[j]; - - if (this.totalFormatter) { - val = this.totalFormatter(val, _objectSpread2(_objectSpread2({}, w), {}, { - seriesIndex: realIndex, - dataPointIndex: j, - w: w - })); - } - - return val; - } - }, { - key: "calculateColumnsDataLabelsPosition", - value: function calculateColumnsDataLabelsPosition(opts) { - var w = this.w; - var i = opts.i, - j = opts.j, - realIndex = opts.realIndex, - groupIndex = opts.groupIndex, - y = opts.y, - bcx = opts.bcx, - barWidth = opts.barWidth, - barHeight = opts.barHeight, - textRects = opts.textRects, - dataLabelsY = opts.dataLabelsY, - dataLabelsConfig = opts.dataLabelsConfig, - barDataLabelsConfig = opts.barDataLabelsConfig, - barTotalDataLabelsConfig = opts.barTotalDataLabelsConfig, - strokeWidth = opts.strokeWidth, - offX = opts.offX, - offY = opts.offY; - var dataLabelsX; - var totalDataLabelsY; - var totalDataLabelsX; - var totalDataLabelsAnchor = 'middle'; - barHeight = Math.abs(barHeight); - var vertical = w.config.plotOptions.bar.dataLabels.orientation === 'vertical'; - bcx = bcx - strokeWidth / 2 + (groupIndex !== -1 ? groupIndex * barWidth : 0); - var dataPointsDividedWidth = w.globals.gridWidth / w.globals.dataPoints; - - if (w.globals.isXNumeric) { - dataLabelsX = bcx - barWidth / 2 + offX; - } else { - dataLabelsX = bcx - dataPointsDividedWidth + barWidth / 2 + offX; - } - - if (vertical) { - var offsetDLX = 2; - dataLabelsX = dataLabelsX + textRects.height / 2 - strokeWidth / 2 - offsetDLX; - } - - var valIsNegative = this.barCtx.series[i][j] < 0; - var newY = y; - - if (this.barCtx.isReversed) { - newY = y - barHeight + (valIsNegative ? barHeight * 2 : 0); - y = y - barHeight; - } - - switch (barDataLabelsConfig.position) { - case 'center': - if (vertical) { - if (valIsNegative) { - dataLabelsY = newY + barHeight / 2 + offY; - } else { - dataLabelsY = newY + barHeight / 2 - offY; - } - } else { - if (valIsNegative) { - dataLabelsY = newY - barHeight / 2 + textRects.height / 2 + offY; - } else { - dataLabelsY = newY + barHeight / 2 + textRects.height / 2 - offY; - } - } - - break; - - case 'bottom': - if (vertical) { - if (valIsNegative) { - dataLabelsY = newY + barHeight + offY; - } else { - dataLabelsY = newY + barHeight - offY; - } - } else { - if (valIsNegative) { - dataLabelsY = newY - barHeight + textRects.height + strokeWidth + offY; - } else { - dataLabelsY = newY + barHeight - textRects.height / 2 + strokeWidth - offY; - } - } - - break; - - case 'top': - if (vertical) { - if (valIsNegative) { - dataLabelsY = newY + offY; - } else { - dataLabelsY = newY - offY; - } - } else { - if (valIsNegative) { - dataLabelsY = newY - textRects.height / 2 - offY; - } else { - dataLabelsY = newY + textRects.height + offY; - } - } - - break; - } - - if (this.barCtx.lastActiveBarSerieIndex === realIndex && barTotalDataLabelsConfig.enabled) { - var ADDITIONAL_OFFX = 18; - var graphics = new Graphics(this.barCtx.ctx); - var totalLabeltextRects = graphics.getTextRects(this.getStackedTotalDataLabel({ - realIndex: realIndex, - j: j - }), dataLabelsConfig.fontSize); - - if (valIsNegative) { - totalDataLabelsY = newY - totalLabeltextRects.height / 2 - offY - barTotalDataLabelsConfig.offsetY + ADDITIONAL_OFFX; - } else { - totalDataLabelsY = newY + totalLabeltextRects.height + offY + barTotalDataLabelsConfig.offsetY - ADDITIONAL_OFFX; - } - - totalDataLabelsX = dataLabelsX + barTotalDataLabelsConfig.offsetX; - } - - if (!w.config.chart.stacked) { - if (dataLabelsY < 0) { - dataLabelsY = 0 + strokeWidth; - } else if (dataLabelsY + textRects.height / 3 > w.globals.gridHeight) { - dataLabelsY = w.globals.gridHeight - strokeWidth; - } - } - - return { - bcx: bcx, - bcy: y, - dataLabelsX: dataLabelsX, - dataLabelsY: dataLabelsY, - totalDataLabelsX: totalDataLabelsX, - totalDataLabelsY: totalDataLabelsY, - totalDataLabelsAnchor: totalDataLabelsAnchor - }; - } - }, { - key: "calculateBarsDataLabelsPosition", - value: function calculateBarsDataLabelsPosition(opts) { - var w = this.w; - var x = opts.x, - i = opts.i, - j = opts.j, - realIndex = opts.realIndex, - groupIndex = opts.groupIndex, - bcy = opts.bcy, - barHeight = opts.barHeight, - barWidth = opts.barWidth, - textRects = opts.textRects, - dataLabelsX = opts.dataLabelsX, - strokeWidth = opts.strokeWidth, - dataLabelsConfig = opts.dataLabelsConfig, - barDataLabelsConfig = opts.barDataLabelsConfig, - barTotalDataLabelsConfig = opts.barTotalDataLabelsConfig, - offX = opts.offX, - offY = opts.offY; - var dataPointsDividedHeight = w.globals.gridHeight / w.globals.dataPoints; - barWidth = Math.abs(barWidth); - bcy = bcy + (groupIndex !== -1 ? groupIndex * barHeight : 0); - var dataLabelsY = bcy - (this.barCtx.isRangeBar ? 0 : dataPointsDividedHeight) + barHeight / 2 + textRects.height / 2 + offY - 3; - var totalDataLabelsX; - var totalDataLabelsY; - var totalDataLabelsAnchor = 'start'; - var valIsNegative = this.barCtx.series[i][j] < 0; - var newX = x; - - if (this.barCtx.isReversed) { - newX = x + barWidth - (valIsNegative ? barWidth * 2 : 0); - x = w.globals.gridWidth - barWidth; - } - - switch (barDataLabelsConfig.position) { - case 'center': - if (valIsNegative) { - dataLabelsX = newX + barWidth / 2 - offX; - } else { - dataLabelsX = Math.max(textRects.width / 2, newX - barWidth / 2) + offX; - } - - break; - - case 'bottom': - if (valIsNegative) { - dataLabelsX = newX + barWidth - strokeWidth - Math.round(textRects.width / 2) - offX; - } else { - dataLabelsX = newX - barWidth + strokeWidth + Math.round(textRects.width / 2) + offX; - } - - break; - - case 'top': - if (valIsNegative) { - dataLabelsX = newX - strokeWidth + Math.round(textRects.width / 2) - offX; - } else { - dataLabelsX = newX - strokeWidth - Math.round(textRects.width / 2) + offX; - } - - break; - } - - if (this.barCtx.lastActiveBarSerieIndex === realIndex && barTotalDataLabelsConfig.enabled) { - var ADDITIONAL_OFFX = 15; - var graphics = new Graphics(this.barCtx.ctx); - var totalLabeltextRects = graphics.getTextRects(this.getStackedTotalDataLabel({ - realIndex: realIndex, - j: j - }), dataLabelsConfig.fontSize); - - if (valIsNegative) { - totalDataLabelsX = newX - strokeWidth + Math.round(totalLabeltextRects.width / 2) - offX - barTotalDataLabelsConfig.offsetX - ADDITIONAL_OFFX; - totalDataLabelsAnchor = 'end'; - } else { - totalDataLabelsX = newX - strokeWidth - Math.round(totalLabeltextRects.width / 2) + offX + barTotalDataLabelsConfig.offsetX + ADDITIONAL_OFFX; - } - - totalDataLabelsY = dataLabelsY + barTotalDataLabelsConfig.offsetY; - } - - if (!w.config.chart.stacked) { - if (dataLabelsX < 0) { - dataLabelsX = dataLabelsX + textRects.width + strokeWidth; - } else if (dataLabelsX + textRects.width / 2 > w.globals.gridWidth) { - dataLabelsX = w.globals.gridWidth - textRects.width - strokeWidth; - } - } - - return { - bcx: x, - bcy: bcy, - dataLabelsX: dataLabelsX, - dataLabelsY: dataLabelsY, - totalDataLabelsX: totalDataLabelsX, - totalDataLabelsY: totalDataLabelsY, - totalDataLabelsAnchor: totalDataLabelsAnchor - }; - } - }, { - key: "drawCalculatedDataLabels", - value: function drawCalculatedDataLabels(_ref2) { - var x = _ref2.x, - y = _ref2.y, - val = _ref2.val, - i = _ref2.i, - j = _ref2.j, - textRects = _ref2.textRects, - barHeight = _ref2.barHeight, - barWidth = _ref2.barWidth, - dataLabelsConfig = _ref2.dataLabelsConfig; - var w = this.w; - var rotate = 'rotate(0)'; - if (w.config.plotOptions.bar.dataLabels.orientation === 'vertical') rotate = "rotate(-90, ".concat(x, ", ").concat(y, ")"); - var dataLabels = new DataLabels(this.barCtx.ctx); - var graphics = new Graphics(this.barCtx.ctx); - var formatter = dataLabelsConfig.formatter; - var elDataLabelsWrap = null; - var isSeriesNotCollapsed = w.globals.collapsedSeriesIndices.indexOf(i) > -1; - - if (dataLabelsConfig.enabled && !isSeriesNotCollapsed) { - elDataLabelsWrap = graphics.group({ - class: 'apexcharts-data-labels', - transform: rotate - }); - var text = ''; - - if (typeof val !== 'undefined') { - text = formatter(val, _objectSpread2(_objectSpread2({}, w), {}, { - seriesIndex: i, - dataPointIndex: j, - w: w - })); - } - - if (!val && w.config.plotOptions.bar.hideZeroBarsWhenGrouped) { - text = ''; - } - - var valIsNegative = w.globals.series[i][j] < 0; - var position = w.config.plotOptions.bar.dataLabels.position; - - if (w.config.plotOptions.bar.dataLabels.orientation === 'vertical') { - if (position === 'top') { - if (valIsNegative) dataLabelsConfig.textAnchor = 'end';else dataLabelsConfig.textAnchor = 'start'; - } - - if (position === 'center') { - dataLabelsConfig.textAnchor = 'middle'; - } - - if (position === 'bottom') { - if (valIsNegative) dataLabelsConfig.textAnchor = 'end';else dataLabelsConfig.textAnchor = 'start'; - } - } - - if (this.barCtx.isRangeBar && this.barCtx.barOptions.dataLabels.hideOverflowingLabels) { - // hide the datalabel if it cannot fit into the rect - var txRect = graphics.getTextRects(text, parseFloat(dataLabelsConfig.style.fontSize)); - - if (barWidth < txRect.width) { - text = ''; - } - } - - if (w.config.chart.stacked && this.barCtx.barOptions.dataLabels.hideOverflowingLabels) { - // if there is not enough space to draw the label in the bar/column rect, check hideOverflowingLabels property to prevent overflowing on wrong rect - // Note: This issue is only seen in stacked charts - if (this.barCtx.isHorizontal) { - if (textRects.width / 1.6 > Math.abs(barWidth)) { - text = ''; - } - } else { - if (textRects.height / 1.6 > Math.abs(barHeight)) { - text = ''; - } - } - } - - var modifiedDataLabelsConfig = _objectSpread2({}, dataLabelsConfig); - - if (this.barCtx.isHorizontal) { - if (val < 0) { - if (dataLabelsConfig.textAnchor === 'start') { - modifiedDataLabelsConfig.textAnchor = 'end'; - } else if (dataLabelsConfig.textAnchor === 'end') { - modifiedDataLabelsConfig.textAnchor = 'start'; - } - } - } - - dataLabels.plotDataLabelsText({ - x: x, - y: y, - text: text, - i: i, - j: j, - parent: elDataLabelsWrap, - dataLabelsConfig: modifiedDataLabelsConfig, - alwaysDrawDataLabel: true, - offsetCorrection: true - }); - } - - return elDataLabelsWrap; - } - }, { - key: "drawTotalDataLabels", - value: function drawTotalDataLabels(_ref3) { - var x = _ref3.x, - y = _ref3.y, - val = _ref3.val, - realIndex = _ref3.realIndex, - textAnchor = _ref3.textAnchor, - barTotalDataLabelsConfig = _ref3.barTotalDataLabelsConfig; - var graphics = new Graphics(this.barCtx.ctx); - var totalDataLabelText; - - if (barTotalDataLabelsConfig.enabled && typeof x !== 'undefined' && typeof y !== 'undefined' && this.barCtx.lastActiveBarSerieIndex === realIndex) { - totalDataLabelText = graphics.drawText({ - x: x, - y: y, - foreColor: barTotalDataLabelsConfig.style.color, - text: val, - textAnchor: textAnchor, - fontFamily: barTotalDataLabelsConfig.style.fontFamily, - fontSize: barTotalDataLabelsConfig.style.fontSize, - fontWeight: barTotalDataLabelsConfig.style.fontWeight - }); - } - - return totalDataLabelText; - } - }]); - - return BarDataLabels; - }(); - - var Helpers$1 = /*#__PURE__*/function () { - function Helpers(barCtx) { - _classCallCheck(this, Helpers); - - this.w = barCtx.w; - this.barCtx = barCtx; - } - - _createClass(Helpers, [{ - key: "initVariables", - value: function initVariables(series) { - var w = this.w; - this.barCtx.series = series; - this.barCtx.totalItems = 0; - this.barCtx.seriesLen = 0; - this.barCtx.visibleI = -1; // visible Series - - this.barCtx.visibleItems = 1; // number of visible bars after user zoomed in/out - - for (var sl = 0; sl < series.length; sl++) { - if (series[sl].length > 0) { - this.barCtx.seriesLen = this.barCtx.seriesLen + 1; - this.barCtx.totalItems += series[sl].length; - } - - if (w.globals.isXNumeric) { - // get max visible items - for (var j = 0; j < series[sl].length; j++) { - if (w.globals.seriesX[sl][j] > w.globals.minX && w.globals.seriesX[sl][j] < w.globals.maxX) { - this.barCtx.visibleItems++; - } - } - } else { - this.barCtx.visibleItems = w.globals.dataPoints; - } - } - - if (this.barCtx.seriesLen === 0) { - // A small adjustment when combo charts are used - this.barCtx.seriesLen = 1; - } - - this.barCtx.zeroSerieses = []; - - if (!w.globals.comboCharts) { - this.checkZeroSeries({ - series: series - }); - } - } - }, { - key: "initialPositions", - value: function initialPositions() { - var w = this.w; - var x, y, yDivision, xDivision, barHeight, barWidth, zeroH, zeroW; - var dataPoints = w.globals.dataPoints; - - if (this.barCtx.isRangeBar) { - // timeline rangebar chart - dataPoints = w.globals.labels.length; - } - - var seriesLen = this.barCtx.seriesLen; - - if (w.config.plotOptions.bar.rangeBarGroupRows) { - seriesLen = 1; - } - - if (this.barCtx.isHorizontal) { - // height divided into equal parts - yDivision = w.globals.gridHeight / dataPoints; - barHeight = yDivision / seriesLen; - - if (w.globals.isXNumeric) { - yDivision = w.globals.gridHeight / this.barCtx.totalItems; - barHeight = yDivision / this.barCtx.seriesLen; - } - - barHeight = barHeight * parseInt(this.barCtx.barOptions.barHeight, 10) / 100; - - if (String(this.barCtx.barOptions.barHeight).indexOf('%') === -1) { - barHeight = parseInt(this.barCtx.barOptions.barHeight, 10); - } - - zeroW = this.barCtx.baseLineInvertedY + w.globals.padHorizontal + (this.barCtx.isReversed ? w.globals.gridWidth : 0) - (this.barCtx.isReversed ? this.barCtx.baseLineInvertedY * 2 : 0); - y = (yDivision - barHeight * this.barCtx.seriesLen) / 2; - } else { - // width divided into equal parts - xDivision = w.globals.gridWidth / this.barCtx.visibleItems; - - if (w.config.xaxis.convertedCatToNumeric) { - xDivision = w.globals.gridWidth / w.globals.dataPoints; - } - - barWidth = xDivision / this.barCtx.seriesLen * parseInt(this.barCtx.barOptions.columnWidth, 10) / 100; - - if (w.globals.isXNumeric) { - // max barwidth should be equal to minXDiff to avoid overlap - var xRatio = this.barCtx.xRatio; - - if (w.config.xaxis.convertedCatToNumeric) { - xRatio = this.barCtx.initialXRatio; - } - - if (w.globals.minXDiff && w.globals.minXDiff !== 0.5 && w.globals.minXDiff / xRatio > 0) { - xDivision = w.globals.minXDiff / xRatio; - } - - barWidth = xDivision / this.barCtx.seriesLen * parseInt(this.barCtx.barOptions.columnWidth, 10) / 100; - - if (barWidth < 1) { - barWidth = 1; - } - } - - if (String(this.barCtx.barOptions.columnWidth).indexOf('%') === -1) { - barWidth = parseInt(this.barCtx.barOptions.columnWidth, 10); - } - - zeroH = w.globals.gridHeight - this.barCtx.baseLineY[this.barCtx.yaxisIndex] - (this.barCtx.isReversed ? w.globals.gridHeight : 0) + (this.barCtx.isReversed ? this.barCtx.baseLineY[this.barCtx.yaxisIndex] * 2 : 0); - x = w.globals.padHorizontal + (xDivision - barWidth * this.barCtx.seriesLen) / 2; - } - - return { - x: x, - y: y, - yDivision: yDivision, - xDivision: xDivision, - barHeight: barHeight, - barWidth: barWidth, - zeroH: zeroH, - zeroW: zeroW - }; - } - }, { - key: "initializeStackedPrevVars", - value: function initializeStackedPrevVars(ctx) { - var w = ctx.w; - - if (w.globals.hasSeriesGroups) { - w.globals.seriesGroups.forEach(function (group) { - if (!ctx[group]) ctx[group] = {}; - ctx[group].prevY = []; - ctx[group].prevX = []; - ctx[group].prevYF = []; - ctx[group].prevXF = []; - ctx[group].prevYVal = []; - ctx[group].prevXVal = []; - }); - } else { - ctx.prevY = []; // y position on chart (in columns) - - ctx.prevX = []; // x position on chart (in horz bars) - - ctx.prevYF = []; // starting y and ending y (height) in columns - - ctx.prevXF = []; // starting x and ending x (width) in bars - - ctx.prevYVal = []; // y values (series[i][j]) in columns - - ctx.prevXVal = []; // x values (series[i][j]) in bars - } - } - }, { - key: "initializeStackedXYVars", - value: function initializeStackedXYVars(ctx) { - var w = ctx.w; - - if (w.globals.hasSeriesGroups) { - w.globals.seriesGroups.forEach(function (group) { - if (!ctx[group]) ctx[group] = {}; - ctx[group].xArrj = []; - ctx[group].xArrjF = []; - ctx[group].xArrjVal = []; - ctx[group].yArrj = []; - ctx[group].yArrjF = []; - ctx[group].yArrjVal = []; - }); - } else { - ctx.xArrj = []; // xj indicates x position on graph in bars - - ctx.xArrjF = []; // xjF indicates bar's x position + x2 positions in bars - - ctx.xArrjVal = []; // x val means the actual series's y values in horizontal/bars - - ctx.yArrj = []; // yj indicates y position on graph in columns - - ctx.yArrjF = []; // yjF indicates bar's y position + y2 positions in columns - - ctx.yArrjVal = []; // y val means the actual series's y values in columns - } - } - }, { - key: "getPathFillColor", - value: function getPathFillColor(series, i, j, realIndex) { - var _w$config$series$i$da, _w$config$series$i$da2, _w$config$series$i$da3, _w$config$series$i$da4; - - var w = this.w; - var fill = new Fill(this.barCtx.ctx); - var fillColor = null; - var seriesNumber = this.barCtx.barOptions.distributed ? j : i; - - if (this.barCtx.barOptions.colors.ranges.length > 0) { - var colorRange = this.barCtx.barOptions.colors.ranges; - colorRange.map(function (range) { - if (series[i][j] >= range.from && series[i][j] <= range.to) { - fillColor = range.color; - } - }); - } - - if (w.config.series[i].data[j] && w.config.series[i].data[j].fillColor) { - fillColor = w.config.series[i].data[j].fillColor; - } - - var pathFill = fill.fillPath({ - seriesNumber: this.barCtx.barOptions.distributed ? seriesNumber : realIndex, - dataPointIndex: j, - color: fillColor, - value: series[i][j], - fillConfig: (_w$config$series$i$da = w.config.series[i].data[j]) === null || _w$config$series$i$da === void 0 ? void 0 : _w$config$series$i$da.fill, - fillType: (_w$config$series$i$da2 = w.config.series[i].data[j]) !== null && _w$config$series$i$da2 !== void 0 && (_w$config$series$i$da3 = _w$config$series$i$da2.fill) !== null && _w$config$series$i$da3 !== void 0 && _w$config$series$i$da3.type ? (_w$config$series$i$da4 = w.config.series[i].data[j]) === null || _w$config$series$i$da4 === void 0 ? void 0 : _w$config$series$i$da4.fill.type : w.config.fill.type - }); - return pathFill; - } - }, { - key: "getStrokeWidth", - value: function getStrokeWidth(i, j, realIndex) { - var strokeWidth = 0; - var w = this.w; - - if (!this.barCtx.series[i][j]) { - this.barCtx.isNullValue = true; - } else { - this.barCtx.isNullValue = false; - } - - if (w.config.stroke.show) { - if (!this.barCtx.isNullValue) { - strokeWidth = Array.isArray(this.barCtx.strokeWidth) ? this.barCtx.strokeWidth[realIndex] : this.barCtx.strokeWidth; - } - } - - return strokeWidth; - } - }, { - key: "shouldApplyRadius", - value: function shouldApplyRadius(realIndex) { - var w = this.w; - var applyRadius = false; - - if (w.config.plotOptions.bar.borderRadius > 0) { - if (w.config.chart.stacked) { - if (w.config.plotOptions.bar.borderRadiusWhenStacked === 'last') { - if (this.barCtx.lastActiveBarSerieIndex === realIndex) { - applyRadius = true; - } - } else { - applyRadius = true; - } - } else { - applyRadius = true; - } - } - - return applyRadius; - } - }, { - key: "barBackground", - value: function barBackground(_ref) { - var j = _ref.j, - i = _ref.i, - x1 = _ref.x1, - x2 = _ref.x2, - y1 = _ref.y1, - y2 = _ref.y2, - elSeries = _ref.elSeries; - var w = this.w; - var graphics = new Graphics(this.barCtx.ctx); - var sr = new Series(this.barCtx.ctx); - var activeSeriesIndex = sr.getActiveConfigSeriesIndex(); - - if (this.barCtx.barOptions.colors.backgroundBarColors.length > 0 && activeSeriesIndex === i) { - if (j >= this.barCtx.barOptions.colors.backgroundBarColors.length) { - j %= this.barCtx.barOptions.colors.backgroundBarColors.length; - } - - var bcolor = this.barCtx.barOptions.colors.backgroundBarColors[j]; - var rect = graphics.drawRect(typeof x1 !== 'undefined' ? x1 : 0, typeof y1 !== 'undefined' ? y1 : 0, typeof x2 !== 'undefined' ? x2 : w.globals.gridWidth, typeof y2 !== 'undefined' ? y2 : w.globals.gridHeight, this.barCtx.barOptions.colors.backgroundBarRadius, bcolor, this.barCtx.barOptions.colors.backgroundBarOpacity); - elSeries.add(rect); - rect.node.classList.add('apexcharts-backgroundBar'); - } - } - }, { - key: "getColumnPaths", - value: function getColumnPaths(_ref2) { - var _w$config$series$real; - - var barWidth = _ref2.barWidth, - barXPosition = _ref2.barXPosition, - y1 = _ref2.y1, - y2 = _ref2.y2, - strokeWidth = _ref2.strokeWidth, - seriesGroup = _ref2.seriesGroup, - realIndex = _ref2.realIndex, - i = _ref2.i, - j = _ref2.j, - w = _ref2.w; - var graphics = new Graphics(this.barCtx.ctx); - strokeWidth = Array.isArray(strokeWidth) ? strokeWidth[realIndex] : strokeWidth; - if (!strokeWidth) strokeWidth = 0; - var bW = barWidth; - var bXP = barXPosition; - - if ((_w$config$series$real = w.config.series[realIndex].data[j]) !== null && _w$config$series$real !== void 0 && _w$config$series$real.columnWidthOffset) { - bXP = barXPosition - w.config.series[realIndex].data[j].columnWidthOffset / 2; - bW = barWidth + w.config.series[realIndex].data[j].columnWidthOffset; - } - - var x1 = bXP; - var x2 = bXP + bW; // append tiny pixels to avoid exponentials (which cause issues in border-radius) - - y1 += 0.001; - y2 += 0.001; - var pathTo = graphics.move(x1, y1); - var pathFrom = graphics.move(x1, y1); - var sl = graphics.line(x2 - strokeWidth, y1); - - if (w.globals.previousPaths.length > 0) { - pathFrom = this.barCtx.getPreviousPath(realIndex, j, false); - } - - pathTo = pathTo + graphics.line(x1, y2) + graphics.line(x2 - strokeWidth, y2) + graphics.line(x2 - strokeWidth, y1) + (w.config.plotOptions.bar.borderRadiusApplication === 'around' ? ' Z' : ' z'); // the lines in pathFrom are repeated to equal it to the points of pathTo - // this is to avoid weird animation (bug in svg.js) - - pathFrom = pathFrom + graphics.line(x1, y1) + sl + sl + sl + sl + sl + graphics.line(x1, y1) + (w.config.plotOptions.bar.borderRadiusApplication === 'around' ? ' Z' : ' z'); - - if (this.shouldApplyRadius(realIndex)) { - pathTo = graphics.roundPathCorners(pathTo, w.config.plotOptions.bar.borderRadius); - } - - if (w.config.chart.stacked) { - var _ctx = this.barCtx; - - if (w.globals.hasSeriesGroups && seriesGroup) { - _ctx = this.barCtx[seriesGroup]; - } - - _ctx.yArrj.push(y2); - - _ctx.yArrjF.push(Math.abs(y1 - y2)); - - _ctx.yArrjVal.push(this.barCtx.series[i][j]); - } - - return { - pathTo: pathTo, - pathFrom: pathFrom - }; - } - }, { - key: "getBarpaths", - value: function getBarpaths(_ref3) { - var _w$config$series$real2; - - var barYPosition = _ref3.barYPosition, - barHeight = _ref3.barHeight, - x1 = _ref3.x1, - x2 = _ref3.x2, - strokeWidth = _ref3.strokeWidth, - seriesGroup = _ref3.seriesGroup, - realIndex = _ref3.realIndex, - i = _ref3.i, - j = _ref3.j, - w = _ref3.w; - var graphics = new Graphics(this.barCtx.ctx); - strokeWidth = Array.isArray(strokeWidth) ? strokeWidth[realIndex] : strokeWidth; - if (!strokeWidth) strokeWidth = 0; - var bYP = barYPosition; - var bH = barHeight; - - if ((_w$config$series$real2 = w.config.series[realIndex].data[j]) !== null && _w$config$series$real2 !== void 0 && _w$config$series$real2.barHeightOffset) { - bYP = barYPosition - w.config.series[realIndex].data[j].barHeightOffset / 2; - bH = barHeight + w.config.series[realIndex].data[j].barHeightOffset; - } - - var y1 = bYP; - var y2 = bYP + bH; // append tiny pixels to avoid exponentials (which cause issues in border-radius) - - x1 += 0.001; - x2 += 0.001; - var pathTo = graphics.move(x1, y1); - var pathFrom = graphics.move(x1, y1); - - if (w.globals.previousPaths.length > 0) { - pathFrom = this.barCtx.getPreviousPath(realIndex, j, false); - } - - var sl = graphics.line(x1, y2 - strokeWidth); - pathTo = pathTo + graphics.line(x2, y1) + graphics.line(x2, y2 - strokeWidth) + sl + (w.config.plotOptions.bar.borderRadiusApplication === 'around' ? ' Z' : ' z'); - pathFrom = pathFrom + graphics.line(x1, y1) + sl + sl + sl + sl + sl + graphics.line(x1, y1) + (w.config.plotOptions.bar.borderRadiusApplication === 'around' ? ' Z' : ' z'); - - if (this.shouldApplyRadius(realIndex)) { - pathTo = graphics.roundPathCorners(pathTo, w.config.plotOptions.bar.borderRadius); - } - - if (w.config.chart.stacked) { - var _ctx = this.barCtx; - - if (w.globals.hasSeriesGroups && seriesGroup) { - _ctx = this.barCtx[seriesGroup]; - } - - _ctx.xArrj.push(x2); - - _ctx.xArrjF.push(Math.abs(x1 - x2)); - - _ctx.xArrjVal.push(this.barCtx.series[i][j]); - } - - return { - pathTo: pathTo, - pathFrom: pathFrom - }; - } - }, { - key: "checkZeroSeries", - value: function checkZeroSeries(_ref4) { - var series = _ref4.series; - var w = this.w; - - for (var zs = 0; zs < series.length; zs++) { - var total = 0; - - for (var zsj = 0; zsj < series[w.globals.maxValsInArrayIndex].length; zsj++) { - total += series[zs][zsj]; - } - - if (total === 0) { - this.barCtx.zeroSerieses.push(zs); - } - } - } - }, { - key: "getXForValue", - value: function getXForValue(value, zeroW) { - var zeroPositionForNull = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; - var xForVal = zeroPositionForNull ? zeroW : null; - - if (typeof value !== 'undefined' && value !== null) { - xForVal = zeroW + value / this.barCtx.invertedYRatio - (this.barCtx.isReversed ? value / this.barCtx.invertedYRatio : 0) * 2; - } - - return xForVal; - } - }, { - key: "getYForValue", - value: function getYForValue(value, zeroH) { - var zeroPositionForNull = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; - var yForVal = zeroPositionForNull ? zeroH : null; - - if (typeof value !== 'undefined' && value !== null) { - yForVal = zeroH - value / this.barCtx.yRatio[this.barCtx.yaxisIndex] + (this.barCtx.isReversed ? value / this.barCtx.yRatio[this.barCtx.yaxisIndex] : 0) * 2; - } - - return yForVal; - } - }, { - key: "getGoalValues", - value: function getGoalValues(type, zeroW, zeroH, i, j) { - var _this = this; - - var w = this.w; - var goals = []; - - var pushGoal = function pushGoal(value, attrs) { - var _goals$push; - - goals.push((_goals$push = {}, _defineProperty(_goals$push, type, type === 'x' ? _this.getXForValue(value, zeroW, false) : _this.getYForValue(value, zeroH, false)), _defineProperty(_goals$push, "attrs", attrs), _goals$push)); - }; - - if (w.globals.seriesGoals[i] && w.globals.seriesGoals[i][j] && Array.isArray(w.globals.seriesGoals[i][j])) { - w.globals.seriesGoals[i][j].forEach(function (goal) { - pushGoal(goal.value, goal); - }); - } - - if (this.barCtx.barOptions.isDumbbell && w.globals.seriesRange.length) { - var colors = this.barCtx.barOptions.dumbbellColors ? this.barCtx.barOptions.dumbbellColors : w.globals.colors; - var commonAttrs = { - strokeHeight: type === 'x' ? 0 : w.globals.markers.size[i], - strokeWidth: type === 'x' ? w.globals.markers.size[i] : 0, - strokeDashArray: 0, - strokeLineCap: 'round', - strokeColor: Array.isArray(colors[i]) ? colors[i][0] : colors[i] - }; - pushGoal(w.globals.seriesRangeStart[i][j], commonAttrs); - pushGoal(w.globals.seriesRangeEnd[i][j], _objectSpread2(_objectSpread2({}, commonAttrs), {}, { - strokeColor: Array.isArray(colors[i]) ? colors[i][1] : colors[i] - })); - } - - return goals; - } - }, { - key: "drawGoalLine", - value: function drawGoalLine(_ref5) { - var barXPosition = _ref5.barXPosition, - barYPosition = _ref5.barYPosition, - goalX = _ref5.goalX, - goalY = _ref5.goalY, - barWidth = _ref5.barWidth, - barHeight = _ref5.barHeight; - var graphics = new Graphics(this.barCtx.ctx); - var lineGroup = graphics.group({ - className: 'apexcharts-bar-goals-groups' - }); - lineGroup.node.classList.add('apexcharts-element-hidden'); - this.barCtx.w.globals.delayedElements.push({ - el: lineGroup.node - }); - lineGroup.attr('clip-path', "url(#gridRectMarkerMask".concat(this.barCtx.w.globals.cuid, ")")); - var line = null; - - if (this.barCtx.isHorizontal) { - if (Array.isArray(goalX)) { - goalX.forEach(function (goal) { - var sHeight = typeof goal.attrs.strokeHeight !== 'undefined' ? goal.attrs.strokeHeight : barHeight / 2; - var y = barYPosition + sHeight + barHeight / 2; - line = graphics.drawLine(goal.x, y - sHeight * 2, goal.x, y, goal.attrs.strokeColor ? goal.attrs.strokeColor : undefined, goal.attrs.strokeDashArray, goal.attrs.strokeWidth ? goal.attrs.strokeWidth : 2, goal.attrs.strokeLineCap); - lineGroup.add(line); - }); - } - } else { - if (Array.isArray(goalY)) { - goalY.forEach(function (goal) { - var sWidth = typeof goal.attrs.strokeWidth !== 'undefined' ? goal.attrs.strokeWidth : barWidth / 2; - var x = barXPosition + sWidth + barWidth / 2; - line = graphics.drawLine(x - sWidth * 2, goal.y, x, goal.y, goal.attrs.strokeColor ? goal.attrs.strokeColor : undefined, goal.attrs.strokeDashArray, goal.attrs.strokeHeight ? goal.attrs.strokeHeight : 2, goal.attrs.strokeLineCap); - lineGroup.add(line); - }); - } - } - - return lineGroup; - } - }]); - - return Helpers; - }(); - - /** - * ApexCharts Bar Class responsible for drawing both Columns and Bars. - * - * @module Bar - **/ - - var Bar = /*#__PURE__*/function () { - function Bar(ctx, xyRatios) { - _classCallCheck(this, Bar); - - this.ctx = ctx; - this.w = ctx.w; - var w = this.w; - this.barOptions = w.config.plotOptions.bar; - this.isHorizontal = this.barOptions.horizontal; - this.strokeWidth = w.config.stroke.width; - this.isNullValue = false; - this.isRangeBar = w.globals.seriesRange.length && this.isHorizontal; - this.xyRatios = xyRatios; - - if (this.xyRatios !== null) { - this.xRatio = xyRatios.xRatio; - this.initialXRatio = xyRatios.initialXRatio; - this.yRatio = xyRatios.yRatio; - this.invertedXRatio = xyRatios.invertedXRatio; - this.invertedYRatio = xyRatios.invertedYRatio; - this.baseLineY = xyRatios.baseLineY; - this.baseLineInvertedY = xyRatios.baseLineInvertedY; - } - - this.yaxisIndex = 0; - this.seriesLen = 0; - var ser = new Series(this.ctx); - this.lastActiveBarSerieIndex = ser.getActiveConfigSeriesIndex('desc', ['bar', 'column']); - var barSeriesIndices = ser.getBarSeriesIndices(); - var coreUtils = new CoreUtils(this.ctx); - this.stackedSeriesTotals = coreUtils.getStackedSeriesTotals(this.w.config.series.map(function (s, i) { - return barSeriesIndices.indexOf(i) === -1 ? i : -1; - }).filter(function (s) { - return s !== -1; - })); - this.barHelpers = new Helpers$1(this); - } - /** primary draw method which is called on bar object - * @memberof Bar - * @param {array} series - user supplied series values - * @param {int} seriesIndex - the index by which series will be drawn on the svg - * @return {node} element which is supplied to parent chart draw method for appending - **/ - - - _createClass(Bar, [{ - key: "draw", - value: function draw(series, seriesIndex) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var coreUtils = new CoreUtils(this.ctx, w); - series = coreUtils.getLogSeries(series); - this.series = series; - this.yRatio = coreUtils.getLogYRatios(this.yRatio); - this.barHelpers.initVariables(series); - var ret = graphics.group({ - class: 'apexcharts-bar-series apexcharts-plot-series' - }); - - if (w.config.dataLabels.enabled) { - if (this.totalItems > this.barOptions.dataLabels.maxItems) { - console.warn('WARNING: DataLabels are enabled but there are too many to display. This may cause performance issue when rendering.'); - } - } - - for (var i = 0, bc = 0; i < series.length; i++, bc++) { - var x = void 0, - y = void 0, - xDivision = void 0, - // xDivision is the GRIDWIDTH divided by number of datapoints (columns) - yDivision = void 0, - // yDivision is the GRIDHEIGHT divided by number of datapoints (bars) - zeroH = void 0, - // zeroH is the baseline where 0 meets y axis - zeroW = void 0; // zeroW is the baseline where 0 meets x axis - - var yArrj = []; // hold y values of current iterating series - - var xArrj = []; // hold x values of current iterating series - - var realIndex = w.globals.comboCharts ? seriesIndex[i] : i; // el to which series will be drawn - - var elSeries = graphics.group({ - class: "apexcharts-series", - rel: i + 1, - seriesName: Utils$1.escapeString(w.globals.seriesNames[realIndex]), - 'data:realIndex': realIndex - }); - this.ctx.series.addCollapsedClassToSeries(elSeries, realIndex); - - if (series[i].length > 0) { - this.visibleI = this.visibleI + 1; - } - - var barHeight = 0; - var barWidth = 0; - - if (this.yRatio.length > 1) { - this.yaxisIndex = realIndex; - } - - this.isReversed = w.config.yaxis[this.yaxisIndex] && w.config.yaxis[this.yaxisIndex].reversed; - var initPositions = this.barHelpers.initialPositions(); - y = initPositions.y; - barHeight = initPositions.barHeight; - yDivision = initPositions.yDivision; - zeroW = initPositions.zeroW; - x = initPositions.x; - barWidth = initPositions.barWidth; - xDivision = initPositions.xDivision; - zeroH = initPositions.zeroH; - - if (!this.horizontal) { - xArrj.push(x + barWidth / 2); - } // eldatalabels - - - var elDataLabelsWrap = graphics.group({ - class: 'apexcharts-datalabels', - 'data:realIndex': realIndex - }); - var elGoalsMarkers = graphics.group({ - class: 'apexcharts-bar-goals-markers', - style: "pointer-events: none" - }); - - for (var j = 0; j < w.globals.dataPoints; j++) { - var strokeWidth = this.barHelpers.getStrokeWidth(i, j, realIndex); - var paths = null; - var pathsParams = { - indexes: { - i: i, - j: j, - realIndex: realIndex, - bc: bc - }, - x: x, - y: y, - strokeWidth: strokeWidth, - elSeries: elSeries - }; - - if (this.isHorizontal) { - paths = this.drawBarPaths(_objectSpread2(_objectSpread2({}, pathsParams), {}, { - barHeight: barHeight, - zeroW: zeroW, - yDivision: yDivision - })); - barWidth = this.series[i][j] / this.invertedYRatio; - } else { - paths = this.drawColumnPaths(_objectSpread2(_objectSpread2({}, pathsParams), {}, { - xDivision: xDivision, - barWidth: barWidth, - zeroH: zeroH - })); - barHeight = this.series[i][j] / this.yRatio[this.yaxisIndex]; - } - - var barGoalLine = this.barHelpers.drawGoalLine({ - barXPosition: paths.barXPosition, - barYPosition: paths.barYPosition, - goalX: paths.goalX, - goalY: paths.goalY, - barHeight: barHeight, - barWidth: barWidth - }); - - if (barGoalLine) { - elGoalsMarkers.add(barGoalLine); - } - - y = paths.y; - x = paths.x; // push current X - - if (j > 0) { - xArrj.push(x + barWidth / 2); - } - - yArrj.push(y); - var pathFill = this.barHelpers.getPathFillColor(series, i, j, realIndex); - this.renderSeries({ - realIndex: realIndex, - pathFill: pathFill, - j: j, - i: i, - pathFrom: paths.pathFrom, - pathTo: paths.pathTo, - strokeWidth: strokeWidth, - elSeries: elSeries, - x: x, - y: y, - series: series, - barHeight: paths.barHeight ? paths.barHeight : barHeight, - barWidth: paths.barWidth ? paths.barWidth : barWidth, - elDataLabelsWrap: elDataLabelsWrap, - elGoalsMarkers: elGoalsMarkers, - visibleSeries: this.visibleI, - type: 'bar' - }); - } // push all x val arrays into main xArr - - - w.globals.seriesXvalues[realIndex] = xArrj; - w.globals.seriesYvalues[realIndex] = yArrj; - ret.add(elSeries); - } - - return ret; - } - }, { - key: "renderSeries", - value: function renderSeries(_ref) { - var realIndex = _ref.realIndex, - pathFill = _ref.pathFill, - lineFill = _ref.lineFill, - j = _ref.j, - i = _ref.i, - groupIndex = _ref.groupIndex, - pathFrom = _ref.pathFrom, - pathTo = _ref.pathTo, - strokeWidth = _ref.strokeWidth, - elSeries = _ref.elSeries, - x = _ref.x, - y = _ref.y, - y1 = _ref.y1, - y2 = _ref.y2, - series = _ref.series, - barHeight = _ref.barHeight, - barWidth = _ref.barWidth, - barYPosition = _ref.barYPosition, - elDataLabelsWrap = _ref.elDataLabelsWrap, - elGoalsMarkers = _ref.elGoalsMarkers, - visibleSeries = _ref.visibleSeries, - type = _ref.type; - var w = this.w; - var graphics = new Graphics(this.ctx); - - if (!lineFill) { - /* fix apexcharts#341 */ - lineFill = this.barOptions.distributed ? w.globals.stroke.colors[j] : w.globals.stroke.colors[realIndex]; - } - - if (w.config.series[i].data[j] && w.config.series[i].data[j].strokeColor) { - lineFill = w.config.series[i].data[j].strokeColor; - } - - if (this.isNullValue) { - pathFill = 'none'; - } - - var delay = j / w.config.chart.animations.animateGradually.delay * (w.config.chart.animations.speed / w.globals.dataPoints) / 2.4; - var renderedPath = graphics.renderPaths({ - i: i, - j: j, - realIndex: realIndex, - pathFrom: pathFrom, - pathTo: pathTo, - stroke: lineFill, - strokeWidth: strokeWidth, - strokeLineCap: w.config.stroke.lineCap, - fill: pathFill, - animationDelay: delay, - initialSpeed: w.config.chart.animations.speed, - dataChangeSpeed: w.config.chart.animations.dynamicAnimation.speed, - className: "apexcharts-".concat(type, "-area") - }); - renderedPath.attr('clip-path', "url(#gridRectMask".concat(w.globals.cuid, ")")); - var forecast = w.config.forecastDataPoints; - - if (forecast.count > 0) { - if (j >= w.globals.dataPoints - forecast.count) { - renderedPath.node.setAttribute('stroke-dasharray', forecast.dashArray); - renderedPath.node.setAttribute('stroke-width', forecast.strokeWidth); - renderedPath.node.setAttribute('fill-opacity', forecast.fillOpacity); - } - } - - if (typeof y1 !== 'undefined' && typeof y2 !== 'undefined') { - renderedPath.attr('data-range-y1', y1); - renderedPath.attr('data-range-y2', y2); - } - - var filters = new Filters(this.ctx); - filters.setSelectionFilter(renderedPath, realIndex, j); - elSeries.add(renderedPath); - var barDataLabels = new BarDataLabels(this); - var dataLabelsObj = barDataLabels.handleBarDataLabels({ - x: x, - y: y, - y1: y1, - y2: y2, - i: i, - j: j, - series: series, - realIndex: realIndex, - groupIndex: groupIndex, - barHeight: barHeight, - barWidth: barWidth, - barYPosition: barYPosition, - renderedPath: renderedPath, - visibleSeries: visibleSeries - }); - - if (dataLabelsObj.dataLabels !== null) { - elDataLabelsWrap.add(dataLabelsObj.dataLabels); - } - - if (dataLabelsObj.totalDataLabels) { - elDataLabelsWrap.add(dataLabelsObj.totalDataLabels); - } - - elSeries.add(elDataLabelsWrap); - - if (elGoalsMarkers) { - elSeries.add(elGoalsMarkers); - } - - return elSeries; - } - }, { - key: "drawBarPaths", - value: function drawBarPaths(_ref2) { - var indexes = _ref2.indexes, - barHeight = _ref2.barHeight, - strokeWidth = _ref2.strokeWidth, - zeroW = _ref2.zeroW, - x = _ref2.x, - y = _ref2.y, - yDivision = _ref2.yDivision, - elSeries = _ref2.elSeries; - var w = this.w; - var i = indexes.i; - var j = indexes.j; - var barYPosition; - - if (w.globals.isXNumeric) { - y = (w.globals.seriesX[i][j] - w.globals.minX) / this.invertedXRatio - barHeight; - barYPosition = y + barHeight * this.visibleI; - } else { - if (w.config.plotOptions.bar.hideZeroBarsWhenGrouped) { - var nonZeroColumns = 0; - var zeroEncounters = 0; - w.globals.seriesPercent.forEach(function (_s, _si) { - if (_s[j]) { - nonZeroColumns++; - } - - if (_si < i && _s[j] === 0) { - zeroEncounters++; - } - }); - - if (nonZeroColumns > 0) { - barHeight = this.seriesLen * barHeight / nonZeroColumns; - } - - barYPosition = y + barHeight * this.visibleI; - barYPosition -= barHeight * zeroEncounters; - } else { - barYPosition = y + barHeight * this.visibleI; - } - } - - x = this.barHelpers.getXForValue(this.series[i][j], zeroW); - var paths = this.barHelpers.getBarpaths({ - barYPosition: barYPosition, - barHeight: barHeight, - x1: zeroW, - x2: x, - strokeWidth: strokeWidth, - series: this.series, - realIndex: indexes.realIndex, - i: i, - j: j, - w: w - }); - - if (!w.globals.isXNumeric) { - y = y + yDivision; - } - - this.barHelpers.barBackground({ - j: j, - i: i, - y1: barYPosition - barHeight * this.visibleI, - y2: barHeight * this.seriesLen, - elSeries: elSeries - }); - return { - pathTo: paths.pathTo, - pathFrom: paths.pathFrom, - x: x, - y: y, - goalX: this.barHelpers.getGoalValues('x', zeroW, null, i, j), - barYPosition: barYPosition, - barHeight: barHeight - }; - } - }, { - key: "drawColumnPaths", - value: function drawColumnPaths(_ref3) { - var indexes = _ref3.indexes, - x = _ref3.x, - y = _ref3.y, - xDivision = _ref3.xDivision, - barWidth = _ref3.barWidth, - zeroH = _ref3.zeroH, - strokeWidth = _ref3.strokeWidth, - elSeries = _ref3.elSeries; - var w = this.w; - var realIndex = indexes.realIndex; - var i = indexes.i; - var j = indexes.j; - var bc = indexes.bc; - var barXPosition; - - if (w.globals.isXNumeric) { - var sxI = realIndex; - - if (!w.globals.seriesX[realIndex].length) { - sxI = w.globals.maxValsInArrayIndex; - } - - if (w.globals.seriesX[sxI][j]) { - x = (w.globals.seriesX[sxI][j] - w.globals.minX) / this.xRatio - barWidth * this.seriesLen / 2; - } // re-calc barXPosition as x changed - - - barXPosition = x + barWidth * this.visibleI; - } else { - if (w.config.plotOptions.bar.hideZeroBarsWhenGrouped) { - var nonZeroColumns = 0; - var zeroEncounters = 0; - w.globals.seriesPercent.forEach(function (_s, _si) { - if (_s[j]) { - nonZeroColumns++; - } - - if (_si < i && _s[j] === 0) { - zeroEncounters++; - } - }); - - if (nonZeroColumns > 0) { - barWidth = this.seriesLen * barWidth / nonZeroColumns; - } - - barXPosition = x + barWidth * this.visibleI; - barXPosition -= barWidth * zeroEncounters; - } else { - barXPosition = x + barWidth * this.visibleI; - } - } - - y = this.barHelpers.getYForValue(this.series[i][j], zeroH); - var paths = this.barHelpers.getColumnPaths({ - barXPosition: barXPosition, - barWidth: barWidth, - y1: zeroH, - y2: y, - strokeWidth: strokeWidth, - series: this.series, - realIndex: indexes.realIndex, - i: i, - j: j, - w: w - }); - - if (!w.globals.isXNumeric) { - x = x + xDivision; - } - - this.barHelpers.barBackground({ - bc: bc, - j: j, - i: i, - x1: barXPosition - strokeWidth / 2 - barWidth * this.visibleI, - x2: barWidth * this.seriesLen + strokeWidth / 2, - elSeries: elSeries - }); - return { - pathTo: paths.pathTo, - pathFrom: paths.pathFrom, - x: x, - y: y, - goalY: this.barHelpers.getGoalValues('y', null, zeroH, i, j), - barXPosition: barXPosition, - barWidth: barWidth - }; - } - /** getPreviousPath is a common function for bars/columns which is used to get previous paths when data changes. - * @memberof Bar - * @param {int} realIndex - current iterating i - * @param {int} j - current iterating series's j index - * @return {string} pathFrom is the string which will be appended in animations - **/ - - }, { - key: "getPreviousPath", - value: function getPreviousPath(realIndex, j) { - var w = this.w; - var pathFrom; - - for (var pp = 0; pp < w.globals.previousPaths.length; pp++) { - var gpp = w.globals.previousPaths[pp]; - - if (gpp.paths && gpp.paths.length > 0 && parseInt(gpp.realIndex, 10) === parseInt(realIndex, 10)) { - if (typeof w.globals.previousPaths[pp].paths[j] !== 'undefined') { - pathFrom = w.globals.previousPaths[pp].paths[j].d; - } - } - } - - return pathFrom; - } - }]); - - return Bar; - }(); - - /** - * ApexCharts BarStacked Class responsible for drawing both Stacked Columns and Bars. - * - * @module BarStacked - * The whole calculation for stacked bar/column is different from normal bar/column, - * hence it makes sense to derive a new class for it extending most of the props of Parent Bar - **/ - - var BarStacked = /*#__PURE__*/function (_Bar) { - _inherits(BarStacked, _Bar); - - var _super = _createSuper(BarStacked); - - function BarStacked() { - _classCallCheck(this, BarStacked); - - return _super.apply(this, arguments); - } - - _createClass(BarStacked, [{ - key: "draw", - value: function draw(series, seriesIndex) { - var _this = this; - - var w = this.w; - this.graphics = new Graphics(this.ctx); - this.bar = new Bar(this.ctx, this.xyRatios); - var coreUtils = new CoreUtils(this.ctx, w); - series = coreUtils.getLogSeries(series); - this.yRatio = coreUtils.getLogYRatios(this.yRatio); - this.barHelpers.initVariables(series); - - if (w.config.chart.stackType === '100%') { - series = w.globals.seriesPercent.slice(); - } - - this.series = series; - this.barHelpers.initializeStackedPrevVars(this); - var ret = this.graphics.group({ - class: 'apexcharts-bar-series apexcharts-plot-series' - }); - var x = 0; - var y = 0; - - var _loop = function _loop(i, bc) { - var xDivision = void 0; // xDivision is the GRIDWIDTH divided by number of datapoints (columns) - - var yDivision = void 0; // yDivision is the GRIDHEIGHT divided by number of datapoints (bars) - - var zeroH = void 0; // zeroH is the baseline where 0 meets y axis - - var zeroW = void 0; // zeroW is the baseline where 0 meets x axis - - var groupIndex = -1; // groupIndex is the index of group buckets (group1, group2, ...) - - _this.groupCtx = _this; - w.globals.seriesGroups.forEach(function (group, gIndex) { - if (group.indexOf(w.config.series[i].name) > -1) { - groupIndex = gIndex; - } - }); - - if (groupIndex !== -1) { - _this.groupCtx = _this[w.globals.seriesGroups[groupIndex]]; - } - - var xArrValues = []; - var yArrValues = []; - var realIndex = w.globals.comboCharts ? seriesIndex[i] : i; - - if (_this.yRatio.length > 1) { - _this.yaxisIndex = realIndex; - } - - _this.isReversed = w.config.yaxis[_this.yaxisIndex] && w.config.yaxis[_this.yaxisIndex].reversed; // el to which series will be drawn - - var elSeries = _this.graphics.group({ - class: "apexcharts-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[realIndex]), - rel: i + 1, - 'data:realIndex': realIndex - }); - - _this.ctx.series.addCollapsedClassToSeries(elSeries, realIndex); // eldatalabels - - - var elDataLabelsWrap = _this.graphics.group({ - class: 'apexcharts-datalabels', - 'data:realIndex': realIndex - }); - - var elGoalsMarkers = _this.graphics.group({ - class: 'apexcharts-bar-goals-markers', - style: "pointer-events: none" - }); - - var barHeight = 0; - var barWidth = 0; - - var initPositions = _this.initialPositions(x, y, xDivision, yDivision, zeroH, zeroW); - - y = initPositions.y; - barHeight = initPositions.barHeight; - yDivision = initPositions.yDivision; - zeroW = initPositions.zeroW; - x = initPositions.x; - barWidth = initPositions.barWidth; - xDivision = initPositions.xDivision; - zeroH = initPositions.zeroH; - - _this.barHelpers.initializeStackedXYVars(_this); // where all stack bar disappear after collapsing the first series - - - if (_this.groupCtx.prevY.length === 1 && _this.groupCtx.prevY[0].every(function (val) { - return isNaN(val); - })) { - _this.groupCtx.prevY[0] = _this.groupCtx.prevY[0].map(function (val) { - return zeroH; - }); - _this.groupCtx.prevYF[0] = _this.groupCtx.prevYF[0].map(function (val) { - return 0; - }); - } - - for (var j = 0; j < w.globals.dataPoints; j++) { - var strokeWidth = _this.barHelpers.getStrokeWidth(i, j, realIndex); - - var commonPathOpts = { - indexes: { - i: i, - j: j, - realIndex: realIndex, - bc: bc - }, - strokeWidth: strokeWidth, - x: x, - y: y, - elSeries: elSeries, - groupIndex: groupIndex, - seriesGroup: w.globals.seriesGroups[groupIndex] - }; - var paths = null; - - if (_this.isHorizontal) { - paths = _this.drawStackedBarPaths(_objectSpread2(_objectSpread2({}, commonPathOpts), {}, { - zeroW: zeroW, - barHeight: barHeight, - yDivision: yDivision - })); - barWidth = _this.series[i][j] / _this.invertedYRatio; - } else { - paths = _this.drawStackedColumnPaths(_objectSpread2(_objectSpread2({}, commonPathOpts), {}, { - xDivision: xDivision, - barWidth: barWidth, - zeroH: zeroH - })); - barHeight = _this.series[i][j] / _this.yRatio[_this.yaxisIndex]; - } - - var barGoalLine = _this.barHelpers.drawGoalLine({ - barXPosition: paths.barXPosition, - barYPosition: paths.barYPosition, - goalX: paths.goalX, - goalY: paths.goalY, - barHeight: barHeight, - barWidth: barWidth - }); - - if (barGoalLine) { - elGoalsMarkers.add(barGoalLine); - } - - y = paths.y; - x = paths.x; - xArrValues.push(x); - yArrValues.push(y); - - var pathFill = _this.barHelpers.getPathFillColor(series, i, j, realIndex); - - elSeries = _this.renderSeries({ - realIndex: realIndex, - pathFill: pathFill, - j: j, - i: i, - groupIndex: groupIndex, - pathFrom: paths.pathFrom, - pathTo: paths.pathTo, - strokeWidth: strokeWidth, - elSeries: elSeries, - x: x, - y: y, - series: series, - barHeight: barHeight, - barWidth: barWidth, - elDataLabelsWrap: elDataLabelsWrap, - elGoalsMarkers: elGoalsMarkers, - type: 'bar', - visibleSeries: 0 - }); - } // push all x val arrays into main xArr - - - w.globals.seriesXvalues[realIndex] = xArrValues; - w.globals.seriesYvalues[realIndex] = yArrValues; // push all current y values array to main PrevY Array - - _this.groupCtx.prevY.push(_this.groupCtx.yArrj); - - _this.groupCtx.prevYF.push(_this.groupCtx.yArrjF); - - _this.groupCtx.prevYVal.push(_this.groupCtx.yArrjVal); - - _this.groupCtx.prevX.push(_this.groupCtx.xArrj); - - _this.groupCtx.prevXF.push(_this.groupCtx.xArrjF); - - _this.groupCtx.prevXVal.push(_this.groupCtx.xArrjVal); - - ret.add(elSeries); - }; - - for (var i = 0, bc = 0; i < series.length; i++, bc++) { - _loop(i, bc); - } - - return ret; - } - }, { - key: "initialPositions", - value: function initialPositions(x, y, xDivision, yDivision, zeroH, zeroW) { - var w = this.w; - var barHeight, barWidth; - - if (this.isHorizontal) { - var _w$globals$seriesGrou; - - // height divided into equal parts - yDivision = w.globals.gridHeight / w.globals.dataPoints; - barHeight = yDivision; - barHeight = barHeight * parseInt(w.config.plotOptions.bar.barHeight, 10) / 100; - - if ((_w$globals$seriesGrou = w.globals.seriesGroups) !== null && _w$globals$seriesGrou !== void 0 && _w$globals$seriesGrou.length) { - barHeight = barHeight / w.globals.seriesGroups.length; - } - - if (String(w.config.plotOptions.bar.barHeight).indexOf('%') === -1) { - barHeight = parseInt(w.config.plotOptions.bar.barHeight, 10); - } - - zeroW = this.baseLineInvertedY + w.globals.padHorizontal + (this.isReversed ? w.globals.gridWidth : 0) - (this.isReversed ? this.baseLineInvertedY * 2 : 0); // initial y position is half of barHeight * half of number of Bars - - y = (yDivision - barHeight) / 2; - } else { - var _w$globals$seriesGrou2; - - // width divided into equal parts - xDivision = w.globals.gridWidth / w.globals.dataPoints; - barWidth = xDivision; - - if (w.globals.isXNumeric && w.globals.dataPoints > 1) { - // the check (w.globals.dataPoints > 1) fixes apexcharts.js #1617 - xDivision = w.globals.minXDiff / this.xRatio; - barWidth = xDivision * parseInt(this.barOptions.columnWidth, 10) / 100; - } else { - barWidth = barWidth * parseInt(w.config.plotOptions.bar.columnWidth, 10) / 100; - } - - if ((_w$globals$seriesGrou2 = w.globals.seriesGroups) !== null && _w$globals$seriesGrou2 !== void 0 && _w$globals$seriesGrou2.length) { - barWidth = barWidth / w.globals.seriesGroups.length; - } - - if (String(w.config.plotOptions.bar.columnWidth).indexOf('%') === -1) { - barWidth = parseInt(w.config.plotOptions.bar.columnWidth, 10); - } - - zeroH = w.globals.gridHeight - this.baseLineY[this.yaxisIndex] - (this.isReversed ? w.globals.gridHeight : 0) + (this.isReversed ? this.baseLineY[this.yaxisIndex] * 2 : 0); // initial x position is one third of barWidth - - x = w.globals.padHorizontal + (xDivision - barWidth) / 2; - } - - return { - x: x, - y: y, - yDivision: yDivision, - xDivision: xDivision, - barHeight: barHeight, - barWidth: barWidth, - zeroH: zeroH, - zeroW: zeroW - }; - } - }, { - key: "drawStackedBarPaths", - value: function drawStackedBarPaths(_ref) { - var indexes = _ref.indexes, - barHeight = _ref.barHeight, - strokeWidth = _ref.strokeWidth, - zeroW = _ref.zeroW, - x = _ref.x, - y = _ref.y, - groupIndex = _ref.groupIndex, - seriesGroup = _ref.seriesGroup, - yDivision = _ref.yDivision, - elSeries = _ref.elSeries; - var w = this.w; - var barYPosition = y + (groupIndex !== -1 ? groupIndex * barHeight : 0); - var barXPosition; - var i = indexes.i; - var j = indexes.j; - var prevBarW = 0; - - for (var k = 0; k < this.groupCtx.prevXF.length; k++) { - prevBarW = prevBarW + this.groupCtx.prevXF[k][j]; - } - - var gsi = i; // an index to keep track of the series inside a group - - if (seriesGroup) { - gsi = seriesGroup.indexOf(w.config.series[i].name); - } - - if (gsi > 0) { - var bXP = zeroW; - - if (this.groupCtx.prevXVal[gsi - 1][j] < 0) { - bXP = this.series[i][j] >= 0 ? this.groupCtx.prevX[gsi - 1][j] + prevBarW - (this.isReversed ? prevBarW : 0) * 2 : this.groupCtx.prevX[gsi - 1][j]; - } else if (this.groupCtx.prevXVal[gsi - 1][j] >= 0) { - bXP = this.series[i][j] >= 0 ? this.groupCtx.prevX[gsi - 1][j] : this.groupCtx.prevX[gsi - 1][j] - prevBarW + (this.isReversed ? prevBarW : 0) * 2; - } - - barXPosition = bXP; - } else { - // the first series will not have prevX values - barXPosition = zeroW; - } - - if (this.series[i][j] === null) { - x = barXPosition; - } else { - x = barXPosition + this.series[i][j] / this.invertedYRatio - (this.isReversed ? this.series[i][j] / this.invertedYRatio : 0) * 2; - } - - var paths = this.barHelpers.getBarpaths({ - barYPosition: barYPosition, - barHeight: barHeight, - x1: barXPosition, - x2: x, - strokeWidth: strokeWidth, - series: this.series, - realIndex: indexes.realIndex, - seriesGroup: seriesGroup, - i: i, - j: j, - w: w - }); - this.barHelpers.barBackground({ - j: j, - i: i, - y1: barYPosition, - y2: barHeight, - elSeries: elSeries - }); - y = y + yDivision; - return { - pathTo: paths.pathTo, - pathFrom: paths.pathFrom, - goalX: this.barHelpers.getGoalValues('x', zeroW, null, i, j), - barYPosition: barYPosition, - x: x, - y: y - }; - } - }, { - key: "drawStackedColumnPaths", - value: function drawStackedColumnPaths(_ref2) { - var indexes = _ref2.indexes, - x = _ref2.x, - y = _ref2.y, - xDivision = _ref2.xDivision, - barWidth = _ref2.barWidth, - zeroH = _ref2.zeroH, - groupIndex = _ref2.groupIndex, - seriesGroup = _ref2.seriesGroup, - elSeries = _ref2.elSeries; - var w = this.w; - var i = indexes.i; - var j = indexes.j; - var bc = indexes.bc; - - if (w.globals.isXNumeric) { - var seriesVal = w.globals.seriesX[i][j]; - if (!seriesVal) seriesVal = 0; - x = (seriesVal - w.globals.minX) / this.xRatio - barWidth / 2; - - if (w.globals.seriesGroups.length) { - x = (seriesVal - w.globals.minX) / this.xRatio - barWidth / 2 * w.globals.seriesGroups.length; - } - } - - var barXPosition = x + (groupIndex !== -1 ? groupIndex * barWidth : 0); - var barYPosition; - var prevBarH = 0; - - for (var k = 0; k < this.groupCtx.prevYF.length; k++) { - // fix issue #1215 - // in case where this.groupCtx.prevYF[k][j] is NaN, use 0 instead - prevBarH = prevBarH + (!isNaN(this.groupCtx.prevYF[k][j]) ? this.groupCtx.prevYF[k][j] : 0); - } - - var gsi = i; // an index to keep track of the series inside a group - - if (seriesGroup) { - gsi = seriesGroup.indexOf(w.config.series[i].name); - } - - if (gsi > 0 && !w.globals.isXNumeric || gsi > 0 && w.globals.isXNumeric && w.globals.seriesX[i - 1][j] === w.globals.seriesX[i][j]) { - var _this$groupCtx$prevYF; - - var bYP; - var prevYValue; - var p = Math.min(this.yRatio.length + 1, i + 1); - - if (this.groupCtx.prevY[gsi - 1] !== undefined && this.groupCtx.prevY[gsi - 1].length) { - for (var ii = 1; ii < p; ii++) { - var _this$groupCtx$prevY; - - if (!isNaN((_this$groupCtx$prevY = this.groupCtx.prevY[gsi - ii]) === null || _this$groupCtx$prevY === void 0 ? void 0 : _this$groupCtx$prevY[j])) { - // find the previous available value to give prevYValue - prevYValue = this.groupCtx.prevY[gsi - ii][j]; // if found it, break the loop - - break; - } - } - } - - for (var _ii = 1; _ii < p; _ii++) { - var _this$groupCtx$prevYV, _this$groupCtx$prevYV2; - - // find the previous available value(non-NaN) to give bYP - if (((_this$groupCtx$prevYV = this.groupCtx.prevYVal[gsi - _ii]) === null || _this$groupCtx$prevYV === void 0 ? void 0 : _this$groupCtx$prevYV[j]) < 0) { - bYP = this.series[i][j] >= 0 ? prevYValue - prevBarH + (this.isReversed ? prevBarH : 0) * 2 : prevYValue; // found it? break the loop - - break; - } else if (((_this$groupCtx$prevYV2 = this.groupCtx.prevYVal[gsi - _ii]) === null || _this$groupCtx$prevYV2 === void 0 ? void 0 : _this$groupCtx$prevYV2[j]) >= 0) { - bYP = this.series[i][j] >= 0 ? prevYValue : prevYValue + prevBarH - (this.isReversed ? prevBarH : 0) * 2; // found it? break the loop - - break; - } - } - - if (typeof bYP === 'undefined') bYP = w.globals.gridHeight; // if this.prevYF[0] is all 0 resulted from line #486 - // AND every arr starting from the second only contains NaN - - if ((_this$groupCtx$prevYF = this.groupCtx.prevYF[0]) !== null && _this$groupCtx$prevYF !== void 0 && _this$groupCtx$prevYF.every(function (val) { - return val === 0; - }) && this.groupCtx.prevYF.slice(1, gsi).every(function (arr) { - return arr.every(function (val) { - return isNaN(val); - }); - })) { - barYPosition = zeroH; - } else { - // Nothing special - barYPosition = bYP; - } - } else { - // the first series will not have prevY values, also if the prev index's series X doesn't matches the current index's series X, then start from zero - barYPosition = zeroH; - } - - if (this.series[i][j]) { - y = barYPosition - this.series[i][j] / this.yRatio[this.yaxisIndex] + (this.isReversed ? this.series[i][j] / this.yRatio[this.yaxisIndex] : 0) * 2; - } else { - // fixes #3610 - y = barYPosition; - } - - var paths = this.barHelpers.getColumnPaths({ - barXPosition: barXPosition, - barWidth: barWidth, - y1: barYPosition, - y2: y, - yRatio: this.yRatio[this.yaxisIndex], - strokeWidth: this.strokeWidth, - series: this.series, - seriesGroup: seriesGroup, - realIndex: indexes.realIndex, - i: i, - j: j, - w: w - }); - this.barHelpers.barBackground({ - bc: bc, - j: j, - i: i, - x1: barXPosition, - x2: barWidth, - elSeries: elSeries - }); - x = x + xDivision; - return { - pathTo: paths.pathTo, - pathFrom: paths.pathFrom, - goalY: this.barHelpers.getGoalValues('y', null, zeroH, i, j), - barXPosition: barXPosition, - x: w.globals.isXNumeric ? x - xDivision : x, - y: y - }; - } - }]); - - return BarStacked; - }(Bar); - - /** - * ApexCharts BoxCandleStick Class responsible for drawing both Stacked Columns and Bars. - * - * @module BoxCandleStick - **/ - - var BoxCandleStick = /*#__PURE__*/function (_Bar) { - _inherits(BoxCandleStick, _Bar); - - var _super = _createSuper(BoxCandleStick); - - function BoxCandleStick() { - _classCallCheck(this, BoxCandleStick); - - return _super.apply(this, arguments); - } - - _createClass(BoxCandleStick, [{ - key: "draw", - value: function draw(series, ctype, seriesIndex) { - var _this = this; - - var w = this.w; - var graphics = new Graphics(this.ctx); - var type = w.globals.comboCharts ? ctype : w.config.chart.type; - var fill = new Fill(this.ctx); - this.candlestickOptions = this.w.config.plotOptions.candlestick; - this.boxOptions = this.w.config.plotOptions.boxPlot; - this.isHorizontal = w.config.plotOptions.bar.horizontal; - var coreUtils = new CoreUtils(this.ctx, w); - series = coreUtils.getLogSeries(series); - this.series = series; - this.yRatio = coreUtils.getLogYRatios(this.yRatio); - this.barHelpers.initVariables(series); - var ret = graphics.group({ - class: "apexcharts-".concat(type, "-series apexcharts-plot-series") - }); - - var _loop = function _loop(i) { - _this.isBoxPlot = w.config.chart.type === 'boxPlot' || w.config.series[i].type === 'boxPlot'; - var x = void 0, - y = void 0, - xDivision = void 0, - // xDivision is the GRIDWIDTH divided by number of datapoints (columns) - yDivision = void 0, - // yDivision is the GRIDHEIGHT divided by number of datapoints (bars) - zeroH = void 0, - // zeroH is the baseline where 0 meets y axis - zeroW = void 0; // zeroW is the baseline where 0 meets x axis - - var yArrj = []; // hold y values of current iterating series - - var xArrj = []; // hold x values of current iterating series - - var realIndex = w.globals.comboCharts ? seriesIndex[i] : i; // el to which series will be drawn - - var elSeries = graphics.group({ - class: "apexcharts-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[realIndex]), - rel: i + 1, - 'data:realIndex': realIndex - }); - - _this.ctx.series.addCollapsedClassToSeries(elSeries, realIndex); - - if (series[i].length > 0) { - _this.visibleI = _this.visibleI + 1; - } - - var barHeight = 0; - var barWidth = 0; - - if (_this.yRatio.length > 1) { - _this.yaxisIndex = realIndex; - } - - var initPositions = _this.barHelpers.initialPositions(); - - y = initPositions.y; - barHeight = initPositions.barHeight; - yDivision = initPositions.yDivision; - zeroW = initPositions.zeroW; - x = initPositions.x; - barWidth = initPositions.barWidth; - xDivision = initPositions.xDivision; - zeroH = initPositions.zeroH; - xArrj.push(x + barWidth / 2); // eldatalabels - - var elDataLabelsWrap = graphics.group({ - class: 'apexcharts-datalabels', - 'data:realIndex': realIndex - }); - - var _loop2 = function _loop2(j) { - var strokeWidth = _this.barHelpers.getStrokeWidth(i, j, realIndex); - - var paths = null; - var pathsParams = { - indexes: { - i: i, - j: j, - realIndex: realIndex - }, - x: x, - y: y, - strokeWidth: strokeWidth, - elSeries: elSeries - }; - - if (_this.isHorizontal) { - paths = _this.drawHorizontalBoxPaths(_objectSpread2(_objectSpread2({}, pathsParams), {}, { - yDivision: yDivision, - barHeight: barHeight, - zeroW: zeroW - })); - } else { - paths = _this.drawVerticalBoxPaths(_objectSpread2(_objectSpread2({}, pathsParams), {}, { - xDivision: xDivision, - barWidth: barWidth, - zeroH: zeroH - })); - } - - y = paths.y; - x = paths.x; // push current X - - if (j > 0) { - xArrj.push(x + barWidth / 2); - } - - yArrj.push(y); - paths.pathTo.forEach(function (pathTo, pi) { - var lineFill = !_this.isBoxPlot && _this.candlestickOptions.wick.useFillColor ? paths.color[pi] : w.globals.stroke.colors[i]; - var pathFill = fill.fillPath({ - seriesNumber: realIndex, - dataPointIndex: j, - color: paths.color[pi], - value: series[i][j] - }); - - _this.renderSeries({ - realIndex: realIndex, - pathFill: pathFill, - lineFill: lineFill, - j: j, - i: i, - pathFrom: paths.pathFrom, - pathTo: pathTo, - strokeWidth: strokeWidth, - elSeries: elSeries, - x: x, - y: y, - series: series, - barHeight: barHeight, - barWidth: barWidth, - elDataLabelsWrap: elDataLabelsWrap, - visibleSeries: _this.visibleI, - type: w.config.chart.type - }); - }); - }; - - for (var j = 0; j < w.globals.dataPoints; j++) { - _loop2(j); - } // push all x val arrays into main xArr - - - w.globals.seriesXvalues[realIndex] = xArrj; - w.globals.seriesYvalues[realIndex] = yArrj; - ret.add(elSeries); - }; - - for (var i = 0; i < series.length; i++) { - _loop(i); - } - - return ret; - } - }, { - key: "drawVerticalBoxPaths", - value: function drawVerticalBoxPaths(_ref) { - var indexes = _ref.indexes, - x = _ref.x; - _ref.y; - var xDivision = _ref.xDivision, - barWidth = _ref.barWidth, - zeroH = _ref.zeroH, - strokeWidth = _ref.strokeWidth; - var w = this.w; - var graphics = new Graphics(this.ctx); - var i = indexes.i; - var j = indexes.j; - var isPositive = true; - var colorPos = w.config.plotOptions.candlestick.colors.upward; - var colorNeg = w.config.plotOptions.candlestick.colors.downward; - var color = ''; - - if (this.isBoxPlot) { - color = [this.boxOptions.colors.lower, this.boxOptions.colors.upper]; - } - - var yRatio = this.yRatio[this.yaxisIndex]; - var realIndex = indexes.realIndex; - var ohlc = this.getOHLCValue(realIndex, j); - var l1 = zeroH; - var l2 = zeroH; - - if (ohlc.o > ohlc.c) { - isPositive = false; - } - - var y1 = Math.min(ohlc.o, ohlc.c); - var y2 = Math.max(ohlc.o, ohlc.c); - var m = ohlc.m; - - if (w.globals.isXNumeric) { - x = (w.globals.seriesX[realIndex][j] - w.globals.minX) / this.xRatio - barWidth / 2; - } - - var barXPosition = x + barWidth * this.visibleI; - - if (typeof this.series[i][j] === 'undefined' || this.series[i][j] === null) { - y1 = zeroH; - y2 = zeroH; - } else { - y1 = zeroH - y1 / yRatio; - y2 = zeroH - y2 / yRatio; - l1 = zeroH - ohlc.h / yRatio; - l2 = zeroH - ohlc.l / yRatio; - m = zeroH - ohlc.m / yRatio; - } - - var pathTo = graphics.move(barXPosition, zeroH); - var pathFrom = graphics.move(barXPosition + barWidth / 2, y1); - - if (w.globals.previousPaths.length > 0) { - pathFrom = this.getPreviousPath(realIndex, j, true); - } - - if (this.isBoxPlot) { - pathTo = [graphics.move(barXPosition, y1) + graphics.line(barXPosition + barWidth / 2, y1) + graphics.line(barXPosition + barWidth / 2, l1) + graphics.line(barXPosition + barWidth / 4, l1) + graphics.line(barXPosition + barWidth - barWidth / 4, l1) + graphics.line(barXPosition + barWidth / 2, l1) + graphics.line(barXPosition + barWidth / 2, y1) + graphics.line(barXPosition + barWidth, y1) + graphics.line(barXPosition + barWidth, m) + graphics.line(barXPosition, m) + graphics.line(barXPosition, y1 + strokeWidth / 2), graphics.move(barXPosition, m) + graphics.line(barXPosition + barWidth, m) + graphics.line(barXPosition + barWidth, y2) + graphics.line(barXPosition + barWidth / 2, y2) + graphics.line(barXPosition + barWidth / 2, l2) + graphics.line(barXPosition + barWidth - barWidth / 4, l2) + graphics.line(barXPosition + barWidth / 4, l2) + graphics.line(barXPosition + barWidth / 2, l2) + graphics.line(barXPosition + barWidth / 2, y2) + graphics.line(barXPosition, y2) + graphics.line(barXPosition, m) + 'z']; - } else { - // candlestick - pathTo = [graphics.move(barXPosition, y2) + graphics.line(barXPosition + barWidth / 2, y2) + graphics.line(barXPosition + barWidth / 2, l1) + graphics.line(barXPosition + barWidth / 2, y2) + graphics.line(barXPosition + barWidth, y2) + graphics.line(barXPosition + barWidth, y1) + graphics.line(barXPosition + barWidth / 2, y1) + graphics.line(barXPosition + barWidth / 2, l2) + graphics.line(barXPosition + barWidth / 2, y1) + graphics.line(barXPosition, y1) + graphics.line(barXPosition, y2 - strokeWidth / 2)]; - } - - pathFrom = pathFrom + graphics.move(barXPosition, y1); - - if (!w.globals.isXNumeric) { - x = x + xDivision; - } - - return { - pathTo: pathTo, - pathFrom: pathFrom, - x: x, - y: y2, - barXPosition: barXPosition, - color: this.isBoxPlot ? color : isPositive ? [colorPos] : [colorNeg] - }; - } - }, { - key: "drawHorizontalBoxPaths", - value: function drawHorizontalBoxPaths(_ref2) { - var indexes = _ref2.indexes; - _ref2.x; - var y = _ref2.y, - yDivision = _ref2.yDivision, - barHeight = _ref2.barHeight, - zeroW = _ref2.zeroW, - strokeWidth = _ref2.strokeWidth; - var w = this.w; - var graphics = new Graphics(this.ctx); - var i = indexes.i; - var j = indexes.j; - var color = this.boxOptions.colors.lower; - - if (this.isBoxPlot) { - color = [this.boxOptions.colors.lower, this.boxOptions.colors.upper]; - } - - var yRatio = this.invertedYRatio; - var realIndex = indexes.realIndex; - var ohlc = this.getOHLCValue(realIndex, j); - var l1 = zeroW; - var l2 = zeroW; - var x1 = Math.min(ohlc.o, ohlc.c); - var x2 = Math.max(ohlc.o, ohlc.c); - var m = ohlc.m; - - if (w.globals.isXNumeric) { - y = (w.globals.seriesX[realIndex][j] - w.globals.minX) / this.invertedXRatio - barHeight / 2; - } - - var barYPosition = y + barHeight * this.visibleI; - - if (typeof this.series[i][j] === 'undefined' || this.series[i][j] === null) { - x1 = zeroW; - x2 = zeroW; - } else { - x1 = zeroW + x1 / yRatio; - x2 = zeroW + x2 / yRatio; - l1 = zeroW + ohlc.h / yRatio; - l2 = zeroW + ohlc.l / yRatio; - m = zeroW + ohlc.m / yRatio; - } - - var pathTo = graphics.move(zeroW, barYPosition); - var pathFrom = graphics.move(x1, barYPosition + barHeight / 2); - - if (w.globals.previousPaths.length > 0) { - pathFrom = this.getPreviousPath(realIndex, j, true); - } - - pathTo = [graphics.move(x1, barYPosition) + graphics.line(x1, barYPosition + barHeight / 2) + graphics.line(l1, barYPosition + barHeight / 2) + graphics.line(l1, barYPosition + barHeight / 2 - barHeight / 4) + graphics.line(l1, barYPosition + barHeight / 2 + barHeight / 4) + graphics.line(l1, barYPosition + barHeight / 2) + graphics.line(x1, barYPosition + barHeight / 2) + graphics.line(x1, barYPosition + barHeight) + graphics.line(m, barYPosition + barHeight) + graphics.line(m, barYPosition) + graphics.line(x1 + strokeWidth / 2, barYPosition), graphics.move(m, barYPosition) + graphics.line(m, barYPosition + barHeight) + graphics.line(x2, barYPosition + barHeight) + graphics.line(x2, barYPosition + barHeight / 2) + graphics.line(l2, barYPosition + barHeight / 2) + graphics.line(l2, barYPosition + barHeight - barHeight / 4) + graphics.line(l2, barYPosition + barHeight / 4) + graphics.line(l2, barYPosition + barHeight / 2) + graphics.line(x2, barYPosition + barHeight / 2) + graphics.line(x2, barYPosition) + graphics.line(m, barYPosition) + 'z']; - pathFrom = pathFrom + graphics.move(x1, barYPosition); - - if (!w.globals.isXNumeric) { - y = y + yDivision; - } - - return { - pathTo: pathTo, - pathFrom: pathFrom, - x: x2, - y: y, - barYPosition: barYPosition, - color: color - }; - } - }, { - key: "getOHLCValue", - value: function getOHLCValue(i, j) { - var w = this.w; - return { - o: this.isBoxPlot ? w.globals.seriesCandleH[i][j] : w.globals.seriesCandleO[i][j], - h: this.isBoxPlot ? w.globals.seriesCandleO[i][j] : w.globals.seriesCandleH[i][j], - m: w.globals.seriesCandleM[i][j], - l: this.isBoxPlot ? w.globals.seriesCandleC[i][j] : w.globals.seriesCandleL[i][j], - c: this.isBoxPlot ? w.globals.seriesCandleL[i][j] : w.globals.seriesCandleC[i][j] - }; - } - }]); - - return BoxCandleStick; - }(Bar); - - var TreemapHelpers = /*#__PURE__*/function () { - function TreemapHelpers(ctx) { - _classCallCheck(this, TreemapHelpers); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(TreemapHelpers, [{ - key: "checkColorRange", - value: function checkColorRange() { - var w = this.w; - var negRange = false; - var chartOpts = w.config.plotOptions[w.config.chart.type]; - - if (chartOpts.colorScale.ranges.length > 0) { - chartOpts.colorScale.ranges.map(function (range, index) { - if (range.from <= 0) { - negRange = true; - } - }); - } - - return negRange; - } - }, { - key: "getShadeColor", - value: function getShadeColor(chartType, i, j, negRange) { - var w = this.w; - var colorShadePercent = 1; - var shadeIntensity = w.config.plotOptions[chartType].shadeIntensity; - var colorProps = this.determineColor(chartType, i, j); - - if (w.globals.hasNegs || negRange) { - if (w.config.plotOptions[chartType].reverseNegativeShade) { - if (colorProps.percent < 0) { - colorShadePercent = colorProps.percent / 100 * (shadeIntensity * 1.25); - } else { - colorShadePercent = (1 - colorProps.percent / 100) * (shadeIntensity * 1.25); - } - } else { - if (colorProps.percent <= 0) { - colorShadePercent = 1 - (1 + colorProps.percent / 100) * shadeIntensity; - } else { - colorShadePercent = (1 - colorProps.percent / 100) * shadeIntensity; - } - } - } else { - colorShadePercent = 1 - colorProps.percent / 100; - - if (chartType === 'treemap') { - colorShadePercent = (1 - colorProps.percent / 100) * (shadeIntensity * 1.25); - } - } - - var color = colorProps.color; - var utils = new Utils$1(); - - if (w.config.plotOptions[chartType].enableShades) { - if (this.w.config.theme.mode === 'dark') { - color = Utils$1.hexToRgba(utils.shadeColor(colorShadePercent * -1, colorProps.color), w.config.fill.opacity); - } else { - color = Utils$1.hexToRgba(utils.shadeColor(colorShadePercent, colorProps.color), w.config.fill.opacity); - } - } - - return { - color: color, - colorProps: colorProps - }; - } - }, { - key: "determineColor", - value: function determineColor(chartType, i, j) { - var w = this.w; - var val = w.globals.series[i][j]; - var chartOpts = w.config.plotOptions[chartType]; - var seriesNumber = chartOpts.colorScale.inverse ? j : i; - - if (chartOpts.distributed && w.config.chart.type === 'treemap') { - seriesNumber = j; - } - - var color = w.globals.colors[seriesNumber]; - var foreColor = null; - var min = Math.min.apply(Math, _toConsumableArray(w.globals.series[i])); - var max = Math.max.apply(Math, _toConsumableArray(w.globals.series[i])); - - if (!chartOpts.distributed && chartType === 'heatmap') { - min = w.globals.minY; - max = w.globals.maxY; - } - - if (typeof chartOpts.colorScale.min !== 'undefined') { - min = chartOpts.colorScale.min < w.globals.minY ? chartOpts.colorScale.min : w.globals.minY; - max = chartOpts.colorScale.max > w.globals.maxY ? chartOpts.colorScale.max : w.globals.maxY; - } - - var total = Math.abs(max) + Math.abs(min); - var percent = 100 * val / (total === 0 ? total - 0.000001 : total); - - if (chartOpts.colorScale.ranges.length > 0) { - var colorRange = chartOpts.colorScale.ranges; - colorRange.map(function (range, index) { - if (val >= range.from && val <= range.to) { - color = range.color; - foreColor = range.foreColor ? range.foreColor : null; - min = range.from; - max = range.to; - var rTotal = Math.abs(max) + Math.abs(min); - percent = 100 * val / (rTotal === 0 ? rTotal - 0.000001 : rTotal); - } - }); - } - - return { - color: color, - foreColor: foreColor, - percent: percent - }; - } - }, { - key: "calculateDataLabels", - value: function calculateDataLabels(_ref) { - var text = _ref.text, - x = _ref.x, - y = _ref.y, - i = _ref.i, - j = _ref.j, - colorProps = _ref.colorProps, - fontSize = _ref.fontSize; - var w = this.w; - var dataLabelsConfig = w.config.dataLabels; - var graphics = new Graphics(this.ctx); - var dataLabels = new DataLabels(this.ctx); - var elDataLabelsWrap = null; - - if (dataLabelsConfig.enabled) { - elDataLabelsWrap = graphics.group({ - class: 'apexcharts-data-labels' - }); - var offX = dataLabelsConfig.offsetX; - var offY = dataLabelsConfig.offsetY; - var dataLabelsX = x + offX; - var dataLabelsY = y + parseFloat(dataLabelsConfig.style.fontSize) / 3 + offY; - dataLabels.plotDataLabelsText({ - x: dataLabelsX, - y: dataLabelsY, - text: text, - i: i, - j: j, - color: colorProps.foreColor, - parent: elDataLabelsWrap, - fontSize: fontSize, - dataLabelsConfig: dataLabelsConfig - }); - } - - return elDataLabelsWrap; - } - }, { - key: "addListeners", - value: function addListeners(elRect) { - var graphics = new Graphics(this.ctx); - elRect.node.addEventListener('mouseenter', graphics.pathMouseEnter.bind(this, elRect)); - elRect.node.addEventListener('mouseleave', graphics.pathMouseLeave.bind(this, elRect)); - elRect.node.addEventListener('mousedown', graphics.pathMouseDown.bind(this, elRect)); - } - }]); - - return TreemapHelpers; - }(); - - /** - * ApexCharts HeatMap Class. - * @module HeatMap - **/ - - var HeatMap = /*#__PURE__*/function () { - function HeatMap(ctx, xyRatios) { - _classCallCheck(this, HeatMap); - - this.ctx = ctx; - this.w = ctx.w; - this.xRatio = xyRatios.xRatio; - this.yRatio = xyRatios.yRatio; - this.dynamicAnim = this.w.config.chart.animations.dynamicAnimation; - this.helpers = new TreemapHelpers(ctx); - this.rectRadius = this.w.config.plotOptions.heatmap.radius; - this.strokeWidth = this.w.config.stroke.show ? this.w.config.stroke.width : 0; - } - - _createClass(HeatMap, [{ - key: "draw", - value: function draw(series) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var ret = graphics.group({ - class: 'apexcharts-heatmap' - }); - ret.attr('clip-path', "url(#gridRectMask".concat(w.globals.cuid, ")")); // width divided into equal parts - - var xDivision = w.globals.gridWidth / w.globals.dataPoints; - var yDivision = w.globals.gridHeight / w.globals.series.length; - var y1 = 0; - var rev = false; - this.negRange = this.helpers.checkColorRange(); - var heatSeries = series.slice(); - - if (w.config.yaxis[0].reversed) { - rev = true; - heatSeries.reverse(); - } - - for (var i = rev ? 0 : heatSeries.length - 1; rev ? i < heatSeries.length : i >= 0; rev ? i++ : i--) { - // el to which series will be drawn - var elSeries = graphics.group({ - class: "apexcharts-series apexcharts-heatmap-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[i]), - rel: i + 1, - 'data:realIndex': i - }); - this.ctx.series.addCollapsedClassToSeries(elSeries, i); - - if (w.config.chart.dropShadow.enabled) { - var shadow = w.config.chart.dropShadow; - var filters = new Filters(this.ctx); - filters.dropShadow(elSeries, shadow, i); - } - - var x1 = 0; - var shadeIntensity = w.config.plotOptions.heatmap.shadeIntensity; - - for (var j = 0; j < heatSeries[i].length; j++) { - var heatColor = this.helpers.getShadeColor(w.config.chart.type, i, j, this.negRange); - var color = heatColor.color; - var heatColorProps = heatColor.colorProps; - - if (w.config.fill.type === 'image') { - var fill = new Fill(this.ctx); - color = fill.fillPath({ - seriesNumber: i, - dataPointIndex: j, - opacity: w.globals.hasNegs ? heatColorProps.percent < 0 ? 1 - (1 + heatColorProps.percent / 100) : shadeIntensity + heatColorProps.percent / 100 : heatColorProps.percent / 100, - patternID: Utils$1.randomId(), - width: w.config.fill.image.width ? w.config.fill.image.width : xDivision, - height: w.config.fill.image.height ? w.config.fill.image.height : yDivision - }); - } - - var radius = this.rectRadius; - var rect = graphics.drawRect(x1, y1, xDivision, yDivision, radius); - rect.attr({ - cx: x1, - cy: y1 - }); - rect.node.classList.add('apexcharts-heatmap-rect'); - elSeries.add(rect); - rect.attr({ - fill: color, - i: i, - index: i, - j: j, - val: heatSeries[i][j], - 'stroke-width': this.strokeWidth, - stroke: w.config.plotOptions.heatmap.useFillColorAsStroke ? color : w.globals.stroke.colors[0], - color: color - }); - this.helpers.addListeners(rect); - - if (w.config.chart.animations.enabled && !w.globals.dataChanged) { - var speed = 1; - - if (!w.globals.resized) { - speed = w.config.chart.animations.speed; - } - - this.animateHeatMap(rect, x1, y1, xDivision, yDivision, speed); - } - - if (w.globals.dataChanged) { - var _speed = 1; - - if (this.dynamicAnim.enabled && w.globals.shouldAnimate) { - _speed = this.dynamicAnim.speed; - var colorFrom = w.globals.previousPaths[i] && w.globals.previousPaths[i][j] && w.globals.previousPaths[i][j].color; - if (!colorFrom) colorFrom = 'rgba(255, 255, 255, 0)'; - this.animateHeatColor(rect, Utils$1.isColorHex(colorFrom) ? colorFrom : Utils$1.rgb2hex(colorFrom), Utils$1.isColorHex(color) ? color : Utils$1.rgb2hex(color), _speed); - } - } - - var formatter = w.config.dataLabels.formatter; - var formattedText = formatter(w.globals.series[i][j], { - value: w.globals.series[i][j], - seriesIndex: i, - dataPointIndex: j, - w: w - }); - var dataLabels = this.helpers.calculateDataLabels({ - text: formattedText, - x: x1 + xDivision / 2, - y: y1 + yDivision / 2, - i: i, - j: j, - colorProps: heatColorProps, - series: heatSeries - }); - - if (dataLabels !== null) { - elSeries.add(dataLabels); - } - - x1 = x1 + xDivision; - } - - y1 = y1 + yDivision; - ret.add(elSeries); - } // adjust yaxis labels for heatmap - - - var yAxisScale = w.globals.yAxisScale[0].result.slice(); - - if (w.config.yaxis[0].reversed) { - yAxisScale.unshift(''); - } else { - yAxisScale.push(''); - } - - w.globals.yAxisScale[0].result = yAxisScale; - var divisor = w.globals.gridHeight / w.globals.series.length; - w.config.yaxis[0].labels.offsetY = -(divisor / 2); - return ret; - } - }, { - key: "animateHeatMap", - value: function animateHeatMap(el, x, y, width, height, speed) { - var animations = new Animations(this.ctx); - animations.animateRect(el, { - x: x + width / 2, - y: y + height / 2, - width: 0, - height: 0 - }, { - x: x, - y: y, - width: width, - height: height - }, speed, function () { - animations.animationCompleted(el); - }); - } - }, { - key: "animateHeatColor", - value: function animateHeatColor(el, colorFrom, colorTo, speed) { - el.attr({ - fill: colorFrom - }).animate(speed).attr({ - fill: colorTo - }); - } - }]); - - return HeatMap; - }(); - - var CircularChartsHelpers = /*#__PURE__*/function () { - function CircularChartsHelpers(ctx) { - _classCallCheck(this, CircularChartsHelpers); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(CircularChartsHelpers, [{ - key: "drawYAxisTexts", - value: function drawYAxisTexts(x, y, i, text) { - var w = this.w; - var yaxisConfig = w.config.yaxis[0]; - var formatter = w.globals.yLabelFormatters[0]; - var graphics = new Graphics(this.ctx); - var yaxisLabel = graphics.drawText({ - x: x + yaxisConfig.labels.offsetX, - y: y + yaxisConfig.labels.offsetY, - text: formatter(text, i), - textAnchor: 'middle', - fontSize: yaxisConfig.labels.style.fontSize, - fontFamily: yaxisConfig.labels.style.fontFamily, - foreColor: Array.isArray(yaxisConfig.labels.style.colors) ? yaxisConfig.labels.style.colors[i] : yaxisConfig.labels.style.colors - }); - return yaxisLabel; - } - }]); - - return CircularChartsHelpers; - }(); - - /** - * ApexCharts Pie Class for drawing Pie / Donut Charts. - * @module Pie - **/ - - var Pie = /*#__PURE__*/function () { - function Pie(ctx) { - _classCallCheck(this, Pie); - - this.ctx = ctx; - this.w = ctx.w; - var w = this.w; - this.chartType = this.w.config.chart.type; - this.initialAnim = this.w.config.chart.animations.enabled; - this.dynamicAnim = this.initialAnim && this.w.config.chart.animations.dynamicAnimation.enabled; - this.animBeginArr = [0]; - this.animDur = 0; - this.donutDataLabels = this.w.config.plotOptions.pie.donut.labels; - this.lineColorArr = w.globals.stroke.colors !== undefined ? w.globals.stroke.colors : w.globals.colors; - this.defaultSize = Math.min(w.globals.gridWidth, w.globals.gridHeight); - this.centerY = this.defaultSize / 2; - this.centerX = w.globals.gridWidth / 2; - - if (w.config.chart.type === 'radialBar') { - this.fullAngle = 360; - } else { - this.fullAngle = Math.abs(w.config.plotOptions.pie.endAngle - w.config.plotOptions.pie.startAngle); - } - - this.initialAngle = w.config.plotOptions.pie.startAngle % this.fullAngle; - w.globals.radialSize = this.defaultSize / 2.05 - w.config.stroke.width - (!w.config.chart.sparkline.enabled ? w.config.chart.dropShadow.blur : 0); - this.donutSize = w.globals.radialSize * parseInt(w.config.plotOptions.pie.donut.size, 10) / 100; - this.maxY = 0; - this.sliceLabels = []; - this.sliceSizes = []; - this.prevSectorAngleArr = []; // for dynamic animations - } - - _createClass(Pie, [{ - key: "draw", - value: function draw(series) { - var _this = this; - - var self = this; - var w = this.w; - var graphics = new Graphics(this.ctx); - this.ret = graphics.group({ - class: 'apexcharts-pie' - }); - if (w.globals.noData) return this.ret; - var total = 0; - - for (var k = 0; k < series.length; k++) { - // CALCULATE THE TOTAL - total += Utils$1.negToZero(series[k]); - } - - var sectorAngleArr = []; // el to which series will be drawn - - var elSeries = graphics.group(); // prevent division by zero error if there is no data - - if (total === 0) { - total = 0.00001; - } - - series.forEach(function (m) { - _this.maxY = Math.max(_this.maxY, m); - }); // override maxY if user provided in config - - if (w.config.yaxis[0].max) { - this.maxY = w.config.yaxis[0].max; - } - - if (w.config.grid.position === 'back' && this.chartType === 'polarArea') { - this.drawPolarElements(this.ret); - } - - for (var i = 0; i < series.length; i++) { - // CALCULATE THE ANGLES - var angle = this.fullAngle * Utils$1.negToZero(series[i]) / total; - sectorAngleArr.push(angle); - - if (this.chartType === 'polarArea') { - sectorAngleArr[i] = this.fullAngle / series.length; - this.sliceSizes.push(w.globals.radialSize * series[i] / this.maxY); - } else { - this.sliceSizes.push(w.globals.radialSize); - } - } - - if (w.globals.dataChanged) { - var prevTotal = 0; - - for (var _k = 0; _k < w.globals.previousPaths.length; _k++) { - // CALCULATE THE PREV TOTAL - prevTotal += Utils$1.negToZero(w.globals.previousPaths[_k]); - } - - var previousAngle; - - for (var _i = 0; _i < w.globals.previousPaths.length; _i++) { - // CALCULATE THE PREVIOUS ANGLES - previousAngle = this.fullAngle * Utils$1.negToZero(w.globals.previousPaths[_i]) / prevTotal; - this.prevSectorAngleArr.push(previousAngle); - } - } // on small chart size after few count of resizes browser window donutSize can be negative - - - if (this.donutSize < 0) { - this.donutSize = 0; - } - - var scaleSize = w.config.plotOptions.pie.customScale; - var halfW = w.globals.gridWidth / 2; - var halfH = w.globals.gridHeight / 2; - var translateX = halfW - w.globals.gridWidth / 2 * scaleSize; - var translateY = halfH - w.globals.gridHeight / 2 * scaleSize; - - if (this.chartType === 'donut') { - // draw the inner circle and add some text to it - var circle = graphics.drawCircle(this.donutSize); - circle.attr({ - cx: this.centerX, - cy: this.centerY, - fill: w.config.plotOptions.pie.donut.background ? w.config.plotOptions.pie.donut.background : 'transparent' - }); - elSeries.add(circle); - } - - var elG = self.drawArcs(sectorAngleArr, series); // add slice dataLabels at the end - - this.sliceLabels.forEach(function (s) { - elG.add(s); - }); - elSeries.attr({ - transform: "translate(".concat(translateX, ", ").concat(translateY, ") scale(").concat(scaleSize, ")") - }); - elSeries.add(elG); - this.ret.add(elSeries); - - if (this.donutDataLabels.show) { - var dataLabels = this.renderInnerDataLabels(this.donutDataLabels, { - hollowSize: this.donutSize, - centerX: this.centerX, - centerY: this.centerY, - opacity: this.donutDataLabels.show, - translateX: translateX, - translateY: translateY - }); - this.ret.add(dataLabels); - } - - if (w.config.grid.position === 'front' && this.chartType === 'polarArea') { - this.drawPolarElements(this.ret); - } - - return this.ret; - } // core function for drawing pie arcs - - }, { - key: "drawArcs", - value: function drawArcs(sectorAngleArr, series) { - var w = this.w; - var filters = new Filters(this.ctx); - var graphics = new Graphics(this.ctx); - var fill = new Fill(this.ctx); - var g = graphics.group({ - class: 'apexcharts-slices' - }); - var startAngle = this.initialAngle; - var prevStartAngle = this.initialAngle; - var endAngle = this.initialAngle; - var prevEndAngle = this.initialAngle; - this.strokeWidth = w.config.stroke.show ? w.config.stroke.width : 0; - - for (var i = 0; i < sectorAngleArr.length; i++) { - var elPieArc = graphics.group({ - class: "apexcharts-series apexcharts-pie-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[i]), - rel: i + 1, - 'data:realIndex': i - }); - g.add(elPieArc); - startAngle = endAngle; - prevStartAngle = prevEndAngle; - endAngle = startAngle + sectorAngleArr[i]; - prevEndAngle = prevStartAngle + this.prevSectorAngleArr[i]; - var angle = endAngle < startAngle ? this.fullAngle + endAngle - startAngle : endAngle - startAngle; - var pathFill = fill.fillPath({ - seriesNumber: i, - size: this.sliceSizes[i], - value: series[i] - }); // additionally, pass size for gradient drawing in the fillPath function - - var path = this.getChangedPath(prevStartAngle, prevEndAngle); - var elPath = graphics.drawPath({ - d: path, - stroke: Array.isArray(this.lineColorArr) ? this.lineColorArr[i] : this.lineColorArr, - strokeWidth: 0, - fill: pathFill, - fillOpacity: w.config.fill.opacity, - classes: "apexcharts-pie-area apexcharts-".concat(this.chartType.toLowerCase(), "-slice-").concat(i) - }); - elPath.attr({ - index: 0, - j: i - }); - filters.setSelectionFilter(elPath, 0, i); - - if (w.config.chart.dropShadow.enabled) { - var shadow = w.config.chart.dropShadow; - filters.dropShadow(elPath, shadow, i); - } - - this.addListeners(elPath, this.donutDataLabels); - Graphics.setAttrs(elPath.node, { - 'data:angle': angle, - 'data:startAngle': startAngle, - 'data:strokeWidth': this.strokeWidth, - 'data:value': series[i] - }); - var labelPosition = { - x: 0, - y: 0 - }; - - if (this.chartType === 'pie' || this.chartType === 'polarArea') { - labelPosition = Utils$1.polarToCartesian(this.centerX, this.centerY, w.globals.radialSize / 1.25 + w.config.plotOptions.pie.dataLabels.offset, (startAngle + angle / 2) % this.fullAngle); - } else if (this.chartType === 'donut') { - labelPosition = Utils$1.polarToCartesian(this.centerX, this.centerY, (w.globals.radialSize + this.donutSize) / 2 + w.config.plotOptions.pie.dataLabels.offset, (startAngle + angle / 2) % this.fullAngle); - } - - elPieArc.add(elPath); // Animation code starts - - var dur = 0; - - if (this.initialAnim && !w.globals.resized && !w.globals.dataChanged) { - dur = angle / this.fullAngle * w.config.chart.animations.speed; - if (dur === 0) dur = 1; - this.animDur = dur + this.animDur; - this.animBeginArr.push(this.animDur); - } else { - this.animBeginArr.push(0); - } - - if (this.dynamicAnim && w.globals.dataChanged) { - this.animatePaths(elPath, { - size: this.sliceSizes[i], - endAngle: endAngle, - startAngle: startAngle, - prevStartAngle: prevStartAngle, - prevEndAngle: prevEndAngle, - animateStartingPos: true, - i: i, - animBeginArr: this.animBeginArr, - shouldSetPrevPaths: true, - dur: w.config.chart.animations.dynamicAnimation.speed - }); - } else { - this.animatePaths(elPath, { - size: this.sliceSizes[i], - endAngle: endAngle, - startAngle: startAngle, - i: i, - totalItems: sectorAngleArr.length - 1, - animBeginArr: this.animBeginArr, - dur: dur - }); - } // animation code ends - - - if (w.config.plotOptions.pie.expandOnClick && this.chartType !== 'polarArea') { - elPath.click(this.pieClicked.bind(this, i)); - } - - if (typeof w.globals.selectedDataPoints[0] !== 'undefined' && w.globals.selectedDataPoints[0].indexOf(i) > -1) { - this.pieClicked(i); - } - - if (w.config.dataLabels.enabled) { - var xPos = labelPosition.x; - var yPos = labelPosition.y; - var text = 100 * angle / this.fullAngle + '%'; - - if (angle !== 0 && w.config.plotOptions.pie.dataLabels.minAngleToShowLabel < sectorAngleArr[i]) { - var formatter = w.config.dataLabels.formatter; - - if (formatter !== undefined) { - text = formatter(w.globals.seriesPercent[i][0], { - seriesIndex: i, - w: w - }); - } - - var foreColor = w.globals.dataLabels.style.colors[i]; - var elPieLabelWrap = graphics.group({ - class: "apexcharts-datalabels" - }); - var elPieLabel = graphics.drawText({ - x: xPos, - y: yPos, - text: text, - textAnchor: 'middle', - fontSize: w.config.dataLabels.style.fontSize, - fontFamily: w.config.dataLabels.style.fontFamily, - fontWeight: w.config.dataLabels.style.fontWeight, - foreColor: foreColor - }); - elPieLabelWrap.add(elPieLabel); - - if (w.config.dataLabels.dropShadow.enabled) { - var textShadow = w.config.dataLabels.dropShadow; - filters.dropShadow(elPieLabel, textShadow); - } - - elPieLabel.node.classList.add('apexcharts-pie-label'); - - if (w.config.chart.animations.animate && w.globals.resized === false) { - elPieLabel.node.classList.add('apexcharts-pie-label-delay'); - elPieLabel.node.style.animationDelay = w.config.chart.animations.speed / 940 + 's'; - } - - this.sliceLabels.push(elPieLabelWrap); - } - } - } - - return g; - } - }, { - key: "addListeners", - value: function addListeners(elPath, dataLabels) { - var graphics = new Graphics(this.ctx); // append filters on mouseenter and mouseleave - - elPath.node.addEventListener('mouseenter', graphics.pathMouseEnter.bind(this, elPath)); - elPath.node.addEventListener('mouseleave', graphics.pathMouseLeave.bind(this, elPath)); - elPath.node.addEventListener('mouseleave', this.revertDataLabelsInner.bind(this, elPath.node, dataLabels)); - elPath.node.addEventListener('mousedown', graphics.pathMouseDown.bind(this, elPath)); - - if (!this.donutDataLabels.total.showAlways) { - elPath.node.addEventListener('mouseenter', this.printDataLabelsInner.bind(this, elPath.node, dataLabels)); - elPath.node.addEventListener('mousedown', this.printDataLabelsInner.bind(this, elPath.node, dataLabels)); - } - } // This function can be used for other circle charts too - - }, { - key: "animatePaths", - value: function animatePaths(el, opts) { - var w = this.w; - var me = this; - var angle = opts.endAngle < opts.startAngle ? this.fullAngle + opts.endAngle - opts.startAngle : opts.endAngle - opts.startAngle; - var prevAngle = angle; - var fromStartAngle = opts.startAngle; - var toStartAngle = opts.startAngle; - - if (opts.prevStartAngle !== undefined && opts.prevEndAngle !== undefined) { - fromStartAngle = opts.prevEndAngle; - prevAngle = opts.prevEndAngle < opts.prevStartAngle ? this.fullAngle + opts.prevEndAngle - opts.prevStartAngle : opts.prevEndAngle - opts.prevStartAngle; - } - - if (opts.i === w.config.series.length - 1) { - // some adjustments for the last overlapping paths - if (angle + toStartAngle > this.fullAngle) { - opts.endAngle = opts.endAngle - (angle + toStartAngle); - } else if (angle + toStartAngle < this.fullAngle) { - opts.endAngle = opts.endAngle + (this.fullAngle - (angle + toStartAngle)); - } - } - - if (angle === this.fullAngle) angle = this.fullAngle - 0.01; - me.animateArc(el, fromStartAngle, toStartAngle, angle, prevAngle, opts); - } - }, { - key: "animateArc", - value: function animateArc(el, fromStartAngle, toStartAngle, angle, prevAngle, opts) { - var me = this; - var w = this.w; - var animations = new Animations(this.ctx); - var size = opts.size; - var path; - - if (isNaN(fromStartAngle) || isNaN(prevAngle)) { - fromStartAngle = toStartAngle; - prevAngle = angle; - opts.dur = 0; - } - - var currAngle = angle; - var startAngle = toStartAngle; - var fromAngle = fromStartAngle < toStartAngle ? this.fullAngle + fromStartAngle - toStartAngle : fromStartAngle - toStartAngle; - - if (w.globals.dataChanged && opts.shouldSetPrevPaths) { - // to avoid flicker when updating, set prev path first and then animate from there - if (opts.prevEndAngle) { - path = me.getPiePath({ - me: me, - startAngle: opts.prevStartAngle, - angle: opts.prevEndAngle < opts.prevStartAngle ? this.fullAngle + opts.prevEndAngle - opts.prevStartAngle : opts.prevEndAngle - opts.prevStartAngle, - size: size - }); - el.attr({ - d: path - }); - } - } - - if (opts.dur !== 0) { - el.animate(opts.dur, w.globals.easing, opts.animBeginArr[opts.i]).afterAll(function () { - if (me.chartType === 'pie' || me.chartType === 'donut' || me.chartType === 'polarArea') { - this.animate(w.config.chart.animations.dynamicAnimation.speed).attr({ - 'stroke-width': me.strokeWidth - }); - } - - if (opts.i === w.config.series.length - 1) { - animations.animationCompleted(el); - } - }).during(function (pos) { - currAngle = fromAngle + (angle - fromAngle) * pos; - - if (opts.animateStartingPos) { - currAngle = prevAngle + (angle - prevAngle) * pos; - startAngle = fromStartAngle - prevAngle + (toStartAngle - (fromStartAngle - prevAngle)) * pos; - } - - path = me.getPiePath({ - me: me, - startAngle: startAngle, - angle: currAngle, - size: size - }); - el.node.setAttribute('data:pathOrig', path); - el.attr({ - d: path - }); - }); - } else { - path = me.getPiePath({ - me: me, - startAngle: startAngle, - angle: angle, - size: size - }); - - if (!opts.isTrack) { - w.globals.animationEnded = true; - } - - el.node.setAttribute('data:pathOrig', path); - el.attr({ - d: path, - 'stroke-width': me.strokeWidth - }); - } - } - }, { - key: "pieClicked", - value: function pieClicked(i) { - var w = this.w; - var me = this; - var path; - var size = me.sliceSizes[i] + (w.config.plotOptions.pie.expandOnClick ? 4 : 0); - var elPath = w.globals.dom.Paper.select(".apexcharts-".concat(me.chartType.toLowerCase(), "-slice-").concat(i)).members[0]; - - if (elPath.attr('data:pieClicked') === 'true') { - elPath.attr({ - 'data:pieClicked': 'false' - }); - this.revertDataLabelsInner(elPath.node, this.donutDataLabels); - var origPath = elPath.attr('data:pathOrig'); - elPath.attr({ - d: origPath - }); - return; - } else { - // reset all elems - var allEls = w.globals.dom.baseEl.getElementsByClassName('apexcharts-pie-area'); - Array.prototype.forEach.call(allEls, function (pieSlice) { - pieSlice.setAttribute('data:pieClicked', 'false'); - var origPath = pieSlice.getAttribute('data:pathOrig'); - - if (origPath) { - pieSlice.setAttribute('d', origPath); - } - }); - elPath.attr('data:pieClicked', 'true'); - } - - var startAngle = parseInt(elPath.attr('data:startAngle'), 10); - var angle = parseInt(elPath.attr('data:angle'), 10); - path = me.getPiePath({ - me: me, - startAngle: startAngle, - angle: angle, - size: size - }); - if (angle === 360) return; - elPath.plot(path); - } - }, { - key: "getChangedPath", - value: function getChangedPath(prevStartAngle, prevEndAngle) { - var path = ''; - - if (this.dynamicAnim && this.w.globals.dataChanged) { - path = this.getPiePath({ - me: this, - startAngle: prevStartAngle, - angle: prevEndAngle - prevStartAngle, - size: this.size - }); - } - - return path; - } - }, { - key: "getPiePath", - value: function getPiePath(_ref) { - var me = _ref.me, - startAngle = _ref.startAngle, - angle = _ref.angle, - size = _ref.size; - var path; - var startDeg = startAngle; - var startRadians = Math.PI * (startDeg - 90) / 180; - var endDeg = angle + startAngle; // prevent overlap - - if (Math.ceil(endDeg) >= this.fullAngle + this.w.config.plotOptions.pie.startAngle % this.fullAngle) { - endDeg = this.fullAngle + this.w.config.plotOptions.pie.startAngle % this.fullAngle - 0.01; - } - - if (Math.ceil(endDeg) > this.fullAngle) endDeg -= this.fullAngle; - var endRadians = Math.PI * (endDeg - 90) / 180; - var x1 = me.centerX + size * Math.cos(startRadians); - var y1 = me.centerY + size * Math.sin(startRadians); - var x2 = me.centerX + size * Math.cos(endRadians); - var y2 = me.centerY + size * Math.sin(endRadians); - var startInner = Utils$1.polarToCartesian(me.centerX, me.centerY, me.donutSize, endDeg); - var endInner = Utils$1.polarToCartesian(me.centerX, me.centerY, me.donutSize, startDeg); - var largeArc = angle > 180 ? 1 : 0; - var pathBeginning = ['M', x1, y1, 'A', size, size, 0, largeArc, 1, x2, y2]; - - if (me.chartType === 'donut') { - path = [].concat(pathBeginning, ['L', startInner.x, startInner.y, 'A', me.donutSize, me.donutSize, 0, largeArc, 0, endInner.x, endInner.y, 'L', x1, y1, 'z']).join(' '); - } else if (me.chartType === 'pie' || me.chartType === 'polarArea') { - path = [].concat(pathBeginning, ['L', me.centerX, me.centerY, 'L', x1, y1]).join(' '); - } else { - path = [].concat(pathBeginning).join(' '); - } - - return path; - } - }, { - key: "drawPolarElements", - value: function drawPolarElements(parent) { - var w = this.w; - var scale = new Range$1(this.ctx); - var graphics = new Graphics(this.ctx); - var helpers = new CircularChartsHelpers(this.ctx); - var gCircles = graphics.group(); - var gYAxis = graphics.group(); - var yScale = scale.niceScale(0, Math.ceil(this.maxY), w.config.yaxis[0].tickAmount, 0, true); - var yTexts = yScale.result.reverse(); - var len = yScale.result.length; - this.maxY = yScale.niceMax; - var circleSize = w.globals.radialSize; - var diff = circleSize / (len - 1); - - for (var i = 0; i < len - 1; i++) { - var circle = graphics.drawCircle(circleSize); - circle.attr({ - cx: this.centerX, - cy: this.centerY, - fill: 'none', - 'stroke-width': w.config.plotOptions.polarArea.rings.strokeWidth, - stroke: w.config.plotOptions.polarArea.rings.strokeColor - }); - - if (w.config.yaxis[0].show) { - var yLabel = helpers.drawYAxisTexts(this.centerX, this.centerY - circleSize + parseInt(w.config.yaxis[0].labels.style.fontSize, 10) / 2, i, yTexts[i]); - gYAxis.add(yLabel); - } - - gCircles.add(circle); - circleSize = circleSize - diff; - } - - this.drawSpokes(parent); - parent.add(gCircles); - parent.add(gYAxis); - } - }, { - key: "renderInnerDataLabels", - value: function renderInnerDataLabels(dataLabelsConfig, opts) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var g = graphics.group({ - class: 'apexcharts-datalabels-group', - transform: "translate(".concat(opts.translateX ? opts.translateX : 0, ", ").concat(opts.translateY ? opts.translateY : 0, ") scale(").concat(w.config.plotOptions.pie.customScale, ")") - }); - var showTotal = dataLabelsConfig.total.show; - g.node.style.opacity = opts.opacity; - var x = opts.centerX; - var y = opts.centerY; - var labelColor, valueColor; - - if (dataLabelsConfig.name.color === undefined) { - labelColor = w.globals.colors[0]; - } else { - labelColor = dataLabelsConfig.name.color; - } - - var labelFontSize = dataLabelsConfig.name.fontSize; - var labelFontFamily = dataLabelsConfig.name.fontFamily; - var labelFontWeight = dataLabelsConfig.name.fontWeight; - - if (dataLabelsConfig.value.color === undefined) { - valueColor = w.config.chart.foreColor; - } else { - valueColor = dataLabelsConfig.value.color; - } - - var lbFormatter = dataLabelsConfig.value.formatter; - var val = ''; - var name = ''; - - if (showTotal) { - labelColor = dataLabelsConfig.total.color; - labelFontSize = dataLabelsConfig.total.fontSize; - labelFontFamily = dataLabelsConfig.total.fontFamily; - labelFontWeight = dataLabelsConfig.total.fontWeight; - name = dataLabelsConfig.total.label; - val = dataLabelsConfig.total.formatter(w); - } else { - if (w.globals.series.length === 1) { - val = lbFormatter(w.globals.series[0], w); - name = w.globals.seriesNames[0]; - } - } - - if (name) { - name = dataLabelsConfig.name.formatter(name, dataLabelsConfig.total.show, w); - } - - if (dataLabelsConfig.name.show) { - var elLabel = graphics.drawText({ - x: x, - y: y + parseFloat(dataLabelsConfig.name.offsetY), - text: name, - textAnchor: 'middle', - foreColor: labelColor, - fontSize: labelFontSize, - fontWeight: labelFontWeight, - fontFamily: labelFontFamily - }); - elLabel.node.classList.add('apexcharts-datalabel-label'); - g.add(elLabel); - } - - if (dataLabelsConfig.value.show) { - var valOffset = dataLabelsConfig.name.show ? parseFloat(dataLabelsConfig.value.offsetY) + 16 : dataLabelsConfig.value.offsetY; - var elValue = graphics.drawText({ - x: x, - y: y + valOffset, - text: val, - textAnchor: 'middle', - foreColor: valueColor, - fontWeight: dataLabelsConfig.value.fontWeight, - fontSize: dataLabelsConfig.value.fontSize, - fontFamily: dataLabelsConfig.value.fontFamily - }); - elValue.node.classList.add('apexcharts-datalabel-value'); - g.add(elValue); - } // for a multi-series circle chart, we need to show total value instead of first series labels - - - return g; - } - /** - * - * @param {string} name - The name of the series - * @param {string} val - The value of that series - * @param {object} el - Optional el (indicates which series was hovered/clicked). If this param is not present, means we need to show total - */ - - }, { - key: "printInnerLabels", - value: function printInnerLabels(labelsConfig, name, val, el) { - var w = this.w; - var labelColor; - - if (el) { - if (labelsConfig.name.color === undefined) { - labelColor = w.globals.colors[parseInt(el.parentNode.getAttribute('rel'), 10) - 1]; - } else { - labelColor = labelsConfig.name.color; - } - } else { - if (w.globals.series.length > 1 && labelsConfig.total.show) { - labelColor = labelsConfig.total.color; - } - } - - var elLabel = w.globals.dom.baseEl.querySelector('.apexcharts-datalabel-label'); - var elValue = w.globals.dom.baseEl.querySelector('.apexcharts-datalabel-value'); - var lbFormatter = labelsConfig.value.formatter; - val = lbFormatter(val, w); // we need to show Total Val - so get the formatter of it - - if (!el && typeof labelsConfig.total.formatter === 'function') { - val = labelsConfig.total.formatter(w); - } - - var isTotal = name === labelsConfig.total.label; - name = labelsConfig.name.formatter(name, isTotal, w); - - if (elLabel !== null) { - elLabel.textContent = name; - } - - if (elValue !== null) { - elValue.textContent = val; - } - - if (elLabel !== null) { - elLabel.style.fill = labelColor; - } - } - }, { - key: "printDataLabelsInner", - value: function printDataLabelsInner(el, dataLabelsConfig) { - var w = this.w; - var val = el.getAttribute('data:value'); - var name = w.globals.seriesNames[parseInt(el.parentNode.getAttribute('rel'), 10) - 1]; - - if (w.globals.series.length > 1) { - this.printInnerLabels(dataLabelsConfig, name, val, el); - } - - var dataLabelsGroup = w.globals.dom.baseEl.querySelector('.apexcharts-datalabels-group'); - - if (dataLabelsGroup !== null) { - dataLabelsGroup.style.opacity = 1; - } - } - }, { - key: "drawSpokes", - value: function drawSpokes(parent) { - var _this2 = this; - - var w = this.w; - var graphics = new Graphics(this.ctx); - var spokeConfig = w.config.plotOptions.polarArea.spokes; - if (spokeConfig.strokeWidth === 0) return; - var spokes = []; - var angleDivision = 360 / w.globals.series.length; - - for (var i = 0; i < w.globals.series.length; i++) { - spokes.push(Utils$1.polarToCartesian(this.centerX, this.centerY, w.globals.radialSize, w.config.plotOptions.pie.startAngle + angleDivision * i)); - } - - spokes.forEach(function (p, i) { - var line = graphics.drawLine(p.x, p.y, _this2.centerX, _this2.centerY, Array.isArray(spokeConfig.connectorColors) ? spokeConfig.connectorColors[i] : spokeConfig.connectorColors); - parent.add(line); - }); - } - }, { - key: "revertDataLabelsInner", - value: function revertDataLabelsInner(elem, dataLabelsConfig, event) { - var _this3 = this; - - var w = this.w; - var dataLabelsGroup = w.globals.dom.baseEl.querySelector('.apexcharts-datalabels-group'); - var sliceOut = false; - var slices = w.globals.dom.baseEl.getElementsByClassName("apexcharts-pie-area"); - - var selectSlice = function selectSlice(_ref2) { - var makeSliceOut = _ref2.makeSliceOut, - printLabel = _ref2.printLabel; - Array.prototype.forEach.call(slices, function (s) { - if (s.getAttribute('data:pieClicked') === 'true') { - if (makeSliceOut) { - sliceOut = true; - } - - if (printLabel) { - _this3.printDataLabelsInner(s, dataLabelsConfig); - } - } - }); - }; - - selectSlice({ - makeSliceOut: true, - printLabel: false - }); - - if (dataLabelsConfig.total.show && w.globals.series.length > 1) { - if (sliceOut && !dataLabelsConfig.total.showAlways) { - selectSlice({ - makeSliceOut: false, - printLabel: true - }); - } else { - this.printInnerLabels(dataLabelsConfig, dataLabelsConfig.total.label, dataLabelsConfig.total.formatter(w)); - } - } else { - selectSlice({ - makeSliceOut: false, - printLabel: true - }); - - if (!sliceOut) { - if (w.globals.selectedDataPoints.length && w.globals.series.length > 1) { - if (w.globals.selectedDataPoints[0].length > 0) { - var index = w.globals.selectedDataPoints[0]; - var el = w.globals.dom.baseEl.querySelector(".apexcharts-".concat(this.chartType.toLowerCase(), "-slice-").concat(index)); - this.printDataLabelsInner(el, dataLabelsConfig); - } else if (dataLabelsGroup && w.globals.selectedDataPoints.length && w.globals.selectedDataPoints[0].length === 0) { - dataLabelsGroup.style.opacity = 0; - } - } else { - if (dataLabelsGroup && w.globals.series.length > 1) { - dataLabelsGroup.style.opacity = 0; - } - } - } - } - } - }]); - - return Pie; - }(); - - /** - * ApexCharts Radar Class for Spider/Radar Charts. - * @module Radar - **/ - - var Radar = /*#__PURE__*/function () { - function Radar(ctx) { - _classCallCheck(this, Radar); - - this.ctx = ctx; - this.w = ctx.w; - this.chartType = this.w.config.chart.type; - this.initialAnim = this.w.config.chart.animations.enabled; - this.dynamicAnim = this.initialAnim && this.w.config.chart.animations.dynamicAnimation.enabled; - this.animDur = 0; - var w = this.w; - this.graphics = new Graphics(this.ctx); - this.lineColorArr = w.globals.stroke.colors !== undefined ? w.globals.stroke.colors : w.globals.colors; - this.defaultSize = w.globals.svgHeight < w.globals.svgWidth ? w.globals.gridHeight + w.globals.goldenPadding * 1.5 : w.globals.gridWidth; - this.isLog = w.config.yaxis[0].logarithmic; - this.coreUtils = new CoreUtils(this.ctx); - this.maxValue = this.isLog ? this.coreUtils.getLogVal(w.globals.maxY, 0) : w.globals.maxY; - this.minValue = this.isLog ? this.coreUtils.getLogVal(this.w.globals.minY, 0) : w.globals.minY; - this.polygons = w.config.plotOptions.radar.polygons; - this.strokeWidth = w.config.stroke.show ? w.config.stroke.width : 0; - this.size = this.defaultSize / 2.1 - this.strokeWidth - w.config.chart.dropShadow.blur; - - if (w.config.xaxis.labels.show) { - this.size = this.size - w.globals.xAxisLabelsWidth / 1.75; - } - - if (w.config.plotOptions.radar.size !== undefined) { - this.size = w.config.plotOptions.radar.size; - } - - this.dataRadiusOfPercent = []; - this.dataRadius = []; - this.angleArr = []; - this.yaxisLabelsTextsPos = []; - } - - _createClass(Radar, [{ - key: "draw", - value: function draw(series) { - var _this = this; - - var w = this.w; - var fill = new Fill(this.ctx); - var allSeries = []; - var dataLabels = new DataLabels(this.ctx); - - if (series.length) { - this.dataPointsLen = series[w.globals.maxValsInArrayIndex].length; - } - - this.disAngle = Math.PI * 2 / this.dataPointsLen; - var halfW = w.globals.gridWidth / 2; - var halfH = w.globals.gridHeight / 2; - var translateX = halfW + w.config.plotOptions.radar.offsetX; - var translateY = halfH + w.config.plotOptions.radar.offsetY; - var ret = this.graphics.group({ - class: 'apexcharts-radar-series apexcharts-plot-series', - transform: "translate(".concat(translateX || 0, ", ").concat(translateY || 0, ")") - }); - var dataPointsPos = []; - var elPointsMain = null; - var elDataPointsMain = null; - this.yaxisLabels = this.graphics.group({ - class: 'apexcharts-yaxis' - }); - series.forEach(function (s, i) { - var longestSeries = s.length === w.globals.dataPoints; // el to which series will be drawn - - var elSeries = _this.graphics.group().attr({ - class: "apexcharts-series", - 'data:longestSeries': longestSeries, - seriesName: Utils$1.escapeString(w.globals.seriesNames[i]), - rel: i + 1, - 'data:realIndex': i - }); - - _this.dataRadiusOfPercent[i] = []; - _this.dataRadius[i] = []; - _this.angleArr[i] = []; - s.forEach(function (dv, j) { - var range = Math.abs(_this.maxValue - _this.minValue); - dv = dv + Math.abs(_this.minValue); - - if (_this.isLog) { - dv = _this.coreUtils.getLogVal(dv, 0); - } - - _this.dataRadiusOfPercent[i][j] = dv / range; - _this.dataRadius[i][j] = _this.dataRadiusOfPercent[i][j] * _this.size; - _this.angleArr[i][j] = j * _this.disAngle; - }); - dataPointsPos = _this.getDataPointsPos(_this.dataRadius[i], _this.angleArr[i]); - - var paths = _this.createPaths(dataPointsPos, { - x: 0, - y: 0 - }); // points - - - elPointsMain = _this.graphics.group({ - class: 'apexcharts-series-markers-wrap apexcharts-element-hidden' - }); // datapoints - - elDataPointsMain = _this.graphics.group({ - class: "apexcharts-datalabels", - 'data:realIndex': i - }); - w.globals.delayedElements.push({ - el: elPointsMain.node, - index: i - }); - var defaultRenderedPathOptions = { - i: i, - realIndex: i, - animationDelay: i, - initialSpeed: w.config.chart.animations.speed, - dataChangeSpeed: w.config.chart.animations.dynamicAnimation.speed, - className: "apexcharts-radar", - shouldClipToGrid: false, - bindEventsOnPaths: false, - stroke: w.globals.stroke.colors[i], - strokeLineCap: w.config.stroke.lineCap - }; - var pathFrom = null; - - if (w.globals.previousPaths.length > 0) { - pathFrom = _this.getPreviousPath(i); - } - - for (var p = 0; p < paths.linePathsTo.length; p++) { - var renderedLinePath = _this.graphics.renderPaths(_objectSpread2(_objectSpread2({}, defaultRenderedPathOptions), {}, { - pathFrom: pathFrom === null ? paths.linePathsFrom[p] : pathFrom, - pathTo: paths.linePathsTo[p], - strokeWidth: Array.isArray(_this.strokeWidth) ? _this.strokeWidth[i] : _this.strokeWidth, - fill: 'none', - drawShadow: false - })); - - elSeries.add(renderedLinePath); - var pathFill = fill.fillPath({ - seriesNumber: i - }); - - var renderedAreaPath = _this.graphics.renderPaths(_objectSpread2(_objectSpread2({}, defaultRenderedPathOptions), {}, { - pathFrom: pathFrom === null ? paths.areaPathsFrom[p] : pathFrom, - pathTo: paths.areaPathsTo[p], - strokeWidth: 0, - fill: pathFill, - drawShadow: false - })); - - if (w.config.chart.dropShadow.enabled) { - var filters = new Filters(_this.ctx); - var shadow = w.config.chart.dropShadow; - filters.dropShadow(renderedAreaPath, Object.assign({}, shadow, { - noUserSpaceOnUse: true - }), i); - } - - elSeries.add(renderedAreaPath); - } - - s.forEach(function (sj, j) { - var markers = new Markers(_this.ctx); - var opts = markers.getMarkerConfig({ - cssClass: 'apexcharts-marker', - seriesIndex: i, - dataPointIndex: j - }); - - var point = _this.graphics.drawMarker(dataPointsPos[j].x, dataPointsPos[j].y, opts); - - point.attr('rel', j); - point.attr('j', j); - point.attr('index', i); - point.node.setAttribute('default-marker-size', opts.pSize); - - var elPointsWrap = _this.graphics.group({ - class: 'apexcharts-series-markers' - }); - - if (elPointsWrap) { - elPointsWrap.add(point); - } - - elPointsMain.add(elPointsWrap); - elSeries.add(elPointsMain); - var dataLabelsConfig = w.config.dataLabels; - - if (dataLabelsConfig.enabled) { - var text = dataLabelsConfig.formatter(w.globals.series[i][j], { - seriesIndex: i, - dataPointIndex: j, - w: w - }); - dataLabels.plotDataLabelsText({ - x: dataPointsPos[j].x, - y: dataPointsPos[j].y, - text: text, - textAnchor: 'middle', - i: i, - j: i, - parent: elDataPointsMain, - offsetCorrection: false, - dataLabelsConfig: _objectSpread2({}, dataLabelsConfig) - }); - } - - elSeries.add(elDataPointsMain); - }); - allSeries.push(elSeries); - }); - this.drawPolygons({ - parent: ret - }); - - if (w.config.xaxis.labels.show) { - var xaxisTexts = this.drawXAxisTexts(); - ret.add(xaxisTexts); - } - - allSeries.forEach(function (elS) { - ret.add(elS); - }); - ret.add(this.yaxisLabels); - return ret; - } - }, { - key: "drawPolygons", - value: function drawPolygons(opts) { - var _this2 = this; - - var w = this.w; - var parent = opts.parent; - var helpers = new CircularChartsHelpers(this.ctx); - var yaxisTexts = w.globals.yAxisScale[0].result.reverse(); - var layers = yaxisTexts.length; - var radiusSizes = []; - var layerDis = this.size / (layers - 1); - - for (var i = 0; i < layers; i++) { - radiusSizes[i] = layerDis * i; - } - - radiusSizes.reverse(); - var polygonStrings = []; - var lines = []; - radiusSizes.forEach(function (radiusSize, r) { - var polygon = Utils$1.getPolygonPos(radiusSize, _this2.dataPointsLen); - var string = ''; - polygon.forEach(function (p, i) { - if (r === 0) { - var line = _this2.graphics.drawLine(p.x, p.y, 0, 0, Array.isArray(_this2.polygons.connectorColors) ? _this2.polygons.connectorColors[i] : _this2.polygons.connectorColors); - - lines.push(line); - } - - if (i === 0) { - _this2.yaxisLabelsTextsPos.push({ - x: p.x, - y: p.y - }); - } - - string += p.x + ',' + p.y + ' '; - }); - polygonStrings.push(string); - }); - polygonStrings.forEach(function (p, i) { - var strokeColors = _this2.polygons.strokeColors; - var strokeWidth = _this2.polygons.strokeWidth; - - var polygon = _this2.graphics.drawPolygon(p, Array.isArray(strokeColors) ? strokeColors[i] : strokeColors, Array.isArray(strokeWidth) ? strokeWidth[i] : strokeWidth, w.globals.radarPolygons.fill.colors[i]); - - parent.add(polygon); - }); - lines.forEach(function (l) { - parent.add(l); - }); - - if (w.config.yaxis[0].show) { - this.yaxisLabelsTextsPos.forEach(function (p, i) { - var yText = helpers.drawYAxisTexts(p.x, p.y, i, yaxisTexts[i]); - - _this2.yaxisLabels.add(yText); - }); - } - } - }, { - key: "drawXAxisTexts", - value: function drawXAxisTexts() { - var _this3 = this; - - var w = this.w; - var xaxisLabelsConfig = w.config.xaxis.labels; - var elXAxisWrap = this.graphics.group({ - class: 'apexcharts-xaxis' - }); - var polygonPos = Utils$1.getPolygonPos(this.size, this.dataPointsLen); - w.globals.labels.forEach(function (label, i) { - var formatter = w.config.xaxis.labels.formatter; - var dataLabels = new DataLabels(_this3.ctx); - - if (polygonPos[i]) { - var textPos = _this3.getTextPos(polygonPos[i], _this3.size); - - var text = formatter(label, { - seriesIndex: -1, - dataPointIndex: i, - w: w - }); - dataLabels.plotDataLabelsText({ - x: textPos.newX, - y: textPos.newY, - text: text, - textAnchor: textPos.textAnchor, - i: i, - j: i, - parent: elXAxisWrap, - color: Array.isArray(xaxisLabelsConfig.style.colors) && xaxisLabelsConfig.style.colors[i] ? xaxisLabelsConfig.style.colors[i] : '#a8a8a8', - dataLabelsConfig: _objectSpread2({ - textAnchor: textPos.textAnchor, - dropShadow: { - enabled: false - } - }, xaxisLabelsConfig), - offsetCorrection: false - }); - } - }); - return elXAxisWrap; - } - }, { - key: "createPaths", - value: function createPaths(pos, origin) { - var _this4 = this; - - var linePathsTo = []; - var linePathsFrom = []; - var areaPathsTo = []; - var areaPathsFrom = []; - - if (pos.length) { - linePathsFrom = [this.graphics.move(origin.x, origin.y)]; - areaPathsFrom = [this.graphics.move(origin.x, origin.y)]; - var linePathTo = this.graphics.move(pos[0].x, pos[0].y); - var areaPathTo = this.graphics.move(pos[0].x, pos[0].y); - pos.forEach(function (p, i) { - linePathTo += _this4.graphics.line(p.x, p.y); - areaPathTo += _this4.graphics.line(p.x, p.y); - - if (i === pos.length - 1) { - linePathTo += 'Z'; - areaPathTo += 'Z'; - } - }); - linePathsTo.push(linePathTo); - areaPathsTo.push(areaPathTo); - } - - return { - linePathsFrom: linePathsFrom, - linePathsTo: linePathsTo, - areaPathsFrom: areaPathsFrom, - areaPathsTo: areaPathsTo - }; - } - }, { - key: "getTextPos", - value: function getTextPos(pos, polygonSize) { - var limit = 10; - var textAnchor = 'middle'; - var newX = pos.x; - var newY = pos.y; - - if (Math.abs(pos.x) >= limit) { - if (pos.x > 0) { - textAnchor = 'start'; - newX += 10; - } else if (pos.x < 0) { - textAnchor = 'end'; - newX -= 10; - } - } else { - textAnchor = 'middle'; - } - - if (Math.abs(pos.y) >= polygonSize - limit) { - if (pos.y < 0) { - newY -= 10; - } else if (pos.y > 0) { - newY += 10; - } - } - - return { - textAnchor: textAnchor, - newX: newX, - newY: newY - }; - } - }, { - key: "getPreviousPath", - value: function getPreviousPath(realIndex) { - var w = this.w; - var pathFrom = null; - - for (var pp = 0; pp < w.globals.previousPaths.length; pp++) { - var gpp = w.globals.previousPaths[pp]; - - if (gpp.paths.length > 0 && parseInt(gpp.realIndex, 10) === parseInt(realIndex, 10)) { - if (typeof w.globals.previousPaths[pp].paths[0] !== 'undefined') { - pathFrom = w.globals.previousPaths[pp].paths[0].d; - } - } - } - - return pathFrom; - } - }, { - key: "getDataPointsPos", - value: function getDataPointsPos(dataRadiusArr, angleArr) { - var dataPointsLen = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.dataPointsLen; - dataRadiusArr = dataRadiusArr || []; - angleArr = angleArr || []; - var dataPointsPosArray = []; - - for (var j = 0; j < dataPointsLen; j++) { - var curPointPos = {}; - curPointPos.x = dataRadiusArr[j] * Math.sin(angleArr[j]); - curPointPos.y = -dataRadiusArr[j] * Math.cos(angleArr[j]); - dataPointsPosArray.push(curPointPos); - } - - return dataPointsPosArray; - } - }]); - - return Radar; - }(); - - /** - * ApexCharts Radial Class for drawing Circle / Semi Circle Charts. - * @module Radial - **/ - - var Radial = /*#__PURE__*/function (_Pie) { - _inherits(Radial, _Pie); - - var _super = _createSuper(Radial); - - function Radial(ctx) { - var _this; - - _classCallCheck(this, Radial); - - _this = _super.call(this, ctx); - _this.ctx = ctx; - _this.w = ctx.w; - _this.animBeginArr = [0]; - _this.animDur = 0; - var w = _this.w; - _this.startAngle = w.config.plotOptions.radialBar.startAngle; - _this.endAngle = w.config.plotOptions.radialBar.endAngle; - _this.totalAngle = Math.abs(w.config.plotOptions.radialBar.endAngle - w.config.plotOptions.radialBar.startAngle); - _this.trackStartAngle = w.config.plotOptions.radialBar.track.startAngle; - _this.trackEndAngle = w.config.plotOptions.radialBar.track.endAngle; - _this.donutDataLabels = _this.w.config.plotOptions.radialBar.dataLabels; - _this.radialDataLabels = _this.donutDataLabels; // make a copy for easy reference - - if (!_this.trackStartAngle) _this.trackStartAngle = _this.startAngle; - if (!_this.trackEndAngle) _this.trackEndAngle = _this.endAngle; - if (_this.endAngle === 360) _this.endAngle = 359.99; - _this.margin = parseInt(w.config.plotOptions.radialBar.track.margin, 10); - return _this; - } - - _createClass(Radial, [{ - key: "draw", - value: function draw(series) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var ret = graphics.group({ - class: 'apexcharts-radialbar' - }); - if (w.globals.noData) return ret; - var elSeries = graphics.group(); - var centerY = this.defaultSize / 2; - var centerX = w.globals.gridWidth / 2; - var size = this.defaultSize / 2.05; - - if (!w.config.chart.sparkline.enabled) { - size = size - w.config.stroke.width - w.config.chart.dropShadow.blur; - } - - var colorArr = w.globals.fill.colors; - - if (w.config.plotOptions.radialBar.track.show) { - var elTracks = this.drawTracks({ - size: size, - centerX: centerX, - centerY: centerY, - colorArr: colorArr, - series: series - }); - elSeries.add(elTracks); - } - - var elG = this.drawArcs({ - size: size, - centerX: centerX, - centerY: centerY, - colorArr: colorArr, - series: series - }); - var totalAngle = 360; - - if (w.config.plotOptions.radialBar.startAngle < 0) { - totalAngle = this.totalAngle; - } - - var angleRatio = (360 - totalAngle) / 360; - w.globals.radialSize = size - size * angleRatio; - - if (this.radialDataLabels.value.show) { - var offset = Math.max(this.radialDataLabels.value.offsetY, this.radialDataLabels.name.offsetY); - w.globals.radialSize += offset * angleRatio; - } - - elSeries.add(elG.g); - - if (w.config.plotOptions.radialBar.hollow.position === 'front') { - elG.g.add(elG.elHollow); - - if (elG.dataLabels) { - elG.g.add(elG.dataLabels); - } - } - - ret.add(elSeries); - return ret; - } - }, { - key: "drawTracks", - value: function drawTracks(opts) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var g = graphics.group({ - class: 'apexcharts-tracks' - }); - var filters = new Filters(this.ctx); - var fill = new Fill(this.ctx); - var strokeWidth = this.getStrokeWidth(opts); - opts.size = opts.size - strokeWidth / 2; - - for (var i = 0; i < opts.series.length; i++) { - var elRadialBarTrack = graphics.group({ - class: 'apexcharts-radialbar-track apexcharts-track' - }); - g.add(elRadialBarTrack); - elRadialBarTrack.attr({ - rel: i + 1 - }); - opts.size = opts.size - strokeWidth - this.margin; - var trackConfig = w.config.plotOptions.radialBar.track; - var pathFill = fill.fillPath({ - seriesNumber: 0, - size: opts.size, - fillColors: Array.isArray(trackConfig.background) ? trackConfig.background[i] : trackConfig.background, - solid: true - }); - var startAngle = this.trackStartAngle; - var endAngle = this.trackEndAngle; - if (Math.abs(endAngle) + Math.abs(startAngle) >= 360) endAngle = 360 - Math.abs(this.startAngle) - 0.1; - var elPath = graphics.drawPath({ - d: '', - stroke: pathFill, - strokeWidth: strokeWidth * parseInt(trackConfig.strokeWidth, 10) / 100, - fill: 'none', - strokeOpacity: trackConfig.opacity, - classes: 'apexcharts-radialbar-area' - }); - - if (trackConfig.dropShadow.enabled) { - var shadow = trackConfig.dropShadow; - filters.dropShadow(elPath, shadow); - } - - elRadialBarTrack.add(elPath); - elPath.attr('id', 'apexcharts-radialbarTrack-' + i); - this.animatePaths(elPath, { - centerX: opts.centerX, - centerY: opts.centerY, - endAngle: endAngle, - startAngle: startAngle, - size: opts.size, - i: i, - totalItems: 2, - animBeginArr: 0, - dur: 0, - isTrack: true, - easing: w.globals.easing - }); - } - - return g; - } - }, { - key: "drawArcs", - value: function drawArcs(opts) { - var w = this.w; // size, donutSize, centerX, centerY, colorArr, lineColorArr, sectorAngleArr, series - - var graphics = new Graphics(this.ctx); - var fill = new Fill(this.ctx); - var filters = new Filters(this.ctx); - var g = graphics.group(); - var strokeWidth = this.getStrokeWidth(opts); - opts.size = opts.size - strokeWidth / 2; - var hollowFillID = w.config.plotOptions.radialBar.hollow.background; - var hollowSize = opts.size - strokeWidth * opts.series.length - this.margin * opts.series.length - strokeWidth * parseInt(w.config.plotOptions.radialBar.track.strokeWidth, 10) / 100 / 2; - var hollowRadius = hollowSize - w.config.plotOptions.radialBar.hollow.margin; - - if (w.config.plotOptions.radialBar.hollow.image !== undefined) { - hollowFillID = this.drawHollowImage(opts, g, hollowSize, hollowFillID); - } - - var elHollow = this.drawHollow({ - size: hollowRadius, - centerX: opts.centerX, - centerY: opts.centerY, - fill: hollowFillID ? hollowFillID : 'transparent' - }); - - if (w.config.plotOptions.radialBar.hollow.dropShadow.enabled) { - var shadow = w.config.plotOptions.radialBar.hollow.dropShadow; - filters.dropShadow(elHollow, shadow); - } - - var shown = 1; - - if (!this.radialDataLabels.total.show && w.globals.series.length > 1) { - shown = 0; - } - - var dataLabels = null; - - if (this.radialDataLabels.show) { - dataLabels = this.renderInnerDataLabels(this.radialDataLabels, { - hollowSize: hollowSize, - centerX: opts.centerX, - centerY: opts.centerY, - opacity: shown - }); - } - - if (w.config.plotOptions.radialBar.hollow.position === 'back') { - g.add(elHollow); - - if (dataLabels) { - g.add(dataLabels); - } - } - - var reverseLoop = false; - - if (w.config.plotOptions.radialBar.inverseOrder) { - reverseLoop = true; - } - - for (var i = reverseLoop ? opts.series.length - 1 : 0; reverseLoop ? i >= 0 : i < opts.series.length; reverseLoop ? i-- : i++) { - var elRadialBarArc = graphics.group({ - class: "apexcharts-series apexcharts-radial-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[i]) - }); - g.add(elRadialBarArc); - elRadialBarArc.attr({ - rel: i + 1, - 'data:realIndex': i - }); - this.ctx.series.addCollapsedClassToSeries(elRadialBarArc, i); - opts.size = opts.size - strokeWidth - this.margin; - var pathFill = fill.fillPath({ - seriesNumber: i, - size: opts.size, - value: opts.series[i] - }); - var startAngle = this.startAngle; - var prevStartAngle = void 0; // if data exceeds 100, make it 100 - - var dataValue = Utils$1.negToZero(opts.series[i] > 100 ? 100 : opts.series[i]) / 100; - var endAngle = Math.round(this.totalAngle * dataValue) + this.startAngle; - var prevEndAngle = void 0; - - if (w.globals.dataChanged) { - prevStartAngle = this.startAngle; - prevEndAngle = Math.round(this.totalAngle * Utils$1.negToZero(w.globals.previousPaths[i]) / 100) + prevStartAngle; - } - - var currFullAngle = Math.abs(endAngle) + Math.abs(startAngle); - - if (currFullAngle >= 360) { - endAngle = endAngle - 0.01; - } - - var prevFullAngle = Math.abs(prevEndAngle) + Math.abs(prevStartAngle); - - if (prevFullAngle >= 360) { - prevEndAngle = prevEndAngle - 0.01; - } - - var angle = endAngle - startAngle; - var dashArray = Array.isArray(w.config.stroke.dashArray) ? w.config.stroke.dashArray[i] : w.config.stroke.dashArray; - var elPath = graphics.drawPath({ - d: '', - stroke: pathFill, - strokeWidth: strokeWidth, - fill: 'none', - fillOpacity: w.config.fill.opacity, - classes: 'apexcharts-radialbar-area apexcharts-radialbar-slice-' + i, - strokeDashArray: dashArray - }); - Graphics.setAttrs(elPath.node, { - 'data:angle': angle, - 'data:value': opts.series[i] - }); - - if (w.config.chart.dropShadow.enabled) { - var _shadow = w.config.chart.dropShadow; - filters.dropShadow(elPath, _shadow, i); - } - - filters.setSelectionFilter(elPath, 0, i); - this.addListeners(elPath, this.radialDataLabels); - elRadialBarArc.add(elPath); - elPath.attr({ - index: 0, - j: i - }); - var dur = 0; - - if (this.initialAnim && !w.globals.resized && !w.globals.dataChanged) { - dur = w.config.chart.animations.speed; - } - - if (w.globals.dataChanged) { - dur = w.config.chart.animations.dynamicAnimation.speed; - } - - this.animDur = dur / (opts.series.length * 1.2) + this.animDur; - this.animBeginArr.push(this.animDur); - this.animatePaths(elPath, { - centerX: opts.centerX, - centerY: opts.centerY, - endAngle: endAngle, - startAngle: startAngle, - prevEndAngle: prevEndAngle, - prevStartAngle: prevStartAngle, - size: opts.size, - i: i, - totalItems: 2, - animBeginArr: this.animBeginArr, - dur: dur, - shouldSetPrevPaths: true, - easing: w.globals.easing - }); - } - - return { - g: g, - elHollow: elHollow, - dataLabels: dataLabels - }; - } - }, { - key: "drawHollow", - value: function drawHollow(opts) { - var graphics = new Graphics(this.ctx); - var circle = graphics.drawCircle(opts.size * 2); - circle.attr({ - class: 'apexcharts-radialbar-hollow', - cx: opts.centerX, - cy: opts.centerY, - r: opts.size, - fill: opts.fill - }); - return circle; - } - }, { - key: "drawHollowImage", - value: function drawHollowImage(opts, g, hollowSize, hollowFillID) { - var w = this.w; - var fill = new Fill(this.ctx); - var randID = Utils$1.randomId(); - var hollowFillImg = w.config.plotOptions.radialBar.hollow.image; - - if (w.config.plotOptions.radialBar.hollow.imageClipped) { - fill.clippedImgArea({ - width: hollowSize, - height: hollowSize, - image: hollowFillImg, - patternID: "pattern".concat(w.globals.cuid).concat(randID) - }); - hollowFillID = "url(#pattern".concat(w.globals.cuid).concat(randID, ")"); - } else { - var imgWidth = w.config.plotOptions.radialBar.hollow.imageWidth; - var imgHeight = w.config.plotOptions.radialBar.hollow.imageHeight; - - if (imgWidth === undefined && imgHeight === undefined) { - var image = w.globals.dom.Paper.image(hollowFillImg).loaded(function (loader) { - this.move(opts.centerX - loader.width / 2 + w.config.plotOptions.radialBar.hollow.imageOffsetX, opts.centerY - loader.height / 2 + w.config.plotOptions.radialBar.hollow.imageOffsetY); - }); - g.add(image); - } else { - var _image = w.globals.dom.Paper.image(hollowFillImg).loaded(function (loader) { - this.move(opts.centerX - imgWidth / 2 + w.config.plotOptions.radialBar.hollow.imageOffsetX, opts.centerY - imgHeight / 2 + w.config.plotOptions.radialBar.hollow.imageOffsetY); - this.size(imgWidth, imgHeight); - }); - - g.add(_image); - } - } - - return hollowFillID; - } - }, { - key: "getStrokeWidth", - value: function getStrokeWidth(opts) { - var w = this.w; - return opts.size * (100 - parseInt(w.config.plotOptions.radialBar.hollow.size, 10)) / 100 / (opts.series.length + 1) - this.margin; - } - }]); - - return Radial; - }(Pie); - - /** - * ApexCharts RangeBar Class responsible for drawing Range/Timeline Bars. - * - * @module RangeBar - **/ - - var RangeBar = /*#__PURE__*/function (_Bar) { - _inherits(RangeBar, _Bar); - - var _super = _createSuper(RangeBar); - - function RangeBar() { - _classCallCheck(this, RangeBar); - - return _super.apply(this, arguments); - } - - _createClass(RangeBar, [{ - key: "draw", - value: function draw(series, seriesIndex) { - var w = this.w; - var graphics = new Graphics(this.ctx); - this.rangeBarOptions = this.w.config.plotOptions.rangeBar; - this.series = series; - this.seriesRangeStart = w.globals.seriesRangeStart; - this.seriesRangeEnd = w.globals.seriesRangeEnd; - this.barHelpers.initVariables(series); - var ret = graphics.group({ - class: 'apexcharts-rangebar-series apexcharts-plot-series' - }); - - for (var i = 0; i < series.length; i++) { - var x = void 0, - y = void 0, - xDivision = void 0, - // xDivision is the GRIDWIDTH divided by number of datapoints (columns) - yDivision = void 0, - // yDivision is the GRIDHEIGHT divided by number of datapoints (bars) - zeroH = void 0, - // zeroH is the baseline where 0 meets y axis - zeroW = void 0; // zeroW is the baseline where 0 meets x axis - - var realIndex = w.globals.comboCharts ? seriesIndex[i] : i; // el to which series will be drawn - - var elSeries = graphics.group({ - class: "apexcharts-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[realIndex]), - rel: i + 1, - 'data:realIndex': realIndex - }); - this.ctx.series.addCollapsedClassToSeries(elSeries, realIndex); - - if (series[i].length > 0) { - this.visibleI = this.visibleI + 1; - } - - var barHeight = 0; - var barWidth = 0; - - if (this.yRatio.length > 1) { - this.yaxisIndex = realIndex; - } - - var initPositions = this.barHelpers.initialPositions(); - y = initPositions.y; - zeroW = initPositions.zeroW; - x = initPositions.x; - barWidth = initPositions.barWidth; - xDivision = initPositions.xDivision; - zeroH = initPositions.zeroH; // eldatalabels - - var elDataLabelsWrap = graphics.group({ - class: 'apexcharts-datalabels', - 'data:realIndex': realIndex - }); - var elGoalsMarkers = graphics.group({ - class: 'apexcharts-rangebar-goals-markers', - style: "pointer-events: none" - }); - - for (var j = 0; j < w.globals.dataPoints; j++) { - var strokeWidth = this.barHelpers.getStrokeWidth(i, j, realIndex); - var y1 = this.seriesRangeStart[i][j]; - var y2 = this.seriesRangeEnd[i][j]; - var paths = null; - var barYPosition = null; - var params = { - x: x, - y: y, - strokeWidth: strokeWidth, - elSeries: elSeries - }; - yDivision = initPositions.yDivision; - barHeight = initPositions.barHeight; - - if (this.isHorizontal) { - barYPosition = y + barHeight * this.visibleI; - var seriesLen = this.seriesLen; - - if (w.config.plotOptions.bar.rangeBarGroupRows) { - seriesLen = 1; - } - - var srty = (yDivision - barHeight * seriesLen) / 2; - - if (typeof w.config.series[i].data[j] === 'undefined') { - // no data exists for further indexes, hence we need to get out the innr loop. - // As we are iterating over total datapoints, there is a possiblity the series might not have data for j index - break; - } - - if (w.config.series[i].data[j].x) { - var positions = this.detectOverlappingBars({ - i: i, - j: j, - barYPosition: barYPosition, - srty: srty, - barHeight: barHeight, - yDivision: yDivision, - initPositions: initPositions - }); - barHeight = positions.barHeight; - barYPosition = positions.barYPosition; - } - - paths = this.drawRangeBarPaths(_objectSpread2({ - indexes: { - i: i, - j: j, - realIndex: realIndex - }, - barHeight: barHeight, - barYPosition: barYPosition, - zeroW: zeroW, - yDivision: yDivision, - y1: y1, - y2: y2 - }, params)); - barWidth = paths.barWidth; - } else { - paths = this.drawRangeColumnPaths(_objectSpread2({ - indexes: { - i: i, - j: j, - realIndex: realIndex - }, - zeroH: zeroH, - barWidth: barWidth, - xDivision: xDivision - }, params)); - barHeight = paths.barHeight; - } - - var barGoalLine = this.barHelpers.drawGoalLine({ - barXPosition: paths.barXPosition, - barYPosition: barYPosition, - goalX: paths.goalX, - goalY: paths.goalY, - barHeight: barHeight, - barWidth: barWidth - }); - - if (barGoalLine) { - elGoalsMarkers.add(barGoalLine); - } - - y = paths.y; - x = paths.x; - var pathFill = this.barHelpers.getPathFillColor(series, i, j, realIndex); - var lineFill = w.globals.stroke.colors[realIndex]; - this.renderSeries({ - realIndex: realIndex, - pathFill: pathFill, - lineFill: lineFill, - j: j, - i: i, - x: x, - y: y, - y1: y1, - y2: y2, - pathFrom: paths.pathFrom, - pathTo: paths.pathTo, - strokeWidth: strokeWidth, - elSeries: elSeries, - series: series, - barHeight: barHeight, - barYPosition: barYPosition, - barWidth: barWidth, - elDataLabelsWrap: elDataLabelsWrap, - elGoalsMarkers: elGoalsMarkers, - visibleSeries: this.visibleI, - type: 'rangebar' - }); - } - - ret.add(elSeries); - } - - return ret; - } - }, { - key: "detectOverlappingBars", - value: function detectOverlappingBars(_ref) { - var i = _ref.i, - j = _ref.j, - barYPosition = _ref.barYPosition, - srty = _ref.srty, - barHeight = _ref.barHeight, - yDivision = _ref.yDivision, - initPositions = _ref.initPositions; - var w = this.w; - var overlaps = []; - var rangeName = w.config.series[i].data[j].rangeName; - var labelX = w.config.series[i].data[j].x; - var rowIndex = w.globals.labels.indexOf(labelX); - var overlappedIndex = w.globals.seriesRange[i].findIndex(function (tx) { - return tx.x === labelX && tx.overlaps.length > 0; - }); - - if (w.config.plotOptions.bar.rangeBarGroupRows) { - barYPosition = srty + yDivision * rowIndex; - } else { - barYPosition = srty + barHeight * this.visibleI + yDivision * rowIndex; - } - - if (overlappedIndex > -1 && !w.config.plotOptions.bar.rangeBarOverlap) { - overlaps = w.globals.seriesRange[i][overlappedIndex].overlaps; - - if (overlaps.indexOf(rangeName) > -1) { - barHeight = initPositions.barHeight / overlaps.length; - barYPosition = barHeight * this.visibleI + yDivision * (100 - parseInt(this.barOptions.barHeight, 10)) / 100 / 2 + barHeight * (this.visibleI + overlaps.indexOf(rangeName)) + yDivision * rowIndex; - } - } - - return { - barYPosition: barYPosition, - barHeight: barHeight - }; - } - }, { - key: "drawRangeColumnPaths", - value: function drawRangeColumnPaths(_ref2) { - var indexes = _ref2.indexes, - x = _ref2.x; - _ref2.strokeWidth; - var xDivision = _ref2.xDivision, - barWidth = _ref2.barWidth, - zeroH = _ref2.zeroH; - var w = this.w; - var i = indexes.i; - var j = indexes.j; - var yRatio = this.yRatio[this.yaxisIndex]; - var realIndex = indexes.realIndex; - var range = this.getRangeValue(realIndex, j); - var y1 = Math.min(range.start, range.end); - var y2 = Math.max(range.start, range.end); - - if (w.globals.isXNumeric) { - x = (w.globals.seriesX[i][j] - w.globals.minX) / this.xRatio - barWidth / 2; - } - - var barXPosition = x + barWidth * this.visibleI; - - if (typeof this.series[i][j] === 'undefined' || this.series[i][j] === null) { - y1 = zeroH; - } else { - y1 = zeroH - y1 / yRatio; - y2 = zeroH - y2 / yRatio; - } - - var barHeight = Math.abs(y2 - y1); - var paths = this.barHelpers.getColumnPaths({ - barXPosition: barXPosition, - barWidth: barWidth, - y1: y1, - y2: y2, - strokeWidth: this.strokeWidth, - series: this.seriesRangeEnd, - realIndex: indexes.realIndex, - i: realIndex, - j: j, - w: w - }); - - if (!w.globals.isXNumeric) { - x = x + xDivision; - } - - return { - pathTo: paths.pathTo, - pathFrom: paths.pathFrom, - barHeight: barHeight, - x: x, - y: y2, - goalY: this.barHelpers.getGoalValues('y', null, zeroH, i, j), - barXPosition: barXPosition - }; - } - }, { - key: "drawRangeBarPaths", - value: function drawRangeBarPaths(_ref3) { - var indexes = _ref3.indexes, - y = _ref3.y, - y1 = _ref3.y1, - y2 = _ref3.y2, - yDivision = _ref3.yDivision, - barHeight = _ref3.barHeight, - barYPosition = _ref3.barYPosition, - zeroW = _ref3.zeroW; - var w = this.w; - var x1 = zeroW + y1 / this.invertedYRatio; - var x2 = zeroW + y2 / this.invertedYRatio; - var barWidth = Math.abs(x2 - x1); - var paths = this.barHelpers.getBarpaths({ - barYPosition: barYPosition, - barHeight: barHeight, - x1: x1, - x2: x2, - strokeWidth: this.strokeWidth, - series: this.seriesRangeEnd, - i: indexes.realIndex, - realIndex: indexes.realIndex, - j: indexes.j, - w: w - }); - - if (!w.globals.isXNumeric) { - y = y + yDivision; - } - - return { - pathTo: paths.pathTo, - pathFrom: paths.pathFrom, - barWidth: barWidth, - x: x2, - goalX: this.barHelpers.getGoalValues('x', zeroW, null, indexes.realIndex, indexes.j), - y: y - }; - } - }, { - key: "getRangeValue", - value: function getRangeValue(i, j) { - var w = this.w; - return { - start: w.globals.seriesRangeStart[i][j], - end: w.globals.seriesRangeEnd[i][j] - }; - } - }]); - - return RangeBar; - }(Bar); - - var Helpers = /*#__PURE__*/function () { - function Helpers(lineCtx) { - _classCallCheck(this, Helpers); - - this.w = lineCtx.w; - this.lineCtx = lineCtx; - } - - _createClass(Helpers, [{ - key: "sameValueSeriesFix", - value: function sameValueSeriesFix(i, series) { - var w = this.w; - - if (w.config.fill.type === 'gradient' || w.config.fill.type[i] === 'gradient') { - var coreUtils = new CoreUtils(this.lineCtx.ctx, w); // applied only to LINE chart - // a small adjustment to allow gradient line to draw correctly for all same values - - /* #fix https://github.com/apexcharts/apexcharts.js/issues/358 */ - - if (coreUtils.seriesHaveSameValues(i)) { - var gSeries = series[i].slice(); - gSeries[gSeries.length - 1] = gSeries[gSeries.length - 1] + 0.000001; - series[i] = gSeries; - } - } - - return series; - } - }, { - key: "calculatePoints", - value: function calculatePoints(_ref) { - var series = _ref.series, - realIndex = _ref.realIndex, - x = _ref.x, - y = _ref.y, - i = _ref.i, - j = _ref.j, - prevY = _ref.prevY; - var w = this.w; - var ptX = []; - var ptY = []; - - if (j === 0) { - var xPT1st = this.lineCtx.categoryAxisCorrection + w.config.markers.offsetX; // the first point for line series - // we need to check whether it's not a time series, because a time series may - // start from the middle of the x axis - - if (w.globals.isXNumeric) { - xPT1st = (w.globals.seriesX[realIndex][0] - w.globals.minX) / this.lineCtx.xRatio + w.config.markers.offsetX; - } // push 2 points for the first data values - - - ptX.push(xPT1st); - ptY.push(Utils$1.isNumber(series[i][0]) ? prevY + w.config.markers.offsetY : null); - ptX.push(x + w.config.markers.offsetX); - ptY.push(Utils$1.isNumber(series[i][j + 1]) ? y + w.config.markers.offsetY : null); - } else { - ptX.push(x + w.config.markers.offsetX); - ptY.push(Utils$1.isNumber(series[i][j + 1]) ? y + w.config.markers.offsetY : null); - } - - var pointsPos = { - x: ptX, - y: ptY - }; - return pointsPos; - } - }, { - key: "checkPreviousPaths", - value: function checkPreviousPaths(_ref2) { - var pathFromLine = _ref2.pathFromLine, - pathFromArea = _ref2.pathFromArea, - realIndex = _ref2.realIndex; - var w = this.w; - - for (var pp = 0; pp < w.globals.previousPaths.length; pp++) { - var gpp = w.globals.previousPaths[pp]; - - if ((gpp.type === 'line' || gpp.type === 'area') && gpp.paths.length > 0 && parseInt(gpp.realIndex, 10) === parseInt(realIndex, 10)) { - if (gpp.type === 'line') { - this.lineCtx.appendPathFrom = false; - pathFromLine = w.globals.previousPaths[pp].paths[0].d; - } else if (gpp.type === 'area') { - this.lineCtx.appendPathFrom = false; - pathFromArea = w.globals.previousPaths[pp].paths[0].d; - - if (w.config.stroke.show && w.globals.previousPaths[pp].paths[1]) { - pathFromLine = w.globals.previousPaths[pp].paths[1].d; - } - } - } - } - - return { - pathFromLine: pathFromLine, - pathFromArea: pathFromArea - }; - } - }, { - key: "determineFirstPrevY", - value: function determineFirstPrevY(_ref3) { - var _series$i; - - var i = _ref3.i, - series = _ref3.series, - prevY = _ref3.prevY, - lineYPosition = _ref3.lineYPosition; - var w = this.w; - - if (typeof ((_series$i = series[i]) === null || _series$i === void 0 ? void 0 : _series$i[0]) !== 'undefined') { - if (w.config.chart.stacked) { - if (i > 0) { - // 1st y value of previous series - lineYPosition = this.lineCtx.prevSeriesY[i - 1][0]; - } else { - // the first series will not have prevY values - lineYPosition = this.lineCtx.zeroY; - } - } else { - lineYPosition = this.lineCtx.zeroY; - } - - prevY = lineYPosition - series[i][0] / this.lineCtx.yRatio[this.lineCtx.yaxisIndex] + (this.lineCtx.isReversed ? series[i][0] / this.lineCtx.yRatio[this.lineCtx.yaxisIndex] : 0) * 2; - } else { - // the first value in the current series is null - if (w.config.chart.stacked && i > 0 && typeof series[i][0] === 'undefined') { - // check for undefined value (undefined value will occur when we clear the series while user clicks on legend to hide serieses) - for (var s = i - 1; s >= 0; s--) { - // for loop to get to 1st previous value until we get it - if (series[s][0] !== null && typeof series[s][0] !== 'undefined') { - lineYPosition = this.lineCtx.prevSeriesY[s][0]; - prevY = lineYPosition; - break; - } - } - } - } - - return { - prevY: prevY, - lineYPosition: lineYPosition - }; - } - }]); - - return Helpers; - }(); - - /** - * ApexCharts Line Class responsible for drawing Line / Area / RangeArea Charts. - * This class is also responsible for generating values for Bubble/Scatter charts, so need to rename it to Axis Charts to avoid confusions - * @module Line - **/ - - var Line = /*#__PURE__*/function () { - function Line(ctx, xyRatios, isPointsChart) { - _classCallCheck(this, Line); - - this.ctx = ctx; - this.w = ctx.w; - this.xyRatios = xyRatios; - this.pointsChart = !(this.w.config.chart.type !== 'bubble' && this.w.config.chart.type !== 'scatter') || isPointsChart; - this.scatter = new Scatter(this.ctx); - this.noNegatives = this.w.globals.minX === Number.MAX_VALUE; - this.lineHelpers = new Helpers(this); - this.markers = new Markers(this.ctx); - this.prevSeriesY = []; - this.categoryAxisCorrection = 0; - this.yaxisIndex = 0; - } - - _createClass(Line, [{ - key: "draw", - value: function draw(series, ctype, seriesIndex, seriesRangeEnd) { - var w = this.w; - var graphics = new Graphics(this.ctx); - var type = w.globals.comboCharts ? ctype : w.config.chart.type; - var ret = graphics.group({ - class: "apexcharts-".concat(type, "-series apexcharts-plot-series") - }); - var coreUtils = new CoreUtils(this.ctx, w); - this.yRatio = this.xyRatios.yRatio; - this.zRatio = this.xyRatios.zRatio; - this.xRatio = this.xyRatios.xRatio; - this.baseLineY = this.xyRatios.baseLineY; - series = coreUtils.getLogSeries(series); - this.yRatio = coreUtils.getLogYRatios(this.yRatio); // push all series in an array, so we can draw in reverse order (for stacked charts) - - var allSeries = []; - - for (var i = 0; i < series.length; i++) { - series = this.lineHelpers.sameValueSeriesFix(i, series); - var realIndex = w.globals.comboCharts ? seriesIndex[i] : i; - - this._initSerieVariables(series, i, realIndex); - - var yArrj = []; // hold y values of current iterating series - - var xArrj = []; // hold x values of current iterating series - - var x = w.globals.padHorizontal + this.categoryAxisCorrection; - var y = 1; - var linePaths = []; - var areaPaths = []; - this.ctx.series.addCollapsedClassToSeries(this.elSeries, realIndex); - - if (w.globals.isXNumeric && w.globals.seriesX.length > 0) { - x = (w.globals.seriesX[realIndex][0] - w.globals.minX) / this.xRatio; - } - - xArrj.push(x); - var pX = x; - var pY = void 0; - var pY2 = void 0; - var prevX = pX; - var prevY = this.zeroY; - var prevY2 = this.zeroY; - var lineYPosition = 0; // the first value in the current series is not null or undefined - - var firstPrevY = this.lineHelpers.determineFirstPrevY({ - i: i, - series: series, - prevY: prevY, - lineYPosition: lineYPosition - }); - prevY = firstPrevY.prevY; - yArrj.push(prevY); - pY = prevY; // y2 are needed for range-area charts - - var firstPrevY2 = void 0; - - if (type === 'rangeArea') { - firstPrevY2 = this.lineHelpers.determineFirstPrevY({ - i: i, - series: seriesRangeEnd, - prevY: prevY2, - lineYPosition: lineYPosition - }); - prevY2 = firstPrevY2.prevY; - pY2 = prevY2; - } - - var pathsFrom = this._calculatePathsFrom({ - type: type, - series: series, - i: i, - realIndex: realIndex, - prevX: prevX, - prevY: prevY, - prevY2: prevY2 - }); - - var iteratingOpts = { - type: type, - series: series, - realIndex: realIndex, - i: i, - x: x, - y: y, - pX: pX, - pY: pY, - pathsFrom: pathsFrom, - linePaths: linePaths, - areaPaths: areaPaths, - seriesIndex: seriesIndex, - lineYPosition: lineYPosition, - xArrj: xArrj, - yArrj: yArrj, - seriesRangeEnd: seriesRangeEnd - }; - - var paths = this._iterateOverDataPoints(_objectSpread2(_objectSpread2({}, iteratingOpts), {}, { - iterations: type === 'rangeArea' ? series[i].length - 1 : undefined, - isRangeStart: true - })); - - if (type === 'rangeArea') { - var pathsFrom2 = this._calculatePathsFrom({ - series: seriesRangeEnd, - i: i, - realIndex: realIndex, - prevX: prevX, - prevY: prevY2 - }); - - var rangePaths = this._iterateOverDataPoints(_objectSpread2(_objectSpread2({}, iteratingOpts), {}, { - series: seriesRangeEnd, - pY: pY2, - pathsFrom: pathsFrom2, - iterations: seriesRangeEnd[i].length - 1, - isRangeStart: false - })); - - paths.linePaths[0] = rangePaths.linePath + paths.linePath; - paths.pathFromLine = rangePaths.pathFromLine + paths.pathFromLine; - } - - this._handlePaths({ - type: type, - realIndex: realIndex, - i: i, - paths: paths - }); - - this.elSeries.add(this.elPointsMain); - this.elSeries.add(this.elDataLabelsWrap); - allSeries.push(this.elSeries); - } - - if (w.config.chart.stacked) { - for (var s = allSeries.length; s > 0; s--) { - ret.add(allSeries[s - 1]); - } - } else { - for (var _s = 0; _s < allSeries.length; _s++) { - ret.add(allSeries[_s]); - } - } - - return ret; - } - }, { - key: "_initSerieVariables", - value: function _initSerieVariables(series, i, realIndex) { - var w = this.w; - var graphics = new Graphics(this.ctx); // width divided into equal parts - - this.xDivision = w.globals.gridWidth / (w.globals.dataPoints - (w.config.xaxis.tickPlacement === 'on' ? 1 : 0)); - this.strokeWidth = Array.isArray(w.config.stroke.width) ? w.config.stroke.width[realIndex] : w.config.stroke.width; - - if (this.yRatio.length > 1) { - this.yaxisIndex = realIndex; - } - - this.isReversed = w.config.yaxis[this.yaxisIndex] && w.config.yaxis[this.yaxisIndex].reversed; // zeroY is the 0 value in y series which can be used in negative charts - - this.zeroY = w.globals.gridHeight - this.baseLineY[this.yaxisIndex] - (this.isReversed ? w.globals.gridHeight : 0) + (this.isReversed ? this.baseLineY[this.yaxisIndex] * 2 : 0); - this.areaBottomY = this.zeroY; - - if (this.zeroY > w.globals.gridHeight || w.config.plotOptions.area.fillTo === 'end') { - this.areaBottomY = w.globals.gridHeight; - } - - this.categoryAxisCorrection = this.xDivision / 2; // el to which series will be drawn - - this.elSeries = graphics.group({ - class: "apexcharts-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[realIndex]) - }); // points - - this.elPointsMain = graphics.group({ - class: 'apexcharts-series-markers-wrap', - 'data:realIndex': realIndex - }); // eldatalabels - - this.elDataLabelsWrap = graphics.group({ - class: 'apexcharts-datalabels', - 'data:realIndex': realIndex - }); - var longestSeries = series[i].length === w.globals.dataPoints; - this.elSeries.attr({ - 'data:longestSeries': longestSeries, - rel: i + 1, - 'data:realIndex': realIndex - }); - this.appendPathFrom = true; - } - }, { - key: "_calculatePathsFrom", - value: function _calculatePathsFrom(_ref) { - var type = _ref.type, - series = _ref.series, - i = _ref.i, - realIndex = _ref.realIndex, - prevX = _ref.prevX, - prevY = _ref.prevY, - prevY2 = _ref.prevY2; - var w = this.w; - var graphics = new Graphics(this.ctx); - var linePath, areaPath, pathFromLine, pathFromArea; - - if (series[i][0] === null) { - // when the first value itself is null, we need to move the pointer to a location where a null value is not found - for (var s = 0; s < series[i].length; s++) { - if (series[i][s] !== null) { - prevX = this.xDivision * s; - prevY = this.zeroY - series[i][s] / this.yRatio[this.yaxisIndex]; - linePath = graphics.move(prevX, prevY); - areaPath = graphics.move(prevX, this.areaBottomY); - break; - } - } - } else { - linePath = graphics.move(prevX, prevY); - - if (type === 'rangeArea') { - linePath = graphics.move(prevX, prevY2) + graphics.line(prevX, prevY); - } - - areaPath = graphics.move(prevX, this.areaBottomY) + graphics.line(prevX, prevY); - } - - pathFromLine = graphics.move(-1, this.zeroY) + graphics.line(-1, this.zeroY); - pathFromArea = graphics.move(-1, this.zeroY) + graphics.line(-1, this.zeroY); - - if (w.globals.previousPaths.length > 0) { - var pathFrom = this.lineHelpers.checkPreviousPaths({ - pathFromLine: pathFromLine, - pathFromArea: pathFromArea, - realIndex: realIndex - }); - pathFromLine = pathFrom.pathFromLine; - pathFromArea = pathFrom.pathFromArea; - } - - return { - prevX: prevX, - prevY: prevY, - linePath: linePath, - areaPath: areaPath, - pathFromLine: pathFromLine, - pathFromArea: pathFromArea - }; - } - }, { - key: "_handlePaths", - value: function _handlePaths(_ref2) { - var type = _ref2.type, - realIndex = _ref2.realIndex, - i = _ref2.i, - paths = _ref2.paths; - var w = this.w; - var graphics = new Graphics(this.ctx); - var fill = new Fill(this.ctx); // push all current y values array to main PrevY Array - - this.prevSeriesY.push(paths.yArrj); // push all x val arrays into main xArr - - w.globals.seriesXvalues[realIndex] = paths.xArrj; - w.globals.seriesYvalues[realIndex] = paths.yArrj; - var forecast = w.config.forecastDataPoints; - - if (forecast.count > 0 && type !== 'rangeArea') { - var forecastCutoff = w.globals.seriesXvalues[realIndex][w.globals.seriesXvalues[realIndex].length - forecast.count - 1]; - var elForecastMask = graphics.drawRect(forecastCutoff, 0, w.globals.gridWidth, w.globals.gridHeight, 0); - w.globals.dom.elForecastMask.appendChild(elForecastMask.node); - var elNonForecastMask = graphics.drawRect(0, 0, forecastCutoff, w.globals.gridHeight, 0); - w.globals.dom.elNonForecastMask.appendChild(elNonForecastMask.node); - } // these elements will be shown after area path animation completes - - - if (!this.pointsChart) { - w.globals.delayedElements.push({ - el: this.elPointsMain.node, - index: realIndex - }); - } - - var defaultRenderedPathOptions = { - i: i, - realIndex: realIndex, - animationDelay: i, - initialSpeed: w.config.chart.animations.speed, - dataChangeSpeed: w.config.chart.animations.dynamicAnimation.speed, - className: "apexcharts-".concat(type) - }; - - if (type === 'area') { - var pathFill = fill.fillPath({ - seriesNumber: realIndex - }); - - for (var p = 0; p < paths.areaPaths.length; p++) { - var renderedPath = graphics.renderPaths(_objectSpread2(_objectSpread2({}, defaultRenderedPathOptions), {}, { - pathFrom: paths.pathFromArea, - pathTo: paths.areaPaths[p], - stroke: 'none', - strokeWidth: 0, - strokeLineCap: null, - fill: pathFill - })); - this.elSeries.add(renderedPath); - } - } - - if (w.config.stroke.show && !this.pointsChart) { - var lineFill = null; - - if (type === 'line') { - lineFill = fill.fillPath({ - seriesNumber: realIndex, - i: i - }); - } else { - if (w.config.stroke.fill.type === 'solid') { - lineFill = w.globals.stroke.colors[realIndex]; - } else { - var prevFill = w.config.fill; - w.config.fill = w.config.stroke.fill; - lineFill = fill.fillPath({ - seriesNumber: realIndex, - i: i - }); - w.config.fill = prevFill; - } - } // range-area paths are drawn using linePaths - - - for (var _p = 0; _p < paths.linePaths.length; _p++) { - var _pathFill = lineFill; - - if (type === 'rangeArea') { - _pathFill = fill.fillPath({ - seriesNumber: realIndex - }); - } - - var linePathCommonOpts = _objectSpread2(_objectSpread2({}, defaultRenderedPathOptions), {}, { - pathFrom: paths.pathFromLine, - pathTo: paths.linePaths[_p], - stroke: lineFill, - strokeWidth: this.strokeWidth, - strokeLineCap: w.config.stroke.lineCap, - fill: type === 'rangeArea' ? _pathFill : 'none' - }); - - var _renderedPath = graphics.renderPaths(linePathCommonOpts); - - this.elSeries.add(_renderedPath); - - _renderedPath.attr('fill-rule', "evenodd"); - - if (forecast.count > 0 && type !== 'rangeArea') { - var renderedForecastPath = graphics.renderPaths(linePathCommonOpts); - renderedForecastPath.node.setAttribute('stroke-dasharray', forecast.dashArray); - - if (forecast.strokeWidth) { - renderedForecastPath.node.setAttribute('stroke-width', forecast.strokeWidth); - } - - this.elSeries.add(renderedForecastPath); - renderedForecastPath.attr('clip-path', "url(#forecastMask".concat(w.globals.cuid, ")")); - - _renderedPath.attr('clip-path', "url(#nonForecastMask".concat(w.globals.cuid, ")")); - } - } - } - } - }, { - key: "_iterateOverDataPoints", - value: function _iterateOverDataPoints(_ref3) { - var type = _ref3.type, - series = _ref3.series, - iterations = _ref3.iterations, - realIndex = _ref3.realIndex, - i = _ref3.i, - x = _ref3.x, - y = _ref3.y, - pX = _ref3.pX, - pY = _ref3.pY, - pathsFrom = _ref3.pathsFrom, - linePaths = _ref3.linePaths, - areaPaths = _ref3.areaPaths, - seriesIndex = _ref3.seriesIndex, - lineYPosition = _ref3.lineYPosition, - xArrj = _ref3.xArrj, - yArrj = _ref3.yArrj, - isRangeStart = _ref3.isRangeStart, - seriesRangeEnd = _ref3.seriesRangeEnd; - var w = this.w; - var graphics = new Graphics(this.ctx); - var yRatio = this.yRatio; - var prevY = pathsFrom.prevY, - linePath = pathsFrom.linePath, - areaPath = pathsFrom.areaPath, - pathFromLine = pathsFrom.pathFromLine, - pathFromArea = pathsFrom.pathFromArea; - var minY = Utils$1.isNumber(w.globals.minYArr[realIndex]) ? w.globals.minYArr[realIndex] : w.globals.minY; - - if (!iterations) { - iterations = w.globals.dataPoints > 1 ? w.globals.dataPoints - 1 : w.globals.dataPoints; - } - - var y2 = y; - - for (var j = 0; j < iterations; j++) { - var isNull = typeof series[i][j + 1] === 'undefined' || series[i][j + 1] === null; - - if (w.globals.isXNumeric) { - var sX = w.globals.seriesX[realIndex][j + 1]; - - if (typeof w.globals.seriesX[realIndex][j + 1] === 'undefined') { - /* fix #374 */ - sX = w.globals.seriesX[realIndex][iterations - 1]; - } - - x = (sX - w.globals.minX) / this.xRatio; - } else { - x = x + this.xDivision; - } - - if (w.config.chart.stacked) { - if (i > 0 && w.globals.collapsedSeries.length < w.config.series.length - 1) { - // a collapsed series in a stacked bar chart may provide wrong result for the next series, hence find the prevIndex of prev series which is not collapsed - fixes apexcharts.js#1372 - var prevIndex = function prevIndex(pi) { - var pii = pi; - - for (var cpi = 0; cpi < w.globals.series.length; cpi++) { - if (w.globals.collapsedSeriesIndices.indexOf(pi) > -1) { - pii--; - break; - } - } - - return pii >= 0 ? pii : 0; - }; - - lineYPosition = this.prevSeriesY[prevIndex(i - 1)][j + 1]; - } else { - // the first series will not have prevY values - lineYPosition = this.zeroY; - } - } else { - lineYPosition = this.zeroY; - } - - if (isNull) { - y = lineYPosition - minY / yRatio[this.yaxisIndex] + (this.isReversed ? minY / yRatio[this.yaxisIndex] : 0) * 2; - } else { - y = lineYPosition - series[i][j + 1] / yRatio[this.yaxisIndex] + (this.isReversed ? series[i][j + 1] / yRatio[this.yaxisIndex] : 0) * 2; - - if (type === 'rangeArea') { - y2 = lineYPosition - seriesRangeEnd[i][j + 1] / yRatio[this.yaxisIndex] + (this.isReversed ? seriesRangeEnd[i][j + 1] / yRatio[this.yaxisIndex] : 0) * 2; - } - } // push current X - - - xArrj.push(x); // push current Y that will be used as next series's bottom position - - yArrj.push(y); - var pointsPos = this.lineHelpers.calculatePoints({ - series: series, - x: x, - y: y, - realIndex: realIndex, - i: i, - j: j, - prevY: prevY - }); - - var calculatedPaths = this._createPaths({ - type: type, - series: series, - i: i, - realIndex: realIndex, - j: j, - x: x, - y: y, - y2: y2, - pX: pX, - pY: pY, - linePath: linePath, - areaPath: areaPath, - linePaths: linePaths, - areaPaths: areaPaths, - seriesIndex: seriesIndex, - isRangeStart: isRangeStart - }); - - areaPaths = calculatedPaths.areaPaths; - linePaths = calculatedPaths.linePaths; - pX = calculatedPaths.pX; - pY = calculatedPaths.pY; - areaPath = calculatedPaths.areaPath; - linePath = calculatedPaths.linePath; - - if (this.appendPathFrom) { - pathFromLine = pathFromLine + graphics.line(x, this.zeroY); - pathFromArea = pathFromArea + graphics.line(x, this.zeroY); - } - - this.handleNullDataPoints(series, pointsPos, i, j, realIndex); - - this._handleMarkersAndLabels({ - type: type, - pointsPos: pointsPos, - i: i, - j: j, - realIndex: realIndex, - isRangeStart: isRangeStart - }); - } - - return { - yArrj: yArrj, - xArrj: xArrj, - pathFromArea: pathFromArea, - areaPaths: areaPaths, - pathFromLine: pathFromLine, - linePaths: linePaths, - linePath: linePath, - areaPath: areaPath - }; - } - }, { - key: "_handleMarkersAndLabels", - value: function _handleMarkersAndLabels(_ref4) { - var type = _ref4.type, - pointsPos = _ref4.pointsPos, - isRangeStart = _ref4.isRangeStart, - i = _ref4.i, - j = _ref4.j, - realIndex = _ref4.realIndex; - var w = this.w; - var dataLabels = new DataLabels(this.ctx); - - if (!this.pointsChart) { - if (w.globals.series[i].length > 1) { - this.elPointsMain.node.classList.add('apexcharts-element-hidden'); - } - - var elPointsWrap = this.markers.plotChartMarkers(pointsPos, realIndex, j + 1); - - if (elPointsWrap !== null) { - this.elPointsMain.add(elPointsWrap); - } - } else { - // scatter / bubble chart points creation - this.scatter.draw(this.elSeries, j, { - realIndex: realIndex, - pointsPos: pointsPos, - zRatio: this.zRatio, - elParent: this.elPointsMain - }); - } - - var drawnLabels = dataLabels.drawDataLabel({ - type: type, - isRangeStart: isRangeStart, - pos: pointsPos, - i: realIndex, - j: j + 1 - }); - - if (drawnLabels !== null) { - this.elDataLabelsWrap.add(drawnLabels); - } - } - }, { - key: "_createPaths", - value: function _createPaths(_ref5) { - var type = _ref5.type, - series = _ref5.series, - i = _ref5.i, - realIndex = _ref5.realIndex, - j = _ref5.j, - x = _ref5.x, - y = _ref5.y, - y2 = _ref5.y2, - pX = _ref5.pX, - pY = _ref5.pY, - linePath = _ref5.linePath, - areaPath = _ref5.areaPath, - linePaths = _ref5.linePaths, - areaPaths = _ref5.areaPaths, - seriesIndex = _ref5.seriesIndex, - isRangeStart = _ref5.isRangeStart; - var w = this.w; - var graphics = new Graphics(this.ctx); - var curve = w.config.stroke.curve; - var areaBottomY = this.areaBottomY; - - if (Array.isArray(w.config.stroke.curve)) { - if (Array.isArray(seriesIndex)) { - curve = w.config.stroke.curve[seriesIndex[i]]; - } else { - curve = w.config.stroke.curve[i]; - } - } // logic of smooth curve derived from chartist - // CREDITS: https://gionkunz.github.io/chartist-js/ - - - if (curve === 'smooth') { - var length = (x - pX) * 0.35; - - if (w.globals.hasNullValues) { - if (series[i][j] !== null) { - if (series[i][j + 1] !== null) { - linePath = graphics.move(pX, pY) + graphics.curve(pX + length, pY, x - length, y, x + 1, y); - areaPath = graphics.move(pX + 1, pY) + graphics.curve(pX + length, pY, x - length, y, x + 1, y) + graphics.line(x, areaBottomY) + graphics.line(pX, areaBottomY) + 'z'; - } else { - linePath = graphics.move(pX, pY); - areaPath = graphics.move(pX, pY) + 'z'; - } - } - - linePaths.push(linePath); - areaPaths.push(areaPath); - } else { - linePath = linePath + graphics.curve(pX + length, pY, x - length, y, x, y); - areaPath = areaPath + graphics.curve(pX + length, pY, x - length, y, x, y); - } - - pX = x; - pY = y; - - if (j === series[i].length - 2) { - // last loop, close path - areaPath = areaPath + graphics.curve(pX, pY, x, y, x, areaBottomY) + graphics.move(x, y) + 'z'; - - if (type === 'rangeArea' && isRangeStart) { - linePath = linePath + graphics.curve(pX, pY, x, y, x, y2) + graphics.move(x, y2) + 'z'; - } else { - if (!w.globals.hasNullValues) { - linePaths.push(linePath); - areaPaths.push(areaPath); - } - } - } - } else { - if (series[i][j + 1] === null) { - linePath = linePath + graphics.move(x, y); - var numericOrCatX = w.globals.isXNumeric ? (w.globals.seriesX[realIndex][j] - w.globals.minX) / this.xRatio : x - this.xDivision; - areaPath = areaPath + graphics.line(numericOrCatX, areaBottomY) + graphics.move(x, y) + 'z'; - } - - if (series[i][j] === null) { - linePath = linePath + graphics.move(x, y); - areaPath = areaPath + graphics.move(x, areaBottomY); - } - - if (curve === 'stepline') { - linePath = linePath + graphics.line(x, null, 'H') + graphics.line(null, y, 'V'); - areaPath = areaPath + graphics.line(x, null, 'H') + graphics.line(null, y, 'V'); - } else if (curve === 'straight') { - linePath = linePath + graphics.line(x, y); - areaPath = areaPath + graphics.line(x, y); - } - - if (j === series[i].length - 2) { - // last loop, close path - areaPath = areaPath + graphics.line(x, areaBottomY) + graphics.move(x, y) + 'z'; - - if (type === 'rangeArea' && isRangeStart) { - linePath = linePath + graphics.line(x, y2) + graphics.move(x, y2) + 'z'; - } else { - linePaths.push(linePath); - areaPaths.push(areaPath); - } - } - } - - return { - linePaths: linePaths, - areaPaths: areaPaths, - pX: pX, - pY: pY, - linePath: linePath, - areaPath: areaPath - }; - } - }, { - key: "handleNullDataPoints", - value: function handleNullDataPoints(series, pointsPos, i, j, realIndex) { - var w = this.w; - - if (series[i][j] === null && w.config.markers.showNullDataPoints || series[i].length === 1) { - // fixes apexcharts.js#1282, #1252 - var elPointsWrap = this.markers.plotChartMarkers(pointsPos, realIndex, j + 1, this.strokeWidth - w.config.markers.strokeWidth / 2, true); - - if (elPointsWrap !== null) { - this.elPointsMain.add(elPointsWrap); - } - } - } - }]); - - return Line; - }(); - - /* - * treemap-squarify.js - open source implementation of squarified treemaps - * - * Treemap Squared 0.5 - Treemap Charting library - * - * https://github.com/imranghory/treemap-squared/ - * - * Copyright (c) 2012 Imran Ghory (imranghory@gmail.com) - * Licensed under the MIT (http://www.opensource.org/licenses/mit-license.php) license. - * - * - * Implementation of the squarify treemap algorithm described in: - * - * Bruls, Mark; Huizing, Kees; van Wijk, Jarke J. (2000), "Squarified treemaps" - * in de Leeuw, W.; van Liere, R., Data Visualization 2000: - * Proc. Joint Eurographics and IEEE TCVG Symp. on Visualization, Springer-Verlag, pp. 33–42. - * - * Paper is available online at: http://www.win.tue.nl/~vanwijk/stm.pdf - * - * The code in this file is completeley decoupled from the drawing code so it should be trivial - * to port it to any other vector drawing library. Given an array of datapoints this library returns - * an array of cartesian coordinates that represent the rectangles that make up the treemap. - * - * The library also supports multidimensional data (nested treemaps) and performs normalization on the data. - * - * See the README file for more details. - */ - window.TreemapSquared = {}; - - (function () { - - window.TreemapSquared.generate = function () { - function Container(xoffset, yoffset, width, height) { - this.xoffset = xoffset; // offset from the the top left hand corner - - this.yoffset = yoffset; // ditto - - this.height = height; - this.width = width; - - this.shortestEdge = function () { - return Math.min(this.height, this.width); - }; // getCoordinates - for a row of boxes which we've placed - // return an array of their cartesian coordinates - - - this.getCoordinates = function (row) { - var coordinates = []; - var subxoffset = this.xoffset, - subyoffset = this.yoffset; //our offset within the container - - var areawidth = sumArray(row) / this.height; - var areaheight = sumArray(row) / this.width; - var i; - - if (this.width >= this.height) { - for (i = 0; i < row.length; i++) { - coordinates.push([subxoffset, subyoffset, subxoffset + areawidth, subyoffset + row[i] / areawidth]); - subyoffset = subyoffset + row[i] / areawidth; - } - } else { - for (i = 0; i < row.length; i++) { - coordinates.push([subxoffset, subyoffset, subxoffset + row[i] / areaheight, subyoffset + areaheight]); - subxoffset = subxoffset + row[i] / areaheight; - } - } - - return coordinates; - }; // cutArea - once we've placed some boxes into an row we then need to identify the remaining area, - // this function takes the area of the boxes we've placed and calculates the location and - // dimensions of the remaining space and returns a container box defined by the remaining area - - - this.cutArea = function (area) { - var newcontainer; - - if (this.width >= this.height) { - var areawidth = area / this.height; - var newwidth = this.width - areawidth; - newcontainer = new Container(this.xoffset + areawidth, this.yoffset, newwidth, this.height); - } else { - var areaheight = area / this.width; - var newheight = this.height - areaheight; - newcontainer = new Container(this.xoffset, this.yoffset + areaheight, this.width, newheight); - } - - return newcontainer; - }; - } // normalize - the Bruls algorithm assumes we're passing in areas that nicely fit into our - // container box, this method takes our raw data and normalizes the data values into - // area values so that this assumption is valid. - - - function normalize(data, area) { - var normalizeddata = []; - var sum = sumArray(data); - var multiplier = area / sum; - var i; - - for (i = 0; i < data.length; i++) { - normalizeddata[i] = data[i] * multiplier; - } - - return normalizeddata; - } // treemapMultidimensional - takes multidimensional data (aka [[23,11],[11,32]] - nested array) - // and recursively calls itself using treemapSingledimensional - // to create a patchwork of treemaps and merge them - - - function treemapMultidimensional(data, width, height, xoffset, yoffset) { - xoffset = typeof xoffset === 'undefined' ? 0 : xoffset; - yoffset = typeof yoffset === 'undefined' ? 0 : yoffset; - var mergeddata = []; - var mergedtreemap; - var results = []; - var i; - - if (isArray(data[0])) { - // if we've got more dimensions of depth - for (i = 0; i < data.length; i++) { - mergeddata[i] = sumMultidimensionalArray(data[i]); - } - - mergedtreemap = treemapSingledimensional(mergeddata, width, height, xoffset, yoffset); - - for (i = 0; i < data.length; i++) { - results.push(treemapMultidimensional(data[i], mergedtreemap[i][2] - mergedtreemap[i][0], mergedtreemap[i][3] - mergedtreemap[i][1], mergedtreemap[i][0], mergedtreemap[i][1])); - } - } else { - results = treemapSingledimensional(data, width, height, xoffset, yoffset); - } - - return results; - } // treemapSingledimensional - simple wrapper around squarify - - - function treemapSingledimensional(data, width, height, xoffset, yoffset) { - xoffset = typeof xoffset === 'undefined' ? 0 : xoffset; - yoffset = typeof yoffset === 'undefined' ? 0 : yoffset; - var rawtreemap = squarify(normalize(data, width * height), [], new Container(xoffset, yoffset, width, height), []); - return flattenTreemap(rawtreemap); - } // flattenTreemap - squarify implementation returns an array of arrays of coordinates - // because we have a new array everytime we switch to building a new row - // this converts it into an array of coordinates. - - - function flattenTreemap(rawtreemap) { - var flattreemap = []; - var i, j; - - for (i = 0; i < rawtreemap.length; i++) { - for (j = 0; j < rawtreemap[i].length; j++) { - flattreemap.push(rawtreemap[i][j]); - } - } - - return flattreemap; - } // squarify - as per the Bruls paper - // plus coordinates stack and containers so we get - // usable data out of it - - - function squarify(data, currentrow, container, stack) { - var length; - var nextdatapoint; - var newcontainer; - - if (data.length === 0) { - stack.push(container.getCoordinates(currentrow)); - return; - } - - length = container.shortestEdge(); - nextdatapoint = data[0]; - - if (improvesRatio(currentrow, nextdatapoint, length)) { - currentrow.push(nextdatapoint); - squarify(data.slice(1), currentrow, container, stack); - } else { - newcontainer = container.cutArea(sumArray(currentrow), stack); - stack.push(container.getCoordinates(currentrow)); - squarify(data, [], newcontainer, stack); - } - - return stack; - } // improveRatio - implements the worse calculation and comparision as given in Bruls - // (note the error in the original paper; fixed here) - - - function improvesRatio(currentrow, nextnode, length) { - var newrow; - - if (currentrow.length === 0) { - return true; - } - - newrow = currentrow.slice(); - newrow.push(nextnode); - var currentratio = calculateRatio(currentrow, length); - var newratio = calculateRatio(newrow, length); // the pseudocode in the Bruls paper has the direction of the comparison - // wrong, this is the correct one. - - return currentratio >= newratio; - } // calculateRatio - calculates the maximum width to height ratio of the - // boxes in this row - - - function calculateRatio(row, length) { - var min = Math.min.apply(Math, row); - var max = Math.max.apply(Math, row); - var sum = sumArray(row); - return Math.max(Math.pow(length, 2) * max / Math.pow(sum, 2), Math.pow(sum, 2) / (Math.pow(length, 2) * min)); - } // isArray - checks if arr is an array - - - function isArray(arr) { - return arr && arr.constructor === Array; - } // sumArray - sums a single dimensional array - - - function sumArray(arr) { - var sum = 0; - var i; - - for (i = 0; i < arr.length; i++) { - sum += arr[i]; - } - - return sum; - } // sumMultidimensionalArray - sums the values in a nested array (aka [[0,1],[[2,3]]]) - - - function sumMultidimensionalArray(arr) { - var i, - total = 0; - - if (isArray(arr[0])) { - for (i = 0; i < arr.length; i++) { - total += sumMultidimensionalArray(arr[i]); - } - } else { - total = sumArray(arr); - } - - return total; - } - - return treemapMultidimensional; - }(); - })(); - - /** - * ApexCharts TreemapChart Class. - * @module TreemapChart - **/ - - var TreemapChart = /*#__PURE__*/function () { - function TreemapChart(ctx, xyRatios) { - _classCallCheck(this, TreemapChart); - - this.ctx = ctx; - this.w = ctx.w; - this.strokeWidth = this.w.config.stroke.width; - this.helpers = new TreemapHelpers(ctx); - this.dynamicAnim = this.w.config.chart.animations.dynamicAnimation; - this.labels = []; - } - - _createClass(TreemapChart, [{ - key: "draw", - value: function draw(series) { - var _this = this; - - var w = this.w; - var graphics = new Graphics(this.ctx); - var fill = new Fill(this.ctx); - var ret = graphics.group({ - class: 'apexcharts-treemap' - }); - if (w.globals.noData) return ret; - var ser = []; - series.forEach(function (s) { - var d = s.map(function (v) { - return Math.abs(v); - }); - ser.push(d); - }); - this.negRange = this.helpers.checkColorRange(); - w.config.series.forEach(function (s, i) { - s.data.forEach(function (l) { - if (!Array.isArray(_this.labels[i])) _this.labels[i] = []; - - _this.labels[i].push(l.x); - }); - }); - var nodes = window.TreemapSquared.generate(ser, w.globals.gridWidth, w.globals.gridHeight); - nodes.forEach(function (node, i) { - var elSeries = graphics.group({ - class: "apexcharts-series apexcharts-treemap-series", - seriesName: Utils$1.escapeString(w.globals.seriesNames[i]), - rel: i + 1, - 'data:realIndex': i - }); - - if (w.config.chart.dropShadow.enabled) { - var shadow = w.config.chart.dropShadow; - var filters = new Filters(_this.ctx); - filters.dropShadow(ret, shadow, i); - } - - var elDataLabelWrap = graphics.group({ - class: 'apexcharts-data-labels' - }); - node.forEach(function (r, j) { - var x1 = r[0]; - var y1 = r[1]; - var x2 = r[2]; - var y2 = r[3]; - var elRect = graphics.drawRect(x1, y1, x2 - x1, y2 - y1, 0, '#fff', 1, _this.strokeWidth, w.config.plotOptions.treemap.useFillColorAsStroke ? color : w.globals.stroke.colors[i]); - elRect.attr({ - cx: x1, - cy: y1, - index: i, - i: i, - j: j, - width: x2 - x1, - height: y2 - y1 - }); - - var colorProps = _this.helpers.getShadeColor(w.config.chart.type, i, j, _this.negRange); - - var color = colorProps.color; - - if (typeof w.config.series[i].data[j] !== 'undefined' && w.config.series[i].data[j].fillColor) { - color = w.config.series[i].data[j].fillColor; - } - - var pathFill = fill.fillPath({ - color: color, - seriesNumber: i, - dataPointIndex: j - }); - elRect.node.classList.add('apexcharts-treemap-rect'); - elRect.attr({ - fill: pathFill - }); - - _this.helpers.addListeners(elRect); - - var fromRect = { - x: x1 + (x2 - x1) / 2, - y: y1 + (y2 - y1) / 2, - width: 0, - height: 0 - }; - var toRect = { - x: x1, - y: y1, - width: x2 - x1, - height: y2 - y1 - }; - - if (w.config.chart.animations.enabled && !w.globals.dataChanged) { - var speed = 1; - - if (!w.globals.resized) { - speed = w.config.chart.animations.speed; - } - - _this.animateTreemap(elRect, fromRect, toRect, speed); - } - - if (w.globals.dataChanged) { - var _speed = 1; - - if (_this.dynamicAnim.enabled && w.globals.shouldAnimate) { - _speed = _this.dynamicAnim.speed; - - if (w.globals.previousPaths[i] && w.globals.previousPaths[i][j] && w.globals.previousPaths[i][j].rect) { - fromRect = w.globals.previousPaths[i][j].rect; - } - - _this.animateTreemap(elRect, fromRect, toRect, _speed); - } - } - - var fontSize = _this.getFontSize(r); - - var formattedText = w.config.dataLabels.formatter(_this.labels[i][j], { - value: w.globals.series[i][j], - seriesIndex: i, - dataPointIndex: j, - w: w - }); - - var dataLabels = _this.helpers.calculateDataLabels({ - text: formattedText, - x: (x1 + x2) / 2, - y: (y1 + y2) / 2 + _this.strokeWidth / 2 + fontSize / 3, - i: i, - j: j, - colorProps: colorProps, - fontSize: fontSize, - series: series - }); - - if (w.config.dataLabels.enabled && dataLabels) { - _this.rotateToFitLabel(dataLabels, fontSize, formattedText, x1, y1, x2, y2); - } - - elSeries.add(elRect); - - if (dataLabels !== null) { - elSeries.add(dataLabels); - } - }); - elSeries.add(elDataLabelWrap); - ret.add(elSeries); - }); - return ret; - } // This calculates a font-size based upon - // average label length and the size of the box the label is - // going into. The maximum font size is set in chart config. - - }, { - key: "getFontSize", - value: function getFontSize(coordinates) { - var w = this.w; // total length of labels (i.e [["Italy"],["Spain", "Greece"]] -> 16) - - function totalLabelLength(arr) { - var i, - total = 0; - - if (Array.isArray(arr[0])) { - for (i = 0; i < arr.length; i++) { - total += totalLabelLength(arr[i]); - } - } else { - for (i = 0; i < arr.length; i++) { - total += arr[i].length; - } - } - - return total; - } // count of labels (i.e [["Italy"],["Spain", "Greece"]] -> 3) - - - function countLabels(arr) { - var i, - total = 0; - - if (Array.isArray(arr[0])) { - for (i = 0; i < arr.length; i++) { - total += countLabels(arr[i]); - } - } else { - for (i = 0; i < arr.length; i++) { - total += 1; - } - } - - return total; - } - - var averagelabelsize = totalLabelLength(this.labels) / countLabels(this.labels); - - function fontSize(width, height) { - // the font size should be proportional to the size of the box (and the value) - // otherwise you can end up creating a visual distortion where two boxes of identical - // size have different sized labels, and thus make it look as if the two boxes - // represent different sizes - var area = width * height; - var arearoot = Math.pow(area, 0.5); - return Math.min(arearoot / averagelabelsize, parseInt(w.config.dataLabels.style.fontSize, 10)); - } - - return fontSize(coordinates[2] - coordinates[0], coordinates[3] - coordinates[1]); - } - }, { - key: "rotateToFitLabel", - value: function rotateToFitLabel(elText, fontSize, text, x1, y1, x2, y2) { - var graphics = new Graphics(this.ctx); - var textRect = graphics.getTextRects(text, fontSize); //if the label fits better sideways then rotate it - - if (textRect.width + this.w.config.stroke.width + 5 > x2 - x1 && textRect.width <= y2 - y1) { - var labelRotatingCenter = graphics.rotateAroundCenter(elText.node); - elText.node.setAttribute('transform', "rotate(-90 ".concat(labelRotatingCenter.x, " ").concat(labelRotatingCenter.y, ")")); - } - } - }, { - key: "animateTreemap", - value: function animateTreemap(el, fromRect, toRect, speed) { - var animations = new Animations(this.ctx); - animations.animateRect(el, { - x: fromRect.x, - y: fromRect.y, - width: fromRect.width, - height: fromRect.height - }, { - x: toRect.x, - y: toRect.y, - width: toRect.width, - height: toRect.height - }, speed, function () { - animations.animationCompleted(el); - }); - } - }]); - - return TreemapChart; - }(); - - var MINUTES_IN_DAY = 24 * 60; - var SECONDS_IN_DAY = MINUTES_IN_DAY * 60; - var MIN_ZOOM_DAYS = 10 / SECONDS_IN_DAY; - /** - * ApexCharts TimeScale Class for generating time ticks for x-axis. - * - * @module TimeScale - **/ - - var TimeScale = /*#__PURE__*/function () { - function TimeScale(ctx) { - _classCallCheck(this, TimeScale); - - this.ctx = ctx; - this.w = ctx.w; - this.timeScaleArray = []; - this.utc = this.w.config.xaxis.labels.datetimeUTC; - } - - _createClass(TimeScale, [{ - key: "calculateTimeScaleTicks", - value: function calculateTimeScaleTicks(minX, maxX) { - var _this = this; - - var w = this.w; // null check when no series to show - - if (w.globals.allSeriesCollapsed) { - w.globals.labels = []; - w.globals.timescaleLabels = []; - return []; - } - - var dt = new DateTime(this.ctx); - var daysDiff = (maxX - minX) / (1000 * SECONDS_IN_DAY); - this.determineInterval(daysDiff); - w.globals.disableZoomIn = false; - w.globals.disableZoomOut = false; - - if (daysDiff < MIN_ZOOM_DAYS) { - w.globals.disableZoomIn = true; - } else if (daysDiff > 50000) { - w.globals.disableZoomOut = true; - } - - var timeIntervals = dt.getTimeUnitsfromTimestamp(minX, maxX, this.utc); - var daysWidthOnXAxis = w.globals.gridWidth / daysDiff; - var hoursWidthOnXAxis = daysWidthOnXAxis / 24; - var minutesWidthOnXAxis = hoursWidthOnXAxis / 60; - var secondsWidthOnXAxis = minutesWidthOnXAxis / 60; - var numberOfHours = Math.floor(daysDiff * 24); - var numberOfMinutes = Math.floor(daysDiff * MINUTES_IN_DAY); - var numberOfSeconds = Math.floor(daysDiff * SECONDS_IN_DAY); - var numberOfDays = Math.floor(daysDiff); - var numberOfMonths = Math.floor(daysDiff / 30); - var numberOfYears = Math.floor(daysDiff / 365); - var firstVal = { - minMillisecond: timeIntervals.minMillisecond, - minSecond: timeIntervals.minSecond, - minMinute: timeIntervals.minMinute, - minHour: timeIntervals.minHour, - minDate: timeIntervals.minDate, - minMonth: timeIntervals.minMonth, - minYear: timeIntervals.minYear - }; - var currentMillisecond = firstVal.minMillisecond; - var currentSecond = firstVal.minSecond; - var currentMinute = firstVal.minMinute; - var currentHour = firstVal.minHour; - var currentMonthDate = firstVal.minDate; - var currentDate = firstVal.minDate; - var currentMonth = firstVal.minMonth; - var currentYear = firstVal.minYear; - var params = { - firstVal: firstVal, - currentMillisecond: currentMillisecond, - currentSecond: currentSecond, - currentMinute: currentMinute, - currentHour: currentHour, - currentMonthDate: currentMonthDate, - currentDate: currentDate, - currentMonth: currentMonth, - currentYear: currentYear, - daysWidthOnXAxis: daysWidthOnXAxis, - hoursWidthOnXAxis: hoursWidthOnXAxis, - minutesWidthOnXAxis: minutesWidthOnXAxis, - secondsWidthOnXAxis: secondsWidthOnXAxis, - numberOfSeconds: numberOfSeconds, - numberOfMinutes: numberOfMinutes, - numberOfHours: numberOfHours, - numberOfDays: numberOfDays, - numberOfMonths: numberOfMonths, - numberOfYears: numberOfYears - }; - - switch (this.tickInterval) { - case 'years': - { - this.generateYearScale(params); - break; - } - - case 'months': - case 'half_year': - { - this.generateMonthScale(params); - break; - } - - case 'months_days': - case 'months_fortnight': - case 'days': - case 'week_days': - { - this.generateDayScale(params); - break; - } - - case 'hours': - { - this.generateHourScale(params); - break; - } - - case 'minutes_fives': - case 'minutes': - this.generateMinuteScale(params); - break; - - case 'seconds_tens': - case 'seconds_fives': - case 'seconds': - this.generateSecondScale(params); - break; - } // first, we will adjust the month values index - // as in the upper function, it is starting from 0 - // we will start them from 1 - - - var adjustedMonthInTimeScaleArray = this.timeScaleArray.map(function (ts) { - var defaultReturn = { - position: ts.position, - unit: ts.unit, - year: ts.year, - day: ts.day ? ts.day : 1, - hour: ts.hour ? ts.hour : 0, - month: ts.month + 1 - }; - - if (ts.unit === 'month') { - return _objectSpread2(_objectSpread2({}, defaultReturn), {}, { - day: 1, - value: ts.value + 1 - }); - } else if (ts.unit === 'day' || ts.unit === 'hour') { - return _objectSpread2(_objectSpread2({}, defaultReturn), {}, { - value: ts.value - }); - } else if (ts.unit === 'minute') { - return _objectSpread2(_objectSpread2({}, defaultReturn), {}, { - value: ts.value, - minute: ts.value - }); - } else if (ts.unit === 'second') { - return _objectSpread2(_objectSpread2({}, defaultReturn), {}, { - value: ts.value, - minute: ts.minute, - second: ts.second - }); - } - - return ts; - }); - var filteredTimeScale = adjustedMonthInTimeScaleArray.filter(function (ts) { - var modulo = 1; - var ticks = Math.ceil(w.globals.gridWidth / 120); - var value = ts.value; - - if (w.config.xaxis.tickAmount !== undefined) { - ticks = w.config.xaxis.tickAmount; - } - - if (adjustedMonthInTimeScaleArray.length > ticks) { - modulo = Math.floor(adjustedMonthInTimeScaleArray.length / ticks); - } - - var shouldNotSkipUnit = false; // there is a big change in unit i.e days to months - - var shouldNotPrint = false; // should skip these values - - switch (_this.tickInterval) { - case 'years': - // make years label denser - if (ts.unit === 'year') { - shouldNotSkipUnit = true; - } - - break; - - case 'half_year': - modulo = 7; - - if (ts.unit === 'year') { - shouldNotSkipUnit = true; - } - - break; - - case 'months': - modulo = 1; - - if (ts.unit === 'year') { - shouldNotSkipUnit = true; - } - - break; - - case 'months_fortnight': - modulo = 15; - - if (ts.unit === 'year' || ts.unit === 'month') { - shouldNotSkipUnit = true; - } - - if (value === 30) { - shouldNotPrint = true; - } - - break; - - case 'months_days': - modulo = 10; - - if (ts.unit === 'month') { - shouldNotSkipUnit = true; - } - - if (value === 30) { - shouldNotPrint = true; - } - - break; - - case 'week_days': - modulo = 8; - - if (ts.unit === 'month') { - shouldNotSkipUnit = true; - } - - break; - - case 'days': - modulo = 1; - - if (ts.unit === 'month') { - shouldNotSkipUnit = true; - } - - break; - - case 'hours': - if (ts.unit === 'day') { - shouldNotSkipUnit = true; - } - - break; - - case 'minutes_fives': - if (value % 5 !== 0) { - shouldNotPrint = true; - } - - break; - - case 'seconds_tens': - if (value % 10 !== 0) { - shouldNotPrint = true; - } - - break; - - case 'seconds_fives': - if (value % 5 !== 0) { - shouldNotPrint = true; - } - - break; - } - - if (_this.tickInterval === 'hours' || _this.tickInterval === 'minutes_fives' || _this.tickInterval === 'seconds_tens' || _this.tickInterval === 'seconds_fives') { - if (!shouldNotPrint) { - return true; - } - } else { - if ((value % modulo === 0 || shouldNotSkipUnit) && !shouldNotPrint) { - return true; - } - } - }); - return filteredTimeScale; - } - }, { - key: "recalcDimensionsBasedOnFormat", - value: function recalcDimensionsBasedOnFormat(filteredTimeScale, inverted) { - var w = this.w; - var reformattedTimescaleArray = this.formatDates(filteredTimeScale); - var removedOverlappingTS = this.removeOverlappingTS(reformattedTimescaleArray); - w.globals.timescaleLabels = removedOverlappingTS.slice(); // at this stage, we need to re-calculate coords of the grid as timeline labels may have altered the xaxis labels coords - // The reason we can't do this prior to this stage is because timeline labels depends on gridWidth, and as the ticks are calculated based on available gridWidth, there can be unknown number of ticks generated for different minX and maxX - // Dependency on Dimensions(), need to refactor correctly - // TODO - find an alternate way to avoid calling this Heavy method twice - - var dimensions = new Dimensions(this.ctx); - dimensions.plotCoords(); - } - }, { - key: "determineInterval", - value: function determineInterval(daysDiff) { - var yearsDiff = daysDiff / 365; - var hoursDiff = daysDiff * 24; - var minutesDiff = hoursDiff * 60; - var secondsDiff = minutesDiff * 60; - - switch (true) { - case yearsDiff > 5: - this.tickInterval = 'years'; - break; - - case daysDiff > 800: - this.tickInterval = 'half_year'; - break; - - case daysDiff > 180: - this.tickInterval = 'months'; - break; - - case daysDiff > 90: - this.tickInterval = 'months_fortnight'; - break; - - case daysDiff > 60: - this.tickInterval = 'months_days'; - break; - - case daysDiff > 30: - this.tickInterval = 'week_days'; - break; - - case daysDiff > 2: - this.tickInterval = 'days'; - break; - - case hoursDiff > 2.4: - this.tickInterval = 'hours'; - break; - - case minutesDiff > 15: - this.tickInterval = 'minutes_fives'; - break; - - case minutesDiff > 5: - this.tickInterval = 'minutes'; - break; - - case minutesDiff > 1: - this.tickInterval = 'seconds_tens'; - break; - - case secondsDiff > 20: - this.tickInterval = 'seconds_fives'; - break; - - default: - this.tickInterval = 'seconds'; - break; - } - } - }, { - key: "generateYearScale", - value: function generateYearScale(_ref) { - var firstVal = _ref.firstVal, - currentMonth = _ref.currentMonth, - currentYear = _ref.currentYear, - daysWidthOnXAxis = _ref.daysWidthOnXAxis, - numberOfYears = _ref.numberOfYears; - var firstTickValue = firstVal.minYear; - var firstTickPosition = 0; - var dt = new DateTime(this.ctx); - var unit = 'year'; - - if (firstVal.minDate > 1 || firstVal.minMonth > 0) { - var remainingDays = dt.determineRemainingDaysOfYear(firstVal.minYear, firstVal.minMonth, firstVal.minDate); // remainingDaysofFirstMonth is used to reacht the 2nd tick position - - var remainingDaysOfFirstYear = dt.determineDaysOfYear(firstVal.minYear) - remainingDays + 1; // calculate the first tick position - - firstTickPosition = remainingDaysOfFirstYear * daysWidthOnXAxis; - firstTickValue = firstVal.minYear + 1; // push the first tick in the array - - this.timeScaleArray.push({ - position: firstTickPosition, - value: firstTickValue, - unit: unit, - year: firstTickValue, - month: Utils$1.monthMod(currentMonth + 1) - }); - } else if (firstVal.minDate === 1 && firstVal.minMonth === 0) { - // push the first tick in the array - this.timeScaleArray.push({ - position: firstTickPosition, - value: firstTickValue, - unit: unit, - year: currentYear, - month: Utils$1.monthMod(currentMonth + 1) - }); - } - - var year = firstTickValue; - var pos = firstTickPosition; // keep drawing rest of the ticks - - for (var i = 0; i < numberOfYears; i++) { - year++; - pos = dt.determineDaysOfYear(year - 1) * daysWidthOnXAxis + pos; - this.timeScaleArray.push({ - position: pos, - value: year, - unit: unit, - year: year, - month: 1 - }); - } - } - }, { - key: "generateMonthScale", - value: function generateMonthScale(_ref2) { - var firstVal = _ref2.firstVal, - currentMonthDate = _ref2.currentMonthDate, - currentMonth = _ref2.currentMonth, - currentYear = _ref2.currentYear, - daysWidthOnXAxis = _ref2.daysWidthOnXAxis, - numberOfMonths = _ref2.numberOfMonths; - var firstTickValue = currentMonth; - var firstTickPosition = 0; - var dt = new DateTime(this.ctx); - var unit = 'month'; - var yrCounter = 0; - - if (firstVal.minDate > 1) { - // remainingDaysofFirstMonth is used to reacht the 2nd tick position - var remainingDaysOfFirstMonth = dt.determineDaysOfMonths(currentMonth + 1, firstVal.minYear) - currentMonthDate + 1; // calculate the first tick position - - firstTickPosition = remainingDaysOfFirstMonth * daysWidthOnXAxis; - firstTickValue = Utils$1.monthMod(currentMonth + 1); - var year = currentYear + yrCounter; - - var _month = Utils$1.monthMod(firstTickValue); - - var value = firstTickValue; // it's Jan, so update the year - - if (firstTickValue === 0) { - unit = 'year'; - value = year; - _month = 1; - yrCounter += 1; - year = year + yrCounter; - } // push the first tick in the array - - - this.timeScaleArray.push({ - position: firstTickPosition, - value: value, - unit: unit, - year: year, - month: _month - }); - } else { - // push the first tick in the array - this.timeScaleArray.push({ - position: firstTickPosition, - value: firstTickValue, - unit: unit, - year: currentYear, - month: Utils$1.monthMod(currentMonth) - }); - } - - var month = firstTickValue + 1; - var pos = firstTickPosition; // keep drawing rest of the ticks - - for (var i = 0, j = 1; i < numberOfMonths; i++, j++) { - month = Utils$1.monthMod(month); - - if (month === 0) { - unit = 'year'; - yrCounter += 1; - } else { - unit = 'month'; - } - - var _year = this._getYear(currentYear, month, yrCounter); - - pos = dt.determineDaysOfMonths(month, _year) * daysWidthOnXAxis + pos; - var monthVal = month === 0 ? _year : month; - this.timeScaleArray.push({ - position: pos, - value: monthVal, - unit: unit, - year: _year, - month: month === 0 ? 1 : month - }); - month++; - } - } - }, { - key: "generateDayScale", - value: function generateDayScale(_ref3) { - var firstVal = _ref3.firstVal, - currentMonth = _ref3.currentMonth, - currentYear = _ref3.currentYear, - hoursWidthOnXAxis = _ref3.hoursWidthOnXAxis, - numberOfDays = _ref3.numberOfDays; - var dt = new DateTime(this.ctx); - var unit = 'day'; - var firstTickValue = firstVal.minDate + 1; - var date = firstTickValue; - - var changeMonth = function changeMonth(dateVal, month, year) { - var monthdays = dt.determineDaysOfMonths(month + 1, year); - - if (dateVal > monthdays) { - month = month + 1; - date = 1; - unit = 'month'; - val = month; - return month; - } - - return month; - }; - - var remainingHours = 24 - firstVal.minHour; - var yrCounter = 0; // calculate the first tick position - - var firstTickPosition = remainingHours * hoursWidthOnXAxis; - var val = firstTickValue; - var month = changeMonth(date, currentMonth, currentYear); - - if (firstVal.minHour === 0 && firstVal.minDate === 1) { - // the first value is the first day of month - firstTickPosition = 0; - val = Utils$1.monthMod(firstVal.minMonth); - unit = 'month'; - date = firstVal.minDate; - numberOfDays++; - } else if (firstVal.minDate !== 1 && firstVal.minHour === 0 && firstVal.minMinute === 0) { - // fixes apexcharts/apexcharts.js/issues/1730 - firstTickPosition = 0; - firstTickValue = firstVal.minDate; - date = firstTickValue; - val = firstTickValue; // in case it's the last date of month, we need to check it - - month = changeMonth(date, currentMonth, currentYear); - } // push the first tick in the array - - - this.timeScaleArray.push({ - position: firstTickPosition, - value: val, - unit: unit, - year: this._getYear(currentYear, month, yrCounter), - month: Utils$1.monthMod(month), - day: date - }); - var pos = firstTickPosition; // keep drawing rest of the ticks - - for (var i = 0; i < numberOfDays; i++) { - date += 1; - unit = 'day'; - month = changeMonth(date, month, this._getYear(currentYear, month, yrCounter)); - - var year = this._getYear(currentYear, month, yrCounter); - - pos = 24 * hoursWidthOnXAxis + pos; - var value = date === 1 ? Utils$1.monthMod(month) : date; - this.timeScaleArray.push({ - position: pos, - value: value, - unit: unit, - year: year, - month: Utils$1.monthMod(month), - day: value - }); - } - } - }, { - key: "generateHourScale", - value: function generateHourScale(_ref4) { - var firstVal = _ref4.firstVal, - currentDate = _ref4.currentDate, - currentMonth = _ref4.currentMonth, - currentYear = _ref4.currentYear, - minutesWidthOnXAxis = _ref4.minutesWidthOnXAxis, - numberOfHours = _ref4.numberOfHours; - var dt = new DateTime(this.ctx); - var yrCounter = 0; - var unit = 'hour'; - - var changeDate = function changeDate(dateVal, month) { - var monthdays = dt.determineDaysOfMonths(month + 1, currentYear); - - if (dateVal > monthdays) { - date = 1; - month = month + 1; - } - - return { - month: month, - date: date - }; - }; - - var changeMonth = function changeMonth(dateVal, month) { - var monthdays = dt.determineDaysOfMonths(month + 1, currentYear); - - if (dateVal > monthdays) { - month = month + 1; - return month; - } - - return month; - }; // factor in minSeconds as well - - - var remainingMins = 60 - (firstVal.minMinute + firstVal.minSecond / 60.0); - var firstTickPosition = remainingMins * minutesWidthOnXAxis; - var firstTickValue = firstVal.minHour + 1; - var hour = firstTickValue + 1; - - if (remainingMins === 60) { - firstTickPosition = 0; - firstTickValue = firstVal.minHour; - hour = firstTickValue + 1; - } - - var date = currentDate; - var month = changeMonth(date, currentMonth); // push the first tick in the array - - this.timeScaleArray.push({ - position: firstTickPosition, - value: firstTickValue, - unit: unit, - day: date, - hour: hour, - year: currentYear, - month: Utils$1.monthMod(month) - }); - var pos = firstTickPosition; // keep drawing rest of the ticks - - for (var i = 0; i < numberOfHours; i++) { - unit = 'hour'; - - if (hour >= 24) { - hour = 0; - date += 1; - unit = 'day'; - var checkNextMonth = changeDate(date, month); - month = checkNextMonth.month; - month = changeMonth(date, month); - } - - var year = this._getYear(currentYear, month, yrCounter); - - pos = 60 * minutesWidthOnXAxis + pos; - var val = hour === 0 ? date : hour; - this.timeScaleArray.push({ - position: pos, - value: val, - unit: unit, - hour: hour, - day: date, - year: year, - month: Utils$1.monthMod(month) - }); - hour++; - } - } - }, { - key: "generateMinuteScale", - value: function generateMinuteScale(_ref5) { - var currentMillisecond = _ref5.currentMillisecond, - currentSecond = _ref5.currentSecond, - currentMinute = _ref5.currentMinute, - currentHour = _ref5.currentHour, - currentDate = _ref5.currentDate, - currentMonth = _ref5.currentMonth, - currentYear = _ref5.currentYear, - minutesWidthOnXAxis = _ref5.minutesWidthOnXAxis, - secondsWidthOnXAxis = _ref5.secondsWidthOnXAxis, - numberOfMinutes = _ref5.numberOfMinutes; - var yrCounter = 0; - var unit = 'minute'; - var remainingSecs = 60 - currentSecond; - var firstTickPosition = (remainingSecs - currentMillisecond / 1000) * secondsWidthOnXAxis; - var minute = currentMinute + 1; - var date = currentDate; - var month = currentMonth; - var year = currentYear; - var hour = currentHour; - var pos = firstTickPosition; - - for (var i = 0; i < numberOfMinutes; i++) { - if (minute >= 60) { - minute = 0; - hour += 1; - - if (hour === 24) { - hour = 0; - } - } - - this.timeScaleArray.push({ - position: pos, - value: minute, - unit: unit, - hour: hour, - minute: minute, - day: date, - year: this._getYear(year, month, yrCounter), - month: Utils$1.monthMod(month) - }); - pos += minutesWidthOnXAxis; - minute++; - } - } - }, { - key: "generateSecondScale", - value: function generateSecondScale(_ref6) { - var currentMillisecond = _ref6.currentMillisecond, - currentSecond = _ref6.currentSecond, - currentMinute = _ref6.currentMinute, - currentHour = _ref6.currentHour, - currentDate = _ref6.currentDate, - currentMonth = _ref6.currentMonth, - currentYear = _ref6.currentYear, - secondsWidthOnXAxis = _ref6.secondsWidthOnXAxis, - numberOfSeconds = _ref6.numberOfSeconds; - var yrCounter = 0; - var unit = 'second'; - var remainingMillisecs = 1000 - currentMillisecond; - var firstTickPosition = remainingMillisecs / 1000 * secondsWidthOnXAxis; - var second = currentSecond + 1; - var minute = currentMinute; - var date = currentDate; - var month = currentMonth; - var year = currentYear; - var hour = currentHour; - var pos = firstTickPosition; - - for (var i = 0; i < numberOfSeconds; i++) { - if (second >= 60) { - minute++; - second = 0; - - if (minute >= 60) { - hour++; - minute = 0; - - if (hour === 24) { - hour = 0; - } - } - } - - this.timeScaleArray.push({ - position: pos, - value: second, - unit: unit, - hour: hour, - minute: minute, - second: second, - day: date, - year: this._getYear(year, month, yrCounter), - month: Utils$1.monthMod(month) - }); - pos += secondsWidthOnXAxis; - second++; - } - } - }, { - key: "createRawDateString", - value: function createRawDateString(ts, value) { - var raw = ts.year; - - if (ts.month === 0) { - // invalid month, correct it - ts.month = 1; - } - - raw += '-' + ('0' + ts.month.toString()).slice(-2); // unit is day - - if (ts.unit === 'day') { - raw += ts.unit === 'day' ? '-' + ('0' + value).slice(-2) : '-01'; - } else { - raw += '-' + ('0' + (ts.day ? ts.day : '1')).slice(-2); - } // unit is hour - - - if (ts.unit === 'hour') { - raw += ts.unit === 'hour' ? 'T' + ('0' + value).slice(-2) : 'T00'; - } else { - raw += 'T' + ('0' + (ts.hour ? ts.hour : '0')).slice(-2); - } - - if (ts.unit === 'minute') { - raw += ':' + ('0' + value).slice(-2); - } else { - raw += ':' + (ts.minute ? ('0' + ts.minute).slice(-2) : '00'); - } - - if (ts.unit === 'second') { - raw += ':' + ('0' + value).slice(-2); - } else { - raw += ':00'; - } - - if (this.utc) { - raw += '.000Z'; - } - - return raw; - } - }, { - key: "formatDates", - value: function formatDates(filteredTimeScale) { - var _this2 = this; - - var w = this.w; - var reformattedTimescaleArray = filteredTimeScale.map(function (ts) { - var value = ts.value.toString(); - var dt = new DateTime(_this2.ctx); - - var raw = _this2.createRawDateString(ts, value); - - var dateToFormat = dt.getDate(dt.parseDate(raw)); - - if (!_this2.utc) { - // Fixes #1726, #1544, #1485, #1255 - dateToFormat = dt.getDate(dt.parseDateWithTimezone(raw)); - } - - if (w.config.xaxis.labels.format === undefined) { - var customFormat = 'dd MMM'; - var dtFormatter = w.config.xaxis.labels.datetimeFormatter; - if (ts.unit === 'year') customFormat = dtFormatter.year; - if (ts.unit === 'month') customFormat = dtFormatter.month; - if (ts.unit === 'day') customFormat = dtFormatter.day; - if (ts.unit === 'hour') customFormat = dtFormatter.hour; - if (ts.unit === 'minute') customFormat = dtFormatter.minute; - if (ts.unit === 'second') customFormat = dtFormatter.second; - value = dt.formatDate(dateToFormat, customFormat); - } else { - value = dt.formatDate(dateToFormat, w.config.xaxis.labels.format); - } - - return { - dateString: raw, - position: ts.position, - value: value, - unit: ts.unit, - year: ts.year, - month: ts.month - }; - }); - return reformattedTimescaleArray; - } - }, { - key: "removeOverlappingTS", - value: function removeOverlappingTS(arr) { - var _this3 = this; - - var graphics = new Graphics(this.ctx); - var equalLabelLengthFlag = false; // These labels got same length? - - var constantLabelWidth; // If true, what is the constant length to use - - if (arr.length > 0 && // check arr length - arr[0].value && // check arr[0] contains value - arr.every(function (lb) { - return lb.value.length === arr[0].value.length; - }) // check every arr label value is the same as the first one - ) { - equalLabelLengthFlag = true; // These labels got same length - - constantLabelWidth = graphics.getTextRects(arr[0].value).width; // The constant label width to use - } - - var lastDrawnIndex = 0; - var filteredArray = arr.map(function (item, index) { - if (index > 0 && _this3.w.config.xaxis.labels.hideOverlappingLabels) { - var prevLabelWidth = !equalLabelLengthFlag // if vary in label length - ? graphics.getTextRects(arr[lastDrawnIndex].value).width // get individual length - : constantLabelWidth; // else: use constant length - - var prevPos = arr[lastDrawnIndex].position; - var pos = item.position; - - if (pos > prevPos + prevLabelWidth + 10) { - lastDrawnIndex = index; - return item; - } else { - return null; - } - } else { - return item; - } - }); - filteredArray = filteredArray.filter(function (f) { - return f !== null; - }); - return filteredArray; - } - }, { - key: "_getYear", - value: function _getYear(currentYear, month, yrCounter) { - return currentYear + Math.floor(month / 12) + yrCounter; - } - }]); - - return TimeScale; - }(); - - /** - * ApexCharts Core Class responsible for major calculations and creating elements. - * - * @module Core - **/ - - var Core = /*#__PURE__*/function () { - function Core(el, ctx) { - _classCallCheck(this, Core); - - this.ctx = ctx; - this.w = ctx.w; - this.el = el; - } // get data and store into appropriate vars - - - _createClass(Core, [{ - key: "setupElements", - value: function setupElements() { - var gl = this.w.globals; - var cnf = this.w.config; // const graphics = new Graphics(this.ctx) - - var ct = cnf.chart.type; - var axisChartsArrTypes = ['line', 'area', 'bar', 'rangeBar', 'rangeArea', 'candlestick', 'boxPlot', 'scatter', 'bubble', 'radar', 'heatmap', 'treemap']; - var xyChartsArrTypes = ['line', 'area', 'bar', 'rangeBar', 'rangeArea', 'candlestick', 'boxPlot', 'scatter', 'bubble']; - gl.axisCharts = axisChartsArrTypes.indexOf(ct) > -1; - gl.xyCharts = xyChartsArrTypes.indexOf(ct) > -1; - gl.isBarHorizontal = (cnf.chart.type === 'bar' || cnf.chart.type === 'rangeBar' || cnf.chart.type === 'boxPlot') && cnf.plotOptions.bar.horizontal; - gl.chartClass = '.apexcharts' + gl.chartID; - gl.dom.baseEl = this.el; - gl.dom.elWrap = document.createElement('div'); - Graphics.setAttrs(gl.dom.elWrap, { - id: gl.chartClass.substring(1), - class: 'apexcharts-canvas ' + gl.chartClass.substring(1) - }); - this.el.appendChild(gl.dom.elWrap); - gl.dom.Paper = new window.SVG.Doc(gl.dom.elWrap); - gl.dom.Paper.attr({ - class: 'apexcharts-svg', - 'xmlns:data': 'ApexChartsNS', - transform: "translate(".concat(cnf.chart.offsetX, ", ").concat(cnf.chart.offsetY, ")") - }); - gl.dom.Paper.node.style.background = cnf.chart.background; - this.setSVGDimensions(); // append foreignElement (legend's parent) - // legend is kept in foreignElement to be included while exporting - // removing foreignElement and creating legend through HTML will not render legend in export - - gl.dom.elLegendForeign = document.createElementNS(gl.SVGNS, 'foreignObject'); - Graphics.setAttrs(gl.dom.elLegendForeign, { - x: 0, - y: 0, - width: gl.svgWidth, - height: gl.svgHeight - }); - gl.dom.elLegendWrap = document.createElement('div'); - gl.dom.elLegendWrap.classList.add('apexcharts-legend'); - gl.dom.elLegendWrap.setAttribute('xmlns', 'http://www.w3.org/1999/xhtml'); - gl.dom.elLegendForeign.appendChild(gl.dom.elLegendWrap); - gl.dom.Paper.node.appendChild(gl.dom.elLegendForeign); // the elGraphical is the parent of all primary visuals - - gl.dom.elGraphical = gl.dom.Paper.group().attr({ - class: 'apexcharts-inner apexcharts-graphical' - }); - gl.dom.elDefs = gl.dom.Paper.defs(); - gl.dom.Paper.add(gl.dom.elGraphical); - gl.dom.elGraphical.add(gl.dom.elDefs); - } - }, { - key: "plotChartType", - value: function plotChartType(ser, xyRatios) { - var w = this.w; - var cnf = w.config; - var gl = w.globals; - var lineSeries = { - series: [], - i: [] - }; - var areaSeries = { - series: [], - i: [] - }; - var scatterSeries = { - series: [], - i: [] - }; - var bubbleSeries = { - series: [], - i: [] - }; - var columnSeries = { - series: [], - i: [] - }; - var candlestickSeries = { - series: [], - i: [] - }; - var boxplotSeries = { - series: [], - i: [] - }; - var rangeBarSeries = { - series: [], - i: [] - }; - var rangeAreaSeries = { - series: [], - seriesRangeEnd: [], - i: [] - }; - gl.series.map(function (serie, st) { - var comboCount = 0; // if user has specified a particular type for particular series - - if (typeof ser[st].type !== 'undefined') { - if (ser[st].type === 'column' || ser[st].type === 'bar') { - if (gl.series.length > 1 && cnf.plotOptions.bar.horizontal) { - // horizontal bars not supported in mixed charts, hence show a warning - console.warn('Horizontal bars are not supported in a mixed/combo chart. Please turn off `plotOptions.bar.horizontal`'); - } - - columnSeries.series.push(serie); - columnSeries.i.push(st); - comboCount++; - w.globals.columnSeries = columnSeries.series; - } else if (ser[st].type === 'area') { - areaSeries.series.push(serie); - areaSeries.i.push(st); - comboCount++; - } else if (ser[st].type === 'line') { - lineSeries.series.push(serie); - lineSeries.i.push(st); - comboCount++; - } else if (ser[st].type === 'scatter') { - scatterSeries.series.push(serie); - scatterSeries.i.push(st); - } else if (ser[st].type === 'bubble') { - bubbleSeries.series.push(serie); - bubbleSeries.i.push(st); - comboCount++; - } else if (ser[st].type === 'candlestick') { - candlestickSeries.series.push(serie); - candlestickSeries.i.push(st); - comboCount++; - } else if (ser[st].type === 'boxPlot') { - boxplotSeries.series.push(serie); - boxplotSeries.i.push(st); - comboCount++; - } else if (ser[st].type === 'rangeBar') { - rangeBarSeries.series.push(serie); - rangeBarSeries.i.push(st); - comboCount++; - } else if (ser[st].type === 'rangeArea') { - rangeAreaSeries.series.push(gl.seriesRangeStart[st]); - rangeAreaSeries.seriesRangeEnd.push(gl.seriesRangeEnd[st]); - rangeAreaSeries.i.push(st); - comboCount++; - } else { - // user has specified type, but it is not valid (other than line/area/column) - console.warn('You have specified an unrecognized chart type. Available types for this property are line/area/column/bar/scatter/bubble/candlestick/boxPlot/rangeBar/rangeArea'); - } - - if (comboCount > 1) { - gl.comboCharts = true; - } - } else { - lineSeries.series.push(serie); - lineSeries.i.push(st); - } - }); - var line = new Line(this.ctx, xyRatios); - var boxCandlestick = new BoxCandleStick(this.ctx, xyRatios); - this.ctx.pie = new Pie(this.ctx); - var radialBar = new Radial(this.ctx); - this.ctx.rangeBar = new RangeBar(this.ctx, xyRatios); - var radar = new Radar(this.ctx); - var elGraph = []; - - if (gl.comboCharts) { - if (areaSeries.series.length > 0) { - elGraph.push(line.draw(areaSeries.series, 'area', areaSeries.i)); - } - - if (columnSeries.series.length > 0) { - if (w.config.chart.stacked) { - var barStacked = new BarStacked(this.ctx, xyRatios); - elGraph.push(barStacked.draw(columnSeries.series, columnSeries.i)); - } else { - this.ctx.bar = new Bar(this.ctx, xyRatios); - elGraph.push(this.ctx.bar.draw(columnSeries.series, columnSeries.i)); - } - } - - if (rangeAreaSeries.series.length > 0) { - elGraph.push(line.draw(rangeAreaSeries.series, 'rangeArea', rangeAreaSeries.i, rangeAreaSeries.seriesRangeEnd)); - } - - if (lineSeries.series.length > 0) { - elGraph.push(line.draw(lineSeries.series, 'line', lineSeries.i)); - } - - if (candlestickSeries.series.length > 0) { - elGraph.push(boxCandlestick.draw(candlestickSeries.series, 'candlestick', candlestickSeries.i)); - } - - if (boxplotSeries.series.length > 0) { - elGraph.push(boxCandlestick.draw(boxplotSeries.series, 'boxPlot', boxplotSeries.i)); - } - - if (rangeBarSeries.series.length > 0) { - elGraph.push(this.ctx.rangeBar.draw(rangeBarSeries.series, rangeBarSeries.i)); - } - - if (scatterSeries.series.length > 0) { - var scatterLine = new Line(this.ctx, xyRatios, true); - elGraph.push(scatterLine.draw(scatterSeries.series, 'scatter', scatterSeries.i)); - } - - if (bubbleSeries.series.length > 0) { - var bubbleLine = new Line(this.ctx, xyRatios, true); - elGraph.push(bubbleLine.draw(bubbleSeries.series, 'bubble', bubbleSeries.i)); - } - } else { - switch (cnf.chart.type) { - case 'line': - elGraph = line.draw(gl.series, 'line'); - break; - - case 'area': - elGraph = line.draw(gl.series, 'area'); - break; - - case 'bar': - if (cnf.chart.stacked) { - var _barStacked = new BarStacked(this.ctx, xyRatios); - - elGraph = _barStacked.draw(gl.series); - } else { - this.ctx.bar = new Bar(this.ctx, xyRatios); - elGraph = this.ctx.bar.draw(gl.series); - } - - break; - - case 'candlestick': - var candleStick = new BoxCandleStick(this.ctx, xyRatios); - elGraph = candleStick.draw(gl.series, 'candlestick'); - break; - - case 'boxPlot': - var boxPlot = new BoxCandleStick(this.ctx, xyRatios); - elGraph = boxPlot.draw(gl.series, 'boxPlot'); - break; - - case 'rangeBar': - elGraph = this.ctx.rangeBar.draw(gl.series); - break; - - case 'rangeArea': - elGraph = line.draw(gl.seriesRangeStart, 'rangeArea', undefined, gl.seriesRangeEnd); - break; - - case 'heatmap': - var heatmap = new HeatMap(this.ctx, xyRatios); - elGraph = heatmap.draw(gl.series); - break; - - case 'treemap': - var treemap = new TreemapChart(this.ctx, xyRatios); - elGraph = treemap.draw(gl.series); - break; - - case 'pie': - case 'donut': - case 'polarArea': - elGraph = this.ctx.pie.draw(gl.series); - break; - - case 'radialBar': - elGraph = radialBar.draw(gl.series); - break; - - case 'radar': - elGraph = radar.draw(gl.series); - break; - - default: - elGraph = line.draw(gl.series); - } - } - - return elGraph; - } - }, { - key: "setSVGDimensions", - value: function setSVGDimensions() { - var gl = this.w.globals; - var cnf = this.w.config; - gl.svgWidth = cnf.chart.width; - gl.svgHeight = cnf.chart.height; - var elDim = Utils$1.getDimensions(this.el); - var widthUnit = cnf.chart.width.toString().split(/[0-9]+/g).pop(); - - if (widthUnit === '%') { - if (Utils$1.isNumber(elDim[0])) { - if (elDim[0].width === 0) { - elDim = Utils$1.getDimensions(this.el.parentNode); - } - - gl.svgWidth = elDim[0] * parseInt(cnf.chart.width, 10) / 100; - } - } else if (widthUnit === 'px' || widthUnit === '') { - gl.svgWidth = parseInt(cnf.chart.width, 10); - } - - var heightUnit = cnf.chart.height.toString().split(/[0-9]+/g).pop(); - - if (gl.svgHeight !== 'auto' && gl.svgHeight !== '') { - if (heightUnit === '%') { - var elParentDim = Utils$1.getDimensions(this.el.parentNode); - gl.svgHeight = elParentDim[1] * parseInt(cnf.chart.height, 10) / 100; - } else { - gl.svgHeight = parseInt(cnf.chart.height, 10); - } - } else { - if (gl.axisCharts) { - gl.svgHeight = gl.svgWidth / 1.61; - } else { - gl.svgHeight = gl.svgWidth / 1.2; - } - } - - if (gl.svgWidth < 0) gl.svgWidth = 0; - if (gl.svgHeight < 0) gl.svgHeight = 0; - Graphics.setAttrs(gl.dom.Paper.node, { - width: gl.svgWidth, - height: gl.svgHeight - }); - - if (heightUnit !== '%') { - // fixes https://github.com/apexcharts/apexcharts.js/issues/2059 - var offsetY = cnf.chart.sparkline.enabled ? 0 : gl.axisCharts ? cnf.chart.parentHeightOffset : 0; - gl.dom.Paper.node.parentNode.parentNode.style.minHeight = gl.svgHeight + offsetY + 'px'; - } - - gl.dom.elWrap.style.width = gl.svgWidth + 'px'; - gl.dom.elWrap.style.height = gl.svgHeight + 'px'; - } - }, { - key: "shiftGraphPosition", - value: function shiftGraphPosition() { - var gl = this.w.globals; - var tY = gl.translateY; - var tX = gl.translateX; - var scalingAttrs = { - transform: 'translate(' + tX + ', ' + tY + ')' - }; - Graphics.setAttrs(gl.dom.elGraphical.node, scalingAttrs); - } // To prevent extra spacings in the bottom of the chart, we need to recalculate the height for pie/donut/radialbar charts - - }, { - key: "resizeNonAxisCharts", - value: function resizeNonAxisCharts() { - var w = this.w; - var gl = w.globals; - var legendHeight = 0; - var offY = w.config.chart.sparkline.enabled ? 1 : 15; - offY = offY + w.config.grid.padding.bottom; - - if ((w.config.legend.position === 'top' || w.config.legend.position === 'bottom') && w.config.legend.show && !w.config.legend.floating) { - legendHeight = new Legend(this.ctx).legendHelpers.getLegendBBox().clwh + 10; - } - - var el = w.globals.dom.baseEl.querySelector('.apexcharts-radialbar, .apexcharts-pie'); - var chartInnerDimensions = w.globals.radialSize * 2.05; - - if (el && !w.config.chart.sparkline.enabled && w.config.plotOptions.radialBar.startAngle !== 0) { - var elRadialRect = Utils$1.getBoundingClientRect(el); - chartInnerDimensions = elRadialRect.bottom; - var maxHeight = elRadialRect.bottom - elRadialRect.top; - chartInnerDimensions = Math.max(w.globals.radialSize * 2.05, maxHeight); - } - - var newHeight = chartInnerDimensions + gl.translateY + legendHeight + offY; - - if (gl.dom.elLegendForeign) { - gl.dom.elLegendForeign.setAttribute('height', newHeight); - } // fix apexcharts/apexcharts.js/issues/3105 (when % is provided in height, it keeps increasing) - - - if (w.config.chart.height && String(w.config.chart.height).indexOf('%') > 0) return; - gl.dom.elWrap.style.height = newHeight + 'px'; - Graphics.setAttrs(gl.dom.Paper.node, { - height: newHeight - }); - gl.dom.Paper.node.parentNode.parentNode.style.minHeight = newHeight + 'px'; - } - /* - ** All the calculations for setting range in charts will be done here - */ - - }, { - key: "coreCalculations", - value: function coreCalculations() { - var range = new Range(this.ctx); - range.init(); - } - }, { - key: "resetGlobals", - value: function resetGlobals() { - var _this = this; - - var resetxyValues = function resetxyValues() { - return _this.w.config.series.map(function (s) { - return []; - }); - }; - - var globalObj = new Globals(); - var gl = this.w.globals; - globalObj.initGlobalVars(gl); - gl.seriesXvalues = resetxyValues(); - gl.seriesYvalues = resetxyValues(); - } - }, { - key: "isMultipleY", - value: function isMultipleY() { - // user has supplied an array in yaxis property. So, turn on multipleYAxis flag - if (this.w.config.yaxis.constructor === Array && this.w.config.yaxis.length > 1) { - this.w.globals.isMultipleYAxis = true; - return true; - } - } - }, { - key: "xySettings", - value: function xySettings() { - var xyRatios = null; - var w = this.w; - - if (w.globals.axisCharts) { - if (w.config.xaxis.crosshairs.position === 'back') { - var crosshairs = new Crosshairs(this.ctx); - crosshairs.drawXCrosshairs(); - } - - if (w.config.yaxis[0].crosshairs.position === 'back') { - var _crosshairs = new Crosshairs(this.ctx); - - _crosshairs.drawYCrosshairs(); - } - - if (w.config.xaxis.type === 'datetime' && w.config.xaxis.labels.formatter === undefined) { - this.ctx.timeScale = new TimeScale(this.ctx); - var formattedTimeScale = []; - - if (isFinite(w.globals.minX) && isFinite(w.globals.maxX) && !w.globals.isBarHorizontal) { - formattedTimeScale = this.ctx.timeScale.calculateTimeScaleTicks(w.globals.minX, w.globals.maxX); - } else if (w.globals.isBarHorizontal) { - formattedTimeScale = this.ctx.timeScale.calculateTimeScaleTicks(w.globals.minY, w.globals.maxY); - } - - this.ctx.timeScale.recalcDimensionsBasedOnFormat(formattedTimeScale); - } - - var coreUtils = new CoreUtils(this.ctx); - xyRatios = coreUtils.getCalculatedRatios(); - } - - return xyRatios; - } - }, { - key: "updateSourceChart", - value: function updateSourceChart(targetChart) { - this.ctx.w.globals.selection = undefined; - - this.ctx.updateHelpers._updateOptions({ - chart: { - selection: { - xaxis: { - min: targetChart.w.globals.minX, - max: targetChart.w.globals.maxX - } - } - } - }, false, false); - } - }, { - key: "setupBrushHandler", - value: function setupBrushHandler() { - var _this2 = this; - - var w = this.w; // only for brush charts - - if (!w.config.chart.brush.enabled) { - return; - } // if user has not defined a custom function for selection - we handle the brush chart - // otherwise we leave it to the user to define the functionality for selection - - - if (typeof w.config.chart.events.selection !== 'function') { - var targets = w.config.chart.brush.targets || [w.config.chart.brush.target]; // retro compatibility with single target option - - targets.forEach(function (target) { - var targetChart = ApexCharts.getChartByID(target); - targetChart.w.globals.brushSource = _this2.ctx; - - if (typeof targetChart.w.config.chart.events.zoomed !== 'function') { - targetChart.w.config.chart.events.zoomed = function () { - _this2.updateSourceChart(targetChart); - }; - } - - if (typeof targetChart.w.config.chart.events.scrolled !== 'function') { - targetChart.w.config.chart.events.scrolled = function () { - _this2.updateSourceChart(targetChart); - }; - } - }); - - w.config.chart.events.selection = function (chart, e) { - targets.forEach(function (target) { - var targetChart = ApexCharts.getChartByID(target); - var yaxis = Utils$1.clone(w.config.yaxis); - - if (w.config.chart.brush.autoScaleYaxis && targetChart.w.globals.series.length === 1) { - var scale = new Range$1(targetChart); - yaxis = scale.autoScaleY(targetChart, yaxis, e); - } - - var multipleYaxis = targetChart.w.config.yaxis.reduce(function (acc, curr, index) { - return [].concat(_toConsumableArray(acc), [_objectSpread2(_objectSpread2({}, targetChart.w.config.yaxis[index]), {}, { - min: yaxis[0].min, - max: yaxis[0].max - })]); - }, []); - - targetChart.ctx.updateHelpers._updateOptions({ - xaxis: { - min: e.xaxis.min, - max: e.xaxis.max - }, - yaxis: multipleYaxis - }, false, false, false, false); - }); - }; - } - } - }]); - - return Core; - }(); - - var UpdateHelpers = /*#__PURE__*/function () { - function UpdateHelpers(ctx) { - _classCallCheck(this, UpdateHelpers); - - this.ctx = ctx; - this.w = ctx.w; - } - /** - * private method to update Options. - * - * @param {object} options - A new config object can be passed which will be merged with the existing config object - * @param {boolean} redraw - should redraw from beginning or should use existing paths and redraw from there - * @param {boolean} animate - should animate or not on updating Options - * @param {boolean} overwriteInitialConfig - should update the initial config or not - */ - - - _createClass(UpdateHelpers, [{ - key: "_updateOptions", - value: function _updateOptions(options) { - var _this = this; - - var redraw = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - var animate = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; - var updateSyncedCharts = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true; - var overwriteInitialConfig = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false; - return new Promise(function (resolve) { - var charts = [_this.ctx]; - - if (updateSyncedCharts) { - charts = _this.ctx.getSyncedCharts(); - } - - if (_this.ctx.w.globals.isExecCalled) { - // If the user called exec method, we don't want to get grouped charts as user specifically provided a chartID to update - charts = [_this.ctx]; - _this.ctx.w.globals.isExecCalled = false; - } - - charts.forEach(function (ch, chartIndex) { - var w = ch.w; - w.globals.shouldAnimate = animate; - - if (!redraw) { - w.globals.resized = true; - w.globals.dataChanged = true; - - if (animate) { - ch.series.getPreviousPaths(); - } - } - - if (options && _typeof(options) === 'object') { - ch.config = new Config(options); - options = CoreUtils.extendArrayProps(ch.config, options, w); // fixes #914, #623 - - if (ch.w.globals.chartID !== _this.ctx.w.globals.chartID) { - // don't overwrite series of synchronized charts - delete options.series; - } - - w.config = Utils$1.extend(w.config, options); - - if (overwriteInitialConfig) { - // we need to forget the lastXAxis and lastYAxis as user forcefully overwriteInitialConfig. If we do not do this, and next time when user zooms the chart after setting yaxis.min/max or xaxis.min/max - the stored lastXAxis will never allow the chart to use the updated min/max by user. - w.globals.lastXAxis = options.xaxis ? Utils$1.clone(options.xaxis) : []; - w.globals.lastYAxis = options.yaxis ? Utils$1.clone(options.yaxis) : []; // After forgetting lastAxes, we need to restore the new config in initialConfig/initialSeries - - w.globals.initialConfig = Utils$1.extend({}, w.config); - w.globals.initialSeries = Utils$1.clone(w.config.series); - - if (options.series) { - // Replace the collapsed series data - for (var i = 0; i < w.globals.collapsedSeriesIndices.length; i++) { - var series = w.config.series[w.globals.collapsedSeriesIndices[i]]; - w.globals.collapsedSeries[i].data = w.globals.axisCharts ? series.data.slice() : series; - } - - for (var _i = 0; _i < w.globals.ancillaryCollapsedSeriesIndices.length; _i++) { - var _series = w.config.series[w.globals.ancillaryCollapsedSeriesIndices[_i]]; - w.globals.ancillaryCollapsedSeries[_i].data = w.globals.axisCharts ? _series.data.slice() : _series; - } // Ensure that auto-generated axes are scaled to the visible data - - - ch.series.emptyCollapsedSeries(w.config.series); - } - } - } - - return ch.update(options).then(function () { - if (chartIndex === charts.length - 1) { - resolve(ch); - } - }); - }); - }); - } - /** - * Private method to update Series. - * - * @param {array} series - New series which will override the existing - */ - - }, { - key: "_updateSeries", - value: function _updateSeries(newSeries, animate) { - var _this2 = this; - - var overwriteInitialSeries = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return new Promise(function (resolve) { - var w = _this2.w; - w.globals.shouldAnimate = animate; - w.globals.dataChanged = true; - - if (animate) { - _this2.ctx.series.getPreviousPaths(); - } - - var existingSeries; // axis charts - - if (w.globals.axisCharts) { - existingSeries = newSeries.map(function (s, i) { - return _this2._extendSeries(s, i); - }); - - if (existingSeries.length === 0) { - existingSeries = [{ - data: [] - }]; - } - - w.config.series = existingSeries; - } else { - // non-axis chart (pie/radialbar) - w.config.series = newSeries.slice(); - } - - if (overwriteInitialSeries) { - w.globals.initialConfig.series = Utils$1.clone(w.config.series); - w.globals.initialSeries = Utils$1.clone(w.config.series); - } - - return _this2.ctx.update().then(function () { - resolve(_this2.ctx); - }); - }); - } - }, { - key: "_extendSeries", - value: function _extendSeries(s, i) { - var w = this.w; - var ser = w.config.series[i]; - return _objectSpread2(_objectSpread2({}, w.config.series[i]), {}, { - name: s.name ? s.name : ser && ser.name, - color: s.color ? s.color : ser && ser.color, - type: s.type ? s.type : ser && ser.type, - data: s.data ? s.data : ser && ser.data - }); - } - }, { - key: "toggleDataPointSelection", - value: function toggleDataPointSelection(seriesIndex, dataPointIndex) { - var w = this.w; - var elPath = null; - var parent = ".apexcharts-series[data\\:realIndex='".concat(seriesIndex, "']"); - - if (w.globals.axisCharts) { - elPath = w.globals.dom.Paper.select("".concat(parent, " path[j='").concat(dataPointIndex, "'], ").concat(parent, " circle[j='").concat(dataPointIndex, "'], ").concat(parent, " rect[j='").concat(dataPointIndex, "']")).members[0]; - } else { - // dataPointIndex will be undefined here, hence using seriesIndex - if (typeof dataPointIndex === 'undefined') { - elPath = w.globals.dom.Paper.select("".concat(parent, " path[j='").concat(seriesIndex, "']")).members[0]; - - if (w.config.chart.type === 'pie' || w.config.chart.type === 'polarArea' || w.config.chart.type === 'donut') { - this.ctx.pie.pieClicked(seriesIndex); - } - } - } - - if (elPath) { - var graphics = new Graphics(this.ctx); - graphics.pathMouseDown(elPath, null); - } else { - console.warn('toggleDataPointSelection: Element not found'); - return null; - } - - return elPath.node ? elPath.node : null; - } - }, { - key: "forceXAxisUpdate", - value: function forceXAxisUpdate(options) { - var w = this.w; - var minmax = ['min', 'max']; - minmax.forEach(function (a) { - if (typeof options.xaxis[a] !== 'undefined') { - w.config.xaxis[a] = options.xaxis[a]; - w.globals.lastXAxis[a] = options.xaxis[a]; - } - }); - - if (options.xaxis.categories && options.xaxis.categories.length) { - w.config.xaxis.categories = options.xaxis.categories; - } - - if (w.config.xaxis.convertedCatToNumeric) { - var defaults = new Defaults(options); - options = defaults.convertCatToNumericXaxis(options, this.ctx); - } - - return options; - } - }, { - key: "forceYAxisUpdate", - value: function forceYAxisUpdate(options) { - if (options.chart && options.chart.stacked && options.chart.stackType === '100%') { - if (Array.isArray(options.yaxis)) { - options.yaxis.forEach(function (yaxe, index) { - options.yaxis[index].min = 0; - options.yaxis[index].max = 100; - }); - } else { - options.yaxis.min = 0; - options.yaxis.max = 100; - } - } - - return options; - } - /** - * This function reverts the yaxis and xaxis min/max values to what it was when the chart was defined. - * This function fixes an important bug where a user might load a new series after zooming in/out of previous series which resulted in wrong min/max - * Also, this should never be called internally on zoom/pan - the reset should only happen when user calls the updateSeries() function externally - * The function also accepts an object {xaxis, yaxis} which when present is set as the new xaxis/yaxis - */ - - }, { - key: "revertDefaultAxisMinMax", - value: function revertDefaultAxisMinMax(opts) { - var _this3 = this; - - var w = this.w; - var xaxis = w.globals.lastXAxis; - var yaxis = w.globals.lastYAxis; - - if (opts && opts.xaxis) { - xaxis = opts.xaxis; - } - - if (opts && opts.yaxis) { - yaxis = opts.yaxis; - } - - w.config.xaxis.min = xaxis.min; - w.config.xaxis.max = xaxis.max; - - var getLastYAxis = function getLastYAxis(index) { - if (typeof yaxis[index] !== 'undefined') { - w.config.yaxis[index].min = yaxis[index].min; - w.config.yaxis[index].max = yaxis[index].max; - } - }; - - w.config.yaxis.map(function (yaxe, index) { - if (w.globals.zoomed) { - // user has zoomed, check the last yaxis - getLastYAxis(index); - } else { - // user hasn't zoomed, check the last yaxis first - if (typeof yaxis[index] !== 'undefined') { - getLastYAxis(index); - } else { - // if last y-axis don't exist, check the original yaxis - if (typeof _this3.ctx.opts.yaxis[index] !== 'undefined') { - yaxe.min = _this3.ctx.opts.yaxis[index].min; - yaxe.max = _this3.ctx.opts.yaxis[index].max; - } - } - } - }); - } - }]); - - return UpdateHelpers; - }(); - - (function (root, factory) { - /* istanbul ignore next */ - if (typeof define === 'function' && define.amd) { - define(function () { - return factory(root, root.document); - }); - /* below check fixes #412 */ - } else if ((typeof exports === "undefined" ? "undefined" : _typeof(exports)) === 'object' && typeof module !== 'undefined') { - module.exports = root.document ? factory(root, root.document) : function (w) { - return factory(w, w.document); - }; - } else { - root.SVG = factory(root, root.document); - } - })(typeof window !== 'undefined' ? window : undefined, function (window, document) { - // Find global reference - uses 'this' by default when available, - // falls back to 'window' otherwise (for bundlers like Webpack) - var globalRef = typeof this !== 'undefined' ? this : window; // The main wrapping element - - var SVG = globalRef.SVG = function (element) { - if (SVG.supported) { - element = new SVG.Doc(element); - - if (!SVG.parser.draw) { - SVG.prepare(); - } - - return element; - } - }; // Default namespaces - - - SVG.ns = 'http://www.w3.org/2000/svg'; - SVG.xmlns = 'http://www.w3.org/2000/xmlns/'; - SVG.xlink = 'http://www.w3.org/1999/xlink'; - SVG.svgjs = 'http://svgjs.dev'; // Svg support test - - SVG.supported = function () { - return true; // !!document.createElementNS && - // !! document.createElementNS(SVG.ns,'svg').createSVGRect - }(); // Don't bother to continue if SVG is not supported - - - if (!SVG.supported) return false; // Element id sequence - - SVG.did = 1000; // Get next named element id - - SVG.eid = function (name) { - return 'Svgjs' + capitalize(name) + SVG.did++; - }; // Method for element creation - - - SVG.create = function (name) { - // create element - var element = document.createElementNS(this.ns, name); // apply unique id - - element.setAttribute('id', this.eid(name)); - return element; - }; // Method for extending objects - - - SVG.extend = function () { - var modules, methods; // Get list of modules - - modules = [].slice.call(arguments); // Get object with extensions - - methods = modules.pop(); - - for (var i = modules.length - 1; i >= 0; i--) { - if (modules[i]) { - for (var key in methods) { - modules[i].prototype[key] = methods[key]; - } - } - } // Make sure SVG.Set inherits any newly added methods - - - if (SVG.Set && SVG.Set.inherit) { - SVG.Set.inherit(); - } - }; // Invent new element - - - SVG.invent = function (config) { - // Create element initializer - var initializer = typeof config.create === 'function' ? config.create : function () { - this.constructor.call(this, SVG.create(config.create)); - }; // Inherit prototype - - if (config.inherit) { - initializer.prototype = new config.inherit(); - } // Extend with methods - - - if (config.extend) { - SVG.extend(initializer, config.extend); - } // Attach construct method to parent - - - if (config.construct) { - SVG.extend(config.parent || SVG.Container, config.construct); - } - - return initializer; - }; // Adopt existing svg elements - - - SVG.adopt = function (node) { - // check for presence of node - if (!node) return null; // make sure a node isn't already adopted - - if (node.instance) return node.instance; // initialize variables - - var element; // adopt with element-specific settings - - if (node.nodeName == 'svg') { - element = node.parentNode instanceof window.SVGElement ? new SVG.Nested() : new SVG.Doc(); - } else if (node.nodeName == 'linearGradient') { - element = new SVG.Gradient('linear'); - } else if (node.nodeName == 'radialGradient') { - element = new SVG.Gradient('radial'); - } else if (SVG[capitalize(node.nodeName)]) { - element = new SVG[capitalize(node.nodeName)](); - } else { - element = new SVG.Element(node); - } // ensure references - - - element.type = node.nodeName; - element.node = node; - node.instance = element; // SVG.Class specific preparations - - if (element instanceof SVG.Doc) { - element.namespace().defs(); - } // pull svgjs data from the dom (getAttributeNS doesn't work in html5) - - - element.setData(JSON.parse(node.getAttribute('svgjs:data')) || {}); - return element; - }; // Initialize parsing element - - - SVG.prepare = function () { - // Select document body and create invisible svg element - var body = document.getElementsByTagName('body')[0], - draw = (body ? new SVG.Doc(body) : SVG.adopt(document.documentElement).nested()).size(2, 0); // Create parser object - - SVG.parser = { - body: body || document.documentElement, - draw: draw.style('opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden').node, - poly: draw.polyline().node, - path: draw.path().node, - native: SVG.create('svg') - }; - }; - - SVG.parser = { - native: SVG.create('svg') - }; - document.addEventListener('DOMContentLoaded', function () { - if (!SVG.parser.draw) { - SVG.prepare(); - } - }, false); // Storage for regular expressions - - SVG.regex = { - // Parse unit value - numberAndUnit: /^([+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?)([a-z%]*)$/i, - // Parse hex value - hex: /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i, - // Parse rgb value - rgb: /rgb\((\d+),(\d+),(\d+)\)/, - // Parse reference id - reference: /#([a-z0-9\-_]+)/i, - // splits a transformation chain - transforms: /\)\s*,?\s*/, - // Whitespace - whitespace: /\s/g, - // Test hex value - isHex: /^#[a-f0-9]{3,6}$/i, - // Test rgb value - isRgb: /^rgb\(/, - // Test css declaration - isCss: /[^:]+:[^;]+;?/, - // Test for blank string - isBlank: /^(\s+)?$/, - // Test for numeric string - isNumber: /^[+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i, - // Test for percent value - isPercent: /^-?[\d\.]+%$/, - // Test for image url - isImage: /\.(jpg|jpeg|png|gif|svg)(\?[^=]+.*)?/i, - // split at whitespace and comma - delimiter: /[\s,]+/, - // The following regex are used to parse the d attribute of a path - // Matches all hyphens which are not after an exponent - hyphen: /([^e])\-/gi, - // Replaces and tests for all path letters - pathLetters: /[MLHVCSQTAZ]/gi, - // yes we need this one, too - isPathLetter: /[MLHVCSQTAZ]/i, - // matches 0.154.23.45 - numbersWithDots: /((\d?\.\d+(?:e[+-]?\d+)?)((?:\.\d+(?:e[+-]?\d+)?)+))+/gi, - // matches . - dots: /\./g - }; - SVG.utils = { - // Map function - map: function map(array, block) { - var il = array.length, - result = []; - - for (var i = 0; i < il; i++) { - result.push(block(array[i])); - } - - return result; - }, - // Filter function - filter: function filter(array, block) { - var il = array.length, - result = []; - - for (var i = 0; i < il; i++) { - if (block(array[i])) { - result.push(array[i]); - } - } - - return result; - }, - filterSVGElements: function filterSVGElements(nodes) { - return this.filter(nodes, function (el) { - return el instanceof window.SVGElement; - }); - } - }; - SVG.defaults = { - // Default attribute values - attrs: { - // fill and stroke - 'fill-opacity': 1, - 'stroke-opacity': 1, - 'stroke-width': 0, - 'stroke-linejoin': 'miter', - 'stroke-linecap': 'butt', - fill: '#000000', - stroke: '#000000', - opacity: 1, - // position - x: 0, - y: 0, - cx: 0, - cy: 0, - // size - width: 0, - height: 0, - // radius - r: 0, - rx: 0, - ry: 0, - // gradient - offset: 0, - 'stop-opacity': 1, - 'stop-color': '#000000', - // text - 'font-size': 16, - 'font-family': 'Helvetica, Arial, sans-serif', - 'text-anchor': 'start' - } - }; // Module for color convertions - - SVG.Color = function (color) { - var match; // initialize defaults - - this.r = 0; - this.g = 0; - this.b = 0; - if (!color) return; // parse color - - if (typeof color === 'string') { - if (SVG.regex.isRgb.test(color)) { - // get rgb values - match = SVG.regex.rgb.exec(color.replace(SVG.regex.whitespace, '')); // parse numeric values - - this.r = parseInt(match[1]); - this.g = parseInt(match[2]); - this.b = parseInt(match[3]); - } else if (SVG.regex.isHex.test(color)) { - // get hex values - match = SVG.regex.hex.exec(fullHex(color)); // parse numeric values - - this.r = parseInt(match[1], 16); - this.g = parseInt(match[2], 16); - this.b = parseInt(match[3], 16); - } - } else if (_typeof(color) === 'object') { - this.r = color.r; - this.g = color.g; - this.b = color.b; - } - }; - - SVG.extend(SVG.Color, { - // Default to hex conversion - toString: function toString() { - return this.toHex(); - }, - // Build hex value - toHex: function toHex() { - return '#' + compToHex(this.r) + compToHex(this.g) + compToHex(this.b); - }, - // Build rgb value - toRgb: function toRgb() { - return 'rgb(' + [this.r, this.g, this.b].join() + ')'; - }, - // Calculate true brightness - brightness: function brightness() { - return this.r / 255 * 0.30 + this.g / 255 * 0.59 + this.b / 255 * 0.11; - }, - // Make color morphable - morph: function morph(color) { - this.destination = new SVG.Color(color); - return this; - }, - // Get morphed color at given position - at: function at(pos) { - // make sure a destination is defined - if (!this.destination) return this; // normalise pos - - pos = pos < 0 ? 0 : pos > 1 ? 1 : pos; // generate morphed color - - return new SVG.Color({ - r: ~~(this.r + (this.destination.r - this.r) * pos), - g: ~~(this.g + (this.destination.g - this.g) * pos), - b: ~~(this.b + (this.destination.b - this.b) * pos) - }); - } - }); // Testers - // Test if given value is a color string - - SVG.Color.test = function (color) { - color += ''; - return SVG.regex.isHex.test(color) || SVG.regex.isRgb.test(color); - }; // Test if given value is a rgb object - - - SVG.Color.isRgb = function (color) { - return color && typeof color.r === 'number' && typeof color.g === 'number' && typeof color.b === 'number'; - }; // Test if given value is a color - - - SVG.Color.isColor = function (color) { - return SVG.Color.isRgb(color) || SVG.Color.test(color); - }; // Module for array conversion - - - SVG.Array = function (array, fallback) { - array = (array || []).valueOf(); // if array is empty and fallback is provided, use fallback - - if (array.length == 0 && fallback) { - array = fallback.valueOf(); - } // parse array - - - this.value = this.parse(array); - }; - - SVG.extend(SVG.Array, { - // Convert array to string - toString: function toString() { - return this.value.join(' '); - }, - // Real value - valueOf: function valueOf() { - return this.value; - }, - // Parse whitespace separated string - parse: function parse(array) { - array = array.valueOf(); // if already is an array, no need to parse it - - if (Array.isArray(array)) return array; - return this.split(array); - } - }); // Poly points array - - SVG.PointArray = function (array, fallback) { - SVG.Array.call(this, array, fallback || [[0, 0]]); - }; // Inherit from SVG.Array - - - SVG.PointArray.prototype = new SVG.Array(); - SVG.PointArray.prototype.constructor = SVG.PointArray; - var pathHandlers = { - M: function M(c, p, p0) { - p.x = p0.x = c[0]; - p.y = p0.y = c[1]; - return ['M', p.x, p.y]; - }, - L: function L(c, p) { - p.x = c[0]; - p.y = c[1]; - return ['L', c[0], c[1]]; - }, - H: function H(c, p) { - p.x = c[0]; - return ['H', c[0]]; - }, - V: function V(c, p) { - p.y = c[0]; - return ['V', c[0]]; - }, - C: function C(c, p) { - p.x = c[4]; - p.y = c[5]; - return ['C', c[0], c[1], c[2], c[3], c[4], c[5]]; - }, - Q: function Q(c, p) { - p.x = c[2]; - p.y = c[3]; - return ['Q', c[0], c[1], c[2], c[3]]; - }, - Z: function Z(c, p, p0) { - p.x = p0.x; - p.y = p0.y; - return ['Z']; - } - }; - var mlhvqtcsa = 'mlhvqtcsaz'.split(''); - - for (var i = 0, il = mlhvqtcsa.length; i < il; ++i) { - pathHandlers[mlhvqtcsa[i]] = function (i) { - return function (c, p, p0) { - if (i == 'H') c[0] = c[0] + p.x;else if (i == 'V') c[0] = c[0] + p.y;else if (i == 'A') { - c[5] = c[5] + p.x, c[6] = c[6] + p.y; - } else { - for (var j = 0, jl = c.length; j < jl; ++j) { - c[j] = c[j] + (j % 2 ? p.y : p.x); - } - } - - if (pathHandlers && typeof pathHandlers[i] === 'function') { - // this check fixes jest unit tests - return pathHandlers[i](c, p, p0); - } - }; - }(mlhvqtcsa[i].toUpperCase()); - } // Path points array - - - SVG.PathArray = function (array, fallback) { - SVG.Array.call(this, array, fallback || [['M', 0, 0]]); - }; // Inherit from SVG.Array - - - SVG.PathArray.prototype = new SVG.Array(); - SVG.PathArray.prototype.constructor = SVG.PathArray; - SVG.extend(SVG.PathArray, { - // Convert array to string - toString: function toString() { - return arrayToString(this.value); - }, - // Move path string - move: function move(x, y) { - // get bounding box of current situation - var box = this.bbox(); // get relative offset - - x -= box.x; - y -= box.y; - return this; - }, - // Get morphed path array at given position - at: function at(pos) { - // make sure a destination is defined - if (!this.destination) return this; - var sourceArray = this.value, - destinationArray = this.destination.value, - array = [], - pathArray = new SVG.PathArray(), - il, - jl; // Animate has specified in the SVG spec - // See: https://www.w3.org/TR/SVG11/paths.html#PathElement - - for (var i = 0, il = sourceArray.length; i < il; i++) { - array[i] = [sourceArray[i][0]]; - - for (var j = 1, jl = sourceArray[i].length; j < jl; j++) { - array[i][j] = sourceArray[i][j] + (destinationArray[i][j] - sourceArray[i][j]) * pos; - } // For the two flags of the elliptical arc command, the SVG spec say: - // Flags and booleans are interpolated as fractions between zero and one, with any non-zero value considered to be a value of one/true - // Elliptical arc command as an array followed by corresponding indexes: - // ['A', rx, ry, x-axis-rotation, large-arc-flag, sweep-flag, x, y] - // 0 1 2 3 4 5 6 7 - - - if (array[i][0] === 'A') { - array[i][4] = +(array[i][4] != 0); - array[i][5] = +(array[i][5] != 0); - } - } // Directly modify the value of a path array, this is done this way for performance - - - pathArray.value = array; - return pathArray; - }, - // Absolutize and parse path to array - parse: function parse(array) { - // if it's already a patharray, no need to parse it - if (array instanceof SVG.PathArray) return array.valueOf(); // prepare for parsing - - var s, - arr, - paramCnt = { - 'M': 2, - 'L': 2, - 'H': 1, - 'V': 1, - 'C': 6, - 'S': 4, - 'Q': 4, - 'T': 2, - 'A': 7, - 'Z': 0 - }; - - if (typeof array === 'string') { - array = array.replace(SVG.regex.numbersWithDots, pathRegReplace) // convert 45.123.123 to 45.123 .123 - .replace(SVG.regex.pathLetters, ' $& ') // put some room between letters and numbers - .replace(SVG.regex.hyphen, '$1 -') // add space before hyphen - .trim() // trim - .split(SVG.regex.delimiter); // split into array - } else { - array = array.reduce(function (prev, curr) { - return [].concat.call(prev, curr); - }, []); - } // array now is an array containing all parts of a path e.g. ['M', '0', '0', 'L', '30', '30' ...] - - - var arr = [], - p = new SVG.Point(), - p0 = new SVG.Point(), - index = 0, - len = array.length; - - do { - // Test if we have a path letter - if (SVG.regex.isPathLetter.test(array[index])) { - s = array[index]; - ++index; // If last letter was a move command and we got no new, it defaults to [L]ine - } else if (s == 'M') { - s = 'L'; - } else if (s == 'm') { - s = 'l'; - } - - arr.push(pathHandlers[s].call(null, array.slice(index, index = index + paramCnt[s.toUpperCase()]).map(parseFloat), p, p0)); - } while (len > index); - - return arr; - }, - // Get bounding box of path - bbox: function bbox() { - if (!SVG.parser.draw) { - SVG.prepare(); - } - - SVG.parser.path.setAttribute('d', this.toString()); - return SVG.parser.path.getBBox(); - } - }); // Module for unit convertions - - SVG.Number = SVG.invent({ - // Initialize - create: function create(value, unit) { - // initialize defaults - this.value = 0; - this.unit = unit || ''; // parse value - - if (typeof value === 'number') { - // ensure a valid numeric value - this.value = isNaN(value) ? 0 : !isFinite(value) ? value < 0 ? -3.4e+38 : +3.4e+38 : value; - } else if (typeof value === 'string') { - unit = value.match(SVG.regex.numberAndUnit); - - if (unit) { - // make value numeric - this.value = parseFloat(unit[1]); // normalize - - if (unit[5] == '%') { - this.value /= 100; - } else if (unit[5] == 's') { - this.value *= 1000; - } // store unit - - - this.unit = unit[5]; - } - } else { - if (value instanceof SVG.Number) { - this.value = value.valueOf(); - this.unit = value.unit; - } - } - }, - // Add methods - extend: { - // Stringalize - toString: function toString() { - return (this.unit == '%' ? ~~(this.value * 1e8) / 1e6 : this.unit == 's' ? this.value / 1e3 : this.value) + this.unit; - }, - toJSON: function toJSON() { - return this.toString(); - }, - // Convert to primitive - valueOf: function valueOf() { - return this.value; - }, - // Add number - plus: function plus(number) { - number = new SVG.Number(number); - return new SVG.Number(this + number, this.unit || number.unit); - }, - // Subtract number - minus: function minus(number) { - number = new SVG.Number(number); - return new SVG.Number(this - number, this.unit || number.unit); - }, - // Multiply number - times: function times(number) { - number = new SVG.Number(number); - return new SVG.Number(this * number, this.unit || number.unit); - }, - // Divide number - divide: function divide(number) { - number = new SVG.Number(number); - return new SVG.Number(this / number, this.unit || number.unit); - }, - // Convert to different unit - to: function to(unit) { - var number = new SVG.Number(this); - - if (typeof unit === 'string') { - number.unit = unit; - } - - return number; - }, - // Make number morphable - morph: function morph(number) { - this.destination = new SVG.Number(number); - - if (number.relative) { - this.destination.value += this.value; - } - - return this; - }, - // Get morphed number at given position - at: function at(pos) { - // Make sure a destination is defined - if (!this.destination) return this; // Generate new morphed number - - return new SVG.Number(this.destination).minus(this).times(pos).plus(this); - } - } - }); - SVG.Element = SVG.invent({ - // Initialize node - create: function create(node) { - // make stroke value accessible dynamically - this._stroke = SVG.defaults.attrs.stroke; - this._event = null; // initialize data object - - this.dom = {}; // create circular reference - - if (this.node = node) { - this.type = node.nodeName; - this.node.instance = this; // store current attribute value - - this._stroke = node.getAttribute('stroke') || this._stroke; - } - }, - // Add class methods - extend: { - // Move over x-axis - x: function x(_x) { - return this.attr('x', _x); - }, - // Move over y-axis - y: function y(_y) { - return this.attr('y', _y); - }, - // Move by center over x-axis - cx: function cx(x) { - return x == null ? this.x() + this.width() / 2 : this.x(x - this.width() / 2); - }, - // Move by center over y-axis - cy: function cy(y) { - return y == null ? this.y() + this.height() / 2 : this.y(y - this.height() / 2); - }, - // Move element to given x and y values - move: function move(x, y) { - return this.x(x).y(y); - }, - // Move element by its center - center: function center(x, y) { - return this.cx(x).cy(y); - }, - // Set width of element - width: function width(_width) { - return this.attr('width', _width); - }, - // Set height of element - height: function height(_height) { - return this.attr('height', _height); - }, - // Set element size to given width and height - size: function size(width, height) { - var p = proportionalSize(this, width, height); - return this.width(new SVG.Number(p.width)).height(new SVG.Number(p.height)); - }, - // Clone element - clone: function clone(parent) { - // write dom data to the dom so the clone can pickup the data - this.writeDataToDom(); // clone element and assign new id - - var clone = assignNewId(this.node.cloneNode(true)); // insert the clone in the given parent or after myself - - if (parent) parent.add(clone);else this.after(clone); - return clone; - }, - // Remove element - remove: function remove() { - if (this.parent()) { - this.parent().removeElement(this); - } - - return this; - }, - // Replace element - replace: function replace(element) { - this.after(element).remove(); - return element; - }, - // Add element to given container and return self - addTo: function addTo(parent) { - return parent.put(this); - }, - // Add element to given container and return container - putIn: function putIn(parent) { - return parent.add(this); - }, - // Get / set id - id: function id(_id) { - return this.attr('id', _id); - }, - // Show element - show: function show() { - return this.style('display', ''); - }, - // Hide element - hide: function hide() { - return this.style('display', 'none'); - }, - // Is element visible? - visible: function visible() { - return this.style('display') != 'none'; - }, - // Return id on string conversion - toString: function toString() { - return this.attr('id'); - }, - // Return array of classes on the node - classes: function classes() { - var attr = this.attr('class'); - return attr == null ? [] : attr.trim().split(SVG.regex.delimiter); - }, - // Return true if class exists on the node, false otherwise - hasClass: function hasClass(name) { - return this.classes().indexOf(name) != -1; - }, - // Add class to the node - addClass: function addClass(name) { - if (!this.hasClass(name)) { - var array = this.classes(); - array.push(name); - this.attr('class', array.join(' ')); - } - - return this; - }, - // Remove class from the node - removeClass: function removeClass(name) { - if (this.hasClass(name)) { - this.attr('class', this.classes().filter(function (c) { - return c != name; - }).join(' ')); - } - - return this; - }, - // Toggle the presence of a class on the node - toggleClass: function toggleClass(name) { - return this.hasClass(name) ? this.removeClass(name) : this.addClass(name); - }, - // Get referenced element form attribute value - reference: function reference(attr) { - return SVG.get(this.attr(attr)); - }, - // Returns the parent element instance - parent: function parent(type) { - var parent = this; // check for parent - - if (!parent.node.parentNode) return null; // get parent element - - parent = SVG.adopt(parent.node.parentNode); - if (!type) return parent; // loop trough ancestors if type is given - - while (parent && parent.node instanceof window.SVGElement) { - if (typeof type === 'string' ? parent.matches(type) : parent instanceof type) return parent; - if (!parent.node.parentNode || parent.node.parentNode.nodeName == '#document') return null; // #759, #720 - - parent = SVG.adopt(parent.node.parentNode); - } - }, - // Get parent document - doc: function doc() { - return this instanceof SVG.Doc ? this : this.parent(SVG.Doc); - }, - // return array of all ancestors of given type up to the root svg - parents: function parents(type) { - var parents = [], - parent = this; - - do { - parent = parent.parent(type); - if (!parent || !parent.node) break; - parents.push(parent); - } while (parent.parent); - - return parents; - }, - // matches the element vs a css selector - matches: function matches(selector) { - return _matches(this.node, selector); - }, - // Returns the svg node to call native svg methods on it - native: function native() { - return this.node; - }, - // Import raw svg - svg: function svg(_svg) { - // create temporary holder - var well = document.createElement('svg'); // act as a setter if svg is given - - if (_svg && this instanceof SVG.Parent) { - // dump raw svg - well.innerHTML = '' + _svg.replace(/\n/, '').replace(/<([\w:-]+)([^<]+?)\/>/g, '<$1$2>') + ''; // transplant nodes - - for (var i = 0, il = well.firstChild.childNodes.length; i < il; i++) { - this.node.appendChild(well.firstChild.firstChild); - } // otherwise act as a getter - - } else { - // create a wrapping svg element in case of partial content - well.appendChild(_svg = document.createElement('svg')); // write svgjs data to the dom - - this.writeDataToDom(); // insert a copy of this node - - _svg.appendChild(this.node.cloneNode(true)); // return target element - - - return well.innerHTML.replace(/^/, '').replace(/<\/svg>$/, ''); - } - - return this; - }, - // write svgjs data to the dom - writeDataToDom: function writeDataToDom() { - // dump variables recursively - if (this.each || this.lines) { - var fn = this.each ? this : this.lines(); - fn.each(function () { - this.writeDataToDom(); - }); - } // remove previously set data - - - this.node.removeAttribute('svgjs:data'); - - if (Object.keys(this.dom).length) { - this.node.setAttribute('svgjs:data', JSON.stringify(this.dom)); - } // see #428 - - - return this; - }, - // set given data to the elements data property - setData: function setData(o) { - this.dom = o; - return this; - }, - is: function is(obj) { - return _is(this, obj); - } - } - }); - SVG.easing = { - '-': function _(pos) { - return pos; - }, - '<>': function _(pos) { - return -Math.cos(pos * Math.PI) / 2 + 0.5; - }, - '>': function _(pos) { - return Math.sin(pos * Math.PI / 2); - }, - '<': function _(pos) { - return -Math.cos(pos * Math.PI / 2) + 1; - } - }; - - SVG.morph = function (pos) { - return function (from, to) { - return new SVG.MorphObj(from, to).at(pos); - }; - }; - - SVG.Situation = SVG.invent({ - create: function create(o) { - this.init = false; - this.reversed = false; - this.reversing = false; - this.duration = new SVG.Number(o.duration).valueOf(); - this.delay = new SVG.Number(o.delay).valueOf(); - this.start = +new Date() + this.delay; - this.finish = this.start + this.duration; - this.ease = o.ease; // this.loop is incremented from 0 to this.loops - // it is also incremented when in an infinite loop (when this.loops is true) - - this.loop = 0; - this.loops = false; - this.animations = {// functionToCall: [list of morphable objects] - // e.g. move: [SVG.Number, SVG.Number] - }; - this.attrs = {// holds all attributes which are not represented from a function svg.js provides - // e.g. someAttr: SVG.Number - }; - this.styles = {// holds all styles which should be animated - // e.g. fill-color: SVG.Color - }; - this.transforms = [// holds all transformations as transformation objects - // e.g. [SVG.Rotate, SVG.Translate, SVG.Matrix] - ]; - this.once = {// functions to fire at a specific position - // e.g. "0.5": function foo(){} - }; - } - }); - SVG.FX = SVG.invent({ - create: function create(element) { - this._target = element; - this.situations = []; - this.active = false; - this.situation = null; - this.paused = false; - this.lastPos = 0; - this.pos = 0; // The absolute position of an animation is its position in the context of its complete duration (including delay and loops) - // When performing a delay, absPos is below 0 and when performing a loop, its value is above 1 - - this.absPos = 0; - this._speed = 1; - }, - extend: { - /** - * sets or returns the target of this animation - * @param o object || number In case of Object it holds all parameters. In case of number its the duration of the animation - * @param ease function || string Function which should be used for easing or easing keyword - * @param delay Number indicating the delay before the animation starts - * @return target || this - */ - animate: function animate(o, ease, delay) { - if (_typeof(o) === 'object') { - ease = o.ease; - delay = o.delay; - o = o.duration; - } - - var situation = new SVG.Situation({ - duration: o || 1000, - delay: delay || 0, - ease: SVG.easing[ease || '-'] || ease - }); - this.queue(situation); - return this; - }, - - /** - * sets a delay before the next element of the queue is called - * @param delay Duration of delay in milliseconds - * @return this.target() - */ - - /** - * sets or returns the target of this animation - * @param null || target SVG.Element which should be set as new target - * @return target || this - */ - target: function target(_target) { - if (_target && _target instanceof SVG.Element) { - this._target = _target; - return this; - } - - return this._target; - }, - // returns the absolute position at a given time - timeToAbsPos: function timeToAbsPos(timestamp) { - return (timestamp - this.situation.start) / (this.situation.duration / this._speed); - }, - // returns the timestamp from a given absolute positon - absPosToTime: function absPosToTime(absPos) { - return this.situation.duration / this._speed * absPos + this.situation.start; - }, - // starts the animationloop - startAnimFrame: function startAnimFrame() { - this.stopAnimFrame(); - this.animationFrame = window.requestAnimationFrame(function () { - this.step(); - }.bind(this)); - }, - // cancels the animationframe - stopAnimFrame: function stopAnimFrame() { - window.cancelAnimationFrame(this.animationFrame); - }, - // kicks off the animation - only does something when the queue is currently not active and at least one situation is set - start: function start() { - // dont start if already started - if (!this.active && this.situation) { - this.active = true; - this.startCurrent(); - } - - return this; - }, - // start the current situation - startCurrent: function startCurrent() { - this.situation.start = +new Date() + this.situation.delay / this._speed; - this.situation.finish = this.situation.start + this.situation.duration / this._speed; - return this.initAnimations().step(); - }, - - /** - * adds a function / Situation to the animation queue - * @param fn function / situation to add - * @return this - */ - queue: function queue(fn) { - if (typeof fn === 'function' || fn instanceof SVG.Situation) { - this.situations.push(fn); - } - - if (!this.situation) this.situation = this.situations.shift(); - return this; - }, - - /** - * pulls next element from the queue and execute it - * @return this - */ - dequeue: function dequeue() { - // stop current animation - this.stop(); // get next animation from queue - - this.situation = this.situations.shift(); - - if (this.situation) { - if (this.situation instanceof SVG.Situation) { - this.start(); - } else { - // If it is not a SVG.Situation, then it is a function, we execute it - this.situation.call(this); - } - } - - return this; - }, - // updates all animations to the current state of the element - // this is important when one property could be changed from another property - initAnimations: function initAnimations() { - var source; - var s = this.situation; - if (s.init) return this; - - for (var i in s.animations) { - source = this.target()[i](); - - if (!Array.isArray(source)) { - source = [source]; - } - - if (!Array.isArray(s.animations[i])) { - s.animations[i] = [s.animations[i]]; - } // if(s.animations[i].length > source.length) { - // source.concat = source.concat(s.animations[i].slice(source.length, s.animations[i].length)) - // } - - - for (var j = source.length; j--;) { - // The condition is because some methods return a normal number instead - // of a SVG.Number - if (s.animations[i][j] instanceof SVG.Number) { - source[j] = new SVG.Number(source[j]); - } - - s.animations[i][j] = source[j].morph(s.animations[i][j]); - } - } - - for (var i in s.attrs) { - s.attrs[i] = new SVG.MorphObj(this.target().attr(i), s.attrs[i]); - } - - for (var i in s.styles) { - s.styles[i] = new SVG.MorphObj(this.target().style(i), s.styles[i]); - } - - s.initialTransformation = this.target().matrixify(); - s.init = true; - return this; - }, - clearQueue: function clearQueue() { - this.situations = []; - return this; - }, - clearCurrent: function clearCurrent() { - this.situation = null; - return this; - }, - - /** stops the animation immediately - * @param jumpToEnd A Boolean indicating whether to complete the current animation immediately. - * @param clearQueue A Boolean indicating whether to remove queued animation as well. - * @return this - */ - stop: function stop(jumpToEnd, clearQueue) { - var active = this.active; - this.active = false; - - if (clearQueue) { - this.clearQueue(); - } - - if (jumpToEnd && this.situation) { - // initialize the situation if it was not - !active && this.startCurrent(); - this.atEnd(); - } - - this.stopAnimFrame(); - return this.clearCurrent(); - }, - after: function after(fn) { - var c = this.last(), - wrapper = function wrapper(e) { - if (e.detail.situation == c) { - fn.call(this, c); - this.off('finished.fx', wrapper); // prevent memory leak - } - }; - - this.target().on('finished.fx', wrapper); - return this._callStart(); - }, - // adds a callback which is called whenever one animation step is performed - during: function during(fn) { - var c = this.last(), - wrapper = function wrapper(e) { - if (e.detail.situation == c) { - fn.call(this, e.detail.pos, SVG.morph(e.detail.pos), e.detail.eased, c); - } - }; // see above - - - this.target().off('during.fx', wrapper).on('during.fx', wrapper); - this.after(function () { - this.off('during.fx', wrapper); - }); - return this._callStart(); - }, - // calls after ALL animations in the queue are finished - afterAll: function afterAll(fn) { - var wrapper = function wrapper(e) { - fn.call(this); - this.off('allfinished.fx', wrapper); - }; // see above - - - this.target().off('allfinished.fx', wrapper).on('allfinished.fx', wrapper); - return this._callStart(); - }, - last: function last() { - return this.situations.length ? this.situations[this.situations.length - 1] : this.situation; - }, - // adds one property to the animations - add: function add(method, args, type) { - this.last()[type || 'animations'][method] = args; - return this._callStart(); - }, - - /** perform one step of the animation - * @param ignoreTime Boolean indicating whether to ignore time and use position directly or recalculate position based on time - * @return this - */ - step: function step(ignoreTime) { - // convert current time to an absolute position - if (!ignoreTime) this.absPos = this.timeToAbsPos(+new Date()); // This part convert an absolute position to a position - - if (this.situation.loops !== false) { - var absPos, absPosInt, lastLoop; // If the absolute position is below 0, we just treat it as if it was 0 - - absPos = Math.max(this.absPos, 0); - absPosInt = Math.floor(absPos); - - if (this.situation.loops === true || absPosInt < this.situation.loops) { - this.pos = absPos - absPosInt; - lastLoop = this.situation.loop; - this.situation.loop = absPosInt; - } else { - this.absPos = this.situation.loops; - this.pos = 1; // The -1 here is because we don't want to toggle reversed when all the loops have been completed - - lastLoop = this.situation.loop - 1; - this.situation.loop = this.situation.loops; - } - - if (this.situation.reversing) { - // Toggle reversed if an odd number of loops as occured since the last call of step - this.situation.reversed = this.situation.reversed != Boolean((this.situation.loop - lastLoop) % 2); - } - } else { - // If there are no loop, the absolute position must not be above 1 - this.absPos = Math.min(this.absPos, 1); - this.pos = this.absPos; - } // while the absolute position can be below 0, the position must not be below 0 - - - if (this.pos < 0) this.pos = 0; - if (this.situation.reversed) this.pos = 1 - this.pos; // apply easing - - var eased = this.situation.ease(this.pos); // call once-callbacks - - for (var i in this.situation.once) { - if (i > this.lastPos && i <= eased) { - this.situation.once[i].call(this.target(), this.pos, eased); - delete this.situation.once[i]; - } - } // fire during callback with position, eased position and current situation as parameter - - - if (this.active) this.target().fire('during', { - pos: this.pos, - eased: eased, - fx: this, - situation: this.situation - }); // the user may call stop or finish in the during callback - // so make sure that we still have a valid situation - - if (!this.situation) { - return this; - } // apply the actual animation to every property - - - this.eachAt(); // do final code when situation is finished - - if (this.pos == 1 && !this.situation.reversed || this.situation.reversed && this.pos == 0) { - // stop animation callback - this.stopAnimFrame(); // fire finished callback with current situation as parameter - - this.target().fire('finished', { - fx: this, - situation: this.situation - }); - - if (!this.situations.length) { - this.target().fire('allfinished'); // Recheck the length since the user may call animate in the afterAll callback - - if (!this.situations.length) { - this.target().off('.fx'); // there shouldnt be any binding left, but to make sure... - - this.active = false; - } - } // start next animation - - - if (this.active) this.dequeue();else this.clearCurrent(); - } else if (!this.paused && this.active) { - // we continue animating when we are not at the end - this.startAnimFrame(); - } // save last eased position for once callback triggering - - - this.lastPos = eased; - return this; - }, - // calculates the step for every property and calls block with it - eachAt: function eachAt() { - var len, - at, - self = this, - target = this.target(), - s = this.situation; // apply animations which can be called trough a method - - for (var i in s.animations) { - at = [].concat(s.animations[i]).map(function (el) { - return typeof el !== 'string' && el.at ? el.at(s.ease(self.pos), self.pos) : el; - }); - target[i].apply(target, at); - } // apply animation which has to be applied with attr() - - - for (var i in s.attrs) { - at = [i].concat(s.attrs[i]).map(function (el) { - return typeof el !== 'string' && el.at ? el.at(s.ease(self.pos), self.pos) : el; - }); - target.attr.apply(target, at); - } // apply animation which has to be applied with style() - - - for (var i in s.styles) { - at = [i].concat(s.styles[i]).map(function (el) { - return typeof el !== 'string' && el.at ? el.at(s.ease(self.pos), self.pos) : el; - }); - target.style.apply(target, at); - } // animate initialTransformation which has to be chained - - - if (s.transforms.length) { - // get initial initialTransformation - at = s.initialTransformation; - - for (var i = 0, len = s.transforms.length; i < len; i++) { - // get next transformation in chain - var a = s.transforms[i]; // multiply matrix directly - - if (a instanceof SVG.Matrix) { - if (a.relative) { - at = at.multiply(new SVG.Matrix().morph(a).at(s.ease(this.pos))); - } else { - at = at.morph(a).at(s.ease(this.pos)); - } - - continue; - } // when transformation is absolute we have to reset the needed transformation first - - - if (!a.relative) { - a.undo(at.extract()); - } // and reapply it after - - - at = at.multiply(a.at(s.ease(this.pos))); - } // set new matrix on element - - - target.matrix(at); - } - - return this; - }, - // adds an once-callback which is called at a specific position and never again - once: function once(pos, fn, isEased) { - var c = this.last(); - if (!isEased) pos = c.ease(pos); - c.once[pos] = fn; - return this; - }, - _callStart: function _callStart() { - setTimeout(function () { - this.start(); - }.bind(this), 0); - return this; - } - }, - parent: SVG.Element, - // Add method to parent elements - construct: { - // Get fx module or create a new one, then animate with given duration and ease - animate: function animate(o, ease, delay) { - return (this.fx || (this.fx = new SVG.FX(this))).animate(o, ease, delay); - }, - delay: function delay(_delay) { - return (this.fx || (this.fx = new SVG.FX(this))).delay(_delay); - }, - stop: function stop(jumpToEnd, clearQueue) { - if (this.fx) { - this.fx.stop(jumpToEnd, clearQueue); - } - - return this; - }, - finish: function finish() { - if (this.fx) { - this.fx.finish(); - } - - return this; - } - } - }); // MorphObj is used whenever no morphable object is given - - SVG.MorphObj = SVG.invent({ - create: function create(from, to) { - // prepare color for morphing - if (SVG.Color.isColor(to)) return new SVG.Color(from).morph(to); // check if we have a list of values - - if (SVG.regex.delimiter.test(from)) { - // prepare path for morphing - if (SVG.regex.pathLetters.test(from)) return new SVG.PathArray(from).morph(to); // prepare value list for morphing - else return new SVG.Array(from).morph(to); - } // prepare number for morphing - - - if (SVG.regex.numberAndUnit.test(to)) return new SVG.Number(from).morph(to); // prepare for plain morphing - - this.value = from; - this.destination = to; - }, - extend: { - at: function at(pos, real) { - return real < 1 ? this.value : this.destination; - }, - valueOf: function valueOf() { - return this.value; - } - } - }); - SVG.extend(SVG.FX, { - // Add animatable attributes - attr: function attr(a, v, relative) { - // apply attributes individually - if (_typeof(a) === 'object') { - for (var key in a) { - this.attr(key, a[key]); - } - } else { - this.add(a, v, 'attrs'); - } - - return this; - }, - // Add animatable plot - plot: function plot(a, b, c, d) { - // Lines can be plotted with 4 arguments - if (arguments.length == 4) { - return this.plot([a, b, c, d]); - } - - return this.add('plot', new (this.target().morphArray)(a)); - } - }); - SVG.Box = SVG.invent({ - create: function create(x, y, width, height) { - if (_typeof(x) === 'object' && !(x instanceof SVG.Element)) { - // chromes getBoundingClientRect has no x and y property - return SVG.Box.call(this, x.left != null ? x.left : x.x, x.top != null ? x.top : x.y, x.width, x.height); - } else if (arguments.length == 4) { - this.x = x; - this.y = y; - this.width = width; - this.height = height; - } // add center, right, bottom... - - - fullBox(this); - } - }); - SVG.BBox = SVG.invent({ - // Initialize - create: function create(element) { - SVG.Box.apply(this, [].slice.call(arguments)); // get values if element is given - - if (element instanceof SVG.Element) { - var box; // yes this is ugly, but Firefox can be a pain when it comes to elements that are not yet rendered - - try { - if (!document.documentElement.contains) { - // This is IE - it does not support contains() for top-level SVGs - var topParent = element.node; - - while (topParent.parentNode) { - topParent = topParent.parentNode; - } - - if (topParent != document) throw new Error('Element not in the dom'); - } else {// the element is NOT in the dom, throw error - // disabling the check below which fixes issue #76 - // if (!document.documentElement.contains(element.node)) throw new Exception('Element not in the dom') - } // find native bbox - - - box = element.node.getBBox(); - } catch (e) { - if (element instanceof SVG.Shape) { - if (!SVG.parser.draw) { - // fixes apexcharts/vue-apexcharts #14 - SVG.prepare(); - } - - var clone = element.clone(SVG.parser.draw.instance).show(); - - if (clone && clone.node && typeof clone.node.getBBox === 'function') { - // this check fixes jest unit tests - box = clone.node.getBBox(); - } - - if (clone && typeof clone.remove === 'function') { - clone.remove(); - } - } else { - box = { - x: element.node.clientLeft, - y: element.node.clientTop, - width: element.node.clientWidth, - height: element.node.clientHeight - }; - } - } - - SVG.Box.call(this, box); - } - }, - // Define ancestor - inherit: SVG.Box, - // Define Parent - parent: SVG.Element, - // Constructor - construct: { - // Get bounding box - bbox: function bbox() { - return new SVG.BBox(this); - } - } - }); - SVG.BBox.prototype.constructor = SVG.BBox; - SVG.Matrix = SVG.invent({ - // Initialize - create: function create(source) { - var base = arrayToMatrix([1, 0, 0, 1, 0, 0]); // ensure source as object - - source = source === null ? base : source instanceof SVG.Element ? source.matrixify() : typeof source === 'string' ? arrayToMatrix(source.split(SVG.regex.delimiter).map(parseFloat)) : arguments.length == 6 ? arrayToMatrix([].slice.call(arguments)) : Array.isArray(source) ? arrayToMatrix(source) : source && _typeof(source) === 'object' ? source : base; // merge source - - for (var i = abcdef.length - 1; i >= 0; --i) { - this[abcdef[i]] = source[abcdef[i]] != null ? source[abcdef[i]] : base[abcdef[i]]; - } - }, - // Add methods - extend: { - // Extract individual transformations - extract: function extract() { - // find delta transform points - var px = deltaTransformPoint(this, 0, 1); - deltaTransformPoint(this, 1, 0); - var skewX = 180 / Math.PI * Math.atan2(px.y, px.x) - 90; - return { - // translation - x: this.e, - y: this.f, - transformedX: (this.e * Math.cos(skewX * Math.PI / 180) + this.f * Math.sin(skewX * Math.PI / 180)) / Math.sqrt(this.a * this.a + this.b * this.b), - transformedY: (this.f * Math.cos(skewX * Math.PI / 180) + this.e * Math.sin(-skewX * Math.PI / 180)) / Math.sqrt(this.c * this.c + this.d * this.d), - // rotation - rotation: skewX, - a: this.a, - b: this.b, - c: this.c, - d: this.d, - e: this.e, - f: this.f, - matrix: new SVG.Matrix(this) - }; - }, - // Clone matrix - clone: function clone() { - return new SVG.Matrix(this); - }, - // Morph one matrix into another - morph: function morph(matrix) { - // store new destination - this.destination = new SVG.Matrix(matrix); - return this; - }, - // Multiplies by given matrix - multiply: function multiply(matrix) { - return new SVG.Matrix(this.native().multiply(parseMatrix(matrix).native())); - }, - // Inverses matrix - inverse: function inverse() { - return new SVG.Matrix(this.native().inverse()); - }, - // Translate matrix - translate: function translate(x, y) { - return new SVG.Matrix(this.native().translate(x || 0, y || 0)); - }, - // Convert to native SVGMatrix - native: function native() { - // create new matrix - var matrix = SVG.parser.native.createSVGMatrix(); // update with current values - - for (var i = abcdef.length - 1; i >= 0; i--) { - matrix[abcdef[i]] = this[abcdef[i]]; - } - - return matrix; - }, - // Convert matrix to string - toString: function toString() { - // Construct the matrix directly, avoid values that are too small - return 'matrix(' + float32String(this.a) + ',' + float32String(this.b) + ',' + float32String(this.c) + ',' + float32String(this.d) + ',' + float32String(this.e) + ',' + float32String(this.f) + ')'; - } - }, - // Define parent - parent: SVG.Element, - // Add parent method - construct: { - // Get current matrix - ctm: function ctm() { - return new SVG.Matrix(this.node.getCTM()); - }, - // Get current screen matrix - screenCTM: function screenCTM() { - /* https://bugzilla.mozilla.org/show_bug.cgi?id=1344537 - This is needed because FF does not return the transformation matrix - for the inner coordinate system when getScreenCTM() is called on nested svgs. - However all other Browsers do that */ - if (this instanceof SVG.Nested) { - var rect = this.rect(1, 1); - var m = rect.node.getScreenCTM(); - rect.remove(); - return new SVG.Matrix(m); - } - - return new SVG.Matrix(this.node.getScreenCTM()); - } - } - }); - SVG.Point = SVG.invent({ - // Initialize - create: function create(x, y) { - var source, - base = { - x: 0, - y: 0 - }; // ensure source as object - - source = Array.isArray(x) ? { - x: x[0], - y: x[1] - } : _typeof(x) === 'object' ? { - x: x.x, - y: x.y - } : x != null ? { - x: x, - y: y != null ? y : x - } : base; // If y has no value, then x is used has its value - // merge source - - this.x = source.x; - this.y = source.y; - }, - // Add methods - extend: { - // Clone point - clone: function clone() { - return new SVG.Point(this); - }, - // Morph one point into another - morph: function morph(x, y) { - // store new destination - this.destination = new SVG.Point(x, y); - return this; - } - } - }); - SVG.extend(SVG.Element, { - // Get point - point: function point(x, y) { - return new SVG.Point(x, y).transform(this.screenCTM().inverse()); - } - }); - SVG.extend(SVG.Element, { - // Set svg element attribute - attr: function attr(a, v, n) { - // act as full getter - if (a == null) { - // get an object of attributes - a = {}; - v = this.node.attributes; - - for (var n = v.length - 1; n >= 0; n--) { - a[v[n].nodeName] = SVG.regex.isNumber.test(v[n].nodeValue) ? parseFloat(v[n].nodeValue) : v[n].nodeValue; - } - - return a; - } else if (_typeof(a) === 'object') { - // apply every attribute individually if an object is passed - for (var v_ in a) { - this.attr(v_, a[v_]); - } - } else if (v === null) { - // remove value - this.node.removeAttribute(a); - } else if (v == null) { - // act as a getter if the first and only argument is not an object - v = this.node.getAttribute(a); - return v == null ? SVG.defaults.attrs[a] : SVG.regex.isNumber.test(v) ? parseFloat(v) : v; - } else { - // BUG FIX: some browsers will render a stroke if a color is given even though stroke width is 0 - if (a == 'stroke-width') { - this.attr('stroke', parseFloat(v) > 0 ? this._stroke : null); - } else if (a == 'stroke') { - this._stroke = v; - } // convert image fill and stroke to patterns - - - if (a == 'fill' || a == 'stroke') { - if (SVG.regex.isImage.test(v)) { - v = this.doc().defs().image(v, 0, 0); - } - - if (v instanceof SVG.Image) { - v = this.doc().defs().pattern(0, 0, function () { - this.add(v); - }); - } - } // ensure correct numeric values (also accepts NaN and Infinity) - - - if (typeof v === 'number') { - v = new SVG.Number(v); - } // ensure full hex color - else if (SVG.Color.isColor(v)) { - v = new SVG.Color(v); - } // parse array values - else if (Array.isArray(v)) { - v = new SVG.Array(v); - } // if the passed attribute is leading... - - - if (a == 'leading') { - // ... call the leading method instead - if (this.leading) { - this.leading(v); - } - } else { - // set given attribute on node - typeof n === 'string' ? this.node.setAttributeNS(n, a, v.toString()) : this.node.setAttribute(a, v.toString()); - } // rebuild if required - - - if (this.rebuild && (a == 'font-size' || a == 'x')) { - this.rebuild(a, v); - } - } - - return this; - } - }); - SVG.extend(SVG.Element, { - // Add transformations - transform: function transform(o, relative) { - // get target in case of the fx module, otherwise reference this - var target = this, - matrix; - // act as a getter - - if (_typeof(o) !== 'object') { - // get current matrix - matrix = new SVG.Matrix(target).extract(); - return typeof o === 'string' ? matrix[o] : matrix; - } // get current matrix - - - matrix = new SVG.Matrix(target); // ensure relative flag - - relative = !!relative || !!o.relative; // act on matrix - - if (o.a != null) { - matrix = relative // relative - ? matrix.multiply(new SVG.Matrix(o)) // absolute - : new SVG.Matrix(o); - } - - return this.attr('transform', matrix); - } - }); - SVG.extend(SVG.Element, { - // Reset all transformations - untransform: function untransform() { - return this.attr('transform', null); - }, - // merge the whole transformation chain into one matrix and returns it - matrixify: function matrixify() { - var matrix = (this.attr('transform') || '').split(SVG.regex.transforms).slice(0, -1).map(function (str) { - // generate key => value pairs - var kv = str.trim().split('('); - return [kv[0], kv[1].split(SVG.regex.delimiter).map(function (str) { - return parseFloat(str); - })]; - }) // merge every transformation into one matrix - .reduce(function (matrix, transform) { - if (transform[0] == 'matrix') return matrix.multiply(arrayToMatrix(transform[1])); - return matrix[transform[0]].apply(matrix, transform[1]); - }, new SVG.Matrix()); - return matrix; - }, - // add an element to another parent without changing the visual representation on the screen - toParent: function toParent(parent) { - if (this == parent) return this; - var ctm = this.screenCTM(); - var pCtm = parent.screenCTM().inverse(); - this.addTo(parent).untransform().transform(pCtm.multiply(ctm)); - return this; - }, - // same as above with parent equals root-svg - toDoc: function toDoc() { - return this.toParent(this.doc()); - } - }); - SVG.Transformation = SVG.invent({ - create: function create(source, inversed) { - if (arguments.length > 1 && typeof inversed !== 'boolean') { - return this.constructor.call(this, [].slice.call(arguments)); - } - - if (Array.isArray(source)) { - for (var i = 0, len = this.arguments.length; i < len; ++i) { - this[this.arguments[i]] = source[i]; - } - } else if (source && _typeof(source) === 'object') { - for (var i = 0, len = this.arguments.length; i < len; ++i) { - this[this.arguments[i]] = source[this.arguments[i]]; - } - } - - this.inversed = false; - - if (inversed === true) { - this.inversed = true; - } - } - }); - SVG.Translate = SVG.invent({ - parent: SVG.Matrix, - inherit: SVG.Transformation, - create: function create(source, inversed) { - this.constructor.apply(this, [].slice.call(arguments)); - }, - extend: { - arguments: ['transformedX', 'transformedY'], - method: 'translate' - } - }); - SVG.extend(SVG.Element, { - // Dynamic style generator - style: function style(s, v) { - if (arguments.length == 0) { - // get full style - return this.node.style.cssText || ''; - } else if (arguments.length < 2) { - // apply every style individually if an object is passed - if (_typeof(s) === 'object') { - for (var v_ in s) { - this.style(v_, s[v_]); - } - } else if (SVG.regex.isCss.test(s)) { - // parse css string - s = s.split(/\s*;\s*/) // filter out suffix ; and stuff like ;; - .filter(function (e) { - return !!e; - }).map(function (e) { - return e.split(/\s*:\s*/); - }); // apply every definition individually - - while (v = s.pop()) { - this.style(v[0], v[1]); - } - } else { - // act as a getter if the first and only argument is not an object - return this.node.style[camelCase(s)]; - } - } else { - this.node.style[camelCase(s)] = v === null || SVG.regex.isBlank.test(v) ? '' : v; - } - - return this; - } - }); - SVG.Parent = SVG.invent({ - // Initialize node - create: function create(element) { - this.constructor.call(this, element); - }, - // Inherit from - inherit: SVG.Element, - // Add class methods - extend: { - // Returns all child elements - children: function children() { - return SVG.utils.map(SVG.utils.filterSVGElements(this.node.childNodes), function (node) { - return SVG.adopt(node); - }); - }, - // Add given element at a position - add: function add(element, i) { - if (i == null) { - this.node.appendChild(element.node); - } else if (element.node != this.node.childNodes[i]) { - this.node.insertBefore(element.node, this.node.childNodes[i]); - } - - return this; - }, - // Basically does the same as `add()` but returns the added element instead - put: function put(element, i) { - this.add(element, i); - return element; - }, - // Checks if the given element is a child - has: function has(element) { - return this.index(element) >= 0; - }, - // Gets index of given element - index: function index(element) { - return [].slice.call(this.node.childNodes).indexOf(element.node); - }, - // Get a element at the given index - get: function get(i) { - return SVG.adopt(this.node.childNodes[i]); - }, - // Get first child - first: function first() { - return this.get(0); - }, - // Get the last child - last: function last() { - return this.get(this.node.childNodes.length - 1); - }, - // Iterates over all children and invokes a given block - each: function each(block, deep) { - var il, - children = this.children(); - - for (var i = 0, il = children.length; i < il; i++) { - if (children[i] instanceof SVG.Element) { - block.apply(children[i], [i, children]); - } - - if (deep && children[i] instanceof SVG.Container) { - children[i].each(block, deep); - } - } - - return this; - }, - // Remove a given child - removeElement: function removeElement(element) { - this.node.removeChild(element.node); - return this; - }, - // Remove all elements in this container - clear: function clear() { - // remove children - while (this.node.hasChildNodes()) { - this.node.removeChild(this.node.lastChild); - } // remove defs reference - - - delete this._defs; - return this; - }, - // Get defs - defs: function defs() { - return this.doc().defs(); - } - } - }); - SVG.extend(SVG.Parent, { - ungroup: function ungroup(parent, depth) { - if (depth === 0 || this instanceof SVG.Defs || this.node == SVG.parser.draw) return this; - parent = parent || (this instanceof SVG.Doc ? this : this.parent(SVG.Parent)); - depth = depth || Infinity; - this.each(function () { - if (this instanceof SVG.Defs) return this; - if (this instanceof SVG.Parent) return this.ungroup(parent, depth - 1); - return this.toParent(parent); - }); - this.node.firstChild || this.remove(); - return this; - }, - flatten: function flatten(parent, depth) { - return this.ungroup(parent, depth); - } - }); - SVG.Container = SVG.invent({ - // Initialize node - create: function create(element) { - this.constructor.call(this, element); - }, - // Inherit from - inherit: SVG.Parent - }); - SVG.ViewBox = SVG.invent({ - // Define parent - parent: SVG.Container, - // Add parent method - construct: {} - }) // Add events to elements - ; - ['click', 'dblclick', 'mousedown', 'mouseup', 'mouseover', 'mouseout', 'mousemove', // , 'mouseenter' -> not supported by IE - // , 'mouseleave' -> not supported by IE - 'touchstart', 'touchmove', 'touchleave', 'touchend', 'touchcancel'].forEach(function (event) { - // add event to SVG.Element - SVG.Element.prototype[event] = function (f) { - // bind event to element rather than element node - SVG.on(this.node, event, f); - return this; - }; - }); // Initialize listeners stack - - SVG.listeners = []; - SVG.handlerMap = []; - SVG.listenerId = 0; // Add event binder in the SVG namespace - - SVG.on = function (node, event, listener, binding, options) { - // create listener, get object-index - var l = listener.bind(binding || node.instance || node), - index = (SVG.handlerMap.indexOf(node) + 1 || SVG.handlerMap.push(node)) - 1, - ev = event.split('.')[0], - ns = event.split('.')[1] || '*'; // ensure valid object - - SVG.listeners[index] = SVG.listeners[index] || {}; - SVG.listeners[index][ev] = SVG.listeners[index][ev] || {}; - SVG.listeners[index][ev][ns] = SVG.listeners[index][ev][ns] || {}; - - if (!listener._svgjsListenerId) { - listener._svgjsListenerId = ++SVG.listenerId; - } // reference listener - - - SVG.listeners[index][ev][ns][listener._svgjsListenerId] = l; // add listener - - node.addEventListener(ev, l, options || { - passive: true - }); - }; // Add event unbinder in the SVG namespace - - - SVG.off = function (node, event, listener) { - var index = SVG.handlerMap.indexOf(node), - ev = event && event.split('.')[0], - ns = event && event.split('.')[1], - namespace = ''; - if (index == -1) return; - - if (listener) { - if (typeof listener === 'function') listener = listener._svgjsListenerId; - if (!listener) return; // remove listener reference - - if (SVG.listeners[index][ev] && SVG.listeners[index][ev][ns || '*']) { - // remove listener - node.removeEventListener(ev, SVG.listeners[index][ev][ns || '*'][listener], false); - delete SVG.listeners[index][ev][ns || '*'][listener]; - } - } else if (ns && ev) { - // remove all listeners for a namespaced event - if (SVG.listeners[index][ev] && SVG.listeners[index][ev][ns]) { - for (var listener_ in SVG.listeners[index][ev][ns]) { - SVG.off(node, [ev, ns].join('.'), listener_); - } - - delete SVG.listeners[index][ev][ns]; - } - } else if (ns) { - // remove all listeners for a specific namespace - for (var event_ in SVG.listeners[index]) { - for (var namespace in SVG.listeners[index][event_]) { - if (ns === namespace) { - SVG.off(node, [event_, ns].join('.')); - } - } - } - } else if (ev) { - // remove all listeners for the event - if (SVG.listeners[index][ev]) { - for (var namespace in SVG.listeners[index][ev]) { - SVG.off(node, [ev, namespace].join('.')); - } - - delete SVG.listeners[index][ev]; - } - } else { - // remove all listeners on a given node - for (var event_ in SVG.listeners[index]) { - SVG.off(node, event_); - } - - delete SVG.listeners[index]; - delete SVG.handlerMap[index]; - } - }; // - - - SVG.extend(SVG.Element, { - // Bind given event to listener - on: function on(event, listener, binding, options) { - SVG.on(this.node, event, listener, binding, options); - return this; - }, - // Unbind event from listener - off: function off(event, listener) { - SVG.off(this.node, event, listener); - return this; - }, - // Fire given event - fire: function fire(event, data) { - // Dispatch event - if (event instanceof window.Event) { - this.node.dispatchEvent(event); - } else { - this.node.dispatchEvent(event = new SVG.CustomEvent(event, { - detail: data, - cancelable: true - })); - } - - this._event = event; - return this; - }, - event: function event() { - return this._event; - } - }); - SVG.Defs = SVG.invent({ - // Initialize node - create: 'defs', - // Inherit from - inherit: SVG.Container - }); - SVG.G = SVG.invent({ - // Initialize node - create: 'g', - // Inherit from - inherit: SVG.Container, - // Add class methods - extend: { - // Move over x-axis - x: function x(_x2) { - return _x2 == null ? this.transform('x') : this.transform({ - x: _x2 - this.x() - }, true); - } - }, - // Add parent method - construct: { - // Create a group element - group: function group() { - return this.put(new SVG.G()); - } - } - }); - SVG.Doc = SVG.invent({ - // Initialize node - create: function create(element) { - if (element) { - // ensure the presence of a dom element - element = typeof element === 'string' ? document.getElementById(element) : element; // If the target is an svg element, use that element as the main wrapper. - // This allows svg.js to work with svg documents as well. - - if (element.nodeName == 'svg') { - this.constructor.call(this, element); - } else { - this.constructor.call(this, SVG.create('svg')); - element.appendChild(this.node); - this.size('100%', '100%'); - } // set svg element attributes and ensure defs node - - - this.namespace().defs(); - } - }, - // Inherit from - inherit: SVG.Container, - // Add class methods - extend: { - // Add namespaces - namespace: function namespace() { - return this.attr({ - xmlns: SVG.ns, - version: '1.1' - }).attr('xmlns:xlink', SVG.xlink, SVG.xmlns).attr('xmlns:svgjs', SVG.svgjs, SVG.xmlns); - }, - // Creates and returns defs element - defs: function defs() { - if (!this._defs) { - var defs; // Find or create a defs element in this instance - - if (defs = this.node.getElementsByTagName('defs')[0]) { - this._defs = SVG.adopt(defs); - } else { - this._defs = new SVG.Defs(); - } // Make sure the defs node is at the end of the stack - - - this.node.appendChild(this._defs.node); - } - - return this._defs; - }, - // custom parent method - parent: function parent() { - if (!this.node.parentNode || this.node.parentNode.nodeName == '#document') return null; - return this.node.parentNode; - }, - // Removes the doc from the DOM - remove: function remove() { - if (this.parent()) { - this.parent().removeChild(this.node); - } - - return this; - }, - clear: function clear() { - // remove children - while (this.node.hasChildNodes()) { - this.node.removeChild(this.node.lastChild); - } // remove defs reference - - - delete this._defs; // add back parser - - if (SVG.parser.draw && !SVG.parser.draw.parentNode) { - this.node.appendChild(SVG.parser.draw); - } - - return this; - }, - clone: function clone(parent) { - // write dom data to the dom so the clone can pickup the data - this.writeDataToDom(); // get reference to node - - var node = this.node; // clone element and assign new id - - var clone = assignNewId(node.cloneNode(true)); // insert the clone in the given parent or after myself - - if (parent) { - (parent.node || parent).appendChild(clone.node); - } else { - node.parentNode.insertBefore(clone.node, node.nextSibling); - } - - return clone; - } - } - }); // ### This module adds backward / forward functionality to elements. - // - - SVG.extend(SVG.Element, {// Get all siblings, including myself - }); - SVG.Gradient = SVG.invent({ - // Initialize node - create: function create(type) { - this.constructor.call(this, SVG.create(type + 'Gradient')); // store type - - this.type = type; - }, - // Inherit from - inherit: SVG.Container, - // Add class methods - extend: { - // Add a color stop - at: function at(offset, color, opacity) { - return this.put(new SVG.Stop()).update(offset, color, opacity); - }, - // Update gradient - update: function update(block) { - // remove all stops - this.clear(); // invoke passed block - - if (typeof block === 'function') { - block.call(this, this); - } - - return this; - }, - // Return the fill id - fill: function fill() { - return 'url(#' + this.id() + ')'; - }, - // Alias string convertion to fill - toString: function toString() { - return this.fill(); - }, - // custom attr to handle transform - attr: function attr(a, b, c) { - if (a == 'transform') a = 'gradientTransform'; - return SVG.Container.prototype.attr.call(this, a, b, c); - } - }, - // Add parent method - construct: { - // Create gradient element in defs - gradient: function gradient(type, block) { - return this.defs().gradient(type, block); - } - } - }); // Add animatable methods to both gradient and fx module - - SVG.extend(SVG.Gradient, SVG.FX, { - // From position - from: function from(x, y) { - return (this._target || this).type == 'radial' ? this.attr({ - fx: new SVG.Number(x), - fy: new SVG.Number(y) - }) : this.attr({ - x1: new SVG.Number(x), - y1: new SVG.Number(y) - }); - }, - // To position - to: function to(x, y) { - return (this._target || this).type == 'radial' ? this.attr({ - cx: new SVG.Number(x), - cy: new SVG.Number(y) - }) : this.attr({ - x2: new SVG.Number(x), - y2: new SVG.Number(y) - }); - } - }); // Base gradient generation - - SVG.extend(SVG.Defs, { - // define gradient - gradient: function gradient(type, block) { - return this.put(new SVG.Gradient(type)).update(block); - } - }); - SVG.Stop = SVG.invent({ - // Initialize node - create: 'stop', - // Inherit from - inherit: SVG.Element, - // Add class methods - extend: { - // add color stops - update: function update(o) { - if (typeof o === 'number' || o instanceof SVG.Number) { - o = { - offset: arguments[0], - color: arguments[1], - opacity: arguments[2] - }; - } // set attributes - - - if (o.opacity != null) this.attr('stop-opacity', o.opacity); - if (o.color != null) this.attr('stop-color', o.color); - if (o.offset != null) this.attr('offset', new SVG.Number(o.offset)); - return this; - } - } - }); - SVG.Pattern = SVG.invent({ - // Initialize node - create: 'pattern', - // Inherit from - inherit: SVG.Container, - // Add class methods - extend: { - // Return the fill id - fill: function fill() { - return 'url(#' + this.id() + ')'; - }, - // Update pattern by rebuilding - update: function update(block) { - // remove content - this.clear(); // invoke passed block - - if (typeof block === 'function') { - block.call(this, this); - } - - return this; - }, - // Alias string convertion to fill - toString: function toString() { - return this.fill(); - }, - // custom attr to handle transform - attr: function attr(a, b, c) { - if (a == 'transform') a = 'patternTransform'; - return SVG.Container.prototype.attr.call(this, a, b, c); - } - }, - // Add parent method - construct: { - // Create pattern element in defs - pattern: function pattern(width, height, block) { - return this.defs().pattern(width, height, block); - } - } - }); - SVG.extend(SVG.Defs, { - // Define gradient - pattern: function pattern(width, height, block) { - return this.put(new SVG.Pattern()).update(block).attr({ - x: 0, - y: 0, - width: width, - height: height, - patternUnits: 'userSpaceOnUse' - }); - } - }); - SVG.Shape = SVG.invent({ - // Initialize node - create: function create(element) { - this.constructor.call(this, element); - }, - // Inherit from - inherit: SVG.Element - }); - SVG.Symbol = SVG.invent({ - // Initialize node - create: 'symbol', - // Inherit from - inherit: SVG.Container, - construct: { - // create symbol - symbol: function symbol() { - return this.put(new SVG.Symbol()); - } - } - }); - SVG.Use = SVG.invent({ - // Initialize node - create: 'use', - // Inherit from - inherit: SVG.Shape, - // Add class methods - extend: { - // Use element as a reference - element: function element(_element, file) { - // Set lined element - return this.attr('href', (file || '') + '#' + _element, SVG.xlink); - } - }, - // Add parent method - construct: { - // Create a use element - use: function use(element, file) { - return this.put(new SVG.Use()).element(element, file); - } - } - }); - SVG.Rect = SVG.invent({ - // Initialize node - create: 'rect', - // Inherit from - inherit: SVG.Shape, - // Add parent method - construct: { - // Create a rect element - rect: function rect(width, height) { - return this.put(new SVG.Rect()).size(width, height); - } - } - }); - SVG.Circle = SVG.invent({ - // Initialize node - create: 'circle', - // Inherit from - inherit: SVG.Shape, - // Add parent method - construct: { - // Create circle element, based on ellipse - circle: function circle(size) { - return this.put(new SVG.Circle()).rx(new SVG.Number(size).divide(2)).move(0, 0); - } - } - }); - SVG.extend(SVG.Circle, SVG.FX, { - // Radius x value - rx: function rx(_rx) { - return this.attr('r', _rx); - }, - // Alias radius x value - ry: function ry(_ry) { - return this.rx(_ry); - } - }); - SVG.Ellipse = SVG.invent({ - // Initialize node - create: 'ellipse', - // Inherit from - inherit: SVG.Shape, - // Add parent method - construct: { - // Create an ellipse - ellipse: function ellipse(width, height) { - return this.put(new SVG.Ellipse()).size(width, height).move(0, 0); - } - } - }); - SVG.extend(SVG.Ellipse, SVG.Rect, SVG.FX, { - // Radius x value - rx: function rx(_rx2) { - return this.attr('rx', _rx2); - }, - // Radius y value - ry: function ry(_ry2) { - return this.attr('ry', _ry2); - } - }); // Add common method - - SVG.extend(SVG.Circle, SVG.Ellipse, { - // Move over x-axis - x: function x(_x3) { - return _x3 == null ? this.cx() - this.rx() : this.cx(_x3 + this.rx()); - }, - // Move over y-axis - y: function y(_y2) { - return _y2 == null ? this.cy() - this.ry() : this.cy(_y2 + this.ry()); - }, - // Move by center over x-axis - cx: function cx(x) { - return x == null ? this.attr('cx') : this.attr('cx', x); - }, - // Move by center over y-axis - cy: function cy(y) { - return y == null ? this.attr('cy') : this.attr('cy', y); - }, - // Set width of element - width: function width(_width2) { - return _width2 == null ? this.rx() * 2 : this.rx(new SVG.Number(_width2).divide(2)); - }, - // Set height of element - height: function height(_height2) { - return _height2 == null ? this.ry() * 2 : this.ry(new SVG.Number(_height2).divide(2)); - }, - // Custom size function - size: function size(width, height) { - var p = proportionalSize(this, width, height); - return this.rx(new SVG.Number(p.width).divide(2)).ry(new SVG.Number(p.height).divide(2)); - } - }); - SVG.Line = SVG.invent({ - // Initialize node - create: 'line', - // Inherit from - inherit: SVG.Shape, - // Add class methods - extend: { - // Get array - array: function array() { - return new SVG.PointArray([[this.attr('x1'), this.attr('y1')], [this.attr('x2'), this.attr('y2')]]); - }, - // Overwrite native plot() method - plot: function plot(x1, y1, x2, y2) { - if (x1 == null) { - return this.array(); - } else if (typeof y1 !== 'undefined') { - x1 = { - x1: x1, - y1: y1, - x2: x2, - y2: y2 - }; - } else { - x1 = new SVG.PointArray(x1).toLine(); - } - - return this.attr(x1); - }, - // Move by left top corner - move: function move(x, y) { - return this.attr(this.array().move(x, y).toLine()); - }, - // Set element size to given width and height - size: function size(width, height) { - var p = proportionalSize(this, width, height); - return this.attr(this.array().size(p.width, p.height).toLine()); - } - }, - // Add parent method - construct: { - // Create a line element - line: function line(x1, y1, x2, y2) { - // make sure plot is called as a setter - // x1 is not necessarily a number, it can also be an array, a string and a SVG.PointArray - return SVG.Line.prototype.plot.apply(this.put(new SVG.Line()), x1 != null ? [x1, y1, x2, y2] : [0, 0, 0, 0]); - } - } - }); - SVG.Polyline = SVG.invent({ - // Initialize node - create: 'polyline', - // Inherit from - inherit: SVG.Shape, - // Add parent method - construct: { - // Create a wrapped polyline element - polyline: function polyline(p) { - // make sure plot is called as a setter - return this.put(new SVG.Polyline()).plot(p || new SVG.PointArray()); - } - } - }); - SVG.Polygon = SVG.invent({ - // Initialize node - create: 'polygon', - // Inherit from - inherit: SVG.Shape, - // Add parent method - construct: { - // Create a wrapped polygon element - polygon: function polygon(p) { - // make sure plot is called as a setter - return this.put(new SVG.Polygon()).plot(p || new SVG.PointArray()); - } - } - }); // Add polygon-specific functions - - SVG.extend(SVG.Polyline, SVG.Polygon, { - // Get array - array: function array() { - return this._array || (this._array = new SVG.PointArray(this.attr('points'))); - }, - // Plot new path - plot: function plot(p) { - return p == null ? this.array() : this.clear().attr('points', typeof p === 'string' ? p : this._array = new SVG.PointArray(p)); - }, - // Clear array cache - clear: function clear() { - delete this._array; - return this; - }, - // Move by left top corner - move: function move(x, y) { - return this.attr('points', this.array().move(x, y)); - }, - // Set element size to given width and height - size: function size(width, height) { - var p = proportionalSize(this, width, height); - return this.attr('points', this.array().size(p.width, p.height)); - } - }); // unify all point to point elements - - SVG.extend(SVG.Line, SVG.Polyline, SVG.Polygon, { - // Define morphable array - morphArray: SVG.PointArray, - // Move by left top corner over x-axis - x: function x(_x4) { - return _x4 == null ? this.bbox().x : this.move(_x4, this.bbox().y); - }, - // Move by left top corner over y-axis - y: function y(_y3) { - return _y3 == null ? this.bbox().y : this.move(this.bbox().x, _y3); - }, - // Set width of element - width: function width(_width3) { - var b = this.bbox(); - return _width3 == null ? b.width : this.size(_width3, b.height); - }, - // Set height of element - height: function height(_height3) { - var b = this.bbox(); - return _height3 == null ? b.height : this.size(b.width, _height3); - } - }); - SVG.Path = SVG.invent({ - // Initialize node - create: 'path', - // Inherit from - inherit: SVG.Shape, - // Add class methods - extend: { - // Define morphable array - morphArray: SVG.PathArray, - // Get array - array: function array() { - return this._array || (this._array = new SVG.PathArray(this.attr('d'))); - }, - // Plot new path - plot: function plot(d) { - return d == null ? this.array() : this.clear().attr('d', typeof d === 'string' ? d : this._array = new SVG.PathArray(d)); - }, - // Clear array cache - clear: function clear() { - delete this._array; - return this; - } - }, - // Add parent method - construct: { - // Create a wrapped path element - path: function path(d) { - // make sure plot is called as a setter - return this.put(new SVG.Path()).plot(d || new SVG.PathArray()); - } - } - }); - SVG.Image = SVG.invent({ - // Initialize node - create: 'image', - // Inherit from - inherit: SVG.Shape, - // Add class methods - extend: { - // (re)load image - load: function load(url) { - if (!url) return this; - var self = this, - img = new window.Image(); // preload image - - SVG.on(img, 'load', function () { - SVG.off(img); - var p = self.parent(SVG.Pattern); - if (p === null) return; // ensure image size - - if (self.width() == 0 && self.height() == 0) { - self.size(img.width, img.height); - } // ensure pattern size if not set - - - if (p && p.width() == 0 && p.height() == 0) { - p.size(self.width(), self.height()); - } // callback - - - if (typeof self._loaded === 'function') { - self._loaded.call(self, { - width: img.width, - height: img.height, - ratio: img.width / img.height, - url: url - }); - } - }); - SVG.on(img, 'error', function (e) { - SVG.off(img); - - if (typeof self._error === 'function') { - self._error.call(self, e); - } - }); - return this.attr('href', img.src = this.src = url, SVG.xlink); - }, - // Add loaded callback - loaded: function loaded(_loaded) { - this._loaded = _loaded; - return this; - }, - error: function error(_error) { - this._error = _error; - return this; - } - }, - // Add parent method - construct: { - // create image element, load image and set its size - image: function image(source, width, height) { - return this.put(new SVG.Image()).load(source).size(width || 0, height || width || 0); - } - } - }); - SVG.Text = SVG.invent({ - // Initialize node - create: function create() { - this.constructor.call(this, SVG.create('text')); - this.dom.leading = new SVG.Number(1.3); // store leading value for rebuilding - - this._rebuild = true; // enable automatic updating of dy values - - this._build = false; // disable build mode for adding multiple lines - // set default font - - this.attr('font-family', SVG.defaults.attrs['font-family']); - }, - // Inherit from - inherit: SVG.Shape, - // Add class methods - extend: { - // Move over x-axis - x: function x(_x5) { - // act as getter - if (_x5 == null) { - return this.attr('x'); - } - - return this.attr('x', _x5); - }, - // Set the text content - text: function text(_text) { - // act as getter - if (typeof _text === 'undefined') { - var _text = ''; - var children = this.node.childNodes; - - for (var i = 0, len = children.length; i < len; ++i) { - // add newline if its not the first child and newLined is set to true - if (i != 0 && children[i].nodeType != 3 && SVG.adopt(children[i]).dom.newLined == true) { - _text += '\n'; - } // add content of this node - - - _text += children[i].textContent; - } - - return _text; - } // remove existing content - - - this.clear().build(true); - - if (typeof _text === 'function') { - // call block - _text.call(this, this); - } else { - // store text and make sure text is not blank - _text = _text.split('\n'); // build new lines - - for (var i = 0, il = _text.length; i < il; i++) { - this.tspan(_text[i]).newLine(); - } - } // disable build mode and rebuild lines - - - return this.build(false).rebuild(); - }, - // Set font size - size: function size(_size) { - return this.attr('font-size', _size).rebuild(); - }, - // Set / get leading - leading: function leading(value) { - // act as getter - if (value == null) { - return this.dom.leading; - } // act as setter - - - this.dom.leading = new SVG.Number(value); - return this.rebuild(); - }, - // Get all the first level lines - lines: function lines() { - var node = (this.textPath && this.textPath() || this).node; // filter tspans and map them to SVG.js instances - - var lines = SVG.utils.map(SVG.utils.filterSVGElements(node.childNodes), function (el) { - return SVG.adopt(el); - }); // return an instance of SVG.set - - return new SVG.Set(lines); - }, - // Rebuild appearance type - rebuild: function rebuild(_rebuild) { - // store new rebuild flag if given - if (typeof _rebuild === 'boolean') { - this._rebuild = _rebuild; - } // define position of all lines - - - if (this._rebuild) { - var self = this, - blankLineOffset = 0, - dy = this.dom.leading * new SVG.Number(this.attr('font-size')); - this.lines().each(function () { - if (this.dom.newLined) { - if (!self.textPath()) { - this.attr('x', self.attr('x')); - } - - if (this.text() == '\n') { - blankLineOffset += dy; - } else { - this.attr('dy', dy + blankLineOffset); - blankLineOffset = 0; - } - } - }); - this.fire('rebuild'); - } - - return this; - }, - // Enable / disable build mode - build: function build(_build) { - this._build = !!_build; - return this; - }, - // overwrite method from parent to set data properly - setData: function setData(o) { - this.dom = o; - this.dom.leading = new SVG.Number(o.leading || 1.3); - return this; - } - }, - // Add parent method - construct: { - // Create text element - text: function text(_text2) { - return this.put(new SVG.Text()).text(_text2); - }, - // Create plain text element - plain: function plain(text) { - return this.put(new SVG.Text()).plain(text); - } - } - }); - SVG.Tspan = SVG.invent({ - // Initialize node - create: 'tspan', - // Inherit from - inherit: SVG.Shape, - // Add class methods - extend: { - // Set text content - text: function text(_text3) { - if (_text3 == null) return this.node.textContent + (this.dom.newLined ? '\n' : ''); - typeof _text3 === 'function' ? _text3.call(this, this) : this.plain(_text3); - return this; - }, - // Shortcut dx - dx: function dx(_dx) { - return this.attr('dx', _dx); - }, - // Shortcut dy - dy: function dy(_dy) { - return this.attr('dy', _dy); - }, - // Create new line - newLine: function newLine() { - // fetch text parent - var t = this.parent(SVG.Text); // mark new line - - this.dom.newLined = true; // apply new hy¡n - - return this.dy(t.dom.leading * t.attr('font-size')).attr('x', t.x()); - } - } - }); - SVG.extend(SVG.Text, SVG.Tspan, { - // Create plain text node - plain: function plain(text) { - // clear if build mode is disabled - if (this._build === false) { - this.clear(); - } // create text node - - - this.node.appendChild(document.createTextNode(text)); - return this; - }, - // Create a tspan - tspan: function tspan(text) { - var node = (this.textPath && this.textPath() || this).node, - tspan = new SVG.Tspan(); // clear if build mode is disabled - - if (this._build === false) { - this.clear(); - } // add new tspan - - - node.appendChild(tspan.node); - return tspan.text(text); - }, - // Clear all lines - clear: function clear() { - var node = (this.textPath && this.textPath() || this).node; // remove existing child nodes - - while (node.hasChildNodes()) { - node.removeChild(node.lastChild); - } - - return this; - }, - // Get length of text element - length: function length() { - return this.node.getComputedTextLength(); - } - }); - SVG.TextPath = SVG.invent({ - // Initialize node - create: 'textPath', - // Inherit from - inherit: SVG.Parent, - // Define parent class - parent: SVG.Text, - // Add parent method - construct: { - morphArray: SVG.PathArray, - // return the array of the path track element - array: function array() { - var track = this.track(); - return track ? track.array() : null; - }, - // Plot path if any - plot: function plot(d) { - var track = this.track(), - pathArray = null; - - if (track) { - pathArray = track.plot(d); - } - - return d == null ? pathArray : this; - }, - // Get the path track element - track: function track() { - var path = this.textPath(); - - if (path) { - return path.reference('href'); - } - }, - // Get the textPath child - textPath: function textPath() { - if (this.node.firstChild && this.node.firstChild.nodeName == 'textPath') { - return SVG.adopt(this.node.firstChild); - } - } - } - }); - SVG.Nested = SVG.invent({ - // Initialize node - create: function create() { - this.constructor.call(this, SVG.create('svg')); - this.style('overflow', 'visible'); - }, - // Inherit from - inherit: SVG.Container, - // Add parent method - construct: { - // Create nested svg document - nested: function nested() { - return this.put(new SVG.Nested()); - } - } - }); // Define list of available attributes for stroke and fill - - var sugar = { - stroke: ['color', 'width', 'opacity', 'linecap', 'linejoin', 'miterlimit', 'dasharray', 'dashoffset'], - fill: ['color', 'opacity', 'rule'], - prefix: function prefix(t, a) { - return a == 'color' ? t : t + '-' + a; - } - } // Add sugar for fill and stroke - ; - ['fill', 'stroke'].forEach(function (m) { - var extension = {}; - - extension[m] = function (o) { - if (typeof o === 'undefined') { - return this; - } - - if (typeof o === 'string' || SVG.Color.isRgb(o) || o && typeof o.fill === 'function') { - this.attr(m, o); - } else // set all attributes from sugar.fill and sugar.stroke list - { - for (var i = sugar[m].length - 1; i >= 0; i--) { - if (o[sugar[m][i]] != null) { - this.attr(sugar.prefix(m, sugar[m][i]), o[sugar[m][i]]); - } - } - } - - return this; - }; - - SVG.extend(SVG.Element, SVG.FX, extension); - }); - SVG.extend(SVG.Element, SVG.FX, { - // Map translate to transform - translate: function translate(x, y) { - return this.transform({ - x: x, - y: y - }); - }, - // Map matrix to transform - matrix: function matrix(m) { - return this.attr('transform', new SVG.Matrix(arguments.length == 6 ? [].slice.call(arguments) : m)); - }, - // Opacity - opacity: function opacity(value) { - return this.attr('opacity', value); - }, - // Relative move over x axis - dx: function dx(x) { - return this.x(new SVG.Number(x).plus(this instanceof SVG.FX ? 0 : this.x()), true); - }, - // Relative move over y axis - dy: function dy(y) { - return this.y(new SVG.Number(y).plus(this instanceof SVG.FX ? 0 : this.y()), true); - } - }); - SVG.extend(SVG.Path, { - // Get path length - length: function length() { - return this.node.getTotalLength(); - }, - // Get point at length - pointAt: function pointAt(length) { - return this.node.getPointAtLength(length); - } - }); - SVG.Set = SVG.invent({ - // Initialize - create: function create(members) { - // Set initial state - Array.isArray(members) ? this.members = members : this.clear(); - }, - // Add class methods - extend: { - // Add element to set - add: function add() { - var il, - elements = [].slice.call(arguments); - - for (var i = 0, il = elements.length; i < il; i++) { - this.members.push(elements[i]); - } - - return this; - }, - // Remove element from set - remove: function remove(element) { - var i = this.index(element); // remove given child - - if (i > -1) { - this.members.splice(i, 1); - } - - return this; - }, - // Iterate over all members - each: function each(block) { - for (var i = 0, il = this.members.length; i < il; i++) { - block.apply(this.members[i], [i, this.members]); - } - - return this; - }, - // Restore to defaults - clear: function clear() { - // initialize store - this.members = []; - return this; - }, - // Get the length of a set - length: function length() { - return this.members.length; - }, - // Checks if a given element is present in set - has: function has(element) { - return this.index(element) >= 0; - }, - // retuns index of given element in set - index: function index(element) { - return this.members.indexOf(element); - }, - // Get member at given index - get: function get(i) { - return this.members[i]; - }, - // Get first member - first: function first() { - return this.get(0); - }, - // Get last member - last: function last() { - return this.get(this.members.length - 1); - }, - // Default value - valueOf: function valueOf() { - return this.members; - } - }, - // Add parent method - construct: { - // Create a new set - set: function set(members) { - return new SVG.Set(members); - } - } - }); - SVG.FX.Set = SVG.invent({ - // Initialize node - create: function create(set) { - // store reference to set - this.set = set; - } - }); // Alias methods - - SVG.Set.inherit = function () { - var methods = []; // gather shape methods - - for (var m in SVG.Shape.prototype) { - if (typeof SVG.Shape.prototype[m] === 'function' && typeof SVG.Set.prototype[m] !== 'function') { - methods.push(m); - } - } // apply shape aliasses - - - methods.forEach(function (method) { - SVG.Set.prototype[method] = function () { - for (var i = 0, il = this.members.length; i < il; i++) { - if (this.members[i] && typeof this.members[i][method] === 'function') { - this.members[i][method].apply(this.members[i], arguments); - } - } - - return method == 'animate' ? this.fx || (this.fx = new SVG.FX.Set(this)) : this; - }; - }); // clear methods for the next round - - methods = []; // gather fx methods - - for (var m in SVG.FX.prototype) { - if (typeof SVG.FX.prototype[m] === 'function' && typeof SVG.FX.Set.prototype[m] !== 'function') { - methods.push(m); - } - } // apply fx aliasses - - - methods.forEach(function (method) { - SVG.FX.Set.prototype[method] = function () { - for (var i = 0, il = this.set.members.length; i < il; i++) { - this.set.members[i].fx[method].apply(this.set.members[i].fx, arguments); - } - - return this; - }; - }); - }; - - SVG.extend(SVG.Element, {}); - SVG.extend(SVG.Element, { - // Remember arbitrary data - remember: function remember(k, v) { - // remember every item in an object individually - if (_typeof(arguments[0]) === 'object') { - for (var v_ in k) { - this.remember(v_, k[v_]); - } - } // retrieve memory - else if (arguments.length == 1) { - return this.memory()[k]; - } // store memory - else { - this.memory()[k] = v; - } - - return this; - }, - // Erase a given memory - forget: function forget() { - if (arguments.length == 0) { - this._memory = {}; - } else { - for (var i = arguments.length - 1; i >= 0; i--) { - delete this.memory()[arguments[i]]; - } - } - - return this; - }, - // Initialize or return local memory object - memory: function memory() { - return this._memory || (this._memory = {}); - } - }); // Method for getting an element by id - - SVG.get = function (id) { - var node = document.getElementById(idFromReference(id) || id); - return SVG.adopt(node); - }; // Select elements by query string - - - SVG.select = function (query, parent) { - return new SVG.Set(SVG.utils.map((parent || document).querySelectorAll(query), function (node) { - return SVG.adopt(node); - })); - }; - - SVG.extend(SVG.Parent, { - // Scoped select method - select: function select(query) { - return SVG.select(query, this.node); - } - }); - - function pathRegReplace(a, b, c, d) { - return c + d.replace(SVG.regex.dots, ' .'); - } // creates deep clone of array - - - function _is(el, obj) { - return el instanceof obj; - } // tests if a given selector matches an element - - - function _matches(el, selector) { - return (el.matches || el.matchesSelector || el.msMatchesSelector || el.mozMatchesSelector || el.webkitMatchesSelector || el.oMatchesSelector).call(el, selector); - } // Convert dash-separated-string to camelCase - - - function camelCase(s) { - return s.toLowerCase().replace(/-(.)/g, function (m, g) { - return g.toUpperCase(); - }); - } // Capitalize first letter of a string - - - function capitalize(s) { - return s.charAt(0).toUpperCase() + s.slice(1); - } // Ensure to six-based hex - - - function fullHex(hex) { - return hex.length == 4 ? ['#', hex.substring(1, 2), hex.substring(1, 2), hex.substring(2, 3), hex.substring(2, 3), hex.substring(3, 4), hex.substring(3, 4)].join('') : hex; - } // Component to hex value - - - function compToHex(comp) { - var hex = comp.toString(16); - return hex.length == 1 ? '0' + hex : hex; - } // Calculate proportional width and height values when necessary - - - function proportionalSize(element, width, height) { - if (width == null || height == null) { - var box = element.bbox(); - - if (width == null) { - width = box.width / box.height * height; - } else if (height == null) { - height = box.height / box.width * width; - } - } - - return { - width: width, - height: height - }; - } // Delta transform point - - - function deltaTransformPoint(matrix, x, y) { - return { - x: x * matrix.a + y * matrix.c + 0, - y: x * matrix.b + y * matrix.d + 0 - }; - } // Map matrix array to object - - - function arrayToMatrix(a) { - return { - a: a[0], - b: a[1], - c: a[2], - d: a[3], - e: a[4], - f: a[5] - }; - } // Parse matrix if required - - - function parseMatrix(matrix) { - if (!(matrix instanceof SVG.Matrix)) { - matrix = new SVG.Matrix(matrix); - } - - return matrix; - } // Add centre point to transform object - - - function arrayToString(a) { - for (var i = 0, il = a.length, s = ''; i < il; i++) { - s += a[i][0]; - - if (a[i][1] != null) { - s += a[i][1]; - - if (a[i][2] != null) { - s += ' '; - s += a[i][2]; - - if (a[i][3] != null) { - s += ' '; - s += a[i][3]; - s += ' '; - s += a[i][4]; - - if (a[i][5] != null) { - s += ' '; - s += a[i][5]; - s += ' '; - s += a[i][6]; - - if (a[i][7] != null) { - s += ' '; - s += a[i][7]; - } - } - } - } - } - } - - return s + ' '; - } // Deep new id assignment - - - function assignNewId(node) { - // do the same for SVG child nodes as well - for (var i = node.childNodes.length - 1; i >= 0; i--) { - if (node.childNodes[i] instanceof window.SVGElement) { - assignNewId(node.childNodes[i]); - } - } - - return SVG.adopt(node).id(SVG.eid(node.nodeName)); - } // Add more bounding box properties - - - function fullBox(b) { - if (b.x == null) { - b.x = 0; - b.y = 0; - b.width = 0; - b.height = 0; - } - - b.w = b.width; - b.h = b.height; - b.x2 = b.x + b.width; - b.y2 = b.y + b.height; - b.cx = b.x + b.width / 2; - b.cy = b.y + b.height / 2; - return b; - } // Get id from reference string - - - function idFromReference(url) { - var m = (url || '').toString().match(SVG.regex.reference); - if (m) return m[1]; - } // If values like 1e-88 are passed, this is not a valid 32 bit float, - // but in those cases, we are so close to 0 that 0 works well! - - - function float32String(v) { - return Math.abs(v) > 1e-37 ? v : 0; - } // Create matrix array for looping - - - var abcdef = 'abcdef'.split(''); // Add CustomEvent to IE9 and IE10 - - if (typeof window.CustomEvent !== 'function') { - // Code from: https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent - var CustomEventPoly = function CustomEventPoly(event, options) { - options = options || { - bubbles: false, - cancelable: false, - detail: undefined - }; - var e = document.createEvent('CustomEvent'); - e.initCustomEvent(event, options.bubbles, options.cancelable, options.detail); - return e; - }; - - CustomEventPoly.prototype = window.Event.prototype; - SVG.CustomEvent = CustomEventPoly; - } else { - SVG.CustomEvent = window.CustomEvent; - } - - return SVG; - }); - - /*! svg.filter.js - v2.0.2 - 2016-02-24 - * https://github.com/wout/svg.filter.js - * Copyright (c) 2016 Wout Fierens; Licensed MIT */ - (function() { - - // Main filter class - SVG.Filter = SVG.invent({ - create: 'filter', - inherit: SVG.Parent, - extend: { - // Static strings - source: 'SourceGraphic', - sourceAlpha: 'SourceAlpha', - background: 'BackgroundImage', - backgroundAlpha: 'BackgroundAlpha', - fill: 'FillPaint', - stroke: 'StrokePaint', - - autoSetIn: true, - // Custom put method for leaner code - put: function(element, i) { - this.add(element, i); - - if(!element.attr('in') && this.autoSetIn){ - element.attr('in',this.source); - } - if(!element.attr('result')){ - element.attr('result',element); - } - - return element - }, - // Blend effect - blend: function(in1, in2, mode) { - return this.put(new SVG.BlendEffect(in1, in2, mode)) - }, - // ColorMatrix effect - colorMatrix: function(type, values) { - return this.put(new SVG.ColorMatrixEffect(type, values)) - }, - // ConvolveMatrix effect - convolveMatrix: function(matrix) { - return this.put(new SVG.ConvolveMatrixEffect(matrix)) - }, - // ComponentTransfer effect - componentTransfer: function(components) { - return this.put(new SVG.ComponentTransferEffect(components)) - }, - // Composite effect - composite: function(in1, in2, operator) { - return this.put(new SVG.CompositeEffect(in1, in2, operator)) - }, - // Flood effect - flood: function(color, opacity) { - return this.put(new SVG.FloodEffect(color, opacity)) - }, - // Offset effect - offset: function(x, y) { - return this.put(new SVG.OffsetEffect(x,y)) - }, - // Image effect - image: function(src) { - return this.put(new SVG.ImageEffect(src)) - }, - // Merge effect - merge: function() { - //pass the array of arguments to the constructor because we dont know if the user gave us an array as the first arguemnt or wether they listed the effects in the arguments - var args = [undefined]; - for(var i in arguments) args.push(arguments[i]); - return this.put(new (SVG.MergeEffect.bind.apply(SVG.MergeEffect,args))) - }, - // Gaussian Blur effect - gaussianBlur: function(x,y) { - return this.put(new SVG.GaussianBlurEffect(x,y)) - }, - // Morphology effect - morphology: function(operator,radius){ - return this.put(new SVG.MorphologyEffect(operator,radius)) - }, - // DiffuseLighting effect - diffuseLighting: function(surfaceScale,diffuseConstant,kernelUnitLength){ - return this.put(new SVG.DiffuseLightingEffect(surfaceScale,diffuseConstant,kernelUnitLength)) - }, - // DisplacementMap effect - displacementMap: function(in1,in2,scale,xChannelSelector,yChannelSelector){ - return this.put(new SVG.DisplacementMapEffect(in1,in2,scale,xChannelSelector,yChannelSelector)) - }, - // SpecularLighting effect - specularLighting: function(surfaceScale,diffuseConstant,specularExponent,kernelUnitLength){ - return this.put(new SVG.SpecularLightingEffect(surfaceScale,diffuseConstant,specularExponent,kernelUnitLength)) - }, - // Tile effect - tile: function(){ - return this.put(new SVG.TileEffect()); - }, - // Turbulence effect - turbulence: function(baseFrequency,numOctaves,seed,stitchTiles,type){ - return this.put(new SVG.TurbulenceEffect(baseFrequency,numOctaves,seed,stitchTiles,type)) - }, - // Default string value - toString: function() { - return 'url(#' + this.attr('id') + ')' - } - } - }); - - //add .filter function - SVG.extend(SVG.Defs, { - // Define filter - filter: function(block) { - var filter = this.put(new SVG.Filter); - - /* invoke passed block */ - if (typeof block === 'function') - block.call(filter, filter); - - return filter - } - }); - SVG.extend(SVG.Container, { - // Define filter on defs - filter: function(block) { - return this.defs().filter(block) - } - }); - SVG.extend(SVG.Element, SVG.G, SVG.Nested, { - // Create filter element in defs and store reference - filter: function(block) { - this.filterer = block instanceof SVG.Element ? - block : this.doc().filter(block); - - if(this.doc() && this.filterer.doc() !== this.doc()){ - this.doc().defs().add(this.filterer); - } - - this.attr('filter', this.filterer); - - return this.filterer - }, - // Remove filter - unfilter: function(remove) { - /* also remove the filter node */ - if (this.filterer && remove === true) - this.filterer.remove(); - - /* delete reference to filterer */ - delete this.filterer; - - /* remove filter attribute */ - return this.attr('filter', null) - } - }); - - // Create SVG.Effect class - SVG.Effect = SVG.invent({ - create: function(){ - this.constructor.call(this); - }, - inherit: SVG.Element, - extend: { - // Set in attribute - in: function(effect) { - return effect == null? this.parent() && this.parent().select('[result="'+this.attr('in')+'"]').get(0) || this.attr('in') : this.attr('in', effect) - }, - // Named result - result: function(result) { - return result == null? this.attr('result') : this.attr('result',result) - }, - // Stringification - toString: function() { - return this.result() - } - } - }); - - // create class for parent effects like merge - // Inherit from SVG.Parent - SVG.ParentEffect = SVG.invent({ - create: function(){ - this.constructor.call(this); - }, - inherit: SVG.Parent, - extend: { - // Set in attribute - in: function(effect) { - return effect == null? this.parent() && this.parent().select('[result="'+this.attr('in')+'"]').get(0) || this.attr('in') : this.attr('in', effect) - }, - // Named result - result: function(result) { - return result == null? this.attr('result') : this.attr('result',result) - }, - // Stringification - toString: function() { - return this.result() - } - } - }); - - //chaining - var chainingEffects = { - // Blend effect - blend: function(in2, mode) { - return this.parent() && this.parent().blend(this, in2, mode) //pass this as the first input - }, - // ColorMatrix effect - colorMatrix: function(type, values) { - return this.parent() && this.parent().colorMatrix(type, values).in(this) - }, - // ConvolveMatrix effect - convolveMatrix: function(matrix) { - return this.parent() && this.parent().convolveMatrix(matrix).in(this) - }, - // ComponentTransfer effect - componentTransfer: function(components) { - return this.parent() && this.parent().componentTransfer(components).in(this) - }, - // Composite effect - composite: function(in2, operator) { - return this.parent() && this.parent().composite(this, in2, operator) //pass this as the first input - }, - // Flood effect - flood: function(color, opacity) { - return this.parent() && this.parent().flood(color, opacity) //this effect dont have inputs - }, - // Offset effect - offset: function(x, y) { - return this.parent() && this.parent().offset(x,y).in(this) - }, - // Image effect - image: function(src) { - return this.parent() && this.parent().image(src) //this effect dont have inputs - }, - // Merge effect - merge: function() { - return this.parent() && this.parent().merge.apply(this.parent(),[this].concat(arguments)) //pass this as the first argument - }, - // Gaussian Blur effect - gaussianBlur: function(x,y) { - return this.parent() && this.parent().gaussianBlur(x,y).in(this) - }, - // Morphology effect - morphology: function(operator,radius){ - return this.parent() && this.parent().morphology(operator,radius).in(this) - }, - // DiffuseLighting effect - diffuseLighting: function(surfaceScale,diffuseConstant,kernelUnitLength){ - return this.parent() && this.parent().diffuseLighting(surfaceScale,diffuseConstant,kernelUnitLength).in(this) - }, - // DisplacementMap effect - displacementMap: function(in2,scale,xChannelSelector,yChannelSelector){ - return this.parent() && this.parent().displacementMap(this,in2,scale,xChannelSelector,yChannelSelector) //pass this as the first input - }, - // SpecularLighting effect - specularLighting: function(surfaceScale,diffuseConstant,specularExponent,kernelUnitLength){ - return this.parent() && this.parent().specularLighting(surfaceScale,diffuseConstant,specularExponent,kernelUnitLength).in(this) - }, - // Tile effect - tile: function(){ - return this.parent() && this.parent().tile().in(this) - }, - // Turbulence effect - turbulence: function(baseFrequency,numOctaves,seed,stitchTiles,type){ - return this.parent() && this.parent().turbulence(baseFrequency,numOctaves,seed,stitchTiles,type).in(this) - } - }; - SVG.extend(SVG.Effect,chainingEffects); - SVG.extend(SVG.ParentEffect,chainingEffects); - - //crea class for child effects, like MergeNode, FuncR and lights - SVG.ChildEffect = SVG.invent({ - create: function(){ - this.constructor.call(this); - }, - inherit: SVG.Element, - extend: { - in: function(effect){ - this.attr('in',effect); - } - //dont include any "result" functions because these types of nodes dont have them - } - }); - - // Create all different effects - var effects = { - blend: function(in1,in2,mode){ - this.attr({ - in: in1, - in2: in2, - mode: mode || 'normal' - }); - }, - colorMatrix: function(type,values){ - if (type == 'matrix') - values = normaliseMatrix(values); - - this.attr({ - type: type - , values: typeof values == 'undefined' ? null : values - }); - }, - convolveMatrix: function(matrix){ - matrix = normaliseMatrix(matrix); - - this.attr({ - order: Math.sqrt(matrix.split(' ').length) - , kernelMatrix: matrix - }); - }, - composite: function(in1, in2, operator){ - this.attr({ - in: in1, - in2: in2, - operator: operator - }); - }, - flood: function(color,opacity){ - this.attr('flood-color',color); - if(opacity != null) this.attr('flood-opacity',opacity); - }, - offset: function(x,y){ - this.attr({ - dx: x, - dy: y - }); - }, - image: function(src){ - this.attr('href', src, SVG.xlink); - }, - displacementMap: function(in1,in2,scale,xChannelSelector,yChannelSelector){ - this.attr({ - in: in1, - in2: in2, - scale: scale, - xChannelSelector: xChannelSelector, - yChannelSelector: yChannelSelector - }); - }, - gaussianBlur: function(x,y){ - if(x != null || y != null) - this.attr('stdDeviation', listString(Array.prototype.slice.call(arguments))); - else - this.attr('stdDeviation', '0 0'); - }, - morphology: function(operator,radius){ - this.attr({ - operator: operator, - radius: radius - }); - }, - tile: function(){ - - }, - turbulence: function(baseFrequency,numOctaves,seed,stitchTiles,type){ - this.attr({ - numOctaves: numOctaves, - seed: seed, - stitchTiles: stitchTiles, - baseFrequency: baseFrequency, - type: type - }); - } - }; - - // Create all parent effects - var parentEffects = { - merge: function(){ - var children; - - //test to see if we have a set - if(arguments[0] instanceof SVG.Set){ - var that = this; - arguments[0].each(function(i){ - if(this instanceof SVG.MergeNode) - that.put(this); - else if(this instanceof SVG.Effect || this instanceof SVG.ParentEffect) - that.put(new SVG.MergeNode(this)); - }); - } - else { - //if the first argument is an array use it - if(Array.isArray(arguments[0])) - children = arguments[0]; - else - children = arguments; - - for(var i = 0; i < children.length; i++){ - if(children[i] instanceof SVG.MergeNode){ - this.put(children[i]); - } - else this.put(new SVG.MergeNode(children[i])); - } - } - }, - componentTransfer: function(compontents){ - /* create rgb set */ - this.rgb = new SVG.Set - - /* create components */ - ;(['r', 'g', 'b', 'a']).forEach(function(c) { - /* create component */ - this[c] = new SVG['Func' + c.toUpperCase()]('identity'); - - /* store component in set */ - this.rgb.add(this[c]); - - /* add component node */ - this.node.appendChild(this[c].node); - }.bind(this)); //lost context in foreach - - /* set components */ - if (compontents) { - if (compontents.rgb) { - (['r', 'g', 'b']).forEach(function(c) { - this[c].attr(compontents.rgb); - }.bind(this)); - - delete compontents.rgb; - } - - /* set individual components */ - for (var c in compontents) - this[c].attr(compontents[c]); - } - }, - diffuseLighting: function(surfaceScale,diffuseConstant,kernelUnitLength){ - this.attr({ - surfaceScale: surfaceScale, - diffuseConstant: diffuseConstant, - kernelUnitLength: kernelUnitLength - }); - }, - specularLighting: function(surfaceScale,diffuseConstant,specularExponent,kernelUnitLength){ - this.attr({ - surfaceScale: surfaceScale, - diffuseConstant: diffuseConstant, - specularExponent: specularExponent, - kernelUnitLength: kernelUnitLength - }); - }, - }; - - // Create child effects like PointLight and MergeNode - var childEffects = { - distantLight: function(azimuth, elevation){ - this.attr({ - azimuth: azimuth, - elevation: elevation - }); - }, - pointLight: function(x,y,z){ - this.attr({ - x: x, - y: y, - z: z - }); - }, - spotLight: function(x,y,z,pointsAtX,pointsAtY,pointsAtZ){ - this.attr({ - x: x, - y: y, - z: z, - pointsAtX: pointsAtX, - pointsAtY: pointsAtY, - pointsAtZ: pointsAtZ - }); - }, - mergeNode: function(in1){ - this.attr('in',in1); - } - } - - // Create compontent functions - ;(['r', 'g', 'b', 'a']).forEach(function(c) { - /* create class */ - childEffects['Func' + c.toUpperCase()] = function(type) { - this.attr('type',type); - - // take diffent arguments based on the type - switch(type){ - case 'table': - this.attr('tableValues',arguments[1]); - break - case 'linear': - this.attr('slope',arguments[1]); - this.attr('intercept',arguments[2]); - break - case 'gamma': - this.attr('amplitude',arguments[1]); - this.attr('exponent',arguments[2]); - this.attr('offset',arguments[2]); - break - } - }; - }); - - //create effects - foreach(effects,function(effect,i){ - - /* capitalize name */ - var name = i.charAt(0).toUpperCase() + i.slice(1); - var proto = {}; - - /* create class */ - SVG[name + 'Effect'] = SVG.invent({ - create: function() { - //call super - this.constructor.call(this, SVG.create('fe' + name)); - - //call constructor for this effect - effect.apply(this,arguments); - - //set the result - this.result(this.attr('id') + 'Out'); - }, - inherit: SVG.Effect, - extend: proto - }); - }); - - //create parent effects - foreach(parentEffects,function(effect,i){ - - /* capitalize name */ - var name = i.charAt(0).toUpperCase() + i.slice(1); - var proto = {}; - - /* create class */ - SVG[name + 'Effect'] = SVG.invent({ - create: function() { - //call super - this.constructor.call(this, SVG.create('fe' + name)); - - //call constructor for this effect - effect.apply(this,arguments); - - //set the result - this.result(this.attr('id') + 'Out'); - }, - inherit: SVG.ParentEffect, - extend: proto - }); - }); - - //create child effects - foreach(childEffects,function(effect,i){ - - /* capitalize name */ - var name = i.charAt(0).toUpperCase() + i.slice(1); - var proto = {}; - - /* create class */ - SVG[name] = SVG.invent({ - create: function() { - //call super - this.constructor.call(this, SVG.create('fe' + name)); - - //call constructor for this effect - effect.apply(this,arguments); - }, - inherit: SVG.ChildEffect, - extend: proto - }); - }); - - // Effect-specific extensions - SVG.extend(SVG.MergeEffect,{ - in: function(effect){ - if(effect instanceof SVG.MergeNode) - this.add(effect,0); - else - this.add(new SVG.MergeNode(effect),0); - - return this - } - }); - SVG.extend(SVG.CompositeEffect,SVG.BlendEffect,SVG.DisplacementMapEffect,{ - in2: function(effect){ - return effect == null? this.parent() && this.parent().select('[result="'+this.attr('in2')+'"]').get(0) || this.attr('in2') : this.attr('in2', effect) - } - }); - - // Presets - SVG.filter = { - sepiatone: [ .343, .669, .119, 0, 0 - , .249, .626, .130, 0, 0 - , .172, .334, .111, 0, 0 - , .000, .000, .000, 1, 0 ] - }; - - // Helpers - function normaliseMatrix(matrix) { - /* convert possible array value to string */ - if (Array.isArray(matrix)) - matrix = new SVG.Array(matrix); - - /* ensure there are no leading, tailing or double spaces */ - return matrix.toString().replace(/^\s+/, '').replace(/\s+$/, '').replace(/\s+/g, ' ') - } - - function listString(list) { - if (!Array.isArray(list)) - return list - - for (var i = 0, l = list.length, s = []; i < l; i++) - s.push(list[i]); - - return s.join(' ') - } - - function foreach(){ //loops through mutiple objects - var fn = function(){}; - if(typeof arguments[arguments.length-1] == 'function'){ - fn = arguments[arguments.length-1]; - Array.prototype.splice.call(arguments,arguments.length-1,1); - } - for(var k in arguments){ - for(var i in arguments[k]){ - fn(arguments[k][i],i,arguments[k]); - } - } - } - - }).call(undefined); - - (function() { - - SVG.extend(SVG.PathArray, { - morph: function(array) { - - var startArr = this.value - , destArr = this.parse(array); - - var startOffsetM = 0 - , destOffsetM = 0; - - var startOffsetNextM = false - , destOffsetNextM = false; - - while(true){ - // stop if there is no M anymore - if(startOffsetM === false && destOffsetM === false) break - - // find the next M in path array - startOffsetNextM = findNextM(startArr, startOffsetM === false ? false : startOffsetM+1); - destOffsetNextM = findNextM( destArr, destOffsetM === false ? false : destOffsetM+1); - - // We have to add one M to the startArray - if(startOffsetM === false){ - var bbox = new SVG.PathArray(result.start).bbox(); - - // when the last block had no bounding box we simply take the first M we got - if(bbox.height == 0 || bbox.width == 0){ - startOffsetM = startArr.push(startArr[0]) - 1; - }else { - // we take the middle of the bbox instead when we got one - startOffsetM = startArr.push( ['M', bbox.x + bbox.width/2, bbox.y + bbox.height/2 ] ) - 1; - } - } - - // We have to add one M to the destArray - if( destOffsetM === false){ - var bbox = new SVG.PathArray(result.dest).bbox(); - - if(bbox.height == 0 || bbox.width == 0){ - destOffsetM = destArr.push(destArr[0]) - 1; - }else { - destOffsetM = destArr.push( ['M', bbox.x + bbox.width/2, bbox.y + bbox.height/2 ] ) - 1; - } - } - - // handle block from M to next M - var result = handleBlock(startArr, startOffsetM, startOffsetNextM, destArr, destOffsetM, destOffsetNextM); - - // update the arrays to their new values - startArr = startArr.slice(0, startOffsetM).concat(result.start, startOffsetNextM === false ? [] : startArr.slice(startOffsetNextM)); - destArr = destArr.slice(0, destOffsetM).concat(result.dest , destOffsetNextM === false ? [] : destArr.slice( destOffsetNextM)); - - // update offsets - startOffsetM = startOffsetNextM === false ? false : startOffsetM + result.start.length; - destOffsetM = destOffsetNextM === false ? false : destOffsetM + result.dest.length; - - } - - // copy back arrays - this.value = startArr; - this.destination = new SVG.PathArray(); - this.destination.value = destArr; - - return this - } - }); - - - - // sorry for the long declaration - // slices out one block (from M to M) and syncronize it so the types and length match - function handleBlock(startArr, startOffsetM, startOffsetNextM, destArr, destOffsetM, destOffsetNextM, undefined$1){ - - // slice out the block we need - var startArrTemp = startArr.slice(startOffsetM, startOffsetNextM || undefined$1) - , destArrTemp = destArr.slice( destOffsetM, destOffsetNextM || undefined$1); - - var i = 0 - , posStart = {pos:[0,0], start:[0,0]} - , posDest = {pos:[0,0], start:[0,0]}; - - do{ - - // convert shorthand types to long form - startArrTemp[i] = simplyfy.call(posStart, startArrTemp[i]); - destArrTemp[i] = simplyfy.call(posDest , destArrTemp[i]); - - // check if both shape types match - // 2 elliptical arc curve commands ('A'), are considered different if the - // flags (large-arc-flag, sweep-flag) don't match - if(startArrTemp[i][0] != destArrTemp[i][0] || startArrTemp[i][0] == 'M' || - (startArrTemp[i][0] == 'A' && - (startArrTemp[i][4] != destArrTemp[i][4] || startArrTemp[i][5] != destArrTemp[i][5]) - ) - ) { - - // if not, convert shapes to beziere - Array.prototype.splice.apply(startArrTemp, [i, 1].concat(toBeziere.call(posStart, startArrTemp[i]))); - Array.prototype.splice.apply(destArrTemp, [i, 1].concat(toBeziere.call(posDest, destArrTemp[i]))); - - } else { - - // only update positions otherwise - startArrTemp[i] = setPosAndReflection.call(posStart, startArrTemp[i]); - destArrTemp[i] = setPosAndReflection.call(posDest , destArrTemp[i]); - - } - - // we are at the end at both arrays. stop here - if(++i == startArrTemp.length && i == destArrTemp.length) break - - // destArray is longer. Add one element - if(i == startArrTemp.length){ - startArrTemp.push([ - 'C', - posStart.pos[0], - posStart.pos[1], - posStart.pos[0], - posStart.pos[1], - posStart.pos[0], - posStart.pos[1], - ]); - } - - // startArr is longer. Add one element - if(i == destArrTemp.length){ - destArrTemp.push([ - 'C', - posDest.pos[0], - posDest.pos[1], - posDest.pos[0], - posDest.pos[1], - posDest.pos[0], - posDest.pos[1] - ]); - } - - - }while(true) - - // return the updated block - return {start:startArrTemp, dest:destArrTemp} - } - - // converts shorthand types to long form - function simplyfy(val){ - - switch(val[0]){ - case 'z': // shorthand line to start - case 'Z': - val[0] = 'L'; - val[1] = this.start[0]; - val[2] = this.start[1]; - break - case 'H': // shorthand horizontal line - val[0] = 'L'; - val[2] = this.pos[1]; - break - case 'V': // shorthand vertical line - val[0] = 'L'; - val[2] = val[1]; - val[1] = this.pos[0]; - break - case 'T': // shorthand quadratic beziere - val[0] = 'Q'; - val[3] = val[1]; - val[4] = val[2]; - val[1] = this.reflection[1]; - val[2] = this.reflection[0]; - break - case 'S': // shorthand cubic beziere - val[0] = 'C'; - val[6] = val[4]; - val[5] = val[3]; - val[4] = val[2]; - val[3] = val[1]; - val[2] = this.reflection[1]; - val[1] = this.reflection[0]; - break - } - - return val - - } - - // updates reflection point and current position - function setPosAndReflection(val){ - - var len = val.length; - - this.pos = [ val[len-2], val[len-1] ]; - - if('SCQT'.indexOf(val[0]) != -1) - this.reflection = [ 2 * this.pos[0] - val[len-4], 2 * this.pos[1] - val[len-3] ]; - - return val - } - - // converts all types to cubic beziere - function toBeziere(val){ - var retVal = [val]; - - switch(val[0]){ - case 'M': // special handling for M - this.pos = this.start = [val[1], val[2]]; - return retVal - case 'L': - val[5] = val[3] = val[1]; - val[6] = val[4] = val[2]; - val[1] = this.pos[0]; - val[2] = this.pos[1]; - break - case 'Q': - val[6] = val[4]; - val[5] = val[3]; - val[4] = val[4] * 1/3 + val[2] * 2/3; - val[3] = val[3] * 1/3 + val[1] * 2/3; - val[2] = this.pos[1] * 1/3 + val[2] * 2/3; - val[1] = this.pos[0] * 1/3 + val[1] * 2/3; - break - case 'A': - retVal = arcToBeziere(this.pos, val); - val = retVal[0]; - break - } - - val[0] = 'C'; - this.pos = [val[5], val[6]]; - this.reflection = [2 * val[5] - val[3], 2 * val[6] - val[4]]; - - return retVal - - } - - // finds the next position of type M - function findNextM(arr, offset){ - - if(offset === false) return false - - for(var i = offset, len = arr.length;i < len;++i){ - - if(arr[i][0] == 'M') return i - - } - - return false - } - - - - // Convert an arc segment into equivalent cubic Bezier curves - // Depending on the arc, up to 4 curves might be used to represent it since a - // curve gives a good approximation for only a quarter of an ellipse - // The curves are returned as an array of SVG curve commands: - // [ ['C', x1, y1, x2, y2, x, y] ... ] - function arcToBeziere(pos, val) { - // Parameters extraction, handle out-of-range parameters as specified in the SVG spec - // See: https://www.w3.org/TR/SVG11/implnote.html#ArcOutOfRangeParameters - var rx = Math.abs(val[1]), ry = Math.abs(val[2]), xAxisRotation = val[3] % 360 - , largeArcFlag = val[4], sweepFlag = val[5], x = val[6], y = val[7] - , A = new SVG.Point(pos), B = new SVG.Point(x, y) - , primedCoord, lambda, mat, k, c, cSquare, t, O, OA, OB, tetaStart, tetaEnd - , deltaTeta, nbSectors, f, arcSegPoints, angle, sinAngle, cosAngle, pt, i, il - , retVal = [], x1, y1, x2, y2; - - // Ensure radii are non-zero - if(rx === 0 || ry === 0 || (A.x === B.x && A.y === B.y)) { - // treat this arc as a straight line segment - return [['C', A.x, A.y, B.x, B.y, B.x, B.y]] - } - - // Ensure radii are large enough using the algorithm provided in the SVG spec - // See: https://www.w3.org/TR/SVG11/implnote.html#ArcCorrectionOutOfRangeRadii - primedCoord = new SVG.Point((A.x-B.x)/2, (A.y-B.y)/2).transform(new SVG.Matrix().rotate(xAxisRotation)); - lambda = (primedCoord.x * primedCoord.x) / (rx * rx) + (primedCoord.y * primedCoord.y) / (ry * ry); - if(lambda > 1) { - lambda = Math.sqrt(lambda); - rx = lambda*rx; - ry = lambda*ry; - } - - // To simplify calculations, we make the arc part of a unit circle (rayon is 1) instead of an ellipse - mat = new SVG.Matrix().rotate(xAxisRotation).scale(1/rx, 1/ry).rotate(-xAxisRotation); - A = A.transform(mat); - B = B.transform(mat); - - // Calculate the horizontal and vertical distance between the initial and final point of the arc - k = [B.x-A.x, B.y-A.y]; - - // Find the length of the chord formed by A and B - cSquare = k[0]*k[0] + k[1]*k[1]; - c = Math.sqrt(cSquare); - - // Calculate the ratios of the horizontal and vertical distance on the length of the chord - k[0] /= c; - k[1] /= c; - - // Calculate the distance between the circle center and the chord midpoint - // using this formula: t = sqrt(r^2 - c^2 / 4) - // where t is the distance between the cirle center and the chord midpoint, - // r is the rayon of the circle and c is the chord length - // From: http://www.ajdesigner.com/phpcircle/circle_segment_chord_t.php - // Because of the imprecision of floating point numbers, cSquare might end - // up being slightly above 4 which would result in a negative radicand - // To prevent that, a test is made before computing the square root - t = (cSquare < 4) ? Math.sqrt(1 - cSquare/4) : 0; - - // For most situations, there are actually two different ellipses that - // satisfy the constraints imposed by the points A and B, the radii rx and ry, - // and the xAxisRotation - // When the flags largeArcFlag and sweepFlag are equal, it means that the - // second ellipse is used as a solution - // See: https://www.w3.org/TR/SVG/paths.html#PathDataEllipticalArcCommands - if(largeArcFlag === sweepFlag) { - t *= -1; - } - - // Calculate the coordinates of the center of the circle from the midpoint of the chord - // This is done by multiplying the ratios calculated previously by the distance between - // the circle center and the chord midpoint and using these values to go from the midpoint - // to the center of the circle - // The negative of the vertical distance ratio is used to modify the x coordinate while - // the horizontal distance ratio is used to modify the y coordinate - // That is because the center of the circle is perpendicular to the chord and perpendicular - // lines are negative reciprocals - O = new SVG.Point((B.x+A.x)/2 + t*-k[1], (B.y+A.y)/2 + t*k[0]); - // Move the center of the circle at the origin - OA = new SVG.Point(A.x-O.x, A.y-O.y); - OB = new SVG.Point(B.x-O.x, B.y-O.y); - - // Calculate the start and end angle - tetaStart = Math.acos(OA.x/Math.sqrt(OA.x*OA.x + OA.y*OA.y)); - if (OA.y < 0) { - tetaStart *= -1; - } - tetaEnd = Math.acos(OB.x/Math.sqrt(OB.x*OB.x + OB.y*OB.y)); - if (OB.y < 0) { - tetaEnd *= -1; - } - - // If sweep-flag is '1', then the arc will be drawn in a "positive-angle" direction, - // make sure that the end angle is above the start angle - if (sweepFlag && tetaStart > tetaEnd) { - tetaEnd += 2*Math.PI; - } - // If sweep-flag is '0', then the arc will be drawn in a "negative-angle" direction, - // make sure that the end angle is below the start angle - if (!sweepFlag && tetaStart < tetaEnd) { - tetaEnd -= 2*Math.PI; - } - - // Find the number of Bezier curves that are required to represent the arc - // A cubic Bezier curve gives a good enough approximation when representing at most a quarter of a circle - nbSectors = Math.ceil(Math.abs(tetaStart-tetaEnd) * 2/Math.PI); - - // Calculate the coordinates of the points of all the Bezier curves required to represent the arc - // For an in-depth explanation of this part see: http://pomax.github.io/bezierinfo/#circles_cubic - arcSegPoints = []; - angle = tetaStart; - deltaTeta = (tetaEnd-tetaStart)/nbSectors; - f = 4*Math.tan(deltaTeta/4)/3; - for (i = 0; i <= nbSectors; i++) { // The <= is because a Bezier curve have a start and a endpoint - cosAngle = Math.cos(angle); - sinAngle = Math.sin(angle); - - pt = new SVG.Point(O.x+cosAngle, O.y+sinAngle); - arcSegPoints[i] = [new SVG.Point(pt.x+f*sinAngle, pt.y-f*cosAngle), pt, new SVG.Point(pt.x-f*sinAngle, pt.y+f*cosAngle)]; - - angle += deltaTeta; - } - - // Remove the first control point of the first segment point and remove the second control point of the last segment point - // These two control points are not used in the approximation of the arc, that is why they are removed - arcSegPoints[0][0] = arcSegPoints[0][1].clone(); - arcSegPoints[arcSegPoints.length-1][2] = arcSegPoints[arcSegPoints.length-1][1].clone(); - - // Revert the transformation that was applied to make the arc part of a unit circle instead of an ellipse - mat = new SVG.Matrix().rotate(xAxisRotation).scale(rx, ry).rotate(-xAxisRotation); - for (i = 0, il = arcSegPoints.length; i < il; i++) { - arcSegPoints[i][0] = arcSegPoints[i][0].transform(mat); - arcSegPoints[i][1] = arcSegPoints[i][1].transform(mat); - arcSegPoints[i][2] = arcSegPoints[i][2].transform(mat); - } - - - // Convert the segments points to SVG curve commands - for (i = 1, il = arcSegPoints.length; i < il; i++) { - pt = arcSegPoints[i-1][2]; - x1 = pt.x; - y1 = pt.y; - - pt = arcSegPoints[i][0]; - x2 = pt.x; - y2 = pt.y; - - pt = arcSegPoints[i][1]; - x = pt.x; - y = pt.y; - - retVal.push(['C', x1, y1, x2, y2, x, y]); - } - - return retVal - } - }()); - - /*! svg.draggable.js - v2.2.2 - 2019-01-08 - * https://github.com/svgdotjs/svg.draggable.js - * Copyright (c) 2019 Wout Fierens; Licensed MIT */ - (function() { - - // creates handler, saves it - function DragHandler(el){ - el.remember('_draggable', this); - this.el = el; - } - - - // Sets new parameter, starts dragging - DragHandler.prototype.init = function(constraint, val){ - var _this = this; - this.constraint = constraint; - this.value = val; - this.el.on('mousedown.drag', function(e){ _this.start(e); }); - this.el.on('touchstart.drag', function(e){ _this.start(e); }); - }; - - // transforms one point from screen to user coords - DragHandler.prototype.transformPoint = function(event, offset){ - event = event || window.event; - var touches = event.changedTouches && event.changedTouches[0] || event; - this.p.x = touches.clientX - (offset || 0); - this.p.y = touches.clientY; - return this.p.matrixTransform(this.m) - }; - - // gets elements bounding box with special handling of groups, nested and use - DragHandler.prototype.getBBox = function(){ - - var box = this.el.bbox(); - - if(this.el instanceof SVG.Nested) box = this.el.rbox(); - - if (this.el instanceof SVG.G || this.el instanceof SVG.Use || this.el instanceof SVG.Nested) { - box.x = this.el.x(); - box.y = this.el.y(); - } - - return box - }; - - // start dragging - DragHandler.prototype.start = function(e){ - - // check for left button - if(e.type == 'click'|| e.type == 'mousedown' || e.type == 'mousemove'){ - if((e.which || e.buttons) != 1){ - return - } - } - - var _this = this; - - // fire beforedrag event - this.el.fire('beforedrag', { event: e, handler: this }); - if(this.el.event().defaultPrevented) return; - - // prevent browser drag behavior as soon as possible - e.preventDefault(); - - // prevent propagation to a parent that might also have dragging enabled - e.stopPropagation(); - - // search for parent on the fly to make sure we can call - // draggable() even when element is not in the dom currently - this.parent = this.parent || this.el.parent(SVG.Nested) || this.el.parent(SVG.Doc); - this.p = this.parent.node.createSVGPoint(); - - // save current transformation matrix - this.m = this.el.node.getScreenCTM().inverse(); - - var box = this.getBBox(); - - var anchorOffset; - - // fix text-anchor in text-element (#37) - if(this.el instanceof SVG.Text){ - anchorOffset = this.el.node.getComputedTextLength(); - - switch(this.el.attr('text-anchor')){ - case 'middle': - anchorOffset /= 2; - break - case 'start': - anchorOffset = 0; - break; - } - } - - this.startPoints = { - // We take absolute coordinates since we are just using a delta here - point: this.transformPoint(e, anchorOffset), - box: box, - transform: this.el.transform() - }; - - // add drag and end events to window - SVG.on(window, 'mousemove.drag', function(e){ _this.drag(e); }); - SVG.on(window, 'touchmove.drag', function(e){ _this.drag(e); }); - SVG.on(window, 'mouseup.drag', function(e){ _this.end(e); }); - SVG.on(window, 'touchend.drag', function(e){ _this.end(e); }); - - // fire dragstart event - this.el.fire('dragstart', {event: e, p: this.startPoints.point, m: this.m, handler: this}); - }; - - // while dragging - DragHandler.prototype.drag = function(e){ - - var box = this.getBBox() - , p = this.transformPoint(e) - , x = this.startPoints.box.x + p.x - this.startPoints.point.x - , y = this.startPoints.box.y + p.y - this.startPoints.point.y - , c = this.constraint - , gx = p.x - this.startPoints.point.x - , gy = p.y - this.startPoints.point.y; - - this.el.fire('dragmove', { - event: e - , p: p - , m: this.m - , handler: this - }); - - if(this.el.event().defaultPrevented) return p - - // move the element to its new position, if possible by constraint - if (typeof c == 'function') { - - var coord = c.call(this.el, x, y, this.m); - - // bool, just show us if movement is allowed or not - if (typeof coord == 'boolean') { - coord = { - x: coord, - y: coord - }; - } - - // if true, we just move. If !false its a number and we move it there - if (coord.x === true) { - this.el.x(x); - } else if (coord.x !== false) { - this.el.x(coord.x); - } - - if (coord.y === true) { - this.el.y(y); - } else if (coord.y !== false) { - this.el.y(coord.y); - } - - } else if (typeof c == 'object') { - - // keep element within constrained box - if (c.minX != null && x < c.minX) { - x = c.minX; - gx = x - this.startPoints.box.x; - } else if (c.maxX != null && x > c.maxX - box.width) { - x = c.maxX - box.width; - gx = x - this.startPoints.box.x; - } if (c.minY != null && y < c.minY) { - y = c.minY; - gy = y - this.startPoints.box.y; - } else if (c.maxY != null && y > c.maxY - box.height) { - y = c.maxY - box.height; - gy = y - this.startPoints.box.y; - } - - if (c.snapToGrid != null) { - x = x - (x % c.snapToGrid); - y = y - (y % c.snapToGrid); - gx = gx - (gx % c.snapToGrid); - gy = gy - (gy % c.snapToGrid); - } - - if(this.el instanceof SVG.G) - this.el.matrix(this.startPoints.transform).transform({x:gx, y: gy}, true); - else - this.el.move(x, y); - } - - // so we can use it in the end-method, too - return p - }; - - DragHandler.prototype.end = function(e){ - - // final drag - var p = this.drag(e); - - // fire dragend event - this.el.fire('dragend', { event: e, p: p, m: this.m, handler: this }); - - // unbind events - SVG.off(window, 'mousemove.drag'); - SVG.off(window, 'touchmove.drag'); - SVG.off(window, 'mouseup.drag'); - SVG.off(window, 'touchend.drag'); - - }; - - SVG.extend(SVG.Element, { - // Make element draggable - // Constraint might be an object (as described in readme.md) or a function in the form "function (x, y)" that gets called before every move. - // The function can return a boolean or an object of the form {x, y}, to which the element will be moved. "False" skips moving, true moves to raw x, y. - draggable: function(value, constraint) { - - // Check the parameters and reassign if needed - if (typeof value == 'function' || typeof value == 'object') { - constraint = value; - value = true; - } - - var dragHandler = this.remember('_draggable') || new DragHandler(this); - - // When no parameter is given, value is true - value = typeof value === 'undefined' ? true : value; - - if(value) dragHandler.init(constraint || {}, value); - else { - this.off('mousedown.drag'); - this.off('touchstart.drag'); - } - - return this - } - - }); - - }).call(undefined); - - (function() { - - function SelectHandler(el) { - - this.el = el; - el.remember('_selectHandler', this); - this.pointSelection = {isSelected: false}; - this.rectSelection = {isSelected: false}; - - // helper list with position settings of each type of point - this.pointsList = { - lt: [ 0, 0 ], - rt: [ 'width', 0 ], - rb: [ 'width', 'height' ], - lb: [ 0, 'height' ], - t: [ 'width', 0 ], - r: [ 'width', 'height' ], - b: [ 'width', 'height' ], - l: [ 0, 'height' ] - }; - - // helper function to get point coordinates based on settings above and an object (bbox in our case) - this.pointCoord = function (setting, object, isPointCentered) { - var coord = typeof setting !== 'string' ? setting : object[setting]; - // Top, bottom, right and left points are placed in the center of element width/height - return isPointCentered ? coord / 2 : coord - }; - - this.pointCoords = function (point, object) { - var settings = this.pointsList[point]; - - return { - x: this.pointCoord(settings[0], object, (point === 't' || point === 'b')), - y: this.pointCoord(settings[1], object, (point === 'r' || point === 'l')) - } - }; - } - - SelectHandler.prototype.init = function (value, options) { - - var bbox = this.el.bbox(); - this.options = {}; - - // store defaults list of points in order to verify users config - var points = this.el.selectize.defaults.points; - - // Merging the defaults and the options-object together - for (var i in this.el.selectize.defaults) { - this.options[i] = this.el.selectize.defaults[i]; - if (options[i] !== undefined) { - this.options[i] = options[i]; - } - } - - // prepare & validate list of points to be added (or excluded) - var pointsLists = ['points', 'pointsExclude']; - - for (var i in pointsLists) { - var option = this.options[pointsLists[i]]; - - if (typeof option === 'string') { - if (option.length > 0) { - // if set as comma separated string list => convert it into an array - option = option.split(/\s*,\s*/i); - } else { - option = []; - } - } else if (typeof option === 'boolean' && pointsLists[i] === 'points') { - // this is not needed, but let's have it for legacy support - option = option ? points : []; - } - - this.options[pointsLists[i]] = option; - } - - // intersect correct all points options with users config (exclude unwanted points) - // ES5 -> NO arrow functions nor Array.includes() - this.options.points = [ points, this.options.points ].reduce( - function (a, b) { - return a.filter( - function (c) { - return b.indexOf(c) > -1; - } - ) - } - ); - - // exclude pointsExclude, if wanted - this.options.points = [ this.options.points, this.options.pointsExclude ].reduce( - function (a, b) { - return a.filter( - function (c) { - return b.indexOf(c) < 0; - } - ) - } - ); - - this.parent = this.el.parent(); - this.nested = (this.nested || this.parent.group()); - this.nested.matrix(new SVG.Matrix(this.el).translate(bbox.x, bbox.y)); - - // When deepSelect is enabled and the element is a line/polyline/polygon, draw only points for moving - if (this.options.deepSelect && ['line', 'polyline', 'polygon'].indexOf(this.el.type) !== -1) { - this.selectPoints(value); - } else { - this.selectRect(value); - } - - this.observe(); - this.cleanup(); - - }; - - SelectHandler.prototype.selectPoints = function (value) { - - this.pointSelection.isSelected = value; - - // When set is already there we dont have to create one - if (this.pointSelection.set) { - return this; - } - - // Create our set of elements - this.pointSelection.set = this.parent.set(); - // draw the points and mark the element as selected - this.drawPoints(); - - return this; - - }; - - // create the point-array which contains the 2 points of a line or simply the points-array of polyline/polygon - SelectHandler.prototype.getPointArray = function () { - var bbox = this.el.bbox(); - - return this.el.array().valueOf().map(function (el) { - return [el[0] - bbox.x, el[1] - bbox.y]; - }); - }; - - // Draws a points - SelectHandler.prototype.drawPoints = function () { - - var _this = this, array = this.getPointArray(); - - // go through the array of points - for (var i = 0, len = array.length; i < len; ++i) { - - var curriedEvent = (function (k) { - return function (ev) { - ev = ev || window.event; - ev.preventDefault ? ev.preventDefault() : ev.returnValue = false; - ev.stopPropagation(); - - var x = ev.pageX || ev.touches[0].pageX; - var y = ev.pageY || ev.touches[0].pageY; - _this.el.fire('point', {x: x, y: y, i: k, event: ev}); - }; - })(i); - - // add every point to the set - // add css-classes and a touchstart-event which fires our event for moving points - var point = this.drawPoint(array[i][0], array[i][1]) - .addClass(this.options.classPoints) - .addClass(this.options.classPoints + '_point') - .on('touchstart', curriedEvent) - .on('mousedown', curriedEvent); - this.pointSelection.set.add(point); - } - }; - - // The function to draw single point - SelectHandler.prototype.drawPoint = function (cx, cy) { - var pointType = this.options.pointType; - - switch (pointType) { - case 'circle': - return this.drawCircle(cx, cy); - case 'rect': - return this.drawRect(cx, cy); - default: - if (typeof pointType === 'function') { - return pointType.call(this, cx, cy); - } - - throw new Error('Unknown ' + pointType + ' point type!'); - } - }; - - // The function to draw the circle point - SelectHandler.prototype.drawCircle = function (cx, cy) { - return this.nested.circle(this.options.pointSize) - .center(cx, cy); - }; - - // The function to draw the rect point - SelectHandler.prototype.drawRect = function (cx, cy) { - return this.nested.rect(this.options.pointSize, this.options.pointSize) - .center(cx, cy); - }; - - // every time a point is moved, we have to update the positions of our point - SelectHandler.prototype.updatePointSelection = function () { - var array = this.getPointArray(); - - this.pointSelection.set.each(function (i) { - if (this.cx() === array[i][0] && this.cy() === array[i][1]) { - return; - } - this.center(array[i][0], array[i][1]); - }); - }; - - SelectHandler.prototype.updateRectSelection = function () { - var _this = this, bbox = this.el.bbox(); - - this.rectSelection.set.get(0).attr({ - width: bbox.width, - height: bbox.height - }); - - // set.get(1) is always in the upper left corner. no need to move it - if (this.options.points.length) { - this.options.points.map(function (point, index) { - var coords = _this.pointCoords(point, bbox); - - _this.rectSelection.set.get(index + 1).center(coords.x, coords.y); - }); - } - - if (this.options.rotationPoint) { - var length = this.rectSelection.set.length(); - - this.rectSelection.set.get(length - 1).center(bbox.width / 2, 20); - } - }; - - SelectHandler.prototype.selectRect = function (value) { - - var _this = this, bbox = this.el.bbox(); - - this.rectSelection.isSelected = value; - - // when set is already p - this.rectSelection.set = this.rectSelection.set || this.parent.set(); - - // helperFunction to create a mouse-down function which triggers the event specified in `eventName` - function getMoseDownFunc(eventName) { - return function (ev) { - ev = ev || window.event; - ev.preventDefault ? ev.preventDefault() : ev.returnValue = false; - ev.stopPropagation(); - - var x = ev.pageX || ev.touches[0].pageX; - var y = ev.pageY || ev.touches[0].pageY; - _this.el.fire(eventName, {x: x, y: y, event: ev}); - }; - } - - // create the selection-rectangle and add the css-class - if (!this.rectSelection.set.get(0)) { - this.rectSelection.set.add(this.nested.rect(bbox.width, bbox.height).addClass(this.options.classRect)); - } - - // Draw Points at the edges, if enabled - if (this.options.points.length && this.rectSelection.set.length() < 2) { - var ename ="touchstart", mname = "mousedown"; - - this.options.points.map(function (point, index) { - var coords = _this.pointCoords(point, bbox); - - var pointElement = _this.drawPoint(coords.x, coords.y) - .attr('class', _this.options.classPoints + '_' + point) - .on(mname, getMoseDownFunc(point)) - .on(ename, getMoseDownFunc(point)); - _this.rectSelection.set.add(pointElement); - }); - - this.rectSelection.set.each(function () { - this.addClass(_this.options.classPoints); - }); - } - - // draw rotationPint, if enabled - if (this.options.rotationPoint && ((this.options.points && !this.rectSelection.set.get(9)) || (!this.options.points && !this.rectSelection.set.get(1)))) { - - var curriedEvent = function (ev) { - ev = ev || window.event; - ev.preventDefault ? ev.preventDefault() : ev.returnValue = false; - ev.stopPropagation(); - - var x = ev.pageX || ev.touches[0].pageX; - var y = ev.pageY || ev.touches[0].pageY; - _this.el.fire('rot', {x: x, y: y, event: ev}); - }; - - var pointElement = this.drawPoint(bbox.width / 2, 20) - .attr('class', this.options.classPoints + '_rot') - .on("touchstart", curriedEvent) - .on("mousedown", curriedEvent); - this.rectSelection.set.add(pointElement); - } - - }; - - SelectHandler.prototype.handler = function () { - - var bbox = this.el.bbox(); - this.nested.matrix(new SVG.Matrix(this.el).translate(bbox.x, bbox.y)); - - if (this.rectSelection.isSelected) { - this.updateRectSelection(); - } - - if (this.pointSelection.isSelected) { - this.updatePointSelection(); - } - - }; - - SelectHandler.prototype.observe = function () { - var _this = this; - - if (MutationObserver) { - if (this.rectSelection.isSelected || this.pointSelection.isSelected) { - this.observerInst = this.observerInst || new MutationObserver(function () { - _this.handler(); - }); - this.observerInst.observe(this.el.node, {attributes: true}); - } else { - try { - this.observerInst.disconnect(); - delete this.observerInst; - } catch (e) { - } - } - } else { - this.el.off('DOMAttrModified.select'); - - if (this.rectSelection.isSelected || this.pointSelection.isSelected) { - this.el.on('DOMAttrModified.select', function () { - _this.handler(); - }); - } - } - }; - - SelectHandler.prototype.cleanup = function () { - - //var _this = this; - - if (!this.rectSelection.isSelected && this.rectSelection.set) { - // stop watching the element, remove the selection - this.rectSelection.set.each(function () { - this.remove(); - }); - - this.rectSelection.set.clear(); - delete this.rectSelection.set; - } - - if (!this.pointSelection.isSelected && this.pointSelection.set) { - // Remove all points, clear the set, stop watching the element - this.pointSelection.set.each(function () { - this.remove(); - }); - - this.pointSelection.set.clear(); - delete this.pointSelection.set; - } - - if (!this.pointSelection.isSelected && !this.rectSelection.isSelected) { - this.nested.remove(); - delete this.nested; - - } - }; - - - SVG.extend(SVG.Element, { - // Select element with mouse - selectize: function (value, options) { - - // Check the parameters and reassign if needed - if (typeof value === 'object') { - options = value; - value = true; - } - - var selectHandler = this.remember('_selectHandler') || new SelectHandler(this); - - selectHandler.init(value === undefined ? true : value, options || {}); - - return this; - - } - }); - - SVG.Element.prototype.selectize.defaults = { - points: ['lt', 'rt', 'rb', 'lb', 't', 'r', 'b', 'l'], // which points to draw, default all - pointsExclude: [], // easier option if to exclude few than rewrite all - classRect: 'svg_select_boundingRect', // Css-class added to the rect - classPoints: 'svg_select_points', // Css-class added to the points - pointSize: 7, // size of point - rotationPoint: true, // If true, rotation point is drawn. Needed for rotation! - deepSelect: false, // If true, moving of single points is possible (only line, polyline, polyon) - pointType: 'circle' // Point type: circle or rect, default circle - }; - }()); - - (function() { - (function () { - - function ResizeHandler(el) { - - el.remember('_resizeHandler', this); - - this.el = el; - this.parameters = {}; - this.lastUpdateCall = null; - this.p = el.doc().node.createSVGPoint(); - } - - ResizeHandler.prototype.transformPoint = function(x, y, m){ - - this.p.x = x - (this.offset.x - window.pageXOffset); - this.p.y = y - (this.offset.y - window.pageYOffset); - - return this.p.matrixTransform(m || this.m); - - }; - - ResizeHandler.prototype._extractPosition = function(event) { - // Extract a position from a mouse/touch event. - // Returns { x: .., y: .. } - return { - x: event.clientX != null ? event.clientX : event.touches[0].clientX, - y: event.clientY != null ? event.clientY : event.touches[0].clientY - } - }; - - ResizeHandler.prototype.init = function (options) { - - var _this = this; - - this.stop(); - - if (options === 'stop') { - return; - } - - this.options = {}; - - // Merge options and defaults - for (var i in this.el.resize.defaults) { - this.options[i] = this.el.resize.defaults[i]; - if (typeof options[i] !== 'undefined') { - this.options[i] = options[i]; - } - } - - // We listen to all these events which are specifying different edges - this.el.on('lt.resize', function(e){ _this.resize(e || window.event); }); // Left-Top - this.el.on('rt.resize', function(e){ _this.resize(e || window.event); }); // Right-Top - this.el.on('rb.resize', function(e){ _this.resize(e || window.event); }); // Right-Bottom - this.el.on('lb.resize', function(e){ _this.resize(e || window.event); }); // Left-Bottom - - this.el.on('t.resize', function(e){ _this.resize(e || window.event); }); // Top - this.el.on('r.resize', function(e){ _this.resize(e || window.event); }); // Right - this.el.on('b.resize', function(e){ _this.resize(e || window.event); }); // Bottom - this.el.on('l.resize', function(e){ _this.resize(e || window.event); }); // Left - - this.el.on('rot.resize', function(e){ _this.resize(e || window.event); }); // Rotation - - this.el.on('point.resize', function(e){ _this.resize(e || window.event); }); // Point-Moving - - // This call ensures, that the plugin reacts to a change of snapToGrid immediately - this.update(); - - }; - - ResizeHandler.prototype.stop = function(){ - this.el.off('lt.resize'); - this.el.off('rt.resize'); - this.el.off('rb.resize'); - this.el.off('lb.resize'); - - this.el.off('t.resize'); - this.el.off('r.resize'); - this.el.off('b.resize'); - this.el.off('l.resize'); - - this.el.off('rot.resize'); - - this.el.off('point.resize'); - - return this; - }; - - ResizeHandler.prototype.resize = function (event) { - - var _this = this; - - this.m = this.el.node.getScreenCTM().inverse(); - this.offset = { x: window.pageXOffset, y: window.pageYOffset }; - - var txPt = this._extractPosition(event.detail.event); - this.parameters = { - type: this.el.type, // the type of element - p: this.transformPoint(txPt.x, txPt.y), - x: event.detail.x, // x-position of the mouse when resizing started - y: event.detail.y, // y-position of the mouse when resizing started - box: this.el.bbox(), // The bounding-box of the element - rotation: this.el.transform().rotation // The current rotation of the element - }; - - // Add font-size parameter if the element type is text - if (this.el.type === "text") { - this.parameters.fontSize = this.el.attr()["font-size"]; - } - - // the i-param in the event holds the index of the point which is moved, when using `deepSelect` - if (event.detail.i !== undefined) { - - // get the point array - var array = this.el.array().valueOf(); - - // Save the index and the point which is moved - this.parameters.i = event.detail.i; - this.parameters.pointCoords = [array[event.detail.i][0], array[event.detail.i][1]]; - } - - // Lets check which edge of the bounding-box was clicked and resize the this.el according to this - switch (event.type) { - - // Left-Top-Edge - case 'lt': - // We build a calculating function for every case which gives us the new position of the this.el - this.calc = function (diffX, diffY) { - // The procedure is always the same - // First we snap the edge to the given grid (snapping to 1px grid is normal resizing) - var snap = this.snapToGrid(diffX, diffY); - - // Now we check if the new height and width still valid (> 0) - if (this.parameters.box.width - snap[0] > 0 && this.parameters.box.height - snap[1] > 0) { - // ...if valid, we resize the this.el (which can include moving because the coord-system starts at the left-top and this edge is moving sometimes when resized) - - /* - * but first check if the element is text box, so we can change the font size instead of - * the width and height - */ - - if (this.parameters.type === "text") { - this.el.move(this.parameters.box.x + snap[0], this.parameters.box.y); - this.el.attr("font-size", this.parameters.fontSize - snap[0]); - return; - } - - snap = this.checkAspectRatio(snap); - - this.el.move(this.parameters.box.x + snap[0], this.parameters.box.y + snap[1]).size(this.parameters.box.width - snap[0], this.parameters.box.height - snap[1]); - } - }; - break; - - // Right-Top - case 'rt': - // s.a. - this.calc = function (diffX, diffY) { - var snap = this.snapToGrid(diffX, diffY, 1 << 1); - if (this.parameters.box.width + snap[0] > 0 && this.parameters.box.height - snap[1] > 0) { - if (this.parameters.type === "text") { - this.el.move(this.parameters.box.x - snap[0], this.parameters.box.y); - this.el.attr("font-size", this.parameters.fontSize + snap[0]); - return; - } - - snap = this.checkAspectRatio(snap, true); - - this.el.move(this.parameters.box.x, this.parameters.box.y + snap[1]).size(this.parameters.box.width + snap[0], this.parameters.box.height - snap[1]); - } - }; - break; - - // Right-Bottom - case 'rb': - // s.a. - this.calc = function (diffX, diffY) { - var snap = this.snapToGrid(diffX, diffY, 0); - if (this.parameters.box.width + snap[0] > 0 && this.parameters.box.height + snap[1] > 0) { - if (this.parameters.type === "text") { - this.el.move(this.parameters.box.x - snap[0], this.parameters.box.y); - this.el.attr("font-size", this.parameters.fontSize + snap[0]); - return; - } - - snap = this.checkAspectRatio(snap); - - this.el.move(this.parameters.box.x, this.parameters.box.y).size(this.parameters.box.width + snap[0], this.parameters.box.height + snap[1]); - } - }; - break; - - // Left-Bottom - case 'lb': - // s.a. - this.calc = function (diffX, diffY) { - var snap = this.snapToGrid(diffX, diffY, 1); - if (this.parameters.box.width - snap[0] > 0 && this.parameters.box.height + snap[1] > 0) { - if (this.parameters.type === "text") { - this.el.move(this.parameters.box.x + snap[0], this.parameters.box.y); - this.el.attr("font-size", this.parameters.fontSize - snap[0]); - return; - } - - snap = this.checkAspectRatio(snap, true); - - this.el.move(this.parameters.box.x + snap[0], this.parameters.box.y).size(this.parameters.box.width - snap[0], this.parameters.box.height + snap[1]); - } - }; - break; - - // Top - case 't': - // s.a. - this.calc = function (diffX, diffY) { - var snap = this.snapToGrid(diffX, diffY, 1 << 1); - if (this.parameters.box.height - snap[1] > 0) { - // Disable the font-resizing if it is not from the corner of bounding-box - if (this.parameters.type === "text") { - return; - } - - this.el.move(this.parameters.box.x, this.parameters.box.y + snap[1]).height(this.parameters.box.height - snap[1]); - } - }; - break; - - // Right - case 'r': - // s.a. - this.calc = function (diffX, diffY) { - var snap = this.snapToGrid(diffX, diffY, 0); - if (this.parameters.box.width + snap[0] > 0) { - if (this.parameters.type === "text") { - return; - } - - this.el.move(this.parameters.box.x, this.parameters.box.y).width(this.parameters.box.width + snap[0]); - } - }; - break; - - // Bottom - case 'b': - // s.a. - this.calc = function (diffX, diffY) { - var snap = this.snapToGrid(diffX, diffY, 0); - if (this.parameters.box.height + snap[1] > 0) { - if (this.parameters.type === "text") { - return; - } - - this.el.move(this.parameters.box.x, this.parameters.box.y).height(this.parameters.box.height + snap[1]); - } - }; - break; - - // Left - case 'l': - // s.a. - this.calc = function (diffX, diffY) { - var snap = this.snapToGrid(diffX, diffY, 1); - if (this.parameters.box.width - snap[0] > 0) { - if (this.parameters.type === "text") { - return; - } - - this.el.move(this.parameters.box.x + snap[0], this.parameters.box.y).width(this.parameters.box.width - snap[0]); - } - }; - break; - - // Rotation - case 'rot': - // s.a. - this.calc = function (diffX, diffY) { - - // yes this is kinda stupid but we need the mouse coords back... - var current = {x: diffX + this.parameters.p.x, y: diffY + this.parameters.p.y}; - - // start minus middle - var sAngle = Math.atan2((this.parameters.p.y - this.parameters.box.y - this.parameters.box.height / 2), (this.parameters.p.x - this.parameters.box.x - this.parameters.box.width / 2)); - - // end minus middle - var pAngle = Math.atan2((current.y - this.parameters.box.y - this.parameters.box.height / 2), (current.x - this.parameters.box.x - this.parameters.box.width / 2)); - - var angle = this.parameters.rotation + (pAngle - sAngle) * 180 / Math.PI + this.options.snapToAngle / 2; - - // We have to move the element to the center of the box first and change the rotation afterwards - // because rotation always works around a rotation-center, which is changed when moving the element - // We also set the new rotation center to the center of the box. - this.el.center(this.parameters.box.cx, this.parameters.box.cy).rotate(angle - (angle % this.options.snapToAngle), this.parameters.box.cx, this.parameters.box.cy); - }; - break; - - // Moving one single Point (needed when an element is deepSelected which means you can move every single point of the object) - case 'point': - this.calc = function (diffX, diffY) { - - // Snapping the point to the grid - var snap = this.snapToGrid(diffX, diffY, this.parameters.pointCoords[0], this.parameters.pointCoords[1]); - - // Get the point array - var array = this.el.array().valueOf(); - - // Changing the moved point in the array - array[this.parameters.i][0] = this.parameters.pointCoords[0] + snap[0]; - array[this.parameters.i][1] = this.parameters.pointCoords[1] + snap[1]; - - // And plot the new this.el - this.el.plot(array); - }; - } - - this.el.fire('resizestart', {dx: this.parameters.x, dy: this.parameters.y, event: event}); - // When resizing started, we have to register events for... - // Touches. - SVG.on(window, 'touchmove.resize', function(e) { - _this.update(e || window.event); - }); - SVG.on(window, 'touchend.resize', function() { - _this.done(); - }); - // Mouse. - SVG.on(window, 'mousemove.resize', function (e) { - _this.update(e || window.event); - }); - SVG.on(window, 'mouseup.resize', function () { - _this.done(); - }); - - }; - - // The update-function redraws the element every time the mouse is moving - ResizeHandler.prototype.update = function (event) { - - if (!event) { - if (this.lastUpdateCall) { - this.calc(this.lastUpdateCall[0], this.lastUpdateCall[1]); - } - return; - } - - // Calculate the difference between the mouseposition at start and now - var txPt = this._extractPosition(event); - var p = this.transformPoint(txPt.x, txPt.y); - - var diffX = p.x - this.parameters.p.x, - diffY = p.y - this.parameters.p.y; - - this.lastUpdateCall = [diffX, diffY]; - - // Calculate the new position and height / width of the element - this.calc(diffX, diffY); - - // Emit an event to say we have changed. - this.el.fire('resizing', {dx: diffX, dy: diffY, event: event}); - }; - - // Is called on mouseup. - // Removes the update-function from the mousemove event - ResizeHandler.prototype.done = function () { - this.lastUpdateCall = null; - SVG.off(window, 'mousemove.resize'); - SVG.off(window, 'mouseup.resize'); - SVG.off(window, 'touchmove.resize'); - SVG.off(window, 'touchend.resize'); - this.el.fire('resizedone'); - }; - - // The flag is used to determine whether the resizing is used with a left-Point (first bit) and top-point (second bit) - // In this cases the temp-values are calculated differently - ResizeHandler.prototype.snapToGrid = function (diffX, diffY, flag, pointCoordsY) { - - var temp; - - // If `pointCoordsY` is given, a single Point has to be snapped (deepSelect). That's why we need a different temp-value - if (typeof pointCoordsY !== 'undefined') { - // Note that flag = pointCoordsX in this case - temp = [(flag + diffX) % this.options.snapToGrid, (pointCoordsY + diffY) % this.options.snapToGrid]; - } else { - // We check if the flag is set and if not we set a default-value (both bits set - which means upper-left-edge) - flag = flag == null ? 1 | 1 << 1 : flag; - temp = [(this.parameters.box.x + diffX + (flag & 1 ? 0 : this.parameters.box.width)) % this.options.snapToGrid, (this.parameters.box.y + diffY + (flag & (1 << 1) ? 0 : this.parameters.box.height)) % this.options.snapToGrid]; - } - - if(diffX < 0) { - temp[0] -= this.options.snapToGrid; - } - if(diffY < 0) { - temp[1] -= this.options.snapToGrid; - } - - diffX -= (Math.abs(temp[0]) < this.options.snapToGrid / 2 ? - temp[0] : - temp[0] - (diffX < 0 ? -this.options.snapToGrid : this.options.snapToGrid)); - diffY -= (Math.abs(temp[1]) < this.options.snapToGrid / 2 ? - temp[1] : - temp[1] - (diffY < 0 ? -this.options.snapToGrid : this.options.snapToGrid)); - - return this.constraintToBox(diffX, diffY, flag, pointCoordsY); - - }; - - // keep element within constrained box - ResizeHandler.prototype.constraintToBox = function (diffX, diffY, flag, pointCoordsY) { - //return [diffX, diffY] - var c = this.options.constraint || {}; - var orgX, orgY; - - if (typeof pointCoordsY !== 'undefined') { - orgX = flag; - orgY = pointCoordsY; - } else { - orgX = this.parameters.box.x + (flag & 1 ? 0 : this.parameters.box.width); - orgY = this.parameters.box.y + (flag & (1<<1) ? 0 : this.parameters.box.height); - } - - if (typeof c.minX !== 'undefined' && orgX + diffX < c.minX) { - diffX = c.minX - orgX; - } - - if (typeof c.maxX !== 'undefined' && orgX + diffX > c.maxX) { - diffX = c.maxX - orgX; - } - - if (typeof c.minY !== 'undefined' && orgY + diffY < c.minY) { - diffY = c.minY - orgY; - } - - if (typeof c.maxY !== 'undefined' && orgY + diffY > c.maxY) { - diffY = c.maxY - orgY; - } - - return [diffX, diffY]; - }; - - ResizeHandler.prototype.checkAspectRatio = function (snap, isReverse) { - if (!this.options.saveAspectRatio) { - return snap; - } - - var updatedSnap = snap.slice(); - var aspectRatio = this.parameters.box.width / this.parameters.box.height; - var newW = this.parameters.box.width + snap[0]; - var newH = this.parameters.box.height - snap[1]; - var newAspectRatio = newW / newH; - - if (newAspectRatio < aspectRatio) { - // Height is too big. Adapt it - updatedSnap[1] = newW / aspectRatio - this.parameters.box.height; - isReverse && (updatedSnap[1] = -updatedSnap[1]); - } else if (newAspectRatio > aspectRatio) { - // Width is too big. Adapt it - updatedSnap[0] = this.parameters.box.width - newH * aspectRatio; - isReverse && (updatedSnap[0] = -updatedSnap[0]); - } - - return updatedSnap; - }; - - SVG.extend(SVG.Element, { - // Resize element with mouse - resize: function (options) { - - (this.remember('_resizeHandler') || new ResizeHandler(this)).init(options || {}); - - return this; - - } - - }); - - SVG.Element.prototype.resize.defaults = { - snapToAngle: 0.1, // Specifies the speed the rotation is happening when moving the mouse - snapToGrid: 1, // Snaps to a grid of `snapToGrid` Pixels - constraint: {}, // keep element within constrained box - saveAspectRatio: false // Save aspect ratio when resizing using lt, rt, rb or lb points - }; - - }).call(this); - }()); - - if (typeof window.Apex === 'undefined') { - window.Apex = {}; - } - - var InitCtxVariables = /*#__PURE__*/function () { - function InitCtxVariables(ctx) { - _classCallCheck(this, InitCtxVariables); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(InitCtxVariables, [{ - key: "initModules", - value: function initModules() { - this.ctx.publicMethods = ['updateOptions', 'updateSeries', 'appendData', 'appendSeries', 'toggleSeries', 'showSeries', 'hideSeries', 'setLocale', 'resetSeries', 'zoomX', 'toggleDataPointSelection', 'dataURI', 'exportToCSV', 'addXaxisAnnotation', 'addYaxisAnnotation', 'addPointAnnotation', 'clearAnnotations', 'removeAnnotation', 'paper', 'destroy']; - this.ctx.eventList = ['click', 'mousedown', 'mousemove', 'mouseleave', 'touchstart', 'touchmove', 'touchleave', 'mouseup', 'touchend']; - this.ctx.animations = new Animations(this.ctx); - this.ctx.axes = new Axes(this.ctx); - this.ctx.core = new Core(this.ctx.el, this.ctx); - this.ctx.config = new Config({}); - this.ctx.data = new Data(this.ctx); - this.ctx.grid = new Grid(this.ctx); - this.ctx.graphics = new Graphics(this.ctx); - this.ctx.coreUtils = new CoreUtils(this.ctx); - this.ctx.crosshairs = new Crosshairs(this.ctx); - this.ctx.events = new Events(this.ctx); - this.ctx.exports = new Exports(this.ctx); - this.ctx.localization = new Localization(this.ctx); - this.ctx.options = new Options(); - this.ctx.responsive = new Responsive(this.ctx); - this.ctx.series = new Series(this.ctx); - this.ctx.theme = new Theme(this.ctx); - this.ctx.formatters = new Formatters(this.ctx); - this.ctx.titleSubtitle = new TitleSubtitle(this.ctx); - this.ctx.legend = new Legend(this.ctx); - this.ctx.toolbar = new Toolbar(this.ctx); - this.ctx.tooltip = new Tooltip(this.ctx); - this.ctx.dimensions = new Dimensions(this.ctx); - this.ctx.updateHelpers = new UpdateHelpers(this.ctx); - this.ctx.zoomPanSelection = new ZoomPanSelection(this.ctx); - this.ctx.w.globals.tooltip = new Tooltip(this.ctx); - } - }]); - - return InitCtxVariables; - }(); - - var Destroy = /*#__PURE__*/function () { - function Destroy(ctx) { - _classCallCheck(this, Destroy); - - this.ctx = ctx; - this.w = ctx.w; - } - - _createClass(Destroy, [{ - key: "clear", - value: function clear(_ref) { - var isUpdating = _ref.isUpdating; - - if (this.ctx.zoomPanSelection) { - this.ctx.zoomPanSelection.destroy(); - } - - if (this.ctx.toolbar) { - this.ctx.toolbar.destroy(); - } - - this.ctx.animations = null; - this.ctx.axes = null; - this.ctx.annotations = null; - this.ctx.core = null; - this.ctx.data = null; - this.ctx.grid = null; - this.ctx.series = null; - this.ctx.responsive = null; - this.ctx.theme = null; - this.ctx.formatters = null; - this.ctx.titleSubtitle = null; - this.ctx.legend = null; - this.ctx.dimensions = null; - this.ctx.options = null; - this.ctx.crosshairs = null; - this.ctx.zoomPanSelection = null; - this.ctx.updateHelpers = null; - this.ctx.toolbar = null; - this.ctx.localization = null; - this.ctx.w.globals.tooltip = null; - this.clearDomElements({ - isUpdating: isUpdating - }); - } - }, { - key: "killSVG", - value: function killSVG(draw) { - draw.each(function (i, children) { - this.removeClass('*'); - this.off(); - this.stop(); - }, true); - draw.ungroup(); - draw.clear(); - } - }, { - key: "clearDomElements", - value: function clearDomElements(_ref2) { - var _this = this; - - var isUpdating = _ref2.isUpdating; - var elSVG = this.w.globals.dom.Paper.node; // fixes apexcharts.js#1654 & vue-apexcharts#256 - - if (elSVG.parentNode && elSVG.parentNode.parentNode && !isUpdating) { - elSVG.parentNode.parentNode.style.minHeight = 'unset'; - } // detach root event - - - var baseEl = this.w.globals.dom.baseEl; - - if (baseEl) { - // see https://github.com/apexcharts/vue-apexcharts/issues/275 - this.ctx.eventList.forEach(function (event) { - baseEl.removeEventListener(event, _this.ctx.events.documentEvent); - }); - } - - var domEls = this.w.globals.dom; - - if (this.ctx.el !== null) { - // remove all child elements - resetting the whole chart - while (this.ctx.el.firstChild) { - this.ctx.el.removeChild(this.ctx.el.firstChild); - } - } - - this.killSVG(domEls.Paper); - domEls.Paper.remove(); - domEls.elWrap = null; - domEls.elGraphical = null; - domEls.elLegendWrap = null; - domEls.elLegendForeign = null; - domEls.baseEl = null; - domEls.elGridRect = null; - domEls.elGridRectMask = null; - domEls.elGridRectMarkerMask = null; - domEls.elForecastMask = null; - domEls.elNonForecastMask = null; - domEls.elDefs = null; - } - }]); - - return Destroy; - }(); - - // Helpers to react to element resizes, regardless of what caused them - // TODO Currently this creates a new ResizeObserver every time we want to observe an element for resizes - // Ideally, we should be able to use a single observer for all elements - var ros = new WeakMap(); // Map callbacks to ResizeObserver instances for easy removal - - function addResizeListener(el, fn) { - var called = false; - - if (el.nodeType !== Node.DOCUMENT_FRAGMENT_NODE) { - var elRect = el.getBoundingClientRect(); - - if (el.style.display === 'none' || elRect.width === 0) { - // if elRect.width=0, the chart is not rendered at all - // (it has either display none or hidden in a different tab) - // fixes https://github.com/apexcharts/apexcharts.js/issues/2825 - // fixes https://github.com/apexcharts/apexcharts.js/issues/2991 - // fixes https://github.com/apexcharts/apexcharts.js/issues/2992 - called = true; - } - } - - var ro = new ResizeObserver(function (r) { - // ROs fire immediately after being created, - // per spec: https://drafts.csswg.org/resize-observer/#ref-for-element%E2%91%A3 - // we don't want that so we just discard the first run - if (called) { - fn.call(el, r); - } - - called = true; - }); - - if (el.nodeType === Node.DOCUMENT_FRAGMENT_NODE) { - // Document fragment, observe children instead (needed for Shadow DOM, see #1332) - Array.from(el.children).forEach(function (c) { - return ro.observe(c); - }); - } else { - ro.observe(el); - } - - ros.set(fn, ro); - } - function removeResizeListener(el, fn) { - var ro = ros.get(fn); - - if (ro) { - ro.disconnect(); - ros.delete(fn); - } - } - - var css_248z = "@keyframes opaque {\n 0% {\n opacity: 0\n }\n\n to {\n opacity: 1\n }\n}\n\n@keyframes resizeanim {\n 0%,to {\n opacity: 0\n }\n}\n\n.apexcharts-canvas {\n position: relative;\n user-select: none\n}\n\n.apexcharts-canvas ::-webkit-scrollbar {\n -webkit-appearance: none;\n width: 6px\n}\n\n.apexcharts-canvas ::-webkit-scrollbar-thumb {\n border-radius: 4px;\n background-color: rgba(0,0,0,.5);\n box-shadow: 0 0 1px rgba(255,255,255,.5);\n -webkit-box-shadow: 0 0 1px rgba(255,255,255,.5)\n}\n\n.apexcharts-inner {\n position: relative\n}\n\n.apexcharts-text tspan {\n font-family: inherit\n}\n\n.legend-mouseover-inactive {\n transition: .15s ease all;\n opacity: .2\n}\n\n.apexcharts-legend-text {\n padding-left: 15px;\n margin-left: -15px;\n}\n\n.apexcharts-series-collapsed {\n opacity: 0\n}\n\n.apexcharts-tooltip {\n border-radius: 5px;\n box-shadow: 2px 2px 6px -4px #999;\n cursor: default;\n font-size: 14px;\n left: 62px;\n opacity: 0;\n pointer-events: none;\n position: absolute;\n top: 20px;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n white-space: nowrap;\n z-index: 12;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-theme-light {\n border: 1px solid #e3e3e3;\n background: rgba(255,255,255,.96)\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark {\n color: #fff;\n background: rgba(30,30,30,.8)\n}\n\n.apexcharts-tooltip * {\n font-family: inherit\n}\n\n.apexcharts-tooltip-title {\n padding: 6px;\n font-size: 15px;\n margin-bottom: 4px\n}\n\n.apexcharts-tooltip.apexcharts-theme-light .apexcharts-tooltip-title {\n background: #eceff1;\n border-bottom: 1px solid #ddd\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark .apexcharts-tooltip-title {\n background: rgba(0,0,0,.7);\n border-bottom: 1px solid #333\n}\n\n.apexcharts-tooltip-text-goals-value,.apexcharts-tooltip-text-y-value,.apexcharts-tooltip-text-z-value {\n display: inline-block;\n margin-left: 5px;\n font-weight: 600\n}\n\n.apexcharts-tooltip-text-goals-label:empty,.apexcharts-tooltip-text-goals-value:empty,.apexcharts-tooltip-text-y-label:empty,.apexcharts-tooltip-text-y-value:empty,.apexcharts-tooltip-text-z-value:empty,.apexcharts-tooltip-title:empty {\n display: none\n}\n\n.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n padding: 6px 0 5px\n}\n\n.apexcharts-tooltip-goals-group,.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n display: flex\n}\n\n.apexcharts-tooltip-text-goals-label:not(:empty),.apexcharts-tooltip-text-goals-value:not(:empty) {\n margin-top: -6px\n}\n\n.apexcharts-tooltip-marker {\n width: 12px;\n height: 12px;\n position: relative;\n top: 0;\n margin-right: 10px;\n border-radius: 50%\n}\n\n.apexcharts-tooltip-series-group {\n padding: 0 10px;\n display: none;\n text-align: left;\n justify-content: left;\n align-items: center\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-marker {\n opacity: 1\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active,.apexcharts-tooltip-series-group:last-child {\n padding-bottom: 4px\n}\n\n.apexcharts-tooltip-series-group-hidden {\n opacity: 0;\n height: 0;\n line-height: 0;\n padding: 0!important\n}\n\n.apexcharts-tooltip-y-group {\n padding: 6px 0 5px\n}\n\n.apexcharts-custom-tooltip,.apexcharts-tooltip-box {\n padding: 4px 8px\n}\n\n.apexcharts-tooltip-boxPlot {\n display: flex;\n flex-direction: column-reverse\n}\n\n.apexcharts-tooltip-box>div {\n margin: 4px 0\n}\n\n.apexcharts-tooltip-box span.value {\n font-weight: 700\n}\n\n.apexcharts-tooltip-rangebar {\n padding: 5px 8px\n}\n\n.apexcharts-tooltip-rangebar .category {\n font-weight: 600;\n color: #777\n}\n\n.apexcharts-tooltip-rangebar .series-name {\n font-weight: 700;\n display: block;\n margin-bottom: 5px\n}\n\n.apexcharts-xaxistooltip,.apexcharts-yaxistooltip {\n opacity: 0;\n pointer-events: none;\n color: #373d3f;\n font-size: 13px;\n text-align: center;\n border-radius: 2px;\n position: absolute;\n z-index: 10;\n background: #eceff1;\n border: 1px solid #90a4ae\n}\n\n.apexcharts-xaxistooltip {\n padding: 9px 10px;\n transition: .15s ease all\n}\n\n.apexcharts-xaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-xaxistooltip:after,.apexcharts-xaxistooltip:before {\n left: 50%;\n border: solid transparent;\n content: \" \";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-xaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-left: -6px\n}\n\n.apexcharts-xaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-left: -7px\n}\n\n.apexcharts-xaxistooltip-bottom:after,.apexcharts-xaxistooltip-bottom:before {\n bottom: 100%\n}\n\n.apexcharts-xaxistooltip-top:after,.apexcharts-xaxistooltip-top:before {\n top: 100%\n}\n\n.apexcharts-xaxistooltip-bottom:after {\n border-bottom-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-bottom:before {\n border-bottom-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:before {\n border-bottom-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip-top:after {\n border-top-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-top:before {\n border-top-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-top.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-top.apexcharts-theme-dark:before {\n border-top-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-yaxistooltip {\n padding: 4px 10px\n}\n\n.apexcharts-yaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-yaxistooltip:after,.apexcharts-yaxistooltip:before {\n top: 50%;\n border: solid transparent;\n content: \" \";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-yaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-top: -6px\n}\n\n.apexcharts-yaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-top: -7px\n}\n\n.apexcharts-yaxistooltip-left:after,.apexcharts-yaxistooltip-left:before {\n left: 100%\n}\n\n.apexcharts-yaxistooltip-right:after,.apexcharts-yaxistooltip-right:before {\n right: 100%\n}\n\n.apexcharts-yaxistooltip-left:after {\n border-left-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-left:before {\n border-left-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-left.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-left.apexcharts-theme-dark:before {\n border-left-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip-right:after {\n border-right-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-right:before {\n border-right-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-right.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-right.apexcharts-theme-dark:before {\n border-right-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip.apexcharts-active {\n opacity: 1\n}\n\n.apexcharts-yaxistooltip-hidden {\n display: none\n}\n\n.apexcharts-xcrosshairs,.apexcharts-ycrosshairs {\n pointer-events: none;\n opacity: 0;\n transition: .15s ease all\n}\n\n.apexcharts-xcrosshairs.apexcharts-active,.apexcharts-ycrosshairs.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-ycrosshairs-hidden {\n opacity: 0\n}\n\n.apexcharts-selection-rect {\n cursor: move\n}\n\n.svg_select_boundingRect,.svg_select_points_rot {\n pointer-events: none;\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_boundingRect,.apexcharts-selection-rect+g .svg_select_points_rot {\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_points_l,.apexcharts-selection-rect+g .svg_select_points_r {\n cursor: ew-resize;\n opacity: 1;\n visibility: visible\n}\n\n.svg_select_points {\n fill: #efefef;\n stroke: #333;\n rx: 2\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-zoom {\n cursor: crosshair\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-pan {\n cursor: move\n}\n\n.apexcharts-menu-icon,.apexcharts-pan-icon,.apexcharts-reset-icon,.apexcharts-selection-icon,.apexcharts-toolbar-custom-icon,.apexcharts-zoom-icon,.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n cursor: pointer;\n width: 20px;\n height: 20px;\n line-height: 24px;\n color: #6e8192;\n text-align: center\n}\n\n.apexcharts-menu-icon svg,.apexcharts-reset-icon svg,.apexcharts-zoom-icon svg,.apexcharts-zoomin-icon svg,.apexcharts-zoomout-icon svg {\n fill: #6e8192\n}\n\n.apexcharts-selection-icon svg {\n fill: #444;\n transform: scale(.76)\n}\n\n.apexcharts-theme-dark .apexcharts-menu-icon svg,.apexcharts-theme-dark .apexcharts-pan-icon svg,.apexcharts-theme-dark .apexcharts-reset-icon svg,.apexcharts-theme-dark .apexcharts-selection-icon svg,.apexcharts-theme-dark .apexcharts-toolbar-custom-icon svg,.apexcharts-theme-dark .apexcharts-zoom-icon svg,.apexcharts-theme-dark .apexcharts-zoomin-icon svg,.apexcharts-theme-dark .apexcharts-zoomout-icon svg {\n fill: #f3f4f5\n}\n\n.apexcharts-canvas .apexcharts-reset-zoom-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-selection-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-zoom-icon.apexcharts-selected svg {\n fill: #008ffb\n}\n\n.apexcharts-theme-light .apexcharts-menu-icon:hover svg,.apexcharts-theme-light .apexcharts-reset-icon:hover svg,.apexcharts-theme-light .apexcharts-selection-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoom-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoomin-icon:hover svg,.apexcharts-theme-light .apexcharts-zoomout-icon:hover svg {\n fill: #333\n}\n\n.apexcharts-menu-icon,.apexcharts-selection-icon {\n position: relative\n}\n\n.apexcharts-reset-icon {\n margin-left: 5px\n}\n\n.apexcharts-menu-icon,.apexcharts-reset-icon,.apexcharts-zoom-icon {\n transform: scale(.85)\n}\n\n.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n transform: scale(.7)\n}\n\n.apexcharts-zoomout-icon {\n margin-right: 3px\n}\n\n.apexcharts-pan-icon {\n transform: scale(.62);\n position: relative;\n left: 1px;\n top: 0\n}\n\n.apexcharts-pan-icon svg {\n fill: #fff;\n stroke: #6e8192;\n stroke-width: 2\n}\n\n.apexcharts-pan-icon.apexcharts-selected svg {\n stroke: #008ffb\n}\n\n.apexcharts-pan-icon:not(.apexcharts-selected):hover svg {\n stroke: #333\n}\n\n.apexcharts-toolbar {\n position: absolute;\n z-index: 11;\n max-width: 176px;\n text-align: right;\n border-radius: 3px;\n padding: 0 6px 2px;\n display: flex;\n justify-content: space-between;\n align-items: center\n}\n\n.apexcharts-menu {\n background: #fff;\n position: absolute;\n top: 100%;\n border: 1px solid #ddd;\n border-radius: 3px;\n padding: 3px;\n right: 10px;\n opacity: 0;\n min-width: 110px;\n transition: .15s ease all;\n pointer-events: none\n}\n\n.apexcharts-menu.apexcharts-menu-open {\n opacity: 1;\n pointer-events: all;\n transition: .15s ease all\n}\n\n.apexcharts-menu-item {\n padding: 6px 7px;\n font-size: 12px;\n cursor: pointer\n}\n\n.apexcharts-theme-light .apexcharts-menu-item:hover {\n background: #eee\n}\n\n.apexcharts-theme-dark .apexcharts-menu {\n background: rgba(0,0,0,.7);\n color: #fff\n}\n\n@media screen and (min-width:768px) {\n .apexcharts-canvas:hover .apexcharts-toolbar {\n opacity: 1\n }\n}\n\n.apexcharts-canvas .apexcharts-element-hidden,.apexcharts-datalabel.apexcharts-element-hidden,.apexcharts-hide .apexcharts-series-points {\n opacity: 0\n}\n\n.apexcharts-datalabel,.apexcharts-datalabel-label,.apexcharts-datalabel-value,.apexcharts-datalabels,.apexcharts-pie-label {\n cursor: default;\n pointer-events: none\n}\n\n.apexcharts-pie-label-delay {\n opacity: 0;\n animation-name: opaque;\n animation-duration: .3s;\n animation-fill-mode: forwards;\n animation-timing-function: ease\n}\n\n.apexcharts-annotation-rect,.apexcharts-area-series .apexcharts-area,.apexcharts-area-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-gridline,.apexcharts-line,.apexcharts-line-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-point-annotation-label,.apexcharts-radar-series path,.apexcharts-radar-series polygon,.apexcharts-toolbar svg,.apexcharts-tooltip .apexcharts-marker,.apexcharts-xaxis-annotation-label,.apexcharts-yaxis-annotation-label,.apexcharts-zoom-rect {\n pointer-events: none\n}\n\n.apexcharts-marker {\n transition: .15s ease all\n}\n\n.resize-triggers {\n animation: 1ms resizeanim;\n visibility: hidden;\n opacity: 0;\n height: 100%;\n width: 100%;\n overflow: hidden\n}\n\n.contract-trigger:before,.resize-triggers,.resize-triggers>div {\n content: \" \";\n display: block;\n position: absolute;\n top: 0;\n left: 0\n}\n\n.resize-triggers>div {\n height: 100%;\n width: 100%;\n background: #eee;\n overflow: auto\n}\n\n.contract-trigger:before {\n overflow: hidden;\n width: 200%;\n height: 200%\n}\n"; - - /** - * - * @module ApexCharts - **/ - - var ApexCharts$1 = /*#__PURE__*/function () { - function ApexCharts(el, opts) { - _classCallCheck(this, ApexCharts); - - this.opts = opts; - this.ctx = this; // Pass the user supplied options to the Base Class where these options will be extended with defaults. The returned object from Base Class will become the config object in the entire codebase. - - this.w = new Base(opts).init(); - this.el = el; - this.w.globals.cuid = Utils$1.randomId(); - this.w.globals.chartID = this.w.config.chart.id ? Utils$1.escapeString(this.w.config.chart.id) : this.w.globals.cuid; - var initCtx = new InitCtxVariables(this); - initCtx.initModules(); - this.create = Utils$1.bind(this.create, this); - this.windowResizeHandler = this._windowResizeHandler.bind(this); - this.parentResizeHandler = this._parentResizeCallback.bind(this); - } - /** - * The primary method user will call to render the chart. - */ - - - _createClass(ApexCharts, [{ - key: "render", - value: function render() { - var _this = this; - - // main method - return new Promise(function (resolve, reject) { - // only draw chart, if element found - if (_this.el !== null) { - if (typeof Apex._chartInstances === 'undefined') { - Apex._chartInstances = []; - } - - if (_this.w.config.chart.id) { - Apex._chartInstances.push({ - id: _this.w.globals.chartID, - group: _this.w.config.chart.group, - chart: _this - }); - } // set the locale here - - - _this.setLocale(_this.w.config.chart.defaultLocale); - - var beforeMount = _this.w.config.chart.events.beforeMount; - - if (typeof beforeMount === 'function') { - beforeMount(_this, _this.w); - } - - _this.events.fireEvent('beforeMount', [_this, _this.w]); - - window.addEventListener('resize', _this.windowResizeHandler); - addResizeListener(_this.el.parentNode, _this.parentResizeHandler); // Add CSS if not already added - - if (!_this.css) { - var rootNode = _this.el.getRootNode && _this.el.getRootNode(); - - var inShadowRoot = Utils$1.is('ShadowRoot', rootNode); - var doc = _this.el.ownerDocument; - var globalCSS = doc.getElementById('apexcharts-css'); - - if (inShadowRoot || !globalCSS) { - _this.css = document.createElement('style'); - _this.css.id = 'apexcharts-css'; - _this.css.textContent = css_248z; - - if (inShadowRoot) { - // We are in Shadow DOM, add to shadow root - rootNode.prepend(_this.css); - } else { - // Add to of element's document - doc.head.appendChild(_this.css); - } - } - } - - var graphData = _this.create(_this.w.config.series, {}); - - if (!graphData) return resolve(_this); - - _this.mount(graphData).then(function () { - if (typeof _this.w.config.chart.events.mounted === 'function') { - _this.w.config.chart.events.mounted(_this, _this.w); - } - - _this.events.fireEvent('mounted', [_this, _this.w]); - - resolve(graphData); - }).catch(function (e) { - reject(e); // handle error in case no data or element not found - }); - } else { - reject(new Error('Element not found')); - } - }); - } - }, { - key: "create", - value: function create(ser, opts) { - var w = this.w; - var initCtx = new InitCtxVariables(this); - initCtx.initModules(); - var gl = this.w.globals; - gl.noData = false; - gl.animationEnded = false; - this.responsive.checkResponsiveConfig(opts); - - if (w.config.xaxis.convertedCatToNumeric) { - var defaults = new Defaults(w.config); - defaults.convertCatToNumericXaxis(w.config, this.ctx); - } - - if (this.el === null) { - gl.animationEnded = true; - return null; - } - - this.core.setupElements(); - - if (w.config.chart.type === 'treemap') { - w.config.grid.show = false; - w.config.yaxis[0].show = false; - } - - if (gl.svgWidth === 0) { - // if the element is hidden, skip drawing - gl.animationEnded = true; - return null; - } - - var combo = CoreUtils.checkComboSeries(ser); - gl.comboCharts = combo.comboCharts; - gl.comboBarCount = combo.comboBarCount; - var allSeriesAreEmpty = ser.every(function (s) { - return s.data && s.data.length === 0; - }); - - if (ser.length === 0 || allSeriesAreEmpty) { - this.series.handleNoData(); - } - - this.events.setupEventHandlers(); // Handle the data inputted by user and set some of the global variables (for eg, if data is datetime / numeric / category). Don't calculate the range / min / max at this time - - this.data.parseData(ser); // this is a good time to set theme colors first - - this.theme.init(); // as markers accepts array, we need to setup global markers for easier access - - var markers = new Markers(this); - markers.setGlobalMarkerSize(); // labelFormatters should be called before dimensions as in dimensions we need text labels width - - this.formatters.setLabelFormatters(); - this.titleSubtitle.draw(); // legend is calculated here before coreCalculations because it affects the plottable area - // if there is some data to show or user collapsed all series, then proceed drawing legend - - if (!gl.noData || gl.collapsedSeries.length === gl.series.length || w.config.legend.showForSingleSeries) { - this.legend.init(); - } // check whether in multiple series, all series share the same X - - - this.series.hasAllSeriesEqualX(); // coreCalculations will give the min/max range and yaxis/axis values. It should be called here to set series variable from config to globals - - if (gl.axisCharts) { - this.core.coreCalculations(); - - if (w.config.xaxis.type !== 'category') { - // as we have minX and maxX values, determine the default DateTimeFormat for time series - this.formatters.setLabelFormatters(); - } - - this.ctx.toolbar.minX = w.globals.minX; - this.ctx.toolbar.maxX = w.globals.maxX; - } // we need to generate yaxis for heatmap separately as we are not showing numerics there, but seriesNames. There are some tweaks which are required for heatmap to align labels correctly which are done in below function - // Also we need to do this before calculating Dimensions plotCoords() method of Dimensions - - - this.formatters.heatmapLabelFormatters(); // get the largest marker size which will be needed in dimensions calc - - var coreUtils = new CoreUtils(this); - coreUtils.getLargestMarkerSize(); // We got plottable area here, next task would be to calculate axis areas - - this.dimensions.plotCoords(); - var xyRatios = this.core.xySettings(); - this.grid.createGridMask(); - var elGraph = this.core.plotChartType(ser, xyRatios); - var dataLabels = new DataLabels(this); - dataLabels.bringForward(); - - if (w.config.dataLabels.background.enabled) { - dataLabels.dataLabelsBackground(); - } // after all the drawing calculations, shift the graphical area (actual charts/bars) excluding legends - - - this.core.shiftGraphPosition(); - var dim = { - plot: { - left: w.globals.translateX, - top: w.globals.translateY, - width: w.globals.gridWidth, - height: w.globals.gridHeight - } - }; - return { - elGraph: elGraph, - xyRatios: xyRatios, - dimensions: dim - }; - } - }, { - key: "mount", - value: function mount() { - var _this2 = this; - - var graphData = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; - var me = this; - var w = me.w; - return new Promise(function (resolve, reject) { - // no data to display - if (me.el === null) { - return reject(new Error('Not enough data to display or target element not found')); - } else if (graphData === null || w.globals.allSeriesCollapsed) { - me.series.handleNoData(); - } - - me.grid = new Grid(me); - var elgrid = me.grid.drawGrid(); - me.annotations = new Annotations(me); - me.annotations.drawImageAnnos(); - me.annotations.drawTextAnnos(); - - if (w.config.grid.position === 'back' && elgrid) { - w.globals.dom.elGraphical.add(elgrid.el); - } - - if (Array.isArray(graphData.elGraph)) { - for (var g = 0; g < graphData.elGraph.length; g++) { - w.globals.dom.elGraphical.add(graphData.elGraph[g]); - } - } else { - w.globals.dom.elGraphical.add(graphData.elGraph); - } - - if (w.config.grid.position === 'front' && elgrid) { - w.globals.dom.elGraphical.add(elgrid.el); - } - - if (elgrid && elgrid.elGridBorders && elgrid.elGridBorders.node) { - w.globals.dom.elGraphical.add(elgrid.elGridBorders); - } - - if (w.config.xaxis.crosshairs.position === 'front') { - me.crosshairs.drawXCrosshairs(); - } - - if (w.config.yaxis[0].crosshairs.position === 'front') { - me.crosshairs.drawYCrosshairs(); - } - - if (w.config.chart.type !== 'treemap') { - me.axes.drawAxis(w.config.chart.type, elgrid); - } - - var xAxis = new XAxis(_this2.ctx, elgrid); - var yaxis = new YAxis(_this2.ctx, elgrid); - - if (elgrid !== null) { - xAxis.xAxisLabelCorrections(elgrid.xAxisTickWidth); - yaxis.setYAxisTextAlignments(); - w.config.yaxis.map(function (yaxe, index) { - if (w.globals.ignoreYAxisIndexes.indexOf(index) === -1) { - yaxis.yAxisTitleRotate(index, yaxe.opposite); - } - }); - } - - me.annotations.drawAxesAnnotations(); - - if (!w.globals.noData) { - // draw tooltips at the end - if (w.config.tooltip.enabled && !w.globals.noData) { - me.w.globals.tooltip.drawTooltip(graphData.xyRatios); - } - - if (w.globals.axisCharts && (w.globals.isXNumeric || w.config.xaxis.convertedCatToNumeric || w.globals.isRangeBar)) { - if (w.config.chart.zoom.enabled || w.config.chart.selection && w.config.chart.selection.enabled || w.config.chart.pan && w.config.chart.pan.enabled) { - me.zoomPanSelection.init({ - xyRatios: graphData.xyRatios - }); - } - } else { - var tools = w.config.chart.toolbar.tools; - var toolsArr = ['zoom', 'zoomin', 'zoomout', 'selection', 'pan', 'reset']; - toolsArr.forEach(function (t) { - tools[t] = false; - }); - } - - if (w.config.chart.toolbar.show && !w.globals.allSeriesCollapsed) { - me.toolbar.createToolbar(); - } - } - - if (w.globals.memory.methodsToExec.length > 0) { - w.globals.memory.methodsToExec.forEach(function (fn) { - fn.method(fn.params, false, fn.context); - }); - } - - if (!w.globals.axisCharts && !w.globals.noData) { - me.core.resizeNonAxisCharts(); - } - - resolve(me); - }); - } - /** - * Destroy the chart instance by removing all elements which also clean up event listeners on those elements. - */ - - }, { - key: "destroy", - value: function destroy() { - window.removeEventListener('resize', this.windowResizeHandler); - removeResizeListener(this.el.parentNode, this.parentResizeHandler); // remove the chart's instance from the global Apex._chartInstances - - var chartID = this.w.config.chart.id; - - if (chartID) { - Apex._chartInstances.forEach(function (c, i) { - if (c.id === Utils$1.escapeString(chartID)) { - Apex._chartInstances.splice(i, 1); - } - }); - } - - new Destroy(this.ctx).clear({ - isUpdating: false - }); - } - /** - * Allows users to update Options after the chart has rendered. - * - * @param {object} options - A new config object can be passed which will be merged with the existing config object - * @param {boolean} redraw - should redraw from beginning or should use existing paths and redraw from there - * @param {boolean} animate - should animate or not on updating Options - */ - - }, { - key: "updateOptions", - value: function updateOptions(options) { - var _this3 = this; - - var redraw = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - var animate = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; - var updateSyncedCharts = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : true; - var overwriteInitialConfig = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : true; - var w = this.w; // when called externally, clear some global variables - // fixes apexcharts.js#1488 - - w.globals.selection = undefined; - - if (options.series) { - this.series.resetSeries(false, true, false); - - if (options.series.length && options.series[0].data) { - options.series = options.series.map(function (s, i) { - return _this3.updateHelpers._extendSeries(s, i); - }); - } // user updated the series via updateOptions() function. - // Hence, we need to reset axis min/max to avoid zooming issues - - - this.updateHelpers.revertDefaultAxisMinMax(); - } // user has set x-axis min/max externally - hence we need to forcefully set the xaxis min/max - - - if (options.xaxis) { - options = this.updateHelpers.forceXAxisUpdate(options); - } - - if (options.yaxis) { - options = this.updateHelpers.forceYAxisUpdate(options); - } - - if (w.globals.collapsedSeriesIndices.length > 0) { - this.series.clearPreviousPaths(); - } - /* update theme mode#459 */ - - - if (options.theme) { - options = this.theme.updateThemeOptions(options); - } - - return this.updateHelpers._updateOptions(options, redraw, animate, updateSyncedCharts, overwriteInitialConfig); - } - /** - * Allows users to update Series after the chart has rendered. - * - * @param {array} series - New series which will override the existing - */ - - }, { - key: "updateSeries", - value: function updateSeries() { - var newSeries = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; - var animate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - var overwriteInitialSeries = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; - this.series.resetSeries(false); - this.updateHelpers.revertDefaultAxisMinMax(); - return this.updateHelpers._updateSeries(newSeries, animate, overwriteInitialSeries); - } - /** - * Allows users to append a new series after the chart has rendered. - * - * @param {array} newSerie - New serie which will be appended to the existing series - */ - - }, { - key: "appendSeries", - value: function appendSeries(newSerie) { - var animate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - var overwriteInitialSeries = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; - var newSeries = this.w.config.series.slice(); - newSeries.push(newSerie); - this.series.resetSeries(false); - this.updateHelpers.revertDefaultAxisMinMax(); - return this.updateHelpers._updateSeries(newSeries, animate, overwriteInitialSeries); - } - /** - * Allows users to append Data to series. - * - * @param {array} newData - New data in the same format as series - */ - - }, { - key: "appendData", - value: function appendData(newData) { - var overwriteInitialSeries = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - var me = this; - me.w.globals.dataChanged = true; - me.series.getPreviousPaths(); - var newSeries = me.w.config.series.slice(); - - for (var i = 0; i < newSeries.length; i++) { - if (newData[i] !== null && typeof newData[i] !== 'undefined') { - for (var j = 0; j < newData[i].data.length; j++) { - newSeries[i].data.push(newData[i].data[j]); - } - } - } - - me.w.config.series = newSeries; - - if (overwriteInitialSeries) { - me.w.globals.initialSeries = Utils$1.clone(me.w.config.series); - } - - return this.update(); - } - }, { - key: "update", - value: function update(options) { - var _this4 = this; - - return new Promise(function (resolve, reject) { - new Destroy(_this4.ctx).clear({ - isUpdating: true - }); - - var graphData = _this4.create(_this4.w.config.series, options); - - if (!graphData) return resolve(_this4); - - _this4.mount(graphData).then(function () { - if (typeof _this4.w.config.chart.events.updated === 'function') { - _this4.w.config.chart.events.updated(_this4, _this4.w); - } - - _this4.events.fireEvent('updated', [_this4, _this4.w]); - - _this4.w.globals.isDirty = true; - resolve(_this4); - }).catch(function (e) { - reject(e); - }); - }); - } - /** - * Get all charts in the same "group" (including the instance which is called upon) to sync them when user zooms in/out or pan. - */ - - }, { - key: "getSyncedCharts", - value: function getSyncedCharts() { - var chartGroups = this.getGroupedCharts(); - var allCharts = [this]; - - if (chartGroups.length) { - allCharts = []; - chartGroups.forEach(function (ch) { - allCharts.push(ch); - }); - } - - return allCharts; - } - /** - * Get charts in the same "group" (excluding the instance which is called upon) to perform operations on the other charts of the same group (eg., tooltip hovering) - */ - - }, { - key: "getGroupedCharts", - value: function getGroupedCharts() { - var _this5 = this; - - return Apex._chartInstances.filter(function (ch) { - if (ch.group) { - return true; - } - }).map(function (ch) { - return _this5.w.config.chart.group === ch.group ? ch.chart : _this5; - }); - } - }, { - key: "toggleSeries", - value: function toggleSeries(seriesName) { - return this.series.toggleSeries(seriesName); - } - }, { - key: "highlightSeriesOnLegendHover", - value: function highlightSeriesOnLegendHover(e, targetElement) { - return this.series.toggleSeriesOnHover(e, targetElement); - } - }, { - key: "showSeries", - value: function showSeries(seriesName) { - this.series.showSeries(seriesName); - } - }, { - key: "hideSeries", - value: function hideSeries(seriesName) { - this.series.hideSeries(seriesName); - } - }, { - key: "resetSeries", - value: function resetSeries() { - var shouldUpdateChart = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; - var shouldResetZoom = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - this.series.resetSeries(shouldUpdateChart, shouldResetZoom); - } // Public method to add event listener on chart context - - }, { - key: "addEventListener", - value: function addEventListener(name, handler) { - this.events.addEventListener(name, handler); - } // Public method to remove event listener on chart context - - }, { - key: "removeEventListener", - value: function removeEventListener(name, handler) { - this.events.removeEventListener(name, handler); - } - }, { - key: "addXaxisAnnotation", - value: function addXaxisAnnotation(opts) { - var pushToMemory = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - var context = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : undefined; - var me = this; - - if (context) { - me = context; - } - - me.annotations.addXaxisAnnotationExternal(opts, pushToMemory, me); - } - }, { - key: "addYaxisAnnotation", - value: function addYaxisAnnotation(opts) { - var pushToMemory = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - var context = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : undefined; - var me = this; - - if (context) { - me = context; - } - - me.annotations.addYaxisAnnotationExternal(opts, pushToMemory, me); - } - }, { - key: "addPointAnnotation", - value: function addPointAnnotation(opts) { - var pushToMemory = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; - var context = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : undefined; - var me = this; - - if (context) { - me = context; - } - - me.annotations.addPointAnnotationExternal(opts, pushToMemory, me); - } - }, { - key: "clearAnnotations", - value: function clearAnnotations() { - var context = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : undefined; - var me = this; - - if (context) { - me = context; - } - - me.annotations.clearAnnotations(me); - } - }, { - key: "removeAnnotation", - value: function removeAnnotation(id) { - var context = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : undefined; - var me = this; - - if (context) { - me = context; - } - - me.annotations.removeAnnotation(me, id); - } - }, { - key: "getChartArea", - value: function getChartArea() { - var el = this.w.globals.dom.baseEl.querySelector('.apexcharts-inner'); - return el; - } - }, { - key: "getSeriesTotalXRange", - value: function getSeriesTotalXRange(minX, maxX) { - return this.coreUtils.getSeriesTotalsXRange(minX, maxX); - } - }, { - key: "getHighestValueInSeries", - value: function getHighestValueInSeries() { - var seriesIndex = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; - var range = new Range(this.ctx); - return range.getMinYMaxY(seriesIndex).highestY; - } - }, { - key: "getLowestValueInSeries", - value: function getLowestValueInSeries() { - var seriesIndex = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; - var range = new Range(this.ctx); - return range.getMinYMaxY(seriesIndex).lowestY; - } - }, { - key: "getSeriesTotal", - value: function getSeriesTotal() { - return this.w.globals.seriesTotals; - } - }, { - key: "toggleDataPointSelection", - value: function toggleDataPointSelection(seriesIndex, dataPointIndex) { - return this.updateHelpers.toggleDataPointSelection(seriesIndex, dataPointIndex); - } - }, { - key: "zoomX", - value: function zoomX(min, max) { - this.ctx.toolbar.zoomUpdateOptions(min, max); - } - }, { - key: "setLocale", - value: function setLocale(localeName) { - this.localization.setCurrentLocaleValues(localeName); - } - }, { - key: "dataURI", - value: function dataURI(options) { - var exp = new Exports(this.ctx); - return exp.dataURI(options); - } - }, { - key: "exportToCSV", - value: function exportToCSV() { - var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var exp = new Exports(this.ctx); - return exp.exportToCSV(options); - } - }, { - key: "paper", - value: function paper() { - return this.w.globals.dom.Paper; - } - }, { - key: "_parentResizeCallback", - value: function _parentResizeCallback() { - if (this.w.globals.animationEnded && this.w.config.chart.redrawOnParentResize) { - this._windowResize(); - } - } - /** - * Handle window resize and re-draw the whole chart. - */ - - }, { - key: "_windowResize", - value: function _windowResize() { - var _this6 = this; - - clearTimeout(this.w.globals.resizeTimer); - this.w.globals.resizeTimer = window.setTimeout(function () { - _this6.w.globals.resized = true; - _this6.w.globals.dataChanged = false; // we need to redraw the whole chart on window resize (with a small delay). - - _this6.ctx.update(); - }, 150); - } - }, { - key: "_windowResizeHandler", - value: function _windowResizeHandler() { - var redraw = this.w.config.chart.redrawOnWindowResize; - - if (typeof redraw === 'function') { - redraw = redraw(); - } - - redraw && this._windowResize(); - } - }], [{ - key: "getChartByID", - value: function getChartByID(id) { - var chartId = Utils$1.escapeString(id); - - var c = Apex._chartInstances.filter(function (ch) { - return ch.id === chartId; - })[0]; - - return c && c.chart; - } - /** - * Allows the user to provide data attrs in the element and the chart will render automatically when this method is called by searching for the elements containing 'data-apexcharts' attribute - */ - - }, { - key: "initOnLoad", - value: function initOnLoad() { - var els = document.querySelectorAll('[data-apexcharts]'); - - for (var i = 0; i < els.length; i++) { - var el = els[i]; - var options = JSON.parse(els[i].getAttribute('data-options')); - var apexChart = new ApexCharts(el, options); - apexChart.render(); - } - } - /** - * This static method allows users to call chart methods without necessarily from the - * instance of the chart in case user has assigned chartID to the targeted chart. - * The chartID is used for mapping the instance stored in Apex._chartInstances global variable - * - * This is helpful in cases when you don't have reference of the chart instance - * easily and need to call the method from anywhere. - * For eg, in React/Vue applications when you have many parent/child components, - * and need easy reference to other charts for performing dynamic operations - * - * @param {string} chartID - The unique identifier which will be used to call methods - * on that chart instance - * @param {function} fn - The method name to call - * @param {object} opts - The parameters which are accepted in the original method will be passed here in the same order. - */ - - }, { - key: "exec", - value: function exec(chartID, fn) { - var chart = this.getChartByID(chartID); - if (!chart) return; // turn on the global exec flag to indicate this method was called - - chart.w.globals.isExecCalled = true; - var ret = null; - - if (chart.publicMethods.indexOf(fn) !== -1) { - for (var _len = arguments.length, opts = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { - opts[_key - 2] = arguments[_key]; - } - - ret = chart[fn].apply(chart, opts); - } - - return ret; - } - }, { - key: "merge", - value: function merge(target, source) { - return Utils$1.extend(target, source); - } - }]); - - return ApexCharts; - }(); - - return ApexCharts$1; - -})); diff --git a/cp/public/assets/libs/apexcharts/dist/apexcharts.min.js b/cp/public/assets/libs/apexcharts/dist/apexcharts.min.js deleted file mode 100644 index 2154ac6..0000000 --- a/cp/public/assets/libs/apexcharts/dist/apexcharts.min.js +++ /dev/null @@ -1,14 +0,0 @@ -/*! - * ApexCharts v3.40.0 - * (c) 2018-2023 ApexCharts - * Released under the MIT License. - */ -!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):(t="undefined"!=typeof globalThis?globalThis:t||self).ApexCharts=e()}(this,(function(){"use strict";function t(t,e){var i=Object.keys(t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);e&&(a=a.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),i.push.apply(i,a)}return i}function e(e){for(var i=1;it.length)&&(e=t.length);for(var i=0,a=new Array(e);i>16,o=i>>8&255,n=255&i;return"#"+(16777216+65536*(Math.round((a-r)*s)+r)+256*(Math.round((a-o)*s)+o)+(Math.round((a-n)*s)+n)).toString(16).slice(1)}},{key:"shadeColor",value:function(e,i){return t.isColorHex(i)?this.shadeHexColor(e,i):this.shadeRGBColor(e,i)}}],[{key:"bind",value:function(t,e){return function(){return t.apply(e,arguments)}}},{key:"isObject",value:function(t){return t&&"object"===i(t)&&!Array.isArray(t)&&null!=t}},{key:"is",value:function(t,e){return Object.prototype.toString.call(e)==="[object "+t+"]"}},{key:"listToArray",value:function(t){var e,i=[];for(e=0;ee.length?t:e}))),t.length>e.length?t:e}),0)}},{key:"hexToRgba",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"#999999",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:.6;"#"!==t.substring(0,1)&&(t="#999999");var i=t.replace("#","");i=i.match(new RegExp("(.{"+i.length/3+"})","g"));for(var a=0;a1&&void 0!==arguments[1]?arguments[1]:"x",i=t.toString().slice();return i=i.replace(/[` ~!@#$%^&*()|+\=?;:'",.<>{}[\]\\/]/gi,e)}},{key:"negToZero",value:function(t){return t<0?0:t}},{key:"moveIndexInArray",value:function(t,e,i){if(i>=t.length)for(var a=i-t.length+1;a--;)t.push(void 0);return t.splice(i,0,t.splice(e,1)[0]),t}},{key:"extractNumber",value:function(t){return parseFloat(t.replace(/[^\d.]*/g,""))}},{key:"findAncestor",value:function(t,e){for(;(t=t.parentElement)&&!t.classList.contains(e););return t}},{key:"setELstyles",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&(t.style.key=e[i])}},{key:"isNumber",value:function(t){return!isNaN(t)&&parseFloat(Number(t))===t&&!isNaN(parseInt(t,10))}},{key:"isFloat",value:function(t){return Number(t)===t&&t%1!=0}},{key:"isSafari",value:function(){return/^((?!chrome|android).)*safari/i.test(navigator.userAgent)}},{key:"isFirefox",value:function(){return navigator.userAgent.toLowerCase().indexOf("firefox")>-1}},{key:"isIE11",value:function(){if(-1!==window.navigator.userAgent.indexOf("MSIE")||window.navigator.appVersion.indexOf("Trident/")>-1)return!0}},{key:"isIE",value:function(){var t=window.navigator.userAgent,e=t.indexOf("MSIE ");if(e>0)return parseInt(t.substring(e+5,t.indexOf(".",e)),10);if(t.indexOf("Trident/")>0){var i=t.indexOf("rv:");return parseInt(t.substring(i+3,t.indexOf(".",i)),10)}var a=t.indexOf("Edge/");return a>0&&parseInt(t.substring(a+5,t.indexOf(".",a)),10)}}]),t}(),b=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.setEasingFunctions()}return r(t,[{key:"setEasingFunctions",value:function(){var t;if(!this.w.globals.easing){switch(this.w.config.chart.animations.easing){case"linear":t="-";break;case"easein":t="<";break;case"easeout":t=">";break;case"easeinout":default:t="<>";break;case"swing":t=function(t){var e=1.70158;return(t-=1)*t*((e+1)*t+e)+1};break;case"bounce":t=function(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375};break;case"elastic":t=function(t){return t===!!t?t:Math.pow(2,-10*t)*Math.sin((t-.075)*(2*Math.PI)/.3)+1}}this.w.globals.easing=t}}},{key:"animateLine",value:function(t,e,i,a){t.attr(e).animate(a).attr(i)}},{key:"animateMarker",value:function(t,e,i,a,s,r){e||(e=0),t.attr({r:e,width:e,height:e}).animate(a,s).attr({r:i,width:i.width,height:i.height}).afterAll((function(){r()}))}},{key:"animateCircle",value:function(t,e,i,a,s){t.attr({r:e.r,cx:e.cx,cy:e.cy}).animate(a,s).attr({r:i.r,cx:i.cx,cy:i.cy})}},{key:"animateRect",value:function(t,e,i,a,s){t.attr(e).animate(a).attr(i).afterAll((function(){return s()}))}},{key:"animatePathsGradually",value:function(t){var e=t.el,i=t.realIndex,a=t.j,s=t.fill,r=t.pathFrom,o=t.pathTo,n=t.speed,l=t.delay,h=this.w,c=0;h.config.chart.animations.animateGradually.enabled&&(c=h.config.chart.animations.animateGradually.delay),h.config.chart.animations.dynamicAnimation.enabled&&h.globals.dataChanged&&"bar"!==h.config.chart.type&&(c=0),this.morphSVG(e,i,a,"line"!==h.config.chart.type||h.globals.comboCharts?s:"stroke",r,o,n,l*c)}},{key:"showDelayedElements",value:function(){this.w.globals.delayedElements.forEach((function(t){t.el.classList.remove("apexcharts-element-hidden")}))}},{key:"animationCompleted",value:function(t){var e=this.w;e.globals.animationEnded||(e.globals.animationEnded=!0,this.showDelayedElements(),"function"==typeof e.config.chart.events.animationEnd&&e.config.chart.events.animationEnd(this.ctx,{el:t,w:e}))}},{key:"morphSVG",value:function(t,e,i,a,s,r,o,n){var l=this,h=this.w;s||(s=t.attr("pathFrom")),r||(r=t.attr("pathTo"));var c=function(t){return"radar"===h.config.chart.type&&(o=1),"M 0 ".concat(h.globals.gridHeight)};(!s||s.indexOf("undefined")>-1||s.indexOf("NaN")>-1)&&(s=c()),(!r||r.indexOf("undefined")>-1||r.indexOf("NaN")>-1)&&(r=c()),h.globals.shouldAnimate||(o=1),t.plot(s).animate(1,h.globals.easing,n).plot(s).animate(o,h.globals.easing,n).plot(r).afterAll((function(){x.isNumber(i)?i===h.globals.series[h.globals.maxValsInArrayIndex].length-2&&h.globals.shouldAnimate&&l.animationCompleted(t):"none"!==a&&h.globals.shouldAnimate&&(!h.globals.comboCharts&&e===h.globals.series.length-1||h.globals.comboCharts)&&l.animationCompleted(t),l.showDelayedElements()}))}}]),t}(),v=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"getDefaultFilter",value:function(t,e){var i=this.w;t.unfilter(!0),(new window.SVG.Filter).size("120%","180%","-5%","-40%"),"none"!==i.config.states.normal.filter?this.applyFilter(t,e,i.config.states.normal.filter.type,i.config.states.normal.filter.value):i.config.chart.dropShadow.enabled&&this.dropShadow(t,i.config.chart.dropShadow,e)}},{key:"addNormalFilter",value:function(t,e){var i=this.w;i.config.chart.dropShadow.enabled&&!t.node.classList.contains("apexcharts-marker")&&this.dropShadow(t,i.config.chart.dropShadow,e)}},{key:"addLightenFilter",value:function(t,e,i){var a=this,s=this.w,r=i.intensity;t.unfilter(!0);new window.SVG.Filter;t.filter((function(t){var i=s.config.chart.dropShadow;(i.enabled?a.addShadow(t,e,i):t).componentTransfer({rgb:{type:"linear",slope:1.5,intercept:r}})})),t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)}},{key:"addDarkenFilter",value:function(t,e,i){var a=this,s=this.w,r=i.intensity;t.unfilter(!0);new window.SVG.Filter;t.filter((function(t){var i=s.config.chart.dropShadow;(i.enabled?a.addShadow(t,e,i):t).componentTransfer({rgb:{type:"linear",slope:r}})})),t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)}},{key:"applyFilter",value:function(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:.5;switch(i){case"none":this.addNormalFilter(t,e);break;case"lighten":this.addLightenFilter(t,e,{intensity:a});break;case"darken":this.addDarkenFilter(t,e,{intensity:a})}}},{key:"addShadow",value:function(t,e,i){var a=i.blur,s=i.top,r=i.left,o=i.color,n=i.opacity,l=t.flood(Array.isArray(o)?o[e]:o,n).composite(t.sourceAlpha,"in").offset(r,s).gaussianBlur(a).merge(t.source);return t.blend(t.source,l)}},{key:"dropShadow",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=e.top,s=e.left,r=e.blur,o=e.color,n=e.opacity,l=e.noUserSpaceOnUse,h=this.w;return t.unfilter(!0),x.isIE()&&"radialBar"===h.config.chart.type||(o=Array.isArray(o)?o[i]:o,t.filter((function(t){var e=null;e=x.isSafari()||x.isFirefox()||x.isIE()?t.flood(o,n).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(r):t.flood(o,n).composite(t.sourceAlpha,"in").offset(s,a).gaussianBlur(r).merge(t.source),t.blend(t.source,e)})),l||t.filterer.node.setAttribute("filterUnits","userSpaceOnUse"),this._scaleFilterSize(t.filterer.node)),t}},{key:"setSelectionFilter",value:function(t,e,i){var a=this.w;if(void 0!==a.globals.selectedDataPoints[e]&&a.globals.selectedDataPoints[e].indexOf(i)>-1){t.node.setAttribute("selected",!0);var s=a.config.states.active.filter;"none"!==s&&this.applyFilter(t,e,s.type,s.value)}}},{key:"_scaleFilterSize",value:function(t){!function(e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}({width:"200%",height:"200%",x:"-50%",y:"-50%"})}}]),t}(),m=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"roundPathCorners",value:function(t,e){function i(t,e,i){var s=e.x-t.x,r=e.y-t.y,o=Math.sqrt(s*s+r*r);return a(t,e,Math.min(1,i/o))}function a(t,e,i){return{x:t.x+(e.x-t.x)*i,y:t.y+(e.y-t.y)*i}}function s(t,e){t.length>2&&(t[t.length-2]=e.x,t[t.length-1]=e.y)}function r(t){return{x:parseFloat(t[t.length-2]),y:parseFloat(t[t.length-1])}}t.indexOf("NaN")>-1&&(t="");var o=t.split(/[,\s]/).reduce((function(t,e){var i=e.match("([a-zA-Z])(.+)");return i?(t.push(i[1]),t.push(i[2])):t.push(e),t}),[]).reduce((function(t,e){return parseFloat(e)==e&&t.length?t[t.length-1].push(e):t.push([e]),t}),[]),n=[];if(o.length>1){var l=r(o[0]),h=null;"Z"==o[o.length-1][0]&&o[0].length>2&&(h=["L",l.x,l.y],o[o.length-1]=h),n.push(o[0]);for(var c=1;c2&&"L"==g[0]&&u.length>2&&"L"==u[0]){var p,f,x=r(d),b=r(g),v=r(u);p=i(b,x,e),f=i(b,v,e),s(g,p),g.origPoint=b,n.push(g);var m=a(p,b,.5),y=a(b,f,.5),w=["C",m.x,m.y,y.x,y.y,f.x,f.y];w.origPoint=b,n.push(w)}else n.push(g)}if(h){var k=r(n[n.length-1]);n.push(["Z"]),s(n[0],k)}}else n=o;return n.reduce((function(t,e){return t+e.join(" ")+" "}),"")}},{key:"drawLine",value:function(t,e,i,a){var s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"#a8a8a8",r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,o=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,n=arguments.length>7&&void 0!==arguments[7]?arguments[7]:"butt";return this.w.globals.dom.Paper.line().attr({x1:t,y1:e,x2:i,y2:a,stroke:s,"stroke-dasharray":r,"stroke-width":o,"stroke-linecap":n})}},{key:"drawRect",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"#fefefe",o=arguments.length>6&&void 0!==arguments[6]?arguments[6]:1,n=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,l=arguments.length>8&&void 0!==arguments[8]?arguments[8]:null,h=arguments.length>9&&void 0!==arguments[9]?arguments[9]:0,c=this.w.globals.dom.Paper.rect();return c.attr({x:t,y:e,width:i>0?i:0,height:a>0?a:0,rx:s,ry:s,opacity:o,"stroke-width":null!==n?n:0,stroke:null!==l?l:"none","stroke-dasharray":h}),c.node.setAttribute("fill",r),c}},{key:"drawPolygon",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"#e1e1e1",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none";return this.w.globals.dom.Paper.polygon(t).attr({fill:a,stroke:e,"stroke-width":i})}},{key:"drawCircle",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;t<0&&(t=0);var i=this.w.globals.dom.Paper.circle(2*t);return null!==e&&i.attr(e),i}},{key:"drawPath",value:function(t){var e=t.d,i=void 0===e?"":e,a=t.stroke,s=void 0===a?"#a8a8a8":a,r=t.strokeWidth,o=void 0===r?1:r,n=t.fill,l=t.fillOpacity,h=void 0===l?1:l,c=t.strokeOpacity,d=void 0===c?1:c,g=t.classes,u=t.strokeLinecap,p=void 0===u?null:u,f=t.strokeDashArray,x=void 0===f?0:f,b=this.w;return null===p&&(p=b.config.stroke.lineCap),(i.indexOf("undefined")>-1||i.indexOf("NaN")>-1)&&(i="M 0 ".concat(b.globals.gridHeight)),b.globals.dom.Paper.path(i).attr({fill:n,"fill-opacity":h,stroke:s,"stroke-opacity":d,"stroke-linecap":p,"stroke-width":o,"stroke-dasharray":x,class:g})}},{key:"group",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w.globals.dom.Paper.group();return null!==t&&e.attr(t),e}},{key:"move",value:function(t,e){var i=["M",t,e].join(" ");return i}},{key:"line",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=null;return null===i?a=[" L",t,e].join(" "):"H"===i?a=[" H",t].join(" "):"V"===i&&(a=[" V",e].join(" ")),a}},{key:"curve",value:function(t,e,i,a,s,r){var o=["C",t,e,i,a,s,r].join(" ");return o}},{key:"quadraticCurve",value:function(t,e,i,a){return["Q",t,e,i,a].join(" ")}},{key:"arc",value:function(t,e,i,a,s,r,o){var n="A";arguments.length>7&&void 0!==arguments[7]&&arguments[7]&&(n="a");var l=[n,t,e,i,a,s,r,o].join(" ");return l}},{key:"renderPaths",value:function(t){var i,a=t.j,s=t.realIndex,r=t.pathFrom,o=t.pathTo,n=t.stroke,l=t.strokeWidth,h=t.strokeLinecap,c=t.fill,d=t.animationDelay,g=t.initialSpeed,u=t.dataChangeSpeed,p=t.className,f=t.shouldClipToGrid,x=void 0===f||f,m=t.bindEventsOnPaths,y=void 0===m||m,w=t.drawShadow,k=void 0===w||w,A=this.w,S=new v(this.ctx),C=new b(this.ctx),L=this.w.config.chart.animations.enabled,P=L&&this.w.config.chart.animations.dynamicAnimation.enabled,I=!!(L&&!A.globals.resized||P&&A.globals.dataChanged&&A.globals.shouldAnimate);I?i=r:(i=o,A.globals.animationEnded=!0);var T=A.config.stroke.dashArray,M=0;M=Array.isArray(T)?T[s]:A.config.stroke.dashArray;var X=this.drawPath({d:i,stroke:n,strokeWidth:l,fill:c,fillOpacity:1,classes:p,strokeLinecap:h,strokeDashArray:M});if(X.attr("index",s),x&&X.attr({"clip-path":"url(#gridRectMask".concat(A.globals.cuid,")")}),"none"!==A.config.states.normal.filter.type)S.getDefaultFilter(X,s);else if(A.config.chart.dropShadow.enabled&&k&&(!A.config.chart.dropShadow.enabledOnSeries||A.config.chart.dropShadow.enabledOnSeries&&-1!==A.config.chart.dropShadow.enabledOnSeries.indexOf(s))){var z=A.config.chart.dropShadow;S.dropShadow(X,z,s)}y&&(X.node.addEventListener("mouseenter",this.pathMouseEnter.bind(this,X)),X.node.addEventListener("mouseleave",this.pathMouseLeave.bind(this,X)),X.node.addEventListener("mousedown",this.pathMouseDown.bind(this,X))),X.attr({pathTo:o,pathFrom:r});var E={el:X,j:a,realIndex:s,pathFrom:r,pathTo:o,fill:c,strokeWidth:l,delay:d};return!L||A.globals.resized||A.globals.dataChanged?!A.globals.resized&&A.globals.dataChanged||C.showDelayedElements():C.animatePathsGradually(e(e({},E),{},{speed:g})),A.globals.dataChanged&&P&&I&&C.animatePathsGradually(e(e({},E),{},{speed:u})),X}},{key:"drawPattern",value:function(t,e,i){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"#a8a8a8",s=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0;return this.w.globals.dom.Paper.pattern(e,i,(function(r){"horizontalLines"===t?r.line(0,0,i,0).stroke({color:a,width:s+1}):"verticalLines"===t?r.line(0,0,0,e).stroke({color:a,width:s+1}):"slantedLines"===t?r.line(0,0,e,i).stroke({color:a,width:s}):"squares"===t?r.rect(e,i).fill("none").stroke({color:a,width:s}):"circles"===t&&r.circle(e).fill("none").stroke({color:a,width:s})}))}},{key:"drawGradient",value:function(t,e,i,a,s){var r,o=arguments.length>5&&void 0!==arguments[5]?arguments[5]:null,n=arguments.length>6&&void 0!==arguments[6]?arguments[6]:null,l=arguments.length>7&&void 0!==arguments[7]?arguments[7]:null,h=arguments.length>8&&void 0!==arguments[8]?arguments[8]:0,c=this.w;e.length<9&&0===e.indexOf("#")&&(e=x.hexToRgba(e,a)),i.length<9&&0===i.indexOf("#")&&(i=x.hexToRgba(i,s));var d=0,g=1,u=1,p=null;null!==n&&(d=void 0!==n[0]?n[0]/100:0,g=void 0!==n[1]?n[1]/100:1,u=void 0!==n[2]?n[2]/100:1,p=void 0!==n[3]?n[3]/100:null);var f=!("donut"!==c.config.chart.type&&"pie"!==c.config.chart.type&&"polarArea"!==c.config.chart.type&&"bubble"!==c.config.chart.type);if(r=null===l||0===l.length?c.globals.dom.Paper.gradient(f?"radial":"linear",(function(t){t.at(d,e,a),t.at(g,i,s),t.at(u,i,s),null!==p&&t.at(p,e,a)})):c.globals.dom.Paper.gradient(f?"radial":"linear",(function(t){(Array.isArray(l[h])?l[h]:l).forEach((function(e){t.at(e.offset/100,e.color,e.opacity)}))})),f){var b=c.globals.gridWidth/2,v=c.globals.gridHeight/2;"bubble"!==c.config.chart.type?r.attr({gradientUnits:"userSpaceOnUse",cx:b,cy:v,r:o}):r.attr({cx:.5,cy:.5,r:.8,fx:.2,fy:.2})}else"vertical"===t?r.from(0,0).to(0,1):"diagonal"===t?r.from(0,0).to(1,1):"horizontal"===t?r.from(0,1).to(1,1):"diagonal2"===t&&r.from(1,0).to(0,1);return r}},{key:"getTextBasedOnMaxWidth",value:function(t){var e=t.text,i=t.maxWidth,a=t.fontSize,s=t.fontFamily,r=this.getTextRects(e,a,s),o=r.width/e.length,n=Math.floor(i/o);return i-1){var n=i.globals.selectedDataPoints[s].indexOf(r);i.globals.selectedDataPoints[s].splice(n,1)}}else{if(!i.config.states.active.allowMultipleDataPointsSelection&&i.globals.selectedDataPoints.length>0){i.globals.selectedDataPoints=[];var l=i.globals.dom.Paper.select(".apexcharts-series path").members,h=i.globals.dom.Paper.select(".apexcharts-series circle, .apexcharts-series rect").members,c=function(t){Array.prototype.forEach.call(t,(function(t){t.node.setAttribute("selected","false"),a.getDefaultFilter(t,s)}))};c(l),c(h)}t.node.setAttribute("selected","true"),o="true",void 0===i.globals.selectedDataPoints[s]&&(i.globals.selectedDataPoints[s]=[]),i.globals.selectedDataPoints[s].push(r)}if("true"===o){var d=i.config.states.active.filter;if("none"!==d)a.applyFilter(t,s,d.type,d.value);else if("none"!==i.config.states.hover.filter&&!i.globals.isTouchDevice){var g=i.config.states.hover.filter;a.applyFilter(t,s,g.type,g.value)}}else if("none"!==i.config.states.active.filter.type)if("none"===i.config.states.hover.filter.type||i.globals.isTouchDevice)a.getDefaultFilter(t,s);else{g=i.config.states.hover.filter;a.applyFilter(t,s,g.type,g.value)}"function"==typeof i.config.chart.events.dataPointSelection&&i.config.chart.events.dataPointSelection(e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:s,dataPointIndex:r,w:i}),e&&this.ctx.events.fireEvent("dataPointSelection",[e,this.ctx,{selectedDataPoints:i.globals.selectedDataPoints,seriesIndex:s,dataPointIndex:r,w:i}])}},{key:"rotateAroundCenter",value:function(t){var e={};return t&&"function"==typeof t.getBBox&&(e=t.getBBox()),{x:e.x+e.width/2,y:e.y+e.height/2}}},{key:"getTextRects",value:function(t,e,i,a){var s=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],r=this.w,o=this.drawText({x:-200,y:-200,text:t,textAnchor:"start",fontSize:e,fontFamily:i,foreColor:"#fff",opacity:0});a&&o.attr("transform",a),r.globals.dom.Paper.add(o);var n=o.bbox();return s||(n=o.node.getBoundingClientRect()),o.remove(),{width:n.width,height:n.height}}},{key:"placeTextWithEllipsis",value:function(t,e,i){if("function"==typeof t.getComputedTextLength&&(t.textContent=e,e.length>0&&t.getComputedTextLength()>=i/1.1)){for(var a=e.length-3;a>0;a-=3)if(t.getSubStringLength(0,a)<=i/1.1)return void(t.textContent=e.substring(0,a)+"...");t.textContent="."}}}],[{key:"setAttrs",value:function(t,e){for(var i in e)e.hasOwnProperty(i)&&t.setAttribute(i,e[i])}}]),t}(),y=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"getStackedSeriesTotals",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=this.w,i=[];if(0===e.globals.series.length)return i;for(var a=0;a0&&void 0!==arguments[0]?arguments[0]:null;return null===t?this.w.config.series.reduce((function(t,e){return t+e}),0):this.w.globals.series[t].reduce((function(t,e){return t+e}),0)}},{key:"isSeriesNull",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;return 0===(null===t?this.w.config.series.filter((function(t){return null!==t})):this.w.config.series[t].data.filter((function(t){return null!==t}))).length}},{key:"seriesHaveSameValues",value:function(t){return this.w.globals.series[t].every((function(t,e,i){return t===i[0]}))}},{key:"getCategoryLabels",value:function(t){var e=this.w,i=t.slice();return e.config.xaxis.convertedCatToNumeric&&(i=t.map((function(t,i){return e.config.xaxis.labels.formatter(t-e.globals.minX+1)}))),i}},{key:"getLargestSeries",value:function(){var t=this.w;t.globals.maxValsInArrayIndex=t.globals.series.map((function(t){return t.length})).indexOf(Math.max.apply(Math,t.globals.series.map((function(t){return t.length}))))}},{key:"getLargestMarkerSize",value:function(){var t=this.w,e=0;return t.globals.markers.size.forEach((function(t){e=Math.max(e,t)})),t.config.markers.discrete&&t.config.markers.discrete.length&&t.config.markers.discrete.forEach((function(t){e=Math.max(e,t.size)})),e>0&&(e+=t.config.markers.hover.sizeOffset+1),t.globals.markers.largestSize=e,e}},{key:"getSeriesTotals",value:function(){var t=this.w;t.globals.seriesTotals=t.globals.series.map((function(t,e){var i=0;if(Array.isArray(t))for(var a=0;at&&i.globals.seriesX[s][o]0&&(e=!0),{comboBarCount:i,comboCharts:e}}},{key:"extendArrayProps",value:function(t,e,i){return e.yaxis&&(e=t.extendYAxis(e,i)),e.annotations&&(e.annotations.yaxis&&(e=t.extendYAxisAnnotations(e)),e.annotations.xaxis&&(e=t.extendXAxisAnnotations(e)),e.annotations.points&&(e=t.extendPointAnnotations(e))),e}}]),t}(),w=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e}return r(t,[{key:"setOrientations",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=this.w;if("vertical"===t.label.orientation){var a=null!==e?e:0,s=i.globals.dom.baseEl.querySelector(".apexcharts-xaxis-annotations .apexcharts-xaxis-annotation-label[rel='".concat(a,"']"));if(null!==s){var r=s.getBoundingClientRect();s.setAttribute("x",parseFloat(s.getAttribute("x"))-r.height+4),"top"===t.label.position?s.setAttribute("y",parseFloat(s.getAttribute("y"))+r.width):s.setAttribute("y",parseFloat(s.getAttribute("y"))-r.width);var o=this.annoCtx.graphics.rotateAroundCenter(s),n=o.x,l=o.y;s.setAttribute("transform","rotate(-90 ".concat(n," ").concat(l,")"))}}}},{key:"addBackgroundToAnno",value:function(t,e){var i=this.w;if(!t||void 0===e.label.text||void 0!==e.label.text&&!String(e.label.text).trim())return null;var a=i.globals.dom.baseEl.querySelector(".apexcharts-grid").getBoundingClientRect(),s=t.getBoundingClientRect(),r=e.label.style.padding.left,o=e.label.style.padding.right,n=e.label.style.padding.top,l=e.label.style.padding.bottom;"vertical"===e.label.orientation&&(n=e.label.style.padding.left,l=e.label.style.padding.right,r=e.label.style.padding.top,o=e.label.style.padding.bottom);var h=s.left-a.left-r,c=s.top-a.top-n,d=this.annoCtx.graphics.drawRect(h-i.globals.barPadForNumericAxis,c,s.width+r+o,s.height+n+l,e.label.borderRadius,e.label.style.background,1,e.label.borderWidth,e.label.borderColor,0);return e.id&&d.node.classList.add(e.id),d}},{key:"annotationsBackground",value:function(){var t=this,e=this.w,i=function(i,a,s){var r=e.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations .apexcharts-").concat(s,"-annotation-label[rel='").concat(a,"']"));if(r){var o=r.parentNode,n=t.addBackgroundToAnno(r,i);n&&(o.insertBefore(n.node,r),i.label.mouseEnter&&n.node.addEventListener("mouseenter",i.label.mouseEnter.bind(t,i)),i.label.mouseLeave&&n.node.addEventListener("mouseleave",i.label.mouseLeave.bind(t,i)),i.label.click&&n.node.addEventListener("click",i.label.click.bind(t,i)))}};e.config.annotations.xaxis.map((function(t,e){i(t,e,"xaxis")})),e.config.annotations.yaxis.map((function(t,e){i(t,e,"yaxis")})),e.config.annotations.points.map((function(t,e){i(t,e,"point")}))}},{key:"getY1Y2",value:function(t,e){var i,a="y1"===t?e.y:e.y2,s=this.w;if(this.annoCtx.invertAxis){var r=s.globals.labels.indexOf(a);s.config.xaxis.convertedCatToNumeric&&(r=s.globals.categoryLabels.indexOf(a));var o=s.globals.dom.baseEl.querySelector(".apexcharts-yaxis-texts-g text:nth-child("+(r+1)+")");o&&(i=parseFloat(o.getAttribute("y")))}else{var n;if(s.config.yaxis[e.yAxisIndex].logarithmic)n=(a=new y(this.annoCtx.ctx).getLogVal(a,e.yAxisIndex))/s.globals.yLogRatio[e.yAxisIndex];else n=(a-s.globals.minYArr[e.yAxisIndex])/(s.globals.yRange[e.yAxisIndex]/s.globals.gridHeight);i=s.globals.gridHeight-n,!e.marker||void 0!==e.y&&null!==e.y||(i=0),s.config.yaxis[e.yAxisIndex]&&s.config.yaxis[e.yAxisIndex].reversed&&(i=n)}return"string"==typeof a&&a.indexOf("px")>-1&&(i=parseFloat(a)),i}},{key:"getX1X2",value:function(t,e){var i=this.w,a=this.annoCtx.invertAxis?i.globals.minY:i.globals.minX,s=this.annoCtx.invertAxis?i.globals.maxY:i.globals.maxX,r=this.annoCtx.invertAxis?i.globals.yRange[0]:i.globals.xRange,o=(e.x-a)/(r/i.globals.gridWidth);this.annoCtx.inversedReversedAxis&&(o=(s-e.x)/(r/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(o=this.getStringX(e.x));var n=(e.x2-a)/(r/i.globals.gridWidth);return this.annoCtx.inversedReversedAxis&&(n=(s-e.x2)/(r/i.globals.gridWidth)),"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric||this.annoCtx.invertAxis||i.globals.dataFormatXNumeric||(n=this.getStringX(e.x2)),void 0!==e.x&&null!==e.x||!e.marker||(o=i.globals.gridWidth),"x1"===t&&"string"==typeof e.x&&e.x.indexOf("px")>-1&&(o=parseFloat(e.x)),"x2"===t&&"string"==typeof e.x2&&e.x2.indexOf("px")>-1&&(n=parseFloat(e.x2)),"x1"===t?o:n}},{key:"getStringX",value:function(t){var e=this.w,i=t;e.config.xaxis.convertedCatToNumeric&&e.globals.categoryLabels.length&&(t=e.globals.categoryLabels.indexOf(t)+1);var a=e.globals.labels.indexOf(t),s=e.globals.dom.baseEl.querySelector(".apexcharts-xaxis-texts-g text:nth-child("+(a+1)+")");return s&&(i=parseFloat(s.getAttribute("x"))),i}}]),t}(),k=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e,this.invertAxis=this.annoCtx.invertAxis,this.helpers=new w(this.annoCtx)}return r(t,[{key:"addXaxisAnnotation",value:function(t,e,i){var a,s=this.w,r=this.helpers.getX1X2("x1",t),o=t.label.text,n=t.strokeDashArray;if(x.isNumber(r)){if(null===t.x2||void 0===t.x2){var l=this.annoCtx.graphics.drawLine(r+t.offsetX,0+t.offsetY,r+t.offsetX,s.globals.gridHeight+t.offsetY,t.borderColor,n,t.borderWidth);e.appendChild(l.node),t.id&&l.node.classList.add(t.id)}else{if((a=this.helpers.getX1X2("x2",t))o){var h=o;o=a,a=h}var c=this.annoCtx.graphics.drawRect(0+t.offsetX,a+t.offsetY,this._getYAxisAnnotationWidth(t),o-a,0,t.fillColor,t.opacity,1,t.borderColor,r);c.node.classList.add("apexcharts-annotation-rect"),c.attr("clip-path","url(#gridRectMask".concat(s.globals.cuid,")")),e.appendChild(c.node),t.id&&c.node.classList.add(t.id)}var d="right"===t.label.position?s.globals.gridWidth:"center"===t.label.position?s.globals.gridWidth/2:0,g=this.annoCtx.graphics.drawText({x:d+t.label.offsetX,y:(null!=a?a:o)+t.label.offsetY-3,text:n,textAnchor:t.label.textAnchor,fontSize:t.label.style.fontSize,fontFamily:t.label.style.fontFamily,fontWeight:t.label.style.fontWeight,foreColor:t.label.style.color,cssClass:"apexcharts-yaxis-annotation-label ".concat(t.label.style.cssClass," ").concat(t.id?t.id:"")});g.attr({rel:i}),e.appendChild(g.node)}},{key:"_getYAxisAnnotationWidth",value:function(t){var e=this.w;e.globals.gridWidth;return(t.width.indexOf("%")>-1?e.globals.gridWidth*parseInt(t.width,10)/100:parseInt(t.width,10))+t.offsetX}},{key:"drawYAxisAnnotations",value:function(){var t=this,e=this.w,i=this.annoCtx.graphics.group({class:"apexcharts-yaxis-annotations"});return e.config.annotations.yaxis.map((function(e,a){t.addYaxisAnnotation(e,i.node,a)})),i}}]),t}(),S=function(){function t(e){a(this,t),this.w=e.w,this.annoCtx=e,this.helpers=new w(this.annoCtx)}return r(t,[{key:"addPointAnnotation",value:function(t,e,i){this.w;var a=this.helpers.getX1X2("x1",t),s=this.helpers.getY1Y2("y1",t);if(x.isNumber(a)){var r={pSize:t.marker.size,pointStrokeWidth:t.marker.strokeWidth,pointFillColor:t.marker.fillColor,pointStrokeColor:t.marker.strokeColor,shape:t.marker.shape,pRadius:t.marker.radius,class:"apexcharts-point-annotation-marker ".concat(t.marker.cssClass," ").concat(t.id?t.id:"")},o=this.annoCtx.graphics.drawMarker(a+t.marker.offsetX,s+t.marker.offsetY,r);e.appendChild(o.node);var n=t.label.text?t.label.text:"",l=this.annoCtx.graphics.drawText({x:a+t.label.offsetX,y:s+t.label.offsetY-t.marker.size-parseFloat(t.label.style.fontSize)/1.6,text:n,textAnchor:t.label.textAnchor,fontSize:t.label.style.fontSize,fontFamily:t.label.style.fontFamily,fontWeight:t.label.style.fontWeight,foreColor:t.label.style.color,cssClass:"apexcharts-point-annotation-label ".concat(t.label.style.cssClass," ").concat(t.id?t.id:"")});if(l.attr({rel:i}),e.appendChild(l.node),t.customSVG.SVG){var h=this.annoCtx.graphics.group({class:"apexcharts-point-annotations-custom-svg "+t.customSVG.cssClass});h.attr({transform:"translate(".concat(a+t.customSVG.offsetX,", ").concat(s+t.customSVG.offsetY,")")}),h.node.innerHTML=t.customSVG.SVG,e.appendChild(h.node)}if(t.image.path){var c=t.image.width?t.image.width:20,d=t.image.height?t.image.height:20;o=this.annoCtx.addImage({x:a+t.image.offsetX-c/2,y:s+t.image.offsetY-d/2,width:c,height:d,path:t.image.path,appendTo:".apexcharts-point-annotations"})}t.mouseEnter&&o.node.addEventListener("mouseenter",t.mouseEnter.bind(this,t)),t.mouseLeave&&o.node.addEventListener("mouseleave",t.mouseLeave.bind(this,t)),t.click&&o.node.addEventListener("click",t.click.bind(this,t))}}},{key:"drawPointAnnotations",value:function(){var t=this,e=this.w,i=this.annoCtx.graphics.group({class:"apexcharts-point-annotations"});return e.config.annotations.points.map((function(e,a){t.addPointAnnotation(e,i.node,a)})),i}}]),t}();var C={name:"en",options:{months:["January","February","March","April","May","June","July","August","September","October","November","December"],shortMonths:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],days:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],shortDays:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],toolbar:{exportToSVG:"Download SVG",exportToPNG:"Download PNG",exportToCSV:"Download CSV",menu:"Menu",selection:"Selection",selectionZoom:"Selection Zoom",zoomIn:"Zoom In",zoomOut:"Zoom Out",pan:"Panning",reset:"Reset Zoom"}}},L=function(){function t(){a(this,t),this.yAxis={show:!0,showAlways:!1,showForNullSeries:!0,seriesName:void 0,opposite:!1,reversed:!1,logarithmic:!1,logBase:10,tickAmount:void 0,forceNiceScale:!1,max:void 0,min:void 0,floating:!1,decimalsInFloat:void 0,labels:{show:!0,minWidth:0,maxWidth:160,offsetX:0,offsetY:0,align:void 0,rotate:0,padding:20,style:{colors:[],fontSize:"11px",fontWeight:400,fontFamily:void 0,cssClass:""},formatter:void 0},axisBorder:{show:!1,color:"#e0e0e0",width:1,offsetX:0,offsetY:0},axisTicks:{show:!1,color:"#e0e0e0",width:6,offsetX:0,offsetY:0},title:{text:void 0,rotate:-90,offsetY:0,offsetX:0,style:{color:void 0,fontSize:"11px",fontWeight:900,fontFamily:void 0,cssClass:""}},tooltip:{enabled:!1,offsetX:0},crosshairs:{show:!0,position:"front",stroke:{color:"#b6b6b6",width:1,dashArray:0}}},this.pointAnnotation={id:void 0,x:0,y:null,yAxisIndex:0,seriesIndex:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,marker:{size:4,fillColor:"#fff",strokeWidth:2,strokeColor:"#333",shape:"circle",offsetX:0,offsetY:0,radius:2,cssClass:""},label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"middle",offsetX:0,offsetY:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}},customSVG:{SVG:void 0,cssClass:void 0,offsetX:0,offsetY:0},image:{path:void 0,width:20,height:20,offsetX:0,offsetY:0}},this.yAxisAnnotation={id:void 0,y:0,y2:null,strokeDashArray:1,fillColor:"#c2c2c2",borderColor:"#c2c2c2",borderWidth:1,opacity:.3,offsetX:0,offsetY:0,width:"100%",yAxisIndex:0,label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"end",position:"right",offsetX:0,offsetY:-3,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}}},this.xAxisAnnotation={id:void 0,x:0,x2:null,strokeDashArray:1,fillColor:"#c2c2c2",borderColor:"#c2c2c2",borderWidth:1,opacity:.3,offsetX:0,offsetY:0,label:{borderColor:"#c2c2c2",borderWidth:1,borderRadius:2,text:void 0,textAnchor:"middle",orientation:"vertical",position:"top",offsetX:0,offsetY:0,mouseEnter:void 0,mouseLeave:void 0,click:void 0,style:{background:"#fff",color:void 0,fontSize:"11px",fontFamily:void 0,fontWeight:400,cssClass:"",padding:{left:5,right:5,top:2,bottom:2}}}},this.text={x:0,y:0,text:"",textAnchor:"start",foreColor:void 0,fontSize:"13px",fontFamily:void 0,fontWeight:400,appendTo:".apexcharts-annotations",backgroundColor:"transparent",borderColor:"#c2c2c2",borderRadius:0,borderWidth:0,paddingLeft:4,paddingRight:4,paddingTop:2,paddingBottom:2}}return r(t,[{key:"init",value:function(){return{annotations:{yaxis:[this.yAxisAnnotation],xaxis:[this.xAxisAnnotation],points:[this.pointAnnotation],texts:[],images:[],shapes:[]},chart:{animations:{enabled:!0,easing:"easeinout",speed:800,animateGradually:{delay:150,enabled:!0},dynamicAnimation:{enabled:!0,speed:350}},background:"transparent",locales:[C],defaultLocale:"en",dropShadow:{enabled:!1,enabledOnSeries:void 0,top:2,left:2,blur:4,color:"#000",opacity:.35},events:{animationEnd:void 0,beforeMount:void 0,mounted:void 0,updated:void 0,click:void 0,mouseMove:void 0,mouseLeave:void 0,xAxisLabelClick:void 0,legendClick:void 0,markerClick:void 0,selection:void 0,dataPointSelection:void 0,dataPointMouseEnter:void 0,dataPointMouseLeave:void 0,beforeZoom:void 0,beforeResetZoom:void 0,zoomed:void 0,scrolled:void 0,brushScrolled:void 0},foreColor:"#373d3f",fontFamily:"Helvetica, Arial, sans-serif",height:"auto",parentHeightOffset:15,redrawOnParentResize:!0,redrawOnWindowResize:!0,id:void 0,group:void 0,offsetX:0,offsetY:0,selection:{enabled:!1,type:"x",fill:{color:"#24292e",opacity:.1},stroke:{width:1,color:"#24292e",opacity:.4,dashArray:3},xaxis:{min:void 0,max:void 0},yaxis:{min:void 0,max:void 0}},sparkline:{enabled:!1},brush:{enabled:!1,autoScaleYaxis:!0,target:void 0},stacked:!1,stackType:"normal",toolbar:{show:!0,offsetX:0,offsetY:0,tools:{download:!0,selection:!0,zoom:!0,zoomin:!0,zoomout:!0,pan:!0,reset:!0,customIcons:[]},export:{csv:{filename:void 0,columnDelimiter:",",headerCategory:"category",headerValue:"value",dateFormatter:function(t){return new Date(t).toDateString()}},png:{filename:void 0},svg:{filename:void 0}},autoSelected:"zoom"},type:"line",width:"100%",zoom:{enabled:!0,type:"x",autoScaleYaxis:!1,zoomedArea:{fill:{color:"#90CAF9",opacity:.4},stroke:{color:"#0D47A1",opacity:.4,width:1}}}},plotOptions:{area:{fillTo:"origin"},bar:{horizontal:!1,columnWidth:"70%",barHeight:"70%",distributed:!1,borderRadius:0,borderRadiusApplication:"around",borderRadiusWhenStacked:"last",rangeBarOverlap:!0,rangeBarGroupRows:!1,hideZeroBarsWhenGrouped:!1,isDumbbell:!1,dumbbellColors:void 0,colors:{ranges:[],backgroundBarColors:[],backgroundBarOpacity:1,backgroundBarRadius:0},dataLabels:{position:"top",maxItems:100,hideOverflowingLabels:!0,orientation:"horizontal",total:{enabled:!1,formatter:void 0,offsetX:0,offsetY:0,style:{color:"#373d3f",fontSize:"12px",fontFamily:void 0,fontWeight:600}}}},bubble:{zScaling:!0,minBubbleRadius:void 0,maxBubbleRadius:void 0},candlestick:{colors:{upward:"#00B746",downward:"#EF403C"},wick:{useFillColor:!0}},boxPlot:{colors:{upper:"#00E396",lower:"#008FFB"}},heatmap:{radius:2,enableShades:!0,shadeIntensity:.5,reverseNegativeShade:!1,distributed:!1,useFillColorAsStroke:!1,colorScale:{inverse:!1,ranges:[],min:void 0,max:void 0}},treemap:{enableShades:!0,shadeIntensity:.5,distributed:!1,reverseNegativeShade:!1,useFillColorAsStroke:!1,colorScale:{inverse:!1,ranges:[],min:void 0,max:void 0}},radialBar:{inverseOrder:!1,startAngle:0,endAngle:360,offsetX:0,offsetY:0,hollow:{margin:5,size:"50%",background:"transparent",image:void 0,imageWidth:150,imageHeight:150,imageOffsetX:0,imageOffsetY:0,imageClipped:!0,position:"front",dropShadow:{enabled:!1,top:0,left:0,blur:3,color:"#000",opacity:.5}},track:{show:!0,startAngle:void 0,endAngle:void 0,background:"#f2f2f2",strokeWidth:"97%",opacity:1,margin:5,dropShadow:{enabled:!1,top:0,left:0,blur:3,color:"#000",opacity:.5}},dataLabels:{show:!0,name:{show:!0,fontSize:"16px",fontFamily:void 0,fontWeight:600,color:void 0,offsetY:0,formatter:function(t){return t}},value:{show:!0,fontSize:"14px",fontFamily:void 0,fontWeight:400,color:void 0,offsetY:16,formatter:function(t){return t+"%"}},total:{show:!1,label:"Total",fontSize:"16px",fontWeight:600,fontFamily:void 0,color:void 0,formatter:function(t){return t.globals.seriesTotals.reduce((function(t,e){return t+e}),0)/t.globals.series.length+"%"}}}},pie:{customScale:1,offsetX:0,offsetY:0,startAngle:0,endAngle:360,expandOnClick:!0,dataLabels:{offset:0,minAngleToShowLabel:10},donut:{size:"65%",background:"transparent",labels:{show:!1,name:{show:!0,fontSize:"16px",fontFamily:void 0,fontWeight:600,color:void 0,offsetY:-10,formatter:function(t){return t}},value:{show:!0,fontSize:"20px",fontFamily:void 0,fontWeight:400,color:void 0,offsetY:10,formatter:function(t){return t}},total:{show:!1,showAlways:!1,label:"Total",fontSize:"16px",fontWeight:400,fontFamily:void 0,color:void 0,formatter:function(t){return t.globals.seriesTotals.reduce((function(t,e){return t+e}),0)}}}}},polarArea:{rings:{strokeWidth:1,strokeColor:"#e8e8e8"},spokes:{strokeWidth:1,connectorColors:"#e8e8e8"}},radar:{size:void 0,offsetX:0,offsetY:0,polygons:{strokeWidth:1,strokeColors:"#e8e8e8",connectorColors:"#e8e8e8",fill:{colors:void 0}}}},colors:void 0,dataLabels:{enabled:!0,enabledOnSeries:void 0,formatter:function(t){return null!==t?t:""},textAnchor:"middle",distributed:!1,offsetX:0,offsetY:0,style:{fontSize:"12px",fontFamily:void 0,fontWeight:600,colors:void 0},background:{enabled:!0,foreColor:"#fff",borderRadius:2,padding:4,opacity:.9,borderWidth:1,borderColor:"#fff",dropShadow:{enabled:!1,top:1,left:1,blur:1,color:"#000",opacity:.45}},dropShadow:{enabled:!1,top:1,left:1,blur:1,color:"#000",opacity:.45}},fill:{type:"solid",colors:void 0,opacity:.85,gradient:{shade:"dark",type:"horizontal",shadeIntensity:.5,gradientToColors:void 0,inverseColors:!0,opacityFrom:1,opacityTo:1,stops:[0,50,100],colorStops:[]},image:{src:[],width:void 0,height:void 0},pattern:{style:"squares",width:6,height:6,strokeWidth:2}},forecastDataPoints:{count:0,fillOpacity:.5,strokeWidth:void 0,dashArray:4},grid:{show:!0,borderColor:"#e0e0e0",strokeDashArray:0,position:"back",xaxis:{lines:{show:!1}},yaxis:{lines:{show:!0}},row:{colors:void 0,opacity:.5},column:{colors:void 0,opacity:.5},padding:{top:0,right:10,bottom:0,left:12}},labels:[],legend:{show:!0,showForSingleSeries:!1,showForNullSeries:!0,showForZeroSeries:!0,floating:!1,position:"bottom",horizontalAlign:"center",inverseOrder:!1,fontSize:"12px",fontFamily:void 0,fontWeight:400,width:void 0,height:void 0,formatter:void 0,tooltipHoverFormatter:void 0,offsetX:-20,offsetY:4,customLegendItems:[],labels:{colors:void 0,useSeriesColors:!1},markers:{width:12,height:12,strokeWidth:0,fillColors:void 0,strokeColor:"#fff",radius:12,customHTML:void 0,offsetX:0,offsetY:0,onClick:void 0},itemMargin:{horizontal:5,vertical:2},onItemClick:{toggleDataSeries:!0},onItemHover:{highlightDataSeries:!0}},markers:{discrete:[],size:0,colors:void 0,strokeColors:"#fff",strokeWidth:2,strokeOpacity:.9,strokeDashArray:0,fillOpacity:1,shape:"circle",width:8,height:8,radius:2,offsetX:0,offsetY:0,onClick:void 0,onDblClick:void 0,showNullDataPoints:!0,hover:{size:void 0,sizeOffset:3}},noData:{text:void 0,align:"center",verticalAlign:"middle",offsetX:0,offsetY:0,style:{color:void 0,fontSize:"14px",fontFamily:void 0}},responsive:[],series:void 0,states:{normal:{filter:{type:"none",value:0}},hover:{filter:{type:"lighten",value:.1}},active:{allowMultipleDataPointsSelection:!1,filter:{type:"darken",value:.5}}},title:{text:void 0,align:"left",margin:5,offsetX:0,offsetY:0,floating:!1,style:{fontSize:"14px",fontWeight:900,fontFamily:void 0,color:void 0}},subtitle:{text:void 0,align:"left",margin:5,offsetX:0,offsetY:30,floating:!1,style:{fontSize:"12px",fontWeight:400,fontFamily:void 0,color:void 0}},stroke:{show:!0,curve:"smooth",lineCap:"butt",width:2,colors:void 0,dashArray:0,fill:{type:"solid",colors:void 0,opacity:.85,gradient:{shade:"dark",type:"horizontal",shadeIntensity:.5,gradientToColors:void 0,inverseColors:!0,opacityFrom:1,opacityTo:1,stops:[0,50,100],colorStops:[]}}},tooltip:{enabled:!0,enabledOnSeries:void 0,shared:!0,followCursor:!1,intersect:!1,inverseOrder:!1,custom:void 0,fillSeriesColor:!1,theme:"light",cssClass:"",style:{fontSize:"12px",fontFamily:void 0},onDatasetHover:{highlightDataSeries:!1},x:{show:!0,format:"dd MMM",formatter:void 0},y:{formatter:void 0,title:{formatter:function(t){return t?t+": ":""}}},z:{formatter:void 0,title:"Size: "},marker:{show:!0,fillColors:void 0},items:{display:"flex"},fixed:{enabled:!1,position:"topRight",offsetX:0,offsetY:0}},xaxis:{type:"category",categories:[],convertedCatToNumeric:!1,offsetX:0,offsetY:0,overwriteCategories:void 0,labels:{show:!0,rotate:-45,rotateAlways:!1,hideOverlappingLabels:!0,trim:!1,minHeight:void 0,maxHeight:120,showDuplicates:!0,style:{colors:[],fontSize:"12px",fontWeight:400,fontFamily:void 0,cssClass:""},offsetX:0,offsetY:0,format:void 0,formatter:void 0,datetimeUTC:!0,datetimeFormatter:{year:"yyyy",month:"MMM 'yy",day:"dd MMM",hour:"HH:mm",minute:"HH:mm:ss",second:"HH:mm:ss"}},group:{groups:[],style:{colors:[],fontSize:"12px",fontWeight:400,fontFamily:void 0,cssClass:""}},axisBorder:{show:!0,color:"#e0e0e0",width:"100%",height:1,offsetX:0,offsetY:0},axisTicks:{show:!0,color:"#e0e0e0",height:6,offsetX:0,offsetY:0},tickAmount:void 0,tickPlacement:"on",min:void 0,max:void 0,range:void 0,floating:!1,decimalsInFloat:void 0,position:"bottom",title:{text:void 0,offsetX:0,offsetY:0,style:{color:void 0,fontSize:"12px",fontWeight:900,fontFamily:void 0,cssClass:""}},crosshairs:{show:!0,width:1,position:"back",opacity:.9,stroke:{color:"#b6b6b6",width:1,dashArray:3},fill:{type:"solid",color:"#B1B9C4",gradient:{colorFrom:"#D8E3F0",colorTo:"#BED1E6",stops:[0,100],opacityFrom:.4,opacityTo:.5}},dropShadow:{enabled:!1,left:0,top:0,blur:1,opacity:.4}},tooltip:{enabled:!0,offsetY:0,formatter:void 0,style:{fontSize:"12px",fontFamily:void 0}}},yaxis:this.yAxis,theme:{mode:"light",palette:"palette1",monochrome:{enabled:!1,color:"#008FFB",shadeTo:"light",shadeIntensity:.65}}}}}]),t}(),P=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.graphics=new m(this.ctx),this.w.globals.isBarHorizontal&&(this.invertAxis=!0),this.helpers=new w(this),this.xAxisAnnotations=new k(this),this.yAxisAnnotations=new A(this),this.pointsAnnotations=new S(this),this.w.globals.isBarHorizontal&&this.w.config.yaxis[0].reversed&&(this.inversedReversedAxis=!0),this.xDivision=this.w.globals.gridWidth/this.w.globals.dataPoints}return r(t,[{key:"drawAxesAnnotations",value:function(){var t=this.w;if(t.globals.axisCharts){for(var e=this.yAxisAnnotations.drawYAxisAnnotations(),i=this.xAxisAnnotations.drawXAxisAnnotations(),a=this.pointsAnnotations.drawPointAnnotations(),s=t.config.chart.animations.enabled,r=[e,i,a],o=[i.node,e.node,a.node],n=0;n<3;n++)t.globals.dom.elGraphical.add(r[n]),!s||t.globals.resized||t.globals.dataChanged||"scatter"!==t.config.chart.type&&"bubble"!==t.config.chart.type&&t.globals.dataPoints>1&&o[n].classList.add("apexcharts-element-hidden"),t.globals.delayedElements.push({el:o[n],index:0});this.helpers.annotationsBackground()}}},{key:"drawImageAnnos",value:function(){var t=this;this.w.config.annotations.images.map((function(e,i){t.addImage(e,i)}))}},{key:"drawTextAnnos",value:function(){var t=this;this.w.config.annotations.texts.map((function(e,i){t.addText(e,i)}))}},{key:"addXaxisAnnotation",value:function(t,e,i){this.xAxisAnnotations.addXaxisAnnotation(t,e,i)}},{key:"addYaxisAnnotation",value:function(t,e,i){this.yAxisAnnotations.addYaxisAnnotation(t,e,i)}},{key:"addPointAnnotation",value:function(t,e,i){this.pointsAnnotations.addPointAnnotation(t,e,i)}},{key:"addText",value:function(t,e){var i=t.x,a=t.y,s=t.text,r=t.textAnchor,o=t.foreColor,n=t.fontSize,l=t.fontFamily,h=t.fontWeight,c=t.cssClass,d=t.backgroundColor,g=t.borderWidth,u=t.strokeDashArray,p=t.borderRadius,f=t.borderColor,x=t.appendTo,b=void 0===x?".apexcharts-annotations":x,v=t.paddingLeft,m=void 0===v?4:v,y=t.paddingRight,w=void 0===y?4:y,k=t.paddingBottom,A=void 0===k?2:k,S=t.paddingTop,C=void 0===S?2:S,L=this.w,P=this.graphics.drawText({x:i,y:a,text:s,textAnchor:r||"start",fontSize:n||"12px",fontWeight:h||"regular",fontFamily:l||L.config.chart.fontFamily,foreColor:o||L.config.chart.foreColor,cssClass:c}),I=L.globals.dom.baseEl.querySelector(b);I&&I.appendChild(P.node);var T=P.bbox();if(s){var M=this.graphics.drawRect(T.x-m,T.y-C,T.width+m+w,T.height+A+C,p,d||"transparent",1,g,f,u);I.insertBefore(M.node,P.node)}}},{key:"addImage",value:function(t,e){var i=this.w,a=t.path,s=t.x,r=void 0===s?0:s,o=t.y,n=void 0===o?0:o,l=t.width,h=void 0===l?20:l,c=t.height,d=void 0===c?20:c,g=t.appendTo,u=void 0===g?".apexcharts-annotations":g,p=i.globals.dom.Paper.image(a);p.size(h,d).move(r,n);var f=i.globals.dom.baseEl.querySelector(u);return f&&f.appendChild(p.node),p}},{key:"addXaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"xaxis",contextMethod:i.addXaxisAnnotation}),i}},{key:"addYaxisAnnotationExternal",value:function(t,e,i){return this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"yaxis",contextMethod:i.addYaxisAnnotation}),i}},{key:"addPointAnnotationExternal",value:function(t,e,i){return void 0===this.invertAxis&&(this.invertAxis=i.w.globals.isBarHorizontal),this.addAnnotationExternal({params:t,pushToMemory:e,context:i,type:"point",contextMethod:i.addPointAnnotation}),i}},{key:"addAnnotationExternal",value:function(t){var e=t.params,i=t.pushToMemory,a=t.context,s=t.type,r=t.contextMethod,o=a,n=o.w,l=n.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations")),h=l.childNodes.length+1,c=new L,d=Object.assign({},"xaxis"===s?c.xAxisAnnotation:"yaxis"===s?c.yAxisAnnotation:c.pointAnnotation),g=x.extend(d,e);switch(s){case"xaxis":this.addXaxisAnnotation(g,l,h);break;case"yaxis":this.addYaxisAnnotation(g,l,h);break;case"point":this.addPointAnnotation(g,l,h)}var u=n.globals.dom.baseEl.querySelector(".apexcharts-".concat(s,"-annotations .apexcharts-").concat(s,"-annotation-label[rel='").concat(h,"']")),p=this.helpers.addBackgroundToAnno(u,g);return p&&l.insertBefore(p.node,u),i&&n.globals.memory.methodsToExec.push({context:o,id:g.id?g.id:x.randomId(),method:r,label:"addAnnotation",params:e}),a}},{key:"clearAnnotations",value:function(t){var e=t.w,i=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis-annotations, .apexcharts-xaxis-annotations, .apexcharts-point-annotations");e.globals.memory.methodsToExec.map((function(t,i){"addText"!==t.label&&"addAnnotation"!==t.label||e.globals.memory.methodsToExec.splice(i,1)})),i=x.listToArray(i),Array.prototype.forEach.call(i,(function(t){for(;t.firstChild;)t.removeChild(t.firstChild)}))}},{key:"removeAnnotation",value:function(t,e){var i=t.w,a=i.globals.dom.baseEl.querySelectorAll(".".concat(e));a&&(i.globals.memory.methodsToExec.map((function(t,a){t.id===e&&i.globals.memory.methodsToExec.splice(a,1)})),Array.prototype.forEach.call(a,(function(t){t.parentElement.removeChild(t)})))}}]),t}(),I=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.months31=[1,3,5,7,8,10,12],this.months30=[2,4,6,9,11],this.daysCntOfYear=[0,31,59,90,120,151,181,212,243,273,304,334]}return r(t,[{key:"isValidDate",value:function(t){return!isNaN(this.parseDate(t))}},{key:"getTimeStamp",value:function(t){return Date.parse(t)?this.w.config.xaxis.labels.datetimeUTC?new Date(new Date(t).toISOString().substr(0,25)).getTime():new Date(t).getTime():t}},{key:"getDate",value:function(t){return this.w.config.xaxis.labels.datetimeUTC?new Date(new Date(t).toUTCString()):new Date(t)}},{key:"parseDate",value:function(t){var e=Date.parse(t);if(!isNaN(e))return this.getTimeStamp(t);var i=Date.parse(t.replace(/-/g,"/").replace(/[a-z]+/gi," "));return i=this.getTimeStamp(i)}},{key:"parseDateWithTimezone",value:function(t){return Date.parse(t.replace(/-/g,"/").replace(/[a-z]+/gi," "))}},{key:"formatDate",value:function(t,e){var i=this.w.globals.locale,a=this.w.config.xaxis.labels.datetimeUTC,s=["\0"].concat(u(i.months)),r=["\x01"].concat(u(i.shortMonths)),o=["\x02"].concat(u(i.days)),n=["\x03"].concat(u(i.shortDays));function l(t,e){var i=t+"";for(e=e||2;i.length12?g-12:0===g?12:g;e=(e=(e=(e=e.replace(/(^|[^\\])HH+/g,"$1"+l(g))).replace(/(^|[^\\])H/g,"$1"+g)).replace(/(^|[^\\])hh+/g,"$1"+l(p))).replace(/(^|[^\\])h/g,"$1"+p);var f=a?t.getUTCMinutes():t.getMinutes();e=(e=e.replace(/(^|[^\\])mm+/g,"$1"+l(f))).replace(/(^|[^\\])m/g,"$1"+f);var x=a?t.getUTCSeconds():t.getSeconds();e=(e=e.replace(/(^|[^\\])ss+/g,"$1"+l(x))).replace(/(^|[^\\])s/g,"$1"+x);var b=a?t.getUTCMilliseconds():t.getMilliseconds();e=e.replace(/(^|[^\\])fff+/g,"$1"+l(b,3)),b=Math.round(b/10),e=e.replace(/(^|[^\\])ff/g,"$1"+l(b)),b=Math.round(b/10);var v=g<12?"AM":"PM";e=(e=(e=e.replace(/(^|[^\\])f/g,"$1"+b)).replace(/(^|[^\\])TT+/g,"$1"+v)).replace(/(^|[^\\])T/g,"$1"+v.charAt(0));var m=v.toLowerCase();e=(e=e.replace(/(^|[^\\])tt+/g,"$1"+m)).replace(/(^|[^\\])t/g,"$1"+m.charAt(0));var y=-t.getTimezoneOffset(),w=a||!y?"Z":y>0?"+":"-";if(!a){var k=(y=Math.abs(y))%60;w+=l(Math.floor(y/60))+":"+l(k)}e=e.replace(/(^|[^\\])K/g,"$1"+w);var A=(a?t.getUTCDay():t.getDay())+1;return e=(e=(e=(e=(e=e.replace(new RegExp(o[0],"g"),o[A])).replace(new RegExp(n[0],"g"),n[A])).replace(new RegExp(s[0],"g"),s[c])).replace(new RegExp(r[0],"g"),r[c])).replace(/\\(.)/g,"$1")}},{key:"getTimeUnitsfromTimestamp",value:function(t,e,i){var a=this.w;void 0!==a.config.xaxis.min&&(t=a.config.xaxis.min),void 0!==a.config.xaxis.max&&(e=a.config.xaxis.max);var s=this.getDate(t),r=this.getDate(e),o=this.formatDate(s,"yyyy MM dd HH mm ss fff").split(" "),n=this.formatDate(r,"yyyy MM dd HH mm ss fff").split(" ");return{minMillisecond:parseInt(o[6],10),maxMillisecond:parseInt(n[6],10),minSecond:parseInt(o[5],10),maxSecond:parseInt(n[5],10),minMinute:parseInt(o[4],10),maxMinute:parseInt(n[4],10),minHour:parseInt(o[3],10),maxHour:parseInt(n[3],10),minDate:parseInt(o[2],10),maxDate:parseInt(n[2],10),minMonth:parseInt(o[1],10)-1,maxMonth:parseInt(n[1],10)-1,minYear:parseInt(o[0],10),maxYear:parseInt(n[0],10)}}},{key:"isLeapYear",value:function(t){return t%4==0&&t%100!=0||t%400==0}},{key:"calculcateLastDaysOfMonth",value:function(t,e,i){return this.determineDaysOfMonths(t,e)-i}},{key:"determineDaysOfYear",value:function(t){var e=365;return this.isLeapYear(t)&&(e=366),e}},{key:"determineRemainingDaysOfYear",value:function(t,e,i){var a=this.daysCntOfYear[e]+i;return e>1&&this.isLeapYear()&&a++,a}},{key:"determineDaysOfMonths",value:function(t,e){var i=30;switch(t=x.monthMod(t),!0){case this.months30.indexOf(t)>-1:2===t&&(i=this.isLeapYear(e)?29:28);break;case this.months31.indexOf(t)>-1:default:i=31}return i}}]),t}(),T=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.tooltipKeyFormat="dd MMM"}return r(t,[{key:"xLabelFormat",value:function(t,e,i,a){var s=this.w;if("datetime"===s.config.xaxis.type&&void 0===s.config.xaxis.labels.formatter&&void 0===s.config.tooltip.x.formatter){var r=new I(this.ctx);return r.formatDate(r.getDate(e),s.config.tooltip.x.format)}return t(e,i,a)}},{key:"defaultGeneralFormatter",value:function(t){return Array.isArray(t)?t.map((function(t){return t})):t}},{key:"defaultYFormatter",value:function(t,e,i){var a=this.w;return x.isNumber(t)&&(t=0!==a.globals.yValueDecimal?t.toFixed(void 0!==e.decimalsInFloat?e.decimalsInFloat:a.globals.yValueDecimal):a.globals.maxYArr[i]-a.globals.minYArr[i]<5?t.toFixed(1):t.toFixed(0)),t}},{key:"setLabelFormatters",value:function(){var t=this,e=this.w;return e.globals.xaxisTooltipFormatter=function(e){return t.defaultGeneralFormatter(e)},e.globals.ttKeyFormatter=function(e){return t.defaultGeneralFormatter(e)},e.globals.ttZFormatter=function(t){return t},e.globals.legendFormatter=function(e){return t.defaultGeneralFormatter(e)},void 0!==e.config.xaxis.labels.formatter?e.globals.xLabelFormatter=e.config.xaxis.labels.formatter:e.globals.xLabelFormatter=function(t){if(x.isNumber(t)){if(!e.config.xaxis.convertedCatToNumeric&&"numeric"===e.config.xaxis.type){if(x.isNumber(e.config.xaxis.decimalsInFloat))return t.toFixed(e.config.xaxis.decimalsInFloat);var i=e.globals.maxX-e.globals.minX;return i>0&&i<100?t.toFixed(1):t.toFixed(0)}if(e.globals.isBarHorizontal)if(e.globals.maxY-e.globals.minYArr<4)return t.toFixed(1);return t.toFixed(0)}return t},"function"==typeof e.config.tooltip.x.formatter?e.globals.ttKeyFormatter=e.config.tooltip.x.formatter:e.globals.ttKeyFormatter=e.globals.xLabelFormatter,"function"==typeof e.config.xaxis.tooltip.formatter&&(e.globals.xaxisTooltipFormatter=e.config.xaxis.tooltip.formatter),(Array.isArray(e.config.tooltip.y)||void 0!==e.config.tooltip.y.formatter)&&(e.globals.ttVal=e.config.tooltip.y),void 0!==e.config.tooltip.z.formatter&&(e.globals.ttZFormatter=e.config.tooltip.z.formatter),void 0!==e.config.legend.formatter&&(e.globals.legendFormatter=e.config.legend.formatter),e.config.yaxis.forEach((function(i,a){void 0!==i.labels.formatter?e.globals.yLabelFormatters[a]=i.labels.formatter:e.globals.yLabelFormatters[a]=function(s){return e.globals.xyCharts?Array.isArray(s)?s.map((function(e){return t.defaultYFormatter(e,i,a)})):t.defaultYFormatter(s,i,a):s}})),e.globals}},{key:"heatmapLabelFormatters",value:function(){var t=this.w;if("heatmap"===t.config.chart.type){t.globals.yAxisScale[0].result=t.globals.seriesNames.slice();var e=t.globals.seriesNames.reduce((function(t,e){return t.length>e.length?t:e}),0);t.globals.yAxisScale[0].niceMax=e,t.globals.yAxisScale[0].niceMin=e}}}]),t}(),M=function(t){var e,i=t.isTimeline,a=t.ctx,s=t.seriesIndex,r=t.dataPointIndex,o=t.y1,n=t.y2,l=t.w,h=l.globals.seriesRangeStart[s][r],c=l.globals.seriesRangeEnd[s][r],d=l.globals.labels[r],g=l.config.series[s].name?l.config.series[s].name:"",u=l.globals.ttKeyFormatter,p=l.config.tooltip.y.title.formatter,f={w:l,seriesIndex:s,dataPointIndex:r,start:h,end:c};("function"==typeof p&&(g=p(g,f)),null!==(e=l.config.series[s].data[r])&&void 0!==e&&e.x&&(d=l.config.series[s].data[r].x),i)||"datetime"===l.config.xaxis.type&&(d=new T(a).xLabelFormat(l.globals.ttKeyFormatter,d,d,{i:void 0,dateFormatter:new I(a).formatDate,w:l}));"function"==typeof u&&(d=u(d,f)),Number.isFinite(o)&&Number.isFinite(n)&&(h=o,c=n);var x="",b="",v=l.globals.colors[s];if(void 0===l.config.tooltip.x.formatter)if("datetime"===l.config.xaxis.type){var m=new I(a);x=m.formatDate(m.getDate(h),l.config.tooltip.x.format),b=m.formatDate(m.getDate(c),l.config.tooltip.x.format)}else x=h,b=c;else x=l.config.tooltip.x.formatter(h),b=l.config.tooltip.x.formatter(c);return{start:h,end:c,startVal:x,endVal:b,ylabel:d,color:v,seriesName:g}},X=function(t){var e=t.color,i=t.seriesName,a=t.ylabel,s=t.start,r=t.end,o=t.seriesIndex,n=t.dataPointIndex,l=t.ctx.tooltip.tooltipLabels.getFormatters(o);s=l.yLbFormatter(s),r=l.yLbFormatter(r);var h=l.yLbFormatter(t.w.globals.series[o][n]),c='\n '.concat(s,'\n - \n ').concat(r,"\n ");return'
'+(i||"")+'
'+a+": "+(t.w.globals.comboCharts?"rangeArea"===t.w.config.series[o].type||"rangeBar"===t.w.config.series[o].type?c:"".concat(h,""):c)+"
"},z=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"line",value:function(){return{chart:{animations:{easing:"swing"}},dataLabels:{enabled:!1},stroke:{width:5,curve:"straight"},markers:{size:0,hover:{sizeOffset:6}},xaxis:{crosshairs:{width:1}}}}},{key:"sparkline",value:function(t){this.opts.yaxis[0].show=!1,this.opts.yaxis[0].title.text="",this.opts.yaxis[0].axisBorder.show=!1,this.opts.yaxis[0].axisTicks.show=!1,this.opts.yaxis[0].floating=!0;return x.extend(t,{grid:{show:!1,padding:{left:0,right:0,top:0,bottom:0}},legend:{show:!1},xaxis:{labels:{show:!1},tooltip:{enabled:!1},axisBorder:{show:!1},axisTicks:{show:!1}},chart:{toolbar:{show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1}})}},{key:"bar",value:function(){return{chart:{stacked:!1,animations:{easing:"swing"}},plotOptions:{bar:{dataLabels:{position:"center"}}},dataLabels:{style:{colors:["#fff"]},background:{enabled:!1}},stroke:{width:0,lineCap:"round"},fill:{opacity:.85},legend:{markers:{shape:"square",radius:2,size:8}},tooltip:{shared:!1,intersect:!0},xaxis:{tooltip:{enabled:!1},tickPlacement:"between",crosshairs:{width:"barWidth",position:"back",fill:{type:"gradient"},dropShadow:{enabled:!1},stroke:{width:0}}}}}},{key:"candlestick",value:function(){var t=this;return{stroke:{width:1,colors:["#333"]},fill:{opacity:1},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,s=e.w;return t._getBoxTooltip(s,i,a,["Open","High","","Low","Close"],"candlestick")}},states:{active:{filter:{type:"none"}}},xaxis:{crosshairs:{width:1}}}}},{key:"boxPlot",value:function(){var t=this;return{chart:{animations:{dynamicAnimation:{enabled:!1}}},stroke:{width:1,colors:["#24292e"]},dataLabels:{enabled:!1},tooltip:{shared:!0,custom:function(e){var i=e.seriesIndex,a=e.dataPointIndex,s=e.w;return t._getBoxTooltip(s,i,a,["Minimum","Q1","Median","Q3","Maximum"],"boxPlot")}},markers:{size:5,strokeWidth:1,strokeColors:"#111"},xaxis:{crosshairs:{width:1}}}}},{key:"rangeBar",value:function(){return{chart:{animations:{animateGradually:!1}},stroke:{width:0,lineCap:"square"},plotOptions:{bar:{borderRadius:0,dataLabels:{position:"center"}}},dataLabels:{enabled:!1,formatter:function(t,e){e.ctx;var i=e.seriesIndex,a=e.dataPointIndex,s=e.w,r=function(){var t=s.globals.seriesRangeStart[i][a];return s.globals.seriesRangeEnd[i][a]-t};return s.globals.comboCharts?"rangeBar"===s.config.series[i].type||"rangeArea"===s.config.series[i].type?r():t:r()},background:{enabled:!1},style:{colors:["#fff"]}},markers:{size:10},tooltip:{shared:!1,followCursor:!0,custom:function(t){return t.w.config.plotOptions&&t.w.config.plotOptions.bar&&t.w.config.plotOptions.bar.horizontal?function(t){var i=M(e(e({},t),{},{isTimeline:!0})),a=i.color,s=i.seriesName,r=i.ylabel,o=i.startVal,n=i.endVal;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t):function(t){var i=M(t),a=i.color,s=i.seriesName,r=i.ylabel,o=i.start,n=i.end;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t)}},xaxis:{tickPlacement:"between",tooltip:{enabled:!1},crosshairs:{stroke:{width:0}}}}}},{key:"dumbbell",value:function(t){var e,i;return null!==(e=t.plotOptions.bar)&&void 0!==e&&e.barHeight||(t.plotOptions.bar.barHeight=2),null!==(i=t.plotOptions.bar)&&void 0!==i&&i.columnWidth||(t.plotOptions.bar.columnWidth=2),t}},{key:"area",value:function(){return{stroke:{width:4,fill:{type:"solid",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}}},fill:{type:"gradient",gradient:{inverseColors:!1,shade:"light",type:"vertical",opacityFrom:.65,opacityTo:.5,stops:[0,100,100]}},markers:{size:0,hover:{sizeOffset:6}},tooltip:{followCursor:!1}}}},{key:"rangeArea",value:function(){return{stroke:{curve:"straight",width:0},fill:{type:"solid",opacity:.6},markers:{size:0},states:{hover:{filter:{type:"none"}},active:{filter:{type:"none"}}},tooltip:{intersect:!1,shared:!0,followCursor:!0,custom:function(t){return function(t){var i=M(t),a=i.color,s=i.seriesName,r=i.ylabel,o=i.start,n=i.end;return X(e(e({},t),{},{color:a,seriesName:s,ylabel:r,start:o,end:n}))}(t)}}}}},{key:"brush",value:function(t){return x.extend(t,{chart:{toolbar:{autoSelected:"selection",show:!1},zoom:{enabled:!1}},dataLabels:{enabled:!1},stroke:{width:1},tooltip:{enabled:!1},xaxis:{tooltip:{enabled:!1}}})}},{key:"stacked100",value:function(t){t.dataLabels=t.dataLabels||{},t.dataLabels.formatter=t.dataLabels.formatter||void 0;var e=t.dataLabels.formatter;return t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})),"bar"===t.chart.type&&(t.dataLabels.formatter=e||function(t){return"number"==typeof t&&t?t.toFixed(0)+"%":t}),t}},{key:"stackedBars",value:function(){var t=this.bar();return e(e({},t),{},{plotOptions:e(e({},t.plotOptions),{},{bar:e(e({},t.plotOptions.bar),{},{borderRadiusApplication:"end",borderRadiusWhenStacked:"last"})})})}},{key:"convertCatToNumeric",value:function(t){return t.xaxis.convertedCatToNumeric=!0,t}},{key:"convertCatToNumericXaxis",value:function(t,e,i){t.xaxis.type="numeric",t.xaxis.labels=t.xaxis.labels||{},t.xaxis.labels.formatter=t.xaxis.labels.formatter||function(t){return x.isNumber(t)?Math.floor(t):t};var a=t.xaxis.labels.formatter,s=t.xaxis.categories&&t.xaxis.categories.length?t.xaxis.categories:t.labels;return i&&i.length&&(s=i.map((function(t){return Array.isArray(t)?t:String(t)}))),s&&s.length&&(t.xaxis.labels.formatter=function(t){return x.isNumber(t)?a(s[Math.floor(t)-1]):a(t)}),t.xaxis.categories=[],t.labels=[],t.xaxis.tickAmount=t.xaxis.tickAmount||"dataPoints",t}},{key:"bubble",value:function(){return{dataLabels:{style:{colors:["#fff"]}},tooltip:{shared:!1,intersect:!0},xaxis:{crosshairs:{width:0}},fill:{type:"solid",gradient:{shade:"light",inverse:!0,shadeIntensity:.55,opacityFrom:.4,opacityTo:.8}}}}},{key:"scatter",value:function(){return{dataLabels:{enabled:!1},tooltip:{shared:!1,intersect:!0},markers:{size:6,strokeWidth:1,hover:{sizeOffset:2}}}}},{key:"heatmap",value:function(){return{chart:{stacked:!1},fill:{opacity:1},dataLabels:{style:{colors:["#fff"]}},stroke:{colors:["#fff"]},tooltip:{followCursor:!0,marker:{show:!1},x:{show:!1}},legend:{position:"top",markers:{shape:"square",size:10,offsetY:2}},grid:{padding:{right:20}}}}},{key:"treemap",value:function(){return{chart:{zoom:{enabled:!1}},dataLabels:{style:{fontSize:14,fontWeight:600,colors:["#fff"]}},stroke:{show:!0,width:2,colors:["#fff"]},legend:{show:!1},fill:{gradient:{stops:[0,100]}},tooltip:{followCursor:!0,x:{show:!1}},grid:{padding:{left:0,right:0}},xaxis:{crosshairs:{show:!1},tooltip:{enabled:!1}}}}},{key:"pie",value:function(){return{chart:{toolbar:{show:!1}},plotOptions:{pie:{donut:{labels:{show:!1}}}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",stops:[0,100]}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"donut",value:function(){return{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},style:{colors:["#fff"]},background:{enabled:!1},dropShadow:{enabled:!0}},stroke:{colors:["#fff"]},fill:{opacity:1,gradient:{shade:"light",shadeIntensity:.35,stops:[80,100],opacityFrom:1,opacityTo:1}},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"polarArea",value:function(){return this.opts.yaxis[0].tickAmount=this.opts.yaxis[0].tickAmount?this.opts.yaxis[0].tickAmount:6,{chart:{toolbar:{show:!1}},dataLabels:{formatter:function(t){return t.toFixed(1)+"%"},enabled:!1},stroke:{show:!0,width:2},fill:{opacity:.7},tooltip:{theme:"dark",fillSeriesColor:!0},legend:{position:"right"}}}},{key:"radar",value:function(){return this.opts.yaxis[0].labels.offsetY=this.opts.yaxis[0].labels.offsetY?this.opts.yaxis[0].labels.offsetY:6,{dataLabels:{enabled:!1,style:{fontSize:"11px"}},stroke:{width:2},markers:{size:3,strokeWidth:1,strokeOpacity:1},fill:{opacity:.2},tooltip:{shared:!1,intersect:!0,followCursor:!0},grid:{show:!1},xaxis:{labels:{formatter:function(t){return t},style:{colors:["#a8a8a8"],fontSize:"11px"}},tooltip:{enabled:!1},crosshairs:{show:!1}}}}},{key:"radialBar",value:function(){return{chart:{animations:{dynamicAnimation:{enabled:!0,speed:800}},toolbar:{show:!1}},fill:{gradient:{shade:"dark",shadeIntensity:.4,inverseColors:!1,type:"diagonal2",opacityFrom:1,opacityTo:1,stops:[70,98,100]}},legend:{show:!1,position:"right"},tooltip:{enabled:!1,fillSeriesColor:!0}}}},{key:"_getBoxTooltip",value:function(t,e,i,a,s){var r=t.globals.seriesCandleO[e][i],o=t.globals.seriesCandleH[e][i],n=t.globals.seriesCandleM[e][i],l=t.globals.seriesCandleL[e][i],h=t.globals.seriesCandleC[e][i];return t.config.series[e].type&&t.config.series[e].type!==s?'
\n '.concat(t.config.series[e].name?t.config.series[e].name:"series-"+(e+1),": ").concat(t.globals.series[e][i],"\n
"):'
')+"
".concat(a[0],': ')+r+"
"+"
".concat(a[1],': ')+o+"
"+(n?"
".concat(a[2],': ')+n+"
":"")+"
".concat(a[3],': ')+l+"
"+"
".concat(a[4],': ')+h+"
"}}]),t}(),E=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"init",value:function(t){var e=t.responsiveOverride,a=this.opts,s=new L,r=new z(a);this.chartType=a.chart.type,a=this.extendYAxis(a),a=this.extendAnnotations(a);var o=s.init(),n={};if(a&&"object"===i(a)){var l,h,c,d,g,u,p={};p=-1!==["line","area","bar","candlestick","boxPlot","rangeBar","rangeArea","bubble","scatter","heatmap","treemap","pie","polarArea","donut","radar","radialBar"].indexOf(a.chart.type)?r[a.chart.type]():r.line(),a.chart.stacked&&"bar"===a.chart.type&&(p=r.stackedBars()),null!==(l=a.chart.brush)&&void 0!==l&&l.enabled&&(p=r.brush(p)),a.chart.stacked&&"100%"===a.chart.stackType&&(a=r.stacked100(a)),null!==(h=a.plotOptions)&&void 0!==h&&null!==(c=h.bar)&&void 0!==c&&c.isDumbbell&&(a=r.dumbbell(a)),this.checkForDarkTheme(window.Apex),this.checkForDarkTheme(a),a.xaxis=a.xaxis||window.Apex.xaxis||{},e||(a.xaxis.convertedCatToNumeric=!1),(null!==(d=(a=this.checkForCatToNumericXAxis(this.chartType,p,a)).chart.sparkline)&&void 0!==d&&d.enabled||null!==(g=window.Apex.chart)&&void 0!==g&&null!==(u=g.sparkline)&&void 0!==u&&u.enabled)&&(p=r.sparkline(p)),n=x.extend(o,p)}var f=x.extend(n,window.Apex);return o=x.extend(f,a),o=this.handleUserInputErrors(o)}},{key:"checkForCatToNumericXAxis",value:function(t,e,i){var a,s,r=new z(i),o=("bar"===t||"boxPlot"===t)&&(null===(a=i.plotOptions)||void 0===a||null===(s=a.bar)||void 0===s?void 0:s.horizontal),n="pie"===t||"polarArea"===t||"donut"===t||"radar"===t||"radialBar"===t||"heatmap"===t,l="datetime"!==i.xaxis.type&&"numeric"!==i.xaxis.type,h=i.xaxis.tickPlacement?i.xaxis.tickPlacement:e.xaxis&&e.xaxis.tickPlacement;return o||n||!l||"between"===h||(i=r.convertCatToNumeric(i)),i}},{key:"extendYAxis",value:function(t,e){var i=new L;(void 0===t.yaxis||!t.yaxis||Array.isArray(t.yaxis)&&0===t.yaxis.length)&&(t.yaxis={}),t.yaxis.constructor!==Array&&window.Apex.yaxis&&window.Apex.yaxis.constructor!==Array&&(t.yaxis=x.extend(t.yaxis,window.Apex.yaxis)),t.yaxis.constructor!==Array?t.yaxis=[x.extend(i.yAxis,t.yaxis)]:t.yaxis=x.extendArray(t.yaxis,i.yAxis);var a=!1;t.yaxis.forEach((function(t){t.logarithmic&&(a=!0)}));var s=t.series;return e&&!s&&(s=e.config.series),a&&s.length!==t.yaxis.length&&s.length&&(t.yaxis=s.map((function(e,a){if(e.name||(s[a].name="series-".concat(a+1)),t.yaxis[a])return t.yaxis[a].seriesName=s[a].name,t.yaxis[a];var r=x.extend(i.yAxis,t.yaxis[0]);return r.show=!1,r}))),a&&s.length>1&&s.length!==t.yaxis.length&&console.warn("A multi-series logarithmic chart should have equal number of series and y-axes. Please make sure to equalize both."),t}},{key:"extendAnnotations",value:function(t){return void 0===t.annotations&&(t.annotations={},t.annotations.yaxis=[],t.annotations.xaxis=[],t.annotations.points=[]),t=this.extendYAxisAnnotations(t),t=this.extendXAxisAnnotations(t),t=this.extendPointAnnotations(t)}},{key:"extendYAxisAnnotations",value:function(t){var e=new L;return t.annotations.yaxis=x.extendArray(void 0!==t.annotations.yaxis?t.annotations.yaxis:[],e.yAxisAnnotation),t}},{key:"extendXAxisAnnotations",value:function(t){var e=new L;return t.annotations.xaxis=x.extendArray(void 0!==t.annotations.xaxis?t.annotations.xaxis:[],e.xAxisAnnotation),t}},{key:"extendPointAnnotations",value:function(t){var e=new L;return t.annotations.points=x.extendArray(void 0!==t.annotations.points?t.annotations.points:[],e.pointAnnotation),t}},{key:"checkForDarkTheme",value:function(t){t.theme&&"dark"===t.theme.mode&&(t.tooltip||(t.tooltip={}),"light"!==t.tooltip.theme&&(t.tooltip.theme="dark"),t.chart.foreColor||(t.chart.foreColor="#f6f7f8"),t.chart.background||(t.chart.background="#424242"),t.theme.palette||(t.theme.palette="palette4"))}},{key:"handleUserInputErrors",value:function(t){var e=t;if(e.tooltip.shared&&e.tooltip.intersect)throw new Error("tooltip.shared cannot be enabled when tooltip.intersect is true. Turn off any other option by setting it to false.");if("bar"===e.chart.type&&e.plotOptions.bar.horizontal){if(e.yaxis.length>1)throw new Error("Multiple Y Axis for bars are not supported. Switch to column chart by setting plotOptions.bar.horizontal=false");e.yaxis[0].reversed&&(e.yaxis[0].opposite=!0),e.xaxis.tooltip.enabled=!1,e.yaxis[0].tooltip.enabled=!1,e.chart.zoom.enabled=!1}return"bar"!==e.chart.type&&"rangeBar"!==e.chart.type||e.tooltip.shared&&"barWidth"===e.xaxis.crosshairs.width&&e.series.length>1&&(e.xaxis.crosshairs.width="tickWidth"),"candlestick"!==e.chart.type&&"boxPlot"!==e.chart.type||e.yaxis[0].reversed&&(console.warn("Reversed y-axis in ".concat(e.chart.type," chart is not supported.")),e.yaxis[0].reversed=!1),e}}]),t}(),Y=function(){function t(){a(this,t)}return r(t,[{key:"initGlobalVars",value:function(t){t.series=[],t.seriesCandleO=[],t.seriesCandleH=[],t.seriesCandleM=[],t.seriesCandleL=[],t.seriesCandleC=[],t.seriesRangeStart=[],t.seriesRangeEnd=[],t.seriesRange=[],t.seriesPercent=[],t.seriesGoals=[],t.seriesX=[],t.seriesZ=[],t.seriesNames=[],t.seriesTotals=[],t.seriesLog=[],t.seriesColors=[],t.stackedSeriesTotals=[],t.seriesXvalues=[],t.seriesYvalues=[],t.labels=[],t.hasXaxisGroups=!1,t.groups=[],t.hasSeriesGroups=!1,t.seriesGroups=[],t.categoryLabels=[],t.timescaleLabels=[],t.noLabelsProvided=!1,t.resizeTimer=null,t.selectionResizeTimer=null,t.delayedElements=[],t.pointsArray=[],t.dataLabelsRects=[],t.isXNumeric=!1,t.skipLastTimelinelabel=!1,t.skipFirstTimelinelabel=!1,t.isDataXYZ=!1,t.isMultiLineX=!1,t.isMultipleYAxis=!1,t.maxY=-Number.MAX_VALUE,t.minY=Number.MIN_VALUE,t.minYArr=[],t.maxYArr=[],t.maxX=-Number.MAX_VALUE,t.minX=Number.MAX_VALUE,t.initialMaxX=-Number.MAX_VALUE,t.initialMinX=Number.MAX_VALUE,t.maxDate=0,t.minDate=Number.MAX_VALUE,t.minZ=Number.MAX_VALUE,t.maxZ=-Number.MAX_VALUE,t.minXDiff=Number.MAX_VALUE,t.yAxisScale=[],t.xAxisScale=null,t.xAxisTicksPositions=[],t.yLabelsCoords=[],t.yTitleCoords=[],t.barPadForNumericAxis=0,t.padHorizontal=0,t.xRange=0,t.yRange=[],t.zRange=0,t.dataPoints=0,t.xTickAmount=0}},{key:"globalVars",value:function(t){return{chartID:null,cuid:null,events:{beforeMount:[],mounted:[],updated:[],clicked:[],selection:[],dataPointSelection:[],zoomed:[],scrolled:[]},colors:[],clientX:null,clientY:null,fill:{colors:[]},stroke:{colors:[]},dataLabels:{style:{colors:[]}},radarPolygons:{fill:{colors:[]}},markers:{colors:[],size:t.markers.size,largestSize:0},animationEnded:!1,isTouchDevice:"ontouchstart"in window||navigator.msMaxTouchPoints,isDirty:!1,isExecCalled:!1,initialConfig:null,initialSeries:[],lastXAxis:[],lastYAxis:[],columnSeries:null,labels:[],timescaleLabels:[],noLabelsProvided:!1,allSeriesCollapsed:!1,collapsedSeries:[],collapsedSeriesIndices:[],ancillaryCollapsedSeries:[],ancillaryCollapsedSeriesIndices:[],risingSeries:[],dataFormatXNumeric:!1,capturedSeriesIndex:-1,capturedDataPointIndex:-1,selectedDataPoints:[],goldenPadding:35,invalidLogScale:!1,ignoreYAxisIndexes:[],yAxisSameScaleIndices:[],maxValsInArrayIndex:0,radialSize:0,selection:void 0,zoomEnabled:"zoom"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.zoom&&t.chart.zoom.enabled,panEnabled:"pan"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.pan,selectionEnabled:"selection"===t.chart.toolbar.autoSelected&&t.chart.toolbar.tools.selection,yaxis:null,mousedown:!1,lastClientPosition:{},visibleXRange:void 0,yValueDecimal:0,total:0,SVGNS:"http://www.w3.org/2000/svg",svgWidth:0,svgHeight:0,noData:!1,locale:{},dom:{},memory:{methodsToExec:[]},shouldAnimate:!0,skipLastTimelinelabel:!1,skipFirstTimelinelabel:!1,delayedElements:[],axisCharts:!0,isDataXYZ:!1,resized:!1,resizeTimer:null,comboCharts:!1,dataChanged:!1,previousPaths:[],allSeriesHasEqualX:!0,pointsArray:[],dataLabelsRects:[],lastDrawnDataLabelsIndexes:[],hasNullValues:!1,easing:null,zoomed:!1,gridWidth:0,gridHeight:0,rotateXLabels:!1,defaultLabels:!1,xLabelFormatter:void 0,yLabelFormatters:[],xaxisTooltipFormatter:void 0,ttKeyFormatter:void 0,ttVal:void 0,ttZFormatter:void 0,LINE_HEIGHT_RATIO:1.618,xAxisLabelsHeight:0,xAxisGroupLabelsHeight:0,xAxisLabelsWidth:0,yAxisLabelsWidth:0,scaleX:1,scaleY:1,translateX:0,translateY:0,translateYAxisX:[],yAxisWidths:[],translateXAxisY:0,translateXAxisX:0,tooltip:null}}},{key:"init",value:function(t){var e=this.globalVars(t);return this.initGlobalVars(e),e.initialConfig=x.extend({},t),e.initialSeries=x.clone(t.series),e.lastXAxis=x.clone(e.initialConfig.xaxis),e.lastYAxis=x.clone(e.initialConfig.yaxis),e}}]),t}(),F=function(){function t(e){a(this,t),this.opts=e}return r(t,[{key:"init",value:function(){var t=new E(this.opts).init({responsiveOverride:!1});return{config:t,globals:(new Y).init(t)}}}]),t}(),R=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.opts=null,this.seriesIndex=0}return r(t,[{key:"clippedImgArea",value:function(t){var e=this.w,i=e.config,a=parseInt(e.globals.gridWidth,10),s=parseInt(e.globals.gridHeight,10),r=a>s?a:s,o=t.image,n=0,l=0;void 0===t.width&&void 0===t.height?void 0!==i.fill.image.width&&void 0!==i.fill.image.height?(n=i.fill.image.width+1,l=i.fill.image.height):(n=r+1,l=r):(n=t.width,l=t.height);var h=document.createElementNS(e.globals.SVGNS,"pattern");m.setAttrs(h,{id:t.patternID,patternUnits:t.patternUnits?t.patternUnits:"userSpaceOnUse",width:n+"px",height:l+"px"});var c=document.createElementNS(e.globals.SVGNS,"image");h.appendChild(c),c.setAttributeNS(window.SVG.xlink,"href",o),m.setAttrs(c,{x:0,y:0,preserveAspectRatio:"none",width:n+"px",height:l+"px"}),c.style.opacity=t.opacity,e.globals.dom.elDefs.node.appendChild(h)}},{key:"getSeriesIndex",value:function(t){var e=this.w;return("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||"heatmap"===e.config.chart.type||"treemap"===e.config.chart.type?this.seriesIndex=t.seriesNumber:this.seriesIndex=t.seriesNumber%e.globals.series.length,this.seriesIndex}},{key:"fillPath",value:function(t){var e=this.w;this.opts=t;var i,a,s,r=this.w.config;this.seriesIndex=this.getSeriesIndex(t);var o=this.getFillColors()[this.seriesIndex];void 0!==e.globals.seriesColors[this.seriesIndex]&&(o=e.globals.seriesColors[this.seriesIndex]),"function"==typeof o&&(o=o({seriesIndex:this.seriesIndex,dataPointIndex:t.dataPointIndex,value:t.value,w:e}));var n=t.fillType?t.fillType:this.getFillType(this.seriesIndex),l=Array.isArray(r.fill.opacity)?r.fill.opacity[this.seriesIndex]:r.fill.opacity;t.color&&(o=t.color);var h=o;if(-1===o.indexOf("rgb")?o.length<9&&(h=x.hexToRgba(o,l)):o.indexOf("rgba")>-1&&(l=x.getOpacityFromRGBA(o)),t.opacity&&(l=t.opacity),"pattern"===n&&(a=this.handlePatternFill({fillConfig:t.fillConfig,patternFill:a,fillColor:o,fillOpacity:l,defaultColor:h})),"gradient"===n&&(s=this.handleGradientFill({fillConfig:t.fillConfig,fillColor:o,fillOpacity:l,i:this.seriesIndex})),"image"===n){var c=r.fill.image.src,d=t.patternID?t.patternID:"";this.clippedImgArea({opacity:l,image:Array.isArray(c)?t.seriesNumber-1&&(u=x.getOpacityFromRGBA(g));var p=void 0===o.gradient.opacityTo?a:Array.isArray(o.gradient.opacityTo)?o.gradient.opacityTo[r]:o.gradient.opacityTo;if(void 0===o.gradient.gradientToColors||0===o.gradient.gradientToColors.length)n="dark"===o.gradient.shade?c.shadeColor(-1*parseFloat(o.gradient.shadeIntensity),i.indexOf("rgb")>-1?x.rgb2hex(i):i):c.shadeColor(parseFloat(o.gradient.shadeIntensity),i.indexOf("rgb")>-1?x.rgb2hex(i):i);else if(o.gradient.gradientToColors[l.seriesNumber]){var f=o.gradient.gradientToColors[l.seriesNumber];n=f,f.indexOf("rgba")>-1&&(p=x.getOpacityFromRGBA(f))}else n=i;if(o.gradient.gradientFrom&&(g=o.gradient.gradientFrom),o.gradient.gradientTo&&(n=o.gradient.gradientTo),o.gradient.inverseColors){var b=g;g=n,n=b}return g.indexOf("rgb")>-1&&(g=x.rgb2hex(g)),n.indexOf("rgb")>-1&&(n=x.rgb2hex(n)),h.drawGradient(d,g,n,u,p,l.size,o.gradient.stops,o.gradient.colorStops,r)}}]),t}(),D=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"setGlobalMarkerSize",value:function(){var t=this.w;if(t.globals.markers.size=Array.isArray(t.config.markers.size)?t.config.markers.size:[t.config.markers.size],t.globals.markers.size.length>0){if(t.globals.markers.size.length4&&void 0!==arguments[4]&&arguments[4],o=this.w,n=e,l=t,h=null,c=new m(this.ctx),d=o.config.markers.discrete&&o.config.markers.discrete.length;if((o.globals.markers.size[e]>0||r||d)&&(h=c.group({class:r||d?"":"apexcharts-series-markers"})).attr("clip-path","url(#gridRectMarkerMask".concat(o.globals.cuid,")")),Array.isArray(l.x))for(var g=0;g0:o.config.markers.size>0)||r||d){x.isNumber(l.y[g])?p+=" w".concat(x.randomId()):p="apexcharts-nullpoint";var f=this.getMarkerConfig({cssClass:p,seriesIndex:e,dataPointIndex:u});o.config.series[n].data[u]&&(o.config.series[n].data[u].fillColor&&(f.pointFillColor=o.config.series[n].data[u].fillColor),o.config.series[n].data[u].strokeColor&&(f.pointStrokeColor=o.config.series[n].data[u].strokeColor)),a&&(f.pSize=a),(l.x[g]<0||l.x[g]>o.globals.gridWidth||l.y[g]<0||l.y[g]>o.globals.gridHeight)&&(f.pSize=0),(s=c.drawMarker(l.x[g],l.y[g],f)).attr("rel",u),s.attr("j",u),s.attr("index",e),s.node.setAttribute("default-marker-size",f.pSize),new v(this.ctx).setSelectionFilter(s,e,u),this.addEvents(s),h&&h.add(s)}else void 0===o.globals.pointsArray[e]&&(o.globals.pointsArray[e]=[]),o.globals.pointsArray[e].push([l.x[g],l.y[g]])}return h}},{key:"getMarkerConfig",value:function(t){var e=t.cssClass,i=t.seriesIndex,a=t.dataPointIndex,s=void 0===a?null:a,r=t.finishRadius,o=void 0===r?null:r,n=this.w,l=this.getMarkerStyle(i),h=n.globals.markers.size[i],c=n.config.markers;return null!==s&&c.discrete.length&&c.discrete.map((function(t){t.seriesIndex===i&&t.dataPointIndex===s&&(l.pointStrokeColor=t.strokeColor,l.pointFillColor=t.fillColor,h=t.size,l.pointShape=t.shape)})),{pSize:null===o?h:o,pRadius:c.radius,width:Array.isArray(c.width)?c.width[i]:c.width,height:Array.isArray(c.height)?c.height[i]:c.height,pointStrokeWidth:Array.isArray(c.strokeWidth)?c.strokeWidth[i]:c.strokeWidth,pointStrokeColor:l.pointStrokeColor,pointFillColor:l.pointFillColor,shape:l.pointShape||(Array.isArray(c.shape)?c.shape[i]:c.shape),class:e,pointStrokeOpacity:Array.isArray(c.strokeOpacity)?c.strokeOpacity[i]:c.strokeOpacity,pointStrokeDashArray:Array.isArray(c.strokeDashArray)?c.strokeDashArray[i]:c.strokeDashArray,pointFillOpacity:Array.isArray(c.fillOpacity)?c.fillOpacity[i]:c.fillOpacity,seriesIndex:i}}},{key:"addEvents",value:function(t){var e=this.w,i=new m(this.ctx);t.node.addEventListener("mouseenter",i.pathMouseEnter.bind(this.ctx,t)),t.node.addEventListener("mouseleave",i.pathMouseLeave.bind(this.ctx,t)),t.node.addEventListener("mousedown",i.pathMouseDown.bind(this.ctx,t)),t.node.addEventListener("click",e.config.markers.onClick),t.node.addEventListener("dblclick",e.config.markers.onDblClick),t.node.addEventListener("touchstart",i.pathMouseDown.bind(this.ctx,t),{passive:!0})}},{key:"getMarkerStyle",value:function(t){var e=this.w,i=e.globals.markers.colors,a=e.config.markers.strokeColor||e.config.markers.strokeColors;return{pointStrokeColor:Array.isArray(a)?a[t]:a,pointFillColor:Array.isArray(i)?i[t]:i}}}]),t}(),H=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.initialAnim=this.w.config.chart.animations.enabled,this.dynamicAnim=this.initialAnim&&this.w.config.chart.animations.dynamicAnimation.enabled}return r(t,[{key:"draw",value:function(t,e,i){var a=this.w,s=new m(this.ctx),r=i.realIndex,o=i.pointsPos,n=i.zRatio,l=i.elParent,h=s.group({class:"apexcharts-series-markers apexcharts-series-".concat(a.config.chart.type)});if(h.attr("clip-path","url(#gridRectMarkerMask".concat(a.globals.cuid,")")),Array.isArray(o.x))for(var c=0;cf.maxBubbleRadius&&(p=f.maxBubbleRadius)}a.config.chart.animations.enabled||(u=p);var x=o.x[c],b=o.y[c];if(u=u||0,null!==b&&void 0!==a.globals.series[r][d]||(g=!1),g){var v=this.drawPoint(x,b,u,p,r,d,e);h.add(v)}l.add(h)}}},{key:"drawPoint",value:function(t,e,i,a,s,r,o){var n=this.w,l=s,h=new b(this.ctx),c=new v(this.ctx),d=new R(this.ctx),g=new D(this.ctx),u=new m(this.ctx),p=g.getMarkerConfig({cssClass:"apexcharts-marker",seriesIndex:l,dataPointIndex:r,finishRadius:"bubble"===n.config.chart.type||n.globals.comboCharts&&n.config.series[s]&&"bubble"===n.config.series[s].type?a:null});a=p.pSize;var f,x=d.fillPath({seriesNumber:s,dataPointIndex:r,color:p.pointFillColor,patternUnits:"objectBoundingBox",value:n.globals.series[s][o]});if("circle"===p.shape?f=u.drawCircle(i):"square"!==p.shape&&"rect"!==p.shape||(f=u.drawRect(0,0,p.width-p.pointStrokeWidth/2,p.height-p.pointStrokeWidth/2,p.pRadius)),n.config.series[l].data[r]&&n.config.series[l].data[r].fillColor&&(x=n.config.series[l].data[r].fillColor),f.attr({x:t-p.width/2-p.pointStrokeWidth/2,y:e-p.height/2-p.pointStrokeWidth/2,cx:t,cy:e,fill:x,"fill-opacity":p.pointFillOpacity,stroke:p.pointStrokeColor,r:a,"stroke-width":p.pointStrokeWidth,"stroke-dasharray":p.pointStrokeDashArray,"stroke-opacity":p.pointStrokeOpacity}),n.config.chart.dropShadow.enabled){var y=n.config.chart.dropShadow;c.dropShadow(f,y,s)}if(!this.initialAnim||n.globals.dataChanged||n.globals.resized)n.globals.animationEnded=!0;else{var w=n.config.chart.animations.speed;h.animateMarker(f,0,"circle"===p.shape?a:{width:p.width,height:p.height},w,n.globals.easing,(function(){window.setTimeout((function(){h.animationCompleted(f)}),100)}))}if(n.globals.dataChanged&&"circle"===p.shape)if(this.dynamicAnim){var k,A,S,C,L=n.config.chart.animations.dynamicAnimation.speed;null!=(C=n.globals.previousPaths[s]&&n.globals.previousPaths[s][o])&&(k=C.x,A=C.y,S=void 0!==C.r?C.r:a);for(var P=0;Pn.globals.gridHeight+d&&(e=n.globals.gridHeight+d/2),void 0===n.globals.dataLabelsRects[a]&&(n.globals.dataLabelsRects[a]=[]),n.globals.dataLabelsRects[a].push({x:t,y:e,width:c,height:d});var g=n.globals.dataLabelsRects[a].length-2,u=void 0!==n.globals.lastDrawnDataLabelsIndexes[a]?n.globals.lastDrawnDataLabelsIndexes[a][n.globals.lastDrawnDataLabelsIndexes[a].length-1]:0;if(void 0!==n.globals.dataLabelsRects[a][g]){var p=n.globals.dataLabelsRects[a][u];(t>p.x+p.width+2||e>p.y+p.height+2||t+ce.globals.gridWidth+f.textRects.width+10)&&(n="");var x=e.globals.dataLabels.style.colors[r];(("bar"===e.config.chart.type||"rangeBar"===e.config.chart.type)&&e.config.plotOptions.bar.distributed||e.config.dataLabels.distributed)&&(x=e.globals.dataLabels.style.colors[o]),"function"==typeof x&&(x=x({series:e.globals.series,seriesIndex:r,dataPointIndex:o,w:e})),g&&(x=g);var b=d.offsetX,y=d.offsetY;if("bar"!==e.config.chart.type&&"rangeBar"!==e.config.chart.type||(b=0,y=0),f.drawnextLabel){var w=i.drawText({width:100,height:parseInt(d.style.fontSize,10),x:a+b,y:s+y,foreColor:x,textAnchor:l||d.textAnchor,text:n,fontSize:h||d.style.fontSize,fontFamily:d.style.fontFamily,fontWeight:d.style.fontWeight||"normal"});if(w.attr({class:"apexcharts-datalabel",cx:a,cy:s}),d.dropShadow.enabled){var k=d.dropShadow;new v(this.ctx).dropShadow(w,k)}c.add(w),void 0===e.globals.lastDrawnDataLabelsIndexes[r]&&(e.globals.lastDrawnDataLabelsIndexes[r]=[]),e.globals.lastDrawnDataLabelsIndexes[r].push(o)}}}},{key:"addBackgroundToDataLabel",value:function(t,e){var i=this.w,a=i.config.dataLabels.background,s=a.padding,r=a.padding/2,o=e.width,n=e.height,l=new m(this.ctx).drawRect(e.x-s,e.y-r/2,o+2*s,n+r,a.borderRadius,"transparent"===i.config.chart.background?"#fff":i.config.chart.background,a.opacity,a.borderWidth,a.borderColor);a.dropShadow.enabled&&new v(this.ctx).dropShadow(l,a.dropShadow);return l}},{key:"dataLabelsBackground",value:function(){var t=this.w;if("bubble"!==t.config.chart.type)for(var e=t.globals.dom.baseEl.querySelectorAll(".apexcharts-datalabels text"),i=0;i0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w,s=x.clone(a.globals.initialSeries);a.globals.previousPaths=[],i?(a.globals.collapsedSeries=[],a.globals.ancillaryCollapsedSeries=[],a.globals.collapsedSeriesIndices=[],a.globals.ancillaryCollapsedSeriesIndices=[]):s=this.emptyCollapsedSeries(s),a.config.series=s,t&&(e&&(a.globals.zoomed=!1,this.ctx.updateHelpers.revertDefaultAxisMinMax()),this.ctx.updateHelpers._updateSeries(s,a.config.chart.animations.dynamicAnimation.enabled))}},{key:"emptyCollapsedSeries",value:function(t){for(var e=this.w,i=0;i-1&&(t[i].data=[]);return t}},{key:"toggleSeriesOnHover",value:function(t,e){var i=this.w;e||(e=t.target);var a=i.globals.dom.baseEl.querySelectorAll(".apexcharts-series, .apexcharts-datalabels");if("mousemove"===t.type){var s=parseInt(e.getAttribute("rel"),10)-1,r=null,o=null;i.globals.axisCharts||"radialBar"===i.config.chart.type?i.globals.axisCharts?(r=i.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(s,"']")),o=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels[data\\:realIndex='".concat(s,"']"))):r=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(s+1,"']")):r=i.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(s+1,"'] path"));for(var n=0;n=t.from&&a<=t.to&&s[e].classList.remove(i.legendInactiveClass)}}(a.config.plotOptions.heatmap.colorScale.ranges[o])}else"mouseout"===t.type&&r("remove")}},{key:"getActiveConfigSeriesIndex",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"asc",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],i=this.w,a=0;if(i.config.series.length>1)for(var s=i.config.series.map((function(t,a){return t.data&&t.data.length>0&&-1===i.globals.collapsedSeriesIndices.indexOf(a)&&(!i.globals.comboCharts||0===e.length||e.length&&e.indexOf(i.config.series[a].type)>-1)?a:-1})),r="asc"===t?0:s.length-1;"asc"===t?r=0;"asc"===t?r++:r--)if(-1!==s[r]){a=s[r];break}return a}},{key:"getBarSeriesIndices",value:function(){return this.w.globals.comboCharts?this.w.config.series.map((function(t,e){return"bar"===t.type||"column"===t.type?e:-1})).filter((function(t){return-1!==t})):this.w.config.series.map((function(t,e){return e}))}},{key:"getPreviousPaths",value:function(){var t=this.w;function e(e,i,a){for(var s=e[i].childNodes,r={type:a,paths:[],realIndex:e[i].getAttribute("data:realIndex")},o=0;o0)for(var a=function(e){for(var i=t.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(t.config.chart.type," .apexcharts-series[data\\:realIndex='").concat(e,"'] rect")),a=[],s=function(t){var e=function(e){return i[t].getAttribute(e)},s={x:parseFloat(e("x")),y:parseFloat(e("y")),width:parseFloat(e("width")),height:parseFloat(e("height"))};a.push({rect:s,color:i[t].getAttribute("color")})},r=0;r0)for(var a=0;a0?t:[]}));return t}}]),t}(),W=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.twoDSeries=[],this.threeDSeries=[],this.twoDSeriesX=[],this.seriesGoals=[],this.coreUtils=new y(this.ctx)}return r(t,[{key:"isMultiFormat",value:function(){return this.isFormatXY()||this.isFormat2DArray()}},{key:"isFormatXY",value:function(){var t=this.w.config.series.slice(),e=new N(this.ctx);if(this.activeSeriesIndex=e.getActiveConfigSeriesIndex(),void 0!==t[this.activeSeriesIndex].data&&t[this.activeSeriesIndex].data.length>0&&null!==t[this.activeSeriesIndex].data[0]&&void 0!==t[this.activeSeriesIndex].data[0].x&&null!==t[this.activeSeriesIndex].data[0])return!0}},{key:"isFormat2DArray",value:function(){var t=this.w.config.series.slice(),e=new N(this.ctx);if(this.activeSeriesIndex=e.getActiveConfigSeriesIndex(),void 0!==t[this.activeSeriesIndex].data&&t[this.activeSeriesIndex].data.length>0&&void 0!==t[this.activeSeriesIndex].data[0]&&null!==t[this.activeSeriesIndex].data[0]&&t[this.activeSeriesIndex].data[0].constructor===Array)return!0}},{key:"handleFormat2DArray",value:function(t,e){for(var i=this.w.config,a=this.w.globals,s="boxPlot"===i.chart.type||"boxPlot"===i.series[e].type,r=0;r=5?this.twoDSeries.push(x.parseNumber(t[e].data[r][4])):this.twoDSeries.push(x.parseNumber(t[e].data[r][1])),a.dataFormatXNumeric=!0),"datetime"===i.xaxis.type){var o=new Date(t[e].data[r][0]);o=new Date(o).getTime(),this.twoDSeriesX.push(o)}else this.twoDSeriesX.push(t[e].data[r][0]);for(var n=0;n-1&&(r=this.activeSeriesIndex);for(var o=0;o1&&void 0!==arguments[1]?arguments[1]:this.ctx,s=this.w.config,r=this.w.globals,o=new I(a),n=s.labels.length>0?s.labels.slice():s.xaxis.categories.slice();if(r.isRangeBar="rangeBar"===s.chart.type&&r.isBarHorizontal,r.hasXaxisGroups="category"===s.xaxis.type&&s.xaxis.group.groups.length>0,r.hasXaxisGroups&&(r.groups=s.xaxis.group.groups),r.hasSeriesGroups=null===(e=t[0])||void 0===e?void 0:e.group,r.hasSeriesGroups){var l=[],h=u(new Set(t.map((function(t){return t.group}))));t.forEach((function(t,e){var i=h.indexOf(t.group);l[i]||(l[i]=[]),l[i].push(t.name)})),r.seriesGroups=l}for(var c=function(){for(var t=0;t0&&(this.twoDSeriesX=n,r.seriesX.push(this.twoDSeriesX))),r.labels.push(this.twoDSeriesX);var g=t[d].data.map((function(t){return x.parseNumber(t)}));r.series.push(g)}r.seriesZ.push(this.threeDSeries),void 0!==t[d].name?r.seriesNames.push(t[d].name):r.seriesNames.push("series-"+parseInt(d+1,10)),void 0!==t[d].color?r.seriesColors.push(t[d].color):r.seriesColors.push(void 0)}return this.w}},{key:"parseDataNonAxisCharts",value:function(t){var e=this.w.globals,i=this.w.config;e.series=t.slice(),e.seriesNames=i.labels.slice();for(var a=0;a0)i.labels=e.xaxis.categories;else if(e.labels.length>0)i.labels=e.labels.slice();else if(this.fallbackToCategory){if(i.labels=i.labels[0],i.seriesRange.length&&(i.seriesRange.map((function(t){t.forEach((function(t){i.labels.indexOf(t.x)<0&&t.x&&i.labels.push(t.x)}))})),i.labels=i.labels.filter((function(t,e,i){return i.indexOf(t)===e}))),e.xaxis.convertedCatToNumeric)new z(e).convertCatToNumericXaxis(e,this.ctx,i.seriesX[0]),this._generateExternalLabels(t)}else this._generateExternalLabels(t)}},{key:"_generateExternalLabels",value:function(t){var e=this.w.globals,i=this.w.config,a=[];if(e.axisCharts){if(e.series.length>0)if(this.isFormatXY())for(var s=i.series.map((function(t,e){return t.data.filter((function(t,e,i){return i.findIndex((function(e){return e.x===t.x}))===e}))})),r=s.reduce((function(t,e,i,a){return a[t].length>e.length?t:i}),0),o=0;o4&&void 0!==arguments[4]?arguments[4]:[],r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"12px",o=!(arguments.length>6&&void 0!==arguments[6])||arguments[6],n=this.w,l=void 0===t[a]?"":t[a],h=l,c=n.globals.xLabelFormatter,d=n.config.xaxis.labels.formatter,g=!1,u=new T(this.ctx),p=l;o&&(h=u.xLabelFormat(c,l,p,{i:a,dateFormatter:new I(this.ctx).formatDate,w:n}),void 0!==d&&(h=d(l,t[a],{i:a,dateFormatter:new I(this.ctx).formatDate,w:n})));var f,x;e.length>0?(f=e[a].unit,x=null,e.forEach((function(t){"month"===t.unit?x="year":"day"===t.unit?x="month":"hour"===t.unit?x="day":"minute"===t.unit&&(x="hour")})),g=x===f,i=e[a].position,h=e[a].value):"datetime"===n.config.xaxis.type&&void 0===d&&(h=""),void 0===h&&(h=""),h=Array.isArray(h)?h:h.toString();var b=new m(this.ctx),v={};v=n.globals.rotateXLabels&&o?b.getTextRects(h,parseInt(r,10),null,"rotate(".concat(n.config.xaxis.labels.rotate," 0 0)"),!1):b.getTextRects(h,parseInt(r,10));var y=!n.config.xaxis.labels.showDuplicates&&this.ctx.timeScale;return!Array.isArray(h)&&(0===h.indexOf("NaN")||0===h.toLowerCase().indexOf("invalid")||h.toLowerCase().indexOf("infinity")>=0||s.indexOf(h)>=0&&y)&&(h=""),{x:i,text:h,textRect:v,isBold:g}}},{key:"checkLabelBasedOnTickamount",value:function(t,e,i){var a=this.w,s=a.config.xaxis.tickAmount;return"dataPoints"===s&&(s=Math.round(a.globals.gridWidth/120)),s>i||t%Math.round(i/(s+1))==0||(e.text=""),e}},{key:"checkForOverflowingLabels",value:function(t,e,i,a,s){var r=this.w;if(0===t&&r.globals.skipFirstTimelinelabel&&(e.text=""),t===i-1&&r.globals.skipLastTimelinelabel&&(e.text=""),r.config.xaxis.labels.hideOverlappingLabels&&a.length>0){var o=s[s.length-1];e.x0){!0===n.config.yaxis[s].opposite&&(t+=a.width);for(var c=e;c>=0;c--){var d=h+e/10+n.config.yaxis[s].labels.offsetY-1;n.globals.isBarHorizontal&&(d=r*c),"heatmap"===n.config.chart.type&&(d+=r/2);var g=l.drawLine(t+i.offsetX-a.width+a.offsetX,d+a.offsetY,t+i.offsetX+a.offsetX,d+a.offsetY,a.color);o.add(g),h+=r}}}}]),t}(),G=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"scaleSvgNode",value:function(t,e){var i=parseFloat(t.getAttributeNS(null,"width")),a=parseFloat(t.getAttributeNS(null,"height"));t.setAttributeNS(null,"width",i*e),t.setAttributeNS(null,"height",a*e),t.setAttributeNS(null,"viewBox","0 0 "+i+" "+a)}},{key:"fixSvgStringForIe11",value:function(t){if(!x.isIE11())return t.replace(/ /g," ");var e=0,i=t.replace(/xmlns="http:\/\/www.w3.org\/2000\/svg"/g,(function(t){return 2===++e?'xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:svgjs="http://svgjs.dev"':t}));return i=(i=i.replace(/xmlns:NS\d+=""/g,"")).replace(/NS\d+:(\w+:\w+=")/g,"$1")}},{key:"getSvgString",value:function(t){null==t&&(t=1);var e=this.w.globals.dom.Paper.svg();if(1!==t){var i=this.w.globals.dom.Paper.node.cloneNode(!0);this.scaleSvgNode(i,t),e=(new XMLSerializer).serializeToString(i)}return this.fixSvgStringForIe11(e)}},{key:"cleanup",value:function(){var t=this.w,e=t.globals.dom.baseEl.getElementsByClassName("apexcharts-xcrosshairs"),i=t.globals.dom.baseEl.getElementsByClassName("apexcharts-ycrosshairs"),a=t.globals.dom.baseEl.querySelectorAll(".apexcharts-zoom-rect, .apexcharts-selection-rect");Array.prototype.forEach.call(a,(function(t){t.setAttribute("width",0)})),e&&e[0]&&(e[0].setAttribute("x",-500),e[0].setAttribute("x1",-500),e[0].setAttribute("x2",-500)),i&&i[0]&&(i[0].setAttribute("y",-100),i[0].setAttribute("y1",-100),i[0].setAttribute("y2",-100))}},{key:"svgUrl",value:function(){this.cleanup();var t=this.getSvgString(),e=new Blob([t],{type:"image/svg+xml;charset=utf-8"});return URL.createObjectURL(e)}},{key:"dataURI",value:function(t){var e=this;return new Promise((function(i){var a=e.w,s=t?t.scale||t.width/a.globals.svgWidth:1;e.cleanup();var r=document.createElement("canvas");r.width=a.globals.svgWidth*s,r.height=parseInt(a.globals.dom.elWrap.style.height,10)*s;var o="transparent"===a.config.chart.background?"#fff":a.config.chart.background,n=r.getContext("2d");n.fillStyle=o,n.fillRect(0,0,r.width*s,r.height*s);var l=e.getSvgString(s);if(window.canvg&&x.isIE11()){var h=window.canvg.Canvg.fromString(n,l,{ignoreClear:!0,ignoreDimensions:!0});h.start();var c=r.msToBlob();h.stop(),i({blob:c})}else{var d="data:image/svg+xml,"+encodeURIComponent(l),g=new Image;g.crossOrigin="anonymous",g.onload=function(){if(n.drawImage(g,0,0),r.msToBlob){var t=r.msToBlob();i({blob:t})}else{var e=r.toDataURL("image/png");i({imgURI:e})}},g.src=d}}))}},{key:"exportToSVG",value:function(){this.triggerDownload(this.svgUrl(),this.w.config.chart.toolbar.export.svg.filename,".svg")}},{key:"exportToPng",value:function(){var t=this;this.dataURI().then((function(e){var i=e.imgURI,a=e.blob;a?navigator.msSaveOrOpenBlob(a,t.w.globals.chartID+".png"):t.triggerDownload(i,t.w.config.chart.toolbar.export.png.filename,".png")}))}},{key:"exportToCSV",value:function(t){var e=this,i=t.series,a=t.fileName,s=t.columnDelimiter,r=void 0===s?",":s,o=t.lineDelimiter,n=void 0===o?"\n":o,l=this.w;i||(i=l.config.series);var h=[],c=[],d="",g=l.globals.series.map((function(t,e){return-1===l.globals.collapsedSeriesIndices.indexOf(e)?t:[]})),p=Math.max.apply(Math,u(i.map((function(t){return t.data?t.data.length:0})))),f=new W(this.ctx),b=new B(this.ctx),v=function(t){var i="";if(l.globals.axisCharts){if("category"===l.config.xaxis.type||l.config.xaxis.convertedCatToNumeric)if(l.globals.isBarHorizontal){var a=l.globals.yLabelFormatters[0],s=new N(e.ctx).getActiveConfigSeriesIndex();i=a(l.globals.labels[t],{seriesIndex:s,dataPointIndex:t,w:l})}else i=b.getLabel(l.globals.labels,l.globals.timescaleLabels,0,t).text;"datetime"===l.config.xaxis.type&&(l.config.xaxis.categories.length?i=l.config.xaxis.categories[t]:l.config.labels.length&&(i=l.config.labels[t]))}else i=l.config.labels[t];return Array.isArray(i)&&(i=i.join(" ")),x.isNumber(i)?i:i.split(r).join("")},m=function(t,e){if(h.length&&0===e&&c.push(h.join(r)),t.data){t.data=t.data.length&&t.data||u(Array(p)).map((function(){return""}));for(var a=0;a=10?l.config.chart.toolbar.export.csv.dateFormatter(s):x.isNumber(s)?s:s.split(r).join("")));for(var o=0;o0&&!s.globals.isBarHorizontal&&(this.xaxisLabels=s.globals.timescaleLabels.slice()),s.config.xaxis.overwriteCategories&&(this.xaxisLabels=s.config.xaxis.overwriteCategories),this.drawnLabels=[],this.drawnLabelsRects=[],"top"===s.config.xaxis.position?this.offY=0:this.offY=s.globals.gridHeight+1,this.offY=this.offY+s.config.xaxis.axisBorder.offsetY,this.isCategoryBarHorizontal="bar"===s.config.chart.type&&s.config.plotOptions.bar.horizontal,this.xaxisFontSize=s.config.xaxis.labels.style.fontSize,this.xaxisFontFamily=s.config.xaxis.labels.style.fontFamily,this.xaxisForeColors=s.config.xaxis.labels.style.colors,this.xaxisBorderWidth=s.config.xaxis.axisBorder.width,this.isCategoryBarHorizontal&&(this.xaxisBorderWidth=s.config.yaxis[0].axisBorder.width.toString()),this.xaxisBorderWidth.indexOf("%")>-1?this.xaxisBorderWidth=s.globals.gridWidth*parseInt(this.xaxisBorderWidth,10)/100:this.xaxisBorderWidth=parseInt(this.xaxisBorderWidth,10),this.xaxisBorderHeight=s.config.xaxis.axisBorder.height,this.yaxis=s.config.yaxis[0]}return r(t,[{key:"drawXaxis",value:function(){var t=this.w,e=new m(this.ctx),i=e.group({class:"apexcharts-xaxis",transform:"translate(".concat(t.config.xaxis.offsetX,", ").concat(t.config.xaxis.offsetY,")")}),a=e.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(t.globals.translateXAxisX,", ").concat(t.globals.translateXAxisY,")")});i.add(a);for(var s=[],r=0;r6&&void 0!==arguments[6]?arguments[6]:{},h=[],c=[],d=this.w,g=l.xaxisFontSize||this.xaxisFontSize,u=l.xaxisFontFamily||this.xaxisFontFamily,p=l.xaxisForeColors||this.xaxisForeColors,f=l.fontWeight||d.config.xaxis.labels.style.fontWeight,x=l.cssClass||d.config.xaxis.labels.style.cssClass,b=d.globals.padHorizontal,v=a.length,m="category"===d.config.xaxis.type?d.globals.dataPoints:v;if(0===m&&v>m&&(m=v),s){var y=m>1?m-1:m;o=d.globals.gridWidth/y,b=b+r(0,o)/2+d.config.xaxis.labels.offsetX}else o=d.globals.gridWidth/m,b=b+r(0,o)+d.config.xaxis.labels.offsetX;for(var w=function(s){var l=b-r(s,o)/2+d.config.xaxis.labels.offsetX;0===s&&1===v&&o/2===b&&1===m&&(l=d.globals.gridWidth/2);var y=n.axesUtils.getLabel(a,d.globals.timescaleLabels,l,s,h,g,t),w=28;d.globals.rotateXLabels&&t&&(w=22),d.config.xaxis.title.text&&"top"===d.config.xaxis.position&&(w+=parseFloat(d.config.xaxis.title.style.fontSize)+2),t||(w=w+parseFloat(g)+(d.globals.xAxisLabelsHeight-d.globals.xAxisGroupLabelsHeight)+(d.globals.rotateXLabels?10:0)),y=void 0!==d.config.xaxis.tickAmount&&"dataPoints"!==d.config.xaxis.tickAmount&&"datetime"!==d.config.xaxis.type?n.axesUtils.checkLabelBasedOnTickamount(s,y,v):n.axesUtils.checkForOverflowingLabels(s,y,v,h,c);if(d.config.xaxis.labels.show){var k=e.drawText({x:y.x,y:n.offY+d.config.xaxis.labels.offsetY+w-("top"===d.config.xaxis.position?d.globals.xAxisHeight+d.config.xaxis.axisTicks.height-2:0),text:y.text,textAnchor:"middle",fontWeight:y.isBold?600:f,fontSize:g,fontFamily:u,foreColor:Array.isArray(p)?t&&d.config.xaxis.convertedCatToNumeric?p[d.globals.minX+s-1]:p[s]:p,isPlainText:!1,cssClass:(t?"apexcharts-xaxis-label ":"apexcharts-xaxis-group-label ")+x});if(i.add(k),k.on("click",(function(t){if("function"==typeof d.config.chart.events.xAxisLabelClick){var e=Object.assign({},d,{labelIndex:s});d.config.chart.events.xAxisLabelClick(t,n.ctx,e)}})),t){var A=document.createElementNS(d.globals.SVGNS,"title");A.textContent=Array.isArray(y.text)?y.text.join(" "):y.text,k.node.appendChild(A),""!==y.text&&(h.push(y.text),c.push(y))}}sa.globals.gridWidth)){var r=this.offY+a.config.xaxis.axisTicks.offsetY;if(e=e+r+a.config.xaxis.axisTicks.height,"top"===a.config.xaxis.position&&(e=r-a.config.xaxis.axisTicks.height),a.config.xaxis.axisTicks.show){var o=new m(this.ctx).drawLine(t+a.config.xaxis.axisTicks.offsetX,r+a.config.xaxis.offsetY,s+a.config.xaxis.axisTicks.offsetX,e+a.config.xaxis.offsetY,a.config.xaxis.axisTicks.color);i.add(o),o.node.classList.add("apexcharts-xaxis-tick")}}}},{key:"getXAxisTicksPositions",value:function(){var t=this.w,e=[],i=this.xaxisLabels.length,a=t.globals.padHorizontal;if(t.globals.timescaleLabels.length>0)for(var s=0;s0){var h=s[s.length-1].getBBox(),c=s[0].getBBox();h.x<-20&&s[s.length-1].parentNode.removeChild(s[s.length-1]),c.x+c.width>t.globals.gridWidth&&!t.globals.isBarHorizontal&&s[0].parentNode.removeChild(s[0]);for(var d=0;d0&&(this.xaxisLabels=i.globals.timescaleLabels.slice())}return r(t,[{key:"drawGridArea",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,e=this.w,i=new m(this.ctx);null===t&&(t=i.group({class:"apexcharts-grid"}));var a=i.drawLine(e.globals.padHorizontal,1,e.globals.padHorizontal,e.globals.gridHeight,"transparent"),s=i.drawLine(e.globals.padHorizontal,e.globals.gridHeight,e.globals.gridWidth,e.globals.gridHeight,"transparent");return t.add(s),t.add(a),t}},{key:"drawGrid",value:function(){var t=null;return this.w.globals.axisCharts&&(t=this.renderGrid(),this.drawGridArea(t.el)),t}},{key:"createGridMask",value:function(){var t=this.w,e=t.globals,i=new m(this.ctx),a=Array.isArray(t.config.stroke.width)?0:t.config.stroke.width;if(Array.isArray(t.config.stroke.width)){var s=0;t.config.stroke.width.forEach((function(t){s=Math.max(s,t)})),a=s}e.dom.elGridRectMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMask.setAttribute("id","gridRectMask".concat(e.cuid)),e.dom.elGridRectMarkerMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elGridRectMarkerMask.setAttribute("id","gridRectMarkerMask".concat(e.cuid)),e.dom.elForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elForecastMask.setAttribute("id","forecastMask".concat(e.cuid)),e.dom.elNonForecastMask=document.createElementNS(e.SVGNS,"clipPath"),e.dom.elNonForecastMask.setAttribute("id","nonForecastMask".concat(e.cuid));var r=t.config.chart.type,o=0,n=0;("bar"===r||"rangeBar"===r||"candlestick"===r||"boxPlot"===r||t.globals.comboBarCount>0)&&t.globals.isXNumeric&&!t.globals.isBarHorizontal&&(o=t.config.grid.padding.left,n=t.config.grid.padding.right,e.barPadForNumericAxis>o&&(o=e.barPadForNumericAxis,n=e.barPadForNumericAxis)),e.dom.elGridRect=i.drawRect(-a/2-o-2,-a/2,e.gridWidth+a+n+o+4,e.gridHeight+a,0,"#fff");var l=t.globals.markers.largestSize+1;e.dom.elGridRectMarker=i.drawRect(2*-l,2*-l,e.gridWidth+4*l,e.gridHeight+4*l,0,"#fff"),e.dom.elGridRectMask.appendChild(e.dom.elGridRect.node),e.dom.elGridRectMarkerMask.appendChild(e.dom.elGridRectMarker.node);var h=e.dom.baseEl.querySelector("defs");h.appendChild(e.dom.elGridRectMask),h.appendChild(e.dom.elForecastMask),h.appendChild(e.dom.elNonForecastMask),h.appendChild(e.dom.elGridRectMarkerMask)}},{key:"_drawGridLines",value:function(t){var e=t.i,i=t.x1,a=t.y1,s=t.x2,r=t.y2,o=t.xCount,n=t.parent,l=this.w;if(!(0===e&&l.globals.skipFirstTimelinelabel||e===o-1&&l.globals.skipLastTimelinelabel&&!l.config.xaxis.labels.formatter||"radar"===l.config.chart.type)){l.config.grid.xaxis.lines.show&&this._drawGridLine({i:e,x1:i,y1:a,x2:s,y2:r,xCount:o,parent:n});var h=0;if(l.globals.hasXaxisGroups&&"between"===l.config.xaxis.tickPlacement){var c=l.globals.groups;if(c){for(var d=0,g=0;d2));s++);return!t.globals.isBarHorizontal||this.isRangeBar?(i=this.xaxisLabels.length,this.isRangeBar&&(i--,a=t.globals.labels.length,t.config.xaxis.tickAmount&&t.config.xaxis.labels.formatter&&(i=t.config.xaxis.tickAmount)),this._drawXYLines({xCount:i,tickAmount:a})):(i=a,a=t.globals.xTickAmount,this._drawInvertedXYLines({xCount:i,tickAmount:a})),this.drawGridBands(i,a),{el:this.elg,elGridBorders:this.elGridBorders,xAxisTickWidth:t.globals.gridWidth/i}}},{key:"drawGridBands",value:function(t,e){var i=this.w;if(void 0!==i.config.grid.row.colors&&i.config.grid.row.colors.length>0)for(var a=0,s=i.globals.gridHeight/e,r=i.globals.gridWidth,o=0,n=0;o=i.config.grid.row.colors.length&&(n=0),this._drawGridBandRect({c:n,x1:0,y1:a,x2:r,y2:s,type:"row"}),a+=i.globals.gridHeight/e;if(void 0!==i.config.grid.column.colors&&i.config.grid.column.colors.length>0)for(var l=i.globals.isBarHorizontal||"category"!==i.config.xaxis.type&&!i.config.xaxis.convertedCatToNumeric?t:t-1,h=i.globals.padHorizontal,c=i.globals.padHorizontal+i.globals.gridWidth/l,d=i.globals.gridHeight,g=0,u=0;g=i.config.grid.column.colors.length&&(u=0),this._drawGridBandRect({c:u,x1:h,y1:0,x2:c,y2:d,type:"column"}),h+=i.globals.gridWidth/l}}]),t}(),_=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"niceScale",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,s=arguments.length>4?arguments[4]:void 0,r=this.w,o=Math.abs(e-t);if("dataPoints"===(i=this._adjustTicksForSmallRange(i,a,o))&&(i=r.globals.dataPoints-1),t===Number.MIN_VALUE&&0===e||!x.isNumber(t)&&!x.isNumber(e)||t===Number.MIN_VALUE&&e===-Number.MAX_VALUE)return t=0,e=i,this.linearScale(t,e,i);t>e?(console.warn("axis.min cannot be greater than axis.max"),e=t+.1):t===e&&(t=0===t?0:t-.5,e=0===e?2:e+.5);var n=[];o<1&&s&&("candlestick"===r.config.chart.type||"candlestick"===r.config.series[a].type||"boxPlot"===r.config.chart.type||"boxPlot"===r.config.series[a].type||r.globals.isRangeData)&&(e*=1.01);var l=i+1;l<2?l=2:l>2&&(l-=2);var h=o/l,c=Math.floor(x.log10(h)),d=Math.pow(10,c),g=Math.round(h/d);g<1&&(g=1);var u=g*d,p=u*Math.floor(t/u),f=u*Math.ceil(e/u),b=p;if(s&&o>2){for(;n.push(b),!((b+=u)>f););return{result:n,niceMin:n[0],niceMax:n[n.length-1]}}var v=t;(n=[]).push(v);for(var m=Math.abs(e-t)/i,y=0;y<=i;y++)v+=m,n.push(v);return n[n.length-2]>=e&&n.pop(),{result:n,niceMin:n[0],niceMax:n[n.length-1]}}},{key:"linearScale",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:10,a=arguments.length>3?arguments[3]:void 0,s=Math.abs(e-t);"dataPoints"===(i=this._adjustTicksForSmallRange(i,a,s))&&(i=this.w.globals.dataPoints-1);var r=s/i;i===Number.MAX_VALUE&&(i=10,r=1);for(var o=[],n=t;i>=0;)o.push(n),n+=r,i-=1;return{result:o,niceMin:o[0],niceMax:o[o.length-1]}}},{key:"logarithmicScaleNice",value:function(t,e,i){e<=0&&(e=Math.max(t,i)),t<=0&&(t=Math.min(e,i));for(var a=[],s=Math.ceil(Math.log(e)/Math.log(i)+1),r=Math.floor(Math.log(t)/Math.log(i));r5)a.allSeriesCollapsed=!1,a.yAxisScale[t]=this.logarithmicScale(e,i,r.logBase),a.yAxisScale[t]=r.forceNiceScale?this.logarithmicScaleNice(e,i,r.logBase):this.logarithmicScale(e,i,r.logBase);else if(i!==-Number.MAX_VALUE&&x.isNumber(i))if(a.allSeriesCollapsed=!1,void 0===r.min&&void 0===r.max||r.forceNiceScale){var n=void 0===s.yaxis[t].max&&void 0===s.yaxis[t].min||s.yaxis[t].forceNiceScale;a.yAxisScale[t]=this.niceScale(e,i,r.tickAmount?r.tickAmount:o<5&&o>1?o+1:5,t,n)}else a.yAxisScale[t]=this.linearScale(e,i,r.tickAmount,t);else a.yAxisScale[t]=this.linearScale(0,5,5)}},{key:"setXScale",value:function(t,e){var i=this.w,a=i.globals,s=i.config.xaxis,r=Math.abs(e-t);return e!==-Number.MAX_VALUE&&x.isNumber(e)?a.xAxisScale=this.linearScale(t,e,s.tickAmount?s.tickAmount:r<5&&r>1?r+1:5,0):a.xAxisScale=this.linearScale(0,5,5),a.xAxisScale}},{key:"setMultipleYScales",value:function(){var t=this,e=this.w.globals,i=this.w.config,a=e.minYArr.concat([]),s=e.maxYArr.concat([]),r=[];i.yaxis.forEach((function(e,o){var n=o;i.series.forEach((function(t,i){t.name===e.seriesName&&(n=i,o!==i?r.push({index:i,similarIndex:o,alreadyExists:!0}):r.push({index:i}))}));var l=a[n],h=s[n];t.setYScaleForIndex(o,l,h)})),this.sameScaleInMultipleAxes(a,s,r)}},{key:"sameScaleInMultipleAxes",value:function(t,e,i){var a=this,s=this.w.config,r=this.w.globals,o=[];i.forEach((function(t){t.alreadyExists&&(void 0===o[t.index]&&(o[t.index]=[]),o[t.index].push(t.index),o[t.index].push(t.similarIndex))})),r.yAxisSameScaleIndices=o,o.forEach((function(t,e){o.forEach((function(i,a){var s,r;e!==a&&(s=t,r=i,s.filter((function(t){return-1!==r.indexOf(t)}))).length>0&&(o[e]=o[e].concat(o[a]))}))}));var n=o.map((function(t){return t.filter((function(e,i){return t.indexOf(e)===i}))})).map((function(t){return t.sort()}));o=o.filter((function(t){return!!t}));var l=n.slice(),h=l.map((function(t){return JSON.stringify(t)}));l=l.filter((function(t,e){return h.indexOf(JSON.stringify(t))===e}));var c=[],d=[];t.forEach((function(t,i){l.forEach((function(a,s){a.indexOf(i)>-1&&(void 0===c[s]&&(c[s]=[],d[s]=[]),c[s].push({key:i,value:t}),d[s].push({key:i,value:e[i]}))}))}));var g=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,Number.MIN_VALUE),u=Array.apply(null,Array(l.length)).map(Number.prototype.valueOf,-Number.MAX_VALUE);c.forEach((function(t,e){t.forEach((function(t,i){g[e]=Math.min(t.value,g[e])}))})),d.forEach((function(t,e){t.forEach((function(t,i){u[e]=Math.max(t.value,u[e])}))})),t.forEach((function(t,e){d.forEach((function(t,i){var o=g[i],n=u[i];s.chart.stacked&&(n=0,t.forEach((function(t,e){t.value!==-Number.MAX_VALUE&&(n+=t.value),o!==Number.MIN_VALUE&&(o+=c[i][e].value)}))),t.forEach((function(i,l){t[l].key===e&&(void 0!==s.yaxis[e].min&&(o="function"==typeof s.yaxis[e].min?s.yaxis[e].min(r.minY):s.yaxis[e].min),void 0!==s.yaxis[e].max&&(n="function"==typeof s.yaxis[e].max?s.yaxis[e].max(r.maxY):s.yaxis[e].max),a.setYScaleForIndex(e,o,n))}))}))}))}},{key:"autoScaleY",value:function(t,e,i){t||(t=this);var a=t.w;if(a.globals.isMultipleYAxis||a.globals.collapsedSeries.length)return console.warn("autoScaleYaxis is not supported in a multi-yaxis chart."),e;var s=a.globals.seriesX[0],r=a.config.chart.stacked;return e.forEach((function(t,o){for(var n=0,l=0;l=i.xaxis.min){n=l;break}var h,c,d=a.globals.minYArr[o],g=a.globals.maxYArr[o],u=a.globals.stackedSeriesTotals;a.globals.series.forEach((function(o,l){var p=o[n];r?(p=u[n],h=c=p,u.forEach((function(t,e){s[e]<=i.xaxis.max&&s[e]>=i.xaxis.min&&(t>c&&null!==t&&(c=t),o[e]=i.xaxis.min){var r=t,o=t;a.globals.series.forEach((function(i,a){null!==t&&(r=Math.min(i[e],r),o=Math.max(i[e],o))})),o>c&&null!==o&&(c=o),rd&&(h=d),e.length>1?(e[l].min=void 0===t.min?h:t.min,e[l].max=void 0===t.max?c:t.max):(e[0].min=void 0===t.min?h:t.min,e[0].max=void 0===t.max?c:t.max)}))})),e}}]),t}(),U=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.scales=new _(e)}return r(t,[{key:"init",value:function(){this.setYRange(),this.setXRange(),this.setZRange()}},{key:"getMinYMaxY",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Number.MAX_VALUE,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:-Number.MAX_VALUE,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.w.config,r=this.w.globals,o=-Number.MAX_VALUE,n=Number.MIN_VALUE;null===a&&(a=t+1);var l=r.series,h=l,c=l;"candlestick"===s.chart.type?(h=r.seriesCandleL,c=r.seriesCandleH):"boxPlot"===s.chart.type?(h=r.seriesCandleO,c=r.seriesCandleC):r.isRangeData&&(h=r.seriesRangeStart,c=r.seriesRangeEnd);for(var d=t;dh[d][g]&&h[d][g]<0&&(n=h[d][g])):r.hasNullValues=!0}}return"rangeBar"===s.chart.type&&r.seriesRangeStart.length&&r.isBarHorizontal&&(n=e),"bar"===s.chart.type&&(n<0&&o<0&&(o=0),n===Number.MIN_VALUE&&(n=0)),{minY:n,maxY:o,lowestY:e,highestY:i}}},{key:"setYRange",value:function(){var t=this.w.globals,e=this.w.config;t.maxY=-Number.MAX_VALUE,t.minY=Number.MIN_VALUE;var i=Number.MAX_VALUE;if(t.isMultipleYAxis)for(var a=0;a=0&&i<=10||void 0!==e.yaxis[0].min||void 0!==e.yaxis[0].max)&&(o=0),t.minY=i-5*o/100,i>0&&t.minY<0&&(t.minY=0),t.maxY=t.maxY+5*o/100}if(e.yaxis.forEach((function(e,i){void 0!==e.max&&("number"==typeof e.max?t.maxYArr[i]=e.max:"function"==typeof e.max&&(t.maxYArr[i]=e.max(t.isMultipleYAxis?t.maxYArr[i]:t.maxY)),t.maxY=t.maxYArr[i]),void 0!==e.min&&("number"==typeof e.min?t.minYArr[i]=e.min:"function"==typeof e.min&&(t.minYArr[i]=e.min(t.isMultipleYAxis?t.minYArr[i]===Number.MIN_VALUE?0:t.minYArr[i]:t.minY)),t.minY=t.minYArr[i])})),t.isBarHorizontal){["min","max"].forEach((function(i){void 0!==e.xaxis[i]&&"number"==typeof e.xaxis[i]&&("min"===i?t.minY=e.xaxis[i]:t.maxY=e.xaxis[i])}))}return t.isMultipleYAxis?(this.scales.setMultipleYScales(),t.minY=i,t.yAxisScale.forEach((function(e,i){t.minYArr[i]=e.niceMin,t.maxYArr[i]=e.niceMax}))):(this.scales.setYScaleForIndex(0,t.minY,t.maxY),t.minY=t.yAxisScale[0].niceMin,t.maxY=t.yAxisScale[0].niceMax,t.minYArr[0]=t.yAxisScale[0].niceMin,t.maxYArr[0]=t.yAxisScale[0].niceMax),{minY:t.minY,maxY:t.maxY,minYArr:t.minYArr,maxYArr:t.maxYArr,yAxisScale:t.yAxisScale}}},{key:"setXRange",value:function(){var t=this.w.globals,e=this.w.config,i="numeric"===e.xaxis.type||"datetime"===e.xaxis.type||"category"===e.xaxis.type&&!t.noLabelsProvided||t.noLabelsProvided||t.isXNumeric;if(t.isXNumeric&&function(){for(var e=0;et.dataPoints&&0!==t.dataPoints&&(a=t.dataPoints-1)):"dataPoints"===e.xaxis.tickAmount?(t.series.length>1&&(a=t.series[t.maxValsInArrayIndex].length-1),t.isXNumeric&&(a=t.maxX-t.minX-1)):a=e.xaxis.tickAmount,t.xTickAmount=a,void 0!==e.xaxis.max&&"number"==typeof e.xaxis.max&&(t.maxX=e.xaxis.max),void 0!==e.xaxis.min&&"number"==typeof e.xaxis.min&&(t.minX=e.xaxis.min),void 0!==e.xaxis.range&&(t.minX=t.maxX-e.xaxis.range),t.minX!==Number.MAX_VALUE&&t.maxX!==-Number.MAX_VALUE)if(e.xaxis.convertedCatToNumeric&&!t.dataFormatXNumeric){for(var s=[],r=t.minX-1;r0&&(t.xAxisScale=this.scales.linearScale(1,t.labels.length,a-1),t.seriesX=t.labels.slice());i&&(t.labels=t.xAxisScale.result.slice())}return t.isBarHorizontal&&t.labels.length&&(t.xTickAmount=t.labels.length),this._handleSingleDataPoint(),this._getMinXDiff(),{minX:t.minX,maxX:t.maxX}}},{key:"setZRange",value:function(){var t=this.w.globals;if(t.isDataXYZ)for(var e=0;e0){var s=e-a[i-1];s>0&&(t.minXDiff=Math.min(s,t.minXDiff))}})),1!==t.dataPoints&&t.minXDiff!==Number.MAX_VALUE||(t.minXDiff=.5)}))}},{key:"_setStackedMinMax",value:function(){var t=this,e=this.w.globals;if(e.series.length){var i=e.seriesGroups;i.length||(i=[this.w.config.series.map((function(t){return t.name}))]);var a={},s={};i.forEach((function(i){a[i]=[],s[i]=[],t.w.config.series.map((function(t,e){return i.indexOf(t.name)>-1?e:null})).filter((function(t){return null!==t})).forEach((function(t){for(var r=0;r0?a[i][r]+=parseFloat(e.series[t][r])+1e-4:s[i][r]+=parseFloat(e.series[t][r]))}))})),Object.entries(a).forEach((function(t){var i=g(t,1)[0];a[i].forEach((function(t,r){e.maxY=Math.max(e.maxY,a[i][r]),e.minY=Math.min(e.minY,s[i][r])}))}))}}}]),t}(),q=function(){function t(e,i){a(this,t),this.ctx=e,this.elgrid=i,this.w=e.w;var s=this.w;this.xaxisFontSize=s.config.xaxis.labels.style.fontSize,this.axisFontFamily=s.config.xaxis.labels.style.fontFamily,this.xaxisForeColors=s.config.xaxis.labels.style.colors,this.isCategoryBarHorizontal="bar"===s.config.chart.type&&s.config.plotOptions.bar.horizontal,this.xAxisoffX=0,"bottom"===s.config.xaxis.position&&(this.xAxisoffX=s.globals.gridHeight),this.drawnLabels=[],this.axesUtils=new B(e)}return r(t,[{key:"drawYaxis",value:function(t){var e=this,i=this.w,a=new m(this.ctx),s=i.config.yaxis[t].labels.style,r=s.fontSize,o=s.fontFamily,n=s.fontWeight,l=a.group({class:"apexcharts-yaxis",rel:t,transform:"translate("+i.globals.translateYAxisX[t]+", 0)"});if(this.axesUtils.isYAxisHidden(t))return l;var h=a.group({class:"apexcharts-yaxis-texts-g"});l.add(h);var c=i.globals.yAxisScale[t].result.length-1,d=i.globals.gridHeight/c,g=i.globals.translateY,u=i.globals.yLabelFormatters[t],p=i.globals.yAxisScale[t].result.slice();p=this.axesUtils.checkForReversedLabels(t,p);var f="";if(i.config.yaxis[t].labels.show)for(var x=function(l){var x=p[l];x=u(x,l,i);var b=i.config.yaxis[t].labels.padding;i.config.yaxis[t].opposite&&0!==i.config.yaxis.length&&(b*=-1);var v="end";i.config.yaxis[t].opposite&&(v="start"),"left"===i.config.yaxis[t].labels.align?v="start":"center"===i.config.yaxis[t].labels.align?v="middle":"right"===i.config.yaxis[t].labels.align&&(v="end");var m=e.axesUtils.getYAxisForeColor(s.colors,t),y=a.drawText({x:b,y:g+c/10+i.config.yaxis[t].labels.offsetY+1,text:x,textAnchor:v,fontSize:r,fontFamily:o,fontWeight:n,maxWidth:i.config.yaxis[t].labels.maxWidth,foreColor:Array.isArray(m)?m[l]:m,isPlainText:!1,cssClass:"apexcharts-yaxis-label "+s.cssClass});l===c&&(f=y),h.add(y);var w=document.createElementNS(i.globals.SVGNS,"title");if(w.textContent=Array.isArray(x)?x.join(" "):x,y.node.appendChild(w),0!==i.config.yaxis[t].labels.rotate){var k=a.rotateAroundCenter(f.node),A=a.rotateAroundCenter(y.node);y.node.setAttribute("transform","rotate(".concat(i.config.yaxis[t].labels.rotate," ").concat(k.x," ").concat(A.y,")"))}g+=d},b=c;b>=0;b--)x(b);if(void 0!==i.config.yaxis[t].title.text){var v=a.group({class:"apexcharts-yaxis-title"}),y=0;i.config.yaxis[t].opposite&&(y=i.globals.translateYAxisX[t]);var w=a.drawText({x:y,y:i.globals.gridHeight/2+i.globals.translateY+i.config.yaxis[t].title.offsetY,text:i.config.yaxis[t].title.text,textAnchor:"end",foreColor:i.config.yaxis[t].title.style.color,fontSize:i.config.yaxis[t].title.style.fontSize,fontWeight:i.config.yaxis[t].title.style.fontWeight,fontFamily:i.config.yaxis[t].title.style.fontFamily,cssClass:"apexcharts-yaxis-title-text "+i.config.yaxis[t].title.style.cssClass});v.add(w),l.add(v)}var k=i.config.yaxis[t].axisBorder,A=31+k.offsetX;if(i.config.yaxis[t].opposite&&(A=-31-k.offsetX),k.show){var S=a.drawLine(A,i.globals.translateY+k.offsetY-2,A,i.globals.gridHeight+i.globals.translateY+k.offsetY+2,k.color,0,k.width);l.add(S)}return i.config.yaxis[t].axisTicks.show&&this.axesUtils.drawYAxisTicks(A,c,k,i.config.yaxis[t].axisTicks,t,d,l),l}},{key:"drawYaxisInversed",value:function(t){var e=this.w,i=new m(this.ctx),a=i.group({class:"apexcharts-xaxis apexcharts-yaxis-inversed"}),s=i.group({class:"apexcharts-xaxis-texts-g",transform:"translate(".concat(e.globals.translateXAxisX,", ").concat(e.globals.translateXAxisY,")")});a.add(s);var r=e.globals.yAxisScale[t].result.length-1,o=e.globals.gridWidth/r+.1,n=o+e.config.xaxis.labels.offsetX,l=e.globals.xLabelFormatter,h=e.globals.yAxisScale[t].result.slice(),c=e.globals.timescaleLabels;c.length>0&&(this.xaxisLabels=c.slice(),r=(h=c.slice()).length),h=this.axesUtils.checkForReversedLabels(t,h);var d=c.length;if(e.config.xaxis.labels.show)for(var g=d?0:r;d?g=0;d?g++:g--){var u=h[g];u=l(u,g,e);var p=e.globals.gridWidth+e.globals.padHorizontal-(n-o+e.config.xaxis.labels.offsetX);if(c.length){var f=this.axesUtils.getLabel(h,c,p,g,this.drawnLabels,this.xaxisFontSize);p=f.x,u=f.text,this.drawnLabels.push(f.text),0===g&&e.globals.skipFirstTimelinelabel&&(u=""),g===h.length-1&&e.globals.skipLastTimelinelabel&&(u="")}var x=i.drawText({x:p,y:this.xAxisoffX+e.config.xaxis.labels.offsetY+30-("top"===e.config.xaxis.position?e.globals.xAxisHeight+e.config.xaxis.axisTicks.height-2:0),text:u,textAnchor:"middle",foreColor:Array.isArray(this.xaxisForeColors)?this.xaxisForeColors[t]:this.xaxisForeColors,fontSize:this.xaxisFontSize,fontFamily:this.xaxisFontFamily,fontWeight:e.config.xaxis.labels.style.fontWeight,isPlainText:!1,cssClass:"apexcharts-xaxis-label "+e.config.xaxis.labels.style.cssClass});s.add(x),x.tspan(u);var b=document.createElementNS(e.globals.SVGNS,"title");b.textContent=u,x.node.appendChild(b),n+=o}return this.inversedYAxisTitleText(a),this.inversedYAxisBorder(a),a}},{key:"inversedYAxisBorder",value:function(t){var e=this.w,i=new m(this.ctx),a=e.config.xaxis.axisBorder;if(a.show){var s=0;"bar"===e.config.chart.type&&e.globals.isXNumeric&&(s-=15);var r=i.drawLine(e.globals.padHorizontal+s+a.offsetX,this.xAxisoffX,e.globals.gridWidth,this.xAxisoffX,a.color,0,a.height);this.elgrid&&this.elgrid.elGridBorders&&e.config.grid.show?this.elgrid.elGridBorders.add(r):t.add(r)}}},{key:"inversedYAxisTitleText",value:function(t){var e=this.w,i=new m(this.ctx);if(void 0!==e.config.xaxis.title.text){var a=i.group({class:"apexcharts-xaxis-title apexcharts-yaxis-title-inversed"}),s=i.drawText({x:e.globals.gridWidth/2+e.config.xaxis.title.offsetX,y:this.xAxisoffX+parseFloat(this.xaxisFontSize)+parseFloat(e.config.xaxis.title.style.fontSize)+e.config.xaxis.title.offsetY+20,text:e.config.xaxis.title.text,textAnchor:"middle",fontSize:e.config.xaxis.title.style.fontSize,fontFamily:e.config.xaxis.title.style.fontFamily,fontWeight:e.config.xaxis.title.style.fontWeight,foreColor:e.config.xaxis.title.style.color,cssClass:"apexcharts-xaxis-title-text "+e.config.xaxis.title.style.cssClass});a.add(s),t.add(a)}}},{key:"yAxisTitleRotate",value:function(t,e){var i=this.w,a=new m(this.ctx),s={width:0,height:0},r={width:0,height:0},o=i.globals.dom.baseEl.querySelector(" .apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-texts-g"));null!==o&&(s=o.getBoundingClientRect());var n=i.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(t,"'] .apexcharts-yaxis-title text"));if(null!==n&&(r=n.getBoundingClientRect()),null!==n){var l=this.xPaddingForYAxisTitle(t,s,r,e);n.setAttribute("x",l.xPos-(e?10:0))}if(null!==n){var h=a.rotateAroundCenter(n);n.setAttribute("transform","rotate(".concat(e?-1*i.config.yaxis[t].title.rotate:i.config.yaxis[t].title.rotate," ").concat(h.x," ").concat(h.y,")"))}}},{key:"xPaddingForYAxisTitle",value:function(t,e,i,a){var s=this.w,r=0,o=0,n=10;return void 0===s.config.yaxis[t].title.text||t<0?{xPos:o,padd:0}:(a?(o=e.width+s.config.yaxis[t].title.offsetX+i.width/2+n/2,0===(r+=1)&&(o-=n/2)):(o=-1*e.width+s.config.yaxis[t].title.offsetX+n/2+i.width/2,s.globals.isBarHorizontal&&(n=25,o=-1*e.width-s.config.yaxis[t].title.offsetX-n)),{xPos:o,padd:n})}},{key:"setYAxisXPosition",value:function(t,e){var i=this.w,a=0,s=0,r=18,o=1;i.config.yaxis.length>1&&(this.multipleYs=!0),i.config.yaxis.map((function(n,l){var h=i.globals.ignoreYAxisIndexes.indexOf(l)>-1||!n.show||n.floating||0===t[l].width,c=t[l].width+e[l].width;n.opposite?i.globals.isBarHorizontal?(s=i.globals.gridWidth+i.globals.translateX-1,i.globals.translateYAxisX[l]=s-n.labels.offsetX):(s=i.globals.gridWidth+i.globals.translateX+o,h||(o=o+c+20),i.globals.translateYAxisX[l]=s-n.labels.offsetX+20):(a=i.globals.translateX-r,h||(r=r+c+20),i.globals.translateYAxisX[l]=a+n.labels.offsetX)}))}},{key:"setYAxisTextAlignments",value:function(){var t=this.w,e=t.globals.dom.baseEl.getElementsByClassName("apexcharts-yaxis");(e=x.listToArray(e)).forEach((function(e,i){var a=t.config.yaxis[i];if(a&&!a.floating&&void 0!==a.labels.align){var s=t.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-texts-g")),r=t.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis[rel='".concat(i,"'] .apexcharts-yaxis-label"));r=x.listToArray(r);var o=s.getBoundingClientRect();"left"===a.labels.align?(r.forEach((function(t,e){t.setAttribute("text-anchor","start")})),a.opposite||s.setAttribute("transform","translate(-".concat(o.width,", 0)"))):"center"===a.labels.align?(r.forEach((function(t,e){t.setAttribute("text-anchor","middle")})),s.setAttribute("transform","translate(".concat(o.width/2*(a.opposite?1:-1),", 0)"))):"right"===a.labels.align&&(r.forEach((function(t,e){t.setAttribute("text-anchor","end")})),a.opposite&&s.setAttribute("transform","translate(".concat(o.width,", 0)")))}}))}}]),t}(),Z=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.documentEvent=x.bind(this.documentEvent,this)}return r(t,[{key:"addEventListener",value:function(t,e){var i=this.w;i.globals.events.hasOwnProperty(t)?i.globals.events[t].push(e):i.globals.events[t]=[e]}},{key:"removeEventListener",value:function(t,e){var i=this.w;if(i.globals.events.hasOwnProperty(t)){var a=i.globals.events[t].indexOf(e);-1!==a&&i.globals.events[t].splice(a,1)}}},{key:"fireEvent",value:function(t,e){var i=this.w;if(i.globals.events.hasOwnProperty(t)){e&&e.length||(e=[]);for(var a=i.globals.events[t],s=a.length,r=0;r0&&(e=this.w.config.chart.locales.concat(window.Apex.chart.locales));var i=e.filter((function(e){return e.name===t}))[0];if(!i)throw new Error("Wrong locale name provided. Please make sure you set the correct locale name in options");var a=x.extend(C,i);this.w.globals.locale=a.options}}]),t}(),J=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"drawAxis",value:function(t,e){var i,a,s=this,r=this.w.globals,o=this.w.config,n=new V(this.ctx,e),l=new q(this.ctx,e);r.axisCharts&&"radar"!==t&&(r.isBarHorizontal?(a=l.drawYaxisInversed(0),i=n.drawXaxisInversed(0),r.dom.elGraphical.add(i),r.dom.elGraphical.add(a)):(i=n.drawXaxis(),r.dom.elGraphical.add(i),o.yaxis.map((function(t,e){if(-1===r.ignoreYAxisIndexes.indexOf(e)&&(a=l.drawYaxis(e),r.dom.Paper.add(a),"back"===s.w.config.grid.position)){var i=r.dom.Paper.children()[1];i.remove(),r.dom.Paper.add(i)}}))))}}]),t}(),Q=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"drawXCrosshairs",value:function(){var t=this.w,e=new m(this.ctx),i=new v(this.ctx),a=t.config.xaxis.crosshairs.fill.gradient,s=t.config.xaxis.crosshairs.dropShadow,r=t.config.xaxis.crosshairs.fill.type,o=a.colorFrom,n=a.colorTo,l=a.opacityFrom,h=a.opacityTo,c=a.stops,d=s.enabled,g=s.left,u=s.top,p=s.blur,f=s.color,b=s.opacity,y=t.config.xaxis.crosshairs.fill.color;if(t.config.xaxis.crosshairs.show){"gradient"===r&&(y=e.drawGradient("vertical",o,n,l,h,null,c,null));var w=e.drawRect();1===t.config.xaxis.crosshairs.width&&(w=e.drawLine());var k=t.globals.gridHeight;(!x.isNumber(k)||k<0)&&(k=0);var A=t.config.xaxis.crosshairs.width;(!x.isNumber(A)||A<0)&&(A=0),w.attr({class:"apexcharts-xcrosshairs",x:0,y:0,y2:k,width:A,height:k,fill:y,filter:"none","fill-opacity":t.config.xaxis.crosshairs.opacity,stroke:t.config.xaxis.crosshairs.stroke.color,"stroke-width":t.config.xaxis.crosshairs.stroke.width,"stroke-dasharray":t.config.xaxis.crosshairs.stroke.dashArray}),d&&(w=i.dropShadow(w,{left:g,top:u,blur:p,color:f,opacity:b})),t.globals.dom.elGraphical.add(w)}}},{key:"drawYCrosshairs",value:function(){var t=this.w,e=new m(this.ctx),i=t.config.yaxis[0].crosshairs,a=t.globals.barPadForNumericAxis;if(t.config.yaxis[0].crosshairs.show){var s=e.drawLine(-a,0,t.globals.gridWidth+a,0,i.stroke.color,i.stroke.dashArray,i.stroke.width);s.attr({class:"apexcharts-ycrosshairs"}),t.globals.dom.elGraphical.add(s)}var r=e.drawLine(-a,0,t.globals.gridWidth+a,0,i.stroke.color,0,0);r.attr({class:"apexcharts-ycrosshairs-hidden"}),t.globals.dom.elGraphical.add(r)}}]),t}(),K=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"checkResponsiveConfig",value:function(t){var e=this,i=this.w,a=i.config;if(0!==a.responsive.length){var s=a.responsive.slice();s.sort((function(t,e){return t.breakpoint>e.breakpoint?1:e.breakpoint>t.breakpoint?-1:0})).reverse();var r=new E({}),o=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},a=s[0].breakpoint,o=window.innerWidth>0?window.innerWidth:screen.width;if(o>a){var n=y.extendArrayProps(r,i.globals.initialConfig,i);t=x.extend(n,t),t=x.extend(i.config,t),e.overrideResponsiveOptions(t)}else for(var l=0;l0&&"function"==typeof e.config.colors[0]&&(e.globals.colors=e.config.series.map((function(i,a){var s=e.config.colors[a];return s||(s=e.config.colors[0]),"function"==typeof s?(t.isColorFn=!0,s({value:e.globals.axisCharts?e.globals.series[a][0]?e.globals.series[a][0]:0:e.globals.series[a],seriesIndex:a,dataPointIndex:a,w:e})):s})))),e.globals.seriesColors.map((function(t,i){t&&(e.globals.colors[i]=t)})),e.config.theme.monochrome.enabled){var a=[],s=e.globals.series.length;(this.isBarDistributed||this.isHeatmapDistributed)&&(s=e.globals.series[0].length*e.globals.series.length);for(var r=e.config.theme.monochrome.color,o=1/(s/e.config.theme.monochrome.shadeIntensity),n=e.config.theme.monochrome.shadeTo,l=0,h=0;h2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,s=e||a.globals.series.length;if(null===i&&(i=this.isBarDistributed||this.isHeatmapDistributed||"heatmap"===a.config.chart.type&&a.config.plotOptions.heatmap.colorScale.inverse),i&&a.globals.series.length&&(s=a.globals.series[a.globals.maxValsInArrayIndex].length*a.globals.series.length),t.lengtht.globals.svgWidth&&(this.dCtx.lgRect.width=t.globals.svgWidth/1.5),this.dCtx.lgRect}},{key:"getLargestStringFromMultiArr",value:function(t,e){var i=t;if(this.w.globals.isMultiLineX){var a=e.map((function(t,e){return Array.isArray(t)?t.length:1})),s=Math.max.apply(Math,u(a));i=e[a.indexOf(s)]}return i}}]),t}(),at=function(){function t(e){a(this,t),this.w=e.w,this.dCtx=e}return r(t,[{key:"getxAxisLabelsCoords",value:function(){var t,e=this.w,i=e.globals.labels.slice();if(e.config.xaxis.convertedCatToNumeric&&0===i.length&&(i=e.globals.categoryLabels),e.globals.timescaleLabels.length>0){var a=this.getxAxisTimeScaleLabelsCoords();t={width:a.width,height:a.height},e.globals.rotateXLabels=!1}else{this.dCtx.lgWidthForSideLegends="left"!==e.config.legend.position&&"right"!==e.config.legend.position||e.config.legend.floating?0:this.dCtx.lgRect.width;var s=e.globals.xLabelFormatter,r=x.getLargestStringFromArr(i),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(r,i);e.globals.isBarHorizontal&&(o=r=e.globals.yAxisScale[0].result.reduce((function(t,e){return t.length>e.length?t:e}),0));var n=new T(this.dCtx.ctx),l=r;r=n.xLabelFormat(s,r,l,{i:void 0,dateFormatter:new I(this.dCtx.ctx).formatDate,w:e}),o=n.xLabelFormat(s,o,l,{i:void 0,dateFormatter:new I(this.dCtx.ctx).formatDate,w:e}),(e.config.xaxis.convertedCatToNumeric&&void 0===r||""===String(r).trim())&&(o=r="1");var h=new m(this.dCtx.ctx),c=h.getTextRects(r,e.config.xaxis.labels.style.fontSize),d=c;if(r!==o&&(d=h.getTextRects(o,e.config.xaxis.labels.style.fontSize)),(t={width:c.width>=d.width?c.width:d.width,height:c.height>=d.height?c.height:d.height}).width*i.length>e.globals.svgWidth-this.dCtx.lgWidthForSideLegends-this.dCtx.yAxisWidth-this.dCtx.gridPad.left-this.dCtx.gridPad.right&&0!==e.config.xaxis.labels.rotate||e.config.xaxis.labels.rotateAlways){if(!e.globals.isBarHorizontal){e.globals.rotateXLabels=!0;var g=function(t){return h.getTextRects(t,e.config.xaxis.labels.style.fontSize,e.config.xaxis.labels.style.fontFamily,"rotate(".concat(e.config.xaxis.labels.rotate," 0 0)"),!1)};c=g(r),r!==o&&(d=g(o)),t.height=(c.height>d.height?c.height:d.height)/1.5,t.width=c.width>d.width?c.width:d.width}}else e.globals.rotateXLabels=!1}return e.config.xaxis.labels.show||(t={width:0,height:0}),{width:t.width,height:t.height}}},{key:"getxAxisGroupLabelsCoords",value:function(){var t,e=this.w;if(!e.globals.hasXaxisGroups)return{width:0,height:0};var i,a=(null===(t=e.config.xaxis.group.style)||void 0===t?void 0:t.fontSize)||e.config.xaxis.labels.style.fontSize,s=e.globals.groups.map((function(t){return t.title})),r=x.getLargestStringFromArr(s),o=this.dCtx.dimHelpers.getLargestStringFromMultiArr(r,s),n=new m(this.dCtx.ctx),l=n.getTextRects(r,a),h=l;return r!==o&&(h=n.getTextRects(o,a)),i={width:l.width>=h.width?l.width:h.width,height:l.height>=h.height?l.height:h.height},e.config.xaxis.labels.show||(i={width:0,height:0}),{width:i.width,height:i.height}}},{key:"getxAxisTitleCoords",value:function(){var t=this.w,e=0,i=0;if(void 0!==t.config.xaxis.title.text){var a=new m(this.dCtx.ctx).getTextRects(t.config.xaxis.title.text,t.config.xaxis.title.style.fontSize);e=a.width,i=a.height}return{width:e,height:i}}},{key:"getxAxisTimeScaleLabelsCoords",value:function(){var t,e=this.w;this.dCtx.timescaleLabels=e.globals.timescaleLabels.slice();var i=this.dCtx.timescaleLabels.map((function(t){return t.value})),a=i.reduce((function(t,e){return void 0===t?(console.error("You have possibly supplied invalid Date format. Please supply a valid JavaScript Date"),0):t.length>e.length?t:e}),0);return 1.05*(t=new m(this.dCtx.ctx).getTextRects(a,e.config.xaxis.labels.style.fontSize)).width*i.length>e.globals.gridWidth&&0!==e.config.xaxis.labels.rotate&&(e.globals.overlappingXLabels=!0),t}},{key:"additionalPaddingXLabels",value:function(t){var e=this,i=this.w,a=i.globals,s=i.config,r=s.xaxis.type,o=t.width;a.skipLastTimelinelabel=!1,a.skipFirstTimelinelabel=!1;var n=i.config.yaxis[0].opposite&&i.globals.isBarHorizontal,l=function(t,n){s.yaxis.length>1&&function(t){return-1!==a.collapsedSeriesIndices.indexOf(t)}(n)||function(t){if(e.dCtx.timescaleLabels&&e.dCtx.timescaleLabels.length){var n=e.dCtx.timescaleLabels[0],l=e.dCtx.timescaleLabels[e.dCtx.timescaleLabels.length-1].position+o/1.75-e.dCtx.yAxisWidthRight,h=n.position-o/1.75+e.dCtx.yAxisWidthLeft,c="right"===i.config.legend.position&&e.dCtx.lgRect.width>0?e.dCtx.lgRect.width:0;l>a.svgWidth-a.translateX-c&&(a.skipLastTimelinelabel=!0),h<-(t.show&&!t.floating||"bar"!==s.chart.type&&"candlestick"!==s.chart.type&&"rangeBar"!==s.chart.type&&"boxPlot"!==s.chart.type?10:o/1.75)&&(a.skipFirstTimelinelabel=!0)}else"datetime"===r?e.dCtx.gridPad.rightString(n.niceMax).length?c:n.niceMax,g=h(d,{seriesIndex:o,dataPointIndex:-1,w:e}),u=g;if(void 0!==g&&0!==g.length||(g=d),e.globals.isBarHorizontal){a=0;var p=e.globals.labels.slice();g=h(g=x.getLargestStringFromArr(p),{seriesIndex:o,dataPointIndex:-1,w:e}),u=t.dCtx.dimHelpers.getLargestStringFromMultiArr(g,p)}var f=new m(t.dCtx.ctx),b="rotate(".concat(r.labels.rotate," 0 0)"),v=f.getTextRects(g,r.labels.style.fontSize,r.labels.style.fontFamily,b,!1),y=v;g!==u&&(y=f.getTextRects(u,r.labels.style.fontSize,r.labels.style.fontFamily,b,!1)),i.push({width:(l>y.width||l>v.width?l:y.width>v.width?y.width:v.width)+a,height:y.height>v.height?y.height:v.height})}else i.push({width:0,height:0})})),i}},{key:"getyAxisTitleCoords",value:function(){var t=this,e=this.w,i=[];return e.config.yaxis.map((function(e,a){if(e.show&&void 0!==e.title.text){var s=new m(t.dCtx.ctx),r="rotate(".concat(e.title.rotate," 0 0)"),o=s.getTextRects(e.title.text,e.title.style.fontSize,e.title.style.fontFamily,r,!1);i.push({width:o.width,height:o.height})}else i.push({width:0,height:0})})),i}},{key:"getTotalYAxisWidth",value:function(){var t=this.w,e=0,i=0,a=0,s=t.globals.yAxisScale.length>1?10:0,r=new B(this.dCtx.ctx),o=function(o,n){var l=t.config.yaxis[n].floating,h=0;o.width>0&&!l?(h=o.width+s,function(e){return t.globals.ignoreYAxisIndexes.indexOf(e)>-1}(n)&&(h=h-o.width-s)):h=l||r.isYAxisHidden(n)?0:5,t.config.yaxis[n].opposite?a+=h:i+=h,e+=h};return t.globals.yLabelsCoords.map((function(t,e){o(t,e)})),t.globals.yTitleCoords.map((function(t,e){o(t,e)})),t.globals.isBarHorizontal&&!t.config.yaxis[0].floating&&(e=t.globals.yLabelsCoords[0].width+t.globals.yTitleCoords[0].width+15),this.dCtx.yAxisWidthLeft=i,this.dCtx.yAxisWidthRight=a,e}}]),t}(),rt=function(){function t(e){a(this,t),this.w=e.w,this.dCtx=e}return r(t,[{key:"gridPadForColumnsInNumericAxis",value:function(t){var e=this.w;if(e.globals.noData||e.globals.allSeriesCollapsed)return 0;var i=function(t){return"bar"===t||"rangeBar"===t||"candlestick"===t||"boxPlot"===t},a=e.config.chart.type,s=0,r=i(a)?e.config.series.length:1;if(e.globals.comboBarCount>0&&(r=e.globals.comboBarCount),e.globals.collapsedSeries.forEach((function(t){i(t.type)&&(r-=1)})),e.config.chart.stacked&&(r=1),(i(a)||e.globals.comboBarCount>0)&&e.globals.isXNumeric&&!e.globals.isBarHorizontal&&r>0){var o,n,l=Math.abs(e.globals.initialMaxX-e.globals.initialMinX);l<=3&&(l=e.globals.dataPoints),o=l/t,e.globals.minXDiff&&e.globals.minXDiff/o>0&&(n=e.globals.minXDiff/o),n>t/2&&(n/=2),(s=n/r*parseInt(e.config.plotOptions.bar.columnWidth,10)/100)<1&&(s=1),s=s/(r>1?1:1.5)+5,e.globals.barPadForNumericAxis=s}return s}},{key:"gridPadFortitleSubtitle",value:function(){var t=this,e=this.w,i=e.globals,a=this.dCtx.isSparkline||!e.globals.axisCharts?0:10;["title","subtitle"].forEach((function(i){void 0!==e.config[i].text?a+=e.config[i].margin:a+=t.dCtx.isSparkline||!e.globals.axisCharts?0:5})),!e.config.legend.show||"bottom"!==e.config.legend.position||e.config.legend.floating||e.globals.axisCharts||(a+=10);var s=this.dCtx.dimHelpers.getTitleSubtitleCoords("title"),r=this.dCtx.dimHelpers.getTitleSubtitleCoords("subtitle");i.gridHeight=i.gridHeight-s.height-r.height-a,i.translateY=i.translateY+s.height+r.height+a}},{key:"setGridXPosForDualYAxis",value:function(t,e){var i=this.w,a=new B(this.dCtx.ctx);i.config.yaxis.map((function(s,r){-1!==i.globals.ignoreYAxisIndexes.indexOf(r)||s.floating||a.isYAxisHidden(r)||(s.opposite&&(i.globals.translateX=i.globals.translateX-(e[r].width+t[r].width)-parseInt(i.config.yaxis[r].labels.style.fontSize,10)/1.2-12),i.globals.translateX<2&&(i.globals.translateX=2))}))}}]),t}(),ot=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.lgRect={},this.yAxisWidth=0,this.yAxisWidthLeft=0,this.yAxisWidthRight=0,this.xAxisHeight=0,this.isSparkline=this.w.config.chart.sparkline.enabled,this.dimHelpers=new it(this),this.dimYAxis=new st(this),this.dimXAxis=new at(this),this.dimGrid=new rt(this),this.lgWidthForSideLegends=0,this.gridPad=this.w.config.grid.padding,this.xPadRight=0,this.xPadLeft=0}return r(t,[{key:"plotCoords",value:function(){var t=this,e=this.w,i=e.globals;this.lgRect=this.dimHelpers.getLegendsRect(),this.isSparkline&&(e.config.markers.discrete.length>0||e.config.markers.size>0)&&Object.entries(this.gridPad).forEach((function(e){var i=g(e,2),a=i[0],s=i[1];t.gridPad[a]=Math.max(s,t.w.globals.markers.largestSize/1.5)})),i.axisCharts?this.setDimensionsForAxisCharts():this.setDimensionsForNonAxisCharts(),this.dimGrid.gridPadFortitleSubtitle(),i.gridHeight=i.gridHeight-this.gridPad.top-this.gridPad.bottom,i.gridWidth=i.gridWidth-this.gridPad.left-this.gridPad.right-this.xPadRight-this.xPadLeft;var a=this.dimGrid.gridPadForColumnsInNumericAxis(i.gridWidth);i.gridWidth=i.gridWidth-2*a,i.translateX=i.translateX+this.gridPad.left+this.xPadLeft+(a>0?a+4:0),i.translateY=i.translateY+this.gridPad.top}},{key:"setDimensionsForAxisCharts",value:function(){var t=this,e=this.w,i=e.globals,a=this.dimYAxis.getyAxisLabelsCoords(),s=this.dimYAxis.getyAxisTitleCoords();e.globals.yLabelsCoords=[],e.globals.yTitleCoords=[],e.config.yaxis.map((function(t,i){e.globals.yLabelsCoords.push({width:a[i].width,index:i}),e.globals.yTitleCoords.push({width:s[i].width,index:i})})),this.yAxisWidth=this.dimYAxis.getTotalYAxisWidth();var r=this.dimXAxis.getxAxisLabelsCoords(),o=this.dimXAxis.getxAxisGroupLabelsCoords(),n=this.dimXAxis.getxAxisTitleCoords();this.conditionalChecksForAxisCoords(r,n,o),i.translateXAxisY=e.globals.rotateXLabels?this.xAxisHeight/8:-4,i.translateXAxisX=e.globals.rotateXLabels&&e.globals.isXNumeric&&e.config.xaxis.labels.rotate<=-45?-this.xAxisWidth/4:0,e.globals.isBarHorizontal&&(i.rotateXLabels=!1,i.translateXAxisY=parseInt(e.config.xaxis.labels.style.fontSize,10)/1.5*-1),i.translateXAxisY=i.translateXAxisY+e.config.xaxis.labels.offsetY,i.translateXAxisX=i.translateXAxisX+e.config.xaxis.labels.offsetX;var l=this.yAxisWidth,h=this.xAxisHeight;i.xAxisLabelsHeight=this.xAxisHeight-n.height,i.xAxisGroupLabelsHeight=i.xAxisLabelsHeight-r.height,i.xAxisLabelsWidth=this.xAxisWidth,i.xAxisHeight=this.xAxisHeight;var c=10;("radar"===e.config.chart.type||this.isSparkline)&&(l=0,h=i.goldenPadding),this.isSparkline&&(this.lgRect={height:0,width:0}),(this.isSparkline||"treemap"===e.config.chart.type)&&(l=0,h=0,c=0),this.isSparkline||this.dimXAxis.additionalPaddingXLabels(r);var d=function(){i.translateX=l,i.gridHeight=i.svgHeight-t.lgRect.height-h-(t.isSparkline||"treemap"===e.config.chart.type?0:e.globals.rotateXLabels?10:15),i.gridWidth=i.svgWidth-l};switch("top"===e.config.xaxis.position&&(c=i.xAxisHeight-e.config.xaxis.axisTicks.height-5),e.config.legend.position){case"bottom":i.translateY=c,d();break;case"top":i.translateY=this.lgRect.height+c,d();break;case"left":i.translateY=c,i.translateX=this.lgRect.width+l,i.gridHeight=i.svgHeight-h-12,i.gridWidth=i.svgWidth-this.lgRect.width-l;break;case"right":i.translateY=c,i.translateX=l,i.gridHeight=i.svgHeight-h-12,i.gridWidth=i.svgWidth-this.lgRect.width-l-5;break;default:throw new Error("Legend position not supported")}this.dimGrid.setGridXPosForDualYAxis(s,a),new q(this.ctx).setYAxisXPosition(a,s)}},{key:"setDimensionsForNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=t.config,a=0;t.config.legend.show&&!t.config.legend.floating&&(a=20);var s="pie"===i.chart.type||"polarArea"===i.chart.type||"donut"===i.chart.type?"pie":"radialBar",r=i.plotOptions[s].offsetY,o=i.plotOptions[s].offsetX;if(!i.legend.show||i.legend.floating)return e.gridHeight=e.svgHeight-i.grid.padding.left+i.grid.padding.right,e.gridWidth=e.gridHeight,e.translateY=r,void(e.translateX=o+(e.svgWidth-e.gridWidth)/2);switch(i.legend.position){case"bottom":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=r-10,e.translateX=o+(e.svgWidth-e.gridWidth)/2;break;case"top":e.gridHeight=e.svgHeight-this.lgRect.height-e.goldenPadding,e.gridWidth=e.svgWidth,e.translateY=this.lgRect.height+r+10,e.translateX=o+(e.svgWidth-e.gridWidth)/2;break;case"left":e.gridWidth=e.svgWidth-this.lgRect.width-a,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=r,e.translateX=o+this.lgRect.width+a;break;case"right":e.gridWidth=e.svgWidth-this.lgRect.width-a-5,e.gridHeight="auto"!==i.chart.height?e.svgHeight:e.gridWidth,e.translateY=r,e.translateX=o+10;break;default:throw new Error("Legend position not supported")}}},{key:"conditionalChecksForAxisCoords",value:function(t,e,i){var a=this.w,s=a.globals.hasXaxisGroups?2:1,r=i.height+t.height+e.height,o=a.globals.isMultiLineX?1.2:a.globals.LINE_HEIGHT_RATIO,n=a.globals.rotateXLabels?22:10,l=a.globals.rotateXLabels&&"bottom"===a.config.legend.position?10:0;this.xAxisHeight=r*o+s*n+l,this.xAxisWidth=t.width,this.xAxisHeight-e.height>a.config.xaxis.labels.maxHeight&&(this.xAxisHeight=a.config.xaxis.labels.maxHeight),a.config.xaxis.labels.minHeight&&this.xAxisHeightc&&(this.yAxisWidth=c)}}]),t}(),nt=function(){function t(e){a(this,t),this.w=e.w,this.lgCtx=e}return r(t,[{key:"getLegendStyles",value:function(){var t=document.createElement("style");t.setAttribute("type","text/css");var e=document.createTextNode("\t\n \t\n .apexcharts-legend {\t\n display: flex;\t\n overflow: auto;\t\n padding: 0 10px;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom, .apexcharts-legend.apx-legend-position-top {\t\n flex-wrap: wrap\t\n }\t\n .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n flex-direction: column;\t\n bottom: 0;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-left, .apexcharts-legend.apx-legend-position-top.apexcharts-align-left, .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\t\n justify-content: flex-start;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-center, .apexcharts-legend.apx-legend-position-top.apexcharts-align-center {\t\n justify-content: center; \t\n }\t\n .apexcharts-legend.apx-legend-position-bottom.apexcharts-align-right, .apexcharts-legend.apx-legend-position-top.apexcharts-align-right {\t\n justify-content: flex-end;\t\n }\t\n .apexcharts-legend-series {\t\n cursor: pointer;\t\n line-height: normal;\t\n }\t\n .apexcharts-legend.apx-legend-position-bottom .apexcharts-legend-series, .apexcharts-legend.apx-legend-position-top .apexcharts-legend-series{\t\n display: flex;\t\n align-items: center;\t\n }\t\n .apexcharts-legend-text {\t\n position: relative;\t\n font-size: 14px;\t\n }\t\n .apexcharts-legend-text *, .apexcharts-legend-marker * {\t\n pointer-events: none;\t\n }\t\n .apexcharts-legend-marker {\t\n position: relative;\t\n display: inline-block;\t\n cursor: pointer;\t\n margin-right: 3px;\t\n border-style: solid;\n }\t\n \t\n .apexcharts-legend.apexcharts-align-right .apexcharts-legend-series, .apexcharts-legend.apexcharts-align-left .apexcharts-legend-series{\t\n display: inline-block;\t\n }\t\n .apexcharts-legend-series.apexcharts-no-click {\t\n cursor: auto;\t\n }\t\n .apexcharts-legend .apexcharts-hidden-zero-series, .apexcharts-legend .apexcharts-hidden-null-series {\t\n display: none !important;\t\n }\t\n .apexcharts-inactive-legend {\t\n opacity: 0.45;\t\n }");return t.appendChild(e),t}},{key:"getLegendBBox",value:function(){var t=this.w.globals.dom.baseEl.querySelector(".apexcharts-legend").getBoundingClientRect(),e=t.width;return{clwh:t.height,clww:e}}},{key:"appendToForeignObject",value:function(){this.w.globals.dom.elLegendForeign.appendChild(this.getLegendStyles())}},{key:"toggleDataSeries",value:function(t,e){var i=this,a=this.w;if(a.globals.axisCharts||"radialBar"===a.config.chart.type){a.globals.resized=!0;var s=null,r=null;if(a.globals.risingSeries=[],a.globals.axisCharts?(s=a.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(t,"']")),r=parseInt(s.getAttribute("data:realIndex"),10)):(s=a.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(t+1,"']")),r=parseInt(s.getAttribute("rel"),10)-1),e)[{cs:a.globals.collapsedSeries,csi:a.globals.collapsedSeriesIndices},{cs:a.globals.ancillaryCollapsedSeries,csi:a.globals.ancillaryCollapsedSeriesIndices}].forEach((function(t){i.riseCollapsedSeries(t.cs,t.csi,r)}));else this.hideSeries({seriesEl:s,realIndex:r})}else{var o=a.globals.dom.Paper.select(" .apexcharts-series[rel='".concat(t+1,"'] path")),n=a.config.chart.type;if("pie"===n||"polarArea"===n||"donut"===n){var l=a.config.plotOptions.pie.donut.labels;new m(this.lgCtx.ctx).pathMouseDown(o.members[0],null),this.lgCtx.ctx.pie.printDataLabelsInner(o.members[0].node,l)}o.fire("click")}}},{key:"hideSeries",value:function(t){var e=t.seriesEl,i=t.realIndex,a=this.w,s=x.clone(a.config.series);if(a.globals.axisCharts){var r=!1;if(a.config.yaxis[i]&&a.config.yaxis[i].show&&a.config.yaxis[i].showAlways&&(r=!0,a.globals.ancillaryCollapsedSeriesIndices.indexOf(i)<0&&(a.globals.ancillaryCollapsedSeries.push({index:i,data:s[i].data.slice(),type:e.parentNode.className.baseVal.split("-")[1]}),a.globals.ancillaryCollapsedSeriesIndices.push(i))),!r){a.globals.collapsedSeries.push({index:i,data:s[i].data.slice(),type:e.parentNode.className.baseVal.split("-")[1]}),a.globals.collapsedSeriesIndices.push(i);var o=a.globals.risingSeries.indexOf(i);a.globals.risingSeries.splice(o,1)}}else a.globals.collapsedSeries.push({index:i,data:s[i]}),a.globals.collapsedSeriesIndices.push(i);for(var n=e.childNodes,l=0;l0){for(var r=0;r-1&&(t[a].data=[])})):t.forEach((function(i,a){e.globals.collapsedSeriesIndices.indexOf(a)>-1&&(t[a]=0)})),t}}]),t}(),lt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.onLegendClick=this.onLegendClick.bind(this),this.onLegendHovered=this.onLegendHovered.bind(this),this.isBarsDistributed="bar"===this.w.config.chart.type&&this.w.config.plotOptions.bar.distributed&&1===this.w.config.series.length,this.legendHelpers=new nt(this)}return r(t,[{key:"init",value:function(){var t=this.w,e=t.globals,i=t.config;if((i.legend.showForSingleSeries&&1===e.series.length||this.isBarsDistributed||e.series.length>1||!e.axisCharts)&&i.legend.show){for(;e.dom.elLegendWrap.firstChild;)e.dom.elLegendWrap.removeChild(e.dom.elLegendWrap.firstChild);this.drawLegends(),x.isIE11()?document.getElementsByTagName("head")[0].appendChild(this.legendHelpers.getLegendStyles()):this.legendHelpers.appendToForeignObject(),"bottom"===i.legend.position||"top"===i.legend.position?this.legendAlignHorizontal():"right"!==i.legend.position&&"left"!==i.legend.position||this.legendAlignVertical()}}},{key:"drawLegends",value:function(){var t=this,e=this.w,i=e.config.legend.fontFamily,a=e.globals.seriesNames,s=e.globals.colors.slice();if("heatmap"===e.config.chart.type){var r=e.config.plotOptions.heatmap.colorScale.ranges;a=r.map((function(t){return t.name?t.name:t.from+" - "+t.to})),s=r.map((function(t){return t.color}))}else this.isBarsDistributed&&(a=e.globals.labels.slice());e.config.legend.customLegendItems.length&&(a=e.config.legend.customLegendItems);for(var o=e.globals.legendFormatter,n=e.config.legend.inverseOrder,l=n?a.length-1:0;n?l>=0:l<=a.length-1;n?l--:l++){var h=o(a[l],{seriesIndex:l,w:e}),c=!1,d=!1;if(e.globals.collapsedSeries.length>0)for(var g=0;g0)for(var u=0;u0?l-10:0)+(h>0?h-10:0)}a.style.position="absolute",r=r+t+i.config.legend.offsetX,o=o+e+i.config.legend.offsetY,a.style.left=r+"px",a.style.top=o+"px","bottom"===i.config.legend.position?(a.style.top="auto",a.style.bottom=5-i.config.legend.offsetY+"px"):"right"===i.config.legend.position&&(a.style.left="auto",a.style.right=25+i.config.legend.offsetX+"px");["width","height"].forEach((function(t){a.style[t]&&(a.style[t]=parseInt(i.config.legend[t],10)+"px")}))}},{key:"legendAlignHorizontal",value:function(){var t=this.w;t.globals.dom.elLegendWrap.style.right=0;var e=this.legendHelpers.getLegendBBox(),i=new ot(this.ctx),a=i.dimHelpers.getTitleSubtitleCoords("title"),s=i.dimHelpers.getTitleSubtitleCoords("subtitle"),r=0;"bottom"===t.config.legend.position?r=-e.clwh/1.8:"top"===t.config.legend.position&&(r=a.height+s.height+t.config.title.margin+t.config.subtitle.margin-10),this.setLegendWrapXY(20,r)}},{key:"legendAlignVertical",value:function(){var t=this.w,e=this.legendHelpers.getLegendBBox(),i=0;"left"===t.config.legend.position&&(i=20),"right"===t.config.legend.position&&(i=t.globals.svgWidth-e.clww-10),this.setLegendWrapXY(i,20)}},{key:"onLegendHovered",value:function(t){var e=this.w,i=t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker");if("heatmap"===e.config.chart.type||this.isBarsDistributed){if(i){var a=parseInt(t.target.getAttribute("rel"),10)-1;this.ctx.events.fireEvent("legendHover",[this.ctx,a,this.w]),new N(this.ctx).highlightRangeInSeries(t,t.target)}}else!t.target.classList.contains("apexcharts-inactive-legend")&&i&&new N(this.ctx).toggleSeriesOnHover(t,t.target)}},{key:"onLegendClick",value:function(t){var e=this.w;if(!e.config.legend.customLegendItems.length&&(t.target.classList.contains("apexcharts-legend-text")||t.target.classList.contains("apexcharts-legend-marker"))){var i=parseInt(t.target.getAttribute("rel"),10)-1,a="true"===t.target.getAttribute("data:collapsed"),s=this.w.config.chart.events.legendClick;"function"==typeof s&&s(this.ctx,i,this.w),this.ctx.events.fireEvent("legendClick",[this.ctx,i,this.w]);var r=this.w.config.legend.markers.onClick;"function"==typeof r&&t.target.classList.contains("apexcharts-legend-marker")&&(r(this.ctx,i,this.w),this.ctx.events.fireEvent("legendMarkerClick",[this.ctx,i,this.w])),"treemap"!==e.config.chart.type&&"heatmap"!==e.config.chart.type&&!this.isBarsDistributed&&e.config.legend.onItemClick.toggleDataSeries&&this.legendHelpers.toggleDataSeries(i,a)}}}]),t}(),ht=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w;var i=this.w;this.ev=this.w.config.chart.events,this.selectedClass="apexcharts-selected",this.localeValues=this.w.globals.locale.toolbar,this.minX=i.globals.minX,this.maxX=i.globals.maxX}return r(t,[{key:"createToolbar",value:function(){var t=this,e=this.w,i=function(){return document.createElement("div")},a=i();if(a.setAttribute("class","apexcharts-toolbar"),a.style.top=e.config.chart.toolbar.offsetY+"px",a.style.right=3-e.config.chart.toolbar.offsetX+"px",e.globals.dom.elWrap.appendChild(a),this.elZoom=i(),this.elZoomIn=i(),this.elZoomOut=i(),this.elPan=i(),this.elSelection=i(),this.elZoomReset=i(),this.elMenuIcon=i(),this.elMenu=i(),this.elCustomIcons=[],this.t=e.config.chart.toolbar.tools,Array.isArray(this.t.customIcons))for(var s=0;s\n \n \n\n'),o("zoomOut",this.elZoomOut,'\n \n \n\n');var n=function(i){t.t[i]&&e.config.chart[i].enabled&&r.push({el:"zoom"===i?t.elZoom:t.elSelection,icon:"string"==typeof t.t[i]?t.t[i]:"zoom"===i?'\n \n \n \n':'\n \n \n',title:t.localeValues["zoom"===i?"selectionZoom":"selection"],class:e.globals.isTouchDevice?"apexcharts-element-hidden":"apexcharts-".concat(i,"-icon")})};n("zoom"),n("selection"),this.t.pan&&e.config.chart.zoom.enabled&&r.push({el:this.elPan,icon:"string"==typeof this.t.pan?this.t.pan:'\n \n \n \n \n \n \n \n',title:this.localeValues.pan,class:e.globals.isTouchDevice?"apexcharts-element-hidden":"apexcharts-pan-icon"}),o("reset",this.elZoomReset,'\n \n \n'),this.t.download&&r.push({el:this.elMenuIcon,icon:"string"==typeof this.t.download?this.t.download:'',title:this.localeValues.menu,class:"apexcharts-menu-icon"});for(var l=0;l0&&e.height>0&&this.slDraggableRect.selectize({points:"l, r",pointSize:8,pointType:"rect"}).resize({constraint:{minX:0,minY:0,maxX:t.globals.gridWidth,maxY:t.globals.gridHeight}}).on("resizing",this.selectionDragging.bind(this,"resizing"))}}},{key:"preselectedSelection",value:function(){var t=this.w,e=this.xyRatios;if(!t.globals.zoomEnabled)if(void 0!==t.globals.selection&&null!==t.globals.selection)this.drawSelectionRect(t.globals.selection);else if(void 0!==t.config.chart.selection.xaxis.min&&void 0!==t.config.chart.selection.xaxis.max){var i=(t.config.chart.selection.xaxis.min-t.globals.minX)/e.xRatio,a={x:i,y:0,width:t.globals.gridWidth-(t.globals.maxX-t.config.chart.selection.xaxis.max)/e.xRatio-i,height:t.globals.gridHeight,translateX:0,translateY:0,selectionEnabled:!0};this.drawSelectionRect(a),this.makeSelectionRectDraggable(),"function"==typeof t.config.chart.events.selection&&t.config.chart.events.selection(this.ctx,{xaxis:{min:t.config.chart.selection.xaxis.min,max:t.config.chart.selection.xaxis.max},yaxis:{}})}}},{key:"drawSelectionRect",value:function(t){var e=t.x,i=t.y,a=t.width,s=t.height,r=t.translateX,o=void 0===r?0:r,n=t.translateY,l=void 0===n?0:n,h=this.w,c=this.zoomRect,d=this.selectionRect;if(this.dragged||null!==h.globals.selection){var g={transform:"translate("+o+", "+l+")"};h.globals.zoomEnabled&&this.dragged&&(a<0&&(a=1),c.attr({x:e,y:i,width:a,height:s,fill:h.config.chart.zoom.zoomedArea.fill.color,"fill-opacity":h.config.chart.zoom.zoomedArea.fill.opacity,stroke:h.config.chart.zoom.zoomedArea.stroke.color,"stroke-width":h.config.chart.zoom.zoomedArea.stroke.width,"stroke-opacity":h.config.chart.zoom.zoomedArea.stroke.opacity}),m.setAttrs(c.node,g)),h.globals.selectionEnabled&&(d.attr({x:e,y:i,width:a>0?a:0,height:s>0?s:0,fill:h.config.chart.selection.fill.color,"fill-opacity":h.config.chart.selection.fill.opacity,stroke:h.config.chart.selection.stroke.color,"stroke-width":h.config.chart.selection.stroke.width,"stroke-dasharray":h.config.chart.selection.stroke.dashArray,"stroke-opacity":h.config.chart.selection.stroke.opacity}),m.setAttrs(d.node,g))}}},{key:"hideSelectionRect",value:function(t){t&&t.attr({x:0,y:0,width:0,height:0})}},{key:"selectionDrawing",value:function(t){var e=t.context,i=t.zoomtype,a=this.w,s=e,r=this.gridRect.getBoundingClientRect(),o=s.startX-1,n=s.startY,l=!1,h=!1,c=s.clientX-r.left-o,d=s.clientY-r.top-n,g={};return Math.abs(c+o)>a.globals.gridWidth?c=a.globals.gridWidth-o:s.clientX-r.left<0&&(c=o),o>s.clientX-r.left&&(l=!0,c=Math.abs(c)),n>s.clientY-r.top&&(h=!0,d=Math.abs(d)),g="x"===i?{x:l?o-c:o,y:0,width:c,height:a.globals.gridHeight}:"y"===i?{x:0,y:h?n-d:n,width:a.globals.gridWidth,height:d}:{x:l?o-c:o,y:h?n-d:n,width:c,height:d},s.drawSelectionRect(g),s.selectionDragging("resizing"),g}},{key:"selectionDragging",value:function(t,e){var i=this,a=this.w,s=this.xyRatios,r=this.selectionRect,o=0;"resizing"===t&&(o=30);var n=function(t){return parseFloat(r.node.getAttribute(t))},l={x:n("x"),y:n("y"),width:n("width"),height:n("height")};a.globals.selection=l,"function"==typeof a.config.chart.events.selection&&a.globals.selectionEnabled&&(clearTimeout(this.w.globals.selectionResizeTimer),this.w.globals.selectionResizeTimer=window.setTimeout((function(){var t=i.gridRect.getBoundingClientRect(),e=r.node.getBoundingClientRect(),o={xaxis:{min:a.globals.xAxisScale.niceMin+(e.left-t.left)*s.xRatio,max:a.globals.xAxisScale.niceMin+(e.right-t.left)*s.xRatio},yaxis:{min:a.globals.yAxisScale[0].niceMin+(t.bottom-e.bottom)*s.yRatio[0],max:a.globals.yAxisScale[0].niceMax-(e.top-t.top)*s.yRatio[0]}};a.config.chart.events.selection(i.ctx,o),a.config.chart.brush.enabled&&void 0!==a.config.chart.events.brushScrolled&&a.config.chart.events.brushScrolled(i.ctx,o)}),o))}},{key:"selectionDrawn",value:function(t){var e=t.context,i=t.zoomtype,a=this.w,s=e,r=this.xyRatios,o=this.ctx.toolbar;if(s.startX>s.endX){var n=s.startX;s.startX=s.endX,s.endX=n}if(s.startY>s.endY){var l=s.startY;s.startY=s.endY,s.endY=l}var h=void 0,c=void 0;a.globals.isRangeBar?(h=a.globals.yAxisScale[0].niceMin+s.startX*r.invertedYRatio,c=a.globals.yAxisScale[0].niceMin+s.endX*r.invertedYRatio):(h=a.globals.xAxisScale.niceMin+s.startX*r.xRatio,c=a.globals.xAxisScale.niceMin+s.endX*r.xRatio);var d=[],g=[];if(a.config.yaxis.forEach((function(t,e){d.push(a.globals.yAxisScale[e].niceMax-r.yRatio[e]*s.startY),g.push(a.globals.yAxisScale[e].niceMax-r.yRatio[e]*s.endY)})),s.dragged&&(s.dragX>10||s.dragY>10)&&h!==c)if(a.globals.zoomEnabled){var u=x.clone(a.globals.initialConfig.yaxis),p=x.clone(a.globals.initialConfig.xaxis);if(a.globals.zoomed=!0,a.config.xaxis.convertedCatToNumeric&&(h=Math.floor(h),c=Math.floor(c),h<1&&(h=1,c=a.globals.dataPoints),c-h<2&&(c=h+1)),"xy"!==i&&"x"!==i||(p={min:h,max:c}),"xy"!==i&&"y"!==i||u.forEach((function(t,e){u[e].min=g[e],u[e].max=d[e]})),a.config.chart.zoom.autoScaleYaxis){var f=new _(s.ctx);u=f.autoScaleY(s.ctx,u,{xaxis:p})}if(o){var b=o.getBeforeZoomRange(p,u);b&&(p=b.xaxis?b.xaxis:p,u=b.yaxis?b.yaxis:u)}var v={xaxis:p};a.config.chart.group||(v.yaxis=u),s.ctx.updateHelpers._updateOptions(v,!1,s.w.config.chart.animations.dynamicAnimation.enabled),"function"==typeof a.config.chart.events.zoomed&&o.zoomCallback(p,u)}else if(a.globals.selectionEnabled){var m,y=null;m={min:h,max:c},"xy"!==i&&"y"!==i||(y=x.clone(a.config.yaxis)).forEach((function(t,e){y[e].min=g[e],y[e].max=d[e]})),a.globals.selection=s.selection,"function"==typeof a.config.chart.events.selection&&a.config.chart.events.selection(s.ctx,{xaxis:m,yaxis:y})}}},{key:"panDragging",value:function(t){var e=t.context,i=this.w,a=e;if(void 0!==i.globals.lastClientPosition.x){var s=i.globals.lastClientPosition.x-a.clientX,r=i.globals.lastClientPosition.y-a.clientY;Math.abs(s)>Math.abs(r)&&s>0?this.moveDirection="left":Math.abs(s)>Math.abs(r)&&s<0?this.moveDirection="right":Math.abs(r)>Math.abs(s)&&r>0?this.moveDirection="up":Math.abs(r)>Math.abs(s)&&r<0&&(this.moveDirection="down")}i.globals.lastClientPosition={x:a.clientX,y:a.clientY};var o=i.globals.isRangeBar?i.globals.minY:i.globals.minX,n=i.globals.isRangeBar?i.globals.maxY:i.globals.maxX;i.config.xaxis.convertedCatToNumeric||a.panScrolled(o,n)}},{key:"delayedPanScrolled",value:function(){var t=this.w,e=t.globals.minX,i=t.globals.maxX,a=(t.globals.maxX-t.globals.minX)/2;"left"===this.moveDirection?(e=t.globals.minX+a,i=t.globals.maxX+a):"right"===this.moveDirection&&(e=t.globals.minX-a,i=t.globals.maxX-a),e=Math.floor(e),i=Math.floor(i),this.updateScrolledChart({xaxis:{min:e,max:i}},e,i)}},{key:"panScrolled",value:function(t,e){var i=this.w,a=this.xyRatios,s=x.clone(i.globals.initialConfig.yaxis),r=a.xRatio,o=i.globals.minX,n=i.globals.maxX;i.globals.isRangeBar&&(r=a.invertedYRatio,o=i.globals.minY,n=i.globals.maxY),"left"===this.moveDirection?(t=o+i.globals.gridWidth/15*r,e=n+i.globals.gridWidth/15*r):"right"===this.moveDirection&&(t=o-i.globals.gridWidth/15*r,e=n-i.globals.gridWidth/15*r),i.globals.isRangeBar||(ti.globals.initialMaxX)&&(t=o,e=n);var l={min:t,max:e};i.config.chart.zoom.autoScaleYaxis&&(s=new _(this.ctx).autoScaleY(this.ctx,s,{xaxis:l}));var h={xaxis:{min:t,max:e}};i.config.chart.group||(h.yaxis=s),this.updateScrolledChart(h,t,e)}},{key:"updateScrolledChart",value:function(t,e,i){var a=this.w;this.ctx.updateHelpers._updateOptions(t,!1,!1),"function"==typeof a.config.chart.events.scrolled&&a.config.chart.events.scrolled(this.ctx,{xaxis:{min:e,max:i}})}}]),i}(ht),dt=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e,this.ctx=e.ctx}return r(t,[{key:"getNearestValues",value:function(t){var e=t.hoverArea,i=t.elGrid,a=t.clientX,s=t.clientY,r=this.w,o=i.getBoundingClientRect(),n=o.width,l=o.height,h=n/(r.globals.dataPoints-1),c=l/r.globals.dataPoints,d=this.hasBars();!r.globals.comboCharts&&!d||r.config.xaxis.convertedCatToNumeric||(h=n/r.globals.dataPoints);var g=a-o.left-r.globals.barPadForNumericAxis,u=s-o.top;g<0||u<0||g>n||u>l?(e.classList.remove("hovering-zoom"),e.classList.remove("hovering-pan")):r.globals.zoomEnabled?(e.classList.remove("hovering-pan"),e.classList.add("hovering-zoom")):r.globals.panEnabled&&(e.classList.remove("hovering-zoom"),e.classList.add("hovering-pan"));var p=Math.round(g/h),f=Math.floor(u/c);d&&!r.config.xaxis.convertedCatToNumeric&&(p=Math.ceil(g/h),p-=1);var b=null,v=null,m=[],y=[];if(r.globals.seriesXvalues.forEach((function(t){m.push([t[0]+1e-6].concat(t))})),r.globals.seriesYvalues.forEach((function(t){y.push([t[0]+1e-6].concat(t))})),m=m.map((function(t){return t.filter((function(t){return x.isNumber(t)}))})),y=y.map((function(t){return t.filter((function(t){return x.isNumber(t)}))})),r.globals.isXNumeric){var w=this.ttCtx.getElGrid().getBoundingClientRect(),k=g*(w.width/n),A=u*(w.height/l);b=(v=this.closestInMultiArray(k,A,m,y)).index,p=v.j,null!==b&&(m=r.globals.seriesXvalues[b],p=(v=this.closestInArray(k,m)).index)}return r.globals.capturedSeriesIndex=null===b?-1:b,(!p||p<1)&&(p=0),r.globals.isBarHorizontal?r.globals.capturedDataPointIndex=f:r.globals.capturedDataPointIndex=p,{capturedSeries:b,j:r.globals.isBarHorizontal?f:p,hoverX:g,hoverY:u}}},{key:"closestInMultiArray",value:function(t,e,i,a){var s=this.w,r=0,o=null,n=-1;s.globals.series.length>1?r=this.getFirstActiveXArray(i):o=0;var l=i[r][0],h=Math.abs(t-l);if(i.forEach((function(e){e.forEach((function(e,i){var a=Math.abs(t-e);a0?e:-1})),s=0;s0)for(var a=0;a *")):this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap > *")}},{key:"getAllMarkers",value:function(){var t=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap");(t=u(t)).sort((function(t,e){var i=Number(t.getAttribute("data:realIndex")),a=Number(e.getAttribute("data:realIndex"));return ai?-1:0}));var e=[];return t.forEach((function(t){e.push(t.querySelector(".apexcharts-marker"))})),e}},{key:"hasMarkers",value:function(t){return this.getElMarkers(t).length>0}},{key:"getElBars",value:function(){return this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-bar-series, .apexcharts-candlestick-series, .apexcharts-boxPlot-series, .apexcharts-rangebar-series")}},{key:"hasBars",value:function(){return this.getElBars().length>0}},{key:"getHoverMarkerSize",value:function(t){var e=this.w,i=e.config.markers.hover.size;return void 0===i&&(i=e.globals.markers.size[t]+e.config.markers.hover.sizeOffset),i}},{key:"toggleAllTooltipSeriesGroups",value:function(t){var e=this.w,i=this.ttCtx;0===i.allTooltipSeriesGroups.length&&(i.allTooltipSeriesGroups=e.globals.dom.baseEl.querySelectorAll(".apexcharts-tooltip-series-group"));for(var a=i.allTooltipSeriesGroups,s=0;s ').concat(i.attrs.name,""),e+="
".concat(i.val,"
")})),v.innerHTML=t+"",m.innerHTML=e+""};o?l.globals.seriesGoals[e][i]&&Array.isArray(l.globals.seriesGoals[e][i])?y():(v.innerHTML="",m.innerHTML=""):y()}else v.innerHTML="",m.innerHTML="";null!==p&&(a[e].querySelector(".apexcharts-tooltip-text-z-label").innerHTML=l.config.tooltip.z.title,a[e].querySelector(".apexcharts-tooltip-text-z-value").innerHTML=void 0!==p?p:"");o&&f[0]&&(null==c||l.globals.ancillaryCollapsedSeriesIndices.indexOf(e)>-1||l.globals.collapsedSeriesIndices.indexOf(e)>-1?f[0].parentNode.style.display="none":f[0].parentNode.style.display=l.config.tooltip.items.display)}},{key:"toggleActiveInactiveSeries",value:function(t){var e=this.w;if(t)this.tooltipUtil.toggleAllTooltipSeriesGroups("enable");else{this.tooltipUtil.toggleAllTooltipSeriesGroups("disable");var i=e.globals.dom.baseEl.querySelector(".apexcharts-tooltip-series-group");i&&(i.classList.add("apexcharts-active"),i.style.display=e.config.tooltip.items.display)}}},{key:"getValuesToPrint",value:function(t){var e=t.i,i=t.j,a=this.w,s=this.ctx.series.filteredSeriesX(),r="",o="",n=null,l=null,h={series:a.globals.series,seriesIndex:e,dataPointIndex:i,w:a},c=a.globals.ttZFormatter;null===i?l=a.globals.series[e]:a.globals.isXNumeric&&"treemap"!==a.config.chart.type?(r=s[e][i],0===s[e].length&&(r=s[this.tooltipUtil.getFirstActiveXArray(s)][i])):r=void 0!==a.globals.labels[i]?a.globals.labels[i]:"";var d=r;a.globals.isXNumeric&&"datetime"===a.config.xaxis.type?r=new T(this.ctx).xLabelFormat(a.globals.ttKeyFormatter,d,d,{i:void 0,dateFormatter:new I(this.ctx).formatDate,w:this.w}):r=a.globals.isBarHorizontal?a.globals.yLabelFormatters[0](d,h):a.globals.xLabelFormatter(d,h);return void 0!==a.config.tooltip.x.formatter&&(r=a.globals.ttKeyFormatter(d,h)),a.globals.seriesZ.length>0&&a.globals.seriesZ[e].length>0&&(n=c(a.globals.seriesZ[e][i],a)),o="function"==typeof a.config.xaxis.tooltip.formatter?a.globals.xaxisTooltipFormatter(d,h):r,{val:Array.isArray(l)?l.join(" "):l,xVal:Array.isArray(r)?r.join(" "):r,xAxisTTVal:Array.isArray(o)?o.join(" "):o,zVal:n}}},{key:"handleCustomTooltip",value:function(t){var e=t.i,i=t.j,a=t.y1,s=t.y2,r=t.w,o=this.ttCtx.getElTooltip(),n=r.config.tooltip.custom;Array.isArray(n)&&n[e]&&(n=n[e]),o.innerHTML=n({ctx:this.ctx,series:r.globals.series,seriesIndex:e,dataPointIndex:i,y1:a,y2:s,w:r})}}]),t}(),ut=function(){function t(e){a(this,t),this.ttCtx=e,this.ctx=e.ctx,this.w=e.w}return r(t,[{key:"moveXCrosshairs",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,i=this.ttCtx,a=this.w,s=i.getElXCrosshairs(),r=t-i.xcrosshairsWidth/2,o=a.globals.labels.slice().length;if(null!==e&&(r=a.globals.gridWidth/o*e),null===s||a.globals.isBarHorizontal||(s.setAttribute("x",r),s.setAttribute("x1",r),s.setAttribute("x2",r),s.setAttribute("y2",a.globals.gridHeight),s.classList.add("apexcharts-active")),r<0&&(r=0),r>a.globals.gridWidth&&(r=a.globals.gridWidth),i.isXAxisTooltipEnabled){var n=r;"tickWidth"!==a.config.xaxis.crosshairs.width&&"barWidth"!==a.config.xaxis.crosshairs.width||(n=r+i.xcrosshairsWidth/2),this.moveXAxisTooltip(n)}}},{key:"moveYCrosshairs",value:function(t){var e=this.ttCtx;null!==e.ycrosshairs&&m.setAttrs(e.ycrosshairs,{y1:t,y2:t}),null!==e.ycrosshairsHidden&&m.setAttrs(e.ycrosshairsHidden,{y1:t,y2:t})}},{key:"moveXAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;if(null!==i.xaxisTooltip&&0!==i.xcrosshairsWidth){i.xaxisTooltip.classList.add("apexcharts-active");var a=i.xaxisOffY+e.config.xaxis.tooltip.offsetY+e.globals.translateY+1+e.config.xaxis.offsetY;if(t-=i.xaxisTooltip.getBoundingClientRect().width/2,!isNaN(t)){t+=e.globals.translateX;var s;s=new m(this.ctx).getTextRects(i.xaxisTooltipText.innerHTML),i.xaxisTooltipText.style.minWidth=s.width+"px",i.xaxisTooltip.style.left=t+"px",i.xaxisTooltip.style.top=a+"px"}}}},{key:"moveYAxisTooltip",value:function(t){var e=this.w,i=this.ttCtx;null===i.yaxisTTEls&&(i.yaxisTTEls=e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxistooltip"));var a=parseInt(i.ycrosshairsHidden.getAttribute("y1"),10),s=e.globals.translateY+a,r=i.yaxisTTEls[t].getBoundingClientRect().height,o=e.globals.translateYAxisX[t]-2;e.config.yaxis[t].opposite&&(o-=26),s-=r/2,-1===e.globals.ignoreYAxisIndexes.indexOf(t)?(i.yaxisTTEls[t].classList.add("apexcharts-active"),i.yaxisTTEls[t].style.top=s+"px",i.yaxisTTEls[t].style.left=o+e.config.yaxis[t].tooltip.offsetX+"px"):i.yaxisTTEls[t].classList.remove("apexcharts-active")}},{key:"moveTooltip",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=this.w,s=this.ttCtx,r=s.getElTooltip(),o=s.tooltipRect,n=null!==i?parseFloat(i):1,l=parseFloat(t)+n+5,h=parseFloat(e)+n/2;if(l>a.globals.gridWidth/2&&(l=l-o.ttWidth-n-10),l>a.globals.gridWidth-o.ttWidth-10&&(l=a.globals.gridWidth-o.ttWidth),l<-20&&(l=-20),a.config.tooltip.followCursor){var c=s.getElGrid().getBoundingClientRect();(l=s.e.clientX-c.left)>a.globals.gridWidth/2&&(l-=s.tooltipRect.ttWidth),(h=s.e.clientY+a.globals.translateY-c.top)>a.globals.gridHeight/2&&(h-=s.tooltipRect.ttHeight)}else a.globals.isBarHorizontal||o.ttHeight/2+h>a.globals.gridHeight&&(h=a.globals.gridHeight-o.ttHeight+a.globals.translateY);isNaN(l)||(l+=a.globals.translateX,r.style.left=l+"px",r.style.top=h+"px")}},{key:"moveMarkers",value:function(t,e){var i=this.w,a=this.ttCtx;if(i.globals.markers.size[t]>0)for(var s=i.globals.dom.baseEl.querySelectorAll(" .apexcharts-series[data\\:realIndex='".concat(t,"'] .apexcharts-marker")),r=0;r0&&(h.setAttribute("r",n),h.setAttribute("cx",i),h.setAttribute("cy",a)),this.moveXCrosshairs(i),r.fixedTooltip||this.moveTooltip(i,a,n)}}},{key:"moveDynamicPointsOnHover",value:function(t){var e,i=this.ttCtx,a=i.w,s=0,r=0,o=a.globals.pointsArray;e=new N(this.ctx).getActiveConfigSeriesIndex("asc",["line","area","scatter","bubble"]);var n=i.tooltipUtil.getHoverMarkerSize(e);o[e]&&(s=o[e][t][0],r=o[e][t][1]);var l=i.tooltipUtil.getAllMarkers();if(null!==l)for(var h=0;h0?(l[h]&&l[h].setAttribute("r",n),l[h]&&l[h].setAttribute("cy",d)):l[h]&&l[h].setAttribute("r",0)}}this.moveXCrosshairs(s),i.fixedTooltip||this.moveTooltip(s,r||a.globals.gridHeight,n)}},{key:"moveStickyTooltipOverBars",value:function(t,e){var i=this.w,a=this.ttCtx,s=i.globals.columnSeries?i.globals.columnSeries.length:i.globals.series.length,r=s>=2&&s%2==0?Math.floor(s/2):Math.floor(s/2)+1;i.globals.isBarHorizontal&&(r=new N(this.ctx).getActiveConfigSeriesIndex("desc")+1);var o=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[rel='".concat(r,"'] path[j='").concat(t,"'], .apexcharts-candlestick-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"'], .apexcharts-boxPlot-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"'], .apexcharts-rangebar-series .apexcharts-series[rel='").concat(r,"'] path[j='").concat(t,"']"));o||"number"!=typeof e||(o=i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[data\\:realIndex='".concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-candlestick-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-boxPlot-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"'],\n .apexcharts-rangebar-series .apexcharts-series[data\\:realIndex='").concat(e,"'] path[j='").concat(t,"']")));var n=o?parseFloat(o.getAttribute("cx")):0,l=o?parseFloat(o.getAttribute("cy")):0,h=o?parseFloat(o.getAttribute("barWidth")):0,c=a.getElGrid().getBoundingClientRect(),d=o&&(o.classList.contains("apexcharts-candlestick-area")||o.classList.contains("apexcharts-boxPlot-area"));i.globals.isXNumeric?(o&&!d&&(n-=s%2!=0?h/2:0),o&&d&&i.globals.comboCharts&&(n-=h/2)):i.globals.isBarHorizontal||(n=a.xAxisTicksPositions[t-1]+a.dataPointsDividedWidth/2,isNaN(n)&&(n=a.xAxisTicksPositions[t]-a.dataPointsDividedWidth/2)),i.globals.isBarHorizontal?l-=a.tooltipRect.ttHeight:i.config.tooltip.followCursor?l=a.e.clientY-c.top-a.tooltipRect.ttHeight/2:l+a.tooltipRect.ttHeight+15>i.globals.gridHeight&&(l=i.globals.gridHeight),i.globals.isBarHorizontal||this.moveXCrosshairs(n),a.fixedTooltip||this.moveTooltip(n,l||i.globals.gridHeight)}}]),t}(),pt=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e,this.ctx=e.ctx,this.tooltipPosition=new ut(e)}return r(t,[{key:"drawDynamicPoints",value:function(){var t=this.w,e=new m(this.ctx),i=new D(this.ctx),a=t.globals.dom.baseEl.querySelectorAll(".apexcharts-series");a=u(a),t.config.chart.stacked&&a.sort((function(t,e){return parseFloat(t.getAttribute("data:realIndex"))-parseFloat(e.getAttribute("data:realIndex"))}));for(var s=0;s2&&void 0!==arguments[2]?arguments[2]:null,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.w;"bubble"!==s.config.chart.type&&this.newPointSize(t,e);var r=e.getAttribute("cx"),o=e.getAttribute("cy");if(null!==i&&null!==a&&(r=i,o=a),this.tooltipPosition.moveXCrosshairs(r),!this.fixedTooltip){if("radar"===s.config.chart.type){var n=this.ttCtx.getElGrid().getBoundingClientRect();r=this.ttCtx.e.clientX-n.left}this.tooltipPosition.moveTooltip(r,o,s.config.markers.hover.size)}}},{key:"enlargePoints",value:function(t){for(var e=this.w,i=this,a=this.ttCtx,s=t,r=e.globals.dom.baseEl.querySelectorAll(".apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker"),o=e.config.markers.hover.size,n=0;n=0?t[e].setAttribute("r",i):t[e].setAttribute("r",0)}}}]),t}(),ft=function(){function t(e){a(this,t),this.w=e.w,this.ttCtx=e}return r(t,[{key:"getAttr",value:function(t,e){return parseFloat(t.target.getAttribute(e))}},{key:"handleHeatTreeTooltip",value:function(t){var e=t.e,i=t.opt,a=t.x,s=t.y,r=t.type,o=this.ttCtx,n=this.w;if(e.target.classList.contains("apexcharts-".concat(r,"-rect"))){var l=this.getAttr(e,"i"),h=this.getAttr(e,"j"),c=this.getAttr(e,"cx"),d=this.getAttr(e,"cy"),g=this.getAttr(e,"width"),u=this.getAttr(e,"height");if(o.tooltipLabels.drawSeriesTexts({ttItems:i.ttItems,i:l,j:h,shared:!1,e:e}),n.globals.capturedSeriesIndex=l,n.globals.capturedDataPointIndex=h,a=c+o.tooltipRect.ttWidth/2+g,s=d+o.tooltipRect.ttHeight/2-u/2,o.tooltipPosition.moveXCrosshairs(c+g/2),a>n.globals.gridWidth/2&&(a=c-o.tooltipRect.ttWidth/2+g),o.w.config.tooltip.followCursor){var p=n.globals.dom.elWrap.getBoundingClientRect();a=n.globals.clientX-p.left-(a>n.globals.gridWidth/2?o.tooltipRect.ttWidth:0),s=n.globals.clientY-p.top-(s>n.globals.gridHeight/2?o.tooltipRect.ttHeight:0)}}return{x:a,y:s}}},{key:"handleMarkerTooltip",value:function(t){var e,i,a=t.e,s=t.opt,r=t.x,o=t.y,n=this.w,l=this.ttCtx;if(a.target.classList.contains("apexcharts-marker")){var h=parseInt(s.paths.getAttribute("cx"),10),c=parseInt(s.paths.getAttribute("cy"),10),d=parseFloat(s.paths.getAttribute("val"));if(i=parseInt(s.paths.getAttribute("rel"),10),e=parseInt(s.paths.parentNode.parentNode.parentNode.getAttribute("rel"),10)-1,l.intersect){var g=x.findAncestor(s.paths,"apexcharts-series");g&&(e=parseInt(g.getAttribute("data:realIndex"),10))}if(l.tooltipLabels.drawSeriesTexts({ttItems:s.ttItems,i:e,j:i,shared:!l.showOnIntersect&&n.config.tooltip.shared,e:a}),"mouseup"===a.type&&l.markerClick(a,e,i),n.globals.capturedSeriesIndex=e,n.globals.capturedDataPointIndex=i,r=h,o=c+n.globals.translateY-1.4*l.tooltipRect.ttHeight,l.w.config.tooltip.followCursor){var u=l.getElGrid().getBoundingClientRect();o=l.e.clientY+n.globals.translateY-u.top}d<0&&(o=c),l.marker.enlargeCurrentPoint(i,s.paths,r,o)}return{x:r,y:o}}},{key:"handleBarTooltip",value:function(t){var e,i,a=t.e,s=t.opt,r=this.w,o=this.ttCtx,n=o.getElTooltip(),l=0,h=0,c=0,d=this.getBarTooltipXY({e:a,opt:s});e=d.i;var g=d.barHeight,u=d.j;r.globals.capturedSeriesIndex=e,r.globals.capturedDataPointIndex=u,r.globals.isBarHorizontal&&o.tooltipUtil.hasBars()||!r.config.tooltip.shared?(h=d.x,c=d.y,i=Array.isArray(r.config.stroke.width)?r.config.stroke.width[e]:r.config.stroke.width,l=h):r.globals.comboCharts||r.config.tooltip.shared||(l/=2),isNaN(c)&&(c=r.globals.svgHeight-o.tooltipRect.ttHeight);var p=parseInt(s.paths.parentNode.getAttribute("data:realIndex"),10),f=r.globals.isMultipleYAxis?r.config.yaxis[p]&&r.config.yaxis[p].reversed:r.config.yaxis[0].reversed;if(h+o.tooltipRect.ttWidth>r.globals.gridWidth&&!f?h-=o.tooltipRect.ttWidth:h<0&&(h=0),o.w.config.tooltip.followCursor){var x=o.getElGrid().getBoundingClientRect();c=o.e.clientY-x.top}null===o.tooltip&&(o.tooltip=r.globals.dom.baseEl.querySelector(".apexcharts-tooltip")),r.config.tooltip.shared||(r.globals.comboBarCount>0?o.tooltipPosition.moveXCrosshairs(l+i/2):o.tooltipPosition.moveXCrosshairs(l)),!o.fixedTooltip&&(!r.config.tooltip.shared||r.globals.isBarHorizontal&&o.tooltipUtil.hasBars())&&(f&&(h-=o.tooltipRect.ttWidth)<0&&(h=0),!f||r.globals.isBarHorizontal&&o.tooltipUtil.hasBars()||(c=c+g-2*(r.globals.series[e][u]<0?g:0)),c=c+r.globals.translateY-o.tooltipRect.ttHeight/2,n.style.left=h+r.globals.translateX+"px",n.style.top=c+"px")}},{key:"getBarTooltipXY",value:function(t){var e=t.e,i=t.opt,a=this.w,s=null,r=this.ttCtx,o=0,n=0,l=0,h=0,c=0,d=e.target.classList;if(d.contains("apexcharts-bar-area")||d.contains("apexcharts-candlestick-area")||d.contains("apexcharts-boxPlot-area")||d.contains("apexcharts-rangebar-area")){var g=e.target,u=g.getBoundingClientRect(),p=i.elGrid.getBoundingClientRect(),f=u.height;c=u.height;var x=u.width,b=parseInt(g.getAttribute("cx"),10),v=parseInt(g.getAttribute("cy"),10);h=parseFloat(g.getAttribute("barWidth"));var m="touchmove"===e.type?e.touches[0].clientX:e.clientX;s=parseInt(g.getAttribute("j"),10),o=parseInt(g.parentNode.getAttribute("rel"),10)-1;var y=g.getAttribute("data-range-y1"),w=g.getAttribute("data-range-y2");a.globals.comboCharts&&(o=parseInt(g.parentNode.getAttribute("data:realIndex"),10)),r.tooltipLabels.drawSeriesTexts({ttItems:i.ttItems,i:o,j:s,y1:y?parseInt(y,10):null,y2:w?parseInt(w,10):null,shared:!r.showOnIntersect&&a.config.tooltip.shared,e:e}),a.config.tooltip.followCursor?a.globals.isBarHorizontal?(n=m-p.left+15,l=v-r.dataPointsDividedHeight+f/2-r.tooltipRect.ttHeight/2):(n=a.globals.isXNumeric?b-x/2:b-r.dataPointsDividedWidth+x/2,l=e.clientY-p.top-r.tooltipRect.ttHeight/2-15):a.globals.isBarHorizontal?((n=b)0&&i.setAttribute("width",e.xcrosshairsWidth)}},{key:"handleYCrosshair",value:function(){var t=this.w,e=this.ttCtx;e.ycrosshairs=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs"),e.ycrosshairsHidden=t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs-hidden")}},{key:"drawYaxisTooltipText",value:function(t,e,i){var a=this.ttCtx,s=this.w,r=s.globals.yLabelFormatters[t];if(a.yaxisTooltips[t]){var o=a.getElGrid().getBoundingClientRect(),n=(e-o.top)*i.yRatio[t],l=s.globals.maxYArr[t]-s.globals.minYArr[t],h=s.globals.minYArr[t]+(l-n);a.tooltipPosition.moveYCrosshairs(e-o.top),a.yaxisTooltipText[t].innerHTML=r(h),a.tooltipPosition.moveYAxisTooltip(t)}}}]),t}(),bt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w;var i=this.w;this.tConfig=i.config.tooltip,this.tooltipUtil=new dt(this),this.tooltipLabels=new gt(this),this.tooltipPosition=new ut(this),this.marker=new pt(this),this.intersect=new ft(this),this.axesTooltip=new xt(this),this.showOnIntersect=this.tConfig.intersect,this.showTooltipTitle=this.tConfig.x.show,this.fixedTooltip=this.tConfig.fixed.enabled,this.xaxisTooltip=null,this.yaxisTTEls=null,this.isBarShared=!i.globals.isBarHorizontal&&this.tConfig.shared,this.lastHoverTime=Date.now()}return r(t,[{key:"getElTooltip",value:function(t){return t||(t=this),t.w.globals.dom.baseEl?t.w.globals.dom.baseEl.querySelector(".apexcharts-tooltip"):null}},{key:"getElXCrosshairs",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-xcrosshairs")}},{key:"getElGrid",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-grid")}},{key:"drawTooltip",value:function(t){var e=this.w;this.xyRatios=t,this.isXAxisTooltipEnabled=e.config.xaxis.tooltip.enabled&&e.globals.axisCharts,this.yaxisTooltips=e.config.yaxis.map((function(t,i){return!!(t.show&&t.tooltip.enabled&&e.globals.axisCharts)})),this.allTooltipSeriesGroups=[],e.globals.axisCharts||(this.showTooltipTitle=!1);var i=document.createElement("div");if(i.classList.add("apexcharts-tooltip"),e.config.tooltip.cssClass&&i.classList.add(e.config.tooltip.cssClass),i.classList.add("apexcharts-theme-".concat(this.tConfig.theme)),e.globals.dom.elWrap.appendChild(i),e.globals.axisCharts){this.axesTooltip.drawXaxisTooltip(),this.axesTooltip.drawYaxisTooltip(),this.axesTooltip.setXCrosshairWidth(),this.axesTooltip.handleYCrosshair();var a=new V(this.ctx);this.xAxisTicksPositions=a.getXAxisTicksPositions()}if(!e.globals.comboCharts&&!this.tConfig.intersect&&"rangeBar"!==e.config.chart.type||this.tConfig.shared||(this.showOnIntersect=!0),0!==e.config.markers.size&&0!==e.globals.markers.largestSize||this.marker.drawDynamicPoints(this),e.globals.collapsedSeries.length!==e.globals.series.length){this.dataPointsDividedHeight=e.globals.gridHeight/e.globals.dataPoints,this.dataPointsDividedWidth=e.globals.gridWidth/e.globals.dataPoints,this.showTooltipTitle&&(this.tooltipTitle=document.createElement("div"),this.tooltipTitle.classList.add("apexcharts-tooltip-title"),this.tooltipTitle.style.fontFamily=this.tConfig.style.fontFamily||e.config.chart.fontFamily,this.tooltipTitle.style.fontSize=this.tConfig.style.fontSize,i.appendChild(this.tooltipTitle));var s=e.globals.series.length;(e.globals.xyCharts||e.globals.comboCharts)&&this.tConfig.shared&&(s=this.showOnIntersect?1:e.globals.series.length),this.legendLabels=e.globals.dom.baseEl.querySelectorAll(".apexcharts-legend-text"),this.ttItems=this.createTTElements(s),this.addSVGEvents()}}},{key:"createTTElements",value:function(t){for(var e=this,i=this.w,a=[],s=this.getElTooltip(),r=function(r){var o=document.createElement("div");o.classList.add("apexcharts-tooltip-series-group"),o.style.order=i.config.tooltip.inverseOrder?t-r:r+1,e.tConfig.shared&&e.tConfig.enabledOnSeries&&Array.isArray(e.tConfig.enabledOnSeries)&&e.tConfig.enabledOnSeries.indexOf(r)<0&&o.classList.add("apexcharts-tooltip-series-group-hidden");var n=document.createElement("span");n.classList.add("apexcharts-tooltip-marker"),n.style.backgroundColor=i.globals.colors[r],o.appendChild(n);var l=document.createElement("div");l.classList.add("apexcharts-tooltip-text"),l.style.fontFamily=e.tConfig.style.fontFamily||i.config.chart.fontFamily,l.style.fontSize=e.tConfig.style.fontSize,["y","goals","z"].forEach((function(t){var e=document.createElement("div");e.classList.add("apexcharts-tooltip-".concat(t,"-group"));var i=document.createElement("span");i.classList.add("apexcharts-tooltip-text-".concat(t,"-label")),e.appendChild(i);var a=document.createElement("span");a.classList.add("apexcharts-tooltip-text-".concat(t,"-value")),e.appendChild(a),l.appendChild(e)})),o.appendChild(l),s.appendChild(o),a.push(o)},o=0;o0&&this.addPathsEventListeners(u,c),this.tooltipUtil.hasBars()&&!this.tConfig.shared&&this.addDatapointEventsListeners(c)}}},{key:"drawFixedTooltipRect",value:function(){var t=this.w,e=this.getElTooltip(),i=e.getBoundingClientRect(),a=i.width+10,s=i.height+10,r=this.tConfig.fixed.offsetX,o=this.tConfig.fixed.offsetY,n=this.tConfig.fixed.position.toLowerCase();return n.indexOf("right")>-1&&(r=r+t.globals.svgWidth-a+10),n.indexOf("bottom")>-1&&(o=o+t.globals.svgHeight-s-10),e.style.left=r+"px",e.style.top=o+"px",{x:r,y:o,ttWidth:a,ttHeight:s}}},{key:"addDatapointEventsListeners",value:function(t){var e=this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers .apexcharts-marker, .apexcharts-bar-area, .apexcharts-candlestick-area, .apexcharts-boxPlot-area, .apexcharts-rangebar-area");this.addPathsEventListeners(e,t)}},{key:"addPathsEventListeners",value:function(t,e){for(var i=this,a=function(a){var s={paths:t[a],tooltipEl:e.tooltipEl,tooltipY:e.tooltipY,tooltipX:e.tooltipX,elGrid:e.elGrid,hoverArea:e.hoverArea,ttItems:e.ttItems};["mousemove","mouseup","touchmove","mouseout","touchend"].map((function(e){return t[a].addEventListener(e,i.onSeriesHover.bind(i,s),{capture:!1,passive:!0})}))},s=0;s=100?this.seriesHover(t,e):(clearTimeout(this.seriesHoverTimeout),this.seriesHoverTimeout=setTimeout((function(){i.seriesHover(t,e)}),100-a))}},{key:"seriesHover",value:function(t,e){var i=this;this.lastHoverTime=Date.now();var a=[],s=this.w;s.config.chart.group&&(a=this.ctx.getGroupedCharts()),s.globals.axisCharts&&(s.globals.minX===-1/0&&s.globals.maxX===1/0||0===s.globals.dataPoints)||(a.length?a.forEach((function(a){var s=i.getElTooltip(a),r={paths:t.paths,tooltipEl:s,tooltipY:t.tooltipY,tooltipX:t.tooltipX,elGrid:t.elGrid,hoverArea:t.hoverArea,ttItems:a.w.globals.tooltip.ttItems};a.w.globals.minX===i.w.globals.minX&&a.w.globals.maxX===i.w.globals.maxX&&a.w.globals.tooltip.seriesHoverByContext({chartCtx:a,ttCtx:a.w.globals.tooltip,opt:r,e:e})})):this.seriesHoverByContext({chartCtx:this.ctx,ttCtx:this.w.globals.tooltip,opt:t,e:e}))}},{key:"seriesHoverByContext",value:function(t){var e=t.chartCtx,i=t.ttCtx,a=t.opt,s=t.e,r=e.w,o=this.getElTooltip();if(o){if(i.tooltipRect={x:0,y:0,ttWidth:o.getBoundingClientRect().width,ttHeight:o.getBoundingClientRect().height},i.e=s,i.tooltipUtil.hasBars()&&!r.globals.comboCharts&&!i.isBarShared)if(this.tConfig.onDatasetHover.highlightDataSeries)new N(e).toggleSeriesOnHover(s,s.target.parentNode);i.fixedTooltip&&i.drawFixedTooltipRect(),r.globals.axisCharts?i.axisChartsTooltips({e:s,opt:a,tooltipRect:i.tooltipRect}):i.nonAxisChartsTooltips({e:s,opt:a,tooltipRect:i.tooltipRect})}}},{key:"axisChartsTooltips",value:function(t){var e,i,a=t.e,s=t.opt,r=this.w,o=s.elGrid.getBoundingClientRect(),n="touchmove"===a.type?a.touches[0].clientX:a.clientX,l="touchmove"===a.type?a.touches[0].clientY:a.clientY;if(this.clientY=l,this.clientX=n,r.globals.capturedSeriesIndex=-1,r.globals.capturedDataPointIndex=-1,lo.top+o.height)this.handleMouseOut(s);else{if(Array.isArray(this.tConfig.enabledOnSeries)&&!r.config.tooltip.shared){var h=parseInt(s.paths.getAttribute("index"),10);if(this.tConfig.enabledOnSeries.indexOf(h)<0)return void this.handleMouseOut(s)}var c=this.getElTooltip(),d=this.getElXCrosshairs(),g=r.globals.xyCharts||"bar"===r.config.chart.type&&!r.globals.isBarHorizontal&&this.tooltipUtil.hasBars()&&this.tConfig.shared||r.globals.comboCharts&&this.tooltipUtil.hasBars();if("mousemove"===a.type||"touchmove"===a.type||"mouseup"===a.type){if(r.globals.collapsedSeries.length+r.globals.ancillaryCollapsedSeries.length===r.globals.series.length)return;null!==d&&d.classList.add("apexcharts-active");var u=this.yaxisTooltips.filter((function(t){return!0===t}));if(null!==this.ycrosshairs&&u.length&&this.ycrosshairs.classList.add("apexcharts-active"),g&&!this.showOnIntersect)this.handleStickyTooltip(a,n,l,s);else if("heatmap"===r.config.chart.type||"treemap"===r.config.chart.type){var p=this.intersect.handleHeatTreeTooltip({e:a,opt:s,x:e,y:i,type:r.config.chart.type});e=p.x,i=p.y,c.style.left=e+"px",c.style.top=i+"px"}else this.tooltipUtil.hasBars()&&this.intersect.handleBarTooltip({e:a,opt:s}),this.tooltipUtil.hasMarkers()&&this.intersect.handleMarkerTooltip({e:a,opt:s,x:e,y:i});if(this.yaxisTooltips.length)for(var f=0;fl.width)this.handleMouseOut(a);else if(null!==n)this.handleStickyCapturedSeries(t,n,a,o);else if(this.tooltipUtil.isXoverlap(o)||s.globals.isBarHorizontal){var h=s.globals.series.findIndex((function(t,e){return!s.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,h,o,a.ttItems)}}},{key:"handleStickyCapturedSeries",value:function(t,e,i,a){var s=this.w;if(!this.tConfig.shared&&null===s.globals.series[e][a])return void this.handleMouseOut(i);if(void 0!==s.globals.series[e][a])this.tConfig.shared&&this.tooltipUtil.isXoverlap(a)&&this.tooltipUtil.isInitialSeriesSameLen()?this.create(t,this,e,a,i.ttItems):this.create(t,this,e,a,i.ttItems,!1);else if(this.tooltipUtil.isXoverlap(a)){var r=s.globals.series.findIndex((function(t,e){return!s.globals.collapsedSeriesIndices.includes(e)}));this.create(t,this,r,a,i.ttItems)}}},{key:"deactivateHoverFilter",value:function(){for(var t=this.w,e=new m(this.ctx),i=t.globals.dom.Paper.select(".apexcharts-bar-area"),a=0;a5&&void 0!==arguments[5]?arguments[5]:null,S=this.w,C=i;"mouseup"===t.type&&this.markerClick(t,a,s),null===A&&(A=this.tConfig.shared);var L=this.tooltipUtil.hasMarkers(a),P=this.tooltipUtil.getElBars();if(S.config.legend.tooltipHoverFormatter){var I=S.config.legend.tooltipHoverFormatter,T=Array.from(this.legendLabels);T.forEach((function(t){var e=t.getAttribute("data:default-text");t.innerHTML=decodeURIComponent(e)}));for(var M=0;M0?C.marker.enlargePoints(s):C.tooltipPosition.moveDynamicPointsOnHover(s);else if(this.tooltipUtil.hasBars()&&(this.barSeriesHeight=this.tooltipUtil.getBarsHeight(P),this.barSeriesHeight>0)){var R=new m(this.ctx),D=S.globals.dom.Paper.select(".apexcharts-bar-area[j='".concat(s,"']"));this.deactivateHoverFilter(),this.tooltipPosition.moveStickyTooltipOverBars(s,a);for(var H=0;Hs.globals.gridHeight&&(p=s.globals.gridHeight-v)),{bcx:c,bcy:h,dataLabelsX:e,dataLabelsY:p,totalDataLabelsX:a,totalDataLabelsY:i,totalDataLabelsAnchor:"middle"}}},{key:"calculateBarsDataLabelsPosition",value:function(t){var e=this.w,i=t.x,a=t.i,s=t.j,r=t.realIndex,o=t.groupIndex,n=t.bcy,l=t.barHeight,h=t.barWidth,c=t.textRects,d=t.dataLabelsX,g=t.strokeWidth,u=t.dataLabelsConfig,p=t.barDataLabelsConfig,f=t.barTotalDataLabelsConfig,x=t.offX,b=t.offY,v=e.globals.gridHeight/e.globals.dataPoints;h=Math.abs(h);var y,w,k=(n+=-1!==o?o*l:0)-(this.barCtx.isRangeBar?0:v)+l/2+c.height/2+b-3,A="start",S=this.barCtx.series[a][s]<0,C=i;switch(this.barCtx.isReversed&&(C=i+h-(S?2*h:0),i=e.globals.gridWidth-h),p.position){case"center":d=S?C+h/2-x:Math.max(c.width/2,C-h/2)+x;break;case"bottom":d=S?C+h-g-Math.round(c.width/2)-x:C-h+g+Math.round(c.width/2)+x;break;case"top":d=S?C-g+Math.round(c.width/2)-x:C-g-Math.round(c.width/2)+x}if(this.barCtx.lastActiveBarSerieIndex===r&&f.enabled){var L=new m(this.barCtx.ctx).getTextRects(this.getStackedTotalDataLabel({realIndex:r,j:s}),u.fontSize);S?(y=C-g+Math.round(L.width/2)-x-f.offsetX-15,A="end"):y=C-g-Math.round(L.width/2)+x+f.offsetX+15,w=k+f.offsetY}return e.config.chart.stacked||(d<0?d=d+c.width+g:d+c.width/2>e.globals.gridWidth&&(d=e.globals.gridWidth-c.width-g)),{bcx:i,bcy:n,dataLabelsX:d,dataLabelsY:k,totalDataLabelsX:y,totalDataLabelsY:w,totalDataLabelsAnchor:A}}},{key:"drawCalculatedDataLabels",value:function(t){var i=t.x,a=t.y,s=t.val,r=t.i,o=t.j,n=t.textRects,l=t.barHeight,h=t.barWidth,c=t.dataLabelsConfig,d=this.w,g="rotate(0)";"vertical"===d.config.plotOptions.bar.dataLabels.orientation&&(g="rotate(-90, ".concat(i,", ").concat(a,")"));var u=new O(this.barCtx.ctx),p=new m(this.barCtx.ctx),f=c.formatter,x=null,b=d.globals.collapsedSeriesIndices.indexOf(r)>-1;if(c.enabled&&!b){x=p.group({class:"apexcharts-data-labels",transform:g});var v="";void 0!==s&&(v=f(s,e(e({},d),{},{seriesIndex:r,dataPointIndex:o,w:d}))),!s&&d.config.plotOptions.bar.hideZeroBarsWhenGrouped&&(v="");var y=d.globals.series[r][o]<0,w=d.config.plotOptions.bar.dataLabels.position;if("vertical"===d.config.plotOptions.bar.dataLabels.orientation&&("top"===w&&(c.textAnchor=y?"end":"start"),"center"===w&&(c.textAnchor="middle"),"bottom"===w&&(c.textAnchor=y?"end":"start")),this.barCtx.isRangeBar&&this.barCtx.barOptions.dataLabels.hideOverflowingLabels)hMath.abs(h)&&(v=""):n.height/1.6>Math.abs(l)&&(v=""));var k=e({},c);this.barCtx.isHorizontal&&s<0&&("start"===c.textAnchor?k.textAnchor="end":"end"===c.textAnchor&&(k.textAnchor="start")),u.plotDataLabelsText({x:i,y:a,text:v,i:r,j:o,parent:x,dataLabelsConfig:k,alwaysDrawDataLabel:!0,offsetCorrection:!0})}return x}},{key:"drawTotalDataLabels",value:function(t){var e,i=t.x,a=t.y,s=t.val,r=t.realIndex,o=t.textAnchor,n=t.barTotalDataLabelsConfig,l=new m(this.barCtx.ctx);return n.enabled&&void 0!==i&&void 0!==a&&this.barCtx.lastActiveBarSerieIndex===r&&(e=l.drawText({x:i,y:a,foreColor:n.style.color,text:s,textAnchor:o,fontFamily:n.style.fontFamily,fontSize:n.style.fontSize,fontWeight:n.style.fontWeight})),e}}]),t}(),mt=function(){function t(e){a(this,t),this.w=e.w,this.barCtx=e}return r(t,[{key:"initVariables",value:function(t){var e=this.w;this.barCtx.series=t,this.barCtx.totalItems=0,this.barCtx.seriesLen=0,this.barCtx.visibleI=-1,this.barCtx.visibleItems=1;for(var i=0;i0&&(this.barCtx.seriesLen=this.barCtx.seriesLen+1,this.barCtx.totalItems+=t[i].length),e.globals.isXNumeric)for(var a=0;ae.globals.minX&&e.globals.seriesX[i][a]0&&(a=l.globals.minXDiff/d),(r=a/this.barCtx.seriesLen*parseInt(this.barCtx.barOptions.columnWidth,10)/100)<1&&(r=1)}-1===String(this.barCtx.barOptions.columnWidth).indexOf("%")&&(r=parseInt(this.barCtx.barOptions.columnWidth,10)),o=l.globals.gridHeight-this.barCtx.baseLineY[this.barCtx.yaxisIndex]-(this.barCtx.isReversed?l.globals.gridHeight:0)+(this.barCtx.isReversed?2*this.barCtx.baseLineY[this.barCtx.yaxisIndex]:0),t=l.globals.padHorizontal+(a-r*this.barCtx.seriesLen)/2}return{x:t,y:e,yDivision:i,xDivision:a,barHeight:s,barWidth:r,zeroH:o,zeroW:n}}},{key:"initializeStackedPrevVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].prevY=[],t[e].prevX=[],t[e].prevYF=[],t[e].prevXF=[],t[e].prevYVal=[],t[e].prevXVal=[]})):(t.prevY=[],t.prevX=[],t.prevYF=[],t.prevXF=[],t.prevYVal=[],t.prevXVal=[])}},{key:"initializeStackedXYVars",value:function(t){var e=t.w;e.globals.hasSeriesGroups?e.globals.seriesGroups.forEach((function(e){t[e]||(t[e]={}),t[e].xArrj=[],t[e].xArrjF=[],t[e].xArrjVal=[],t[e].yArrj=[],t[e].yArrjF=[],t[e].yArrjVal=[]})):(t.xArrj=[],t.xArrjF=[],t.xArrjVal=[],t.yArrj=[],t.yArrjF=[],t.yArrjVal=[])}},{key:"getPathFillColor",value:function(t,e,i,a){var s,r,o,n,l=this.w,h=new R(this.barCtx.ctx),c=null,d=this.barCtx.barOptions.distributed?i:e;this.barCtx.barOptions.colors.ranges.length>0&&this.barCtx.barOptions.colors.ranges.map((function(a){t[e][i]>=a.from&&t[e][i]<=a.to&&(c=a.color)}));return l.config.series[e].data[i]&&l.config.series[e].data[i].fillColor&&(c=l.config.series[e].data[i].fillColor),h.fillPath({seriesNumber:this.barCtx.barOptions.distributed?d:a,dataPointIndex:i,color:c,value:t[e][i],fillConfig:null===(s=l.config.series[e].data[i])||void 0===s?void 0:s.fill,fillType:null!==(r=l.config.series[e].data[i])&&void 0!==r&&null!==(o=r.fill)&&void 0!==o&&o.type?null===(n=l.config.series[e].data[i])||void 0===n?void 0:n.fill.type:l.config.fill.type})}},{key:"getStrokeWidth",value:function(t,e,i){var a=0,s=this.w;return this.barCtx.series[t][e]?this.barCtx.isNullValue=!1:this.barCtx.isNullValue=!0,s.config.stroke.show&&(this.barCtx.isNullValue||(a=Array.isArray(this.barCtx.strokeWidth)?this.barCtx.strokeWidth[i]:this.barCtx.strokeWidth)),a}},{key:"shouldApplyRadius",value:function(t){var e=this.w,i=!1;return e.config.plotOptions.bar.borderRadius>0&&(e.config.chart.stacked&&"last"===e.config.plotOptions.bar.borderRadiusWhenStacked?this.barCtx.lastActiveBarSerieIndex===t&&(i=!0):i=!0),i}},{key:"barBackground",value:function(t){var e=t.j,i=t.i,a=t.x1,s=t.x2,r=t.y1,o=t.y2,n=t.elSeries,l=this.w,h=new m(this.barCtx.ctx),c=new N(this.barCtx.ctx).getActiveConfigSeriesIndex();if(this.barCtx.barOptions.colors.backgroundBarColors.length>0&&c===i){e>=this.barCtx.barOptions.colors.backgroundBarColors.length&&(e%=this.barCtx.barOptions.colors.backgroundBarColors.length);var d=this.barCtx.barOptions.colors.backgroundBarColors[e],g=h.drawRect(void 0!==a?a:0,void 0!==r?r:0,void 0!==s?s:l.globals.gridWidth,void 0!==o?o:l.globals.gridHeight,this.barCtx.barOptions.colors.backgroundBarRadius,d,this.barCtx.barOptions.colors.backgroundBarOpacity);n.add(g),g.node.classList.add("apexcharts-backgroundBar")}}},{key:"getColumnPaths",value:function(t){var e,i=t.barWidth,a=t.barXPosition,s=t.y1,r=t.y2,o=t.strokeWidth,n=t.seriesGroup,l=t.realIndex,h=t.i,c=t.j,d=t.w,g=new m(this.barCtx.ctx);(o=Array.isArray(o)?o[l]:o)||(o=0);var u=i,p=a;null!==(e=d.config.series[l].data[c])&&void 0!==e&&e.columnWidthOffset&&(p=a-d.config.series[l].data[c].columnWidthOffset/2,u=i+d.config.series[l].data[c].columnWidthOffset);var f=p,x=p+u;s+=.001,r+=.001;var b=g.move(f,s),v=g.move(f,s),y=g.line(x-o,s);if(d.globals.previousPaths.length>0&&(v=this.barCtx.getPreviousPath(l,c,!1)),b=b+g.line(f,r)+g.line(x-o,r)+g.line(x-o,s)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),v=v+g.line(f,s)+y+y+y+y+y+g.line(f,s)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(b=g.roundPathCorners(b,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&n&&(w=this.barCtx[n]),w.yArrj.push(r),w.yArrjF.push(Math.abs(s-r)),w.yArrjVal.push(this.barCtx.series[h][c])}return{pathTo:b,pathFrom:v}}},{key:"getBarpaths",value:function(t){var e,i=t.barYPosition,a=t.barHeight,s=t.x1,r=t.x2,o=t.strokeWidth,n=t.seriesGroup,l=t.realIndex,h=t.i,c=t.j,d=t.w,g=new m(this.barCtx.ctx);(o=Array.isArray(o)?o[l]:o)||(o=0);var u=i,p=a;null!==(e=d.config.series[l].data[c])&&void 0!==e&&e.barHeightOffset&&(u=i-d.config.series[l].data[c].barHeightOffset/2,p=a+d.config.series[l].data[c].barHeightOffset);var f=u,x=u+p;s+=.001,r+=.001;var b=g.move(s,f),v=g.move(s,f);d.globals.previousPaths.length>0&&(v=this.barCtx.getPreviousPath(l,c,!1));var y=g.line(s,x-o);if(b=b+g.line(r,f)+g.line(r,x-o)+y+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),v=v+g.line(s,f)+y+y+y+y+y+g.line(s,f)+("around"===d.config.plotOptions.bar.borderRadiusApplication?" Z":" z"),this.shouldApplyRadius(l)&&(b=g.roundPathCorners(b,d.config.plotOptions.bar.borderRadius)),d.config.chart.stacked){var w=this.barCtx;d.globals.hasSeriesGroups&&n&&(w=this.barCtx[n]),w.xArrj.push(r),w.xArrjF.push(Math.abs(s-r)),w.xArrjVal.push(this.barCtx.series[h][c])}return{pathTo:b,pathFrom:v}}},{key:"checkZeroSeries",value:function(t){for(var e=t.series,i=this.w,a=0;a2&&void 0!==arguments[2])||arguments[2]?e:null;return null!=t&&(i=e+t/this.barCtx.invertedYRatio-2*(this.barCtx.isReversed?t/this.barCtx.invertedYRatio:0)),i}},{key:"getYForValue",value:function(t,e){var i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2]?e:null;return null!=t&&(i=e-t/this.barCtx.yRatio[this.barCtx.yaxisIndex]+2*(this.barCtx.isReversed?t/this.barCtx.yRatio[this.barCtx.yaxisIndex]:0)),i}},{key:"getGoalValues",value:function(t,i,a,s,r){var n=this,l=this.w,h=[],c=function(e,s){var r;h.push((o(r={},t,"x"===t?n.getXForValue(e,i,!1):n.getYForValue(e,a,!1)),o(r,"attrs",s),r))};if(l.globals.seriesGoals[s]&&l.globals.seriesGoals[s][r]&&Array.isArray(l.globals.seriesGoals[s][r])&&l.globals.seriesGoals[s][r].forEach((function(t){c(t.value,t)})),this.barCtx.barOptions.isDumbbell&&l.globals.seriesRange.length){var d=this.barCtx.barOptions.dumbbellColors?this.barCtx.barOptions.dumbbellColors:l.globals.colors,g={strokeHeight:"x"===t?0:l.globals.markers.size[s],strokeWidth:"x"===t?l.globals.markers.size[s]:0,strokeDashArray:0,strokeLineCap:"round",strokeColor:Array.isArray(d[s])?d[s][0]:d[s]};c(l.globals.seriesRangeStart[s][r],g),c(l.globals.seriesRangeEnd[s][r],e(e({},g),{},{strokeColor:Array.isArray(d[s])?d[s][1]:d[s]}))}return h}},{key:"drawGoalLine",value:function(t){var e=t.barXPosition,i=t.barYPosition,a=t.goalX,s=t.goalY,r=t.barWidth,o=t.barHeight,n=new m(this.barCtx.ctx),l=n.group({className:"apexcharts-bar-goals-groups"});l.node.classList.add("apexcharts-element-hidden"),this.barCtx.w.globals.delayedElements.push({el:l.node}),l.attr("clip-path","url(#gridRectMarkerMask".concat(this.barCtx.w.globals.cuid,")"));var h=null;return this.barCtx.isHorizontal?Array.isArray(a)&&a.forEach((function(t){var e=void 0!==t.attrs.strokeHeight?t.attrs.strokeHeight:o/2,a=i+e+o/2;h=n.drawLine(t.x,a-2*e,t.x,a,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeWidth?t.attrs.strokeWidth:2,t.attrs.strokeLineCap),l.add(h)})):Array.isArray(s)&&s.forEach((function(t){var i=void 0!==t.attrs.strokeWidth?t.attrs.strokeWidth:r/2,a=e+i+r/2;h=n.drawLine(a-2*i,t.y,a,t.y,t.attrs.strokeColor?t.attrs.strokeColor:void 0,t.attrs.strokeDashArray,t.attrs.strokeHeight?t.attrs.strokeHeight:2,t.attrs.strokeLineCap),l.add(h)})),l}}]),t}(),yt=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w;var s=this.w;this.barOptions=s.config.plotOptions.bar,this.isHorizontal=this.barOptions.horizontal,this.strokeWidth=s.config.stroke.width,this.isNullValue=!1,this.isRangeBar=s.globals.seriesRange.length&&this.isHorizontal,this.xyRatios=i,null!==this.xyRatios&&(this.xRatio=i.xRatio,this.initialXRatio=i.initialXRatio,this.yRatio=i.yRatio,this.invertedXRatio=i.invertedXRatio,this.invertedYRatio=i.invertedYRatio,this.baseLineY=i.baseLineY,this.baseLineInvertedY=i.baseLineInvertedY),this.yaxisIndex=0,this.seriesLen=0;var r=new N(this.ctx);this.lastActiveBarSerieIndex=r.getActiveConfigSeriesIndex("desc",["bar","column"]);var o=r.getBarSeriesIndices(),n=new y(this.ctx);this.stackedSeriesTotals=n.getStackedSeriesTotals(this.w.config.series.map((function(t,e){return-1===o.indexOf(e)?e:-1})).filter((function(t){return-1!==t}))),this.barHelpers=new mt(this)}return r(t,[{key:"draw",value:function(t,i){var a=this.w,s=new m(this.ctx),r=new y(this.ctx,a);t=r.getLogSeries(t),this.series=t,this.yRatio=r.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t);var o=s.group({class:"apexcharts-bar-series apexcharts-plot-series"});a.config.dataLabels.enabled&&this.totalItems>this.barOptions.dataLabels.maxItems&&console.warn("WARNING: DataLabels are enabled but there are too many to display. This may cause performance issue when rendering.");for(var n=0,l=0;n0&&(this.visibleI=this.visibleI+1);var k=0,A=0;this.yRatio.length>1&&(this.yaxisIndex=v),this.isReversed=a.config.yaxis[this.yaxisIndex]&&a.config.yaxis[this.yaxisIndex].reversed;var S=this.barHelpers.initialPositions();p=S.y,k=S.barHeight,c=S.yDivision,g=S.zeroW,u=S.x,A=S.barWidth,h=S.xDivision,d=S.zeroH,this.horizontal||b.push(u+A/2);for(var C=s.group({class:"apexcharts-datalabels","data:realIndex":v}),L=s.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),P=0;P0&&b.push(u+A/2),f.push(p);var z=this.barHelpers.getPathFillColor(t,n,P,v);this.renderSeries({realIndex:v,pathFill:z,j:P,i:n,pathFrom:T.pathFrom,pathTo:T.pathTo,strokeWidth:I,elSeries:w,x:u,y:p,series:t,barHeight:T.barHeight?T.barHeight:k,barWidth:T.barWidth?T.barWidth:A,elDataLabelsWrap:C,elGoalsMarkers:L,visibleSeries:this.visibleI,type:"bar"})}a.globals.seriesXvalues[v]=b,a.globals.seriesYvalues[v]=f,o.add(w)}return o}},{key:"renderSeries",value:function(t){var e=t.realIndex,i=t.pathFill,a=t.lineFill,s=t.j,r=t.i,o=t.groupIndex,n=t.pathFrom,l=t.pathTo,h=t.strokeWidth,c=t.elSeries,d=t.x,g=t.y,u=t.y1,p=t.y2,f=t.series,x=t.barHeight,b=t.barWidth,y=t.barYPosition,w=t.elDataLabelsWrap,k=t.elGoalsMarkers,A=t.visibleSeries,S=t.type,C=this.w,L=new m(this.ctx);a||(a=this.barOptions.distributed?C.globals.stroke.colors[s]:C.globals.stroke.colors[e]),C.config.series[r].data[s]&&C.config.series[r].data[s].strokeColor&&(a=C.config.series[r].data[s].strokeColor),this.isNullValue&&(i="none");var P=s/C.config.chart.animations.animateGradually.delay*(C.config.chart.animations.speed/C.globals.dataPoints)/2.4,I=L.renderPaths({i:r,j:s,realIndex:e,pathFrom:n,pathTo:l,stroke:a,strokeWidth:h,strokeLineCap:C.config.stroke.lineCap,fill:i,animationDelay:P,initialSpeed:C.config.chart.animations.speed,dataChangeSpeed:C.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(S,"-area")});I.attr("clip-path","url(#gridRectMask".concat(C.globals.cuid,")"));var T=C.config.forecastDataPoints;T.count>0&&s>=C.globals.dataPoints-T.count&&(I.node.setAttribute("stroke-dasharray",T.dashArray),I.node.setAttribute("stroke-width",T.strokeWidth),I.node.setAttribute("fill-opacity",T.fillOpacity)),void 0!==u&&void 0!==p&&(I.attr("data-range-y1",u),I.attr("data-range-y2",p)),new v(this.ctx).setSelectionFilter(I,e,s),c.add(I);var M=new vt(this).handleBarDataLabels({x:d,y:g,y1:u,y2:p,i:r,j:s,series:f,realIndex:e,groupIndex:o,barHeight:x,barWidth:b,barYPosition:y,renderedPath:I,visibleSeries:A});return null!==M.dataLabels&&w.add(M.dataLabels),M.totalDataLabels&&w.add(M.totalDataLabels),c.add(w),k&&c.add(k),c}},{key:"drawBarPaths",value:function(t){var e,i=t.indexes,a=t.barHeight,s=t.strokeWidth,r=t.zeroW,o=t.x,n=t.y,l=t.yDivision,h=t.elSeries,c=this.w,d=i.i,g=i.j;if(c.globals.isXNumeric)e=(n=(c.globals.seriesX[d][g]-c.globals.minX)/this.invertedXRatio-a)+a*this.visibleI;else if(c.config.plotOptions.bar.hideZeroBarsWhenGrouped){var u=0,p=0;c.globals.seriesPercent.forEach((function(t,e){t[g]&&u++,e0&&(a=this.seriesLen*a/u),e=n+a*this.visibleI,e-=a*p}else e=n+a*this.visibleI;o=this.barHelpers.getXForValue(this.series[d][g],r);var f=this.barHelpers.getBarpaths({barYPosition:e,barHeight:a,x1:r,x2:o,strokeWidth:s,series:this.series,realIndex:i.realIndex,i:d,j:g,w:c});return c.globals.isXNumeric||(n+=l),this.barHelpers.barBackground({j:g,i:d,y1:e-a*this.visibleI,y2:a*this.seriesLen,elSeries:h}),{pathTo:f.pathTo,pathFrom:f.pathFrom,x:o,y:n,goalX:this.barHelpers.getGoalValues("x",r,null,d,g),barYPosition:e,barHeight:a}}},{key:"drawColumnPaths",value:function(t){var e,i=t.indexes,a=t.x,s=t.y,r=t.xDivision,o=t.barWidth,n=t.zeroH,l=t.strokeWidth,h=t.elSeries,c=this.w,d=i.realIndex,g=i.i,u=i.j,p=i.bc;if(c.globals.isXNumeric){var f=d;c.globals.seriesX[d].length||(f=c.globals.maxValsInArrayIndex),c.globals.seriesX[f][u]&&(a=(c.globals.seriesX[f][u]-c.globals.minX)/this.xRatio-o*this.seriesLen/2),e=a+o*this.visibleI}else if(c.config.plotOptions.bar.hideZeroBarsWhenGrouped){var x=0,b=0;c.globals.seriesPercent.forEach((function(t,e){t[u]&&x++,e0&&(o=this.seriesLen*o/x),e=a+o*this.visibleI,e-=o*b}else e=a+o*this.visibleI;s=this.barHelpers.getYForValue(this.series[g][u],n);var v=this.barHelpers.getColumnPaths({barXPosition:e,barWidth:o,y1:n,y2:s,strokeWidth:l,series:this.series,realIndex:i.realIndex,i:g,j:u,w:c});return c.globals.isXNumeric||(a+=r),this.barHelpers.barBackground({bc:p,j:u,i:g,x1:e-l/2-o*this.visibleI,x2:o*this.seriesLen+l/2,elSeries:h}),{pathTo:v.pathTo,pathFrom:v.pathFrom,x:a,y:s,goalY:this.barHelpers.getGoalValues("y",null,n,g,u),barXPosition:e,barWidth:o}}},{key:"getPreviousPath",value:function(t,e){for(var i,a=this.w,s=0;s0&&parseInt(r.realIndex,10)===parseInt(t,10)&&void 0!==a.globals.previousPaths[s].paths[e]&&(i=a.globals.previousPaths[s].paths[e].d)}return i}}]),t}(),wt=function(t){n(s,t);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i){var a=this,s=this.w;this.graphics=new m(this.ctx),this.bar=new yt(this.ctx,this.xyRatios);var r=new y(this.ctx,s);t=r.getLogSeries(t),this.yRatio=r.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t),"100%"===s.config.chart.stackType&&(t=s.globals.seriesPercent.slice()),this.series=t,this.barHelpers.initializeStackedPrevVars(this);for(var o=this.graphics.group({class:"apexcharts-bar-series apexcharts-plot-series"}),n=0,l=0,h=function(r,h){var c=void 0,d=void 0,g=void 0,u=void 0,p=-1;a.groupCtx=a,s.globals.seriesGroups.forEach((function(t,e){t.indexOf(s.config.series[r].name)>-1&&(p=e)})),-1!==p&&(a.groupCtx=a[s.globals.seriesGroups[p]]);var f=[],b=[],v=s.globals.comboCharts?i[r]:r;a.yRatio.length>1&&(a.yaxisIndex=v),a.isReversed=s.config.yaxis[a.yaxisIndex]&&s.config.yaxis[a.yaxisIndex].reversed;var m=a.graphics.group({class:"apexcharts-series",seriesName:x.escapeString(s.globals.seriesNames[v]),rel:r+1,"data:realIndex":v});a.ctx.series.addCollapsedClassToSeries(m,v);var y=a.graphics.group({class:"apexcharts-datalabels","data:realIndex":v}),w=a.graphics.group({class:"apexcharts-bar-goals-markers",style:"pointer-events: none"}),k=0,A=0,S=a.initialPositions(n,l,c,d,g,u);l=S.y,k=S.barHeight,d=S.yDivision,u=S.zeroW,n=S.x,A=S.barWidth,c=S.xDivision,g=S.zeroH,a.barHelpers.initializeStackedXYVars(a),1===a.groupCtx.prevY.length&&a.groupCtx.prevY[0].every((function(t){return isNaN(t)}))&&(a.groupCtx.prevY[0]=a.groupCtx.prevY[0].map((function(t){return g})),a.groupCtx.prevYF[0]=a.groupCtx.prevYF[0].map((function(t){return 0})));for(var C=0;C1?(i=c.globals.minXDiff/this.xRatio)*parseInt(this.barOptions.columnWidth,10)/100:n*parseInt(c.config.plotOptions.bar.columnWidth,10)/100,null!==(h=c.globals.seriesGroups)&&void 0!==h&&h.length&&(n/=c.globals.seriesGroups.length),-1===String(c.config.plotOptions.bar.columnWidth).indexOf("%")&&(n=parseInt(c.config.plotOptions.bar.columnWidth,10)),s=c.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?c.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),t=c.globals.padHorizontal+(i-n)/2);return{x:t,y:e,yDivision:a,xDivision:i,barHeight:o,barWidth:n,zeroH:s,zeroW:r}}},{key:"drawStackedBarPaths",value:function(t){for(var e,i=t.indexes,a=t.barHeight,s=t.strokeWidth,r=t.zeroW,o=t.x,n=t.y,l=t.groupIndex,h=t.seriesGroup,c=t.yDivision,d=t.elSeries,g=this.w,u=n+(-1!==l?l*a:0),p=i.i,f=i.j,x=0,b=0;b0){var m=r;this.groupCtx.prevXVal[v-1][f]<0?m=this.series[p][f]>=0?this.groupCtx.prevX[v-1][f]+x-2*(this.isReversed?x:0):this.groupCtx.prevX[v-1][f]:this.groupCtx.prevXVal[v-1][f]>=0&&(m=this.series[p][f]>=0?this.groupCtx.prevX[v-1][f]:this.groupCtx.prevX[v-1][f]-x+2*(this.isReversed?x:0)),e=m}else e=r;o=null===this.series[p][f]?e:e+this.series[p][f]/this.invertedYRatio-2*(this.isReversed?this.series[p][f]/this.invertedYRatio:0);var y=this.barHelpers.getBarpaths({barYPosition:u,barHeight:a,x1:e,x2:o,strokeWidth:s,series:this.series,realIndex:i.realIndex,seriesGroup:h,i:p,j:f,w:g});return this.barHelpers.barBackground({j:f,i:p,y1:u,y2:a,elSeries:d}),n+=c,{pathTo:y.pathTo,pathFrom:y.pathFrom,goalX:this.barHelpers.getGoalValues("x",r,null,p,f),barYPosition:u,x:o,y:n}}},{key:"drawStackedColumnPaths",value:function(t){var e=t.indexes,i=t.x,a=t.y,s=t.xDivision,r=t.barWidth,o=t.zeroH,n=t.groupIndex,l=t.seriesGroup,h=t.elSeries,c=this.w,d=e.i,g=e.j,u=e.bc;if(c.globals.isXNumeric){var p=c.globals.seriesX[d][g];p||(p=0),i=(p-c.globals.minX)/this.xRatio-r/2,c.globals.seriesGroups.length&&(i=(p-c.globals.minX)/this.xRatio-r/2*c.globals.seriesGroups.length)}for(var f,x=i+(-1!==n?n*r:0),b=0,v=0;v0&&!c.globals.isXNumeric||m>0&&c.globals.isXNumeric&&c.globals.seriesX[d-1][g]===c.globals.seriesX[d][g]){var y,w,k,A=Math.min(this.yRatio.length+1,d+1);if(void 0!==this.groupCtx.prevY[m-1]&&this.groupCtx.prevY[m-1].length)for(var S=1;S=0?k-b+2*(this.isReversed?b:0):k;break}if((null===(I=this.groupCtx.prevYVal[m-L])||void 0===I?void 0:I[g])>=0){w=this.series[d][g]>=0?k:k+b-2*(this.isReversed?b:0);break}}void 0===w&&(w=c.globals.gridHeight),f=null!==(y=this.groupCtx.prevYF[0])&&void 0!==y&&y.every((function(t){return 0===t}))&&this.groupCtx.prevYF.slice(1,m).every((function(t){return t.every((function(t){return isNaN(t)}))}))?o:w}else f=o;a=this.series[d][g]?f-this.series[d][g]/this.yRatio[this.yaxisIndex]+2*(this.isReversed?this.series[d][g]/this.yRatio[this.yaxisIndex]:0):f;var T=this.barHelpers.getColumnPaths({barXPosition:x,barWidth:r,y1:f,y2:a,yRatio:this.yRatio[this.yaxisIndex],strokeWidth:this.strokeWidth,series:this.series,seriesGroup:l,realIndex:e.realIndex,i:d,j:g,w:c});return this.barHelpers.barBackground({bc:u,j:g,i:d,x1:x,x2:r,elSeries:h}),i+=s,{pathTo:T.pathTo,pathFrom:T.pathFrom,goalY:this.barHelpers.getGoalValues("y",null,o,d,g),barXPosition:x,x:c.globals.isXNumeric?i-s:i,y:a}}}]),s}(yt),kt=function(t){n(s,t);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i,a){var s=this,r=this.w,o=new m(this.ctx),n=r.globals.comboCharts?i:r.config.chart.type,l=new R(this.ctx);this.candlestickOptions=this.w.config.plotOptions.candlestick,this.boxOptions=this.w.config.plotOptions.boxPlot,this.isHorizontal=r.config.plotOptions.bar.horizontal;var h=new y(this.ctx,r);t=h.getLogSeries(t),this.series=t,this.yRatio=h.getLogYRatios(this.yRatio),this.barHelpers.initVariables(t);for(var c=o.group({class:"apexcharts-".concat(n,"-series apexcharts-plot-series")}),d=function(i){s.isBoxPlot="boxPlot"===r.config.chart.type||"boxPlot"===r.config.series[i].type;var n,h,d,g,u=void 0,p=void 0,f=[],b=[],v=r.globals.comboCharts?a[i]:i,m=o.group({class:"apexcharts-series",seriesName:x.escapeString(r.globals.seriesNames[v]),rel:i+1,"data:realIndex":v});s.ctx.series.addCollapsedClassToSeries(m,v),t[i].length>0&&(s.visibleI=s.visibleI+1);var y,w;s.yRatio.length>1&&(s.yaxisIndex=v);var k=s.barHelpers.initialPositions();p=k.y,y=k.barHeight,h=k.yDivision,g=k.zeroW,u=k.x,w=k.barWidth,n=k.xDivision,d=k.zeroH,b.push(u+w/2);for(var A=o.group({class:"apexcharts-datalabels","data:realIndex":v}),S=function(a){var o=s.barHelpers.getStrokeWidth(i,a,v),c=null,x={indexes:{i:i,j:a,realIndex:v},x:u,y:p,strokeWidth:o,elSeries:m};c=s.isHorizontal?s.drawHorizontalBoxPaths(e(e({},x),{},{yDivision:h,barHeight:y,zeroW:g})):s.drawVerticalBoxPaths(e(e({},x),{},{xDivision:n,barWidth:w,zeroH:d})),p=c.y,u=c.x,a>0&&b.push(u+w/2),f.push(p),c.pathTo.forEach((function(e,n){var h=!s.isBoxPlot&&s.candlestickOptions.wick.useFillColor?c.color[n]:r.globals.stroke.colors[i],d=l.fillPath({seriesNumber:v,dataPointIndex:a,color:c.color[n],value:t[i][a]});s.renderSeries({realIndex:v,pathFill:d,lineFill:h,j:a,i:i,pathFrom:c.pathFrom,pathTo:e,strokeWidth:o,elSeries:m,x:u,y:p,series:t,barHeight:y,barWidth:w,elDataLabelsWrap:A,visibleSeries:s.visibleI,type:r.config.chart.type})}))},C=0;Cb.c&&(d=!1);var w=Math.min(b.o,b.c),k=Math.max(b.o,b.c),A=b.m;n.globals.isXNumeric&&(i=(n.globals.seriesX[x][c]-n.globals.minX)/this.xRatio-s/2);var S=i+s*this.visibleI;void 0===this.series[h][c]||null===this.series[h][c]?(w=r,k=r):(w=r-w/f,k=r-k/f,v=r-b.h/f,y=r-b.l/f,A=r-b.m/f);var C=l.move(S,r),L=l.move(S+s/2,w);return n.globals.previousPaths.length>0&&(L=this.getPreviousPath(x,c,!0)),C=this.isBoxPlot?[l.move(S,w)+l.line(S+s/2,w)+l.line(S+s/2,v)+l.line(S+s/4,v)+l.line(S+s-s/4,v)+l.line(S+s/2,v)+l.line(S+s/2,w)+l.line(S+s,w)+l.line(S+s,A)+l.line(S,A)+l.line(S,w+o/2),l.move(S,A)+l.line(S+s,A)+l.line(S+s,k)+l.line(S+s/2,k)+l.line(S+s/2,y)+l.line(S+s-s/4,y)+l.line(S+s/4,y)+l.line(S+s/2,y)+l.line(S+s/2,k)+l.line(S,k)+l.line(S,A)+"z"]:[l.move(S,k)+l.line(S+s/2,k)+l.line(S+s/2,v)+l.line(S+s/2,k)+l.line(S+s,k)+l.line(S+s,w)+l.line(S+s/2,w)+l.line(S+s/2,y)+l.line(S+s/2,w)+l.line(S,w)+l.line(S,k-o/2)],L+=l.move(S,w),n.globals.isXNumeric||(i+=a),{pathTo:C,pathFrom:L,x:i,y:k,barXPosition:S,color:this.isBoxPlot?p:d?[g]:[u]}}},{key:"drawHorizontalBoxPaths",value:function(t){var e=t.indexes;t.x;var i=t.y,a=t.yDivision,s=t.barHeight,r=t.zeroW,o=t.strokeWidth,n=this.w,l=new m(this.ctx),h=e.i,c=e.j,d=this.boxOptions.colors.lower;this.isBoxPlot&&(d=[this.boxOptions.colors.lower,this.boxOptions.colors.upper]);var g=this.invertedYRatio,u=e.realIndex,p=this.getOHLCValue(u,c),f=r,x=r,b=Math.min(p.o,p.c),v=Math.max(p.o,p.c),y=p.m;n.globals.isXNumeric&&(i=(n.globals.seriesX[u][c]-n.globals.minX)/this.invertedXRatio-s/2);var w=i+s*this.visibleI;void 0===this.series[h][c]||null===this.series[h][c]?(b=r,v=r):(b=r+b/g,v=r+v/g,f=r+p.h/g,x=r+p.l/g,y=r+p.m/g);var k=l.move(r,w),A=l.move(b,w+s/2);return n.globals.previousPaths.length>0&&(A=this.getPreviousPath(u,c,!0)),k=[l.move(b,w)+l.line(b,w+s/2)+l.line(f,w+s/2)+l.line(f,w+s/2-s/4)+l.line(f,w+s/2+s/4)+l.line(f,w+s/2)+l.line(b,w+s/2)+l.line(b,w+s)+l.line(y,w+s)+l.line(y,w)+l.line(b+o/2,w),l.move(y,w)+l.line(y,w+s)+l.line(v,w+s)+l.line(v,w+s/2)+l.line(x,w+s/2)+l.line(x,w+s-s/4)+l.line(x,w+s/4)+l.line(x,w+s/2)+l.line(v,w+s/2)+l.line(v,w)+l.line(y,w)+"z"],A+=l.move(b,w),n.globals.isXNumeric||(i+=a),{pathTo:k,pathFrom:A,x:v,y:i,barYPosition:w,color:d}}},{key:"getOHLCValue",value:function(t,e){var i=this.w;return{o:this.isBoxPlot?i.globals.seriesCandleH[t][e]:i.globals.seriesCandleO[t][e],h:this.isBoxPlot?i.globals.seriesCandleO[t][e]:i.globals.seriesCandleH[t][e],m:i.globals.seriesCandleM[t][e],l:this.isBoxPlot?i.globals.seriesCandleC[t][e]:i.globals.seriesCandleL[t][e],c:this.isBoxPlot?i.globals.seriesCandleL[t][e]:i.globals.seriesCandleC[t][e]}}}]),s}(yt),At=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"checkColorRange",value:function(){var t=this.w,e=!1,i=t.config.plotOptions[t.config.chart.type];return i.colorScale.ranges.length>0&&i.colorScale.ranges.map((function(t,i){t.from<=0&&(e=!0)})),e}},{key:"getShadeColor",value:function(t,e,i,a){var s=this.w,r=1,o=s.config.plotOptions[t].shadeIntensity,n=this.determineColor(t,e,i);s.globals.hasNegs||a?r=s.config.plotOptions[t].reverseNegativeShade?n.percent<0?n.percent/100*(1.25*o):(1-n.percent/100)*(1.25*o):n.percent<=0?1-(1+n.percent/100)*o:(1-n.percent/100)*o:(r=1-n.percent/100,"treemap"===t&&(r=(1-n.percent/100)*(1.25*o)));var l=n.color,h=new x;return s.config.plotOptions[t].enableShades&&(l="dark"===this.w.config.theme.mode?x.hexToRgba(h.shadeColor(-1*r,n.color),s.config.fill.opacity):x.hexToRgba(h.shadeColor(r,n.color),s.config.fill.opacity)),{color:l,colorProps:n}}},{key:"determineColor",value:function(t,e,i){var a=this.w,s=a.globals.series[e][i],r=a.config.plotOptions[t],o=r.colorScale.inverse?i:e;r.distributed&&"treemap"===a.config.chart.type&&(o=i);var n=a.globals.colors[o],l=null,h=Math.min.apply(Math,u(a.globals.series[e])),c=Math.max.apply(Math,u(a.globals.series[e]));r.distributed||"heatmap"!==t||(h=a.globals.minY,c=a.globals.maxY),void 0!==r.colorScale.min&&(h=r.colorScale.mina.globals.maxY?r.colorScale.max:a.globals.maxY);var d=Math.abs(c)+Math.abs(h),g=100*s/(0===d?d-1e-6:d);r.colorScale.ranges.length>0&&r.colorScale.ranges.map((function(t,e){if(s>=t.from&&s<=t.to){n=t.color,l=t.foreColor?t.foreColor:null,h=t.from,c=t.to;var i=Math.abs(c)+Math.abs(h);g=100*s/(0===i?i-1e-6:i)}}));return{color:n,foreColor:l,percent:g}}},{key:"calculateDataLabels",value:function(t){var e=t.text,i=t.x,a=t.y,s=t.i,r=t.j,o=t.colorProps,n=t.fontSize,l=this.w.config.dataLabels,h=new m(this.ctx),c=new O(this.ctx),d=null;if(l.enabled){d=h.group({class:"apexcharts-data-labels"});var g=l.offsetX,u=l.offsetY,p=i+g,f=a+parseFloat(l.style.fontSize)/3+u;c.plotDataLabelsText({x:p,y:f,text:e,i:s,j:r,color:o.foreColor,parent:d,fontSize:n,dataLabelsConfig:l})}return d}},{key:"addListeners",value:function(t){var e=new m(this.ctx);t.node.addEventListener("mouseenter",e.pathMouseEnter.bind(this,t)),t.node.addEventListener("mouseleave",e.pathMouseLeave.bind(this,t)),t.node.addEventListener("mousedown",e.pathMouseDown.bind(this,t))}}]),t}(),St=function(){function t(e,i){a(this,t),this.ctx=e,this.w=e.w,this.xRatio=i.xRatio,this.yRatio=i.yRatio,this.dynamicAnim=this.w.config.chart.animations.dynamicAnimation,this.helpers=new At(e),this.rectRadius=this.w.config.plotOptions.heatmap.radius,this.strokeWidth=this.w.config.stroke.show?this.w.config.stroke.width:0}return r(t,[{key:"draw",value:function(t){var e=this.w,i=new m(this.ctx),a=i.group({class:"apexcharts-heatmap"});a.attr("clip-path","url(#gridRectMask".concat(e.globals.cuid,")"));var s=e.globals.gridWidth/e.globals.dataPoints,r=e.globals.gridHeight/e.globals.series.length,o=0,n=!1;this.negRange=this.helpers.checkColorRange();var l=t.slice();e.config.yaxis[0].reversed&&(n=!0,l.reverse());for(var h=n?0:l.length-1;n?h=0;n?h++:h--){var c=i.group({class:"apexcharts-series apexcharts-heatmap-series",seriesName:x.escapeString(e.globals.seriesNames[h]),rel:h+1,"data:realIndex":h});if(this.ctx.series.addCollapsedClassToSeries(c,h),e.config.chart.dropShadow.enabled){var d=e.config.chart.dropShadow;new v(this.ctx).dropShadow(c,d,h)}for(var g=0,u=e.config.plotOptions.heatmap.shadeIntensity,p=0;p-1&&this.pieClicked(d),i.config.dataLabels.enabled){var A=w.x,S=w.y,C=100*u/this.fullAngle+"%";if(0!==u&&i.config.plotOptions.pie.dataLabels.minAngleToShowLabelthis.fullAngle?e.endAngle=e.endAngle-(a+o):a+o=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle&&(n=this.fullAngle+this.w.config.plotOptions.pie.startAngle%this.fullAngle-.01),Math.ceil(n)>this.fullAngle&&(n-=this.fullAngle);var l=Math.PI*(n-90)/180,h=e.centerX+s*Math.cos(o),c=e.centerY+s*Math.sin(o),d=e.centerX+s*Math.cos(l),g=e.centerY+s*Math.sin(l),u=x.polarToCartesian(e.centerX,e.centerY,e.donutSize,n),p=x.polarToCartesian(e.centerX,e.centerY,e.donutSize,r),f=a>180?1:0,b=["M",h,c,"A",s,s,0,f,1,d,g];return"donut"===e.chartType?[].concat(b,["L",u.x,u.y,"A",e.donutSize,e.donutSize,0,f,0,p.x,p.y,"L",h,c,"z"]).join(" "):"pie"===e.chartType||"polarArea"===e.chartType?[].concat(b,["L",e.centerX,e.centerY,"L",h,c]).join(" "):[].concat(b).join(" ")}},{key:"drawPolarElements",value:function(t){var e=this.w,i=new _(this.ctx),a=new m(this.ctx),s=new Ct(this.ctx),r=a.group(),o=a.group(),n=i.niceScale(0,Math.ceil(this.maxY),e.config.yaxis[0].tickAmount,0,!0),l=n.result.reverse(),h=n.result.length;this.maxY=n.niceMax;for(var c=e.globals.radialSize,d=c/(h-1),g=0;g1&&t.total.show&&(s=t.total.color);var o=r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-label"),n=r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-value");i=(0,t.value.formatter)(i,r),a||"function"!=typeof t.total.formatter||(i=t.total.formatter(r));var l=e===t.total.label;e=t.name.formatter(e,l,r),null!==o&&(o.textContent=e),null!==n&&(n.textContent=i),null!==o&&(o.style.fill=s)}},{key:"printDataLabelsInner",value:function(t,e){var i=this.w,a=t.getAttribute("data:value"),s=i.globals.seriesNames[parseInt(t.parentNode.getAttribute("rel"),10)-1];i.globals.series.length>1&&this.printInnerLabels(e,s,a,t);var r=i.globals.dom.baseEl.querySelector(".apexcharts-datalabels-group");null!==r&&(r.style.opacity=1)}},{key:"drawSpokes",value:function(t){var e=this,i=this.w,a=new m(this.ctx),s=i.config.plotOptions.polarArea.spokes;if(0!==s.strokeWidth){for(var r=[],o=360/i.globals.series.length,n=0;n1)o&&!e.total.showAlways?l({makeSliceOut:!1,printLabel:!0}):this.printInnerLabels(e,e.total.label,e.total.formatter(s));else if(l({makeSliceOut:!1,printLabel:!0}),!o)if(s.globals.selectedDataPoints.length&&s.globals.series.length>1)if(s.globals.selectedDataPoints[0].length>0){var h=s.globals.selectedDataPoints[0],c=s.globals.dom.baseEl.querySelector(".apexcharts-".concat(this.chartType.toLowerCase(),"-slice-").concat(h));this.printDataLabelsInner(c,e)}else r&&s.globals.selectedDataPoints.length&&0===s.globals.selectedDataPoints[0].length&&(r.style.opacity=0);else r&&s.globals.series.length>1&&(r.style.opacity=0)}}]),t}(),Pt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.chartType=this.w.config.chart.type,this.initialAnim=this.w.config.chart.animations.enabled,this.dynamicAnim=this.initialAnim&&this.w.config.chart.animations.dynamicAnimation.enabled,this.animDur=0;var i=this.w;this.graphics=new m(this.ctx),this.lineColorArr=void 0!==i.globals.stroke.colors?i.globals.stroke.colors:i.globals.colors,this.defaultSize=i.globals.svgHeight0&&(f=i.getPreviousPath(n));for(var b=0;b=10?t.x>0?(i="start",a+=10):t.x<0&&(i="end",a-=10):i="middle",Math.abs(t.y)>=e-10&&(t.y<0?s-=10:t.y>0&&(s+=10)),{textAnchor:i,newX:a,newY:s}}},{key:"getPreviousPath",value:function(t){for(var e=this.w,i=null,a=0;a0&&parseInt(s.realIndex,10)===parseInt(t,10)&&void 0!==e.globals.previousPaths[a].paths[0]&&(i=e.globals.previousPaths[a].paths[0].d)}return i}},{key:"getDataPointsPos",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.dataPointsLen;t=t||[],e=e||[];for(var a=[],s=0;s=360&&(g=360-Math.abs(this.startAngle)-.1);var u=i.drawPath({d:"",stroke:c,strokeWidth:o*parseInt(h.strokeWidth,10)/100,fill:"none",strokeOpacity:h.opacity,classes:"apexcharts-radialbar-area"});if(h.dropShadow.enabled){var p=h.dropShadow;s.dropShadow(u,p)}l.add(u),u.attr("id","apexcharts-radialbarTrack-"+n),this.animatePaths(u,{centerX:t.centerX,centerY:t.centerY,endAngle:g,startAngle:d,size:t.size,i:n,totalItems:2,animBeginArr:0,dur:0,isTrack:!0,easing:e.globals.easing})}return a}},{key:"drawArcs",value:function(t){var e=this.w,i=new m(this.ctx),a=new R(this.ctx),s=new v(this.ctx),r=i.group(),o=this.getStrokeWidth(t);t.size=t.size-o/2;var n=e.config.plotOptions.radialBar.hollow.background,l=t.size-o*t.series.length-this.margin*t.series.length-o*parseInt(e.config.plotOptions.radialBar.track.strokeWidth,10)/100/2,h=l-e.config.plotOptions.radialBar.hollow.margin;void 0!==e.config.plotOptions.radialBar.hollow.image&&(n=this.drawHollowImage(t,r,l,n));var c=this.drawHollow({size:h,centerX:t.centerX,centerY:t.centerY,fill:n||"transparent"});if(e.config.plotOptions.radialBar.hollow.dropShadow.enabled){var d=e.config.plotOptions.radialBar.hollow.dropShadow;s.dropShadow(c,d)}var g=1;!this.radialDataLabels.total.show&&e.globals.series.length>1&&(g=0);var u=null;this.radialDataLabels.show&&(u=this.renderInnerDataLabels(this.radialDataLabels,{hollowSize:l,centerX:t.centerX,centerY:t.centerY,opacity:g})),"back"===e.config.plotOptions.radialBar.hollow.position&&(r.add(c),u&&r.add(u));var p=!1;e.config.plotOptions.radialBar.inverseOrder&&(p=!0);for(var f=p?t.series.length-1:0;p?f>=0:f100?100:t.series[f])/100,S=Math.round(this.totalAngle*A)+this.startAngle,C=void 0;e.globals.dataChanged&&(k=this.startAngle,C=Math.round(this.totalAngle*x.negToZero(e.globals.previousPaths[f])/100)+k),Math.abs(S)+Math.abs(w)>=360&&(S-=.01),Math.abs(C)+Math.abs(k)>=360&&(C-=.01);var L=S-w,P=Array.isArray(e.config.stroke.dashArray)?e.config.stroke.dashArray[f]:e.config.stroke.dashArray,I=i.drawPath({d:"",stroke:y,strokeWidth:o,fill:"none",fillOpacity:e.config.fill.opacity,classes:"apexcharts-radialbar-area apexcharts-radialbar-slice-"+f,strokeDashArray:P});if(m.setAttrs(I.node,{"data:angle":L,"data:value":t.series[f]}),e.config.chart.dropShadow.enabled){var T=e.config.chart.dropShadow;s.dropShadow(I,T,f)}s.setSelectionFilter(I,0,f),this.addListeners(I,this.radialDataLabels),b.add(I),I.attr({index:0,j:f});var M=0;!this.initialAnim||e.globals.resized||e.globals.dataChanged||(M=e.config.chart.animations.speed),e.globals.dataChanged&&(M=e.config.chart.animations.dynamicAnimation.speed),this.animDur=M/(1.2*t.series.length)+this.animDur,this.animBeginArr.push(this.animDur),this.animatePaths(I,{centerX:t.centerX,centerY:t.centerY,endAngle:S,startAngle:w,prevEndAngle:C,prevStartAngle:k,size:t.size,i:f,totalItems:2,animBeginArr:this.animBeginArr,dur:M,shouldSetPrevPaths:!0,easing:e.globals.easing})}return{g:r,elHollow:c,dataLabels:u}}},{key:"drawHollow",value:function(t){var e=new m(this.ctx).drawCircle(2*t.size);return e.attr({class:"apexcharts-radialbar-hollow",cx:t.centerX,cy:t.centerY,r:t.size,fill:t.fill}),e}},{key:"drawHollowImage",value:function(t,e,i,a){var s=this.w,r=new R(this.ctx),o=x.randomId(),n=s.config.plotOptions.radialBar.hollow.image;if(s.config.plotOptions.radialBar.hollow.imageClipped)r.clippedImgArea({width:i,height:i,image:n,patternID:"pattern".concat(s.globals.cuid).concat(o)}),a="url(#pattern".concat(s.globals.cuid).concat(o,")");else{var l=s.config.plotOptions.radialBar.hollow.imageWidth,h=s.config.plotOptions.radialBar.hollow.imageHeight;if(void 0===l&&void 0===h){var c=s.globals.dom.Paper.image(n).loaded((function(e){this.move(t.centerX-e.width/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-e.height/2+s.config.plotOptions.radialBar.hollow.imageOffsetY)}));e.add(c)}else{var d=s.globals.dom.Paper.image(n).loaded((function(e){this.move(t.centerX-l/2+s.config.plotOptions.radialBar.hollow.imageOffsetX,t.centerY-h/2+s.config.plotOptions.radialBar.hollow.imageOffsetY),this.size(l,h)}));e.add(d)}}return a}},{key:"getStrokeWidth",value:function(t){var e=this.w;return t.size*(100-parseInt(e.config.plotOptions.radialBar.hollow.size,10))/100/(t.series.length+1)-this.margin}}]),i}(Lt),Tt=function(t){n(s,t);var i=d(s);function s(){return a(this,s),i.apply(this,arguments)}return r(s,[{key:"draw",value:function(t,i){var a=this.w,s=new m(this.ctx);this.rangeBarOptions=this.w.config.plotOptions.rangeBar,this.series=t,this.seriesRangeStart=a.globals.seriesRangeStart,this.seriesRangeEnd=a.globals.seriesRangeEnd,this.barHelpers.initVariables(t);for(var r=s.group({class:"apexcharts-rangebar-series apexcharts-plot-series"}),o=0;o0&&(this.visibleI=this.visibleI+1);var f=0,b=0;this.yRatio.length>1&&(this.yaxisIndex=u);var v=this.barHelpers.initialPositions();d=v.y,h=v.zeroW,c=v.x,b=v.barWidth,n=v.xDivision,l=v.zeroH;for(var y=s.group({class:"apexcharts-datalabels","data:realIndex":u}),w=s.group({class:"apexcharts-rangebar-goals-markers",style:"pointer-events: none"}),k=0;k0}));return a=l.config.plotOptions.bar.rangeBarGroupRows?s+o*g:s+r*this.visibleI+o*g,u>-1&&!l.config.plotOptions.bar.rangeBarOverlap&&(h=l.globals.seriesRange[e][u].overlaps).indexOf(c)>-1&&(a=(r=n.barHeight/h.length)*this.visibleI+o*(100-parseInt(this.barOptions.barHeight,10))/100/2+r*(this.visibleI+h.indexOf(c))+o*g),{barYPosition:a,barHeight:r}}},{key:"drawRangeColumnPaths",value:function(t){var e=t.indexes,i=t.x;t.strokeWidth;var a=t.xDivision,s=t.barWidth,r=t.zeroH,o=this.w,n=e.i,l=e.j,h=this.yRatio[this.yaxisIndex],c=e.realIndex,d=this.getRangeValue(c,l),g=Math.min(d.start,d.end),u=Math.max(d.start,d.end);o.globals.isXNumeric&&(i=(o.globals.seriesX[n][l]-o.globals.minX)/this.xRatio-s/2);var p=i+s*this.visibleI;void 0===this.series[n][l]||null===this.series[n][l]?g=r:(g=r-g/h,u=r-u/h);var f=Math.abs(u-g),x=this.barHelpers.getColumnPaths({barXPosition:p,barWidth:s,y1:g,y2:u,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,realIndex:e.realIndex,i:c,j:l,w:o});return o.globals.isXNumeric||(i+=a),{pathTo:x.pathTo,pathFrom:x.pathFrom,barHeight:f,x:i,y:u,goalY:this.barHelpers.getGoalValues("y",null,r,n,l),barXPosition:p}}},{key:"drawRangeBarPaths",value:function(t){var e=t.indexes,i=t.y,a=t.y1,s=t.y2,r=t.yDivision,o=t.barHeight,n=t.barYPosition,l=t.zeroW,h=this.w,c=l+a/this.invertedYRatio,d=l+s/this.invertedYRatio,g=Math.abs(d-c),u=this.barHelpers.getBarpaths({barYPosition:n,barHeight:o,x1:c,x2:d,strokeWidth:this.strokeWidth,series:this.seriesRangeEnd,i:e.realIndex,realIndex:e.realIndex,j:e.j,w:h});return h.globals.isXNumeric||(i+=r),{pathTo:u.pathTo,pathFrom:u.pathFrom,barWidth:g,x:d,goalX:this.barHelpers.getGoalValues("x",l,null,e.realIndex,e.j),y:i}}},{key:"getRangeValue",value:function(t,e){var i=this.w;return{start:i.globals.seriesRangeStart[t][e],end:i.globals.seriesRangeEnd[t][e]}}}]),s}(yt),Mt=function(){function t(e){a(this,t),this.w=e.w,this.lineCtx=e}return r(t,[{key:"sameValueSeriesFix",value:function(t,e){var i=this.w;if(("gradient"===i.config.fill.type||"gradient"===i.config.fill.type[t])&&new y(this.lineCtx.ctx,i).seriesHaveSameValues(t)){var a=e[t].slice();a[a.length-1]=a[a.length-1]+1e-6,e[t]=a}return e}},{key:"calculatePoints",value:function(t){var e=t.series,i=t.realIndex,a=t.x,s=t.y,r=t.i,o=t.j,n=t.prevY,l=this.w,h=[],c=[];if(0===o){var d=this.lineCtx.categoryAxisCorrection+l.config.markers.offsetX;l.globals.isXNumeric&&(d=(l.globals.seriesX[i][0]-l.globals.minX)/this.lineCtx.xRatio+l.config.markers.offsetX),h.push(d),c.push(x.isNumber(e[r][0])?n+l.config.markers.offsetY:null),h.push(a+l.config.markers.offsetX),c.push(x.isNumber(e[r][o+1])?s+l.config.markers.offsetY:null)}else h.push(a+l.config.markers.offsetX),c.push(x.isNumber(e[r][o+1])?s+l.config.markers.offsetY:null);return{x:h,y:c}}},{key:"checkPreviousPaths",value:function(t){for(var e=t.pathFromLine,i=t.pathFromArea,a=t.realIndex,s=this.w,r=0;r0&&parseInt(o.realIndex,10)===parseInt(a,10)&&("line"===o.type?(this.lineCtx.appendPathFrom=!1,e=s.globals.previousPaths[r].paths[0].d):"area"===o.type&&(this.lineCtx.appendPathFrom=!1,i=s.globals.previousPaths[r].paths[0].d,s.config.stroke.show&&s.globals.previousPaths[r].paths[1]&&(e=s.globals.previousPaths[r].paths[1].d)))}return{pathFromLine:e,pathFromArea:i}}},{key:"determineFirstPrevY",value:function(t){var e,i=t.i,a=t.series,s=t.prevY,r=t.lineYPosition,o=this.w;if(void 0!==(null===(e=a[i])||void 0===e?void 0:e[0]))s=(r=o.config.chart.stacked&&i>0?this.lineCtx.prevSeriesY[i-1][0]:this.lineCtx.zeroY)-a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]+2*(this.lineCtx.isReversed?a[i][0]/this.lineCtx.yRatio[this.lineCtx.yaxisIndex]:0);else if(o.config.chart.stacked&&i>0&&void 0===a[i][0])for(var n=i-1;n>=0;n--)if(null!==a[n][0]&&void 0!==a[n][0]){s=r=this.lineCtx.prevSeriesY[n][0];break}return{prevY:s,lineYPosition:r}}}]),t}(),Xt=function(){function t(e,i,s){a(this,t),this.ctx=e,this.w=e.w,this.xyRatios=i,this.pointsChart=!("bubble"!==this.w.config.chart.type&&"scatter"!==this.w.config.chart.type)||s,this.scatter=new H(this.ctx),this.noNegatives=this.w.globals.minX===Number.MAX_VALUE,this.lineHelpers=new Mt(this),this.markers=new D(this.ctx),this.prevSeriesY=[],this.categoryAxisCorrection=0,this.yaxisIndex=0}return r(t,[{key:"draw",value:function(t,i,a,s){var r=this.w,o=new m(this.ctx),n=r.globals.comboCharts?i:r.config.chart.type,l=o.group({class:"apexcharts-".concat(n,"-series apexcharts-plot-series")}),h=new y(this.ctx,r);this.yRatio=this.xyRatios.yRatio,this.zRatio=this.xyRatios.zRatio,this.xRatio=this.xyRatios.xRatio,this.baseLineY=this.xyRatios.baseLineY,t=h.getLogSeries(t),this.yRatio=h.getLogYRatios(this.yRatio);for(var c=[],d=0;d0&&(f=(r.globals.seriesX[g][0]-r.globals.minX)/this.xRatio),p.push(f);var x,b=f,v=void 0,w=b,k=this.zeroY,A=this.zeroY;k=this.lineHelpers.determineFirstPrevY({i:d,series:t,prevY:k,lineYPosition:0}).prevY,u.push(k),x=k;"rangeArea"===n&&(v=A=this.lineHelpers.determineFirstPrevY({i:d,series:s,prevY:A,lineYPosition:0}).prevY);var S={type:n,series:t,realIndex:g,i:d,x:f,y:1,pX:b,pY:x,pathsFrom:this._calculatePathsFrom({type:n,series:t,i:d,realIndex:g,prevX:w,prevY:k,prevY2:A}),linePaths:[],areaPaths:[],seriesIndex:a,lineYPosition:0,xArrj:p,yArrj:u,seriesRangeEnd:s},C=this._iterateOverDataPoints(e(e({},S),{},{iterations:"rangeArea"===n?t[d].length-1:void 0,isRangeStart:!0}));if("rangeArea"===n){var L=this._calculatePathsFrom({series:s,i:d,realIndex:g,prevX:w,prevY:A}),P=this._iterateOverDataPoints(e(e({},S),{},{series:s,pY:v,pathsFrom:L,iterations:s[d].length-1,isRangeStart:!1}));C.linePaths[0]=P.linePath+C.linePath,C.pathFromLine=P.pathFromLine+C.pathFromLine}this._handlePaths({type:n,realIndex:g,i:d,paths:C}),this.elSeries.add(this.elPointsMain),this.elSeries.add(this.elDataLabelsWrap),c.push(this.elSeries)}if(r.config.chart.stacked)for(var I=c.length;I>0;I--)l.add(c[I-1]);else for(var T=0;T1&&(this.yaxisIndex=i),this.isReversed=a.config.yaxis[this.yaxisIndex]&&a.config.yaxis[this.yaxisIndex].reversed,this.zeroY=a.globals.gridHeight-this.baseLineY[this.yaxisIndex]-(this.isReversed?a.globals.gridHeight:0)+(this.isReversed?2*this.baseLineY[this.yaxisIndex]:0),this.areaBottomY=this.zeroY,(this.zeroY>a.globals.gridHeight||"end"===a.config.plotOptions.area.fillTo)&&(this.areaBottomY=a.globals.gridHeight),this.categoryAxisCorrection=this.xDivision/2,this.elSeries=s.group({class:"apexcharts-series",seriesName:x.escapeString(a.globals.seriesNames[i])}),this.elPointsMain=s.group({class:"apexcharts-series-markers-wrap","data:realIndex":i}),this.elDataLabelsWrap=s.group({class:"apexcharts-datalabels","data:realIndex":i});var r=t[e].length===a.globals.dataPoints;this.elSeries.attr({"data:longestSeries":r,rel:e+1,"data:realIndex":i}),this.appendPathFrom=!0}},{key:"_calculatePathsFrom",value:function(t){var e,i,a,s,r=t.type,o=t.series,n=t.i,l=t.realIndex,h=t.prevX,c=t.prevY,d=t.prevY2,g=this.w,u=new m(this.ctx);if(null===o[n][0]){for(var p=0;p0){var f=this.lineHelpers.checkPreviousPaths({pathFromLine:a,pathFromArea:s,realIndex:l});a=f.pathFromLine,s=f.pathFromArea}return{prevX:h,prevY:c,linePath:e,areaPath:i,pathFromLine:a,pathFromArea:s}}},{key:"_handlePaths",value:function(t){var i=t.type,a=t.realIndex,s=t.i,r=t.paths,o=this.w,n=new m(this.ctx),l=new R(this.ctx);this.prevSeriesY.push(r.yArrj),o.globals.seriesXvalues[a]=r.xArrj,o.globals.seriesYvalues[a]=r.yArrj;var h=o.config.forecastDataPoints;if(h.count>0&&"rangeArea"!==i){var c=o.globals.seriesXvalues[a][o.globals.seriesXvalues[a].length-h.count-1],d=n.drawRect(c,0,o.globals.gridWidth,o.globals.gridHeight,0);o.globals.dom.elForecastMask.appendChild(d.node);var g=n.drawRect(0,0,c,o.globals.gridHeight,0);o.globals.dom.elNonForecastMask.appendChild(g.node)}this.pointsChart||o.globals.delayedElements.push({el:this.elPointsMain.node,index:a});var u={i:s,realIndex:a,animationDelay:s,initialSpeed:o.config.chart.animations.speed,dataChangeSpeed:o.config.chart.animations.dynamicAnimation.speed,className:"apexcharts-".concat(i)};if("area"===i)for(var p=l.fillPath({seriesNumber:a}),f=0;f0&&"rangeArea"!==i){var S=n.renderPaths(k);S.node.setAttribute("stroke-dasharray",h.dashArray),h.strokeWidth&&S.node.setAttribute("stroke-width",h.strokeWidth),this.elSeries.add(S),S.attr("clip-path","url(#forecastMask".concat(o.globals.cuid,")")),A.attr("clip-path","url(#nonForecastMask".concat(o.globals.cuid,")"))}}}}},{key:"_iterateOverDataPoints",value:function(t){var e=t.type,i=t.series,a=t.iterations,s=t.realIndex,r=t.i,o=t.x,n=t.y,l=t.pX,h=t.pY,c=t.pathsFrom,d=t.linePaths,g=t.areaPaths,u=t.seriesIndex,p=t.lineYPosition,f=t.xArrj,b=t.yArrj,v=t.isRangeStart,y=t.seriesRangeEnd,w=this.w,k=new m(this.ctx),A=this.yRatio,S=c.prevY,C=c.linePath,L=c.areaPath,P=c.pathFromLine,I=c.pathFromArea,T=x.isNumber(w.globals.minYArr[s])?w.globals.minYArr[s]:w.globals.minY;a||(a=w.globals.dataPoints>1?w.globals.dataPoints-1:w.globals.dataPoints);for(var M=n,X=0;X0&&w.globals.collapsedSeries.length-1){e--;break}return e>=0?e:0}(r-1)][X+1]}else p=this.zeroY;else p=this.zeroY;z?n=p-T/A[this.yaxisIndex]+2*(this.isReversed?T/A[this.yaxisIndex]:0):(n=p-i[r][X+1]/A[this.yaxisIndex]+2*(this.isReversed?i[r][X+1]/A[this.yaxisIndex]:0),"rangeArea"===e&&(M=p-y[r][X+1]/A[this.yaxisIndex]+2*(this.isReversed?y[r][X+1]/A[this.yaxisIndex]:0))),f.push(o),b.push(n);var Y=this.lineHelpers.calculatePoints({series:i,x:o,y:n,realIndex:s,i:r,j:X,prevY:S}),F=this._createPaths({type:e,series:i,i:r,realIndex:s,j:X,x:o,y:n,y2:M,pX:l,pY:h,linePath:C,areaPath:L,linePaths:d,areaPaths:g,seriesIndex:u,isRangeStart:v});g=F.areaPaths,d=F.linePaths,l=F.pX,h=F.pY,L=F.areaPath,C=F.linePath,this.appendPathFrom&&(P+=k.line(o,this.zeroY),I+=k.line(o,this.zeroY)),this.handleNullDataPoints(i,Y,r,X,s),this._handleMarkersAndLabels({type:e,pointsPos:Y,i:r,j:X,realIndex:s,isRangeStart:v})}return{yArrj:b,xArrj:f,pathFromArea:I,areaPaths:g,pathFromLine:P,linePaths:d,linePath:C,areaPath:L}}},{key:"_handleMarkersAndLabels",value:function(t){var e=t.type,i=t.pointsPos,a=t.isRangeStart,s=t.i,r=t.j,o=t.realIndex,n=this.w,l=new O(this.ctx);if(this.pointsChart)this.scatter.draw(this.elSeries,r,{realIndex:o,pointsPos:i,zRatio:this.zRatio,elParent:this.elPointsMain});else{n.globals.series[s].length>1&&this.elPointsMain.node.classList.add("apexcharts-element-hidden");var h=this.markers.plotChartMarkers(i,o,r+1);null!==h&&this.elPointsMain.add(h)}var c=l.drawDataLabel({type:e,isRangeStart:a,pos:i,i:o,j:r+1});null!==c&&this.elDataLabelsWrap.add(c)}},{key:"_createPaths",value:function(t){var e=t.type,i=t.series,a=t.i,s=t.realIndex,r=t.j,o=t.x,n=t.y,l=t.y2,h=t.pX,c=t.pY,d=t.linePath,g=t.areaPath,u=t.linePaths,p=t.areaPaths,f=t.seriesIndex,x=t.isRangeStart,b=this.w,v=new m(this.ctx),y=b.config.stroke.curve,w=this.areaBottomY;if(Array.isArray(b.config.stroke.curve)&&(y=Array.isArray(f)?b.config.stroke.curve[f[a]]:b.config.stroke.curve[a]),"smooth"===y){var k=.35*(o-h);b.globals.hasNullValues?(null!==i[a][r]&&(null!==i[a][r+1]?(d=v.move(h,c)+v.curve(h+k,c,o-k,n,o+1,n),g=v.move(h+1,c)+v.curve(h+k,c,o-k,n,o+1,n)+v.line(o,w)+v.line(h,w)+"z"):(d=v.move(h,c),g=v.move(h,c)+"z")),u.push(d),p.push(g)):(d+=v.curve(h+k,c,o-k,n,o,n),g+=v.curve(h+k,c,o-k,n,o,n)),h=o,c=n,r===i[a].length-2&&(g=g+v.curve(h,c,o,n,o,w)+v.move(o,n)+"z","rangeArea"===e&&x?d=d+v.curve(h,c,o,n,o,l)+v.move(o,l)+"z":b.globals.hasNullValues||(u.push(d),p.push(g)))}else{if(null===i[a][r+1]){d+=v.move(o,n);var A=b.globals.isXNumeric?(b.globals.seriesX[s][r]-b.globals.minX)/this.xRatio:o-this.xDivision;g=g+v.line(A,w)+v.move(o,n)+"z"}null===i[a][r]&&(d+=v.move(o,n),g+=v.move(o,w)),"stepline"===y?(d=d+v.line(o,null,"H")+v.line(null,n,"V"),g=g+v.line(o,null,"H")+v.line(null,n,"V")):"straight"===y&&(d+=v.line(o,n),g+=v.line(o,n)),r===i[a].length-2&&(g=g+v.line(o,w)+v.move(o,n)+"z","rangeArea"===e&&x?d=d+v.line(o,l)+v.move(o,l)+"z":(u.push(d),p.push(g)))}return{linePaths:u,areaPaths:p,pX:h,pY:c,linePath:d,areaPath:g}}},{key:"handleNullDataPoints",value:function(t,e,i,a,s){var r=this.w;if(null===t[i][a]&&r.config.markers.showNullDataPoints||1===t[i].length){var o=this.markers.plotChartMarkers(e,s,a+1,this.strokeWidth-r.config.markers.strokeWidth/2,!0);null!==o&&this.elPointsMain.add(o)}}}]),t}();window.TreemapSquared={},window.TreemapSquared.generate=function(){function t(e,i,a,s){this.xoffset=e,this.yoffset=i,this.height=s,this.width=a,this.shortestEdge=function(){return Math.min(this.height,this.width)},this.getCoordinates=function(t){var e,i=[],a=this.xoffset,s=this.yoffset,o=r(t)/this.height,n=r(t)/this.width;if(this.width>=this.height)for(e=0;e=this.height){var a=e/this.height,s=this.width-a;i=new t(this.xoffset+a,this.yoffset,s,this.height)}else{var r=e/this.width,o=this.height-r;i=new t(this.xoffset,this.yoffset+r,this.width,o)}return i}}function e(e,a,s,o,n){o=void 0===o?0:o,n=void 0===n?0:n;var l=i(function(t,e){var i,a=[],s=e/r(t);for(i=0;i=o}(e,l=t[0],n)?(e.push(l),i(t.slice(1),e,s,o)):(h=s.cutArea(r(e),o),o.push(s.getCoordinates(e)),i(t,[],h,o)),o;o.push(s.getCoordinates(e))}function a(t,e){var i=Math.min.apply(Math,t),a=Math.max.apply(Math,t),s=r(t);return Math.max(Math.pow(e,2)*a/Math.pow(s,2),Math.pow(s,2)/(Math.pow(e,2)*i))}function s(t){return t&&t.constructor===Array}function r(t){var e,i=0;for(e=0;er-a&&l.width<=o-s){var h=n.rotateAroundCenter(t.node);t.node.setAttribute("transform","rotate(-90 ".concat(h.x," ").concat(h.y,")"))}}},{key:"animateTreemap",value:function(t,e,i,a){var s=new b(this.ctx);s.animateRect(t,{x:e.x,y:e.y,width:e.width,height:e.height},{x:i.x,y:i.y,width:i.width,height:i.height},a,(function(){s.animationCompleted(t)}))}}]),t}(),Ft=86400,Rt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w,this.timeScaleArray=[],this.utc=this.w.config.xaxis.labels.datetimeUTC}return r(t,[{key:"calculateTimeScaleTicks",value:function(t,i){var a=this,s=this.w;if(s.globals.allSeriesCollapsed)return s.globals.labels=[],s.globals.timescaleLabels=[],[];var r=new I(this.ctx),o=(i-t)/864e5;this.determineInterval(o),s.globals.disableZoomIn=!1,s.globals.disableZoomOut=!1,o<.00011574074074074075?s.globals.disableZoomIn=!0:o>5e4&&(s.globals.disableZoomOut=!0);var n=r.getTimeUnitsfromTimestamp(t,i,this.utc),l=s.globals.gridWidth/o,h=l/24,c=h/60,d=c/60,g=Math.floor(24*o),u=Math.floor(1440*o),p=Math.floor(o*Ft),f=Math.floor(o),x=Math.floor(o/30),b=Math.floor(o/365),v={minMillisecond:n.minMillisecond,minSecond:n.minSecond,minMinute:n.minMinute,minHour:n.minHour,minDate:n.minDate,minMonth:n.minMonth,minYear:n.minYear},m={firstVal:v,currentMillisecond:v.minMillisecond,currentSecond:v.minSecond,currentMinute:v.minMinute,currentHour:v.minHour,currentMonthDate:v.minDate,currentDate:v.minDate,currentMonth:v.minMonth,currentYear:v.minYear,daysWidthOnXAxis:l,hoursWidthOnXAxis:h,minutesWidthOnXAxis:c,secondsWidthOnXAxis:d,numberOfSeconds:p,numberOfMinutes:u,numberOfHours:g,numberOfDays:f,numberOfMonths:x,numberOfYears:b};switch(this.tickInterval){case"years":this.generateYearScale(m);break;case"months":case"half_year":this.generateMonthScale(m);break;case"months_days":case"months_fortnight":case"days":case"week_days":this.generateDayScale(m);break;case"hours":this.generateHourScale(m);break;case"minutes_fives":case"minutes":this.generateMinuteScale(m);break;case"seconds_tens":case"seconds_fives":case"seconds":this.generateSecondScale(m)}var y=this.timeScaleArray.map((function(t){var i={position:t.position,unit:t.unit,year:t.year,day:t.day?t.day:1,hour:t.hour?t.hour:0,month:t.month+1};return"month"===t.unit?e(e({},i),{},{day:1,value:t.value+1}):"day"===t.unit||"hour"===t.unit?e(e({},i),{},{value:t.value}):"minute"===t.unit?e(e({},i),{},{value:t.value,minute:t.value}):"second"===t.unit?e(e({},i),{},{value:t.value,minute:t.minute,second:t.second}):t}));return y.filter((function(t){var e=1,i=Math.ceil(s.globals.gridWidth/120),r=t.value;void 0!==s.config.xaxis.tickAmount&&(i=s.config.xaxis.tickAmount),y.length>i&&(e=Math.floor(y.length/i));var o=!1,n=!1;switch(a.tickInterval){case"years":"year"===t.unit&&(o=!0);break;case"half_year":e=7,"year"===t.unit&&(o=!0);break;case"months":e=1,"year"===t.unit&&(o=!0);break;case"months_fortnight":e=15,"year"!==t.unit&&"month"!==t.unit||(o=!0),30===r&&(n=!0);break;case"months_days":e=10,"month"===t.unit&&(o=!0),30===r&&(n=!0);break;case"week_days":e=8,"month"===t.unit&&(o=!0);break;case"days":e=1,"month"===t.unit&&(o=!0);break;case"hours":"day"===t.unit&&(o=!0);break;case"minutes_fives":case"seconds_fives":r%5!=0&&(n=!0);break;case"seconds_tens":r%10!=0&&(n=!0)}if("hours"===a.tickInterval||"minutes_fives"===a.tickInterval||"seconds_tens"===a.tickInterval||"seconds_fives"===a.tickInterval){if(!n)return!0}else if((r%e==0||o)&&!n)return!0}))}},{key:"recalcDimensionsBasedOnFormat",value:function(t,e){var i=this.w,a=this.formatDates(t),s=this.removeOverlappingTS(a);i.globals.timescaleLabels=s.slice(),new ot(this.ctx).plotCoords()}},{key:"determineInterval",value:function(t){var e=24*t,i=60*e;switch(!0){case t/365>5:this.tickInterval="years";break;case t>800:this.tickInterval="half_year";break;case t>180:this.tickInterval="months";break;case t>90:this.tickInterval="months_fortnight";break;case t>60:this.tickInterval="months_days";break;case t>30:this.tickInterval="week_days";break;case t>2:this.tickInterval="days";break;case e>2.4:this.tickInterval="hours";break;case i>15:this.tickInterval="minutes_fives";break;case i>5:this.tickInterval="minutes";break;case i>1:this.tickInterval="seconds_tens";break;case 60*i>20:this.tickInterval="seconds_fives";break;default:this.tickInterval="seconds"}}},{key:"generateYearScale",value:function(t){var e=t.firstVal,i=t.currentMonth,a=t.currentYear,s=t.daysWidthOnXAxis,r=t.numberOfYears,o=e.minYear,n=0,l=new I(this.ctx),h="year";if(e.minDate>1||e.minMonth>0){var c=l.determineRemainingDaysOfYear(e.minYear,e.minMonth,e.minDate);n=(l.determineDaysOfYear(e.minYear)-c+1)*s,o=e.minYear+1,this.timeScaleArray.push({position:n,value:o,unit:h,year:o,month:x.monthMod(i+1)})}else 1===e.minDate&&0===e.minMonth&&this.timeScaleArray.push({position:n,value:o,unit:h,year:a,month:x.monthMod(i+1)});for(var d=o,g=n,u=0;u1){l=(h.determineDaysOfMonths(a+1,e.minYear)-i+1)*r,n=x.monthMod(a+1);var g=s+d,u=x.monthMod(n),p=n;0===n&&(c="year",p=g,u=1,g+=d+=1),this.timeScaleArray.push({position:l,value:p,unit:c,year:g,month:u})}else this.timeScaleArray.push({position:l,value:n,unit:c,year:s,month:x.monthMod(a)});for(var f=n+1,b=l,v=0,m=1;vo.determineDaysOfMonths(e+1,i)?(h=1,n="month",g=e+=1,e):e},d=(24-e.minHour)*s,g=l,u=c(h,i,a);0===e.minHour&&1===e.minDate?(d=0,g=x.monthMod(e.minMonth),n="month",h=e.minDate,r++):1!==e.minDate&&0===e.minHour&&0===e.minMinute&&(d=0,l=e.minDate,g=l,u=c(h=l,i,a)),this.timeScaleArray.push({position:d,value:g,unit:n,year:this._getYear(a,u,0),month:x.monthMod(u),day:h});for(var p=d,f=0;fn.determineDaysOfMonths(e+1,s)&&(f=1,e+=1),{month:e,date:f}},c=function(t,e){return t>n.determineDaysOfMonths(e+1,s)?e+=1:e},d=60-(e.minMinute+e.minSecond/60),g=d*r,u=e.minHour+1,p=u+1;60===d&&(g=0,p=(u=e.minHour)+1);var f=i,b=c(f,a);this.timeScaleArray.push({position:g,value:u,unit:l,day:f,hour:p,year:s,month:x.monthMod(b)});for(var v=g,m=0;m=24)p=0,l="day",b=h(f+=1,b).month,b=c(f,b);var y=this._getYear(s,b,0);v=60*r+v;var w=0===p?f:p;this.timeScaleArray.push({position:v,value:w,unit:l,hour:p,day:f,year:y,month:x.monthMod(b)}),p++}}},{key:"generateMinuteScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,r=t.currentDate,o=t.currentMonth,n=t.currentYear,l=t.minutesWidthOnXAxis,h=t.secondsWidthOnXAxis,c=t.numberOfMinutes,d=a+1,g=r,u=o,p=n,f=s,b=(60-i-e/1e3)*h,v=0;v=60&&(d=0,24===(f+=1)&&(f=0)),this.timeScaleArray.push({position:b,value:d,unit:"minute",hour:f,minute:d,day:g,year:this._getYear(p,u,0),month:x.monthMod(u)}),b+=l,d++}},{key:"generateSecondScale",value:function(t){for(var e=t.currentMillisecond,i=t.currentSecond,a=t.currentMinute,s=t.currentHour,r=t.currentDate,o=t.currentMonth,n=t.currentYear,l=t.secondsWidthOnXAxis,h=t.numberOfSeconds,c=i+1,d=a,g=r,u=o,p=n,f=s,b=(1e3-e)/1e3*l,v=0;v=60&&(c=0,++d>=60&&(d=0,24===++f&&(f=0))),this.timeScaleArray.push({position:b,value:c,unit:"second",hour:f,minute:d,second:c,day:g,year:this._getYear(p,u,0),month:x.monthMod(u)}),b+=l,c++}},{key:"createRawDateString",value:function(t,e){var i=t.year;return 0===t.month&&(t.month=1),i+="-"+("0"+t.month.toString()).slice(-2),"day"===t.unit?i+="day"===t.unit?"-"+("0"+e).slice(-2):"-01":i+="-"+("0"+(t.day?t.day:"1")).slice(-2),"hour"===t.unit?i+="hour"===t.unit?"T"+("0"+e).slice(-2):"T00":i+="T"+("0"+(t.hour?t.hour:"0")).slice(-2),"minute"===t.unit?i+=":"+("0"+e).slice(-2):i+=":"+(t.minute?("0"+t.minute).slice(-2):"00"),"second"===t.unit?i+=":"+("0"+e).slice(-2):i+=":00",this.utc&&(i+=".000Z"),i}},{key:"formatDates",value:function(t){var e=this,i=this.w;return t.map((function(t){var a=t.value.toString(),s=new I(e.ctx),r=e.createRawDateString(t,a),o=s.getDate(s.parseDate(r));if(e.utc||(o=s.getDate(s.parseDateWithTimezone(r))),void 0===i.config.xaxis.labels.format){var n="dd MMM",l=i.config.xaxis.labels.datetimeFormatter;"year"===t.unit&&(n=l.year),"month"===t.unit&&(n=l.month),"day"===t.unit&&(n=l.day),"hour"===t.unit&&(n=l.hour),"minute"===t.unit&&(n=l.minute),"second"===t.unit&&(n=l.second),a=s.formatDate(o,n)}else a=s.formatDate(o,i.config.xaxis.labels.format);return{dateString:r,position:t.position,value:a,unit:t.unit,year:t.year,month:t.month}}))}},{key:"removeOverlappingTS",value:function(t){var e,i=this,a=new m(this.ctx),s=!1;t.length>0&&t[0].value&&t.every((function(e){return e.value.length===t[0].value.length}))&&(s=!0,e=a.getTextRects(t[0].value).width);var r=0,o=t.map((function(o,n){if(n>0&&i.w.config.xaxis.labels.hideOverlappingLabels){var l=s?e:a.getTextRects(t[r].value).width,h=t[r].position;return o.position>h+l+10?(r=n,o):null}return o}));return o=o.filter((function(t){return null!==t}))}},{key:"_getYear",value:function(t,e,i){return t+Math.floor(e/12)+i}}]),t}(),Dt=function(){function t(e,i){a(this,t),this.ctx=i,this.w=i.w,this.el=e}return r(t,[{key:"setupElements",value:function(){var t=this.w.globals,e=this.w.config,i=e.chart.type;t.axisCharts=["line","area","bar","rangeBar","rangeArea","candlestick","boxPlot","scatter","bubble","radar","heatmap","treemap"].indexOf(i)>-1,t.xyCharts=["line","area","bar","rangeBar","rangeArea","candlestick","boxPlot","scatter","bubble"].indexOf(i)>-1,t.isBarHorizontal=("bar"===e.chart.type||"rangeBar"===e.chart.type||"boxPlot"===e.chart.type)&&e.plotOptions.bar.horizontal,t.chartClass=".apexcharts"+t.chartID,t.dom.baseEl=this.el,t.dom.elWrap=document.createElement("div"),m.setAttrs(t.dom.elWrap,{id:t.chartClass.substring(1),class:"apexcharts-canvas "+t.chartClass.substring(1)}),this.el.appendChild(t.dom.elWrap),t.dom.Paper=new window.SVG.Doc(t.dom.elWrap),t.dom.Paper.attr({class:"apexcharts-svg","xmlns:data":"ApexChartsNS",transform:"translate(".concat(e.chart.offsetX,", ").concat(e.chart.offsetY,")")}),t.dom.Paper.node.style.background=e.chart.background,this.setSVGDimensions(),t.dom.elLegendForeign=document.createElementNS(t.SVGNS,"foreignObject"),m.setAttrs(t.dom.elLegendForeign,{x:0,y:0,width:t.svgWidth,height:t.svgHeight}),t.dom.elLegendWrap=document.createElement("div"),t.dom.elLegendWrap.classList.add("apexcharts-legend"),t.dom.elLegendWrap.setAttribute("xmlns","http://www.w3.org/1999/xhtml"),t.dom.elLegendForeign.appendChild(t.dom.elLegendWrap),t.dom.Paper.node.appendChild(t.dom.elLegendForeign),t.dom.elGraphical=t.dom.Paper.group().attr({class:"apexcharts-inner apexcharts-graphical"}),t.dom.elDefs=t.dom.Paper.defs(),t.dom.Paper.add(t.dom.elGraphical),t.dom.elGraphical.add(t.dom.elDefs)}},{key:"plotChartType",value:function(t,e){var i=this.w,a=i.config,s=i.globals,r={series:[],i:[]},o={series:[],i:[]},n={series:[],i:[]},l={series:[],i:[]},h={series:[],i:[]},c={series:[],i:[]},d={series:[],i:[]},g={series:[],i:[]},u={series:[],seriesRangeEnd:[],i:[]};s.series.map((function(e,p){var f=0;void 0!==t[p].type?("column"===t[p].type||"bar"===t[p].type?(s.series.length>1&&a.plotOptions.bar.horizontal&&console.warn("Horizontal bars are not supported in a mixed/combo chart. Please turn off `plotOptions.bar.horizontal`"),h.series.push(e),h.i.push(p),f++,i.globals.columnSeries=h.series):"area"===t[p].type?(o.series.push(e),o.i.push(p),f++):"line"===t[p].type?(r.series.push(e),r.i.push(p),f++):"scatter"===t[p].type?(n.series.push(e),n.i.push(p)):"bubble"===t[p].type?(l.series.push(e),l.i.push(p),f++):"candlestick"===t[p].type?(c.series.push(e),c.i.push(p),f++):"boxPlot"===t[p].type?(d.series.push(e),d.i.push(p),f++):"rangeBar"===t[p].type?(g.series.push(e),g.i.push(p),f++):"rangeArea"===t[p].type?(u.series.push(s.seriesRangeStart[p]),u.seriesRangeEnd.push(s.seriesRangeEnd[p]),u.i.push(p),f++):console.warn("You have specified an unrecognized chart type. Available types for this property are line/area/column/bar/scatter/bubble/candlestick/boxPlot/rangeBar/rangeArea"),f>1&&(s.comboCharts=!0)):(r.series.push(e),r.i.push(p))}));var p=new Xt(this.ctx,e),f=new kt(this.ctx,e);this.ctx.pie=new Lt(this.ctx);var x=new It(this.ctx);this.ctx.rangeBar=new Tt(this.ctx,e);var b=new Pt(this.ctx),v=[];if(s.comboCharts){if(o.series.length>0&&v.push(p.draw(o.series,"area",o.i)),h.series.length>0)if(i.config.chart.stacked){var m=new wt(this.ctx,e);v.push(m.draw(h.series,h.i))}else this.ctx.bar=new yt(this.ctx,e),v.push(this.ctx.bar.draw(h.series,h.i));if(u.series.length>0&&v.push(p.draw(u.series,"rangeArea",u.i,u.seriesRangeEnd)),r.series.length>0&&v.push(p.draw(r.series,"line",r.i)),c.series.length>0&&v.push(f.draw(c.series,"candlestick",c.i)),d.series.length>0&&v.push(f.draw(d.series,"boxPlot",d.i)),g.series.length>0&&v.push(this.ctx.rangeBar.draw(g.series,g.i)),n.series.length>0){var y=new Xt(this.ctx,e,!0);v.push(y.draw(n.series,"scatter",n.i))}if(l.series.length>0){var w=new Xt(this.ctx,e,!0);v.push(w.draw(l.series,"bubble",l.i))}}else switch(a.chart.type){case"line":v=p.draw(s.series,"line");break;case"area":v=p.draw(s.series,"area");break;case"bar":if(a.chart.stacked)v=new wt(this.ctx,e).draw(s.series);else this.ctx.bar=new yt(this.ctx,e),v=this.ctx.bar.draw(s.series);break;case"candlestick":v=new kt(this.ctx,e).draw(s.series,"candlestick");break;case"boxPlot":v=new kt(this.ctx,e).draw(s.series,"boxPlot");break;case"rangeBar":v=this.ctx.rangeBar.draw(s.series);break;case"rangeArea":v=p.draw(s.seriesRangeStart,"rangeArea",void 0,s.seriesRangeEnd);break;case"heatmap":v=new St(this.ctx,e).draw(s.series);break;case"treemap":v=new Yt(this.ctx,e).draw(s.series);break;case"pie":case"donut":case"polarArea":v=this.ctx.pie.draw(s.series);break;case"radialBar":v=x.draw(s.series);break;case"radar":v=b.draw(s.series);break;default:v=p.draw(s.series)}return v}},{key:"setSVGDimensions",value:function(){var t=this.w.globals,e=this.w.config;t.svgWidth=e.chart.width,t.svgHeight=e.chart.height;var i=x.getDimensions(this.el),a=e.chart.width.toString().split(/[0-9]+/g).pop();"%"===a?x.isNumber(i[0])&&(0===i[0].width&&(i=x.getDimensions(this.el.parentNode)),t.svgWidth=i[0]*parseInt(e.chart.width,10)/100):"px"!==a&&""!==a||(t.svgWidth=parseInt(e.chart.width,10));var s=e.chart.height.toString().split(/[0-9]+/g).pop();if("auto"!==t.svgHeight&&""!==t.svgHeight)if("%"===s){var r=x.getDimensions(this.el.parentNode);t.svgHeight=r[1]*parseInt(e.chart.height,10)/100}else t.svgHeight=parseInt(e.chart.height,10);else t.axisCharts?t.svgHeight=t.svgWidth/1.61:t.svgHeight=t.svgWidth/1.2;if(t.svgWidth<0&&(t.svgWidth=0),t.svgHeight<0&&(t.svgHeight=0),m.setAttrs(t.dom.Paper.node,{width:t.svgWidth,height:t.svgHeight}),"%"!==s){var o=e.chart.sparkline.enabled?0:t.axisCharts?e.chart.parentHeightOffset:0;t.dom.Paper.node.parentNode.parentNode.style.minHeight=t.svgHeight+o+"px"}t.dom.elWrap.style.width=t.svgWidth+"px",t.dom.elWrap.style.height=t.svgHeight+"px"}},{key:"shiftGraphPosition",value:function(){var t=this.w.globals,e=t.translateY,i={transform:"translate("+t.translateX+", "+e+")"};m.setAttrs(t.dom.elGraphical.node,i)}},{key:"resizeNonAxisCharts",value:function(){var t=this.w,e=t.globals,i=0,a=t.config.chart.sparkline.enabled?1:15;a+=t.config.grid.padding.bottom,"top"!==t.config.legend.position&&"bottom"!==t.config.legend.position||!t.config.legend.show||t.config.legend.floating||(i=new lt(this.ctx).legendHelpers.getLegendBBox().clwh+10);var s=t.globals.dom.baseEl.querySelector(".apexcharts-radialbar, .apexcharts-pie"),r=2.05*t.globals.radialSize;if(s&&!t.config.chart.sparkline.enabled&&0!==t.config.plotOptions.radialBar.startAngle){var o=x.getBoundingClientRect(s);r=o.bottom;var n=o.bottom-o.top;r=Math.max(2.05*t.globals.radialSize,n)}var l=r+e.translateY+i+a;e.dom.elLegendForeign&&e.dom.elLegendForeign.setAttribute("height",l),t.config.chart.height&&String(t.config.chart.height).indexOf("%")>0||(e.dom.elWrap.style.height=l+"px",m.setAttrs(e.dom.Paper.node,{height:l}),e.dom.Paper.node.parentNode.parentNode.style.minHeight=l+"px")}},{key:"coreCalculations",value:function(){new U(this.ctx).init()}},{key:"resetGlobals",value:function(){var t=this,e=function(){return t.w.config.series.map((function(t){return[]}))},i=new Y,a=this.w.globals;i.initGlobalVars(a),a.seriesXvalues=e(),a.seriesYvalues=e()}},{key:"isMultipleY",value:function(){if(this.w.config.yaxis.constructor===Array&&this.w.config.yaxis.length>1)return this.w.globals.isMultipleYAxis=!0,!0}},{key:"xySettings",value:function(){var t=null,e=this.w;if(e.globals.axisCharts){if("back"===e.config.xaxis.crosshairs.position)new Q(this.ctx).drawXCrosshairs();if("back"===e.config.yaxis[0].crosshairs.position)new Q(this.ctx).drawYCrosshairs();if("datetime"===e.config.xaxis.type&&void 0===e.config.xaxis.labels.formatter){this.ctx.timeScale=new Rt(this.ctx);var i=[];isFinite(e.globals.minX)&&isFinite(e.globals.maxX)&&!e.globals.isBarHorizontal?i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minX,e.globals.maxX):e.globals.isBarHorizontal&&(i=this.ctx.timeScale.calculateTimeScaleTicks(e.globals.minY,e.globals.maxY)),this.ctx.timeScale.recalcDimensionsBasedOnFormat(i)}t=new y(this.ctx).getCalculatedRatios()}return t}},{key:"updateSourceChart",value:function(t){this.ctx.w.globals.selection=void 0,this.ctx.updateHelpers._updateOptions({chart:{selection:{xaxis:{min:t.w.globals.minX,max:t.w.globals.maxX}}}},!1,!1)}},{key:"setupBrushHandler",value:function(){var t=this,i=this.w;if(i.config.chart.brush.enabled&&"function"!=typeof i.config.chart.events.selection){var a=i.config.chart.brush.targets||[i.config.chart.brush.target];a.forEach((function(e){var i=ApexCharts.getChartByID(e);i.w.globals.brushSource=t.ctx,"function"!=typeof i.w.config.chart.events.zoomed&&(i.w.config.chart.events.zoomed=function(){t.updateSourceChart(i)}),"function"!=typeof i.w.config.chart.events.scrolled&&(i.w.config.chart.events.scrolled=function(){t.updateSourceChart(i)})})),i.config.chart.events.selection=function(t,s){a.forEach((function(t){var a=ApexCharts.getChartByID(t),r=x.clone(i.config.yaxis);if(i.config.chart.brush.autoScaleYaxis&&1===a.w.globals.series.length){var o=new _(a);r=o.autoScaleY(a,r,s)}var n=a.w.config.yaxis.reduce((function(t,i,s){return[].concat(u(t),[e(e({},a.w.config.yaxis[s]),{},{min:r[0].min,max:r[0].max})])}),[]);a.ctx.updateHelpers._updateOptions({xaxis:{min:s.xaxis.min,max:s.xaxis.max},yaxis:n},!1,!1,!1,!1)}))}}}}]),t}(),Ht=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"_updateOptions",value:function(t){var e=this,a=arguments.length>1&&void 0!==arguments[1]&&arguments[1],s=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],r=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],o=arguments.length>4&&void 0!==arguments[4]&&arguments[4];return new Promise((function(n){var l=[e.ctx];r&&(l=e.ctx.getSyncedCharts()),e.ctx.w.globals.isExecCalled&&(l=[e.ctx],e.ctx.w.globals.isExecCalled=!1),l.forEach((function(r,h){var c=r.w;if(c.globals.shouldAnimate=s,a||(c.globals.resized=!0,c.globals.dataChanged=!0,s&&r.series.getPreviousPaths()),t&&"object"===i(t)&&(r.config=new E(t),t=y.extendArrayProps(r.config,t,c),r.w.globals.chartID!==e.ctx.w.globals.chartID&&delete t.series,c.config=x.extend(c.config,t),o&&(c.globals.lastXAxis=t.xaxis?x.clone(t.xaxis):[],c.globals.lastYAxis=t.yaxis?x.clone(t.yaxis):[],c.globals.initialConfig=x.extend({},c.config),c.globals.initialSeries=x.clone(c.config.series),t.series))){for(var d=0;d2&&void 0!==arguments[2]&&arguments[2];return new Promise((function(s){var r,o=i.w;return o.globals.shouldAnimate=e,o.globals.dataChanged=!0,e&&i.ctx.series.getPreviousPaths(),o.globals.axisCharts?(0===(r=t.map((function(t,e){return i._extendSeries(t,e)}))).length&&(r=[{data:[]}]),o.config.series=r):o.config.series=t.slice(),a&&(o.globals.initialConfig.series=x.clone(o.config.series),o.globals.initialSeries=x.clone(o.config.series)),i.ctx.update().then((function(){s(i.ctx)}))}))}},{key:"_extendSeries",value:function(t,i){var a=this.w,s=a.config.series[i];return e(e({},a.config.series[i]),{},{name:t.name?t.name:s&&s.name,color:t.color?t.color:s&&s.color,type:t.type?t.type:s&&s.type,data:t.data?t.data:s&&s.data})}},{key:"toggleDataPointSelection",value:function(t,e){var i=this.w,a=null,s=".apexcharts-series[data\\:realIndex='".concat(t,"']");return i.globals.axisCharts?a=i.globals.dom.Paper.select("".concat(s," path[j='").concat(e,"'], ").concat(s," circle[j='").concat(e,"'], ").concat(s," rect[j='").concat(e,"']")).members[0]:void 0===e&&(a=i.globals.dom.Paper.select("".concat(s," path[j='").concat(t,"']")).members[0],"pie"!==i.config.chart.type&&"polarArea"!==i.config.chart.type&&"donut"!==i.config.chart.type||this.ctx.pie.pieClicked(t)),a?(new m(this.ctx).pathMouseDown(a,null),a.node?a.node:null):(console.warn("toggleDataPointSelection: Element not found"),null)}},{key:"forceXAxisUpdate",value:function(t){var e=this.w;if(["min","max"].forEach((function(i){void 0!==t.xaxis[i]&&(e.config.xaxis[i]=t.xaxis[i],e.globals.lastXAxis[i]=t.xaxis[i])})),t.xaxis.categories&&t.xaxis.categories.length&&(e.config.xaxis.categories=t.xaxis.categories),e.config.xaxis.convertedCatToNumeric){var i=new z(t);t=i.convertCatToNumericXaxis(t,this.ctx)}return t}},{key:"forceYAxisUpdate",value:function(t){return t.chart&&t.chart.stacked&&"100%"===t.chart.stackType&&(Array.isArray(t.yaxis)?t.yaxis.forEach((function(e,i){t.yaxis[i].min=0,t.yaxis[i].max=100})):(t.yaxis.min=0,t.yaxis.max=100)),t}},{key:"revertDefaultAxisMinMax",value:function(t){var e=this,i=this.w,a=i.globals.lastXAxis,s=i.globals.lastYAxis;t&&t.xaxis&&(a=t.xaxis),t&&t.yaxis&&(s=t.yaxis),i.config.xaxis.min=a.min,i.config.xaxis.max=a.max;var r=function(t){void 0!==s[t]&&(i.config.yaxis[t].min=s[t].min,i.config.yaxis[t].max=s[t].max)};i.config.yaxis.map((function(t,a){i.globals.zoomed||void 0!==s[a]?r(a):void 0!==e.ctx.opts.yaxis[a]&&(t.min=e.ctx.opts.yaxis[a].min,t.max=e.ctx.opts.yaxis[a].max)}))}}]),t}();zt="undefined"!=typeof window?window:void 0,Et=function(t,e){var a=(void 0!==this?this:t).SVG=function(t){if(a.supported)return t=new a.Doc(t),a.parser.draw||a.prepare(),t};if(a.ns="http://www.w3.org/2000/svg",a.xmlns="http://www.w3.org/2000/xmlns/",a.xlink="http://www.w3.org/1999/xlink",a.svgjs="http://svgjs.dev",a.supported=!0,!a.supported)return!1;a.did=1e3,a.eid=function(t){return"Svgjs"+d(t)+a.did++},a.create=function(t){var i=e.createElementNS(this.ns,t);return i.setAttribute("id",this.eid(t)),i},a.extend=function(){var t,e;e=(t=[].slice.call(arguments)).pop();for(var i=t.length-1;i>=0;i--)if(t[i])for(var s in e)t[i].prototype[s]=e[s];a.Set&&a.Set.inherit&&a.Set.inherit()},a.invent=function(t){var e="function"==typeof t.create?t.create:function(){this.constructor.call(this,a.create(t.create))};return t.inherit&&(e.prototype=new t.inherit),t.extend&&a.extend(e,t.extend),t.construct&&a.extend(t.parent||a.Container,t.construct),e},a.adopt=function(e){return e?e.instance?e.instance:((i="svg"==e.nodeName?e.parentNode instanceof t.SVGElement?new a.Nested:new a.Doc:"linearGradient"==e.nodeName?new a.Gradient("linear"):"radialGradient"==e.nodeName?new a.Gradient("radial"):a[d(e.nodeName)]?new(a[d(e.nodeName)]):new a.Element(e)).type=e.nodeName,i.node=e,e.instance=i,i instanceof a.Doc&&i.namespace().defs(),i.setData(JSON.parse(e.getAttribute("svgjs:data"))||{}),i):null;var i},a.prepare=function(){var t=e.getElementsByTagName("body")[0],i=(t?new a.Doc(t):a.adopt(e.documentElement).nested()).size(2,0);a.parser={body:t||e.documentElement,draw:i.style("opacity:0;position:absolute;left:-100%;top:-100%;overflow:hidden").node,poly:i.polyline().node,path:i.path().node,native:a.create("svg")}},a.parser={native:a.create("svg")},e.addEventListener("DOMContentLoaded",(function(){a.parser.draw||a.prepare()}),!1),a.regex={numberAndUnit:/^([+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?)([a-z%]*)$/i,hex:/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i,rgb:/rgb\((\d+),(\d+),(\d+)\)/,reference:/#([a-z0-9\-_]+)/i,transforms:/\)\s*,?\s*/,whitespace:/\s/g,isHex:/^#[a-f0-9]{3,6}$/i,isRgb:/^rgb\(/,isCss:/[^:]+:[^;]+;?/,isBlank:/^(\s+)?$/,isNumber:/^[+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i,isPercent:/^-?[\d\.]+%$/,isImage:/\.(jpg|jpeg|png|gif|svg)(\?[^=]+.*)?/i,delimiter:/[\s,]+/,hyphen:/([^e])\-/gi,pathLetters:/[MLHVCSQTAZ]/gi,isPathLetter:/[MLHVCSQTAZ]/i,numbersWithDots:/((\d?\.\d+(?:e[+-]?\d+)?)((?:\.\d+(?:e[+-]?\d+)?)+))+/gi,dots:/\./g},a.utils={map:function(t,e){for(var i=t.length,a=[],s=0;s1?1:t,new a.Color({r:~~(this.r+(this.destination.r-this.r)*t),g:~~(this.g+(this.destination.g-this.g)*t),b:~~(this.b+(this.destination.b-this.b)*t)})):this}}),a.Color.test=function(t){return t+="",a.regex.isHex.test(t)||a.regex.isRgb.test(t)},a.Color.isRgb=function(t){return t&&"number"==typeof t.r&&"number"==typeof t.g&&"number"==typeof t.b},a.Color.isColor=function(t){return a.Color.isRgb(t)||a.Color.test(t)},a.Array=function(t,e){0==(t=(t||[]).valueOf()).length&&e&&(t=e.valueOf()),this.value=this.parse(t)},a.extend(a.Array,{toString:function(){return this.value.join(" ")},valueOf:function(){return this.value},parse:function(t){return t=t.valueOf(),Array.isArray(t)?t:this.split(t)}}),a.PointArray=function(t,e){a.Array.call(this,t,e||[[0,0]])},a.PointArray.prototype=new a.Array,a.PointArray.prototype.constructor=a.PointArray;for(var s={M:function(t,e,i){return e.x=i.x=t[0],e.y=i.y=t[1],["M",e.x,e.y]},L:function(t,e){return e.x=t[0],e.y=t[1],["L",t[0],t[1]]},H:function(t,e){return e.x=t[0],["H",t[0]]},V:function(t,e){return e.y=t[0],["V",t[0]]},C:function(t,e){return e.x=t[4],e.y=t[5],["C",t[0],t[1],t[2],t[3],t[4],t[5]]},Q:function(t,e){return e.x=t[2],e.y=t[3],["Q",t[0],t[1],t[2],t[3]]},Z:function(t,e,i){return e.x=i.x,e.y=i.y,["Z"]}},r="mlhvqtcsaz".split(""),o=0,n=r.length;ol);return r},bbox:function(){return a.parser.draw||a.prepare(),a.parser.path.setAttribute("d",this.toString()),a.parser.path.getBBox()}}),a.Number=a.invent({create:function(t,e){this.value=0,this.unit=e||"","number"==typeof t?this.value=isNaN(t)?0:isFinite(t)?t:t<0?-34e37:34e37:"string"==typeof t?(e=t.match(a.regex.numberAndUnit))&&(this.value=parseFloat(e[1]),"%"==e[5]?this.value/=100:"s"==e[5]&&(this.value*=1e3),this.unit=e[5]):t instanceof a.Number&&(this.value=t.valueOf(),this.unit=t.unit)},extend:{toString:function(){return("%"==this.unit?~~(1e8*this.value)/1e6:"s"==this.unit?this.value/1e3:this.value)+this.unit},toJSON:function(){return this.toString()},valueOf:function(){return this.value},plus:function(t){return t=new a.Number(t),new a.Number(this+t,this.unit||t.unit)},minus:function(t){return t=new a.Number(t),new a.Number(this-t,this.unit||t.unit)},times:function(t){return t=new a.Number(t),new a.Number(this*t,this.unit||t.unit)},divide:function(t){return t=new a.Number(t),new a.Number(this/t,this.unit||t.unit)},to:function(t){var e=new a.Number(this);return"string"==typeof t&&(e.unit=t),e},morph:function(t){return this.destination=new a.Number(t),t.relative&&(this.destination.value+=this.value),this},at:function(t){return this.destination?new a.Number(this.destination).minus(this).times(t).plus(this):this}}}),a.Element=a.invent({create:function(t){this._stroke=a.defaults.attrs.stroke,this._event=null,this.dom={},(this.node=t)&&(this.type=t.nodeName,this.node.instance=this,this._stroke=t.getAttribute("stroke")||this._stroke)},extend:{x:function(t){return this.attr("x",t)},y:function(t){return this.attr("y",t)},cx:function(t){return null==t?this.x()+this.width()/2:this.x(t-this.width()/2)},cy:function(t){return null==t?this.y()+this.height()/2:this.y(t-this.height()/2)},move:function(t,e){return this.x(t).y(e)},center:function(t,e){return this.cx(t).cy(e)},width:function(t){return this.attr("width",t)},height:function(t){return this.attr("height",t)},size:function(t,e){var i=u(this,t,e);return this.width(new a.Number(i.width)).height(new a.Number(i.height))},clone:function(t){this.writeDataToDom();var e=x(this.node.cloneNode(!0));return t?t.add(e):this.after(e),e},remove:function(){return this.parent()&&this.parent().removeElement(this),this},replace:function(t){return this.after(t).remove(),t},addTo:function(t){return t.put(this)},putIn:function(t){return t.add(this)},id:function(t){return this.attr("id",t)},show:function(){return this.style("display","")},hide:function(){return this.style("display","none")},visible:function(){return"none"!=this.style("display")},toString:function(){return this.attr("id")},classes:function(){var t=this.attr("class");return null==t?[]:t.trim().split(a.regex.delimiter)},hasClass:function(t){return-1!=this.classes().indexOf(t)},addClass:function(t){if(!this.hasClass(t)){var e=this.classes();e.push(t),this.attr("class",e.join(" "))}return this},removeClass:function(t){return this.hasClass(t)&&this.attr("class",this.classes().filter((function(e){return e!=t})).join(" ")),this},toggleClass:function(t){return this.hasClass(t)?this.removeClass(t):this.addClass(t)},reference:function(t){return a.get(this.attr(t))},parent:function(e){var i=this;if(!i.node.parentNode)return null;if(i=a.adopt(i.node.parentNode),!e)return i;for(;i&&i.node instanceof t.SVGElement;){if("string"==typeof e?i.matches(e):i instanceof e)return i;if(!i.node.parentNode||"#document"==i.node.parentNode.nodeName)return null;i=a.adopt(i.node.parentNode)}},doc:function(){return this instanceof a.Doc?this:this.parent(a.Doc)},parents:function(t){var e=[],i=this;do{if(!(i=i.parent(t))||!i.node)break;e.push(i)}while(i.parent);return e},matches:function(t){return function(t,e){return(t.matches||t.matchesSelector||t.msMatchesSelector||t.mozMatchesSelector||t.webkitMatchesSelector||t.oMatchesSelector).call(t,e)}(this.node,t)},native:function(){return this.node},svg:function(t){var i=e.createElement("svg");if(!(t&&this instanceof a.Parent))return i.appendChild(t=e.createElement("svg")),this.writeDataToDom(),t.appendChild(this.node.cloneNode(!0)),i.innerHTML.replace(/^/,"").replace(/<\/svg>$/,"");i.innerHTML=""+t.replace(/\n/,"").replace(/<([\w:-]+)([^<]+?)\/>/g,"<$1$2>")+"";for(var s=0,r=i.firstChild.childNodes.length;s":function(t){return-Math.cos(t*Math.PI)/2+.5},">":function(t){return Math.sin(t*Math.PI/2)},"<":function(t){return 1-Math.cos(t*Math.PI/2)}},a.morph=function(t){return function(e,i){return new a.MorphObj(e,i).at(t)}},a.Situation=a.invent({create:function(t){this.init=!1,this.reversed=!1,this.reversing=!1,this.duration=new a.Number(t.duration).valueOf(),this.delay=new a.Number(t.delay).valueOf(),this.start=+new Date+this.delay,this.finish=this.start+this.duration,this.ease=t.ease,this.loop=0,this.loops=!1,this.animations={},this.attrs={},this.styles={},this.transforms=[],this.once={}}}),a.FX=a.invent({create:function(t){this._target=t,this.situations=[],this.active=!1,this.situation=null,this.paused=!1,this.lastPos=0,this.pos=0,this.absPos=0,this._speed=1},extend:{animate:function(t,e,s){"object"===i(t)&&(e=t.ease,s=t.delay,t=t.duration);var r=new a.Situation({duration:t||1e3,delay:s||0,ease:a.easing[e||"-"]||e});return this.queue(r),this},target:function(t){return t&&t instanceof a.Element?(this._target=t,this):this._target},timeToAbsPos:function(t){return(t-this.situation.start)/(this.situation.duration/this._speed)},absPosToTime:function(t){return this.situation.duration/this._speed*t+this.situation.start},startAnimFrame:function(){this.stopAnimFrame(),this.animationFrame=t.requestAnimationFrame(function(){this.step()}.bind(this))},stopAnimFrame:function(){t.cancelAnimationFrame(this.animationFrame)},start:function(){return!this.active&&this.situation&&(this.active=!0,this.startCurrent()),this},startCurrent:function(){return this.situation.start=+new Date+this.situation.delay/this._speed,this.situation.finish=this.situation.start+this.situation.duration/this._speed,this.initAnimations().step()},queue:function(t){return("function"==typeof t||t instanceof a.Situation)&&this.situations.push(t),this.situation||(this.situation=this.situations.shift()),this},dequeue:function(){return this.stop(),this.situation=this.situations.shift(),this.situation&&(this.situation instanceof a.Situation?this.start():this.situation.call(this)),this},initAnimations:function(){var t,e=this.situation;if(e.init)return this;for(var i in e.animations){t=this.target()[i](),Array.isArray(t)||(t=[t]),Array.isArray(e.animations[i])||(e.animations[i]=[e.animations[i]]);for(var s=t.length;s--;)e.animations[i][s]instanceof a.Number&&(t[s]=new a.Number(t[s])),e.animations[i][s]=t[s].morph(e.animations[i][s])}for(var i in e.attrs)e.attrs[i]=new a.MorphObj(this.target().attr(i),e.attrs[i]);for(var i in e.styles)e.styles[i]=new a.MorphObj(this.target().style(i),e.styles[i]);return e.initialTransformation=this.target().matrixify(),e.init=!0,this},clearQueue:function(){return this.situations=[],this},clearCurrent:function(){return this.situation=null,this},stop:function(t,e){var i=this.active;return this.active=!1,e&&this.clearQueue(),t&&this.situation&&(!i&&this.startCurrent(),this.atEnd()),this.stopAnimFrame(),this.clearCurrent()},after:function(t){var e=this.last();return this.target().on("finished.fx",(function i(a){a.detail.situation==e&&(t.call(this,e),this.off("finished.fx",i))})),this._callStart()},during:function(t){var e=this.last(),i=function(i){i.detail.situation==e&&t.call(this,i.detail.pos,a.morph(i.detail.pos),i.detail.eased,e)};return this.target().off("during.fx",i).on("during.fx",i),this.after((function(){this.off("during.fx",i)})),this._callStart()},afterAll:function(t){var e=function e(i){t.call(this),this.off("allfinished.fx",e)};return this.target().off("allfinished.fx",e).on("allfinished.fx",e),this._callStart()},last:function(){return this.situations.length?this.situations[this.situations.length-1]:this.situation},add:function(t,e,i){return this.last()[i||"animations"][t]=e,this._callStart()},step:function(t){var e,i,a;t||(this.absPos=this.timeToAbsPos(+new Date)),!1!==this.situation.loops?(e=Math.max(this.absPos,0),i=Math.floor(e),!0===this.situation.loops||ithis.lastPos&&r<=s&&(this.situation.once[r].call(this.target(),this.pos,s),delete this.situation.once[r]);return this.active&&this.target().fire("during",{pos:this.pos,eased:s,fx:this,situation:this.situation}),this.situation?(this.eachAt(),1==this.pos&&!this.situation.reversed||this.situation.reversed&&0==this.pos?(this.stopAnimFrame(),this.target().fire("finished",{fx:this,situation:this.situation}),this.situations.length||(this.target().fire("allfinished"),this.situations.length||(this.target().off(".fx"),this.active=!1)),this.active?this.dequeue():this.clearCurrent()):!this.paused&&this.active&&this.startAnimFrame(),this.lastPos=s,this):this},eachAt:function(){var t,e=this,i=this.target(),s=this.situation;for(var r in s.animations)t=[].concat(s.animations[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i[r].apply(i,t);for(var r in s.attrs)t=[r].concat(s.attrs[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i.attr.apply(i,t);for(var r in s.styles)t=[r].concat(s.styles[r]).map((function(t){return"string"!=typeof t&&t.at?t.at(s.ease(e.pos),e.pos):t})),i.style.apply(i,t);if(s.transforms.length){t=s.initialTransformation,r=0;for(var o=s.transforms.length;r=0;--s)this[v[s]]=null!=t[v[s]]?t[v[s]]:e[v[s]]},extend:{extract:function(){var t=p(this,0,1);p(this,1,0);var e=180/Math.PI*Math.atan2(t.y,t.x)-90;return{x:this.e,y:this.f,transformedX:(this.e*Math.cos(e*Math.PI/180)+this.f*Math.sin(e*Math.PI/180))/Math.sqrt(this.a*this.a+this.b*this.b),transformedY:(this.f*Math.cos(e*Math.PI/180)+this.e*Math.sin(-e*Math.PI/180))/Math.sqrt(this.c*this.c+this.d*this.d),rotation:e,a:this.a,b:this.b,c:this.c,d:this.d,e:this.e,f:this.f,matrix:new a.Matrix(this)}},clone:function(){return new a.Matrix(this)},morph:function(t){return this.destination=new a.Matrix(t),this},multiply:function(t){return new a.Matrix(this.native().multiply(function(t){return t instanceof a.Matrix||(t=new a.Matrix(t)),t}(t).native()))},inverse:function(){return new a.Matrix(this.native().inverse())},translate:function(t,e){return new a.Matrix(this.native().translate(t||0,e||0))},native:function(){for(var t=a.parser.native.createSVGMatrix(),e=v.length-1;e>=0;e--)t[v[e]]=this[v[e]];return t},toString:function(){return"matrix("+b(this.a)+","+b(this.b)+","+b(this.c)+","+b(this.d)+","+b(this.e)+","+b(this.f)+")"}},parent:a.Element,construct:{ctm:function(){return new a.Matrix(this.node.getCTM())},screenCTM:function(){if(this instanceof a.Nested){var t=this.rect(1,1),e=t.node.getScreenCTM();return t.remove(),new a.Matrix(e)}return new a.Matrix(this.node.getScreenCTM())}}}),a.Point=a.invent({create:function(t,e){var a;a=Array.isArray(t)?{x:t[0],y:t[1]}:"object"===i(t)?{x:t.x,y:t.y}:null!=t?{x:t,y:null!=e?e:t}:{x:0,y:0},this.x=a.x,this.y=a.y},extend:{clone:function(){return new a.Point(this)},morph:function(t,e){return this.destination=new a.Point(t,e),this}}}),a.extend(a.Element,{point:function(t,e){return new a.Point(t,e).transform(this.screenCTM().inverse())}}),a.extend(a.Element,{attr:function(t,e,s){if(null==t){for(t={},s=(e=this.node.attributes).length-1;s>=0;s--)t[e[s].nodeName]=a.regex.isNumber.test(e[s].nodeValue)?parseFloat(e[s].nodeValue):e[s].nodeValue;return t}if("object"===i(t))for(var r in t)this.attr(r,t[r]);else if(null===e)this.node.removeAttribute(t);else{if(null==e)return null==(e=this.node.getAttribute(t))?a.defaults.attrs[t]:a.regex.isNumber.test(e)?parseFloat(e):e;"stroke-width"==t?this.attr("stroke",parseFloat(e)>0?this._stroke:null):"stroke"==t&&(this._stroke=e),"fill"!=t&&"stroke"!=t||(a.regex.isImage.test(e)&&(e=this.doc().defs().image(e,0,0)),e instanceof a.Image&&(e=this.doc().defs().pattern(0,0,(function(){this.add(e)})))),"number"==typeof e?e=new a.Number(e):a.Color.isColor(e)?e=new a.Color(e):Array.isArray(e)&&(e=new a.Array(e)),"leading"==t?this.leading&&this.leading(e):"string"==typeof s?this.node.setAttributeNS(s,t,e.toString()):this.node.setAttribute(t,e.toString()),!this.rebuild||"font-size"!=t&&"x"!=t||this.rebuild(t,e)}return this}}),a.extend(a.Element,{transform:function(t,e){var s;return"object"!==i(t)?(s=new a.Matrix(this).extract(),"string"==typeof t?s[t]:s):(s=new a.Matrix(this),e=!!e||!!t.relative,null!=t.a&&(s=e?s.multiply(new a.Matrix(t)):new a.Matrix(t)),this.attr("transform",s))}}),a.extend(a.Element,{untransform:function(){return this.attr("transform",null)},matrixify:function(){return(this.attr("transform")||"").split(a.regex.transforms).slice(0,-1).map((function(t){var e=t.trim().split("(");return[e[0],e[1].split(a.regex.delimiter).map((function(t){return parseFloat(t)}))]})).reduce((function(t,e){return"matrix"==e[0]?t.multiply(f(e[1])):t[e[0]].apply(t,e[1])}),new a.Matrix)},toParent:function(t){if(this==t)return this;var e=this.screenCTM(),i=t.screenCTM().inverse();return this.addTo(t).untransform().transform(i.multiply(e)),this},toDoc:function(){return this.toParent(this.doc())}}),a.Transformation=a.invent({create:function(t,e){if(arguments.length>1&&"boolean"!=typeof e)return this.constructor.call(this,[].slice.call(arguments));if(Array.isArray(t))for(var a=0,s=this.arguments.length;a=0},index:function(t){return[].slice.call(this.node.childNodes).indexOf(t.node)},get:function(t){return a.adopt(this.node.childNodes[t])},first:function(){return this.get(0)},last:function(){return this.get(this.node.childNodes.length-1)},each:function(t,e){for(var i=this.children(),s=0,r=i.length;s=0;i--)e.childNodes[i]instanceof t.SVGElement&&x(e.childNodes[i]);return a.adopt(e).id(a.eid(e.nodeName))}function b(t){return Math.abs(t)>1e-37?t:0}["fill","stroke"].forEach((function(t){var e={};e[t]=function(e){if(void 0===e)return this;if("string"==typeof e||a.Color.isRgb(e)||e&&"function"==typeof e.fill)this.attr(t,e);else for(var i=l[t].length-1;i>=0;i--)null!=e[l[t][i]]&&this.attr(l.prefix(t,l[t][i]),e[l[t][i]]);return this},a.extend(a.Element,a.FX,e)})),a.extend(a.Element,a.FX,{translate:function(t,e){return this.transform({x:t,y:e})},matrix:function(t){return this.attr("transform",new a.Matrix(6==arguments.length?[].slice.call(arguments):t))},opacity:function(t){return this.attr("opacity",t)},dx:function(t){return this.x(new a.Number(t).plus(this instanceof a.FX?0:this.x()),!0)},dy:function(t){return this.y(new a.Number(t).plus(this instanceof a.FX?0:this.y()),!0)}}),a.extend(a.Path,{length:function(){return this.node.getTotalLength()},pointAt:function(t){return this.node.getPointAtLength(t)}}),a.Set=a.invent({create:function(t){Array.isArray(t)?this.members=t:this.clear()},extend:{add:function(){for(var t=[].slice.call(arguments),e=0,i=t.length;e-1&&this.members.splice(e,1),this},each:function(t){for(var e=0,i=this.members.length;e=0},index:function(t){return this.members.indexOf(t)},get:function(t){return this.members[t]},first:function(){return this.get(0)},last:function(){return this.get(this.members.length-1)},valueOf:function(){return this.members}},construct:{set:function(t){return new a.Set(t)}}}),a.FX.Set=a.invent({create:function(t){this.set=t}}),a.Set.inherit=function(){var t=[];for(var e in a.Shape.prototype)"function"==typeof a.Shape.prototype[e]&&"function"!=typeof a.Set.prototype[e]&&t.push(e);for(var e in t.forEach((function(t){a.Set.prototype[t]=function(){for(var e=0,i=this.members.length;e=0;t--)delete this.memory()[arguments[t]];return this},memory:function(){return this._memory||(this._memory={})}}),a.get=function(t){var i=e.getElementById(function(t){var e=(t||"").toString().match(a.regex.reference);if(e)return e[1]}(t)||t);return a.adopt(i)},a.select=function(t,i){return new a.Set(a.utils.map((i||e).querySelectorAll(t),(function(t){return a.adopt(t)})))},a.extend(a.Parent,{select:function(t){return a.select(t,this.node)}});var v="abcdef".split("");if("function"!=typeof t.CustomEvent){var m=function(t,i){i=i||{bubbles:!1,cancelable:!1,detail:void 0};var a=e.createEvent("CustomEvent");return a.initCustomEvent(t,i.bubbles,i.cancelable,i.detail),a};m.prototype=t.Event.prototype,a.CustomEvent=m}else a.CustomEvent=t.CustomEvent;return a},"function"==typeof define&&define.amd?define((function(){return Et(zt,zt.document)})):"object"===("undefined"==typeof exports?"undefined":i(exports))&&"undefined"!=typeof module?module.exports=zt.document?Et(zt,zt.document):function(t){return Et(t,t.document)}:zt.SVG=Et(zt,zt.document), -/*! svg.filter.js - v2.0.2 - 2016-02-24 - * https://github.com/wout/svg.filter.js - * Copyright (c) 2016 Wout Fierens; Licensed MIT */ -function(){SVG.Filter=SVG.invent({create:"filter",inherit:SVG.Parent,extend:{source:"SourceGraphic",sourceAlpha:"SourceAlpha",background:"BackgroundImage",backgroundAlpha:"BackgroundAlpha",fill:"FillPaint",stroke:"StrokePaint",autoSetIn:!0,put:function(t,e){return this.add(t,e),!t.attr("in")&&this.autoSetIn&&t.attr("in",this.source),t.attr("result")||t.attr("result",t),t},blend:function(t,e,i){return this.put(new SVG.BlendEffect(t,e,i))},colorMatrix:function(t,e){return this.put(new SVG.ColorMatrixEffect(t,e))},convolveMatrix:function(t){return this.put(new SVG.ConvolveMatrixEffect(t))},componentTransfer:function(t){return this.put(new SVG.ComponentTransferEffect(t))},composite:function(t,e,i){return this.put(new SVG.CompositeEffect(t,e,i))},flood:function(t,e){return this.put(new SVG.FloodEffect(t,e))},offset:function(t,e){return this.put(new SVG.OffsetEffect(t,e))},image:function(t){return this.put(new SVG.ImageEffect(t))},merge:function(){var t=[void 0];for(var e in arguments)t.push(arguments[e]);return this.put(new(SVG.MergeEffect.bind.apply(SVG.MergeEffect,t)))},gaussianBlur:function(t,e){return this.put(new SVG.GaussianBlurEffect(t,e))},morphology:function(t,e){return this.put(new SVG.MorphologyEffect(t,e))},diffuseLighting:function(t,e,i){return this.put(new SVG.DiffuseLightingEffect(t,e,i))},displacementMap:function(t,e,i,a,s){return this.put(new SVG.DisplacementMapEffect(t,e,i,a,s))},specularLighting:function(t,e,i,a){return this.put(new SVG.SpecularLightingEffect(t,e,i,a))},tile:function(){return this.put(new SVG.TileEffect)},turbulence:function(t,e,i,a,s){return this.put(new SVG.TurbulenceEffect(t,e,i,a,s))},toString:function(){return"url(#"+this.attr("id")+")"}}}),SVG.extend(SVG.Defs,{filter:function(t){var e=this.put(new SVG.Filter);return"function"==typeof t&&t.call(e,e),e}}),SVG.extend(SVG.Container,{filter:function(t){return this.defs().filter(t)}}),SVG.extend(SVG.Element,SVG.G,SVG.Nested,{filter:function(t){return this.filterer=t instanceof SVG.Element?t:this.doc().filter(t),this.doc()&&this.filterer.doc()!==this.doc()&&this.doc().defs().add(this.filterer),this.attr("filter",this.filterer),this.filterer},unfilter:function(t){return this.filterer&&!0===t&&this.filterer.remove(),delete this.filterer,this.attr("filter",null)}}),SVG.Effect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}}),SVG.ParentEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Parent,extend:{in:function(t){return null==t?this.parent()&&this.parent().select('[result="'+this.attr("in")+'"]').get(0)||this.attr("in"):this.attr("in",t)},result:function(t){return null==t?this.attr("result"):this.attr("result",t)},toString:function(){return this.result()}}});var t={blend:function(t,e){return this.parent()&&this.parent().blend(this,t,e)},colorMatrix:function(t,e){return this.parent()&&this.parent().colorMatrix(t,e).in(this)},convolveMatrix:function(t){return this.parent()&&this.parent().convolveMatrix(t).in(this)},componentTransfer:function(t){return this.parent()&&this.parent().componentTransfer(t).in(this)},composite:function(t,e){return this.parent()&&this.parent().composite(this,t,e)},flood:function(t,e){return this.parent()&&this.parent().flood(t,e)},offset:function(t,e){return this.parent()&&this.parent().offset(t,e).in(this)},image:function(t){return this.parent()&&this.parent().image(t)},merge:function(){return this.parent()&&this.parent().merge.apply(this.parent(),[this].concat(arguments))},gaussianBlur:function(t,e){return this.parent()&&this.parent().gaussianBlur(t,e).in(this)},morphology:function(t,e){return this.parent()&&this.parent().morphology(t,e).in(this)},diffuseLighting:function(t,e,i){return this.parent()&&this.parent().diffuseLighting(t,e,i).in(this)},displacementMap:function(t,e,i,a){return this.parent()&&this.parent().displacementMap(this,t,e,i,a)},specularLighting:function(t,e,i,a){return this.parent()&&this.parent().specularLighting(t,e,i,a).in(this)},tile:function(){return this.parent()&&this.parent().tile().in(this)},turbulence:function(t,e,i,a,s){return this.parent()&&this.parent().turbulence(t,e,i,a,s).in(this)}};SVG.extend(SVG.Effect,t),SVG.extend(SVG.ParentEffect,t),SVG.ChildEffect=SVG.invent({create:function(){this.constructor.call(this)},inherit:SVG.Element,extend:{in:function(t){this.attr("in",t)}}});var e={blend:function(t,e,i){this.attr({in:t,in2:e,mode:i||"normal"})},colorMatrix:function(t,e){"matrix"==t&&(e=s(e)),this.attr({type:t,values:void 0===e?null:e})},convolveMatrix:function(t){t=s(t),this.attr({order:Math.sqrt(t.split(" ").length),kernelMatrix:t})},composite:function(t,e,i){this.attr({in:t,in2:e,operator:i})},flood:function(t,e){this.attr("flood-color",t),null!=e&&this.attr("flood-opacity",e)},offset:function(t,e){this.attr({dx:t,dy:e})},image:function(t){this.attr("href",t,SVG.xlink)},displacementMap:function(t,e,i,a,s){this.attr({in:t,in2:e,scale:i,xChannelSelector:a,yChannelSelector:s})},gaussianBlur:function(t,e){null!=t||null!=e?this.attr("stdDeviation",function(t){if(!Array.isArray(t))return t;for(var e=0,i=t.length,a=[];e1&&(I*=a=Math.sqrt(a),T*=a);s=(new SVG.Matrix).rotate(M).scale(1/I,1/T).rotate(-M),F=F.transform(s),R=R.transform(s),r=[R.x-F.x,R.y-F.y],n=r[0]*r[0]+r[1]*r[1],o=Math.sqrt(n),r[0]/=o,r[1]/=o,l=n<4?Math.sqrt(1-n/4):0,X===z&&(l*=-1);h=new SVG.Point((R.x+F.x)/2+l*-r[1],(R.y+F.y)/2+l*r[0]),c=new SVG.Point(F.x-h.x,F.y-h.y),d=new SVG.Point(R.x-h.x,R.y-h.y),g=Math.acos(c.x/Math.sqrt(c.x*c.x+c.y*c.y)),c.y<0&&(g*=-1);u=Math.acos(d.x/Math.sqrt(d.x*d.x+d.y*d.y)),d.y<0&&(u*=-1);z&&g>u&&(u+=2*Math.PI);!z&&gr.maxX-e.width&&(o=(a=r.maxX-e.width)-this.startPoints.box.x),null!=r.minY&&sr.maxY-e.height&&(n=(s=r.maxY-e.height)-this.startPoints.box.y),null!=r.snapToGrid&&(a-=a%r.snapToGrid,s-=s%r.snapToGrid,o-=o%r.snapToGrid,n-=n%r.snapToGrid),this.el instanceof SVG.G?this.el.matrix(this.startPoints.transform).transform({x:o,y:n},!0):this.el.move(a,s));return i},t.prototype.end=function(t){var e=this.drag(t);this.el.fire("dragend",{event:t,p:e,m:this.m,handler:this}),SVG.off(window,"mousemove.drag"),SVG.off(window,"touchmove.drag"),SVG.off(window,"mouseup.drag"),SVG.off(window,"touchend.drag")},SVG.extend(SVG.Element,{draggable:function(e,i){"function"!=typeof e&&"object"!=typeof e||(i=e,e=!0);var a=this.remember("_draggable")||new t(this);return(e=void 0===e||e)?a.init(i||{},e):(this.off("mousedown.drag"),this.off("touchstart.drag")),this}})}.call(void 0),function(){function t(t){this.el=t,t.remember("_selectHandler",this),this.pointSelection={isSelected:!1},this.rectSelection={isSelected:!1},this.pointsList={lt:[0,0],rt:["width",0],rb:["width","height"],lb:[0,"height"],t:["width",0],r:["width","height"],b:["width","height"],l:[0,"height"]},this.pointCoord=function(t,e,i){var a="string"!=typeof t?t:e[t];return i?a/2:a},this.pointCoords=function(t,e){var i=this.pointsList[t];return{x:this.pointCoord(i[0],e,"t"===t||"b"===t),y:this.pointCoord(i[1],e,"r"===t||"l"===t)}}}t.prototype.init=function(t,e){var i=this.el.bbox();this.options={};var a=this.el.selectize.defaults.points;for(var s in this.el.selectize.defaults)this.options[s]=this.el.selectize.defaults[s],void 0!==e[s]&&(this.options[s]=e[s]);var r=["points","pointsExclude"];for(var s in r){var o=this.options[r[s]];"string"==typeof o?o=o.length>0?o.split(/\s*,\s*/i):[]:"boolean"==typeof o&&"points"===r[s]&&(o=o?a:[]),this.options[r[s]]=o}this.options.points=[a,this.options.points].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)>-1}))})),this.options.points=[this.options.points,this.options.pointsExclude].reduce((function(t,e){return t.filter((function(t){return e.indexOf(t)<0}))})),this.parent=this.el.parent(),this.nested=this.nested||this.parent.group(),this.nested.matrix(new SVG.Matrix(this.el).translate(i.x,i.y)),this.options.deepSelect&&-1!==["line","polyline","polygon"].indexOf(this.el.type)?this.selectPoints(t):this.selectRect(t),this.observe(),this.cleanup()},t.prototype.selectPoints=function(t){return this.pointSelection.isSelected=t,this.pointSelection.set||(this.pointSelection.set=this.parent.set(),this.drawPoints()),this},t.prototype.getPointArray=function(){var t=this.el.bbox();return this.el.array().valueOf().map((function(e){return[e[0]-t.x,e[1]-t.y]}))},t.prototype.drawPoints=function(){for(var t=this,e=this.getPointArray(),i=0,a=e.length;i0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y+i[1]).size(this.parameters.box.width-i[0],this.parameters.box.height-i[1])}};break;case"rt":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).size(this.parameters.box.width+i[0],this.parameters.box.height-i[1])}};break;case"rb":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x-i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize+i[0]);i=this.checkAspectRatio(i),this.el.move(this.parameters.box.x,this.parameters.box.y).size(this.parameters.box.width+i[0],this.parameters.box.height+i[1])}};break;case"lb":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0&&this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return this.el.move(this.parameters.box.x+i[0],this.parameters.box.y),void this.el.attr("font-size",this.parameters.fontSize-i[0]);i=this.checkAspectRatio(i,!0),this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).size(this.parameters.box.width-i[0],this.parameters.box.height+i[1])}};break;case"t":this.calc=function(t,e){var i=this.snapToGrid(t,e,2);if(this.parameters.box.height-i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y+i[1]).height(this.parameters.box.height-i[1])}};break;case"r":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.width+i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).width(this.parameters.box.width+i[0])}};break;case"b":this.calc=function(t,e){var i=this.snapToGrid(t,e,0);if(this.parameters.box.height+i[1]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x,this.parameters.box.y).height(this.parameters.box.height+i[1])}};break;case"l":this.calc=function(t,e){var i=this.snapToGrid(t,e,1);if(this.parameters.box.width-i[0]>0){if("text"===this.parameters.type)return;this.el.move(this.parameters.box.x+i[0],this.parameters.box.y).width(this.parameters.box.width-i[0])}};break;case"rot":this.calc=function(t,e){var i=t+this.parameters.p.x,a=e+this.parameters.p.y,s=Math.atan2(this.parameters.p.y-this.parameters.box.y-this.parameters.box.height/2,this.parameters.p.x-this.parameters.box.x-this.parameters.box.width/2),r=Math.atan2(a-this.parameters.box.y-this.parameters.box.height/2,i-this.parameters.box.x-this.parameters.box.width/2),o=this.parameters.rotation+180*(r-s)/Math.PI+this.options.snapToAngle/2;this.el.center(this.parameters.box.cx,this.parameters.box.cy).rotate(o-o%this.options.snapToAngle,this.parameters.box.cx,this.parameters.box.cy)};break;case"point":this.calc=function(t,e){var i=this.snapToGrid(t,e,this.parameters.pointCoords[0],this.parameters.pointCoords[1]),a=this.el.array().valueOf();a[this.parameters.i][0]=this.parameters.pointCoords[0]+i[0],a[this.parameters.i][1]=this.parameters.pointCoords[1]+i[1],this.el.plot(a)}}this.el.fire("resizestart",{dx:this.parameters.x,dy:this.parameters.y,event:t}),SVG.on(window,"touchmove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"touchend.resize",(function(){e.done()})),SVG.on(window,"mousemove.resize",(function(t){e.update(t||window.event)})),SVG.on(window,"mouseup.resize",(function(){e.done()}))},t.prototype.update=function(t){if(t){var e=this._extractPosition(t),i=this.transformPoint(e.x,e.y),a=i.x-this.parameters.p.x,s=i.y-this.parameters.p.y;this.lastUpdateCall=[a,s],this.calc(a,s),this.el.fire("resizing",{dx:a,dy:s,event:t})}else this.lastUpdateCall&&this.calc(this.lastUpdateCall[0],this.lastUpdateCall[1])},t.prototype.done=function(){this.lastUpdateCall=null,SVG.off(window,"mousemove.resize"),SVG.off(window,"mouseup.resize"),SVG.off(window,"touchmove.resize"),SVG.off(window,"touchend.resize"),this.el.fire("resizedone")},t.prototype.snapToGrid=function(t,e,i,a){var s;return void 0!==a?s=[(i+t)%this.options.snapToGrid,(a+e)%this.options.snapToGrid]:(i=null==i?3:i,s=[(this.parameters.box.x+t+(1&i?0:this.parameters.box.width))%this.options.snapToGrid,(this.parameters.box.y+e+(2&i?0:this.parameters.box.height))%this.options.snapToGrid]),t<0&&(s[0]-=this.options.snapToGrid),e<0&&(s[1]-=this.options.snapToGrid),t-=Math.abs(s[0])o.maxX&&(t=o.maxX-s),void 0!==o.minY&&r+eo.maxY&&(e=o.maxY-r),[t,e]},t.prototype.checkAspectRatio=function(t,e){if(!this.options.saveAspectRatio)return t;var i=t.slice(),a=this.parameters.box.width/this.parameters.box.height,s=this.parameters.box.width+t[0],r=this.parameters.box.height-t[1],o=s/r;return oa&&(i[0]=this.parameters.box.width-r*a,e&&(i[0]=-i[0])),i},SVG.extend(SVG.Element,{resize:function(e){return(this.remember("_resizeHandler")||new t(this)).init(e||{}),this}}),SVG.Element.prototype.resize.defaults={snapToAngle:.1,snapToGrid:1,constraint:{},saveAspectRatio:!1}}).call(this)}(),void 0===window.Apex&&(window.Apex={});var Ot=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"initModules",value:function(){this.ctx.publicMethods=["updateOptions","updateSeries","appendData","appendSeries","toggleSeries","showSeries","hideSeries","setLocale","resetSeries","zoomX","toggleDataPointSelection","dataURI","exportToCSV","addXaxisAnnotation","addYaxisAnnotation","addPointAnnotation","clearAnnotations","removeAnnotation","paper","destroy"],this.ctx.eventList=["click","mousedown","mousemove","mouseleave","touchstart","touchmove","touchleave","mouseup","touchend"],this.ctx.animations=new b(this.ctx),this.ctx.axes=new J(this.ctx),this.ctx.core=new Dt(this.ctx.el,this.ctx),this.ctx.config=new E({}),this.ctx.data=new W(this.ctx),this.ctx.grid=new j(this.ctx),this.ctx.graphics=new m(this.ctx),this.ctx.coreUtils=new y(this.ctx),this.ctx.crosshairs=new Q(this.ctx),this.ctx.events=new Z(this.ctx),this.ctx.exports=new G(this.ctx),this.ctx.localization=new $(this.ctx),this.ctx.options=new L,this.ctx.responsive=new K(this.ctx),this.ctx.series=new N(this.ctx),this.ctx.theme=new tt(this.ctx),this.ctx.formatters=new T(this.ctx),this.ctx.titleSubtitle=new et(this.ctx),this.ctx.legend=new lt(this.ctx),this.ctx.toolbar=new ht(this.ctx),this.ctx.tooltip=new bt(this.ctx),this.ctx.dimensions=new ot(this.ctx),this.ctx.updateHelpers=new Ht(this.ctx),this.ctx.zoomPanSelection=new ct(this.ctx),this.ctx.w.globals.tooltip=new bt(this.ctx)}}]),t}(),Nt=function(){function t(e){a(this,t),this.ctx=e,this.w=e.w}return r(t,[{key:"clear",value:function(t){var e=t.isUpdating;this.ctx.zoomPanSelection&&this.ctx.zoomPanSelection.destroy(),this.ctx.toolbar&&this.ctx.toolbar.destroy(),this.ctx.animations=null,this.ctx.axes=null,this.ctx.annotations=null,this.ctx.core=null,this.ctx.data=null,this.ctx.grid=null,this.ctx.series=null,this.ctx.responsive=null,this.ctx.theme=null,this.ctx.formatters=null,this.ctx.titleSubtitle=null,this.ctx.legend=null,this.ctx.dimensions=null,this.ctx.options=null,this.ctx.crosshairs=null,this.ctx.zoomPanSelection=null,this.ctx.updateHelpers=null,this.ctx.toolbar=null,this.ctx.localization=null,this.ctx.w.globals.tooltip=null,this.clearDomElements({isUpdating:e})}},{key:"killSVG",value:function(t){t.each((function(t,e){this.removeClass("*"),this.off(),this.stop()}),!0),t.ungroup(),t.clear()}},{key:"clearDomElements",value:function(t){var e=this,i=t.isUpdating,a=this.w.globals.dom.Paper.node;a.parentNode&&a.parentNode.parentNode&&!i&&(a.parentNode.parentNode.style.minHeight="unset");var s=this.w.globals.dom.baseEl;s&&this.ctx.eventList.forEach((function(t){s.removeEventListener(t,e.ctx.events.documentEvent)}));var r=this.w.globals.dom;if(null!==this.ctx.el)for(;this.ctx.el.firstChild;)this.ctx.el.removeChild(this.ctx.el.firstChild);this.killSVG(r.Paper),r.Paper.remove(),r.elWrap=null,r.elGraphical=null,r.elLegendWrap=null,r.elLegendForeign=null,r.baseEl=null,r.elGridRect=null,r.elGridRectMask=null,r.elGridRectMarkerMask=null,r.elForecastMask=null,r.elNonForecastMask=null,r.elDefs=null}}]),t}(),Wt=new WeakMap;var Bt=function(){function t(e,i){a(this,t),this.opts=i,this.ctx=this,this.w=new F(i).init(),this.el=e,this.w.globals.cuid=x.randomId(),this.w.globals.chartID=this.w.config.chart.id?x.escapeString(this.w.config.chart.id):this.w.globals.cuid,new Ot(this).initModules(),this.create=x.bind(this.create,this),this.windowResizeHandler=this._windowResizeHandler.bind(this),this.parentResizeHandler=this._parentResizeCallback.bind(this)}return r(t,[{key:"render",value:function(){var t=this;return new Promise((function(e,i){if(null!==t.el){void 0===Apex._chartInstances&&(Apex._chartInstances=[]),t.w.config.chart.id&&Apex._chartInstances.push({id:t.w.globals.chartID,group:t.w.config.chart.group,chart:t}),t.setLocale(t.w.config.chart.defaultLocale);var a=t.w.config.chart.events.beforeMount;if("function"==typeof a&&a(t,t.w),t.events.fireEvent("beforeMount",[t,t.w]),window.addEventListener("resize",t.windowResizeHandler),function(t,e){var i=!1;if(t.nodeType!==Node.DOCUMENT_FRAGMENT_NODE){var a=t.getBoundingClientRect();"none"!==t.style.display&&0!==a.width||(i=!0)}var s=new ResizeObserver((function(a){i&&e.call(t,a),i=!0}));t.nodeType===Node.DOCUMENT_FRAGMENT_NODE?Array.from(t.children).forEach((function(t){return s.observe(t)})):s.observe(t),Wt.set(e,s)}(t.el.parentNode,t.parentResizeHandler),!t.css){var s=t.el.getRootNode&&t.el.getRootNode(),r=x.is("ShadowRoot",s),o=t.el.ownerDocument,n=o.getElementById("apexcharts-css");!r&&n||(t.css=document.createElement("style"),t.css.id="apexcharts-css",t.css.textContent='@keyframes opaque {\n 0% {\n opacity: 0\n }\n\n to {\n opacity: 1\n }\n}\n\n@keyframes resizeanim {\n 0%,to {\n opacity: 0\n }\n}\n\n.apexcharts-canvas {\n position: relative;\n user-select: none\n}\n\n.apexcharts-canvas ::-webkit-scrollbar {\n -webkit-appearance: none;\n width: 6px\n}\n\n.apexcharts-canvas ::-webkit-scrollbar-thumb {\n border-radius: 4px;\n background-color: rgba(0,0,0,.5);\n box-shadow: 0 0 1px rgba(255,255,255,.5);\n -webkit-box-shadow: 0 0 1px rgba(255,255,255,.5)\n}\n\n.apexcharts-inner {\n position: relative\n}\n\n.apexcharts-text tspan {\n font-family: inherit\n}\n\n.legend-mouseover-inactive {\n transition: .15s ease all;\n opacity: .2\n}\n\n.apexcharts-legend-text {\n padding-left: 15px;\n margin-left: -15px;\n}\n\n.apexcharts-series-collapsed {\n opacity: 0\n}\n\n.apexcharts-tooltip {\n border-radius: 5px;\n box-shadow: 2px 2px 6px -4px #999;\n cursor: default;\n font-size: 14px;\n left: 62px;\n opacity: 0;\n pointer-events: none;\n position: absolute;\n top: 20px;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n white-space: nowrap;\n z-index: 12;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-theme-light {\n border: 1px solid #e3e3e3;\n background: rgba(255,255,255,.96)\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark {\n color: #fff;\n background: rgba(30,30,30,.8)\n}\n\n.apexcharts-tooltip * {\n font-family: inherit\n}\n\n.apexcharts-tooltip-title {\n padding: 6px;\n font-size: 15px;\n margin-bottom: 4px\n}\n\n.apexcharts-tooltip.apexcharts-theme-light .apexcharts-tooltip-title {\n background: #eceff1;\n border-bottom: 1px solid #ddd\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark .apexcharts-tooltip-title {\n background: rgba(0,0,0,.7);\n border-bottom: 1px solid #333\n}\n\n.apexcharts-tooltip-text-goals-value,.apexcharts-tooltip-text-y-value,.apexcharts-tooltip-text-z-value {\n display: inline-block;\n margin-left: 5px;\n font-weight: 600\n}\n\n.apexcharts-tooltip-text-goals-label:empty,.apexcharts-tooltip-text-goals-value:empty,.apexcharts-tooltip-text-y-label:empty,.apexcharts-tooltip-text-y-value:empty,.apexcharts-tooltip-text-z-value:empty,.apexcharts-tooltip-title:empty {\n display: none\n}\n\n.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n padding: 6px 0 5px\n}\n\n.apexcharts-tooltip-goals-group,.apexcharts-tooltip-text-goals-label,.apexcharts-tooltip-text-goals-value {\n display: flex\n}\n\n.apexcharts-tooltip-text-goals-label:not(:empty),.apexcharts-tooltip-text-goals-value:not(:empty) {\n margin-top: -6px\n}\n\n.apexcharts-tooltip-marker {\n width: 12px;\n height: 12px;\n position: relative;\n top: 0;\n margin-right: 10px;\n border-radius: 50%\n}\n\n.apexcharts-tooltip-series-group {\n padding: 0 10px;\n display: none;\n text-align: left;\n justify-content: left;\n align-items: center\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-marker {\n opacity: 1\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active,.apexcharts-tooltip-series-group:last-child {\n padding-bottom: 4px\n}\n\n.apexcharts-tooltip-series-group-hidden {\n opacity: 0;\n height: 0;\n line-height: 0;\n padding: 0!important\n}\n\n.apexcharts-tooltip-y-group {\n padding: 6px 0 5px\n}\n\n.apexcharts-custom-tooltip,.apexcharts-tooltip-box {\n padding: 4px 8px\n}\n\n.apexcharts-tooltip-boxPlot {\n display: flex;\n flex-direction: column-reverse\n}\n\n.apexcharts-tooltip-box>div {\n margin: 4px 0\n}\n\n.apexcharts-tooltip-box span.value {\n font-weight: 700\n}\n\n.apexcharts-tooltip-rangebar {\n padding: 5px 8px\n}\n\n.apexcharts-tooltip-rangebar .category {\n font-weight: 600;\n color: #777\n}\n\n.apexcharts-tooltip-rangebar .series-name {\n font-weight: 700;\n display: block;\n margin-bottom: 5px\n}\n\n.apexcharts-xaxistooltip,.apexcharts-yaxistooltip {\n opacity: 0;\n pointer-events: none;\n color: #373d3f;\n font-size: 13px;\n text-align: center;\n border-radius: 2px;\n position: absolute;\n z-index: 10;\n background: #eceff1;\n border: 1px solid #90a4ae\n}\n\n.apexcharts-xaxistooltip {\n padding: 9px 10px;\n transition: .15s ease all\n}\n\n.apexcharts-xaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-xaxistooltip:after,.apexcharts-xaxistooltip:before {\n left: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-xaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-left: -6px\n}\n\n.apexcharts-xaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-left: -7px\n}\n\n.apexcharts-xaxistooltip-bottom:after,.apexcharts-xaxistooltip-bottom:before {\n bottom: 100%\n}\n\n.apexcharts-xaxistooltip-top:after,.apexcharts-xaxistooltip-top:before {\n top: 100%\n}\n\n.apexcharts-xaxistooltip-bottom:after {\n border-bottom-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-bottom:before {\n border-bottom-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:before {\n border-bottom-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip-top:after {\n border-top-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-top:before {\n border-top-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-top.apexcharts-theme-dark:after,.apexcharts-xaxistooltip-top.apexcharts-theme-dark:before {\n border-top-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-xaxistooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-yaxistooltip {\n padding: 4px 10px\n}\n\n.apexcharts-yaxistooltip.apexcharts-theme-dark {\n background: rgba(0,0,0,.7);\n border: 1px solid rgba(0,0,0,.5);\n color: #fff\n}\n\n.apexcharts-yaxistooltip:after,.apexcharts-yaxistooltip:before {\n top: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-yaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-top: -6px\n}\n\n.apexcharts-yaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-top: -7px\n}\n\n.apexcharts-yaxistooltip-left:after,.apexcharts-yaxistooltip-left:before {\n left: 100%\n}\n\n.apexcharts-yaxistooltip-right:after,.apexcharts-yaxistooltip-right:before {\n right: 100%\n}\n\n.apexcharts-yaxistooltip-left:after {\n border-left-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-left:before {\n border-left-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-left.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-left.apexcharts-theme-dark:before {\n border-left-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip-right:after {\n border-right-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-right:before {\n border-right-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-right.apexcharts-theme-dark:after,.apexcharts-yaxistooltip-right.apexcharts-theme-dark:before {\n border-right-color: rgba(0,0,0,.5)\n}\n\n.apexcharts-yaxistooltip.apexcharts-active {\n opacity: 1\n}\n\n.apexcharts-yaxistooltip-hidden {\n display: none\n}\n\n.apexcharts-xcrosshairs,.apexcharts-ycrosshairs {\n pointer-events: none;\n opacity: 0;\n transition: .15s ease all\n}\n\n.apexcharts-xcrosshairs.apexcharts-active,.apexcharts-ycrosshairs.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-ycrosshairs-hidden {\n opacity: 0\n}\n\n.apexcharts-selection-rect {\n cursor: move\n}\n\n.svg_select_boundingRect,.svg_select_points_rot {\n pointer-events: none;\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_boundingRect,.apexcharts-selection-rect+g .svg_select_points_rot {\n opacity: 0;\n visibility: hidden\n}\n\n.apexcharts-selection-rect+g .svg_select_points_l,.apexcharts-selection-rect+g .svg_select_points_r {\n cursor: ew-resize;\n opacity: 1;\n visibility: visible\n}\n\n.svg_select_points {\n fill: #efefef;\n stroke: #333;\n rx: 2\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-zoom {\n cursor: crosshair\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-pan {\n cursor: move\n}\n\n.apexcharts-menu-icon,.apexcharts-pan-icon,.apexcharts-reset-icon,.apexcharts-selection-icon,.apexcharts-toolbar-custom-icon,.apexcharts-zoom-icon,.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n cursor: pointer;\n width: 20px;\n height: 20px;\n line-height: 24px;\n color: #6e8192;\n text-align: center\n}\n\n.apexcharts-menu-icon svg,.apexcharts-reset-icon svg,.apexcharts-zoom-icon svg,.apexcharts-zoomin-icon svg,.apexcharts-zoomout-icon svg {\n fill: #6e8192\n}\n\n.apexcharts-selection-icon svg {\n fill: #444;\n transform: scale(.76)\n}\n\n.apexcharts-theme-dark .apexcharts-menu-icon svg,.apexcharts-theme-dark .apexcharts-pan-icon svg,.apexcharts-theme-dark .apexcharts-reset-icon svg,.apexcharts-theme-dark .apexcharts-selection-icon svg,.apexcharts-theme-dark .apexcharts-toolbar-custom-icon svg,.apexcharts-theme-dark .apexcharts-zoom-icon svg,.apexcharts-theme-dark .apexcharts-zoomin-icon svg,.apexcharts-theme-dark .apexcharts-zoomout-icon svg {\n fill: #f3f4f5\n}\n\n.apexcharts-canvas .apexcharts-reset-zoom-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-selection-icon.apexcharts-selected svg,.apexcharts-canvas .apexcharts-zoom-icon.apexcharts-selected svg {\n fill: #008ffb\n}\n\n.apexcharts-theme-light .apexcharts-menu-icon:hover svg,.apexcharts-theme-light .apexcharts-reset-icon:hover svg,.apexcharts-theme-light .apexcharts-selection-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoom-icon:not(.apexcharts-selected):hover svg,.apexcharts-theme-light .apexcharts-zoomin-icon:hover svg,.apexcharts-theme-light .apexcharts-zoomout-icon:hover svg {\n fill: #333\n}\n\n.apexcharts-menu-icon,.apexcharts-selection-icon {\n position: relative\n}\n\n.apexcharts-reset-icon {\n margin-left: 5px\n}\n\n.apexcharts-menu-icon,.apexcharts-reset-icon,.apexcharts-zoom-icon {\n transform: scale(.85)\n}\n\n.apexcharts-zoomin-icon,.apexcharts-zoomout-icon {\n transform: scale(.7)\n}\n\n.apexcharts-zoomout-icon {\n margin-right: 3px\n}\n\n.apexcharts-pan-icon {\n transform: scale(.62);\n position: relative;\n left: 1px;\n top: 0\n}\n\n.apexcharts-pan-icon svg {\n fill: #fff;\n stroke: #6e8192;\n stroke-width: 2\n}\n\n.apexcharts-pan-icon.apexcharts-selected svg {\n stroke: #008ffb\n}\n\n.apexcharts-pan-icon:not(.apexcharts-selected):hover svg {\n stroke: #333\n}\n\n.apexcharts-toolbar {\n position: absolute;\n z-index: 11;\n max-width: 176px;\n text-align: right;\n border-radius: 3px;\n padding: 0 6px 2px;\n display: flex;\n justify-content: space-between;\n align-items: center\n}\n\n.apexcharts-menu {\n background: #fff;\n position: absolute;\n top: 100%;\n border: 1px solid #ddd;\n border-radius: 3px;\n padding: 3px;\n right: 10px;\n opacity: 0;\n min-width: 110px;\n transition: .15s ease all;\n pointer-events: none\n}\n\n.apexcharts-menu.apexcharts-menu-open {\n opacity: 1;\n pointer-events: all;\n transition: .15s ease all\n}\n\n.apexcharts-menu-item {\n padding: 6px 7px;\n font-size: 12px;\n cursor: pointer\n}\n\n.apexcharts-theme-light .apexcharts-menu-item:hover {\n background: #eee\n}\n\n.apexcharts-theme-dark .apexcharts-menu {\n background: rgba(0,0,0,.7);\n color: #fff\n}\n\n@media screen and (min-width:768px) {\n .apexcharts-canvas:hover .apexcharts-toolbar {\n opacity: 1\n }\n}\n\n.apexcharts-canvas .apexcharts-element-hidden,.apexcharts-datalabel.apexcharts-element-hidden,.apexcharts-hide .apexcharts-series-points {\n opacity: 0\n}\n\n.apexcharts-datalabel,.apexcharts-datalabel-label,.apexcharts-datalabel-value,.apexcharts-datalabels,.apexcharts-pie-label {\n cursor: default;\n pointer-events: none\n}\n\n.apexcharts-pie-label-delay {\n opacity: 0;\n animation-name: opaque;\n animation-duration: .3s;\n animation-fill-mode: forwards;\n animation-timing-function: ease\n}\n\n.apexcharts-annotation-rect,.apexcharts-area-series .apexcharts-area,.apexcharts-area-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-gridline,.apexcharts-line,.apexcharts-line-series .apexcharts-series-markers .apexcharts-marker.no-pointer-events,.apexcharts-point-annotation-label,.apexcharts-radar-series path,.apexcharts-radar-series polygon,.apexcharts-toolbar svg,.apexcharts-tooltip .apexcharts-marker,.apexcharts-xaxis-annotation-label,.apexcharts-yaxis-annotation-label,.apexcharts-zoom-rect {\n pointer-events: none\n}\n\n.apexcharts-marker {\n transition: .15s ease all\n}\n\n.resize-triggers {\n animation: 1ms resizeanim;\n visibility: hidden;\n opacity: 0;\n height: 100%;\n width: 100%;\n overflow: hidden\n}\n\n.contract-trigger:before,.resize-triggers,.resize-triggers>div {\n content: " ";\n display: block;\n position: absolute;\n top: 0;\n left: 0\n}\n\n.resize-triggers>div {\n height: 100%;\n width: 100%;\n background: #eee;\n overflow: auto\n}\n\n.contract-trigger:before {\n overflow: hidden;\n width: 200%;\n height: 200%\n}\n',r?s.prepend(t.css):o.head.appendChild(t.css))}var l=t.create(t.w.config.series,{});if(!l)return e(t);t.mount(l).then((function(){"function"==typeof t.w.config.chart.events.mounted&&t.w.config.chart.events.mounted(t,t.w),t.events.fireEvent("mounted",[t,t.w]),e(l)})).catch((function(t){i(t)}))}else i(new Error("Element not found"))}))}},{key:"create",value:function(t,e){var i=this.w;new Ot(this).initModules();var a=this.w.globals;(a.noData=!1,a.animationEnded=!1,this.responsive.checkResponsiveConfig(e),i.config.xaxis.convertedCatToNumeric)&&new z(i.config).convertCatToNumericXaxis(i.config,this.ctx);if(null===this.el)return a.animationEnded=!0,null;if(this.core.setupElements(),"treemap"===i.config.chart.type&&(i.config.grid.show=!1,i.config.yaxis[0].show=!1),0===a.svgWidth)return a.animationEnded=!0,null;var s=y.checkComboSeries(t);a.comboCharts=s.comboCharts,a.comboBarCount=s.comboBarCount;var r=t.every((function(t){return t.data&&0===t.data.length}));(0===t.length||r)&&this.series.handleNoData(),this.events.setupEventHandlers(),this.data.parseData(t),this.theme.init(),new D(this).setGlobalMarkerSize(),this.formatters.setLabelFormatters(),this.titleSubtitle.draw(),a.noData&&a.collapsedSeries.length!==a.series.length&&!i.config.legend.showForSingleSeries||this.legend.init(),this.series.hasAllSeriesEqualX(),a.axisCharts&&(this.core.coreCalculations(),"category"!==i.config.xaxis.type&&this.formatters.setLabelFormatters(),this.ctx.toolbar.minX=i.globals.minX,this.ctx.toolbar.maxX=i.globals.maxX),this.formatters.heatmapLabelFormatters(),new y(this).getLargestMarkerSize(),this.dimensions.plotCoords();var o=this.core.xySettings();this.grid.createGridMask();var n=this.core.plotChartType(t,o),l=new O(this);return l.bringForward(),i.config.dataLabels.background.enabled&&l.dataLabelsBackground(),this.core.shiftGraphPosition(),{elGraph:n,xyRatios:o,dimensions:{plot:{left:i.globals.translateX,top:i.globals.translateY,width:i.globals.gridWidth,height:i.globals.gridHeight}}}}},{key:"mount",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,i=this,a=i.w;return new Promise((function(s,r){if(null===i.el)return r(new Error("Not enough data to display or target element not found"));(null===e||a.globals.allSeriesCollapsed)&&i.series.handleNoData(),i.grid=new j(i);var o=i.grid.drawGrid();if(i.annotations=new P(i),i.annotations.drawImageAnnos(),i.annotations.drawTextAnnos(),"back"===a.config.grid.position&&o&&a.globals.dom.elGraphical.add(o.el),Array.isArray(e.elGraph))for(var n=0;n0&&a.globals.memory.methodsToExec.forEach((function(t){t.method(t.params,!1,t.context)})),a.globals.axisCharts||a.globals.noData||i.core.resizeNonAxisCharts(),s(i)}))}},{key:"destroy",value:function(){var t,e;window.removeEventListener("resize",this.windowResizeHandler),this.el.parentNode,t=this.parentResizeHandler,(e=Wt.get(t))&&(e.disconnect(),Wt.delete(t));var i=this.w.config.chart.id;i&&Apex._chartInstances.forEach((function(t,e){t.id===x.escapeString(i)&&Apex._chartInstances.splice(e,1)})),new Nt(this.ctx).clear({isUpdating:!1})}},{key:"updateOptions",value:function(t){var e=this,i=arguments.length>1&&void 0!==arguments[1]&&arguments[1],a=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],s=!(arguments.length>3&&void 0!==arguments[3])||arguments[3],r=!(arguments.length>4&&void 0!==arguments[4])||arguments[4],o=this.w;return o.globals.selection=void 0,t.series&&(this.series.resetSeries(!1,!0,!1),t.series.length&&t.series[0].data&&(t.series=t.series.map((function(t,i){return e.updateHelpers._extendSeries(t,i)}))),this.updateHelpers.revertDefaultAxisMinMax()),t.xaxis&&(t=this.updateHelpers.forceXAxisUpdate(t)),t.yaxis&&(t=this.updateHelpers.forceYAxisUpdate(t)),o.globals.collapsedSeriesIndices.length>0&&this.series.clearPreviousPaths(),t.theme&&(t=this.theme.updateThemeOptions(t)),this.updateHelpers._updateOptions(t,i,a,s,r)}},{key:"updateSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2];return this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(t,e,i)}},{key:"appendSeries",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],a=this.w.config.series.slice();return a.push(t),this.series.resetSeries(!1),this.updateHelpers.revertDefaultAxisMinMax(),this.updateHelpers._updateSeries(a,e,i)}},{key:"appendData",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=this;i.w.globals.dataChanged=!0,i.series.getPreviousPaths();for(var a=i.w.config.series.slice(),s=0;s0&&void 0!==arguments[0])||arguments[0],e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.series.resetSeries(t,e)}},{key:"addEventListener",value:function(t,e){this.events.addEventListener(t,e)}},{key:"removeEventListener",value:function(t,e){this.events.removeEventListener(t,e)}},{key:"addXaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addXaxisAnnotationExternal(t,e,a)}},{key:"addYaxisAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addYaxisAnnotationExternal(t,e,a)}},{key:"addPointAnnotation",value:function(t){var e=!(arguments.length>1&&void 0!==arguments[1])||arguments[1],i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,a=this;i&&(a=i),a.annotations.addPointAnnotationExternal(t,e,a)}},{key:"clearAnnotations",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:void 0,e=this;t&&(e=t),e.annotations.clearAnnotations(e)}},{key:"removeAnnotation",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:void 0,i=this;e&&(i=e),i.annotations.removeAnnotation(i,t)}},{key:"getChartArea",value:function(){return this.w.globals.dom.baseEl.querySelector(".apexcharts-inner")}},{key:"getSeriesTotalXRange",value:function(t,e){return this.coreUtils.getSeriesTotalsXRange(t,e)}},{key:"getHighestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new U(this.ctx).getMinYMaxY(t).highestY}},{key:"getLowestValueInSeries",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return new U(this.ctx).getMinYMaxY(t).lowestY}},{key:"getSeriesTotal",value:function(){return this.w.globals.seriesTotals}},{key:"toggleDataPointSelection",value:function(t,e){return this.updateHelpers.toggleDataPointSelection(t,e)}},{key:"zoomX",value:function(t,e){this.ctx.toolbar.zoomUpdateOptions(t,e)}},{key:"setLocale",value:function(t){this.localization.setCurrentLocaleValues(t)}},{key:"dataURI",value:function(t){return new G(this.ctx).dataURI(t)}},{key:"exportToCSV",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return new G(this.ctx).exportToCSV(t)}},{key:"paper",value:function(){return this.w.globals.dom.Paper}},{key:"_parentResizeCallback",value:function(){this.w.globals.animationEnded&&this.w.config.chart.redrawOnParentResize&&this._windowResize()}},{key:"_windowResize",value:function(){var t=this;clearTimeout(this.w.globals.resizeTimer),this.w.globals.resizeTimer=window.setTimeout((function(){t.w.globals.resized=!0,t.w.globals.dataChanged=!1,t.ctx.update()}),150)}},{key:"_windowResizeHandler",value:function(){var t=this.w.config.chart.redrawOnWindowResize;"function"==typeof t&&(t=t()),t&&this._windowResize()}}],[{key:"getChartByID",value:function(t){var e=x.escapeString(t),i=Apex._chartInstances.filter((function(t){return t.id===e}))[0];return i&&i.chart}},{key:"initOnLoad",value:function(){for(var e=document.querySelectorAll("[data-apexcharts]"),i=0;i2?s-2:0),o=2;o { - if (selector && window.CSS && window.CSS.escape) { - // document.querySelector needs escaping to handle IDs (html5+) containing for instance / - selector = selector.replace(/#([^\s"#']+)/g, (match, id) => `#${CSS.escape(id)}`); - } - return selector; - }; - - // Shout-out Angus Croll (https://goo.gl/pxwQGp) - const toType = object => { - if (object === null || object === undefined) { - return `${object}`; - } - return Object.prototype.toString.call(object).match(/\s([a-z]+)/i)[1].toLowerCase(); - }; - - /** - * Public Util API - */ - - const getUID = prefix => { - do { - prefix += Math.floor(Math.random() * MAX_UID); - } while (document.getElementById(prefix)); - return prefix; - }; - const getTransitionDurationFromElement = element => { - if (!element) { - return 0; - } - - // Get transition-duration of the element - let { - transitionDuration, - transitionDelay - } = window.getComputedStyle(element); - const floatTransitionDuration = Number.parseFloat(transitionDuration); - const floatTransitionDelay = Number.parseFloat(transitionDelay); - - // Return 0 if element or transition duration is not found - if (!floatTransitionDuration && !floatTransitionDelay) { - return 0; - } - - // If multiple durations are defined, take the first - transitionDuration = transitionDuration.split(',')[0]; - transitionDelay = transitionDelay.split(',')[0]; - return (Number.parseFloat(transitionDuration) + Number.parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER; - }; - const triggerTransitionEnd = element => { - element.dispatchEvent(new Event(TRANSITION_END)); - }; - const isElement$1 = object => { - if (!object || typeof object !== 'object') { - return false; - } - if (typeof object.jquery !== 'undefined') { - object = object[0]; - } - return typeof object.nodeType !== 'undefined'; - }; - const getElement = object => { - // it's a jQuery object or a node element - if (isElement$1(object)) { - return object.jquery ? object[0] : object; - } - if (typeof object === 'string' && object.length > 0) { - return document.querySelector(parseSelector(object)); - } - return null; - }; - const isVisible = element => { - if (!isElement$1(element) || element.getClientRects().length === 0) { - return false; - } - const elementIsVisible = getComputedStyle(element).getPropertyValue('visibility') === 'visible'; - // Handle `details` element as its content may falsie appear visible when it is closed - const closedDetails = element.closest('details:not([open])'); - if (!closedDetails) { - return elementIsVisible; - } - if (closedDetails !== element) { - const summary = element.closest('summary'); - if (summary && summary.parentNode !== closedDetails) { - return false; - } - if (summary === null) { - return false; - } - } - return elementIsVisible; - }; - const isDisabled = element => { - if (!element || element.nodeType !== Node.ELEMENT_NODE) { - return true; - } - if (element.classList.contains('disabled')) { - return true; - } - if (typeof element.disabled !== 'undefined') { - return element.disabled; - } - return element.hasAttribute('disabled') && element.getAttribute('disabled') !== 'false'; - }; - const findShadowRoot = element => { - if (!document.documentElement.attachShadow) { - return null; - } - - // Can find the shadow root otherwise it'll return the document - if (typeof element.getRootNode === 'function') { - const root = element.getRootNode(); - return root instanceof ShadowRoot ? root : null; - } - if (element instanceof ShadowRoot) { - return element; - } - - // when we don't find a shadow root - if (!element.parentNode) { - return null; - } - return findShadowRoot(element.parentNode); - }; - const noop = () => {}; - - /** - * Trick to restart an element's animation - * - * @param {HTMLElement} element - * @return void - * - * @see https://www.charistheo.io/blog/2021/02/restart-a-css-animation-with-javascript/#restarting-a-css-animation - */ - const reflow = element => { - element.offsetHeight; // eslint-disable-line no-unused-expressions - }; - - const getjQuery = () => { - if (window.jQuery && !document.body.hasAttribute('data-bs-no-jquery')) { - return window.jQuery; - } - return null; - }; - const DOMContentLoadedCallbacks = []; - const onDOMContentLoaded = callback => { - if (document.readyState === 'loading') { - // add listener on the first call when the document is in loading state - if (!DOMContentLoadedCallbacks.length) { - document.addEventListener('DOMContentLoaded', () => { - for (const callback of DOMContentLoadedCallbacks) { - callback(); - } - }); - } - DOMContentLoadedCallbacks.push(callback); - } else { - callback(); - } - }; - const isRTL = () => document.documentElement.dir === 'rtl'; - const defineJQueryPlugin = plugin => { - onDOMContentLoaded(() => { - const $ = getjQuery(); - /* istanbul ignore if */ - if ($) { - const name = plugin.NAME; - const JQUERY_NO_CONFLICT = $.fn[name]; - $.fn[name] = plugin.jQueryInterface; - $.fn[name].Constructor = plugin; - $.fn[name].noConflict = () => { - $.fn[name] = JQUERY_NO_CONFLICT; - return plugin.jQueryInterface; - }; - } - }); - }; - const execute = (possibleCallback, args = [], defaultValue = possibleCallback) => { - return typeof possibleCallback === 'function' ? possibleCallback(...args) : defaultValue; - }; - const executeAfterTransition = (callback, transitionElement, waitForTransition = true) => { - if (!waitForTransition) { - execute(callback); - return; - } - const durationPadding = 5; - const emulatedDuration = getTransitionDurationFromElement(transitionElement) + durationPadding; - let called = false; - const handler = ({ - target - }) => { - if (target !== transitionElement) { - return; - } - called = true; - transitionElement.removeEventListener(TRANSITION_END, handler); - execute(callback); - }; - transitionElement.addEventListener(TRANSITION_END, handler); - setTimeout(() => { - if (!called) { - triggerTransitionEnd(transitionElement); - } - }, emulatedDuration); - }; - - /** - * Return the previous/next element of a list. - * - * @param {array} list The list of elements - * @param activeElement The active element - * @param shouldGetNext Choose to get next or previous element - * @param isCycleAllowed - * @return {Element|elem} The proper element - */ - const getNextActiveElement = (list, activeElement, shouldGetNext, isCycleAllowed) => { - const listLength = list.length; - let index = list.indexOf(activeElement); - - // if the element does not exist in the list return an element - // depending on the direction and if cycle is allowed - if (index === -1) { - return !shouldGetNext && isCycleAllowed ? list[listLength - 1] : list[0]; - } - index += shouldGetNext ? 1 : -1; - if (isCycleAllowed) { - index = (index + listLength) % listLength; - } - return list[Math.max(0, Math.min(index, listLength - 1))]; - }; - - /** - * -------------------------------------------------------------------------- - * Bootstrap dom/event-handler.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const namespaceRegex = /[^.]*(?=\..*)\.|.*/; - const stripNameRegex = /\..*/; - const stripUidRegex = /::\d+$/; - const eventRegistry = {}; // Events storage - let uidEvent = 1; - const customEvents = { - mouseenter: 'mouseover', - mouseleave: 'mouseout' - }; - const nativeEvents = new Set(['click', 'dblclick', 'mouseup', 'mousedown', 'contextmenu', 'mousewheel', 'DOMMouseScroll', 'mouseover', 'mouseout', 'mousemove', 'selectstart', 'selectend', 'keydown', 'keypress', 'keyup', 'orientationchange', 'touchstart', 'touchmove', 'touchend', 'touchcancel', 'pointerdown', 'pointermove', 'pointerup', 'pointerleave', 'pointercancel', 'gesturestart', 'gesturechange', 'gestureend', 'focus', 'blur', 'change', 'reset', 'select', 'submit', 'focusin', 'focusout', 'load', 'unload', 'beforeunload', 'resize', 'move', 'DOMContentLoaded', 'readystatechange', 'error', 'abort', 'scroll']); - - /** - * Private methods - */ - - function makeEventUid(element, uid) { - return uid && `${uid}::${uidEvent++}` || element.uidEvent || uidEvent++; - } - function getElementEvents(element) { - const uid = makeEventUid(element); - element.uidEvent = uid; - eventRegistry[uid] = eventRegistry[uid] || {}; - return eventRegistry[uid]; - } - function bootstrapHandler(element, fn) { - return function handler(event) { - hydrateObj(event, { - delegateTarget: element - }); - if (handler.oneOff) { - EventHandler.off(element, event.type, fn); - } - return fn.apply(element, [event]); - }; - } - function bootstrapDelegationHandler(element, selector, fn) { - return function handler(event) { - const domElements = element.querySelectorAll(selector); - for (let { - target - } = event; target && target !== this; target = target.parentNode) { - for (const domElement of domElements) { - if (domElement !== target) { - continue; - } - hydrateObj(event, { - delegateTarget: target - }); - if (handler.oneOff) { - EventHandler.off(element, event.type, selector, fn); - } - return fn.apply(target, [event]); - } - } - }; - } - function findHandler(events, callable, delegationSelector = null) { - return Object.values(events).find(event => event.callable === callable && event.delegationSelector === delegationSelector); - } - function normalizeParameters(originalTypeEvent, handler, delegationFunction) { - const isDelegated = typeof handler === 'string'; - // TODO: tooltip passes `false` instead of selector, so we need to check - const callable = isDelegated ? delegationFunction : handler || delegationFunction; - let typeEvent = getTypeEvent(originalTypeEvent); - if (!nativeEvents.has(typeEvent)) { - typeEvent = originalTypeEvent; - } - return [isDelegated, callable, typeEvent]; - } - function addHandler(element, originalTypeEvent, handler, delegationFunction, oneOff) { - if (typeof originalTypeEvent !== 'string' || !element) { - return; - } - let [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction); - - // in case of mouseenter or mouseleave wrap the handler within a function that checks for its DOM position - // this prevents the handler from being dispatched the same way as mouseover or mouseout does - if (originalTypeEvent in customEvents) { - const wrapFunction = fn => { - return function (event) { - if (!event.relatedTarget || event.relatedTarget !== event.delegateTarget && !event.delegateTarget.contains(event.relatedTarget)) { - return fn.call(this, event); - } - }; - }; - callable = wrapFunction(callable); - } - const events = getElementEvents(element); - const handlers = events[typeEvent] || (events[typeEvent] = {}); - const previousFunction = findHandler(handlers, callable, isDelegated ? handler : null); - if (previousFunction) { - previousFunction.oneOff = previousFunction.oneOff && oneOff; - return; - } - const uid = makeEventUid(callable, originalTypeEvent.replace(namespaceRegex, '')); - const fn = isDelegated ? bootstrapDelegationHandler(element, handler, callable) : bootstrapHandler(element, callable); - fn.delegationSelector = isDelegated ? handler : null; - fn.callable = callable; - fn.oneOff = oneOff; - fn.uidEvent = uid; - handlers[uid] = fn; - element.addEventListener(typeEvent, fn, isDelegated); - } - function removeHandler(element, events, typeEvent, handler, delegationSelector) { - const fn = findHandler(events[typeEvent], handler, delegationSelector); - if (!fn) { - return; - } - element.removeEventListener(typeEvent, fn, Boolean(delegationSelector)); - delete events[typeEvent][fn.uidEvent]; - } - function removeNamespacedHandlers(element, events, typeEvent, namespace) { - const storeElementEvent = events[typeEvent] || {}; - for (const [handlerKey, event] of Object.entries(storeElementEvent)) { - if (handlerKey.includes(namespace)) { - removeHandler(element, events, typeEvent, event.callable, event.delegationSelector); - } - } - } - function getTypeEvent(event) { - // allow to get the native events from namespaced events ('click.bs.button' --> 'click') - event = event.replace(stripNameRegex, ''); - return customEvents[event] || event; - } - const EventHandler = { - on(element, event, handler, delegationFunction) { - addHandler(element, event, handler, delegationFunction, false); - }, - one(element, event, handler, delegationFunction) { - addHandler(element, event, handler, delegationFunction, true); - }, - off(element, originalTypeEvent, handler, delegationFunction) { - if (typeof originalTypeEvent !== 'string' || !element) { - return; - } - const [isDelegated, callable, typeEvent] = normalizeParameters(originalTypeEvent, handler, delegationFunction); - const inNamespace = typeEvent !== originalTypeEvent; - const events = getElementEvents(element); - const storeElementEvent = events[typeEvent] || {}; - const isNamespace = originalTypeEvent.startsWith('.'); - if (typeof callable !== 'undefined') { - // Simplest case: handler is passed, remove that listener ONLY. - if (!Object.keys(storeElementEvent).length) { - return; - } - removeHandler(element, events, typeEvent, callable, isDelegated ? handler : null); - return; - } - if (isNamespace) { - for (const elementEvent of Object.keys(events)) { - removeNamespacedHandlers(element, events, elementEvent, originalTypeEvent.slice(1)); - } - } - for (const [keyHandlers, event] of Object.entries(storeElementEvent)) { - const handlerKey = keyHandlers.replace(stripUidRegex, ''); - if (!inNamespace || originalTypeEvent.includes(handlerKey)) { - removeHandler(element, events, typeEvent, event.callable, event.delegationSelector); - } - } - }, - trigger(element, event, args) { - if (typeof event !== 'string' || !element) { - return null; - } - const $ = getjQuery(); - const typeEvent = getTypeEvent(event); - const inNamespace = event !== typeEvent; - let jQueryEvent = null; - let bubbles = true; - let nativeDispatch = true; - let defaultPrevented = false; - if (inNamespace && $) { - jQueryEvent = $.Event(event, args); - $(element).trigger(jQueryEvent); - bubbles = !jQueryEvent.isPropagationStopped(); - nativeDispatch = !jQueryEvent.isImmediatePropagationStopped(); - defaultPrevented = jQueryEvent.isDefaultPrevented(); - } - const evt = hydrateObj(new Event(event, { - bubbles, - cancelable: true - }), args); - if (defaultPrevented) { - evt.preventDefault(); - } - if (nativeDispatch) { - element.dispatchEvent(evt); - } - if (evt.defaultPrevented && jQueryEvent) { - jQueryEvent.preventDefault(); - } - return evt; - } - }; - function hydrateObj(obj, meta = {}) { - for (const [key, value] of Object.entries(meta)) { - try { - obj[key] = value; - } catch (_unused) { - Object.defineProperty(obj, key, { - configurable: true, - get() { - return value; - } - }); - } - } - return obj; - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap dom/manipulator.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - function normalizeData(value) { - if (value === 'true') { - return true; - } - if (value === 'false') { - return false; - } - if (value === Number(value).toString()) { - return Number(value); - } - if (value === '' || value === 'null') { - return null; - } - if (typeof value !== 'string') { - return value; - } - try { - return JSON.parse(decodeURIComponent(value)); - } catch (_unused) { - return value; - } - } - function normalizeDataKey(key) { - return key.replace(/[A-Z]/g, chr => `-${chr.toLowerCase()}`); - } - const Manipulator = { - setDataAttribute(element, key, value) { - element.setAttribute(`data-bs-${normalizeDataKey(key)}`, value); - }, - removeDataAttribute(element, key) { - element.removeAttribute(`data-bs-${normalizeDataKey(key)}`); - }, - getDataAttributes(element) { - if (!element) { - return {}; - } - const attributes = {}; - const bsKeys = Object.keys(element.dataset).filter(key => key.startsWith('bs') && !key.startsWith('bsConfig')); - for (const key of bsKeys) { - let pureKey = key.replace(/^bs/, ''); - pureKey = pureKey.charAt(0).toLowerCase() + pureKey.slice(1, pureKey.length); - attributes[pureKey] = normalizeData(element.dataset[key]); - } - return attributes; - }, - getDataAttribute(element, key) { - return normalizeData(element.getAttribute(`data-bs-${normalizeDataKey(key)}`)); - } - }; - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/config.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Class definition - */ - - class Config { - // Getters - static get Default() { - return {}; - } - static get DefaultType() { - return {}; - } - static get NAME() { - throw new Error('You have to implement the static method "NAME", for each component!'); - } - _getConfig(config) { - config = this._mergeConfigObj(config); - config = this._configAfterMerge(config); - this._typeCheckConfig(config); - return config; - } - _configAfterMerge(config) { - return config; - } - _mergeConfigObj(config, element) { - const jsonConfig = isElement$1(element) ? Manipulator.getDataAttribute(element, 'config') : {}; // try to parse - - return { - ...this.constructor.Default, - ...(typeof jsonConfig === 'object' ? jsonConfig : {}), - ...(isElement$1(element) ? Manipulator.getDataAttributes(element) : {}), - ...(typeof config === 'object' ? config : {}) - }; - } - _typeCheckConfig(config, configTypes = this.constructor.DefaultType) { - for (const [property, expectedTypes] of Object.entries(configTypes)) { - const value = config[property]; - const valueType = isElement$1(value) ? 'element' : toType(value); - if (!new RegExp(expectedTypes).test(valueType)) { - throw new TypeError(`${this.constructor.NAME.toUpperCase()}: Option "${property}" provided type "${valueType}" but expected type "${expectedTypes}".`); - } - } - } - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap base-component.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const VERSION = '5.3.1'; - - /** - * Class definition - */ - - class BaseComponent extends Config { - constructor(element, config) { - super(); - element = getElement(element); - if (!element) { - return; - } - this._element = element; - this._config = this._getConfig(config); - Data.set(this._element, this.constructor.DATA_KEY, this); - } - - // Public - dispose() { - Data.remove(this._element, this.constructor.DATA_KEY); - EventHandler.off(this._element, this.constructor.EVENT_KEY); - for (const propertyName of Object.getOwnPropertyNames(this)) { - this[propertyName] = null; - } - } - _queueCallback(callback, element, isAnimated = true) { - executeAfterTransition(callback, element, isAnimated); - } - _getConfig(config) { - config = this._mergeConfigObj(config, this._element); - config = this._configAfterMerge(config); - this._typeCheckConfig(config); - return config; - } - - // Static - static getInstance(element) { - return Data.get(getElement(element), this.DATA_KEY); - } - static getOrCreateInstance(element, config = {}) { - return this.getInstance(element) || new this(element, typeof config === 'object' ? config : null); - } - static get VERSION() { - return VERSION; - } - static get DATA_KEY() { - return `bs.${this.NAME}`; - } - static get EVENT_KEY() { - return `.${this.DATA_KEY}`; - } - static eventName(name) { - return `${name}${this.EVENT_KEY}`; - } - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap dom/selector-engine.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - const getSelector = element => { - let selector = element.getAttribute('data-bs-target'); - if (!selector || selector === '#') { - let hrefAttribute = element.getAttribute('href'); - - // The only valid content that could double as a selector are IDs or classes, - // so everything starting with `#` or `.`. If a "real" URL is used as the selector, - // `document.querySelector` will rightfully complain it is invalid. - // See https://github.com/twbs/bootstrap/issues/32273 - if (!hrefAttribute || !hrefAttribute.includes('#') && !hrefAttribute.startsWith('.')) { - return null; - } - - // Just in case some CMS puts out a full URL with the anchor appended - if (hrefAttribute.includes('#') && !hrefAttribute.startsWith('#')) { - hrefAttribute = `#${hrefAttribute.split('#')[1]}`; - } - selector = hrefAttribute && hrefAttribute !== '#' ? hrefAttribute.trim() : null; - } - return parseSelector(selector); - }; - const SelectorEngine = { - find(selector, element = document.documentElement) { - return [].concat(...Element.prototype.querySelectorAll.call(element, selector)); - }, - findOne(selector, element = document.documentElement) { - return Element.prototype.querySelector.call(element, selector); - }, - children(element, selector) { - return [].concat(...element.children).filter(child => child.matches(selector)); - }, - parents(element, selector) { - const parents = []; - let ancestor = element.parentNode.closest(selector); - while (ancestor) { - parents.push(ancestor); - ancestor = ancestor.parentNode.closest(selector); - } - return parents; - }, - prev(element, selector) { - let previous = element.previousElementSibling; - while (previous) { - if (previous.matches(selector)) { - return [previous]; - } - previous = previous.previousElementSibling; - } - return []; - }, - // TODO: this is now unused; remove later along with prev() - next(element, selector) { - let next = element.nextElementSibling; - while (next) { - if (next.matches(selector)) { - return [next]; - } - next = next.nextElementSibling; - } - return []; - }, - focusableChildren(element) { - const focusables = ['a', 'button', 'input', 'textarea', 'select', 'details', '[tabindex]', '[contenteditable="true"]'].map(selector => `${selector}:not([tabindex^="-"])`).join(','); - return this.find(focusables, element).filter(el => !isDisabled(el) && isVisible(el)); - }, - getSelectorFromElement(element) { - const selector = getSelector(element); - if (selector) { - return SelectorEngine.findOne(selector) ? selector : null; - } - return null; - }, - getElementFromSelector(element) { - const selector = getSelector(element); - return selector ? SelectorEngine.findOne(selector) : null; - }, - getMultipleElementsFromSelector(element) { - const selector = getSelector(element); - return selector ? SelectorEngine.find(selector) : []; - } - }; - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/component-functions.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - const enableDismissTrigger = (component, method = 'hide') => { - const clickEvent = `click.dismiss${component.EVENT_KEY}`; - const name = component.NAME; - EventHandler.on(document, clickEvent, `[data-bs-dismiss="${name}"]`, function (event) { - if (['A', 'AREA'].includes(this.tagName)) { - event.preventDefault(); - } - if (isDisabled(this)) { - return; - } - const target = SelectorEngine.getElementFromSelector(this) || this.closest(`.${name}`); - const instance = component.getOrCreateInstance(target); - - // Method argument is left, for Alert and only, as it doesn't implement the 'hide' method - instance[method](); - }); - }; - - /** - * -------------------------------------------------------------------------- - * Bootstrap alert.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$f = 'alert'; - const DATA_KEY$a = 'bs.alert'; - const EVENT_KEY$b = `.${DATA_KEY$a}`; - const EVENT_CLOSE = `close${EVENT_KEY$b}`; - const EVENT_CLOSED = `closed${EVENT_KEY$b}`; - const CLASS_NAME_FADE$5 = 'fade'; - const CLASS_NAME_SHOW$8 = 'show'; - - /** - * Class definition - */ - - class Alert extends BaseComponent { - // Getters - static get NAME() { - return NAME$f; - } - - // Public - close() { - const closeEvent = EventHandler.trigger(this._element, EVENT_CLOSE); - if (closeEvent.defaultPrevented) { - return; - } - this._element.classList.remove(CLASS_NAME_SHOW$8); - const isAnimated = this._element.classList.contains(CLASS_NAME_FADE$5); - this._queueCallback(() => this._destroyElement(), this._element, isAnimated); - } - - // Private - _destroyElement() { - this._element.remove(); - EventHandler.trigger(this._element, EVENT_CLOSED); - this.dispose(); - } - - // Static - static jQueryInterface(config) { - return this.each(function () { - const data = Alert.getOrCreateInstance(this); - if (typeof config !== 'string') { - return; - } - if (data[config] === undefined || config.startsWith('_') || config === 'constructor') { - throw new TypeError(`No method named "${config}"`); - } - data[config](this); - }); - } - } - - /** - * Data API implementation - */ - - enableDismissTrigger(Alert, 'close'); - - /** - * jQuery - */ - - defineJQueryPlugin(Alert); - - /** - * -------------------------------------------------------------------------- - * Bootstrap button.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$e = 'button'; - const DATA_KEY$9 = 'bs.button'; - const EVENT_KEY$a = `.${DATA_KEY$9}`; - const DATA_API_KEY$6 = '.data-api'; - const CLASS_NAME_ACTIVE$3 = 'active'; - const SELECTOR_DATA_TOGGLE$5 = '[data-bs-toggle="button"]'; - const EVENT_CLICK_DATA_API$6 = `click${EVENT_KEY$a}${DATA_API_KEY$6}`; - - /** - * Class definition - */ - - class Button extends BaseComponent { - // Getters - static get NAME() { - return NAME$e; - } - - // Public - toggle() { - // Toggle class and sync the `aria-pressed` attribute with the return value of the `.toggle()` method - this._element.setAttribute('aria-pressed', this._element.classList.toggle(CLASS_NAME_ACTIVE$3)); - } - - // Static - static jQueryInterface(config) { - return this.each(function () { - const data = Button.getOrCreateInstance(this); - if (config === 'toggle') { - data[config](); - } - }); - } - } - - /** - * Data API implementation - */ - - EventHandler.on(document, EVENT_CLICK_DATA_API$6, SELECTOR_DATA_TOGGLE$5, event => { - event.preventDefault(); - const button = event.target.closest(SELECTOR_DATA_TOGGLE$5); - const data = Button.getOrCreateInstance(button); - data.toggle(); - }); - - /** - * jQuery - */ - - defineJQueryPlugin(Button); - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/swipe.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$d = 'swipe'; - const EVENT_KEY$9 = '.bs.swipe'; - const EVENT_TOUCHSTART = `touchstart${EVENT_KEY$9}`; - const EVENT_TOUCHMOVE = `touchmove${EVENT_KEY$9}`; - const EVENT_TOUCHEND = `touchend${EVENT_KEY$9}`; - const EVENT_POINTERDOWN = `pointerdown${EVENT_KEY$9}`; - const EVENT_POINTERUP = `pointerup${EVENT_KEY$9}`; - const POINTER_TYPE_TOUCH = 'touch'; - const POINTER_TYPE_PEN = 'pen'; - const CLASS_NAME_POINTER_EVENT = 'pointer-event'; - const SWIPE_THRESHOLD = 40; - const Default$c = { - endCallback: null, - leftCallback: null, - rightCallback: null - }; - const DefaultType$c = { - endCallback: '(function|null)', - leftCallback: '(function|null)', - rightCallback: '(function|null)' - }; - - /** - * Class definition - */ - - class Swipe extends Config { - constructor(element, config) { - super(); - this._element = element; - if (!element || !Swipe.isSupported()) { - return; - } - this._config = this._getConfig(config); - this._deltaX = 0; - this._supportPointerEvents = Boolean(window.PointerEvent); - this._initEvents(); - } - - // Getters - static get Default() { - return Default$c; - } - static get DefaultType() { - return DefaultType$c; - } - static get NAME() { - return NAME$d; - } - - // Public - dispose() { - EventHandler.off(this._element, EVENT_KEY$9); - } - - // Private - _start(event) { - if (!this._supportPointerEvents) { - this._deltaX = event.touches[0].clientX; - return; - } - if (this._eventIsPointerPenTouch(event)) { - this._deltaX = event.clientX; - } - } - _end(event) { - if (this._eventIsPointerPenTouch(event)) { - this._deltaX = event.clientX - this._deltaX; - } - this._handleSwipe(); - execute(this._config.endCallback); - } - _move(event) { - this._deltaX = event.touches && event.touches.length > 1 ? 0 : event.touches[0].clientX - this._deltaX; - } - _handleSwipe() { - const absDeltaX = Math.abs(this._deltaX); - if (absDeltaX <= SWIPE_THRESHOLD) { - return; - } - const direction = absDeltaX / this._deltaX; - this._deltaX = 0; - if (!direction) { - return; - } - execute(direction > 0 ? this._config.rightCallback : this._config.leftCallback); - } - _initEvents() { - if (this._supportPointerEvents) { - EventHandler.on(this._element, EVENT_POINTERDOWN, event => this._start(event)); - EventHandler.on(this._element, EVENT_POINTERUP, event => this._end(event)); - this._element.classList.add(CLASS_NAME_POINTER_EVENT); - } else { - EventHandler.on(this._element, EVENT_TOUCHSTART, event => this._start(event)); - EventHandler.on(this._element, EVENT_TOUCHMOVE, event => this._move(event)); - EventHandler.on(this._element, EVENT_TOUCHEND, event => this._end(event)); - } - } - _eventIsPointerPenTouch(event) { - return this._supportPointerEvents && (event.pointerType === POINTER_TYPE_PEN || event.pointerType === POINTER_TYPE_TOUCH); - } - - // Static - static isSupported() { - return 'ontouchstart' in document.documentElement || navigator.maxTouchPoints > 0; - } - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap carousel.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$c = 'carousel'; - const DATA_KEY$8 = 'bs.carousel'; - const EVENT_KEY$8 = `.${DATA_KEY$8}`; - const DATA_API_KEY$5 = '.data-api'; - const ARROW_LEFT_KEY$1 = 'ArrowLeft'; - const ARROW_RIGHT_KEY$1 = 'ArrowRight'; - const TOUCHEVENT_COMPAT_WAIT = 500; // Time for mouse compat events to fire after touch - - const ORDER_NEXT = 'next'; - const ORDER_PREV = 'prev'; - const DIRECTION_LEFT = 'left'; - const DIRECTION_RIGHT = 'right'; - const EVENT_SLIDE = `slide${EVENT_KEY$8}`; - const EVENT_SLID = `slid${EVENT_KEY$8}`; - const EVENT_KEYDOWN$1 = `keydown${EVENT_KEY$8}`; - const EVENT_MOUSEENTER$1 = `mouseenter${EVENT_KEY$8}`; - const EVENT_MOUSELEAVE$1 = `mouseleave${EVENT_KEY$8}`; - const EVENT_DRAG_START = `dragstart${EVENT_KEY$8}`; - const EVENT_LOAD_DATA_API$3 = `load${EVENT_KEY$8}${DATA_API_KEY$5}`; - const EVENT_CLICK_DATA_API$5 = `click${EVENT_KEY$8}${DATA_API_KEY$5}`; - const CLASS_NAME_CAROUSEL = 'carousel'; - const CLASS_NAME_ACTIVE$2 = 'active'; - const CLASS_NAME_SLIDE = 'slide'; - const CLASS_NAME_END = 'carousel-item-end'; - const CLASS_NAME_START = 'carousel-item-start'; - const CLASS_NAME_NEXT = 'carousel-item-next'; - const CLASS_NAME_PREV = 'carousel-item-prev'; - const SELECTOR_ACTIVE = '.active'; - const SELECTOR_ITEM = '.carousel-item'; - const SELECTOR_ACTIVE_ITEM = SELECTOR_ACTIVE + SELECTOR_ITEM; - const SELECTOR_ITEM_IMG = '.carousel-item img'; - const SELECTOR_INDICATORS = '.carousel-indicators'; - const SELECTOR_DATA_SLIDE = '[data-bs-slide], [data-bs-slide-to]'; - const SELECTOR_DATA_RIDE = '[data-bs-ride="carousel"]'; - const KEY_TO_DIRECTION = { - [ARROW_LEFT_KEY$1]: DIRECTION_RIGHT, - [ARROW_RIGHT_KEY$1]: DIRECTION_LEFT - }; - const Default$b = { - interval: 5000, - keyboard: true, - pause: 'hover', - ride: false, - touch: true, - wrap: true - }; - const DefaultType$b = { - interval: '(number|boolean)', - // TODO:v6 remove boolean support - keyboard: 'boolean', - pause: '(string|boolean)', - ride: '(boolean|string)', - touch: 'boolean', - wrap: 'boolean' - }; - - /** - * Class definition - */ - - class Carousel extends BaseComponent { - constructor(element, config) { - super(element, config); - this._interval = null; - this._activeElement = null; - this._isSliding = false; - this.touchTimeout = null; - this._swipeHelper = null; - this._indicatorsElement = SelectorEngine.findOne(SELECTOR_INDICATORS, this._element); - this._addEventListeners(); - if (this._config.ride === CLASS_NAME_CAROUSEL) { - this.cycle(); - } - } - - // Getters - static get Default() { - return Default$b; - } - static get DefaultType() { - return DefaultType$b; - } - static get NAME() { - return NAME$c; - } - - // Public - next() { - this._slide(ORDER_NEXT); - } - nextWhenVisible() { - // FIXME TODO use `document.visibilityState` - // Don't call next when the page isn't visible - // or the carousel or its parent isn't visible - if (!document.hidden && isVisible(this._element)) { - this.next(); - } - } - prev() { - this._slide(ORDER_PREV); - } - pause() { - if (this._isSliding) { - triggerTransitionEnd(this._element); - } - this._clearInterval(); - } - cycle() { - this._clearInterval(); - this._updateInterval(); - this._interval = setInterval(() => this.nextWhenVisible(), this._config.interval); - } - _maybeEnableCycle() { - if (!this._config.ride) { - return; - } - if (this._isSliding) { - EventHandler.one(this._element, EVENT_SLID, () => this.cycle()); - return; - } - this.cycle(); - } - to(index) { - const items = this._getItems(); - if (index > items.length - 1 || index < 0) { - return; - } - if (this._isSliding) { - EventHandler.one(this._element, EVENT_SLID, () => this.to(index)); - return; - } - const activeIndex = this._getItemIndex(this._getActive()); - if (activeIndex === index) { - return; - } - const order = index > activeIndex ? ORDER_NEXT : ORDER_PREV; - this._slide(order, items[index]); - } - dispose() { - if (this._swipeHelper) { - this._swipeHelper.dispose(); - } - super.dispose(); - } - - // Private - _configAfterMerge(config) { - config.defaultInterval = config.interval; - return config; - } - _addEventListeners() { - if (this._config.keyboard) { - EventHandler.on(this._element, EVENT_KEYDOWN$1, event => this._keydown(event)); - } - if (this._config.pause === 'hover') { - EventHandler.on(this._element, EVENT_MOUSEENTER$1, () => this.pause()); - EventHandler.on(this._element, EVENT_MOUSELEAVE$1, () => this._maybeEnableCycle()); - } - if (this._config.touch && Swipe.isSupported()) { - this._addTouchEventListeners(); - } - } - _addTouchEventListeners() { - for (const img of SelectorEngine.find(SELECTOR_ITEM_IMG, this._element)) { - EventHandler.on(img, EVENT_DRAG_START, event => event.preventDefault()); - } - const endCallBack = () => { - if (this._config.pause !== 'hover') { - return; - } - - // If it's a touch-enabled device, mouseenter/leave are fired as - // part of the mouse compatibility events on first tap - the carousel - // would stop cycling until user tapped out of it; - // here, we listen for touchend, explicitly pause the carousel - // (as if it's the second time we tap on it, mouseenter compat event - // is NOT fired) and after a timeout (to allow for mouse compatibility - // events to fire) we explicitly restart cycling - - this.pause(); - if (this.touchTimeout) { - clearTimeout(this.touchTimeout); - } - this.touchTimeout = setTimeout(() => this._maybeEnableCycle(), TOUCHEVENT_COMPAT_WAIT + this._config.interval); - }; - const swipeConfig = { - leftCallback: () => this._slide(this._directionToOrder(DIRECTION_LEFT)), - rightCallback: () => this._slide(this._directionToOrder(DIRECTION_RIGHT)), - endCallback: endCallBack - }; - this._swipeHelper = new Swipe(this._element, swipeConfig); - } - _keydown(event) { - if (/input|textarea/i.test(event.target.tagName)) { - return; - } - const direction = KEY_TO_DIRECTION[event.key]; - if (direction) { - event.preventDefault(); - this._slide(this._directionToOrder(direction)); - } - } - _getItemIndex(element) { - return this._getItems().indexOf(element); - } - _setActiveIndicatorElement(index) { - if (!this._indicatorsElement) { - return; - } - const activeIndicator = SelectorEngine.findOne(SELECTOR_ACTIVE, this._indicatorsElement); - activeIndicator.classList.remove(CLASS_NAME_ACTIVE$2); - activeIndicator.removeAttribute('aria-current'); - const newActiveIndicator = SelectorEngine.findOne(`[data-bs-slide-to="${index}"]`, this._indicatorsElement); - if (newActiveIndicator) { - newActiveIndicator.classList.add(CLASS_NAME_ACTIVE$2); - newActiveIndicator.setAttribute('aria-current', 'true'); - } - } - _updateInterval() { - const element = this._activeElement || this._getActive(); - if (!element) { - return; - } - const elementInterval = Number.parseInt(element.getAttribute('data-bs-interval'), 10); - this._config.interval = elementInterval || this._config.defaultInterval; - } - _slide(order, element = null) { - if (this._isSliding) { - return; - } - const activeElement = this._getActive(); - const isNext = order === ORDER_NEXT; - const nextElement = element || getNextActiveElement(this._getItems(), activeElement, isNext, this._config.wrap); - if (nextElement === activeElement) { - return; - } - const nextElementIndex = this._getItemIndex(nextElement); - const triggerEvent = eventName => { - return EventHandler.trigger(this._element, eventName, { - relatedTarget: nextElement, - direction: this._orderToDirection(order), - from: this._getItemIndex(activeElement), - to: nextElementIndex - }); - }; - const slideEvent = triggerEvent(EVENT_SLIDE); - if (slideEvent.defaultPrevented) { - return; - } - if (!activeElement || !nextElement) { - // Some weirdness is happening, so we bail - // TODO: change tests that use empty divs to avoid this check - return; - } - const isCycling = Boolean(this._interval); - this.pause(); - this._isSliding = true; - this._setActiveIndicatorElement(nextElementIndex); - this._activeElement = nextElement; - const directionalClassName = isNext ? CLASS_NAME_START : CLASS_NAME_END; - const orderClassName = isNext ? CLASS_NAME_NEXT : CLASS_NAME_PREV; - nextElement.classList.add(orderClassName); - reflow(nextElement); - activeElement.classList.add(directionalClassName); - nextElement.classList.add(directionalClassName); - const completeCallBack = () => { - nextElement.classList.remove(directionalClassName, orderClassName); - nextElement.classList.add(CLASS_NAME_ACTIVE$2); - activeElement.classList.remove(CLASS_NAME_ACTIVE$2, orderClassName, directionalClassName); - this._isSliding = false; - triggerEvent(EVENT_SLID); - }; - this._queueCallback(completeCallBack, activeElement, this._isAnimated()); - if (isCycling) { - this.cycle(); - } - } - _isAnimated() { - return this._element.classList.contains(CLASS_NAME_SLIDE); - } - _getActive() { - return SelectorEngine.findOne(SELECTOR_ACTIVE_ITEM, this._element); - } - _getItems() { - return SelectorEngine.find(SELECTOR_ITEM, this._element); - } - _clearInterval() { - if (this._interval) { - clearInterval(this._interval); - this._interval = null; - } - } - _directionToOrder(direction) { - if (isRTL()) { - return direction === DIRECTION_LEFT ? ORDER_PREV : ORDER_NEXT; - } - return direction === DIRECTION_LEFT ? ORDER_NEXT : ORDER_PREV; - } - _orderToDirection(order) { - if (isRTL()) { - return order === ORDER_PREV ? DIRECTION_LEFT : DIRECTION_RIGHT; - } - return order === ORDER_PREV ? DIRECTION_RIGHT : DIRECTION_LEFT; - } - - // Static - static jQueryInterface(config) { - return this.each(function () { - const data = Carousel.getOrCreateInstance(this, config); - if (typeof config === 'number') { - data.to(config); - return; - } - if (typeof config === 'string') { - if (data[config] === undefined || config.startsWith('_') || config === 'constructor') { - throw new TypeError(`No method named "${config}"`); - } - data[config](); - } - }); - } - } - - /** - * Data API implementation - */ - - EventHandler.on(document, EVENT_CLICK_DATA_API$5, SELECTOR_DATA_SLIDE, function (event) { - const target = SelectorEngine.getElementFromSelector(this); - if (!target || !target.classList.contains(CLASS_NAME_CAROUSEL)) { - return; - } - event.preventDefault(); - const carousel = Carousel.getOrCreateInstance(target); - const slideIndex = this.getAttribute('data-bs-slide-to'); - if (slideIndex) { - carousel.to(slideIndex); - carousel._maybeEnableCycle(); - return; - } - if (Manipulator.getDataAttribute(this, 'slide') === 'next') { - carousel.next(); - carousel._maybeEnableCycle(); - return; - } - carousel.prev(); - carousel._maybeEnableCycle(); - }); - EventHandler.on(window, EVENT_LOAD_DATA_API$3, () => { - const carousels = SelectorEngine.find(SELECTOR_DATA_RIDE); - for (const carousel of carousels) { - Carousel.getOrCreateInstance(carousel); - } - }); - - /** - * jQuery - */ - - defineJQueryPlugin(Carousel); - - /** - * -------------------------------------------------------------------------- - * Bootstrap collapse.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$b = 'collapse'; - const DATA_KEY$7 = 'bs.collapse'; - const EVENT_KEY$7 = `.${DATA_KEY$7}`; - const DATA_API_KEY$4 = '.data-api'; - const EVENT_SHOW$6 = `show${EVENT_KEY$7}`; - const EVENT_SHOWN$6 = `shown${EVENT_KEY$7}`; - const EVENT_HIDE$6 = `hide${EVENT_KEY$7}`; - const EVENT_HIDDEN$6 = `hidden${EVENT_KEY$7}`; - const EVENT_CLICK_DATA_API$4 = `click${EVENT_KEY$7}${DATA_API_KEY$4}`; - const CLASS_NAME_SHOW$7 = 'show'; - const CLASS_NAME_COLLAPSE = 'collapse'; - const CLASS_NAME_COLLAPSING = 'collapsing'; - const CLASS_NAME_COLLAPSED = 'collapsed'; - const CLASS_NAME_DEEPER_CHILDREN = `:scope .${CLASS_NAME_COLLAPSE} .${CLASS_NAME_COLLAPSE}`; - const CLASS_NAME_HORIZONTAL = 'collapse-horizontal'; - const WIDTH = 'width'; - const HEIGHT = 'height'; - const SELECTOR_ACTIVES = '.collapse.show, .collapse.collapsing'; - const SELECTOR_DATA_TOGGLE$4 = '[data-bs-toggle="collapse"]'; - const Default$a = { - parent: null, - toggle: true - }; - const DefaultType$a = { - parent: '(null|element)', - toggle: 'boolean' - }; - - /** - * Class definition - */ - - class Collapse extends BaseComponent { - constructor(element, config) { - super(element, config); - this._isTransitioning = false; - this._triggerArray = []; - const toggleList = SelectorEngine.find(SELECTOR_DATA_TOGGLE$4); - for (const elem of toggleList) { - const selector = SelectorEngine.getSelectorFromElement(elem); - const filterElement = SelectorEngine.find(selector).filter(foundElement => foundElement === this._element); - if (selector !== null && filterElement.length) { - this._triggerArray.push(elem); - } - } - this._initializeChildren(); - if (!this._config.parent) { - this._addAriaAndCollapsedClass(this._triggerArray, this._isShown()); - } - if (this._config.toggle) { - this.toggle(); - } - } - - // Getters - static get Default() { - return Default$a; - } - static get DefaultType() { - return DefaultType$a; - } - static get NAME() { - return NAME$b; - } - - // Public - toggle() { - if (this._isShown()) { - this.hide(); - } else { - this.show(); - } - } - show() { - if (this._isTransitioning || this._isShown()) { - return; - } - let activeChildren = []; - - // find active children - if (this._config.parent) { - activeChildren = this._getFirstLevelChildren(SELECTOR_ACTIVES).filter(element => element !== this._element).map(element => Collapse.getOrCreateInstance(element, { - toggle: false - })); - } - if (activeChildren.length && activeChildren[0]._isTransitioning) { - return; - } - const startEvent = EventHandler.trigger(this._element, EVENT_SHOW$6); - if (startEvent.defaultPrevented) { - return; - } - for (const activeInstance of activeChildren) { - activeInstance.hide(); - } - const dimension = this._getDimension(); - this._element.classList.remove(CLASS_NAME_COLLAPSE); - this._element.classList.add(CLASS_NAME_COLLAPSING); - this._element.style[dimension] = 0; - this._addAriaAndCollapsedClass(this._triggerArray, true); - this._isTransitioning = true; - const complete = () => { - this._isTransitioning = false; - this._element.classList.remove(CLASS_NAME_COLLAPSING); - this._element.classList.add(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW$7); - this._element.style[dimension] = ''; - EventHandler.trigger(this._element, EVENT_SHOWN$6); - }; - const capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1); - const scrollSize = `scroll${capitalizedDimension}`; - this._queueCallback(complete, this._element, true); - this._element.style[dimension] = `${this._element[scrollSize]}px`; - } - hide() { - if (this._isTransitioning || !this._isShown()) { - return; - } - const startEvent = EventHandler.trigger(this._element, EVENT_HIDE$6); - if (startEvent.defaultPrevented) { - return; - } - const dimension = this._getDimension(); - this._element.style[dimension] = `${this._element.getBoundingClientRect()[dimension]}px`; - reflow(this._element); - this._element.classList.add(CLASS_NAME_COLLAPSING); - this._element.classList.remove(CLASS_NAME_COLLAPSE, CLASS_NAME_SHOW$7); - for (const trigger of this._triggerArray) { - const element = SelectorEngine.getElementFromSelector(trigger); - if (element && !this._isShown(element)) { - this._addAriaAndCollapsedClass([trigger], false); - } - } - this._isTransitioning = true; - const complete = () => { - this._isTransitioning = false; - this._element.classList.remove(CLASS_NAME_COLLAPSING); - this._element.classList.add(CLASS_NAME_COLLAPSE); - EventHandler.trigger(this._element, EVENT_HIDDEN$6); - }; - this._element.style[dimension] = ''; - this._queueCallback(complete, this._element, true); - } - _isShown(element = this._element) { - return element.classList.contains(CLASS_NAME_SHOW$7); - } - - // Private - _configAfterMerge(config) { - config.toggle = Boolean(config.toggle); // Coerce string values - config.parent = getElement(config.parent); - return config; - } - _getDimension() { - return this._element.classList.contains(CLASS_NAME_HORIZONTAL) ? WIDTH : HEIGHT; - } - _initializeChildren() { - if (!this._config.parent) { - return; - } - const children = this._getFirstLevelChildren(SELECTOR_DATA_TOGGLE$4); - for (const element of children) { - const selected = SelectorEngine.getElementFromSelector(element); - if (selected) { - this._addAriaAndCollapsedClass([element], this._isShown(selected)); - } - } - } - _getFirstLevelChildren(selector) { - const children = SelectorEngine.find(CLASS_NAME_DEEPER_CHILDREN, this._config.parent); - // remove children if greater depth - return SelectorEngine.find(selector, this._config.parent).filter(element => !children.includes(element)); - } - _addAriaAndCollapsedClass(triggerArray, isOpen) { - if (!triggerArray.length) { - return; - } - for (const element of triggerArray) { - element.classList.toggle(CLASS_NAME_COLLAPSED, !isOpen); - element.setAttribute('aria-expanded', isOpen); - } - } - - // Static - static jQueryInterface(config) { - const _config = {}; - if (typeof config === 'string' && /show|hide/.test(config)) { - _config.toggle = false; - } - return this.each(function () { - const data = Collapse.getOrCreateInstance(this, _config); - if (typeof config === 'string') { - if (typeof data[config] === 'undefined') { - throw new TypeError(`No method named "${config}"`); - } - data[config](); - } - }); - } - } - - /** - * Data API implementation - */ - - EventHandler.on(document, EVENT_CLICK_DATA_API$4, SELECTOR_DATA_TOGGLE$4, function (event) { - // preventDefault only for elements (which change the URL) not inside the collapsible element - if (event.target.tagName === 'A' || event.delegateTarget && event.delegateTarget.tagName === 'A') { - event.preventDefault(); - } - for (const element of SelectorEngine.getMultipleElementsFromSelector(this)) { - Collapse.getOrCreateInstance(element, { - toggle: false - }).toggle(); - } - }); - - /** - * jQuery - */ - - defineJQueryPlugin(Collapse); - - var top = 'top'; - var bottom = 'bottom'; - var right = 'right'; - var left = 'left'; - var auto = 'auto'; - var basePlacements = [top, bottom, right, left]; - var start = 'start'; - var end = 'end'; - var clippingParents = 'clippingParents'; - var viewport = 'viewport'; - var popper = 'popper'; - var reference = 'reference'; - var variationPlacements = /*#__PURE__*/basePlacements.reduce(function (acc, placement) { - return acc.concat([placement + "-" + start, placement + "-" + end]); - }, []); - var placements = /*#__PURE__*/[].concat(basePlacements, [auto]).reduce(function (acc, placement) { - return acc.concat([placement, placement + "-" + start, placement + "-" + end]); - }, []); // modifiers that need to read the DOM - - var beforeRead = 'beforeRead'; - var read = 'read'; - var afterRead = 'afterRead'; // pure-logic modifiers - - var beforeMain = 'beforeMain'; - var main = 'main'; - var afterMain = 'afterMain'; // modifier with the purpose to write to the DOM (or write into a framework state) - - var beforeWrite = 'beforeWrite'; - var write = 'write'; - var afterWrite = 'afterWrite'; - var modifierPhases = [beforeRead, read, afterRead, beforeMain, main, afterMain, beforeWrite, write, afterWrite]; - - function getNodeName(element) { - return element ? (element.nodeName || '').toLowerCase() : null; - } - - function getWindow(node) { - if (node == null) { - return window; - } - - if (node.toString() !== '[object Window]') { - var ownerDocument = node.ownerDocument; - return ownerDocument ? ownerDocument.defaultView || window : window; - } - - return node; - } - - function isElement(node) { - var OwnElement = getWindow(node).Element; - return node instanceof OwnElement || node instanceof Element; - } - - function isHTMLElement(node) { - var OwnElement = getWindow(node).HTMLElement; - return node instanceof OwnElement || node instanceof HTMLElement; - } - - function isShadowRoot(node) { - // IE 11 has no ShadowRoot - if (typeof ShadowRoot === 'undefined') { - return false; - } - - var OwnElement = getWindow(node).ShadowRoot; - return node instanceof OwnElement || node instanceof ShadowRoot; - } - - // and applies them to the HTMLElements such as popper and arrow - - function applyStyles(_ref) { - var state = _ref.state; - Object.keys(state.elements).forEach(function (name) { - var style = state.styles[name] || {}; - var attributes = state.attributes[name] || {}; - var element = state.elements[name]; // arrow is optional + virtual elements - - if (!isHTMLElement(element) || !getNodeName(element)) { - return; - } // Flow doesn't support to extend this property, but it's the most - // effective way to apply styles to an HTMLElement - // $FlowFixMe[cannot-write] - - - Object.assign(element.style, style); - Object.keys(attributes).forEach(function (name) { - var value = attributes[name]; - - if (value === false) { - element.removeAttribute(name); - } else { - element.setAttribute(name, value === true ? '' : value); - } - }); - }); - } - - function effect$2(_ref2) { - var state = _ref2.state; - var initialStyles = { - popper: { - position: state.options.strategy, - left: '0', - top: '0', - margin: '0' - }, - arrow: { - position: 'absolute' - }, - reference: {} - }; - Object.assign(state.elements.popper.style, initialStyles.popper); - state.styles = initialStyles; - - if (state.elements.arrow) { - Object.assign(state.elements.arrow.style, initialStyles.arrow); - } - - return function () { - Object.keys(state.elements).forEach(function (name) { - var element = state.elements[name]; - var attributes = state.attributes[name] || {}; - var styleProperties = Object.keys(state.styles.hasOwnProperty(name) ? state.styles[name] : initialStyles[name]); // Set all values to an empty string to unset them - - var style = styleProperties.reduce(function (style, property) { - style[property] = ''; - return style; - }, {}); // arrow is optional + virtual elements - - if (!isHTMLElement(element) || !getNodeName(element)) { - return; - } - - Object.assign(element.style, style); - Object.keys(attributes).forEach(function (attribute) { - element.removeAttribute(attribute); - }); - }); - }; - } // eslint-disable-next-line import/no-unused-modules - - - const applyStyles$1 = { - name: 'applyStyles', - enabled: true, - phase: 'write', - fn: applyStyles, - effect: effect$2, - requires: ['computeStyles'] - }; - - function getBasePlacement(placement) { - return placement.split('-')[0]; - } - - var max = Math.max; - var min = Math.min; - var round = Math.round; - - function getUAString() { - var uaData = navigator.userAgentData; - - if (uaData != null && uaData.brands && Array.isArray(uaData.brands)) { - return uaData.brands.map(function (item) { - return item.brand + "/" + item.version; - }).join(' '); - } - - return navigator.userAgent; - } - - function isLayoutViewport() { - return !/^((?!chrome|android).)*safari/i.test(getUAString()); - } - - function getBoundingClientRect(element, includeScale, isFixedStrategy) { - if (includeScale === void 0) { - includeScale = false; - } - - if (isFixedStrategy === void 0) { - isFixedStrategy = false; - } - - var clientRect = element.getBoundingClientRect(); - var scaleX = 1; - var scaleY = 1; - - if (includeScale && isHTMLElement(element)) { - scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1; - scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1; - } - - var _ref = isElement(element) ? getWindow(element) : window, - visualViewport = _ref.visualViewport; - - var addVisualOffsets = !isLayoutViewport() && isFixedStrategy; - var x = (clientRect.left + (addVisualOffsets && visualViewport ? visualViewport.offsetLeft : 0)) / scaleX; - var y = (clientRect.top + (addVisualOffsets && visualViewport ? visualViewport.offsetTop : 0)) / scaleY; - var width = clientRect.width / scaleX; - var height = clientRect.height / scaleY; - return { - width: width, - height: height, - top: y, - right: x + width, - bottom: y + height, - left: x, - x: x, - y: y - }; - } - - // means it doesn't take into account transforms. - - function getLayoutRect(element) { - var clientRect = getBoundingClientRect(element); // Use the clientRect sizes if it's not been transformed. - // Fixes https://github.com/popperjs/popper-core/issues/1223 - - var width = element.offsetWidth; - var height = element.offsetHeight; - - if (Math.abs(clientRect.width - width) <= 1) { - width = clientRect.width; - } - - if (Math.abs(clientRect.height - height) <= 1) { - height = clientRect.height; - } - - return { - x: element.offsetLeft, - y: element.offsetTop, - width: width, - height: height - }; - } - - function contains(parent, child) { - var rootNode = child.getRootNode && child.getRootNode(); // First, attempt with faster native method - - if (parent.contains(child)) { - return true; - } // then fallback to custom implementation with Shadow DOM support - else if (rootNode && isShadowRoot(rootNode)) { - var next = child; - - do { - if (next && parent.isSameNode(next)) { - return true; - } // $FlowFixMe[prop-missing]: need a better way to handle this... - - - next = next.parentNode || next.host; - } while (next); - } // Give up, the result is false - - - return false; - } - - function getComputedStyle$1(element) { - return getWindow(element).getComputedStyle(element); - } - - function isTableElement(element) { - return ['table', 'td', 'th'].indexOf(getNodeName(element)) >= 0; - } - - function getDocumentElement(element) { - // $FlowFixMe[incompatible-return]: assume body is always available - return ((isElement(element) ? element.ownerDocument : // $FlowFixMe[prop-missing] - element.document) || window.document).documentElement; - } - - function getParentNode(element) { - if (getNodeName(element) === 'html') { - return element; - } - - return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle - // $FlowFixMe[incompatible-return] - // $FlowFixMe[prop-missing] - element.assignedSlot || // step into the shadow DOM of the parent of a slotted node - element.parentNode || ( // DOM Element detected - isShadowRoot(element) ? element.host : null) || // ShadowRoot detected - // $FlowFixMe[incompatible-call]: HTMLElement is a Node - getDocumentElement(element) // fallback - - ); - } - - function getTrueOffsetParent(element) { - if (!isHTMLElement(element) || // https://github.com/popperjs/popper-core/issues/837 - getComputedStyle$1(element).position === 'fixed') { - return null; - } - - return element.offsetParent; - } // `.offsetParent` reports `null` for fixed elements, while absolute elements - // return the containing block - - - function getContainingBlock(element) { - var isFirefox = /firefox/i.test(getUAString()); - var isIE = /Trident/i.test(getUAString()); - - if (isIE && isHTMLElement(element)) { - // In IE 9, 10 and 11 fixed elements containing block is always established by the viewport - var elementCss = getComputedStyle$1(element); - - if (elementCss.position === 'fixed') { - return null; - } - } - - var currentNode = getParentNode(element); - - if (isShadowRoot(currentNode)) { - currentNode = currentNode.host; - } - - while (isHTMLElement(currentNode) && ['html', 'body'].indexOf(getNodeName(currentNode)) < 0) { - var css = getComputedStyle$1(currentNode); // This is non-exhaustive but covers the most common CSS properties that - // create a containing block. - // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block - - if (css.transform !== 'none' || css.perspective !== 'none' || css.contain === 'paint' || ['transform', 'perspective'].indexOf(css.willChange) !== -1 || isFirefox && css.willChange === 'filter' || isFirefox && css.filter && css.filter !== 'none') { - return currentNode; - } else { - currentNode = currentNode.parentNode; - } - } - - return null; - } // Gets the closest ancestor positioned element. Handles some edge cases, - // such as table ancestors and cross browser bugs. - - - function getOffsetParent(element) { - var window = getWindow(element); - var offsetParent = getTrueOffsetParent(element); - - while (offsetParent && isTableElement(offsetParent) && getComputedStyle$1(offsetParent).position === 'static') { - offsetParent = getTrueOffsetParent(offsetParent); - } - - if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle$1(offsetParent).position === 'static')) { - return window; - } - - return offsetParent || getContainingBlock(element) || window; - } - - function getMainAxisFromPlacement(placement) { - return ['top', 'bottom'].indexOf(placement) >= 0 ? 'x' : 'y'; - } - - function within(min$1, value, max$1) { - return max(min$1, min(value, max$1)); - } - function withinMaxClamp(min, value, max) { - var v = within(min, value, max); - return v > max ? max : v; - } - - function getFreshSideObject() { - return { - top: 0, - right: 0, - bottom: 0, - left: 0 - }; - } - - function mergePaddingObject(paddingObject) { - return Object.assign({}, getFreshSideObject(), paddingObject); - } - - function expandToHashMap(value, keys) { - return keys.reduce(function (hashMap, key) { - hashMap[key] = value; - return hashMap; - }, {}); - } - - var toPaddingObject = function toPaddingObject(padding, state) { - padding = typeof padding === 'function' ? padding(Object.assign({}, state.rects, { - placement: state.placement - })) : padding; - return mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); - }; - - function arrow(_ref) { - var _state$modifiersData$; - - var state = _ref.state, - name = _ref.name, - options = _ref.options; - var arrowElement = state.elements.arrow; - var popperOffsets = state.modifiersData.popperOffsets; - var basePlacement = getBasePlacement(state.placement); - var axis = getMainAxisFromPlacement(basePlacement); - var isVertical = [left, right].indexOf(basePlacement) >= 0; - var len = isVertical ? 'height' : 'width'; - - if (!arrowElement || !popperOffsets) { - return; - } - - var paddingObject = toPaddingObject(options.padding, state); - var arrowRect = getLayoutRect(arrowElement); - var minProp = axis === 'y' ? top : left; - var maxProp = axis === 'y' ? bottom : right; - var endDiff = state.rects.reference[len] + state.rects.reference[axis] - popperOffsets[axis] - state.rects.popper[len]; - var startDiff = popperOffsets[axis] - state.rects.reference[axis]; - var arrowOffsetParent = getOffsetParent(arrowElement); - var clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0; - var centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the popper if the center point is - // outside of the popper bounds - - var min = paddingObject[minProp]; - var max = clientSize - arrowRect[len] - paddingObject[maxProp]; - var center = clientSize / 2 - arrowRect[len] / 2 + centerToReference; - var offset = within(min, center, max); // Prevents breaking syntax highlighting... - - var axisProp = axis; - state.modifiersData[name] = (_state$modifiersData$ = {}, _state$modifiersData$[axisProp] = offset, _state$modifiersData$.centerOffset = offset - center, _state$modifiersData$); - } - - function effect$1(_ref2) { - var state = _ref2.state, - options = _ref2.options; - var _options$element = options.element, - arrowElement = _options$element === void 0 ? '[data-popper-arrow]' : _options$element; - - if (arrowElement == null) { - return; - } // CSS selector - - - if (typeof arrowElement === 'string') { - arrowElement = state.elements.popper.querySelector(arrowElement); - - if (!arrowElement) { - return; - } - } - - if (!contains(state.elements.popper, arrowElement)) { - return; - } - - state.elements.arrow = arrowElement; - } // eslint-disable-next-line import/no-unused-modules - - - const arrow$1 = { - name: 'arrow', - enabled: true, - phase: 'main', - fn: arrow, - effect: effect$1, - requires: ['popperOffsets'], - requiresIfExists: ['preventOverflow'] - }; - - function getVariation(placement) { - return placement.split('-')[1]; - } - - var unsetSides = { - top: 'auto', - right: 'auto', - bottom: 'auto', - left: 'auto' - }; // Round the offsets to the nearest suitable subpixel based on the DPR. - // Zooming can change the DPR, but it seems to report a value that will - // cleanly divide the values into the appropriate subpixels. - - function roundOffsetsByDPR(_ref, win) { - var x = _ref.x, - y = _ref.y; - var dpr = win.devicePixelRatio || 1; - return { - x: round(x * dpr) / dpr || 0, - y: round(y * dpr) / dpr || 0 - }; - } - - function mapToStyles(_ref2) { - var _Object$assign2; - - var popper = _ref2.popper, - popperRect = _ref2.popperRect, - placement = _ref2.placement, - variation = _ref2.variation, - offsets = _ref2.offsets, - position = _ref2.position, - gpuAcceleration = _ref2.gpuAcceleration, - adaptive = _ref2.adaptive, - roundOffsets = _ref2.roundOffsets, - isFixed = _ref2.isFixed; - var _offsets$x = offsets.x, - x = _offsets$x === void 0 ? 0 : _offsets$x, - _offsets$y = offsets.y, - y = _offsets$y === void 0 ? 0 : _offsets$y; - - var _ref3 = typeof roundOffsets === 'function' ? roundOffsets({ - x: x, - y: y - }) : { - x: x, - y: y - }; - - x = _ref3.x; - y = _ref3.y; - var hasX = offsets.hasOwnProperty('x'); - var hasY = offsets.hasOwnProperty('y'); - var sideX = left; - var sideY = top; - var win = window; - - if (adaptive) { - var offsetParent = getOffsetParent(popper); - var heightProp = 'clientHeight'; - var widthProp = 'clientWidth'; - - if (offsetParent === getWindow(popper)) { - offsetParent = getDocumentElement(popper); - - if (getComputedStyle$1(offsetParent).position !== 'static' && position === 'absolute') { - heightProp = 'scrollHeight'; - widthProp = 'scrollWidth'; - } - } // $FlowFixMe[incompatible-cast]: force type refinement, we compare offsetParent with window above, but Flow doesn't detect it - - - offsetParent = offsetParent; - - if (placement === top || (placement === left || placement === right) && variation === end) { - sideY = bottom; - var offsetY = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.height : // $FlowFixMe[prop-missing] - offsetParent[heightProp]; - y -= offsetY - popperRect.height; - y *= gpuAcceleration ? 1 : -1; - } - - if (placement === left || (placement === top || placement === bottom) && variation === end) { - sideX = right; - var offsetX = isFixed && offsetParent === win && win.visualViewport ? win.visualViewport.width : // $FlowFixMe[prop-missing] - offsetParent[widthProp]; - x -= offsetX - popperRect.width; - x *= gpuAcceleration ? 1 : -1; - } - } - - var commonStyles = Object.assign({ - position: position - }, adaptive && unsetSides); - - var _ref4 = roundOffsets === true ? roundOffsetsByDPR({ - x: x, - y: y - }, getWindow(popper)) : { - x: x, - y: y - }; - - x = _ref4.x; - y = _ref4.y; - - if (gpuAcceleration) { - var _Object$assign; - - return Object.assign({}, commonStyles, (_Object$assign = {}, _Object$assign[sideY] = hasY ? '0' : '', _Object$assign[sideX] = hasX ? '0' : '', _Object$assign.transform = (win.devicePixelRatio || 1) <= 1 ? "translate(" + x + "px, " + y + "px)" : "translate3d(" + x + "px, " + y + "px, 0)", _Object$assign)); - } - - return Object.assign({}, commonStyles, (_Object$assign2 = {}, _Object$assign2[sideY] = hasY ? y + "px" : '', _Object$assign2[sideX] = hasX ? x + "px" : '', _Object$assign2.transform = '', _Object$assign2)); - } - - function computeStyles(_ref5) { - var state = _ref5.state, - options = _ref5.options; - var _options$gpuAccelerat = options.gpuAcceleration, - gpuAcceleration = _options$gpuAccelerat === void 0 ? true : _options$gpuAccelerat, - _options$adaptive = options.adaptive, - adaptive = _options$adaptive === void 0 ? true : _options$adaptive, - _options$roundOffsets = options.roundOffsets, - roundOffsets = _options$roundOffsets === void 0 ? true : _options$roundOffsets; - var commonStyles = { - placement: getBasePlacement(state.placement), - variation: getVariation(state.placement), - popper: state.elements.popper, - popperRect: state.rects.popper, - gpuAcceleration: gpuAcceleration, - isFixed: state.options.strategy === 'fixed' - }; - - if (state.modifiersData.popperOffsets != null) { - state.styles.popper = Object.assign({}, state.styles.popper, mapToStyles(Object.assign({}, commonStyles, { - offsets: state.modifiersData.popperOffsets, - position: state.options.strategy, - adaptive: adaptive, - roundOffsets: roundOffsets - }))); - } - - if (state.modifiersData.arrow != null) { - state.styles.arrow = Object.assign({}, state.styles.arrow, mapToStyles(Object.assign({}, commonStyles, { - offsets: state.modifiersData.arrow, - position: 'absolute', - adaptive: false, - roundOffsets: roundOffsets - }))); - } - - state.attributes.popper = Object.assign({}, state.attributes.popper, { - 'data-popper-placement': state.placement - }); - } // eslint-disable-next-line import/no-unused-modules - - - const computeStyles$1 = { - name: 'computeStyles', - enabled: true, - phase: 'beforeWrite', - fn: computeStyles, - data: {} - }; - - var passive = { - passive: true - }; - - function effect(_ref) { - var state = _ref.state, - instance = _ref.instance, - options = _ref.options; - var _options$scroll = options.scroll, - scroll = _options$scroll === void 0 ? true : _options$scroll, - _options$resize = options.resize, - resize = _options$resize === void 0 ? true : _options$resize; - var window = getWindow(state.elements.popper); - var scrollParents = [].concat(state.scrollParents.reference, state.scrollParents.popper); - - if (scroll) { - scrollParents.forEach(function (scrollParent) { - scrollParent.addEventListener('scroll', instance.update, passive); - }); - } - - if (resize) { - window.addEventListener('resize', instance.update, passive); - } - - return function () { - if (scroll) { - scrollParents.forEach(function (scrollParent) { - scrollParent.removeEventListener('scroll', instance.update, passive); - }); - } - - if (resize) { - window.removeEventListener('resize', instance.update, passive); - } - }; - } // eslint-disable-next-line import/no-unused-modules - - - const eventListeners = { - name: 'eventListeners', - enabled: true, - phase: 'write', - fn: function fn() {}, - effect: effect, - data: {} - }; - - var hash$1 = { - left: 'right', - right: 'left', - bottom: 'top', - top: 'bottom' - }; - function getOppositePlacement(placement) { - return placement.replace(/left|right|bottom|top/g, function (matched) { - return hash$1[matched]; - }); - } - - var hash = { - start: 'end', - end: 'start' - }; - function getOppositeVariationPlacement(placement) { - return placement.replace(/start|end/g, function (matched) { - return hash[matched]; - }); - } - - function getWindowScroll(node) { - var win = getWindow(node); - var scrollLeft = win.pageXOffset; - var scrollTop = win.pageYOffset; - return { - scrollLeft: scrollLeft, - scrollTop: scrollTop - }; - } - - function getWindowScrollBarX(element) { - // If has a CSS width greater than the viewport, then this will be - // incorrect for RTL. - // Popper 1 is broken in this case and never had a bug report so let's assume - // it's not an issue. I don't think anyone ever specifies width on - // anyway. - // Browsers where the left scrollbar doesn't cause an issue report `0` for - // this (e.g. Edge 2019, IE11, Safari) - return getBoundingClientRect(getDocumentElement(element)).left + getWindowScroll(element).scrollLeft; - } - - function getViewportRect(element, strategy) { - var win = getWindow(element); - var html = getDocumentElement(element); - var visualViewport = win.visualViewport; - var width = html.clientWidth; - var height = html.clientHeight; - var x = 0; - var y = 0; - - if (visualViewport) { - width = visualViewport.width; - height = visualViewport.height; - var layoutViewport = isLayoutViewport(); - - if (layoutViewport || !layoutViewport && strategy === 'fixed') { - x = visualViewport.offsetLeft; - y = visualViewport.offsetTop; - } - } - - return { - width: width, - height: height, - x: x + getWindowScrollBarX(element), - y: y - }; - } - - // of the `` and `` rect bounds if horizontally scrollable - - function getDocumentRect(element) { - var _element$ownerDocumen; - - var html = getDocumentElement(element); - var winScroll = getWindowScroll(element); - var body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body; - var width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0); - var height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0); - var x = -winScroll.scrollLeft + getWindowScrollBarX(element); - var y = -winScroll.scrollTop; - - if (getComputedStyle$1(body || html).direction === 'rtl') { - x += max(html.clientWidth, body ? body.clientWidth : 0) - width; - } - - return { - width: width, - height: height, - x: x, - y: y - }; - } - - function isScrollParent(element) { - // Firefox wants us to check `-x` and `-y` variations as well - var _getComputedStyle = getComputedStyle$1(element), - overflow = _getComputedStyle.overflow, - overflowX = _getComputedStyle.overflowX, - overflowY = _getComputedStyle.overflowY; - - return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX); - } - - function getScrollParent(node) { - if (['html', 'body', '#document'].indexOf(getNodeName(node)) >= 0) { - // $FlowFixMe[incompatible-return]: assume body is always available - return node.ownerDocument.body; - } - - if (isHTMLElement(node) && isScrollParent(node)) { - return node; - } - - return getScrollParent(getParentNode(node)); - } - - /* - given a DOM element, return the list of all scroll parents, up the list of ancesors - until we get to the top window object. This list is what we attach scroll listeners - to, because if any of these parent elements scroll, we'll need to re-calculate the - reference element's position. - */ - - function listScrollParents(element, list) { - var _element$ownerDocumen; - - if (list === void 0) { - list = []; - } - - var scrollParent = getScrollParent(element); - var isBody = scrollParent === ((_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body); - var win = getWindow(scrollParent); - var target = isBody ? [win].concat(win.visualViewport || [], isScrollParent(scrollParent) ? scrollParent : []) : scrollParent; - var updatedList = list.concat(target); - return isBody ? updatedList : // $FlowFixMe[incompatible-call]: isBody tells us target will be an HTMLElement here - updatedList.concat(listScrollParents(getParentNode(target))); - } - - function rectToClientRect(rect) { - return Object.assign({}, rect, { - left: rect.x, - top: rect.y, - right: rect.x + rect.width, - bottom: rect.y + rect.height - }); - } - - function getInnerBoundingClientRect(element, strategy) { - var rect = getBoundingClientRect(element, false, strategy === 'fixed'); - rect.top = rect.top + element.clientTop; - rect.left = rect.left + element.clientLeft; - rect.bottom = rect.top + element.clientHeight; - rect.right = rect.left + element.clientWidth; - rect.width = element.clientWidth; - rect.height = element.clientHeight; - rect.x = rect.left; - rect.y = rect.top; - return rect; - } - - function getClientRectFromMixedType(element, clippingParent, strategy) { - return clippingParent === viewport ? rectToClientRect(getViewportRect(element, strategy)) : isElement(clippingParent) ? getInnerBoundingClientRect(clippingParent, strategy) : rectToClientRect(getDocumentRect(getDocumentElement(element))); - } // A "clipping parent" is an overflowable container with the characteristic of - // clipping (or hiding) overflowing elements with a position different from - // `initial` - - - function getClippingParents(element) { - var clippingParents = listScrollParents(getParentNode(element)); - var canEscapeClipping = ['absolute', 'fixed'].indexOf(getComputedStyle$1(element).position) >= 0; - var clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element; - - if (!isElement(clipperElement)) { - return []; - } // $FlowFixMe[incompatible-return]: https://github.com/facebook/flow/issues/1414 - - - return clippingParents.filter(function (clippingParent) { - return isElement(clippingParent) && contains(clippingParent, clipperElement) && getNodeName(clippingParent) !== 'body'; - }); - } // Gets the maximum area that the element is visible in due to any number of - // clipping parents - - - function getClippingRect(element, boundary, rootBoundary, strategy) { - var mainClippingParents = boundary === 'clippingParents' ? getClippingParents(element) : [].concat(boundary); - var clippingParents = [].concat(mainClippingParents, [rootBoundary]); - var firstClippingParent = clippingParents[0]; - var clippingRect = clippingParents.reduce(function (accRect, clippingParent) { - var rect = getClientRectFromMixedType(element, clippingParent, strategy); - accRect.top = max(rect.top, accRect.top); - accRect.right = min(rect.right, accRect.right); - accRect.bottom = min(rect.bottom, accRect.bottom); - accRect.left = max(rect.left, accRect.left); - return accRect; - }, getClientRectFromMixedType(element, firstClippingParent, strategy)); - clippingRect.width = clippingRect.right - clippingRect.left; - clippingRect.height = clippingRect.bottom - clippingRect.top; - clippingRect.x = clippingRect.left; - clippingRect.y = clippingRect.top; - return clippingRect; - } - - function computeOffsets(_ref) { - var reference = _ref.reference, - element = _ref.element, - placement = _ref.placement; - var basePlacement = placement ? getBasePlacement(placement) : null; - var variation = placement ? getVariation(placement) : null; - var commonX = reference.x + reference.width / 2 - element.width / 2; - var commonY = reference.y + reference.height / 2 - element.height / 2; - var offsets; - - switch (basePlacement) { - case top: - offsets = { - x: commonX, - y: reference.y - element.height - }; - break; - - case bottom: - offsets = { - x: commonX, - y: reference.y + reference.height - }; - break; - - case right: - offsets = { - x: reference.x + reference.width, - y: commonY - }; - break; - - case left: - offsets = { - x: reference.x - element.width, - y: commonY - }; - break; - - default: - offsets = { - x: reference.x, - y: reference.y - }; - } - - var mainAxis = basePlacement ? getMainAxisFromPlacement(basePlacement) : null; - - if (mainAxis != null) { - var len = mainAxis === 'y' ? 'height' : 'width'; - - switch (variation) { - case start: - offsets[mainAxis] = offsets[mainAxis] - (reference[len] / 2 - element[len] / 2); - break; - - case end: - offsets[mainAxis] = offsets[mainAxis] + (reference[len] / 2 - element[len] / 2); - break; - } - } - - return offsets; - } - - function detectOverflow(state, options) { - if (options === void 0) { - options = {}; - } - - var _options = options, - _options$placement = _options.placement, - placement = _options$placement === void 0 ? state.placement : _options$placement, - _options$strategy = _options.strategy, - strategy = _options$strategy === void 0 ? state.strategy : _options$strategy, - _options$boundary = _options.boundary, - boundary = _options$boundary === void 0 ? clippingParents : _options$boundary, - _options$rootBoundary = _options.rootBoundary, - rootBoundary = _options$rootBoundary === void 0 ? viewport : _options$rootBoundary, - _options$elementConte = _options.elementContext, - elementContext = _options$elementConte === void 0 ? popper : _options$elementConte, - _options$altBoundary = _options.altBoundary, - altBoundary = _options$altBoundary === void 0 ? false : _options$altBoundary, - _options$padding = _options.padding, - padding = _options$padding === void 0 ? 0 : _options$padding; - var paddingObject = mergePaddingObject(typeof padding !== 'number' ? padding : expandToHashMap(padding, basePlacements)); - var altContext = elementContext === popper ? reference : popper; - var popperRect = state.rects.popper; - var element = state.elements[altBoundary ? altContext : elementContext]; - var clippingClientRect = getClippingRect(isElement(element) ? element : element.contextElement || getDocumentElement(state.elements.popper), boundary, rootBoundary, strategy); - var referenceClientRect = getBoundingClientRect(state.elements.reference); - var popperOffsets = computeOffsets({ - reference: referenceClientRect, - element: popperRect, - strategy: 'absolute', - placement: placement - }); - var popperClientRect = rectToClientRect(Object.assign({}, popperRect, popperOffsets)); - var elementClientRect = elementContext === popper ? popperClientRect : referenceClientRect; // positive = overflowing the clipping rect - // 0 or negative = within the clipping rect - - var overflowOffsets = { - top: clippingClientRect.top - elementClientRect.top + paddingObject.top, - bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom, - left: clippingClientRect.left - elementClientRect.left + paddingObject.left, - right: elementClientRect.right - clippingClientRect.right + paddingObject.right - }; - var offsetData = state.modifiersData.offset; // Offsets can be applied only to the popper element - - if (elementContext === popper && offsetData) { - var offset = offsetData[placement]; - Object.keys(overflowOffsets).forEach(function (key) { - var multiply = [right, bottom].indexOf(key) >= 0 ? 1 : -1; - var axis = [top, bottom].indexOf(key) >= 0 ? 'y' : 'x'; - overflowOffsets[key] += offset[axis] * multiply; - }); - } - - return overflowOffsets; - } - - function computeAutoPlacement(state, options) { - if (options === void 0) { - options = {}; - } - - var _options = options, - placement = _options.placement, - boundary = _options.boundary, - rootBoundary = _options.rootBoundary, - padding = _options.padding, - flipVariations = _options.flipVariations, - _options$allowedAutoP = _options.allowedAutoPlacements, - allowedAutoPlacements = _options$allowedAutoP === void 0 ? placements : _options$allowedAutoP; - var variation = getVariation(placement); - var placements$1 = variation ? flipVariations ? variationPlacements : variationPlacements.filter(function (placement) { - return getVariation(placement) === variation; - }) : basePlacements; - var allowedPlacements = placements$1.filter(function (placement) { - return allowedAutoPlacements.indexOf(placement) >= 0; - }); - - if (allowedPlacements.length === 0) { - allowedPlacements = placements$1; - } // $FlowFixMe[incompatible-type]: Flow seems to have problems with two array unions... - - - var overflows = allowedPlacements.reduce(function (acc, placement) { - acc[placement] = detectOverflow(state, { - placement: placement, - boundary: boundary, - rootBoundary: rootBoundary, - padding: padding - })[getBasePlacement(placement)]; - return acc; - }, {}); - return Object.keys(overflows).sort(function (a, b) { - return overflows[a] - overflows[b]; - }); - } - - function getExpandedFallbackPlacements(placement) { - if (getBasePlacement(placement) === auto) { - return []; - } - - var oppositePlacement = getOppositePlacement(placement); - return [getOppositeVariationPlacement(placement), oppositePlacement, getOppositeVariationPlacement(oppositePlacement)]; - } - - function flip(_ref) { - var state = _ref.state, - options = _ref.options, - name = _ref.name; - - if (state.modifiersData[name]._skip) { - return; - } - - var _options$mainAxis = options.mainAxis, - checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, - _options$altAxis = options.altAxis, - checkAltAxis = _options$altAxis === void 0 ? true : _options$altAxis, - specifiedFallbackPlacements = options.fallbackPlacements, - padding = options.padding, - boundary = options.boundary, - rootBoundary = options.rootBoundary, - altBoundary = options.altBoundary, - _options$flipVariatio = options.flipVariations, - flipVariations = _options$flipVariatio === void 0 ? true : _options$flipVariatio, - allowedAutoPlacements = options.allowedAutoPlacements; - var preferredPlacement = state.options.placement; - var basePlacement = getBasePlacement(preferredPlacement); - var isBasePlacement = basePlacement === preferredPlacement; - var fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipVariations ? [getOppositePlacement(preferredPlacement)] : getExpandedFallbackPlacements(preferredPlacement)); - var placements = [preferredPlacement].concat(fallbackPlacements).reduce(function (acc, placement) { - return acc.concat(getBasePlacement(placement) === auto ? computeAutoPlacement(state, { - placement: placement, - boundary: boundary, - rootBoundary: rootBoundary, - padding: padding, - flipVariations: flipVariations, - allowedAutoPlacements: allowedAutoPlacements - }) : placement); - }, []); - var referenceRect = state.rects.reference; - var popperRect = state.rects.popper; - var checksMap = new Map(); - var makeFallbackChecks = true; - var firstFittingPlacement = placements[0]; - - for (var i = 0; i < placements.length; i++) { - var placement = placements[i]; - - var _basePlacement = getBasePlacement(placement); - - var isStartVariation = getVariation(placement) === start; - var isVertical = [top, bottom].indexOf(_basePlacement) >= 0; - var len = isVertical ? 'width' : 'height'; - var overflow = detectOverflow(state, { - placement: placement, - boundary: boundary, - rootBoundary: rootBoundary, - altBoundary: altBoundary, - padding: padding - }); - var mainVariationSide = isVertical ? isStartVariation ? right : left : isStartVariation ? bottom : top; - - if (referenceRect[len] > popperRect[len]) { - mainVariationSide = getOppositePlacement(mainVariationSide); - } - - var altVariationSide = getOppositePlacement(mainVariationSide); - var checks = []; - - if (checkMainAxis) { - checks.push(overflow[_basePlacement] <= 0); - } - - if (checkAltAxis) { - checks.push(overflow[mainVariationSide] <= 0, overflow[altVariationSide] <= 0); - } - - if (checks.every(function (check) { - return check; - })) { - firstFittingPlacement = placement; - makeFallbackChecks = false; - break; - } - - checksMap.set(placement, checks); - } - - if (makeFallbackChecks) { - // `2` may be desired in some cases – research later - var numberOfChecks = flipVariations ? 3 : 1; - - var _loop = function _loop(_i) { - var fittingPlacement = placements.find(function (placement) { - var checks = checksMap.get(placement); - - if (checks) { - return checks.slice(0, _i).every(function (check) { - return check; - }); - } - }); - - if (fittingPlacement) { - firstFittingPlacement = fittingPlacement; - return "break"; - } - }; - - for (var _i = numberOfChecks; _i > 0; _i--) { - var _ret = _loop(_i); - - if (_ret === "break") break; - } - } - - if (state.placement !== firstFittingPlacement) { - state.modifiersData[name]._skip = true; - state.placement = firstFittingPlacement; - state.reset = true; - } - } // eslint-disable-next-line import/no-unused-modules - - - const flip$1 = { - name: 'flip', - enabled: true, - phase: 'main', - fn: flip, - requiresIfExists: ['offset'], - data: { - _skip: false - } - }; - - function getSideOffsets(overflow, rect, preventedOffsets) { - if (preventedOffsets === void 0) { - preventedOffsets = { - x: 0, - y: 0 - }; - } - - return { - top: overflow.top - rect.height - preventedOffsets.y, - right: overflow.right - rect.width + preventedOffsets.x, - bottom: overflow.bottom - rect.height + preventedOffsets.y, - left: overflow.left - rect.width - preventedOffsets.x - }; - } - - function isAnySideFullyClipped(overflow) { - return [top, right, bottom, left].some(function (side) { - return overflow[side] >= 0; - }); - } - - function hide(_ref) { - var state = _ref.state, - name = _ref.name; - var referenceRect = state.rects.reference; - var popperRect = state.rects.popper; - var preventedOffsets = state.modifiersData.preventOverflow; - var referenceOverflow = detectOverflow(state, { - elementContext: 'reference' - }); - var popperAltOverflow = detectOverflow(state, { - altBoundary: true - }); - var referenceClippingOffsets = getSideOffsets(referenceOverflow, referenceRect); - var popperEscapeOffsets = getSideOffsets(popperAltOverflow, popperRect, preventedOffsets); - var isReferenceHidden = isAnySideFullyClipped(referenceClippingOffsets); - var hasPopperEscaped = isAnySideFullyClipped(popperEscapeOffsets); - state.modifiersData[name] = { - referenceClippingOffsets: referenceClippingOffsets, - popperEscapeOffsets: popperEscapeOffsets, - isReferenceHidden: isReferenceHidden, - hasPopperEscaped: hasPopperEscaped - }; - state.attributes.popper = Object.assign({}, state.attributes.popper, { - 'data-popper-reference-hidden': isReferenceHidden, - 'data-popper-escaped': hasPopperEscaped - }); - } // eslint-disable-next-line import/no-unused-modules - - - const hide$1 = { - name: 'hide', - enabled: true, - phase: 'main', - requiresIfExists: ['preventOverflow'], - fn: hide - }; - - function distanceAndSkiddingToXY(placement, rects, offset) { - var basePlacement = getBasePlacement(placement); - var invertDistance = [left, top].indexOf(basePlacement) >= 0 ? -1 : 1; - - var _ref = typeof offset === 'function' ? offset(Object.assign({}, rects, { - placement: placement - })) : offset, - skidding = _ref[0], - distance = _ref[1]; - - skidding = skidding || 0; - distance = (distance || 0) * invertDistance; - return [left, right].indexOf(basePlacement) >= 0 ? { - x: distance, - y: skidding - } : { - x: skidding, - y: distance - }; - } - - function offset(_ref2) { - var state = _ref2.state, - options = _ref2.options, - name = _ref2.name; - var _options$offset = options.offset, - offset = _options$offset === void 0 ? [0, 0] : _options$offset; - var data = placements.reduce(function (acc, placement) { - acc[placement] = distanceAndSkiddingToXY(placement, state.rects, offset); - return acc; - }, {}); - var _data$state$placement = data[state.placement], - x = _data$state$placement.x, - y = _data$state$placement.y; - - if (state.modifiersData.popperOffsets != null) { - state.modifiersData.popperOffsets.x += x; - state.modifiersData.popperOffsets.y += y; - } - - state.modifiersData[name] = data; - } // eslint-disable-next-line import/no-unused-modules - - - const offset$1 = { - name: 'offset', - enabled: true, - phase: 'main', - requires: ['popperOffsets'], - fn: offset - }; - - function popperOffsets(_ref) { - var state = _ref.state, - name = _ref.name; - // Offsets are the actual position the popper needs to have to be - // properly positioned near its reference element - // This is the most basic placement, and will be adjusted by - // the modifiers in the next step - state.modifiersData[name] = computeOffsets({ - reference: state.rects.reference, - element: state.rects.popper, - strategy: 'absolute', - placement: state.placement - }); - } // eslint-disable-next-line import/no-unused-modules - - - const popperOffsets$1 = { - name: 'popperOffsets', - enabled: true, - phase: 'read', - fn: popperOffsets, - data: {} - }; - - function getAltAxis(axis) { - return axis === 'x' ? 'y' : 'x'; - } - - function preventOverflow(_ref) { - var state = _ref.state, - options = _ref.options, - name = _ref.name; - var _options$mainAxis = options.mainAxis, - checkMainAxis = _options$mainAxis === void 0 ? true : _options$mainAxis, - _options$altAxis = options.altAxis, - checkAltAxis = _options$altAxis === void 0 ? false : _options$altAxis, - boundary = options.boundary, - rootBoundary = options.rootBoundary, - altBoundary = options.altBoundary, - padding = options.padding, - _options$tether = options.tether, - tether = _options$tether === void 0 ? true : _options$tether, - _options$tetherOffset = options.tetherOffset, - tetherOffset = _options$tetherOffset === void 0 ? 0 : _options$tetherOffset; - var overflow = detectOverflow(state, { - boundary: boundary, - rootBoundary: rootBoundary, - padding: padding, - altBoundary: altBoundary - }); - var basePlacement = getBasePlacement(state.placement); - var variation = getVariation(state.placement); - var isBasePlacement = !variation; - var mainAxis = getMainAxisFromPlacement(basePlacement); - var altAxis = getAltAxis(mainAxis); - var popperOffsets = state.modifiersData.popperOffsets; - var referenceRect = state.rects.reference; - var popperRect = state.rects.popper; - var tetherOffsetValue = typeof tetherOffset === 'function' ? tetherOffset(Object.assign({}, state.rects, { - placement: state.placement - })) : tetherOffset; - var normalizedTetherOffsetValue = typeof tetherOffsetValue === 'number' ? { - mainAxis: tetherOffsetValue, - altAxis: tetherOffsetValue - } : Object.assign({ - mainAxis: 0, - altAxis: 0 - }, tetherOffsetValue); - var offsetModifierState = state.modifiersData.offset ? state.modifiersData.offset[state.placement] : null; - var data = { - x: 0, - y: 0 - }; - - if (!popperOffsets) { - return; - } - - if (checkMainAxis) { - var _offsetModifierState$; - - var mainSide = mainAxis === 'y' ? top : left; - var altSide = mainAxis === 'y' ? bottom : right; - var len = mainAxis === 'y' ? 'height' : 'width'; - var offset = popperOffsets[mainAxis]; - var min$1 = offset + overflow[mainSide]; - var max$1 = offset - overflow[altSide]; - var additive = tether ? -popperRect[len] / 2 : 0; - var minLen = variation === start ? referenceRect[len] : popperRect[len]; - var maxLen = variation === start ? -popperRect[len] : -referenceRect[len]; // We need to include the arrow in the calculation so the arrow doesn't go - // outside the reference bounds - - var arrowElement = state.elements.arrow; - var arrowRect = tether && arrowElement ? getLayoutRect(arrowElement) : { - width: 0, - height: 0 - }; - var arrowPaddingObject = state.modifiersData['arrow#persistent'] ? state.modifiersData['arrow#persistent'].padding : getFreshSideObject(); - var arrowPaddingMin = arrowPaddingObject[mainSide]; - var arrowPaddingMax = arrowPaddingObject[altSide]; // If the reference length is smaller than the arrow length, we don't want - // to include its full size in the calculation. If the reference is small - // and near the edge of a boundary, the popper can overflow even if the - // reference is not overflowing as well (e.g. virtual elements with no - // width or height) - - var arrowLen = within(0, referenceRect[len], arrowRect[len]); - var minOffset = isBasePlacement ? referenceRect[len] / 2 - additive - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis : minLen - arrowLen - arrowPaddingMin - normalizedTetherOffsetValue.mainAxis; - var maxOffset = isBasePlacement ? -referenceRect[len] / 2 + additive + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis : maxLen + arrowLen + arrowPaddingMax + normalizedTetherOffsetValue.mainAxis; - var arrowOffsetParent = state.elements.arrow && getOffsetParent(state.elements.arrow); - var clientOffset = arrowOffsetParent ? mainAxis === 'y' ? arrowOffsetParent.clientTop || 0 : arrowOffsetParent.clientLeft || 0 : 0; - var offsetModifierValue = (_offsetModifierState$ = offsetModifierState == null ? void 0 : offsetModifierState[mainAxis]) != null ? _offsetModifierState$ : 0; - var tetherMin = offset + minOffset - offsetModifierValue - clientOffset; - var tetherMax = offset + maxOffset - offsetModifierValue; - var preventedOffset = within(tether ? min(min$1, tetherMin) : min$1, offset, tether ? max(max$1, tetherMax) : max$1); - popperOffsets[mainAxis] = preventedOffset; - data[mainAxis] = preventedOffset - offset; - } - - if (checkAltAxis) { - var _offsetModifierState$2; - - var _mainSide = mainAxis === 'x' ? top : left; - - var _altSide = mainAxis === 'x' ? bottom : right; - - var _offset = popperOffsets[altAxis]; - - var _len = altAxis === 'y' ? 'height' : 'width'; - - var _min = _offset + overflow[_mainSide]; - - var _max = _offset - overflow[_altSide]; - - var isOriginSide = [top, left].indexOf(basePlacement) !== -1; - - var _offsetModifierValue = (_offsetModifierState$2 = offsetModifierState == null ? void 0 : offsetModifierState[altAxis]) != null ? _offsetModifierState$2 : 0; - - var _tetherMin = isOriginSide ? _min : _offset - referenceRect[_len] - popperRect[_len] - _offsetModifierValue + normalizedTetherOffsetValue.altAxis; - - var _tetherMax = isOriginSide ? _offset + referenceRect[_len] + popperRect[_len] - _offsetModifierValue - normalizedTetherOffsetValue.altAxis : _max; - - var _preventedOffset = tether && isOriginSide ? withinMaxClamp(_tetherMin, _offset, _tetherMax) : within(tether ? _tetherMin : _min, _offset, tether ? _tetherMax : _max); - - popperOffsets[altAxis] = _preventedOffset; - data[altAxis] = _preventedOffset - _offset; - } - - state.modifiersData[name] = data; - } // eslint-disable-next-line import/no-unused-modules - - - const preventOverflow$1 = { - name: 'preventOverflow', - enabled: true, - phase: 'main', - fn: preventOverflow, - requiresIfExists: ['offset'] - }; - - function getHTMLElementScroll(element) { - return { - scrollLeft: element.scrollLeft, - scrollTop: element.scrollTop - }; - } - - function getNodeScroll(node) { - if (node === getWindow(node) || !isHTMLElement(node)) { - return getWindowScroll(node); - } else { - return getHTMLElementScroll(node); - } - } - - function isElementScaled(element) { - var rect = element.getBoundingClientRect(); - var scaleX = round(rect.width) / element.offsetWidth || 1; - var scaleY = round(rect.height) / element.offsetHeight || 1; - return scaleX !== 1 || scaleY !== 1; - } // Returns the composite rect of an element relative to its offsetParent. - // Composite means it takes into account transforms as well as layout. - - - function getCompositeRect(elementOrVirtualElement, offsetParent, isFixed) { - if (isFixed === void 0) { - isFixed = false; - } - - var isOffsetParentAnElement = isHTMLElement(offsetParent); - var offsetParentIsScaled = isHTMLElement(offsetParent) && isElementScaled(offsetParent); - var documentElement = getDocumentElement(offsetParent); - var rect = getBoundingClientRect(elementOrVirtualElement, offsetParentIsScaled, isFixed); - var scroll = { - scrollLeft: 0, - scrollTop: 0 - }; - var offsets = { - x: 0, - y: 0 - }; - - if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) { - if (getNodeName(offsetParent) !== 'body' || // https://github.com/popperjs/popper-core/issues/1078 - isScrollParent(documentElement)) { - scroll = getNodeScroll(offsetParent); - } - - if (isHTMLElement(offsetParent)) { - offsets = getBoundingClientRect(offsetParent, true); - offsets.x += offsetParent.clientLeft; - offsets.y += offsetParent.clientTop; - } else if (documentElement) { - offsets.x = getWindowScrollBarX(documentElement); - } - } - - return { - x: rect.left + scroll.scrollLeft - offsets.x, - y: rect.top + scroll.scrollTop - offsets.y, - width: rect.width, - height: rect.height - }; - } - - function order(modifiers) { - var map = new Map(); - var visited = new Set(); - var result = []; - modifiers.forEach(function (modifier) { - map.set(modifier.name, modifier); - }); // On visiting object, check for its dependencies and visit them recursively - - function sort(modifier) { - visited.add(modifier.name); - var requires = [].concat(modifier.requires || [], modifier.requiresIfExists || []); - requires.forEach(function (dep) { - if (!visited.has(dep)) { - var depModifier = map.get(dep); - - if (depModifier) { - sort(depModifier); - } - } - }); - result.push(modifier); - } - - modifiers.forEach(function (modifier) { - if (!visited.has(modifier.name)) { - // check for visited object - sort(modifier); - } - }); - return result; - } - - function orderModifiers(modifiers) { - // order based on dependencies - var orderedModifiers = order(modifiers); // order based on phase - - return modifierPhases.reduce(function (acc, phase) { - return acc.concat(orderedModifiers.filter(function (modifier) { - return modifier.phase === phase; - })); - }, []); - } - - function debounce(fn) { - var pending; - return function () { - if (!pending) { - pending = new Promise(function (resolve) { - Promise.resolve().then(function () { - pending = undefined; - resolve(fn()); - }); - }); - } - - return pending; - }; - } - - function mergeByName(modifiers) { - var merged = modifiers.reduce(function (merged, current) { - var existing = merged[current.name]; - merged[current.name] = existing ? Object.assign({}, existing, current, { - options: Object.assign({}, existing.options, current.options), - data: Object.assign({}, existing.data, current.data) - }) : current; - return merged; - }, {}); // IE11 does not support Object.values - - return Object.keys(merged).map(function (key) { - return merged[key]; - }); - } - - var DEFAULT_OPTIONS = { - placement: 'bottom', - modifiers: [], - strategy: 'absolute' - }; - - function areValidElements() { - for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; - } - - return !args.some(function (element) { - return !(element && typeof element.getBoundingClientRect === 'function'); - }); - } - - function popperGenerator(generatorOptions) { - if (generatorOptions === void 0) { - generatorOptions = {}; - } - - var _generatorOptions = generatorOptions, - _generatorOptions$def = _generatorOptions.defaultModifiers, - defaultModifiers = _generatorOptions$def === void 0 ? [] : _generatorOptions$def, - _generatorOptions$def2 = _generatorOptions.defaultOptions, - defaultOptions = _generatorOptions$def2 === void 0 ? DEFAULT_OPTIONS : _generatorOptions$def2; - return function createPopper(reference, popper, options) { - if (options === void 0) { - options = defaultOptions; - } - - var state = { - placement: 'bottom', - orderedModifiers: [], - options: Object.assign({}, DEFAULT_OPTIONS, defaultOptions), - modifiersData: {}, - elements: { - reference: reference, - popper: popper - }, - attributes: {}, - styles: {} - }; - var effectCleanupFns = []; - var isDestroyed = false; - var instance = { - state: state, - setOptions: function setOptions(setOptionsAction) { - var options = typeof setOptionsAction === 'function' ? setOptionsAction(state.options) : setOptionsAction; - cleanupModifierEffects(); - state.options = Object.assign({}, defaultOptions, state.options, options); - state.scrollParents = { - reference: isElement(reference) ? listScrollParents(reference) : reference.contextElement ? listScrollParents(reference.contextElement) : [], - popper: listScrollParents(popper) - }; // Orders the modifiers based on their dependencies and `phase` - // properties - - var orderedModifiers = orderModifiers(mergeByName([].concat(defaultModifiers, state.options.modifiers))); // Strip out disabled modifiers - - state.orderedModifiers = orderedModifiers.filter(function (m) { - return m.enabled; - }); - runModifierEffects(); - return instance.update(); - }, - // Sync update – it will always be executed, even if not necessary. This - // is useful for low frequency updates where sync behavior simplifies the - // logic. - // For high frequency updates (e.g. `resize` and `scroll` events), always - // prefer the async Popper#update method - forceUpdate: function forceUpdate() { - if (isDestroyed) { - return; - } - - var _state$elements = state.elements, - reference = _state$elements.reference, - popper = _state$elements.popper; // Don't proceed if `reference` or `popper` are not valid elements - // anymore - - if (!areValidElements(reference, popper)) { - return; - } // Store the reference and popper rects to be read by modifiers - - - state.rects = { - reference: getCompositeRect(reference, getOffsetParent(popper), state.options.strategy === 'fixed'), - popper: getLayoutRect(popper) - }; // Modifiers have the ability to reset the current update cycle. The - // most common use case for this is the `flip` modifier changing the - // placement, which then needs to re-run all the modifiers, because the - // logic was previously ran for the previous placement and is therefore - // stale/incorrect - - state.reset = false; - state.placement = state.options.placement; // On each update cycle, the `modifiersData` property for each modifier - // is filled with the initial data specified by the modifier. This means - // it doesn't persist and is fresh on each update. - // To ensure persistent data, use `${name}#persistent` - - state.orderedModifiers.forEach(function (modifier) { - return state.modifiersData[modifier.name] = Object.assign({}, modifier.data); - }); - - for (var index = 0; index < state.orderedModifiers.length; index++) { - if (state.reset === true) { - state.reset = false; - index = -1; - continue; - } - - var _state$orderedModifie = state.orderedModifiers[index], - fn = _state$orderedModifie.fn, - _state$orderedModifie2 = _state$orderedModifie.options, - _options = _state$orderedModifie2 === void 0 ? {} : _state$orderedModifie2, - name = _state$orderedModifie.name; - - if (typeof fn === 'function') { - state = fn({ - state: state, - options: _options, - name: name, - instance: instance - }) || state; - } - } - }, - // Async and optimistically optimized update – it will not be executed if - // not necessary (debounced to run at most once-per-tick) - update: debounce(function () { - return new Promise(function (resolve) { - instance.forceUpdate(); - resolve(state); - }); - }), - destroy: function destroy() { - cleanupModifierEffects(); - isDestroyed = true; - } - }; - - if (!areValidElements(reference, popper)) { - return instance; - } - - instance.setOptions(options).then(function (state) { - if (!isDestroyed && options.onFirstUpdate) { - options.onFirstUpdate(state); - } - }); // Modifiers have the ability to execute arbitrary code before the first - // update cycle runs. They will be executed in the same order as the update - // cycle. This is useful when a modifier adds some persistent data that - // other modifiers need to use, but the modifier is run after the dependent - // one. - - function runModifierEffects() { - state.orderedModifiers.forEach(function (_ref) { - var name = _ref.name, - _ref$options = _ref.options, - options = _ref$options === void 0 ? {} : _ref$options, - effect = _ref.effect; - - if (typeof effect === 'function') { - var cleanupFn = effect({ - state: state, - name: name, - instance: instance, - options: options - }); - - var noopFn = function noopFn() {}; - - effectCleanupFns.push(cleanupFn || noopFn); - } - }); - } - - function cleanupModifierEffects() { - effectCleanupFns.forEach(function (fn) { - return fn(); - }); - effectCleanupFns = []; - } - - return instance; - }; - } - var createPopper$2 = /*#__PURE__*/popperGenerator(); // eslint-disable-next-line import/no-unused-modules - - var defaultModifiers$1 = [eventListeners, popperOffsets$1, computeStyles$1, applyStyles$1]; - var createPopper$1 = /*#__PURE__*/popperGenerator({ - defaultModifiers: defaultModifiers$1 - }); // eslint-disable-next-line import/no-unused-modules - - var defaultModifiers = [eventListeners, popperOffsets$1, computeStyles$1, applyStyles$1, offset$1, flip$1, preventOverflow$1, arrow$1, hide$1]; - var createPopper = /*#__PURE__*/popperGenerator({ - defaultModifiers: defaultModifiers - }); // eslint-disable-next-line import/no-unused-modules - - const Popper = /*#__PURE__*/Object.freeze(/*#__PURE__*/Object.defineProperty({ - __proto__: null, - afterMain, - afterRead, - afterWrite, - applyStyles: applyStyles$1, - arrow: arrow$1, - auto, - basePlacements, - beforeMain, - beforeRead, - beforeWrite, - bottom, - clippingParents, - computeStyles: computeStyles$1, - createPopper, - createPopperBase: createPopper$2, - createPopperLite: createPopper$1, - detectOverflow, - end, - eventListeners, - flip: flip$1, - hide: hide$1, - left, - main, - modifierPhases, - offset: offset$1, - placements, - popper, - popperGenerator, - popperOffsets: popperOffsets$1, - preventOverflow: preventOverflow$1, - read, - reference, - right, - start, - top, - variationPlacements, - viewport, - write - }, Symbol.toStringTag, { value: 'Module' })); - - /** - * -------------------------------------------------------------------------- - * Bootstrap dropdown.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$a = 'dropdown'; - const DATA_KEY$6 = 'bs.dropdown'; - const EVENT_KEY$6 = `.${DATA_KEY$6}`; - const DATA_API_KEY$3 = '.data-api'; - const ESCAPE_KEY$2 = 'Escape'; - const TAB_KEY$1 = 'Tab'; - const ARROW_UP_KEY$1 = 'ArrowUp'; - const ARROW_DOWN_KEY$1 = 'ArrowDown'; - const RIGHT_MOUSE_BUTTON = 2; // MouseEvent.button value for the secondary button, usually the right button - - const EVENT_HIDE$5 = `hide${EVENT_KEY$6}`; - const EVENT_HIDDEN$5 = `hidden${EVENT_KEY$6}`; - const EVENT_SHOW$5 = `show${EVENT_KEY$6}`; - const EVENT_SHOWN$5 = `shown${EVENT_KEY$6}`; - const EVENT_CLICK_DATA_API$3 = `click${EVENT_KEY$6}${DATA_API_KEY$3}`; - const EVENT_KEYDOWN_DATA_API = `keydown${EVENT_KEY$6}${DATA_API_KEY$3}`; - const EVENT_KEYUP_DATA_API = `keyup${EVENT_KEY$6}${DATA_API_KEY$3}`; - const CLASS_NAME_SHOW$6 = 'show'; - const CLASS_NAME_DROPUP = 'dropup'; - const CLASS_NAME_DROPEND = 'dropend'; - const CLASS_NAME_DROPSTART = 'dropstart'; - const CLASS_NAME_DROPUP_CENTER = 'dropup-center'; - const CLASS_NAME_DROPDOWN_CENTER = 'dropdown-center'; - const SELECTOR_DATA_TOGGLE$3 = '[data-bs-toggle="dropdown"]:not(.disabled):not(:disabled)'; - const SELECTOR_DATA_TOGGLE_SHOWN = `${SELECTOR_DATA_TOGGLE$3}.${CLASS_NAME_SHOW$6}`; - const SELECTOR_MENU = '.dropdown-menu'; - const SELECTOR_NAVBAR = '.navbar'; - const SELECTOR_NAVBAR_NAV = '.navbar-nav'; - const SELECTOR_VISIBLE_ITEMS = '.dropdown-menu .dropdown-item:not(.disabled):not(:disabled)'; - const PLACEMENT_TOP = isRTL() ? 'top-end' : 'top-start'; - const PLACEMENT_TOPEND = isRTL() ? 'top-start' : 'top-end'; - const PLACEMENT_BOTTOM = isRTL() ? 'bottom-end' : 'bottom-start'; - const PLACEMENT_BOTTOMEND = isRTL() ? 'bottom-start' : 'bottom-end'; - const PLACEMENT_RIGHT = isRTL() ? 'left-start' : 'right-start'; - const PLACEMENT_LEFT = isRTL() ? 'right-start' : 'left-start'; - const PLACEMENT_TOPCENTER = 'top'; - const PLACEMENT_BOTTOMCENTER = 'bottom'; - const Default$9 = { - autoClose: true, - boundary: 'clippingParents', - display: 'dynamic', - offset: [0, 2], - popperConfig: null, - reference: 'toggle' - }; - const DefaultType$9 = { - autoClose: '(boolean|string)', - boundary: '(string|element)', - display: 'string', - offset: '(array|string|function)', - popperConfig: '(null|object|function)', - reference: '(string|element|object)' - }; - - /** - * Class definition - */ - - class Dropdown extends BaseComponent { - constructor(element, config) { - super(element, config); - this._popper = null; - this._parent = this._element.parentNode; // dropdown wrapper - // TODO: v6 revert #37011 & change markup https://getbootstrap.com/docs/5.3/forms/input-group/ - this._menu = SelectorEngine.next(this._element, SELECTOR_MENU)[0] || SelectorEngine.prev(this._element, SELECTOR_MENU)[0] || SelectorEngine.findOne(SELECTOR_MENU, this._parent); - this._inNavbar = this._detectNavbar(); - } - - // Getters - static get Default() { - return Default$9; - } - static get DefaultType() { - return DefaultType$9; - } - static get NAME() { - return NAME$a; - } - - // Public - toggle() { - return this._isShown() ? this.hide() : this.show(); - } - show() { - if (isDisabled(this._element) || this._isShown()) { - return; - } - const relatedTarget = { - relatedTarget: this._element - }; - const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$5, relatedTarget); - if (showEvent.defaultPrevented) { - return; - } - this._createPopper(); - - // If this is a touch-enabled device we add extra - // empty mouseover listeners to the body's immediate children; - // only needed because of broken event delegation on iOS - // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html - if ('ontouchstart' in document.documentElement && !this._parent.closest(SELECTOR_NAVBAR_NAV)) { - for (const element of [].concat(...document.body.children)) { - EventHandler.on(element, 'mouseover', noop); - } - } - this._element.focus(); - this._element.setAttribute('aria-expanded', true); - this._menu.classList.add(CLASS_NAME_SHOW$6); - this._element.classList.add(CLASS_NAME_SHOW$6); - EventHandler.trigger(this._element, EVENT_SHOWN$5, relatedTarget); - } - hide() { - if (isDisabled(this._element) || !this._isShown()) { - return; - } - const relatedTarget = { - relatedTarget: this._element - }; - this._completeHide(relatedTarget); - } - dispose() { - if (this._popper) { - this._popper.destroy(); - } - super.dispose(); - } - update() { - this._inNavbar = this._detectNavbar(); - if (this._popper) { - this._popper.update(); - } - } - - // Private - _completeHide(relatedTarget) { - const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$5, relatedTarget); - if (hideEvent.defaultPrevented) { - return; - } - - // If this is a touch-enabled device we remove the extra - // empty mouseover listeners we added for iOS support - if ('ontouchstart' in document.documentElement) { - for (const element of [].concat(...document.body.children)) { - EventHandler.off(element, 'mouseover', noop); - } - } - if (this._popper) { - this._popper.destroy(); - } - this._menu.classList.remove(CLASS_NAME_SHOW$6); - this._element.classList.remove(CLASS_NAME_SHOW$6); - this._element.setAttribute('aria-expanded', 'false'); - Manipulator.removeDataAttribute(this._menu, 'popper'); - EventHandler.trigger(this._element, EVENT_HIDDEN$5, relatedTarget); - } - _getConfig(config) { - config = super._getConfig(config); - if (typeof config.reference === 'object' && !isElement$1(config.reference) && typeof config.reference.getBoundingClientRect !== 'function') { - // Popper virtual elements require a getBoundingClientRect method - throw new TypeError(`${NAME$a.toUpperCase()}: Option "reference" provided type "object" without a required "getBoundingClientRect" method.`); - } - return config; - } - _createPopper() { - if (typeof Popper === 'undefined') { - throw new TypeError('Bootstrap\'s dropdowns require Popper (https://popper.js.org)'); - } - let referenceElement = this._element; - if (this._config.reference === 'parent') { - referenceElement = this._parent; - } else if (isElement$1(this._config.reference)) { - referenceElement = getElement(this._config.reference); - } else if (typeof this._config.reference === 'object') { - referenceElement = this._config.reference; - } - const popperConfig = this._getPopperConfig(); - this._popper = createPopper(referenceElement, this._menu, popperConfig); - } - _isShown() { - return this._menu.classList.contains(CLASS_NAME_SHOW$6); - } - _getPlacement() { - const parentDropdown = this._parent; - if (parentDropdown.classList.contains(CLASS_NAME_DROPEND)) { - return PLACEMENT_RIGHT; - } - if (parentDropdown.classList.contains(CLASS_NAME_DROPSTART)) { - return PLACEMENT_LEFT; - } - if (parentDropdown.classList.contains(CLASS_NAME_DROPUP_CENTER)) { - return PLACEMENT_TOPCENTER; - } - if (parentDropdown.classList.contains(CLASS_NAME_DROPDOWN_CENTER)) { - return PLACEMENT_BOTTOMCENTER; - } - - // We need to trim the value because custom properties can also include spaces - const isEnd = getComputedStyle(this._menu).getPropertyValue('--bs-position').trim() === 'end'; - if (parentDropdown.classList.contains(CLASS_NAME_DROPUP)) { - return isEnd ? PLACEMENT_TOPEND : PLACEMENT_TOP; - } - return isEnd ? PLACEMENT_BOTTOMEND : PLACEMENT_BOTTOM; - } - _detectNavbar() { - return this._element.closest(SELECTOR_NAVBAR) !== null; - } - _getOffset() { - const { - offset - } = this._config; - if (typeof offset === 'string') { - return offset.split(',').map(value => Number.parseInt(value, 10)); - } - if (typeof offset === 'function') { - return popperData => offset(popperData, this._element); - } - return offset; - } - _getPopperConfig() { - const defaultBsPopperConfig = { - placement: this._getPlacement(), - modifiers: [{ - name: 'preventOverflow', - options: { - boundary: this._config.boundary - } - }, { - name: 'offset', - options: { - offset: this._getOffset() - } - }] - }; - - // Disable Popper if we have a static display or Dropdown is in Navbar - if (this._inNavbar || this._config.display === 'static') { - Manipulator.setDataAttribute(this._menu, 'popper', 'static'); // TODO: v6 remove - defaultBsPopperConfig.modifiers = [{ - name: 'applyStyles', - enabled: false - }]; - } - return { - ...defaultBsPopperConfig, - ...execute(this._config.popperConfig, [defaultBsPopperConfig]) - }; - } - _selectMenuItem({ - key, - target - }) { - const items = SelectorEngine.find(SELECTOR_VISIBLE_ITEMS, this._menu).filter(element => isVisible(element)); - if (!items.length) { - return; - } - - // if target isn't included in items (e.g. when expanding the dropdown) - // allow cycling to get the last item in case key equals ARROW_UP_KEY - getNextActiveElement(items, target, key === ARROW_DOWN_KEY$1, !items.includes(target)).focus(); - } - - // Static - static jQueryInterface(config) { - return this.each(function () { - const data = Dropdown.getOrCreateInstance(this, config); - if (typeof config !== 'string') { - return; - } - if (typeof data[config] === 'undefined') { - throw new TypeError(`No method named "${config}"`); - } - data[config](); - }); - } - static clearMenus(event) { - if (event.button === RIGHT_MOUSE_BUTTON || event.type === 'keyup' && event.key !== TAB_KEY$1) { - return; - } - const openToggles = SelectorEngine.find(SELECTOR_DATA_TOGGLE_SHOWN); - for (const toggle of openToggles) { - const context = Dropdown.getInstance(toggle); - if (!context || context._config.autoClose === false) { - continue; - } - const composedPath = event.composedPath(); - const isMenuTarget = composedPath.includes(context._menu); - if (composedPath.includes(context._element) || context._config.autoClose === 'inside' && !isMenuTarget || context._config.autoClose === 'outside' && isMenuTarget) { - continue; - } - - // Tab navigation through the dropdown menu or events from contained inputs shouldn't close the menu - if (context._menu.contains(event.target) && (event.type === 'keyup' && event.key === TAB_KEY$1 || /input|select|option|textarea|form/i.test(event.target.tagName))) { - continue; - } - const relatedTarget = { - relatedTarget: context._element - }; - if (event.type === 'click') { - relatedTarget.clickEvent = event; - } - context._completeHide(relatedTarget); - } - } - static dataApiKeydownHandler(event) { - // If not an UP | DOWN | ESCAPE key => not a dropdown command - // If input/textarea && if key is other than ESCAPE => not a dropdown command - - const isInput = /input|textarea/i.test(event.target.tagName); - const isEscapeEvent = event.key === ESCAPE_KEY$2; - const isUpOrDownEvent = [ARROW_UP_KEY$1, ARROW_DOWN_KEY$1].includes(event.key); - if (!isUpOrDownEvent && !isEscapeEvent) { - return; - } - if (isInput && !isEscapeEvent) { - return; - } - event.preventDefault(); - - // TODO: v6 revert #37011 & change markup https://getbootstrap.com/docs/5.3/forms/input-group/ - const getToggleButton = this.matches(SELECTOR_DATA_TOGGLE$3) ? this : SelectorEngine.prev(this, SELECTOR_DATA_TOGGLE$3)[0] || SelectorEngine.next(this, SELECTOR_DATA_TOGGLE$3)[0] || SelectorEngine.findOne(SELECTOR_DATA_TOGGLE$3, event.delegateTarget.parentNode); - const instance = Dropdown.getOrCreateInstance(getToggleButton); - if (isUpOrDownEvent) { - event.stopPropagation(); - instance.show(); - instance._selectMenuItem(event); - return; - } - if (instance._isShown()) { - // else is escape and we check if it is shown - event.stopPropagation(); - instance.hide(); - getToggleButton.focus(); - } - } - } - - /** - * Data API implementation - */ - - EventHandler.on(document, EVENT_KEYDOWN_DATA_API, SELECTOR_DATA_TOGGLE$3, Dropdown.dataApiKeydownHandler); - EventHandler.on(document, EVENT_KEYDOWN_DATA_API, SELECTOR_MENU, Dropdown.dataApiKeydownHandler); - EventHandler.on(document, EVENT_CLICK_DATA_API$3, Dropdown.clearMenus); - EventHandler.on(document, EVENT_KEYUP_DATA_API, Dropdown.clearMenus); - EventHandler.on(document, EVENT_CLICK_DATA_API$3, SELECTOR_DATA_TOGGLE$3, function (event) { - event.preventDefault(); - Dropdown.getOrCreateInstance(this).toggle(); - }); - - /** - * jQuery - */ - - defineJQueryPlugin(Dropdown); - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/backdrop.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$9 = 'backdrop'; - const CLASS_NAME_FADE$4 = 'fade'; - const CLASS_NAME_SHOW$5 = 'show'; - const EVENT_MOUSEDOWN = `mousedown.bs.${NAME$9}`; - const Default$8 = { - className: 'modal-backdrop', - clickCallback: null, - isAnimated: false, - isVisible: true, - // if false, we use the backdrop helper without adding any element to the dom - rootElement: 'body' // give the choice to place backdrop under different elements - }; - - const DefaultType$8 = { - className: 'string', - clickCallback: '(function|null)', - isAnimated: 'boolean', - isVisible: 'boolean', - rootElement: '(element|string)' - }; - - /** - * Class definition - */ - - class Backdrop extends Config { - constructor(config) { - super(); - this._config = this._getConfig(config); - this._isAppended = false; - this._element = null; - } - - // Getters - static get Default() { - return Default$8; - } - static get DefaultType() { - return DefaultType$8; - } - static get NAME() { - return NAME$9; - } - - // Public - show(callback) { - if (!this._config.isVisible) { - execute(callback); - return; - } - this._append(); - const element = this._getElement(); - if (this._config.isAnimated) { - reflow(element); - } - element.classList.add(CLASS_NAME_SHOW$5); - this._emulateAnimation(() => { - execute(callback); - }); - } - hide(callback) { - if (!this._config.isVisible) { - execute(callback); - return; - } - this._getElement().classList.remove(CLASS_NAME_SHOW$5); - this._emulateAnimation(() => { - this.dispose(); - execute(callback); - }); - } - dispose() { - if (!this._isAppended) { - return; - } - EventHandler.off(this._element, EVENT_MOUSEDOWN); - this._element.remove(); - this._isAppended = false; - } - - // Private - _getElement() { - if (!this._element) { - const backdrop = document.createElement('div'); - backdrop.className = this._config.className; - if (this._config.isAnimated) { - backdrop.classList.add(CLASS_NAME_FADE$4); - } - this._element = backdrop; - } - return this._element; - } - _configAfterMerge(config) { - // use getElement() with the default "body" to get a fresh Element on each instantiation - config.rootElement = getElement(config.rootElement); - return config; - } - _append() { - if (this._isAppended) { - return; - } - const element = this._getElement(); - this._config.rootElement.append(element); - EventHandler.on(element, EVENT_MOUSEDOWN, () => { - execute(this._config.clickCallback); - }); - this._isAppended = true; - } - _emulateAnimation(callback) { - executeAfterTransition(callback, this._getElement(), this._config.isAnimated); - } - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/focustrap.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$8 = 'focustrap'; - const DATA_KEY$5 = 'bs.focustrap'; - const EVENT_KEY$5 = `.${DATA_KEY$5}`; - const EVENT_FOCUSIN$2 = `focusin${EVENT_KEY$5}`; - const EVENT_KEYDOWN_TAB = `keydown.tab${EVENT_KEY$5}`; - const TAB_KEY = 'Tab'; - const TAB_NAV_FORWARD = 'forward'; - const TAB_NAV_BACKWARD = 'backward'; - const Default$7 = { - autofocus: true, - trapElement: null // The element to trap focus inside of - }; - - const DefaultType$7 = { - autofocus: 'boolean', - trapElement: 'element' - }; - - /** - * Class definition - */ - - class FocusTrap extends Config { - constructor(config) { - super(); - this._config = this._getConfig(config); - this._isActive = false; - this._lastTabNavDirection = null; - } - - // Getters - static get Default() { - return Default$7; - } - static get DefaultType() { - return DefaultType$7; - } - static get NAME() { - return NAME$8; - } - - // Public - activate() { - if (this._isActive) { - return; - } - if (this._config.autofocus) { - this._config.trapElement.focus(); - } - EventHandler.off(document, EVENT_KEY$5); // guard against infinite focus loop - EventHandler.on(document, EVENT_FOCUSIN$2, event => this._handleFocusin(event)); - EventHandler.on(document, EVENT_KEYDOWN_TAB, event => this._handleKeydown(event)); - this._isActive = true; - } - deactivate() { - if (!this._isActive) { - return; - } - this._isActive = false; - EventHandler.off(document, EVENT_KEY$5); - } - - // Private - _handleFocusin(event) { - const { - trapElement - } = this._config; - if (event.target === document || event.target === trapElement || trapElement.contains(event.target)) { - return; - } - const elements = SelectorEngine.focusableChildren(trapElement); - if (elements.length === 0) { - trapElement.focus(); - } else if (this._lastTabNavDirection === TAB_NAV_BACKWARD) { - elements[elements.length - 1].focus(); - } else { - elements[0].focus(); - } - } - _handleKeydown(event) { - if (event.key !== TAB_KEY) { - return; - } - this._lastTabNavDirection = event.shiftKey ? TAB_NAV_BACKWARD : TAB_NAV_FORWARD; - } - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/scrollBar.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const SELECTOR_FIXED_CONTENT = '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top'; - const SELECTOR_STICKY_CONTENT = '.sticky-top'; - const PROPERTY_PADDING = 'padding-right'; - const PROPERTY_MARGIN = 'margin-right'; - - /** - * Class definition - */ - - class ScrollBarHelper { - constructor() { - this._element = document.body; - } - - // Public - getWidth() { - // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes - const documentWidth = document.documentElement.clientWidth; - return Math.abs(window.innerWidth - documentWidth); - } - hide() { - const width = this.getWidth(); - this._disableOverFlow(); - // give padding to element to balance the hidden scrollbar width - this._setElementAttributes(this._element, PROPERTY_PADDING, calculatedValue => calculatedValue + width); - // trick: We adjust positive paddingRight and negative marginRight to sticky-top elements to keep showing fullwidth - this._setElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING, calculatedValue => calculatedValue + width); - this._setElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN, calculatedValue => calculatedValue - width); - } - reset() { - this._resetElementAttributes(this._element, 'overflow'); - this._resetElementAttributes(this._element, PROPERTY_PADDING); - this._resetElementAttributes(SELECTOR_FIXED_CONTENT, PROPERTY_PADDING); - this._resetElementAttributes(SELECTOR_STICKY_CONTENT, PROPERTY_MARGIN); - } - isOverflowing() { - return this.getWidth() > 0; - } - - // Private - _disableOverFlow() { - this._saveInitialAttribute(this._element, 'overflow'); - this._element.style.overflow = 'hidden'; - } - _setElementAttributes(selector, styleProperty, callback) { - const scrollbarWidth = this.getWidth(); - const manipulationCallBack = element => { - if (element !== this._element && window.innerWidth > element.clientWidth + scrollbarWidth) { - return; - } - this._saveInitialAttribute(element, styleProperty); - const calculatedValue = window.getComputedStyle(element).getPropertyValue(styleProperty); - element.style.setProperty(styleProperty, `${callback(Number.parseFloat(calculatedValue))}px`); - }; - this._applyManipulationCallback(selector, manipulationCallBack); - } - _saveInitialAttribute(element, styleProperty) { - const actualValue = element.style.getPropertyValue(styleProperty); - if (actualValue) { - Manipulator.setDataAttribute(element, styleProperty, actualValue); - } - } - _resetElementAttributes(selector, styleProperty) { - const manipulationCallBack = element => { - const value = Manipulator.getDataAttribute(element, styleProperty); - // We only want to remove the property if the value is `null`; the value can also be zero - if (value === null) { - element.style.removeProperty(styleProperty); - return; - } - Manipulator.removeDataAttribute(element, styleProperty); - element.style.setProperty(styleProperty, value); - }; - this._applyManipulationCallback(selector, manipulationCallBack); - } - _applyManipulationCallback(selector, callBack) { - if (isElement$1(selector)) { - callBack(selector); - return; - } - for (const sel of SelectorEngine.find(selector, this._element)) { - callBack(sel); - } - } - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap modal.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$7 = 'modal'; - const DATA_KEY$4 = 'bs.modal'; - const EVENT_KEY$4 = `.${DATA_KEY$4}`; - const DATA_API_KEY$2 = '.data-api'; - const ESCAPE_KEY$1 = 'Escape'; - const EVENT_HIDE$4 = `hide${EVENT_KEY$4}`; - const EVENT_HIDE_PREVENTED$1 = `hidePrevented${EVENT_KEY$4}`; - const EVENT_HIDDEN$4 = `hidden${EVENT_KEY$4}`; - const EVENT_SHOW$4 = `show${EVENT_KEY$4}`; - const EVENT_SHOWN$4 = `shown${EVENT_KEY$4}`; - const EVENT_RESIZE$1 = `resize${EVENT_KEY$4}`; - const EVENT_CLICK_DISMISS = `click.dismiss${EVENT_KEY$4}`; - const EVENT_MOUSEDOWN_DISMISS = `mousedown.dismiss${EVENT_KEY$4}`; - const EVENT_KEYDOWN_DISMISS$1 = `keydown.dismiss${EVENT_KEY$4}`; - const EVENT_CLICK_DATA_API$2 = `click${EVENT_KEY$4}${DATA_API_KEY$2}`; - const CLASS_NAME_OPEN = 'modal-open'; - const CLASS_NAME_FADE$3 = 'fade'; - const CLASS_NAME_SHOW$4 = 'show'; - const CLASS_NAME_STATIC = 'modal-static'; - const OPEN_SELECTOR$1 = '.modal.show'; - const SELECTOR_DIALOG = '.modal-dialog'; - const SELECTOR_MODAL_BODY = '.modal-body'; - const SELECTOR_DATA_TOGGLE$2 = '[data-bs-toggle="modal"]'; - const Default$6 = { - backdrop: true, - focus: true, - keyboard: true - }; - const DefaultType$6 = { - backdrop: '(boolean|string)', - focus: 'boolean', - keyboard: 'boolean' - }; - - /** - * Class definition - */ - - class Modal extends BaseComponent { - constructor(element, config) { - super(element, config); - this._dialog = SelectorEngine.findOne(SELECTOR_DIALOG, this._element); - this._backdrop = this._initializeBackDrop(); - this._focustrap = this._initializeFocusTrap(); - this._isShown = false; - this._isTransitioning = false; - this._scrollBar = new ScrollBarHelper(); - this._addEventListeners(); - } - - // Getters - static get Default() { - return Default$6; - } - static get DefaultType() { - return DefaultType$6; - } - static get NAME() { - return NAME$7; - } - - // Public - toggle(relatedTarget) { - return this._isShown ? this.hide() : this.show(relatedTarget); - } - show(relatedTarget) { - if (this._isShown || this._isTransitioning) { - return; - } - const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$4, { - relatedTarget - }); - if (showEvent.defaultPrevented) { - return; - } - this._isShown = true; - this._isTransitioning = true; - this._scrollBar.hide(); - document.body.classList.add(CLASS_NAME_OPEN); - this._adjustDialog(); - this._backdrop.show(() => this._showElement(relatedTarget)); - } - hide() { - if (!this._isShown || this._isTransitioning) { - return; - } - const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$4); - if (hideEvent.defaultPrevented) { - return; - } - this._isShown = false; - this._isTransitioning = true; - this._focustrap.deactivate(); - this._element.classList.remove(CLASS_NAME_SHOW$4); - this._queueCallback(() => this._hideModal(), this._element, this._isAnimated()); - } - dispose() { - EventHandler.off(window, EVENT_KEY$4); - EventHandler.off(this._dialog, EVENT_KEY$4); - this._backdrop.dispose(); - this._focustrap.deactivate(); - super.dispose(); - } - handleUpdate() { - this._adjustDialog(); - } - - // Private - _initializeBackDrop() { - return new Backdrop({ - isVisible: Boolean(this._config.backdrop), - // 'static' option will be translated to true, and booleans will keep their value, - isAnimated: this._isAnimated() - }); - } - _initializeFocusTrap() { - return new FocusTrap({ - trapElement: this._element - }); - } - _showElement(relatedTarget) { - // try to append dynamic modal - if (!document.body.contains(this._element)) { - document.body.append(this._element); - } - this._element.style.display = 'block'; - this._element.removeAttribute('aria-hidden'); - this._element.setAttribute('aria-modal', true); - this._element.setAttribute('role', 'dialog'); - this._element.scrollTop = 0; - const modalBody = SelectorEngine.findOne(SELECTOR_MODAL_BODY, this._dialog); - if (modalBody) { - modalBody.scrollTop = 0; - } - reflow(this._element); - this._element.classList.add(CLASS_NAME_SHOW$4); - const transitionComplete = () => { - if (this._config.focus) { - this._focustrap.activate(); - } - this._isTransitioning = false; - EventHandler.trigger(this._element, EVENT_SHOWN$4, { - relatedTarget - }); - }; - this._queueCallback(transitionComplete, this._dialog, this._isAnimated()); - } - _addEventListeners() { - EventHandler.on(this._element, EVENT_KEYDOWN_DISMISS$1, event => { - if (event.key !== ESCAPE_KEY$1) { - return; - } - if (this._config.keyboard) { - this.hide(); - return; - } - this._triggerBackdropTransition(); - }); - EventHandler.on(window, EVENT_RESIZE$1, () => { - if (this._isShown && !this._isTransitioning) { - this._adjustDialog(); - } - }); - EventHandler.on(this._element, EVENT_MOUSEDOWN_DISMISS, event => { - // a bad trick to segregate clicks that may start inside dialog but end outside, and avoid listen to scrollbar clicks - EventHandler.one(this._element, EVENT_CLICK_DISMISS, event2 => { - if (this._element !== event.target || this._element !== event2.target) { - return; - } - if (this._config.backdrop === 'static') { - this._triggerBackdropTransition(); - return; - } - if (this._config.backdrop) { - this.hide(); - } - }); - }); - } - _hideModal() { - this._element.style.display = 'none'; - this._element.setAttribute('aria-hidden', true); - this._element.removeAttribute('aria-modal'); - this._element.removeAttribute('role'); - this._isTransitioning = false; - this._backdrop.hide(() => { - document.body.classList.remove(CLASS_NAME_OPEN); - this._resetAdjustments(); - this._scrollBar.reset(); - EventHandler.trigger(this._element, EVENT_HIDDEN$4); - }); - } - _isAnimated() { - return this._element.classList.contains(CLASS_NAME_FADE$3); - } - _triggerBackdropTransition() { - const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED$1); - if (hideEvent.defaultPrevented) { - return; - } - const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; - const initialOverflowY = this._element.style.overflowY; - // return if the following background transition hasn't yet completed - if (initialOverflowY === 'hidden' || this._element.classList.contains(CLASS_NAME_STATIC)) { - return; - } - if (!isModalOverflowing) { - this._element.style.overflowY = 'hidden'; - } - this._element.classList.add(CLASS_NAME_STATIC); - this._queueCallback(() => { - this._element.classList.remove(CLASS_NAME_STATIC); - this._queueCallback(() => { - this._element.style.overflowY = initialOverflowY; - }, this._dialog); - }, this._dialog); - this._element.focus(); - } - - /** - * The following methods are used to handle overflowing modals - */ - - _adjustDialog() { - const isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight; - const scrollbarWidth = this._scrollBar.getWidth(); - const isBodyOverflowing = scrollbarWidth > 0; - if (isBodyOverflowing && !isModalOverflowing) { - const property = isRTL() ? 'paddingLeft' : 'paddingRight'; - this._element.style[property] = `${scrollbarWidth}px`; - } - if (!isBodyOverflowing && isModalOverflowing) { - const property = isRTL() ? 'paddingRight' : 'paddingLeft'; - this._element.style[property] = `${scrollbarWidth}px`; - } - } - _resetAdjustments() { - this._element.style.paddingLeft = ''; - this._element.style.paddingRight = ''; - } - - // Static - static jQueryInterface(config, relatedTarget) { - return this.each(function () { - const data = Modal.getOrCreateInstance(this, config); - if (typeof config !== 'string') { - return; - } - if (typeof data[config] === 'undefined') { - throw new TypeError(`No method named "${config}"`); - } - data[config](relatedTarget); - }); - } - } - - /** - * Data API implementation - */ - - EventHandler.on(document, EVENT_CLICK_DATA_API$2, SELECTOR_DATA_TOGGLE$2, function (event) { - const target = SelectorEngine.getElementFromSelector(this); - if (['A', 'AREA'].includes(this.tagName)) { - event.preventDefault(); - } - EventHandler.one(target, EVENT_SHOW$4, showEvent => { - if (showEvent.defaultPrevented) { - // only register focus restorer if modal will actually get shown - return; - } - EventHandler.one(target, EVENT_HIDDEN$4, () => { - if (isVisible(this)) { - this.focus(); - } - }); - }); - - // avoid conflict when clicking modal toggler while another one is open - const alreadyOpen = SelectorEngine.findOne(OPEN_SELECTOR$1); - if (alreadyOpen) { - Modal.getInstance(alreadyOpen).hide(); - } - const data = Modal.getOrCreateInstance(target); - data.toggle(this); - }); - enableDismissTrigger(Modal); - - /** - * jQuery - */ - - defineJQueryPlugin(Modal); - - /** - * -------------------------------------------------------------------------- - * Bootstrap offcanvas.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$6 = 'offcanvas'; - const DATA_KEY$3 = 'bs.offcanvas'; - const EVENT_KEY$3 = `.${DATA_KEY$3}`; - const DATA_API_KEY$1 = '.data-api'; - const EVENT_LOAD_DATA_API$2 = `load${EVENT_KEY$3}${DATA_API_KEY$1}`; - const ESCAPE_KEY = 'Escape'; - const CLASS_NAME_SHOW$3 = 'show'; - const CLASS_NAME_SHOWING$1 = 'showing'; - const CLASS_NAME_HIDING = 'hiding'; - const CLASS_NAME_BACKDROP = 'offcanvas-backdrop'; - const OPEN_SELECTOR = '.offcanvas.show'; - const EVENT_SHOW$3 = `show${EVENT_KEY$3}`; - const EVENT_SHOWN$3 = `shown${EVENT_KEY$3}`; - const EVENT_HIDE$3 = `hide${EVENT_KEY$3}`; - const EVENT_HIDE_PREVENTED = `hidePrevented${EVENT_KEY$3}`; - const EVENT_HIDDEN$3 = `hidden${EVENT_KEY$3}`; - const EVENT_RESIZE = `resize${EVENT_KEY$3}`; - const EVENT_CLICK_DATA_API$1 = `click${EVENT_KEY$3}${DATA_API_KEY$1}`; - const EVENT_KEYDOWN_DISMISS = `keydown.dismiss${EVENT_KEY$3}`; - const SELECTOR_DATA_TOGGLE$1 = '[data-bs-toggle="offcanvas"]'; - const Default$5 = { - backdrop: true, - keyboard: true, - scroll: false - }; - const DefaultType$5 = { - backdrop: '(boolean|string)', - keyboard: 'boolean', - scroll: 'boolean' - }; - - /** - * Class definition - */ - - class Offcanvas extends BaseComponent { - constructor(element, config) { - super(element, config); - this._isShown = false; - this._backdrop = this._initializeBackDrop(); - this._focustrap = this._initializeFocusTrap(); - this._addEventListeners(); - } - - // Getters - static get Default() { - return Default$5; - } - static get DefaultType() { - return DefaultType$5; - } - static get NAME() { - return NAME$6; - } - - // Public - toggle(relatedTarget) { - return this._isShown ? this.hide() : this.show(relatedTarget); - } - show(relatedTarget) { - if (this._isShown) { - return; - } - const showEvent = EventHandler.trigger(this._element, EVENT_SHOW$3, { - relatedTarget - }); - if (showEvent.defaultPrevented) { - return; - } - this._isShown = true; - this._backdrop.show(); - if (!this._config.scroll) { - new ScrollBarHelper().hide(); - } - this._element.setAttribute('aria-modal', true); - this._element.setAttribute('role', 'dialog'); - this._element.classList.add(CLASS_NAME_SHOWING$1); - const completeCallBack = () => { - if (!this._config.scroll || this._config.backdrop) { - this._focustrap.activate(); - } - this._element.classList.add(CLASS_NAME_SHOW$3); - this._element.classList.remove(CLASS_NAME_SHOWING$1); - EventHandler.trigger(this._element, EVENT_SHOWN$3, { - relatedTarget - }); - }; - this._queueCallback(completeCallBack, this._element, true); - } - hide() { - if (!this._isShown) { - return; - } - const hideEvent = EventHandler.trigger(this._element, EVENT_HIDE$3); - if (hideEvent.defaultPrevented) { - return; - } - this._focustrap.deactivate(); - this._element.blur(); - this._isShown = false; - this._element.classList.add(CLASS_NAME_HIDING); - this._backdrop.hide(); - const completeCallback = () => { - this._element.classList.remove(CLASS_NAME_SHOW$3, CLASS_NAME_HIDING); - this._element.removeAttribute('aria-modal'); - this._element.removeAttribute('role'); - if (!this._config.scroll) { - new ScrollBarHelper().reset(); - } - EventHandler.trigger(this._element, EVENT_HIDDEN$3); - }; - this._queueCallback(completeCallback, this._element, true); - } - dispose() { - this._backdrop.dispose(); - this._focustrap.deactivate(); - super.dispose(); - } - - // Private - _initializeBackDrop() { - const clickCallback = () => { - if (this._config.backdrop === 'static') { - EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED); - return; - } - this.hide(); - }; - - // 'static' option will be translated to true, and booleans will keep their value - const isVisible = Boolean(this._config.backdrop); - return new Backdrop({ - className: CLASS_NAME_BACKDROP, - isVisible, - isAnimated: true, - rootElement: this._element.parentNode, - clickCallback: isVisible ? clickCallback : null - }); - } - _initializeFocusTrap() { - return new FocusTrap({ - trapElement: this._element - }); - } - _addEventListeners() { - EventHandler.on(this._element, EVENT_KEYDOWN_DISMISS, event => { - if (event.key !== ESCAPE_KEY) { - return; - } - if (this._config.keyboard) { - this.hide(); - return; - } - EventHandler.trigger(this._element, EVENT_HIDE_PREVENTED); - }); - } - - // Static - static jQueryInterface(config) { - return this.each(function () { - const data = Offcanvas.getOrCreateInstance(this, config); - if (typeof config !== 'string') { - return; - } - if (data[config] === undefined || config.startsWith('_') || config === 'constructor') { - throw new TypeError(`No method named "${config}"`); - } - data[config](this); - }); - } - } - - /** - * Data API implementation - */ - - EventHandler.on(document, EVENT_CLICK_DATA_API$1, SELECTOR_DATA_TOGGLE$1, function (event) { - const target = SelectorEngine.getElementFromSelector(this); - if (['A', 'AREA'].includes(this.tagName)) { - event.preventDefault(); - } - if (isDisabled(this)) { - return; - } - EventHandler.one(target, EVENT_HIDDEN$3, () => { - // focus on trigger when it is closed - if (isVisible(this)) { - this.focus(); - } - }); - - // avoid conflict when clicking a toggler of an offcanvas, while another is open - const alreadyOpen = SelectorEngine.findOne(OPEN_SELECTOR); - if (alreadyOpen && alreadyOpen !== target) { - Offcanvas.getInstance(alreadyOpen).hide(); - } - const data = Offcanvas.getOrCreateInstance(target); - data.toggle(this); - }); - EventHandler.on(window, EVENT_LOAD_DATA_API$2, () => { - for (const selector of SelectorEngine.find(OPEN_SELECTOR)) { - Offcanvas.getOrCreateInstance(selector).show(); - } - }); - EventHandler.on(window, EVENT_RESIZE, () => { - for (const element of SelectorEngine.find('[aria-modal][class*=show][class*=offcanvas-]')) { - if (getComputedStyle(element).position !== 'fixed') { - Offcanvas.getOrCreateInstance(element).hide(); - } - } - }); - enableDismissTrigger(Offcanvas); - - /** - * jQuery - */ - - defineJQueryPlugin(Offcanvas); - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/sanitizer.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - // js-docs-start allow-list - const ARIA_ATTRIBUTE_PATTERN = /^aria-[\w-]*$/i; - const DefaultAllowlist = { - // Global attributes allowed on any supplied element below. - '*': ['class', 'dir', 'id', 'lang', 'role', ARIA_ATTRIBUTE_PATTERN], - a: ['target', 'href', 'title', 'rel'], - area: [], - b: [], - br: [], - col: [], - code: [], - div: [], - em: [], - hr: [], - h1: [], - h2: [], - h3: [], - h4: [], - h5: [], - h6: [], - i: [], - img: ['src', 'srcset', 'alt', 'title', 'width', 'height'], - li: [], - ol: [], - p: [], - pre: [], - s: [], - small: [], - span: [], - sub: [], - sup: [], - strong: [], - u: [], - ul: [] - }; - // js-docs-end allow-list - - const uriAttributes = new Set(['background', 'cite', 'href', 'itemtype', 'longdesc', 'poster', 'src', 'xlink:href']); - - /** - * A pattern that recognizes URLs that are safe wrt. XSS in URL navigation - * contexts. - * - * Shout-out to Angular https://github.com/angular/angular/blob/15.2.8/packages/core/src/sanitization/url_sanitizer.ts#L38 - */ - // eslint-disable-next-line unicorn/better-regex - const SAFE_URL_PATTERN = /^(?!javascript:)(?:[a-z0-9+.-]+:|[^&:/?#]*(?:[/?#]|$))/i; - const allowedAttribute = (attribute, allowedAttributeList) => { - const attributeName = attribute.nodeName.toLowerCase(); - if (allowedAttributeList.includes(attributeName)) { - if (uriAttributes.has(attributeName)) { - return Boolean(SAFE_URL_PATTERN.test(attribute.nodeValue)); - } - return true; - } - - // Check if a regular expression validates the attribute. - return allowedAttributeList.filter(attributeRegex => attributeRegex instanceof RegExp).some(regex => regex.test(attributeName)); - }; - function sanitizeHtml(unsafeHtml, allowList, sanitizeFunction) { - if (!unsafeHtml.length) { - return unsafeHtml; - } - if (sanitizeFunction && typeof sanitizeFunction === 'function') { - return sanitizeFunction(unsafeHtml); - } - const domParser = new window.DOMParser(); - const createdDocument = domParser.parseFromString(unsafeHtml, 'text/html'); - const elements = [].concat(...createdDocument.body.querySelectorAll('*')); - for (const element of elements) { - const elementName = element.nodeName.toLowerCase(); - if (!Object.keys(allowList).includes(elementName)) { - element.remove(); - continue; - } - const attributeList = [].concat(...element.attributes); - const allowedAttributes = [].concat(allowList['*'] || [], allowList[elementName] || []); - for (const attribute of attributeList) { - if (!allowedAttribute(attribute, allowedAttributes)) { - element.removeAttribute(attribute.nodeName); - } - } - } - return createdDocument.body.innerHTML; - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap util/template-factory.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$5 = 'TemplateFactory'; - const Default$4 = { - allowList: DefaultAllowlist, - content: {}, - // { selector : text , selector2 : text2 , } - extraClass: '', - html: false, - sanitize: true, - sanitizeFn: null, - template: '
' - }; - const DefaultType$4 = { - allowList: 'object', - content: 'object', - extraClass: '(string|function)', - html: 'boolean', - sanitize: 'boolean', - sanitizeFn: '(null|function)', - template: 'string' - }; - const DefaultContentType = { - entry: '(string|element|function|null)', - selector: '(string|element)' - }; - - /** - * Class definition - */ - - class TemplateFactory extends Config { - constructor(config) { - super(); - this._config = this._getConfig(config); - } - - // Getters - static get Default() { - return Default$4; - } - static get DefaultType() { - return DefaultType$4; - } - static get NAME() { - return NAME$5; - } - - // Public - getContent() { - return Object.values(this._config.content).map(config => this._resolvePossibleFunction(config)).filter(Boolean); - } - hasContent() { - return this.getContent().length > 0; - } - changeContent(content) { - this._checkContent(content); - this._config.content = { - ...this._config.content, - ...content - }; - return this; - } - toHtml() { - const templateWrapper = document.createElement('div'); - templateWrapper.innerHTML = this._maybeSanitize(this._config.template); - for (const [selector, text] of Object.entries(this._config.content)) { - this._setContent(templateWrapper, text, selector); - } - const template = templateWrapper.children[0]; - const extraClass = this._resolvePossibleFunction(this._config.extraClass); - if (extraClass) { - template.classList.add(...extraClass.split(' ')); - } - return template; - } - - // Private - _typeCheckConfig(config) { - super._typeCheckConfig(config); - this._checkContent(config.content); - } - _checkContent(arg) { - for (const [selector, content] of Object.entries(arg)) { - super._typeCheckConfig({ - selector, - entry: content - }, DefaultContentType); - } - } - _setContent(template, content, selector) { - const templateElement = SelectorEngine.findOne(selector, template); - if (!templateElement) { - return; - } - content = this._resolvePossibleFunction(content); - if (!content) { - templateElement.remove(); - return; - } - if (isElement$1(content)) { - this._putElementInTemplate(getElement(content), templateElement); - return; - } - if (this._config.html) { - templateElement.innerHTML = this._maybeSanitize(content); - return; - } - templateElement.textContent = content; - } - _maybeSanitize(arg) { - return this._config.sanitize ? sanitizeHtml(arg, this._config.allowList, this._config.sanitizeFn) : arg; - } - _resolvePossibleFunction(arg) { - return execute(arg, [this]); - } - _putElementInTemplate(element, templateElement) { - if (this._config.html) { - templateElement.innerHTML = ''; - templateElement.append(element); - return; - } - templateElement.textContent = element.textContent; - } - } - - /** - * -------------------------------------------------------------------------- - * Bootstrap tooltip.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$4 = 'tooltip'; - const DISALLOWED_ATTRIBUTES = new Set(['sanitize', 'allowList', 'sanitizeFn']); - const CLASS_NAME_FADE$2 = 'fade'; - const CLASS_NAME_MODAL = 'modal'; - const CLASS_NAME_SHOW$2 = 'show'; - const SELECTOR_TOOLTIP_INNER = '.tooltip-inner'; - const SELECTOR_MODAL = `.${CLASS_NAME_MODAL}`; - const EVENT_MODAL_HIDE = 'hide.bs.modal'; - const TRIGGER_HOVER = 'hover'; - const TRIGGER_FOCUS = 'focus'; - const TRIGGER_CLICK = 'click'; - const TRIGGER_MANUAL = 'manual'; - const EVENT_HIDE$2 = 'hide'; - const EVENT_HIDDEN$2 = 'hidden'; - const EVENT_SHOW$2 = 'show'; - const EVENT_SHOWN$2 = 'shown'; - const EVENT_INSERTED = 'inserted'; - const EVENT_CLICK$1 = 'click'; - const EVENT_FOCUSIN$1 = 'focusin'; - const EVENT_FOCUSOUT$1 = 'focusout'; - const EVENT_MOUSEENTER = 'mouseenter'; - const EVENT_MOUSELEAVE = 'mouseleave'; - const AttachmentMap = { - AUTO: 'auto', - TOP: 'top', - RIGHT: isRTL() ? 'left' : 'right', - BOTTOM: 'bottom', - LEFT: isRTL() ? 'right' : 'left' - }; - const Default$3 = { - allowList: DefaultAllowlist, - animation: true, - boundary: 'clippingParents', - container: false, - customClass: '', - delay: 0, - fallbackPlacements: ['top', 'right', 'bottom', 'left'], - html: false, - offset: [0, 6], - placement: 'top', - popperConfig: null, - sanitize: true, - sanitizeFn: null, - selector: false, - template: '', - title: '', - trigger: 'hover focus' - }; - const DefaultType$3 = { - allowList: 'object', - animation: 'boolean', - boundary: '(string|element)', - container: '(string|element|boolean)', - customClass: '(string|function)', - delay: '(number|object)', - fallbackPlacements: 'array', - html: 'boolean', - offset: '(array|string|function)', - placement: '(string|function)', - popperConfig: '(null|object|function)', - sanitize: 'boolean', - sanitizeFn: '(null|function)', - selector: '(string|boolean)', - template: 'string', - title: '(string|element|function)', - trigger: 'string' - }; - - /** - * Class definition - */ - - class Tooltip extends BaseComponent { - constructor(element, config) { - if (typeof Popper === 'undefined') { - throw new TypeError('Bootstrap\'s tooltips require Popper (https://popper.js.org)'); - } - super(element, config); - - // Private - this._isEnabled = true; - this._timeout = 0; - this._isHovered = null; - this._activeTrigger = {}; - this._popper = null; - this._templateFactory = null; - this._newContent = null; - - // Protected - this.tip = null; - this._setListeners(); - if (!this._config.selector) { - this._fixTitle(); - } - } - - // Getters - static get Default() { - return Default$3; - } - static get DefaultType() { - return DefaultType$3; - } - static get NAME() { - return NAME$4; - } - - // Public - enable() { - this._isEnabled = true; - } - disable() { - this._isEnabled = false; - } - toggleEnabled() { - this._isEnabled = !this._isEnabled; - } - toggle() { - if (!this._isEnabled) { - return; - } - this._activeTrigger.click = !this._activeTrigger.click; - if (this._isShown()) { - this._leave(); - return; - } - this._enter(); - } - dispose() { - clearTimeout(this._timeout); - EventHandler.off(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler); - if (this._element.getAttribute('data-bs-original-title')) { - this._element.setAttribute('title', this._element.getAttribute('data-bs-original-title')); - } - this._disposePopper(); - super.dispose(); - } - show() { - if (this._element.style.display === 'none') { - throw new Error('Please use show on visible elements'); - } - if (!(this._isWithContent() && this._isEnabled)) { - return; - } - const showEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOW$2)); - const shadowRoot = findShadowRoot(this._element); - const isInTheDom = (shadowRoot || this._element.ownerDocument.documentElement).contains(this._element); - if (showEvent.defaultPrevented || !isInTheDom) { - return; - } - - // TODO: v6 remove this or make it optional - this._disposePopper(); - const tip = this._getTipElement(); - this._element.setAttribute('aria-describedby', tip.getAttribute('id')); - const { - container - } = this._config; - if (!this._element.ownerDocument.documentElement.contains(this.tip)) { - container.append(tip); - EventHandler.trigger(this._element, this.constructor.eventName(EVENT_INSERTED)); - } - this._popper = this._createPopper(tip); - tip.classList.add(CLASS_NAME_SHOW$2); - - // If this is a touch-enabled device we add extra - // empty mouseover listeners to the body's immediate children; - // only needed because of broken event delegation on iOS - // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html - if ('ontouchstart' in document.documentElement) { - for (const element of [].concat(...document.body.children)) { - EventHandler.on(element, 'mouseover', noop); - } - } - const complete = () => { - EventHandler.trigger(this._element, this.constructor.eventName(EVENT_SHOWN$2)); - if (this._isHovered === false) { - this._leave(); - } - this._isHovered = false; - }; - this._queueCallback(complete, this.tip, this._isAnimated()); - } - hide() { - if (!this._isShown()) { - return; - } - const hideEvent = EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDE$2)); - if (hideEvent.defaultPrevented) { - return; - } - const tip = this._getTipElement(); - tip.classList.remove(CLASS_NAME_SHOW$2); - - // If this is a touch-enabled device we remove the extra - // empty mouseover listeners we added for iOS support - if ('ontouchstart' in document.documentElement) { - for (const element of [].concat(...document.body.children)) { - EventHandler.off(element, 'mouseover', noop); - } - } - this._activeTrigger[TRIGGER_CLICK] = false; - this._activeTrigger[TRIGGER_FOCUS] = false; - this._activeTrigger[TRIGGER_HOVER] = false; - this._isHovered = null; // it is a trick to support manual triggering - - const complete = () => { - if (this._isWithActiveTrigger()) { - return; - } - if (!this._isHovered) { - this._disposePopper(); - } - this._element.removeAttribute('aria-describedby'); - EventHandler.trigger(this._element, this.constructor.eventName(EVENT_HIDDEN$2)); - }; - this._queueCallback(complete, this.tip, this._isAnimated()); - } - update() { - if (this._popper) { - this._popper.update(); - } - } - - // Protected - _isWithContent() { - return Boolean(this._getTitle()); - } - _getTipElement() { - if (!this.tip) { - this.tip = this._createTipElement(this._newContent || this._getContentForTemplate()); - } - return this.tip; - } - _createTipElement(content) { - const tip = this._getTemplateFactory(content).toHtml(); - - // TODO: remove this check in v6 - if (!tip) { - return null; - } - tip.classList.remove(CLASS_NAME_FADE$2, CLASS_NAME_SHOW$2); - // TODO: v6 the following can be achieved with CSS only - tip.classList.add(`bs-${this.constructor.NAME}-auto`); - const tipId = getUID(this.constructor.NAME).toString(); - tip.setAttribute('id', tipId); - if (this._isAnimated()) { - tip.classList.add(CLASS_NAME_FADE$2); - } - return tip; - } - setContent(content) { - this._newContent = content; - if (this._isShown()) { - this._disposePopper(); - this.show(); - } - } - _getTemplateFactory(content) { - if (this._templateFactory) { - this._templateFactory.changeContent(content); - } else { - this._templateFactory = new TemplateFactory({ - ...this._config, - // the `content` var has to be after `this._config` - // to override config.content in case of popover - content, - extraClass: this._resolvePossibleFunction(this._config.customClass) - }); - } - return this._templateFactory; - } - _getContentForTemplate() { - return { - [SELECTOR_TOOLTIP_INNER]: this._getTitle() - }; - } - _getTitle() { - return this._resolvePossibleFunction(this._config.title) || this._element.getAttribute('data-bs-original-title'); - } - - // Private - _initializeOnDelegatedTarget(event) { - return this.constructor.getOrCreateInstance(event.delegateTarget, this._getDelegateConfig()); - } - _isAnimated() { - return this._config.animation || this.tip && this.tip.classList.contains(CLASS_NAME_FADE$2); - } - _isShown() { - return this.tip && this.tip.classList.contains(CLASS_NAME_SHOW$2); - } - _createPopper(tip) { - const placement = execute(this._config.placement, [this, tip, this._element]); - const attachment = AttachmentMap[placement.toUpperCase()]; - return createPopper(this._element, tip, this._getPopperConfig(attachment)); - } - _getOffset() { - const { - offset - } = this._config; - if (typeof offset === 'string') { - return offset.split(',').map(value => Number.parseInt(value, 10)); - } - if (typeof offset === 'function') { - return popperData => offset(popperData, this._element); - } - return offset; - } - _resolvePossibleFunction(arg) { - return execute(arg, [this._element]); - } - _getPopperConfig(attachment) { - const defaultBsPopperConfig = { - placement: attachment, - modifiers: [{ - name: 'flip', - options: { - fallbackPlacements: this._config.fallbackPlacements - } - }, { - name: 'offset', - options: { - offset: this._getOffset() - } - }, { - name: 'preventOverflow', - options: { - boundary: this._config.boundary - } - }, { - name: 'arrow', - options: { - element: `.${this.constructor.NAME}-arrow` - } - }, { - name: 'preSetPlacement', - enabled: true, - phase: 'beforeMain', - fn: data => { - // Pre-set Popper's placement attribute in order to read the arrow sizes properly. - // Otherwise, Popper mixes up the width and height dimensions since the initial arrow style is for top placement - this._getTipElement().setAttribute('data-popper-placement', data.state.placement); - } - }] - }; - return { - ...defaultBsPopperConfig, - ...execute(this._config.popperConfig, [defaultBsPopperConfig]) - }; - } - _setListeners() { - const triggers = this._config.trigger.split(' '); - for (const trigger of triggers) { - if (trigger === 'click') { - EventHandler.on(this._element, this.constructor.eventName(EVENT_CLICK$1), this._config.selector, event => { - const context = this._initializeOnDelegatedTarget(event); - context.toggle(); - }); - } else if (trigger !== TRIGGER_MANUAL) { - const eventIn = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSEENTER) : this.constructor.eventName(EVENT_FOCUSIN$1); - const eventOut = trigger === TRIGGER_HOVER ? this.constructor.eventName(EVENT_MOUSELEAVE) : this.constructor.eventName(EVENT_FOCUSOUT$1); - EventHandler.on(this._element, eventIn, this._config.selector, event => { - const context = this._initializeOnDelegatedTarget(event); - context._activeTrigger[event.type === 'focusin' ? TRIGGER_FOCUS : TRIGGER_HOVER] = true; - context._enter(); - }); - EventHandler.on(this._element, eventOut, this._config.selector, event => { - const context = this._initializeOnDelegatedTarget(event); - context._activeTrigger[event.type === 'focusout' ? TRIGGER_FOCUS : TRIGGER_HOVER] = context._element.contains(event.relatedTarget); - context._leave(); - }); - } - } - this._hideModalHandler = () => { - if (this._element) { - this.hide(); - } - }; - EventHandler.on(this._element.closest(SELECTOR_MODAL), EVENT_MODAL_HIDE, this._hideModalHandler); - } - _fixTitle() { - const title = this._element.getAttribute('title'); - if (!title) { - return; - } - if (!this._element.getAttribute('aria-label') && !this._element.textContent.trim()) { - this._element.setAttribute('aria-label', title); - } - this._element.setAttribute('data-bs-original-title', title); // DO NOT USE IT. Is only for backwards compatibility - this._element.removeAttribute('title'); - } - _enter() { - if (this._isShown() || this._isHovered) { - this._isHovered = true; - return; - } - this._isHovered = true; - this._setTimeout(() => { - if (this._isHovered) { - this.show(); - } - }, this._config.delay.show); - } - _leave() { - if (this._isWithActiveTrigger()) { - return; - } - this._isHovered = false; - this._setTimeout(() => { - if (!this._isHovered) { - this.hide(); - } - }, this._config.delay.hide); - } - _setTimeout(handler, timeout) { - clearTimeout(this._timeout); - this._timeout = setTimeout(handler, timeout); - } - _isWithActiveTrigger() { - return Object.values(this._activeTrigger).includes(true); - } - _getConfig(config) { - const dataAttributes = Manipulator.getDataAttributes(this._element); - for (const dataAttribute of Object.keys(dataAttributes)) { - if (DISALLOWED_ATTRIBUTES.has(dataAttribute)) { - delete dataAttributes[dataAttribute]; - } - } - config = { - ...dataAttributes, - ...(typeof config === 'object' && config ? config : {}) - }; - config = this._mergeConfigObj(config); - config = this._configAfterMerge(config); - this._typeCheckConfig(config); - return config; - } - _configAfterMerge(config) { - config.container = config.container === false ? document.body : getElement(config.container); - if (typeof config.delay === 'number') { - config.delay = { - show: config.delay, - hide: config.delay - }; - } - if (typeof config.title === 'number') { - config.title = config.title.toString(); - } - if (typeof config.content === 'number') { - config.content = config.content.toString(); - } - return config; - } - _getDelegateConfig() { - const config = {}; - for (const [key, value] of Object.entries(this._config)) { - if (this.constructor.Default[key] !== value) { - config[key] = value; - } - } - config.selector = false; - config.trigger = 'manual'; - - // In the future can be replaced with: - // const keysWithDifferentValues = Object.entries(this._config).filter(entry => this.constructor.Default[entry[0]] !== this._config[entry[0]]) - // `Object.fromEntries(keysWithDifferentValues)` - return config; - } - _disposePopper() { - if (this._popper) { - this._popper.destroy(); - this._popper = null; - } - if (this.tip) { - this.tip.remove(); - this.tip = null; - } - } - - // Static - static jQueryInterface(config) { - return this.each(function () { - const data = Tooltip.getOrCreateInstance(this, config); - if (typeof config !== 'string') { - return; - } - if (typeof data[config] === 'undefined') { - throw new TypeError(`No method named "${config}"`); - } - data[config](); - }); - } - } - - /** - * jQuery - */ - - defineJQueryPlugin(Tooltip); - - /** - * -------------------------------------------------------------------------- - * Bootstrap popover.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$3 = 'popover'; - const SELECTOR_TITLE = '.popover-header'; - const SELECTOR_CONTENT = '.popover-body'; - const Default$2 = { - ...Tooltip.Default, - content: '', - offset: [0, 8], - placement: 'right', - template: '', - trigger: 'click' - }; - const DefaultType$2 = { - ...Tooltip.DefaultType, - content: '(null|string|element|function)' - }; - - /** - * Class definition - */ - - class Popover extends Tooltip { - // Getters - static get Default() { - return Default$2; - } - static get DefaultType() { - return DefaultType$2; - } - static get NAME() { - return NAME$3; - } - - // Overrides - _isWithContent() { - return this._getTitle() || this._getContent(); - } - - // Private - _getContentForTemplate() { - return { - [SELECTOR_TITLE]: this._getTitle(), - [SELECTOR_CONTENT]: this._getContent() - }; - } - _getContent() { - return this._resolvePossibleFunction(this._config.content); - } - - // Static - static jQueryInterface(config) { - return this.each(function () { - const data = Popover.getOrCreateInstance(this, config); - if (typeof config !== 'string') { - return; - } - if (typeof data[config] === 'undefined') { - throw new TypeError(`No method named "${config}"`); - } - data[config](); - }); - } - } - - /** - * jQuery - */ - - defineJQueryPlugin(Popover); - - /** - * -------------------------------------------------------------------------- - * Bootstrap scrollspy.js - * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) - * -------------------------------------------------------------------------- - */ - - - /** - * Constants - */ - - const NAME$2 = 'scrollspy'; - const DATA_KEY$2 = 'bs.scrollspy'; - const EVENT_KEY$2 = `.${DATA_KEY$2}`; - const DATA_API_KEY = '.data-api'; - const EVENT_ACTIVATE = `activate${EVENT_KEY$2}`; - const EVENT_CLICK = `click${EVENT_KEY$2}`; - const EVENT_LOAD_DATA_API$1 = `load${EVENT_KEY$2}${DATA_API_KEY}`; - const CLASS_NAME_DROPDOWN_ITEM = 'dropdown-item'; - const CLASS_NAME_ACTIVE$1 = 'active'; - const SELECTOR_DATA_SPY = '[data-bs-spy="scroll"]'; - const SELECTOR_TARGET_LINKS = '[href]'; - const SELECTOR_NAV_LIST_GROUP = '.nav, .list-group'; - const SELECTOR_NAV_LINKS = '.nav-link'; - const SELECTOR_NAV_ITEMS = '.nav-item'; - const SELECTOR_LIST_ITEMS = '.list-group-item'; - const SELECTOR_LINK_ITEMS = `${SELECTOR_NAV_LINKS}, ${SELECTOR_NAV_ITEMS} > ${SELECTOR_NAV_LINKS}, ${SELECTOR_LIST_ITEMS}`; - const SELECTOR_DROPDOWN = '.dropdown'; - const SELECTOR_DROPDOWN_TOGGLE$1 = '.dropdown-toggle'; - const Default$1 = { - offset: null, - // TODO: v6 @deprecated, keep it for backwards compatibility reasons - rootMargin: '0px 0px -25%', - smoothScroll: false, - target: null, - threshold: [0.1, 0.5, 1] - }; - const DefaultType$1 = { - offset: '(number|null)', - // TODO v6 @deprecated, keep it for backwards compatibility reasons - rootMargin: 'string', - smoothScroll: 'boolean', - target: 'element', - threshold: 'array' - }; - - /** - * Class definition - */ - - class ScrollSpy extends BaseComponent { - constructor(element, config) { - super(element, config); - - // this._element is the observablesContainer and config.target the menu links wrapper - this._targetLinks = new Map(); - this._observableSections = new Map(); - this._rootElement = getComputedStyle(this._element).overflowY === 'visible' ? null : this._element; - this._activeTarget = null; - this._observer = null; - this._previousScrollData = { - visibleEntryTop: 0, - parentScrollTop: 0 - }; - this.refresh(); // initialize - } - - // Getters - static get Default() { - return Default$1; - } - static get DefaultType() { - return DefaultType$1; - } - static get NAME() { - return NAME$2; - } - - // Public - refresh() { - this._initializeTargetsAndObservables(); - this._maybeEnableSmoothScroll(); - if (this._observer) { - this._observer.disconnect(); - } else { - this._observer = this._getNewObserver(); - } - for (const section of this._observableSections.values()) { - this._observer.observe(section); - } - } - dispose() { - this._observer.disconnect(); - super.dispose(); - } - - // Private - _configAfterMerge(config) { - // TODO: on v6 target should be given explicitly & remove the {target: 'ss-target'} case - config.target = getElement(config.target) || document.body; - - // TODO: v6 Only for backwards compatibility reasons. Use rootMargin only - config.rootMargin = config.offset ? `${config.offset}px 0px -30%` : config.rootMargin; - if (typeof config.threshold === 'string') { - config.threshold = config.threshold.split(',').map(value => Number.parseFloat(value)); - } - return config; - } - _maybeEnableSmoothScroll() { - if (!this._config.smoothScroll) { - return; - } - - // unregister any previous listeners - EventHandler.off(this._config.target, EVENT_CLICK); - EventHandler.on(this._config.target, EVENT_CLICK, SELECTOR_TARGET_LINKS, event => { - const observableSection = this._observableSections.get(event.target.hash); - if (observableSection) { - event.preventDefault(); - const root = this._rootElement || window; - const height = observableSection.offsetTop - this._element.offsetTop; - if (root.scrollTo) { - root.scrollTo({ - top: height, - behavior: 'smooth' - }); - return; - } - - // Chrome 60 doesn't support `scrollTo` - root.scrollTop = height; - } - }); - } - _getNewObserver() { - const options = { - root: this._rootElement, - threshold: this._config.threshold, - rootMargin: this._config.rootMargin - }; - return new IntersectionObserver(entries => this._observerCallback(entries), options); - } - - // The logic of selection - _observerCallback(entries) { - const targetElement = entry => this._targetLinks.get(`#${entry.target.id}`); - const activate = entry => { - this._previousScrollData.visibleEntryTop = entry.target.offsetTop; - this._process(targetElement(entry)); - }; - const parentScrollTop = (this._rootElement || document.documentElement).scrollTop; - const userScrollsDown = parentScrollTop >= this._previousScrollData.parentScrollTop; - this._previousScrollData.parentScrollTop = parentScrollTop; - for (const entry of entries) { - if (!entry.isIntersecting) { - this._activeTarget = null; - this._clearActiveClass(targetElement(entry)); - continue; - } - const entryIsLowerThanPrevious = entry.target.offsetTop >= this._previousScrollData.visibleEntryTop; - // if we are scrolling down, pick the bigger offsetTop - if (userScrollsDown && entryIsLowerThanPrevious) { - activate(entry); - // if parent isn't scrolled, let's keep the first visible item, breaking the iteration - if (!parentScrollTop) { - return; - } - continue; - } - - // if we are scrolling up, pick the smallest offsetTop - if (!userScrollsDown && !entryIsLowerThanPrevious) { - activate(entry); - } - } - } - _initializeTargetsAndObservables() { - this._targetLinks = new Map(); - this._observableSections = new Map(); - const targetLinks = SelectorEngine.find(SELECTOR_TARGET_LINKS, this._config.target); - for (const anchor of targetLinks) { - // ensure that the anchor has an id and is not disabled - if (!anchor.hash || isDisabled(anchor)) { - continue; - } - const observableSection = SelectorEngine.findOne(decodeURI(anchor.hash), this._element); - - // ensure that the observableSection exists & is visible - if (isVisible(observableSection)) { - this._targetLinks.set(decodeURI(anchor.hash), anchor); - this._observableSections.set(anchor.hash, observableSection); - } - } - } - _process(target) { - if (this._activeTarget === target) { - return; - } - this._clearActiveClass(this._config.target); - this._activeTarget = target; - target.classList.add(CLASS_NAME_ACTIVE$1); - this._activateParents(target); - EventHandler.trigger(this._element, EVENT_ACTIVATE, { - relatedTarget: target - }); - } - _activateParents(target) { - // Activate dropdown parents - if (target.classList.contains(CLASS_NAME_DROPDOWN_ITEM)) { - SelectorEngine.findOne(SELECTOR_DROPDOWN_TOGGLE$1, target.closest(SELECTOR_DROPDOWN)).classList.add(CLASS_NAME_ACTIVE$1); - return; - } - for (const listGroup of SelectorEngine.parents(target, SELECTOR_NAV_LIST_GROUP)) { - // Set triggered links parents as active - // With both
    and