@odoo/o-spreadsheet 18.2.0-alpha.5 → 18.2.0-alpha.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/o-spreadsheet.cjs.js +299 -249
- package/dist/o-spreadsheet.d.ts +27 -41
- package/dist/o-spreadsheet.esm.js +299 -249
- package/dist/o-spreadsheet.iife.js +299 -249
- package/dist/o-spreadsheet.iife.min.js +14 -14
- package/dist/o_spreadsheet.xml +3 -3
- package/package.json +1 -1
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
}
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
|
-
`;class hh extends t.Component{static template="o-spreadsheet-ChartJsComponent";static props={figure:Object};canvas=t.useRef("graphContainer");chart;currentRuntime;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){const e=this.env.model.getters.getChartRuntime(this.props.figure.id);if(!("chartJsConfig"in e))throw new Error("Unsupported chart runtime");return e}setup(){t.onMounted((()=>{const e=this.chartRuntime;this.currentRuntime=e,this.createChart(Be(e.chartJsConfig))})),t.onWillUnmount((()=>this.chart?.destroy())),t.useEffect((()=>{const e=this.chartRuntime;e!==this.currentRuntime&&(e.chartJsConfig.type!==this.currentRuntime.chartJsConfig.type?(this.chart?.destroy(),this.createChart(Be(e.chartJsConfig))):this.updateChartJs(Be(e)),this.currentRuntime=e)}))}createChart(e){const t=this.canvas.el.getContext("2d");this.chart=new window.Chart(t,e)}updateChartJs(e){const t=e.chartJsConfig;t.data&&t.data.datasets?(this.chart.data=t.data,t.options?.plugins?.title&&(this.chart.config.options.plugins.title=t.options.plugins.title)):this.chart.data.datasets=[],this.chart.config.options=t.options,this.chart.update()}}class dh{sheetId;title;getters;constructor(e,t,o){this.title=e.title,this.sheetId=t,this.getters=o}static validateChartDefinition(e,t){throw new Error("This method should be implemented by sub class")}static transformDefinition(e,t){throw new Error("This method should be implemented by sub class")}static getDefinitionFromContextCreation(e){throw new Error("This method should be implemented by sub class")}}function uh(e,t,o,s,i){if("text"===t||"progress"===t||e?.type!==ni.number||o?.type!==ni.number)return;const n=o.value-e.value;return n>0?s:n<0?i:void 0}function gh(e,t,o){if("text"===o||e?.type!==ni.number||t?.type!==ni.number)return"neutral";const s=t.value-e.value;return s>0?"up":s<0?"down":"neutral"}function ph(e){return e.keyValue&&!Uo.test(e.keyValue)?"InvalidScorecardKeyValue":"Success"}function mh(e){return e.baseline&&!Uo.test(e.baseline)?"InvalidScorecardBaseline":"Success"}const fh=new window.Path2D("M8.6 4.8a.5.5 0 0 1 0 .75l-3.9 3.9a.5 .5 0 0 1 -.75 0l-3.8 -3.9a.5 .5 0 0 1 0 -.75l.4-.4a.5.5 0 0 1 .75 0l2.3 2.4v-5.7c0-.25.25-.5.5-.5h.6c.25 0 .5.25.5.5v5.8l2.3 -2.4a.5.5 0 0 1 .75 0z"),vh=new window.Path2D("M8.7 5.5a.5.5 0 0 0 0-.75l-3.8-4a.5.5 0 0 0-.75 0l-3.8 4a.5.5 0 0 0 0 .75l.4.4a.5.5 0 0 0 .75 0l2.3-2.4v5.8c0 .25.25.5.5.5h.6c.25 0 .5-.25.5-.5v-5.8l2.2 2.4a.5.5 0 0 0 .75 0z");let bh=class e extends dh{keyValue;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type="scorecard";constructor(e,t,o){super(e,t,o),this.keyValue=Vr(o,t,e.keyValue),this.baseline=Vr(o,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??Ee,this.baselineColorDown=e.baselineColorDown??Ie,this.humanize=e.humanize??!1}static validateChartDefinition(e,t){return e.checkValidations(t,ph,mh)}static getDefinitionFromContextCreation(e){return{background:e.background,type:"scorecard",keyValue:e.range?e.range[0].dataRange:void 0,title:e.title||{text:""},baselineMode:xe,baselineColorUp:Ee,baselineColorDown:Ie,baseline:e.auxiliaryRange||""}}static transformDefinition(e,t){let o,s;return e.baseline&&(o=gc(jo(e.baseline),t)),e.keyValue&&(s=gc(jo(e.keyValue),t)),{...e,baseline:o?Jo(o):void 0,keyValue:s?Jo(s):void 0}}duplicateInDuplicatedSheet(t){const o=Uc(this.sheetId,t,this.baseline),s=Uc(this.sheetId,t,this.keyValue),i=this.getDefinitionWithSpecificRanges(o,s,t);return new e(i,t,this.getters)}copyInSheetId(t){const o=this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue,t);return new e(o,t,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue)}getContextCreation(){return{...this,range:this.keyValue?[{dataRange:this.getters.getRangeString(this.keyValue,this.sheetId)}]:void 0,auxiliaryRange:this.baseline?this.getters.getRangeString(this.baseline,this.sheetId):void 0}}getDefinitionWithSpecificRanges(e,t,o){return{baselineColorDown:this.baselineColorDown,baselineColorUp:this.baselineColorUp,baselineMode:this.baselineMode,title:this.title,type:"scorecard",background:this.background,baseline:e?this.getters.getRangeString(e,o||this.sheetId):void 0,baselineDescr:this.baselineDescr,keyValue:t?this.getters.getRangeString(t,o||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(t){const o=Bc(this.baseline,t),s=Bc(this.keyValue,t);if(this.baseline===o&&this.keyValue===s)return this;const i=this.getDefinitionWithSpecificRanges(o,s);return new e(i,this.sheetId,this.getters)}};function Sh(e,t){const o=t.getContext("2d");t.width=e.canvas.width;const s=t.width-2*Z;if(t.height=e.canvas.height,o.fillStyle=e.canvas.backgroundColor,o.fillRect(0,0,e.canvas.width,e.canvas.height),e.title){o.font=e.title.style.font,o.fillStyle=e.title.style.color;const t=o.textBaseline;o.textBaseline="middle",o.fillText(na(o,e.title.text,s-e.title.position.x),e.title.position.x,e.title.position.y),o.textBaseline=t}if(e.baseline&&(o.font=e.baseline.style.font,o.fillStyle=e.baseline.style.color,ra(o,e.baseline.text,e.baseline.position,e.baseline.style.underline,e.baseline.style.strikethrough)),e.baselineArrow&&e.baselineArrow.style.size>0){o.save(),o.fillStyle=e.baselineArrow.style.color,o.translate(e.baselineArrow.position.x,e.baselineArrow.position.y);const t=e.baselineArrow.style.size/10;switch(o.scale(t,t),e.baselineArrow.direction){case"down":o.fill(fh);break;case"up":o.fill(vh)}o.restore()}if(e.baselineDescr){const t=e.baselineDescr[0];o.font=t.style.font,o.fillStyle=t.style.color;for(const t of e.baselineDescr)o.fillText(na(o,t.text,s-t.position.x),t.position.x,t.position.y)}if(e.key&&(o.font=e.key.style.font,o.fillStyle=e.key.style.color,ra(o,na(o,e.key.text,s-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.progressBar){if(o.fillStyle=e.progressBar.style.backgroundColor,o.beginPath(),o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width,e.progressBar.dimension.height,e.progressBar.dimension.height/2),o.fill(),o.fillStyle=e.progressBar.style.color,o.beginPath(),e.progressBar.value>0)o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width*Math.max(0,Math.min(1,e.progressBar.value)),e.progressBar.dimension.height,e.progressBar.dimension.height/2);else{const t=e.progressBar.dimension.width*Math.max(0,Math.min(1,-e.progressBar.value));o.roundRect(e.progressBar.position.x+e.progressBar.dimension.width-t,e.progressBar.position.y,t,e.progressBar.dimension.height,e.progressBar.dimension.height/2)}o.fill()}}function yh(e,t){let o,s="";const i=t.getLocale();if(e.keyValue){const n={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};o=t.getEvaluatedCell(n),s=function(e,t,o){return e?t?vr(e,o):e.formattedValue??String(e.value??""):""}(o,e.humanize??!1,i)}let n;const r=e.baseline;if(r){const e={sheetId:r.sheetId,col:r.zone.left,row:r.zone.top};n=t.getEvaluatedCell(e)}const{background:a,fontColor:l}=t.getStyleOfSingleCellChart(e.background,e.keyValue),c=function(e,t,o,s,i){if(!e)return"";if("text"===o||t?.type!==ni.number||e.type!==ni.number)return s?vr(e,i):e.formattedValue;let{value:n,format:r}=e;return"progress"===o?(n=t.value/n,r="0.0%"):(n=Math.abs(t.value-n),"percentage"===o&&0!==n&&(n/=e.value),"percentage"===o&&(r="0.0%"),r||(n=Math.round(100*n)/100)),s?vr({value:n,format:r},i):Jn(n,{format:r,locale:i})}(n,o,e.baselineMode,e.humanize??!1,i),h="progress"===e.baselineMode&&ti(c,i)?Vi(c,i):0;return{title:{...e.title,text:e.title.text?Fo(e.title.text):""},keyValue:s,baselineDisplay:c,baselineArrow:gh(n,o,e.baselineMode),baselineColor:uh(n,e.baselineMode,o,e.baselineColorUp,e.baselineColorDown),baselineDescr:"progress"!==e.baselineMode&&e.baselineDescr?Fo(e.baselineDescr):"",fontColor:l,background:a,baselineStyle:"percentage"!==e.baselineMode&&"progress"!==e.baselineMode&&r?t.getCellStyle({sheetId:r.sheetId,col:r.zone.left,row:r.zone.top}):void 0,keyValueStyle:e.keyValue?t.getCellStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,progressBar:"progress"===e.baselineMode?{value:h,color:h>0?e.baselineColorUp:e.baselineColorDown}:void 0}}const Ch=10,wh=.05;function xh({width:e,height:t},o){return new Eh({width:e,height:t},o).computeDesign()}class Eh{runtime;context;width;height;constructor({width:e,height:t},o){this.runtime=o;const s=document.createElement("canvas");this.width=s.width=e,this.height=s.height=t,this.context=s.getContext("2d")}computeDesign(){const e={canvas:{width:this.width,height:this.height,backgroundColor:this.backgroundColor}},t=this.getTextStyles();let o=0;if(this.title){let s,i;switch(({height:o,width:i}=this.getFullTextDimensions(this.title,t.title.font)),this.runtime.title.align){case"center":s=(this.width-i)/2;break;case"right":s=this.width-i-Ch;break;default:s=Ch}e.title={text:this.title,style:t.title,position:{x:s,y:Ch+o/2}}}const s=t.baselineArrow?.size??0;let{height:i,width:n}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);const r=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;e.baseline={text:this.baseline,style:t.baselineValue,position:{x:(this.width-n-r+s)/2,y:this.keyValue?this.height*(1-wh*(this.runtime.progressBar?1:2)):this.height-(this.height-o-i)/2-Ch}};const a=s+20;if(e.baseline.position.x<a&&(e.baseline.position.x=a),t.baselineArrow&&!this.runtime.progressBar&&(e.baselineArrow={direction:this.baselineArrow,style:t.baselineArrow,position:{x:e.baseline.position.x-s,y:e.baseline.position.y-(i+s)/2}}),this.baselineDescr){const o={x:e.baseline.position.x+n,y:e.baseline.position.y};e.baselineDescr=[{text:this.baselineDescr,style:t.baselineDescr,position:o}]}let l=0;this.runtime.progressBar&&(l=.05*this.height,e.progressBar={position:{x:20,y:.9*this.height-i-l},dimension:{height:l,width:this.width-40},value:this.runtime.progressBar.value,style:{color:this.runtime.progressBar.color,backgroundColor:this.secondaryFontColor}});const{width:c,height:h}=this.getFullTextDimensions(this.keyValue,t.keyValue.font);return this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(Ch,(this.width-c)/2),y:.4*this.height+5+(o+h/2)/2}}),e}get title(){return this.runtime.title.text??""}get keyValue(){return this.runtime.keyValue}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return function(e,t){const o=e||"";return t&&o?" "+o:o}(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return jc(this.backgroundColor)}getTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.actualBoundingBoxAscent+o.actualBoundingBoxDescent}}getFullTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.fontBoundingBoxAscent+o.fontBoundingBoxDescent}}getTextStyles(){let e=16;const t=Math.floor(.9*e);return this.runtime.progressBar&&(e/=1.5),{title:{font:qr(this.runtime.title.fontSize??14,this.runtime.title.bold,this.runtime.title.italic),color:this.runtime.title.color??this.secondaryFontColor},keyValue:{color:this.runtime.keyValueStyle?.textColor||this.runtime.fontColor,font:qr(32,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},baselineValue:{font:qr(e,this.runtime.baselineStyle?.bold,this.runtime.baselineStyle?.italic),strikethrough:this.runtime.baselineStyle?.strikethrough,underline:this.runtime.baselineStyle?.underline,color:this.runtime.baselineStyle?.textColor||this.runtime.baselineColor||this.secondaryFontColor},baselineDescr:{font:qr(t),color:this.secondaryFontColor},baselineArrow:"neutral"===this.baselineArrow||this.runtime.progressBar?void 0:{size:this.keyValue?.8*e:0,color:this.runtime.baselineColor||this.secondaryFontColor}}}}class Ih extends t.Component{static template="o-spreadsheet-ScorecardChart";static props={figure:Object};canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}get title(){const e=this.env.model.getters.getChartDefinition(this.props.figure.id).title.text??"";return Fo(e)}setup(){t.useEffect(this.createChart.bind(this),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}createChart(){const e=this.canvas.el;Sh(xh(e.getBoundingClientRect(),this.runtime),e)}}const Rh=new n;function Th(e,t,o,s){const i=[];e=e.toLowerCase();for(const n of e){const e=t.toLocaleLowerCase().indexOf(n);-1!==e&&(i.push({value:t.slice(0,e),color:""},{value:t[e],color:o,class:s}),t=t.slice(e+1))}return i.push({value:t}),i.filter((e=>e.value))}Rh.add("dataValidation",{getProposals(e,t){if(t.startsWith("="))return[];if(!this.composer.currentEditedCell)return[];const o=this.composer.currentEditedCell,s=this.getters.getValidationRuleForCell(o);if(!s||"isValueInList"!==s.criterion.type&&"isValueInRange"!==s.criterion.type)return[];let i;if("isValueInList"===s.criterion.type)i=s.criterion.values;else{const e=this.getters.getRangeFromSheetXC(o.sheetId,s.criterion.values[0]);i=Array.from(new Set(this.getters.getRangeValues(e).filter(lt).map((e=>e.toString())).filter((e=>""!==e))))}return i.map((e=>({text:e})))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}});const Ah=/(.*?)\((.*?)\)(.*)/,_h=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META"];function Dh(e,t=""){return function(e,t){let o=e.match(Ah),s=o[1].trim();if(!s)throw new Error(`Function argument definition is missing a name: '${e}'.`);let i,n=[],r=!1,a=!1;for(let e of o[2].split(",")){const t=e.trim().toUpperCase();let o=_h.find((e=>t===e));o?n.push(o):"RANGE<ANY>"===t?n.push("RANGE"):"OPTIONAL"===t?r=!0:"REPEATING"===t?a=!0:t.startsWith("DEFAULT=")&&(i=e.trim().slice(8))}const l={name:s,description:t,type:n};(n.includes("ANY")||n.includes("RANGE"))&&(l.acceptErrors=!0);r&&(l.optional=!0);a&&(l.repeating=!0);void 0!==i&&(l.default=!0,l.defaultValue=i);n.some((e=>e.startsWith("RANGE")))&&(l.acceptMatrix=!0);n.every((e=>e.startsWith("RANGE")))&&(l.acceptMatrixOnly=!0);return l}(e,t)}function Oh(e){let t=0,o=0,s=0;for(let i of e.args)t++,i.optional||i.repeating||i.default||o++,i.repeating&&s++;const i=e;return i.minArgRequired=o,i.maxArgPossible=s?1/0:t,i.nbrArgRepeating=s,i.getArgToFocus=function(e,t){if(!t)return e=>e;if(1===t)return t=>Math.min(t,e);const o=e-t;return e=>{if(e<=o)return e;return o+((e-o)%t||t)}}(t,s),i.hidden=e.hidden||!1,i}function Fh(e,t){Pi((()=>1===t.length||1===t[0].length),e)}function Mh(e,...t){if(t.every(Ci)){const o=t[0].length,s=t[0][0].length;for(const i of t)Pi((()=>i.length===o&&i[0].length===s),e)}else if(t.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length))))throw new Ti(e)}function Ph(e,t){Pi((()=>t>0),e)}function Nh(e,t){Pi((()=>t.length===t[0].length),e)}const kh={description:Fo("Returns a result array constrained to a specific width and height."),args:[Dh("input_range (any, range<any>)",Fo("The range to constrain.")),Dh("rows (number)",Fo("The number of rows in the constrained array.")),Dh("columns (number)",Fo("The number of columns in the constrained array."))],compute:function(e,t,o){const s=bn(e),i=zi(t?.value,this.locale),n=zi(o?.value,this.locale);Ph(Fo("The rows argument (%s) must be strictly positive.",i.toString()),i),Ph(Fo("The columns argument (%s) must be strictly positive.",i.toString()),n);const r=Math.min(i,s[0].length);return rn(Math.min(n,s.length),r,((e,t)=>s[e][t]))},isExported:!1},Lh={description:Fo("Creates a new array from the selected columns in the existing range."),args:[Dh("array (any, range<any>)",Fo("The array that contains the columns to be returned.")),Dh("col_num (number, range<number>)",Fo("The first column index of the columns to be returned.")),Dh("col_num2 (number, range<number>, repeating)",Fo("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=bn(e),s=Sn(t,(e=>zi(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));Pi((()=>0===i.length),Fo("The columns arguments must be between -%s and %s (got %s), excluding 0.",o.length.toString(),o.length.toString(),i.join(",")));const n=Array(s.length);for(let e=0;e<s.length;e++)s[e]>0?n[e]=o[s[e]-1]:n[e]=o[o.length+s[e]];return n},isExported:!0},Vh={description:Fo("Creates a new array from the selected rows in the existing range."),args:[Dh("array (any, range<any>)",Fo("The array that contains the rows to be returned.")),Dh("row_num (number, range<number>)",Fo("The first row index of the rows to be returned.")),Dh("row_num2 (number, range<number>, repeating)",Fo("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=bn(e),s=Sn(t,(e=>zi(e?.value,this.locale))),i=o.length,n=s.filter((e=>0===e||o[0].length<Math.abs(e)));return Pi((()=>0===n.length),Fo("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),n.join(","))),rn(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},Hh={description:Fo("Expands or pads an array to specified row and column dimensions."),args:[Dh("array (any, range<any>)",Fo("The array to expand.")),Dh("rows (number)",Fo("The number of rows in the expanded array. If missing, rows will not be expanded.")),Dh("columns (number, optional)",Fo("The number of columns in the expanded array. If missing, columns will not be expanded.")),Dh("pad_with (any, default=0)",Fo("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=bn(e),n=zi(t?.value,this.locale),r=void 0!==o?zi(o.value,this.locale):i.length;return Pi((()=>n>=i[0].length),Fo("The rows arguments (%s) must be greater or equal than the number of rows of the array.",n.toString())),Pi((()=>r>=i.length),Fo("The columns arguments (%s) must be greater or equal than the number of columns of the array.",r.toString())),rn(r,n,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},Uh={description:Fo("Flattens all the values from one or more ranges into a single column."),args:[Dh("range (any, range<any>)",Fo("The first range to flatten.")),Dh("range2 (any, range<any>, repeating)",Fo("Additional ranges to flatten."))],compute:function(...e){return[Sn(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},Bh={description:Fo("Calculates the frequency distribution of a range."),args:[Dh("data (range<number>)",Fo("The array of ranges containing the values to be counted.")),Dh("classes (number, range<number>)",Fo("The range containing the set of classes."))],compute:function(e,t){const o=Sn([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=Sn([t],(e=>e.value)).filter((e=>"number"==typeof e)),i=s.map(((e,t)=>({initialIndex:t,value:e,count:0}))).sort(((e,t)=>e.value-t.value));i.push({initialIndex:i.length,value:1/0,count:0});const n=o.sort(((e,t)=>e-t));let r=0;for(const e of n){for(;e>i[r].value&&r<i.length-1;)r++;i[r].count++}return[i.sort(((e,t)=>e.initialIndex-t.initialIndex)).map((e=>e.count))]},isExported:!0},zh={description:Fo("Appends ranges horizontally and in sequence to return a larger array."),args:[Dh("range1 (any, range<any>)",Fo("The first range to be appended.")),Dh("range2 (any, range<any>, repeating)",Fo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>e?.[0]?.length??0))),o=[];for(const s of e){const e=bn(s);for(let s=0;s<e.length;s++){const i=Array(t).fill({value:null});for(let t=0;t<e[s].length;t++)i[t]=e[s][t];o.push(i)}}return o},isExported:!0},$h={description:Fo("Returns the matrix determinant of a square matrix."),args:[Dh("square_matrix (number, range<number>)",Fo("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=Ui(e,"square_matrix");return Nh(Fo("The argument square_matrix must have the same number of columns and rows."),t),Ya(t).determinant},isExported:!0},Wh={description:Fo("Returns the multiplicative inverse of a square matrix."),args:[Dh("square_matrix (number, range<number>)",Fo("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=Ui(e,"square_matrix");Nh(Fo("The argument square_matrix must have the same number of columns and rows."),t);const{inverted:o}=Ya(t);return o||new Ti(Fo("The matrix is not invertible."))},isExported:!0},Gh={description:Fo("Calculates the matrix product of two matrices."),args:[Dh("matrix1 (number, range<number>)",Fo("The first matrix in the matrix multiplication operation.")),Dh("matrix2 (number, range<number>)",Fo("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=Ui(e,"matrix1"),s=Ui(t,"matrix2");return Pi((()=>o.length===s[0].length),Fo("In [[FUNCTION_NAME]], the number of columns of the first matrix (%s) must be equal to the number of rows of the second matrix (%s).",o.length.toString(),s[0].length.toString())),Ka(o,s)},isExported:!0},qh={description:Fo("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[Dh("range1 (number, range<number>)",Fo("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),Dh("range2 (number, range<number>, repeating)",Fo("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){Mh(Fo("All the ranges must have the same dimensions."),...e);const t=e.map(bn);let o=0;for(let e=0;e<t[0].length;e++)for(let s=0;s<t[0][e].length;s++){if(!t.every((t=>"number"==typeof t[e][s].value)))continue;let i=1;for(const o of t)i*=Vi(o[e][s],this.locale);o+=i}return o},isExported:!0};function Zh(e,t,o){Mh("The arguments array_x and array_y must have the same dimensions.",e,t);const s=bn(e),i=bn(t);let n=!1,r=0;for(const e in s)for(const t in s[e]){const a=s[e][t].value,l=i[e][t].value;"number"==typeof a&&"number"==typeof l&&(n=!0,r+=o(a,l))}return n?r:new Ti(Fo("The arguments array_x and array_y must contain at least one pair of numbers."))}const jh={description:Fo("Calculates the sum of the difference of the squares of the values in two array."),args:[Dh("array_x (number, range<number>)",Fo("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),Dh("array_y (number, range<number>)",Fo("The array or range of values whose squares will be subtracted from the squares of corresponding entries in array_x and added together."))],compute:function(e,t){return Zh(e,t,((e,t)=>e**2-t**2))},isExported:!0},Yh={description:Fo("Calculates the sum of the sum of the squares of the values in two array."),args:[Dh("array_x (number, range<number>)",Fo("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),Dh("array_y (number, range<number>)",Fo("The array or range of values whose squares will be added to the squares of corresponding entries in array_x and added together."))],compute:function(e,t){return Zh(e,t,((e,t)=>e**2+t**2))},isExported:!0},Xh={description:Fo("Calculates the sum of squares of the differences of values in two array."),args:[Dh("array_x (number, range<number>)",Fo("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),Dh("array_y (number, range<number>)",Fo("The array or range of values that will be subtracted from corresponding entries in array_x, the result squared, and all such results added together."))],compute:function(e,t){return Zh(e,t,((e,t)=>(e-t)**2))},isExported:!0},Kh=!1,Jh=[Dh("array (any, range<any>)",Fo("The array which will be transformed.")),Dh("ignore (number, default=0)",Fo("The control to ignore blanks and errors. 0 (default) is to keep all values, 1 is to ignore blanks, 2 is to ignore errors, and 3 is to ignore blanks and errors.")),Dh("scan_by_column (number, default=false)",Fo("Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row."))];function Qh(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!ki(e.value);if(3===t)return e=>null!==e.value&&!ki(e.value);throw new Ti(Fo("Argument ignore must be between 0 and 3"))}const ed={description:Fo("Transforms a range of cells into a single column."),args:Jh,compute:function(e,t={value:0},o={value:Kh}){const s=bn(e),i=Vi(t.value,this.locale),n=(Yi(o.value)?s:ln(s)).flat().filter(Qh(i));return 0===n.length?new Di(Fo("No results for the given arguments of TOCOL.")):[n]},isExported:!0},td={description:Fo("Transforms a range of cells into a single row."),args:Jh,compute:function(e,t={value:0},o={value:Kh}){const s=bn(e),i=Vi(t.value,this.locale),n=(Yi(o.value)?s:ln(s)).flat().filter(Qh(i)).map((e=>[e]));return 0===n.length||0===n[0].length?new Di(Fo("No results for the given arguments of TOROW.")):n},isExported:!0},od={description:Fo("Transposes the rows and columns of a range."),args:[Dh("range (any, range<any>)",Fo("The range to be transposed."))],compute:function(e){const t=bn(e);return rn(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},sd={description:Fo("Appends ranges vertically and in sequence to return a larger array."),args:[Dh("range1 (any, range<any>)",Fo("The first range to be appended.")),Dh("range2 (any, range<any>, repeating)",Fo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>bn(e).length))),o=e.reduce(((e,t)=>e+bn(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=bn(t);for(let t=0;t<e.length;t++)for(let o=0;o<e[t].length;o++)s[t][i+o]=e[t][o];i+=e[0].length}return s},isExported:!0},id={description:Fo("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[Dh("range (any, range<any>)",Fo("The range to wrap.")),Dh("wrap_count (number)",Fo("The maximum number of cells for each column, rounded down to the nearest whole number.")),Dh("pad_with (any, default=0)",Fo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=bn(e),i=zi(t?.value,this.locale);Fh(Fo("Argument range must be a single row or column."),s);const n=s.flat();return rn(Math.ceil(n.length/i),i,((e,t)=>{const s=e*i+t;return s<n.length?n[s]:o}))},isExported:!0},nd={description:Fo("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[Dh("range (any, range<any>)",Fo("The range to wrap.")),Dh("wrap_count (number)",Fo("The maximum number of cells for each row, rounded down to the nearest whole number.")),Dh("pad_with (any, default=0)",Fo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=bn(e),i=zi(t?.value,this.locale);Fh(Fo("Argument range must be a single row or column."),s);const n=s.flat(),r=Math.ceil(n.length/i);return rn(i,r,((e,t)=>{const s=t*i+e;return s<n.length?n[s]:o}))},isExported:!0};var rd=Object.freeze({__proto__:null,ARRAY_CONSTRAIN:kh,CHOOSECOLS:Lh,CHOOSEROWS:Vh,EXPAND:Hh,FLATTEN:Uh,FREQUENCY:Bh,HSTACK:zh,MDETERM:$h,MINVERSE:Wh,MMULT:Gh,SUMPRODUCT:qh,SUMX2MY2:jh,SUMX2PY2:Yh,SUMXMY2:Xh,TOCOL:ed,TOROW:td,TRANSPOSE:od,VSTACK:sd,WRAPCOLS:id,WRAPROWS:nd});const ad={description:Fo("Apply a large number format"),args:[Dh("value (number)",Fo("The number.")),Dh("unit (string, optional)",Fo("The formatting unit. Use 'k', 'm', or 'b' to force the unit"))],compute:function(e,t){return{value:Vi(e,this.locale),format:br(e,t,this.locale)}}};var ld=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:ad});const cd=/^-?[a-z0-9]+$/i,hd={description:Fo("Absolute value of a number."),args:[Dh("value (number)",Fo("The number of which to return the absolute value."))],compute:function(e){return Math.abs(Vi(e,this.locale))},isExported:!0},dd={description:Fo("Inverse cosine of a value, in radians."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)<=1),Fo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.acos(t)},isExported:!0},ud={description:Fo("Inverse hyperbolic cosine of a number."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>t>=1),Fo("The value (%s) must be greater than or equal to 1.",t.toString())),Math.acosh(t)},isExported:!0},gd={description:Fo("Inverse cotangent of a value."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=Vi(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},pd={description:Fo("Inverse hyperbolic cotangent of a value."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)>1),Fo("The value (%s) cannot be between -1 and 1 inclusive.",t.toString())),Math.log((t+1)/(t-1))/2},isExported:!0},md={description:Fo("Inverse sine of a value, in radians."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)<=1),Fo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.asin(t)},isExported:!0},fd={description:Fo("Inverse hyperbolic sine of a number."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(Vi(e,this.locale))},isExported:!0},vd={description:Fo("Inverse tangent of a value, in radians."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(Vi(e,this.locale))},isExported:!0},bd={description:Fo("Angle from the X axis to a point (x,y), in radians."),args:[Dh("x (number)",Fo("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),Dh("y (number)",Fo("The y coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis."))],compute:function(e,t){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>0!==o||0!==s),Fo("Function [[FUNCTION_NAME]] caused a divide by zero error."),Ii.DivisionByZero),Math.atan2(s,o)},isExported:!0},Sd={description:Fo("Inverse hyperbolic tangent of a number."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)<1),Fo("The value (%s) must be between -1 and 1 exclusive.",t.toString())),Math.atanh(t)},isExported:!0},yd={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("value (number)",Fo("The value to round up to the nearest integer multiple of factor.")),Dh("factor (number, default=1)",Fo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>s>=0||o<=0),Fo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function Cd(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.ceil(e/t)*t:0===o?-Math.floor(Math.abs(e)/t)*t:-Math.ceil(Math.abs(e)/t)*t)}const wd={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round up to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Dh("mode (number, default=0)",Fo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded towards zero. Otherwise, it is rounded away from zero."))],compute:function(e,t={value:1},o={value:0}){const s=Vi(t,this.locale);return{value:Cd(Vi(e,this.locale),s,Vi(o,this.locale)),format:e?.format}},isExported:!0},xd={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round up to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Vi(t,this.locale);return{value:Cd(Vi(e,this.locale),o),format:e?.format}},isExported:!0},Ed={description:Fo("Cosine of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(Vi(e,this.locale))},isExported:!0},Id={description:Fo("Hyperbolic cosine of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(Vi(e,this.locale))},isExported:!0},Rd={description:Fo("Cotangent of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the cotangent of, in radians."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.tan(t)},isExported:!0},Td={description:Fo("Hyperbolic cotangent of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.tanh(t)},isExported:!0},Ad={description:Fo("Number of empty values."),args:[Dh("value1 (any, range)",Fo("The first value or range in which to count the number of blanks.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return on(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},_d={description:Fo("A conditional count across a range."),args:[Dh("range (range)",Fo("The range that is tested against criterion.")),Dh("criterion (string)",Fo("The pattern or test to apply to range."))],compute:function(...e){let t=0;return gn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Dd={description:Fo("Count values depending on multiple criteria."),args:[Dh("criteria_range1 (range)",Fo("The range to check against criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("Additional criteria to check."))],compute:function(...e){let t=0;return gn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Od={description:Fo("Counts number of unique values in a range."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider for uniqueness.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return Za(e)}},Fd={description:Fo("Counts number of unique values in a range, filtered by a set of criteria."),args:[Dh("range (range)",Fo("The range of cells from which the number of unique values will be counted.")),Dh("criteria_range1 (range)",Fo("The range of cells over which to evaluate criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=new Set;return gn(t,((t,s)=>{const i=e[t]?.[s];yn(i)&&o.add(i.value)}),this.locale),o.size}},Md={description:Fo("Cosecant of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the cosecant of, in radians."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.sin(t)},isExported:!0},Pd={description:Fo("Hyperbolic cosecant of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.sinh(t)},isExported:!0},Nd={description:Fo("Converts from another base to decimal."),args:[Dh("value (string)",Fo("The number to convert.")),Dh("base (number)",Fo("The base to convert the value from."))],compute:function(e,t){let o=Vi(t,this.locale);o=Math.floor(o),Pi((()=>2<=o&&o<=36),Fo("The base (%s) must be between 2 and 36 inclusive.",o.toString()));const s=qi(e);if(""===s)return 0;Pi((()=>cd.test(s)),Fo("The value (%s) must be a valid base %s representation.",s,o.toString()));const i=parseInt(s,o);return Pi((()=>!isNaN(i)),Fo("The value (%s) must be a valid base %s representation.",s,o.toString())),i},isExported:!0},kd={description:Fo("Converts an angle value in radians to degrees."),args:[Dh("angle (number)",Fo("The angle to convert from radians to degrees."))],compute:function(e){return 180*Vi(e,this.locale)/Math.PI},isExported:!0},Ld={description:Fo("Euler's number, e (~2.718) raised to a power."),args:[Dh("value (number)",Fo("The exponent to raise e."))],compute:function(e){return Math.exp(Vi(e,this.locale))},isExported:!0},Vd={description:Fo("Rounds number down to nearest multiple of factor."),args:[Dh("value (number)",Fo("The value to round down to the nearest integer multiple of factor.")),Dh("factor (number, default=1)",Fo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>s>=0||o<=0),Fo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function Hd(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.floor(e/t)*t:0===o?-Math.ceil(Math.abs(e)/t)*t:-Math.floor(Math.abs(e)/t)*t)}const Ud={description:Fo("Rounds number down to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round down to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Dh("mode (number, default=0)",Fo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded away from zero. Otherwise, it is rounded towards zero."))],compute:function(e,t={value:1},o={value:0}){const s=Vi(t,this.locale);return{value:Hd(Vi(e,this.locale),s,Vi(o,this.locale)),format:e?.format}},isExported:!0},Bd={description:Fo("Rounds number down to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round down to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Vi(t,this.locale);return{value:Hd(Vi(e,this.locale),o),format:e?.format}},isExported:!0},zd={description:Fo("Whether the provided value is even."),args:[Dh("value (number)",Fo("The value to be verified as even."))],compute:function(e){const t=Bi(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},$d={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round up to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:Cd(Vi(e,this.locale),Vi(t,this.locale)),format:e?.format}},isExported:!0},Wd={description:Fo("Whether the provided value is even."),args:[Dh("value (number)",Fo("The value to be verified as even."))],compute:function(e){const t=Bi(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},Gd={description:Fo("The logarithm of a number, base e (euler's number)."),args:[Dh("value (number)",Fo("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>t>0),Fo("The value (%s) must be strictly positive.",t.toString())),Math.log(t)},isExported:!0};function qd(e,t){Pi((()=>0!==t),Fo("The divisor must be different from 0."),Ii.DivisionByZero);const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const Zd={description:Fo("Modulo (remainder) operator."),args:[Dh("dividend (number)",Fo("The number to be divided to find the remainder.")),Dh("divisor (number)",Fo("The number to divide by."))],compute:function(e,t){const o=Vi(t,this.locale);return{value:qd(Vi(e,this.locale),o),format:e?.format}},isExported:!0},jd={description:Fo("Returns a n x n unit matrix, where n is the input dimension."),args:[Dh("dimension (number)",Fo("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=zi(e,this.locale);return Ph(Fo("The argument dimension must be positive"),t),ja(t)},isExported:!0},Yd={description:Fo("Rounds a number up to the nearest odd integer."),args:[Dh("value (number)",Fo("The value to round to the next greatest odd number."))],compute:function(e){const t=Vi(e,this.locale);let o=Math.ceil(Math.abs(t));return o=1&o?o:o+1,{value:t<0?-o:o,format:e?.format}},isExported:!0},Xd={description:Fo("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},Kd={description:Fo("A number raised to a power."),args:[Dh("base (number)",Fo("The number to raise to the exponent power.")),Dh("exponent (number)",Fo("The exponent to raise base to."))],compute:function(e,t){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>o>=0||Number.isInteger(s)),Fo("The exponent (%s) must be an integer when the base is negative.",s.toString())),{value:Math.pow(o,s),format:e?.format}},isExported:!0},Jd={description:Fo("Result of multiplying a series of numbers together."),args:[Dh("factor1 (number, range<number>)",Fo("The first number or range to calculate for the product.")),Dh("factor2 (number, range<number>, repeating)",Fo("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(let s of e)if(Ci(s))for(let e of s)for(let s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),ki(e))return s}else void 0!==s&&null!==s.value&&(o*=Bi(s,this.locale),t+=1);return{value:0===t?0:o,format:Ni(e[0])}},isExported:!0},Qd={description:Fo("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},eu={description:Fo("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[Dh("rows (number, default=1)",Fo("The number of rows to be returned.")),Dh("columns (number, default=1)",Fo("The number of columns to be returned.")),Dh("min (number, default=0)",Fo("The minimum number you would like returned.")),Dh("max (number, default=1)",Fo("The maximum number you would like returned.")),Dh("whole_number (number, default=FALSE)",Fo("Return a whole number or a decimal value."))],compute:function(e={value:1},t={value:1},o={value:0},s={value:1},i={value:!1}){const n=zi(t,this.locale),r=zi(e,this.locale),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Yi(i);Ph(Fo("The number of columns (%s) must be positive.",n.toString()),n),Ph(Fo("The number of rows (%s) must be positive.",r.toString()),r),Pi((()=>a<=l),Fo("The maximum (%s) must be greater than or equal to the minimum (%s).",l.toString(),a.toString())),c&&Pi((()=>Number.isInteger(a)&&Number.isInteger(l)),Fo("The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.",l.toString(),a.toString()));const h=Array(n);for(let e=0;e<n;e++){h[e]=Array(r);for(let t=0;t<r;t++)h[e][t]=c?Math.floor(Math.random()*(l-a+1)+a):a+Math.random()*(l-a)}return h},isExported:!0},tu={description:Fo("Random integer between two values, inclusive."),args:[Dh("low (number)",Fo("The low end of the random range.")),Dh("high (number)",Fo("The high end of the random range."))],compute:function(e,t){let o=Vi(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=Vi(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),Pi((()=>o<=s),Fo("The high (%s) must be greater than or equal to the low (%s).",s.toString(),o.toString())),{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},ou={description:Fo("Rounds a number according to standard rules."),args:[Dh("value (number)",Fo("The value to round to places number of places.")),Dh("places (number, default=0)",Fo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Vi(e,this.locale);let s=Vi(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.round(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.round(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},su={description:Fo("Rounds down a number."),args:[Dh("value (number)",Fo("The value to round to places number of places, always rounding down.")),Dh("places (number, default=0)",Fo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Vi(e,this.locale);let s=Vi(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.floor(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.floor(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},iu={description:Fo("Rounds up a number."),args:[Dh("value (number)",Fo("The value to round to places number of places, always rounding up.")),Dh("places (number, default=0)",Fo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Vi(e,this.locale);let s=Vi(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.ceil(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.ceil(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},nu={description:Fo("Secant of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(Vi(e,this.locale))},isExported:!0},ru={description:Fo("Hyperbolic secant of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(Vi(e,this.locale))},isExported:!0},au={description:Fo("Returns a sequence of numbers."),args:[Dh("rows (number)",Fo("The number of rows to return")),Dh("columns (number, optional, default=1)",Fo("The number of columns to return")),Dh("start (number, optional, default=1)",Fo("The first number in the sequence")),Dh("step (number, optional, default=1)",Fo("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=Vi(o,this.locale),n=Vi(s,this.locale),r=zi(e,this.locale),a=zi(t,this.locale);return Ph(Fo("The number of columns (%s) must be positive.",a),a),Ph(Fo("The number of rows (%s) must be positive.",r),r),rn(a,r,((e,t)=>({value:i+t*a*n+e*n})))},isExported:!0},lu={description:Fo("Sine of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(Vi(e,this.locale))},isExported:!0},cu={description:Fo("Hyperbolic sine of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(Vi(e,this.locale))},isExported:!0},hu={description:Fo("Positive square root of a positive number."),args:[Dh("value (number)",Fo("The number for which to calculate the positive square root."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>t>=0),Fo("The value (%s) must be positive or null.",t.toString())),{value:Math.sqrt(t),format:e?.format}},isExported:!0},du={description:Fo("Sum of a series of numbers and/or cells."),args:[Dh("value1 (number, range<number>)",Fo("The first number or range to add together.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:qa(e,this.locale),format:Ni(t)}},isExported:!0},uu={description:Fo("A conditional sum across a range."),args:[Dh("criteria_range (range)",Fo("The range which is tested against criterion.")),Dh("criterion (string)",Fo("The pattern or test to apply to range.")),Dh("sum_range (range, default=criteria_range)",Fo("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return gn([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},gu={description:Fo("Sums a range depending on multiple criteria."),args:[Dh("sum_range (range)",Fo("The range to sum.")),Dh("criteria_range1 (range)",Fo("The range to check against criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges to check.")),Dh("criterion2 (string, repeating)",Fo("Additional criteria to check."))],compute:function(e,...t){let o=0;return gn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},pu={description:Fo("Tangent of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(Vi(e,this.locale))},isExported:!0},mu={description:Fo("Hyperbolic tangent of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(Vi(e,this.locale))},isExported:!0};function fu(e,t){return 0===t?Math.trunc(e):(Number.isInteger(t)||(t=Math.trunc(t)),Math.trunc(e*Math.pow(10,t))/Math.pow(10,t))}const vu={description:Fo("Truncates a number."),args:[Dh("value (number)",Fo("The value to be truncated.")),Dh("places (number, default=0)",Fo("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:fu(Vi(e,this.locale),Vi(t,this.locale)),format:e?.format}},isExported:!0},bu={description:Fo("Rounds a number down to the nearest integer that is less than or equal to it."),args:[Dh("value (number)",Fo("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(Vi(e,this.locale))},isExported:!0};var Su=Object.freeze({__proto__:null,ABS:hd,ACOS:dd,ACOSH:ud,ACOT:gd,ACOTH:pd,ASIN:md,ASINH:fd,ATAN:vd,ATAN2:bd,ATANH:Sd,CEILING:yd,CEILING_MATH:wd,CEILING_PRECISE:xd,COS:Ed,COSH:Id,COT:Rd,COTH:Td,COUNTBLANK:Ad,COUNTIF:_d,COUNTIFS:Dd,COUNTUNIQUE:Od,COUNTUNIQUEIFS:Fd,CSC:Md,CSCH:Pd,DECIMAL:Nd,DEGREES:kd,EXP:Ld,FLOOR:Vd,FLOOR_MATH:Ud,FLOOR_PRECISE:Bd,INT:bu,ISEVEN:zd,ISODD:Wd,ISO_CEILING:$d,LN:Gd,MOD:Zd,MUNIT:jd,ODD:Yd,PI:Xd,POWER:Kd,PRODUCT:Jd,RAND:Qd,RANDARRAY:eu,RANDBETWEEN:tu,ROUND:ou,ROUNDDOWN:su,ROUNDUP:iu,SEC:nu,SECH:ru,SEQUENCE:au,SIN:lu,SINH:cu,SQRT:hu,SUM:du,SUMIF:uu,SUMIFS:gu,TAN:pu,TANH:mu,TRUNC:vu});function yu(e,t){const o=[],s=[];let i=0,n=0;Qi([e],(e=>{o.push(e),i+=1})),Qi([t],(e=>{s.push(e),n+=1})),Pi((()=>i===n),Fo("[[FUNCTION_NAME]] has mismatched argument count %s vs %s.",i,n));const r=[],a=[];for(let e=0;e<i;e++){const t=o[e]?.value,i=s[e]?.value;"number"==typeof t&&"number"==typeof i&&(a.push(t),r.push(i))}return{flatDataX:r,flatDataY:a}}function Cu(e,t,o){const{flatDataX:s,flatDataY:i}=yu(e,t),n=i.length;Pi((()=>0!==n&&(!o||1!==n)),Fo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),Ii.DivisionByZero);let r=0,a=0;for(let e=0;e<n;e++)r+=i[e],a+=s[e];const l=r/n,c=a/n;let h=0;for(let e=0;e<n;e++)h+=(i[e]-l)*(s[e]-c);return h/(n-(o?1:0))}function wu(e,t,o,s){let i=0;const n=o?nn:sn,r=n(e,((e,t)=>(i+=1,e+t)),0,s);Pi((()=>0!==i&&(!t||1!==i)),Fo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),Ii.DivisionByZero);const a=r/i;return n(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function xu(e,t,o,s){const i=Vi(t,s);Pi((()=>o?0<=i&&i<=1:0<i&&i<1),Fo("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));let n,r=[],a=0;return Qi(e,(e=>{const t=e?.value;"number"==typeof t&&(n=pn(r,e,"nextSmaller","asc",r.length,((e,t)=>e[t])),r.splice(n+1,0,t),a++)})),Pi((()=>0!==a),Fo("[[FUNCTION_NAME]] has no valid input data.")),o||Pi((()=>1/(a+1)<=i&&i<=a/(a+1)),Fo("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),ii(r,i,o)}const Eu={description:Fo("Average magnitude of deviations from mean."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=sn(e,((e,o)=>(t+=1,e+o)),0,this.locale);Gi(t);const s=o/t;return sn(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},Iu={description:Fo("Numerical average value in a dataset, ignoring text."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the average value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:el(e,this.locale),format:Ni(e[0])}},isExported:!0},Ru=Fo("[[FUNCTION_NAME]] has mismatched range sizes."),Tu=Fo("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),Au={description:Fo("Weighted average."),args:[Dh("values (number, range<number>)",Fo("Values to average.")),Dh("weights (number, range<number>)",Fo("Weights for each corresponding value.")),Dh("additional_values (number, range<number>, repeating)",Fo("Additional values to average.")),Dh("additional_weights (number, range<number>, repeating)",Fo("Additional weights."))],compute:function(...e){let t=0,o=0;for(let s=0;s<e.length-1;s+=2){const i=e[s],n=e[s+1];if(Mh(Ru,i,n),Ci(i))for(let e=0;e<i.length;e++)for(let s=0;s<i[0].length;s++){const r=i[e][s].value,a=Ci(n)?n?.[e][s].value:Vi(n,this.locale),l="number"==typeof r,c="number"==typeof a;l&&c?(Pi((()=>a>=0),Tu),t+=r*a,o+=a):Pi((()=>l===c),Fo("[[FUNCTION_NAME]] expects number values."))}else{const e=Vi(i,this.locale),s=Ci(n)?n?.[0][0].value:Vi(n,this.locale);"number"==typeof s&&(Pi((()=>s>=0),Tu),t+=e*s,o+=s)}}return Gi(o),{value:t/o,format:Ni(e[0])}}},_u={description:Fo("Numerical average value in a dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the average value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=nn(e,((e,o)=>(t+=1,e+o)),0,this.locale);return Gi(t),{value:o/t,format:Ni(e[0])}},isExported:!0},Du={description:Fo("Average of values depending on criteria."),args:[Dh("criteria_range (number, range<number>)",Fo("The range to check against criterion.")),Dh("criterion (string)",Fo("The pattern or test to apply to criteria_range.")),Dh("average_range (number, range<number>, default=criteria_range)",Fo("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=bn(void 0===o?e:o);let i=0,n=0;return gn([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,n+=o)}),this.locale),Gi(i),n/i},isExported:!0},Ou={description:Fo("Average of values depending on multiple criteria."),args:[Dh("average_range (range)",Fo("The range to average.")),Dh("criteria_range1 (range)",Fo("The range to check against criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional criteria_range and criterion to check.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=bn(e);let s=0,i=0;return gn(t,((e,t)=>{const n=o[e]?.[t]?.value;"number"==typeof n&&(s+=1,i+=n)}),this.locale),Gi(s),i/s},isExported:!0},Fu={description:Fo("The number of numeric values in dataset."),args:[Dh("value1 (number, any, range<number>)",Fo("The first value or range to consider when counting.")),Dh("value2 (number, any, range<number>, repeating)",Fo("Additional values or ranges to consider when counting."))],compute:function(...e){return tl(e,this.locale)},isExported:!0},Mu={description:Fo("The number of values in a dataset."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider when counting.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider when counting."))],compute:function(...e){return ol(e)},isExported:!0},Pu={description:Fo("The covariance of a dataset."),args:[Dh("data_y (any, range)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (any, range)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Cu(e,t,!1)},isExported:!0},Nu={description:Fo("The covariance of a dataset."),args:[Dh("data_y (any, range)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (any, range)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Cu(e,t,!1)},isExported:!0},ku={description:Fo("The sample covariance of a dataset."),args:[Dh("data_y (any, range)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (any, range)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Cu(e,t,!0)},isExported:!0},Lu={description:Fo("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[Dh("x (number, range<number>)",Fo("The value(s) on the x-axis to forecast.")),Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=yu(t,o);return ul([i],[s],an(bn(e),(e=>Vi(e,this.locale))),!0)},isExported:!0},Vu={description:Fo("Fits points to exponential growth trend."),args:[Dh("known_data_y (range<number>)",Fo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),Dh("known_data_x (range<number>, default={1;2;3;...})",Fo("The values of the independent variable(s) corresponding with known_data_y.")),Dh("new_data_x (any, range, default=known_data_x)",Fo("The data points to return the y values for on the ideal curve fit.")),Dh("b (boolean, default=TRUE)",Fo("Given a general exponential form of y = b*m^x for a curve fit, calculates b if TRUE or forces b to be 1 and only calculates the m values if FALSE."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return hl(ul(dl(Ui(e,"the first argument (known_data_y)")),Ui(t,"the second argument (known_data_x)"),Ui(o,"the third argument (new_data_y)"),Yi(s)))}},Hu={description:Fo("Compute the intercept of the linear regression."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t),[[],[i]]=rl([o],[s]);return i},isExported:!0},Uu={description:Fo("Nth largest element from a data set."),args:[Dh("data (any, range)",Fo("Array or range containing the dataset to consider.")),Dh("n (number)",Fo("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(Vi(t?.value,this.locale));let s,i=[],n=0;Qi([e],(e=>{"number"==typeof e?.value&&(s=pn(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),n++,n>o&&(i.shift(),n--))}));const r=i.shift();return Pi((()=>void 0!==r),Fo("[[FUNCTION_NAME]] has no valid input data.")),Pi((()=>n>=o),Fo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),r},isExported:!0},Bu={description:Fo("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>, default={1;2;3;...})",Fo("The range representing the array or matrix of independent data.")),Dh("calculate_b (boolean, default=TRUE)",Fo("A flag specifying wheter to compute the slope or not")),Dh("verbose (boolean, default=FALSE)",Fo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){return rl(Ui(t,"the first argument (data_y)"),Ui(e,"the second argument (data_x)"),Yi(o),Yi(s))},isExported:!0},zu={description:Fo("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>, optional, default={1;2;3;...})",Fo("The range representing the array or matrix of independent data.")),Dh("calculate_b (boolean, default=TRUE)",Fo("A flag specifying wheter to compute the slope or not")),Dh("verbose (boolean, default=FALSE)",Fo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){const i=rl(Ui(t,"the second argument (data_x)"),dl(Ui(e,"the first argument (data_y)")),Yi(o),Yi(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},$u={description:Fo("Compute the Matthews correlation coefficient of a dataset."),args:[Dh("data_x (range)",Fo("The range representing the array or matrix of observed data.")),Dh("data_y (range)",Fo("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(Qa(o,s),0===o.length)return new Ti(Fo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));const i=o.length;let n=0,r=0,a=0,l=0;for(let e=0;e<i;++e){const t=Yi(o[e]);t===Yi(s[e])?t?r++:n++:t?l++:a++}return(r*n-a*l)/Math.sqrt((r+a)*(r+l)*(n+a)*(n+l))},isExported:!1},Wu={description:Fo("Maximum value in a numeric dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the maximum value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return sl(e,this.locale)},isExported:!0},Gu={description:Fo("Maximum numeric value in a dataset."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider when calculating the maximum value.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=nn(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:Ni(e[0])}},isExported:!0},qu={description:Fo("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[Dh("range (range)",Fo("The range of cells from which the maximum will be determined.")),Dh("criteria_range1 (range)",Fo("The range of cells over which to evaluate criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return gn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o<i?i:o)}),this.locale),o===-1/0?0:o},isExported:!0},Zu={description:Fo("Median value in a numeric dataset."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider when calculating the median value.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){let t=[];return en(e,(e=>{t.push(e)}),this.locale),{value:xu(t,{value:.5},!0,this.locale),format:Ni(t[0])}},isExported:!0},ju={description:Fo("Minimum value in a numeric dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the minimum value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return il(e,this.locale)},isExported:!0},Yu={description:Fo("Minimum numeric value in a dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the minimum value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=nn(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:Ni(e[0])}},isExported:!0},Xu={description:Fo("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[Dh("range (range)",Fo("The range of cells from which the minimum will be determined.")),Dh("criteria_range1 (range)",Fo("The range of cells over which to evaluate criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return gn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o>i?i:o)}),this.locale),o===1/0?0:o},isExported:!0};function Ku(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t);if(0===o.length)throw new Ti(Fo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));if(o.length<2)throw new Ti(Fo("[[FUNCTION_NAME]] needs at least two values for both parameters."));const i=o.length;let n=0,r=0,a=0,l=0,c=0;for(let e=0;e<i;e++){const t=o[e],i=s[e];n+=t,r+=i,a+=t*i,l+=t*t,c+=i*i}return(i*a-n*r)/Math.sqrt((i*l-n*n)*(i*c-r*r))}const Ju={description:Fo("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Ku(e,t)},isExported:!0},Qu=Ju,eg={description:Fo("Value at a given percentile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("percentile (number)",Fo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return og.compute.bind(this)(e,t)},isExported:!0},tg={description:Fo("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("percentile (number)",Fo("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:xu([e],t,!1,this.locale),format:Ni(e)}},isExported:!0},og={description:Fo("Value at a given percentile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("percentile (number)",Fo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:xu([e],t,!0,this.locale),format:Ni(e)}},isExported:!0},sg={description:Fo("Compute the coefficients of polynomial regression of the dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data.")),Dh("order (number)",Fo("The order of the polynomial to fit the data, between 1 and 6.")),Dh("intercept (boolean, default=TRUE)",Fo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:n}=yu(e,t);return al(n,i,Vi(o,this.locale),Yi(s))},isExported:!1},ig={description:Fo("Predict value by computing a polynomial regression of the dataset."),args:[Dh("x (number, range<number>)",Fo("The value(s) on the x-axis to forecast.")),Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data.")),Dh("order (number)",Fo("The order of the polynomial to fit the data, between 1 and 6.")),Dh("intercept (boolean, default=TRUE)",Fo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s,i={value:!0}){const n=Vi(s,this.locale),{flatDataX:r,flatDataY:a}=yu(t,o),l=al(a,r,n,Yi(i)).flat();return an(bn(e),(e=>cl(l,Vi(e,this.locale),n)))},isExported:!1},ng={description:Fo("Value nearest to a specific quartile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("quartile_number (number)",Fo("Which quartile value to return."))],compute:function(e,t){return ag.compute.bind(this)(e,t)},isExported:!0},rg={description:Fo("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("quartile_number (number)",Fo("Which quartile value, exclusive of 0 and 4, to return."))],compute:function(e,t){return{value:xu([e],{value:.25*Math.trunc(Vi(t,this.locale))},!1,this.locale),format:Ni(e)}},isExported:!0},ag={description:Fo("Value nearest to a specific quartile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("quartile_number (number)",Fo("Which quartile value to return."))],compute:function(e,t){return{value:xu([e],{value:.25*Math.trunc(Vi(t,this.locale))},!0,this.locale),format:Ni(e)}},isExported:!0},lg={description:Fo("Returns the rank of a specified value in a dataset."),args:[Dh("value (number)",Fo("The value whose rank will be determined.")),Dh("data (range)",Fo("The range containing the dataset to consider.")),Dh("is_ascending (boolean, default=FALSE)",Fo("Whether to consider the values in data in descending or ascending order."))],compute:function(e,t,o={value:!1}){const s=Yi(o),i=Vi(e,this.locale);let n=1,r=!1;for(const e of t)for(const t of e){if("number"!=typeof t.value)continue;const e=Vi(t,this.locale);e===i?r=!0:e>i!==s&&n++}if(!r)throw new Di(Fo("Value not found in the given data."));return n},isExported:!0},cg={description:Fo("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Math.pow(Ku(t,e),2)},isExported:!0},hg={description:Fo("Compute the slope of the linear regression."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t),[[i]]=rl([o],[s]);return i},isExported:!0},dg={description:Fo("Nth smallest element in a data set."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("n (number)",Fo("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(Vi(t?.value,this.locale));let s,i=[],n=0;Qi([e],(e=>{"number"==typeof e?.value&&(s=pn(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),n++,n>o&&(i.pop(),n--))}));const r=i.pop();return Pi((()=>void 0!==r),Fo("[[FUNCTION_NAME]] has no valid input data.")),Pi((()=>n>=o),Fo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),r},isExported:!0},ug={description:Fo("Compute the Spearman rank correlation coefficient of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(t,e),i=o.length,n=o.map(((e,t)=>[e,s[t]]));n.sort(((e,t)=>e[0]-t[0]));for(let e=0;e<i;++e)n[e][0]=e;n.sort(((e,t)=>e[1]-t[1]));let r=0;for(let e=0;e<i;++e)r+=(n[e][0]-e)**2;return 1-6*r/(i**3-i)},isExported:!1},gg={description:Fo("Standard deviation."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Cg.compute.bind(this)(...e))},isExported:!0},pg={description:Fo("Standard deviation of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(wg.compute.bind(this)(...e))},isExported:!0},mg={description:Fo("Standard deviation."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(xg.compute.bind(this)(...e))},isExported:!0},fg={description:Fo("Standard deviation of sample (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Eg.compute.bind(this)(...e))},isExported:!0},vg={description:Fo("Standard deviation of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Ig.compute.bind(this)(...e))},isExported:!0},bg={description:Fo("Standard deviation of entire population (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Rg.compute.bind(this)(...e))},isExported:!0},Sg={description:Fo("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t);return rl([o],[s],!0,!0)[1][2]},isExported:!0},yg={description:Fo("Fits points to linear trend derived via least-squares."),args:[Dh("known_data_y (number, range<number>)",Fo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),Dh("known_data_x (number, range<number>, optional, default={1;2;3;...})",Fo("The values of the independent variable(s) corresponding with known_data_y.")),Dh("new_data_x (number, range<number>, optional, default=known_data_x)",Fo("The data points to return the y values for on the ideal curve fit.")),Dh("b (boolean, optional, default=TRUE)",Fo("Given a general linear form of y = m*x+b for a curve fit, calculates b if TRUE or forces b to be 0 and only calculates the m values if FALSE, i.e. forces the curve fit to pass through the origin."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return ul(Ui(e,"the first argument (known_data_y)"),Ui(t,"the second argument (known_data_x)"),Ui(o,"the third argument (new_data_y)"),Yi(s))}},Cg={description:Fo("Variance."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return wu(e,!0,!1,this.locale)},isExported:!0},wg={description:Fo("Variance of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return wu(e,!1,!1,this.locale)},isExported:!0},xg={description:Fo("Variance."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return wu(e,!0,!1,this.locale)},isExported:!0},Eg={description:Fo("Variance of sample (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return wu(e,!0,!0,this.locale)},isExported:!0},Ig={description:Fo("Variance of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return wu(e,!1,!1,this.locale)},isExported:!0},Rg={description:Fo("Variance of entire population (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return wu(e,!1,!0,this.locale)},isExported:!0};var Tg=Object.freeze({__proto__:null,AVEDEV:Eu,AVERAGE:Iu,AVERAGEA:_u,AVERAGEIF:Du,AVERAGEIFS:Ou,AVERAGE_WEIGHTED:Au,CORREL:Qu,COUNT:Fu,COUNTA:Mu,COVAR:Pu,COVARIANCE_P:Nu,COVARIANCE_S:ku,FORECAST:Lu,GROWTH:Vu,INTERCEPT:Hu,LARGE:Uu,LINEST:Bu,LOGEST:zu,MATTHEWS:$u,MAX:Wu,MAXA:Gu,MAXIFS:qu,MEDIAN:Zu,MIN:ju,MINA:Yu,MINIFS:Xu,PEARSON:Ju,PERCENTILE:eg,PERCENTILE_EXC:tg,PERCENTILE_INC:og,POLYFIT_COEFFS:sg,POLYFIT_FORECAST:ig,QUARTILE:ng,QUARTILE_EXC:rg,QUARTILE_INC:ag,RANK:lg,RSQ:cg,SLOPE:hg,SMALL:dg,SPEARMAN:ug,STDEV:gg,STDEVA:fg,STDEVP:vg,STDEVPA:bg,STDEV_P:pg,STDEV_S:mg,STEYX:Sg,TREND:yg,VAR:Cg,VARA:Eg,VARP:Ig,VARPA:Rg,VAR_P:wg,VAR_S:xg});function Ag(e,t,o,s){const i=new Map,n=e.length;for(let t=n-1;t>=0;t--)i.set(qi(e[t][0]).toUpperCase(),t);const r=t?.value;if("number"!=typeof r&&"string"!=typeof r)throw new Ti(Fo("The field must be a number or a string"));let a;if("number"==typeof r){if(a=Math.trunc(r)-1,a<0||n-1<a)throw new Ti(Fo("The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.",{fieldValue:r.toString(),dimRowDB:n.toString()}))}else{const e=qi(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new Ti(Fo("The field (%s) must be one of %s.",qi(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new Ti(Fo("The criteria range contains %s row, it must be at least 2 rows.",l.toString()));let c=new Set;const h=e[0].length;for(let t=1;t<l;t++){let n=[],r=!0;for(let s=0;s<o.length;s++){const a=qi(o[s][0]).toUpperCase(),l=i.get(a),c=o[s][t];if(null!==c.value){if(void 0===l){r=!1;break}n.push([e[l].slice(1,h)]),n.push(c)}}if(r){if(!(n.length>0)){c=new Set(Array(h-1).keys());break}gn(n,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const _g=[Dh("database (range)",Fo("The array or range containing the data to consider, structured in such a way that the first row contains the labels for each column's values.")),Dh("field (number, string)",Fo("Indicates which column in database contains the values to be extracted and operated on.")),Dh("criteria (range)",Fo("An array or range containing zero or more criteria to filter the database values by before operating."))],Dg={description:Fo("Average of a set of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Iu.compute.bind(this)([s])},isExported:!0},Og={description:Fo("Counts values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Fu.compute.bind(this)([s])},isExported:!0},Fg={description:Fo("Counts values and text from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Mu.compute.bind(this)([s])},isExported:!0},Mg={description:Fo("Single value from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Pi((()=>1===s.length),Fo("More than one match found in DGET evaluation.")),s[0]},isExported:!0},Pg={description:Fo("Maximum of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Wu.compute.bind(this)([s])},isExported:!0},Ng={description:Fo("Minimum of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return ju.compute.bind(this)([s])},isExported:!0},kg={description:Fo("Product of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Jd.compute.bind(this)([s])},isExported:!0},Lg={description:Fo("Standard deviation of population sample from table."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return gg.compute.bind(this)([s])},isExported:!0},Vg={description:Fo("Standard deviation of entire population from table."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return vg.compute.bind(this)([s])},isExported:!0},Hg={description:Fo("Sum of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return du.compute.bind(this)([s])},isExported:!0},Ug={description:Fo("Variance of population sample from table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Cg.compute.bind(this)([s])},isExported:!0},Bg={description:Fo("Variance of a population from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Ig.compute.bind(this)([s])},isExported:!0};var zg=Object.freeze({__proto__:null,DAVERAGE:Dg,DCOUNT:Og,DCOUNTA:Fg,DGET:Mg,DMAX:Pg,DMIN:Ng,DPRODUCT:kg,DSTDEV:Lg,DSTDEVP:Vg,DSUM:Hg,DVAR:Ug,DVARP:Bg});var $g;!function(e){e.WHOLE_YEARS="Y",e.WHOLE_MONTHS="M",e.WHOLE_DAYS="D",e.DAYS_WITHOUT_WHOLE_MONTHS="MD",e.MONTH_WITHOUT_WHOLE_YEARS="YM",e.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR="YD"}($g||($g={}));const Wg={description:Fo("Converts year/month/day into a date."),args:[Dh("year (number)",Fo("The year component of the date.")),Dh("month (number)",Fo("The month component of the date.")),Dh("day (number)",Fo("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(Vi(e,this.locale));const i=Math.trunc(Vi(t,this.locale)),n=Math.trunc(Vi(o,this.locale));Pi((()=>0<=s&&s<=9999),Fo("The year (%s) must be between 0 and 9999 inclusive.",s.toString())),s<1900&&(s+=1900);const r=zs(new Is(s,i-1,n));return Pi((()=>r>=0),Fo("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")),{value:r,format:this.locale.dateFormat}},isExported:!0},Gg={description:Fo("Calculates the number of days, months, or years between two dates."),args:[Dh("start_date (date)",Fo("The start date to consider in the calculation. Must be a reference to a cell containing a DATE, a function returning a DATE type, or a number.")),Dh("end_date (date)",Fo("The end date to consider in the calculation. Must be a reference to a cell containing a DATE, a function returning a DATE type, or a number.")),Dh("unit (string)",Fo('A text abbreviation for unit of time. Accepted values are "Y" (the number of whole years between start_date and end_date), "M" (the number of whole months between start_date and end_date), "D" (the number of days between start_date and end_date), "MD" (the number of days between start_date and end_date after subtracting whole months), "YM" (the number of whole months between start_date and end_date after subtracting whole years), "YD" (the number of days between start_date and end_date, assuming start_date and end_date were no more than one year apart).'))],compute:function(e,t,o){const s=qi(o).toUpperCase();Pi((()=>Object.values($g).includes(s)),((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return Fo("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values($g),qi(o)));const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Bs(i),a=Bs(n);switch(Pi((()=>n>=i),Fo("start_date (%s) should be on or before end_date (%s).",r.toLocaleDateString(),a.toLocaleDateString())),s){case $g.WHOLE_YEARS:return Ks(r,a);case $g.WHOLE_MONTHS:return Ys(r,a);case $g.WHOLE_DAYS:return Xs(r,a);case $g.MONTH_WITHOUT_WHOLE_YEARS:return Ys(r,a)-12*Ks(r,a);case $g.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-r.getDate();if(e<0){e=Ws(new Is(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case $g.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return js(e,t,1)<1}(i,n))return Xs(r,a);const e=new Is(r.getFullYear(),a.getMonth(),a.getDate());let t=Xs(r,e);return t<0&&(e.setFullYear(r.getFullYear()+1),t=Xs(r,e)),t}}},isExported:!0},qg={description:Fo("Converts a date string to a date value."),args:[Dh("date_string (string)",Fo("The string representing the date."))],compute:function(e){const t=qi(e),o=Us(t,this.locale);return Pi((()=>null!==o),Fo("The date_string (%s) cannot be parsed to date/time.",t.toString())),Math.trunc(o.value)},isExported:!0},Zg={description:Fo("Day of the month that a specific date falls on."),args:[Dh("date (string)",Fo("The date from which to extract the day."))],compute:function(e){return Xi(e,this.locale).getDate()},isExported:!0},jg={description:Fo("Number of days between two dates."),args:[Dh("end_date (date)",Fo("The end of the date range.")),Dh("start_date (date)",Fo("The start of the date range."))],compute:function(e,t){const o=Xi(e,this.locale),s=Xi(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/Ts)},isExported:!0},Yg={description:Fo("Number of days between two dates on a 360-day year (months of 30 days)."),args:[Dh("start_date (date)",Fo("The start date to consider in the calculation.")),Dh("end_date (date)",Fo("The end date to consider in the calculation.")),Dh("method (number, default=0)",Fo("An indicator of what day count method to use. (0) US NASD method (1) European method"))],compute:function(e,t,o={value:0}){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=js(s,i,Yi(o)?4:0);return Math.sign(i-s)*Math.round(360*n)},isExported:!0},Xg={description:Fo("Date a number of months before/after another date."),args:[Dh("start_date (date)",Fo("The date from which to calculate the result.")),Dh("months (number)",Fo("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:zs(qs(Xi(e,this.locale),Math.trunc(Vi(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},Kg={description:Fo("Last day of a month before or after a date."),args:[Dh("start_date (date)",Fo("The date from which to calculate the result.")),Dh("months (number)",Fo("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Xi(e,this.locale),s=Math.trunc(Vi(t,this.locale)),i=o.getFullYear(),n=o.getMonth();return{value:zs(new Is(i,n+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Jg={description:Fo("Hour component of a specific time."),args:[Dh("time (date)",Fo("The time from which to calculate the hour component."))],compute:function(e){return Xi(e,this.locale).getHours()},isExported:!0},Qg={description:Fo("ISO week number of the year."),args:[Dh("date (date)",Fo("The date for which to determine the ISO week number. Must be a reference to a cell containing a date, a function returning a date type, or a number."))],compute:function(e){const t=Xi(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new Is(o,0,s).getDay();)s+=1;const i=new Is(o,0,s-3);let n=31;for(;4!==new Is(o,11,n).getDay();)n-=1;const r=new Is(o,11,n+3);let a,l;switch(a=i.getTime()<=t.getTime()?t.getTime()<=r.getTime()?0:1:-1,a){case 0:l=i;break;case 1:l=new Is(o,11,n+3+1);break;case-1:let e=1;for(;4!==new Is(o-1,0,e).getDay();)e+=1;l=new Is(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/Ts;return Math.floor(c/7)+1},isExported:!0},ep={description:Fo("Minute component of a specific time."),args:[Dh("time (date)",Fo("The time from which to calculate the minute component."))],compute:function(e){return Xi(e,this.locale).getMinutes()},isExported:!0},tp={description:Fo("Month of the year a specific date falls in"),args:[Dh("date (date)",Fo("The date from which to extract the month."))],compute:function(e){return Xi(e,this.locale).getMonth()+1},isExported:!0},op={description:Fo("Net working days between two provided days."),args:[Dh("start_date (date)",Fo("The start date of the period from which to calculate the number of net working days.")),Dh("end_date (date)",Fo("The end date of the period from which to calculate the number of net working days.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return ip.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function sp(e){const t=e?.value;if("string"==typeof t){Pi((()=>{if(7!==t.length)return!1;for(let e of t)if("0"!==e&&"1"!==e)return!1;return!0}),Fo('When weekend is a string (%s) it must be composed of "0" or "1".',t));let e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return Pi((()=>1<=t&&t<=7||11<=t&&t<=17),Fo("The weekend (%s) must be a string or a number in the range 1-7 or 11-17.",t.toString())),t<=7?[t-2==-1?6:t-2,t-1]:[t-11];throw new Ti(Fo("The weekend must be a number or a string."))}const ip={description:Fo("Net working days between two dates (specifying weekends)."),args:[Dh("start_date (date)",Fo("The start date of the period from which to calculate the number of net working days.")),Dh("end_date (date)",Fo("The end date of the period from which to calculate the number of net working days.")),Dh("weekend (any, default=1)",Fo("A number or string representing which days of the week are considered weekends.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Xi(e,this.locale),n=Xi(t,this.locale),r=sp(o);let a=new Set;void 0!==s&&Qi([s],(e=>{const t=Xi(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>n.getTime(),c=Is.fromTimestamp((l?i:n).getTime());let h=Is.fromTimestamp((l?n:i).getTime());const d=c.getTime();let u=h.getTime(),g=0;for(;u<=d;)r.includes(h.getDay())||a.has(u)||(g+=1),h.setDate(h.getDate()+1),u=h.getTime();return l?-g:g},isExported:!0},np={description:Fo("Current date and time as a date value."),args:[],compute:function(){const e=Is.now(),t=e.getTime()-Rs.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/Ts)+o,format:za(this.locale)}},isExported:!0},rp={description:Fo("Minute component of a specific time."),args:[Dh("time (date)",Fo("The time from which to calculate the second component."))],compute:function(e){return Xi(e,this.locale).getSeconds()},isExported:!0},ap={description:Fo("Converts hour/minute/second into a time."),args:[Dh("hour (number)",Fo("The hour component of the time.")),Dh("minute (number)",Fo("The minute component of the time.")),Dh("second (number)",Fo("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Math.trunc(Vi(o,this.locale));return i+=Math.floor(n/60),n=n%60+(n<0?60:0),s+=Math.floor(i/60),i=i%60+(i<0?60:0),s%=24,Pi((()=>s>=0),Fo("The function [[FUNCTION_NAME]] result cannot be negative")),{value:s/24+i/1440+n/86400,format:this.locale.timeFormat}},isExported:!0},lp={description:Fo("Converts a time string into its serial number representation."),args:[Dh("time_string (string)",Fo("The string that holds the time representation."))],compute:function(e){const t=qi(e),o=Us(t,this.locale);Pi((()=>null!==o),Fo("The time_string (%s) cannot be parsed to date/time.",t));const s=o.value-Math.trunc(o.value);return s<0?1+s:s},isExported:!0},cp={description:Fo("Current date as a date value."),args:[],compute:function(){const e=Is.now();return{value:zs(new Is(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},hp={description:Fo("Day of the week of the date provided (as number)."),args:[Dh("date (date)",Fo("The date for which to determine the day of the week. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("type (number, default=1)",Fo("A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1."))],compute:function(e,t={value:1}){const o=Xi(e,this.locale),s=Math.round(Vi(t,this.locale)),i=o.getDay();return Pi((()=>[1,2,3].includes(s)),Fo("The type (%s) must be 1, 2 or 3.",s.toString())),1===s?i+1:2===s?0===i?7:i:0===i?6:i-1},isExported:!0},dp={description:Fo("Week number of the year."),args:[Dh("date (date)",Fo("The date for which to determine the week number. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("type (number, default=1)",Fo("A number representing the day that a week starts on. Sunday = 1."))],compute:function(e,t={value:1}){const o=Xi(e,this.locale),s=Math.round(Vi(t,this.locale));if(Pi((()=>1===s||2===s||11<=s&&s<=17||21===s),Fo("The type (%s) is out of range.",s.toString())),21===s)return Qg.compute.bind(this)(e);let i;i=1===s||2===s?s-1:s-10==7?0:s-10;const n=o.getFullYear();let r=1,a=new Is(n,0,r);for(;a.getDay()!==i;)r+=1,a=new Is(n,0,r);const l=(o.getTime()-a.getTime())/Ts;return l<0?1:Math.floor(l/7)+(1===r?1:2)},isExported:!0},up={description:Fo("Date after a number of workdays."),args:[Dh("start_date (date)",Fo("The date from which to begin counting.")),Dh("num_days (number)",Fo("The number of working days to advance from start_date. If negative, counts backwards.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return gp.compute.bind(this)(e,t,{value:1},o)},isExported:!0},gp={description:Fo("Date after a number of workdays (specifying weekends)."),args:[Dh("start_date (date)",Fo("The date from which to begin counting.")),Dh("num_days (number)",Fo("The number of working days to advance from start_date. If negative, counts backwards.")),Dh("weekend (any, default=1)",Fo("A number or string representing which days of the week are considered weekends.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){let i=Xi(e,this.locale),n=Math.trunc(Vi(t,this.locale));"string"==typeof o.value&&Pi((()=>"1111111"!==o.value),Fo("The weekend must be different from '1111111'."));const r=sp(o);let a=new Set;void 0!==s&&Qi([s],(e=>{const t=Xi(e,this.locale);a.add(t.getTime())}));let l=Is.fromTimestamp(i.getTime()),c=l.getTime();const h=Math.sign(n);let d=Math.abs(n);for(;d>0;)l.setDate(l.getDate()+h),c=l.getTime(),r.includes(l.getDay())||a.has(c)||(d-=1);const u=c-Rs.getTime();return{value:Math.round(u/Ts),format:this.locale.dateFormat}},isExported:!0},pp={description:Fo("Year specified by a given date."),args:[Dh("date (date)",Fo("The date from which to extract the year."))],compute:function(e){return Xi(e,this.locale).getFullYear()},isExported:!0},mp={description:Fo("Exact number of years between two dates."),args:[Dh("start_date (date)",Fo("The start date to consider in the calculation. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("end_date (date)",Fo("The end date to consider in the calculation. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("day_count_convention (number, default=0)",Fo("An indicator of what day count method to use."))],compute:function(e,t,o={value:0}){let s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale));const n=Math.trunc(Vi(o,this.locale));return Pi((()=>s>=0),Fo("The start_date (%s) must be positive or null.",s.toString())),Pi((()=>i>=0),Fo("The end_date (%s) must be positive or null.",i.toString())),Pi((()=>0<=n&&n<=4),Fo("The day_count_convention (%s) must be between 0 and 4 inclusive.",n.toString())),js(s,i,n)}},fp={description:Fo("First day of the month preceding a date."),args:[Dh("date (date)",Fo("The date from which to calculate the result."))],compute:function(e){const t=Xi(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:zs(new Is(o,s,1)),format:this.locale.dateFormat}}},vp={description:Fo("Last day of the month following a date."),args:[Dh("date (date)",Fo("The date from which to calculate the result."))],compute:function(e){return Kg.compute.bind(this)(e,{value:0})}},bp={description:Fo("Quarter of the year a specific date falls in"),args:[Dh("date (date)",Fo("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Xi(e,this.locale).getMonth()+1)/3)}},Sp={description:Fo("First day of the quarter of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the start of quarter."))],compute:function(e){const t=bp.compute.bind(this)(e),o=pp.compute.bind(this)(e);return{value:zs(new Is(o,3*(t-1),1)),format:this.locale.dateFormat}}},yp={description:Fo("Last day of the quarter of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the end of quarter."))],compute:function(e){const t=bp.compute.bind(this)(e),o=pp.compute.bind(this)(e);return{value:zs(new Is(o,3*t,0)),format:this.locale.dateFormat}}},Cp={description:Fo("First day of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the start of the year."))],compute:function(e){const t=pp.compute.bind(this)(e);return{value:zs(new Is(t,0,1)),format:this.locale.dateFormat}}},wp={description:Fo("Last day of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the end of the year."))],compute:function(e){const t=pp.compute.bind(this)(e);return{value:zs(new Is(t+1,0,0)),format:this.locale.dateFormat}}};var xp=Object.freeze({__proto__:null,DATE:Wg,DATEDIF:Gg,DATEVALUE:qg,DAY:Zg,DAYS:jg,DAYS360:Yg,EDATE:Xg,EOMONTH:Kg,HOUR:Jg,ISOWEEKNUM:Qg,MINUTE:ep,MONTH:tp,MONTH_END:vp,MONTH_START:fp,NETWORKDAYS:op,NETWORKDAYS_INTL:ip,NOW:np,QUARTER:bp,QUARTER_END:yp,QUARTER_START:Sp,SECOND:rp,TIME:ap,TIMEVALUE:lp,TODAY:cp,WEEKDAY:hp,WEEKNUM:dp,WORKDAY:up,WORKDAY_INTL:gp,YEAR:pp,YEARFRAC:mp,YEAR_END:wp,YEAR_START:Cp});const Ep={description:Fo("Compare two numeric values, returning 1 if they're equal."),args:[Dh("number1 (number)",Fo("The first number to compare.")),Dh("number2 (number, default=0)",Fo("The second number to compare."))],compute:function(e,t={value:0}){return Vi(e,this.locale)===Vi(t,this.locale)?1:0},isExported:!0};var Ip=Object.freeze({__proto__:null,DELTA:Ep});const Rp=[ni.number,ni.error,ni.text,ni.boolean];function Tp(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===ni.empty)return o.type===ni.empty?0:1;if(o.type===ni.empty)return-1;let s=Rp.indexOf(e.type)-Rp.indexOf(o.type);return 0===s&&(s=e.type===ni.text||e.type===ni.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function Ap(e,t,o,s,i){let n=s.right>s.left;if(e.model.getters.doesIntersectMerge(t,s)){let o;n=!1;for(let i=s.top;i<=s.bottom;i++){o=[];for(let n=s.left;n<=s.right;n++){let s=e.model.getters.getMerge({sheetId:t,col:n,row:i});s&&!o.includes(s.id.toString())&&o.push(s.id.toString())}if(o.length>=2){n=!0;break}}}if(n)return void _p(e,t,o,s,i);const r=e.model.getters.getContiguousZone(t,s);ns(r,s)?_p(e,t,o,s,i):e.askConfirmation(Fo("We found data next to your selection. Since this data was not selected, it will not be sorted. Do you want to extend your selection?"),(()=>_p(e,t,o,r,i)),(()=>_p(e,t,o,s,i)))}function _p(e,t,o,s,i,n){const r=e.model.dispatch("SORT_CELLS",{sheetId:t,col:o.col,row:o.row,zone:s,sortDirection:i,sortOptions:n});if(r.isCancelledBecause("InvalidSortZone")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Fo("Cannot sort. To sort, select only cells or only merges that have the same size."))}if(r.isCancelledBecause("SortZoneWithArrayFormulas")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Fo("Cannot sort a zone with array formulas."))}}function Dp(e,t,...o){for(const[e,t]of o.entries())Pi((()=>void 0!==t),Fo("Value for parameter %d is missing, while the function [[FUNCTION_NAME]] expect a number or a range.",e+1));const s=[],i=[],n=e.length;for(let r=0;r<o.length;r+=2){s.push(Yi(Ja(o[r+1])?.value)?"asc":"desc");const a=o[r];if(Ci(a)&&(a.length>1||a[0].length>1))Pi((()=>1===a.length&&a[0].length===n),Fo("Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.",`sort_column${r+1}`,n,a.length,a[0].length)),i.push(a.flat().map((e=>e.value)));else{const o=Vi(Ja(a)?.value,t);if(o<1||o>e[0].length)return e;i.push(e.map((e=>e[o-1].value)))}}if(0===i.length)for(let t=0;t<e[0].length;t++)i.push(e.map((e=>e[t].value))),s.push("asc");const r={desc:Tp("desc"),asc:Tp("asc")},a=Ze(0,e.length);return a.sort(((e,t)=>{for(const[o,n]of i.entries()){const i=n[e],a=n[t],l={value:i,type:null===i?ni.empty:"string"==typeof i?ni.text:typeof i},c={value:a,type:null===a?ni.empty:"string"==typeof a?ni.text:typeof a},h=r[s[o]](l,c);if(0!==h)return h}return 0})),a.map((t=>e[t]))}const Op={description:Fo("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[Dh("range (any, range<any>)",Fo("The data to be filtered.")),Dh("condition1 (boolean, range<boolean>)",Fo("A column or row containing true or false values corresponding to the first column or row of range.")),Dh("condition2 (boolean, range<boolean>, repeating)",Fo("Additional column or row containing true or false values."))],compute:function(e,...t){let o=bn(e);const s=t.map((e=>an(bn(e),(e=>e.value))));s.map((e=>Fh(Fo("The arguments condition must be a single column or row."),e))),Mh(Fo("The arguments conditions must have the same dimensions."),...t);const i=s.map((e=>e.flat())),n=1===s[0].length?"row":"col";o="row"===n?ln(o):o,Pi((()=>i.every((e=>e.length===o.length))),Fo("FILTER has mismatched sizes on the range and conditions."));const r=[];for(let e=0;e<o.length;e++){const t=o[e];i.every((t=>("boolean"==typeof t[e]||"number"==typeof t[e])&&t[e]))&&r.push(t)}return r.length?"row"===n?ln(r):r:new Di(Fo("No match found in FILTER evaluation"))},isExported:!0},Fp={description:Fo("Sorts the rows of a given array or range by the values in one or more columns."),args:[Dh("range (range)",Fo("The data to be sorted.")),Dh("sort_column (any, range<number>, repeating)",Fo("The index of the column in range or a range outside of range containing the values by which to sort.")),Dh("is_ascending (boolean, repeating)",Fo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,...t){const o=ln(e);return ln(Dp(o,this.locale,...t))},isExported:!0},Mp={description:Fo("Returns the first n items in a data set after performing a sort."),args:[Dh("range (range)",Fo("The data to be sorted.")),Dh("n (number, default=1)",Fo("The number of items to return.")),Dh("display_ties_mode (number, default=0)",Fo("A number representing the way to display ties.")),Dh("sort_column (number, range<number>, repeating)",Fo("The index of the column in range or a range outside of range containing the values by which to sort.")),Dh("is_ascending (boolean, repeating)",Fo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,t,o,...s){const i=Vi(t?.value??1,this.locale);Pi((()=>i>=0),Fo("Wrong value of 'n'. Expected a positive number. Got %s.",i));const n=Vi(o?.value??0,this.locale);Pi((()=>n>=0&&n<=3),Fo("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",n));const r=Dp(ln(e),this.locale,...s),a=(e,t)=>JSON.stringify(r[e].map((e=>e.value)))===JSON.stringify(r[t].map((e=>e.value)));switch(n){case 0:return ln(r.slice(0,i));case 1:for(let e=i;e<r.length;e++)if(!a(e,i-1))return ln(r.slice(0,e));return ln(r);case 2:{const e=[r[0]];for(let t=1;t<r.length;t++)for(let o=0;o<t&&!a(t,o);o++)o===t-1&&e.push(r[t]);return ln(e.slice(0,i))}case 3:{const e=[r[0]];let t=1;for(let o=1;o<r.length&&(a(o,o-1)||t++,!(t>i));o++)e.push(r[o]);return ln(e)}}},isExported:!0},Pp={description:Fo("Unique rows in the provided source range."),args:[Dh("range (any, range<any>)",Fo("The data to filter by unique entries.")),Dh("by_column (boolean, default=FALSE)",Fo("Whether to filter the data by columns or by rows.")),Dh("exactly_once (boolean, default=FALSE)",Fo("Whether to return only entries with no duplicates."))],compute:function(e={value:""},t,o){if(!Ci(e))return[[e]];const s=Yi(t?.value)||!1,i=Yi(o?.value)||!1;s||(e=ln(e));const n=new Map;for(const t of e){const e=JSON.stringify(t.map((e=>e.value))),o=n.get(e);o?o.count++:n.set(e,{data:t,count:1})}const r=[];for(const e of n.values())i&&e.count>1||r.push(e.data);if(!r.length)throw new Ti(Fo("No unique values found"));return s?r:ln(r)},isExported:!0};var Np=Object.freeze({__proto__:null,FILTER:Op,SORT:Fp,SORTN:Mp,UNIQUE:Pp});function kp(e,t){Pi((()=>e<t),Fo("The maturity (%s) must be strictly greater than the settlement (%s).",t.toString(),e.toString()))}function Lp(e,t){Pi((()=>t<e),Fo("The settlement date (%s) must be strictly greater than the issue date (%s).",e.toString(),t.toString()))}function Vp(e){Pi((()=>[1,2,4].includes(e)),Fo("The frequency (%s) must be one of %s",e.toString(),[1,2,4].toString()))}function Hp(e){Pi((()=>0<=e&&e<=4),Fo("The day_count_convention (%s) must be between 0 and 4 inclusive.",e.toString()))}function Up(e){Pi((()=>e>0),Fo("The redemption (%s) must be strictly positive.",e.toString()))}function Bp(e){Pi((()=>e>0),Fo("The price (%s) must be strictly positive.",e.toString()))}function zp(e){Pi((()=>e>0),Fo("The number_of_periods (%s) must be greater than 0.",e.toString()))}function $p(e){Pi((()=>e>0),Fo("The rate (%s) must be strictly positive.",e.toString()))}function Wp(e){Pi((()=>e>0),Fo("The life (%s) must be strictly positive.",e.toString()))}function Gp(e){Pi((()=>e>=0),Fo("The cost (%s) must be positive or null.",e.toString()))}function qp(e){Pi((()=>e>0),Fo("The period (%s) must be strictly positive.",e.toString()))}function Zp(e){Pi((()=>e>=0),Fo("The salvage (%s) must be positive or null.",e.toString()))}function jp(e){Pi((()=>e>0),Fo("The present value (%s) must be strictly positive.",e.toString()))}function Yp(e,t){Pi((()=>e<=t),Fo("The period (%s) must be less than or equal life (%s).",e.toString(),t.toString()))}function Xp(e){Pi((()=>e>0),Fo("The investment (%s) must be strictly positive.",e.toString()))}function Kp(e){Pi((()=>e>0),Fo("The discount (%s) must be strictly positive.",e.toString()))}function Jp(e){Pi((()=>e<1),Fo("The discount (%s) must be smaller than 1.",e.toString()))}function Qp(e){Pi((()=>e>0),Fo("The depreciation factor (%s) must be strictly positive.",e.toString()))}function em(e,t,o){const s=Xi(e,o),i=Xi(t,o),n=Xi(e,o);n.setFullYear(s.getFullYear()+1),Pi((()=>i.getTime()<=n.getTime()),Fo("The settlement date (%s) must at most one year after the maturity date (%s).",e.toString(),t.toString()))}function tm(e,t,o){zp(o),Pi((()=>e>0),Fo("The first_period (%s) must be strictly positive.",e.toString())),Pi((()=>t>0),Fo("The last_period (%s) must be strictly positive.",t.toString())),Pi((()=>e<=t),Fo("The first_period (%s) must be smaller or equal to the last_period (%s).",e.toString(),t.toString())),Pi((()=>t<=o),Fo("The last_period (%s) must be smaller or equal to the number_of_periods (%s).",e.toString(),o.toString()))}function om(e){Pi((()=>e>-1),Fo("The rate_guess (%s) must be strictly greater than -1.",e.toString()))}function sm(e,t){Pi((()=>e.length===t.length&&e[0].length===t[0].length),Fo("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."))}function im(e){Pi((()=>e.every((t=>t>=e[0]))),Fo("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e[0].toString()))}const nm=[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))];function rm(e,t,o,s,i=1e-10,n){let r,a,l,c,h=o,d=!1,u=0;do{l=e(h),isNaN(l)?(Pi((()=>u<s&&void 0!==n),Fo("Function [[FUNCTION_NAME]] didn't find any result.")),u++,h=n(c),c=h):(r=h-l/t(h),a=Math.abs(r-h),h=r,d=a<i||Math.abs(l)<i,Pi((()=>u<s),Fo("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const am={description:Fo("Accrued interest of security paying at maturity."),args:[Dh("issue (date)",Fo("The date the security was initially issued.")),Dh("maturity (date)",Fo("The maturity date of the security.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(s,this.locale),l=Vi(o,this.locale),c=Math.trunc(Vi(i,this.locale));!function(e){Pi((()=>e>=0),Fo("The issue (%s) must be positive or null.",e.toString()))}(n),Lp(r,n),Hp(c),Up(a),$p(l);return a*l*js(n,r,c)},isExported:!0},lm={description:Fo("Depreciation for an accounting period."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("purchase_date (date)",Fo("The date the asset was purchased.")),Dh("first_period_end (date)",Fo("The date the first period ended.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation.")),Dh("rate (number)",Fo("The deprecation rate.")),Dh("day_count_convention (number, optional)",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Vi(e,this.locale),l=Math.trunc(Vi(t,this.locale)),c=Math.trunc(Vi(o,this.locale)),h=Vi(s,this.locale),d=Vi(i,this.locale),u=Vi(n,this.locale),g=Math.trunc(Vi(r,this.locale));!function(e){Pi((()=>e>0),Fo("The cost (%s) must be strictly positive.",e.toString()))}(a),function(e){Pi((()=>e>=0),Fo("The purchase_date (%s) must be positive or null.",e.toString()))}(l),Zp(h),function(e,t){Pi((()=>e<=t),Fo("The salvage (%s) must be smaller or equal than the cost (%s).",e.toString(),t.toString()))}(h,a),function(e){Pi((()=>e>=0),Fo("The period (%s) must be positive or null.",e.toString()))}(d),$p(u),Hp(g),Pi((()=>l<=c),Fo("The purchase_date (%s) must be before the first_period_end (%s).",l.toString(),c.toString()));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=js(l,c,g),v=l===c?m:m*f,b=a-v-m*p;return b>=h?0===p?v:m:h-b<m?m-(h-b):0},isExported:!0},cm={description:Fo("Days in coupon period containing settlement date."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));if(kp(i,n),Vp(r),Hp(a),1===a){const i=pm.compute.bind(this)(e,t,o,s).value;return um.compute.bind(this)(e,t,o,s).value-i}return(3===a?365:360)/r},isExported:!0},hm={description:Fo("Days from settlement until next coupon."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=pm.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return i-l;if(4===a){const e=js(l,i,a);return Math.round(360*e)}const c=Xi(i,this.locale),h=Xi(l,this.locale),d=h.getFullYear(),u=c.getFullYear(),g=h.getMonth()+1,p=c.getMonth()+1;let m=h.getDate(),f=c.getDate();return 2===g&&2===p&&Gs(h)&&Gs(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&Gs(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},dm={description:Fo("Days from settlement until next coupon."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=um.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return l-i;if(4===a){const e=js(i,l,a);return Math.round(360*e)}const c=hm.compute.bind(this)(e,t,o,s);return cm.compute.bind(this)(e,t,o,s)-c},isExported:!0},um={description:Fo("Next coupon date after the settlement date."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=12/r,c=gm.compute.bind(this)(e,t,o,s);return{value:zs(qs(Xi(n,this.locale),-(c-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},gm={description:Fo("Number of coupons between settlement and maturity."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);let l=1,c=n;const h=12/r;for(;c>i;)c=zs(qs(Xi(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},pm={description:Fo("Last coupon date prior to or on the settlement date."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=12/r,c=gm.compute.bind(this)(e,t,o,s);return{value:zs(qs(Xi(n,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},mm={description:Fo("Cumulative interest paid over a set of periods."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("first_period (number)",Fo("The number of the payment period to begin the cumulative calculation.")),Dh("last_period (number)",Fo("The number of the payment period to end the cumulative calculation.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,n={value:0}){const r=Vi(s,this.locale),a=Vi(i,this.locale),l=Vi(e,this.locale),c=Vi(o,this.locale),h=Vi(t,this.locale),d=Yi(n)?1:0;tm(r,a,h),$p(l),jp(c);let u=0;for(let e=r;e<=a;e++)u+=_m(l,e,h,c,0,d);return u},isExported:!0},fm={description:Fo("Cumulative principal paid over a set of periods."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("first_period (number)",Fo("The number of the payment period to begin the cumulative calculation.")),Dh("last_period (number)",Fo("The number of the payment period to end the cumulative calculation.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,n={value:0}){const r=Vi(s,this.locale),a=Vi(i,this.locale),l=Vi(e,this.locale),c=Vi(o,this.locale),h=Vi(t,this.locale),d=Yi(n)?1:0;tm(r,a,h),$p(l),jp(c);let u=0;for(let e=r;e<=a;e++)u+=zm(l,e,h,c,0,d);return u},isExported:!0},vm={description:Fo("Depreciation via declining balance method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation.")),Dh("month (number, optional)",Fo("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const n=Vi(e,this.locale),r=Vi(t,this.locale),a=Vi(o,this.locale),l=Math.trunc(Vi(s,this.locale)),c=i.length?Math.trunc(Vi(i[0],this.locale)):12,h=a+(12===c?0:1);Gp(n),Zp(r),qp(l),Wp(a),Pi((()=>1<=c&&c<=12),Fo("The month (%s) must be between 1 and 12 inclusive.",c.toString())),Pi((()=>l<=h),Fo("The period (%s) must be less than or equal to %s.",l.toString(),h.toString()));const d=c/12;let u=1-Math.pow(r/n,1/a);u=Math.round(1e3*u)/1e3;let g=n,p=n*(1-u*d);for(let e=1;e<l;e++)g=p,p=g*(1-u),e===a&&(p=g*(1-u*(1-d)));return{value:g-p,format:"#,##0.00"}},isExported:!0};function bm(e,t,o,s,i){if(Gp(e),Zp(t),qp(s),Wp(o),Yp(s,o),Qp(i),0===e||t>=e)return 0;const n=i/o;if(n>1)return 1===s?e-t:0;if(s<=1)return e*n;const r=e*Math.pow(1-n,s-1),a=e*Math.pow(1-n,s),l=a<t?r-t:r-a;return Math.max(l,0)}const Sm={description:Fo("Depreciation via double-declining balance method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation.")),Dh("factor (number, default=2)",Fo("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){return{value:bm(Vi(e,this.locale),Vi(t,this.locale),Vi(o,this.locale),Vi(s,this.locale),Vi(i,this.locale)),format:"#,##0.00"}},isExported:!0},ym={description:Fo("Discount rate of a security based on price."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Bp(a),Up(l);return(l-a)/l/js(n,r,c)},isExported:!0},Cm={description:Fo("Convert a decimal fraction to decimal value."),args:[Dh("fractional_price (number)",Fo("The price quotation given using fractional decimal conventions.")),Dh("unit (number)",Fo("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));Pi((()=>s>0),Fo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},wm={description:Fo("Convert a decimal value to decimal fraction."),args:[Dh("decimal_price (number)",Fo("The price quotation given as a decimal value.")),Dh("unit (number)",Fo("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));Pi((()=>s>0),Fo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},xm={description:Fo("Number of periods for an investment to reach a value."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=Math.trunc(Vi(e,this.locale)),a=Math.trunc(Vi(t,this.locale)),l=Vi(o,this.locale),c=Vi(s,this.locale),h=Math.trunc(Vi(i,this.locale)),d=Math.trunc(Vi(n,this.locale));kp(r,a),Vp(h),Hp(d),Pi((()=>l>=0),Fo("The rate (%s) must be positive or null.",l.toString())),Pi((()=>c>=0),Fo("The yield (%s) must be positive or null.",c.toString()));const u=js(r,a,d),g=u-Math.trunc(u)||1/h,p=Math.ceil(u*h),m=l/h,f=c/h;let v=0,b=0;for(let e=1;e<=p;e++){const t=(m+(e===p?1:0))/(1+f)**e;b+=(g+(e-1)/h)*t,v+=t}return 0===v?0:b/v},isExported:!0},Em={description:Fo("Annual effective interest rate."),args:[Dh("nominal_rate (number)",Fo("The nominal interest rate per year.")),Dh("periods_per_year (number)",Fo("The number of compounding periods per year."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));return Pi((()=>o>0),Fo("The nominal rate (%s) must be strictly greater than 0.",o.toString())),Pi((()=>s>0),Fo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),Math.pow(1+o/s,s)-1},isExported:!0};function Im(e,t,o,s,i){return 0===e?-(s+o*t):-s*(1+e)**t-o*(1+e*i)*((1+e)**t-1)/e}const Rm={description:Fo("Future value of an annuity investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("payment_amount (number)",Fo("The amount per period to be paid.")),Dh("present_value (number, default=0)",Fo("The current value of the annuity.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;return{value:Im(Vi(e,this.locale),Vi(t,this.locale),Vi(o,this.locale),Vi(s,this.locale),Yi(i)?1:0),format:"#,##0.00"}},isExported:!0},Tm={description:Fo("Future value of principal from series of rates."),args:[Dh("principal (number)",Fo("The amount of initial capital or value to compound against.")),Dh("rate_schedule (number, range<number>)",Fo("A series of interest rates to compound against the principal."))],compute:function(e,t){return on([t],((e,t)=>e*(1+Vi(t,this.locale))),Vi(e,this.locale))},isExported:!0},Am={description:Fo("Calculates effective interest rate."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("investment (number)",Fo("The amount invested in the security.")),Dh("redemption (number)",Fo("The amount to be received at maturity.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(s,this.locale),l=Vi(o,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Xp(l),Up(a),Hp(c);return(a-l)/l/js(n,r,c)},isExported:!0};function _m(e,t,o,s,i,n){return Um(e,o,s,i,n)-zm(e,t,o,s,i,n)}const Dm={description:Fo("Payment on the principal of an investment."),args:[Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("period (number)",Fo("The amortization period, in terms of number of periods.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},n={value:0}){return{value:_m(Vi(e,this.locale),Vi(t,this.locale),Vi(o,this.locale),Vi(s,this.locale),Vi(i,this.locale),Yi(n)?1:0),format:"#,##0.00"}},isExported:!0},Om={description:Fo("Internal rate of return given periodic cashflows."),args:[Dh("cashflow_amounts (number, range<number>)",Fo("An array or range containing the income or payments associated with the investment.")),Dh("rate_guess (number, default=0.1)",Fo("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=Vi(t,this.locale);om(o);let s=!1,i=!1,n=[];en([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),n.push(e)}),this.locale),Pi((()=>s&&i),Fo("The cashflow_amounts must include negative and positive values."));const r=n.shift();return{value:rm((function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*e**(s-i))),t*e**s)}(e,r,n)}),(function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*(s-i)*e**(s-i-1))),t*s*e**(s-1))}(e,r,n)}),o+1,20,1e-5)-1,format:"0%"}},isExported:!0},Fm={description:Fo("Returns the interest paid at a particular period of an investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("period (number)",Fo("The period for which you want to view the interest payment.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity."))],compute:function(e,t,o,s){const i=Vi(e,this.locale),n=Vi(t,this.locale),r=Vi(o,this.locale),a=Vi(s,this.locale);Pi((()=>0!==r),Fo("The number of periods must be different than 0.",r.toString()));return-1*(a-a*(n/r))*i},isExported:!0},Mm={description:Fo("Modified Macaulay duration."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){return xm.compute.bind(this)(e,t,o,s,i,n)/(1+Vi(s,this.locale)/Math.trunc(Vi(i,this.locale)))},isExported:!0},Pm={description:Fo("Modified internal rate of return."),args:[Dh("cashflow_amounts (range<number>)",Fo("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),Dh("financing_rate (number)",Fo("The interest rate paid on funds invested.")),Dh("reinvestment_return_rate (number)",Fo("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=Vi(t,this.locale),i=Vi(o,this.locale),n=ln(e).flat().filter((e=>null!==e.value)).map((e=>Vi(e,this.locale))),r=n.length;let a=0,l=0;for(const e of Ze(0,r)){const t=n[e];t>=0?a+=t*(i+1)**(r-e-1):l+=t/(s+1)**e}Pi((()=>0!==l&&0!==a),Fo("There must be both positive and negative values in cashflow_amounts."));return(-a/l)**(1/(r-1))-1},isExported:!0},Nm={description:Fo("Annual nominal interest rate."),args:[Dh("effective_rate (number)",Fo("The effective interest rate per year.")),Dh("periods_per_year (number)",Fo("The number of compounding periods per year."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));return Pi((()=>o>0),Fo("The effective rate (%s) must must strictly greater than 0.",o.toString())),Pi((()=>s>0),Fo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),(Math.pow(o+1,1/s)-1)*s},isExported:!0},km={description:Fo("Number of payment periods for an investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("payment_amount (number)",Fo("The amount of each payment made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Vi(e,this.locale),r=Vi(t,this.locale),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Yi(i)?1:0;if(0===n)return-(l+a)/r;const h=r*(1+n*c)/n;return Math.log((h-l)/(a+h))/Math.log(1+n)},isExported:!0};function Lm(e,t,o,s){let i=0;return sn(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const Vm={description:Fo("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[Dh("discount (number)",Fo("The discount rate of the investment over one period.")),Dh("cashflow1 (number, range<number>)",Fo("The first future cash flow.")),Dh("cashflow2 (number, range<number>, repeating)",Fo("Additional future cash flows."))],compute:function(e,...t){const o=Vi(e,this.locale);return Pi((()=>-1!==o),Fo("The discount (%s) must be different from -1.",o.toString())),{value:Lm(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},Hm={description:Fo("Computes the number of periods needed for an investment to reach a value."),args:[Dh("rate (number)",Fo("The rate at which the investment grows each period.")),Dh("present_value (number)",Fo("The investment's current value.")),Dh("future_value (number)",Fo("The investment's desired future value."))],compute:function(e,t,o){const s=Vi(e,this.locale),i=Vi(t,this.locale),n=Vi(o,this.locale);return $p(s),Pi((()=>i>0),Fo("The present_value (%s) must be strictly positive.",i.toString())),Pi((()=>n>0),Fo("The future_value (%s) must be strictly positive.",n.toString())),(Math.log(n)-Math.log(i))/Math.log(1+s)},isExported:!0};function Um(e,t,o,s,i){if(zp(t),0===e)return-(s+o)/t;let n=-(o*(1+e)**t+s);return n=n*e/((1+e*i)*((1+e)**t-1)),n}const Bm={description:Fo("Periodic payment for an annuity investment."),args:[Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){const n=Vi(t,this.locale),r=Vi(e,this.locale),a=Yi(i)?1:0,l=Vi(s,this.locale);return{value:Um(r,n,Vi(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function zm(e,t,o,s,i,n){zp(o),Pi((()=>t>0&&t<=o),Fo("The period must be between 1 and number_of_periods (%s)",o));const r=Um(e,o,s,i,n);if(1===n&&1===t)return r;return r+-Im(e,0===n?t-1:t-2,r,s+r*n,0)*e}const $m={description:Fo("Payment on the principal of an investment."),args:[Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("period (number)",Fo("The amortization period, in terms of number of periods.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},n={value:0}){const r=Vi(o,this.locale),a=Vi(e,this.locale),l=Vi(t,this.locale),c=Yi(n)?1:0,h=Vi(i,this.locale);return{value:zm(a,l,r,Vi(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},Wm={description:Fo("Present value of an annuity investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("payment_amount (number)",Fo("The amount per period to be paid.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Vi(e,this.locale),r=Vi(t,this.locale),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Yi(i)?1:0;return{value:n?-(a*(1+n*c)*((1+n)**r-1)/n+l)/(1+n)**r:-(l+a*r),format:"#,##0.00"}},isExported:!0},Gm={description:Fo("Price of a security paying periodic interest."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Vi(e,this.locale)),l=Math.trunc(Vi(t,this.locale)),c=Vi(o,this.locale),h=Vi(s,this.locale),d=Vi(i,this.locale),u=Math.trunc(Vi(n,this.locale)),g=Math.trunc(Vi(r,this.locale));kp(a,l),Vp(u),Hp(g),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Pi((()=>h>=0),Fo("The yield (%s) must be positive or null.",h.toString())),Up(d);const p=js(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=1+h/u,b=100*c/u;if(1===m)return(b+d)/(f*h/u+1)-b*(1-f);let S=0;for(let e=1;e<=m;e++)S+=b/v**(e-1+f);return d/v**(m-1+f)+S-b*(1-f)},isExported:!0},qm={description:Fo("Price of a discount security."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("discount (number)",Fo("The discount rate of the security at time of purchase.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Kp(a),Up(l);return l-a*l*js(n,r,c)},isExported:!0},Zm={description:Fo("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("issue (date)",Fo("The date the security was initially issued.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Vi(e,this.locale)),a=Math.trunc(Vi(t,this.locale)),l=Math.trunc(Vi(o,this.locale)),c=Vi(s,this.locale),h=Vi(i,this.locale),d=Math.trunc(Vi(n,this.locale));Lp(r,l),kp(r,a),Hp(d),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Pi((()=>h>=0),Fo("The yield (%s) must be positive or null.",h.toString()));const u=js(r,a,d),g=js(r,l,d);return(100+js(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},jm=.1,Ym={description:Fo("Interest rate of an annuity investment."),args:[Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("payment_per_period (number)",Fo("The amount per period to be paid.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period.")),Dh("rate_guess (number, default=0.1)",Fo("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},n={value:jm}){const r=Vi(e,this.locale),a=Vi(t,this.locale),l=Yi(i)?1:0,c=Vi(n,this.locale)||jm;let h=Vi(s,this.locale),d=Vi(o,this.locale);zp(r),Pi((()=>[a,d,h].some((e=>e>0))&&[a,d,h].some((e=>e<0))),Fo("There must be both positive and negative values in [payment_amount, present_value, future_value].",r.toString())),om(c),h-=a*l,d+=a*l;return{value:rm((e=>{const t=Math.pow(1+e,r);return h+d*t+a*((t-1)/e)}),(e=>{const t=Math.pow(1+e,r-1),o=Math.pow(1+e,r);return d*r*t+a*(r*t/e-(o-1)/e/e)}),c,40,1e-5),format:"0%"}},isExported:!0},Xm={description:Fo("Amount received at maturity for a security."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("investment (number)",Fo("The amount invested (irrespective of face value of each security).")),Dh("discount (number)",Fo("The discount rate of the security invested in.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Xp(a),Kp(l);return a/(1-l*js(n,r,c))},isExported:!0},Km={description:Fo("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[Dh("number_of_periods (number)",Fo("The number of periods.")),Dh("present_value (number)",Fo("The present value of the investment.")),Dh("future_value (number)",Fo("The future value of the investment."))],compute:function(e,t,o){const s=Vi(e,this.locale),i=Vi(t,this.locale),n=Vi(o,this.locale);return zp(s),(n/i)**(1/s)-1},isExported:!0},Jm={description:Fo("Depreciation of an asset using the straight-line method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(Vi(e,this.locale)-Vi(t,this.locale))/Vi(o,this.locale),format:"#,##0.00"}},isExported:!0},Qm={description:Fo("Depreciation via sum of years digit method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=Vi(e,this.locale),n=Vi(t,this.locale),r=Vi(o,this.locale),a=Vi(s,this.locale);qp(a),Wp(r),Yp(a,r);return{value:(r-a+1)/(r*(r+1)/2)*(i-n),format:"#,##0.00"}},isExported:!0};function ef(e,t,o){return 100*(1-o*js(e,t,2))}const tf={description:Fo("Price of a US Treasury bill."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("discount (number)",Fo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Vi(o,this.locale);return kp(s,i),em(s,i,this.locale),Kp(n),Jp(n),ef(s,i,n)},isExported:!0},of={description:Fo("Equivalent rate of return for a US Treasury bill."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("discount (number)",Fo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Vi(o,this.locale);kp(s,i),em(s,i,this.locale),Kp(n),Jp(n);const r=jg.compute.bind(this)({value:i},{value:s});if(r<=182)return 365*n/(360-n*r);const a=ef(s,i,n)/100,l=r/(366===r?366:365);return(-2*l+2*Math.sqrt(l**2-(2*l-1)*(1-1/a)))/(2*l-1)},isExported:!0},sf={description:Fo("The yield of a US Treasury bill based on price."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Vi(o,this.locale);kp(s,i),em(s,i,this.locale),Bp(n);return(100-n)/n*(1/js(s,i,2))},isExported:!0},nf={description:Fo("Variable declining balance. WARNING : does not handle decimal periods."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("start (number)",Fo("Starting period to calculate depreciation.")),Dh("end (number)",Fo("Ending period to calculate depreciation.")),Dh("factor (number, default=2)",Fo("The number of months in the first year of depreciation.")),Dh("no_switch (number, default=false)",Fo("Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation."))],compute:function(e,t,o,s,i,n={value:2},r={value:false}){n=n||0;const a=Vi(e,this.locale),l=Vi(t,this.locale),c=Vi(o,this.locale),h=Math.trunc(Vi(s,this.locale)),d=Math.trunc(Vi(i,this.locale)),u=Vi(n,this.locale),g=Yi(r);if(Gp(a),Zp(l),function(e,t,o){Wp(o),Pi((()=>e>=0),Fo("The start_period (%s) must be greater or equal than 0.",e.toString())),Pi((()=>t>=0),Fo("The end_period (%s) must be greater or equal than 0.",t.toString())),Pi((()=>e<=t),Fo("The start_period (%s) must be smaller or equal to the end_period (%s).",e.toString(),t.toString())),Pi((()=>t<=o),Fo("The end_period (%s) must be smaller or equal to the life (%s).",e.toString(),o.toString()))}(h,d,c),Qp(u),0===a)return 0;if(l>=a)return h<1?a-l:0;const p=u/c;if(p>=1)return h<1?a-l:0;let m=a,f=0,v=0,b=!1;for(let e=0;e<d;e++){if(!b||g){const t=m*p,o=(m-l)/(c-e);!g&&o>t?(b=!0,f=o):f=t}const t=Math.max(m-f,l);e>=h&&(v+=m-t),m=t}return v},isExported:!0},rf={description:Fo("Internal rate of return given non-periodic cash flows."),args:[Dh("cashflow_amounts (range<number>)",Fo("An range containing the income or payments associated with the investment.")),Dh("cashflow_dates (range<number>)",Fo("An range with dates corresponding to the cash flows in cashflow_amounts.")),Dh("rate_guess (number, default=0.1)",Fo("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:jm}){const s=Vi(o,this.locale),i=e.flat().map((e=>Vi(e,this.locale))),n=t.flat().map((e=>Vi(e,this.locale)));var r;sm(e,t),r=i,Pi((()=>r.some((e=>e>0))&&r.some((e=>e<0))),Fo("There must be both positive and negative values in cashflow_amounts.")),im(n),om(s);const a=new Map;for(const e of Ze(0,n.length)){const t=n[e];a.has(t)?a.set(t,a.get(t)+i[e]):a.set(t,i[e])}const l=Array.from(a.keys()),c=l.map((e=>a.get(e)));return rm((e=>{let t=c[0];for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=c[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=s*c[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},af={description:Fo("Net present value given to non-periodic cash flows.."),args:[Dh("discount (number)",Fo("The discount rate of the investment over one period.")),Dh("cashflow_amounts (number, range<number>)",Fo("An range containing the income or payments associated with the investment.")),Dh("cashflow_dates (number, range<number>)",Fo("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=Vi(e,this.locale),i=Ci(t)?t.flat().map((e=>Bi(e,this.locale))):[Bi(t,this.locale)],n=Ci(o)?o.flat().map((e=>Bi(e,this.locale))):[Bi(o,this.locale)];if(Ci(o)&&Ci(t)?sm(t,o):Pi((()=>i.length===n.length),Fo("There must be the same number of values in cashflow_amounts and cashflow_dates.")),im(n),$p(s),1===i.length)return i[0];const r=new Map;for(const e of Ze(0,n.length)){const t=n[e];r.has(t)?r.set(t,r.get(t)+i[e]):r.set(t,i[e])}const a=Array.from(r.keys()),l=a.map((e=>r.get(e)));let c=l[0];for(const e of Ze(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},lf={description:Fo("Annual yield of a security paying periodic interest."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Vi(e,this.locale)),l=Math.trunc(Vi(t,this.locale)),c=Vi(o,this.locale),h=Vi(s,this.locale),d=Vi(i,this.locale),u=Math.trunc(Vi(n,this.locale)),g=Math.trunc(Vi(r,this.locale));kp(a,l),Vp(u),Hp(g),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Bp(h),Up(d);const p=js(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=100*c/u;if(1===m){const e=h+v*(1-f);return(d+v-e)*u*(1/f)/e}const b=rm((function(e){return function(e,t,o,s,i,n){let r=n-(e+i*(1-t))*s**(o-1+t);for(let e=1;e<=o;e++)r+=i*s**(e-1);return r}(h,f,m,e,v,d)}),(function(e){return function(e,t,o,s,i){let n=-(e+i*(1-t))*(o-1+t)*s**(o-2+t);for(let e=1;e<=o;e++)n+=i*(e-1)*s**(e-2);return n}(h,f,m,e,v)}),1+(c+1)/u,100,1e-5);return(b-1)*u},isExported:!0},cf={description:Fo("Annual yield of a discount security."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Bp(a),Up(l);return(l/a-1)/js(n,r,c)},isExported:!0},hf={description:Fo("Annual yield of a security paying interest at maturity."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("issue (date)",Fo("The date the security was initially issued.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("price (number)",Fo("The price at which the security is bought.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Vi(e,this.locale)),a=Math.trunc(Vi(t,this.locale)),l=Math.trunc(Vi(o,this.locale)),c=Vi(s,this.locale),h=Vi(i,this.locale),d=Math.trunc(Vi(n,this.locale));kp(r,a),Hp(d),Pi((()=>r>=l),Fo("The settlement (%s) must be greater than or equal to the issue (%s).",r.toString(),l.toString())),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Bp(h);const u=js(l,a,d),g=js(l,r,d),p=js(r,a,d);return(100*(1+c*u)/(h+100*c*g)-1)/p},isExported:!0};var df,uf=Object.freeze({__proto__:null,ACCRINTM:am,AMORLINC:lm,COUPDAYBS:hm,COUPDAYS:cm,COUPDAYSNC:dm,COUPNCD:um,COUPNUM:gm,COUPPCD:pm,CUMIPMT:mm,CUMPRINC:fm,DB:vm,DDB:Sm,DISC:ym,DOLLARDE:Cm,DOLLARFR:wm,DURATION:xm,EFFECT:Em,FV:Rm,FVSCHEDULE:Tm,INTRATE:Am,IPMT:Dm,IRR:Om,ISPMT:Fm,MDURATION:Mm,MIRR:Pm,NOMINAL:Nm,NPER:km,NPV:Vm,PDURATION:Hm,PMT:Bm,PPMT:$m,PRICE:Gm,PRICEDISC:qm,PRICEMAT:Zm,PV:Wm,RATE:Ym,RECEIVED:Xm,RRI:Km,SLN:Jm,SYD:Qm,TBILLEQ:of,TBILLPRICE:tf,TBILLYIELD:sf,VDB:nf,XIRR:rf,XNPV:af,YIELD:lf,YIELDDISC:cf,YIELDMAT:hf});!function(e){e[e.LeftRef=0]="LeftRef",e[e.RightRef=1]="RightRef",e[e.Separator=2]="Separator",e[e.FullColumnSeparator=3]="FullColumnSeparator",e[e.FullRowSeparator=4]="FullRowSeparator",e[e.RightColumnRef=5]="RightColumnRef",e[e.RightRowRef=6]="RightRowRef",e[e.Found=7]="Found"}(df||(df={}));const gf=(e,t=(()=>!0))=>[{goTo:e,guard:t}],pf=(e,t=(()=>!0))=>({goTo:e,guard:t}),mf={[df.LeftRef]:{REFERENCE:gf(df.Separator),NUMBER:gf(df.FullRowSeparator),SYMBOL:[pf(df.FullColumnSeparator,(e=>Bo(e.value))),pf(df.FullRowSeparator,(e=>zo(e.value)))]},[df.FullColumnSeparator]:{SPACE:gf(df.FullColumnSeparator),OPERATOR:gf(df.RightColumnRef,(e=>":"===e.value))},[df.FullRowSeparator]:{SPACE:gf(df.FullRowSeparator),OPERATOR:gf(df.RightRowRef,(e=>":"===e.value))},[df.Separator]:{SPACE:gf(df.Separator),OPERATOR:gf(df.RightRef,(e=>":"===e.value))},[df.RightRef]:{SPACE:gf(df.RightRef),NUMBER:gf(df.Found),REFERENCE:gf(df.Found,(e=>Go(e.value))),SYMBOL:gf(df.Found,(e=>$o(e.value)||Wo(e.value)))},[df.RightColumnRef]:{SPACE:gf(df.RightColumnRef),SYMBOL:gf(df.Found,(e=>$o(e.value))),REFERENCE:gf(df.Found,(e=>Go(e.value)))},[df.RightRowRef]:{SPACE:gf(df.RightRowRef),NUMBER:gf(df.Found),REFERENCE:gf(df.Found,(e=>Go(e.value))),SYMBOL:gf(df.Found,(e=>Wo(e.value)))},[df.Found]:{}};function ff(e){let t=0,o=mf[df.LeftRef],s="";for(;void 0!==o;){const i=e[t++];if(!i)return null;const n=o[i.type]?.find((e=>e.guard(i))),r=n?n.goTo:void 0;switch(r){case void 0:return null;case df.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=mf[r],s+=i.value}}return null}function vf(e,t=Si){const o=fa(e,t),s=[];for(;o.length;)s.push(ff(o)||o.shift());return s}const bf=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Sf=["-","+"],yf=["%"],Cf=["*","+","&"],wf={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function xf(e){const t=e.shift();if(!t)throw new Ai;switch(t.type){case"DEBUGGER":const o=Rf(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:si(t.value,Si)};case"STRING":return{type:"STRING",value:He(t.value)};case"INVALID_REFERENCE":return{type:"REFERENCE",value:Ii.InvalidReference};case"REFERENCE":if(":"===e[0]?.value&&"REFERENCE"===e[1]?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`}}return{type:"REFERENCE",value:t.value};case"SYMBOL":const s=t.value,i=e[0];if("LEFT_PAREN"===i?.type&&bf.test(t.value)&&s===$e(s,"'")){const t=function(e){If(e,"LEFT_PAREN",Fo("Missing opening parenthesis"));const t=e[0];if("RIGHT_PAREN"===t?.type)return If(e,"RIGHT_PAREN"),[];const o=[];o.push(Ef(e));for(;"RIGHT_PAREN"!==e[0]?.type;)If(e,"ARG_SEPARATOR",Fo("Wrong function call")),o.push(Ef(e));return If(e,"RIGHT_PAREN"),o}(e);return{type:"FUNCALL",value:s,args:t}}const n=s.toUpperCase();return"TRUE"===n||"FALSE"===n?{type:"BOOLEAN",value:"TRUE"===n}:{type:"SYMBOL",value:$e(t.value,"'")};case"LEFT_PAREN":const r=Rf(e);return If(e,"RIGHT_PAREN",Fo("Missing closing parenthesis")),r;case"OPERATOR":const a=t.value;if(Sf.includes(a))return{type:"UNARY_OPERATION",value:a,operand:Rf(e,wf[a])};throw new Ai(Fo("Unexpected token: %s",t.value));default:throw new Ai(Fo("Unexpected token: %s",t.value))}}function Ef(e){const t=e[0];return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:""}:Rf(e)}function If(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new Ai(o)}function Rf(e,t=0){if(0===e.length)throw new Ai;let o=xf(e);for(;"OPERATOR"===e[0]?.type&&wf[e[0].value]>t;){const t=e.shift().value;if(yf.includes(t))o={type:"UNARY_OPERATION",value:t,operand:o,postfix:!0};else{o={type:"BIN_OPERATION",value:t,left:o,right:Rf(e,wf[t])}}}return o}function Tf(e){return Af(vf(e))}function Af(e){e=e.filter((e=>"SPACE"!==e.type)),"="===e[0]?.value&&e.splice(0,1);const t=Rf(e);if(e.length)throw new Ai;return t}function _f(e,t,o){return Ff(e,(e=>e.type===t?o(e):e))}function Df(e){return Array.from(Of(e))}function*Of(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*Of(t);break;case"UNARY_OPERATION":yield*Of(e.operand);break;case"BIN_OPERATION":yield*Of(e.left),yield*Of(e.right)}}function Ff(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>Ff(e,t)))};case"UNARY_OPERATION":return{...e,operand:Ff(e.operand,t)};case"BIN_OPERATION":return{...e,right:Ff(e.right,t),left:Ff(e.left,t)};default:return e}}function Mf(e){switch(e.type){case"FUNCALL":const t=e.args.map((e=>Mf(e)));return`${e.value}(${t.join(",")})`;case"NUMBER":return e.value.toString();case"REFERENCE":default:return e.value;case"STRING":return`"${e.value}"`;case"BOOLEAN":return e.value?"TRUE":"FALSE";case"UNARY_OPERATION":return e.postfix?Pf(e)+e.value:e.value+Nf(e);case"BIN_OPERATION":return Pf(e)+e.value+Nf(e)}}function Pf(e){const t=e.value,o="left"in e?e.left:e.operand,s=o.value;return"BIN_OPERATION"===o.type&&wf[s]<wf[t]?`(${Mf(o)})`:Mf(o)}function Nf(e){const t=e.value,o="right"in e?e.right:e.operand,s=wf[o.value],i=wf[t];let n=!1;return"BIN_OPERATION"!==o.type?n=!1:s<i?n=!0:s!==i||Cf.includes(t)||(n=!0),n?`(${Mf(o)})`:Mf(o)}function kf(e,t){return function(e){for(const t of e)if(t.functionContext){const{argsTokens:e,args:o}=t.functionContext;if(delete t.functionContext.argsTokens,o.length||!e)continue;"LEFT_PAREN"===e[0]?.[0]?.type&&(e[0]=e[0].slice(1));for(const t of e){let e=t;"ARG_SEPARATOR"===e.at(-1)?.type&&(e=e.slice(0,-1));try{o.push(Af(e))}catch(e){o.push(void 0)}}}return e}(function(e){let t=[],o="";function s(e){if(0===t.length)return;const o=t.at(-1);if(o&&o.argsTokens){const{argsTokens:t,argPosition:s}=o;t[s]||(t[s]=[]),t[s].push({value:e.value,type:e.type})}}return e.map(((e,i)=>{switch(["SPACE","LEFT_PAREN"].includes(e.type)||(o=""),e.type){case"SYMBOL":s(e),o=e.value;break;case"LEFT_PAREN":t.push({parent:o,argPosition:0,argsTokens:[],args:[]}),s(e),o="";break;case"RIGHT_PAREN":const i=t.pop();i?.argsTokens?.flat().forEach(s),s(e);break;case"ARG_SEPARATOR":s(e),t.length&&t[t.length-1].argPosition++;break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){let t=[],o=0;return e.map(((s,i)=>{if("LEFT_PAREN"===s.type){t.push(o+1),o=0;for(let o=i-1;o>=0;o--){if("SPACE"!==e[o].type){"SYMBOL"===e[o].type&&(e[o].parenthesesCode=t.join(":"));break}e[o].parenthesesCode=t.join(":")}}return s.parenthesesCode=t.join(":"),"RIGHT_PAREN"===s.type&&t.length&&(o=t.pop()),s}))}(function(e){let t=0;return e.map((e=>{const o=e.value.toString().length,s=Object.assign({},e,{start:t,end:t+o,length:o});return t=s.end,s}))}(vf(e,t)))))}function Lf(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=qo(e.value),[s,i]=t.split(":"),n=Vf(s),r=i?`:${Vf(i)}`:"";return{...e,value:Zo(o,n+r)}}function Vf(e){switch(function(e){if(function(e){return e.startsWith("$")&&e.length>1&&e.slice(1).includes("$")}(e))return"colrow";if(function(e){return e.startsWith("$")}(e))return"col";if(function(e){return e.includes("$",1)}(e))return"row";return"none"}(e)){case"none":e=Hf(e,"colrow");break;case"colrow":e=Hf(e,"row");break;case"row":e=Hf(e,"col");break;case"col":e=Hf(e,"none")}return e}function Hf(e,t){if(e.includes("!"))throw new Error("The given XC should not contain a sheet name");let o;switch(e=e.replace(/\$/g,""),t){case"col":return"$"+e;case"row":return o=e.search(/[0-9]/),e.slice(0,o)+"$"+e.slice(o);case"colrow":return o=e.search(/[0-9]/),-1===o||0===o?"$"+e:"$"+(e=e.slice(0,o)+"$"+e.slice(o));case"none":return e}}function Uf(e,t,o){const s=(t.startsWith("=")?kf(t,o):[]).filter((t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end)),i=s.filter((e=>"REFERENCE"===e.type));if(0===i.length)return;const n=s.map(Lf).map((e=>e.value)).join(""),r=s[0].start,a=s[s.length-1].end,l=t.slice(0,r)+n+t.slice(a),c=l.length-t.length,h={start:i[0].start,end:i[i.length-1].end+c};return 1===i.length&&e.start===e.end&&(h.start=h.end),{content:l,selection:h}}const Bf=["address","col","contents","format","row","type"],zf={description:Fo("Gets information about a cell."),args:[Dh("info_type (string)",Fo("The type of information requested. Can be one of %s",Bf.join(", "))),Dh("reference (meta)",Fo("The reference to the cell."))],compute:function(e,t){const o=qi(e).toLowerCase();Pi((()=>Bf.includes(o)),Fo("The info_type should be one of %s.",Bf.join(", ")));const s=this.__originSheetId,i=qi(t),n=i.includes(":")?i.split(":")[0]:i;let{sheetName:r,xc:a}=qo(n);r=r===this.getters.getSheetName(s)?void 0:r;const l=Zo(r,Hf(a,"colrow")),c=this.getters.getRangeFromSheetXC(s,l);switch(o){case"address":return this.getters.getRangeString(c,s);case"col":return c.zone.left+1;case"contents":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).value}case"format":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).format||""}case"row":return c.zone.top+1;case"type":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top},t=this.getters.getEvaluatedCell(e).type;return t===ni.empty?"b":t===ni.text?"l":"v"}}return""},isExported:!0},$f={description:Fo("Whether a value is an error other than #N/A."),args:[Dh("value (any)",Fo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return ki(t)&&t!==Ii.NotAvailable},isExported:!0},Wf={description:Fo("Whether a value is an error."),args:[Dh("value (any)",Fo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return ki(t)},isExported:!0},Gf={description:Fo("Whether a value is `true` or `false`."),args:[Dh("value (any)",Fo("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},qf={description:Fo("Whether a value is the error #N/A."),args:[Dh("value (any)",Fo("The value to be verified as an error type."))],compute:function(e){return e?.value===Ii.NotAvailable},isExported:!0},Zf={description:Fo("Whether a value is non-textual."),args:[Dh("value (any)",Fo("The value to be checked."))],compute:function(e){return!Yf.compute.bind(this)(e)},isExported:!0},jf={description:Fo("Whether a value is a number."),args:[Dh("value (any)",Fo("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},Yf={description:Fo("Whether a value is text."),args:[Dh("value (any)",Fo("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===ki(e?.value)},isExported:!0},Xf={description:Fo("Whether the referenced cell is empty"),args:[Dh("value (any)",Fo("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},Kf={description:Fo("Returns the error value #N/A."),args:[],compute:function(){return{value:Ii.NotAvailable}},isExported:!0};var Jf=Object.freeze({__proto__:null,CELL:zf,ISBLANK:Xf,ISERR:$f,ISERROR:Wf,ISLOGICAL:Gf,ISNA:qf,ISNONTEXT:Zf,ISNUMBER:jf,ISTEXT:Yf,NA:Kf});const Qf={description:Fo("Logical `and` operator."),args:[Dh("logical_expression1 (boolean, range<boolean>)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE, or an expression that can be coerced to a logical value.")),Dh("logical_expression2 (boolean, range<boolean>, repeating)",Fo("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Wa(e);return Pi((()=>o),Fo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},ev={description:Fo("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},tv={description:Fo("Returns value depending on logical expression."),args:[Dh("logical_expression (boolean)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),Dh("value_if_true (any)",Fo("The value the function returns if logical_expression is TRUE.")),Dh("value_if_false (any, default=FALSE)",Fo("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){const s=Yi(e?.value)?t:o;return void 0===s?{value:""}:(null===s.value&&(s.value=""),s)},isExported:!0},ov={description:Fo("Value if it is not an error, otherwise 2nd argument."),args:[Dh("value (any)",Fo("The value to return if value itself is not an error.")),Dh('value_if_error (any, default="empty")',Fo("The value the function returns if value is an error."))],compute:function(e,t={value:""}){const o=ki(e?.value)?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},sv={description:Fo("Value if it is not an #N/A error, otherwise 2nd argument."),args:[Dh("value (any)",Fo("The value to return if value itself is not #N/A an error.")),Dh('value_if_error (any, default="empty")',Fo("The value the function returns if value is an #N/A error."))],compute:function(e,t={value:""}){const o=e?.value===Ii.NotAvailable?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},iv={description:Fo("Returns a value depending on multiple logical expressions."),args:[Dh("condition1 (boolean)",Fo("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),Dh("value1 (any)",Fo("The returned value if condition1 is TRUE.")),Dh("condition2 (boolean, any, repeating)",Fo("Additional conditions to be evaluated if the previous ones are FALSE.")),Dh("value2 (any, repeating)",Fo("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){Pi((()=>e.length%2==0),Fo("Wrong number of arguments. Expected an even number of arguments."));for(let t=0;t<e.length-1;t+=2)if(Yi(e[t]?.value)){const o=e[t+1];return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)}return new Ti(Fo("No match."))},isExported:!0},nv={description:Fo("Returns opposite of provided logical value."),args:[Dh("logical_expression (boolean)",Fo("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!Yi(e)},isExported:!0},rv={description:Fo("Logical `or` operator."),args:[Dh("logical_expression1 (boolean, range<boolean>)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE, or an expression that can be coerced to a logical value.")),Dh("logical_expression2 (boolean, range<boolean>, repeating)",Fo("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Ga(e);return Pi((()=>o),Fo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},av={description:Fo("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},lv={description:Fo("Logical `xor` operator."),args:[Dh("logical_expression1 (boolean, range<boolean>)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE, or an expression that can be coerced to a logical value.")),Dh("logical_expression2 (boolean, range<boolean>, repeating)",Fo("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return cn(e,(e=>(t=!0,o=o?!e:e,!0))),Pi((()=>t),Fo("[[FUNCTION_NAME]] has no valid input data.")),o},isExported:!0};var cv=Object.freeze({__proto__:null,AND:Qf,FALSE:ev,IF:tv,IFERROR:ov,IFNA:sv,IFS:iv,NOT:nv,OR:rv,TRUE:av,XOR:lv});function hv(e,t){const o=t.getPivotId(e);if(!o)throw new Ti(Fo('There is no pivot with id "%s"',e));return o}function dv(e){if(e.length%2!=0)throw new Ti(Fo("Function PIVOT takes an even number of arguments."))}function uv(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,n=Jo(i),r=e.getters.getRangeFromSheetXC(o,n);if(void 0===r||r.invalidXc||r.invalidSheetName)throw new _i;s.push(r)}for(const t of o)if(t.computedBy){const o=e.getters.getMeasureCompiledFormula(t);s.push(...o.dependencies.filter((e=>!e.invalidXc)))}const i=e.__originCellPosition;i&&s.length&&(e.updateDependencies?.(i),e.addDependencies?.(i,s))}const gv=!0;function pv(e){return{value:Ii.NotAvailable,message:Fo("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",qi(e))}}const mv={description:Fo("Returns a cell reference as a string. "),args:[Dh("row (number)",Fo("The row number of the cell reference. ")),Dh("column (number)",Fo("The column number (not name) of the cell reference. A is column number 1. ")),Dh("absolute_relative_mode (number, default=1)",Fo("An indicator of whether the reference is row/column absolute. 1 is row and column absolute (e.g. $A$1), 2 is row absolute and column relative (e.g. A$1), 3 is row relative and column absolute (e.g. $A1), and 4 is row and column relative (e.g. A1).")),Dh("use_a1_notation (boolean, default=TRUE)",Fo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).")),Dh("sheet (string, optional)",Fo("A string indicating the name of the sheet into which the address points."))],compute:function(e,t,o={value:1},s={value:!0},i){const n=$i(e,this.locale),r=$i(t,this.locale);Wi(n),Wi(r);const a=$i(o,this.locale);var l,c;Pi((()=>[1,2,3,4].includes(a)),(l=4,c=a,Fo("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));let h;if(Yi(s)){h=yo(r-1,n-1,{rowFixed:[1,2].includes(a),colFixed:[1,3].includes(a)})}else{h=([1,2].includes(a)?`R${n}`:`R[${n}]`)+([1,3].includes(a)?`C${r}`:`C[${r}]`)}return void 0!==i?Zo(qi(i),h):h},isExported:!0},fv={description:Fo("Column number of a specified cell."),args:[Dh("cell_reference (meta, default='this cell')",Fo("The cell whose column number will be returned. Column A corresponds to 1. By default, the function use the cell in which the formula is entered."))],compute:function(e){if(ki(e?.value))return e;const t=void 0===e?this.__originCellPosition?.col:Yo(e.value).left;return Pi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},vv={description:Fo("Number of columns in a specified array or range."),args:[Dh("range (meta)",Fo("The range whose column count will be returned."))],compute:function(e){if(ki(e?.value))return e;const t=Yo(e.value);return t.right-t.left+1},isExported:!0},bv={description:Fo("Horizontal lookup"),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("range (range)",Fo("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),Dh("index (number)",Fo("The row index of the value to be returned, where the first row in range is numbered 1.")),Dh("is_sorted (boolean, default=true)",Fo("Indicates whether the row to be searched (the first row of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:gv}){const i=Math.trunc(Vi(o?.value,this.locale));Pi((()=>1<=i&&i<=t[0].length),Fo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const n=(e,t)=>e[t][0].value,r=Yi(s.value)?pn(t,e,"nextSmaller","asc",t.length,n):mn(t,e,"wildcard",t.length,n),a=t[r];return void 0===a?pv(e):a[i-1]},isExported:!0},Sv={description:Fo("Returns the content of a cell, specified by row and column offset."),args:[Dh("reference (any, range)",Fo("The range of cells from which the values are returned.")),Dh("row (number, default=0)",Fo("The index of the row to be returned from within the reference range of cells.")),Dh("column (number, default=0)",Fo("The index of the column to be returned from within the reference range of cells."))],compute:function(e,t={value:0},o={value:0}){const s=bn(e),i=Vi(t.value,this.locale),n=Vi(o.value,this.locale);return Pi((()=>n>=0&&n-1<s.length&&i>=0&&i-1<s[0].length),Fo("Index out of range.")),0===i&&0===n?s:0===i?[s[n-1]]:0===n?s.map((e=>[e[i-1]])):s[n-1][i-1]},isExported:!0},yv={description:Fo("Returns the content of a cell, specified by a string."),args:[Dh("reference (string)",Fo("The range of cells from which the values are returned.")),Dh("use_a1_notation (boolean, default=TRUE)",Fo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."))],compute:function(e,t={value:!0}){let o=e?.value?.toString();if(!o)return new _i(Fo("Reference should be defined."));if(!Yi(t))return new Ti(Fo("R1C1 notation is not supported."));const s=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);const n=this.getters.getRangeFromSheetXC(s,o);if(void 0===n||n.invalidXc||n.invalidSheetName)return new _i;i&&this.addDependencies?.(i,[n]);const r=[];for(let e=n.zone.left;e<=n.zone.right;e++){const t=[];for(let o=n.zone.top;o<=n.zone.bottom;o++){const s={sheetId:n.sheetId,col:e,row:o};t.push(this.getters.getEvaluatedCell(s))}r.push(t)}return 1===r.length&&1===r[0].length?r[0][0]:r},isExported:!0},Cv={description:Fo("Look up a value."),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("search_array (range)",Fo("One method of using this function is to provide a single sorted row or column search_array to look through for the search_key with a second argument result_range. The other way is to combine these two arguments into one search_array where the first row or column is searched and a value is returned from the last row or column in the array. If search_key is not found, a non-exact match may be returned.")),Dh("result_range (range, optional)",Fo("The range from which to return a result. The value returned corresponds to the location where search_key is found in search_range. This range must be only a single row or column and should not be used if using the search_result_array method."))],compute:function(e,t,o){let s=t.length,i=t[0].length;const n=i>=s,r=n?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,a=pn(t,e,"nextSmaller","asc",n?i:s,r);return-1===a||n&&void 0===t[0][a]||!n&&void 0===t[a][i-1]?pv(e):void 0===o?n?t[s-1][a]:t[a][i-1]:(s=o.length,i=o[0].length,Pi((()=>1===s||1===i),Fo("The result_range must be a single row or a single column.")),s>1?(Pi((()=>a<=s-1),Fo("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",(a+1).toString())),o[a][0]):(Pi((()=>a<=i-1),Fo("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",(a+1).toString())),o[0][a]))},isExported:!0},wv={description:Fo("Position of item in range that matches value."),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("range (any, range)",Fo("The one-dimensional array to be searched.")),Dh("search_type (number, default=1)",Fo("The search method. 1 (default) finds the largest value less than or equal to search_key when range is sorted in ascending order. 0 finds the exact value when range is unsorted. -1 finds the smallest value greater than or equal to search_key when range is sorted in descending order."))],compute:function(e,t,o={value:1}){let s=Vi(o,this.locale);const i=t.length,n=t[0].length;Pi((()=>1===i||1===n),Fo("The range must be a single row or a single column."));let r=-1;const a=1===i?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,l=1===i?t[0].length:t.length;switch(s=Math.sign(s),s){case 1:r=pn(t,e,"nextSmaller","asc",l,a);break;case 0:r=mn(t,e,"wildcard",l,a);break;case-1:r=pn(t,e,"nextGreater","desc",l,a)}return 1===i&&void 0===t[0][r]||1!==i&&void 0===t[r]?pv(e):r+1},isExported:!0},xv={description:Fo("Row number of a specified cell."),args:[Dh("cell_reference (meta, default='this cell')",Fo("The cell whose row number will be returned. By default, this function uses the cell in which the formula is entered."))],compute:function(e){if(ki(e?.value))return e;const t=void 0===e?this.__originCellPosition?.row:Yo(e.value).top;return Pi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},Ev={description:Fo("Number of rows in a specified array or range."),args:[Dh("range (meta)",Fo("The range whose row count will be returned."))],compute:function(e){if(ki(e?.value))return e;const t=Yo(e.value);return t.bottom-t.top+1},isExported:!0},Iv={description:Fo("Vertical lookup."),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("range (any, range)",Fo("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),Dh("index (number)",Fo("The column index of the value to be returned, where the first column in range is numbered 1.")),Dh("is_sorted (boolean, default=true)",Fo("Indicates whether the column to be searched (the first column of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:gv}){const i=Math.trunc(Vi(o?.value,this.locale));Pi((()=>1<=i&&i<=t.length),Fo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const n=(e,t)=>e[0][t].value,r=Yi(s.value)?pn(t,e,"nextSmaller","asc",t[0].length,n):mn(t,e,"wildcard",t[0].length,n),a=t[i-1][r];return void 0===a?pv(e):a},isExported:!0},Rv={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},Tv={description:Fo("Search a range for a match and return the corresponding item from a second range."),args:[Dh("search_key (string,number,boolean)",Fo("The value to search for.")),Dh("lookup_range (any, range)",Fo("The range to consider for the search. Should be a single column or a single row.")),Dh("return_range (any, range)",Fo("The range containing the return value. Should have the same dimensions as lookup_range.")),Dh("if_not_found (any, optional)",Fo("If a valid match is not found, return this value.")),Dh("match_mode (any, default=0)",Fo("(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.")),Dh("search_mode (any, default=1)",Fo("(1) Search starting at first item. (-1) Search starting at last item. (2) Perform a binary search that relies on lookup_array being sorted in ascending order. If not sorted, invalid results will be returned. (-2) Perform a binary search that relies on lookup_array being sorted in descending order. If not sorted, invalid results will be returned. "))],compute:function(e,t,o,s,i={value:0},n={value:1}){const r=Math.trunc(Vi(i.value,this.locale)),a=Math.trunc(Vi(n.value,this.locale));Pi((()=>1===t.length||1===t[0].length),Fo("lookup_range should be either a single row or single column.")),Pi((()=>[-1,1,-2,2].includes(a)),Fo("search_mode should be a value in [-1, 1, -2, 2].")),Pi((()=>[-1,0,1,2].includes(r)),Fo("match_mode should be a value in [-1, 0, 1, 2]."));const l=1===t.length?"col":"row";Pi((()=>!(2===r&&[-2,2].includes(a))),Fo("the search and match mode combination is not supported for XLOOKUP evaluation.")),Pi((()=>"col"===l?o[0].length===t[0].length:o.length===t.length),Fo("return_range should have the same dimensions as lookup_range."));const c="col"===l?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,h="col"===l?t[0].length:t.length,d=Rv[r],u=-1===a,g=2===a||-2===a?pn(t,e,d,2===a?"asc":"desc",h,c):mn(t,e,d,h,c,u);return-1!==g?"col"===l?o.map((e=>[e[g]])):[o[g]]:void 0===s?pv(e):[[s]]},isExported:!0},Av={description:Fo("Get the value from a pivot."),args:[Dh("pivot_id (number,string)",Fo("ID of the pivot.")),Dh("measure_name (string)",Fo("Name of the measure.")),Dh("domain_field_name (string,optional,repeating)",Fo("Field name.")),Dh("domain_value (number,string,boolean,optional,repeating)",Fo("Value."))],compute:function(e,t,...o){const s=qi(e),i=qi(t),n=hv(s,this.getters);!function(e,t,o){const{measures:s}=o.getPivotCoreDefinition(e);if(!s.find((e=>e.id===t))){const e=`(${s.map((e=>e.id)).join(", ")})`;throw new Ti(Fo("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(n,i,this.getters),dv(o);const r=this.getters.getPivot(n),a=this.getters.getPivotCoreDefinition(n);uv(this,a,a.measures.filter((e=>e.id===i))),r.init({reload:r.needsReevaluation});const l=r.assertIsValid({throwOnError:!1});if(l)return l;if(!r.areDomainArgsFieldsValid(o)){const e=Fo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:Ii.GenericError,message:Fo("Dimensions don't match the pivot definition")+". "+e}}const c=r.parseArgsToPivotDomain(o);return r.getPivotCellValueAndFormat(i,c)}},_v={description:Fo("Get the header of a pivot."),args:[Dh("pivot_id (number,string)",Fo("ID of the pivot.")),Dh("domain_field_name (string,optional,repeating)",Fo("Field name.")),Dh("domain_value (number,string,value,optional,repeating)",Fo("Value."))],compute:function(e,...t){const o=qi(e),s=hv(o,this.getters);dv(t);const i=this.getters.getPivot(s);uv(this,this.getters.getPivotCoreDefinition(s),[]),i.init({reload:i.needsReevaluation});const n=i.assertIsValid({throwOnError:!1});if(n)return n;if(!i.areDomainArgsFieldsValid(t)){const e=Fo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:Ii.GenericError,message:Fo("Dimensions don't match the pivot definition")+". "+e}}const r=i.parseArgsToPivotDomain(t),a=r.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(qi(a.value),r);const{value:l,format:c}=i.getPivotHeaderValueAndFormat(r);return{value:l,format:a&&"measure"!==a.field&&"false"!==a.value?c:void 0}}},Dv={description:Fo("Get a pivot table."),args:[Dh("pivot_id (string)",Fo("ID of the pivot.")),Dh("row_count (number, optional)",Fo("number of rows")),Dh("include_total (boolean, default=TRUE)",Fo("Whether to include total/sub-totals or not.")),Dh("include_column_titles (boolean, default=TRUE)",Fo("Whether to include the column titles or not.")),Dh("column_count (number, optional)",Fo("number of columns"))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE}){const n=qi(e),r=Vi(t,this.locale);if(r<0)return new Ti(Fo("The number of rows must be positive."));const a=Vi(i,this.locale);if(a<0)return new Ti(Fo("The number of columns must be positive."));const l=Yi(s),c=Yi(o),h=hv(n,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);uv(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getTableStructure(),m=p.getPivotCells(c,l),f=l?p.columns.length:0,v=this.getters.getPivotDisplayName(h),b=Math.min(f+r,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+a,m.length),y=[];for(const e of Ze(0,S)){y[e]=[];for(const t of Ze(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":y[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);y[e].push(rc(d,o.domain,t));break;case"MEASURE_HEADER":y[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":y[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}return l&&(y[0][0]={value:v}),y}},Ov={description:Fo("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[Dh("cell_reference (meta)",Fo("The starting point from which to count the offset rows and columns.")),Dh("offset_rows (number)",Fo("The number of rows to offset by.")),Dh("offset_columns (number)",Fo("The number of columns to offset by.")),Dh("height (number, default='height of cell_reference')",Fo("The number of rows of the range to return starting at the offset target.")),Dh("width (number, default='width of cell_reference')",Fo("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(ki(e?.value))return e;const n=e?.value;if(!n)throw new Error("In this context, the function OFFSET needs to have a cell or range in parameter.");const r=Yo(n);let a=r.bottom-r.top+1,l=r.right-r.left+1;if(s){const e=Vi(s,this.locale);Ph(Fo("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}),e),a=e}if(i){const e=Vi(i,this.locale);Ph(Fo("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}),e),l=e}const{sheetName:c}=qo(n),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=Vi(t,this.locale),u=Vi(o,this.locale),g=this.__originCellPosition;g&&this.updateDependencies?.(g);const p=r.left+u,m=r.top+d;if(p<0||m<0)return new _i(Fo("OFFSET evaluates to an out of bounds range."));const f={left:p,top:m,right:p+l-1,bottom:m+a-1},v=this.getters.getRangeFromZone(this.__originSheetId,f);return v.invalidXc||v.invalidSheetName?new _i:(g&&this.addDependencies?.(g,[v]),rn(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var Fv=Object.freeze({__proto__:null,ADDRESS:mv,COLUMN:fv,COLUMNS:vv,HLOOKUP:bv,INDEX:Sv,INDIRECT:yv,LOOKUP:Cv,MATCH:wv,OFFSET:Ov,PIVOT:Dv,PIVOT_HEADER:_v,PIVOT_VALUE:Av,ROW:xv,ROWS:Ev,VLOOKUP:Iv,XLOOKUP:Tv});const Mv={description:Fo("Sum of two numbers."),args:[Dh("value1 (number)",Fo("The first addend.")),Dh("value2 (number)",Fo("The second addend."))],compute:function(e,t){return{value:Vi(e,this.locale)+Vi(t,this.locale),format:e?.format||t?.format}}},Pv={description:Fo("Concatenation of two values."),args:[Dh("value1 (string)",Fo("The value to which value2 will be appended.")),Dh("value2 (string)",Fo("The value to append to value1."))],compute:function(e,t){return qi(e)+qi(t)},isExported:!0},Nv={description:Fo("One number divided by another."),args:[Dh("dividend (number)",Fo("The number to be divided.")),Dh("divisor (number)",Fo("The number to divide by."))],compute:function(e,t){const o=Vi(t,this.locale);return Pi((()=>0!==o),Fo("The divisor must be different from zero."),Ii.DivisionByZero),{value:Vi(e,this.locale)/o,format:e?.format||t?.format}}};function kv(e){return void 0===e||null===e.value}const Lv={number:0,string:"",boolean:!1},Vv={description:Fo("Equal."),args:[Dh("value1 (string, number, boolean)",Fo("The first value.")),Dh("value2 (string, number, boolean)",Fo("The value to test against value1 for equality."))],compute:function(e,t){if(ki(e?.value))return e;if(ki(t?.value))return t;let o=kv(e)?Lv[typeof t?.value]:e?.value,s=kv(t)?Lv[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),{value:o===s}}};function Hv(e,t,o){if(ki(e?.value))return e;if(ki(t?.value))return t;let s=kv(e)?Lv[typeof t?.value]:e?.value,i=kv(t)?Lv[typeof e?.value]:t?.value;"number"!=typeof s&&(s=qi(s).toUpperCase()),"number"!=typeof i&&(i=qi(i).toUpperCase());const n=typeof s,r=typeof i;return"string"===n&&"number"===r?{value:!0}:"string"===r&&"number"===n?{value:!1}:{value:o(s,i)}}const Uv={description:Fo("Strictly greater than."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being greater than value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){return Hv(e,t,((e,t)=>e>t))}},Bv={description:Fo("Greater than or equal to."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being greater than or equal to value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){return Hv(e,t,((e,t)=>e>=t))}},zv={description:Fo("Less than."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being less than value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){const o=Bv.compute.bind(this)(e,t);return ki(o.value)?o:{value:!o.value}}},$v={description:Fo("Less than or equal to."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being less than or equal to value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){const o=Uv.compute.bind(this)(e,t);return ki(o.value)?o:{value:!o.value}}},Wv={description:Fo("Difference of two numbers."),args:[Dh("value1 (number)",Fo("The minuend, or number to be subtracted from.")),Dh("value2 (number)",Fo("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:Vi(e,this.locale)-Vi(t,this.locale),format:e?.format||t?.format}}},Gv={description:Fo("Product of two numbers"),args:[Dh("factor1 (number)",Fo("The first multiplicand.")),Dh("factor2 (number)",Fo("The second multiplicand."))],compute:function(e,t){return{value:Vi(e,this.locale)*Vi(t,this.locale),format:e?.format||t?.format}}},qv={description:Fo("Not equal."),args:[Dh("value1 (string, number, boolean)",Fo("The first value.")),Dh("value2 (string, number, boolean)",Fo("The value to test against value1 for inequality."))],compute:function(e,t){const o=Vv.compute.bind(this)(e,t);return ki(o.value)?o:{value:!o.value}}},Zv={description:Fo("A number raised to a power."),args:[Dh("base (number)",Fo("The number to raise to the exponent power.")),Dh("exponent (number)",Fo("The exponent to raise base to."))],compute:function(e,t){return Kd.compute.bind(this)(e,t)}},jv={description:Fo("A number with the sign reversed."),args:[Dh("value (number)",Fo("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-Vi(e,this.locale),format:e?.format}}},Yv={description:Fo("Value interpreted as a percentage."),args:[Dh("percentage (number)",Fo("The value to interpret as a percentage."))],compute:function(e){return Vi(e,this.locale)/100}},Xv={description:Fo("A specified number, unchanged."),args:[Dh("value (any)",Fo("The number to return."))],compute:function(e={value:null}){return e}};var Kv=Object.freeze({__proto__:null,ADD:Mv,CONCAT:Pv,DIVIDE:Nv,EQ:Vv,GT:Uv,GTE:Bv,LT:zv,LTE:$v,MINUS:Wv,MULTIPLY:Gv,NE:qv,POW:Zv,UMINUS:jv,UNARY_PERCENT:Yv,UPLUS:Xv});const Jv=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),Qv={transform:e=>e,inverseTransform:e=>e},eb=1e-10,tb=.0254,ob=tb/72,sb=.3048,ib=.9144,nb=1609.34,rb=1852,ab=946073047258e4,lb={g:{...Qv,category:"weight"},u:{...Jv(166053e-29),category:"weight"},grain:{...Jv(.0647989),category:"weight"},ozm:{...Jv(28.3495),category:"weight"},lbm:{...Jv(453.592),category:"weight"},stone:{...Jv(6350.29),category:"weight"},sg:{...Jv(14593.90294),category:"weight"},cwt:{...Jv(45359.237),category:"weight"},uk_cwt:{...Jv(50802.3),category:"weight"},ton:{...Jv(907184.74),category:"weight"},uk_ton:{...Jv(1016046.9),category:"weight"},m:{...Qv,category:"distance"},km:{...Jv(1e3),category:"distance"},ang:{...Jv(eb),category:"distance"},Picapt:{...Jv(ob),category:"distance"},pica:{...Jv(tb/6),category:"distance"},in:{...Jv(tb),category:"distance"},ft:{...Jv(sb),category:"distance"},yd:{...Jv(ib),category:"distance"},ell:{...Jv(1.143),category:"distance"},mi:{...Jv(nb),category:"distance"},survey_mi:{...Jv(1609.34),category:"distance"},Nmi:{...Jv(rb),category:"distance"},ly:{...Jv(ab),category:"distance"},parsec:{...Jv(0x6da012f95c9fd0),category:"distance"},sec:{...Qv,category:"time"},min:{...Jv(60),category:"time"},hr:{...Jv(3600),category:"time"},day:{...Jv(86400),category:"time"},yr:{...Jv(31556952),category:"time"},Pa:{...Qv,category:"pressure"},bar:{...Jv(1e5),category:"pressure"},mmHg:{...Jv(133.322),category:"pressure"},Torr:{...Jv(133.322),category:"pressure"},psi:{...Jv(6894.76),category:"pressure"},atm:{...Jv(101325),category:"pressure"},N:{...Qv,category:"force"},dyn:{...Jv(1e-5),category:"force"},pond:{...Jv(.00980665),category:"force"},lbf:{...Jv(4.44822),category:"force"},J:{...Qv,category:"energy"},eV:{...Jv(160218e-24),category:"energy"},e:{...Jv(1e-7),category:"energy"},flb:{...Jv(1.3558179483),category:"energy"},c:{...Jv(4.184),category:"energy"},cal:{...Jv(4.1868),category:"energy"},BTU:{...Jv(1055.06),category:"energy"},Wh:{...Jv(3600),category:"energy"},HPh:{...Jv(2684520),category:"energy"},W:{...Qv,category:"power"},PS:{...Jv(735.499),category:"power"},HP:{...Jv(745.7),category:"power"},T:{...Qv,category:"magnetism"},ga:{...Jv(1e-4),category:"magnetism"},K:{...Qv,category:"temperature"},C:{transform:e=>e+273.15,inverseTransform:e=>e-273.15,category:"temperature"},F:{transform:e=>5*(e-32)/9+273.15,inverseTransform:e=>9*(e-273.15)/5+32,category:"temperature"},Rank:{...Jv(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...Qv,category:"volume",order:3},"ang^3":{...Jv(Math.pow(eb,3)),category:"volume",order:3},"Picapt^3":{...Jv(Math.pow(ob,3)),category:"volume",order:3},tsp:{...Jv(492892e-11),category:"volume"},tspm:{...Jv(5e-6),category:"volume"},tbs:{...Jv(14786764825785619e-21),category:"volume"},"in^3":{...Jv(Math.pow(tb,3)),category:"volume",order:3},oz:{...Jv(295735295625e-16),category:"volume"},cup:{...Jv(237e-6),category:"volume"},pt:{...Jv(.0004731765),category:"volume"},uk_pt:{...Jv(568261e-9),category:"volume"},qt:{...Jv(.0009463529),category:"volume"},l:{...Jv(.001),category:"volume"},uk_qt:{...Jv(.0011365225),category:"volume"},gal:{...Jv(.0037854118),category:"volume"},uk_gal:{...Jv(.00454609),category:"volume"},"ft^3":{...Jv(Math.pow(sb,3)),category:"volume",order:3},bushel:{...Jv(.0352390704),category:"volume"},barrel:{...Jv(.158987295),category:"volume"},"yd^3":{...Jv(Math.pow(ib,3)),category:"volume",order:3},MTON:{...Jv(1.13267386368),category:"volume"},GRT:{...Jv(2.83168),category:"volume"},"mi^3":{...Jv(Math.pow(nb,3)),category:"volume",order:3},"Nmi^3":{...Jv(Math.pow(rb,3)),category:"volume",order:3},"ly^3":{...Jv(Math.pow(ab,3)),category:"volume",order:3},"m^2":{...Qv,category:"area",order:2},"ang^2":{...Jv(Math.pow(eb,2)),category:"area",order:2},"Picapt^2":{...Jv(Math.pow(ob,2)),category:"area",order:2},"in^2":{...Jv(Math.pow(tb,2)),category:"area",order:2},"ft^2":{...Jv(Math.pow(sb,2)),category:"area",order:2},"yd^2":{...Jv(Math.pow(ib,2)),category:"area",order:2},ar:{...Jv(100),category:"area"},Morgen:{...Jv(2500),category:"area"},uk_acre:{...Jv(4046.8564224),category:"area"},us_acre:{...Jv(4046.8726098743),category:"area"},ha:{...Jv(1e4),category:"area"},"mi^2":{...Jv(Math.pow(nb,2)),category:"area",order:2},"Nmi^2":{...Jv(Math.pow(rb,2)),category:"area",order:2},"ly^2":{...Jv(Math.pow(ab,2)),category:"area",order:2},bit:{...Qv,category:"information"},byte:{...Jv(8),category:"information"},"m/s":{...Qv,category:"speed"},"m/hr":{...Jv(1/3600),category:"speed"},"km/hr":{...Jv(1/3.6),category:"speed"},mph:{...Jv(.44704),category:"speed"},kn:{...Jv(.5144444444),category:"speed"},admkn:{...Jv(.5147733333),category:"speed"}},cb={shweight:"cwt",lcwt:"uk_cwt",hweight:"uk_cwt",LTON:"uk_ton",brton:"uk_ton",pc:"parsec",Pica:"Picapt",d:"day",mn:"min",s:"sec",p:"Pa",at:"atm",dy:"dyn",ev:"eV",hh:"HPh",wh:"Wh",btu:"BTU",h:"HP",cel:"C",fah:"F",kel:"K",us_pt:"pt",L:"l",lt:"l",ang3:"ang^3",ft3:"ft^3",in3:"in^3",ly3:"ly^3",m3:"m^3",mi3:"mi^3",yd3:"yd^3",Nmi3:"Nmi^3",Picapt3:"Picapt^3","Pica^3":"Picapt^3",Pica3:"Picapt^3",regton:"GRT",ang2:"ang^2",ft2:"ft^2",in2:"in^2",ly2:"ly^2",m2:"m^2",mi2:"mi^2",Nmi2:"Nmi^2",Picapt2:"Picapt^2","Pica^2":"Picapt^2",Pica2:"Picapt^2",yd2:"yd^2","m/h":"m/hr","m/sec":"m/s"},hb={"":1,Y:1e24,Z:1e21,E:1e18,P:1e15,T:1e12,G:1e9,M:1e6,k:1e3,h:100,da:10,e:10,d:.1,c:.01,m:.001,u:1e-6,n:1e-9,p:1e-12,f:1e-15,a:1e-18,z:1e-21,y:1e-21,Yi:Math.pow(2,80),Zi:Math.pow(2,70),Ei:Math.pow(2,60),Pi:Math.pow(2,50),Ti:Math.pow(2,40),Gi:Math.pow(2,30),Mi:Math.pow(2,20),ki:Math.pow(2,10)},db={weight:Fo("Weight"),distance:Fo("Distance"),time:Fo("Time"),pressure:Fo("Pressure"),force:Fo("Force"),energy:Fo("Energy"),power:Fo("Power"),magnetism:Fo("Magnetism"),temperature:Fo("Temperature"),volume:Fo("Volume"),area:Fo("Area"),information:Fo("Information"),speed:Fo("Speed")};function ub(e){return db[e]??""}function gb(e){for(const[t,o]of Object.entries(hb)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=lb[s];if(!i&&cb[s]&&(i=lb[cb[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const pb={description:Fo("Converts a numeric value to a different unit of measure."),args:[Dh("value (number)",Fo("the numeric value in start_unit to convert to end_unit")),Dh("start_unit (string)",Fo("The starting unit, the unit currently assigned to value")),Dh("end_unit (string)",Fo("The unit of measure into which to convert value"))],compute:function(e,t,o){const s=Vi(e,this.locale),i=qi(t),n=qi(o),r=gb(i),a=gb(n);return r?a?r.category!==a.category?{value:Ii.GenericError,message:Fo("Incompatible units of measure ('%s' vs '%s')",ub(r.category),ub(a.category))}:{value:a.inverseTransform(r.factor*r.transform(s))/a.factor,format:e?.format}:{value:Ii.GenericError,message:Fo("Invalid units of measure ('%s')",n)}:{value:Ii.GenericError,message:Fo("Invalid units of measure ('%s')",i)}},isExported:!0};var mb=Object.freeze({__proto__:null,CONVERT:pb});const fb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,vb={description:Fo("Gets character associated with number."),args:[Dh("table_number (number)",Fo("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(Vi(e,this.locale));return Pi((()=>t>=1),Fo("The table_number (%s) is out of range.",t.toString())),String.fromCharCode(t)},isExported:!0},bb={description:Fo("Remove non-printable characters from a piece of text."),args:[Dh("text (string)",Fo("The text whose non-printable characters are to be removed."))],compute:function(e){const t=qi(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},Sb={description:Fo("Appends strings to one another."),args:[Dh("string1 (string, range<string>)",Fo("The initial string.")),Dh("string2 (string, range<string>, repeating)",Fo("More strings to append in sequence."))],compute:function(...e){return on(e,((e,t)=>e+qi(t)),"")},isExported:!0},yb={description:Fo("Tests whether two strings are identical."),args:[Dh("string1 (string)",Fo("The first string to compare.")),Dh("string2 (string)",Fo("The second string to compare."))],compute:function(e,t){return qi(e)===qi(t)},isExported:!0},Cb={description:Fo("First position of string found in text, case-sensitive."),args:[Dh("search_for (string)",Fo("The string to look for within text_to_search.")),Dh("text_to_search (string)",Fo("The text to search for the first occurrence of search_for.")),Dh("starting_at (number, default=1)",Fo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=qi(e),i=qi(t),n=Vi(o,this.locale);Pi((()=>""!==i),Fo("The text_to_search must be non-empty.")),Pi((()=>n>=1),Fo("The starting_at (%s) must be greater than or equal to 1.",n.toString()));const r=i.indexOf(s,n-1);return Pi((()=>r>=0),Fo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s.toString(),i)),r+1},isExported:!0},wb={description:Fo("Concatenates elements of arrays with delimiter."),args:[Dh("delimiter (string)",Fo("The character or string to place between each concatenated value.")),Dh("value_or_array1 (string, range<string>)",Fo("The value or values to be appended using delimiter.")),Dh("value_or_array2 (string, range<string>, repeating)",Fo("More values to be appended using delimiter."))],compute:function(e,...t){const o=qi(e);return on(t,((e,t)=>(e?e+o:"")+qi(t)),"")}},xb={description:Fo("Substring from beginning of specified string."),args:[Dh("text (string)",Fo("The string from which the left portion will be returned.")),Dh("number_of_characters (number, optional)",Fo("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?Vi(t[0],this.locale):1;return Pi((()=>o>=0),Fo("The number_of_characters (%s) must be positive or null.",o.toString())),qi(e).substring(0,o)},isExported:!0},Eb={description:Fo("Length of a string."),args:[Dh("text (string)",Fo("The string whose length will be returned."))],compute:function(e){return qi(e).length},isExported:!0},Ib={description:Fo("Converts a specified string to lowercase."),args:[Dh("text (string)",Fo("The string to convert to lowercase."))],compute:function(e){return qi(e).toLowerCase()},isExported:!0},Rb={description:Fo("A segment of a string."),args:[Dh("text (string)",Fo("The string to extract a segment from.")),Dh("starting_at (number)",Fo("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),Dh("extract_length (number)",Fo("The length of the segment to extract."))],compute:function(e,t,o){const s=qi(e),i=Vi(t,this.locale),n=Vi(o,this.locale);return Pi((()=>i>=1),Fo("The starting_at argument (%s) must be positive greater than one.",i.toString())),Pi((()=>n>=0),Fo("The extract_length argument (%s) must be positive or null.",n.toString())),s.slice(i-1,i+n-1)},isExported:!0},Tb={description:Fo("Capitalizes each word in a specified string."),args:[Dh("text_to_capitalize (string)",Fo("The text which will be returned with the first letter of each word in uppercase and all other letters in lowercase."))],compute:function(e){return qi(e).replace(fb,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},Ab={description:Fo("Replaces part of a text string with different text."),args:[Dh("text (string)",Fo("The text, a part of which will be replaced.")),Dh("position (number)",Fo("The position where the replacement will begin (starting from 1).")),Dh("length (number)",Fo("The number of characters in the text to be replaced.")),Dh("new_text (string)",Fo("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=Vi(t,this.locale);Pi((()=>i>=1),Fo("The position (%s) must be greater than or equal to 1.",i.toString()));const n=qi(e),r=Vi(o,this.locale),a=qi(s);return n.substring(0,i-1)+a+n.substring(i-1+r)},isExported:!0},_b={description:Fo("A substring from the end of a specified string."),args:[Dh("text (string)",Fo("The string from which the right portion will be returned.")),Dh("number_of_characters (number, optional)",Fo("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?Vi(t[0],this.locale):1;Pi((()=>o>=0),Fo("The number_of_characters (%s) must be positive or null.",o.toString()));const s=qi(e),i=s.length;return s.substring(i-o,i)},isExported:!0},Db={description:Fo("First position of string found in text, ignoring case."),args:[Dh("search_for (string)",Fo("The string to look for within text_to_search.")),Dh("text_to_search (string)",Fo("The text to search for the first occurrence of search_for.")),Dh("starting_at (number, default=1)",Fo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=qi(e).toLowerCase(),i=qi(t).toLowerCase(),n=Vi(o,this.locale);Pi((()=>""!==i),Fo("The text_to_search must be non-empty.")),Pi((()=>n>=1),Fo("The starting_at (%s) must be greater than or equal to 1.",n.toString()));const r=i.indexOf(s,n-1);return Pi((()=>r>=0),Fo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)),r+1},isExported:!0},Ob={description:Fo("Split text by specific character delimiter(s)."),args:[Dh("text (string)",Fo("The text to divide.")),Dh("delimiter (string)",Fo("The character or characters to use to split text.")),Dh("split_by_each (boolean, default=true})",Fo("Whether or not to divide text around each character contained in delimiter.")),Dh("remove_empty_text (boolean, default=true)",Fo("Whether or not to remove empty text messages from the split results. The default behavior is to treat consecutive delimiters as one (if TRUE). If FALSE, empty cells values are added between consecutive delimiters."))],compute:function(e,t,o={value:true},s={value:true}){const i=qi(e),n=Ue(qi(t)),r=Yi(o),a=Yi(s);Pi((()=>n.length>0),Fo("The _delimiter (%s) must be not be empty.",n));const l=r?new RegExp(`[${n}]`,"g"):new RegExp(n,"g");let c=i.split(l);return a&&(c=c.filter((e=>""!==e))),ln([c])},isExported:!0},Fb={description:Fo("Replaces existing text with new text in a string."),args:[Dh("text_to_search (string)",Fo("The text within which to search and replace.")),Dh("search_for (string)",Fo("The string to search for within text_to_search.")),Dh("replace_with (string)",Fo("The string that will replace search_for.")),Dh("occurrence_number (number, optional)",Fo("The instance of search_for within text_to_search to replace with replace_with. By default, all occurrences of search_for are replaced; however, if occurrence_number is specified, only the indicated instance of search_for is replaced."))],compute:function(e,t,o,s){const i=Vi(s,this.locale);Pi((()=>i>=0),Fo("The occurrenceNumber (%s) must be positive or null.",i.toString()));const n=qi(e),r=qi(t);if(""===r)return n;const a=qi(o),l=new RegExp(Ue(r),"g");if(0===i)return n.replace(l,a);let c=0;return n.replace(l,(e=>++c===i?a:e))},isExported:!0},Mb={description:Fo("Combines text from multiple strings and/or arrays."),args:[Dh("delimiter (string)",Fo(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),Dh("ignore_empty (boolean)",Fo("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.")),Dh("text1 (string, range<string>)",Fo("Any text item. This could be a string, or an array of strings in a range.")),Dh("text2 (string, range<string>, repeating)",Fo("Additional text item(s)."))],compute:function(e,t,...o){const s=qi(e),i=Yi(t);let n=0;return on(o,((e,t)=>i&&""===qi(t)?e:(n++?e+s:"")+qi(t)),"")},isExported:!0},Pb={description:Fo("Removes space characters."),args:[Dh("text (string)",Fo("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return Tt(qi(e))},isExported:!0},Nb={description:Fo("Converts a specified string to uppercase."),args:[Dh("text (string)",Fo("The string to convert to uppercase."))],compute:function(e){return qi(e).toUpperCase()},isExported:!0},kb={description:Fo("Converts a number to text according to a specified format."),args:[Dh("number (number)",Fo("The number, date or time to format.")),Dh("format (string)",Fo("The pattern by which to format the number, enclosed in quotation marks."))],compute:function(e,t){return Jn(Vi(e,this.locale),{format:qi(t),locale:this.locale})},isExported:!0},Lb={description:Fo("Converts a string to a numeric value."),args:[Dh("value (number)",Fo("the string to be converted"))],compute:function(e){return Vi(e,this.locale)},isExported:!0};var Vb=Object.freeze({__proto__:null,CHAR:vb,CLEAN:bb,CONCATENATE:Sb,EXACT:yb,FIND:Cb,JOIN:wb,LEFT:xb,LEN:Eb,LOWER:Ib,MID:Rb,PROPER:Tb,REPLACE:Ab,RIGHT:_b,SEARCH:Db,SPLIT:Ob,SUBSTITUTE:Fb,TEXT:kb,TEXTJOIN:Mb,TRIM:Pb,UPPER:Nb,VALUE:Lb});const Hb={description:Fo("Creates a hyperlink in a cell."),args:[Dh("url (string)",Fo("The full URL of the link enclosed in quotation marks.")),Dh("link_label (string, optional)",Fo("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=qi(e).trim(),s=qi(t)||o;return""===o?s:tt(s,o)},isExported:!0};var Ub=Object.freeze({__proto__:null,HYPERLINK:Hb});const Bb=[{name:Fo("Array"),functions:rd},{name:Fo("Database"),functions:zg},{name:Fo("Date"),functions:xp},{name:Fo("Filter"),functions:Np},{name:Fo("Financial"),functions:uf},{name:Fo("Info"),functions:Jf},{name:Fo("Lookup"),functions:Fv},{name:Fo("Logical"),functions:cv},{name:Fo("Math"),functions:Su},{name:Fo("Misc"),functions:ld},{name:Fo("Operator"),functions:Kv},{name:Fo("Statistical"),functions:Tg},{name:Fo("Text"),functions:Vb},{name:Fo("Engineering"),functions:Ip},{name:Fo("Web"),functions:Ub},{name:Fo("Parser"),functions:mb}],zb=/^[A-Z0-9\_\.]+$/;const $b=new class extends n{mapping={};add(e,t){if(e=e.toUpperCase(),!zb.test(e))throw new Error(Fo("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=Oh(t);return function(e){let t=!1,o=!1,s=!1;for(let i of e){if(i.type.includes("META")&&i.type.length>1)throw new Error(Fo("Function ${name} has an argument that has been declared with more than one type whose type 'META'. The 'META' type can only be declared alone."));if(t&&!i.repeating)throw new Error(Fo("Function ${name} has no-repeatable arguments declared after repeatable ones. All repeatable arguments must be declared last."));const e=o||t||s,n=!(i.optional||i.repeating||i.default);if(e&&n)throw new Error(Fo("Function ${name} has at mandatory arguments declared after optional ones. All optional arguments must be after all mandatory arguments."));t=i.repeating,o=i.optional,s=i.default}}(o.args),this.mapping[e]=function(e,t){function o(...o){let i,n=1,r=1,a=1/0,l=1/0;for(let s=0;s<o.length;s++){const c=e.args[e.getArgToFocus(s+1)-1],h=o[s];if(Ci(h)&&!c.acceptMatrix){const e=h.length,t=h[0].length;1!==e||1!==t?(i??=new Array(o.length),1!==e&&1!==t?(i[s]="matrix",n=Math.max(n,e),r=Math.max(r,t),a=Math.min(a,e),l=Math.min(l,t)):1!==e?(i[s]="horizontal",n=Math.max(n,e),a=Math.min(a,e)):1!==t&&(i[s]="vertical",r=Math.max(r,t),l=Math.min(l,t))):o[s]=h[0][0]}if(!Ci(h)&&c.acceptMatrixOnly)throw new Ai(Fo("Function %s expects the parameter '%s' to be reference to a cell or range.",t,(s+1).toString()))}if(1===n&&1===r)return s.apply(this,o);const c=(e,t)=>o.map(((o,s)=>{switch(i?.[s]){case"matrix":return o[e][t];case"horizontal":return o[e][0];case"vertical":return o[0][t];case void 0:return o}}));return rn(n,r,((e,t)=>{if(e>a-1||t>l-1)return Wb;const o=s.apply(this,c(e,t));return Ci(o)?o[0][0]:o}))}function s(...o){for(let t=0;t<o.length;t++){const s=o[t];if(!e.args[e.getArgToFocus(t+1)-1].acceptErrors&&!Ci(s)&&ki(s?.value))return s}try{return i.apply(this,o)}catch(e){return Gb(e,t)}}function i(...o){this.debug;const s=e.compute.apply(this,o);return Ci(s)?"object"==typeof s[0][0]&&null!==s[0][0]&&"value"in s[0][0]?(function(e,t){const o=e.length,s=e[0]?.length??0;for(let i=0;i<o;i++)for(let o=0;o<s;o++)t(e[i][o])}(s,(e=>qb(e,t))),s):an(s,(e=>({value:e}))):"object"==typeof s&&null!==s&&"value"in s?(qb(s,t),s):{value:s}}return o}(o,e),super.add(e,o),this}};for(let e of Bb){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),$b.add(o,{isExported:!1,...s})}}const Wb=new Di(Fo("Array arguments to [[FUNCTION_NAME]] are of different size."));function Gb(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&ki(e.value)?(jb(e)&&qb(e,t),e):(console.error(e),new Ti(Zb+(jb(e)?" "+e.message:"")));var o}function qb(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const Zb=Fo("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function jb(e){return void 0!==e?.message&&"string"==typeof e.message}function Yb(e,t,o){const{x:s,y:i,width:n,height:r}=o;if(n<0||r<0)return;const l=t.color||a,{ctx:c}=e;c.save(),t.noBorder||(t.dashed&&c.setLineDash([5,3]),c.strokeStyle=l,t.thinLine?(c.lineWidth=1,c.strokeRect(s,i,n,r)):(c.lineWidth=2,c.strokeRect(s+.5,i+.5,n,r))),t.noFill||(c.fillStyle=Jt(Bt(l),t.fillAlpha??.12),c.fillRect(s,i,n,r)),c.restore()}Rh.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!this.composer.currentContent.startsWith("="))return[];const o=Object.entries($b.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:Th(t,e,I,"o-semi-bold")}))).sort(((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)));return o},selectProposal(e,t){let o=e.end,s=e.end;["SYMBOL","FUNCTION"].includes(e.type)&&(o=e.start);const i=this.composer.currentTokens;t+="(";const n=i.map((e=>e.start)).indexOf(e.start);if(n+1<i.length){const e=i[n+1];"LEFT_PAREN"===e?.type&&s++}this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}});class Xb extends Ac{mutators=["register","unRegister"];providers=[];constructor(e){super(e),this.onDispose((()=>{this.providers=[]}))}get renderingLayers(){return["Highlights"]}get highlights(){const e=this.getters.getActiveSheetId();return this.providers.flatMap((e=>e.highlights)).filter((t=>t.sheetId===e)).map((e=>{const{numberOfRows:t,numberOfCols:o}=cs(e.zone),s=t*o==1?this.getters.expandZone(e.sheetId,e.zone):e.zone;return{...e,zone:s}}))}register(e){this.providers.push(e)}unRegister(e){this.providers=this.providers.filter((t=>t!==e))}drawLayer(e,t){if("Highlights"===t)for(const t of this.highlights){Yb(e,t,this.getters.getVisibleRect(t.zone))}}}class Kb{mutators=["notifyUser","raiseError","askConfirmation","updateNotificationCallbacks"];notifyUser=e=>window.alert(e.text);askConfirmation=(e,t,o)=>{window.confirm(e)?t():o?.()};raiseError=(e,t)=>{window.alert(e),t?.()};updateNotificationCallbacks(e){this.notifyUser=e.notifyUser||this.notifyUser,this.raiseError=e.raiseError||this.raiseError,this.askConfirmation=e.askConfirmation||this.askConfirmation}}const Jb="#000000",Qb="#3da4ab",eS={OPERATOR:Qb,NUMBER:"#02c39a",STRING:"#00a82d",FUNCTION:Jb,DEBUGGER:Qb,LEFT_PAREN:Jb,RIGHT_PAREN:Jb,ARG_SEPARATOR:Jb,ORPHAN_RIGHT_PAREN:"#ff0000"};class tS extends Ac{mutators=["startEdition","setCurrentContent","stopEdition","stopComposerRangeSelection","cancelEdition","cycleReferences","toggleEditionMode","changeComposerCursorSelection","replaceComposerCursorSelection"];col=0;row=0;editionMode="inactive";sheetId="";_currentContent="";currentTokens=[];selectionStart=0;selectionEnd=0;initialContent="";colorIndexByRange={};notificationStore=this.get(Kb);highlightStore=this.get(Xb);constructor(e){super(e),this.highlightStore.register(this),this.onDispose((()=>{this.highlightStore.unRegister(this)}))}handleEvent(e){const t=this.getters.getActiveSheetId();let o;if(o=e.options.unbounded?this.getters.getUnboundedZone(t,e.anchor.zone):e.anchor.zone,"newAnchor"===e.mode)"selecting"===this.editionMode&&this.insertSelectedRange(o);else"selecting"===this.editionMode?this.replaceSelectedRange(o):this.updateComposerRange(e.previousAnchor.zone,o)}changeComposerCursorSelection(e,t){this.isSelectionValid(this._currentContent.length,e,t)&&(this.selectionStart=e,this.selectionEnd=t,this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode="editing")}startEdition(e,t){if(t){const o=e||this.getComposerContent(this.getters.getActivePosition());if(!this.isSelectionValid(o.length,t.start,t.end))return}const{col:o,row:s}=this.getters.getActivePosition();this.model.dispatch("SELECT_FIGURE",{id:null}),this.model.dispatch("SCROLL_TO_CELL",{col:o,row:s}),"inactive"!==this.editionMode&&e?this.setContent(e,t):this._startEdition(e,t),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor()}cancelEdition(){this.cancelEditionAndActivateSheet(),this.resetContent()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case"SELECT_FIGURE":e.id&&(this.cancelEditionAndActivateSheet(),this.resetContent());break;case"START_CHANGE_HIGHLIGHT":const{left:t,top:o}=e.zone;this.isSelectingRange&&(this.editionMode="editing"),this.model.selection.resetAnchor(this,{cell:{col:t,row:o},zone:e.zone})}}get currentContent(){return"inactive"===this.editionMode?this.getComposerContent(this.getters.getActivePosition()):this._currentContent}get composerSelection(){return{start:this.selectionStart,end:this.selectionEnd}}get isSelectingRange(){return"selecting"===this.editionMode}get showSelectionIndicator(){return this.isSelectingRange&&this.canStartComposerRangeSelection()}get tokenAtCursor(){const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd);return e===t&&0===t?void 0:this.currentTokens.find((o=>o.start<=e&&o.end>=t))}cycleReferences(){const e=this.getters.getLocale(),t=Uf(this.composerSelection,this._currentContent,e);void 0!==t&&this.setCurrentContent(t.content,t.selection)}toggleEditionMode(){if("inactive"===this.editionMode)return;const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd),o=[...this.currentTokens].reverse().find((o=>o.end>=e&&t>=o.start&&"REFERENCE"===o.type));if("editing"===this.editionMode&&o){const e=this.getters.getActiveSheetId(),{sheetName:t,xc:s}=qo(o.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=o.end;const n=this.getters.getRangeFromSheetXC(this.sheetId,s).zone;this.captureSelection(n),this.editionMode="selecting"}else this.editionMode="editing"}captureSelection(e,t,o){this.model.selection.capture(this,{cell:{col:t||e.left,row:o||e.right},zone:e},{handleEvent:this.handleEvent.bind(this),release:()=>{this._stopEdition()}})}isSelectionValid(e,t,o){return t>=0&&t<=e&&o>=0&&o<=e}startComposerRangeSelection(){if(this.sheetId===this.getters.getActiveSheetId()){const e=fs({col:this.col,row:this.row});this.model.selection.resetAnchor(this,{cell:{col:this.col,row:this.row},zone:e})}this.editionMode="selecting"}_startEdition(e,t){const o=this.getters.getActiveCell(),s=this.getters.getLocale();e&&o.format?.includes("%")&&ti(e,s)&&(t=t||{start:e.length,end:e.length},e=`${e}%`);const{col:i,row:n,sheetId:r}=this.getters.getActivePosition();this.col=i,this.sheetId=r,this.row=n,this.initialContent=this.getComposerContent({sheetId:r,col:i,row:n}),this.editionMode="editing",this.setContent(e||this.initialContent,t),this.colorIndexByRange={};const a=fs({col:this.col,row:this.row});this.captureSelection(a,i,n)}_stopEdition(){if("inactive"!==this.editionMode){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(!(this.initialContent!==e))return;if(e&&e.startsWith("=")){const t=this.currentTokens.filter((e=>"LEFT_PAREN"===e.type)).length-this.currentTokens.filter((e=>"RIGHT_PAREN"===e.type)).length;t>0&&(e+=dt(new Array(t).fill(")")))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return Da(this._currentContent,this.getters.getLocale())}cancelEditionAndActivateSheet(){if("inactive"===this.editionMode)return;this._cancelEdition();this.getters.getActiveSheetId()!==this.sheetId&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getters.getActiveSheetId(),sheetIdTo:this.sheetId})}_cancelEdition(){"inactive"!==this.editionMode&&(this.editionMode="inactive",this.model.selection.release(this),this.colorIndexByRange={})}resetContent(){this.setContent(this.initialContent||"")}setContent(e,t,o){const s=this._currentContent!==e;if(this._currentContent=e,t?(this.selectionStart=t.start,this.selectionEnd=t.end):this.selectionStart=this.selectionEnd=e.length,s||"inactive"!==this.editionMode){const t=this.getters.getLocale();this.currentTokens=e.startsWith("=")?kf(e,t):[],this.currentTokens.length>100&&o&&this.notificationStore.raiseError(Fo("This formula has over 100 parts. It can't be processed properly, consider splitting it into multiple cells"))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection()}getAutoCompleteProviders(){return Rh.getAll()}insertSelectedRange(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=this.getZoneReference(e);this.canStartComposerRangeSelection()?this.insertText(o,t):this.insertText(","+o,t)}replaceSelectedRange(e){const t=this.getZoneReference(e),o=this.tokenAtCursor,s="REFERENCE"===o?.type?o.start:this.selectionStart;this.replaceText(t,s,this.selectionEnd)}updateComposerRange(e,t){const o=this.getters.getActiveSheetId(),s=this.tokenAtCursor,i=(s?[s,...this.currentTokens]:this.currentTokens).filter((e=>"REFERENCE"===e.type)).find((t=>{const{xc:s,sheetName:i}=qo(t.value),n=i||this.getters.getSheetName(this.sheetId);if(this.getters.getSheetName(o)!==n)return!1;const r=this.getters.getRangeFromSheetXC(o,s);return ns(this.getters.expandZone(o,r.zone),e)}));if(!i)return;const n=this.getters.getRangeFromSheetXC(o,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;const r=this.getters.getRangeFromZone(o,t),a=this.getRangeReference(r,n.parts);this.replaceSelection(a)}getZoneReference(e){const t=this.sheetId,o=this.getters.getActiveSheetId(),s=this.getters.getRangeFromZone(o,e);return this.getters.getSelectionRangeString(s,t)}getRangeReference(e,t){let o=[...t];const s=e.clone({parts:o});return this.getters.getSelectionRangeString(s,this.sheetId)}replaceSelection(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=Math.max(this.selectionStart,this.selectionEnd);this.replaceText(e,t,o)}replaceText(e,t,o){this._currentContent=this._currentContent.slice(0,t)+this._currentContent.slice(o,this._currentContent.length),this.insertText(e,t)}insertText(e,t){const o=this._currentContent.slice(0,t)+e+this._currentContent.slice(t),s=t+e.length;this.setCurrentContent(o,{start:s,end:s})}updateTokenColor(){this.updateRangeColor();for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].color=this.getTokenColor(this.currentTokens[e])}getTokenColor(e){if("REFERENCE"===e.type){const{xc:t,sheetName:o}=qo(e.value);return this.rangeColor(t,o)||Jb}if("SYMBOL"===e.type){const t=e.value.toUpperCase();if("TRUE"===t||"FALSE"===t)return eS.NUMBER;if(t in $b.content)return eS.FUNCTION}return["LEFT_PAREN","RIGHT_PAREN"].includes(e.type)&&""===e.parenthesesCode?eS.ORPHAN_RIGHT_PAREN:eS[e.type]||Jb}rangeColor(e,t){const o=t?this.model.getters.getSheetIdByName(t):this.sheetId,s=this.highlights.find((t=>{if(t.sheetId!==o)return!1;let s=this.model.getters.getRangeFromSheetXC(o,e).zone;return s=1===Ss(s)?this.model.getters.expandZone(o,s):s,ns(s,t.zone)}));return s&&s.color?s.color:void 0}computeFormulaCursorContext(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isBlurred=!1;if(this.selectionStart!==this.selectionEnd)return;const e=this.getParenthesesCodeAfterCursor(),t=[...this.currentTokens].reverse().find((t=>e.startsWith(t.parenthesesCode)&&"SYMBOL"===t.type));if(t)for(let e=0;e<this.currentTokens.length;e++)(this.currentTokens[e].parenthesesCode||"").startsWith(t.parenthesesCode||"")||(this.currentTokens[e].isBlurred=!0)}getParenthesesCodeAfterCursor(){const e=this.tokenAtCursor?.parenthesesCode||"";return"RIGHT_PAREN"===this.tokenAtCursor?.type?e.slice(0,-1)||"":e}computeParenthesisRelatedToCursor(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isParenthesisLinkedToCursor=!1;const e=this.tokenAtCursor;if(e&&""!==e.parenthesesCode&&["LEFT_PAREN","RIGHT_PAREN"].includes(e.type))for(let t=0;t<this.currentTokens.length;t++){const o=this.currentTokens[t];["LEFT_PAREN","RIGHT_PAREN"].includes(o.type)&&o.parenthesesCode===e.parenthesesCode&&o!==e&&(this.currentTokens[t].isParenthesisLinkedToCursor=!0,this.tokenAtCursor.isParenthesisLinkedToCursor=!0)}}updateRangeColor(){if(!this._currentContent.startsWith("=")||"inactive"===this.editionMode)return;const e=this.sheetId,t=this.getReferencedRanges().map((t=>this.getters.getRangeString(t,e))),o={};for(const e of t)void 0!==this.colorIndexByRange[e]&&(o[e]=this.colorIndexByRange[e]);const s=new Set(Object.values(o));let i=0;const n=()=>{for(;s.has(i);)i++;return s.add(i),i};for(const e of t){const t=e in o?o[e]:n();o[e]=t}this.colorIndexByRange=o}get highlights(){if(!this.currentContent.startsWith("=")||"inactive"===this.editionMode)return[];const e=this.sheetId,t=e=>{const t=this.colorIndexByRange[e];return Vt[t%Vt.length]};return this.getReferencedRanges().map((o=>{const s=this.getters.getRangeString(o,e),{numberOfRows:i,numberOfCols:n}=cs(o.zone);return{zone:i*n==1?this.getters.expandZone(o.sheetId,o.zone):o.zone,color:t(s),sheetId:o.sheetId,interactive:!0}}))}getReferencedRanges(){const e=this.sheetId;return this.currentTokens.filter((e=>"REFERENCE"===e.type)).map((t=>this.getters.getRangeFromSheetXC(e,t.value))).filter((e=>!e.invalidSheetName&&!e.invalidXc))}get autocompleteProvider(){const e=this.currentContent,t=e.startsWith("=")?this.tokenAtCursor:{type:"STRING",value:e};if("inactive"===this.editionMode||!t||["TRUE","FALSE"].includes(t.value.toUpperCase())||!this.canStartComposerRangeSelection()&&!["SYMBOL","STRING","UNKNOWN"].includes(t.type))return;const o={composer:this,getters:this.getters},s=this.getAutoCompleteProviders().sort(((e,t)=>(e.sequence??1/0)-(t.sequence??1/0))).map((s=>({...s,getProposals:s.getProposals.bind(o,t,e),selectProposal:s.selectProposal.bind(o,t)})));for(const e of s){let o=e.getProposals();const s=o?.find((e=>e.text===t.value)),i=t.value.replace(/[ ,\(\)]/g,"");if(s&&this._currentContent!==this.initialContent)return;if(i&&o&&!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(t.type)){const e=Br(i,o,(e=>e.fuzzySearchKey||e.text));(!s||e.length>1)&&(o=e)}if(e.maxDisplayedProposals&&(o=o?.slice(0,e.maxDisplayedProposals)),o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1}}}canStartComposerRangeSelection(){if(this._currentContent.startsWith("=")){const e=this.tokenAtCursor;if(!e)return!1;const t=this.currentTokens.map((e=>e.start)).indexOf(e.start);let o=t,s=e;for(;!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(s.type)||pa.includes(s.value);){if("SPACE"!==s.type||o<1)return!1;o--,s=this.currentTokens[o]}for(o=t+1,s=this.currentTokens[o];s&&!["ARG_SEPARATOR","RIGHT_PAREN","OPERATOR"].includes(s.type);){if("SPACE"!==s.type)return!1;o++,s=this.currentTokens[o]}return!0}return!1}}class oS{scope;code="";constructor(e=new iS){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new sS(this.scope,this.code,e)}toString(){return nS(this.code)}}class sS{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=nS(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;const e=this.scope.nextVariableName(),t=new oS(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}}class iS{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function nS(e){let t="",o=0;const s=e.split("\n").map((e=>e.trim())).filter((e=>""!==e));for(const e of s)e.startsWith("}")&&o--,t+="\t".repeat(o)+e+"\n",e.endsWith("{")&&o++;return t.trim()}const rS=$b.content,aS={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},lS={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},cS={};function hS(e){return dS(vf(e))}function dS(e){try{return function(e){const{dependencies:t,constantValues:o,symbols:s}=function(e){const t={numbers:[],strings:[]},o=[],s=[];for(const i of e)switch(i.type){case"INVALID_REFERENCE":case"REFERENCE":o.push(i.value);break;case"STRING":const e=He(i.value);t.strings.includes(e)||t.strings.push(e);break;case"NUMBER":{const e=si(i.value,Si);t.numbers.includes(e)||t.numbers.push(e);break}case"SYMBOL":s.push($e(i.value,"'"))}return{dependencies:o,constantValues:t,symbols:s}}(e),i=function(e,t,o,s){let i="";for(const s of e)switch(s.type){case"STRING":const e=He(s.value);i+=`|S${o.strings.indexOf(e)}|`;break;case"NUMBER":i+=`|N${o.numbers.indexOf(si(s.value,Si))}|`;break;case"REFERENCE":case"INVALID_REFERENCE":s.value.includes(":")?i+=`R|${t.indexOf(s.value)}|`:i+=`C|${t.indexOf(s.value)}|`;break;case"SPACE":i+="";break;default:i+=s.value}return i}(e,t,o);if(!cS[i]){const r=Af([...e]),a=new iS;if("BIN_OPERATION"===r.type&&":"===r.value)throw new Ai(Fo("Invalid formula"));if("EMPTY"===r.type)throw new Ai(Fo("Invalid formula"));const l=u(r),c=new oS;c.append(`// ${i}`),c.append(l),c.append(`return ${l.returnExpression};`);let h=new Function("deps","ref","range","getSymbolValue","ctx",c.toString());function d(e){const{args:t}=e,o=e.value.toUpperCase(),s=rS[o];if(!s)throw new Oi(Fo('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=rS[o];if(t<s.minArgRequired)throw new Ai(Fo("Invalid number of arguments for the %s function. Expected %s minimum, but got %s instead.",o,s.minArgRequired.toString(),t.toString()));if(t>s.maxArgPossible)throw new Ai(Fo("Invalid number of arguments for the %s function. Expected %s maximum, but got %s instead.",o,s.maxArgPossible.toString(),t.toString()));const i=s.nbrArgRepeating;if(i>1){const e=s.args.length-i;if((t-e)%i!=0)throw new Ai(Fo("Invalid number of arguments for the %s function. Expected all arguments after position %s to be supplied by groups of %s arguments",o,e.toString(),i.toString()))}}(e);const i=[];for(let e=0;e<t.length;e++){const o=s.getArgToFocus(e+1)-1,n=s.args[o],r=t[e],a=n.type||[],l=a.includes("META"),c=a.some((e=>uS(e)));i.push(u(r,l,c))}return i}function u(e,i=!1,n=!1){const r=new oS(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&i)throw new Ai(Fo("Argument must be a reference to a cell or range."));switch(e.debug&&(r.append("debugger;"),r.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return r.return(`{ value: ${e.value} }`);case"NUMBER":return r.return(`{ value: this.constantValues.numbers[${o.numbers.indexOf(e.value)}] }`);case"STRING":return r.return(`{ value: this.constantValues.strings[${o.strings.indexOf(e.value)}] }`);case"REFERENCE":const a=t.indexOf(e.value);return!i&&e.value.includes(":")||n?r.return(`range(deps[${a}])`):r.return(`ref(deps[${a}], ${i?"true":"false"})`);case"FUNCALL":const l=d(e).map((e=>e.assignResultToVariable()));r.append(...l);const c=e.value.toUpperCase();return r.return(`ctx['${c}'](${l.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=lS[e.value],o=u(e.operand,!1,!1).assignResultToVariable();return r.append(o),r.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=aS[e.value],o=u(e.left,!1,!1).assignResultToVariable(),s=u(e.right,!1,!1).assignResultToVariable();return r.append(o),r.append(s),r.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const h=s.indexOf(e.value);return r.return(`getSymbolValue(this.symbols[${h}])`);case"EMPTY":return r.return("undefined")}}cS[i]=h}const n={execute:cS[i],dependencies:t,constantValues:o,symbols:s,tokens:e,isBadExpression:!1,normalizedFormula:i};return n}(e)}catch(t){return{tokens:e,dependencies:[],execute:function(){return t},isBadExpression:!0,normalizedFormula:e.map((e=>e.value)).join("")}}}function uS(e){return e.startsWith("RANGE")}const gS=$b.content;function pS(e){try{return 0===Df(Af(e)).filter((e=>"FUNCALL"===e.type&&!gS[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function mS(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=Af(e)}catch{return[]}return function(e,t){return Df(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}const fS=["PIVOT.VALUE","PIVOT.HEADER","PIVOT"];function vS(e,t){const o=`"${t?`${e.name}:${t}`:e.name}"`,s=e.string!==e.name?e.string+o:o;return{text:o,description:e.string+(e.help?` (${e.help})`:""),htmlContent:[{value:o,color:eS.STRING}],fuzzySearchKey:s}}function bS(e,t){let o=e.end;const s=e.end;"ARG_SEPARATOR"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function SS(e,t){let o=e.end;const s=e.end;"LEFT_PAREN"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function yS(e){const t=e.functionContext?.args[0];if(t&&["STRING","NUMBER"].includes(t.type))return t.value}function CS(e){return mS(e,fS)[0]}function wS(e){return mS(e,fS).length}const xS=new n;xS.add("SPREADSHEET",!1),Rh.add("pivot_ids",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!["PIVOT.VALUE","PIVOT.HEADER","PIVOT"].includes(t.parent.toUpperCase())||0!==t.argPosition)return;const o=this.getters.getPivotIds();return o.includes(e.value)?void 0:o.map((e=>{const t=this.getters.getPivotCoreDefinition(e),o=`${this.getters.getPivotFormulaId(e)}`;return{text:o,description:t.name,htmlContent:[{value:o,color:eS.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(at)},selectProposal:SS}),Rh.add("pivot_measures",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if("PIVOT.VALUE"!==t?.parent.toUpperCase()||1!==t.argPosition)return[];const o=yS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return[];const i=this.getters.getPivot(s);return i.init(),i.isValid()?i.definition.measures.map((e=>{if("__count"===e.fieldName){const e='"__count"';return{text:e,description:Fo("Count"),htmlContent:[{value:e,color:eS.STRING}],fuzzySearchKey:Fo("Count")+e}}return function(e){const t=`"${e.id}"`,o=e.displayName+e.fieldName+t;return{text:t,description:e.displayName,htmlContent:[{value:t,color:eS.STRING}],fuzzySearchKey:o}}(e)})).filter(at):[]},selectProposal:bS}),Rh.add("pivot_group_fields",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==0}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==1}(e))return;const o=yS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);i.init();const n=i.getFields(),{columns:r,rows:a}=i.definition;let l=t.args;"PIVOT.VALUE"===t?.parent.toUpperCase()?(l=l.filter(((e,t)=>t%2==0)),l=l.slice(1,t.argPosition)):l=l.filter(((e,t)=>t%2==1));const c=l.map((e=>e?.value)).filter(at),h=r.map((e=>e.nameWithGranularity)),d=a.map((e=>e.nameWithGranularity)),u=[];let g=["ARG_SEPARATOR","SPACE"].includes(e.type)?c.at(-1):c.at(-2);const p=xS.get(i.type);if(p&&g?.startsWith("#")&&(g=g.slice(1)),void 0===g&&(u.push(h[0]),u.push(d[0])),d.includes(g)){const e=d[d.indexOf(g)+1];u.push(e),u.push(h[0])}if(h.includes(g)){const e=h[h.indexOf(g)+1];u.push(e)}const m=u.filter(at);return m.map((e=>{const[t,o]=e.split(":"),s=n[t];return s?vS(s,o):void 0})).concat(m.map((e=>{if(!p)return;const t=e.split(":")[0],o=n[t];if(!o)return;const s=`"#${e}"`;return{text:s,description:Fo("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:eS.STRING}],fuzzySearchKey:o.string+s}}))).filter(at)},selectProposal:bS}),Rh.add("pivot_group_values",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!e||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==1}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==0}(e))return;const o=yS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);if(!i.isValid())return;const n=t.argPosition,r=e.functionContext?.args[n-1]?.value;if(!r)return;let a;try{a=i.definition.getDimension(r)}catch(e){return}return"month_number"===a.granularity?Object.values(Xn).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:eS.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:Fo("Quarter %s",e),htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"day_of_month"===a.granularity?Ze(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"iso_week_number"===a.granularity?Ze(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"day_of_week"===a.granularity?Ze(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"hour_number"===a.granularity?Ze(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"minute_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"second_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):i.getPossibleFieldValues(a).map((({value:e,label:t})=>{const o="string"==typeof e,s=o?`"${e}"`:e.toString(),i=t===e?"":t;return{text:s,description:i,htmlContent:[{value:s,color:o?eS.STRING:eS.NUMBER}],fuzzySearchKey:e+i}}))},selectProposal:bS}),Rh.add("sheet_names",{sequence:150,autoSelectFirstProposal:!0,getProposals(e){return"SYMBOL"===e.type||"UNKNOWN"===e.type&&e.value.startsWith("'")?this.getters.getSheetIds().map((e=>{const t=We(this.getters.getSheetName(e));return{text:t,fuzzySearchKey:t.startsWith("'")?t:"'"+t}})):[]},selectProposal(e,t){const o=e.start,s=e.end;this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t+"!")}});const ES=new n;ES.add("ALPHANUMERIC_INCREMENT_MODIFIER",{apply:(e,t)=>{e.current+=e.increment;const o=`${e.prefix}${e.current.toString().padStart(e.numberPostfixLength||0,"0")}`;return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:o},tooltip:{props:{content:o}}}}}).add("INCREMENT_MODIFIER",{apply:(e,t,o)=>{e.current+=e.increment;const s=e.current.toString(),i=o.getLocale(),n=Jn(e.current,{format:t.cell?.format,locale:i});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:n}}:void 0}}}).add("DATE_INCREMENT_MODIFIER",{apply:(e,t,o)=>{const s=Xi(e.current,o.getLocale());s.setFullYear(s.getFullYear()+e.increment.years||0),s.setMonth(s.getMonth()+e.increment.months||0),s.setDate(s.getDate()+e.increment.days||0);const i=$s(s);e.current=i;const n=o.getLocale(),r=Jn(i,{format:t.cell?.format,locale:n});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:r}}:void 0}}}).add("COPY_MODIFIER",{apply:(e,t,o)=>{const s=t.cell?.content||"",i={locale:o.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:t.cell?Ir(t.cell,i).formattedValue:""}}:void 0}}}).add("FORMULA_MODIFIER",{apply:(e,t,o,s)=>{e.current+=e.increment;let i=0,n=0;switch(s){case"up":i=0,n=-e.current;break;case"down":i=0,n=e.current;break;case"left":i=-e.current,n=0;break;case"right":i=e.current,n=0}const r=t.cell;if(!r||!r.isFormula)return{cellData:{}};const a=t.sheetId,l=o.getTranslatedCellFormula(a,i,n,r.compiledFormula.tokens);return{cellData:{border:t.border,style:r.style,format:r.format,content:l},tooltip:l?{props:{content:l}}:void 0}}});const IS=new n,RS=/(\d+)$/,TS=/^(.*\D+)/,AS=/^(.*\D+)(\d+)$/;function _S(e,t,o){let s=[],i=!1;for(let n of t){n===e&&(i=!0);const t=void 0===n||n.isFormula?void 0:Ir(n,{locale:Si,format:n.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function DS(e){let t=1;return e.length>=2&&(t=function(e){const t=[];let o=e[0];for(let s=1;s<e.length;s++){const i=e[s];t.push(i-o),o=i}return t.reduce(((e,t)=>e+t),0)/t.length}(e)*e.length),t}function OS(e){if(e.length<2)return 1;const t=e.map((e=>Xi(e,Si))),o=function(e){if(e.length<2)return[{years:0,months:0,days:0}];const t=e.map(((t,o)=>{if(0===o)return{years:0,months:0,days:0};const s=Is.fromTimestamp(e[o-1].getTime()),i=Ks(s,t),n=Ys(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+n);return{years:i,months:n,days:Xs(s,t)}}));return t.slice(1)}(t),s=(i=o).length<2?i[0]||{years:0,months:0,days:0}:i.every((e=>e.years===i[0].years&&e.months===i[0].months&&e.days===i[0].days))?i[0]:void 0;var i;if(void 0===s)return;const n=1===Object.values(s).filter((e=>0!==e)).length,r=Object.values(s).every((e=>0===e));if(!n||r){const o=t.map(((e,o)=>{if(0===o)return 0;const s=t[o-1];return Math.floor(e.getTime())-Math.floor(s.getTime())})).slice(1);if(o.every((e=>e===o[0])))return e.length*(e[1]-e[0])}return{years:s.years*e.length,months:s.months*e.length,days:s.days*e.length}}IS.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&rr(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.text&&AS.test(e.content),generateRule:(e,t)=>{const o=parseInt(e.content.match(RS)[0]),s=e.content.match(TS)[0],i=e.content.length-s.length,n=DS(_S(e,t,(e=>e.type===ni.text&&AS.test(e.value))).filter((e=>s===(e.value??"").toString().match(TS)[0])).map((e=>parseInt((e.value??"").toString().match(RS)[0]))));return{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:s,current:o,increment:n,numberPostfixLength:i}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.text,generateRule:()=>({type:"COPY_MODIFIER"}),sequence:20}).add("update_formula",{condition:e=>e.isFormula,generateRule:(e,t)=>({type:"FORMULA_MODIFIER",increment:t.length,current:0}),sequence:30}).add("increment_dates",{condition:(e,t)=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.number&&!!e.format&&rr(e.format),generateRule:(e,t)=>{const o=OS(_S(e,t,(e=>e.type===ni.number&&!!e.format&&rr(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=Ir(e,{locale:Si});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===ni.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ni.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.number,generateRule:(e,t)=>{const o=DS(_S(e,t,(e=>e.type===ni.number&&!rr(e.format||""))).map((e=>Number(e.value)))),s=Ir(e,{locale:Si});return{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ni.number?s.value:0}},sequence:40});const FS=new n,MS=30,PS=10,NS=20,kS=12,LS=80,VS="#F3F2F1",HS=6,US=25;function BS(e,t){const o=e.getBoundingClientRect();e.width=o.width,e.height=o.height;const s=e.getContext("2d"),i=function(e,t,o){const s=t.maxValue,i=t.minValue,n=t.gaugeValue,r=function(e,t){const o=t?US:0,s=e.height-NS-o-PS,i=e.width-2*MS;let n,r;i>2*s?(n=2*s,r=s):(n=i,r=i/2);const a=o+PS+(s-r)/2;return{x:MS+(i-n)/2,y:a,width:n,height:r}}(e,t.title.text),a=r.width/6,l=n?(n.value-i.value)/(s.value-i.value):0,c={x:e.width/2,y:r.y+r.height-r.height/12};let h=LS;r.height<300&&(h*=r.height/300);const d=r.width/2,u=n?.label||"-";jr(o,u,{fontSize:h},"px")>d&&(h=function(e,t,o,s=.25){let i=1;if(o(i)>e)return i;if(o(t)<e)return t;let n=(i+t)/2,r=o(n),a=0;for(;Math.abs(r-e)>s&&a<20;)r>=e?t=(i+t)/2:i=(i+t)/2,n=(i+t)/2,r=o(n),a++;return n}(d,h,(e=>jr(o,u,{fontSize:e},"px"))));const g={x:r.x+a/2,y:r.y+r.height+kS},p={x:r.x+r.width-a/2,y:r.y+r.height+kS},m=jc(t.background),f=function(e,t,o,s){const i=e.maxValue,n=e.minValue,r={x:t.x+t.width/2,y:t.y+t.height},a={fontSize:kS},l=[],c=[];for(const h of e.inflectionValues){const e=(h.value-n.value)/(i.value-n.value),d=jr(s,h.label,a,"px"),u=Math.PI-Math.PI*e,g=qS(u,t.height+HS,r.x,r.y,d+2,kS);let p=c.some((e=>GS(e,g)))?kS:0;c.push(g),l.push({rotation:u,label:h.label,fontSize:kS,color:o,offset:p})}return l}(t,r,m,o);let v=0,b=0,S=0;t.title.text&&({width:b,height:S}=Kr(o,t.title.text,{fontSize:X,...t.title},"px"));switch(t.title.align){case"right":v=e.width-b-Z;break;case"center":v=(e.width-b)/2;break;default:v=Z}return{width:e.width,height:e.height,title:{label:t.title.text??"",fontSize:t.title.fontSize??X,textPosition:{x:v,y:Y+S/2},color:t.title.color??m,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:r,arcWidth:a,percentage:qe(l,0,1),color:zS(t)},inflectionValues:f,gaugeValue:{label:u,textPosition:c,fontSize:h,color:m},minLabel:{label:t.minValue.label,textPosition:g,fontSize:kS,color:m},maxLabel:{label:t.maxValue.label,textPosition:p,fontSize:kS,color:m}}}(o,t,s);!function(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}(s,i),function(e,t){e.save();const o=t.gauge,s=o.rect.x+o.rect.width/2,i=o.rect.y+o.rect.height,n=o.rect.height-o.arcWidth/2;if(n<0)return;const r=1===o.percentage?0:Math.PI*(1+o.percentage);e.strokeStyle=VS,e.beginPath(),e.lineWidth=o.arcWidth,e.arc(s,i,n,r,0),e.stroke(),e.strokeStyle=o.color,e.beginPath(),e.arc(s,i,n,Math.PI,r),e.stroke(),e.restore()}(s,i),function(e,t){const{x:o,y:s,width:i,height:n}=t.gauge.rect;for(const r of t.inflectionValues){e.save(),e.translate(o+i/2-.5,s+n-.5),e.rotate(Math.PI/2-r.rotation),e.lineWidth=2,e.strokeStyle=jc(t.backgroundColor)+"aa",e.beginPath(),e.moveTo(0,-(n-t.gauge.arcWidth)),e.lineTo(0,-n-3),e.stroke(),e.textAlign="center",e.font=`${r.fontSize}px ${fe}`,e.fillStyle=r.color;const a=-n-HS-r.offset;e.fillText(r.label,0,a),e.restore()}}(s,i),function(e,t){for(const o of[t.minLabel,t.maxLabel,t.gaugeValue])e.save(),e.textAlign="center",e.fillStyle=o.color,e.font=`${o.fontSize}px ${fe}`,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i),function(e,t){e.save();const o=t.title;e.font=qr(o.fontSize,o.bold,o.italic),e.textBaseline="middle",e.fillStyle=o.color,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i)}function zS(e){const t=e.gaugeValue?.value;if(void 0===t)return VS;for(let o=0;o<e.inflectionValues.length;o++){const s=e.inflectionValues[o];if("<"===s.operator&&t<s.value)return e.colors[o];if("<="===s.operator&&t<=s.value)return e.colors[o]}return e.colors.at(-1)}function $S(e){return[{start:e.topLeft,end:e.topRight},{start:e.topRight,end:e.bottomRight},{start:e.bottomRight,end:e.bottomLeft},{start:e.bottomLeft,end:e.topLeft}]}function WS(e,t){const o=e.start,s=e.end,i=t.start,n=t.end;function r(e,t,o){return(o.y-e.y)*(t.x-e.x)>(t.y-e.y)*(o.x-e.x)}return r(o,i,n)!==r(s,i,n)&&r(o,s,i)!==r(o,s,n)}function GS(e,t){const o=$S(e),s=$S(t);for(const e of o)for(const t of s)if(WS(e,t))return!0;return!1}function qS(e,t,o,s,i,n){const r=Math.cos(e),a=Math.sin(e),l=r*t,c=a*t,h=a*(i/2),d=r*(i/2),u=r*(t+n),g=a*(t+n);return{bottomLeft:{x:l-h+o,y:s-(c+d)},bottomRight:{x:l+h+o,y:s-(c-d)},topRight:{x:u+h+o,y:s-(g-d)},topLeft:{x:u-h+o,y:s-(g+d)}}}class ZS extends t.Component{static template="o-spreadsheet-GaugeChartComponent";canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}setup(){t.useEffect((()=>BS(this.canvas.el,this.runtime)),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}}function jS(e){return 8===(e=Bt(e).replace("#","")).length?e.slice(6)+e.slice(0,6):e}ZS.props={figure:Object};const YS={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1};function XS(e,t,o){const s=document.createElement("div");s.style.width=`${t.width}px`,s.style.height=`${t.height}px`;const i=document.createElement("canvas");if(s.append(i),i.setAttribute("width",t.width.toString()),i.setAttribute("height",t.height.toString()),document.body.append(s),"chartJsConfig"in e){const t=Be(e.chartJsConfig);t.plugins=[KS];const o=new window.Chart(i,t),n=o.toBase64Image();return o.destroy(),s.remove(),n}if("scorecard"===o){Sh(xh(t,e),i);const o=i.toDataURL();return s.remove(),o}if("gauge"===o){BS(i,e);const t=i.toDataURL();return s.remove(),t}}const KS={id:"customCanvasBackgroundColor",beforeDraw:e=>{const{ctx:t}=e;t.save(),t.globalCompositeOperation="destination-over",t.fillStyle="#ffffff",t.fillRect(0,0,e.width,e.height),t.restore()}};class JS{xmlString;constructor(e){this.xmlString=e}toString(){return this.xmlString}}const QS=["areaChart","area3DChart","lineChart","line3DChart","stockChart","radarChart","scatterChart","pieChart","pie3DChart","doughnutChart","barChart","bar3DChart","ofPieChart","surfaceChart","surface3DChart","bubbleChart","comboChart","radarChart"],ey="000000",ty={arrow:"3Arrows",smiley:"3Symbols",dot:"3TrafficLights1"},oy={styleSheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",sst:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",Relationships:"http://schemas.openxmlformats.org/package/2006/relationships",Types:"http://schemas.openxmlformats.org/package/2006/content-types",worksheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",workbook:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",drawing:"http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing",table:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",revision:"http://schemas.microsoft.com/office/spreadsheetml/2014/revision",revision3:"http://schemas.microsoft.com/office/spreadsheetml/2016/revision3",markupCompatibility:"http://schemas.openxmlformats.org/markup-compatibility/2006"},sy="http://schemas.openxmlformats.org/drawingml/2006/main",iy="http://schemas.openxmlformats.org/drawingml/2006/chart",ny={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",sharedStrings:"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml",styles:"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml",drawing:"application/vnd.openxmlformats-officedocument.drawing+xml",chart:"application/vnd.openxmlformats-officedocument.drawingml.chart+xml",themes:"application/vnd.openxmlformats-officedocument.theme+xml",table:"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml",pivot:"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml",externalLink:"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml"},ry={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",sharedStrings:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings",styles:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles",drawing:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing",chart:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart",theme:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme",table:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/table",hyperlink:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",image:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image"},ay="http://schemas.openxmlformats.org/officeDocument/2006/relationships",ly=.75,cy=.143,hy=8.43,dy=12.75,uy=30,gy=100,py=164,my={FLOOR:[{type:"NUMBER",value:1}],CEILING:[{type:"NUMBER",value:1}],ROUND:[{type:"NUMBER",value:0}],ROUNDUP:[{type:"NUMBER",value:0}],ROUNDDOWN:[{type:"NUMBER",value:0}]},fy=["ACOT","ACOTH","AGGREGATE","ARABIC","BASE","BETA.DIST","BETA.INV","BINOM.DIST","BINOM.DIST.RANGE","BINOM.INV","BITAND","BITLSHIFT","BITOR","BITRSHIFT","BITXOR","BYCOL","BYROW","CEILING.MATH","CEILING.PRECISE","CHISQ.DIST","CHISQ.DIST.RT","CHISQ.INV","CHISQ.INV.RT","CHISQ.TEST","CHOOSECOLS","CHOOSEROWS","COMBINA","CONCAT","CONFIDENCE.NORM","CONFIDENCE.T","COT","COTH","COVARIANCE.P","COVARIANCE.S","CSC","CSCH","DAYS","DECIMAL","DROP","ERF.PRECISE","ERFC.PRECISE","EXPAND","EXPON.DIST","F.DIST","F.DIST.RT","F.INV","F.INV.RT","F.TEST","FIELDVALUE","FILTERXML","FLOOR.MATH","FLOOR.PRECISE","FORECAST.ETS","FORECAST.ETS.CONFINT","FORECAST.ETS.SEASONALITY","FORECAST.ETS.STAT","FORECAST.LINEAR","FORMULATEXT","GAMMA","GAMMA.DIST","GAMMA.INV","GAMMALN.PRECISE","GAUSS","HSTACK","HYPGEOM.DIST","IFNA","IFS","IMCOSH","IMCOT","IMCSC","IMCSCH","IMSEC","IMSECH","IMSINH","IMTAN","ISFORMULA","ISOMITTED","ISOWEEKNUM","LAMBDA","LET","LOGNORM.DIST","LOGNORM.INV","MAKEARRAY","MAP","MAXIFS","MINIFS","MODE.MULT","MODE.SNGL","MUNIT","NEGBINOM.DIST","NORM.DIST","NORM.INV","NORM.S.DIST","NORM.S.INV","NUMBERVALUE","PDURATION","PERCENTILE.EXC","PERCENTILE.INC","PERCENTRANK.EXC","PERCENTRANK.INC","PERMUTATIONA","PHI","POISSON.DIST","PQSOURCE","PYTHON_STR","PYTHON_TYPE","PYTHON_TYPENAME","QUARTILE.EXC","QUARTILE.INC","QUERYSTRING","RANDARRAY","RANK.AVG","RANK.EQ","REDUCE","RRI","SCAN","SEC","SECH","SEQUENCE","SHEET","SHEETS","SKEW.P","SORTBY","STDEV.P","STDEV.S","SWITCH","T.DIST","T.DIST.2T","T.DIST.RT","T.INV","T.INV.2T","T.TEST","TAKE","TEXTAFTER","TEXTBEFORE","TEXTJOIN","TEXTSPLIT","TOCOL","TOROW","UNICHAR","UNICODE","UNIQUE","VAR.P","VAR.S","VSTACK","WEBSERVICE","WEIBULL.DIST","WRAPCOLS","WRAPROWS","XLOOKUP","XOR","Z.TEST"],vy="[Content_Types].xml",by=new n;Mc`
|
|
12
|
+
`;class hh extends t.Component{static template="o-spreadsheet-ChartJsComponent";static props={figure:Object};canvas=t.useRef("graphContainer");chart;currentRuntime;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){const e=this.env.model.getters.getChartRuntime(this.props.figure.id);if(!("chartJsConfig"in e))throw new Error("Unsupported chart runtime");return e}setup(){t.onMounted((()=>{const e=this.chartRuntime;this.currentRuntime=e,this.createChart(Be(e.chartJsConfig))})),t.onWillUnmount((()=>this.chart?.destroy())),t.useEffect((()=>{const e=this.chartRuntime;e!==this.currentRuntime&&(e.chartJsConfig.type!==this.currentRuntime.chartJsConfig.type?(this.chart?.destroy(),this.createChart(Be(e.chartJsConfig))):this.updateChartJs(Be(e)),this.currentRuntime=e)}))}createChart(e){const t=this.canvas.el.getContext("2d");this.chart=new window.Chart(t,e)}updateChartJs(e){const t=e.chartJsConfig;t.data&&t.data.datasets?(this.chart.data=t.data,t.options?.plugins?.title&&(this.chart.config.options.plugins.title=t.options.plugins.title)):this.chart.data.datasets=[],this.chart.config.options=t.options,this.chart.update()}}class dh{sheetId;title;getters;constructor(e,t,o){this.title=e.title,this.sheetId=t,this.getters=o}static validateChartDefinition(e,t){throw new Error("This method should be implemented by sub class")}static transformDefinition(e,t){throw new Error("This method should be implemented by sub class")}static getDefinitionFromContextCreation(e){throw new Error("This method should be implemented by sub class")}}function uh(e,t,o,s,i){if("text"===t||"progress"===t||e?.type!==ni.number||o?.type!==ni.number)return;const n=o.value-e.value;return n>0?s:n<0?i:void 0}function gh(e,t,o){if("text"===o||e?.type!==ni.number||t?.type!==ni.number)return"neutral";const s=t.value-e.value;return s>0?"up":s<0?"down":"neutral"}function ph(e){return e.keyValue&&!Uo.test(e.keyValue)?"InvalidScorecardKeyValue":"Success"}function mh(e){return e.baseline&&!Uo.test(e.baseline)?"InvalidScorecardBaseline":"Success"}const fh=new window.Path2D("M8.6 4.8a.5.5 0 0 1 0 .75l-3.9 3.9a.5 .5 0 0 1 -.75 0l-3.8 -3.9a.5 .5 0 0 1 0 -.75l.4-.4a.5.5 0 0 1 .75 0l2.3 2.4v-5.7c0-.25.25-.5.5-.5h.6c.25 0 .5.25.5.5v5.8l2.3 -2.4a.5.5 0 0 1 .75 0z"),vh=new window.Path2D("M8.7 5.5a.5.5 0 0 0 0-.75l-3.8-4a.5.5 0 0 0-.75 0l-3.8 4a.5.5 0 0 0 0 .75l.4.4a.5.5 0 0 0 .75 0l2.3-2.4v5.8c0 .25.25.5.5.5h.6c.25 0 .5-.25.5-.5v-5.8l2.2 2.4a.5.5 0 0 0 .75 0z");let bh=class e extends dh{keyValue;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type="scorecard";constructor(e,t,o){super(e,t,o),this.keyValue=Vr(o,t,e.keyValue),this.baseline=Vr(o,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??Ee,this.baselineColorDown=e.baselineColorDown??Ie,this.humanize=e.humanize??!1}static validateChartDefinition(e,t){return e.checkValidations(t,ph,mh)}static getDefinitionFromContextCreation(e){return{background:e.background,type:"scorecard",keyValue:e.range?e.range[0].dataRange:void 0,title:e.title||{text:""},baselineMode:xe,baselineColorUp:Ee,baselineColorDown:Ie,baseline:e.auxiliaryRange||""}}static transformDefinition(e,t){let o,s;return e.baseline&&(o=gc(jo(e.baseline),t)),e.keyValue&&(s=gc(jo(e.keyValue),t)),{...e,baseline:o?Jo(o):void 0,keyValue:s?Jo(s):void 0}}duplicateInDuplicatedSheet(t){const o=Uc(this.sheetId,t,this.baseline),s=Uc(this.sheetId,t,this.keyValue),i=this.getDefinitionWithSpecificRanges(o,s,t);return new e(i,t,this.getters)}copyInSheetId(t){const o=this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue,t);return new e(o,t,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue)}getContextCreation(){return{...this,range:this.keyValue?[{dataRange:this.getters.getRangeString(this.keyValue,this.sheetId)}]:void 0,auxiliaryRange:this.baseline?this.getters.getRangeString(this.baseline,this.sheetId):void 0}}getDefinitionWithSpecificRanges(e,t,o){return{baselineColorDown:this.baselineColorDown,baselineColorUp:this.baselineColorUp,baselineMode:this.baselineMode,title:this.title,type:"scorecard",background:this.background,baseline:e?this.getters.getRangeString(e,o||this.sheetId):void 0,baselineDescr:this.baselineDescr,keyValue:t?this.getters.getRangeString(t,o||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges(t){const o=Bc(this.baseline,t),s=Bc(this.keyValue,t);if(this.baseline===o&&this.keyValue===s)return this;const i=this.getDefinitionWithSpecificRanges(o,s);return new e(i,this.sheetId,this.getters)}};function Sh(e,t){const o=t.getContext("2d");t.width=e.canvas.width;const s=t.width-2*Z;if(t.height=e.canvas.height,o.fillStyle=e.canvas.backgroundColor,o.fillRect(0,0,e.canvas.width,e.canvas.height),e.title){o.font=e.title.style.font,o.fillStyle=e.title.style.color;const t=o.textBaseline;o.textBaseline="middle",o.fillText(na(o,e.title.text,s-e.title.position.x),e.title.position.x,e.title.position.y),o.textBaseline=t}if(e.baseline&&(o.font=e.baseline.style.font,o.fillStyle=e.baseline.style.color,ra(o,e.baseline.text,e.baseline.position,e.baseline.style.underline,e.baseline.style.strikethrough)),e.baselineArrow&&e.baselineArrow.style.size>0){o.save(),o.fillStyle=e.baselineArrow.style.color,o.translate(e.baselineArrow.position.x,e.baselineArrow.position.y);const t=e.baselineArrow.style.size/10;switch(o.scale(t,t),e.baselineArrow.direction){case"down":o.fill(fh);break;case"up":o.fill(vh)}o.restore()}if(e.baselineDescr){const t=e.baselineDescr[0];o.font=t.style.font,o.fillStyle=t.style.color;for(const t of e.baselineDescr)o.fillText(na(o,t.text,s-t.position.x),t.position.x,t.position.y)}if(e.key&&(o.font=e.key.style.font,o.fillStyle=e.key.style.color,ra(o,na(o,e.key.text,s-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.progressBar){if(o.fillStyle=e.progressBar.style.backgroundColor,o.beginPath(),o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width,e.progressBar.dimension.height,e.progressBar.dimension.height/2),o.fill(),o.fillStyle=e.progressBar.style.color,o.beginPath(),e.progressBar.value>0)o.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width*Math.max(0,Math.min(1,e.progressBar.value)),e.progressBar.dimension.height,e.progressBar.dimension.height/2);else{const t=e.progressBar.dimension.width*Math.max(0,Math.min(1,-e.progressBar.value));o.roundRect(e.progressBar.position.x+e.progressBar.dimension.width-t,e.progressBar.position.y,t,e.progressBar.dimension.height,e.progressBar.dimension.height/2)}o.fill()}}function yh(e,t){let o,s="";const i=t.getLocale();if(e.keyValue){const n={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};o=t.getEvaluatedCell(n),s=function(e,t,o){return e?t?vr(e,o):e.formattedValue??String(e.value??""):""}(o,e.humanize??!1,i)}let n;const r=e.baseline;if(r){const e={sheetId:r.sheetId,col:r.zone.left,row:r.zone.top};n=t.getEvaluatedCell(e)}const{background:a,fontColor:l}=t.getStyleOfSingleCellChart(e.background,e.keyValue),c=function(e,t,o,s,i){if(!e)return"";if("text"===o||t?.type!==ni.number||e.type!==ni.number)return s?vr(e,i):e.formattedValue;let{value:n,format:r}=e;return"progress"===o?(n=t.value/n,r="0.0%"):(n=Math.abs(t.value-n),"percentage"===o&&0!==n&&(n/=e.value),"percentage"===o&&(r="0.0%"),r||(n=Math.round(100*n)/100)),s?vr({value:n,format:r},i):Jn(n,{format:r,locale:i})}(n,o,e.baselineMode,e.humanize??!1,i),h="progress"===e.baselineMode&&ti(c,i)?Vi(c,i):0;return{title:{...e.title,text:e.title.text?Fo(e.title.text):""},keyValue:s,baselineDisplay:c,baselineArrow:gh(n,o,e.baselineMode),baselineColor:uh(n,e.baselineMode,o,e.baselineColorUp,e.baselineColorDown),baselineDescr:"progress"!==e.baselineMode&&e.baselineDescr?Fo(e.baselineDescr):"",fontColor:l,background:a,baselineStyle:"percentage"!==e.baselineMode&&"progress"!==e.baselineMode&&r?t.getCellStyle({sheetId:r.sheetId,col:r.zone.left,row:r.zone.top}):void 0,keyValueStyle:e.keyValue?t.getCellStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,progressBar:"progress"===e.baselineMode?{value:h,color:h>0?e.baselineColorUp:e.baselineColorDown}:void 0}}const Ch=10,wh=.05;function xh({width:e,height:t},o){return new Eh({width:e,height:t},o).computeDesign()}class Eh{runtime;context;width;height;constructor({width:e,height:t},o){this.runtime=o;const s=document.createElement("canvas");this.width=s.width=e,this.height=s.height=t,this.context=s.getContext("2d")}computeDesign(){const e={canvas:{width:this.width,height:this.height,backgroundColor:this.backgroundColor}},t=this.getTextStyles();let o=0;if(this.title){let s,i;switch(({height:o,width:i}=this.getFullTextDimensions(this.title,t.title.font)),this.runtime.title.align){case"center":s=(this.width-i)/2;break;case"right":s=this.width-i-Ch;break;default:s=Ch}e.title={text:this.title,style:t.title,position:{x:s,y:Ch+o/2}}}const s=t.baselineArrow?.size??0;let{height:i,width:n}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);const r=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;e.baseline={text:this.baseline,style:t.baselineValue,position:{x:(this.width-n-r+s)/2,y:this.keyValue?this.height*(1-wh*(this.runtime.progressBar?1:2)):this.height-(this.height-o-i)/2-Ch}};const a=s+20;if(e.baseline.position.x<a&&(e.baseline.position.x=a),t.baselineArrow&&!this.runtime.progressBar&&(e.baselineArrow={direction:this.baselineArrow,style:t.baselineArrow,position:{x:e.baseline.position.x-s,y:e.baseline.position.y-(i+s)/2}}),this.baselineDescr){const o={x:e.baseline.position.x+n,y:e.baseline.position.y};e.baselineDescr=[{text:this.baselineDescr,style:t.baselineDescr,position:o}]}let l=0;this.runtime.progressBar&&(l=.05*this.height,e.progressBar={position:{x:20,y:.9*this.height-i-l},dimension:{height:l,width:this.width-40},value:this.runtime.progressBar.value,style:{color:this.runtime.progressBar.color,backgroundColor:this.secondaryFontColor}});const{width:c,height:h}=this.getFullTextDimensions(this.keyValue,t.keyValue.font);return this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(Ch,(this.width-c)/2),y:.4*this.height+5+(o+h/2)/2}}),e}get title(){return this.runtime.title.text??""}get keyValue(){return this.runtime.keyValue}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return function(e,t){const o=e||"";return t&&o?" "+o:o}(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return jc(this.backgroundColor)}getTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.actualBoundingBoxAscent+o.actualBoundingBoxDescent}}getFullTextDimensions(e,t){this.context.font=t;const o=this.context.measureText(e);return{width:o.width,height:o.fontBoundingBoxAscent+o.fontBoundingBoxDescent}}getTextStyles(){let e=16;const t=Math.floor(.9*e);return this.runtime.progressBar&&(e/=1.5),{title:{font:qr(this.runtime.title.fontSize??14,this.runtime.title.bold,this.runtime.title.italic),color:this.runtime.title.color??this.secondaryFontColor},keyValue:{color:this.runtime.keyValueStyle?.textColor||this.runtime.fontColor,font:qr(32,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},baselineValue:{font:qr(e,this.runtime.baselineStyle?.bold,this.runtime.baselineStyle?.italic),strikethrough:this.runtime.baselineStyle?.strikethrough,underline:this.runtime.baselineStyle?.underline,color:this.runtime.baselineStyle?.textColor||this.runtime.baselineColor||this.secondaryFontColor},baselineDescr:{font:qr(t),color:this.secondaryFontColor},baselineArrow:"neutral"===this.baselineArrow||this.runtime.progressBar?void 0:{size:this.keyValue?.8*e:0,color:this.runtime.baselineColor||this.secondaryFontColor}}}}class Ih extends t.Component{static template="o-spreadsheet-ScorecardChart";static props={figure:Object};canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}get title(){const e=this.env.model.getters.getChartDefinition(this.props.figure.id).title.text??"";return Fo(e)}setup(){t.useEffect(this.createChart.bind(this),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}createChart(){const e=this.canvas.el;Sh(xh(e.getBoundingClientRect(),this.runtime),e)}}const Rh=new n;function Th(e,t,o,s){const i=[];e=e.toLowerCase();for(const n of e){const e=t.toLocaleLowerCase().indexOf(n);-1!==e&&(i.push({value:t.slice(0,e),color:""},{value:t[e],color:o,class:s}),t=t.slice(e+1))}return i.push({value:t}),i.filter((e=>e.value))}Rh.add("dataValidation",{getProposals(e,t){if(t.startsWith("="))return[];if(!this.composer.currentEditedCell)return[];const o=this.composer.currentEditedCell,s=this.getters.getValidationRuleForCell(o);if(!s||"isValueInList"!==s.criterion.type&&"isValueInRange"!==s.criterion.type)return[];let i;if("isValueInList"===s.criterion.type)i=s.criterion.values;else{const e=this.getters.getRangeFromSheetXC(o.sheetId,s.criterion.values[0]);i=Array.from(new Set(this.getters.getRangeValues(e).filter(lt).map((e=>e.toString())).filter((e=>""!==e))))}return i.map((e=>({text:e})))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}});const Ah=/(.*?)\((.*?)\)(.*)/,_h=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META"];function Dh(e,t=""){return function(e,t){let o=e.match(Ah),s=o[1].trim();if(!s)throw new Error(`Function argument definition is missing a name: '${e}'.`);let i,n=[],r=!1,a=!1;for(let e of o[2].split(",")){const t=e.trim().toUpperCase();let o=_h.find((e=>t===e));o?n.push(o):"RANGE<ANY>"===t?n.push("RANGE"):"OPTIONAL"===t?r=!0:"REPEATING"===t?a=!0:t.startsWith("DEFAULT=")&&(i=e.trim().slice(8))}const l={name:s,description:t,type:n};(n.includes("ANY")||n.includes("RANGE"))&&(l.acceptErrors=!0);r&&(l.optional=!0);a&&(l.repeating=!0);void 0!==i&&(l.default=!0,l.defaultValue=i);n.some((e=>e.startsWith("RANGE")))&&(l.acceptMatrix=!0);n.every((e=>e.startsWith("RANGE")))&&(l.acceptMatrixOnly=!0);return l}(e,t)}function Oh(e){let t=0,o=0,s=0;for(let i of e.args)t++,i.optional||i.repeating||i.default||o++,i.repeating&&s++;const i=e;return i.minArgRequired=o,i.maxArgPossible=s?1/0:t,i.nbrArgRepeating=s,i.getArgToFocus=function(e,t){if(!t)return e=>e;if(1===t)return t=>Math.min(t,e);const o=e-t;return e=>{if(e<=o)return e;return o+((e-o)%t||t)}}(t,s),i.hidden=e.hidden||!1,i}function Fh(e,t){Pi((()=>1===t.length||1===t[0].length),e)}function Mh(e,...t){if(t.every(Ci)){const o=t[0].length,s=t[0][0].length;for(const i of t)Pi((()=>i.length===o&&i[0].length===s),e)}else if(t.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length))))throw new Ti(e)}function Ph(e,t){Pi((()=>t>0),e)}function Nh(e,t){Pi((()=>t.length===t[0].length),e)}const kh={description:Fo("Returns a result array constrained to a specific width and height."),args:[Dh("input_range (any, range<any>)",Fo("The range to constrain.")),Dh("rows (number)",Fo("The number of rows in the constrained array.")),Dh("columns (number)",Fo("The number of columns in the constrained array."))],compute:function(e,t,o){const s=bn(e),i=zi(t?.value,this.locale),n=zi(o?.value,this.locale);Ph(Fo("The rows argument (%s) must be strictly positive.",i.toString()),i),Ph(Fo("The columns argument (%s) must be strictly positive.",i.toString()),n);const r=Math.min(i,s[0].length);return rn(Math.min(n,s.length),r,((e,t)=>s[e][t]))},isExported:!1},Lh={description:Fo("Creates a new array from the selected columns in the existing range."),args:[Dh("array (any, range<any>)",Fo("The array that contains the columns to be returned.")),Dh("col_num (number, range<number>)",Fo("The first column index of the columns to be returned.")),Dh("col_num2 (number, range<number>, repeating)",Fo("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=bn(e),s=Sn(t,(e=>zi(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));Pi((()=>0===i.length),Fo("The columns arguments must be between -%s and %s (got %s), excluding 0.",o.length.toString(),o.length.toString(),i.join(",")));const n=Array(s.length);for(let e=0;e<s.length;e++)s[e]>0?n[e]=o[s[e]-1]:n[e]=o[o.length+s[e]];return n},isExported:!0},Vh={description:Fo("Creates a new array from the selected rows in the existing range."),args:[Dh("array (any, range<any>)",Fo("The array that contains the rows to be returned.")),Dh("row_num (number, range<number>)",Fo("The first row index of the rows to be returned.")),Dh("row_num2 (number, range<number>, repeating)",Fo("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=bn(e),s=Sn(t,(e=>zi(e?.value,this.locale))),i=o.length,n=s.filter((e=>0===e||o[0].length<Math.abs(e)));return Pi((()=>0===n.length),Fo("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),n.join(","))),rn(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},Hh={description:Fo("Expands or pads an array to specified row and column dimensions."),args:[Dh("array (any, range<any>)",Fo("The array to expand.")),Dh("rows (number)",Fo("The number of rows in the expanded array. If missing, rows will not be expanded.")),Dh("columns (number, optional)",Fo("The number of columns in the expanded array. If missing, columns will not be expanded.")),Dh("pad_with (any, default=0)",Fo("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=bn(e),n=zi(t?.value,this.locale),r=void 0!==o?zi(o.value,this.locale):i.length;return Pi((()=>n>=i[0].length),Fo("The rows arguments (%s) must be greater or equal than the number of rows of the array.",n.toString())),Pi((()=>r>=i.length),Fo("The columns arguments (%s) must be greater or equal than the number of columns of the array.",r.toString())),rn(r,n,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},Uh={description:Fo("Flattens all the values from one or more ranges into a single column."),args:[Dh("range (any, range<any>)",Fo("The first range to flatten.")),Dh("range2 (any, range<any>, repeating)",Fo("Additional ranges to flatten."))],compute:function(...e){return[Sn(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},Bh={description:Fo("Calculates the frequency distribution of a range."),args:[Dh("data (range<number>)",Fo("The array of ranges containing the values to be counted.")),Dh("classes (number, range<number>)",Fo("The range containing the set of classes."))],compute:function(e,t){const o=Sn([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=Sn([t],(e=>e.value)).filter((e=>"number"==typeof e)),i=s.map(((e,t)=>({initialIndex:t,value:e,count:0}))).sort(((e,t)=>e.value-t.value));i.push({initialIndex:i.length,value:1/0,count:0});const n=o.sort(((e,t)=>e-t));let r=0;for(const e of n){for(;e>i[r].value&&r<i.length-1;)r++;i[r].count++}return[i.sort(((e,t)=>e.initialIndex-t.initialIndex)).map((e=>e.count))]},isExported:!0},zh={description:Fo("Appends ranges horizontally and in sequence to return a larger array."),args:[Dh("range1 (any, range<any>)",Fo("The first range to be appended.")),Dh("range2 (any, range<any>, repeating)",Fo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>e?.[0]?.length??0))),o=[];for(const s of e){const e=bn(s);for(let s=0;s<e.length;s++){const i=Array(t).fill({value:null});for(let t=0;t<e[s].length;t++)i[t]=e[s][t];o.push(i)}}return o},isExported:!0},$h={description:Fo("Returns the matrix determinant of a square matrix."),args:[Dh("square_matrix (number, range<number>)",Fo("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=Ui(e,"square_matrix");return Nh(Fo("The argument square_matrix must have the same number of columns and rows."),t),Ya(t).determinant},isExported:!0},Wh={description:Fo("Returns the multiplicative inverse of a square matrix."),args:[Dh("square_matrix (number, range<number>)",Fo("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=Ui(e,"square_matrix");Nh(Fo("The argument square_matrix must have the same number of columns and rows."),t);const{inverted:o}=Ya(t);return o||new Ti(Fo("The matrix is not invertible."))},isExported:!0},Gh={description:Fo("Calculates the matrix product of two matrices."),args:[Dh("matrix1 (number, range<number>)",Fo("The first matrix in the matrix multiplication operation.")),Dh("matrix2 (number, range<number>)",Fo("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=Ui(e,"matrix1"),s=Ui(t,"matrix2");return Pi((()=>o.length===s[0].length),Fo("In [[FUNCTION_NAME]], the number of columns of the first matrix (%s) must be equal to the number of rows of the second matrix (%s).",o.length.toString(),s[0].length.toString())),Ka(o,s)},isExported:!0},qh={description:Fo("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[Dh("range1 (number, range<number>)",Fo("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),Dh("range2 (number, range<number>, repeating)",Fo("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){Mh(Fo("All the ranges must have the same dimensions."),...e);const t=e.map(bn);let o=0;for(let e=0;e<t[0].length;e++)for(let s=0;s<t[0][e].length;s++){if(!t.every((t=>"number"==typeof t[e][s].value)))continue;let i=1;for(const o of t)i*=Vi(o[e][s],this.locale);o+=i}return o},isExported:!0};function Zh(e,t,o){Mh("The arguments array_x and array_y must have the same dimensions.",e,t);const s=bn(e),i=bn(t);let n=!1,r=0;for(const e in s)for(const t in s[e]){const a=s[e][t].value,l=i[e][t].value;"number"==typeof a&&"number"==typeof l&&(n=!0,r+=o(a,l))}return n?r:new Ti(Fo("The arguments array_x and array_y must contain at least one pair of numbers."))}const jh={description:Fo("Calculates the sum of the difference of the squares of the values in two array."),args:[Dh("array_x (number, range<number>)",Fo("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),Dh("array_y (number, range<number>)",Fo("The array or range of values whose squares will be subtracted from the squares of corresponding entries in array_x and added together."))],compute:function(e,t){return Zh(e,t,((e,t)=>e**2-t**2))},isExported:!0},Yh={description:Fo("Calculates the sum of the sum of the squares of the values in two array."),args:[Dh("array_x (number, range<number>)",Fo("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),Dh("array_y (number, range<number>)",Fo("The array or range of values whose squares will be added to the squares of corresponding entries in array_x and added together."))],compute:function(e,t){return Zh(e,t,((e,t)=>e**2+t**2))},isExported:!0},Xh={description:Fo("Calculates the sum of squares of the differences of values in two array."),args:[Dh("array_x (number, range<number>)",Fo("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),Dh("array_y (number, range<number>)",Fo("The array or range of values that will be subtracted from corresponding entries in array_x, the result squared, and all such results added together."))],compute:function(e,t){return Zh(e,t,((e,t)=>(e-t)**2))},isExported:!0},Kh=!1,Jh=[Dh("array (any, range<any>)",Fo("The array which will be transformed.")),Dh("ignore (number, default=0)",Fo("The control to ignore blanks and errors. 0 (default) is to keep all values, 1 is to ignore blanks, 2 is to ignore errors, and 3 is to ignore blanks and errors.")),Dh("scan_by_column (number, default=false)",Fo("Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row."))];function Qh(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!ki(e.value);if(3===t)return e=>null!==e.value&&!ki(e.value);throw new Ti(Fo("Argument ignore must be between 0 and 3"))}const ed={description:Fo("Transforms a range of cells into a single column."),args:Jh,compute:function(e,t={value:0},o={value:Kh}){const s=bn(e),i=Vi(t.value,this.locale),n=(Yi(o.value)?s:ln(s)).flat().filter(Qh(i));return 0===n.length?new Di(Fo("No results for the given arguments of TOCOL.")):[n]},isExported:!0},td={description:Fo("Transforms a range of cells into a single row."),args:Jh,compute:function(e,t={value:0},o={value:Kh}){const s=bn(e),i=Vi(t.value,this.locale),n=(Yi(o.value)?s:ln(s)).flat().filter(Qh(i)).map((e=>[e]));return 0===n.length||0===n[0].length?new Di(Fo("No results for the given arguments of TOROW.")):n},isExported:!0},od={description:Fo("Transposes the rows and columns of a range."),args:[Dh("range (any, range<any>)",Fo("The range to be transposed."))],compute:function(e){const t=bn(e);return rn(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},sd={description:Fo("Appends ranges vertically and in sequence to return a larger array."),args:[Dh("range1 (any, range<any>)",Fo("The first range to be appended.")),Dh("range2 (any, range<any>, repeating)",Fo("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>bn(e).length))),o=e.reduce(((e,t)=>e+bn(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=bn(t);for(let t=0;t<e.length;t++)for(let o=0;o<e[t].length;o++)s[t][i+o]=e[t][o];i+=e[0].length}return s},isExported:!0},id={description:Fo("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[Dh("range (any, range<any>)",Fo("The range to wrap.")),Dh("wrap_count (number)",Fo("The maximum number of cells for each column, rounded down to the nearest whole number.")),Dh("pad_with (any, default=0)",Fo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=bn(e),i=zi(t?.value,this.locale);Fh(Fo("Argument range must be a single row or column."),s);const n=s.flat();return rn(Math.ceil(n.length/i),i,((e,t)=>{const s=e*i+t;return s<n.length?n[s]:o}))},isExported:!0},nd={description:Fo("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[Dh("range (any, range<any>)",Fo("The range to wrap.")),Dh("wrap_count (number)",Fo("The maximum number of cells for each row, rounded down to the nearest whole number.")),Dh("pad_with (any, default=0)",Fo("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=bn(e),i=zi(t?.value,this.locale);Fh(Fo("Argument range must be a single row or column."),s);const n=s.flat(),r=Math.ceil(n.length/i);return rn(i,r,((e,t)=>{const s=t*i+e;return s<n.length?n[s]:o}))},isExported:!0};var rd=Object.freeze({__proto__:null,ARRAY_CONSTRAIN:kh,CHOOSECOLS:Lh,CHOOSEROWS:Vh,EXPAND:Hh,FLATTEN:Uh,FREQUENCY:Bh,HSTACK:zh,MDETERM:$h,MINVERSE:Wh,MMULT:Gh,SUMPRODUCT:qh,SUMX2MY2:jh,SUMX2PY2:Yh,SUMXMY2:Xh,TOCOL:ed,TOROW:td,TRANSPOSE:od,VSTACK:sd,WRAPCOLS:id,WRAPROWS:nd});const ad={description:Fo("Apply a large number format"),args:[Dh("value (number)",Fo("The number.")),Dh("unit (string, optional)",Fo("The formatting unit. Use 'k', 'm', or 'b' to force the unit"))],compute:function(e,t){return{value:Vi(e,this.locale),format:br(e,t,this.locale)}}};var ld=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:ad});const cd=/^-?[a-z0-9]+$/i,hd={description:Fo("Absolute value of a number."),args:[Dh("value (number)",Fo("The number of which to return the absolute value."))],compute:function(e){return Math.abs(Vi(e,this.locale))},isExported:!0},dd={description:Fo("Inverse cosine of a value, in radians."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)<=1),Fo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.acos(t)},isExported:!0},ud={description:Fo("Inverse hyperbolic cosine of a number."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>t>=1),Fo("The value (%s) must be greater than or equal to 1.",t.toString())),Math.acosh(t)},isExported:!0},gd={description:Fo("Inverse cotangent of a value."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=Vi(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},pd={description:Fo("Inverse hyperbolic cotangent of a value."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)>1),Fo("The value (%s) cannot be between -1 and 1 inclusive.",t.toString())),Math.log((t+1)/(t-1))/2},isExported:!0},md={description:Fo("Inverse sine of a value, in radians."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)<=1),Fo("The value (%s) must be between -1 and 1 inclusive.",t.toString())),Math.asin(t)},isExported:!0},fd={description:Fo("Inverse hyperbolic sine of a number."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(Vi(e,this.locale))},isExported:!0},vd={description:Fo("Inverse tangent of a value, in radians."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(Vi(e,this.locale))},isExported:!0},bd={description:Fo("Angle from the X axis to a point (x,y), in radians."),args:[Dh("x (number)",Fo("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),Dh("y (number)",Fo("The y coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis."))],compute:function(e,t){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>0!==o||0!==s),Fo("Function [[FUNCTION_NAME]] caused a divide by zero error."),Ii.DivisionByZero),Math.atan2(s,o)},isExported:!0},Sd={description:Fo("Inverse hyperbolic tangent of a number."),args:[Dh("value (number)",Fo("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>Math.abs(t)<1),Fo("The value (%s) must be between -1 and 1 exclusive.",t.toString())),Math.atanh(t)},isExported:!0},yd={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("value (number)",Fo("The value to round up to the nearest integer multiple of factor.")),Dh("factor (number, default=1)",Fo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>s>=0||o<=0),Fo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function Cd(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.ceil(e/t)*t:0===o?-Math.floor(Math.abs(e)/t)*t:-Math.ceil(Math.abs(e)/t)*t)}const wd={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round up to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Dh("mode (number, default=0)",Fo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded towards zero. Otherwise, it is rounded away from zero."))],compute:function(e,t={value:1},o={value:0}){const s=Vi(t,this.locale);return{value:Cd(Vi(e,this.locale),s,Vi(o,this.locale)),format:e?.format}},isExported:!0},xd={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round up to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Vi(t,this.locale);return{value:Cd(Vi(e,this.locale),o),format:e?.format}},isExported:!0},Ed={description:Fo("Cosine of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(Vi(e,this.locale))},isExported:!0},Id={description:Fo("Hyperbolic cosine of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(Vi(e,this.locale))},isExported:!0},Rd={description:Fo("Cotangent of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the cotangent of, in radians."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.tan(t)},isExported:!0},Td={description:Fo("Hyperbolic cotangent of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.tanh(t)},isExported:!0},Ad={description:Fo("Number of empty values."),args:[Dh("value1 (any, range)",Fo("The first value or range in which to count the number of blanks.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return on(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},_d={description:Fo("A conditional count across a range."),args:[Dh("range (range)",Fo("The range that is tested against criterion.")),Dh("criterion (string)",Fo("The pattern or test to apply to range."))],compute:function(...e){let t=0;return gn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Dd={description:Fo("Count values depending on multiple criteria."),args:[Dh("criteria_range1 (range)",Fo("The range to check against criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("Additional criteria to check."))],compute:function(...e){let t=0;return gn(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Od={description:Fo("Counts number of unique values in a range."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider for uniqueness.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return Za(e)}},Fd={description:Fo("Counts number of unique values in a range, filtered by a set of criteria."),args:[Dh("range (range)",Fo("The range of cells from which the number of unique values will be counted.")),Dh("criteria_range1 (range)",Fo("The range of cells over which to evaluate criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=new Set;return gn(t,((t,s)=>{const i=e[t]?.[s];yn(i)&&o.add(i.value)}),this.locale),o.size}},Md={description:Fo("Cosecant of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the cosecant of, in radians."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.sin(t)},isExported:!0},Pd={description:Fo("Hyperbolic cosecant of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=Vi(e,this.locale);return Gi(t),1/Math.sinh(t)},isExported:!0},Nd={description:Fo("Converts from another base to decimal."),args:[Dh("value (string)",Fo("The number to convert.")),Dh("base (number)",Fo("The base to convert the value from."))],compute:function(e,t){let o=Vi(t,this.locale);o=Math.floor(o),Pi((()=>2<=o&&o<=36),Fo("The base (%s) must be between 2 and 36 inclusive.",o.toString()));const s=qi(e);if(""===s)return 0;Pi((()=>cd.test(s)),Fo("The value (%s) must be a valid base %s representation.",s,o.toString()));const i=parseInt(s,o);return Pi((()=>!isNaN(i)),Fo("The value (%s) must be a valid base %s representation.",s,o.toString())),i},isExported:!0},kd={description:Fo("Converts an angle value in radians to degrees."),args:[Dh("angle (number)",Fo("The angle to convert from radians to degrees."))],compute:function(e){return 180*Vi(e,this.locale)/Math.PI},isExported:!0},Ld={description:Fo("Euler's number, e (~2.718) raised to a power."),args:[Dh("value (number)",Fo("The exponent to raise e."))],compute:function(e){return Math.exp(Vi(e,this.locale))},isExported:!0},Vd={description:Fo("Rounds number down to nearest multiple of factor."),args:[Dh("value (number)",Fo("The value to round down to the nearest integer multiple of factor.")),Dh("factor (number, default=1)",Fo("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>s>=0||o<=0),Fo("The factor (%s) must be positive when the value (%s) is positive.",s.toString(),o.toString())),{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function Hd(e,t,o=0){return 0===t?0:(t=Math.abs(t),e>=0?Math.floor(e/t)*t:0===o?-Math.ceil(Math.abs(e)/t)*t:-Math.floor(Math.abs(e)/t)*t)}const Ud={description:Fo("Rounds number down to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round down to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Dh("mode (number, default=0)",Fo("If number is negative, specifies the rounding direction. If 0 or blank, it is rounded away from zero. Otherwise, it is rounded towards zero."))],compute:function(e,t={value:1},o={value:0}){const s=Vi(t,this.locale);return{value:Hd(Vi(e,this.locale),s,Vi(o,this.locale)),format:e?.format}},isExported:!0},Bd={description:Fo("Rounds number down to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round down to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=Vi(t,this.locale);return{value:Hd(Vi(e,this.locale),o),format:e?.format}},isExported:!0},zd={description:Fo("Whether the provided value is even."),args:[Dh("value (number)",Fo("The value to be verified as even."))],compute:function(e){const t=Bi(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},$d={description:Fo("Rounds number up to nearest multiple of factor."),args:[Dh("number (number)",Fo("The value to round up to the nearest integer multiple of significance.")),Dh("significance (number, default=1)",Fo("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:Cd(Vi(e,this.locale),Vi(t,this.locale)),format:e?.format}},isExported:!0},Wd={description:Fo("Whether the provided value is even."),args:[Dh("value (number)",Fo("The value to be verified as even."))],compute:function(e){const t=Bi(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},Gd={description:Fo("The logarithm of a number, base e (euler's number)."),args:[Dh("value (number)",Fo("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>t>0),Fo("The value (%s) must be strictly positive.",t.toString())),Math.log(t)},isExported:!0};function qd(e,t){Pi((()=>0!==t),Fo("The divisor must be different from 0."),Ii.DivisionByZero);const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const Zd={description:Fo("Modulo (remainder) operator."),args:[Dh("dividend (number)",Fo("The number to be divided to find the remainder.")),Dh("divisor (number)",Fo("The number to divide by."))],compute:function(e,t){const o=Vi(t,this.locale);return{value:qd(Vi(e,this.locale),o),format:e?.format}},isExported:!0},jd={description:Fo("Returns a n x n unit matrix, where n is the input dimension."),args:[Dh("dimension (number)",Fo("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=zi(e,this.locale);return Ph(Fo("The argument dimension must be positive"),t),ja(t)},isExported:!0},Yd={description:Fo("Rounds a number up to the nearest odd integer."),args:[Dh("value (number)",Fo("The value to round to the next greatest odd number."))],compute:function(e){const t=Vi(e,this.locale);let o=Math.ceil(Math.abs(t));return o=1&o?o:o+1,{value:t<0?-o:o,format:e?.format}},isExported:!0},Xd={description:Fo("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},Kd={description:Fo("A number raised to a power."),args:[Dh("base (number)",Fo("The number to raise to the exponent power.")),Dh("exponent (number)",Fo("The exponent to raise base to."))],compute:function(e,t){const o=Vi(e,this.locale),s=Vi(t,this.locale);return Pi((()=>o>=0||Number.isInteger(s)),Fo("The exponent (%s) must be an integer when the base is negative.",s.toString())),{value:Math.pow(o,s),format:e?.format}},isExported:!0},Jd={description:Fo("Result of multiplying a series of numbers together."),args:[Dh("factor1 (number, range<number>)",Fo("The first number or range to calculate for the product.")),Dh("factor2 (number, range<number>, repeating)",Fo("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(let s of e)if(Ci(s))for(let e of s)for(let s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),ki(e))return s}else void 0!==s&&null!==s.value&&(o*=Bi(s,this.locale),t+=1);return{value:0===t?0:o,format:Ni(e[0])}},isExported:!0},Qd={description:Fo("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},eu={description:Fo("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[Dh("rows (number, default=1)",Fo("The number of rows to be returned.")),Dh("columns (number, default=1)",Fo("The number of columns to be returned.")),Dh("min (number, default=0)",Fo("The minimum number you would like returned.")),Dh("max (number, default=1)",Fo("The maximum number you would like returned.")),Dh("whole_number (number, default=FALSE)",Fo("Return a whole number or a decimal value."))],compute:function(e={value:1},t={value:1},o={value:0},s={value:1},i={value:!1}){const n=zi(t,this.locale),r=zi(e,this.locale),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Yi(i);Ph(Fo("The number of columns (%s) must be positive.",n.toString()),n),Ph(Fo("The number of rows (%s) must be positive.",r.toString()),r),Pi((()=>a<=l),Fo("The maximum (%s) must be greater than or equal to the minimum (%s).",l.toString(),a.toString())),c&&Pi((()=>Number.isInteger(a)&&Number.isInteger(l)),Fo("The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.",l.toString(),a.toString()));const h=Array(n);for(let e=0;e<n;e++){h[e]=Array(r);for(let t=0;t<r;t++)h[e][t]=c?Math.floor(Math.random()*(l-a+1)+a):a+Math.random()*(l-a)}return h},isExported:!0},tu={description:Fo("Random integer between two values, inclusive."),args:[Dh("low (number)",Fo("The low end of the random range.")),Dh("high (number)",Fo("The high end of the random range."))],compute:function(e,t){let o=Vi(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=Vi(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),Pi((()=>o<=s),Fo("The high (%s) must be greater than or equal to the low (%s).",s.toString(),o.toString())),{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},ou={description:Fo("Rounds a number according to standard rules."),args:[Dh("value (number)",Fo("The value to round to places number of places.")),Dh("places (number, default=0)",Fo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Vi(e,this.locale);let s=Vi(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.round(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.round(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},su={description:Fo("Rounds down a number."),args:[Dh("value (number)",Fo("The value to round to places number of places, always rounding down.")),Dh("places (number, default=0)",Fo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Vi(e,this.locale);let s=Vi(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.floor(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.floor(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},iu={description:Fo("Rounds up a number."),args:[Dh("value (number)",Fo("The value to round to places number of places, always rounding up.")),Dh("places (number, default=0)",Fo("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=Vi(e,this.locale);let s=Vi(t,this.locale);const i=Math.abs(o);let n;return 0===s?n=Math.ceil(i):(Number.isInteger(s)||(s=Math.trunc(s)),n=Math.ceil(i*Math.pow(10,s))/Math.pow(10,s)),{value:o>=0?n:-n,format:e?.format}},isExported:!0},nu={description:Fo("Secant of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(Vi(e,this.locale))},isExported:!0},ru={description:Fo("Hyperbolic secant of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(Vi(e,this.locale))},isExported:!0},au={description:Fo("Returns a sequence of numbers."),args:[Dh("rows (number)",Fo("The number of rows to return")),Dh("columns (number, optional, default=1)",Fo("The number of columns to return")),Dh("start (number, optional, default=1)",Fo("The first number in the sequence")),Dh("step (number, optional, default=1)",Fo("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=Vi(o,this.locale),n=Vi(s,this.locale),r=zi(e,this.locale),a=zi(t,this.locale);return Ph(Fo("The number of columns (%s) must be positive.",a),a),Ph(Fo("The number of rows (%s) must be positive.",r),r),rn(a,r,((e,t)=>({value:i+t*a*n+e*n})))},isExported:!0},lu={description:Fo("Sine of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(Vi(e,this.locale))},isExported:!0},cu={description:Fo("Hyperbolic sine of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(Vi(e,this.locale))},isExported:!0},hu={description:Fo("Positive square root of a positive number."),args:[Dh("value (number)",Fo("The number for which to calculate the positive square root."))],compute:function(e){const t=Vi(e,this.locale);return Pi((()=>t>=0),Fo("The value (%s) must be positive or null.",t.toString())),{value:Math.sqrt(t),format:e?.format}},isExported:!0},du={description:Fo("Sum of a series of numbers and/or cells."),args:[Dh("value1 (number, range<number>)",Fo("The first number or range to add together.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:qa(e,this.locale),format:Ni(t)}},isExported:!0},uu={description:Fo("A conditional sum across a range."),args:[Dh("criteria_range (range)",Fo("The range which is tested against criterion.")),Dh("criterion (string)",Fo("The pattern or test to apply to range.")),Dh("sum_range (range, default=criteria_range)",Fo("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return gn([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},gu={description:Fo("Sums a range depending on multiple criteria."),args:[Dh("sum_range (range)",Fo("The range to sum.")),Dh("criteria_range1 (range)",Fo("The range to check against criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges to check.")),Dh("criterion2 (string, repeating)",Fo("Additional criteria to check."))],compute:function(e,...t){let o=0;return gn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},pu={description:Fo("Tangent of an angle provided in radians."),args:[Dh("angle (number)",Fo("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(Vi(e,this.locale))},isExported:!0},mu={description:Fo("Hyperbolic tangent of any real number."),args:[Dh("value (number)",Fo("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(Vi(e,this.locale))},isExported:!0};function fu(e,t){return 0===t?Math.trunc(e):(Number.isInteger(t)||(t=Math.trunc(t)),Math.trunc(e*Math.pow(10,t))/Math.pow(10,t))}const vu={description:Fo("Truncates a number."),args:[Dh("value (number)",Fo("The value to be truncated.")),Dh("places (number, default=0)",Fo("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:fu(Vi(e,this.locale),Vi(t,this.locale)),format:e?.format}},isExported:!0},bu={description:Fo("Rounds a number down to the nearest integer that is less than or equal to it."),args:[Dh("value (number)",Fo("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(Vi(e,this.locale))},isExported:!0};var Su=Object.freeze({__proto__:null,ABS:hd,ACOS:dd,ACOSH:ud,ACOT:gd,ACOTH:pd,ASIN:md,ASINH:fd,ATAN:vd,ATAN2:bd,ATANH:Sd,CEILING:yd,CEILING_MATH:wd,CEILING_PRECISE:xd,COS:Ed,COSH:Id,COT:Rd,COTH:Td,COUNTBLANK:Ad,COUNTIF:_d,COUNTIFS:Dd,COUNTUNIQUE:Od,COUNTUNIQUEIFS:Fd,CSC:Md,CSCH:Pd,DECIMAL:Nd,DEGREES:kd,EXP:Ld,FLOOR:Vd,FLOOR_MATH:Ud,FLOOR_PRECISE:Bd,INT:bu,ISEVEN:zd,ISODD:Wd,ISO_CEILING:$d,LN:Gd,MOD:Zd,MUNIT:jd,ODD:Yd,PI:Xd,POWER:Kd,PRODUCT:Jd,RAND:Qd,RANDARRAY:eu,RANDBETWEEN:tu,ROUND:ou,ROUNDDOWN:su,ROUNDUP:iu,SEC:nu,SECH:ru,SEQUENCE:au,SIN:lu,SINH:cu,SQRT:hu,SUM:du,SUMIF:uu,SUMIFS:gu,TAN:pu,TANH:mu,TRUNC:vu});function yu(e,t){const o=[],s=[];let i=0,n=0;Qi([e],(e=>{o.push(e),i+=1})),Qi([t],(e=>{s.push(e),n+=1})),Pi((()=>i===n),Fo("[[FUNCTION_NAME]] has mismatched argument count %s vs %s.",i,n));const r=[],a=[];for(let e=0;e<i;e++){const t=o[e]?.value,i=s[e]?.value;"number"==typeof t&&"number"==typeof i&&(a.push(t),r.push(i))}return{flatDataX:r,flatDataY:a}}function Cu(e,t,o){const{flatDataX:s,flatDataY:i}=yu(e,t),n=i.length;Pi((()=>0!==n&&(!o||1!==n)),Fo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),Ii.DivisionByZero);let r=0,a=0;for(let e=0;e<n;e++)r+=i[e],a+=s[e];const l=r/n,c=a/n;let h=0;for(let e=0;e<n;e++)h+=(i[e]-l)*(s[e]-c);return h/(n-(o?1:0))}function wu(e,t,o,s){let i=0;const n=o?nn:sn,r=n(e,((e,t)=>(i+=1,e+t)),0,s);Pi((()=>0!==i&&(!t||1!==i)),Fo("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."),Ii.DivisionByZero);const a=r/i;return n(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function xu(e,t,o,s){const i=Vi(t,s);Pi((()=>o?0<=i&&i<=1:0<i&&i<1),Fo("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));let n,r=[],a=0;return Qi(e,(e=>{const t=e?.value;"number"==typeof t&&(n=pn(r,e,"nextSmaller","asc",r.length,((e,t)=>e[t])),r.splice(n+1,0,t),a++)})),Pi((()=>0!==a),Fo("[[FUNCTION_NAME]] has no valid input data.")),o||Pi((()=>1/(a+1)<=i&&i<=a/(a+1)),Fo("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),ii(r,i,o)}const Eu={description:Fo("Average magnitude of deviations from mean."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=sn(e,((e,o)=>(t+=1,e+o)),0,this.locale);Gi(t);const s=o/t;return sn(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},Iu={description:Fo("Numerical average value in a dataset, ignoring text."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the average value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:el(e,this.locale),format:Ni(e[0])}},isExported:!0},Ru=Fo("[[FUNCTION_NAME]] has mismatched range sizes."),Tu=Fo("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),Au={description:Fo("Weighted average."),args:[Dh("values (number, range<number>)",Fo("Values to average.")),Dh("weights (number, range<number>)",Fo("Weights for each corresponding value.")),Dh("additional_values (number, range<number>, repeating)",Fo("Additional values to average.")),Dh("additional_weights (number, range<number>, repeating)",Fo("Additional weights."))],compute:function(...e){let t=0,o=0;for(let s=0;s<e.length-1;s+=2){const i=e[s],n=e[s+1];if(Mh(Ru,i,n),Ci(i))for(let e=0;e<i.length;e++)for(let s=0;s<i[0].length;s++){const r=i[e][s].value,a=Ci(n)?n?.[e][s].value:Vi(n,this.locale),l="number"==typeof r,c="number"==typeof a;l&&c?(Pi((()=>a>=0),Tu),t+=r*a,o+=a):Pi((()=>l===c),Fo("[[FUNCTION_NAME]] expects number values."))}else{const e=Vi(i,this.locale),s=Ci(n)?n?.[0][0].value:Vi(n,this.locale);"number"==typeof s&&(Pi((()=>s>=0),Tu),t+=e*s,o+=s)}}return Gi(o),{value:t/o,format:Ni(e[0])}}},_u={description:Fo("Numerical average value in a dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the average value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=nn(e,((e,o)=>(t+=1,e+o)),0,this.locale);return Gi(t),{value:o/t,format:Ni(e[0])}},isExported:!0},Du={description:Fo("Average of values depending on criteria."),args:[Dh("criteria_range (number, range<number>)",Fo("The range to check against criterion.")),Dh("criterion (string)",Fo("The pattern or test to apply to criteria_range.")),Dh("average_range (number, range<number>, default=criteria_range)",Fo("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=bn(void 0===o?e:o);let i=0,n=0;return gn([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,n+=o)}),this.locale),Gi(i),n/i},isExported:!0},Ou={description:Fo("Average of values depending on multiple criteria."),args:[Dh("average_range (range)",Fo("The range to average.")),Dh("criteria_range1 (range)",Fo("The range to check against criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional criteria_range and criterion to check.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=bn(e);let s=0,i=0;return gn(t,((e,t)=>{const n=o[e]?.[t]?.value;"number"==typeof n&&(s+=1,i+=n)}),this.locale),Gi(s),i/s},isExported:!0},Fu={description:Fo("The number of numeric values in dataset."),args:[Dh("value1 (number, any, range<number>)",Fo("The first value or range to consider when counting.")),Dh("value2 (number, any, range<number>, repeating)",Fo("Additional values or ranges to consider when counting."))],compute:function(...e){return tl(e,this.locale)},isExported:!0},Mu={description:Fo("The number of values in a dataset."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider when counting.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider when counting."))],compute:function(...e){return ol(e)},isExported:!0},Pu={description:Fo("The covariance of a dataset."),args:[Dh("data_y (any, range)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (any, range)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Cu(e,t,!1)},isExported:!0},Nu={description:Fo("The covariance of a dataset."),args:[Dh("data_y (any, range)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (any, range)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Cu(e,t,!1)},isExported:!0},ku={description:Fo("The sample covariance of a dataset."),args:[Dh("data_y (any, range)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (any, range)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Cu(e,t,!0)},isExported:!0},Lu={description:Fo("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[Dh("x (number, range<number>)",Fo("The value(s) on the x-axis to forecast.")),Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=yu(t,o);return ul([i],[s],an(bn(e),(e=>Vi(e,this.locale))),!0)},isExported:!0},Vu={description:Fo("Fits points to exponential growth trend."),args:[Dh("known_data_y (range<number>)",Fo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),Dh("known_data_x (range<number>, default={1;2;3;...})",Fo("The values of the independent variable(s) corresponding with known_data_y.")),Dh("new_data_x (any, range, default=known_data_x)",Fo("The data points to return the y values for on the ideal curve fit.")),Dh("b (boolean, default=TRUE)",Fo("Given a general exponential form of y = b*m^x for a curve fit, calculates b if TRUE or forces b to be 1 and only calculates the m values if FALSE."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return hl(ul(dl(Ui(e,"the first argument (known_data_y)")),Ui(t,"the second argument (known_data_x)"),Ui(o,"the third argument (new_data_y)"),Yi(s)))}},Hu={description:Fo("Compute the intercept of the linear regression."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t),[[],[i]]=rl([o],[s]);return i},isExported:!0},Uu={description:Fo("Nth largest element from a data set."),args:[Dh("data (any, range)",Fo("Array or range containing the dataset to consider.")),Dh("n (number)",Fo("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(Vi(t?.value,this.locale));let s,i=[],n=0;Qi([e],(e=>{"number"==typeof e?.value&&(s=pn(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),n++,n>o&&(i.shift(),n--))}));const r=i.shift();return Pi((()=>void 0!==r),Fo("[[FUNCTION_NAME]] has no valid input data.")),Pi((()=>n>=o),Fo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),r},isExported:!0},Bu={description:Fo("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>, default={1;2;3;...})",Fo("The range representing the array or matrix of independent data.")),Dh("calculate_b (boolean, default=TRUE)",Fo("A flag specifying wheter to compute the slope or not")),Dh("verbose (boolean, default=FALSE)",Fo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){return rl(Ui(t,"the first argument (data_y)"),Ui(e,"the second argument (data_x)"),Yi(o),Yi(s))},isExported:!0},zu={description:Fo("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>, optional, default={1;2;3;...})",Fo("The range representing the array or matrix of independent data.")),Dh("calculate_b (boolean, default=TRUE)",Fo("A flag specifying wheter to compute the slope or not")),Dh("verbose (boolean, default=FALSE)",Fo("A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept"))],compute:function(e,t=[[]],o={value:!0},s={value:!1}){const i=rl(Ui(t,"the second argument (data_x)"),dl(Ui(e,"the first argument (data_y)")),Yi(o),Yi(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},$u={description:Fo("Compute the Matthews correlation coefficient of a dataset."),args:[Dh("data_x (range)",Fo("The range representing the array or matrix of observed data.")),Dh("data_y (range)",Fo("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(Qa(o,s),0===o.length)return new Ti(Fo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));const i=o.length;let n=0,r=0,a=0,l=0;for(let e=0;e<i;++e){const t=Yi(o[e]);t===Yi(s[e])?t?r++:n++:t?l++:a++}return(r*n-a*l)/Math.sqrt((r+a)*(r+l)*(n+a)*(n+l))},isExported:!1},Wu={description:Fo("Maximum value in a numeric dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the maximum value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return sl(e,this.locale)},isExported:!0},Gu={description:Fo("Maximum numeric value in a dataset."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider when calculating the maximum value.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=nn(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:Ni(e[0])}},isExported:!0},qu={description:Fo("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[Dh("range (range)",Fo("The range of cells from which the maximum will be determined.")),Dh("criteria_range1 (range)",Fo("The range of cells over which to evaluate criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return gn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o<i?i:o)}),this.locale),o===-1/0?0:o},isExported:!0},Zu={description:Fo("Median value in a numeric dataset."),args:[Dh("value1 (any, range)",Fo("The first value or range to consider when calculating the median value.")),Dh("value2 (any, range, repeating)",Fo("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){let t=[];return en(e,(e=>{t.push(e)}),this.locale),{value:xu(t,{value:.5},!0,this.locale),format:Ni(t[0])}},isExported:!0},ju={description:Fo("Minimum value in a numeric dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the minimum value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return il(e,this.locale)},isExported:!0},Yu={description:Fo("Minimum numeric value in a dataset."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range to consider when calculating the minimum value.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=nn(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:Ni(e[0])}},isExported:!0},Xu={description:Fo("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[Dh("range (range)",Fo("The range of cells from which the minimum will be determined.")),Dh("criteria_range1 (range)",Fo("The range of cells over which to evaluate criterion1.")),Dh("criterion1 (string)",Fo("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Dh("criteria_range2 (any, range, repeating)",Fo("Additional ranges over which to evaluate the additional criteria. The filtered set will be the intersection of the sets produced by each criterion-range pair.")),Dh("criterion2 (string, repeating)",Fo("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return gn(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o=o>i?i:o)}),this.locale),o===1/0?0:o},isExported:!0};function Ku(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t);if(0===o.length)throw new Ti(Fo("[[FUNCTION_NAME]] expects non-empty ranges for both parameters."));if(o.length<2)throw new Ti(Fo("[[FUNCTION_NAME]] needs at least two values for both parameters."));const i=o.length;let n=0,r=0,a=0,l=0,c=0;for(let e=0;e<i;e++){const t=o[e],i=s[e];n+=t,r+=i,a+=t*i,l+=t*t,c+=i*i}return(i*a-n*r)/Math.sqrt((i*l-n*n)*(i*c-r*r))}const Ju={description:Fo("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Ku(e,t)},isExported:!0},Qu=Ju,eg={description:Fo("Value at a given percentile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("percentile (number)",Fo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return og.compute.bind(this)(e,t)},isExported:!0},tg={description:Fo("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("percentile (number)",Fo("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:xu([e],t,!1,this.locale),format:Ni(e)}},isExported:!0},og={description:Fo("Value at a given percentile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("percentile (number)",Fo("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:xu([e],t,!0,this.locale),format:Ni(e)}},isExported:!0},sg={description:Fo("Compute the coefficients of polynomial regression of the dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data.")),Dh("order (number)",Fo("The order of the polynomial to fit the data, between 1 and 6.")),Dh("intercept (boolean, default=TRUE)",Fo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:n}=yu(e,t);return al(n,i,Vi(o,this.locale),Yi(s))},isExported:!1},ig={description:Fo("Predict value by computing a polynomial regression of the dataset."),args:[Dh("x (number, range<number>)",Fo("The value(s) on the x-axis to forecast.")),Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data.")),Dh("order (number)",Fo("The order of the polynomial to fit the data, between 1 and 6.")),Dh("intercept (boolean, default=TRUE)",Fo("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s,i={value:!0}){const n=Vi(s,this.locale),{flatDataX:r,flatDataY:a}=yu(t,o),l=al(a,r,n,Yi(i)).flat();return an(bn(e),(e=>cl(l,Vi(e,this.locale),n)))},isExported:!1},ng={description:Fo("Value nearest to a specific quartile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("quartile_number (number)",Fo("Which quartile value to return."))],compute:function(e,t){return ag.compute.bind(this)(e,t)},isExported:!0},rg={description:Fo("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("quartile_number (number)",Fo("Which quartile value, exclusive of 0 and 4, to return."))],compute:function(e,t){return{value:xu([e],{value:.25*Math.trunc(Vi(t,this.locale))},!1,this.locale),format:Ni(e)}},isExported:!0},ag={description:Fo("Value nearest to a specific quartile of a dataset."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("quartile_number (number)",Fo("Which quartile value to return."))],compute:function(e,t){return{value:xu([e],{value:.25*Math.trunc(Vi(t,this.locale))},!0,this.locale),format:Ni(e)}},isExported:!0},lg={description:Fo("Returns the rank of a specified value in a dataset."),args:[Dh("value (number)",Fo("The value whose rank will be determined.")),Dh("data (range)",Fo("The range containing the dataset to consider.")),Dh("is_ascending (boolean, default=FALSE)",Fo("Whether to consider the values in data in descending or ascending order."))],compute:function(e,t,o={value:!1}){const s=Yi(o),i=Vi(e,this.locale);let n=1,r=!1;for(const e of t)for(const t of e){if("number"!=typeof t.value)continue;const e=Vi(t,this.locale);e===i?r=!0:e>i!==s&&n++}if(!r)throw new Di(Fo("Value not found in the given data."));return n},isExported:!0},cg={description:Fo("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){return Math.pow(Ku(t,e),2)},isExported:!0},hg={description:Fo("Compute the slope of the linear regression."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t),[[i]]=rl([o],[s]);return i},isExported:!0},dg={description:Fo("Nth smallest element in a data set."),args:[Dh("data (any, range)",Fo("The array or range containing the dataset to consider.")),Dh("n (number)",Fo("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(Vi(t?.value,this.locale));let s,i=[],n=0;Qi([e],(e=>{"number"==typeof e?.value&&(s=pn(i,e,"nextSmaller","asc",i.length,((e,t)=>e[t].value)),i.splice(s+1,0,e),n++,n>o&&(i.pop(),n--))}));const r=i.pop();return Pi((()=>void 0!==r),Fo("[[FUNCTION_NAME]] has no valid input data.")),Pi((()=>n>=o),Fo("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)),r},isExported:!0},ug={description:Fo("Compute the Spearman rank correlation coefficient of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(t,e),i=o.length,n=o.map(((e,t)=>[e,s[t]]));n.sort(((e,t)=>e[0]-t[0]));for(let e=0;e<i;++e)n[e][0]=e;n.sort(((e,t)=>e[1]-t[1]));let r=0;for(let e=0;e<i;++e)r+=(n[e][0]-e)**2;return 1-6*r/(i**3-i)},isExported:!1},gg={description:Fo("Standard deviation."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Cg.compute.bind(this)(...e))},isExported:!0},pg={description:Fo("Standard deviation of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(wg.compute.bind(this)(...e))},isExported:!0},mg={description:Fo("Standard deviation."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(xg.compute.bind(this)(...e))},isExported:!0},fg={description:Fo("Standard deviation of sample (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Eg.compute.bind(this)(...e))},isExported:!0},vg={description:Fo("Standard deviation of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Ig.compute.bind(this)(...e))},isExported:!0},bg={description:Fo("Standard deviation of entire population (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Rg.compute.bind(this)(...e))},isExported:!0},Sg={description:Fo("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[Dh("data_y (range<number>)",Fo("The range representing the array or matrix of dependent data.")),Dh("data_x (range<number>)",Fo("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=yu(e,t);return rl([o],[s],!0,!0)[1][2]},isExported:!0},yg={description:Fo("Fits points to linear trend derived via least-squares."),args:[Dh("known_data_y (number, range<number>)",Fo("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),Dh("known_data_x (number, range<number>, optional, default={1;2;3;...})",Fo("The values of the independent variable(s) corresponding with known_data_y.")),Dh("new_data_x (number, range<number>, optional, default=known_data_x)",Fo("The data points to return the y values for on the ideal curve fit.")),Dh("b (boolean, optional, default=TRUE)",Fo("Given a general linear form of y = m*x+b for a curve fit, calculates b if TRUE or forces b to be 0 and only calculates the m values if FALSE, i.e. forces the curve fit to pass through the origin."))],compute:function(e,t=[[]],o=[[]],s={value:!0}){return ul(Ui(e,"the first argument (known_data_y)"),Ui(t,"the second argument (known_data_x)"),Ui(o,"the third argument (new_data_y)"),Yi(s))}},Cg={description:Fo("Variance."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return wu(e,!0,!1,this.locale)},isExported:!0},wg={description:Fo("Variance of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return wu(e,!1,!1,this.locale)},isExported:!0},xg={description:Fo("Variance."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return wu(e,!0,!1,this.locale)},isExported:!0},Eg={description:Fo("Variance of sample (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the sample.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the sample."))],compute:function(...e){return wu(e,!0,!0,this.locale)},isExported:!0},Ig={description:Fo("Variance of entire population."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return wu(e,!1,!1,this.locale)},isExported:!0},Rg={description:Fo("Variance of entire population (text as 0)."),args:[Dh("value1 (number, range<number>)",Fo("The first value or range of the population.")),Dh("value2 (number, range<number>, repeating)",Fo("Additional values or ranges to include in the population."))],compute:function(...e){return wu(e,!1,!0,this.locale)},isExported:!0};var Tg=Object.freeze({__proto__:null,AVEDEV:Eu,AVERAGE:Iu,AVERAGEA:_u,AVERAGEIF:Du,AVERAGEIFS:Ou,AVERAGE_WEIGHTED:Au,CORREL:Qu,COUNT:Fu,COUNTA:Mu,COVAR:Pu,COVARIANCE_P:Nu,COVARIANCE_S:ku,FORECAST:Lu,GROWTH:Vu,INTERCEPT:Hu,LARGE:Uu,LINEST:Bu,LOGEST:zu,MATTHEWS:$u,MAX:Wu,MAXA:Gu,MAXIFS:qu,MEDIAN:Zu,MIN:ju,MINA:Yu,MINIFS:Xu,PEARSON:Ju,PERCENTILE:eg,PERCENTILE_EXC:tg,PERCENTILE_INC:og,POLYFIT_COEFFS:sg,POLYFIT_FORECAST:ig,QUARTILE:ng,QUARTILE_EXC:rg,QUARTILE_INC:ag,RANK:lg,RSQ:cg,SLOPE:hg,SMALL:dg,SPEARMAN:ug,STDEV:gg,STDEVA:fg,STDEVP:vg,STDEVPA:bg,STDEV_P:pg,STDEV_S:mg,STEYX:Sg,TREND:yg,VAR:Cg,VARA:Eg,VARP:Ig,VARPA:Rg,VAR_P:wg,VAR_S:xg});function Ag(e,t,o,s){const i=new Map,n=e.length;for(let t=n-1;t>=0;t--)i.set(qi(e[t][0]).toUpperCase(),t);const r=t?.value;if("number"!=typeof r&&"string"!=typeof r)throw new Ti(Fo("The field must be a number or a string"));let a;if("number"==typeof r){if(a=Math.trunc(r)-1,a<0||n-1<a)throw new Ti(Fo("The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.",{fieldValue:r.toString(),dimRowDB:n.toString()}))}else{const e=qi(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new Ti(Fo("The field (%s) must be one of %s.",qi(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new Ti(Fo("The criteria range contains %s row, it must be at least 2 rows.",l.toString()));let c=new Set;const h=e[0].length;for(let t=1;t<l;t++){let n=[],r=!0;for(let s=0;s<o.length;s++){const a=qi(o[s][0]).toUpperCase(),l=i.get(a),c=o[s][t];if(null!==c.value){if(void 0===l){r=!1;break}n.push([e[l].slice(1,h)]),n.push(c)}}if(r){if(!(n.length>0)){c=new Set(Array(h-1).keys());break}gn(n,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const _g=[Dh("database (range)",Fo("The array or range containing the data to consider, structured in such a way that the first row contains the labels for each column's values.")),Dh("field (number, string)",Fo("Indicates which column in database contains the values to be extracted and operated on.")),Dh("criteria (range)",Fo("An array or range containing zero or more criteria to filter the database values by before operating."))],Dg={description:Fo("Average of a set of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Iu.compute.bind(this)([s])},isExported:!0},Og={description:Fo("Counts values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Fu.compute.bind(this)([s])},isExported:!0},Fg={description:Fo("Counts values and text from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Mu.compute.bind(this)([s])},isExported:!0},Mg={description:Fo("Single value from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Pi((()=>1===s.length),Fo("More than one match found in DGET evaluation.")),s[0]},isExported:!0},Pg={description:Fo("Maximum of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Wu.compute.bind(this)([s])},isExported:!0},Ng={description:Fo("Minimum of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return ju.compute.bind(this)([s])},isExported:!0},kg={description:Fo("Product of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Jd.compute.bind(this)([s])},isExported:!0},Lg={description:Fo("Standard deviation of population sample from table."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return gg.compute.bind(this)([s])},isExported:!0},Vg={description:Fo("Standard deviation of entire population from table."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return vg.compute.bind(this)([s])},isExported:!0},Hg={description:Fo("Sum of values from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return du.compute.bind(this)([s])},isExported:!0},Ug={description:Fo("Variance of population sample from table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Cg.compute.bind(this)([s])},isExported:!0},Bg={description:Fo("Variance of a population from a table-like range."),args:_g,compute:function(e,t,o){const s=Ag(e,t,o,this.locale);return Ig.compute.bind(this)([s])},isExported:!0};var zg=Object.freeze({__proto__:null,DAVERAGE:Dg,DCOUNT:Og,DCOUNTA:Fg,DGET:Mg,DMAX:Pg,DMIN:Ng,DPRODUCT:kg,DSTDEV:Lg,DSTDEVP:Vg,DSUM:Hg,DVAR:Ug,DVARP:Bg});var $g;!function(e){e.WHOLE_YEARS="Y",e.WHOLE_MONTHS="M",e.WHOLE_DAYS="D",e.DAYS_WITHOUT_WHOLE_MONTHS="MD",e.MONTH_WITHOUT_WHOLE_YEARS="YM",e.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR="YD"}($g||($g={}));const Wg={description:Fo("Converts year/month/day into a date."),args:[Dh("year (number)",Fo("The year component of the date.")),Dh("month (number)",Fo("The month component of the date.")),Dh("day (number)",Fo("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(Vi(e,this.locale));const i=Math.trunc(Vi(t,this.locale)),n=Math.trunc(Vi(o,this.locale));Pi((()=>0<=s&&s<=9999),Fo("The year (%s) must be between 0 and 9999 inclusive.",s.toString())),s<1900&&(s+=1900);const r=zs(new Is(s,i-1,n));return Pi((()=>r>=0),Fo("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")),{value:r,format:this.locale.dateFormat}},isExported:!0},Gg={description:Fo("Calculates the number of days, months, or years between two dates."),args:[Dh("start_date (date)",Fo("The start date to consider in the calculation. Must be a reference to a cell containing a DATE, a function returning a DATE type, or a number.")),Dh("end_date (date)",Fo("The end date to consider in the calculation. Must be a reference to a cell containing a DATE, a function returning a DATE type, or a number.")),Dh("unit (string)",Fo('A text abbreviation for unit of time. Accepted values are "Y" (the number of whole years between start_date and end_date), "M" (the number of whole months between start_date and end_date), "D" (the number of days between start_date and end_date), "MD" (the number of days between start_date and end_date after subtracting whole months), "YM" (the number of whole months between start_date and end_date after subtracting whole years), "YD" (the number of days between start_date and end_date, assuming start_date and end_date were no more than one year apart).'))],compute:function(e,t,o){const s=qi(o).toUpperCase();Pi((()=>Object.values($g).includes(s)),((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return Fo("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values($g),qi(o)));const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Bs(i),a=Bs(n);switch(Pi((()=>n>=i),Fo("start_date (%s) should be on or before end_date (%s).",r.toLocaleDateString(),a.toLocaleDateString())),s){case $g.WHOLE_YEARS:return Ks(r,a);case $g.WHOLE_MONTHS:return Ys(r,a);case $g.WHOLE_DAYS:return Xs(r,a);case $g.MONTH_WITHOUT_WHOLE_YEARS:return Ys(r,a)-12*Ks(r,a);case $g.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-r.getDate();if(e<0){e=Ws(new Is(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case $g.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return js(e,t,1)<1}(i,n))return Xs(r,a);const e=new Is(r.getFullYear(),a.getMonth(),a.getDate());let t=Xs(r,e);return t<0&&(e.setFullYear(r.getFullYear()+1),t=Xs(r,e)),t}}},isExported:!0},qg={description:Fo("Converts a date string to a date value."),args:[Dh("date_string (string)",Fo("The string representing the date."))],compute:function(e){const t=qi(e),o=Us(t,this.locale);return Pi((()=>null!==o),Fo("The date_string (%s) cannot be parsed to date/time.",t.toString())),Math.trunc(o.value)},isExported:!0},Zg={description:Fo("Day of the month that a specific date falls on."),args:[Dh("date (string)",Fo("The date from which to extract the day."))],compute:function(e){return Xi(e,this.locale).getDate()},isExported:!0},jg={description:Fo("Number of days between two dates."),args:[Dh("end_date (date)",Fo("The end of the date range.")),Dh("start_date (date)",Fo("The start of the date range."))],compute:function(e,t){const o=Xi(e,this.locale),s=Xi(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/Ts)},isExported:!0},Yg={description:Fo("Number of days between two dates on a 360-day year (months of 30 days)."),args:[Dh("start_date (date)",Fo("The start date to consider in the calculation.")),Dh("end_date (date)",Fo("The end date to consider in the calculation.")),Dh("method (number, default=0)",Fo("An indicator of what day count method to use. (0) US NASD method (1) European method"))],compute:function(e,t,o={value:0}){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=js(s,i,Yi(o)?4:0);return Math.sign(i-s)*Math.round(360*n)},isExported:!0},Xg={description:Fo("Date a number of months before/after another date."),args:[Dh("start_date (date)",Fo("The date from which to calculate the result.")),Dh("months (number)",Fo("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:zs(qs(Xi(e,this.locale),Math.trunc(Vi(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},Kg={description:Fo("Last day of a month before or after a date."),args:[Dh("start_date (date)",Fo("The date from which to calculate the result.")),Dh("months (number)",Fo("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Xi(e,this.locale),s=Math.trunc(Vi(t,this.locale)),i=o.getFullYear(),n=o.getMonth();return{value:zs(new Is(i,n+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Jg={description:Fo("Hour component of a specific time."),args:[Dh("time (date)",Fo("The time from which to calculate the hour component."))],compute:function(e){return Xi(e,this.locale).getHours()},isExported:!0},Qg={description:Fo("ISO week number of the year."),args:[Dh("date (date)",Fo("The date for which to determine the ISO week number. Must be a reference to a cell containing a date, a function returning a date type, or a number."))],compute:function(e){const t=Xi(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new Is(o,0,s).getDay();)s+=1;const i=new Is(o,0,s-3);let n=31;for(;4!==new Is(o,11,n).getDay();)n-=1;const r=new Is(o,11,n+3);let a,l;switch(a=i.getTime()<=t.getTime()?t.getTime()<=r.getTime()?0:1:-1,a){case 0:l=i;break;case 1:l=new Is(o,11,n+3+1);break;case-1:let e=1;for(;4!==new Is(o-1,0,e).getDay();)e+=1;l=new Is(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/Ts;return Math.floor(c/7)+1},isExported:!0},ep={description:Fo("Minute component of a specific time."),args:[Dh("time (date)",Fo("The time from which to calculate the minute component."))],compute:function(e){return Xi(e,this.locale).getMinutes()},isExported:!0},tp={description:Fo("Month of the year a specific date falls in"),args:[Dh("date (date)",Fo("The date from which to extract the month."))],compute:function(e){return Xi(e,this.locale).getMonth()+1},isExported:!0},op={description:Fo("Net working days between two provided days."),args:[Dh("start_date (date)",Fo("The start date of the period from which to calculate the number of net working days.")),Dh("end_date (date)",Fo("The end date of the period from which to calculate the number of net working days.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return ip.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function sp(e){const t=e?.value;if("string"==typeof t){Pi((()=>{if(7!==t.length)return!1;for(let e of t)if("0"!==e&&"1"!==e)return!1;return!0}),Fo('When weekend is a string (%s) it must be composed of "0" or "1".',t));let e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return Pi((()=>1<=t&&t<=7||11<=t&&t<=17),Fo("The weekend (%s) must be a string or a number in the range 1-7 or 11-17.",t.toString())),t<=7?[t-2==-1?6:t-2,t-1]:[t-11];throw new Ti(Fo("The weekend must be a number or a string."))}const ip={description:Fo("Net working days between two dates (specifying weekends)."),args:[Dh("start_date (date)",Fo("The start date of the period from which to calculate the number of net working days.")),Dh("end_date (date)",Fo("The end date of the period from which to calculate the number of net working days.")),Dh("weekend (any, default=1)",Fo("A number or string representing which days of the week are considered weekends.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Xi(e,this.locale),n=Xi(t,this.locale),r=sp(o);let a=new Set;void 0!==s&&Qi([s],(e=>{const t=Xi(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>n.getTime(),c=Is.fromTimestamp((l?i:n).getTime());let h=Is.fromTimestamp((l?n:i).getTime());const d=c.getTime();let u=h.getTime(),g=0;for(;u<=d;)r.includes(h.getDay())||a.has(u)||(g+=1),h.setDate(h.getDate()+1),u=h.getTime();return l?-g:g},isExported:!0},np={description:Fo("Current date and time as a date value."),args:[],compute:function(){const e=Is.now(),t=e.getTime()-Rs.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/Ts)+o,format:za(this.locale)}},isExported:!0},rp={description:Fo("Minute component of a specific time."),args:[Dh("time (date)",Fo("The time from which to calculate the second component."))],compute:function(e){return Xi(e,this.locale).getSeconds()},isExported:!0},ap={description:Fo("Converts hour/minute/second into a time."),args:[Dh("hour (number)",Fo("The hour component of the time.")),Dh("minute (number)",Fo("The minute component of the time.")),Dh("second (number)",Fo("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Math.trunc(Vi(o,this.locale));return i+=Math.floor(n/60),n=n%60+(n<0?60:0),s+=Math.floor(i/60),i=i%60+(i<0?60:0),s%=24,Pi((()=>s>=0),Fo("The function [[FUNCTION_NAME]] result cannot be negative")),{value:s/24+i/1440+n/86400,format:this.locale.timeFormat}},isExported:!0},lp={description:Fo("Converts a time string into its serial number representation."),args:[Dh("time_string (string)",Fo("The string that holds the time representation."))],compute:function(e){const t=qi(e),o=Us(t,this.locale);Pi((()=>null!==o),Fo("The time_string (%s) cannot be parsed to date/time.",t));const s=o.value-Math.trunc(o.value);return s<0?1+s:s},isExported:!0},cp={description:Fo("Current date as a date value."),args:[],compute:function(){const e=Is.now();return{value:zs(new Is(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},hp={description:Fo("Day of the week of the date provided (as number)."),args:[Dh("date (date)",Fo("The date for which to determine the day of the week. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("type (number, default=1)",Fo("A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1."))],compute:function(e,t={value:1}){const o=Xi(e,this.locale),s=Math.round(Vi(t,this.locale)),i=o.getDay();return Pi((()=>[1,2,3].includes(s)),Fo("The type (%s) must be 1, 2 or 3.",s.toString())),1===s?i+1:2===s?0===i?7:i:0===i?6:i-1},isExported:!0},dp={description:Fo("Week number of the year."),args:[Dh("date (date)",Fo("The date for which to determine the week number. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("type (number, default=1)",Fo("A number representing the day that a week starts on. Sunday = 1."))],compute:function(e,t={value:1}){const o=Xi(e,this.locale),s=Math.round(Vi(t,this.locale));if(Pi((()=>1===s||2===s||11<=s&&s<=17||21===s),Fo("The type (%s) is out of range.",s.toString())),21===s)return Qg.compute.bind(this)(e);let i;i=1===s||2===s?s-1:s-10==7?0:s-10;const n=o.getFullYear();let r=1,a=new Is(n,0,r);for(;a.getDay()!==i;)r+=1,a=new Is(n,0,r);const l=(o.getTime()-a.getTime())/Ts;return l<0?1:Math.floor(l/7)+(1===r?1:2)},isExported:!0},up={description:Fo("Date after a number of workdays."),args:[Dh("start_date (date)",Fo("The date from which to begin counting.")),Dh("num_days (number)",Fo("The number of working days to advance from start_date. If negative, counts backwards.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return gp.compute.bind(this)(e,t,{value:1},o)},isExported:!0},gp={description:Fo("Date after a number of workdays (specifying weekends)."),args:[Dh("start_date (date)",Fo("The date from which to begin counting.")),Dh("num_days (number)",Fo("The number of working days to advance from start_date. If negative, counts backwards.")),Dh("weekend (any, default=1)",Fo("A number or string representing which days of the week are considered weekends.")),Dh("holidays (date, range<date>, optional)",Fo("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){let i=Xi(e,this.locale),n=Math.trunc(Vi(t,this.locale));"string"==typeof o.value&&Pi((()=>"1111111"!==o.value),Fo("The weekend must be different from '1111111'."));const r=sp(o);let a=new Set;void 0!==s&&Qi([s],(e=>{const t=Xi(e,this.locale);a.add(t.getTime())}));let l=Is.fromTimestamp(i.getTime()),c=l.getTime();const h=Math.sign(n);let d=Math.abs(n);for(;d>0;)l.setDate(l.getDate()+h),c=l.getTime(),r.includes(l.getDay())||a.has(c)||(d-=1);const u=c-Rs.getTime();return{value:Math.round(u/Ts),format:this.locale.dateFormat}},isExported:!0},pp={description:Fo("Year specified by a given date."),args:[Dh("date (date)",Fo("The date from which to extract the year."))],compute:function(e){return Xi(e,this.locale).getFullYear()},isExported:!0},mp={description:Fo("Exact number of years between two dates."),args:[Dh("start_date (date)",Fo("The start date to consider in the calculation. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("end_date (date)",Fo("The end date to consider in the calculation. Must be a reference to a cell containing a date, a function returning a date type, or a number.")),Dh("day_count_convention (number, default=0)",Fo("An indicator of what day count method to use."))],compute:function(e,t,o={value:0}){let s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale));const n=Math.trunc(Vi(o,this.locale));return Pi((()=>s>=0),Fo("The start_date (%s) must be positive or null.",s.toString())),Pi((()=>i>=0),Fo("The end_date (%s) must be positive or null.",i.toString())),Pi((()=>0<=n&&n<=4),Fo("The day_count_convention (%s) must be between 0 and 4 inclusive.",n.toString())),js(s,i,n)}},fp={description:Fo("First day of the month preceding a date."),args:[Dh("date (date)",Fo("The date from which to calculate the result."))],compute:function(e){const t=Xi(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:zs(new Is(o,s,1)),format:this.locale.dateFormat}}},vp={description:Fo("Last day of the month following a date."),args:[Dh("date (date)",Fo("The date from which to calculate the result."))],compute:function(e){return Kg.compute.bind(this)(e,{value:0})}},bp={description:Fo("Quarter of the year a specific date falls in"),args:[Dh("date (date)",Fo("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Xi(e,this.locale).getMonth()+1)/3)}},Sp={description:Fo("First day of the quarter of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the start of quarter."))],compute:function(e){const t=bp.compute.bind(this)(e),o=pp.compute.bind(this)(e);return{value:zs(new Is(o,3*(t-1),1)),format:this.locale.dateFormat}}},yp={description:Fo("Last day of the quarter of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the end of quarter."))],compute:function(e){const t=bp.compute.bind(this)(e),o=pp.compute.bind(this)(e);return{value:zs(new Is(o,3*t,0)),format:this.locale.dateFormat}}},Cp={description:Fo("First day of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the start of the year."))],compute:function(e){const t=pp.compute.bind(this)(e);return{value:zs(new Is(t,0,1)),format:this.locale.dateFormat}}},wp={description:Fo("Last day of the year a specific date falls in."),args:[Dh("date (date)",Fo("The date from which to calculate the end of the year."))],compute:function(e){const t=pp.compute.bind(this)(e);return{value:zs(new Is(t+1,0,0)),format:this.locale.dateFormat}}};var xp=Object.freeze({__proto__:null,DATE:Wg,DATEDIF:Gg,DATEVALUE:qg,DAY:Zg,DAYS:jg,DAYS360:Yg,EDATE:Xg,EOMONTH:Kg,HOUR:Jg,ISOWEEKNUM:Qg,MINUTE:ep,MONTH:tp,MONTH_END:vp,MONTH_START:fp,NETWORKDAYS:op,NETWORKDAYS_INTL:ip,NOW:np,QUARTER:bp,QUARTER_END:yp,QUARTER_START:Sp,SECOND:rp,TIME:ap,TIMEVALUE:lp,TODAY:cp,WEEKDAY:hp,WEEKNUM:dp,WORKDAY:up,WORKDAY_INTL:gp,YEAR:pp,YEARFRAC:mp,YEAR_END:wp,YEAR_START:Cp});const Ep={description:Fo("Compare two numeric values, returning 1 if they're equal."),args:[Dh("number1 (number)",Fo("The first number to compare.")),Dh("number2 (number, default=0)",Fo("The second number to compare."))],compute:function(e,t={value:0}){return Vi(e,this.locale)===Vi(t,this.locale)?1:0},isExported:!0};var Ip=Object.freeze({__proto__:null,DELTA:Ep});const Rp=[ni.number,ni.error,ni.text,ni.boolean];function Tp(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===ni.empty)return o.type===ni.empty?0:1;if(o.type===ni.empty)return-1;let s=Rp.indexOf(e.type)-Rp.indexOf(o.type);return 0===s&&(s=e.type===ni.text||e.type===ni.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function Ap(e,t,o,s,i){let n=s.right>s.left;if(e.model.getters.doesIntersectMerge(t,s)){let o;n=!1;for(let i=s.top;i<=s.bottom;i++){o=[];for(let n=s.left;n<=s.right;n++){let s=e.model.getters.getMerge({sheetId:t,col:n,row:i});s&&!o.includes(s.id.toString())&&o.push(s.id.toString())}if(o.length>=2){n=!0;break}}}if(n)return void _p(e,t,o,s,i);const r=e.model.getters.getContiguousZone(t,s);ns(r,s)?_p(e,t,o,s,i):e.askConfirmation(Fo("We found data next to your selection. Since this data was not selected, it will not be sorted. Do you want to extend your selection?"),(()=>_p(e,t,o,r,i)),(()=>_p(e,t,o,s,i)))}function _p(e,t,o,s,i,n){const r=e.model.dispatch("SORT_CELLS",{sheetId:t,col:o.col,row:o.row,zone:s,sortDirection:i,sortOptions:n});if(r.isCancelledBecause("InvalidSortZone")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Fo("Cannot sort. To sort, select only cells or only merges that have the same size."))}if(r.isCancelledBecause("SortZoneWithArrayFormulas")){const{col:t,row:i}=o;e.model.selection.selectZone({cell:{col:t,row:i},zone:s}),e.raiseError(Fo("Cannot sort a zone with array formulas."))}}function Dp(e,t,...o){for(const[e,t]of o.entries())Pi((()=>void 0!==t),Fo("Value for parameter %d is missing, while the function [[FUNCTION_NAME]] expect a number or a range.",e+1));const s=[],i=[],n=e.length;for(let r=0;r<o.length;r+=2){s.push(Yi(Ja(o[r+1])?.value)?"asc":"desc");const a=o[r];if(Ci(a)&&(a.length>1||a[0].length>1))Pi((()=>1===a.length&&a[0].length===n),Fo("Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.",`sort_column${r+1}`,n,a.length,a[0].length)),i.push(a.flat().map((e=>e.value)));else{const o=Vi(Ja(a)?.value,t);if(o<1||o>e[0].length)return e;i.push(e.map((e=>e[o-1].value)))}}if(0===i.length)for(let t=0;t<e[0].length;t++)i.push(e.map((e=>e[t].value))),s.push("asc");const r={desc:Tp("desc"),asc:Tp("asc")},a=Ze(0,e.length);return a.sort(((e,t)=>{for(const[o,n]of i.entries()){const i=n[e],a=n[t],l={value:i,type:null===i?ni.empty:"string"==typeof i?ni.text:typeof i},c={value:a,type:null===a?ni.empty:"string"==typeof a?ni.text:typeof a},h=r[s[o]](l,c);if(0!==h)return h}return 0})),a.map((t=>e[t]))}const Op={description:Fo("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[Dh("range (any, range<any>)",Fo("The data to be filtered.")),Dh("condition1 (boolean, range<boolean>)",Fo("A column or row containing true or false values corresponding to the first column or row of range.")),Dh("condition2 (boolean, range<boolean>, repeating)",Fo("Additional column or row containing true or false values."))],compute:function(e,...t){let o=bn(e);const s=t.map((e=>an(bn(e),(e=>e.value))));s.map((e=>Fh(Fo("The arguments condition must be a single column or row."),e))),Mh(Fo("The arguments conditions must have the same dimensions."),...t);const i=s.map((e=>e.flat())),n=1===s[0].length?"row":"col";o="row"===n?ln(o):o,Pi((()=>i.every((e=>e.length===o.length))),Fo("FILTER has mismatched sizes on the range and conditions."));const r=[];for(let e=0;e<o.length;e++){const t=o[e];i.every((t=>("boolean"==typeof t[e]||"number"==typeof t[e])&&t[e]))&&r.push(t)}return r.length?"row"===n?ln(r):r:new Di(Fo("No match found in FILTER evaluation"))},isExported:!0},Fp={description:Fo("Sorts the rows of a given array or range by the values in one or more columns."),args:[Dh("range (range)",Fo("The data to be sorted.")),Dh("sort_column (any, range<number>, repeating)",Fo("The index of the column in range or a range outside of range containing the values by which to sort.")),Dh("is_ascending (boolean, repeating)",Fo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,...t){const o=ln(e);return ln(Dp(o,this.locale,...t))},isExported:!0},Mp={description:Fo("Returns the first n items in a data set after performing a sort."),args:[Dh("range (range)",Fo("The data to be sorted.")),Dh("n (number, default=1)",Fo("The number of items to return.")),Dh("display_ties_mode (number, default=0)",Fo("A number representing the way to display ties.")),Dh("sort_column (number, range<number>, repeating)",Fo("The index of the column in range or a range outside of range containing the values by which to sort.")),Dh("is_ascending (boolean, repeating)",Fo("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,t,o,...s){const i=Vi(t?.value??1,this.locale);Pi((()=>i>=0),Fo("Wrong value of 'n'. Expected a positive number. Got %s.",i));const n=Vi(o?.value??0,this.locale);Pi((()=>n>=0&&n<=3),Fo("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",n));const r=Dp(ln(e),this.locale,...s),a=(e,t)=>JSON.stringify(r[e].map((e=>e.value)))===JSON.stringify(r[t].map((e=>e.value)));switch(n){case 0:return ln(r.slice(0,i));case 1:for(let e=i;e<r.length;e++)if(!a(e,i-1))return ln(r.slice(0,e));return ln(r);case 2:{const e=[r[0]];for(let t=1;t<r.length;t++)for(let o=0;o<t&&!a(t,o);o++)o===t-1&&e.push(r[t]);return ln(e.slice(0,i))}case 3:{const e=[r[0]];let t=1;for(let o=1;o<r.length&&(a(o,o-1)||t++,!(t>i));o++)e.push(r[o]);return ln(e)}}},isExported:!0},Pp={description:Fo("Unique rows in the provided source range."),args:[Dh("range (any, range<any>)",Fo("The data to filter by unique entries.")),Dh("by_column (boolean, default=FALSE)",Fo("Whether to filter the data by columns or by rows.")),Dh("exactly_once (boolean, default=FALSE)",Fo("Whether to return only entries with no duplicates."))],compute:function(e={value:""},t,o){if(!Ci(e))return[[e]];const s=Yi(t?.value)||!1,i=Yi(o?.value)||!1;s||(e=ln(e));const n=new Map;for(const t of e){const e=JSON.stringify(t.map((e=>e.value))),o=n.get(e);o?o.count++:n.set(e,{data:t,count:1})}const r=[];for(const e of n.values())i&&e.count>1||r.push(e.data);if(!r.length)throw new Ti(Fo("No unique values found"));return s?r:ln(r)},isExported:!0};var Np=Object.freeze({__proto__:null,FILTER:Op,SORT:Fp,SORTN:Mp,UNIQUE:Pp});function kp(e,t){Pi((()=>e<t),Fo("The maturity (%s) must be strictly greater than the settlement (%s).",t.toString(),e.toString()))}function Lp(e,t){Pi((()=>t<e),Fo("The settlement date (%s) must be strictly greater than the issue date (%s).",e.toString(),t.toString()))}function Vp(e){Pi((()=>[1,2,4].includes(e)),Fo("The frequency (%s) must be one of %s",e.toString(),[1,2,4].toString()))}function Hp(e){Pi((()=>0<=e&&e<=4),Fo("The day_count_convention (%s) must be between 0 and 4 inclusive.",e.toString()))}function Up(e){Pi((()=>e>0),Fo("The redemption (%s) must be strictly positive.",e.toString()))}function Bp(e){Pi((()=>e>0),Fo("The price (%s) must be strictly positive.",e.toString()))}function zp(e){Pi((()=>e>0),Fo("The number_of_periods (%s) must be greater than 0.",e.toString()))}function $p(e){Pi((()=>e>0),Fo("The rate (%s) must be strictly positive.",e.toString()))}function Wp(e){Pi((()=>e>0),Fo("The life (%s) must be strictly positive.",e.toString()))}function Gp(e){Pi((()=>e>=0),Fo("The cost (%s) must be positive or null.",e.toString()))}function qp(e){Pi((()=>e>0),Fo("The period (%s) must be strictly positive.",e.toString()))}function Zp(e){Pi((()=>e>=0),Fo("The salvage (%s) must be positive or null.",e.toString()))}function jp(e){Pi((()=>e>0),Fo("The present value (%s) must be strictly positive.",e.toString()))}function Yp(e,t){Pi((()=>e<=t),Fo("The period (%s) must be less than or equal life (%s).",e.toString(),t.toString()))}function Xp(e){Pi((()=>e>0),Fo("The investment (%s) must be strictly positive.",e.toString()))}function Kp(e){Pi((()=>e>0),Fo("The discount (%s) must be strictly positive.",e.toString()))}function Jp(e){Pi((()=>e<1),Fo("The discount (%s) must be smaller than 1.",e.toString()))}function Qp(e){Pi((()=>e>0),Fo("The depreciation factor (%s) must be strictly positive.",e.toString()))}function em(e,t,o){const s=Xi(e,o),i=Xi(t,o),n=Xi(e,o);n.setFullYear(s.getFullYear()+1),Pi((()=>i.getTime()<=n.getTime()),Fo("The settlement date (%s) must at most one year after the maturity date (%s).",e.toString(),t.toString()))}function tm(e,t,o){zp(o),Pi((()=>e>0),Fo("The first_period (%s) must be strictly positive.",e.toString())),Pi((()=>t>0),Fo("The last_period (%s) must be strictly positive.",t.toString())),Pi((()=>e<=t),Fo("The first_period (%s) must be smaller or equal to the last_period (%s).",e.toString(),t.toString())),Pi((()=>t<=o),Fo("The last_period (%s) must be smaller or equal to the number_of_periods (%s).",e.toString(),o.toString()))}function om(e){Pi((()=>e>-1),Fo("The rate_guess (%s) must be strictly greater than -1.",e.toString()))}function sm(e,t){Pi((()=>e.length===t.length&&e[0].length===t[0].length),Fo("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."))}function im(e){Pi((()=>e.every((t=>t>=e[0]))),Fo("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e[0].toString()))}const nm=[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))];function rm(e,t,o,s,i=1e-10,n){let r,a,l,c,h=o,d=!1,u=0;do{l=e(h),isNaN(l)?(Pi((()=>u<s&&void 0!==n),Fo("Function [[FUNCTION_NAME]] didn't find any result.")),u++,h=n(c),c=h):(r=h-l/t(h),a=Math.abs(r-h),h=r,d=a<i||Math.abs(l)<i,Pi((()=>u<s),Fo("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const am={description:Fo("Accrued interest of security paying at maturity."),args:[Dh("issue (date)",Fo("The date the security was initially issued.")),Dh("maturity (date)",Fo("The maturity date of the security.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(s,this.locale),l=Vi(o,this.locale),c=Math.trunc(Vi(i,this.locale));!function(e){Pi((()=>e>=0),Fo("The issue (%s) must be positive or null.",e.toString()))}(n),Lp(r,n),Hp(c),Up(a),$p(l);return a*l*js(n,r,c)},isExported:!0},lm={description:Fo("Depreciation for an accounting period."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("purchase_date (date)",Fo("The date the asset was purchased.")),Dh("first_period_end (date)",Fo("The date the first period ended.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation.")),Dh("rate (number)",Fo("The deprecation rate.")),Dh("day_count_convention (number, optional)",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Vi(e,this.locale),l=Math.trunc(Vi(t,this.locale)),c=Math.trunc(Vi(o,this.locale)),h=Vi(s,this.locale),d=Vi(i,this.locale),u=Vi(n,this.locale),g=Math.trunc(Vi(r,this.locale));!function(e){Pi((()=>e>0),Fo("The cost (%s) must be strictly positive.",e.toString()))}(a),function(e){Pi((()=>e>=0),Fo("The purchase_date (%s) must be positive or null.",e.toString()))}(l),Zp(h),function(e,t){Pi((()=>e<=t),Fo("The salvage (%s) must be smaller or equal than the cost (%s).",e.toString(),t.toString()))}(h,a),function(e){Pi((()=>e>=0),Fo("The period (%s) must be positive or null.",e.toString()))}(d),$p(u),Hp(g),Pi((()=>l<=c),Fo("The purchase_date (%s) must be before the first_period_end (%s).",l.toString(),c.toString()));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=js(l,c,g),v=l===c?m:m*f,b=a-v-m*p;return b>=h?0===p?v:m:h-b<m?m-(h-b):0},isExported:!0},cm={description:Fo("Days in coupon period containing settlement date."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));if(kp(i,n),Vp(r),Hp(a),1===a){const i=pm.compute.bind(this)(e,t,o,s).value;return um.compute.bind(this)(e,t,o,s).value-i}return(3===a?365:360)/r},isExported:!0},hm={description:Fo("Days from settlement until next coupon."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=pm.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return i-l;if(4===a){const e=js(l,i,a);return Math.round(360*e)}const c=Xi(i,this.locale),h=Xi(l,this.locale),d=h.getFullYear(),u=c.getFullYear(),g=h.getMonth()+1,p=c.getMonth()+1;let m=h.getDate(),f=c.getDate();return 2===g&&2===p&&Gs(h)&&Gs(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&Gs(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},dm={description:Fo("Days from settlement until next coupon."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=um.compute.bind(this)(e,t,o,s).value;if([1,2,3].includes(a))return l-i;if(4===a){const e=js(i,l,a);return Math.round(360*e)}const c=hm.compute.bind(this)(e,t,o,s);return cm.compute.bind(this)(e,t,o,s)-c},isExported:!0},um={description:Fo("Next coupon date after the settlement date."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=12/r,c=gm.compute.bind(this)(e,t,o,s);return{value:zs(qs(Xi(n,this.locale),-(c-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},gm={description:Fo("Number of coupons between settlement and maturity."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);let l=1,c=n;const h=12/r;for(;c>i;)c=zs(qs(Xi(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},pm={description:Fo("Last coupon date prior to or on the settlement date."),args:nm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(Vi(e,this.locale)),n=Math.trunc(Vi(t,this.locale)),r=Math.trunc(Vi(o,this.locale)),a=Math.trunc(Vi(s,this.locale));kp(i,n),Vp(r),Hp(a);const l=12/r,c=gm.compute.bind(this)(e,t,o,s);return{value:zs(qs(Xi(n,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},mm={description:Fo("Cumulative interest paid over a set of periods."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("first_period (number)",Fo("The number of the payment period to begin the cumulative calculation.")),Dh("last_period (number)",Fo("The number of the payment period to end the cumulative calculation.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,n={value:0}){const r=Vi(s,this.locale),a=Vi(i,this.locale),l=Vi(e,this.locale),c=Vi(o,this.locale),h=Vi(t,this.locale),d=Yi(n)?1:0;tm(r,a,h),$p(l),jp(c);let u=0;for(let e=r;e<=a;e++)u+=_m(l,e,h,c,0,d);return u},isExported:!0},fm={description:Fo("Cumulative principal paid over a set of periods."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("first_period (number)",Fo("The number of the payment period to begin the cumulative calculation.")),Dh("last_period (number)",Fo("The number of the payment period to end the cumulative calculation.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i,n={value:0}){const r=Vi(s,this.locale),a=Vi(i,this.locale),l=Vi(e,this.locale),c=Vi(o,this.locale),h=Vi(t,this.locale),d=Yi(n)?1:0;tm(r,a,h),$p(l),jp(c);let u=0;for(let e=r;e<=a;e++)u+=zm(l,e,h,c,0,d);return u},isExported:!0},vm={description:Fo("Depreciation via declining balance method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation.")),Dh("month (number, optional)",Fo("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const n=Vi(e,this.locale),r=Vi(t,this.locale),a=Vi(o,this.locale),l=Math.trunc(Vi(s,this.locale)),c=i.length?Math.trunc(Vi(i[0],this.locale)):12,h=a+(12===c?0:1);Gp(n),Zp(r),qp(l),Wp(a),Pi((()=>1<=c&&c<=12),Fo("The month (%s) must be between 1 and 12 inclusive.",c.toString())),Pi((()=>l<=h),Fo("The period (%s) must be less than or equal to %s.",l.toString(),h.toString()));const d=c/12;let u=1-Math.pow(r/n,1/a);u=Math.round(1e3*u)/1e3;let g=n,p=n*(1-u*d);for(let e=1;e<l;e++)g=p,p=g*(1-u),e===a&&(p=g*(1-u*(1-d)));return{value:g-p,format:"#,##0.00"}},isExported:!0};function bm(e,t,o,s,i){if(Gp(e),Zp(t),qp(s),Wp(o),Yp(s,o),Qp(i),0===e||t>=e)return 0;const n=i/o;if(n>1)return 1===s?e-t:0;if(s<=1)return e*n;const r=e*Math.pow(1-n,s-1),a=e*Math.pow(1-n,s),l=a<t?r-t:r-a;return Math.max(l,0)}const Sm={description:Fo("Depreciation via double-declining balance method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation.")),Dh("factor (number, default=2)",Fo("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){return{value:bm(Vi(e,this.locale),Vi(t,this.locale),Vi(o,this.locale),Vi(s,this.locale),Vi(i,this.locale)),format:"#,##0.00"}},isExported:!0},ym={description:Fo("Discount rate of a security based on price."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Bp(a),Up(l);return(l-a)/l/js(n,r,c)},isExported:!0},Cm={description:Fo("Convert a decimal fraction to decimal value."),args:[Dh("fractional_price (number)",Fo("The price quotation given using fractional decimal conventions.")),Dh("unit (number)",Fo("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));Pi((()=>s>0),Fo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},wm={description:Fo("Convert a decimal value to decimal fraction."),args:[Dh("decimal_price (number)",Fo("The price quotation given as a decimal value.")),Dh("unit (number)",Fo("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));Pi((()=>s>0),Fo("The unit (%s) must be strictly positive.",s.toString()));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},xm={description:Fo("Number of periods for an investment to reach a value."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=Math.trunc(Vi(e,this.locale)),a=Math.trunc(Vi(t,this.locale)),l=Vi(o,this.locale),c=Vi(s,this.locale),h=Math.trunc(Vi(i,this.locale)),d=Math.trunc(Vi(n,this.locale));kp(r,a),Vp(h),Hp(d),Pi((()=>l>=0),Fo("The rate (%s) must be positive or null.",l.toString())),Pi((()=>c>=0),Fo("The yield (%s) must be positive or null.",c.toString()));const u=js(r,a,d),g=u-Math.trunc(u)||1/h,p=Math.ceil(u*h),m=l/h,f=c/h;let v=0,b=0;for(let e=1;e<=p;e++){const t=(m+(e===p?1:0))/(1+f)**e;b+=(g+(e-1)/h)*t,v+=t}return 0===v?0:b/v},isExported:!0},Em={description:Fo("Annual effective interest rate."),args:[Dh("nominal_rate (number)",Fo("The nominal interest rate per year.")),Dh("periods_per_year (number)",Fo("The number of compounding periods per year."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));return Pi((()=>o>0),Fo("The nominal rate (%s) must be strictly greater than 0.",o.toString())),Pi((()=>s>0),Fo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),Math.pow(1+o/s,s)-1},isExported:!0};function Im(e,t,o,s,i){return 0===e?-(s+o*t):-s*(1+e)**t-o*(1+e*i)*((1+e)**t-1)/e}const Rm={description:Fo("Future value of an annuity investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("payment_amount (number)",Fo("The amount per period to be paid.")),Dh("present_value (number, default=0)",Fo("The current value of the annuity.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;return{value:Im(Vi(e,this.locale),Vi(t,this.locale),Vi(o,this.locale),Vi(s,this.locale),Yi(i)?1:0),format:"#,##0.00"}},isExported:!0},Tm={description:Fo("Future value of principal from series of rates."),args:[Dh("principal (number)",Fo("The amount of initial capital or value to compound against.")),Dh("rate_schedule (number, range<number>)",Fo("A series of interest rates to compound against the principal."))],compute:function(e,t){return on([t],((e,t)=>e*(1+Vi(t,this.locale))),Vi(e,this.locale))},isExported:!0},Am={description:Fo("Calculates effective interest rate."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("investment (number)",Fo("The amount invested in the security.")),Dh("redemption (number)",Fo("The amount to be received at maturity.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(s,this.locale),l=Vi(o,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Xp(l),Up(a),Hp(c);return(a-l)/l/js(n,r,c)},isExported:!0};function _m(e,t,o,s,i,n){return Um(e,o,s,i,n)-zm(e,t,o,s,i,n)}const Dm={description:Fo("Payment on the principal of an investment."),args:[Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("period (number)",Fo("The amortization period, in terms of number of periods.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},n={value:0}){return{value:_m(Vi(e,this.locale),Vi(t,this.locale),Vi(o,this.locale),Vi(s,this.locale),Vi(i,this.locale),Yi(n)?1:0),format:"#,##0.00"}},isExported:!0},Om={description:Fo("Internal rate of return given periodic cashflows."),args:[Dh("cashflow_amounts (number, range<number>)",Fo("An array or range containing the income or payments associated with the investment.")),Dh("rate_guess (number, default=0.1)",Fo("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=Vi(t,this.locale);om(o);let s=!1,i=!1,n=[];en([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),n.push(e)}),this.locale),Pi((()=>s&&i),Fo("The cashflow_amounts must include negative and positive values."));const r=n.shift();return{value:rm((function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*e**(s-i))),t*e**s)}(e,r,n)}),(function(e){return function(e,t,o){const s=o.length;let i=0;return o.reduce(((t,o)=>(i++,t+o*(s-i)*e**(s-i-1))),t*s*e**(s-1))}(e,r,n)}),o+1,20,1e-5)-1,format:"0%"}},isExported:!0},Fm={description:Fo("Returns the interest paid at a particular period of an investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("period (number)",Fo("The period for which you want to view the interest payment.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity."))],compute:function(e,t,o,s){const i=Vi(e,this.locale),n=Vi(t,this.locale),r=Vi(o,this.locale),a=Vi(s,this.locale);Pi((()=>0!==r),Fo("The number of periods must be different than 0.",r.toString()));return-1*(a-a*(n/r))*i},isExported:!0},Mm={description:Fo("Modified Macaulay duration."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){return xm.compute.bind(this)(e,t,o,s,i,n)/(1+Vi(s,this.locale)/Math.trunc(Vi(i,this.locale)))},isExported:!0},Pm={description:Fo("Modified internal rate of return."),args:[Dh("cashflow_amounts (range<number>)",Fo("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),Dh("financing_rate (number)",Fo("The interest rate paid on funds invested.")),Dh("reinvestment_return_rate (number)",Fo("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=Vi(t,this.locale),i=Vi(o,this.locale),n=ln(e).flat().filter((e=>null!==e.value)).map((e=>Vi(e,this.locale))),r=n.length;let a=0,l=0;for(const e of Ze(0,r)){const t=n[e];t>=0?a+=t*(i+1)**(r-e-1):l+=t/(s+1)**e}Pi((()=>0!==l&&0!==a),Fo("There must be both positive and negative values in cashflow_amounts."));return(-a/l)**(1/(r-1))-1},isExported:!0},Nm={description:Fo("Annual nominal interest rate."),args:[Dh("effective_rate (number)",Fo("The effective interest rate per year.")),Dh("periods_per_year (number)",Fo("The number of compounding periods per year."))],compute:function(e,t){const o=Vi(e,this.locale),s=Math.trunc(Vi(t,this.locale));return Pi((()=>o>0),Fo("The effective rate (%s) must must strictly greater than 0.",o.toString())),Pi((()=>s>0),Fo("The number of periods by year (%s) must strictly greater than 0.",s.toString())),(Math.pow(o+1,1/s)-1)*s},isExported:!0},km={description:Fo("Number of payment periods for an investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("payment_amount (number)",Fo("The amount of each payment made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Vi(e,this.locale),r=Vi(t,this.locale),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Yi(i)?1:0;if(0===n)return-(l+a)/r;const h=r*(1+n*c)/n;return Math.log((h-l)/(a+h))/Math.log(1+n)},isExported:!0};function Lm(e,t,o,s){let i=0;return sn(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const Vm={description:Fo("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[Dh("discount (number)",Fo("The discount rate of the investment over one period.")),Dh("cashflow1 (number, range<number>)",Fo("The first future cash flow.")),Dh("cashflow2 (number, range<number>, repeating)",Fo("Additional future cash flows."))],compute:function(e,...t){const o=Vi(e,this.locale);return Pi((()=>-1!==o),Fo("The discount (%s) must be different from -1.",o.toString())),{value:Lm(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},Hm={description:Fo("Computes the number of periods needed for an investment to reach a value."),args:[Dh("rate (number)",Fo("The rate at which the investment grows each period.")),Dh("present_value (number)",Fo("The investment's current value.")),Dh("future_value (number)",Fo("The investment's desired future value."))],compute:function(e,t,o){const s=Vi(e,this.locale),i=Vi(t,this.locale),n=Vi(o,this.locale);return $p(s),Pi((()=>i>0),Fo("The present_value (%s) must be strictly positive.",i.toString())),Pi((()=>n>0),Fo("The future_value (%s) must be strictly positive.",n.toString())),(Math.log(n)-Math.log(i))/Math.log(1+s)},isExported:!0};function Um(e,t,o,s,i){if(zp(t),0===e)return-(s+o)/t;let n=-(o*(1+e)**t+s);return n=n*e/((1+e*i)*((1+e)**t-1)),n}const Bm={description:Fo("Periodic payment for an annuity investment."),args:[Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){const n=Vi(t,this.locale),r=Vi(e,this.locale),a=Yi(i)?1:0,l=Vi(s,this.locale);return{value:Um(r,n,Vi(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function zm(e,t,o,s,i,n){zp(o),Pi((()=>t>0&&t<=o),Fo("The period must be between 1 and number_of_periods (%s)",o));const r=Um(e,o,s,i,n);if(1===n&&1===t)return r;return r+-Im(e,0===n?t-1:t-2,r,s+r*n,0)*e}const $m={description:Fo("Payment on the principal of an investment."),args:[Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("period (number)",Fo("The amortization period, in terms of number of periods.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s,i={value:0},n={value:0}){const r=Vi(o,this.locale),a=Vi(e,this.locale),l=Vi(t,this.locale),c=Yi(n)?1:0,h=Vi(i,this.locale);return{value:zm(a,l,r,Vi(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},Wm={description:Fo("Present value of an annuity investment."),args:[Dh("rate (number)",Fo("The interest rate.")),Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("payment_amount (number)",Fo("The amount per period to be paid.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period."))],compute:function(e,t,o,s={value:0},i={value:0}){s=s||0,i=i||0;const n=Vi(e,this.locale),r=Vi(t,this.locale),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Yi(i)?1:0;return{value:n?-(a*(1+n*c)*((1+n)**r-1)/n+l)/(1+n)**r:-(l+a*r),format:"#,##0.00"}},isExported:!0},Gm={description:Fo("Price of a security paying periodic interest."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Vi(e,this.locale)),l=Math.trunc(Vi(t,this.locale)),c=Vi(o,this.locale),h=Vi(s,this.locale),d=Vi(i,this.locale),u=Math.trunc(Vi(n,this.locale)),g=Math.trunc(Vi(r,this.locale));kp(a,l),Vp(u),Hp(g),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Pi((()=>h>=0),Fo("The yield (%s) must be positive or null.",h.toString())),Up(d);const p=js(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=1+h/u,b=100*c/u;if(1===m)return(b+d)/(f*h/u+1)-b*(1-f);let S=0;for(let e=1;e<=m;e++)S+=b/v**(e-1+f);return d/v**(m-1+f)+S-b*(1-f)},isExported:!0},qm={description:Fo("Price of a discount security."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("discount (number)",Fo("The discount rate of the security at time of purchase.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Kp(a),Up(l);return l-a*l*js(n,r,c)},isExported:!0},Zm={description:Fo("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("issue (date)",Fo("The date the security was initially issued.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("yield (number)",Fo("The expected annual yield of the security.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Vi(e,this.locale)),a=Math.trunc(Vi(t,this.locale)),l=Math.trunc(Vi(o,this.locale)),c=Vi(s,this.locale),h=Vi(i,this.locale),d=Math.trunc(Vi(n,this.locale));Lp(r,l),kp(r,a),Hp(d),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Pi((()=>h>=0),Fo("The yield (%s) must be positive or null.",h.toString()));const u=js(r,a,d),g=js(r,l,d);return(100+js(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},jm=.1,Ym={description:Fo("Interest rate of an annuity investment."),args:[Dh("number_of_periods (number)",Fo("The number of payments to be made.")),Dh("payment_per_period (number)",Fo("The amount per period to be paid.")),Dh("present_value (number)",Fo("The current value of the annuity.")),Dh("future_value (number, default=0)",Fo("The future value remaining after the final payment has been made.")),Dh("end_or_beginning (number, default=0)",Fo("Whether payments are due at the end (0) or beginning (1) of each period.")),Dh("rate_guess (number, default=0.1)",Fo("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},n={value:jm}){const r=Vi(e,this.locale),a=Vi(t,this.locale),l=Yi(i)?1:0,c=Vi(n,this.locale)||jm;let h=Vi(s,this.locale),d=Vi(o,this.locale);zp(r),Pi((()=>[a,d,h].some((e=>e>0))&&[a,d,h].some((e=>e<0))),Fo("There must be both positive and negative values in [payment_amount, present_value, future_value].",r.toString())),om(c),h-=a*l,d+=a*l;return{value:rm((e=>{const t=Math.pow(1+e,r);return h+d*t+a*((t-1)/e)}),(e=>{const t=Math.pow(1+e,r-1),o=Math.pow(1+e,r);return d*r*t+a*(r*t/e-(o-1)/e/e)}),c,40,1e-5),format:"0%"}},isExported:!0},Xm={description:Fo("Amount received at maturity for a security."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("investment (number)",Fo("The amount invested (irrespective of face value of each security).")),Dh("discount (number)",Fo("The discount rate of the security invested in.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Xp(a),Kp(l);return a/(1-l*js(n,r,c))},isExported:!0},Km={description:Fo("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[Dh("number_of_periods (number)",Fo("The number of periods.")),Dh("present_value (number)",Fo("The present value of the investment.")),Dh("future_value (number)",Fo("The future value of the investment."))],compute:function(e,t,o){const s=Vi(e,this.locale),i=Vi(t,this.locale),n=Vi(o,this.locale);return zp(s),(n/i)**(1/s)-1},isExported:!0},Jm={description:Fo("Depreciation of an asset using the straight-line method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(Vi(e,this.locale)-Vi(t,this.locale))/Vi(o,this.locale),format:"#,##0.00"}},isExported:!0},Qm={description:Fo("Depreciation via sum of years digit method."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("period (number)",Fo("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=Vi(e,this.locale),n=Vi(t,this.locale),r=Vi(o,this.locale),a=Vi(s,this.locale);qp(a),Wp(r),Yp(a,r);return{value:(r-a+1)/(r*(r+1)/2)*(i-n),format:"#,##0.00"}},isExported:!0};function ef(e,t,o){return 100*(1-o*js(e,t,2))}const tf={description:Fo("Price of a US Treasury bill."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("discount (number)",Fo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Vi(o,this.locale);return kp(s,i),em(s,i,this.locale),Kp(n),Jp(n),ef(s,i,n)},isExported:!0},of={description:Fo("Equivalent rate of return for a US Treasury bill."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("discount (number)",Fo("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Vi(o,this.locale);kp(s,i),em(s,i,this.locale),Kp(n),Jp(n);const r=jg.compute.bind(this)({value:i},{value:s});if(r<=182)return 365*n/(360-n*r);const a=ef(s,i,n)/100,l=r/(366===r?366:365);return(-2*l+2*Math.sqrt(l**2-(2*l-1)*(1-1/a)))/(2*l-1)},isExported:!0},sf={description:Fo("The yield of a US Treasury bill based on price."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(Vi(e,this.locale)),i=Math.trunc(Vi(t,this.locale)),n=Vi(o,this.locale);kp(s,i),em(s,i,this.locale),Bp(n);return(100-n)/n*(1/js(s,i,2))},isExported:!0},nf={description:Fo("Variable declining balance. WARNING : does not handle decimal periods."),args:[Dh("cost (number)",Fo("The initial cost of the asset.")),Dh("salvage (number)",Fo("The value of the asset at the end of depreciation.")),Dh("life (number)",Fo("The number of periods over which the asset is depreciated.")),Dh("start (number)",Fo("Starting period to calculate depreciation.")),Dh("end (number)",Fo("Ending period to calculate depreciation.")),Dh("factor (number, default=2)",Fo("The number of months in the first year of depreciation.")),Dh("no_switch (number, default=false)",Fo("Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation."))],compute:function(e,t,o,s,i,n={value:2},r={value:false}){n=n||0;const a=Vi(e,this.locale),l=Vi(t,this.locale),c=Vi(o,this.locale),h=Math.trunc(Vi(s,this.locale)),d=Math.trunc(Vi(i,this.locale)),u=Vi(n,this.locale),g=Yi(r);if(Gp(a),Zp(l),function(e,t,o){Wp(o),Pi((()=>e>=0),Fo("The start_period (%s) must be greater or equal than 0.",e.toString())),Pi((()=>t>=0),Fo("The end_period (%s) must be greater or equal than 0.",t.toString())),Pi((()=>e<=t),Fo("The start_period (%s) must be smaller or equal to the end_period (%s).",e.toString(),t.toString())),Pi((()=>t<=o),Fo("The end_period (%s) must be smaller or equal to the life (%s).",e.toString(),o.toString()))}(h,d,c),Qp(u),0===a)return 0;if(l>=a)return h<1?a-l:0;const p=u/c;if(p>=1)return h<1?a-l:0;let m=a,f=0,v=0,b=!1;for(let e=0;e<d;e++){if(!b||g){const t=m*p,o=(m-l)/(c-e);!g&&o>t?(b=!0,f=o):f=t}const t=Math.max(m-f,l);e>=h&&(v+=m-t),m=t}return v},isExported:!0},rf={description:Fo("Internal rate of return given non-periodic cash flows."),args:[Dh("cashflow_amounts (range<number>)",Fo("An range containing the income or payments associated with the investment.")),Dh("cashflow_dates (range<number>)",Fo("An range with dates corresponding to the cash flows in cashflow_amounts.")),Dh("rate_guess (number, default=0.1)",Fo("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:jm}){const s=Vi(o,this.locale),i=e.flat().map((e=>Vi(e,this.locale))),n=t.flat().map((e=>Vi(e,this.locale)));var r;sm(e,t),r=i,Pi((()=>r.some((e=>e>0))&&r.some((e=>e<0))),Fo("There must be both positive and negative values in cashflow_amounts.")),im(n),om(s);const a=new Map;for(const e of Ze(0,n.length)){const t=n[e];a.has(t)?a.set(t,a.get(t)+i[e]):a.set(t,i[e])}const l=Array.from(a.keys()),c=l.map((e=>a.get(e)));return rm((e=>{let t=c[0];for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=c[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of Ze(1,c.length)){const s=(l[0]-l[o])/365;t+=s*c[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},af={description:Fo("Net present value given to non-periodic cash flows.."),args:[Dh("discount (number)",Fo("The discount rate of the investment over one period.")),Dh("cashflow_amounts (number, range<number>)",Fo("An range containing the income or payments associated with the investment.")),Dh("cashflow_dates (number, range<number>)",Fo("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=Vi(e,this.locale),i=Ci(t)?t.flat().map((e=>Bi(e,this.locale))):[Bi(t,this.locale)],n=Ci(o)?o.flat().map((e=>Bi(e,this.locale))):[Bi(o,this.locale)];if(Ci(o)&&Ci(t)?sm(t,o):Pi((()=>i.length===n.length),Fo("There must be the same number of values in cashflow_amounts and cashflow_dates.")),im(n),$p(s),1===i.length)return i[0];const r=new Map;for(const e of Ze(0,n.length)){const t=n[e];r.has(t)?r.set(t,r.get(t)+i[e]):r.set(t,i[e])}const a=Array.from(r.keys()),l=a.map((e=>r.get(e)));let c=l[0];for(const e of Ze(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},lf={description:Fo("Annual yield of a security paying periodic interest."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("frequency (number)",Fo("The number of interest or coupon payments per year (1, 2, or 4).")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n,r={value:0}){r=r||0;const a=Math.trunc(Vi(e,this.locale)),l=Math.trunc(Vi(t,this.locale)),c=Vi(o,this.locale),h=Vi(s,this.locale),d=Vi(i,this.locale),u=Math.trunc(Vi(n,this.locale)),g=Math.trunc(Vi(r,this.locale));kp(a,l),Vp(u),Hp(g),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Bp(h),Up(d);const p=js(a,l,g)*u,m=Math.ceil(p),f=p-Math.floor(p)||1,v=100*c/u;if(1===m){const e=h+v*(1-f);return(d+v-e)*u*(1/f)/e}const b=rm((function(e){return function(e,t,o,s,i,n){let r=n-(e+i*(1-t))*s**(o-1+t);for(let e=1;e<=o;e++)r+=i*s**(e-1);return r}(h,f,m,e,v,d)}),(function(e){return function(e,t,o,s,i){let n=-(e+i*(1-t))*(o-1+t)*s**(o-2+t);for(let e=1;e<=o;e++)n+=i*(e-1)*s**(e-2);return n}(h,f,m,e,v)}),1+(c+1)/u,100,1e-5);return(b-1)*u},isExported:!0},cf={description:Fo("Annual yield of a discount security."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("price (number)",Fo("The price at which the security is bought per 100 face value.")),Dh("redemption (number)",Fo("The redemption amount per 100 face value, or par.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){i=i||0;const n=Math.trunc(Vi(e,this.locale)),r=Math.trunc(Vi(t,this.locale)),a=Vi(o,this.locale),l=Vi(s,this.locale),c=Math.trunc(Vi(i,this.locale));kp(n,r),Hp(c),Bp(a),Up(l);return(l/a-1)/js(n,r,c)},isExported:!0},hf={description:Fo("Annual yield of a security paying interest at maturity."),args:[Dh("settlement (date)",Fo("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Dh("maturity (date)",Fo("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Dh("issue (date)",Fo("The date the security was initially issued.")),Dh("rate (number)",Fo("The annualized rate of interest.")),Dh("price (number)",Fo("The price at which the security is bought.")),Dh("day_count_convention (number, default=0 )",Fo("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){n=n||0;const r=Math.trunc(Vi(e,this.locale)),a=Math.trunc(Vi(t,this.locale)),l=Math.trunc(Vi(o,this.locale)),c=Vi(s,this.locale),h=Vi(i,this.locale),d=Math.trunc(Vi(n,this.locale));kp(r,a),Hp(d),Pi((()=>r>=l),Fo("The settlement (%s) must be greater than or equal to the issue (%s).",r.toString(),l.toString())),Pi((()=>c>=0),Fo("The rate (%s) must be positive or null.",c.toString())),Bp(h);const u=js(l,a,d),g=js(l,r,d),p=js(r,a,d);return(100*(1+c*u)/(h+100*c*g)-1)/p},isExported:!0};var df,uf=Object.freeze({__proto__:null,ACCRINTM:am,AMORLINC:lm,COUPDAYBS:hm,COUPDAYS:cm,COUPDAYSNC:dm,COUPNCD:um,COUPNUM:gm,COUPPCD:pm,CUMIPMT:mm,CUMPRINC:fm,DB:vm,DDB:Sm,DISC:ym,DOLLARDE:Cm,DOLLARFR:wm,DURATION:xm,EFFECT:Em,FV:Rm,FVSCHEDULE:Tm,INTRATE:Am,IPMT:Dm,IRR:Om,ISPMT:Fm,MDURATION:Mm,MIRR:Pm,NOMINAL:Nm,NPER:km,NPV:Vm,PDURATION:Hm,PMT:Bm,PPMT:$m,PRICE:Gm,PRICEDISC:qm,PRICEMAT:Zm,PV:Wm,RATE:Ym,RECEIVED:Xm,RRI:Km,SLN:Jm,SYD:Qm,TBILLEQ:of,TBILLPRICE:tf,TBILLYIELD:sf,VDB:nf,XIRR:rf,XNPV:af,YIELD:lf,YIELDDISC:cf,YIELDMAT:hf});!function(e){e[e.LeftRef=0]="LeftRef",e[e.RightRef=1]="RightRef",e[e.Separator=2]="Separator",e[e.FullColumnSeparator=3]="FullColumnSeparator",e[e.FullRowSeparator=4]="FullRowSeparator",e[e.RightColumnRef=5]="RightColumnRef",e[e.RightRowRef=6]="RightRowRef",e[e.Found=7]="Found"}(df||(df={}));const gf=(e,t=(()=>!0))=>[{goTo:e,guard:t}],pf=(e,t=(()=>!0))=>({goTo:e,guard:t}),mf={[df.LeftRef]:{REFERENCE:gf(df.Separator),NUMBER:gf(df.FullRowSeparator),SYMBOL:[pf(df.FullColumnSeparator,(e=>Bo(e.value))),pf(df.FullRowSeparator,(e=>zo(e.value)))]},[df.FullColumnSeparator]:{SPACE:gf(df.FullColumnSeparator),OPERATOR:gf(df.RightColumnRef,(e=>":"===e.value))},[df.FullRowSeparator]:{SPACE:gf(df.FullRowSeparator),OPERATOR:gf(df.RightRowRef,(e=>":"===e.value))},[df.Separator]:{SPACE:gf(df.Separator),OPERATOR:gf(df.RightRef,(e=>":"===e.value))},[df.RightRef]:{SPACE:gf(df.RightRef),NUMBER:gf(df.Found),REFERENCE:gf(df.Found,(e=>Go(e.value))),SYMBOL:gf(df.Found,(e=>$o(e.value)||Wo(e.value)))},[df.RightColumnRef]:{SPACE:gf(df.RightColumnRef),SYMBOL:gf(df.Found,(e=>$o(e.value))),REFERENCE:gf(df.Found,(e=>Go(e.value)))},[df.RightRowRef]:{SPACE:gf(df.RightRowRef),NUMBER:gf(df.Found),REFERENCE:gf(df.Found,(e=>Go(e.value))),SYMBOL:gf(df.Found,(e=>Wo(e.value)))},[df.Found]:{}};function ff(e){let t=0,o=mf[df.LeftRef],s="";for(;void 0!==o;){const i=e[t++];if(!i)return null;const n=o[i.type]?.find((e=>e.guard(i))),r=n?n.goTo:void 0;switch(r){case void 0:return null;case df.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=mf[r],s+=i.value}}return null}function vf(e,t=Si){const o=fa(e,t),s=[];for(;o.length;)s.push(ff(o)||o.shift());return s}const bf=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Sf=["-","+"],yf=["%"],Cf=["*","+","&"],wf={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function xf(e){const t=e.shift();if(!t)throw new Ai;switch(t.type){case"DEBUGGER":const o=Rf(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:si(t.value,Si)};case"STRING":return{type:"STRING",value:He(t.value)};case"INVALID_REFERENCE":return{type:"REFERENCE",value:Ii.InvalidReference};case"REFERENCE":if(":"===e[0]?.value&&"REFERENCE"===e[1]?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`}}return{type:"REFERENCE",value:t.value};case"SYMBOL":const s=t.value,i=e[0];if("LEFT_PAREN"===i?.type&&bf.test(t.value)&&s===$e(s,"'")){const t=function(e){If(e,"LEFT_PAREN",Fo("Missing opening parenthesis"));const t=e[0];if("RIGHT_PAREN"===t?.type)return If(e,"RIGHT_PAREN"),[];const o=[];o.push(Ef(e));for(;"RIGHT_PAREN"!==e[0]?.type;)If(e,"ARG_SEPARATOR",Fo("Wrong function call")),o.push(Ef(e));return If(e,"RIGHT_PAREN"),o}(e);return{type:"FUNCALL",value:s,args:t}}const n=s.toUpperCase();return"TRUE"===n||"FALSE"===n?{type:"BOOLEAN",value:"TRUE"===n}:{type:"SYMBOL",value:$e(t.value,"'")};case"LEFT_PAREN":const r=Rf(e);return If(e,"RIGHT_PAREN",Fo("Missing closing parenthesis")),r;case"OPERATOR":const a=t.value;if(Sf.includes(a))return{type:"UNARY_OPERATION",value:a,operand:Rf(e,wf[a])};throw new Ai(Fo("Unexpected token: %s",t.value));default:throw new Ai(Fo("Unexpected token: %s",t.value))}}function Ef(e){const t=e[0];return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:""}:Rf(e)}function If(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new Ai(o)}function Rf(e,t=0){if(0===e.length)throw new Ai;let o=xf(e);for(;"OPERATOR"===e[0]?.type&&wf[e[0].value]>t;){const t=e.shift().value;if(yf.includes(t))o={type:"UNARY_OPERATION",value:t,operand:o,postfix:!0};else{o={type:"BIN_OPERATION",value:t,left:o,right:Rf(e,wf[t])}}}return o}function Tf(e){return Af(vf(e))}function Af(e){e=e.filter((e=>"SPACE"!==e.type)),"="===e[0]?.value&&e.splice(0,1);const t=Rf(e);if(e.length)throw new Ai;return t}function _f(e,t,o){return Ff(e,(e=>e.type===t?o(e):e))}function Df(e){return Array.from(Of(e))}function*Of(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*Of(t);break;case"UNARY_OPERATION":yield*Of(e.operand);break;case"BIN_OPERATION":yield*Of(e.left),yield*Of(e.right)}}function Ff(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>Ff(e,t)))};case"UNARY_OPERATION":return{...e,operand:Ff(e.operand,t)};case"BIN_OPERATION":return{...e,right:Ff(e.right,t),left:Ff(e.left,t)};default:return e}}function Mf(e){switch(e.type){case"FUNCALL":const t=e.args.map((e=>Mf(e)));return`${e.value}(${t.join(",")})`;case"NUMBER":return e.value.toString();case"REFERENCE":default:return e.value;case"STRING":return`"${e.value}"`;case"BOOLEAN":return e.value?"TRUE":"FALSE";case"UNARY_OPERATION":return e.postfix?Pf(e)+e.value:e.value+Nf(e);case"BIN_OPERATION":return Pf(e)+e.value+Nf(e)}}function Pf(e){const t=e.value,o="left"in e?e.left:e.operand,s=o.value;return"BIN_OPERATION"===o.type&&wf[s]<wf[t]?`(${Mf(o)})`:Mf(o)}function Nf(e){const t=e.value,o="right"in e?e.right:e.operand,s=wf[o.value],i=wf[t];let n=!1;return"BIN_OPERATION"!==o.type?n=!1:s<i?n=!0:s!==i||Cf.includes(t)||(n=!0),n?`(${Mf(o)})`:Mf(o)}function kf(e,t){return function(e){for(const t of e)if(t.functionContext){const{argsTokens:e,args:o}=t.functionContext;if(delete t.functionContext.argsTokens,o.length||!e)continue;"LEFT_PAREN"===e[0]?.[0]?.type&&(e[0]=e[0].slice(1));for(const t of e){let e=t;"ARG_SEPARATOR"===e.at(-1)?.type&&(e=e.slice(0,-1));try{o.push(Af(e))}catch(e){o.push(void 0)}}}return e}(function(e){let t=[],o="";function s(e){if(0===t.length)return;const o=t.at(-1);if(o&&o.argsTokens){const{argsTokens:t,argPosition:s}=o;t[s]||(t[s]=[]),t[s].push({value:e.value,type:e.type})}}return e.map(((e,i)=>{switch(["SPACE","LEFT_PAREN"].includes(e.type)||(o=""),e.type){case"SYMBOL":s(e),o=e.value;break;case"LEFT_PAREN":t.push({parent:o,argPosition:0,argsTokens:[],args:[]}),s(e),o="";break;case"RIGHT_PAREN":const i=t.pop();i?.argsTokens?.flat().forEach(s),s(e);break;case"ARG_SEPARATOR":s(e),t.length&&t[t.length-1].argPosition++;break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){let t=[],o=0;return e.map(((s,i)=>{if("LEFT_PAREN"===s.type){t.push(o+1),o=0;for(let o=i-1;o>=0;o--){if("SPACE"!==e[o].type){"SYMBOL"===e[o].type&&(e[o].parenthesesCode=t.join(":"));break}e[o].parenthesesCode=t.join(":")}}return s.parenthesesCode=t.join(":"),"RIGHT_PAREN"===s.type&&t.length&&(o=t.pop()),s}))}(function(e){let t=0;return e.map((e=>{const o=e.value.toString().length,s=Object.assign({},e,{start:t,end:t+o,length:o});return t=s.end,s}))}(vf(e,t)))))}function Lf(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=qo(e.value),[s,i]=t.split(":"),n=Vf(s),r=i?`:${Vf(i)}`:"";return{...e,value:Zo(o,n+r)}}function Vf(e){switch(function(e){if(function(e){return e.startsWith("$")&&e.length>1&&e.slice(1).includes("$")}(e))return"colrow";if(function(e){return e.startsWith("$")}(e))return"col";if(function(e){return e.includes("$",1)}(e))return"row";return"none"}(e)){case"none":e=Hf(e,"colrow");break;case"colrow":e=Hf(e,"row");break;case"row":e=Hf(e,"col");break;case"col":e=Hf(e,"none")}return e}function Hf(e,t){if(e.includes("!"))throw new Error("The given XC should not contain a sheet name");let o;switch(e=e.replace(/\$/g,""),t){case"col":return"$"+e;case"row":return o=e.search(/[0-9]/),e.slice(0,o)+"$"+e.slice(o);case"colrow":return o=e.search(/[0-9]/),-1===o||0===o?"$"+e:"$"+(e=e.slice(0,o)+"$"+e.slice(o));case"none":return e}}function Uf(e,t,o){const s=(t.startsWith("=")?kf(t,o):[]).filter((t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end)),i=s.filter((e=>"REFERENCE"===e.type));if(0===i.length)return;const n=s.map(Lf).map((e=>e.value)).join(""),r=s[0].start,a=s[s.length-1].end,l=t.slice(0,r)+n+t.slice(a),c=l.length-t.length,h={start:i[0].start,end:i[i.length-1].end+c};return 1===i.length&&e.start===e.end&&(h.start=h.end),{content:l,selection:h}}const Bf=["address","col","contents","format","row","type"],zf={description:Fo("Gets information about a cell."),args:[Dh("info_type (string)",Fo("The type of information requested. Can be one of %s",Bf.join(", "))),Dh("reference (meta)",Fo("The reference to the cell."))],compute:function(e,t){const o=qi(e).toLowerCase();Pi((()=>Bf.includes(o)),Fo("The info_type should be one of %s.",Bf.join(", ")));const s=this.__originSheetId,i=qi(t),n=i.includes(":")?i.split(":")[0]:i;let{sheetName:r,xc:a}=qo(n);r=r===this.getters.getSheetName(s)?void 0:r;const l=Zo(r,Hf(a,"colrow")),c=this.getters.getRangeFromSheetXC(s,l);switch(o){case"address":return this.getters.getRangeString(c,s);case"col":return c.zone.left+1;case"contents":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).value}case"format":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).format||""}case"row":return c.zone.top+1;case"type":{const e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top},t=this.getters.getEvaluatedCell(e).type;return t===ni.empty?"b":t===ni.text?"l":"v"}}return""},isExported:!0},$f={description:Fo("Whether a value is an error other than #N/A."),args:[Dh("value (any)",Fo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return ki(t)&&t!==Ii.NotAvailable},isExported:!0},Wf={description:Fo("Whether a value is an error."),args:[Dh("value (any)",Fo("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return ki(t)},isExported:!0},Gf={description:Fo("Whether a value is `true` or `false`."),args:[Dh("value (any)",Fo("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},qf={description:Fo("Whether a value is the error #N/A."),args:[Dh("value (any)",Fo("The value to be verified as an error type."))],compute:function(e){return e?.value===Ii.NotAvailable},isExported:!0},Zf={description:Fo("Whether a value is non-textual."),args:[Dh("value (any)",Fo("The value to be checked."))],compute:function(e){return!Yf.compute.bind(this)(e)},isExported:!0},jf={description:Fo("Whether a value is a number."),args:[Dh("value (any)",Fo("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},Yf={description:Fo("Whether a value is text."),args:[Dh("value (any)",Fo("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===ki(e?.value)},isExported:!0},Xf={description:Fo("Whether the referenced cell is empty"),args:[Dh("value (any)",Fo("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},Kf={description:Fo("Returns the error value #N/A."),args:[],compute:function(){return{value:Ii.NotAvailable}},isExported:!0};var Jf=Object.freeze({__proto__:null,CELL:zf,ISBLANK:Xf,ISERR:$f,ISERROR:Wf,ISLOGICAL:Gf,ISNA:qf,ISNONTEXT:Zf,ISNUMBER:jf,ISTEXT:Yf,NA:Kf});const Qf={description:Fo("Logical `and` operator."),args:[Dh("logical_expression1 (boolean, range<boolean>)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE, or an expression that can be coerced to a logical value.")),Dh("logical_expression2 (boolean, range<boolean>, repeating)",Fo("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Wa(e);return Pi((()=>o),Fo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},ev={description:Fo("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},tv={description:Fo("Returns value depending on logical expression."),args:[Dh("logical_expression (boolean)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),Dh("value_if_true (any)",Fo("The value the function returns if logical_expression is TRUE.")),Dh("value_if_false (any, default=FALSE)",Fo("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){const s=Yi(e?.value)?t:o;return void 0===s?{value:""}:(null===s.value&&(s.value=""),s)},isExported:!0},ov={description:Fo("Value if it is not an error, otherwise 2nd argument."),args:[Dh("value (any)",Fo("The value to return if value itself is not an error.")),Dh('value_if_error (any, default="empty")',Fo("The value the function returns if value is an error."))],compute:function(e,t={value:""}){const o=ki(e?.value)?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},sv={description:Fo("Value if it is not an #N/A error, otherwise 2nd argument."),args:[Dh("value (any)",Fo("The value to return if value itself is not #N/A an error.")),Dh('value_if_error (any, default="empty")',Fo("The value the function returns if value is an #N/A error."))],compute:function(e,t={value:""}){const o=e?.value===Ii.NotAvailable?t:e;return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)},isExported:!0},iv={description:Fo("Returns a value depending on multiple logical expressions."),args:[Dh("condition1 (boolean)",Fo("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),Dh("value1 (any)",Fo("The returned value if condition1 is TRUE.")),Dh("condition2 (boolean, any, repeating)",Fo("Additional conditions to be evaluated if the previous ones are FALSE.")),Dh("value2 (any, repeating)",Fo("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){Pi((()=>e.length%2==0),Fo("Wrong number of arguments. Expected an even number of arguments."));for(let t=0;t<e.length-1;t+=2)if(Yi(e[t]?.value)){const o=e[t+1];return void 0===o?{value:""}:(null===o.value&&(o.value=""),o)}return new Ti(Fo("No match."))},isExported:!0},nv={description:Fo("Returns opposite of provided logical value."),args:[Dh("logical_expression (boolean)",Fo("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!Yi(e)},isExported:!0},rv={description:Fo("Logical `or` operator."),args:[Dh("logical_expression1 (boolean, range<boolean>)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE, or an expression that can be coerced to a logical value.")),Dh("logical_expression2 (boolean, range<boolean>, repeating)",Fo("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Ga(e);return Pi((()=>o),Fo("[[FUNCTION_NAME]] has no valid input data.")),t},isExported:!0},av={description:Fo("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},lv={description:Fo("Logical `xor` operator."),args:[Dh("logical_expression1 (boolean, range<boolean>)",Fo("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE, or an expression that can be coerced to a logical value.")),Dh("logical_expression2 (boolean, range<boolean>, repeating)",Fo("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return cn(e,(e=>(t=!0,o=o?!e:e,!0))),Pi((()=>t),Fo("[[FUNCTION_NAME]] has no valid input data.")),o},isExported:!0};var cv=Object.freeze({__proto__:null,AND:Qf,FALSE:ev,IF:tv,IFERROR:ov,IFNA:sv,IFS:iv,NOT:nv,OR:rv,TRUE:av,XOR:lv});function hv(e,t){const o=t.getPivotId(e);if(!o)throw new Ti(Fo('There is no pivot with id "%s"',e));return o}function dv(e){if(e.length%2!=0)throw new Ti(Fo("Function PIVOT takes an even number of arguments."))}function uv(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,n=Jo(i),r=e.getters.getRangeFromSheetXC(o,n);if(void 0===r||r.invalidXc||r.invalidSheetName)throw new _i;s.push(r)}for(const t of o)if(t.computedBy){const o=e.getters.getMeasureCompiledFormula(t);s.push(...o.dependencies.filter((e=>!e.invalidXc)))}const i=e.__originCellPosition;i&&s.length&&(e.updateDependencies?.(i),e.addDependencies?.(i,s))}const gv=!0;function pv(e){return{value:Ii.NotAvailable,message:Fo("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",qi(e))}}const mv={description:Fo("Returns a cell reference as a string. "),args:[Dh("row (number)",Fo("The row number of the cell reference. ")),Dh("column (number)",Fo("The column number (not name) of the cell reference. A is column number 1. ")),Dh("absolute_relative_mode (number, default=1)",Fo("An indicator of whether the reference is row/column absolute. 1 is row and column absolute (e.g. $A$1), 2 is row absolute and column relative (e.g. A$1), 3 is row relative and column absolute (e.g. $A1), and 4 is row and column relative (e.g. A1).")),Dh("use_a1_notation (boolean, default=TRUE)",Fo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).")),Dh("sheet (string, optional)",Fo("A string indicating the name of the sheet into which the address points."))],compute:function(e,t,o={value:1},s={value:!0},i){const n=$i(e,this.locale),r=$i(t,this.locale);Wi(n),Wi(r);const a=$i(o,this.locale);var l,c;Pi((()=>[1,2,3,4].includes(a)),(l=4,c=a,Fo("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));let h;if(Yi(s)){h=yo(r-1,n-1,{rowFixed:[1,2].includes(a),colFixed:[1,3].includes(a)})}else{h=([1,2].includes(a)?`R${n}`:`R[${n}]`)+([1,3].includes(a)?`C${r}`:`C[${r}]`)}return void 0!==i?Zo(qi(i),h):h},isExported:!0},fv={description:Fo("Column number of a specified cell."),args:[Dh("cell_reference (meta, default='this cell')",Fo("The cell whose column number will be returned. Column A corresponds to 1. By default, the function use the cell in which the formula is entered."))],compute:function(e){if(ki(e?.value))return e;const t=void 0===e?this.__originCellPosition?.col:Yo(e.value).left;return Pi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},vv={description:Fo("Number of columns in a specified array or range."),args:[Dh("range (meta)",Fo("The range whose column count will be returned."))],compute:function(e){if(ki(e?.value))return e;const t=Yo(e.value);return t.right-t.left+1},isExported:!0},bv={description:Fo("Horizontal lookup"),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("range (any, range)",Fo("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),Dh("index (number)",Fo("The row index of the value to be returned, where the first row in range is numbered 1.")),Dh("is_sorted (boolean, default=true)",Fo("Indicates whether the row to be searched (the first row of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:gv}){const i=Math.trunc(Vi(o?.value,this.locale)),n=bn(t);Pi((()=>1<=i&&i<=n[0].length),Fo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[t][0].value,a=Yi(s.value)?pn(n,e,"nextSmaller","asc",n.length,r):mn(n,e,"wildcard",n.length,r),l=n[a];return void 0===l?pv(e):l[i-1]},isExported:!0},Sv={description:Fo("Returns the content of a cell, specified by row and column offset."),args:[Dh("reference (any, range)",Fo("The range of cells from which the values are returned.")),Dh("row (number, default=0)",Fo("The index of the row to be returned from within the reference range of cells.")),Dh("column (number, default=0)",Fo("The index of the column to be returned from within the reference range of cells."))],compute:function(e,t={value:0},o={value:0}){const s=bn(e),i=Vi(t.value,this.locale),n=Vi(o.value,this.locale);return Pi((()=>n>=0&&n-1<s.length&&i>=0&&i-1<s[0].length),Fo("Index out of range.")),0===i&&0===n?s:0===i?[s[n-1]]:0===n?s.map((e=>[e[i-1]])):s[n-1][i-1]},isExported:!0},yv={description:Fo("Returns the content of a cell, specified by a string."),args:[Dh("reference (string)",Fo("The range of cells from which the values are returned.")),Dh("use_a1_notation (boolean, default=TRUE)",Fo("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."))],compute:function(e,t={value:!0}){let o=e?.value?.toString();if(!o)return new _i(Fo("Reference should be defined."));if(!Yi(t))return new Ti(Fo("R1C1 notation is not supported."));const s=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);const n=this.getters.getRangeFromSheetXC(s,o);if(void 0===n||n.invalidXc||n.invalidSheetName)return new _i;i&&this.addDependencies?.(i,[n]);const r=[];for(let e=n.zone.left;e<=n.zone.right;e++){const t=[];for(let o=n.zone.top;o<=n.zone.bottom;o++){const s={sheetId:n.sheetId,col:e,row:o};t.push(this.getters.getEvaluatedCell(s))}r.push(t)}return 1===r.length&&1===r[0].length?r[0][0]:r},isExported:!0},Cv={description:Fo("Look up a value."),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("search_array (any, range)",Fo("One method of using this function is to provide a single sorted row or column search_array to look through for the search_key with a second argument result_range. The other way is to combine these two arguments into one search_array where the first row or column is searched and a value is returned from the last row or column in the array. If search_key is not found, a non-exact match may be returned.")),Dh("result_range (any, range, optional)",Fo("The range from which to return a result. The value returned corresponds to the location where search_key is found in search_range. This range must be only a single row or column and should not be used if using the search_result_array method."))],compute:function(e,t,o){const s=bn(t),i=bn(o);let n=s.length,r=s[0].length;const a=r>=n,l=a?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=pn(s,e,"nextSmaller","asc",a?r:n,l);return-1===c||a&&void 0===s[0][c]||!a&&void 0===s[c][r-1]?pv(e):0===i[0].length?a?s[n-1][c]:s[c][r-1]:(n=i.length,r=i[0].length,Pi((()=>1===n||1===r),Fo("The result_range must be a single row or a single column.")),n>1?(Pi((()=>c<=n-1),Fo("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",(c+1).toString())),i[c][0]):(Pi((()=>c<=r-1),Fo("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",(c+1).toString())),i[0][c]))},isExported:!0},wv={description:Fo("Position of item in range that matches value."),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("range (any, range)",Fo("The one-dimensional array to be searched.")),Dh("search_type (number, default=1)",Fo("The search method. 1 (default) finds the largest value less than or equal to search_key when range is sorted in ascending order. 0 finds the exact value when range is unsorted. -1 finds the smallest value greater than or equal to search_key when range is sorted in descending order."))],compute:function(e,t,o={value:1}){let s=Vi(o,this.locale);const i=bn(t),n=i.length,r=i[0].length;Pi((()=>1===n||1===r),Fo("The range must be a single row or a single column."));let a=-1;const l=1===n?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,c=1===n?i[0].length:i.length;switch(s=Math.sign(s),s){case 1:a=pn(i,e,"nextSmaller","asc",c,l);break;case 0:a=mn(i,e,"wildcard",c,l);break;case-1:a=pn(i,e,"nextGreater","desc",c,l)}return 1===n&&void 0===i[0][a]||1!==n&&void 0===i[a]?pv(e):a+1},isExported:!0},xv={description:Fo("Row number of a specified cell."),args:[Dh("cell_reference (meta, default='this cell')",Fo("The cell whose row number will be returned. By default, this function uses the cell in which the formula is entered."))],compute:function(e){if(ki(e?.value))return e;const t=void 0===e?this.__originCellPosition?.row:Yo(e.value).top;return Pi((()=>void 0!==t),"In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter."),t+1},isExported:!0},Ev={description:Fo("Number of rows in a specified array or range."),args:[Dh("range (meta)",Fo("The range whose row count will be returned."))],compute:function(e){if(ki(e?.value))return e;const t=Yo(e.value);return t.bottom-t.top+1},isExported:!0},Iv={description:Fo("Vertical lookup."),args:[Dh("search_key (string, number, boolean)",Fo("The value to search for. For example, 42, 'Cats', or I24.")),Dh("range (any, range)",Fo("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),Dh("index (number)",Fo("The column index of the value to be returned, where the first column in range is numbered 1.")),Dh("is_sorted (boolean, default=true)",Fo("Indicates whether the column to be searched (the first column of the specified range) is sorted, in which case the closest match for search_key will be returned."))],compute:function(e,t,o,s={value:gv}){const i=Math.trunc(Vi(o?.value,this.locale)),n=bn(t);Pi((()=>1<=i&&i<=n.length),Fo("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[0][t].value,a=Yi(s.value)?pn(n,e,"nextSmaller","asc",n[0].length,r):mn(n,e,"wildcard",n[0].length,r),l=n[i-1][a];return void 0===l?pv(e):l},isExported:!0},Rv={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},Tv={description:Fo("Search a range for a match and return the corresponding item from a second range."),args:[Dh("search_key (string,number,boolean)",Fo("The value to search for.")),Dh("lookup_range (any, range)",Fo("The range to consider for the search. Should be a single column or a single row.")),Dh("return_range (any, range)",Fo("The range containing the return value. Should have the same dimensions as lookup_range.")),Dh("if_not_found (any, optional)",Fo("If a valid match is not found, return this value.")),Dh("match_mode (any, default=0)",Fo("(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.")),Dh("search_mode (any, default=1)",Fo("(1) Search starting at first item. (-1) Search starting at last item. (2) Perform a binary search that relies on lookup_array being sorted in ascending order. If not sorted, invalid results will be returned. (-2) Perform a binary search that relies on lookup_array being sorted in descending order. If not sorted, invalid results will be returned. "))],compute:function(e,t,o,s,i={value:0},n={value:1}){const r=Math.trunc(Vi(i.value,this.locale)),a=Math.trunc(Vi(n.value,this.locale)),l=bn(t),c=bn(o);Pi((()=>1===l.length||1===l[0].length),Fo("lookup_range should be either a single row or single column.")),Pi((()=>[-1,1,-2,2].includes(a)),Fo("search_mode should be a value in [-1, 1, -2, 2].")),Pi((()=>[-1,0,1,2].includes(r)),Fo("match_mode should be a value in [-1, 0, 1, 2]."));const h=1===l.length?"col":"row";Pi((()=>!(2===r&&[-2,2].includes(a))),Fo("the search and match mode combination is not supported for XLOOKUP evaluation.")),Pi((()=>"col"===h?c[0].length===l[0].length:c.length===l.length),Fo("return_range should have the same dimensions as lookup_range."));const d="col"===h?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,u="col"===h?l[0].length:l.length,g=Rv[r],p=-1===a,m=2===a||-2===a?pn(l,e,g,2===a?"asc":"desc",u,d):mn(l,e,g,u,d,p);return-1!==m?"col"===h?c.map((e=>[e[m]])):[c[m]]:void 0===s?pv(e):[[s]]},isExported:!0},Av={description:Fo("Get the value from a pivot."),args:[Dh("pivot_id (number,string)",Fo("ID of the pivot.")),Dh("measure_name (string)",Fo("Name of the measure.")),Dh("domain_field_name (string,optional,repeating)",Fo("Field name.")),Dh("domain_value (number,string,boolean,optional,repeating)",Fo("Value."))],compute:function(e,t,...o){const s=qi(e),i=qi(t),n=hv(s,this.getters);!function(e,t,o){const{measures:s}=o.getPivotCoreDefinition(e);if(!s.find((e=>e.id===t))){const e=`(${s.map((e=>e.id)).join(", ")})`;throw new Ti(Fo("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(n,i,this.getters),dv(o);const r=this.getters.getPivot(n),a=this.getters.getPivotCoreDefinition(n);uv(this,a,a.measures.filter((e=>e.id===i))),r.init({reload:r.needsReevaluation});const l=r.assertIsValid({throwOnError:!1});if(l)return l;if(!r.areDomainArgsFieldsValid(o)){const e=Fo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:Ii.GenericError,message:Fo("Dimensions don't match the pivot definition")+". "+e}}const c=r.parseArgsToPivotDomain(o);return r.getPivotCellValueAndFormat(i,c)}},_v={description:Fo("Get the header of a pivot."),args:[Dh("pivot_id (number,string)",Fo("ID of the pivot.")),Dh("domain_field_name (string,optional,repeating)",Fo("Field name.")),Dh("domain_value (number,string,value,optional,repeating)",Fo("Value."))],compute:function(e,...t){const o=qi(e),s=hv(o,this.getters);dv(t);const i=this.getters.getPivot(s);uv(this,this.getters.getPivotCoreDefinition(s),[]),i.init({reload:i.needsReevaluation});const n=i.assertIsValid({throwOnError:!1});if(n)return n;if(!i.areDomainArgsFieldsValid(t)){const e=Fo("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:Ii.GenericError,message:Fo("Dimensions don't match the pivot definition")+". "+e}}const r=i.parseArgsToPivotDomain(t),a=r.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(qi(a.value),r);const{value:l,format:c}=i.getPivotHeaderValueAndFormat(r);return{value:l,format:a&&"measure"!==a.field&&"false"!==a.value?c:void 0}}},Dv={description:Fo("Get a pivot table."),args:[Dh("pivot_id (string)",Fo("ID of the pivot.")),Dh("row_count (number, optional)",Fo("number of rows")),Dh("include_total (boolean, default=TRUE)",Fo("Whether to include total/sub-totals or not.")),Dh("include_column_titles (boolean, default=TRUE)",Fo("Whether to include the column titles or not.")),Dh("column_count (number, optional)",Fo("number of columns"))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE}){const n=qi(e),r=Vi(t,this.locale);if(r<0)return new Ti(Fo("The number of rows must be positive."));const a=Vi(i,this.locale);if(a<0)return new Ti(Fo("The number of columns must be positive."));const l=Yi(s),c=Yi(o),h=hv(n,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);uv(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getTableStructure(),m=p.getPivotCells(c,l),f=l?p.columns.length:0,v=this.getters.getPivotDisplayName(h),b=Math.min(f+r,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+a,m.length),y=[];for(const e of Ze(0,S)){y[e]=[];for(const t of Ze(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":y[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);y[e].push(rc(d,o.domain,t));break;case"MEASURE_HEADER":y[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":y[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}return l&&(y[0][0]={value:v}),y}},Ov={description:Fo("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[Dh("cell_reference (meta)",Fo("The starting point from which to count the offset rows and columns.")),Dh("offset_rows (number)",Fo("The number of rows to offset by.")),Dh("offset_columns (number)",Fo("The number of columns to offset by.")),Dh("height (number, default='height of cell_reference')",Fo("The number of rows of the range to return starting at the offset target.")),Dh("width (number, default='width of cell_reference')",Fo("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(ki(e?.value))return e;const n=e?.value;if(!n)throw new Error("In this context, the function OFFSET needs to have a cell or range in parameter.");const r=Yo(n);let a=r.bottom-r.top+1,l=r.right-r.left+1;if(s){const e=Vi(s,this.locale);Ph(Fo("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}),e),a=e}if(i){const e=Vi(i,this.locale);Ph(Fo("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}),e),l=e}const{sheetName:c}=qo(n),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=Vi(t,this.locale),u=Vi(o,this.locale),g=this.__originCellPosition;g&&this.updateDependencies?.(g);const p=r.left+u,m=r.top+d;if(p<0||m<0)return new _i(Fo("OFFSET evaluates to an out of bounds range."));const f={left:p,top:m,right:p+l-1,bottom:m+a-1},v=this.getters.getRangeFromZone(this.__originSheetId,f);return v.invalidXc||v.invalidSheetName?new _i:(g&&this.addDependencies?.(g,[v]),rn(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var Fv=Object.freeze({__proto__:null,ADDRESS:mv,COLUMN:fv,COLUMNS:vv,HLOOKUP:bv,INDEX:Sv,INDIRECT:yv,LOOKUP:Cv,MATCH:wv,OFFSET:Ov,PIVOT:Dv,PIVOT_HEADER:_v,PIVOT_VALUE:Av,ROW:xv,ROWS:Ev,VLOOKUP:Iv,XLOOKUP:Tv});const Mv={description:Fo("Sum of two numbers."),args:[Dh("value1 (number)",Fo("The first addend.")),Dh("value2 (number)",Fo("The second addend."))],compute:function(e,t){return{value:Vi(e,this.locale)+Vi(t,this.locale),format:e?.format||t?.format}}},Pv={description:Fo("Concatenation of two values."),args:[Dh("value1 (string)",Fo("The value to which value2 will be appended.")),Dh("value2 (string)",Fo("The value to append to value1."))],compute:function(e,t){return qi(e)+qi(t)},isExported:!0},Nv={description:Fo("One number divided by another."),args:[Dh("dividend (number)",Fo("The number to be divided.")),Dh("divisor (number)",Fo("The number to divide by."))],compute:function(e,t){const o=Vi(t,this.locale);return Pi((()=>0!==o),Fo("The divisor must be different from zero."),Ii.DivisionByZero),{value:Vi(e,this.locale)/o,format:e?.format||t?.format}}};function kv(e){return void 0===e||null===e.value}const Lv={number:0,string:"",boolean:!1},Vv={description:Fo("Equal."),args:[Dh("value1 (string, number, boolean)",Fo("The first value.")),Dh("value2 (string, number, boolean)",Fo("The value to test against value1 for equality."))],compute:function(e,t){if(ki(e?.value))return e;if(ki(t?.value))return t;let o=kv(e)?Lv[typeof t?.value]:e?.value,s=kv(t)?Lv[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),{value:o===s}}};function Hv(e,t,o){if(ki(e?.value))return e;if(ki(t?.value))return t;let s=kv(e)?Lv[typeof t?.value]:e?.value,i=kv(t)?Lv[typeof e?.value]:t?.value;"number"!=typeof s&&(s=qi(s).toUpperCase()),"number"!=typeof i&&(i=qi(i).toUpperCase());const n=typeof s,r=typeof i;return"string"===n&&"number"===r?{value:!0}:"string"===r&&"number"===n?{value:!1}:{value:o(s,i)}}const Uv={description:Fo("Strictly greater than."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being greater than value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){return Hv(e,t,((e,t)=>e>t))}},Bv={description:Fo("Greater than or equal to."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being greater than or equal to value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){return Hv(e,t,((e,t)=>e>=t))}},zv={description:Fo("Less than."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being less than value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){const o=Bv.compute.bind(this)(e,t);return ki(o.value)?o:{value:!o.value}}},$v={description:Fo("Less than or equal to."),args:[Dh("value1 (number, string, boolean)",Fo("The value to test as being less than or equal to value2.")),Dh("value2 (number, string, boolean)",Fo("The second value."))],compute:function(e,t){const o=Uv.compute.bind(this)(e,t);return ki(o.value)?o:{value:!o.value}}},Wv={description:Fo("Difference of two numbers."),args:[Dh("value1 (number)",Fo("The minuend, or number to be subtracted from.")),Dh("value2 (number)",Fo("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:Vi(e,this.locale)-Vi(t,this.locale),format:e?.format||t?.format}}},Gv={description:Fo("Product of two numbers"),args:[Dh("factor1 (number)",Fo("The first multiplicand.")),Dh("factor2 (number)",Fo("The second multiplicand."))],compute:function(e,t){return{value:Vi(e,this.locale)*Vi(t,this.locale),format:e?.format||t?.format}}},qv={description:Fo("Not equal."),args:[Dh("value1 (string, number, boolean)",Fo("The first value.")),Dh("value2 (string, number, boolean)",Fo("The value to test against value1 for inequality."))],compute:function(e,t){const o=Vv.compute.bind(this)(e,t);return ki(o.value)?o:{value:!o.value}}},Zv={description:Fo("A number raised to a power."),args:[Dh("base (number)",Fo("The number to raise to the exponent power.")),Dh("exponent (number)",Fo("The exponent to raise base to."))],compute:function(e,t){return Kd.compute.bind(this)(e,t)}},jv={description:Fo("A number with the sign reversed."),args:[Dh("value (number)",Fo("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-Vi(e,this.locale),format:e?.format}}},Yv={description:Fo("Value interpreted as a percentage."),args:[Dh("percentage (number)",Fo("The value to interpret as a percentage."))],compute:function(e){return Vi(e,this.locale)/100}},Xv={description:Fo("A specified number, unchanged."),args:[Dh("value (any)",Fo("The number to return."))],compute:function(e={value:null}){return e}};var Kv=Object.freeze({__proto__:null,ADD:Mv,CONCAT:Pv,DIVIDE:Nv,EQ:Vv,GT:Uv,GTE:Bv,LT:zv,LTE:$v,MINUS:Wv,MULTIPLY:Gv,NE:qv,POW:Zv,UMINUS:jv,UNARY_PERCENT:Yv,UPLUS:Xv});const Jv=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),Qv={transform:e=>e,inverseTransform:e=>e},eb=1e-10,tb=.0254,ob=tb/72,sb=.3048,ib=.9144,nb=1609.34,rb=1852,ab=946073047258e4,lb={g:{...Qv,category:"weight"},u:{...Jv(166053e-29),category:"weight"},grain:{...Jv(.0647989),category:"weight"},ozm:{...Jv(28.3495),category:"weight"},lbm:{...Jv(453.592),category:"weight"},stone:{...Jv(6350.29),category:"weight"},sg:{...Jv(14593.90294),category:"weight"},cwt:{...Jv(45359.237),category:"weight"},uk_cwt:{...Jv(50802.3),category:"weight"},ton:{...Jv(907184.74),category:"weight"},uk_ton:{...Jv(1016046.9),category:"weight"},m:{...Qv,category:"distance"},km:{...Jv(1e3),category:"distance"},ang:{...Jv(eb),category:"distance"},Picapt:{...Jv(ob),category:"distance"},pica:{...Jv(tb/6),category:"distance"},in:{...Jv(tb),category:"distance"},ft:{...Jv(sb),category:"distance"},yd:{...Jv(ib),category:"distance"},ell:{...Jv(1.143),category:"distance"},mi:{...Jv(nb),category:"distance"},survey_mi:{...Jv(1609.34),category:"distance"},Nmi:{...Jv(rb),category:"distance"},ly:{...Jv(ab),category:"distance"},parsec:{...Jv(0x6da012f95c9fd0),category:"distance"},sec:{...Qv,category:"time"},min:{...Jv(60),category:"time"},hr:{...Jv(3600),category:"time"},day:{...Jv(86400),category:"time"},yr:{...Jv(31556952),category:"time"},Pa:{...Qv,category:"pressure"},bar:{...Jv(1e5),category:"pressure"},mmHg:{...Jv(133.322),category:"pressure"},Torr:{...Jv(133.322),category:"pressure"},psi:{...Jv(6894.76),category:"pressure"},atm:{...Jv(101325),category:"pressure"},N:{...Qv,category:"force"},dyn:{...Jv(1e-5),category:"force"},pond:{...Jv(.00980665),category:"force"},lbf:{...Jv(4.44822),category:"force"},J:{...Qv,category:"energy"},eV:{...Jv(160218e-24),category:"energy"},e:{...Jv(1e-7),category:"energy"},flb:{...Jv(1.3558179483),category:"energy"},c:{...Jv(4.184),category:"energy"},cal:{...Jv(4.1868),category:"energy"},BTU:{...Jv(1055.06),category:"energy"},Wh:{...Jv(3600),category:"energy"},HPh:{...Jv(2684520),category:"energy"},W:{...Qv,category:"power"},PS:{...Jv(735.499),category:"power"},HP:{...Jv(745.7),category:"power"},T:{...Qv,category:"magnetism"},ga:{...Jv(1e-4),category:"magnetism"},K:{...Qv,category:"temperature"},C:{transform:e=>e+273.15,inverseTransform:e=>e-273.15,category:"temperature"},F:{transform:e=>5*(e-32)/9+273.15,inverseTransform:e=>9*(e-273.15)/5+32,category:"temperature"},Rank:{...Jv(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...Qv,category:"volume",order:3},"ang^3":{...Jv(Math.pow(eb,3)),category:"volume",order:3},"Picapt^3":{...Jv(Math.pow(ob,3)),category:"volume",order:3},tsp:{...Jv(492892e-11),category:"volume"},tspm:{...Jv(5e-6),category:"volume"},tbs:{...Jv(14786764825785619e-21),category:"volume"},"in^3":{...Jv(Math.pow(tb,3)),category:"volume",order:3},oz:{...Jv(295735295625e-16),category:"volume"},cup:{...Jv(237e-6),category:"volume"},pt:{...Jv(.0004731765),category:"volume"},uk_pt:{...Jv(568261e-9),category:"volume"},qt:{...Jv(.0009463529),category:"volume"},l:{...Jv(.001),category:"volume"},uk_qt:{...Jv(.0011365225),category:"volume"},gal:{...Jv(.0037854118),category:"volume"},uk_gal:{...Jv(.00454609),category:"volume"},"ft^3":{...Jv(Math.pow(sb,3)),category:"volume",order:3},bushel:{...Jv(.0352390704),category:"volume"},barrel:{...Jv(.158987295),category:"volume"},"yd^3":{...Jv(Math.pow(ib,3)),category:"volume",order:3},MTON:{...Jv(1.13267386368),category:"volume"},GRT:{...Jv(2.83168),category:"volume"},"mi^3":{...Jv(Math.pow(nb,3)),category:"volume",order:3},"Nmi^3":{...Jv(Math.pow(rb,3)),category:"volume",order:3},"ly^3":{...Jv(Math.pow(ab,3)),category:"volume",order:3},"m^2":{...Qv,category:"area",order:2},"ang^2":{...Jv(Math.pow(eb,2)),category:"area",order:2},"Picapt^2":{...Jv(Math.pow(ob,2)),category:"area",order:2},"in^2":{...Jv(Math.pow(tb,2)),category:"area",order:2},"ft^2":{...Jv(Math.pow(sb,2)),category:"area",order:2},"yd^2":{...Jv(Math.pow(ib,2)),category:"area",order:2},ar:{...Jv(100),category:"area"},Morgen:{...Jv(2500),category:"area"},uk_acre:{...Jv(4046.8564224),category:"area"},us_acre:{...Jv(4046.8726098743),category:"area"},ha:{...Jv(1e4),category:"area"},"mi^2":{...Jv(Math.pow(nb,2)),category:"area",order:2},"Nmi^2":{...Jv(Math.pow(rb,2)),category:"area",order:2},"ly^2":{...Jv(Math.pow(ab,2)),category:"area",order:2},bit:{...Qv,category:"information"},byte:{...Jv(8),category:"information"},"m/s":{...Qv,category:"speed"},"m/hr":{...Jv(1/3600),category:"speed"},"km/hr":{...Jv(1/3.6),category:"speed"},mph:{...Jv(.44704),category:"speed"},kn:{...Jv(.5144444444),category:"speed"},admkn:{...Jv(.5147733333),category:"speed"}},cb={shweight:"cwt",lcwt:"uk_cwt",hweight:"uk_cwt",LTON:"uk_ton",brton:"uk_ton",pc:"parsec",Pica:"Picapt",d:"day",mn:"min",s:"sec",p:"Pa",at:"atm",dy:"dyn",ev:"eV",hh:"HPh",wh:"Wh",btu:"BTU",h:"HP",cel:"C",fah:"F",kel:"K",us_pt:"pt",L:"l",lt:"l",ang3:"ang^3",ft3:"ft^3",in3:"in^3",ly3:"ly^3",m3:"m^3",mi3:"mi^3",yd3:"yd^3",Nmi3:"Nmi^3",Picapt3:"Picapt^3","Pica^3":"Picapt^3",Pica3:"Picapt^3",regton:"GRT",ang2:"ang^2",ft2:"ft^2",in2:"in^2",ly2:"ly^2",m2:"m^2",mi2:"mi^2",Nmi2:"Nmi^2",Picapt2:"Picapt^2","Pica^2":"Picapt^2",Pica2:"Picapt^2",yd2:"yd^2","m/h":"m/hr","m/sec":"m/s"},hb={"":1,Y:1e24,Z:1e21,E:1e18,P:1e15,T:1e12,G:1e9,M:1e6,k:1e3,h:100,da:10,e:10,d:.1,c:.01,m:.001,u:1e-6,n:1e-9,p:1e-12,f:1e-15,a:1e-18,z:1e-21,y:1e-21,Yi:Math.pow(2,80),Zi:Math.pow(2,70),Ei:Math.pow(2,60),Pi:Math.pow(2,50),Ti:Math.pow(2,40),Gi:Math.pow(2,30),Mi:Math.pow(2,20),ki:Math.pow(2,10)},db={weight:Fo("Weight"),distance:Fo("Distance"),time:Fo("Time"),pressure:Fo("Pressure"),force:Fo("Force"),energy:Fo("Energy"),power:Fo("Power"),magnetism:Fo("Magnetism"),temperature:Fo("Temperature"),volume:Fo("Volume"),area:Fo("Area"),information:Fo("Information"),speed:Fo("Speed")};function ub(e){return db[e]??""}function gb(e){for(const[t,o]of Object.entries(hb)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=lb[s];if(!i&&cb[s]&&(i=lb[cb[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const pb={description:Fo("Converts a numeric value to a different unit of measure."),args:[Dh("value (number)",Fo("the numeric value in start_unit to convert to end_unit")),Dh("start_unit (string)",Fo("The starting unit, the unit currently assigned to value")),Dh("end_unit (string)",Fo("The unit of measure into which to convert value"))],compute:function(e,t,o){const s=Vi(e,this.locale),i=qi(t),n=qi(o),r=gb(i),a=gb(n);return r?a?r.category!==a.category?{value:Ii.GenericError,message:Fo("Incompatible units of measure ('%s' vs '%s')",ub(r.category),ub(a.category))}:{value:a.inverseTransform(r.factor*r.transform(s))/a.factor,format:e?.format}:{value:Ii.GenericError,message:Fo("Invalid units of measure ('%s')",n)}:{value:Ii.GenericError,message:Fo("Invalid units of measure ('%s')",i)}},isExported:!0};var mb=Object.freeze({__proto__:null,CONVERT:pb});const fb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,vb={description:Fo("Gets character associated with number."),args:[Dh("table_number (number)",Fo("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(Vi(e,this.locale));return Pi((()=>t>=1),Fo("The table_number (%s) is out of range.",t.toString())),String.fromCharCode(t)},isExported:!0},bb={description:Fo("Remove non-printable characters from a piece of text."),args:[Dh("text (string)",Fo("The text whose non-printable characters are to be removed."))],compute:function(e){const t=qi(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},Sb={description:Fo("Appends strings to one another."),args:[Dh("string1 (string, range<string>)",Fo("The initial string.")),Dh("string2 (string, range<string>, repeating)",Fo("More strings to append in sequence."))],compute:function(...e){return on(e,((e,t)=>e+qi(t)),"")},isExported:!0},yb={description:Fo("Tests whether two strings are identical."),args:[Dh("string1 (string)",Fo("The first string to compare.")),Dh("string2 (string)",Fo("The second string to compare."))],compute:function(e,t){return qi(e)===qi(t)},isExported:!0},Cb={description:Fo("First position of string found in text, case-sensitive."),args:[Dh("search_for (string)",Fo("The string to look for within text_to_search.")),Dh("text_to_search (string)",Fo("The text to search for the first occurrence of search_for.")),Dh("starting_at (number, default=1)",Fo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=qi(e),i=qi(t),n=Vi(o,this.locale);Pi((()=>""!==i),Fo("The text_to_search must be non-empty.")),Pi((()=>n>=1),Fo("The starting_at (%s) must be greater than or equal to 1.",n.toString()));const r=i.indexOf(s,n-1);return Pi((()=>r>=0),Fo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s.toString(),i)),r+1},isExported:!0},wb={description:Fo("Concatenates elements of arrays with delimiter."),args:[Dh("delimiter (string)",Fo("The character or string to place between each concatenated value.")),Dh("value_or_array1 (string, range<string>)",Fo("The value or values to be appended using delimiter.")),Dh("value_or_array2 (string, range<string>, repeating)",Fo("More values to be appended using delimiter."))],compute:function(e,...t){const o=qi(e);return on(t,((e,t)=>(e?e+o:"")+qi(t)),"")}},xb={description:Fo("Substring from beginning of specified string."),args:[Dh("text (string)",Fo("The string from which the left portion will be returned.")),Dh("number_of_characters (number, optional)",Fo("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?Vi(t[0],this.locale):1;return Pi((()=>o>=0),Fo("The number_of_characters (%s) must be positive or null.",o.toString())),qi(e).substring(0,o)},isExported:!0},Eb={description:Fo("Length of a string."),args:[Dh("text (string)",Fo("The string whose length will be returned."))],compute:function(e){return qi(e).length},isExported:!0},Ib={description:Fo("Converts a specified string to lowercase."),args:[Dh("text (string)",Fo("The string to convert to lowercase."))],compute:function(e){return qi(e).toLowerCase()},isExported:!0},Rb={description:Fo("A segment of a string."),args:[Dh("text (string)",Fo("The string to extract a segment from.")),Dh("starting_at (number)",Fo("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),Dh("extract_length (number)",Fo("The length of the segment to extract."))],compute:function(e,t,o){const s=qi(e),i=Vi(t,this.locale),n=Vi(o,this.locale);return Pi((()=>i>=1),Fo("The starting_at argument (%s) must be positive greater than one.",i.toString())),Pi((()=>n>=0),Fo("The extract_length argument (%s) must be positive or null.",n.toString())),s.slice(i-1,i+n-1)},isExported:!0},Tb={description:Fo("Capitalizes each word in a specified string."),args:[Dh("text_to_capitalize (string)",Fo("The text which will be returned with the first letter of each word in uppercase and all other letters in lowercase."))],compute:function(e){return qi(e).replace(fb,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},Ab={description:Fo("Replaces part of a text string with different text."),args:[Dh("text (string)",Fo("The text, a part of which will be replaced.")),Dh("position (number)",Fo("The position where the replacement will begin (starting from 1).")),Dh("length (number)",Fo("The number of characters in the text to be replaced.")),Dh("new_text (string)",Fo("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=Vi(t,this.locale);Pi((()=>i>=1),Fo("The position (%s) must be greater than or equal to 1.",i.toString()));const n=qi(e),r=Vi(o,this.locale),a=qi(s);return n.substring(0,i-1)+a+n.substring(i-1+r)},isExported:!0},_b={description:Fo("A substring from the end of a specified string."),args:[Dh("text (string)",Fo("The string from which the right portion will be returned.")),Dh("number_of_characters (number, optional)",Fo("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?Vi(t[0],this.locale):1;Pi((()=>o>=0),Fo("The number_of_characters (%s) must be positive or null.",o.toString()));const s=qi(e),i=s.length;return s.substring(i-o,i)},isExported:!0},Db={description:Fo("First position of string found in text, ignoring case."),args:[Dh("search_for (string)",Fo("The string to look for within text_to_search.")),Dh("text_to_search (string)",Fo("The text to search for the first occurrence of search_for.")),Dh("starting_at (number, default=1)",Fo("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=qi(e).toLowerCase(),i=qi(t).toLowerCase(),n=Vi(o,this.locale);Pi((()=>""!==i),Fo("The text_to_search must be non-empty.")),Pi((()=>n>=1),Fo("The starting_at (%s) must be greater than or equal to 1.",n.toString()));const r=i.indexOf(s,n-1);return Pi((()=>r>=0),Fo("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)),r+1},isExported:!0},Ob={description:Fo("Split text by specific character delimiter(s)."),args:[Dh("text (string)",Fo("The text to divide.")),Dh("delimiter (string)",Fo("The character or characters to use to split text.")),Dh("split_by_each (boolean, default=true})",Fo("Whether or not to divide text around each character contained in delimiter.")),Dh("remove_empty_text (boolean, default=true)",Fo("Whether or not to remove empty text messages from the split results. The default behavior is to treat consecutive delimiters as one (if TRUE). If FALSE, empty cells values are added between consecutive delimiters."))],compute:function(e,t,o={value:true},s={value:true}){const i=qi(e),n=Ue(qi(t)),r=Yi(o),a=Yi(s);Pi((()=>n.length>0),Fo("The _delimiter (%s) must be not be empty.",n));const l=r?new RegExp(`[${n}]`,"g"):new RegExp(n,"g");let c=i.split(l);return a&&(c=c.filter((e=>""!==e))),ln([c])},isExported:!0},Fb={description:Fo("Replaces existing text with new text in a string."),args:[Dh("text_to_search (string)",Fo("The text within which to search and replace.")),Dh("search_for (string)",Fo("The string to search for within text_to_search.")),Dh("replace_with (string)",Fo("The string that will replace search_for.")),Dh("occurrence_number (number, optional)",Fo("The instance of search_for within text_to_search to replace with replace_with. By default, all occurrences of search_for are replaced; however, if occurrence_number is specified, only the indicated instance of search_for is replaced."))],compute:function(e,t,o,s){const i=Vi(s,this.locale);Pi((()=>i>=0),Fo("The occurrenceNumber (%s) must be positive or null.",i.toString()));const n=qi(e),r=qi(t);if(""===r)return n;const a=qi(o),l=new RegExp(Ue(r),"g");if(0===i)return n.replace(l,a);let c=0;return n.replace(l,(e=>++c===i?a:e))},isExported:!0},Mb={description:Fo("Combines text from multiple strings and/or arrays."),args:[Dh("delimiter (string)",Fo(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),Dh("ignore_empty (boolean)",Fo("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.")),Dh("text1 (string, range<string>)",Fo("Any text item. This could be a string, or an array of strings in a range.")),Dh("text2 (string, range<string>, repeating)",Fo("Additional text item(s)."))],compute:function(e,t,...o){const s=qi(e),i=Yi(t);let n=0;return on(o,((e,t)=>i&&""===qi(t)?e:(n++?e+s:"")+qi(t)),"")},isExported:!0},Pb={description:Fo("Removes space characters."),args:[Dh("text (string)",Fo("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return Tt(qi(e))},isExported:!0},Nb={description:Fo("Converts a specified string to uppercase."),args:[Dh("text (string)",Fo("The string to convert to uppercase."))],compute:function(e){return qi(e).toUpperCase()},isExported:!0},kb={description:Fo("Converts a number to text according to a specified format."),args:[Dh("number (number)",Fo("The number, date or time to format.")),Dh("format (string)",Fo("The pattern by which to format the number, enclosed in quotation marks."))],compute:function(e,t){return Jn(Vi(e,this.locale),{format:qi(t),locale:this.locale})},isExported:!0},Lb={description:Fo("Converts a string to a numeric value."),args:[Dh("value (number)",Fo("the string to be converted"))],compute:function(e){return Vi(e,this.locale)},isExported:!0};var Vb=Object.freeze({__proto__:null,CHAR:vb,CLEAN:bb,CONCATENATE:Sb,EXACT:yb,FIND:Cb,JOIN:wb,LEFT:xb,LEN:Eb,LOWER:Ib,MID:Rb,PROPER:Tb,REPLACE:Ab,RIGHT:_b,SEARCH:Db,SPLIT:Ob,SUBSTITUTE:Fb,TEXT:kb,TEXTJOIN:Mb,TRIM:Pb,UPPER:Nb,VALUE:Lb});const Hb={description:Fo("Creates a hyperlink in a cell."),args:[Dh("url (string)",Fo("The full URL of the link enclosed in quotation marks.")),Dh("link_label (string, optional)",Fo("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=qi(e).trim(),s=qi(t)||o;return""===o?s:tt(s,o)},isExported:!0};var Ub=Object.freeze({__proto__:null,HYPERLINK:Hb});const Bb=[{name:Fo("Array"),functions:rd},{name:Fo("Database"),functions:zg},{name:Fo("Date"),functions:xp},{name:Fo("Filter"),functions:Np},{name:Fo("Financial"),functions:uf},{name:Fo("Info"),functions:Jf},{name:Fo("Lookup"),functions:Fv},{name:Fo("Logical"),functions:cv},{name:Fo("Math"),functions:Su},{name:Fo("Misc"),functions:ld},{name:Fo("Operator"),functions:Kv},{name:Fo("Statistical"),functions:Tg},{name:Fo("Text"),functions:Vb},{name:Fo("Engineering"),functions:Ip},{name:Fo("Web"),functions:Ub},{name:Fo("Parser"),functions:mb}],zb=/^[A-Z0-9\_\.]+$/;const $b=new class extends n{mapping={};add(e,t){if(e=e.toUpperCase(),!zb.test(e))throw new Error(Fo("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=Oh(t);return function(e){let t=!1,o=!1,s=!1;for(let i of e){if(i.type.includes("META")&&i.type.length>1)throw new Error(Fo("Function ${name} has an argument that has been declared with more than one type whose type 'META'. The 'META' type can only be declared alone."));if(t&&!i.repeating)throw new Error(Fo("Function ${name} has no-repeatable arguments declared after repeatable ones. All repeatable arguments must be declared last."));const e=o||t||s,n=!(i.optional||i.repeating||i.default);if(e&&n)throw new Error(Fo("Function ${name} has at mandatory arguments declared after optional ones. All optional arguments must be after all mandatory arguments."));t=i.repeating,o=i.optional,s=i.default}}(o.args),this.mapping[e]=function(e,t){function o(...o){let i,n=1,r=1,a=1/0,l=1/0;for(let s=0;s<o.length;s++){const c=e.args[e.getArgToFocus(s+1)-1],h=o[s];if(Ci(h)&&!c.acceptMatrix){const e=h.length,t=h[0].length;1!==e||1!==t?(i??=new Array(o.length),1!==e&&1!==t?(i[s]="matrix",n=Math.max(n,e),r=Math.max(r,t),a=Math.min(a,e),l=Math.min(l,t)):1!==e?(i[s]="horizontal",n=Math.max(n,e),a=Math.min(a,e)):1!==t&&(i[s]="vertical",r=Math.max(r,t),l=Math.min(l,t))):o[s]=h[0][0]}if(!Ci(h)&&c.acceptMatrixOnly)throw new Ai(Fo("Function %s expects the parameter '%s' to be reference to a cell or range.",t,(s+1).toString()))}if(1===n&&1===r)return s.apply(this,o);const c=(e,t)=>o.map(((o,s)=>{switch(i?.[s]){case"matrix":return o[e][t];case"horizontal":return o[e][0];case"vertical":return o[0][t];case void 0:return o}}));return rn(n,r,((e,t)=>{if(e>a-1||t>l-1)return Wb;const o=s.apply(this,c(e,t));return Ci(o)?o[0][0]:o}))}function s(...o){for(let t=0;t<o.length;t++){const s=o[t];if(!e.args[e.getArgToFocus(t+1)-1].acceptErrors&&!Ci(s)&&ki(s?.value))return s}try{return i.apply(this,o)}catch(e){return Gb(e,t)}}function i(...o){this.debug;const s=e.compute.apply(this,o);return Ci(s)?"object"==typeof s[0][0]&&null!==s[0][0]&&"value"in s[0][0]?(function(e,t){const o=e.length,s=e[0]?.length??0;for(let i=0;i<o;i++)for(let o=0;o<s;o++)t(e[i][o])}(s,(e=>qb(e,t))),s):an(s,(e=>({value:e}))):"object"==typeof s&&null!==s&&"value"in s?(qb(s,t),s):{value:s}}return o}(o,e),super.add(e,o),this}};for(let e of Bb){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),$b.add(o,{isExported:!1,...s})}}const Wb=new Di(Fo("Array arguments to [[FUNCTION_NAME]] are of different size."));function Gb(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&ki(e.value)?(jb(e)&&qb(e,t),e):(console.error(e),new Ti(Zb+(jb(e)?" "+e.message:"")));var o}function qb(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const Zb=Fo("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function jb(e){return void 0!==e?.message&&"string"==typeof e.message}function Yb(e,t,o){const{x:s,y:i,width:n,height:r}=o;if(n<0||r<0)return;const l=t.color||a,{ctx:c}=e;c.save(),t.noBorder||(t.dashed&&c.setLineDash([5,3]),c.strokeStyle=l,t.thinLine?(c.lineWidth=1,c.strokeRect(s,i,n,r)):(c.lineWidth=2,c.strokeRect(s+.5,i+.5,n,r))),t.noFill||(c.fillStyle=Jt(Bt(l),t.fillAlpha??.12),c.fillRect(s,i,n,r)),c.restore()}Rh.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!this.composer.currentContent.startsWith("="))return[];const o=Object.entries($b.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:Th(t,e,I,"o-semi-bold")}))).sort(((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)));return o},selectProposal(e,t){let o=e.end,s=e.end;["SYMBOL","FUNCTION"].includes(e.type)&&(o=e.start);const i=this.composer.currentTokens;t+="(";const n=i.map((e=>e.start)).indexOf(e.start);if(n+1<i.length){const e=i[n+1];"LEFT_PAREN"===e?.type&&s++}this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}});class Xb extends Ac{mutators=["register","unRegister"];providers=[];constructor(e){super(e),this.onDispose((()=>{this.providers=[]}))}get renderingLayers(){return["Highlights"]}get highlights(){const e=this.getters.getActiveSheetId();return this.providers.flatMap((e=>e.highlights)).filter((t=>t.sheetId===e)).map((e=>{const{numberOfRows:t,numberOfCols:o}=cs(e.zone),s=t*o==1?this.getters.expandZone(e.sheetId,e.zone):e.zone;return{...e,zone:s}}))}register(e){this.providers.push(e)}unRegister(e){this.providers=this.providers.filter((t=>t!==e))}drawLayer(e,t){if("Highlights"===t)for(const t of this.highlights){Yb(e,t,this.getters.getVisibleRect(t.zone))}}}class Kb{mutators=["notifyUser","raiseError","askConfirmation","updateNotificationCallbacks"];notifyUser=e=>window.alert(e.text);askConfirmation=(e,t,o)=>{window.confirm(e)?t():o?.()};raiseError=(e,t)=>{window.alert(e),t?.()};updateNotificationCallbacks(e){this.notifyUser=e.notifyUser||this.notifyUser,this.raiseError=e.raiseError||this.raiseError,this.askConfirmation=e.askConfirmation||this.askConfirmation}}const Jb="#000000",Qb="#3da4ab",eS={OPERATOR:Qb,NUMBER:"#02c39a",STRING:"#00a82d",FUNCTION:Jb,DEBUGGER:Qb,LEFT_PAREN:Jb,RIGHT_PAREN:Jb,ARG_SEPARATOR:Jb,ORPHAN_RIGHT_PAREN:"#ff0000"};class tS extends Ac{mutators=["startEdition","setCurrentContent","stopEdition","stopComposerRangeSelection","cancelEdition","cycleReferences","toggleEditionMode","changeComposerCursorSelection","replaceComposerCursorSelection"];col=0;row=0;editionMode="inactive";sheetId="";_currentContent="";currentTokens=[];selectionStart=0;selectionEnd=0;initialContent="";colorIndexByRange={};notificationStore=this.get(Kb);highlightStore=this.get(Xb);constructor(e){super(e),this.highlightStore.register(this),this.onDispose((()=>{this.highlightStore.unRegister(this)}))}handleEvent(e){const t=this.getters.getActiveSheetId();let o;if(o=e.options.unbounded?this.getters.getUnboundedZone(t,e.anchor.zone):e.anchor.zone,"newAnchor"===e.mode)"selecting"===this.editionMode&&this.insertSelectedRange(o);else"selecting"===this.editionMode?this.replaceSelectedRange(o):this.updateComposerRange(e.previousAnchor.zone,o)}changeComposerCursorSelection(e,t){this.isSelectionValid(this._currentContent.length,e,t)&&(this.selectionStart=e,this.selectionEnd=t,this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode="editing")}startEdition(e,t){if(t){const o=e||this.getComposerContent(this.getters.getActivePosition());if(!this.isSelectionValid(o.length,t.start,t.end))return}const{col:o,row:s}=this.getters.getActivePosition();this.model.dispatch("SELECT_FIGURE",{id:null}),this.model.dispatch("SCROLL_TO_CELL",{col:o,row:s}),"inactive"!==this.editionMode&&e?this.setContent(e,t):this._startEdition(e,t),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor()}cancelEdition(){this.cancelEditionAndActivateSheet(),this.resetContent()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case"SELECT_FIGURE":e.id&&(this.cancelEditionAndActivateSheet(),this.resetContent());break;case"START_CHANGE_HIGHLIGHT":const{left:t,top:o}=e.zone;this.isSelectingRange&&(this.editionMode="editing"),this.model.selection.resetAnchor(this,{cell:{col:t,row:o},zone:e.zone})}}get currentContent(){return"inactive"===this.editionMode?this.getComposerContent(this.getters.getActivePosition()):this._currentContent}get composerSelection(){return{start:this.selectionStart,end:this.selectionEnd}}get isSelectingRange(){return"selecting"===this.editionMode}get showSelectionIndicator(){return this.isSelectingRange&&this.canStartComposerRangeSelection()}get tokenAtCursor(){const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd);return e===t&&0===t?void 0:this.currentTokens.find((o=>o.start<=e&&o.end>=t))}cycleReferences(){const e=this.getters.getLocale(),t=Uf(this.composerSelection,this._currentContent,e);void 0!==t&&this.setCurrentContent(t.content,t.selection)}toggleEditionMode(){if("inactive"===this.editionMode)return;const e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd),o=[...this.currentTokens].reverse().find((o=>o.end>=e&&t>=o.start&&"REFERENCE"===o.type));if("editing"===this.editionMode&&o){const e=this.getters.getActiveSheetId(),{sheetName:t,xc:s}=qo(o.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=o.end;const n=this.getters.getRangeFromSheetXC(this.sheetId,s).zone;this.captureSelection(n),this.editionMode="selecting"}else this.editionMode="editing"}captureSelection(e,t,o){this.model.selection.capture(this,{cell:{col:t||e.left,row:o||e.right},zone:e},{handleEvent:this.handleEvent.bind(this),release:()=>{this._stopEdition()}})}isSelectionValid(e,t,o){return t>=0&&t<=e&&o>=0&&o<=e}startComposerRangeSelection(){if(this.sheetId===this.getters.getActiveSheetId()){const e=fs({col:this.col,row:this.row});this.model.selection.resetAnchor(this,{cell:{col:this.col,row:this.row},zone:e})}this.editionMode="selecting"}_startEdition(e,t){const o=this.getters.getActiveCell(),s=this.getters.getLocale();e&&o.format?.includes("%")&&ti(e,s)&&(t=t||{start:e.length,end:e.length},e=`${e}%`);const{col:i,row:n,sheetId:r}=this.getters.getActivePosition();this.col=i,this.sheetId=r,this.row=n,this.initialContent=this.getComposerContent({sheetId:r,col:i,row:n}),this.editionMode="editing",this.setContent(e||this.initialContent,t),this.colorIndexByRange={};const a=fs({col:this.col,row:this.row});this.captureSelection(a,i,n)}_stopEdition(){if("inactive"!==this.editionMode){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(!(this.initialContent!==e))return;if(e&&e.startsWith("=")){const t=this.currentTokens.filter((e=>"LEFT_PAREN"===e.type)).length-this.currentTokens.filter((e=>"RIGHT_PAREN"===e.type)).length;t>0&&(e+=dt(new Array(t).fill(")")))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return Da(this._currentContent,this.getters.getLocale())}cancelEditionAndActivateSheet(){if("inactive"===this.editionMode)return;this._cancelEdition();this.getters.getActiveSheetId()!==this.sheetId&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getters.getActiveSheetId(),sheetIdTo:this.sheetId})}_cancelEdition(){"inactive"!==this.editionMode&&(this.editionMode="inactive",this.model.selection.release(this),this.colorIndexByRange={})}resetContent(){this.setContent(this.initialContent||"")}setContent(e,t,o){const s=this._currentContent!==e;if(this._currentContent=e,t?(this.selectionStart=t.start,this.selectionEnd=t.end):this.selectionStart=this.selectionEnd=e.length,s||"inactive"!==this.editionMode){const t=this.getters.getLocale();this.currentTokens=e.startsWith("=")?kf(e,t):[],this.currentTokens.length>100&&o&&this.notificationStore.raiseError(Fo("This formula has over 100 parts. It can't be processed properly, consider splitting it into multiple cells"))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection()}getAutoCompleteProviders(){return Rh.getAll()}insertSelectedRange(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=this.getZoneReference(e);this.canStartComposerRangeSelection()?this.insertText(o,t):this.insertText(","+o,t)}replaceSelectedRange(e){const t=this.getZoneReference(e),o=this.tokenAtCursor,s="REFERENCE"===o?.type?o.start:this.selectionStart;this.replaceText(t,s,this.selectionEnd)}updateComposerRange(e,t){const o=this.getters.getActiveSheetId(),s=this.tokenAtCursor,i=(s?[s,...this.currentTokens]:this.currentTokens).filter((e=>"REFERENCE"===e.type)).find((t=>{const{xc:s,sheetName:i}=qo(t.value),n=i||this.getters.getSheetName(this.sheetId);if(this.getters.getSheetName(o)!==n)return!1;const r=this.getters.getRangeFromSheetXC(o,s);return ns(this.getters.expandZone(o,r.zone),e)}));if(!i)return;const n=this.getters.getRangeFromSheetXC(o,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;const r=this.getters.getRangeFromZone(o,t),a=this.getRangeReference(r,n.parts);this.replaceSelection(a)}getZoneReference(e){const t=this.sheetId,o=this.getters.getActiveSheetId(),s=this.getters.getRangeFromZone(o,e);return this.getters.getSelectionRangeString(s,t)}getRangeReference(e,t){let o=[...t];const s=e.clone({parts:o});return this.getters.getSelectionRangeString(s,this.sheetId)}replaceSelection(e){const t=Math.min(this.selectionStart,this.selectionEnd),o=Math.max(this.selectionStart,this.selectionEnd);this.replaceText(e,t,o)}replaceText(e,t,o){this._currentContent=this._currentContent.slice(0,t)+this._currentContent.slice(o,this._currentContent.length),this.insertText(e,t)}insertText(e,t){const o=this._currentContent.slice(0,t)+e+this._currentContent.slice(t),s=t+e.length;this.setCurrentContent(o,{start:s,end:s})}updateTokenColor(){this.updateRangeColor();for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].color=this.getTokenColor(this.currentTokens[e])}getTokenColor(e){if("REFERENCE"===e.type){const{xc:t,sheetName:o}=qo(e.value);return this.rangeColor(t,o)||Jb}if("SYMBOL"===e.type){const t=e.value.toUpperCase();if("TRUE"===t||"FALSE"===t)return eS.NUMBER;if(t in $b.content)return eS.FUNCTION}return["LEFT_PAREN","RIGHT_PAREN"].includes(e.type)&&""===e.parenthesesCode?eS.ORPHAN_RIGHT_PAREN:eS[e.type]||Jb}rangeColor(e,t){const o=t?this.model.getters.getSheetIdByName(t):this.sheetId,s=this.highlights.find((t=>{if(t.sheetId!==o)return!1;let s=this.model.getters.getRangeFromSheetXC(o,e).zone;return s=1===Ss(s)?this.model.getters.expandZone(o,s):s,ns(s,t.zone)}));return s&&s.color?s.color:void 0}computeFormulaCursorContext(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isBlurred=!1;if(this.selectionStart!==this.selectionEnd)return;const e=this.getParenthesesCodeAfterCursor(),t=[...this.currentTokens].reverse().find((t=>e.startsWith(t.parenthesesCode)&&"SYMBOL"===t.type));if(t)for(let e=0;e<this.currentTokens.length;e++)(this.currentTokens[e].parenthesesCode||"").startsWith(t.parenthesesCode||"")||(this.currentTokens[e].isBlurred=!0)}getParenthesesCodeAfterCursor(){const e=this.tokenAtCursor?.parenthesesCode||"";return"RIGHT_PAREN"===this.tokenAtCursor?.type?e.slice(0,-1)||"":e}computeParenthesisRelatedToCursor(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isParenthesisLinkedToCursor=!1;const e=this.tokenAtCursor;if(e&&""!==e.parenthesesCode&&["LEFT_PAREN","RIGHT_PAREN"].includes(e.type))for(let t=0;t<this.currentTokens.length;t++){const o=this.currentTokens[t];["LEFT_PAREN","RIGHT_PAREN"].includes(o.type)&&o.parenthesesCode===e.parenthesesCode&&o!==e&&(this.currentTokens[t].isParenthesisLinkedToCursor=!0,this.tokenAtCursor.isParenthesisLinkedToCursor=!0)}}updateRangeColor(){if(!this._currentContent.startsWith("=")||"inactive"===this.editionMode)return;const e=this.sheetId,t=this.getReferencedRanges().map((t=>this.getters.getRangeString(t,e))),o={};for(const e of t)void 0!==this.colorIndexByRange[e]&&(o[e]=this.colorIndexByRange[e]);const s=new Set(Object.values(o));let i=0;const n=()=>{for(;s.has(i);)i++;return s.add(i),i};for(const e of t){const t=e in o?o[e]:n();o[e]=t}this.colorIndexByRange=o}get highlights(){if(!this.currentContent.startsWith("=")||"inactive"===this.editionMode)return[];const e=this.sheetId,t=e=>{const t=this.colorIndexByRange[e];return Vt[t%Vt.length]};return this.getReferencedRanges().map((o=>{const s=this.getters.getRangeString(o,e),{numberOfRows:i,numberOfCols:n}=cs(o.zone);return{zone:i*n==1?this.getters.expandZone(o.sheetId,o.zone):o.zone,color:t(s),sheetId:o.sheetId,interactive:!0}}))}getReferencedRanges(){const e=this.sheetId;return this.currentTokens.filter((e=>"REFERENCE"===e.type)).map((t=>this.getters.getRangeFromSheetXC(e,t.value))).filter((e=>!e.invalidSheetName&&!e.invalidXc))}get autocompleteProvider(){const e=this.currentContent,t=e.startsWith("=")?this.tokenAtCursor:{type:"STRING",value:e};if("inactive"===this.editionMode||!t||["TRUE","FALSE"].includes(t.value.toUpperCase())||!this.canStartComposerRangeSelection()&&!["SYMBOL","STRING","UNKNOWN"].includes(t.type))return;const o={composer:this,getters:this.getters},s=this.getAutoCompleteProviders().sort(((e,t)=>(e.sequence??1/0)-(t.sequence??1/0))).map((s=>({...s,getProposals:s.getProposals.bind(o,t,e),selectProposal:s.selectProposal.bind(o,t)})));for(const e of s){let o=e.getProposals();const s=o?.find((e=>e.text===t.value)),i=t.value.replace(/[ ,\(\)]/g,"");if(s&&this._currentContent!==this.initialContent)return;if(i&&o&&!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(t.type)){const e=Br(i,o,(e=>e.fuzzySearchKey||e.text));(!s||e.length>1)&&(o=e)}if(e.maxDisplayedProposals&&(o=o?.slice(0,e.maxDisplayedProposals)),o?.length)return{proposals:o,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1}}}canStartComposerRangeSelection(){if(this._currentContent.startsWith("=")){const e=this.tokenAtCursor;if(!e)return!1;const t=this.currentTokens.map((e=>e.start)).indexOf(e.start);let o=t,s=e;for(;!["ARG_SEPARATOR","LEFT_PAREN","OPERATOR"].includes(s.type)||pa.includes(s.value);){if("SPACE"!==s.type||o<1)return!1;o--,s=this.currentTokens[o]}for(o=t+1,s=this.currentTokens[o];s&&!["ARG_SEPARATOR","RIGHT_PAREN","OPERATOR"].includes(s.type);){if("SPACE"!==s.type)return!1;o++,s=this.currentTokens[o]}return!0}return!1}}class oS{scope;code="";constructor(e=new iS){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new sS(this.scope,this.code,e)}toString(){return nS(this.code)}}class sS{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=nS(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;const e=this.scope.nextVariableName(),t=new oS(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}}class iS{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function nS(e){let t="",o=0;const s=e.split("\n").map((e=>e.trim())).filter((e=>""!==e));for(const e of s)e.startsWith("}")&&o--,t+="\t".repeat(o)+e+"\n",e.endsWith("{")&&o++;return t.trim()}const rS=$b.content,aS={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},lS={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},cS={};function hS(e){return dS(vf(e))}function dS(e){try{return function(e){const{dependencies:t,constantValues:o,symbols:s}=function(e){const t={numbers:[],strings:[]},o=[],s=[];for(const i of e)switch(i.type){case"INVALID_REFERENCE":case"REFERENCE":o.push(i.value);break;case"STRING":const e=He(i.value);t.strings.includes(e)||t.strings.push(e);break;case"NUMBER":{const e=si(i.value,Si);t.numbers.includes(e)||t.numbers.push(e);break}case"SYMBOL":s.push($e(i.value,"'"))}return{dependencies:o,constantValues:t,symbols:s}}(e),i=function(e,t,o,s){let i="";for(const s of e)switch(s.type){case"STRING":const e=He(s.value);i+=`|S${o.strings.indexOf(e)}|`;break;case"NUMBER":i+=`|N${o.numbers.indexOf(si(s.value,Si))}|`;break;case"REFERENCE":case"INVALID_REFERENCE":s.value.includes(":")?i+=`R|${t.indexOf(s.value)}|`:i+=`C|${t.indexOf(s.value)}|`;break;case"SPACE":i+="";break;default:i+=s.value}return i}(e,t,o);if(!cS[i]){const r=Af([...e]),a=new iS;if("BIN_OPERATION"===r.type&&":"===r.value)throw new Ai(Fo("Invalid formula"));if("EMPTY"===r.type)throw new Ai(Fo("Invalid formula"));const l=u(r),c=new oS;c.append(`// ${i}`),c.append(l),c.append(`return ${l.returnExpression};`);let h=new Function("deps","ref","range","getSymbolValue","ctx",c.toString());function d(e){const{args:t}=e,o=e.value.toUpperCase(),s=rS[o];if(!s)throw new Oi(Fo('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=rS[o];if(t<s.minArgRequired)throw new Ai(Fo("Invalid number of arguments for the %s function. Expected %s minimum, but got %s instead.",o,s.minArgRequired.toString(),t.toString()));if(t>s.maxArgPossible)throw new Ai(Fo("Invalid number of arguments for the %s function. Expected %s maximum, but got %s instead.",o,s.maxArgPossible.toString(),t.toString()));const i=s.nbrArgRepeating;if(i>1){const e=s.args.length-i;if((t-e)%i!=0)throw new Ai(Fo("Invalid number of arguments for the %s function. Expected all arguments after position %s to be supplied by groups of %s arguments",o,e.toString(),i.toString()))}}(e);const i=[];for(let e=0;e<t.length;e++){const o=s.getArgToFocus(e+1)-1,n=s.args[o],r=t[e],a=n.type||[],l=a.includes("META"),c=a.some((e=>uS(e)));i.push(u(r,l,c))}return i}function u(e,i=!1,n=!1){const r=new oS(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&i)throw new Ai(Fo("Argument must be a reference to a cell or range."));switch(e.debug&&(r.append("debugger;"),r.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return r.return(`{ value: ${e.value} }`);case"NUMBER":return r.return(`{ value: this.constantValues.numbers[${o.numbers.indexOf(e.value)}] }`);case"STRING":return r.return(`{ value: this.constantValues.strings[${o.strings.indexOf(e.value)}] }`);case"REFERENCE":const a=t.indexOf(e.value);return!i&&e.value.includes(":")||n?r.return(`range(deps[${a}])`):r.return(`ref(deps[${a}], ${i?"true":"false"})`);case"FUNCALL":const l=d(e).map((e=>e.assignResultToVariable()));r.append(...l);const c=e.value.toUpperCase();return r.return(`ctx['${c}'](${l.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=lS[e.value],o=u(e.operand,!1,!1).assignResultToVariable();return r.append(o),r.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=aS[e.value],o=u(e.left,!1,!1).assignResultToVariable(),s=u(e.right,!1,!1).assignResultToVariable();return r.append(o),r.append(s),r.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const h=s.indexOf(e.value);return r.return(`getSymbolValue(this.symbols[${h}])`);case"EMPTY":return r.return("undefined")}}cS[i]=h}const n={execute:cS[i],dependencies:t,constantValues:o,symbols:s,tokens:e,isBadExpression:!1,normalizedFormula:i};return n}(e)}catch(t){return{tokens:e,dependencies:[],execute:function(){return t},isBadExpression:!0,normalizedFormula:e.map((e=>e.value)).join("")}}}function uS(e){return e.startsWith("RANGE")}const gS=$b.content;function pS(e){try{return 0===Df(Af(e)).filter((e=>"FUNCALL"===e.type&&!gS[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function mS(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=Af(e)}catch{return[]}return function(e,t){return Df(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}const fS=["PIVOT.VALUE","PIVOT.HEADER","PIVOT"];function vS(e,t){const o=`"${t?`${e.name}:${t}`:e.name}"`,s=e.string!==e.name?e.string+o:o;return{text:o,description:e.string+(e.help?` (${e.help})`:""),htmlContent:[{value:o,color:eS.STRING}],fuzzySearchKey:s}}function bS(e,t){let o=e.end;const s=e.end;"ARG_SEPARATOR"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function SS(e,t){let o=e.end;const s=e.end;"LEFT_PAREN"!==e.type&&(o=e.start),this.composer.stopComposerRangeSelection(),this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}function yS(e){const t=e.functionContext?.args[0];if(t&&["STRING","NUMBER"].includes(t.type))return t.value}function CS(e){return mS(e,fS)[0]}function wS(e){return mS(e,fS).length}const xS=new n;xS.add("SPREADSHEET",!1),Rh.add("pivot_ids",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!["PIVOT.VALUE","PIVOT.HEADER","PIVOT"].includes(t.parent.toUpperCase())||0!==t.argPosition)return;const o=this.getters.getPivotIds();return o.includes(e.value)?void 0:o.map((e=>{const t=this.getters.getPivotCoreDefinition(e),o=`${this.getters.getPivotFormulaId(e)}`;return{text:o,description:t.name,htmlContent:[{value:o,color:eS.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(at)},selectProposal:SS}),Rh.add("pivot_measures",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if("PIVOT.VALUE"!==t?.parent.toUpperCase()||1!==t.argPosition)return[];const o=yS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return[];const i=this.getters.getPivot(s);return i.init(),i.isValid()?i.definition.measures.map((e=>{if("__count"===e.fieldName){const e='"__count"';return{text:e,description:Fo("Count"),htmlContent:[{value:e,color:eS.STRING}],fuzzySearchKey:Fo("Count")+e}}return function(e){const t=`"${e.id}"`,o=e.displayName+e.fieldName+t;return{text:t,description:e.displayName,htmlContent:[{value:t,color:eS.STRING}],fuzzySearchKey:o}}(e)})).filter(at):[]},selectProposal:bS}),Rh.add("pivot_group_fields",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==0}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==1}(e))return;const o=yS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);i.init();const n=i.getFields(),{columns:r,rows:a}=i.definition;let l=t.args;"PIVOT.VALUE"===t?.parent.toUpperCase()?(l=l.filter(((e,t)=>t%2==0)),l=l.slice(1,t.argPosition)):l=l.filter(((e,t)=>t%2==1));const c=l.map((e=>e?.value)).filter(at),h=r.map((e=>e.nameWithGranularity)),d=a.map((e=>e.nameWithGranularity)),u=[];let g=["ARG_SEPARATOR","SPACE"].includes(e.type)?c.at(-1):c.at(-2);const p=xS.get(i.type);if(p&&g?.startsWith("#")&&(g=g.slice(1)),void 0===g&&(u.push(h[0]),u.push(d[0])),d.includes(g)){const e=d[d.indexOf(g)+1];u.push(e),u.push(h[0])}if(h.includes(g)){const e=h[h.indexOf(g)+1];u.push(e)}const m=u.filter(at);return m.map((e=>{const[t,o]=e.split(":"),s=n[t];return s?vS(s,o):void 0})).concat(m.map((e=>{if(!p)return;const t=e.split(":")[0],o=n[t];if(!o)return;const s=`"#${e}"`;return{text:s,description:Fo("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:eS.STRING}],fuzzySearchKey:o.string+s}}))).filter(at)},selectProposal:bS}),Rh.add("pivot_group_values",{sequence:50,autoSelectFirstProposal:!0,getProposals(e){const t=e.functionContext;if(!t||!e||!function(e){const t=e.functionContext;return"PIVOT.VALUE"===t?.parent.toUpperCase()&&t.argPosition>=2&&t.argPosition%2==1}(e)&&!function(e){const t=e.functionContext;return"PIVOT.HEADER"===t?.parent.toUpperCase()&&t.argPosition>=1&&t.argPosition%2==0}(e))return;const o=yS(e),s=this.getters.getPivotId(o);if(!s||!this.getters.isExistingPivot(s))return;const i=this.getters.getPivot(s);if(!i.isValid())return;const n=t.argPosition,r=e.functionContext?.args[n-1]?.value;if(!r)return;let a;try{a=i.definition.getDimension(r)}catch(e){return}return"month_number"===a.granularity?Object.values(Xn).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:eS.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:Fo("Quarter %s",e),htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"day_of_month"===a.granularity?Ze(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"iso_week_number"===a.granularity?Ze(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"day_of_week"===a.granularity?Ze(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"hour_number"===a.granularity?Ze(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"minute_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):"second_number"===a.granularity?Ze(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:eS.NUMBER}]}))):i.getPossibleFieldValues(a).map((({value:e,label:t})=>{const o="string"==typeof e,s=o?`"${e}"`:e.toString(),i=t===e?"":t;return{text:s,description:i,htmlContent:[{value:s,color:o?eS.STRING:eS.NUMBER}],fuzzySearchKey:e+i}}))},selectProposal:bS}),Rh.add("sheet_names",{sequence:150,autoSelectFirstProposal:!0,getProposals(e){return"SYMBOL"===e.type||"UNKNOWN"===e.type&&e.value.startsWith("'")?this.getters.getSheetIds().map((e=>{const t=We(this.getters.getSheetName(e));return{text:t,fuzzySearchKey:t.startsWith("'")?t:"'"+t}})):[]},selectProposal(e,t){const o=e.start,s=e.end;this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t+"!")}});const ES=new n;ES.add("ALPHANUMERIC_INCREMENT_MODIFIER",{apply:(e,t)=>{e.current+=e.increment;const o=`${e.prefix}${e.current.toString().padStart(e.numberPostfixLength||0,"0")}`;return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:o},tooltip:{props:{content:o}}}}}).add("INCREMENT_MODIFIER",{apply:(e,t,o)=>{e.current+=e.increment;const s=e.current.toString(),i=o.getLocale(),n=Jn(e.current,{format:t.cell?.format,locale:i});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:n}}:void 0}}}).add("DATE_INCREMENT_MODIFIER",{apply:(e,t,o)=>{const s=Xi(e.current,o.getLocale());s.setFullYear(s.getFullYear()+e.increment.years||0),s.setMonth(s.getMonth()+e.increment.months||0),s.setDate(s.getDate()+e.increment.days||0);const i=$s(s);e.current=i;const n=o.getLocale(),r=Jn(i,{format:t.cell?.format,locale:n});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:r}}:void 0}}}).add("COPY_MODIFIER",{apply:(e,t,o)=>{const s=t.cell?.content||"",i={locale:o.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:s},tooltip:s?{props:{content:t.cell?Ir(t.cell,i).formattedValue:""}}:void 0}}}).add("FORMULA_MODIFIER",{apply:(e,t,o,s)=>{e.current+=e.increment;let i=0,n=0;switch(s){case"up":i=0,n=-e.current;break;case"down":i=0,n=e.current;break;case"left":i=-e.current,n=0;break;case"right":i=e.current,n=0}const r=t.cell;if(!r||!r.isFormula)return{cellData:{}};const a=t.sheetId,l=o.getTranslatedCellFormula(a,i,n,r.compiledFormula.tokens);return{cellData:{border:t.border,style:r.style,format:r.format,content:l},tooltip:l?{props:{content:l}}:void 0}}});const IS=new n,RS=/(\d+)$/,TS=/^(.*\D+)/,AS=/^(.*\D+)(\d+)$/;function _S(e,t,o){let s=[],i=!1;for(let n of t){n===e&&(i=!0);const t=void 0===n||n.isFormula?void 0:Ir(n,{locale:Si,format:n.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function DS(e){let t=1;return e.length>=2&&(t=function(e){const t=[];let o=e[0];for(let s=1;s<e.length;s++){const i=e[s];t.push(i-o),o=i}return t.reduce(((e,t)=>e+t),0)/t.length}(e)*e.length),t}function OS(e){if(e.length<2)return 1;const t=e.map((e=>Xi(e,Si))),o=function(e){if(e.length<2)return[{years:0,months:0,days:0}];const t=e.map(((t,o)=>{if(0===o)return{years:0,months:0,days:0};const s=Is.fromTimestamp(e[o-1].getTime()),i=Ks(s,t),n=Ys(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+n);return{years:i,months:n,days:Xs(s,t)}}));return t.slice(1)}(t),s=(i=o).length<2?i[0]||{years:0,months:0,days:0}:i.every((e=>e.years===i[0].years&&e.months===i[0].months&&e.days===i[0].days))?i[0]:void 0;var i;if(void 0===s)return;const n=1===Object.values(s).filter((e=>0!==e)).length,r=Object.values(s).every((e=>0===e));if(!n||r){const o=t.map(((e,o)=>{if(0===o)return 0;const s=t[o-1];return Math.floor(e.getTime())-Math.floor(s.getTime())})).slice(1);if(o.every((e=>e===o[0])))return e.length*(e[1]-e[0])}return{years:s.years*e.length,months:s.months*e.length,days:s.days*e.length}}IS.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&rr(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.text&&AS.test(e.content),generateRule:(e,t)=>{const o=parseInt(e.content.match(RS)[0]),s=e.content.match(TS)[0],i=e.content.length-s.length,n=DS(_S(e,t,(e=>e.type===ni.text&&AS.test(e.value))).filter((e=>s===(e.value??"").toString().match(TS)[0])).map((e=>parseInt((e.value??"").toString().match(RS)[0]))));return{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:s,current:o,increment:n,numberPostfixLength:i}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.text,generateRule:()=>({type:"COPY_MODIFIER"}),sequence:20}).add("update_formula",{condition:e=>e.isFormula,generateRule:(e,t)=>({type:"FORMULA_MODIFIER",increment:t.length,current:0}),sequence:30}).add("increment_dates",{condition:(e,t)=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.number&&!!e.format&&rr(e.format),generateRule:(e,t)=>{const o=OS(_S(e,t,(e=>e.type===ni.number&&!!e.format&&rr(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=Ir(e,{locale:Si});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===ni.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ni.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&Ir(e,{locale:Si}).type===ni.number,generateRule:(e,t)=>{const o=DS(_S(e,t,(e=>e.type===ni.number&&!rr(e.format||""))).map((e=>Number(e.value)))),s=Ir(e,{locale:Si});return{type:"INCREMENT_MODIFIER",increment:o,current:s.type===ni.number?s.value:0}},sequence:40});const FS=new n,MS=30,PS=10,NS=20,kS=12,LS=80,VS="#F3F2F1",HS=6,US=25;function BS(e,t){const o=e.getBoundingClientRect();e.width=o.width,e.height=o.height;const s=e.getContext("2d"),i=function(e,t,o){const s=t.maxValue,i=t.minValue,n=t.gaugeValue,r=function(e,t){const o=t?US:0,s=e.height-NS-o-PS,i=e.width-2*MS;let n,r;i>2*s?(n=2*s,r=s):(n=i,r=i/2);const a=o+PS+(s-r)/2;return{x:MS+(i-n)/2,y:a,width:n,height:r}}(e,t.title.text),a=r.width/6,l=n?(n.value-i.value)/(s.value-i.value):0,c={x:e.width/2,y:r.y+r.height-r.height/12};let h=LS;r.height<300&&(h*=r.height/300);const d=r.width/2,u=n?.label||"-";jr(o,u,{fontSize:h},"px")>d&&(h=function(e,t,o,s=.25){let i=1;if(o(i)>e)return i;if(o(t)<e)return t;let n=(i+t)/2,r=o(n),a=0;for(;Math.abs(r-e)>s&&a<20;)r>=e?t=(i+t)/2:i=(i+t)/2,n=(i+t)/2,r=o(n),a++;return n}(d,h,(e=>jr(o,u,{fontSize:e},"px"))));const g={x:r.x+a/2,y:r.y+r.height+kS},p={x:r.x+r.width-a/2,y:r.y+r.height+kS},m=jc(t.background),f=function(e,t,o,s){const i=e.maxValue,n=e.minValue,r={x:t.x+t.width/2,y:t.y+t.height},a={fontSize:kS},l=[],c=[];for(const h of e.inflectionValues){const e=(h.value-n.value)/(i.value-n.value),d=jr(s,h.label,a,"px"),u=Math.PI-Math.PI*e,g=qS(u,t.height+HS,r.x,r.y,d+2,kS);let p=c.some((e=>GS(e,g)))?kS:0;c.push(g),l.push({rotation:u,label:h.label,fontSize:kS,color:o,offset:p})}return l}(t,r,m,o);let v=0,b=0,S=0;t.title.text&&({width:b,height:S}=Kr(o,t.title.text,{fontSize:X,...t.title},"px"));switch(t.title.align){case"right":v=e.width-b-Z;break;case"center":v=(e.width-b)/2;break;default:v=Z}return{width:e.width,height:e.height,title:{label:t.title.text??"",fontSize:t.title.fontSize??X,textPosition:{x:v,y:Y+S/2},color:t.title.color??m,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:r,arcWidth:a,percentage:qe(l,0,1),color:zS(t)},inflectionValues:f,gaugeValue:{label:u,textPosition:c,fontSize:h,color:m},minLabel:{label:t.minValue.label,textPosition:g,fontSize:kS,color:m},maxLabel:{label:t.maxValue.label,textPosition:p,fontSize:kS,color:m}}}(o,t,s);!function(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}(s,i),function(e,t){e.save();const o=t.gauge,s=o.rect.x+o.rect.width/2,i=o.rect.y+o.rect.height,n=o.rect.height-o.arcWidth/2;if(n<0)return;const r=1===o.percentage?0:Math.PI*(1+o.percentage);e.strokeStyle=VS,e.beginPath(),e.lineWidth=o.arcWidth,e.arc(s,i,n,r,0),e.stroke(),e.strokeStyle=o.color,e.beginPath(),e.arc(s,i,n,Math.PI,r),e.stroke(),e.restore()}(s,i),function(e,t){const{x:o,y:s,width:i,height:n}=t.gauge.rect;for(const r of t.inflectionValues){e.save(),e.translate(o+i/2-.5,s+n-.5),e.rotate(Math.PI/2-r.rotation),e.lineWidth=2,e.strokeStyle=jc(t.backgroundColor)+"aa",e.beginPath(),e.moveTo(0,-(n-t.gauge.arcWidth)),e.lineTo(0,-n-3),e.stroke(),e.textAlign="center",e.font=`${r.fontSize}px ${fe}`,e.fillStyle=r.color;const a=-n-HS-r.offset;e.fillText(r.label,0,a),e.restore()}}(s,i),function(e,t){for(const o of[t.minLabel,t.maxLabel,t.gaugeValue])e.save(),e.textAlign="center",e.fillStyle=o.color,e.font=`${o.fontSize}px ${fe}`,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i),function(e,t){e.save();const o=t.title;e.font=qr(o.fontSize,o.bold,o.italic),e.textBaseline="middle",e.fillStyle=o.color,e.fillText(o.label,o.textPosition.x,o.textPosition.y),e.restore()}(s,i)}function zS(e){const t=e.gaugeValue?.value;if(void 0===t)return VS;for(let o=0;o<e.inflectionValues.length;o++){const s=e.inflectionValues[o];if("<"===s.operator&&t<s.value)return e.colors[o];if("<="===s.operator&&t<=s.value)return e.colors[o]}return e.colors.at(-1)}function $S(e){return[{start:e.topLeft,end:e.topRight},{start:e.topRight,end:e.bottomRight},{start:e.bottomRight,end:e.bottomLeft},{start:e.bottomLeft,end:e.topLeft}]}function WS(e,t){const o=e.start,s=e.end,i=t.start,n=t.end;function r(e,t,o){return(o.y-e.y)*(t.x-e.x)>(t.y-e.y)*(o.x-e.x)}return r(o,i,n)!==r(s,i,n)&&r(o,s,i)!==r(o,s,n)}function GS(e,t){const o=$S(e),s=$S(t);for(const e of o)for(const t of s)if(WS(e,t))return!0;return!1}function qS(e,t,o,s,i,n){const r=Math.cos(e),a=Math.sin(e),l=r*t,c=a*t,h=a*(i/2),d=r*(i/2),u=r*(t+n),g=a*(t+n);return{bottomLeft:{x:l-h+o,y:s-(c+d)},bottomRight:{x:l+h+o,y:s-(c-d)},topRight:{x:u+h+o,y:s-(g-d)},topLeft:{x:u-h+o,y:s-(g+d)}}}class ZS extends t.Component{static template="o-spreadsheet-GaugeChartComponent";canvas=t.useRef("chartContainer");get runtime(){return this.env.model.getters.getChartRuntime(this.props.figure.id)}setup(){t.useEffect((()=>BS(this.canvas.el,this.runtime)),(()=>{const e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el]}))}}function jS(e){return 8===(e=Bt(e).replace("#","")).length?e.slice(6)+e.slice(0,6):e}ZS.props={figure:Object};const YS={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1};function XS(e,t,o){const s=document.createElement("div");s.style.width=`${t.width}px`,s.style.height=`${t.height}px`;const i=document.createElement("canvas");if(s.append(i),i.setAttribute("width",t.width.toString()),i.setAttribute("height",t.height.toString()),document.body.append(s),"chartJsConfig"in e){const t=Be(e.chartJsConfig);t.plugins=[KS];const o=new window.Chart(i,t),n=o.toBase64Image();return o.destroy(),s.remove(),n}if("scorecard"===o){Sh(xh(t,e),i);const o=i.toDataURL();return s.remove(),o}if("gauge"===o){BS(i,e);const t=i.toDataURL();return s.remove(),t}}const KS={id:"customCanvasBackgroundColor",beforeDraw:e=>{const{ctx:t}=e;t.save(),t.globalCompositeOperation="destination-over",t.fillStyle="#ffffff",t.fillRect(0,0,e.width,e.height),t.restore()}};class JS{xmlString;constructor(e){this.xmlString=e}toString(){return this.xmlString}}const QS=["areaChart","area3DChart","lineChart","line3DChart","stockChart","radarChart","scatterChart","pieChart","pie3DChart","doughnutChart","barChart","bar3DChart","ofPieChart","surfaceChart","surface3DChart","bubbleChart","comboChart","radarChart"],ey="000000",ty={arrow:"3Arrows",smiley:"3Symbols",dot:"3TrafficLights1"},oy={styleSheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",sst:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",Relationships:"http://schemas.openxmlformats.org/package/2006/relationships",Types:"http://schemas.openxmlformats.org/package/2006/content-types",worksheet:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",workbook:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",drawing:"http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing",table:"http://schemas.openxmlformats.org/spreadsheetml/2006/main",revision:"http://schemas.microsoft.com/office/spreadsheetml/2014/revision",revision3:"http://schemas.microsoft.com/office/spreadsheetml/2016/revision3",markupCompatibility:"http://schemas.openxmlformats.org/markup-compatibility/2006"},sy="http://schemas.openxmlformats.org/drawingml/2006/main",iy="http://schemas.openxmlformats.org/drawingml/2006/chart",ny={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",sharedStrings:"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml",styles:"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml",drawing:"application/vnd.openxmlformats-officedocument.drawing+xml",chart:"application/vnd.openxmlformats-officedocument.drawingml.chart+xml",themes:"application/vnd.openxmlformats-officedocument.theme+xml",table:"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml",pivot:"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml",externalLink:"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml"},ry={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",sharedStrings:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings",styles:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles",drawing:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing",chart:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart",theme:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme",table:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/table",hyperlink:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink",image:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image"},ay="http://schemas.openxmlformats.org/officeDocument/2006/relationships",ly=.75,cy=.143,hy=8.43,dy=12.75,uy=30,gy=100,py=164,my={FLOOR:[{type:"NUMBER",value:1}],CEILING:[{type:"NUMBER",value:1}],ROUND:[{type:"NUMBER",value:0}],ROUNDUP:[{type:"NUMBER",value:0}],ROUNDDOWN:[{type:"NUMBER",value:0}]},fy=["ACOT","ACOTH","AGGREGATE","ARABIC","BASE","BETA.DIST","BETA.INV","BINOM.DIST","BINOM.DIST.RANGE","BINOM.INV","BITAND","BITLSHIFT","BITOR","BITRSHIFT","BITXOR","BYCOL","BYROW","CEILING.MATH","CEILING.PRECISE","CHISQ.DIST","CHISQ.DIST.RT","CHISQ.INV","CHISQ.INV.RT","CHISQ.TEST","CHOOSECOLS","CHOOSEROWS","COMBINA","CONCAT","CONFIDENCE.NORM","CONFIDENCE.T","COT","COTH","COVARIANCE.P","COVARIANCE.S","CSC","CSCH","DAYS","DECIMAL","DROP","ERF.PRECISE","ERFC.PRECISE","EXPAND","EXPON.DIST","F.DIST","F.DIST.RT","F.INV","F.INV.RT","F.TEST","FIELDVALUE","FILTERXML","FLOOR.MATH","FLOOR.PRECISE","FORECAST.ETS","FORECAST.ETS.CONFINT","FORECAST.ETS.SEASONALITY","FORECAST.ETS.STAT","FORECAST.LINEAR","FORMULATEXT","GAMMA","GAMMA.DIST","GAMMA.INV","GAMMALN.PRECISE","GAUSS","HSTACK","HYPGEOM.DIST","IFNA","IFS","IMCOSH","IMCOT","IMCSC","IMCSCH","IMSEC","IMSECH","IMSINH","IMTAN","ISFORMULA","ISOMITTED","ISOWEEKNUM","LAMBDA","LET","LOGNORM.DIST","LOGNORM.INV","MAKEARRAY","MAP","MAXIFS","MINIFS","MODE.MULT","MODE.SNGL","MUNIT","NEGBINOM.DIST","NORM.DIST","NORM.INV","NORM.S.DIST","NORM.S.INV","NUMBERVALUE","PDURATION","PERCENTILE.EXC","PERCENTILE.INC","PERCENTRANK.EXC","PERCENTRANK.INC","PERMUTATIONA","PHI","POISSON.DIST","PQSOURCE","PYTHON_STR","PYTHON_TYPE","PYTHON_TYPENAME","QUARTILE.EXC","QUARTILE.INC","QUERYSTRING","RANDARRAY","RANK.AVG","RANK.EQ","REDUCE","RRI","SCAN","SEC","SECH","SEQUENCE","SHEET","SHEETS","SKEW.P","SORTBY","STDEV.P","STDEV.S","SWITCH","T.DIST","T.DIST.2T","T.DIST.RT","T.INV","T.INV.2T","T.TEST","TAKE","TEXTAFTER","TEXTBEFORE","TEXTJOIN","TEXTSPLIT","TOCOL","TOROW","UNICHAR","UNICODE","UNIQUE","VAR.P","VAR.S","VSTACK","WEBSERVICE","WEIBULL.DIST","WRAPCOLS","WRAPROWS","XLOOKUP","XOR","Z.TEST"],vy="[Content_Types].xml",by=new n;Mc`
|
|
13
13
|
.o-spreadsheet {
|
|
14
14
|
.o-icon {
|
|
15
15
|
display: flex;
|
|
@@ -33,7 +33,7 @@
|
|
|
33
33
|
}
|
|
34
34
|
`;function Sy(e){return e=`<svg xmlns="http://www.w3.org/2000/svg" ${e.slice(4)}`,"data:image/svg+xml; charset=utf8, "+encodeURIComponent(e)}const yy={arrowGood:{template:"ARROW_UP",img:Sy('<svg class="o-icon arrow-up" width="10" height="10" focusable="false" viewBox="0 0 448 512"><path fill="#6AA84F" d="M34.9 289.5l-22.2-22.2c-9.4-9.4-9.4-24.6 0-33.9L207 39c9.4-9.4 24.6-9.4 33.9 0l194.3 194.3c9.4 9.4 9.4 24.6 0 33.9L413 289.4c-9.5 9.5-25 9.3-34.3-.4L264 168.6V456c0 13.3-10.7 24-24 24h-32c-13.3 0-24-10.7-24-24V168.6L69.2 289.1c-9.3 9.8-24.8 10-34.3.4z"></path></svg>')},arrowNeutral:{template:"ARROW_RIGHT",img:Sy('<svg class="o-icon arrow-right" width="10" height="10" focusable="false" viewBox="0 0 448 512"><path fill="#F0AD4E" d="M190.5 66.9l22.2-22.2c9.4-9.4 24.6-9.4 33.9 0L441 239c9.4 9.4 9.4 24.6 0 33.9L246.6 467.3c-9.4 9.4-24.6 9.4-33.9 0l-22.2-22.2c-9.5-9.5-9.3-25 .4-34.3L311.4 296H24c-13.3 0-24-10.7-24-24v-32c0-13.3 10.7-24 24-24h287.4L190.9 101.2c-9.8-9.3-10-24.8-.4-34.3z"></path></svg>')},arrowBad:{template:"ARROW_DOWN",img:Sy('<svg class="o-icon arrow-down" width="10" height="10" focusable="false" viewBox="0 0 448 512"><path fill="#E06666" d="M413.1 222.5l22.2 22.2c9.4 9.4 9.4 24.6 0 33.9L241 473c-9.4 9.4-24.6 9.4-33.9 0L12.7 278.6c-9.4-9.4-9.4-24.6 0-33.9l22.2-22.2c9.5-9.5 25-9.3 34.3.4L184 343.4V56c0-13.3 10.7-24 24-24h32c13.3 0 24 10.7 24 24v287.4l114.8-120.5c9.3-9.8 24.8-10 34.3-.4z"></path></svg>')},smileyGood:{template:"SMILE",img:Sy('<svg class="o-icon smile" width="10" height="10" focusable="false" viewBox="0 0 496 512"><path fill="#6AA84F" d="M248 8C111 8 0 119 0 256s111 248 248 248 248-111 248-248S385 8 248 8zm0 448c-110.3 0-200-89.7-200-200S137.7 56 248 56s200 89.7 200 200-89.7 200-200 200zm-80-216c17.7 0 32-14.3 32-32s-14.3-32-32-32-32 14.3-32 32 14.3 32 32 32zm160 0c17.7 0 32-14.3 32-32s-14.3-32-32-32-32 14.3-32 32 14.3 32 32 32zm4 72.6c-20.8 25-51.5 39.4-84 39.4s-63.2-14.3-84-39.4c-8.5-10.2-23.7-11.5-33.8-3.1-10.2 8.5-11.5 23.6-3.1 33.8 30 36 74.1 56.6 120.9 56.6s90.9-20.6 120.9-56.6c8.5-10.2 7.1-25.3-3.1-33.8-10.1-8.4-25.3-7.1-33.8 3.1z"></path></svg>')},smileyNeutral:{template:"MEH",img:Sy('<svg class="o-icon meh" width="10" height="10" focusable="false" viewBox="0 0 496 512"><path fill="#F0AD4E" d="M248 8C111 8 0 119 0 256s111 248 248 248 248-111 248-248S385 8 248 8zm0 448c-110.3 0-200-89.7-200-200S137.7 56 248 56s200 89.7 200 200-89.7 200-200 200zm-80-216c17.7 0 32-14.3 32-32s-14.3-32-32-32-32 14.3-32 32 14.3 32 32 32zm160-64c-17.7 0-32 14.3-32 32s14.3 32 32 32 32-14.3 32-32-14.3-32-32-32zm8 144H160c-13.2 0-24 10.8-24 24s10.8 24 24 24h176c13.2 0 24-10.8 24-24s-10.8-24-24-24z"></path></svg>')},smileyBad:{template:"FROWN",img:Sy('<svg class="o-icon frown" width="10" height="10" focusable="false" viewBox="0 0 496 512"><path fill="#E06666" d="M248 8C111 8 0 119 0 256s111 248 248 248 248-111 248-248S385 8 248 8zm0 448c-110.3 0-200-89.7-200-200S137.7 56 248 56s200 89.7 200 200-89.7 200-200 200zm-80-216c17.7 0 32-14.3 32-32s-14.3-32-32-32-32 14.3-32 32 14.3 32 32 32zm160-64c-17.7 0-32 14.3-32 32s14.3 32 32 32 32-14.3 32-32-14.3-32-32-32zm-80 128c-40.2 0-78 17.7-103.8 48.6-8.5 10.2-7.1 25.3 3.1 33.8 10.2 8.4 25.3 7.1 33.8-3.1 16.6-19.9 41-31.4 66.9-31.4s50.3 11.4 66.9 31.4c8.1 9.7 23.1 11.9 33.8 3.1 10.2-8.5 11.5-23.6 3.1-33.8C326 321.7 288.2 304 248 304z"></path></svg>')},dotGood:{template:"GREEN_DOT",img:Sy('<svg class="o-icon green-dot" width="10" height="10" focusable="false" viewBox="0 0 512 512"><path fill="#6AA84F" d="M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8z"></path></svg>')},dotNeutral:{template:"YELLOW_DOT",img:Sy('<svg class="o-icon yellow-dot" width="10" height="10" focusable="false" viewBox="0 0 512 512"><path fill="#F0AD4E" d="M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8z"></path></svg>')},dotBad:{template:"RED_DOT",img:Sy('<svg class="o-icon red-dot" width="10" height="10" focusable="false" viewBox="0 0 512 512"><path fill="#E06666" d="M256 8C119 8 8 119 8 256s111 248 248 248 248-111 248-248S393 8 256 8z"></path></svg>')}},Cy={arrows:{good:"arrowGood",neutral:"arrowNeutral",bad:"arrowBad"},smiley:{good:"smileyGood",neutral:"smileyNeutral",bad:"smileyBad"},dots:{good:"dotGood",neutral:"dotNeutral",bad:"dotBad"}};var wy;by.add("conditional_formatting",((e,t)=>{const o=e.getConditionalIcon(t);if(o)return yy[o].img})),function(e){e.DiagonalBorderNotSupported="Diagonal Borders",e.BorderStyleNotSupported="Border style",e.FillStyleNotSupported="Fill Style",e.FontNotSupported="Font",e.HorizontalAlignmentNotSupported="Horizontal Alignment",e.VerticalAlignmentNotSupported="Vertical Alignments",e.MultipleRulesCfNotSupported="Multiple rules conditional formats",e.CfTypeNotSupported="Conditional format type",e.CfFormatBorderNotSupported="Borders in conditional formats",e.CfFormatAlignmentNotSupported="Alignment in conditional formats",e.CfFormatNumFmtNotSupported="Num formats in conditional formats",e.CfIconSetEmptyIconNotSupported="IconSets with empty icons",e.BadlyFormattedHyperlink="Badly formatted hyperlink",e.NumFmtIdNotSupported="Number format",e.TimeDataValidationNotSupported="Time data validation rules",e.TextLengthDataValidationNotSupported="Text length data validation rules",e.WholeNumberDataValidationNotSupported="Whole number data validation rules",e.NotEqualDateDataValidationNotSupported="Not equal date data validation rules"}(wy||(wy={}));class xy{_parsingWarnings=new Set;_conversionWarnings=new Set;addParsingWarning(e){this._parsingWarnings.add(e)}addConversionWarning(e){this._conversionWarnings.add(e)}get warnings(){return[...this._parsingWarnings,...this._conversionWarnings]}generateNotSupportedWarning(e,t,o){let s=`${e} ${t?'"'+t+'" is':"are"} not yet supported. `;o&&(s+=`Only ${o.join(", ")} are currently supported.`),this._conversionWarnings.has(s)||this._conversionWarnings.add(s)}}const Ey=["thin","medium","thick","dashed","dotted"],Iy=["general","left","center","right"],Ry=["top","center","bottom"],Ty=["Arial"],Ay=["solid"],_y=["expression","cellIs","colorScale","iconSet","containsText","notContainsText","beginsWith","endsWith","containsBlanks","notContainsBlanks"],Dy={b:"boolean",d:"date",e:"error",inlineStr:"inlineStr",n:"number",s:"sharedString",str:"str"},Oy={dashDot:"thin",dashDotDot:"thin",dashed:"dashed",dotted:"dotted",double:"thin",hair:"thin",medium:"medium",mediumDashDot:"thin",mediumDashDotDot:"thin",mediumDashed:"thin",none:void 0,slantDashDot:"thin",thick:"thick",thin:"thin"},Fy={general:void 0,left:"left",center:"center",right:"right",fill:"left",justify:"left",centerContinuous:"center",distributed:"center"},My={top:"top",center:"middle",bottom:"bottom",justify:"middle",distributed:"middle"},Py={top:"top",middle:"center",bottom:"bottom"};const Ny={aboveAverage:void 0,expression:void 0,cellIs:void 0,colorScale:void 0,dataBar:void 0,iconSet:void 0,top10:void 0,uniqueValues:void 0,duplicateValues:void 0,containsText:"ContainsText",notContainsText:"NotContains",beginsWith:"BeginsWith",endsWith:"EndsWith",containsBlanks:"IsEmpty",notContainsBlanks:"IsNotEmpty",containsErrors:void 0,notContainsErrors:void 0,timePeriod:void 0},ky={num:"number",percent:"percentage",max:"value",min:"value",percentile:"percentile",formula:"formula"},Ly={NoIcons:void 0,"3Arrows":"arrows","3ArrowsGray":"arrows","3Symbols":"smiley","3Symbols2":"smiley","3Signs":"dots","3Flags":"dots","3TrafficLights1":"dots","3TrafficLights2":"dots","4Arrows":"arrows","4ArrowsGray":"arrows","4RedToBlack":"dots","4Rating":"smiley","4TrafficLights":"dots","5Arrows":"arrows","5ArrowsGray":"arrows","5Rating":"smiley","5Quarters":"dots","3Stars":"smiley","3Triangles":"arrows","5Boxes":"dots"},Vy={b:"bottom",t:"top",l:"left",r:"right",tr:"right"},Hy={areaChart:void 0,area3DChart:void 0,lineChart:"line",line3DChart:void 0,stockChart:void 0,radarChart:"radar",scatterChart:"scatter",pieChart:"pie",pie3DChart:void 0,doughnutChart:"pie",barChart:"bar",bar3DChart:void 0,ofPieChart:void 0,surfaceChart:void 0,surface3DChart:void 0,bubbleChart:void 0,comboChart:"combo"},Uy={1:"AVERAGE",2:"COUNT",3:"COUNTA",4:"MAX",5:"MIN",6:"PRODUCT",7:"STDEV",8:"STDEVP",9:"SUM",10:"VAR",11:"VARP",101:"AVERAGE",102:"COUNT",103:"COUNTA",104:"MAX",105:"MIN",106:"PRODUCT",107:"STDEV",108:"STDEVP",109:"SUM",110:"VAR",111:"VARP"},By={0:"",1:"0",2:"0.00",3:"#,#00",4:"#,##0.00",9:"0%",10:"0.00%",11:void 0,12:void 0,13:void 0,14:"m/d/yyyy",15:"m/d/yyyy",16:"m/d/yyyy",17:"m/d/yyyy",18:"hh:mm:ss a",19:"hh:mm:ss a",20:"hhhh:mm:ss",21:"hhhh:mm:ss",22:"m/d/yy h:mm",37:void 0,38:void 0,39:void 0,40:void 0,45:"hhhh:mm:ss",46:"hhhh:mm:ss",47:"hhhh:mm:ss",48:void 0,49:"@"},zy={0:1,"0.00":2,"#,#00":3,"#,##0.00":4,"0%":9,"0.00%":10,"0.00E+00":11,"# ?/?":12,"# ??/??":13,"mm-dd-yy":14,"d-mm-yy":15,"mm-yy":16,"mmm-yy":17,"h:mm AM/PM":18,"h:mm:ss AM/PM":19,"h:mm":20,"h:mm:ss":21,"m/d/yy h:mm":22,"#,##0 ;(#,##0)":37,"#,##0 ;[Red](#,##0)":38,"#,##0.00;(#,##0.00)":39,"#,##0.00;[Red](#,##0.00)":40,"mm:ss":45,"[h]:mm:ss":46,"mmss.0":47,"##0.0E+0":48,"@":49,"hh:mm:ss a":19},$y={0:"000000",1:"FFFFFF",2:"FF0000",3:"00FF00",4:"0000FF",5:"FFFF00",6:"FF00FF",7:"00FFFF",8:"000000",9:"FFFFFF",10:"FF0000",11:"00FF00",12:"0000FF",13:"FFFF00",14:"FF00FF",15:"00FFFF",16:"800000",17:"008000",18:"000080",19:"808000",20:"800080",21:"008080",22:"C0C0C0",23:"808080",24:"9999FF",25:"993366",26:"FFFFCC",27:"CCFFFF",28:"660066",29:"FF8080",30:"0066CC",31:"CCCCFF",32:"000080",33:"FF00FF",34:"FFFF00",35:"00FFFF",36:"800080",37:"800000",38:"008080",39:"0000FF",40:"00CCFF",41:"CCFFFF",42:"CCFFCC",43:"FFFF99",44:"99CCFF",45:"FF99CC",46:"CC99FF",47:"FFCC99",48:"3366FF",49:"33CCCC",50:"99CC00",51:"FFCC00",52:"FF9900",53:"FF6600",54:"666699",55:"969696",56:"003366",57:"339966",58:"003300",59:"333300",60:"993300",61:"993366",62:"333399",63:"333333",64:"000000",65:"FFFFFF"},Wy={"image/avif":"avif","image/bmp":"bmp","image/gif":"gif","image/vnd.microsoft.icon":"ico","image/jpeg":"jpeg","image/png":"png","image/tiff":"tiff","image/webp":"webp"},Gy={avif:"image/avif",bmp:"image/bmp",gif:"image/gif",ico:"image/vnd.microsoft.icon",jpeg:"image/jpeg",png:"image/png",tiff:"image/tiff",webp:"image/webp",jpg:"image/jpeg"},qy={between:"isBetween",notBetween:"isNotBetween",equal:"isEqual",notEqual:"isNotEqual",greaterThan:"isGreaterThan",greaterThanOrEqual:"isGreaterOrEqualTo",lessThan:"isLessThan",lessThanOrEqual:"isLessOrEqualTo"},Zy={between:"dateIsBetween",notBetween:"dateIsNotBetween",equal:"dateIs",greaterThan:"dateIsAfter",greaterThanOrEqual:"dateIsOnOrAfter",lessThan:"dateIsBefore",lessThanOrEqual:"dateIsOnOrBefore"};function jy(e){if(!e)return;let t;if(e.rgb)t=e.rgb;else if(e.auto)t=ey;else{if(!e.indexed)return;t=$y[e.indexed]}var o;return t=6===(o=t).length?"#"+o+"FF":"#"+o.slice(2)+o.slice(0,2),e.tint&&(t=function(e,t){const o=Zt(e),s=Yt(o);t<0&&(s.l=s.l*(1+t));t>0&&(s.l=s.l*(1-t)+(100-100*(1-t)));return qt(jt(s))}(t,e.tint)),t=t.toUpperCase(),9===t.length&&t.endsWith("FF")&&(t=t.slice(0,7)),t}function Yy(e){return 9===e.length&&(e=e.slice(0,7)),parseInt(e.replace("#",""),16)}function Xy(e,t){const o=e.split("/"),s=t.split("/");let i="",n=0;for(let e=0;e<o.length-1;e++)o[e]===s[e]?n++:i+="../";return i+=s.slice(n).join("/"),i}function Ky(e,t=0){const o={};for(let s=0;s<e.length;s++)e[s]&&(o[s+t]=e[s]);return o}function Jy(e){return e.replace(/_x([0-9a-zA-Z]{4})_/g,((e,t)=>String.fromCharCode(parseInt(t,16))))}function Qy(e,t,o){return"COL"===t?(e.cols[o]||(e.cols[o]={}),e.cols[o]):(e.rows[o]||(e.rows[o]={}),e.rows[o])}const eC=/^(yy|yyyy|m{1,5}|d{1,4}|h{1,2}|s{1,2}|am\/pm|a\/m|\s|-|\/|\.|:)+$/i;function tC(e,t,o){if(0===e)return;let s=By[e]||t.find((t=>t.id===e))?.format;if(s)try{let e=s.replace(/\[(.*)-[A-Z0-9]{3}\]/g,"[$1]");if(e=e.replace(/\[\$\]/g,""),e=e.replace(/_.{1}/g,""),e=e.replace(/\*.{1}/g,""),function(e){return eC.test(e)}(e)&&(e=function(e){return e=e.toLowerCase(),e=e.replace(/mmmmm/g,"mmm"),e=e.replace(/am\/pm|a\/m/g,"a"),e=e.replace(/hhhh/g,"hh"),e=e.replace(/\bh\b/g,"hh"),e}(e)),function(e){try{return Jn(0,{format:e,locale:Si}),!0}catch(e){return!1}}(e))return e}catch(e){}o.generateNotSupportedWarning(wy.NumFmtIdNotSupported,s||`nmFmtId ${e}`)}function oC(e,t){const o=e.borders.map((e=>{!function(e,t){e.diagonal&&t.generateNotSupportedWarning(wy.DiagonalBorderNotSupported)}(e,t);const o={top:sC(e.top,t),bottom:sC(e.bottom,t),left:sC(e.left,t),right:sC(e.right,t)};return Object.keys(o).forEach((e=>void 0===o[e]&&delete o[e])),o}));return Ky(o,1)}function sC(e,t){if(!e)return;!function(e,t){Ey.includes(e.style)||t.generateNotSupportedWarning(wy.BorderStyleNotSupported,e.style,Ey)}(e,t);const o=Oy[e.style];return o?{style:o,color:jy(e.color)}:void 0}function iC(e,t){return Ky(e.styles.map((o=>nC({fontStyle:e.fonts[o.fontId],fillStyle:e.fills[o.fillId],alignment:o.alignment},t))),1)}function nC(e,t){return function(e,t,o){e&&e.name&&!Ty.includes(e.name)&&o.generateNotSupportedWarning(wy.FontNotSupported,e.name,Ty);t&&t.patternType&&!Ay.includes(t.patternType)&&o.generateNotSupportedWarning(wy.FillStyleNotSupported,t.patternType,Ay)}(e?.fontStyle,e?.fillStyle,t),function(e,t){e&&!Iy.includes(e)&&t.generateNotSupportedWarning(wy.HorizontalAlignmentNotSupported,e,Iy)}(e?.alignment?.horizontal,t),function(e,t){e&&!Ry.includes(e)&&t.generateNotSupportedWarning(wy.VerticalAlignmentNotSupported,e,Ry)}(e?.alignment?.vertical,t),{bold:e.fontStyle?.bold,italic:e.fontStyle?.italic,strikethrough:e.fontStyle?.strike,underline:e.fontStyle?.underline,verticalAlign:e.alignment?.vertical?My[e.alignment.vertical]:void 0,align:e.alignment?.horizontal?Fy[e.alignment.horizontal]:void 0,fillColor:"solid"===e.fillStyle?.patternType?jy(e.fillStyle?.fgColor):jy(e.fillStyle?.bgColor),textColor:jy(e.fontStyle?.color),fontSize:e.fontStyle?.size,wrapping:e.alignment?.wrapText?"wrap":"overflow"}}function rC(e,t){const o=[];for(let s of e.styles){const i=tC(s.numFmtId,e.numFmts,t);i&&(o[s.numFmtId]=i)}return Ky(o,1)}function aC(e,t,o){const s=[];let i=1;for(let r of e){if(0===r.cfRules.length)continue;uC(r,t,o);const e=r.cfRules[0];let a;const l=[];if(void 0!==e.dxfId||"colorScale"===e.type||"iconSet"===e.type||"dataBar"===e.type){switch(e.type){case"aboveAverage":case"containsErrors":case"notContainsErrors":case"duplicateValues":case"expression":case"top10":case"uniqueValues":case"timePeriod":continue;case"dataBar":const t=lC(i++,r);t&&s.push(t);continue;case"colorScale":const c=cC(i++,r);c&&s.push(c);continue;case"iconSet":const h=hC(i++,r,o);h&&s.push(h);continue;case"containsText":case"notContainsText":case"beginsWith":case"endsWith":if(!e.text)continue;a=Ny[e.type],l.push(e.text);break;case"containsBlanks":case"notContainsBlanks":a=Ny[e.type];break;case"cellIs":if(!e.operator||!e.formula||0===e.formula.length)continue;a=(n=e.operator).slice(0,1).toUpperCase()+n.slice(1),l.push(e.formula[0]),2===e.formula.length&&l.push(e.formula[1])}a&&void 0!==e.dxfId&&s.push({id:(i++).toString(),ranges:r.sqref,stopIfTrue:e.stopIfTrue,rule:{type:"CellIsRule",operator:a,values:l,style:nC({fontStyle:t[e.dxfId].font,fillStyle:t[e.dxfId].fill},o)}})}}var n;return s}function lC(e,t){const o=t.cfRules[0].dataBar;if(!o)return;const s=Yy(jy(o.color)||"#FFFFFF");return{id:e.toString(),stopIfTrue:t.cfRules[0].stopIfTrue,ranges:t.sqref,rule:{type:"DataBarRule",color:s}}}function cC(e,t){const o=t.cfRules[0].colorScale;if(!o||o.cfvos.length!==o.colors.length||o.cfvos.length<2||o.cfvos.length>3)return;const s=[];for(let e=0;e<o.cfvos.length;e++)s.push({color:Yy(jy(o.colors[e])||"#FFFFFF"),type:ky[o.cfvos[e].type],value:o.cfvos[e].value});const i=s[0],n=2===s.length?s[1]:s[2],r=3===s.length?s[1]:void 0;return{id:e.toString(),stopIfTrue:t.cfRules[0].stopIfTrue,ranges:t.sqref,rule:{type:"ColorScaleRule",minimum:i,midpoint:r,maximum:n}}}function hC(e,t,o){const s=t.cfRules[0].iconSet;if(!s)return;let i=s.cfvos,n=s.cfIcons;if(i.length<3||n&&n.length<3)return;i.length>3&&(i=[i[0],i[Math.floor(i.length/2)],i[i.length-1]]),n&&n.length>3&&(n=[n[0],n[Math.floor(n.length/2)],n[n.length-1]]);const r=[];for(let e=1;e<=2;e++){const t=ky[i[e].type];if("value"===t)return;r.push({value:i[e].value||"",operator:i[e].gte?"ge":"gt",type:t})}let a={lower:n?dC(n[0].iconSet,n[0].iconId):dC(s.iconSet,0),middle:n?dC(n[1].iconSet,n[1].iconId):dC(s.iconSet,1),upper:n?dC(n[2].iconSet,n[2].iconId):dC(s.iconSet,2)};s.reverse&&(a={upper:a.lower,middle:a.middle,lower:a.upper});for(let e of Object.keys(a))if(!a[e])switch(o.generateNotSupportedWarning(wy.CfIconSetEmptyIconNotSupported),e){case"upper":a[e]=Cy.dots.good;break;case"middle":a[e]=Cy.dots.neutral;break;case"lower":a[e]=Cy.dots.bad}return{id:e.toString(),stopIfTrue:t.cfRules[0].stopIfTrue,ranges:t.sqref,rule:{type:"IconSetRule",icons:a,upperInflectionPoint:r[1],lowerInflectionPoint:r[0]}}}function dC(e,t){const o=Ly[e];return o?0===t?Cy[o].bad:1===t?Cy[o].neutral:Cy[o].good:""}function uC(e,t,o){if(e.cfRules.length>1&&o.generateNotSupportedWarning(wy.MultipleRulesCfNotSupported),_y.includes(e.cfRules[0].type)||o.generateNotSupportedWarning(wy.CfTypeNotSupported,e.cfRules[0].type),e.cfRules[0].dxfId){const s=t[e.cfRules[0].dxfId];s.border&&o.generateNotSupportedWarning(wy.CfFormatBorderNotSupported),s.alignment&&o.generateNotSupportedWarning(wy.CfFormatAlignmentNotSupported),s.numFmt&&o.generateNotSupportedWarning(wy.CfFormatNumFmtNotSupported)}}function gC(e){switch(e){case"IsNotEmpty":case"NotContains":return"notContainsBlanks";case"IsEmpty":return"containsBlanks";default:return e.charAt(0).toLowerCase()+e.slice(1)}}function pC(e){return Math.round(ly*e*100)/100}function mC(e){return Math.round(cy*e*100)/100}function fC(e,t,o,s,i){const n=o?e.styles[o]:{},r=s?e.formats[s]:void 0,a={font:{size:n?.fontSize||me,color:{rgb:n?.textColor?n.textColor:"000000"},family:2,name:"Arial"},fill:n?.fillColor?{fgColor:{rgb:n.fillColor}}:{reservedAttribute:"none"},numFmt:r?{format:r,id:0}:void 0,border:i||0,alignment:{horizontal:n.align,vertical:n.verticalAlign?Py[n.verticalAlign]:void 0,wrapText:!("wrap"!==n.wrapping&&!t?.includes(Pe))||void 0}};return a.font.strike=!!n?.strikethrough||void 0,a.font.underline=!!n?.underline||void 0,a.font.bold=!!n?.bold||void 0,a.font.italic=!!n?.italic||void 0,a}function vC(e,t){const o=function(e,t){if(!e)return 0;let o=zy[e.format];o||(o=SC(e,t)+py);return o}(t.numFmt,e.numFmts),s={fontId:SC(t.font,e.fonts),fillId:SC(t.fill,e.fills),borderId:t.border,numFmtId:o,alignment:{vertical:t.alignment.vertical,horizontal:t.alignment.horizontal,wrapText:t.alignment.wrapText}};return SC(s,e.styles)}function bC(e,t,o){let s,i=e.find((e=>e.path===t));return i?(s=`rId${(i.rels.length+1).toString()}`,i.rels.push({...o,id:s})):(s="rId1",e.push({path:t,rels:[{...o,id:s}]})),s}function SC(e,t){let o=t.length;const s="object"==typeof e?mt:(e,t)=>e===t;for(let i=0;i<o;i++)if(s(e,t[i]))return i;return t[t.length]=e,t.length-1}const yC=[];function CC(e){const t=yC.findIndex((t=>t===e));return-1===t?(yC.push(e),yC.length):t+1}const wC=[];function xC(e){const t=wC.findIndex((t=>t===e));return-1===t?(wC.push(e),wC.length):t+1}function EC(e){return Math.round(914400*e/96)}function IC(e,t,o){let s,i,n=e;if(({xc:n,sheetName:s}=qo(e)),s){const e=o.sheets.findIndex((e=>e.name===s));if(e<0)throw new Error("Unable to find a sheet with the name "+s);i=e}else i=Number(t);const r=jo(n);return void 0===r.right&&(r.right=o.sheets[i].colNumber),void 0===r.bottom&&(r.bottom=o.sheets[i].rowNumber),(r.right-r.left+1)*(r.bottom-r.top+1)}function RC(e){return Math.round(96*e/914400)}function TC(e,t){let o=0;for(let s=0;s<e;s++){const e=t.cols.find((e=>s>=e.min&&s<=e.max));e?.width?o+=e.width:t.sheetFormat?.defaultColWidth?o+=t.sheetFormat.defaultColWidth:o+=hy}return o/cy}function AC(e,t){let o=0;for(let s=0;s<e;s++){const e=t.rows[s];e?.height?o+=e.height:t.sheetFormat?.defaultRowHeight?o+=t.sheetFormat.defaultRowHeight:o+=dy}return o/ly}function _C(e){let t=1;return e.figures.map((o=>function(e,t,o){let s,i,n,r;if(1===e.anchors.length)({x:s,y:i}=FC(e.anchors[0],o)),r=RC(e.figureSize.cx),n=RC(e.figureSize.cy);else{({x:s,y:i}=FC(e.anchors[0],o));const{x:t,y:a}=FC(e.anchors[1],o);r=t-s,n=a-i}const a={id:t,x:s,y:i};if("dataSets"in(l=e.data)&&l.dataSets.length>0)return{...a,width:r,height:n,tag:"chart",data:DC(e.data)};if(function(e){return"imageSrc"in e}(e.data))return{...a,width:RC(e.data.size.cx),height:RC(e.data.size.cy),tag:"image",data:{path:e.data.imageSrc,mimetype:e.data.mimetype}};var l;return}(o,(t++).toString(),e))).filter(at)}function DC(e){const t=e.dataSets.some((e=>"reference"in(e.label??{}))),o=e.labelRange?OC(e.labelRange,t):void 0,s=e.dataSets.map((e=>{let o;return e.label&&"text"in e.label&&(o=e.label.text),{dataRange:OC(e.range,t),label:o,backgroundColor:e.backgroundColor}}));return"pie"===e.type&&s.reverse(),{dataSets:s,dataSetsHaveTitle:t,labelRange:o,title:e.title??{text:""},type:e.type,background:jy({rgb:e.backgroundColor})||"#FFFFFF",legendPosition:e.legendPosition,stacked:e.stacked||!1,aggregated:!1,cumulative:e.cumulative||!1,labelsAsText:!1}}function OC(e,t){let{sheetName:o,xc:s}=qo(e),i=jo(s);if(t&&void 0!==i.bottom&&void 0!==i.right){const e=i.bottom-i.top+1,t=i.right-i.left+1;1===e?i={...i,left:i.left-1}:1===t&&(i={...i,top:i.top-1})}return Zo(o,Jo(i))}function FC(e,t){return{x:TC(e.col,t)+RC(e.colOffset),y:AC(e.row,t)+RC(e.rowOffset)}}function MC(e,t){const o=[];let s=1;for(const i of e)if(i)switch(i.type){case"time":t.generateNotSupportedWarning(wy.TimeDataValidationNotSupported);break;case"textLength":t.generateNotSupportedWarning(wy.TextLengthDataValidationNotSupported);break;case"whole":t.generateNotSupportedWarning(wy.WholeNumberDataValidationNotSupported);break;case"decimal":const e=PC(s++,i);o.push(e);break;case"list":const n=NC(s++,i);o.push(n);break;case"date":if("notEqual"===i.operator){t.generateNotSupportedWarning(wy.NotEqualDateDataValidationNotSupported);break}const r=kC(s++,i);o.push(r);break;case"custom":const a=LC(s++,i);o.push(a)}return o}function PC(e,t){const o=[t.formula1.toString()];return t.formula2&&o.push(t.formula2.toString()),{id:e.toString(),ranges:t.sqref,isBlocking:"warning"!==t.errorStyle,criterion:{type:qy[t.operator],values:o}}}function NC(e,t){const o=t.formula1.toString(),s=Uo.test(o);return{id:e.toString(),ranges:t.sqref,isBlocking:"warning"!==t.errorStyle,criterion:{type:s?"isValueInRange":"isValueInList",values:s?[o]:o.replaceAll('"',"").split(","),displayStyle:"arrow"}}}function kC(e,t){let o;const s=[t.formula1.toString()];return t.formula2?(s.push(t.formula2.toString()),o={type:Zy[t.operator],values:Pr(s,Si)}):o={type:Zy[t.operator],values:Pr(s,Si),dateValue:"exactDate"},{id:e.toString(),ranges:t.sqref,isBlocking:"warning"!==t.errorStyle,criterion:o}}function LC(e,t){return{id:e.toString(),ranges:t.sqref,isBlocking:"warning"!==t.errorStyle,criterion:{type:"customFormula",values:[`=${t.formula1.toString()}`]}}}const VC=new RegExp(/'?\[([0-9]*)\](.*)'?!(\$?[a-zA-Z]*\$?[0-9]*)/g),HC=new RegExp(/SUBTOTAL\(([0-9]*),/g),UC=new RegExp(Po.source,"ig");function BC(e,t){const o=function(e){const t={};for(let o of e.rows)for(let e of o.cells)e.formula&&void 0!==e.formula.sharedIndex&&e.formula.content&&(t[e.formula.sharedIndex]={refCellXc:e.xc,formula:e.formula.content});return t}(e);for(let s of e.rows.map((e=>e.cells)).flat())s?.formula&&(s.formula.content=void 0===s.formula.sharedIndex||s.formula.content?"="+s.formula.content:"="+$C(s.xc,o[s.formula.sharedIndex]),s.formula.content=zC(s.formula.content,t))}function zC(e,t){return e=(e=(e=(e=e.replace("_xlfn.","")).replace(/#REF!/g,"#REF")).replace(HC,((e,t)=>{const o=Uy[t];return o?o+"(":e}))).replace(VC,((e,o,s,i)=>{o=Number(o)-1,i=i.replace(/\$/g,"");const n=t.externalBooks[o].sheetNames.findIndex((e=>e===s));if(-1===n)return e;const r=t.externalBooks[o].datasets.find((e=>e.sheetId===n))?.data;if(!r)return e;const a=r&&r[i];return(Number(a)?a:`"${a}"`)||e}))}function $C(e,t){const o=So(t.refCellXc);let s,i=t.formula.slice();do{if(s=UC.exec(i),s){const t=So(s[0].replace("$","")),n=So(e),r={colFixed:s[0].startsWith("$"),rowFixed:s[0].includes("$",1)},a={col:n.col-o.col,row:n.row-o.row},l={col:r.colFixed?t.col:t.col+a.col,row:r.rowFixed?t.row:t.row+a.row};i=i.slice(0,s.index)+yo(l.col,l.row,r)+i.slice(s.index+s[0].length)}}while(s);return i}function WC(e,t){return e.sheets.map((o=>{BC(o,e);const s=function(e){const t=[0,0];for(let o of e.rows)t[0]=Math.max(t[0],Dt(o.cells.map((e=>So(e.xc).col)))),t[1]=Math.max(t[1],o.index);return t[0]=Math.max(t[0],uy),t[1]=Math.max(t[1],gy),t}(o),i=o.sheetViews[0],n=YC(o,"ROW",s[1]),r=YC(o,"COL",s[0]);return{id:o.sheetName,areGridLinesVisible:!i||i.showGridLines,name:o.sheetName,colNumber:s[0],rowNumber:s[1],...ZC(o,e,s,t),merges:o.merges,cols:GC(o,s[0],r),rows:qC(o,s[1],n),conditionalFormats:aC(o.cfs,e.dxfs,t),dataValidationRules:MC(o.dataValidations,t),figures:_C(o),isVisible:o.isVisible,panes:i?{xSplit:i.pane.xSplit,ySplit:i.pane.ySplit}:{xSplit:0,ySplit:0},tables:[],headerGroups:{COL:r,ROW:n},color:jy(o.sheetProperties?.tabColor)}}))}function GC(e,t,o){const s={};for(let n=1;n<t+1;n++){const t=e.cols.find((e=>e.min<=n&&n<=e.max));let r;r=t&&t.width?t.width:e.sheetFormat?.defaultColWidth?e.sheetFormat.defaultColWidth:hy;const a=n-1,l=o.some((e=>e.isFolded&&e.start<=a&&a<=e.end));s[a]={size:(i=r,i?Math.round(i/cy*100)/100:i),isHidden:!l&&t?.hidden}}var i;return s}function qC(e,t,o){const s={};for(let n=1;n<t+1;n++){const t=e.rows.find((e=>e.index===n));let r;r=t&&t.height?t.height:e.sheetFormat?.defaultRowHeight?e.sheetFormat.defaultRowHeight:dy;const a=n-1,l=o.some((e=>e.isFolded&&e.start<=a&&a<=e.end));s[a]={size:(i=r,i?Math.round(i/ly*100)/100:i),isHidden:!l&&t?.hidden}}var i;return s}function ZC(e,t,o,s){const i={},n={},r={},a={},l=t.sharedStrings.map(wt);const c=e.hyperlinks.reduce(((e,t)=>(e[t.xc]=t,e)),{});for(let o of e.rows)for(let e of o.cells)i[e.xc]=jC(e,c,l,s),e.styleIndex&&(n[e.xc]=e.styleIndex+1,r[e.xc]=t.styles[e.styleIndex].numFmtId+1,a[e.xc]=t.styles[e.styleIndex].borderId+1);for(let s of e.rows.filter((e=>e.styleIndex)))for(let e=1;e<=o[0];e++){const o=yo(e-1,s.index-1);n[o]??=s.styleIndex+1,a[o]??=t.styles[s.styleIndex].borderId+1,r[o]??=t.styles[s.styleIndex].numFmtId+1}for(let s of e.cols.filter((e=>e.styleIndex)))for(let e=s.min;e<=Math.min(s.max,o[0]);e++)for(let i=1;i<=o[1];i++){const o=yo(e-1,i-1);n[o]??=s.styleIndex+1,a[o]??=t.styles[s.styleIndex].borderId+1,r[o]??=t.styles[s.styleIndex].numFmtId+1}return{cells:i,styles:n,formats:r,borders:a}}function jC(e,t,o,s){let i;switch(e.type){case"sharedString":i=o[parseInt(e.value,10)];break;case"boolean":i=Number(e.value)?"TRUE":"FALSE";break;case"date":case"error":case"inlineStr":case"number":case"str":i=e.value}return i&&t[e.xc]&&(i=function(e,t,o){const s=e.display||t;e.relTarget||e.location||o.generateNotSupportedWarning(wy.BadlyFormattedHyperlink);const i=e.relTarget?e.relTarget:nt(qo(e.location).sheetName);return tt(s,i)}(t[e.xc],i,s)),e.formula&&(i=e.formula.content),i}function YC(e,t,o){const s=e?.sheetProperties?.outlinePr,i=[];let n=0;for(let r=0;r<o;r++){const o=KC(e,t,r),a=o?.outlineLevel||0;if(a>n){const o=XC(e,t,r,("ROW"===t?s?.summaryBelow:s?.summaryRight)??!0);o&&i.push(o)}n=a}return i}function XC(e,t,o,s){const i=KC(e,t,o),n=i?.outlineLevel;if(!n||!n)return;let r=n,a=o,l=i;for(;l&&r>=n;)a++,l=KC(e,t,a),r=l?.outlineLevel||0;const c=o,h=a-1,d=KC(e,t,s?h+1:c-1);return{start:c-1,end:h-1,isFolded:d?.collapsed||!1}}function KC(e,t,o){return"COL"===t?e.cols.find((e=>e.min<=o&&o<=e.max)):e.rows.find((e=>e.index===o))}const JC={light:Fo("Light"),medium:Fo("Medium"),dark:Fo("Dark"),custom:Fo("Custom")},QC={hasFilters:!1,totalRow:!1,firstColumn:!1,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,automaticAutofill:!0,styleId:"TableStyleMedium2"};function ew(e,t){return{coloredText:eo(t,.3),light:Qt(t,.8),medium:Qt(t,.6),dark:eo(t,.3),mediumBorder:Qt(t,.45),highlight:t,name:e}}const tw={black:{name:Fo("Black"),coloredText:"#000000",light:"#D9D9D9",medium:"#A6A6A6",dark:"#404040",mediumBorder:"#000000",highlight:"#000000"},lightBlue:ew(Fo("Light blue"),"#346B90"),red:ew(Fo("Red"),"#C53628"),lightGreen:ew(Fo("Light green"),"#748747"),purple:ew(Fo("Purple"),"#6C4E65"),gray:{name:Fo("Gray"),coloredText:"#666666",light:"#EEEEEE",medium:"#DDDDDD",dark:"#767676",mediumBorder:"#D0D0D0",highlight:"#A9A9A9"},orange:ew(Fo("Orange"),"#C37034")},ow={black:tw.black,orangeBlue:{...tw.lightBlue,highlight:tw.orange.highlight},purpleGreen:{...tw.lightGreen,highlight:tw.purple.highlight},redBlue:{...tw.lightBlue,highlight:tw.red.highlight}},sw=e=>({category:"light",templateName:"lightColoredText",primaryColor:e.highlight,wholeTable:{style:{textColor:e.coloredText},border:{top:{color:e.highlight,style:"thin"},bottom:{color:e.highlight,style:"thin"}}},headerRow:{border:{bottom:{color:e.highlight,style:"thin"}}},totalRow:{border:{top:{color:e.highlight,style:"thin"}}},firstRowStripe:{style:{fillColor:e.light}}}),iw=e=>({category:"light",templateName:"lightWithHeader",primaryColor:e.highlight,wholeTable:{border:{top:{color:e.highlight,style:"thin"},bottom:{color:e.highlight,style:"thin"},left:{color:e.highlight,style:"thin"},right:{color:e.highlight,style:"thin"}}},headerRow:{style:{fillColor:e.highlight,textColor:"#FFFFFF"},border:{bottom:{color:e.highlight,style:"thin"}}},totalRow:{border:{top:{color:e.highlight,style:"medium"}}},firstRowStripe:{border:{bottom:{color:e.highlight,style:"thin"}}},secondRowStripe:{border:{bottom:{color:e.highlight,style:"thin"}}}}),nw=e=>({category:"light",templateName:"lightAllBorders",primaryColor:e.highlight,wholeTable:{border:{top:{color:e.highlight,style:"thin"},bottom:{color:e.highlight,style:"thin"},left:{color:e.highlight,style:"thin"},right:{color:e.highlight,style:"thin"},horizontal:{color:e.highlight,style:"thin"},vertical:{color:e.highlight,style:"thin"}}},headerRow:{border:{bottom:{color:e.highlight,style:"medium"}}},totalRow:{border:{top:{color:e.highlight,style:"medium"}}},firstRowStripe:{style:{fillColor:e.light}},firstColumnStripe:{style:{fillColor:e.light}}}),rw=e=>({category:"medium",templateName:"mediumBandedBorders",primaryColor:e.highlight,wholeTable:{border:{top:{color:e.mediumBorder,style:"thin"},bottom:{color:e.mediumBorder,style:"thin"},left:{color:e.mediumBorder,style:"thin"},right:{color:e.mediumBorder,style:"thin"},horizontal:{color:e.mediumBorder,style:"thin"}}},headerRow:{style:{fillColor:e.highlight,textColor:"#FFFFFF"}},totalRow:{border:{top:{color:e.highlight,style:"medium"}}},firstRowStripe:{style:{fillColor:e.light}},firstColumnStripe:{style:{fillColor:e.light}}}),aw=e=>({category:"medium",templateName:"mediumWhiteBorders",primaryColor:e.highlight,wholeTable:{border:{horizontal:{color:"#FFFFFF",style:"thin"},vertical:{color:"#FFFFFF",style:"thin"}},style:{fillColor:e.light}},headerRow:{border:{bottom:{color:"#FFFFFF",style:"thick"}},style:{fillColor:e.highlight,textColor:"#FFFFFF"}},totalRow:{border:{top:{color:"#FFFFFF",style:"thick"}},style:{fillColor:e.highlight,textColor:"#FFFFFF"}},firstColumn:{style:{fillColor:e.highlight,textColor:"#FFFFFF"}},lastColumn:{style:{fillColor:e.highlight,textColor:"#FFFFFF"}},firstRowStripe:{style:{fillColor:e.medium}},firstColumnStripe:{style:{fillColor:e.medium}}}),lw=e=>({category:"medium",templateName:"mediumMinimalBorders",primaryColor:e.highlight,wholeTable:{border:{top:{color:"#000000",style:"medium"},bottom:{color:"#000000",style:"medium"}}},totalRow:{border:{top:{color:"#000000",style:"medium"}}},headerRow:{style:{fillColor:e.highlight,textColor:"#FFFFFF"},border:{bottom:{color:"#000000",style:"medium"}}},firstColumn:{style:{fillColor:e.highlight,textColor:"#FFFFFF"}},lastColumn:{style:{fillColor:e.highlight,textColor:"#FFFFFF"}},firstRowStripe:{style:{fillColor:tw.black.light}},firstColumnStripe:{style:{fillColor:tw.black.light}}}),cw=e=>({category:"medium",templateName:"mediumAllBorders",primaryColor:e.highlight,wholeTable:{border:{top:{color:e.mediumBorder,style:"thin"},bottom:{color:e.mediumBorder,style:"thin"},left:{color:e.mediumBorder,style:"thin"},right:{color:e.mediumBorder,style:"thin"},horizontal:{color:e.mediumBorder,style:"thin"},vertical:{color:e.mediumBorder,style:"thin"}},style:{fillColor:e.light}},totalRow:{border:{top:{color:e.highlight,style:"medium"}}},firstRowStripe:{style:{fillColor:e.medium}},firstColumnStripe:{style:{fillColor:e.medium}}}),hw=e=>({category:"dark",templateName:"dark",primaryColor:e.highlight,wholeTable:{style:{fillColor:e.highlight,textColor:"#FFFFFF"}},totalRow:{style:{fillColor:e.dark,textColor:"#FFFFFF"},border:{top:{color:"#FFFFFF",style:"thick"}}},headerRow:{style:{fillColor:"#000000"},border:{bottom:{color:"#FFFFFF",style:"thick"}}},firstColumn:{style:{fillColor:e.dark},border:{right:{color:"#FFFFFF",style:"thick"}}},lastColumn:{style:{fillColor:e.dark},border:{left:{color:"#FFFFFF",style:"thick"}}},firstRowStripe:{style:{fillColor:e.dark}},firstColumnStripe:{style:{fillColor:e.dark}}}),dw=e=>({category:"dark",templateName:"darkNoBorders",primaryColor:e.highlight,wholeTable:{style:{fillColor:e.light}},totalRow:{border:{top:{color:"#000000",style:"medium"}}},headerRow:{style:{fillColor:e.highlight,textColor:"#FFFFFF"}},firstRowStripe:{style:{fillColor:e.medium}},firstColumnStripe:{style:{fillColor:e.medium}}}),uw=hw(tw.black);uw.wholeTable.style.fillColor="#737373";const gw=lw(tw.black);function pw(e,t,o){return{...t(o),displayName:`${o.name}, ${e}`}}gw.wholeTable.border={...gw.wholeTable.border,left:{color:"#000000",style:"thin"},right:{color:"#000000",style:"thin"},horizontal:{color:"#000000",style:"thin"},vertical:{color:"#000000",style:"thin"}};const mw={None:{category:"light",templateName:"none",primaryColor:"",displayName:"none"},TableStyleLight1:pw("TableStyleLight1",sw,tw.black),TableStyleLight2:pw("TableStyleLight2",sw,tw.lightBlue),TableStyleLight3:pw("TableStyleLight3",sw,tw.red),TableStyleLight4:pw("TableStyleLight4",sw,tw.lightGreen),TableStyleLight5:pw("TableStyleLight5",sw,tw.purple),TableStyleLight6:pw("TableStyleLight6",sw,tw.gray),TableStyleLight7:pw("TableStyleLight7",sw,tw.orange),TableStyleLight8:pw("TableStyleLight8",iw,tw.black),TableStyleLight9:pw("TableStyleLight9",iw,tw.lightBlue),TableStyleLight10:pw("TableStyleLight10",iw,tw.red),TableStyleLight11:pw("TableStyleLight11",iw,tw.lightGreen),TableStyleLight12:pw("TableStyleLight12",iw,tw.purple),TableStyleLight13:pw("TableStyleLight13",iw,tw.gray),TableStyleLight14:pw("TableStyleLight14",iw,tw.orange),TableStyleLight15:pw("TableStyleLight15",nw,tw.black),TableStyleLight16:pw("TableStyleLight16",nw,tw.lightBlue),TableStyleLight17:pw("TableStyleLight17",nw,tw.red),TableStyleLight18:pw("TableStyleLight18",nw,tw.lightGreen),TableStyleLight19:pw("TableStyleLight19",nw,tw.purple),TableStyleLight20:pw("TableStyleLight20",nw,tw.gray),TableStyleLight21:pw("TableStyleLight21",nw,tw.orange),TableStyleMedium1:pw("TableStyleMedium1",rw,tw.black),TableStyleMedium2:pw("TableStyleMedium2",rw,tw.lightBlue),TableStyleMedium3:pw("TableStyleMedium3",rw,tw.red),TableStyleMedium4:pw("TableStyleMedium4",rw,tw.lightGreen),TableStyleMedium5:pw("TableStyleMedium5",rw,tw.purple),TableStyleMedium6:pw("TableStyleMedium6",rw,tw.gray),TableStyleMedium7:pw("TableStyleMedium7",rw,tw.orange),TableStyleMedium8:pw("TableStyleMedium8",aw,tw.black),TableStyleMedium9:pw("TableStyleMedium9",aw,tw.lightBlue),TableStyleMedium10:pw("TableStyleMedium10",aw,tw.red),TableStyleMedium11:pw("TableStyleMedium11",aw,tw.lightGreen),TableStyleMedium12:pw("TableStyleMedium12",aw,tw.purple),TableStyleMedium13:pw("TableStyleMedium13",aw,tw.gray),TableStyleMedium14:pw("TableStyleMedium14",aw,tw.orange),TableStyleMedium15:{...gw,displayName:"Black, TableStyleMedium15"},TableStyleMedium16:pw("TableStyleMedium16",lw,tw.lightBlue),TableStyleMedium17:pw("TableStyleMedium17",lw,tw.red),TableStyleMedium18:pw("TableStyleMedium18",lw,tw.lightGreen),TableStyleMedium19:pw("TableStyleMedium19",lw,tw.purple),TableStyleMedium20:pw("TableStyleMedium20",lw,tw.gray),TableStyleMedium21:pw("TableStyleMedium21",lw,tw.orange),TableStyleMedium22:pw("TableStyleMedium22",cw,tw.black),TableStyleMedium23:pw("TableStyleMedium23",cw,tw.lightBlue),TableStyleMedium24:pw("TableStyleMedium24",cw,tw.red),TableStyleMedium25:pw("TableStyleMedium25",cw,tw.lightGreen),TableStyleMedium26:pw("TableStyleMedium26",cw,tw.purple),TableStyleMedium27:pw("TableStyleMedium27",cw,tw.gray),TableStyleMedium28:pw("TableStyleMedium28",cw,tw.orange),TableStyleDark1:{...uw,displayName:"Black, TableStyleDark1"},TableStyleDark2:pw("TableStyleDark2",hw,tw.lightBlue),TableStyleDark3:pw("TableStyleDark3",hw,tw.red),TableStyleDark4:pw("TableStyleDark4",hw,tw.lightGreen),TableStyleDark5:pw("TableStyleDark5",hw,tw.purple),TableStyleDark6:pw("TableStyleDark6",hw,tw.gray),TableStyleDark7:pw("TableStyleDark7",hw,tw.orange),TableStyleDark8:pw("TableStyleDark8",dw,ow.black),TableStyleDark9:pw("TableStyleDark9",dw,ow.redBlue),TableStyleDark10:pw("TableStyleDark10",dw,ow.purpleGreen),TableStyleDark11:pw("TableStyleDark11",dw,ow.orangeBlue)},fw={none:()=>({category:"none",templateName:"none",primaryColor:"",name:"none"}),lightColoredText:sw,lightAllBorders:nw,mediumAllBorders:cw,lightWithHeader:iw,mediumBandedBorders:rw,mediumMinimalBorders:lw,darkNoBorders:dw,mediumWhiteBorders:aw,dark:hw};function vw(e,t,o){const s=ew("",o);return{...fw[t](s),category:"custom",displayName:e}}function bw(e,t){for(const o of t.sheets){const t=e.sheets.find((e=>e.name===o.sheetName));if(t){t.tables||(t.tables=[]);for(const e of o.tables)t.tables.push({range:e.ref,config:Sw(e)});for(const e of o.pivotTables)t.tables.push({range:e.location.ref,config:yw(e)})}}!function(e,t){for(let o of e){const e=t.find((e=>e.sheetName===o.name)).tables;for(let t of e){const e=t.name+"[";for(let s of us(Yo(t.ref))){const i=yo(s.col,s.row);let n=o.cells[i];if(n?.startsWith("=")){let s;for(;-1!==(s=n.indexOf(e));){let o=n.slice(s+e.length),r=o.indexOf("]");o.startsWith("[")&&(r=o.indexOf("]",r+1),r=o.indexOf("]",r+1)),o=o.slice(0,r);const a=Cw(o,t,i);n=n.slice(0,s)+a+n.slice(e.length+s+r+1)}o.cells[i]=n}}}}}(e.sheets,t.sheets)}function Sw(e){const t=e.style?.name||"";return{hasFilters:void 0!==e.autoFilter,numberOfHeaders:e.headerRowCount,totalRow:e.totalsRowCount>0,firstColumn:e.style?.showFirstColumn||!1,lastColumn:e.style?.showLastColumn||!1,bandedRows:e.style?.showRowStripes||!1,bandedColumns:e.style?.showColumnStripes||!1,styleId:mw[t]?t:QC.styleId}}function yw(e){return{hasFilters:!1,numberOfHeaders:e.location.firstDataRow,totalRow:e.rowGrandTotals,firstColumn:!0,lastColumn:e.style?.showLastColumn||!1,bandedRows:e.style?.showRowStripes||!1,bandedColumns:e.style?.showColStripes||!1,styleId:QC.styleId}}function Cw(e,t,o){const s=e.split(","),i=Yo(t.ref),n={...i};let r=!0;if(1===s.length){const e=t.cols.findIndex((e=>e.name===s[0]));n.left=n.right=e+i.left,t.headerRowCount&&(n.top+=t.headerRowCount),t.totalsRowCount&&(n.bottom-=1)}else{switch(s[0].slice(1,s[0].length-1)){case"#All":n.top=t.headerRowCount?i.top+t.headerRowCount:i.top,n.bottom=i.bottom;break;case"#Data":n.top=t.headerRowCount?i.top+t.headerRowCount:i.top,n.bottom=t.totalsRowCount?i.bottom+1:i.bottom;break;case"#This Row":n.top=n.bottom=So(o).row;break;case"#Headers":n.top=n.bottom=i.top,t.headerRowCount||(r=!1);break;case"#Totals":n.top=n.bottom=i.bottom,t.totalsRowCount||(r=!1)}const e=s[1].slice(1,s[1].length-1),a=t.cols.findIndex((t=>t.name===e));n.left=n.right=a+i.left}return r?n.top!==n.bottom?Jo(n):yo(n.left,n.top):Ii.InvalidReference}function ww(e,t,o){return{content:(new XMLSerializer).serializeToString(e),path:t,contentType:o}}function xw(e){return String(e).replace(/\&/g,"&").replace(/\</g,"<").replace(/\>/g,">").replace(/\"/g,""").replace(/\'/g,"'").replace(/[\x00-\x08\x0B\x0C\x0E-\x1F]/g,"")}function Ew(e){return new JS(e.map((([e,t])=>`${e}="${xw(t)}"`)).join(" "))}function Iw(e,t="text/xml"){const o=(new DOMParser).parseFromString(e.toString(),t),s=o.querySelector("parsererror");if(s){const t=s.innerHTML,o=parseInt(t.split(":")[0],10),i=e.toString().trim().split("\n"),n=i.slice(Math.max(o-3,0),Math.min(o+2,i.length)).join("\n");throw new Error(`XML string could not be parsed: ${t}\n${n}`)}return o}function Rw(e){if(e)return{style:e.style,color:{rgb:e.color}}}function Tw(e,t){return _w`
|
|
35
35
|
<Override ContentType="${t}" PartName="${e}" />
|
|
36
|
-
`}function Aw(e){return new JS(e.join("\n"))}function _w(e,...t){let o=[e[0]];for(let s=0;s<t.length;s++){const i=t[s]instanceof JS?t[s]:xw(t[s]);o.push(i+e[s+1])}return new JS(dt(o))}function Dw(e){return e.replace(/NAMESPACE.*NAMESPACE(.*)/,"$1")}function Ow(e){return e.replaceAll(/([a-zA-Z0-9]+):([a-zA-Z0-9]+)/g,"NAMESPACE$1NAMESPACE$2")}class Fw{value;constructor(e){this.value=e}asString(){return Jy(String(this.value))}asBool(){return"true"===this.value||"false"!==this.value&&Boolean(Number(this.value))}asNum(){return Number(this.value)}}class Mw{rootFile;xlsxFileStructure;warningManager;relationships;currentFile=void 0;constructor(e,t,o){this.rootFile=e,this.currentFile=e.file.fileName,this.xlsxFileStructure=t,this.warningManager=o,this.relationships={},e.rels&&this.extractRelationships(e.rels).map((e=>{this.relationships[e.id]=e}))}extractRelationships(e){return this.mapOnElements({parent:e.xml,query:"Relationship"},(e=>({id:this.extractAttr(e,"Id",{required:!0}).asString(),target:this.extractAttr(e,"Target",{required:!0}).asString(),type:this.extractAttr(e,"Type",{required:!0}).asString()})))}getListOfXMLFiles(){return Object.entries(this.xlsxFileStructure).filter((([e])=>"images"!==e)).map((([e,t])=>t)).flat().filter(at)}mapOnElements(e,t){const o=[],s=this.currentFile;let i;if(e.children){const t=this.querySelector(e.parent,e.query)?.children;i=t||[]}else i=this.querySelectorAll(e.parent,e.query);if(i)for(let e of i)try{o.push(t(e))}catch(t){this.catchErrorOnElement(t,e)}return this.currentFile=s,o}catchErrorOnElement(e,t){const o=t?`Error when parsing an element <${t.tagName}> of file ${this.currentFile}, skip this element. \n${e.stack}`:`Error when parsing file ${this.currentFile}.`;this.warningManager.addParsingWarning([o,e.message].join("\n"))}extractAttr(e,t,o){const s=e.attributes[t];s||this.handleMissingValue(e,`attribute "${t}"`,o);const i=s?.value?s.value:o?.default;return void 0===i?void 0:new Fw(i)}extractTextContent(e,t){if(void 0!==t?.default&&"string"!=typeof t.default)throw new Error("extractTextContent default value should be a string");const o="preserve"===e?.attributes["xml:space"]?.value;let s=e?.textContent;return e&&null!==s||this.handleMissingValue(e,"text content",t),s&&(s=o?s:s.trim()),s?Jy(s):t?.default}extractChildAttr(e,t,o,s){let i;i="number"==typeof t?e.children[t]:this.querySelector(e,t),i||this.handleMissingValue(e,"number"==typeof t?`child at index ${t}`:`child <${t}>`,s);const n=i?this.extractAttr(i,o,s)?.asString():s?.default;return void 0!==n?new Fw(n):void 0}extractChildTextContent(e,t,o){if(void 0!==o?.default&&"string"!=typeof o.default)throw new Error("extractTextContent default value should be a string");let s=this.querySelector(e,t);return s||this.handleMissingValue(e,`child <${t}>`,o),s?this.extractTextContent(s,o):o?.default}handleMissingValue(e,t,o){if(o?.required){if(!o?.default)throw new Error(`Missing required ${t} in element <${e.tagName}> of ${this.currentFile}, and no default value was set`);this.warningManager.addParsingWarning(`Missing required ${t} in element <${e.tagName}> of ${this.currentFile}, replacing it by the default value ${o.default}`)}}extractColor(e,t,o){if(!e)return o?{rgb:o}:void 0;const s=this.extractAttr(e,"theme")?.asString();let i;if(void 0!==s){if(!t||!t.clrScheme)throw new Error("Color referencing a theme but no theme was provided");i=this.getThemeColor(s,t.clrScheme)}else i=this.extractAttr(e,"rgb")?.asString(),i="FF000000"===i?void 0:i;return{rgb:i||o,auto:this.extractAttr(e,"auto")?.asBool(),indexed:this.extractAttr(e,"indexed")?.asNum(),tint:this.extractAttr(e,"tint")?.asNum()}}getTargetXmlFile(e){if(!e)throw new Error("Undefined target file");const t=this.processRelationshipTargetName(e.target),o=this.getListOfXMLFiles().find((e=>e.file.fileName.endsWith(t)));if(!o||!o.file)throw new Error("Cannot find target file");return o}getTargetImageFile(e){if(!e)throw new Error("Undefined target file");const t=this.processRelationshipTargetName(e.target),o=this.xlsxFileStructure.images.find((e=>e.fileName.endsWith(t)));if(!o)throw new Error("Cannot find target file");return o}querySelector(e,t){const o=Ow(t);return e.querySelector(o)}querySelectorAll(e,t){const o=Ow(t);return e.querySelectorAll(o)}getThemeColor(e,t){switch(e){case"0":return"FFFFFF";case"1":return"000000";case"2":return t[3].value;case"3":return t[2].value;default:return t[e].value}}processRelationshipTargetName(e){return e.replace(/\.+\//,"")}}class Pw extends Mw{getTheme(){return{clrScheme:this.mapOnElements({query:"a:clrScheme",parent:this.rootFile.file.xml,children:!0},(e=>({name:e.tagName,value:this.extractChildAttr(e,0,"val",{required:!0,default:ey}).asString(),lastClr:this.extractChildAttr(e,0,"lastClr",{default:ey}).asString()})))}}getSharedStrings(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"si"},(e=>this.mapOnElements({parent:e,query:"t"},(e=>this.extractTextContent(e)||"")).join("")))}}class Nw extends Mw{theme;constructor(e,t,o,s){super(e,t,o),this.theme=s}extractConditionalFormattings(){const e=this.mapOnElements({parent:this.rootFile.file.xml,query:"worksheet > conditionalFormatting"},(e=>({sqref:this.extractAttr(e,"sqref",{required:!0}).asString().split(" "),pivot:this.extractAttr(e,"pivot")?.asBool(),cfRules:this.extractCFRules(e,this.theme)})));return e.push(...this.mapOnElements({parent:this.rootFile.file.xml,query:"extLst x14:conditionalFormatting"},(e=>({sqref:this.extractChildTextContent(e,"xm:sqref",{required:!0}).split(" "),pivot:this.extractAttr(e,"xm:pivot")?.asBool(),cfRules:this.extractCFRules(e,this.theme)})))),e}extractCFRules(e,t){return this.mapOnElements({parent:e,query:"cfRule, x14:cfRule"},(e=>({type:this.extractAttr(e,"type",{required:!0}).asString(),priority:this.extractAttr(e,"priority",{required:!0}).asNum(),colorScale:this.extractCfColorScale(e,t),formula:this.extractCfFormula(e),iconSet:this.extractCfIconSet(e),dxfId:this.extractAttr(e,"dxfId")?.asNum(),stopIfTrue:this.extractAttr(e,"stopIfTrue")?.asBool(),aboveAverage:this.extractAttr(e,"aboveAverage")?.asBool(),percent:this.extractAttr(e,"percent")?.asBool(),bottom:this.extractAttr(e,"bottom")?.asBool(),operator:this.extractAttr(e,"operator")?.asString(),text:this.extractAttr(e,"text")?.asString(),timePeriod:this.extractAttr(e,"timePeriod")?.asString(),rank:this.extractAttr(e,"rank")?.asNum(),stdDev:this.extractAttr(e,"stdDev")?.asNum(),equalAverage:this.extractAttr(e,"equalAverage")?.asBool(),dataBar:this.extractCfDataBar(e,t)})))}extractCfFormula(e){return this.mapOnElements({parent:e,query:"formula"},(e=>this.extractTextContent(e,{required:!0})))}extractCfColorScale(e,t){const o=this.querySelector(e,"colorScale");if(o)return{colors:this.mapOnElements({parent:o,query:"color"},(e=>this.extractColor(e,t,"ffffff"))),cfvos:this.extractCFVos(o)}}extractCfDataBar(e,t){const o=this.querySelector(e,"dataBar");if(o)return{color:this.extractColor(o.querySelector("color"),t,"EFF7FF"),cfvos:this.extractCFVos(o)}}extractCfIconSet(e){const t=this.querySelector(e,"iconSet, x14:iconSet");if(t)return{iconSet:this.extractAttr(t,"iconSet",{default:"3TrafficLights1"}).asString(),showValue:this.extractAttr(t,"showValue",{default:!0}).asBool(),percent:this.extractAttr(t,"percent",{default:!0}).asBool(),reverse:this.extractAttr(t,"reverse")?.asBool(),custom:this.extractAttr(t,"custom")?.asBool(),cfvos:this.extractCFVos(t),cfIcons:this.extractCfIcons(t)}}extractCfIcons(e){const t=this.mapOnElements({parent:e,query:"cfIcon, x14:cfIcon"},(e=>({iconSet:this.extractAttr(e,"iconSet",{required:!0}).asString(),iconId:this.extractAttr(e,"iconId",{required:!0}).asNum()})));return 0===t.length?void 0:t}extractCFVos(e){return this.mapOnElements({parent:e,query:"cfvo, x14:cfvo"},(e=>({type:this.extractAttr(e,"type",{required:!0}).asString(),gte:this.extractAttr(e,"gte",{default:!0})?.asBool(),value:e.attributes.val?this.extractAttr(e,"val")?.asString():this.extractChildTextContent(e,"f, xm:f")})))}}class kw extends Mw{theme;constructor(e,t,o,s){super(e,t,o),this.theme=s}extractDataValidations(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"worksheet > dataValidations > dataValidation"},(e=>({type:this.extractAttr(e,"type",{required:!0}).asString(),operator:this.extractAttr(e,"operator",{default:"between"})?.asString(),sqref:this.extractAttr(e,"sqref",{required:!0}).asString().split(" "),errorStyle:this.extractAttr(e,"errorStyle")?.asString(),formula1:this.extractDataValidationFormula(e,1)[0],formula2:this.extractDataValidationFormula(e,2)[0],showErrorMessage:this.extractAttr(e,"showErrorMessage")?.asBool(),errorTitle:this.extractAttr(e,"errorTitle")?.asString(),error:this.extractAttr(e,"error")?.asString(),showInputMessage:this.extractAttr(e,"showInputMessage")?.asBool(),promptTitle:this.extractAttr(e,"promptTitle")?.asString(),prompt:this.extractAttr(e,"prompt")?.asString(),allowBlank:this.extractAttr(e,"allowBlank")?.asBool()})))}extractDataValidationFormula(e,t){return this.mapOnElements({parent:e,query:`formula${t}`},(e=>this.extractTextContent(e,{required:!0})))}}class Lw extends Mw{extractChart(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"c:chartSpace"},(e=>{const t=this.getChartType(e);if(!Hy[t])throw new Error(`Unsupported chart type ${t}`);if("combo"===Hy[t])return this.extractComboChart(e);const o=this.mapOnElements({parent:e,query:"c:chart > c:title a:t"},(e=>e.textContent||"")).join(""),s=this.extractChildAttr(e,"c:grouping","val",{default:"clustered"}).asString();return{title:{text:o},type:Hy[t],dataSets:this.extractChartDatasets(this.querySelectorAll(e,`c:${t}`),t),labelRange:this.extractChildTextContent(e,`c:ser ${"scatterChart"===t?"c:numRef":"c:cat"} c:f`),backgroundColor:this.extractChildAttr(e,"c:chartSpace > c:spPr a:srgbClr","val",{default:"ffffff"}).asString(),legendPosition:Vy[this.extractChildAttr(e,"c:legendPos","val",{default:"b"}).asString()],stacked:"stacked"===s,fontColor:"000000"}}))[0]}extractComboChart(e){const t=this.mapOnElements({parent:e,query:"c:title a:t"},(e=>e.textContent||"")).join(""),o=this.extractChildAttr(e,"c:grouping","val",{default:"clustered"}).asString();return{title:{text:t},type:"combo",dataSets:[...this.extractChartDatasets(this.querySelectorAll(e,"c:barChart"),"comboChart"),...this.extractChartDatasets(this.querySelectorAll(e,"c:lineChart"),"comboChart")],labelRange:this.extractChildTextContent(e,"c:ser c:cat c:f"),backgroundColor:this.extractChildAttr(e,"c:chartSpace > c:spPr a:srgbClr","val",{default:"ffffff"}).asString(),legendPosition:Vy[this.extractChildAttr(e,"c:legendPos","val",{default:"b"}).asString()],stacked:"stacked"===o,fontColor:"000000"}}extractChartDatasets(e,t){return Array.from(e).map((e=>"scatterChart"===t?this.extractScatterChartDatasets(e):this.mapOnElements({parent:e,query:"c:ser"},(e=>{let t={};const o=this.extractChildTextContent(e,"c:tx c:f");if(o)t={reference:o};else{const o=this.extractChildTextContent(e,"c:tx c:v");o&&(t={text:o})}const s=this.extractChildAttr(e,"c:spPr a:solidFill a:srgbClr","val");return{label:t,range:this.extractChildTextContent(e,"c:val c:f",{required:!0}),backgroundColor:s?`${Bt(s.asString())}`:void 0}})))).flat()}extractScatterChartDatasets(e){return this.mapOnElements({parent:e,query:"c:ser"},(e=>{let t={};const o=this.extractChildTextContent(e,"c:tx c:f");if(o)t={reference:o};else{const o=this.extractChildTextContent(e,"c:tx c:v");o&&(t={text:o})}return{label:t,range:this.extractChildTextContent(e,"c:yVal c:f",{required:!0})}}))}getChartType(e){const t=this.querySelector(e,"c:plotArea");if(!t)throw new Error("Missing plot area in the chart definition.");let o;for(let e of t.children){const t=Dw(e.tagName);QS.some((e=>e===t))&&(o?o!==t&&(o="comboChart"):o=t)}if(o)return o;throw new Error("Unknown chart type")}}const Vw="oneCellAnchor",Hw="twoCellAnchor";class Uw extends Mw{extractFigures(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"xdr:wsDr",children:!0},(e=>{const t=Dw(e.tagName),o=this.extractFigureAnchorsByType(e,t),s=this.querySelector(e,"c:chart"),i=this.querySelector(e,"a:blip");if(!s&&!i)throw new Error("Only chart and image figures are currently supported.");return{anchors:o,data:s?this.extractChart(s):this.extractImage(e),figureSize:t===Vw?this.extractFigureSizeFromSizeTag(e,"xdr:ext"):void 0}}))}extractFigureAnchorsByType(e,t){switch(t){case Vw:return[this.extractFigureAnchor("xdr:from",e)];case Hw:return[this.extractFigureAnchor("xdr:from",e),this.extractFigureAnchor("xdr:to",e)];default:throw new Error(`${t} is not supported for xlsx drawings. `)}}extractFigureSizeFromSizeTag(e,t){const o=this.querySelector(e,t);if(!o)throw new Error(`Missing size element '${t}'`);return{cx:this.extractAttr(o,"cx",{required:!0}).asNum(),cy:this.extractAttr(o,"cy",{required:!0}).asNum()}}extractFigureAnchor(e,t){const o=this.querySelector(t,e);if(!o)throw new Error(`Missing anchor element ${e}`);return{col:Number(this.extractChildTextContent(o,"xdr:col",{required:!0})),colOffset:Number(this.extractChildTextContent(o,"xdr:colOff",{required:!0})),row:Number(this.extractChildTextContent(o,"xdr:row",{required:!0})),rowOffset:Number(this.extractChildTextContent(o,"xdr:rowOff",{required:!0}))}}extractChart(e){const t=this.extractAttr(e,"r:id",{required:!0}).asString(),o=this.getTargetXmlFile(this.relationships[t]),s=new Lw(o,this.xlsxFileStructure,this.warningManager).extractChart();if(!s)throw new Error("Unable to extract chart definition");return s}extractImage(e){const t=this.querySelector(e,"a:blip"),o=this.extractAttr(t,"r:embed",{required:!0}).asString(),s=this.getTargetImageFile(this.relationships[o]);if(!s)throw new Error("Unable to extract image");const i=s.fileName.split(".").at(-1),n=Dw(e.tagName),r=n===Hw?this.querySelector(e,"a:xfrm"):e,a=n===Hw?"a:ext":"xdr:ext",l=this.extractFigureSizeFromSizeTag(r,a);return{imageSrc:s.imageSrc,mimetype:i?Gy[i]:void 0,size:l}}}class Bw extends Mw{getPivotTable(){return this.mapOnElements({query:":root",parent:this.rootFile.file.xml},(e=>({name:this.extractAttr(e,"name",{required:!0}).asString(),rowGrandTotals:this.extractAttr(e,"rowGrandTotals",{default:!0}).asBool(),location:this.extractPivotLocation(e),style:this.extractPivotStyleInfo(e)})))[0]}extractPivotLocation(e){return this.mapOnElements({query:"location",parent:e},(e=>({ref:this.extractAttr(e,"ref",{required:!0}).asString(),firstHeaderRow:this.extractAttr(e,"firstHeaderRow",{required:!0}).asNum(),firstDataRow:this.extractAttr(e,"firstDataRow",{required:!0}).asNum(),firstDataCol:this.extractAttr(e,"firstDataCol",{required:!0}).asNum()})))[0]}extractPivotStyleInfo(e){return this.mapOnElements({query:"pivotTableStyleInfo",parent:e},(e=>({name:this.extractAttr(e,"name",{required:!0}).asString(),showRowHeaders:this.extractAttr(e,"showRowHeaders",{required:!0}).asBool(),showColHeaders:this.extractAttr(e,"showColHeaders",{required:!0}).asBool(),showRowStripes:this.extractAttr(e,"showRowStripes",{required:!0}).asBool(),showColStripes:this.extractAttr(e,"showColStripes",{required:!0}).asBool(),showLastColumn:this.extractAttr(e,"showLastColumn")?.asBool()})))[0]}}class zw extends Mw{getTable(){return this.mapOnElements({query:"table",parent:this.rootFile.file.xml},(e=>({displayName:this.extractAttr(e,"displayName",{required:!0}).asString(),name:this.extractAttr(e,"name")?.asString(),id:this.extractAttr(e,"id",{required:!0}).asString(),ref:this.extractAttr(e,"ref",{required:!0}).asString(),headerRowCount:this.extractAttr(e,"headerRowCount",{default:1}).asNum(),totalsRowCount:this.extractAttr(e,"totalsRowCount",{default:0}).asNum(),cols:this.extractTableCols(e),style:this.extractTableStyleInfo(e),autoFilter:this.extractTableAutoFilter(e)})))[0]}extractTableCols(e){return this.mapOnElements({query:"tableColumn",parent:e},(e=>({id:this.extractAttr(e,"id",{required:!0}).asString(),name:this.extractAttr(e,"name",{required:!0}).asString(),colFormula:this.extractChildTextContent(e,"calculatedColumnFormula")})))}extractTableStyleInfo(e){return this.mapOnElements({query:"tableStyleInfo",parent:e},(e=>({name:this.extractAttr(e,"name")?.asString(),showFirstColumn:this.extractAttr(e,"showFirstColumn")?.asBool(),showLastColumn:this.extractAttr(e,"showLastColumn")?.asBool(),showRowStripes:this.extractAttr(e,"showRowStripes")?.asBool(),showColumnStripes:this.extractAttr(e,"showColumnStripes")?.asBool()})))[0]}extractTableAutoFilter(e){return this.mapOnElements({query:"autoFilter",parent:e},(e=>({columns:this.extractFilterColumns(e),zone:this.extractAttr(e,"ref",{required:!0}).asString()})))[0]}extractFilterColumns(e){return this.mapOnElements({query:"tableColumn",parent:e},(t=>({colId:this.extractAttr(e,"colId",{required:!0}).asNum(),hiddenButton:this.extractAttr(e,"hiddenButton",{default:!1}).asBool(),filters:this.extractSimpleFilter(t)})))}extractSimpleFilter(e){return this.mapOnElements({query:"filter",parent:e},(e=>({val:this.extractAttr(e,"val",{required:!0}).asString()})))}}class $w extends Mw{theme;constructor(e,t,o,s){super(e,t,o),this.theme=s}getSheet(){return this.mapOnElements({query:"worksheet",parent:this.rootFile.file.xml},(e=>{const t=this.getSheetWorkbookInfo();return{sheetName:this.extractSheetName(),sheetViews:this.extractSheetViews(e),sheetFormat:this.extractSheetFormat(e),sheetProperties:this.extractSheetProperties(e),cols:this.extractCols(e),rows:this.extractRows(e),sharedFormulas:this.extractSharedFormulas(e),merges:this.extractMerges(e),cfs:this.extractConditionalFormats(),dataValidations:this.extractDataValidations(),figures:this.extractFigures(e),hyperlinks:this.extractHyperLinks(e),tables:this.extractTables(e),pivotTables:this.extractPivotTables(),isVisible:"visible"===t.state}}))[0]}extractSheetViews(e){return this.mapOnElements({parent:e,query:"sheetView"},(e=>{const t=this.querySelector(e,"pane");return{tabSelected:this.extractAttr(e,"tabSelected",{default:!1}).asBool(),showFormulas:this.extractAttr(e,"showFormulas",{default:!1}).asBool(),showGridLines:this.extractAttr(e,"showGridLines",{default:!0}).asBool(),showRowColHeaders:this.extractAttr(e,"showRowColHeaders",{default:!0}).asBool(),pane:{xSplit:t?this.extractAttr(t,"xSplit",{default:0}).asNum():0,ySplit:t?this.extractAttr(t,"ySplit",{default:0}).asNum():0}}}))}extractSheetName(){const e=Xy(this.xlsxFileStructure.workbook.file.fileName,this.rootFile.file.fileName),t=this.extractRelationships(this.xlsxFileStructure.workbook.rels).find((t=>t.target===e)).id;for(let e of this.querySelectorAll(this.xlsxFileStructure.workbook.file.xml,"sheet"))if(e.attributes["r:id"].value===t)return e.attributes.name.value;throw new Error("Missing sheet name")}getSheetWorkbookInfo(){const e=Xy(this.xlsxFileStructure.workbook.file.fileName,this.rootFile.file.fileName),t=this.extractRelationships(this.xlsxFileStructure.workbook.rels).find((t=>t.target===e)).id,o=this.mapOnElements({parent:this.xlsxFileStructure.workbook.file.xml,query:"sheet"},(e=>({relationshipId:this.extractAttr(e,"r:id",{required:!0}).asString(),sheetId:this.extractAttr(e,"sheetId",{required:!0}).asString(),sheetName:this.extractAttr(e,"name",{required:!0}).asString(),state:this.extractAttr(e,"state",{default:"visible"}).asString()}))).find((e=>e.relationshipId===t));if(!o)throw new Error("Cannot find corresponding workbook sheet");return o}extractConditionalFormats(){return new Nw(this.rootFile,this.xlsxFileStructure,this.warningManager,this.theme).extractConditionalFormattings()}extractDataValidations(){return new kw(this.rootFile,this.xlsxFileStructure,this.warningManager,this.theme).extractDataValidations()}extractFigures(e){return this.mapOnElements({parent:e,query:"drawing"},(e=>{const t=this.extractAttr(e,"r:id",{required:!0})?.asString(),o=this.getTargetXmlFile(this.relationships[t]);return new Uw(o,this.xlsxFileStructure,this.warningManager).extractFigures()}))[0]||[]}extractTables(e){return this.mapOnElements({query:"tablePart",parent:e},(e=>{const t=this.extractAttr(e,"r:id",{required:!0})?.asString(),o=this.getTargetXmlFile(this.relationships[t]);return new zw(o,this.xlsxFileStructure,this.warningManager).getTable()}))}extractPivotTables(){try{return Object.values(this.relationships).filter((e=>e.type.endsWith("pivotTable"))).map((e=>{const t=this.getTargetXmlFile(e);return new Bw(t,this.xlsxFileStructure,this.warningManager).getPivotTable()}))}catch(e){return this.catchErrorOnElement(e),[]}}extractMerges(e){return this.mapOnElements({parent:e,query:"mergeCell"},(e=>this.extractAttr(e,"ref",{required:!0}).asString()))}extractSheetFormat(e){const t=this.querySelector(e,"sheetFormatPr");if(t)return{defaultColWidth:this.extractAttr(t,"defaultColWidth",{default:hy.toString()}).asNum(),defaultRowHeight:this.extractAttr(t,"defaultRowHeight",{default:dy.toString()}).asNum()}}extractSheetProperties(e){const t=this.querySelector(e,"sheetPr");if(t)return{outlinePr:this.extractSheetOutlineProperties(t),tabColor:this.extractColor(this.querySelector(t,"tabColor"),this.theme)}}extractSheetOutlineProperties(e){const t=this.querySelector(e,"outlinePr");if(t)return{summaryBelow:this.extractAttr(t,"summaryBelow",{default:!0}).asBool(),summaryRight:this.extractAttr(t,"summaryRight",{default:!0}).asBool()}}extractCols(e){return this.mapOnElements({parent:e,query:"cols col"},(e=>({width:this.extractAttr(e,"width")?.asNum(),customWidth:this.extractAttr(e,"customWidth")?.asBool(),bestFit:this.extractAttr(e,"bestFit")?.asBool(),hidden:this.extractAttr(e,"hidden")?.asBool(),min:this.extractAttr(e,"min",{required:!0})?.asNum(),max:this.extractAttr(e,"max",{required:!0})?.asNum(),styleIndex:this.extractAttr(e,"style")?.asNum(),outlineLevel:this.extractAttr(e,"outlineLevel")?.asNum(),collapsed:this.extractAttr(e,"collapsed")?.asBool()})))}extractRows(e){return this.mapOnElements({parent:e,query:"sheetData row"},(e=>({index:this.extractAttr(e,"r",{required:!0})?.asNum(),cells:this.extractCells(e),height:this.extractAttr(e,"ht")?.asNum(),customHeight:this.extractAttr(e,"customHeight")?.asBool(),hidden:this.extractAttr(e,"hidden")?.asBool(),styleIndex:this.extractAttr(e,"s")?.asNum(),outlineLevel:this.extractAttr(e,"outlineLevel")?.asNum(),collapsed:this.extractAttr(e,"collapsed")?.asBool()})))}extractCells(e){return this.mapOnElements({parent:e,query:"c"},(e=>({xc:this.extractAttr(e,"r",{required:!0})?.asString(),styleIndex:this.extractAttr(e,"s")?.asNum(),type:Dy[this.extractAttr(e,"t",{default:"n"})?.asString()],value:this.extractChildTextContent(e,"v"),formula:this.extractCellFormula(e)})))}extractCellFormula(e){const t=this.querySelector(e,"f");if(t)return{content:this.extractTextContent(t),sharedIndex:this.extractAttr(t,"si")?.asNum(),ref:this.extractAttr(t,"ref")?.asString()}}extractHyperLinks(e){return this.mapOnElements({parent:e,query:"hyperlink"},(e=>{const t=this.extractAttr(e,"r:id")?.asString();return{xc:this.extractAttr(e,"ref",{required:!0})?.asString(),location:this.extractAttr(e,"location")?.asString(),display:this.extractAttr(e,"display")?.asString(),relTarget:t?this.relationships[t].target:void 0}}))}extractSharedFormulas(e){const t=this.querySelectorAll(e,"f[si][ref]"),o={};for(let e of t){const t=this.extractAttr(e,"si",{required:!0}).asNum(),s=this.extractTextContent(e,{required:!0});o[t]=s}const s=[];for(let e=0;e<Object.keys(o).length;e++)o[e]?s.push(o[e]):(this.warningManager.addParsingWarning(`Missing shared formula ${e}, replacing it by empty formula`),s.push(""));return s}}class Ww extends Mw{theme;constructor(e,t,o){super(e.styles,e,t),this.theme=o}getNumFormats(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"numFmt"},(e=>this.extractNumFormats(e)))}extractNumFormats(e){return{id:this.extractAttr(e,"numFmtId",{required:!0}).asNum(),format:this.extractAttr(e,"formatCode",{required:!0,default:""}).asString()}}getFonts(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"font"},(e=>this.extractFont(e)))}extractFont(e){const t=this.extractChildAttr(e,"name","val",{default:"Arial"}).asString(),o=this.extractChildAttr(e,"sz","val",{default:me.toString()}).asNum(),s=this.extractColor(this.querySelector(e,"color"),this.theme),i=this.querySelector(e,"i")||void 0,n=i&&"0"!==i.attributes.val?.value,r=this.querySelector(e,"b")||void 0,a=r&&"0"!==r.attributes.val?.value,l=this.querySelector(e,"strike")||void 0,c=l&&"0"!==l.attributes.val?.value,h=this.querySelector(e,"u")||void 0;return{name:t,size:o,color:s,italic:n,bold:a,underline:h&&"none"!==h.attributes.val?.value,strike:c}}getFills(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"fill"},(e=>this.extractFill(e)))}extractFill(e){const t=e.children[0];return"patternFill"===t.tagName?{patternType:t.attributes.patternType?.value,bgColor:this.extractColor(this.querySelector(t,"bgColor"),this.theme),fgColor:this.extractColor(this.querySelector(t,"fgColor"),this.theme)}:{patternType:"solid",fgColor:this.extractColor(this.querySelectorAll(t,"color")[1],this.theme)}}getBorders(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"border"},(e=>this.extractBorder(e)))}extractBorder(e){const t={left:this.extractSingleBorder(e,"left",this.theme),right:this.extractSingleBorder(e,"right",this.theme),top:this.extractSingleBorder(e,"top",this.theme),bottom:this.extractSingleBorder(e,"bottom",this.theme),diagonal:this.extractSingleBorder(e,"diagonal",this.theme)};return t.diagonal&&(t.diagonalUp=this.extractAttr(e,"diagonalUp")?.asBool(),t.diagonalDown=this.extractAttr(e,"diagonalDown")?.asBool()),t}extractSingleBorder(e,t,o){const s=this.querySelector(e,t);if(s&&s.attributes.style)return{style:this.extractAttr(s,"style",{required:!0,default:"thin"}).asString(),color:this.extractColor(s.children[0],o,"000000")}}extractAlignment(e){return{horizontal:this.extractAttr(e,"horizontal",{default:"general"}).asString(),vertical:this.extractAttr(e,"vertical",{default:"bottom"}).asString(),textRotation:this.extractAttr(e,"textRotation")?.asNum(),wrapText:this.extractAttr(e,"wrapText")?.asBool(),indent:this.extractAttr(e,"indent")?.asNum(),relativeIndent:this.extractAttr(e,"relativeIndent")?.asNum(),justifyLastLine:this.extractAttr(e,"justifyLastLine")?.asBool(),shrinkToFit:this.extractAttr(e,"shrinkToFit")?.asBool(),readingOrder:this.extractAttr(e,"readingOrder")?.asNum()}}getDxfs(){return this.mapOnElements({query:"dxf",parent:this.rootFile.file.xml},(e=>{const t=this.querySelector(e,"font"),o=this.querySelector(e,"fill"),s=this.querySelector(e,"border"),i=this.querySelector(e,"numFmt"),n=this.querySelector(e,"alignment");return{font:t?this.extractFont(t):void 0,fill:o?this.extractFill(o):void 0,numFmt:i?this.extractNumFormats(i):void 0,alignment:n?this.extractAlignment(n):void 0,border:s?this.extractBorder(s):void 0}}))}getStyles(){return this.mapOnElements({query:"cellXfs xf",parent:this.rootFile.file.xml},(e=>{const t=this.querySelector(e,"alignment");return{fontId:this.extractAttr(e,"fontId",{required:!0,default:0}).asNum(),fillId:this.extractAttr(e,"fillId",{required:!0,default:0}).asNum(),borderId:this.extractAttr(e,"borderId",{required:!0,default:0}).asNum(),numFmtId:this.extractAttr(e,"numFmtId",{required:!0,default:0}).asNum(),alignment:t?this.extractAlignment(t):void 0}}))}}class Gw extends Mw{getExternalBook(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"externalBook"},(e=>({rId:this.extractAttr(e,"r:id",{required:!0}).asString(),sheetNames:this.mapOnElements({parent:e,query:"sheetName"},(e=>this.extractAttr(e,"val",{required:!0}).asString())),datasets:this.extractExternalSheetData(e)})))[0]}extractExternalSheetData(e){return this.mapOnElements({parent:e,query:"sheetData"},(e=>{const t=this.mapOnElements({parent:e,query:"cell"},(e=>({xc:this.extractAttr(e,"r",{required:!0}).asString(),value:this.extractChildTextContent(e,"v",{required:!0})}))),o={};for(let e of t)o[e.xc]=e.value;return{sheetId:this.extractAttr(e,"sheetId",{required:!0}).asNum(),data:o}}))}}function qw(e,t){const o=function(e,t){const o=t[vy],s=o.querySelectorAll(`Override[ContentType="${e}"]`),i=[];for(let e of s){const t=e?.attributes.PartName.value;i.push(t.substring(1))}return i}(e,t);return function(e,t){const o=[];for(let s of e){const e=Zw(s,t);o.push({file:{fileName:s,xml:t[s]},rels:e?{fileName:e,xml:t[e]}:void 0})}return o}(o,t)}function Zw(e,t){if(e===vy)return"_rels/.rels";let o="";const s=e.split("/");for(let e=0;e<s.length-1;e++)o+=s[e]+"/";return o+="_rels/",o+=s[s.length-1]+".rels",t[o]||(o=void 0),o}class jw{warningManager;xmls;images;constructor(e){this.warningManager=new xy,this.xmls={},this.images=[];for(let t of Object.keys(e))if(t.endsWith(".xml")||t.endsWith(".rels")){const o=e[t].replaceAll(/(<\/?)([a-zA-Z0-9]+):([a-zA-Z0-9]+)/g,"$1NAMESPACE$2NAMESPACE$3");this.xmls[t]=Iw(new JS(o))}else t.includes("media/image")&&this.images.push({fileName:t,imageSrc:e[t].imageSrc})}convertXlsx(){const e=this.getXlsxData();return this.convertImportedData(e)}getXlsxData(){const e=this.buildXlsxFileStructure(),t=e.theme?new Pw(e.theme,e,this.warningManager).getTheme():void 0,o=e.sharedStrings?new Pw(e.sharedStrings,e,this.warningManager).getSharedStrings():[],s=e.sheets.sort(((e,t)=>e.file.fileName.localeCompare(t.file.fileName,void 0,{numeric:!0}))).map((o=>new $w(o,e,this.warningManager,t).getSheet())),i=e.externalLinks.map((t=>new Gw(t,e,this.warningManager).getExternalBook())),n=new Ww(e,this.warningManager,t);return{fonts:n.getFonts(),fills:n.getFills(),borders:n.getBorders(),dxfs:n.getDxfs(),numFmts:n.getNumFormats(),styles:n.getStyles(),sheets:s,sharedStrings:o,externalBooks:i}}buildXlsxFileStructure(){const e={sheets:qw(ny.sheet,this.xmls),workbook:qw(ny.workbook,this.xmls)[0],styles:qw(ny.styles,this.xmls)[0],sharedStrings:qw(ny.sharedStrings,this.xmls)[0],theme:qw(ny.themes,this.xmls)[0],charts:qw(ny.chart,this.xmls),figures:qw(ny.drawing,this.xmls),tables:qw(ny.table,this.xmls),pivots:qw(ny.pivot,this.xmls),externalLinks:qw(ny.externalLink,this.xmls),images:this.images};if(!e.workbook.rels)throw Error(Fo("Cannot find workbook relations file"));return e}convertImportedData(e){const t={version:24,sheets:WC(e,this.warningManager),styles:iC(e,this.warningManager),formats:rC(e,this.warningManager),borders:oC(e,this.warningManager),revisionId:Se};return bw(t,e),Object.keys(e.styles).map((t=>{e.styles[t]=bt(e.styles[t])})),t}}function Yw(e){const t=vf(e);let o=[];return{text:"".concat(...t.map((e=>{if("REFERENCE"===e.type&&Po.test(e.value)){const t=e.value.trim();return o.includes(t)||o.push(t),`${De}${o.indexOf(t)}${De}`}return e.value}))),dependencies:o}}const Xw={am_ET:7,ar_001:6,ar_SY:6,az_AZ:1,eu_ES:1,be_BY:1,bn_IN:1,bs_BA:1,bg_BG:1,ca_ES:1,zh_CN:7,zh_HK:7,zh_TW:7,hr_HR:1,cs_CZ:1,da_DK:1,nl_BE:1,nl_NL:1,en_AU:7,en_CA:7,en_GB:1,en_IN:7,en_NZ:7,et_EE:1,fi_FI:1,fr_BE:1,fr_CA:7,fr_CH:1,fr_FR:1,gl_ES:1,ka_GE:1,de_DE:1,de_CH:1,el_GR:1,gu_IN:7,he_IL:7,hi_IN:7,hu_HU:1,id_ID:7,it_IT:1,ja_JP:7,kab_DZ:6,km_KH:7,ko_KP:1,ko_KR:7,lo_LA:7,lv_LV:1,lt_LT:1,lb_LU:1,mk_MK:1,ml_IN:1,mn_MN:7,ms_MY:1,nb_NO:1,fa_IR:6,pl_PL:1,pt_AO:1,pt_BR:7,pt_PT:1,ro_RO:1,ru_RU:1,sr_RS:7,"sr@latin":7,sk_SK:1,sl_SI:1,es_AR:7,es_BO:1,es_CL:1,es_CO:7,es_CR:1,es_DO:1,es_EC:1,es_GT:7,es_MX:7,es_PA:7,es_PE:7,es_PY:7,es_UY:1,es_VE:7,sw:1,sv_SE:1,th_TH:7,tl_PH:1,tr_TR:1,uk_UA:1,vi_VN:1,sq_AL:1,te_IN:7,en_US:7,my_MM:7,es_ES:1,es_419:1},Kw=new n;function Jw(e){for(let t of e.sheets||[]){let e=[];for(let o of t.filterTables||[]){const t=Yo(o.range),s=e.findIndex((e=>rs(e,t)));-1!==s?e[s]=t:e.push(t)}t.filterTables=e.map((e=>({range:Jo(e)})))}return e}Kw.add("migration_1",{versionFrom:"1",migrate:e=>(e.sheets&&e.sheets[0]&&(e.activeSheet=e.sheets[0].name),e)}).add("migration_2",{versionFrom:"2",migrate(e){if(e.sheets&&e.sheets.length)for(let t of e.sheets)t.id=t.id||t.name;return e}}).add("migration_3",{versionFrom:"3",migrate(e){if(e.sheets&&e.activeSheet){const t=e.sheets.find((t=>t.name===e.activeSheet));e.activeSheet=t.id}return e}}).add("migration_4",{versionFrom:"4",migrate(e){for(let t of e.sheets||[])t.figures=t.figures||[];return e}}).add("migration_5",{versionFrom:"5",migrate(e){for(let t of e.sheets||[])for(let e in t.cells||[]){const o=t.cells[e];o.content&&o.content.startsWith("=")&&(o.formula=Yw(o.content))}return e}}).add("migration_6",{versionFrom:"6",migrate(e){for(let t of e.sheets||[])for(let e in t.figures||[]){const{dataSets:o,...s}=t.figures[e].data,i=[];for(let e of o)if(e.labelCell){const t=Yo(e.dataRange),o=e.labelCell+":"+yo(t.right,t.bottom);i.push(o)}else i.push(e.dataRange);s.dataSetsHaveTitle=Boolean(o[0].labelCell),s.dataSets=i,t.figures[e].data=s}return e}}).add("migration_7",{versionFrom:"7",migrate(e){const t=[];for(let o of e.sheets||[]){if(!o.name)continue;const e=o.name,s=Nt(Ge(e,"_"),t,{compute:(e,t)=>`${e}${t}`});o.name=s,t.push(s);const i=t=>{if(void 0===t)return t;let o=t.replace(e,s),i=t;for(;i!==o;)i=o,o=i.replace(e,s);return i};for(let e in o.cells){const t=o.cells[e];t.formula&&(t.formula.dependencies=t.formula.dependencies.map(i))}for(let e of o.figures||[])if("chart"===e.type){const t=e.data.dataSets.map(i),o=i(e.data.labelRange);e.data={...e.data,dataSets:t,labelRange:o}}for(let e of o.conditionalFormats||[]){e.ranges=e.ranges.map(i);for(const t of["minimum","maximum","midpoint","upperInflectionPoint","lowerInflectionPoint"])"formula"===e.rule[t]?.type&&(e.rule[t].value=i(e.rule[t].value))}}return e}}).add("migration_8",{versionFrom:"8",migrate(e){for(const t of e.sheets||[])for(const e of t.figures||[])e.data.background=m,e.data.verticalAxisPosition="left",e.data.legendPosition="top",e.data.stacked=!1;return e}}).add("migration_9",{versionFrom:"9",migrate(e){for(let t of e.sheets||[])for(let e in t.cells||[]){const o=t.cells[e];if(o.formula){let{text:e,dependencies:t}=o.formula;for(let[o,s]of Object.entries(t)){const t=`\\${De}${o}\\${De}`;e=e.replace(new RegExp(t,"g"),s)}o.content=e,delete o.formula}}return e}}).add("migration_10",{versionFrom:"10",migrate(e){const t={};for(let o of e.sheets||[])for(let e in o.cells||[]){const s=o.cells[e];s.format&&(s.format=ws(s.format,t))}return e.formats=t,e}}).add("migration_11",{versionFrom:"11",migrate(e){for(let t of e.sheets||[])t.isVisible=!0;return e}}).add("migration_12",{versionFrom:"12",migrate:e=>Jw(e)}).add("migration_12_5",{versionFrom:"12.5",migrate(e){for(const t in e.borders){const o=e.borders[t];for(const e in o)Array.isArray(o[e])&&(o[e]={style:o[e][0],color:o[e][1]})}return e}}).add("migration_13",{versionFrom:"13",migrate:e=>(e.settings||(e.settings={}),e.settings.locale||(e.settings.locale=Si),e)}).add("migration_14",{versionFrom:"14",migrate:e=>Jw(e)}).add("migration_14_5",{versionFrom:"14.5",migrate(e){for(const t of e.sheets||[])t.tables=t.tables||t.filterTables||[],delete t.filterTables;return e}}).add("migration_15",{versionFrom:"15",migrate:e=>(e.pivots||(e.pivots={}),e.pivotNextId||(e.pivotNextId=Gl(e.pivots)+1),e)}).add("migration_16",{versionFrom:"16",migrate(e){for(const t of e.sheets||[])for(const e in t.figures||[]){const o=t.figures[e];"title"in o.data&&"string"==typeof o.data.title&&(o.data.title={text:o.data.title});const s=o.data.type;if(!["line","bar","pie","scatter","waterfall","combo"].includes(s))continue;const{dataSets:i,...n}=t.figures[e].data,r=i.map((e=>({dataRange:e})));n.dataSets=r,t.figures[e].data=n}return e}}).add("migration_17",{versionFrom:"17",migrate:e=>e}).add("migration_18",{versionFrom:"18",migrate(e){for(const t of Object.values(e.pivots||{}))t.measures=t.measures.map((e=>({id:e.name,fieldName:e.name,aggregator:e.aggregator}))),t.columns=t.columns.map((e=>({fieldName:e.name,order:e.order,granularity:e.granularity}))),t.rows=t.rows.map((e=>({fieldName:e.name,order:e.order,granularity:e.granularity})));return e}}).add("migration_19",{versionFrom:"19",migrate(e){const t=e.settings?.locale;if(t){const e=t.code;t.weekStart=Xw[e]||1}return e}}).add("migration_20",{versionFrom:"20",migrate(e){for(const t of e.sheets||[]){t.styles={},t.formats={},t.borders={};for(const e in t.cells)t.styles[e]=t.cells[e].style,t.formats[e]=t.cells[e].format,t.borders[e]=t.cells[e].border,delete t.cells[e].style,delete t.cells[e].format,delete t.cells[e].border}return e}}).add("migration_21",{versionFrom:"21",migrate(e){for(const t of e.sheets||[])for(const e of t.figures||[]){if("chart"!==e.tag||"gauge"!==e.data.type)continue;const t=e.data;t?.sectionRule?.lowerInflectionPoint&&(t.sectionRule.lowerInflectionPoint.operator="<="),t?.sectionRule?.upperInflectionPoint&&(t.sectionRule.upperInflectionPoint.operator="<=")}return e}}).add("migration_22",{versionFrom:"22",migrate(e){for(const t of e.sheets||[])for(const e of t.tables||[])e.config||(e.config={...QC,hasFilters:!0});return e}}).add("migration_23",{versionFrom:"23",migrate(e){for(const t of e.sheets||[])for(const e in t.cells){const o=t.cells[e];o&&(t.cells[e]=o.content)}return e}}).add("migration_24",{versionFrom:"24",migrate:e=>e});const Qw=25,ex="Sheet1";function tx(e,t){if(!e)return nx();console.debug("### Loading data ###");const o=performance.now();if(e["[Content_Types].xml"]){const o=new jw(e);if(e=o.convertXlsx(),t)for(let e of o.warningManager.warnings.sort())console.warn(e)}return"version"in e&&e.version<Qw&&(console.debug("Migrating data from version",e.version),e=function(e){const t=performance.now(),o=Kw.getAll().sort(((e,t)=>function(e,t){const o=e.split(".").map(Number),s=t.split(".").map(Number);for(let e=0;e<Math.max(o.length,s.length);e++){const t=o[e]||0,i=s[e]||0;if(t>i)return 1;if(t<i)return-1}return 0}(e.versionFrom,t.versionFrom)));for(let t=o.findIndex((t=>t.versionFrom===e.version.toString()));t<o.length;t++)e=o[t].migrate(e);return console.debug("Data migrated in",performance.now()-t,"ms"),e}(e)),e=function(e){return e=function(e){if(e.uniqueFigureIds)return e;const t=new Set,o=new aa;for(const s of e.sheets||[])for(const e of s.figures||[])t.has(e.id)&&(e.id+=o.uuidv4()),t.add(e.id);return e.uniqueFigureIds=!0,e}(e),e=function(e){const t=Object.assign(nx(),e,{version:Qw});t.sheets=t.sheets?t.sheets.map(((e,t)=>Object.assign(ix(`Sheet${t+1}`,`Sheet${t+1}`),e))):[],0===t.sheets.length&&t.sheets.push(ix(ex,"Sheet1"));_a(t.settings.locale)||(t.settings.locale=Si);return t}(e),e}(e),console.debug("Data loaded in",performance.now()-o,"ms"),console.debug("###"),e}function ox(e,t){return t=function(e,t){if(0!==Object.keys(e).length)return t;const o=[],s=[],i=e=>{if("CREATE_SHEET"===e.type)o.push(e.sheetId);else if("sheetId"in e&&!o.includes(e.sheetId))return{...e,sheetId:ex};return e};for(const e of t)"REMOTE_REVISION"===e.type?s.push({...e,commands:e.commands.map(i)}):s.push(e);return s}(e,t),t=sx(t,"SORT_CELLS"),t=function(e,t){const o=[],s={};for(const t of e.sheets||[])t.figures?.forEach((e=>{"chart"===e.tag&&(s[e.id]=e.data)}));for(const e of t)if("REMOTE_REVISION"===e.type){const t=[];for(const o of e.commands){let e=o;switch(o.type){case"CREATE_CHART":s[o.id]=o.definition;break;case"UPDATE_CHART":if(!s[o.id]){console.log(`Fix chart definition: chart with id ${o.id} not found.`);continue}const t={...s[o.id],...o.definition};e={...o,definition:t},s[o.id]=t}t.push(e)}o.push({...e,commands:t})}else o.push(e);return o}(e,t=sx(t,"SET_DECIMAL")),t}function sx(e,t){const o=[];for(const s of e)"REMOTE_REVISION"===s.type?o.push({...s,commands:s.commands.filter((e=>e.type!==t))}):o.push(s);return o}function ix(e,t){return{id:e,name:t,colNumber:26,rowNumber:100,cells:{},styles:{},formats:{},borders:{},cols:{},rows:{},merges:[],conditionalFormats:[],dataValidationRules:[],figures:[],tables:[],isVisible:!0}}function nx(e="Sheet1"){return{version:Qw,sheets:[ix(ex,e)],styles:{},formats:{},borders:{},revisionId:Se,uniqueFigureIds:!0,settings:{locale:Si},pivots:{},pivotNextId:1,customTableStyles:{}}}function rx(e,t){return{...ix(e,t),charts:[],images:[],cellValues:{}}}const ax={wrongPasteSelection:Fo("This operation is not allowed with multiple selections."),willRemoveExistingMerge:Fo("This operation is not possible due to a merge. Please remove the merges first than try again."),wrongFigurePasteOption:Fo("Cannot do a special paste of a figure."),frozenPaneOverlap:Fo("This operation is not allowed due to an overlapping frozen pane.")};function lx(e,t){t.isSuccessful||(t.reasons.includes("WrongPasteSelection")?e.raiseError(ax.wrongPasteSelection):t.reasons.includes("WillRemoveExistingMerge")?e.raiseError(ax.willRemoveExistingMerge):t.reasons.includes("WrongFigurePasteOption")?e.raiseError(ax.wrongFigurePasteOption):t.reasons.includes("FrozenPaneOverlap")&&e.raiseError(ax.frozenPaneOverlap))}function cx(e,t,o){const s=e.model.dispatch("PASTE",{target:t,pasteOption:o});lx(e,s)}function hx(e,t,o,s){let i;try{i=e.model.dispatch("PASTE_FROM_OS_CLIPBOARD",{target:t,clipboardContent:o,pasteOption:s})}catch(n){const r=o.data;r?.version!==Qw&&e.raiseError(Fo("An unexpected error occurred while pasting content. This is probably due to a spreadsheet version mismatch.")),i=e.model.dispatch("PASTE_FROM_OS_CLIPBOARD",{target:t,clipboardContent:{text:o.text},pasteOption:s})}lx(e,i)}const dx={Errors:{InvalidRange:Fo("The range is invalid"),FirstArgMissing:Fo("The argument is missing. Please provide a value"),SecondArgMissing:Fo("The second argument is missing. Please provide a value"),MinNaN:Fo("The minpoint must be a number"),MidNaN:Fo("The midpoint must be a number"),MaxNaN:Fo("The maxpoint must be a number"),ValueUpperInflectionNaN:Fo("The first value must be a number"),ValueLowerInflectionNaN:Fo("The second value must be a number"),MinBiggerThanMax:Fo("Minimum must be smaller then Maximum"),MinBiggerThanMid:Fo("Minimum must be smaller then Midpoint"),MidBiggerThanMax:Fo("Midpoint must be smaller then Maximum"),LowerBiggerThanUpper:Fo("Lower inflection point must be smaller than upper inflection point"),MinInvalidFormula:Fo("Invalid Minpoint formula"),MaxInvalidFormula:Fo("Invalid Maxpoint formula"),MidInvalidFormula:Fo("Invalid Midpoint formula"),ValueUpperInvalidFormula:Fo("Invalid upper inflection point formula"),ValueLowerInvalidFormula:Fo("Invalid lower inflection point formula"),EmptyRange:Fo("A range needs to be defined"),ValueCellIsInvalidFormula:Fo("At least one of the provided values is an invalid formula"),Unexpected:Fo("The rule is invalid for an unknown reason")},ColorScale:Fo("Color scale"),IconSet:Fo("Icon set"),DataBar:Fo("Data bar")},ux={IsEmpty:Fo("Is empty"),IsNotEmpty:Fo("Is not empty"),ContainsText:Fo("Contains"),NotContains:Fo("Does not contain"),BeginsWith:Fo("Starts with"),EndsWith:Fo("Ends with"),Equal:Fo("Is equal to"),NotEqual:Fo("Is not equal to"),GreaterThan:Fo("Is greater than"),GreaterThanOrEqual:Fo("Is greater than or equal to"),LessThan:Fo("Is less than"),LessThanOrEqual:Fo("Is less than or equal to"),Between:Fo("Is between"),NotBetween:Fo("Is not between")},gx={Series:Fo("Series"),BackgroundColor:Fo("Background color"),StackedBarChart:Fo("Stacked bar chart"),StackedLineChart:Fo("Stacked line chart"),StackedAreaChart:Fo("Stacked area chart"),StackedColumnChart:Fo("Stacked column chart"),CumulativeData:Fo("Cumulative data"),TreatLabelsAsText:Fo("Treat labels as text"),AggregatedChart:Fo("Aggregate"),Errors:{Unexpected:Fo("The chart definition is invalid for an unknown reason"),InvalidDataSet:Fo("The dataset is invalid"),InvalidLabelRange:Fo("Labels are invalid"),InvalidScorecardKeyValue:Fo("The key value is invalid"),InvalidScorecardBaseline:Fo("The baseline value is invalid"),InvalidGaugeDataRange:Fo("The data range is invalid"),EmptyGaugeRangeMin:Fo("A minimum range limit value is needed"),GaugeRangeMinNaN:Fo("The minimum range limit value must be a number"),EmptyGaugeRangeMax:Fo("A maximum range limit value is needed"),GaugeRangeMaxNaN:Fo("The maximum range limit value must be a number"),GaugeRangeMinBiggerThanRangeMax:Fo("Minimum range limit must be smaller than maximum range limit"),GaugeLowerInflectionPointNaN:Fo("The lower inflection point value must be a number"),GaugeUpperInflectionPointNaN:Fo("The upper inflection point value must be a number")},GeoChart:{ColorScales:{blues:Fo("Blues"),cividis:Fo("Cividis"),greens:Fo("Greens"),greys:Fo("Greys"),oranges:Fo("Oranges"),purples:Fo("Purples"),rainbow:Fo("Rainbow"),reds:Fo("Reds"),viridis:Fo("Viridis")}}},px={Custom:Fo("Custom")},mx=Fo("Merged cells are preventing this operation. Unmerge those cells and try again."),fx={Errors:{Unexpected:Fo("Cannot split the selection for an unknown reason"),NoSplitSeparatorInSelection:Fo("There is no match for the selected separator in the selection"),MoreThanOneColumnSelected:Fo("Only a selection from a single column can be split"),SplitWillOverwriteContent:Fo("Splitting will overwrite existing content")}},vx={Errors:{Unexpected:Fo("Cannot remove duplicates for an unknown reason"),MoreThanOneRangeSelected:Fo("Please select only one range of cells"),EmptyTarget:Fo("Please select a range of cells containing values."),NoColumnsProvided:Fo("Please select at latest one column to analyze."),WillRemoveExistingMerge:ax.willRemoveExistingMerge}},bx={DateIs:{today:Fo("today"),yesterday:Fo("yesterday"),tomorrow:Fo("tomorrow"),lastWeek:Fo("in the past week"),lastMonth:Fo("in the past month"),lastYear:Fo("in the past year")},DateIsBefore:{today:Fo("today"),yesterday:Fo("yesterday"),tomorrow:Fo("tomorrow"),lastWeek:Fo("one week ago"),lastMonth:Fo("one month ago"),lastYear:Fo("one year ago")},CriterionError:{notEmptyValue:Fo("The value must not be empty"),numberValue:Fo("The value must be a number"),dateValue:Fo("The value must be a date"),validRange:Fo("The value must be a valid range"),validFormula:Fo("The formula must be valid")},Errors:{InvalidRange:Fo("The range is invalid."),InvalidDataValidationCriterionValue:Fo("One or more of the provided criteria values are invalid. Please review and correct them."),InvalidNumberOfCriterionValues:Fo("One or more of the provided criteria values are missing."),Unexpected:Fo("The rule is invalid for an unknown reason.")}},Sx={Errors:{Unexpected:Fo("The table zone is invalid for an unknown reason"),TableOverlap:Fo("You cannot create overlapping tables."),NonContinuousTargets:Fo("A table can only be created on a continuous selection."),InvalidRange:Fo("The range is invalid"),TargetOutOfSheet:Fo("The range is out of the sheet")},Checkboxes:{hasFilters:Fo("Filter button"),headerRow:Fo("Header row(s)"),bandedRows:Fo("Banded rows"),firstColumn:Fo("First column"),lastColumn:Fo("Last column"),bandedColumns:Fo("Banded columns"),automaticAutofill:Fo("Automatically autofill formulas"),totalRow:Fo("Total row"),isDynamic:Fo("Auto-adjust to formula result")},Tooltips:{filterWithoutHeader:Fo("Cannot have filters without a header row"),isDynamic:Fo("For tables based on array formulas only")}},yx={labels:{no_calculations:Fo("No calculations"),"%_of_grand_total":Fo("% of grand total"),"%_of_col_total":Fo("% of column total"),"%_of_row_total":Fo("% of row total"),"%_of":Fo("% of"),"%_of_parent_row_total":Fo("% of parent row total"),"%_of_parent_col_total":Fo("% of parent column total"),"%_of_parent_total":Fo("% of parent total"),difference_from:Fo("Difference from"),"%_difference_from":Fo("% difference from"),running_total:Fo("Running total"),"%_running_total":Fo("% Running total"),rank_asc:Fo("Rank smallest to largest"),rank_desc:Fo("Rank largest to smallest"),index:Fo("Index")},descriptions:{"%_of_grand_total":()=>Fo("Displayed as % of grand total"),"%_of_col_total":()=>Fo("Displayed as % of column total"),"%_of_row_total":()=>Fo("Displayed as % of row total"),"%_of":e=>Fo('Displayed as % of "%s"',e),"%_of_parent_row_total":e=>Fo('Displayed as % of parent row total of "%s"',e),"%_of_parent_col_total":()=>Fo("Displayed as % of parent column total"),"%_of_parent_total":e=>Fo('Displayed as % of parent "%s" total',e),difference_from:e=>Fo('Displayed as difference from "%s"',e),"%_difference_from":e=>Fo('Displayed as % difference from "%s"',e),running_total:e=>Fo('Displayed as running total based on "%s"',e),"%_running_total":e=>Fo('Displayed as % running total based on "%s"',e),rank_asc:e=>Fo('Displayed as rank from smallest to largest based on "%s"',e),rank_desc:e=>Fo('Displayed as rank largest to smallest based on "%s"',e),index:()=>Fo("Displayed as index")},documentation:{no_calculations:Fo("Displays the value that is entered in the field."),"%_of_grand_total":Fo("Displays values as a percentage of the grand total of all the values or data points in the report."),"%_of_col_total":Fo("Displays all the values in each column or series as a percentage of the total for the column or series."),"%_of_row_total":Fo("Displays the value in each row or category as a percentage of the total for the row or category."),"%_of":Fo("Displays values as a percentage of the value of the Base item in the Base field."),"%_of_parent_row_total":Fo("Calculates values as follows:\n(value for the item) / (value for the parent item on rows)"),"%_of_parent_col_total":Fo("Calculates values as follows:\n(value for the item) / (value for the parent item on columns)"),"%_of_parent_total":Fo("Calculates values as follows:\n(value for the item) / (value for the parent item of the selected Base field)"),difference_from:Fo("Displays values as the difference from the value of the Base item in the Base field."),"%_difference_from":Fo("Displays values as the percentage difference from the value of the Base item in the Base field."),running_total:Fo("Displays the value for successive items in the Base field as a running total."),"%_running_total":Fo("Calculates the value as a percentage for successive items in the Base field that are displayed as a running total."),rank_asc:Fo("Displays the rank of selected values in a specific field, listing the smallest item in the field as 1, and each larger value with a higher rank value."),rank_desc:Fo("Displays the rank of selected values in a specific field, listing the largest item in the field as 1, and each smaller value with a higher rank value."),index:Fo("Calculates values as follows:\n((value in cell) x (Grand Total of Grand Totals)) / ((Grand Row Total) x (Grand Column Total))")}},Cx={second:1e3,minute:6e4,hour:36e5,day:864e5,month:2592e6,year:31536e6},wx={inSeconds:function(e){return Math.floor(e/Cx.second)},inMinutes:function(e){return Math.floor(e/Cx.minute)},inHours:function(e){return Math.floor(e/Cx.hour)},inDays:function(e){return Math.floor(e/Cx.day)},inMonths:function(e){return Math.floor(e/Cx.month)},inYears:function(e){return Math.floor(e/Cx.year)}},xx=/^((d|dd|m|mm|yyyy|yy|hh|h|ss|a)(-|:|\s|\/))*(d|dd|m|mm|yyyy|yy|hh|h|ss|a)$/i;function Ex(e,t,o){const s=function(e){const t=e.indexOf("h");e=t>=0?e.slice(0,t).replace(/m/g,"M")+e.slice(t):e.replace(/m/g,"M");e.includes("a")||(e=e.replace(/h/g,"H"));return e}(t),i=function(e,t,o){const s=e.map((e=>Us(e,o)?.jsDate));if(s.some((e=>void 0===e))||e.length<2)return;const i=s.map((e=>e.getTime())),n=Dt(i)-Ot(i),r=function(e){if(e.includes("s"))return"second";if(e.includes("m"))return"minute";if(e.includes("h")||e.includes("H"))return"hour";if(e.includes("d"))return"day";if(e.includes("M"))return"month";return"year"}(t);if(Cx.second>=Cx[r]&&wx.inSeconds(n)<180)return"second";if(Cx.minute>=Cx[r]&&wx.inMinutes(n)<180)return"minute";if(Cx.hour>=Cx[r]&&wx.inHours(n)<96)return"hour";if(Cx.day>=Cx[r]&&wx.inDays(n)<90)return"day";if(Cx.month>=Cx[r]&&wx.inMonths(n)<36)return"month";return"year"}(e,s,o),n={};return i&&(n[i]=s),{parser:s,displayFormats:n,unit:i??!1}}function Ix(e,t,o,s){let i=zx(s,t,o).formattedValues,n=Wx(s,t);e.dataSetsHaveTitle&&n[0]&&i.length>n[0].data.length&&i.shift(),({labels:i,dataSetsValues:n}=Hx(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Ux(i,n));const r=$x(s,t,"left"),a=$x(s,t,"right"),l=e.horizontal?{x:r||a}:{y:r,y1:a},c=[];for(const t in n){const{data:o}=n[t],s=e.dataSets?.[t].trend;if(!s?.display||e.horizontal){c.push(void 0);continue}const i=Ox(s,o);c.push(i)}return{dataSetsValues:n,trendDataSetsValues:c,axisFormats:l,labels:i,locale:s.getLocale()}}function Rx(e,t,o,s){const i=Ix(e,t,o,s),n=i.dataSetsValues,r=[];if(n[0]){const e=n[0].data.map((e=>e>0?e:0));r.push({...n[0],data:e})}if(n[1]){const e=n[1].data.map((e=>e>0?-e:0));r.push({...n[1],data:e})}return{...i,dataSetsValues:r}}function Tx(e,t,o,s){const i=function(e,t,o){if(function(e,t,o){return!e.labelsAsText&&Nx(t,o)}(e,t,o)&&function(){if(!window.Chart)return!1;const e="luxon"===new window.Chart._adapters._date({})._id;e||Lx||(Lx=!0,console.warn("'chartjs-adapter-luxon' time adapter is not installed. Time scale axes are disabled."));return e}())return"time";if(function(e,t,o){return!e.labelsAsText&&kx(t,o)}(e,t,o))return"linear";return"category"}(e,o,s),n=zx(s,t,o);let r="linear"===i?n.values:n.formattedValues,a=Wx(s,t);e.dataSetsHaveTitle&&a[0]&&r.length>a[0].data.length&&r.shift(),({labels:r,dataSetsValues:a}=Hx(r,a)),"time"===i&&({labels:r,dataSetsValues:a}=function(e,t){if(0===e.length||e.every((e=>!e)))return{labels:e,dataSetsValues:t};const o=[...e],s=Be(t);for(let e=0;e<o.length;e++)if(!o[e]){o[e]=gt(o,e);for(let t of s)t.data[e]=void 0}return{labels:o,dataSetsValues:s}}(r,a)),e.aggregated&&({labels:r,dataSetsValues:a}=Ux(r,a));const l={y:$x(s,t,"left"),y1:$x(s,t,"right"),x:Bx(s,o)},c=[];for(const t in a){let{data:o}=a[t];if(e.cumulative){let e=0;o=o.map((t=>isNaN(parseFloat(t))?t:(e+=parseFloat(t),e))),a[t]={...a[t],data:o}}const n=e.dataSets?.[t].trend;n?.display?c.push(Fx(n,o,r,i,s.getLocale())):c.push(void 0)}return{dataSetsValues:a,axisFormats:l,labels:r,locale:s.getLocale(),trendDataSetsValues:c,axisType:i}}function Ax(e,t,o,s){let i=zx(s,t,o).formattedValues,n=Wx(s,t);e.dataSetsHaveTitle&&n[0]&&i.length>n[0].data.length&&i.shift(),({labels:i,dataSetsValues:n}=Hx(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Ux(i,n)),({dataSetsValues:n,labels:i}=function(e,t){const o=Math.max(e.length,...t.map((e=>e.data?.length||0))),s=Ze(0,o).filter((e=>t.some((t=>"number"==typeof t.data[e]&&t.data[e]>0))));return{labels:s.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:s.map((t=>"number"==typeof e.data[t]&&e.data[t]>0?e.data[t]:null))})))}}(i,n));return{dataSetsValues:n,axisFormats:{y:$x(s,t,"left")},labels:i,locale:s.getLocale()}}function _x(e,t,o,s){let i=zx(s,t,o).formattedValues,n=Wx(s,t);e.dataSetsHaveTitle&&n[0]&&i.length>n[0].data.length&&i.shift(),({labels:i,dataSetsValues:n}=Hx(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Ux(i,n));return{dataSetsValues:n,axisFormats:{r:$x(s,t,"left")||$x(s,t,"right")},labels:i,locale:s.getLocale()}}function Dx(e,t,o,s){let i=zx(s,t,o).formattedValues;e.dataSetsHaveTitle&&i.shift();let n=Wx(s,t);({labels:i,dataSetsValues:n}=Ux(i,n));return{dataSetsValues:n,axisFormats:{y:$x(s,t,"left")||$x(s,t,"right")},labels:i,locale:s.getLocale(),availableRegions:s.getGeoChartAvailableRegions(),geoFeatureNameToId:s.geoFeatureNameToId,getGeoJsonFeatures:s.getGeoJsonFeatures}}function Ox(e,t){const o=[],s=[],i=[];for(let e=0;e<t.length;e++)"number"==typeof t[e]&&(o.push(t[e]),s.push(e+1)),i.push(e+1);const n=Mx(e,o,s,Ze(.5,i.length+.55,.2));return n.length?n:void 0}function Fx(e,t,o,s,i){const n=[],r=[],a=[],l=t.length;if(l<2)return;switch(s){case"category":for(let e=0;e<l;e++)"number"==typeof t[e]&&(n.push(t[e]),r.push(e+1)),a.push(e+1);break;case"linear":for(let e=0;e<t.length;e++){const s=Number(o[e]);isNaN(s)||("number"==typeof t[e]&&(n.push(t[e]),r.push(s)),a.push(s))}break;case"time":for(let e=0;e<t.length;e++){const s=Vi({value:o[e]},i);null!==t[e]&&(n.push(t[e]),r.push(s)),a.push(s)}}const c=Math.min(...a),h=Math.max(...a);if(h===c)return;const d=(h-c)/(5*a.length),u=Mx(e,n,r,Ze(c,h+d/2,d));return u.length?u:void 0}function Mx(e,t,o,s){if(t.length<2||o.length<2||0===s.length)return[];const i=Math.min(...o),n=Math.max(...o)-i,r=o.map((e=>(e-i)/n)),a=s.map((e=>(e-i)/n));try{switch(e.type){case"polynomial":{const o=e.order;if(!o)return s.map((e=>({x:e,y:NaN})));if(1===o)return ul([t],[r],[a],!0)[0].map(((e,t)=>({x:s[t],y:e})));const i=al(t,r,o,!0).flat();return a.map(((e,t)=>({x:s[t],y:cl(i,e,o)})))}case"exponential":{const e=[],o=[];for(let s=0;s<t.length;s++)t[s]>0&&(e.push(Math.log(t[s])),o.push(r[s]));return o.length?hl(ul([e],[o],[a],!0))[0].map(((e,t)=>({x:s[t],y:e}))):s.map((e=>({x:e,y:NaN})))}case"logarithmic":return ul([t],dl([r]),dl([a]),!0)[0].map(((e,t)=>({x:s[t],y:e})));case"trailingMovingAverage":return function(e,t,o=Te){const s=[];for(let e=0;e<o-1;e++)s.push({x:t[e],y:NaN});for(let i=0;i<=e.length-o;i++){let n=0;for(let t=i;t<i+o;t++)n+=e[t];s.push({x:t[i+o-1],y:n/o})}return s}(t,o,e.window);default:return s.map((e=>({x:e,y:NaN})))}}catch(e){return s.map((e=>({x:e,y:NaN})))}}function Px(e,t){return Nx(e,t)||kx(e,t)}function Nx(e,t){if(!e||!kx(e,t))return!1;const o=Bx(t,e);return Boolean(o&&xx.test(o))}function kx(e,t){if(!e)return!1;const o=t.getRangeValues(e);return!o.some((e=>isNaN(Number(e))&&e))&&!o.every((e=>!e))}let Lx=!1;function Vx(e,t){if(t.dataRange){const o=t.labelCell?[t.labelCell.zone]:[],s=Co([t.dataRange.zone],o)[0];if(void 0===s)return[];const i=e.getRangeFromZone(t.dataRange.sheetId,s);return e.getRangeValues(i).map((e=>""===e?void 0:e))}return[]}function Hx(e,t){const o=Ze(0,Math.max(e.length,...t.map((e=>e.data?.length||0)))).filter((o=>{const s=e[o],i=t.map((e=>e.data?.[o]));return s||i.some((e=>"number"==typeof e))}));return{labels:o.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:o.map((t=>"number"==typeof e.data[t]?e.data[t]:null))})))}}function Ux(e,t){const o=new Set(e),s={};o.forEach((e=>{s[e]=new Array(t.length).fill(0)}));for(const o of Ze(0,e.length)){const n=e[o];for(const e of Ze(0,t.length))s[n][e]+="number"==typeof(i=t[e].data[o])?i:0}var i;return{labels:Array.from(o),dataSetsValues:t.map(((e,t)=>({...e,data:Array.from(o).map((e=>s[e][t]))})))}}function Bx(e,t){if(!t)return;const{sheetId:o,zone:{left:s,top:i,bottom:n}}=t;for(let t=i;t<=n;t++){const i=e.getEvaluatedCell({sheetId:o,col:s,row:t}).format;if(i)return i}}function zx(e,t,o){let s={values:[],formattedValues:[]};if(o){const{left:i}=o.zone;if(o.invalidXc||o.invalidSheetName||e.isColHidden(o.sheetId,i)){if(t[0]){s={formattedValues:Ze(0,Vx(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}}else s={formattedValues:e.getRangeFormattedValues(o),values:e.getRangeValues(o).map((e=>String(e??"")))}}else if(1===t.length)for(let o=0;o<Vx(e,t[0]).length;o++)s.formattedValues.push(""),s.values.push("");else if(t[0]){s={formattedValues:Ze(0,Vx(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}return s}function $x(e,t,o){const s=t.filter((e=>"right"===o==!!e.rightYAxis));for(const t of s){const o=e.getRangeFormats(t.dataRange).find((e=>void 0!==e&&!rr(e)));if(o)return o}}function Wx(e,t){const o=[];for(const[s,i]of Object.entries(t)){if(e.isColHidden(i.dataRange.sheetId,i.dataRange.zone.left))continue;let t;if(i.labelCell){const o=i.labelCell,n=o?e.getEvaluatedCell({sheetId:o.sheetId,col:o.zone.left,row:o.zone.top}):void 0;t=n&&o?n.formattedValue:t=`${gx.Series} ${parseInt(s)+1}`}else t=`${gx.Series} ${parseInt(s)+1}`;let n=i.dataRange?Vx(e,i):[];if(n.every((e=>"string"==typeof e&&!ki(e)))&&n.some((e=>""!==e)))n.fill(1);else if(n.every((e=>null==e||!ti(e.toString(),Si))))continue;o.push({data:n,label:t})}return o}function Gx(e,t){const{dataSetsValues:o}=t,s=[],i=tE(e,o.length),n=[];for(const r in o){let{label:a,data:l}=o[r];a=e.dataSets?.[r].label||a;const c=i.next(),h={label:a,data:l,borderColor:e.background||m,borderWidth:e.stacked?1:0,backgroundColor:c,yAxisID:e.horizontal?"y":e.dataSets?.[r].yAxisId||"y",xAxisID:"x"};s.push(h);const d=e.dataSets?.[r].trend,u=t.trendDataSetsValues?.[r];d?.display&&!e.horizontal&&u&&n.push(Qx(h,d,u))}return s.push(...n),s}function qx(e,t){const{dataSetsValues:o,labels:s}=t,i=e.negativeValuesColor||T,n=e.positiveValuesColor||R,r=e.subTotalValuesColor||A,a=[],l=[],c={label:"",data:l,backgroundColor:a},h=[];let d=0;for(const t of o){for(let c=0;c<t.data.length;c++){const u=t.data[c];if(h.push(s[c]),isNaN(Number(u))){l.push([d,d]),a.push("");continue}l.push([d,u+d]);let g=u>=0?n:i;0===c&&t===o[0]&&e.firstValueAsSubtotal&&(g=r),a.push(g),d+=u}e.showSubTotals&&(h.push(Fo("Subtotal")),l.push([0,d]),a.push(r))}return{datasets:[c],labels:h}}function Zx(e,t){const{dataSetsValues:o,axisType:s,labels:i}=t,n=[],r=!!e.fillArea,a=!!e.stacked,l=[],c=tE(e,o.length);for(let h=0;h<o.length;h++){let{label:d,data:u}=o[h];d=e.dataSets?.[h].label||d;const g=c.next();s&&["linear","time"].includes(s)&&(u=u.map(((e,t)=>({x:i[t]||void 0,y:e}))));const p={label:d,data:u,tension:0,borderColor:g,backgroundColor:r?Jt(g,Re):g,pointBackgroundColor:g,fill:!!r&&eE(h,a),yAxisID:e.dataSets?.[h].yAxisId||"y"};n.push(p);const m=e.dataSets?.[h].trend,f=t.trendDataSetsValues?.[h];m?.display&&f&&l.push(Qx(p,m,f))}return n.push(...l),n}function jx(e,t){const o=Zx(e,t);for(const e of o)e.xAxisID!==Lc&&(e.showLine=!1);return o}function Yx(e,t){const{dataSetsValues:o}=t,s=[],i=Math.max(0,...o.map((e=>e?.data?.length??0))),n=sh(new ho(i),o);for(const{label:e,data:t}of o){const o={label:e,data:t,borderColor:m,backgroundColor:n,hoverOffset:30};s.push(o)}return s}function Xx(e,t){const{dataSetsValues:o}=t,s=[],i=tE(e,o.length),n=[];for(let r=0;r<o.length;r++){let{label:a,data:l}=o[r];a=e.dataSets?.[r].label||a;const c=e.dataSets?.[r],h=i.next(),d=c?.type??"line",u={label:a,data:l,borderColor:h,backgroundColor:h,yAxisID:e.dataSets?.[r].yAxisId||"y",xAxisID:"x",type:d,order:"bar"===d?o.length+r:r};s.push(u);const g=e.dataSets?.[r].trend,p=t.trendDataSetsValues?.[r];g?.display&&p&&n.push(Qx(u,g,p))}return s.push(...n),s}function Kx(e,t){const{dataSetsValues:o}=t,s=[],i=e.fillArea??!1,n=tE(e,o.length);for(let t=0;t<o.length;t++){let{label:r,data:a}=o[t];e.dataSets?.[t]?.label&&(r=e.dataSets[t].label);const l=n.next(),c={label:r,data:a,borderColor:l,backgroundColor:l};i&&(c.backgroundColor=Jt(l,Re),c.fill="start"),s.push(c)}return s}function Jx(e,t){const{availableRegions:o,dataSetsValues:s,labels:i}=t,n=e.region||o[0]?.id,r=n?t.getGeoJsonFeatures(n):void 0,a={outline:r,showOutline:!!r,data:[]};if(r&&n){const e={};if(s[0])for(let o=0;o<s[0].data.length;o++){if(!i[o]||void 0===s[0].data[o])continue;const r=t.geoFeatureNameToId(n,i[o]);r&&(e[r]={value:s[0].data[o],label:i[o]})}for(const t of r)t.id&&a.data.push({feature:{...t,properties:{name:e[t.id]?.label}},value:e[t.id]?.value})}return[a]}function Qx(e,t,o){const s=Zt(e.backgroundColor);s.a=1;const i=t.color||Qt(qt(s),.5);return{type:"line",xAxisID:Lc,yAxisID:e.yAxisID,label:e.label?Fo("Trend line for %s",e.label):"",data:o,order:-1,showLine:!0,pointRadius:0,backgroundColor:i,borderColor:i,borderDash:[5,5],borderWidth:void 0,fill:!1,pointBackgroundColor:i}}function eE(e,t){return t?0===e?"origin":"-1":"origin"}function tE(e,t){return new ho(t,e.dataSets?.map((e=>e.backgroundColor))||[])}function oE(e){return{padding:{left:Z,right:Z,top:Y,bottom:j}}}function sE(e,t){return{display:"none"!==e.legendPosition,position:"none"!==e.legendPosition?e.legendPosition:void 0}}function iE(e,t){return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:"rect",lineWidth:3})}}function nE(e,t){const o=e.fillArea,s=o?"rect":"line",i=o?2:3;return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:s,lineWidth:i})}}function rE(e,t){const{dataSetsValues:o}=t,s=Math.max(0,...o.map((e=>e?.data?.length??0))),i=sh(new ho(s),o);return{...sE(e),labels:{color:Zc(e.background),usePointStyle:!0,generateLabels:e=>e.data.labels.map(((e,t)=>({text:ih(String(e)),strokeStyle:i[t],fillStyle:i[t],pointStyle:"rect",hidden:!1,lineWidth:2})))}}}function aE(e,t){return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:"circle",strokeStyle:e.background||"#ffffff",lineWidth:8})}}function lE(e,t){return{...dE,...sE(e),...uE(Zc(e.background),{lineWidth:3})}}function cE(e,t){const o=Zc(e.background),s=e.negativeValuesColor||T,i=e.positiveValuesColor||R,n=e.subTotalValuesColor||A;return{...sE(e),labels:{usePointStyle:!0,generateLabels:()=>{const t=[{text:Fo("Positive values"),fontColor:o,fillStyle:i,strokeStyle:i,pointStyle:"rect"},{text:Fo("Negative values"),fontColor:o,fillStyle:s,strokeStyle:s,pointStyle:"rect"}];return(e.showSubTotals||e.firstValueAsSubtotal)&&t.push({text:Fo("Subtotals"),fontColor:o,fillStyle:n,strokeStyle:n,pointStyle:"rect"}),t}},onClick:()=>{}}}function hE(e,t){const o=e.fillArea??!1,s=o?"rect":"line",i=o?2:3;return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:s,lineWidth:i})}}const dE={onHover:e=>{const t=e.native?.target;t&&(t.style.cursor="pointer")},onLeave:e=>{const t=e.native?.target;t&&(t.style.cursor="default")},onClick:(e,t,o)=>{const s=t.datasetIndex;o.legendItems&&void 0!==s&&(o.chart.isDatasetVisible(s)?o.chart.hide(s):o.chart.show(s),e.native.preventDefault(),e.native.stopPropagation())}};function uE(e,t){return{labels:{color:e,usePointStyle:!0,generateLabels:o=>o.data.datasets.map(((s,i)=>s.xAxisID===Lc?{text:ih(s.label),fontColor:e,strokeStyle:s.borderColor,hidden:!o.isDatasetVisible(i),pointStyle:"line",datasetIndex:i,lineWidth:3}:{text:ih(s.label),fontColor:e,strokeStyle:s.borderColor,fillStyle:s.backgroundColor,hidden:!o.isDatasetVisible(i),pointStyle:"line"===s.type?"line":"rect",datasetIndex:i,...t}))}}}function gE(e,t){let o={};const{trendDataSetsValues:s,locale:i,axisFormats:n}=t,r={stacked:e.stacked,locale:i};if(e.horizontal)o.x=wE(e,"bottom","values",{...r,format:n?.x}),o.y=wE(e,"left","labels",r);else{o.x=wE(e,"bottom","labels",r);const t={...r,format:n?.y};o.y=wE(e,"left","values",t);const s={...r,format:n?.y1};o.y1=wE(e,"right","values",s)}if(o=bt(o),s&&s.length&&s.some(at)){const e=Math.max(...s.map((e=>e?.length||0)));o[Lc]={...o.x,labels:Array(e).fill(""),offset:!1,display:!1}}return o}function pE(e,t){const{locale:o,axisType:s,trendDataSetsValues:i,labels:n,axisFormats:r}=t,a=r?.x,l=e.stacked;let c={x:wE(e,"bottom","labels",{locale:o}),y:wE(e,"left","values",{locale:o,stacked:l,format:r?.y}),y1:wE(e,"right","values",{locale:o,stacked:l,format:r?.y1})};if(c=bt(c),"time"===s&&n&&a){const e={type:"time",time:Ex(n,a,o)};Object.assign(c.x,e),c.x.ticks.maxTicksLimit=15}else"linear"===s&&(c.x.type="linear",c.x.ticks.callback=e=>Jn(e,{format:a,locale:o}));if(i&&i.length&&i.some(at)&&(c[Lc]={...c.x,display:!1},"category"===s||"time"===s)){const e=Math.max(...i.map((e=>e?.length||0)));c[Lc].type="category",c[Lc].labels=Ze(0,e).map((e=>e.toString())),c[Lc].offset=!1}return c}function mE(e,t){const o=pE(e,t);return{...o,x:{...o.x,grid:{display:!0}}}}function fE(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;e.dataSets;const n={x:{...wE(e,"bottom","labels",{locale:o}),grid:{display:!1}},y:{position:e.verticalAxisPosition,ticks:{color:Zc(e.background),callback:th({locale:o,format:i})},grid:{lineWidth:e=>0===e.tick.value?2:1},title:CE(e.axesDesign?.y)}},r=n?.y||n?.y1;return r&&(r.grid={lineWidth:e=>0===e.tick.value?2:1}),n}function vE(e,t){const{dataSetsValues:o}=t,s=gE(e,t),i=s.x.ticks.callback;s.x.ticks.callback=e=>i(Math.abs(e));const n=Math.max(...o.map((e=>Math.max(...e.data.map(Math.abs)))));return s.x.suggestedMin=-n,s.x.suggestedMax=n,s}function bE(e,t){const{locale:o,axisFormats:s,dataSetsValues:i}=t,n=Math.min(...i.map((e=>Math.min(...e.data.filter((e=>!isNaN(e)))))));return{r:{beginAtZero:!0,ticks:{callback:th({format:s?.r,locale:o}),backdropColor:e.background||"#FFFFFF"},pointLabels:{color:Zc(e.background),callback:ih},suggestedMin:n<0?n-1:0}}}function SE(e,t){const{locale:o,axisFormats:s,availableRegions:i}=t,n=function(e){switch(e){case"top":return"top-left";case"right":return"top-right";case"bottom":return"bottom-right";case"left":case"none":return"bottom-left"}}(e.legendPosition),r=e.region?i.find((t=>t.id===e.region)):i[0],a=s?.y||s?.y1;return{projection:{projection:yE(r?.defaultProjection||"mercator"),axis:"x"},color:{axis:"x",display:"none"!==e.legendPosition,border:{color:D},grid:{color:D},ticks:{color:Zc(e.background),callback:th({locale:o,format:a})},legend:{position:n,align:n.includes("right")?"left":"right",margin:EE(e)},interpolate:xE(e),missing:e.missingValueColor||"#ffffff"}}}function yE(e){return"conicConformal"===e?window.ChartGeo.geoConicConformal().rotate([100,0]):e}function CE(e){if(e?.title?.text){const{text:t,color:o,align:s,italic:i,bold:n}=e.title;return{display:!0,text:t,color:o,font:{style:i?"italic":"normal",weight:n?"bold":"normal",size:e.title.fontSize??K},align:"left"===s?"start":"right"===s?"end":"center"}}}function wE(e,t,o,s){const{useLeftAxis:i,useRightAxis:n}=Qc(e);if("left"===t&&!i||"right"===t&&!n)return;const r=Zc(e.background);let a;if(a="bottom"===t?e.axesDesign?.x:"left"===t?e.axesDesign?.y:e.axesDesign?.y1,"values"===o){const e=!("right"===t&&i);return{position:t,title:CE(a),grid:{display:e},beginAtZero:!0,stacked:s?.stacked,ticks:{color:r,callback:th(s)}}}return{ticks:{padding:5,color:r,callback:function(e){return ih(this.getLabelForValue(e))}},grid:{display:!1},stacked:s?.stacked,title:CE(a)}}function xE(e){if(!e.colorScale||"string"==typeof e.colorScale)return e.colorScale||"oranges";const t=[{value:0,color:e.colorScale.minColor}];return e.colorScale.midColor&&t.push({value:.5,color:e.colorScale.midColor}),t.push({value:1,color:e.colorScale.maxColor}),go(t)}function EE(e){switch(e.legendPosition){case"top":case"right":return{top:!!e.title.text?Y+30:Y,left:Z,right:Z};case"bottom":case"left":case"none":return{left:Z,right:Z,bottom:j}}}function IE(e,t){const{axisFormats:o,locale:s}=t;return{horizontal:"horizontal"in e&&e.horizontal,showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:eh(o,s)}}function RE(e){const t=e.title,o=jc(e.background);return{display:!!t.text,text:Fo(t.text),color:t?.color??o,align:"center"===t.align?"center":"right"===t.align?"end":"start",font:{size:e.title.fontSize??X,weight:t.bold?"bold":"normal",style:t.italic?"italic":"normal"},padding:{bottom:"top"===e.legendPosition?0:Z}}}const TE='\n<templates>\n <t t-name="o-spreadsheet-CustomTooltip">\n <div\n class="o-chart-custom-tooltip border rounded px-2 py-1 pe-none mw-100 position-absolute text-nowrap shadow opacity-100">\n <table class="overflow-hidden m-0">\n <thead>\n <tr>\n <th class="o-tooltip-title align-baseline border-0 text-truncate" t-esc="title" t-attf-style="max-width: {{ labelsMaxWidth }}"/>\n </tr>\n </thead>\n <tbody>\n <tr t-foreach="tooltipItems" t-as="tooltipItem" t-key="tooltipItem_index">\n <td>\n <span\n class="badge ps-2 py-2 rounded-0 align-middle"\n t-attf-style="background-color: {{ tooltipItem.boxColor }}"\n > </span>\n <small\n t-if="tooltipItem.label"\n class="o-tooltip-label d-inline-block text-truncate align-middle smaller ms-2"\n t-esc="tooltipItem.label"\n t-attf-style="max-width: {{ labelsMaxWidth }}"\n />\n </td>\n <td class="o-tooltip-value ps-2 fw-bolder text-end">\n <small class="smaller d-inline-block text-truncate align-middle" t-attf-style="max-width: {{ valuesMaxWidth }}">\n <t t-esc="tooltipItem.value"/>\n <t t-if="tooltipItem.percentage">\n (\n <t t-esc="tooltipItem.percentage"/>\n %)\n </t>\n </small>\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n </t>\n</templates>\n';let AE;function _E(e,o={}){return function(e,o={}){AE||(AE=new t.App(t.Component,{templates:TE,translateFn:Fo}));const s=AE.getTemplate(e),i=s(o,{}),n=document.createElement("div");return t.blockDom.mount(i,n),n}(e,o).innerHTML}function DE(e,t){return{enabled:!1,external:LE,callbacks:{title:function(e){return e.some((e=>e.dataset.xAxisID!==Lc))?void 0:""},label:function(o){const s=o.dataset?.label||o.label,i=e.horizontal;let n=i?o.parsed.x:o.parsed.y;null==n&&(n=o.parsed);const r=i?o.dataset.xAxisID:o.dataset.yAxisID,a=eh(t.axisFormats,t.locale)(n,r);return s?`${s}: ${a}`:a}}}}function OE(e,t){const{axisType:o,locale:s,axisFormats:i}=t,n=i?.x,r={enabled:!1,external:LE,callbacks:{}};return r.callbacks.label="linear"===o?e=>{const t=e.parsed.y;let o=e.dataset.xAxisID===Lc?"":e.parsed.x;"string"==typeof o&&ti(o,s)&&(o=Vi(o,s));const r=Jn(o,{locale:s,format:n}),a=e.dataset.yAxisID||"y",l=Jn(t,{locale:s,format:i?.[a]}),c=e.dataset.label;return r?`${c}: (${r}, ${l})`:`${c}: ${l}`}:function(e){const t=e.dataset?.label||e.label,o=e.parsed.y,n=e.dataset.yAxisID,r=eh(i,s)(o,n);return t?`${t}: ${r}`:r},r.callbacks.title=function(e){return"linear"!==o&&e.some((e=>e.dataset.xAxisID!==Lc))?void 0:""},r}function FE(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:LE,callbacks:{title:function(e){return e[0].dataset.label},label:function(e){const t=function(e,t){const o=e.filter((e=>"number"==typeof e)).reduce(((e,t)=>e+t),0);if(!o)return"";const s=e[t]/o*100;return s.toFixed(2)}(e.dataset.data,e.dataIndex),s=e.label||e.dataset.label,n=e.parsed.y??e.parsed,r=Jn(n,{format:!i&&n>=1e3?"#,##":i,locale:o});return s?`${s}: ${r} (${t}%)`:`${r} (${t}%)`}}}}function ME(e,t){const{dataSetsValues:o,locale:s,axisFormats:i,labels:n}=t,r=i?.y||i?.y1,a=o.map((e=>e.label));return{enabled:!1,external:LE,callbacks:{label:function(e){const[t,o]=e.raw,i=o-t,l=n.length?Math.floor(e.dataIndex/n.length):0,c=a[l],h=Jn(i,{format:!r&&Math.abs(i)>1e3?"#,##":r,locale:s});return c?`${c}: ${h}`:h}}}}function PE(e,t){const o=DE(e,t);return{...o,callbacks:{...o.callbacks,label:e=>{const t={...e,parsed:{y:e.parsed.y,x:Math.abs(e.parsed.x)}};return(o?.callbacks?.label)(t)}}}}function NE(e,t){const{locale:o,axisFormats:s}=t;return{enabled:!1,external:LE,callbacks:{label:function(e){const t=e.dataset?.label||e.label,i=Jn(e.parsed.r,{format:s?.r,locale:o});return t?`${t}: ${i}`:i}}}}function kE(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{filter:function(e){return void 0!==e.raw.value},callbacks:{label:function(e){const t=e.raw,s=t.feature.properties.name,n=t.value,r=Jn(n,{format:!i&&Math.abs(n)>=1e3?"#,##":i,locale:o});return s?`${s}: ${r}`:r}}}}function LE({chart:e,tooltip:t}){if(e.canvas.parentNode.querySelector("div.o-chart-custom-tooltip")?.remove(),0===t.opacity||0===t.dataPoints.length)return;const o=t.body.map(((e,o)=>{let[s,i]=e.lines[0].split(":").map((e=>e.trim()));i||(i=s,s="");const n=t.labelColors[o].backgroundColor;return{label:s,value:i,boxColor:"string"==typeof n?Jt(n,1):n}})),s=_E("o-spreadsheet-CustomTooltip",{labelsMaxWidth:Math.floor(.5*e.canvas.clientWidth)+"px",valuesMaxWidth:Math.floor(.25*e.canvas.clientWidth)+"px",title:t.title[0],tooltipItems:o}),i=Object.assign(document.createElement("template"),{innerHTML:s}).content.firstChild;e.canvas.parentNode?.appendChild(i),Object.assign(i.style,{left:VE(e,t,i.clientWidth)+"px",top:Math.floor(t.caretY-i.clientHeight/2)+"px"})}function VE(e,t,o){const s=t.caretX;return s+o>e.chartArea.right?Math.max(0,s-o):s}var HE=Object.freeze({__proto__:null,INTERACTIVE_LEGEND_CONFIG:dE,canChartParseLabels:Px,getBarChartData:Ix,getBarChartDatasets:Gx,getBarChartLegend:iE,getBarChartScales:gE,getBarChartTooltip:DE,getChartColorsGenerator:tE,getChartLabelFormat:Bx,getChartLayout:oE,getChartShowValues:IE,getChartTitle:RE,getComboChartDatasets:Xx,getComboChartLegend:lE,getData:Vx,getGeoChartData:Dx,getGeoChartDatasets:Jx,getGeoChartScales:SE,getGeoChartTooltip:kE,getLineChartData:Tx,getLineChartDatasets:Zx,getLineChartLegend:nE,getLineChartScales:pE,getLineChartTooltip:OE,getPieChartData:Ax,getPieChartDatasets:Yx,getPieChartLegend:rE,getPieChartTooltip:FE,getPyramidChartData:Rx,getPyramidChartScales:vE,getPyramidChartTooltip:PE,getRadarChartData:_x,getRadarChartDatasets:Kx,getRadarChartLegend:hE,getRadarChartScales:bE,getRadarChartTooltip:NE,getScatterChartDatasets:jx,getScatterChartLegend:aE,getScatterChartScales:mE,getTrendDatasetForBarChart:Ox,getTrendDatasetForLineChart:Fx,getWaterfallChartLegend:cE,getWaterfallChartScales:fE,getWaterfallChartTooltip:ME,getWaterfallDatasetAndLabels:qx});class UE extends dh{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="bar";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.horizontal=e.horizontal,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"bar",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,showValues:e.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new UE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new UE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"bar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:this.horizontal,showValues:this.showValues}}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new UE(i,this.sheetId,this.getters)}}function BE(e,t){const o=e.getDefinition(),s=Ix(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Gx(o,s)},options:{...YS,indexAxis:e.horizontal?"y":"x",layout:oE(),scales:gE(o,s),plugins:{title:RE(o),legend:iE(o),tooltip:DE(o,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}}class zE extends dh{dataSets;labelRange;background;legendPosition;aggregated;dataSetsHaveTitle;dataSetDesign;axesDesign;type="combo";showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId),type:this.dataSetDesign?.[t]?.type??(t?"line":"bar")});return{type:"combo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues}}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new zE(i,this.sheetId,this.getters)}static getDefinitionFromContextCreation(e){const t=(e.range??[]).map(((e,t)=>({...e,type:t?"line":"bar"})));return{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated,legendPosition:e.legendPosition??"top",title:e.title||{text:""},labelRange:e.auxiliaryRange||void 0,type:"combo",axesDesign:e.axesDesign,showValues:e.showValues}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new zE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new zE(t,e,this.getters)}}function $E(e){return e.dataRange&&!Uo.test(e.dataRange)?"InvalidGaugeDataRange":"Success"}function WE(e,t){return t((t=>t.sectionRule?e(t.sectionRule.rangeMin,"rangeMin"):"Success"),(t=>t.sectionRule?e(t.sectionRule.rangeMax,"rangeMax"):"Success"))}function GE(e){return e.sectionRule&&Number(e.sectionRule.rangeMin)>=Number(e.sectionRule.rangeMax)?"GaugeRangeMinBiggerThanRangeMax":"Success"}function qE(e,t){if(""===e)switch(t){case"rangeMin":return"EmptyGaugeRangeMin";case"rangeMax":return"EmptyGaugeRangeMax"}return"Success"}function ZE(e,t){if(isNaN(e))switch(t){case"rangeMin":return"GaugeRangeMinNaN";case"rangeMax":return"GaugeRangeMaxNaN";case"lowerInflectionPointValue":return"GaugeLowerInflectionPointNaN";case"upperInflectionPointValue":return"GaugeUpperInflectionPointNaN"}return"Success"}class jE extends dh{dataRange;sectionRule;background;type="gauge";constructor(e,t,o){super(e,t,o),this.dataRange=Vr(this.getters,this.sheetId,e.dataRange),this.sectionRule=e.sectionRule,this.background=e.background}static validateChartDefinition(e,t){return e.checkValidations(t,$E,e.chainValidations(WE(qE,e.batchValidations),WE(ZE,e.batchValidations),GE),e.chainValidations((o=ZE,(0,e.batchValidations)((e=>e.sectionRule?o(e.sectionRule.lowerInflectionPoint.value,"lowerInflectionPointValue"):"Success"),(e=>e.sectionRule?o(e.sectionRule.upperInflectionPoint.value,"upperInflectionPointValue"):"Success")))));var o}static transformDefinition(e,t){let o;return e.dataRange&&(o=gc(jo(e.dataRange),t)),{...e,dataRange:o?Jo(o):void 0}}static getDefinitionFromContextCreation(e){return{background:e.background,title:e.title||{text:""},type:"gauge",dataRange:e.range?e.range[0].dataRange:void 0,sectionRule:{colors:{lowerColor:"#EA6175",middleColor:"#FFD86D",upperColor:"#43C5B1"},rangeMin:"0",rangeMax:"100",lowerInflectionPoint:{type:"percentage",value:"15",operator:"<="},upperInflectionPoint:{type:"percentage",value:"40",operator:"<="}}}}duplicateInDuplicatedSheet(e){const t=Uc(this.sheetId,e,this.dataRange),o=this.getDefinitionWithSpecificRanges(t,e);return new jE(o,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificRanges(this.dataRange,e);return new jE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.dataRange)}getDefinitionWithSpecificRanges(e,t){return{background:this.background,sectionRule:this.sectionRule,title:this.title,type:"gauge",dataRange:e?this.getters.getRangeString(e,t||this.sheetId):void 0}}getDefinitionForExcel(){}getContextCreation(){return{...this,range:this.dataRange?[{dataRange:this.getters.getRangeString(this.dataRange,this.sheetId)}]:void 0}}updateRanges(e){const t=Bc(this.dataRange,e);if(this.dataRange===t)return this;const o=this.getDefinitionWithSpecificRanges(t);return new jE(o,this.sheetId,this.getters)}}function YE(e,t){const o=t.getLocale(),s=e.sectionRule.colors;let i,n,r;const a=e.dataRange;if(void 0!==a){const e=t.getEvaluatedCell({sheetId:a.sheetId,col:a.zone.left,row:a.zone.top});e.type===ni.number&&(i=e.value,n=e.formattedValue,r=e.format)}const l=Number(e.sectionRule.rangeMin),c=Number(e.sectionRule.rangeMax),h=e.sectionRule.lowerInflectionPoint,d=e.sectionRule.upperInflectionPoint,u=XE(h,l,c),g=XE(d,l,c),p=[],m=[];return void 0!==u&&(p.push({value:u,label:Jn(u,{locale:o,format:r}),operator:h.operator}),m.push(s.lowerColor)),void 0!==g&&g!==u&&(p.push({value:g,label:Jn(g,{locale:o,format:r}),operator:d.operator}),m.push(s.middleColor)),void 0!==g&&void 0!==u&&u>g&&(p.reverse(),m.reverse()),m.push(s.upperColor),{background:t.getStyleOfSingleCellChart(e.background,a).background,title:{...e.title,text:Fo(e.title.text??"")},minValue:{value:l,label:Jn(l,{locale:o,format:r})},maxValue:{value:c,label:Jn(c,{locale:o,format:r})},gaugeValue:void 0!==i&&n?{value:i,label:n}:void 0,inflectionValues:p,colors:m}}function XE(e,t,o){if(""===e.value||isNaN(Number(e.value)))return;const s=Number(e.value);return qe("number"===e.type?s:t+(o-t)*s/100,t,o)}class KE extends dh{dataSets;labelRange;background;legendPosition;type="geo";dataSetsHaveTitle;dataSetDesign;colorScale;missingValueColor;region;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.colorScale=e.colorScale,this.missingValueColor=e.missingValueColor,this.region=e.region}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"geo",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new KE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new KE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"geo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,colorScale:this.colorScale,missingValueColor:this.missingValueColor,region:this.region}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new KE(i,this.sheetId,this.getters)}}class JE extends dh{dataSets;labelRange;background;legendPosition;labelsAsText;stacked;aggregated;type="line";dataSetsHaveTitle;cumulative;dataSetDesign;axesDesign;fillArea;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.cumulative=e.cumulative,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.fillArea=e.fillArea,this.showValues=e.showValues}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static transformDefinition(e,t){return qc(e,t)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"line",labelRange:e.auxiliaryRange||void 0,stacked:e.stacked??!1,aggregated:e.aggregated??!1,cumulative:e.cumulative??!1,axesDesign:e.axesDesign,fillArea:e.fillArea,showValues:e.showValues}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"line",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,stacked:this.stacked,aggregated:this.aggregated,cumulative:this.cumulative,axesDesign:this.axesDesign,fillArea:this.fillArea,showValues:this.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new JE(i,this.sheetId,this.getters)}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new JE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new JE(t,e,this.getters)}}function QE(e,t){const o=e.getDefinition(),s=Tx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:Zx(o,s)},options:{...YS,layout:oE(),scales:pE(o,s),plugins:{title:RE(o),legend:nE(o),tooltip:OE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}}class eI extends dh{dataSets;labelRange;background;legendPosition;type="pie";aggregated;dataSetsHaveTitle;isDoughnut;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.isDoughnut=e.isDoughnut,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pie",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,isDoughnut:!1,showValues:e.showValues}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getContextCreation(){return{...this,range:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)}))),auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinitionWithSpecificDataSets(e,t,o){return{type:"pie",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)}))),legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,isDoughnut:this.isDoughnut,showValues:this.showValues}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new eI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new eI(t,e,this.getters)}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new eI(i,this.sheetId,this.getters)}}function tI(e,t){const o=e.getDefinition(),s=Ax(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:e.isDoughnut?"doughnut":"pie",data:{labels:s.labels,datasets:Yx(0,s)},options:{...YS,layout:oE(),plugins:{title:RE(o),legend:rE(o,s),tooltip:FE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}}class oI extends dh{dataSets;labelRange;background;legendPosition;aggregated;type="pyramid";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal=!0;stacked=!0;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle).slice(0,2),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pyramid",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,horizontal:!0,stacked:!0,showValues:e.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new oI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new oI(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"pyramid",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:!0,stacked:!0,showValues:this.showValues}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new oI(i,this.sheetId,this.getters)}}class sI extends dh{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="radar";dataSetsHaveTitle;dataSetDesign;fillArea;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.fillArea=e.fillArea,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"radar",labelRange:e.auxiliaryRange||void 0,fillArea:e.fillArea??!1,showValues:e.showValues??!1}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new sI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new sI(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"radar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,fillArea:this.fillArea,showValues:this.showValues}}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new sI(i,this.sheetId,this.getters)}}class iI extends dh{dataSets;labelRange;background;legendPosition;labelsAsText;aggregated;type="scatter";dataSetsHaveTitle;dataSetDesign;axesDesign;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static transformDefinition(e,t){return qc(e,t)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"scatter",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,axesDesign:e.axesDesign,showValues:e.showValues}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"scatter",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new iI(i,this.sheetId,this.getters)}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new iI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new iI(t,e,this.getters)}}class nI extends dh{dataSets;labelRange;background;verticalAxisPosition;legendPosition;aggregated;type="waterfall";dataSetsHaveTitle;showSubTotals;firstValueAsSubtotal;showConnectorLines;positiveValuesColor;negativeValuesColor;subTotalValuesColor;dataSetDesign;axesDesign;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.verticalAxisPosition=e.verticalAxisPosition,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showSubTotals=e.showSubTotals,this.showConnectorLines=e.showConnectorLines,this.positiveValuesColor=e.positiveValuesColor,this.negativeValuesColor=e.negativeValuesColor,this.subTotalValuesColor=e.subTotalValuesColor,this.firstValueAsSubtotal=e.firstValueAsSubtotal,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range?e.range:[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"waterfall",verticalAxisPosition:"left",labelRange:e.auxiliaryRange||void 0,showSubTotals:e.showSubTotals??!1,showConnectorLines:e.showConnectorLines??!0,firstValueAsSubtotal:e.firstValueAsSubtotal??!1,axesDesign:e.axesDesign,showValues:e.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new nI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new nI(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"waterfall",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,verticalAxisPosition:this.verticalAxisPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,showSubTotals:this.showSubTotals,showConnectorLines:this.showConnectorLines,positiveValuesColor:this.positiveValuesColor,negativeValuesColor:this.negativeValuesColor,subTotalValuesColor:this.subTotalValuesColor,firstValueAsSubtotal:this.firstValueAsSubtotal,axesDesign:this.axesDesign,showValues:this.showValues}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new nI(i,this.sheetId,this.getters)}}function rI(e,t){const o=e.getDefinition(),s=Ix(o,e.dataSets,e.labelRange,t),{labels:i,datasets:n}=qx(o,s);return{chartJsConfig:{type:"bar",data:{labels:i,datasets:n},options:{...YS,layout:oE(),scales:fE(o,s),plugins:{title:RE(o),legend:cE(o),tooltip:ME(0,s),chartShowValuesPlugin:IE(o,s),waterfallLinesPlugin:{showConnectorLines:o.showConnectorLines}}}},background:e.background||m}}const aI=new n;aI.add("bar",{match:e=>"bar"===e,createChart:(e,t,o)=>new UE(e,t,o),getChartRuntime:BE,validateChartDefinition:UE.validateChartDefinition,transformDefinition:UE.transformDefinition,getChartDefinitionFromContextCreation:UE.getDefinitionFromContextCreation,sequence:10}),aI.add("combo",{match:e=>"combo"===e,createChart:(e,t,o)=>new zE(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Ix(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Xx(o,s)},options:{...YS,layout:oE(),scales:gE(o,s),plugins:{title:RE(o),legend:lE(o),tooltip:DE(o,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:zE.validateChartDefinition,transformDefinition:zE.transformDefinition,getChartDefinitionFromContextCreation:zE.getDefinitionFromContextCreation,sequence:15}),aI.add("line",{match:e=>"line"===e,createChart:(e,t,o)=>new JE(e,t,o),getChartRuntime:QE,validateChartDefinition:JE.validateChartDefinition,transformDefinition:JE.transformDefinition,getChartDefinitionFromContextCreation:JE.getDefinitionFromContextCreation,sequence:20}),aI.add("pie",{match:e=>"pie"===e,createChart:(e,t,o)=>new eI(e,t,o),getChartRuntime:tI,validateChartDefinition:eI.validateChartDefinition,transformDefinition:eI.transformDefinition,getChartDefinitionFromContextCreation:eI.getDefinitionFromContextCreation,sequence:30}),aI.add("scorecard",{match:e=>"scorecard"===e,createChart:(e,t,o)=>new bh(e,t,o),getChartRuntime:yh,validateChartDefinition:bh.validateChartDefinition,transformDefinition:bh.transformDefinition,getChartDefinitionFromContextCreation:bh.getDefinitionFromContextCreation,sequence:40}),aI.add("gauge",{match:e=>"gauge"===e,createChart:(e,t,o)=>new jE(e,t,o),getChartRuntime:YE,validateChartDefinition:jE.validateChartDefinition,transformDefinition:jE.transformDefinition,getChartDefinitionFromContextCreation:jE.getDefinitionFromContextCreation,sequence:50}),aI.add("scatter",{match:e=>"scatter"===e,createChart:(e,t,o)=>new iI(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Tx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:jx(o,s)},options:{...YS,layout:oE(),scales:mE(o,s),plugins:{title:RE(o),legend:aE(o),tooltip:OE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:iI.validateChartDefinition,transformDefinition:iI.transformDefinition,getChartDefinitionFromContextCreation:iI.getDefinitionFromContextCreation,sequence:60}),aI.add("waterfall",{match:e=>"waterfall"===e,createChart:(e,t,o)=>new nI(e,t,o),getChartRuntime:rI,validateChartDefinition:nI.validateChartDefinition,transformDefinition:nI.transformDefinition,getChartDefinitionFromContextCreation:nI.getDefinitionFromContextCreation,sequence:70}),aI.add("pyramid",{match:e=>"pyramid"===e,createChart:(e,t,o)=>new oI(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Rx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Gx(o,s)},options:{...YS,indexAxis:"y",layout:oE(),scales:vE(o,s),plugins:{title:RE(o),legend:iE(o),tooltip:PE(o,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:oI.validateChartDefinition,transformDefinition:oI.transformDefinition,getChartDefinitionFromContextCreation:oI.getDefinitionFromContextCreation,sequence:80}),aI.add("radar",{match:e=>"radar"===e,createChart:(e,t,o)=>new sI(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=_x(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"radar",data:{labels:s.labels,datasets:Kx(o,s)},options:{...YS,layout:oE(),scales:bE(o,s),plugins:{title:RE(o),legend:hE(o),tooltip:NE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:sI.validateChartDefinition,transformDefinition:sI.transformDefinition,getChartDefinitionFromContextCreation:sI.getDefinitionFromContextCreation,sequence:80}),aI.add("geo",{match:e=>"geo"===e,createChart:(e,t,o)=>new KE(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Dx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"choropleth",data:{datasets:Jx(o,s)},options:{...YS,layout:oE(),scales:SE(o,s),plugins:{title:RE(o),tooltip:kE(0,s),legend:{display:!1}}}},background:e.background||m}},validateChartDefinition:KE.validateChartDefinition,transformDefinition:KE.transformDefinition,getChartDefinitionFromContextCreation:KE.getDefinitionFromContextCreation,sequence:90});const lI=new n;lI.add("line",hh),lI.add("bar",hh),lI.add("combo",hh),lI.add("pie",hh),lI.add("gauge",ZS),lI.add("scatter",hh),lI.add("scorecard",Ih),lI.add("waterfall",hh),lI.add("pyramid",hh),lI.add("radar",hh),lI.add("geo",hh);const cI={line:Fo("Line"),column:Fo("Column"),bar:Fo("Bar"),area:Fo("Area"),pie:Fo("Pie"),misc:Fo("Miscellaneous")},hI=new n;hI.add("line",{matcher:e=>"line"===e.type&&!e.stacked&&!e.fillArea,displayName:Fo("Line"),chartType:"line",chartSubtype:"line",subtypeDefinition:{stacked:!1,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.LINE_CHART"}).add("stacked_line",{matcher:e=>"line"===e.type&&!e.fillArea&&!!e.stacked,displayName:Fo("Stacked Line"),chartType:"line",chartSubtype:"stacked_line",subtypeDefinition:{stacked:!0,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.STACKED_LINE_CHART"}).add("area",{matcher:e=>"line"===e.type&&!e.stacked&&!!e.fillArea,displayName:Fo("Area"),chartType:"line",chartSubtype:"area",subtypeDefinition:{stacked:!1,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.AREA_CHART"}).add("stacked_area",{matcher:e=>"line"===e.type&&e.stacked&&!!e.fillArea,displayName:Fo("Stacked Area"),chartType:"line",chartSubtype:"stacked_area",subtypeDefinition:{stacked:!0,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.STACKED_AREA_CHART"}).add("scatter",{displayName:Fo("Scatter"),chartType:"scatter",chartSubtype:"scatter",category:"misc",preview:"o-spreadsheet-ChartPreview.SCATTER_CHART"}).add("column",{matcher:e=>"bar"===e.type&&!e.stacked&&!e.horizontal,displayName:Fo("Column"),chartType:"bar",chartSubtype:"column",subtypeDefinition:{stacked:!1,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.COLUMN_CHART"}).add("stacked_column",{matcher:e=>"bar"===e.type&&e.stacked&&!e.horizontal,displayName:Fo("Stacked Column"),chartType:"bar",chartSubtype:"stacked_column",subtypeDefinition:{stacked:!0,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.STACKED_COLUMN_CHART"}).add("bar",{matcher:e=>"bar"===e.type&&!e.stacked&&!!e.horizontal,displayName:Fo("Bar"),chartType:"bar",chartSubtype:"bar",subtypeDefinition:{horizontal:!0,stacked:!1},category:"bar",preview:"o-spreadsheet-ChartPreview.BAR_CHART"}).add("stacked_bar",{matcher:e=>"bar"===e.type&&e.stacked&&!!e.horizontal,displayName:Fo("Stacked Bar"),chartType:"bar",chartSubtype:"stacked_bar",subtypeDefinition:{horizontal:!0,stacked:!0},category:"bar",preview:"o-spreadsheet-ChartPreview.STACKED_BAR_CHART"}).add("combo",{displayName:Fo("Combo"),chartSubtype:"combo",chartType:"combo",category:"line",preview:"o-spreadsheet-ChartPreview.COMBO_CHART"}).add("pie",{matcher:e=>"pie"===e.type&&!e.isDoughnut,displayName:Fo("Pie"),chartSubtype:"pie",chartType:"pie",subtypeDefinition:{isDoughnut:!1},category:"pie",preview:"o-spreadsheet-ChartPreview.PIE_CHART"}).add("doughnut",{matcher:e=>"pie"===e.type&&!!e.isDoughnut,displayName:Fo("Doughnut"),chartSubtype:"doughnut",chartType:"pie",subtypeDefinition:{isDoughnut:!0},category:"pie",preview:"o-spreadsheet-ChartPreview.DOUGHNUT_CHART"}).add("gauge",{displayName:Fo("Gauge"),chartSubtype:"gauge",chartType:"gauge",category:"misc",preview:"o-spreadsheet-ChartPreview.GAUGE_CHART"}).add("scorecard",{displayName:Fo("Scorecard"),chartSubtype:"scorecard",chartType:"scorecard",category:"misc",preview:"o-spreadsheet-ChartPreview.SCORECARD_CHART"}).add("waterfall",{displayName:Fo("Waterfall"),chartSubtype:"waterfall",chartType:"waterfall",category:"misc",preview:"o-spreadsheet-ChartPreview.WATERFALL_CHART"}).add("pyramid",{displayName:Fo("Population Pyramid"),chartSubtype:"pyramid",chartType:"pyramid",category:"misc",preview:"o-spreadsheet-ChartPreview.POPULATION_PYRAMID_CHART"}).add("radar",{matcher:e=>"radar"===e.type&&!e.fillArea,displayName:Fo("Radar"),chartSubtype:"radar",chartType:"radar",subtypeDefinition:{fillArea:!1},category:"misc",preview:"o-spreadsheet-ChartPreview.RADAR_CHART"}).add("filled_radar",{matcher:e=>"radar"===e.type&&!!e.fillArea,displayName:Fo("Filled Radar"),chartType:"radar",chartSubtype:"filled_radar",subtypeDefinition:{fillArea:!0},category:"misc",preview:"o-spreadsheet-ChartPreview.FILLED_RADAR_CHART"}).add("geo",{displayName:Fo("Geo Chart"),chartSubtype:"geo",chartType:"geo",category:"misc",preview:"o-spreadsheet-ChartPreview.GEO_CHART"});const dI=new n;Mc`
|
|
36
|
+
`}function Aw(e){return new JS(e.join("\n"))}function _w(e,...t){let o=[e[0]];for(let s=0;s<t.length;s++){const i=t[s]instanceof JS?t[s]:xw(t[s]);o.push(i+e[s+1])}return new JS(dt(o))}function Dw(e){return e.replace(/NAMESPACE.*NAMESPACE(.*)/,"$1")}function Ow(e){return e.replaceAll(/([a-zA-Z0-9]+):([a-zA-Z0-9]+)/g,"NAMESPACE$1NAMESPACE$2")}class Fw{value;constructor(e){this.value=e}asString(){return Jy(String(this.value))}asBool(){return"true"===this.value||"false"!==this.value&&Boolean(Number(this.value))}asNum(){return Number(this.value)}}class Mw{rootFile;xlsxFileStructure;warningManager;relationships;currentFile=void 0;constructor(e,t,o){this.rootFile=e,this.currentFile=e.file.fileName,this.xlsxFileStructure=t,this.warningManager=o,this.relationships={},e.rels&&this.extractRelationships(e.rels).map((e=>{this.relationships[e.id]=e}))}extractRelationships(e){return this.mapOnElements({parent:e.xml,query:"Relationship"},(e=>({id:this.extractAttr(e,"Id",{required:!0}).asString(),target:this.extractAttr(e,"Target",{required:!0}).asString(),type:this.extractAttr(e,"Type",{required:!0}).asString()})))}getListOfXMLFiles(){return Object.entries(this.xlsxFileStructure).filter((([e])=>"images"!==e)).map((([e,t])=>t)).flat().filter(at)}mapOnElements(e,t){const o=[],s=this.currentFile;let i;if(e.children){const t=this.querySelector(e.parent,e.query)?.children;i=t||[]}else i=this.querySelectorAll(e.parent,e.query);if(i)for(let e of i)try{o.push(t(e))}catch(t){this.catchErrorOnElement(t,e)}return this.currentFile=s,o}catchErrorOnElement(e,t){const o=t?`Error when parsing an element <${t.tagName}> of file ${this.currentFile}, skip this element. \n${e.stack}`:`Error when parsing file ${this.currentFile}.`;this.warningManager.addParsingWarning([o,e.message].join("\n"))}extractAttr(e,t,o){const s=e.attributes[t];s||this.handleMissingValue(e,`attribute "${t}"`,o);const i=s?.value?s.value:o?.default;return void 0===i?void 0:new Fw(i)}extractTextContent(e,t){if(void 0!==t?.default&&"string"!=typeof t.default)throw new Error("extractTextContent default value should be a string");const o="preserve"===e?.attributes["xml:space"]?.value;let s=e?.textContent;return e&&null!==s||this.handleMissingValue(e,"text content",t),s&&(s=o?s:s.trim()),s?Jy(s):t?.default}extractChildAttr(e,t,o,s){let i;i="number"==typeof t?e.children[t]:this.querySelector(e,t),i||this.handleMissingValue(e,"number"==typeof t?`child at index ${t}`:`child <${t}>`,s);const n=i?this.extractAttr(i,o,s)?.asString():s?.default;return void 0!==n?new Fw(n):void 0}extractChildTextContent(e,t,o){if(void 0!==o?.default&&"string"!=typeof o.default)throw new Error("extractTextContent default value should be a string");let s=this.querySelector(e,t);return s||this.handleMissingValue(e,`child <${t}>`,o),s?this.extractTextContent(s,o):o?.default}handleMissingValue(e,t,o){if(o?.required){if(!o?.default)throw new Error(`Missing required ${t} in element <${e.tagName}> of ${this.currentFile}, and no default value was set`);this.warningManager.addParsingWarning(`Missing required ${t} in element <${e.tagName}> of ${this.currentFile}, replacing it by the default value ${o.default}`)}}extractColor(e,t,o){if(!e)return o?{rgb:o}:void 0;const s=this.extractAttr(e,"theme")?.asString();let i;if(void 0!==s){if(!t||!t.clrScheme)throw new Error("Color referencing a theme but no theme was provided");i=this.getThemeColor(s,t.clrScheme)}else i=this.extractAttr(e,"rgb")?.asString(),i="FF000000"===i?void 0:i;return{rgb:i||o,auto:this.extractAttr(e,"auto")?.asBool(),indexed:this.extractAttr(e,"indexed")?.asNum(),tint:this.extractAttr(e,"tint")?.asNum()}}getTargetXmlFile(e){if(!e)throw new Error("Undefined target file");const t=this.processRelationshipTargetName(e.target),o=this.getListOfXMLFiles().find((e=>e.file.fileName.endsWith(t)));if(!o||!o.file)throw new Error("Cannot find target file");return o}getTargetImageFile(e){if(!e)throw new Error("Undefined target file");const t=this.processRelationshipTargetName(e.target),o=this.xlsxFileStructure.images.find((e=>e.fileName.endsWith(t)));if(!o)throw new Error("Cannot find target file");return o}querySelector(e,t){const o=Ow(t);return e.querySelector(o)}querySelectorAll(e,t){const o=Ow(t);return e.querySelectorAll(o)}getThemeColor(e,t){switch(e){case"0":return"FFFFFF";case"1":return"000000";case"2":return t[3].value;case"3":return t[2].value;default:return t[e].value}}processRelationshipTargetName(e){return e.replace(/\.+\//,"")}}class Pw extends Mw{getTheme(){return{clrScheme:this.mapOnElements({query:"a:clrScheme",parent:this.rootFile.file.xml,children:!0},(e=>({name:e.tagName,value:this.extractChildAttr(e,0,"val",{required:!0,default:ey}).asString(),lastClr:this.extractChildAttr(e,0,"lastClr",{default:ey}).asString()})))}}getSharedStrings(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"si"},(e=>this.mapOnElements({parent:e,query:"t"},(e=>this.extractTextContent(e)||"")).join("")))}}class Nw extends Mw{theme;constructor(e,t,o,s){super(e,t,o),this.theme=s}extractConditionalFormattings(){const e=this.mapOnElements({parent:this.rootFile.file.xml,query:"worksheet > conditionalFormatting"},(e=>({sqref:this.extractAttr(e,"sqref",{required:!0}).asString().split(" "),pivot:this.extractAttr(e,"pivot")?.asBool(),cfRules:this.extractCFRules(e,this.theme)})));return e.push(...this.mapOnElements({parent:this.rootFile.file.xml,query:"extLst x14:conditionalFormatting"},(e=>({sqref:this.extractChildTextContent(e,"xm:sqref",{required:!0}).split(" "),pivot:this.extractAttr(e,"xm:pivot")?.asBool(),cfRules:this.extractCFRules(e,this.theme)})))),e}extractCFRules(e,t){return this.mapOnElements({parent:e,query:"cfRule, x14:cfRule"},(e=>({type:this.extractAttr(e,"type",{required:!0}).asString(),priority:this.extractAttr(e,"priority",{required:!0}).asNum(),colorScale:this.extractCfColorScale(e,t),formula:this.extractCfFormula(e),iconSet:this.extractCfIconSet(e),dxfId:this.extractAttr(e,"dxfId")?.asNum(),stopIfTrue:this.extractAttr(e,"stopIfTrue")?.asBool(),aboveAverage:this.extractAttr(e,"aboveAverage")?.asBool(),percent:this.extractAttr(e,"percent")?.asBool(),bottom:this.extractAttr(e,"bottom")?.asBool(),operator:this.extractAttr(e,"operator")?.asString(),text:this.extractAttr(e,"text")?.asString(),timePeriod:this.extractAttr(e,"timePeriod")?.asString(),rank:this.extractAttr(e,"rank")?.asNum(),stdDev:this.extractAttr(e,"stdDev")?.asNum(),equalAverage:this.extractAttr(e,"equalAverage")?.asBool(),dataBar:this.extractCfDataBar(e,t)})))}extractCfFormula(e){return this.mapOnElements({parent:e,query:"formula"},(e=>this.extractTextContent(e,{required:!0})))}extractCfColorScale(e,t){const o=this.querySelector(e,"colorScale");if(o)return{colors:this.mapOnElements({parent:o,query:"color"},(e=>this.extractColor(e,t,"ffffff"))),cfvos:this.extractCFVos(o)}}extractCfDataBar(e,t){const o=this.querySelector(e,"dataBar");if(o)return{color:this.extractColor(o.querySelector("color"),t,"EFF7FF"),cfvos:this.extractCFVos(o)}}extractCfIconSet(e){const t=this.querySelector(e,"iconSet, x14:iconSet");if(t)return{iconSet:this.extractAttr(t,"iconSet",{default:"3TrafficLights1"}).asString(),showValue:this.extractAttr(t,"showValue",{default:!0}).asBool(),percent:this.extractAttr(t,"percent",{default:!0}).asBool(),reverse:this.extractAttr(t,"reverse")?.asBool(),custom:this.extractAttr(t,"custom")?.asBool(),cfvos:this.extractCFVos(t),cfIcons:this.extractCfIcons(t)}}extractCfIcons(e){const t=this.mapOnElements({parent:e,query:"cfIcon, x14:cfIcon"},(e=>({iconSet:this.extractAttr(e,"iconSet",{required:!0}).asString(),iconId:this.extractAttr(e,"iconId",{required:!0}).asNum()})));return 0===t.length?void 0:t}extractCFVos(e){return this.mapOnElements({parent:e,query:"cfvo, x14:cfvo"},(e=>({type:this.extractAttr(e,"type",{required:!0}).asString(),gte:this.extractAttr(e,"gte",{default:!0})?.asBool(),value:e.attributes.val?this.extractAttr(e,"val")?.asString():this.extractChildTextContent(e,"f, xm:f")})))}}class kw extends Mw{theme;constructor(e,t,o,s){super(e,t,o),this.theme=s}extractDataValidations(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"worksheet > dataValidations > dataValidation"},(e=>({type:this.extractAttr(e,"type",{required:!0}).asString(),operator:this.extractAttr(e,"operator",{default:"between"})?.asString(),sqref:this.extractAttr(e,"sqref",{required:!0}).asString().split(" "),errorStyle:this.extractAttr(e,"errorStyle")?.asString(),formula1:this.extractDataValidationFormula(e,1)[0],formula2:this.extractDataValidationFormula(e,2)[0],showErrorMessage:this.extractAttr(e,"showErrorMessage")?.asBool(),errorTitle:this.extractAttr(e,"errorTitle")?.asString(),error:this.extractAttr(e,"error")?.asString(),showInputMessage:this.extractAttr(e,"showInputMessage")?.asBool(),promptTitle:this.extractAttr(e,"promptTitle")?.asString(),prompt:this.extractAttr(e,"prompt")?.asString(),allowBlank:this.extractAttr(e,"allowBlank")?.asBool()})))}extractDataValidationFormula(e,t){return this.mapOnElements({parent:e,query:`formula${t}`},(e=>this.extractTextContent(e,{required:!0})))}}class Lw extends Mw{extractChart(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"c:chartSpace"},(e=>{const t=this.getChartType(e);if(!Hy[t])throw new Error(`Unsupported chart type ${t}`);if("combo"===Hy[t])return this.extractComboChart(e);const o=this.mapOnElements({parent:e,query:"c:chart > c:title a:t"},(e=>e.textContent||"")).join(""),s=this.extractChildAttr(e,"c:grouping","val",{default:"clustered"}).asString();return{title:{text:o},type:Hy[t],dataSets:this.extractChartDatasets(this.querySelectorAll(e,`c:${t}`),t),labelRange:this.extractChildTextContent(e,`c:ser ${"scatterChart"===t?"c:numRef":"c:cat"} c:f`),backgroundColor:this.extractChildAttr(e,"c:chartSpace > c:spPr a:srgbClr","val",{default:"ffffff"}).asString(),legendPosition:Vy[this.extractChildAttr(e,"c:legendPos","val",{default:"b"}).asString()],stacked:"stacked"===s,fontColor:"000000"}}))[0]}extractComboChart(e){const t=this.mapOnElements({parent:e,query:"c:title a:t"},(e=>e.textContent||"")).join(""),o=this.extractChildAttr(e,"c:grouping","val",{default:"clustered"}).asString();return{title:{text:t},type:"combo",dataSets:[...this.extractChartDatasets(this.querySelectorAll(e,"c:barChart"),"comboChart"),...this.extractChartDatasets(this.querySelectorAll(e,"c:lineChart"),"comboChart")],labelRange:this.extractChildTextContent(e,"c:ser c:cat c:f"),backgroundColor:this.extractChildAttr(e,"c:chartSpace > c:spPr a:srgbClr","val",{default:"ffffff"}).asString(),legendPosition:Vy[this.extractChildAttr(e,"c:legendPos","val",{default:"b"}).asString()],stacked:"stacked"===o,fontColor:"000000"}}extractChartDatasets(e,t){return Array.from(e).map((e=>"scatterChart"===t?this.extractScatterChartDatasets(e):this.mapOnElements({parent:e,query:"c:ser"},(e=>{let t={};const o=this.extractChildTextContent(e,"c:tx c:f");if(o)t={reference:o};else{const o=this.extractChildTextContent(e,"c:tx c:v");o&&(t={text:o})}const s=this.extractChildAttr(e,"c:spPr a:solidFill a:srgbClr","val");return{label:t,range:this.extractChildTextContent(e,"c:val c:f",{required:!0}),backgroundColor:s?`${Bt(s.asString())}`:void 0}})))).flat()}extractScatterChartDatasets(e){return this.mapOnElements({parent:e,query:"c:ser"},(e=>{let t={};const o=this.extractChildTextContent(e,"c:tx c:f");if(o)t={reference:o};else{const o=this.extractChildTextContent(e,"c:tx c:v");o&&(t={text:o})}return{label:t,range:this.extractChildTextContent(e,"c:yVal c:f",{required:!0})}}))}getChartType(e){const t=this.querySelector(e,"c:plotArea");if(!t)throw new Error("Missing plot area in the chart definition.");let o;for(let e of t.children){const t=Dw(e.tagName);QS.some((e=>e===t))&&(o?o!==t&&(o="comboChart"):o=t)}if(o)return o;throw new Error("Unknown chart type")}}const Vw="oneCellAnchor",Hw="twoCellAnchor";class Uw extends Mw{extractFigures(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"xdr:wsDr",children:!0},(e=>{const t=Dw(e.tagName),o=this.extractFigureAnchorsByType(e,t),s=this.querySelector(e,"c:chart"),i=this.querySelector(e,"a:blip");if(!s&&!i)throw new Error("Only chart and image figures are currently supported.");return{anchors:o,data:s?this.extractChart(s):this.extractImage(e),figureSize:t===Vw?this.extractFigureSizeFromSizeTag(e,"xdr:ext"):void 0}}))}extractFigureAnchorsByType(e,t){switch(t){case Vw:return[this.extractFigureAnchor("xdr:from",e)];case Hw:return[this.extractFigureAnchor("xdr:from",e),this.extractFigureAnchor("xdr:to",e)];default:throw new Error(`${t} is not supported for xlsx drawings. `)}}extractFigureSizeFromSizeTag(e,t){const o=this.querySelector(e,t);if(!o)throw new Error(`Missing size element '${t}'`);return{cx:this.extractAttr(o,"cx",{required:!0}).asNum(),cy:this.extractAttr(o,"cy",{required:!0}).asNum()}}extractFigureAnchor(e,t){const o=this.querySelector(t,e);if(!o)throw new Error(`Missing anchor element ${e}`);return{col:Number(this.extractChildTextContent(o,"xdr:col",{required:!0})),colOffset:Number(this.extractChildTextContent(o,"xdr:colOff",{required:!0})),row:Number(this.extractChildTextContent(o,"xdr:row",{required:!0})),rowOffset:Number(this.extractChildTextContent(o,"xdr:rowOff",{required:!0}))}}extractChart(e){const t=this.extractAttr(e,"r:id",{required:!0}).asString(),o=this.getTargetXmlFile(this.relationships[t]),s=new Lw(o,this.xlsxFileStructure,this.warningManager).extractChart();if(!s)throw new Error("Unable to extract chart definition");return s}extractImage(e){const t=this.querySelector(e,"a:blip"),o=this.extractAttr(t,"r:embed",{required:!0}).asString(),s=this.getTargetImageFile(this.relationships[o]);if(!s)throw new Error("Unable to extract image");const i=s.fileName.split(".").at(-1),n=Dw(e.tagName),r=n===Hw?this.querySelector(e,"a:xfrm"):e,a=n===Hw?"a:ext":"xdr:ext",l=this.extractFigureSizeFromSizeTag(r,a);return{imageSrc:s.imageSrc,mimetype:i?Gy[i]:void 0,size:l}}}class Bw extends Mw{getPivotTable(){return this.mapOnElements({query:":root",parent:this.rootFile.file.xml},(e=>({name:this.extractAttr(e,"name",{required:!0}).asString(),rowGrandTotals:this.extractAttr(e,"rowGrandTotals",{default:!0}).asBool(),location:this.extractPivotLocation(e),style:this.extractPivotStyleInfo(e)})))[0]}extractPivotLocation(e){return this.mapOnElements({query:"location",parent:e},(e=>({ref:this.extractAttr(e,"ref",{required:!0}).asString(),firstHeaderRow:this.extractAttr(e,"firstHeaderRow",{required:!0}).asNum(),firstDataRow:this.extractAttr(e,"firstDataRow",{required:!0}).asNum(),firstDataCol:this.extractAttr(e,"firstDataCol",{required:!0}).asNum()})))[0]}extractPivotStyleInfo(e){return this.mapOnElements({query:"pivotTableStyleInfo",parent:e},(e=>({name:this.extractAttr(e,"name",{required:!0}).asString(),showRowHeaders:this.extractAttr(e,"showRowHeaders",{required:!0}).asBool(),showColHeaders:this.extractAttr(e,"showColHeaders",{required:!0}).asBool(),showRowStripes:this.extractAttr(e,"showRowStripes",{required:!0}).asBool(),showColStripes:this.extractAttr(e,"showColStripes",{required:!0}).asBool(),showLastColumn:this.extractAttr(e,"showLastColumn")?.asBool()})))[0]}}class zw extends Mw{getTable(){return this.mapOnElements({query:"table",parent:this.rootFile.file.xml},(e=>({displayName:this.extractAttr(e,"displayName",{required:!0}).asString(),name:this.extractAttr(e,"name")?.asString(),id:this.extractAttr(e,"id",{required:!0}).asString(),ref:this.extractAttr(e,"ref",{required:!0}).asString(),headerRowCount:this.extractAttr(e,"headerRowCount",{default:1}).asNum(),totalsRowCount:this.extractAttr(e,"totalsRowCount",{default:0}).asNum(),cols:this.extractTableCols(e),style:this.extractTableStyleInfo(e),autoFilter:this.extractTableAutoFilter(e)})))[0]}extractTableCols(e){return this.mapOnElements({query:"tableColumn",parent:e},(e=>({id:this.extractAttr(e,"id",{required:!0}).asString(),name:this.extractAttr(e,"name",{required:!0}).asString(),colFormula:this.extractChildTextContent(e,"calculatedColumnFormula")})))}extractTableStyleInfo(e){return this.mapOnElements({query:"tableStyleInfo",parent:e},(e=>({name:this.extractAttr(e,"name")?.asString(),showFirstColumn:this.extractAttr(e,"showFirstColumn")?.asBool(),showLastColumn:this.extractAttr(e,"showLastColumn")?.asBool(),showRowStripes:this.extractAttr(e,"showRowStripes")?.asBool(),showColumnStripes:this.extractAttr(e,"showColumnStripes")?.asBool()})))[0]}extractTableAutoFilter(e){return this.mapOnElements({query:"autoFilter",parent:e},(e=>({columns:this.extractFilterColumns(e),zone:this.extractAttr(e,"ref",{required:!0}).asString()})))[0]}extractFilterColumns(e){return this.mapOnElements({query:"tableColumn",parent:e},(t=>({colId:this.extractAttr(e,"colId",{required:!0}).asNum(),hiddenButton:this.extractAttr(e,"hiddenButton",{default:!1}).asBool(),filters:this.extractSimpleFilter(t)})))}extractSimpleFilter(e){return this.mapOnElements({query:"filter",parent:e},(e=>({val:this.extractAttr(e,"val",{required:!0}).asString()})))}}class $w extends Mw{theme;constructor(e,t,o,s){super(e,t,o),this.theme=s}getSheet(){return this.mapOnElements({query:"worksheet",parent:this.rootFile.file.xml},(e=>{const t=this.getSheetWorkbookInfo();return{sheetName:this.extractSheetName(),sheetViews:this.extractSheetViews(e),sheetFormat:this.extractSheetFormat(e),sheetProperties:this.extractSheetProperties(e),cols:this.extractCols(e),rows:this.extractRows(e),sharedFormulas:this.extractSharedFormulas(e),merges:this.extractMerges(e),cfs:this.extractConditionalFormats(),dataValidations:this.extractDataValidations(),figures:this.extractFigures(e),hyperlinks:this.extractHyperLinks(e),tables:this.extractTables(e),pivotTables:this.extractPivotTables(),isVisible:"visible"===t.state}}))[0]}extractSheetViews(e){return this.mapOnElements({parent:e,query:"sheetView"},(e=>{const t=this.querySelector(e,"pane");return{tabSelected:this.extractAttr(e,"tabSelected",{default:!1}).asBool(),showFormulas:this.extractAttr(e,"showFormulas",{default:!1}).asBool(),showGridLines:this.extractAttr(e,"showGridLines",{default:!0}).asBool(),showRowColHeaders:this.extractAttr(e,"showRowColHeaders",{default:!0}).asBool(),pane:{xSplit:t?this.extractAttr(t,"xSplit",{default:0}).asNum():0,ySplit:t?this.extractAttr(t,"ySplit",{default:0}).asNum():0}}}))}extractSheetName(){const e=Xy(this.xlsxFileStructure.workbook.file.fileName,this.rootFile.file.fileName),t=this.extractRelationships(this.xlsxFileStructure.workbook.rels).find((t=>t.target===e)).id;for(let e of this.querySelectorAll(this.xlsxFileStructure.workbook.file.xml,"sheet"))if(e.attributes["r:id"].value===t)return e.attributes.name.value;throw new Error("Missing sheet name")}getSheetWorkbookInfo(){const e=Xy(this.xlsxFileStructure.workbook.file.fileName,this.rootFile.file.fileName),t=this.extractRelationships(this.xlsxFileStructure.workbook.rels).find((t=>t.target===e)).id,o=this.mapOnElements({parent:this.xlsxFileStructure.workbook.file.xml,query:"sheet"},(e=>({relationshipId:this.extractAttr(e,"r:id",{required:!0}).asString(),sheetId:this.extractAttr(e,"sheetId",{required:!0}).asString(),sheetName:this.extractAttr(e,"name",{required:!0}).asString(),state:this.extractAttr(e,"state",{default:"visible"}).asString()}))).find((e=>e.relationshipId===t));if(!o)throw new Error("Cannot find corresponding workbook sheet");return o}extractConditionalFormats(){return new Nw(this.rootFile,this.xlsxFileStructure,this.warningManager,this.theme).extractConditionalFormattings()}extractDataValidations(){return new kw(this.rootFile,this.xlsxFileStructure,this.warningManager,this.theme).extractDataValidations()}extractFigures(e){return this.mapOnElements({parent:e,query:"drawing"},(e=>{const t=this.extractAttr(e,"r:id",{required:!0})?.asString(),o=this.getTargetXmlFile(this.relationships[t]);return new Uw(o,this.xlsxFileStructure,this.warningManager).extractFigures()}))[0]||[]}extractTables(e){return this.mapOnElements({query:"tablePart",parent:e},(e=>{const t=this.extractAttr(e,"r:id",{required:!0})?.asString(),o=this.getTargetXmlFile(this.relationships[t]);return new zw(o,this.xlsxFileStructure,this.warningManager).getTable()}))}extractPivotTables(){try{return Object.values(this.relationships).filter((e=>e.type.endsWith("pivotTable"))).map((e=>{const t=this.getTargetXmlFile(e);return new Bw(t,this.xlsxFileStructure,this.warningManager).getPivotTable()}))}catch(e){return this.catchErrorOnElement(e),[]}}extractMerges(e){return this.mapOnElements({parent:e,query:"mergeCell"},(e=>this.extractAttr(e,"ref",{required:!0}).asString()))}extractSheetFormat(e){const t=this.querySelector(e,"sheetFormatPr");if(t)return{defaultColWidth:this.extractAttr(t,"defaultColWidth",{default:hy.toString()}).asNum(),defaultRowHeight:this.extractAttr(t,"defaultRowHeight",{default:dy.toString()}).asNum()}}extractSheetProperties(e){const t=this.querySelector(e,"sheetPr");if(t)return{outlinePr:this.extractSheetOutlineProperties(t),tabColor:this.extractColor(this.querySelector(t,"tabColor"),this.theme)}}extractSheetOutlineProperties(e){const t=this.querySelector(e,"outlinePr");if(t)return{summaryBelow:this.extractAttr(t,"summaryBelow",{default:!0}).asBool(),summaryRight:this.extractAttr(t,"summaryRight",{default:!0}).asBool()}}extractCols(e){return this.mapOnElements({parent:e,query:"cols col"},(e=>({width:this.extractAttr(e,"width")?.asNum(),customWidth:this.extractAttr(e,"customWidth")?.asBool(),bestFit:this.extractAttr(e,"bestFit")?.asBool(),hidden:this.extractAttr(e,"hidden")?.asBool(),min:this.extractAttr(e,"min",{required:!0})?.asNum(),max:this.extractAttr(e,"max",{required:!0})?.asNum(),styleIndex:this.extractAttr(e,"style")?.asNum(),outlineLevel:this.extractAttr(e,"outlineLevel")?.asNum(),collapsed:this.extractAttr(e,"collapsed")?.asBool()})))}extractRows(e){return this.mapOnElements({parent:e,query:"sheetData row"},(e=>({index:this.extractAttr(e,"r",{required:!0})?.asNum(),cells:this.extractCells(e),height:this.extractAttr(e,"ht")?.asNum(),customHeight:this.extractAttr(e,"customHeight")?.asBool(),hidden:this.extractAttr(e,"hidden")?.asBool(),styleIndex:this.extractAttr(e,"s")?.asNum(),outlineLevel:this.extractAttr(e,"outlineLevel")?.asNum(),collapsed:this.extractAttr(e,"collapsed")?.asBool()})))}extractCells(e){return this.mapOnElements({parent:e,query:"c"},(e=>({xc:this.extractAttr(e,"r",{required:!0})?.asString(),styleIndex:this.extractAttr(e,"s")?.asNum(),type:Dy[this.extractAttr(e,"t",{default:"n"})?.asString()],value:this.extractChildTextContent(e,"v"),formula:this.extractCellFormula(e)})))}extractCellFormula(e){const t=this.querySelector(e,"f");if(t)return{content:this.extractTextContent(t),sharedIndex:this.extractAttr(t,"si")?.asNum(),ref:this.extractAttr(t,"ref")?.asString()}}extractHyperLinks(e){return this.mapOnElements({parent:e,query:"hyperlink"},(e=>{const t=this.extractAttr(e,"r:id")?.asString();return{xc:this.extractAttr(e,"ref",{required:!0})?.asString(),location:this.extractAttr(e,"location")?.asString(),display:this.extractAttr(e,"display")?.asString(),relTarget:t?this.relationships[t].target:void 0}}))}extractSharedFormulas(e){const t=this.querySelectorAll(e,"f[si][ref]"),o={};for(let e of t){const t=this.extractAttr(e,"si",{required:!0}).asNum(),s=this.extractTextContent(e,{required:!0});o[t]=s}const s=[];for(let e=0;e<Object.keys(o).length;e++)o[e]?s.push(o[e]):(this.warningManager.addParsingWarning(`Missing shared formula ${e}, replacing it by empty formula`),s.push(""));return s}}class Ww extends Mw{theme;constructor(e,t,o){super(e.styles,e,t),this.theme=o}getNumFormats(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"numFmt"},(e=>this.extractNumFormats(e)))}extractNumFormats(e){return{id:this.extractAttr(e,"numFmtId",{required:!0}).asNum(),format:this.extractAttr(e,"formatCode",{required:!0,default:""}).asString()}}getFonts(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"font"},(e=>this.extractFont(e)))}extractFont(e){const t=this.extractChildAttr(e,"name","val",{default:"Arial"}).asString(),o=this.extractChildAttr(e,"sz","val",{default:me.toString()}).asNum(),s=this.extractColor(this.querySelector(e,"color"),this.theme),i=this.querySelector(e,"i")||void 0,n=i&&"0"!==i.attributes.val?.value,r=this.querySelector(e,"b")||void 0,a=r&&"0"!==r.attributes.val?.value,l=this.querySelector(e,"strike")||void 0,c=l&&"0"!==l.attributes.val?.value,h=this.querySelector(e,"u")||void 0;return{name:t,size:o,color:s,italic:n,bold:a,underline:h&&"none"!==h.attributes.val?.value,strike:c}}getFills(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"fill"},(e=>this.extractFill(e)))}extractFill(e){const t=e.children[0];return"patternFill"===t.tagName?{patternType:t.attributes.patternType?.value,bgColor:this.extractColor(this.querySelector(t,"bgColor"),this.theme),fgColor:this.extractColor(this.querySelector(t,"fgColor"),this.theme)}:{patternType:"solid",fgColor:this.extractColor(this.querySelectorAll(t,"color")[1],this.theme)}}getBorders(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"border"},(e=>this.extractBorder(e)))}extractBorder(e){const t={left:this.extractSingleBorder(e,"left",this.theme),right:this.extractSingleBorder(e,"right",this.theme),top:this.extractSingleBorder(e,"top",this.theme),bottom:this.extractSingleBorder(e,"bottom",this.theme),diagonal:this.extractSingleBorder(e,"diagonal",this.theme)};return t.diagonal&&(t.diagonalUp=this.extractAttr(e,"diagonalUp")?.asBool(),t.diagonalDown=this.extractAttr(e,"diagonalDown")?.asBool()),t}extractSingleBorder(e,t,o){const s=this.querySelector(e,t);if(s&&s.attributes.style)return{style:this.extractAttr(s,"style",{required:!0,default:"thin"}).asString(),color:this.extractColor(s.children[0],o,"000000")}}extractAlignment(e){return{horizontal:this.extractAttr(e,"horizontal",{default:"general"}).asString(),vertical:this.extractAttr(e,"vertical",{default:"bottom"}).asString(),textRotation:this.extractAttr(e,"textRotation")?.asNum(),wrapText:this.extractAttr(e,"wrapText")?.asBool(),indent:this.extractAttr(e,"indent")?.asNum(),relativeIndent:this.extractAttr(e,"relativeIndent")?.asNum(),justifyLastLine:this.extractAttr(e,"justifyLastLine")?.asBool(),shrinkToFit:this.extractAttr(e,"shrinkToFit")?.asBool(),readingOrder:this.extractAttr(e,"readingOrder")?.asNum()}}getDxfs(){return this.mapOnElements({query:"dxf",parent:this.rootFile.file.xml},(e=>{const t=this.querySelector(e,"font"),o=this.querySelector(e,"fill"),s=this.querySelector(e,"border"),i=this.querySelector(e,"numFmt"),n=this.querySelector(e,"alignment");return{font:t?this.extractFont(t):void 0,fill:o?this.extractFill(o):void 0,numFmt:i?this.extractNumFormats(i):void 0,alignment:n?this.extractAlignment(n):void 0,border:s?this.extractBorder(s):void 0}}))}getStyles(){return this.mapOnElements({query:"cellXfs xf",parent:this.rootFile.file.xml},(e=>{const t=this.querySelector(e,"alignment");return{fontId:this.extractAttr(e,"fontId",{required:!0,default:0}).asNum(),fillId:this.extractAttr(e,"fillId",{required:!0,default:0}).asNum(),borderId:this.extractAttr(e,"borderId",{required:!0,default:0}).asNum(),numFmtId:this.extractAttr(e,"numFmtId",{required:!0,default:0}).asNum(),alignment:t?this.extractAlignment(t):void 0}}))}}class Gw extends Mw{getExternalBook(){return this.mapOnElements({parent:this.rootFile.file.xml,query:"externalBook"},(e=>({rId:this.extractAttr(e,"r:id",{required:!0}).asString(),sheetNames:this.mapOnElements({parent:e,query:"sheetName"},(e=>this.extractAttr(e,"val",{required:!0}).asString())),datasets:this.extractExternalSheetData(e)})))[0]}extractExternalSheetData(e){return this.mapOnElements({parent:e,query:"sheetData"},(e=>{const t=this.mapOnElements({parent:e,query:"cell"},(e=>({xc:this.extractAttr(e,"r",{required:!0}).asString(),value:this.extractChildTextContent(e,"v",{required:!0})}))),o={};for(let e of t)o[e.xc]=e.value;return{sheetId:this.extractAttr(e,"sheetId",{required:!0}).asNum(),data:o}}))}}function qw(e,t){const o=function(e,t){const o=t[vy],s=o.querySelectorAll(`Override[ContentType="${e}"]`),i=[];for(let e of s){const t=e?.attributes.PartName.value;i.push(t.substring(1))}return i}(e,t);return function(e,t){const o=[];for(let s of e){const e=Zw(s,t);o.push({file:{fileName:s,xml:t[s]},rels:e?{fileName:e,xml:t[e]}:void 0})}return o}(o,t)}function Zw(e,t){if(e===vy)return"_rels/.rels";let o="";const s=e.split("/");for(let e=0;e<s.length-1;e++)o+=s[e]+"/";return o+="_rels/",o+=s[s.length-1]+".rels",t[o]||(o=void 0),o}class jw{warningManager;xmls;images;constructor(e){this.warningManager=new xy,this.xmls={},this.images=[];for(let t of Object.keys(e))if(t.endsWith(".xml")||t.endsWith(".rels")){const o=e[t].replaceAll(/(<\/?)([a-zA-Z0-9]+):([a-zA-Z0-9]+)/g,"$1NAMESPACE$2NAMESPACE$3");this.xmls[t]=Iw(new JS(o))}else t.includes("media/image")&&this.images.push({fileName:t,imageSrc:e[t].imageSrc})}convertXlsx(){const e=this.getXlsxData();return this.convertImportedData(e)}getXlsxData(){const e=this.buildXlsxFileStructure(),t=e.theme?new Pw(e.theme,e,this.warningManager).getTheme():void 0,o=e.sharedStrings?new Pw(e.sharedStrings,e,this.warningManager).getSharedStrings():[],s=e.sheets.sort(((e,t)=>e.file.fileName.localeCompare(t.file.fileName,void 0,{numeric:!0}))).map((o=>new $w(o,e,this.warningManager,t).getSheet())),i=e.externalLinks.map((t=>new Gw(t,e,this.warningManager).getExternalBook())),n=new Ww(e,this.warningManager,t);return{fonts:n.getFonts(),fills:n.getFills(),borders:n.getBorders(),dxfs:n.getDxfs(),numFmts:n.getNumFormats(),styles:n.getStyles(),sheets:s,sharedStrings:o,externalBooks:i}}buildXlsxFileStructure(){const e={sheets:qw(ny.sheet,this.xmls),workbook:qw(ny.workbook,this.xmls)[0],styles:qw(ny.styles,this.xmls)[0],sharedStrings:qw(ny.sharedStrings,this.xmls)[0],theme:qw(ny.themes,this.xmls)[0],charts:qw(ny.chart,this.xmls),figures:qw(ny.drawing,this.xmls),tables:qw(ny.table,this.xmls),pivots:qw(ny.pivot,this.xmls),externalLinks:qw(ny.externalLink,this.xmls),images:this.images};if(!e.workbook.rels)throw Error(Fo("Cannot find workbook relations file"));return e}convertImportedData(e){const t={version:24,sheets:WC(e,this.warningManager),styles:iC(e,this.warningManager),formats:rC(e,this.warningManager),borders:oC(e,this.warningManager),revisionId:Se};return bw(t,e),Object.keys(e.styles).map((t=>{e.styles[t]=bt(e.styles[t])})),t}}function Yw(e){const t=vf(e);let o=[];return{text:"".concat(...t.map((e=>{if("REFERENCE"===e.type&&Po.test(e.value)){const t=e.value.trim();return o.includes(t)||o.push(t),`${De}${o.indexOf(t)}${De}`}return e.value}))),dependencies:o}}const Xw={am_ET:7,ar_001:6,ar_SY:6,az_AZ:1,eu_ES:1,be_BY:1,bn_IN:1,bs_BA:1,bg_BG:1,ca_ES:1,zh_CN:7,zh_HK:7,zh_TW:7,hr_HR:1,cs_CZ:1,da_DK:1,nl_BE:1,nl_NL:1,en_AU:7,en_CA:7,en_GB:1,en_IN:7,en_NZ:7,et_EE:1,fi_FI:1,fr_BE:1,fr_CA:7,fr_CH:1,fr_FR:1,gl_ES:1,ka_GE:1,de_DE:1,de_CH:1,el_GR:1,gu_IN:7,he_IL:7,hi_IN:7,hu_HU:1,id_ID:7,it_IT:1,ja_JP:7,kab_DZ:6,km_KH:7,ko_KP:1,ko_KR:7,lo_LA:7,lv_LV:1,lt_LT:1,lb_LU:1,mk_MK:1,ml_IN:1,mn_MN:7,ms_MY:1,nb_NO:1,fa_IR:6,pl_PL:1,pt_AO:1,pt_BR:7,pt_PT:1,ro_RO:1,ru_RU:1,sr_RS:7,"sr@latin":7,sk_SK:1,sl_SI:1,es_AR:7,es_BO:1,es_CL:1,es_CO:7,es_CR:1,es_DO:1,es_EC:1,es_GT:7,es_MX:7,es_PA:7,es_PE:7,es_PY:7,es_UY:1,es_VE:7,sw:1,sv_SE:1,th_TH:7,tl_PH:1,tr_TR:1,uk_UA:1,vi_VN:1,sq_AL:1,te_IN:7,en_US:7,my_MM:7,es_ES:1,es_419:1},Kw=new n;function Jw(e){for(let t of e.sheets||[]){let e=[];for(let o of t.filterTables||[]){const t=Yo(o.range),s=e.findIndex((e=>rs(e,t)));-1!==s?e[s]=t:e.push(t)}t.filterTables=e.map((e=>({range:Jo(e)})))}return e}Kw.add("migration_1",{versionFrom:"1",migrate:e=>(e.sheets&&e.sheets[0]&&(e.activeSheet=e.sheets[0].name),e)}).add("migration_2",{versionFrom:"2",migrate(e){if(e.sheets&&e.sheets.length)for(let t of e.sheets)t.id=t.id||t.name;return e}}).add("migration_3",{versionFrom:"3",migrate(e){if(e.sheets&&e.activeSheet){const t=e.sheets.find((t=>t.name===e.activeSheet));e.activeSheet=t.id}return e}}).add("migration_4",{versionFrom:"4",migrate(e){for(let t of e.sheets||[])t.figures=t.figures||[];return e}}).add("migration_5",{versionFrom:"5",migrate(e){for(let t of e.sheets||[])for(let e in t.cells||[]){const o=t.cells[e];o.content&&o.content.startsWith("=")&&(o.formula=Yw(o.content))}return e}}).add("migration_6",{versionFrom:"6",migrate(e){for(let t of e.sheets||[])for(let e in t.figures||[]){const{dataSets:o,...s}=t.figures[e].data,i=[];for(let e of o)if(e.labelCell){const t=Yo(e.dataRange),o=e.labelCell+":"+yo(t.right,t.bottom);i.push(o)}else i.push(e.dataRange);s.dataSetsHaveTitle=Boolean(o[0].labelCell),s.dataSets=i,t.figures[e].data=s}return e}}).add("migration_7",{versionFrom:"7",migrate(e){const t=[];for(let o of e.sheets||[]){if(!o.name)continue;const e=o.name,s=Nt(Ge(e,"_"),t,{compute:(e,t)=>`${e}${t}`});o.name=s,t.push(s);const i=t=>{if(void 0===t)return t;let o=t.replace(e,s),i=t;for(;i!==o;)i=o,o=i.replace(e,s);return i};for(let e in o.cells){const t=o.cells[e];t.formula&&(t.formula.dependencies=t.formula.dependencies.map(i))}for(let e of o.figures||[])if("chart"===e.type){const t=e.data.dataSets.map(i),o=i(e.data.labelRange);e.data={...e.data,dataSets:t,labelRange:o}}for(let e of o.conditionalFormats||[]){e.ranges=e.ranges.map(i);for(const t of["minimum","maximum","midpoint","upperInflectionPoint","lowerInflectionPoint"])"formula"===e.rule[t]?.type&&(e.rule[t].value=i(e.rule[t].value))}}return e}}).add("migration_8",{versionFrom:"8",migrate(e){for(const t of e.sheets||[])for(const e of t.figures||[])e.data.background=m,e.data.verticalAxisPosition="left",e.data.legendPosition="top",e.data.stacked=!1;return e}}).add("migration_9",{versionFrom:"9",migrate(e){for(let t of e.sheets||[])for(let e in t.cells||[]){const o=t.cells[e];if(o.formula){let{text:e,dependencies:t}=o.formula;for(let[o,s]of Object.entries(t)){const t=`\\${De}${o}\\${De}`;e=e.replace(new RegExp(t,"g"),s)}o.content=e,delete o.formula}}return e}}).add("migration_10",{versionFrom:"10",migrate(e){const t={};for(let o of e.sheets||[])for(let e in o.cells||[]){const s=o.cells[e];s.format&&(s.format=ws(s.format,t))}return e.formats=t,e}}).add("migration_11",{versionFrom:"11",migrate(e){for(let t of e.sheets||[])t.isVisible=!0;return e}}).add("migration_12",{versionFrom:"12",migrate:e=>Jw(e)}).add("migration_12_5",{versionFrom:"12.5",migrate(e){for(const t in e.borders){const o=e.borders[t];for(const e in o)Array.isArray(o[e])&&(o[e]={style:o[e][0],color:o[e][1]})}return e}}).add("migration_13",{versionFrom:"13",migrate:e=>(e.settings||(e.settings={}),e.settings.locale||(e.settings.locale=Si),e)}).add("migration_14",{versionFrom:"14",migrate:e=>Jw(e)}).add("migration_14_5",{versionFrom:"14.5",migrate(e){for(const t of e.sheets||[])t.tables=t.tables||t.filterTables||[],delete t.filterTables;return e}}).add("migration_15",{versionFrom:"15",migrate:e=>(e.pivots||(e.pivots={}),e.pivotNextId||(e.pivotNextId=Gl(e.pivots)+1),e)}).add("migration_16",{versionFrom:"16",migrate(e){for(const t of e.sheets||[])for(const e in t.figures||[]){const o=t.figures[e];"title"in o.data&&"string"==typeof o.data.title&&(o.data.title={text:o.data.title});const s=o.data.type;if(!["line","bar","pie","scatter","waterfall","combo"].includes(s))continue;const{dataSets:i,...n}=t.figures[e].data,r=i.map((e=>({dataRange:e})));n.dataSets=r,t.figures[e].data=n}return e}}).add("migration_17",{versionFrom:"17",migrate:e=>e}).add("migration_18",{versionFrom:"18",migrate(e){for(const t of Object.values(e.pivots||{}))t.measures=t.measures.map((e=>({id:e.name,fieldName:e.name,aggregator:e.aggregator}))),t.columns=t.columns.map((e=>({fieldName:e.name,order:e.order,granularity:e.granularity}))),t.rows=t.rows.map((e=>({fieldName:e.name,order:e.order,granularity:e.granularity})));return e}}).add("migration_19",{versionFrom:"19",migrate(e){const t=e.settings?.locale;if(t){const e=t.code;t.weekStart=Xw[e]||1}return e}}).add("migration_20",{versionFrom:"20",migrate(e){for(const t of e.sheets||[]){t.styles={},t.formats={},t.borders={};for(const e in t.cells)t.styles[e]=t.cells[e].style,t.formats[e]=t.cells[e].format,t.borders[e]=t.cells[e].border,delete t.cells[e].style,delete t.cells[e].format,delete t.cells[e].border}return e}}).add("migration_21",{versionFrom:"21",migrate(e){for(const t of e.sheets||[])for(const e of t.figures||[]){if("chart"!==e.tag||"gauge"!==e.data.type)continue;const t=e.data;t?.sectionRule?.lowerInflectionPoint&&(t.sectionRule.lowerInflectionPoint.operator="<="),t?.sectionRule?.upperInflectionPoint&&(t.sectionRule.upperInflectionPoint.operator="<=")}return e}}).add("migration_22",{versionFrom:"22",migrate(e){for(const t of e.sheets||[])for(const e of t.tables||[])e.config||(e.config={...QC,hasFilters:!0});return e}}).add("migration_23",{versionFrom:"23",migrate(e){for(const t of e.sheets||[])for(const e in t.cells){const o=t.cells[e];o&&(t.cells[e]=o.content)}return e}}).add("migration_24",{versionFrom:"24",migrate:e=>e});const Qw=25,ex="Sheet1";function tx(e,t){if(!e)return nx();console.debug("### Loading data ###");const o=performance.now();if(e["[Content_Types].xml"]){const o=new jw(e);if(e=o.convertXlsx(),t)for(let e of o.warningManager.warnings.sort())console.warn(e)}return"version"in e&&e.version<Qw&&(console.debug("Migrating data from version",e.version),e=function(e){const t=performance.now(),o=Kw.getAll().sort(((e,t)=>function(e,t){const o=e.split(".").map(Number),s=t.split(".").map(Number);for(let e=0;e<Math.max(o.length,s.length);e++){const t=o[e]||0,i=s[e]||0;if(t>i)return 1;if(t<i)return-1}return 0}(e.versionFrom,t.versionFrom)));for(let t=o.findIndex((t=>t.versionFrom===e.version.toString()));t<o.length;t++)e=o[t].migrate(e);return console.debug("Data migrated in",performance.now()-t,"ms"),e}(e)),e=function(e){return e=function(e){if(e.uniqueFigureIds)return e;const t=new Set,o=new aa;for(const s of e.sheets||[])for(const e of s.figures||[])t.has(e.id)&&(e.id+=o.uuidv4()),t.add(e.id);return e.uniqueFigureIds=!0,e}(e),e=function(e){const t=Object.assign(nx(),e,{version:Qw});t.sheets=t.sheets?t.sheets.map(((e,t)=>Object.assign(ix(`Sheet${t+1}`,`Sheet${t+1}`),e))):[],0===t.sheets.length&&t.sheets.push(ix(ex,"Sheet1"));_a(t.settings.locale)||(t.settings.locale=Si);return t}(e),e}(e),console.debug("Data loaded in",performance.now()-o,"ms"),console.debug("###"),e}function ox(e,t){return t=function(e,t){if(0!==Object.keys(e).length)return t;const o=[],s=[],i=e=>{if("CREATE_SHEET"===e.type)o.push(e.sheetId);else if("sheetId"in e&&!o.includes(e.sheetId))return{...e,sheetId:ex};return e};for(const e of t)"REMOTE_REVISION"===e.type?s.push({...e,commands:e.commands.map(i)}):s.push(e);return s}(e,t),t=sx(t,"SORT_CELLS"),t=function(e,t){const o=[],s={};for(const t of e.sheets||[])t.figures?.forEach((e=>{"chart"===e.tag&&(s[e.id]=e.data)}));for(const e of t)if("REMOTE_REVISION"===e.type){const t=[];for(const o of e.commands){let e=o;switch(o.type){case"CREATE_CHART":s[o.id]=o.definition;break;case"UPDATE_CHART":if(!s[o.id]){console.log(`Fix chart definition: chart with id ${o.id} not found.`);continue}const t={...s[o.id],...o.definition};e={...o,definition:t},s[o.id]=t}t.push(e)}o.push({...e,commands:t})}else o.push(e);return o}(e,t=sx(t,"SET_DECIMAL")),t}function sx(e,t){const o=[];for(const s of e)"REMOTE_REVISION"===s.type?o.push({...s,commands:s.commands.filter((e=>e.type!==t))}):o.push(s);return o}function ix(e,t){return{id:e,name:t,colNumber:26,rowNumber:100,cells:{},styles:{},formats:{},borders:{},cols:{},rows:{},merges:[],conditionalFormats:[],dataValidationRules:[],figures:[],tables:[],isVisible:!0}}function nx(e="Sheet1"){return{version:Qw,sheets:[ix(ex,e)],styles:{},formats:{},borders:{},revisionId:Se,uniqueFigureIds:!0,settings:{locale:Si},pivots:{},pivotNextId:1,customTableStyles:{}}}function rx(e,t){return{...ix(e,t),charts:[],images:[],cellValues:{}}}const ax={wrongPasteSelection:Fo("This operation is not allowed with multiple selections."),willRemoveExistingMerge:Fo("This operation is not possible due to a merge. Please remove the merges first than try again."),wrongFigurePasteOption:Fo("Cannot do a special paste of a figure."),frozenPaneOverlap:Fo("This operation is not allowed due to an overlapping frozen pane.")};function lx(e,t){t.isSuccessful||(t.reasons.includes("WrongPasteSelection")?e.raiseError(ax.wrongPasteSelection):t.reasons.includes("WillRemoveExistingMerge")?e.raiseError(ax.willRemoveExistingMerge):t.reasons.includes("WrongFigurePasteOption")?e.raiseError(ax.wrongFigurePasteOption):t.reasons.includes("FrozenPaneOverlap")&&e.raiseError(ax.frozenPaneOverlap))}function cx(e,t,o){const s=e.model.dispatch("PASTE",{target:t,pasteOption:o});lx(e,s)}function hx(e,t,o,s){let i;try{i=e.model.dispatch("PASTE_FROM_OS_CLIPBOARD",{target:t,clipboardContent:o,pasteOption:s})}catch(n){const r=o.data;r?.version!==Qw&&e.raiseError(Fo("An unexpected error occurred while pasting content. This is probably due to a spreadsheet version mismatch.")),i=e.model.dispatch("PASTE_FROM_OS_CLIPBOARD",{target:t,clipboardContent:{text:o.text},pasteOption:s})}lx(e,i)}const dx={Errors:{InvalidRange:Fo("The range is invalid"),FirstArgMissing:Fo("The argument is missing. Please provide a value"),SecondArgMissing:Fo("The second argument is missing. Please provide a value"),MinNaN:Fo("The minpoint must be a number"),MidNaN:Fo("The midpoint must be a number"),MaxNaN:Fo("The maxpoint must be a number"),ValueUpperInflectionNaN:Fo("The first value must be a number"),ValueLowerInflectionNaN:Fo("The second value must be a number"),MinBiggerThanMax:Fo("Minimum must be smaller then Maximum"),MinBiggerThanMid:Fo("Minimum must be smaller then Midpoint"),MidBiggerThanMax:Fo("Midpoint must be smaller then Maximum"),LowerBiggerThanUpper:Fo("Lower inflection point must be smaller than upper inflection point"),MinInvalidFormula:Fo("Invalid Minpoint formula"),MaxInvalidFormula:Fo("Invalid Maxpoint formula"),MidInvalidFormula:Fo("Invalid Midpoint formula"),ValueUpperInvalidFormula:Fo("Invalid upper inflection point formula"),ValueLowerInvalidFormula:Fo("Invalid lower inflection point formula"),EmptyRange:Fo("A range needs to be defined"),ValueCellIsInvalidFormula:Fo("At least one of the provided values is an invalid formula"),Unexpected:Fo("The rule is invalid for an unknown reason")},ColorScale:Fo("Color scale"),IconSet:Fo("Icon set"),DataBar:Fo("Data bar")},ux={IsEmpty:Fo("Is empty"),IsNotEmpty:Fo("Is not empty"),ContainsText:Fo("Contains"),NotContains:Fo("Does not contain"),BeginsWith:Fo("Starts with"),EndsWith:Fo("Ends with"),Equal:Fo("Is equal to"),NotEqual:Fo("Is not equal to"),GreaterThan:Fo("Is greater than"),GreaterThanOrEqual:Fo("Is greater than or equal to"),LessThan:Fo("Is less than"),LessThanOrEqual:Fo("Is less than or equal to"),Between:Fo("Is between"),NotBetween:Fo("Is not between")},gx={Series:Fo("Series"),BackgroundColor:Fo("Background color"),StackedBarChart:Fo("Stacked bar chart"),StackedLineChart:Fo("Stacked line chart"),StackedAreaChart:Fo("Stacked area chart"),StackedColumnChart:Fo("Stacked column chart"),CumulativeData:Fo("Cumulative data"),TreatLabelsAsText:Fo("Treat labels as text"),AggregatedChart:Fo("Aggregate"),Errors:{Unexpected:Fo("The chart definition is invalid for an unknown reason"),InvalidDataSet:Fo("The dataset is invalid"),InvalidLabelRange:Fo("Labels are invalid"),InvalidScorecardKeyValue:Fo("The key value is invalid"),InvalidScorecardBaseline:Fo("The baseline value is invalid"),InvalidGaugeDataRange:Fo("The data range is invalid"),EmptyGaugeRangeMin:Fo("A minimum range limit value is needed"),GaugeRangeMinNaN:Fo("The minimum range limit value must be a number"),EmptyGaugeRangeMax:Fo("A maximum range limit value is needed"),GaugeRangeMaxNaN:Fo("The maximum range limit value must be a number"),GaugeRangeMinBiggerThanRangeMax:Fo("Minimum range limit must be smaller than maximum range limit"),GaugeLowerInflectionPointNaN:Fo("The lower inflection point value must be a number"),GaugeUpperInflectionPointNaN:Fo("The upper inflection point value must be a number")},GeoChart:{ColorScales:{blues:Fo("Blues"),cividis:Fo("Cividis"),greens:Fo("Greens"),greys:Fo("Greys"),oranges:Fo("Oranges"),purples:Fo("Purples"),rainbow:Fo("Rainbow"),reds:Fo("Reds"),viridis:Fo("Viridis")}}},px={Custom:Fo("Custom")},mx=Fo("Merged cells are preventing this operation. Unmerge those cells and try again."),fx={Errors:{Unexpected:Fo("Cannot split the selection for an unknown reason"),NoSplitSeparatorInSelection:Fo("There is no match for the selected separator in the selection"),MoreThanOneColumnSelected:Fo("Only a selection from a single column can be split"),SplitWillOverwriteContent:Fo("Splitting will overwrite existing content")}},vx={Errors:{Unexpected:Fo("Cannot remove duplicates for an unknown reason"),MoreThanOneRangeSelected:Fo("Please select only one range of cells"),EmptyTarget:Fo("Please select a range of cells containing values."),NoColumnsProvided:Fo("Please select at latest one column to analyze."),WillRemoveExistingMerge:ax.willRemoveExistingMerge}},bx={DateIs:{today:Fo("today"),yesterday:Fo("yesterday"),tomorrow:Fo("tomorrow"),lastWeek:Fo("in the past week"),lastMonth:Fo("in the past month"),lastYear:Fo("in the past year")},DateIsBefore:{today:Fo("today"),yesterday:Fo("yesterday"),tomorrow:Fo("tomorrow"),lastWeek:Fo("one week ago"),lastMonth:Fo("one month ago"),lastYear:Fo("one year ago")},CriterionError:{notEmptyValue:Fo("The value must not be empty"),numberValue:Fo("The value must be a number"),dateValue:Fo("The value must be a date"),validRange:Fo("The value must be a valid range"),validFormula:Fo("The formula must be valid")},Errors:{InvalidRange:Fo("The range is invalid."),InvalidDataValidationCriterionValue:Fo("One or more of the provided criteria values are invalid. Please review and correct them."),InvalidNumberOfCriterionValues:Fo("One or more of the provided criteria values are missing."),Unexpected:Fo("The rule is invalid for an unknown reason.")}},Sx={Errors:{Unexpected:Fo("The table zone is invalid for an unknown reason"),TableOverlap:Fo("You cannot create overlapping tables."),NonContinuousTargets:Fo("A table can only be created on a continuous selection."),InvalidRange:Fo("The range is invalid"),TargetOutOfSheet:Fo("The range is out of the sheet")},Checkboxes:{hasFilters:Fo("Filter button"),headerRow:Fo("Header row(s)"),bandedRows:Fo("Banded rows"),firstColumn:Fo("First column"),lastColumn:Fo("Last column"),bandedColumns:Fo("Banded columns"),automaticAutofill:Fo("Automatically autofill formulas"),totalRow:Fo("Total row"),isDynamic:Fo("Auto-adjust to formula result")},Tooltips:{filterWithoutHeader:Fo("Cannot have filters without a header row"),isDynamic:Fo("For tables based on array formulas only")}},yx={labels:{no_calculations:Fo("No calculations"),"%_of_grand_total":Fo("% of grand total"),"%_of_col_total":Fo("% of column total"),"%_of_row_total":Fo("% of row total"),"%_of":Fo("% of"),"%_of_parent_row_total":Fo("% of parent row total"),"%_of_parent_col_total":Fo("% of parent column total"),"%_of_parent_total":Fo("% of parent total"),difference_from:Fo("Difference from"),"%_difference_from":Fo("% difference from"),running_total:Fo("Running total"),"%_running_total":Fo("% Running total"),rank_asc:Fo("Rank smallest to largest"),rank_desc:Fo("Rank largest to smallest"),index:Fo("Index")},descriptions:{"%_of_grand_total":()=>Fo("Displayed as % of grand total"),"%_of_col_total":()=>Fo("Displayed as % of column total"),"%_of_row_total":()=>Fo("Displayed as % of row total"),"%_of":e=>Fo('Displayed as % of "%s"',e),"%_of_parent_row_total":e=>Fo('Displayed as % of parent row total of "%s"',e),"%_of_parent_col_total":()=>Fo("Displayed as % of parent column total"),"%_of_parent_total":e=>Fo('Displayed as % of parent "%s" total',e),difference_from:e=>Fo('Displayed as difference from "%s"',e),"%_difference_from":e=>Fo('Displayed as % difference from "%s"',e),running_total:e=>Fo('Displayed as running total based on "%s"',e),"%_running_total":e=>Fo('Displayed as % running total based on "%s"',e),rank_asc:e=>Fo('Displayed as rank from smallest to largest based on "%s"',e),rank_desc:e=>Fo('Displayed as rank largest to smallest based on "%s"',e),index:()=>Fo("Displayed as index")},documentation:{no_calculations:Fo("Displays the value that is entered in the field."),"%_of_grand_total":Fo("Displays values as a percentage of the grand total of all the values or data points in the report."),"%_of_col_total":Fo("Displays all the values in each column or series as a percentage of the total for the column or series."),"%_of_row_total":Fo("Displays the value in each row or category as a percentage of the total for the row or category."),"%_of":Fo("Displays values as a percentage of the value of the Base item in the Base field."),"%_of_parent_row_total":Fo("Calculates values as follows:\n(value for the item) / (value for the parent item on rows)"),"%_of_parent_col_total":Fo("Calculates values as follows:\n(value for the item) / (value for the parent item on columns)"),"%_of_parent_total":Fo("Calculates values as follows:\n(value for the item) / (value for the parent item of the selected Base field)"),difference_from:Fo("Displays values as the difference from the value of the Base item in the Base field."),"%_difference_from":Fo("Displays values as the percentage difference from the value of the Base item in the Base field."),running_total:Fo("Displays the value for successive items in the Base field as a running total."),"%_running_total":Fo("Calculates the value as a percentage for successive items in the Base field that are displayed as a running total."),rank_asc:Fo("Displays the rank of selected values in a specific field, listing the smallest item in the field as 1, and each larger value with a higher rank value."),rank_desc:Fo("Displays the rank of selected values in a specific field, listing the largest item in the field as 1, and each smaller value with a higher rank value."),index:Fo("Calculates values as follows:\n((value in cell) x (Grand Total of Grand Totals)) / ((Grand Row Total) x (Grand Column Total))")}},Cx={second:1e3,minute:6e4,hour:36e5,day:864e5,month:2592e6,year:31536e6},wx={inSeconds:function(e){return Math.floor(e/Cx.second)},inMinutes:function(e){return Math.floor(e/Cx.minute)},inHours:function(e){return Math.floor(e/Cx.hour)},inDays:function(e){return Math.floor(e/Cx.day)},inMonths:function(e){return Math.floor(e/Cx.month)},inYears:function(e){return Math.floor(e/Cx.year)}},xx=/^((d|dd|m|mm|yyyy|yy|hh|h|ss|a)(-|:|\s|\/))*(d|dd|m|mm|yyyy|yy|hh|h|ss|a)$/i;function Ex(e,t,o){const s=function(e){const t=e.indexOf("h");e=t>=0?e.slice(0,t).replace(/m/g,"M")+e.slice(t):e.replace(/m/g,"M");e.includes("a")||(e=e.replace(/h/g,"H"));return e}(t),i=function(e,t,o){const s=e.map((e=>Us(e,o)?.jsDate));if(s.some((e=>void 0===e))||e.length<2)return;const i=s.map((e=>e.getTime())),n=Dt(i)-Ot(i),r=function(e){if(e.includes("s"))return"second";if(e.includes("m"))return"minute";if(e.includes("h")||e.includes("H"))return"hour";if(e.includes("d"))return"day";if(e.includes("M"))return"month";return"year"}(t);if(Cx.second>=Cx[r]&&wx.inSeconds(n)<180)return"second";if(Cx.minute>=Cx[r]&&wx.inMinutes(n)<180)return"minute";if(Cx.hour>=Cx[r]&&wx.inHours(n)<96)return"hour";if(Cx.day>=Cx[r]&&wx.inDays(n)<90)return"day";if(Cx.month>=Cx[r]&&wx.inMonths(n)<36)return"month";return"year"}(e,s,o),n={};return i&&(n[i]=s),{parser:s,displayFormats:n,unit:i??!1}}function Ix(e,t,o,s){let i=zx(s,t,o).formattedValues,n=Wx(s,t);e.dataSetsHaveTitle&&n[0]&&i.length>n[0].data.length&&i.shift(),({labels:i,dataSetsValues:n}=Hx(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Ux(i,n));const r=$x(s,t,"left"),a=$x(s,t,"right"),l=e.horizontal?{x:r||a}:{y:r,y1:a},c=[];for(const t in n){const{data:o}=n[t],s=e.dataSets?.[t].trend;if(!s?.display||e.horizontal){c.push(void 0);continue}const i=Ox(s,o);c.push(i)}return{dataSetsValues:n,trendDataSetsValues:c,axisFormats:l,labels:i,locale:s.getLocale()}}function Rx(e,t,o,s){const i=Ix(e,t,o,s),n=i.dataSetsValues,r=[];if(n[0]){const e=n[0].data.map((e=>e>0?e:0));r.push({...n[0],data:e})}if(n[1]){const e=n[1].data.map((e=>e>0?-e:0));r.push({...n[1],data:e})}return{...i,dataSetsValues:r}}function Tx(e,t,o,s){const i=function(e,t,o){if(function(e,t,o){return!e.labelsAsText&&Nx(t,o)}(e,t,o)&&function(){if(!window.Chart)return!1;const e="luxon"===new window.Chart._adapters._date({})._id;e||Lx||(Lx=!0,console.warn("'chartjs-adapter-luxon' time adapter is not installed. Time scale axes are disabled."));return e}())return"time";if(function(e,t,o){return!e.labelsAsText&&kx(t,o)}(e,t,o))return"linear";return"category"}(e,o,s),n=zx(s,t,o);let r="linear"===i?n.values:n.formattedValues,a=Wx(s,t);e.dataSetsHaveTitle&&a[0]&&r.length>a[0].data.length&&r.shift(),({labels:r,dataSetsValues:a}=Hx(r,a)),"time"===i&&({labels:r,dataSetsValues:a}=function(e,t){if(0===e.length||e.every((e=>!e)))return{labels:e,dataSetsValues:t};const o=[...e],s=Be(t);for(let e=0;e<o.length;e++)if(!o[e]){o[e]=gt(o,e);for(let t of s)t.data[e]=void 0}return{labels:o,dataSetsValues:s}}(r,a)),e.aggregated&&({labels:r,dataSetsValues:a}=Ux(r,a));const l={y:$x(s,t,"left"),y1:$x(s,t,"right"),x:Bx(s,o)},c=[];for(const t in a){let{data:o}=a[t];if(e.cumulative){let e=0;o=o.map((t=>isNaN(parseFloat(t))?t:(e+=parseFloat(t),e))),a[t]={...a[t],data:o}}const n=e.dataSets?.[t].trend;n?.display?c.push(Fx(n,o,r,i,s.getLocale())):c.push(void 0)}return{dataSetsValues:a,axisFormats:l,labels:r,locale:s.getLocale(),trendDataSetsValues:c,axisType:i}}function Ax(e,t,o,s){let i=zx(s,t,o).formattedValues,n=Wx(s,t);e.dataSetsHaveTitle&&n[0]&&i.length>n[0].data.length&&i.shift(),({labels:i,dataSetsValues:n}=Hx(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Ux(i,n)),({dataSetsValues:n,labels:i}=function(e,t){const o=Math.max(e.length,...t.map((e=>e.data?.length||0))),s=Ze(0,o).filter((e=>t.some((t=>"number"==typeof t.data[e]&&t.data[e]>0))));return{labels:s.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:s.map((t=>"number"==typeof e.data[t]&&e.data[t]>0?e.data[t]:null))})))}}(i,n));return{dataSetsValues:n,axisFormats:{y:$x(s,t,"left")},labels:i,locale:s.getLocale()}}function _x(e,t,o,s){let i=zx(s,t,o).formattedValues,n=Wx(s,t);e.dataSetsHaveTitle&&n[0]&&i.length>n[0].data.length&&i.shift(),({labels:i,dataSetsValues:n}=Hx(i,n)),e.aggregated&&({labels:i,dataSetsValues:n}=Ux(i,n));return{dataSetsValues:n,axisFormats:{r:$x(s,t,"left")||$x(s,t,"right")},labels:i,locale:s.getLocale()}}function Dx(e,t,o,s){let i=zx(s,t,o).formattedValues;e.dataSetsHaveTitle&&i.shift();let n=Wx(s,t);({labels:i,dataSetsValues:n}=Ux(i,n));return{dataSetsValues:n,axisFormats:{y:$x(s,t,"left")||$x(s,t,"right")},labels:i,locale:s.getLocale(),availableRegions:s.getGeoChartAvailableRegions(),geoFeatureNameToId:s.geoFeatureNameToId,getGeoJsonFeatures:s.getGeoJsonFeatures}}function Ox(e,t){const o=[],s=[],i=[];for(let e=0;e<t.length;e++)"number"==typeof t[e]&&(o.push(t[e]),s.push(e+1)),i.push(e+1);const n=Mx(e,o,s,Ze(.5,i.length+.55,.2));return n.length?n:void 0}function Fx(e,t,o,s,i){const n=[],r=[],a=[],l=t.length;if(l<2)return;switch(s){case"category":for(let e=0;e<l;e++)"number"==typeof t[e]&&(n.push(t[e]),r.push(e+1)),a.push(e+1);break;case"linear":for(let e=0;e<t.length;e++){const s=Number(o[e]);isNaN(s)||("number"==typeof t[e]&&(n.push(t[e]),r.push(s)),a.push(s))}break;case"time":for(let e=0;e<t.length;e++){const s=Vi({value:o[e]},i);null!==t[e]&&(n.push(t[e]),r.push(s)),a.push(s)}}const c=Math.min(...a),h=Math.max(...a);if(h===c)return;const d=(h-c)/(5*a.length),u=Mx(e,n,r,Ze(c,h+d/2,d));return u.length?u:void 0}function Mx(e,t,o,s){if(t.length<2||o.length<2||0===s.length)return[];const{normalizedLabels:i,normalizedNewLabels:n}=function(e,t,o){let s=[],i=[];if("logarithmic"===o.type){const o=Math.max(...e.map(Math.abs));s=e.map((e=>e/o)),i=t.map((e=>e/o))}else{const o=Math.max(...e),n=Math.min(...e),r=o-n;s=e.map((e=>(e-o)/r)),i=t.map((e=>(e-o)/r))}return{normalizedLabels:s,normalizedNewLabels:i}}(o,s,e);try{switch(e.type){case"polynomial":{const o=e.order;if(!o)return s.map((e=>({x:e,y:NaN})));if(1===o)return ul([t],[i],[n],!0)[0].map(((e,t)=>({x:s[t],y:e})));const r=al(t,i,o,!0).flat();return n.map(((e,t)=>({x:s[t],y:cl(r,e,o)})))}case"exponential":{const e=[],o=[];for(let s=0;s<t.length;s++)t[s]>0&&(e.push(Math.log(t[s])),o.push(i[s]));return o.length?hl(ul([e],[o],[n],!0))[0].map(((e,t)=>({x:s[t],y:e}))):s.map((e=>({x:e,y:NaN})))}case"logarithmic":return ul([t],dl([i]),dl([n]),!0)[0].map(((e,t)=>({x:s[t],y:e})));case"trailingMovingAverage":return function(e,t,o=Te){const s=[];for(let e=0;e<o-1;e++)s.push({x:t[e],y:NaN});for(let i=0;i<=e.length-o;i++){let n=0;for(let t=i;t<i+o;t++)n+=e[t];s.push({x:t[i+o-1],y:n/o})}return s}(t,o,e.window);default:return s.map((e=>({x:e,y:NaN})))}}catch(e){return s.map((e=>({x:e,y:NaN})))}}function Px(e,t){return Nx(e,t)||kx(e,t)}function Nx(e,t){if(!e||!kx(e,t))return!1;const o=Bx(t,e);return Boolean(o&&xx.test(o))}function kx(e,t){if(!e)return!1;const o=t.getRangeValues(e);return!o.some((e=>isNaN(Number(e))&&e))&&!o.every((e=>!e))}let Lx=!1;function Vx(e,t){if(t.dataRange){const o=t.labelCell?[t.labelCell.zone]:[],s=Co([t.dataRange.zone],o)[0];if(void 0===s)return[];const i=e.getRangeFromZone(t.dataRange.sheetId,s);return e.getRangeValues(i).map((e=>""===e?void 0:e))}return[]}function Hx(e,t){const o=Ze(0,Math.max(e.length,...t.map((e=>e.data?.length||0)))).filter((o=>{const s=e[o],i=t.map((e=>e.data?.[o]));return s||i.some((e=>"number"==typeof e))}));return{labels:o.map((t=>e[t]||"")),dataSetsValues:t.map((e=>({...e,data:o.map((t=>"number"==typeof e.data[t]?e.data[t]:null))})))}}function Ux(e,t){const o=new Set(e),s={};o.forEach((e=>{s[e]=new Array(t.length).fill(0)}));for(const o of Ze(0,e.length)){const n=e[o];for(const e of Ze(0,t.length))s[n][e]+="number"==typeof(i=t[e].data[o])?i:0}var i;return{labels:Array.from(o),dataSetsValues:t.map(((e,t)=>({...e,data:Array.from(o).map((e=>s[e][t]))})))}}function Bx(e,t){if(!t)return;const{sheetId:o,zone:{left:s,top:i,bottom:n}}=t;for(let t=i;t<=n;t++){const i=e.getEvaluatedCell({sheetId:o,col:s,row:t}).format;if(i)return i}}function zx(e,t,o){let s={values:[],formattedValues:[]};if(o){const{left:i}=o.zone;if(o.invalidXc||o.invalidSheetName||e.isColHidden(o.sheetId,i)){if(t[0]){s={formattedValues:Ze(0,Vx(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}}else s={formattedValues:e.getRangeFormattedValues(o),values:e.getRangeValues(o).map((e=>String(e??"")))}}else if(1===t.length)for(let o=0;o<Vx(e,t[0]).length;o++)s.formattedValues.push(""),s.values.push("");else if(t[0]){s={formattedValues:Ze(0,Vx(e,t[0]).length).map((e=>e.toString())),values:s.formattedValues}}return s}function $x(e,t,o){const s=t.filter((e=>"right"===o==!!e.rightYAxis));for(const t of s){const o=e.getRangeFormats(t.dataRange).find((e=>void 0!==e&&!rr(e)));if(o)return o}}function Wx(e,t){const o=[];for(const[s,i]of Object.entries(t)){if(e.isColHidden(i.dataRange.sheetId,i.dataRange.zone.left))continue;let t;if(i.labelCell){const o=i.labelCell,n=o?e.getEvaluatedCell({sheetId:o.sheetId,col:o.zone.left,row:o.zone.top}):void 0;t=n&&o?n.formattedValue:t=`${gx.Series} ${parseInt(s)+1}`}else t=`${gx.Series} ${parseInt(s)+1}`;let n=i.dataRange?Vx(e,i):[];if(n.every((e=>"string"==typeof e&&!ki(e)))&&n.some((e=>""!==e)))n.fill(1);else if(n.every((e=>null==e||!ti(e.toString(),Si))))continue;o.push({data:n,label:t})}return o}function Gx(e,t){const{dataSetsValues:o}=t,s=[],i=tE(e,o.length),n=[];for(const r in o){let{label:a,data:l}=o[r];a=e.dataSets?.[r].label||a;const c=i.next(),h={label:a,data:l,borderColor:e.background||m,borderWidth:e.stacked?1:0,backgroundColor:c,yAxisID:e.horizontal?"y":e.dataSets?.[r].yAxisId||"y",xAxisID:"x"};s.push(h);const d=e.dataSets?.[r].trend,u=t.trendDataSetsValues?.[r];d?.display&&!e.horizontal&&u&&n.push(Qx(h,d,u))}return s.push(...n),s}function qx(e,t){const{dataSetsValues:o,labels:s}=t,i=e.negativeValuesColor||T,n=e.positiveValuesColor||R,r=e.subTotalValuesColor||A,a=[],l=[],c={label:"",data:l,backgroundColor:a},h=[];let d=0;for(const t of o){for(let c=0;c<t.data.length;c++){const u=t.data[c];if(h.push(s[c]),isNaN(Number(u))){l.push([d,d]),a.push("");continue}l.push([d,u+d]);let g=u>=0?n:i;0===c&&t===o[0]&&e.firstValueAsSubtotal&&(g=r),a.push(g),d+=u}e.showSubTotals&&(h.push(Fo("Subtotal")),l.push([0,d]),a.push(r))}return{datasets:[c],labels:h}}function Zx(e,t){const{dataSetsValues:o,axisType:s,labels:i}=t,n=[],r=!!e.fillArea,a=!!e.stacked,l=[],c=tE(e,o.length);for(let h=0;h<o.length;h++){let{label:d,data:u}=o[h];d=e.dataSets?.[h].label||d;const g=c.next();s&&["linear","time"].includes(s)&&(u=u.map(((e,t)=>({x:i[t]||void 0,y:e}))));const p={label:d,data:u,tension:0,borderColor:g,backgroundColor:r?Jt(g,Re):g,pointBackgroundColor:g,fill:!!r&&eE(h,a),yAxisID:e.dataSets?.[h].yAxisId||"y"};n.push(p);const m=e.dataSets?.[h].trend,f=t.trendDataSetsValues?.[h];m?.display&&f&&l.push(Qx(p,m,f))}return n.push(...l),n}function jx(e,t){const o=Zx(e,t);for(const e of o)e.xAxisID!==Lc&&(e.showLine=!1);return o}function Yx(e,t){const{dataSetsValues:o}=t,s=[],i=Math.max(0,...o.map((e=>e?.data?.length??0))),n=sh(new ho(i),o);for(const{label:e,data:t}of o){const o={label:e,data:t,borderColor:m,backgroundColor:n,hoverOffset:30};s.push(o)}return s}function Xx(e,t){const{dataSetsValues:o}=t,s=[],i=tE(e,o.length),n=[];for(let r=0;r<o.length;r++){let{label:a,data:l}=o[r];a=e.dataSets?.[r].label||a;const c=e.dataSets?.[r],h=i.next(),d=c?.type??"line",u={label:a,data:l,borderColor:h,backgroundColor:h,yAxisID:e.dataSets?.[r].yAxisId||"y",xAxisID:"x",type:d,order:"bar"===d?o.length+r:r};s.push(u);const g=e.dataSets?.[r].trend,p=t.trendDataSetsValues?.[r];g?.display&&p&&n.push(Qx(u,g,p))}return s.push(...n),s}function Kx(e,t){const{dataSetsValues:o}=t,s=[],i=e.fillArea??!1,n=tE(e,o.length);for(let t=0;t<o.length;t++){let{label:r,data:a}=o[t];e.dataSets?.[t]?.label&&(r=e.dataSets[t].label);const l=n.next(),c={label:r,data:a,borderColor:l,backgroundColor:l};i&&(c.backgroundColor=Jt(l,Re),c.fill="start"),s.push(c)}return s}function Jx(e,t){const{availableRegions:o,dataSetsValues:s,labels:i}=t,n=e.region||o[0]?.id,r=n?t.getGeoJsonFeatures(n):void 0,a={outline:r,showOutline:!!r,data:[]};if(r&&n){const e={};if(s[0])for(let o=0;o<s[0].data.length;o++){if(!i[o]||void 0===s[0].data[o])continue;const r=t.geoFeatureNameToId(n,i[o]);r&&(e[r]={value:s[0].data[o],label:i[o]})}for(const t of r)t.id&&a.data.push({feature:{...t,properties:{name:e[t.id]?.label}},value:e[t.id]?.value})}return[a]}function Qx(e,t,o){const s=Zt(e.backgroundColor);s.a=1;const i=t.color||Qt(qt(s),.5);return{type:"line",xAxisID:Lc,yAxisID:e.yAxisID,label:e.label?Fo("Trend line for %s",e.label):"",data:o,order:-1,showLine:!0,pointRadius:0,backgroundColor:i,borderColor:i,borderDash:[5,5],borderWidth:void 0,fill:!1,pointBackgroundColor:i}}function eE(e,t){return t?0===e?"origin":"-1":"origin"}function tE(e,t){return new ho(t,e.dataSets?.map((e=>e.backgroundColor))||[])}function oE(e){return{padding:{left:Z,right:Z,top:Y,bottom:j}}}function sE(e,t){return{display:"none"!==e.legendPosition,position:"none"!==e.legendPosition?e.legendPosition:void 0}}function iE(e,t){return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:"rect",lineWidth:3})}}function nE(e,t){const o=e.fillArea,s=o?"rect":"line",i=o?2:3;return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:s,lineWidth:i})}}function rE(e,t){const{dataSetsValues:o}=t,s=Math.max(0,...o.map((e=>e?.data?.length??0))),i=sh(new ho(s),o);return{...sE(e),labels:{color:Zc(e.background),usePointStyle:!0,generateLabels:e=>e.data.labels.map(((e,t)=>({text:ih(String(e)),strokeStyle:i[t],fillStyle:i[t],pointStyle:"rect",hidden:!1,lineWidth:2})))}}}function aE(e,t){return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:"circle",strokeStyle:e.background||"#ffffff",lineWidth:8})}}function lE(e,t){return{...dE,...sE(e),...uE(Zc(e.background),{lineWidth:3})}}function cE(e,t){const o=Zc(e.background),s=e.negativeValuesColor||T,i=e.positiveValuesColor||R,n=e.subTotalValuesColor||A;return{...sE(e),labels:{usePointStyle:!0,generateLabels:()=>{const t=[{text:Fo("Positive values"),fontColor:o,fillStyle:i,strokeStyle:i,pointStyle:"rect"},{text:Fo("Negative values"),fontColor:o,fillStyle:s,strokeStyle:s,pointStyle:"rect"}];return(e.showSubTotals||e.firstValueAsSubtotal)&&t.push({text:Fo("Subtotals"),fontColor:o,fillStyle:n,strokeStyle:n,pointStyle:"rect"}),t}},onClick:()=>{}}}function hE(e,t){const o=e.fillArea??!1,s=o?"rect":"line",i=o?2:3;return{...dE,...sE(e),...uE(Zc(e.background),{pointStyle:s,lineWidth:i})}}const dE={onHover:e=>{const t=e.native?.target;t&&(t.style.cursor="pointer")},onLeave:e=>{const t=e.native?.target;t&&(t.style.cursor="default")},onClick:(e,t,o)=>{const s=t.datasetIndex;o.legendItems&&void 0!==s&&(o.chart.isDatasetVisible(s)?o.chart.hide(s):o.chart.show(s),e.native.preventDefault(),e.native.stopPropagation())}};function uE(e,t){return{labels:{color:e,usePointStyle:!0,generateLabels:o=>o.data.datasets.map(((s,i)=>s.xAxisID===Lc?{text:ih(s.label),fontColor:e,strokeStyle:s.borderColor,hidden:!o.isDatasetVisible(i),pointStyle:"line",datasetIndex:i,lineWidth:3}:{text:ih(s.label),fontColor:e,strokeStyle:s.borderColor,fillStyle:s.backgroundColor,hidden:!o.isDatasetVisible(i),pointStyle:"line"===s.type?"line":"rect",datasetIndex:i,...t}))}}}function gE(e,t){let o={};const{trendDataSetsValues:s,locale:i,axisFormats:n}=t,r={stacked:e.stacked,locale:i};if(e.horizontal)o.x=wE(e,"bottom","values",{...r,format:n?.x}),o.y=wE(e,"left","labels",r);else{o.x=wE(e,"bottom","labels",r);const t={...r,format:n?.y};o.y=wE(e,"left","values",t);const s={...r,format:n?.y1};o.y1=wE(e,"right","values",s)}if(o=bt(o),s&&s.length&&s.some(at)){const e=Math.max(...s.map((e=>e?.length||0)));o[Lc]={...o.x,labels:Array(e).fill(""),offset:!1,display:!1}}return o}function pE(e,t){const{locale:o,axisType:s,trendDataSetsValues:i,labels:n,axisFormats:r}=t,a=r?.x,l=e.stacked;let c={x:wE(e,"bottom","labels",{locale:o}),y:wE(e,"left","values",{locale:o,stacked:l,format:r?.y}),y1:wE(e,"right","values",{locale:o,stacked:l,format:r?.y1})};if(c=bt(c),"time"===s&&n&&a){const e={type:"time",time:Ex(n,a,o)};Object.assign(c.x,e),c.x.ticks.maxTicksLimit=15}else"linear"===s&&(c.x.type="linear",c.x.ticks.callback=e=>Jn(e,{format:a,locale:o}));if(i&&i.length&&i.some(at)&&(c[Lc]={...c.x,display:!1},"category"===s||"time"===s)){const e=Math.max(...i.map((e=>e?.length||0)));c[Lc].type="category",c[Lc].labels=Ze(0,e).map((e=>e.toString())),c[Lc].offset=!1}return c}function mE(e,t){const o=pE(e,t);return{...o,x:{...o.x,grid:{display:!0}}}}function fE(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;e.dataSets;const n={x:{...wE(e,"bottom","labels",{locale:o}),grid:{display:!1}},y:{position:e.verticalAxisPosition,ticks:{color:Zc(e.background),callback:th({locale:o,format:i})},grid:{lineWidth:e=>0===e.tick.value?2:1},title:CE(e.axesDesign?.y)}},r=n?.y||n?.y1;return r&&(r.grid={lineWidth:e=>0===e.tick.value?2:1}),n}function vE(e,t){const{dataSetsValues:o}=t,s=gE(e,t),i=s.x.ticks.callback;s.x.ticks.callback=e=>i(Math.abs(e));const n=Math.max(...o.map((e=>Math.max(...e.data.map(Math.abs)))));return s.x.suggestedMin=-n,s.x.suggestedMax=n,s}function bE(e,t){const{locale:o,axisFormats:s,dataSetsValues:i}=t,n=Math.min(...i.map((e=>Math.min(...e.data.filter((e=>!isNaN(e)))))));return{r:{beginAtZero:!0,ticks:{callback:th({format:s?.r,locale:o}),backdropColor:e.background||"#FFFFFF"},pointLabels:{color:Zc(e.background),callback:ih},suggestedMin:n<0?n-1:0}}}function SE(e,t){const{locale:o,axisFormats:s,availableRegions:i}=t,n=function(e){switch(e){case"top":return"top-left";case"right":return"top-right";case"bottom":return"bottom-right";case"left":case"none":return"bottom-left"}}(e.legendPosition),r=e.region?i.find((t=>t.id===e.region)):i[0],a=s?.y||s?.y1;return{projection:{projection:yE(r?.defaultProjection||"mercator"),axis:"x"},color:{axis:"x",display:"none"!==e.legendPosition,border:{color:D},grid:{color:D},ticks:{color:Zc(e.background),callback:th({locale:o,format:a})},legend:{position:n,align:n.includes("right")?"left":"right",margin:EE(e)},interpolate:xE(e),missing:e.missingValueColor||"#ffffff"}}}function yE(e){return"conicConformal"===e?window.ChartGeo.geoConicConformal().rotate([100,0]):e}function CE(e){if(e?.title?.text){const{text:t,color:o,align:s,italic:i,bold:n}=e.title;return{display:!0,text:t,color:o,font:{style:i?"italic":"normal",weight:n?"bold":"normal",size:e.title.fontSize??K},align:"left"===s?"start":"right"===s?"end":"center"}}}function wE(e,t,o,s){const{useLeftAxis:i,useRightAxis:n}=Qc(e);if("left"===t&&!i||"right"===t&&!n)return;const r=Zc(e.background);let a;if(a="bottom"===t?e.axesDesign?.x:"left"===t?e.axesDesign?.y:e.axesDesign?.y1,"values"===o){const e=!("right"===t&&i);return{position:t,title:CE(a),grid:{display:e},beginAtZero:!0,stacked:s?.stacked,ticks:{color:r,callback:th(s)}}}return{ticks:{padding:5,color:r,callback:function(e){return ih(this.getLabelForValue(e))}},grid:{display:!1},stacked:s?.stacked,title:CE(a)}}function xE(e){if(!e.colorScale||"string"==typeof e.colorScale)return e.colorScale||"oranges";const t=[{value:0,color:e.colorScale.minColor}];return e.colorScale.midColor&&t.push({value:.5,color:e.colorScale.midColor}),t.push({value:1,color:e.colorScale.maxColor}),go(t)}function EE(e){switch(e.legendPosition){case"top":case"right":return{top:!!e.title.text?Y+30:Y,left:Z,right:Z};case"bottom":case"left":case"none":return{left:Z,right:Z,bottom:j}}}function IE(e,t){const{axisFormats:o,locale:s}=t;return{horizontal:"horizontal"in e&&e.horizontal,showValues:"showValues"in e&&!!e.showValues,background:e.background,callback:eh(o,s)}}function RE(e){const t=e.title,o=jc(e.background);return{display:!!t.text,text:Fo(t.text),color:t?.color??o,align:"center"===t.align?"center":"right"===t.align?"end":"start",font:{size:e.title.fontSize??X,weight:t.bold?"bold":"normal",style:t.italic?"italic":"normal"},padding:{bottom:"top"===e.legendPosition?0:Z}}}const TE='\n<templates>\n <t t-name="o-spreadsheet-CustomTooltip">\n <div\n class="o-chart-custom-tooltip border rounded px-2 py-1 pe-none mw-100 position-absolute text-nowrap shadow opacity-100">\n <table class="overflow-hidden m-0">\n <thead>\n <tr>\n <th class="o-tooltip-title align-baseline border-0 text-truncate" t-esc="title" t-attf-style="max-width: {{ labelsMaxWidth }}"/>\n </tr>\n </thead>\n <tbody>\n <tr t-foreach="tooltipItems" t-as="tooltipItem" t-key="tooltipItem_index">\n <td>\n <span\n class="badge ps-2 py-2 rounded-0 align-middle"\n t-attf-style="background-color: {{ tooltipItem.boxColor }}"\n > </span>\n <small\n t-if="tooltipItem.label"\n class="o-tooltip-label d-inline-block text-truncate align-middle smaller ms-2"\n t-esc="tooltipItem.label"\n t-attf-style="max-width: {{ labelsMaxWidth }}"\n />\n </td>\n <td class="o-tooltip-value ps-2 fw-bolder text-end">\n <small class="smaller d-inline-block text-truncate align-middle" t-attf-style="max-width: {{ valuesMaxWidth }}">\n <t t-esc="tooltipItem.value"/>\n <t t-if="tooltipItem.percentage">\n (\n <t t-esc="tooltipItem.percentage"/>\n %)\n </t>\n </small>\n </td>\n </tr>\n </tbody>\n </table>\n </div>\n </t>\n</templates>\n';let AE;function _E(e,o={}){return function(e,o={}){AE||(AE=new t.App(t.Component,{templates:TE,translateFn:Fo}));const s=AE.getTemplate(e),i=s(o,{}),n=document.createElement("div");return t.blockDom.mount(i,n),n}(e,o).innerHTML}function DE(e,t){return{enabled:!1,external:LE,callbacks:{title:function(e){return e.some((e=>e.dataset.xAxisID!==Lc))?void 0:""},label:function(o){const s=o.dataset?.label||o.label,i=e.horizontal;let n=i?o.parsed.x:o.parsed.y;null==n&&(n=o.parsed);const r=i?o.dataset.xAxisID:o.dataset.yAxisID,a=eh(t.axisFormats,t.locale)(n,r);return s?`${s}: ${a}`:a}}}}function OE(e,t){const{axisType:o,locale:s,axisFormats:i}=t,n=i?.x,r={enabled:!1,external:LE,callbacks:{}};return r.callbacks.label="linear"===o?e=>{const t=e.parsed.y;let o=e.dataset.xAxisID===Lc?"":e.parsed.x;"string"==typeof o&&ti(o,s)&&(o=Vi(o,s));const r=Jn(o,{locale:s,format:n}),a=e.dataset.yAxisID||"y",l=Jn(t,{locale:s,format:i?.[a]}),c=e.dataset.label;return r?`${c}: (${r}, ${l})`:`${c}: ${l}`}:function(e){const t=e.dataset?.label||e.label,o=e.parsed.y,n=e.dataset.yAxisID,r=eh(i,s)(o,n);return t?`${t}: ${r}`:r},r.callbacks.title=function(e){return"linear"!==o&&e.some((e=>e.dataset.xAxisID!==Lc))?void 0:""},r}function FE(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{enabled:!1,external:LE,callbacks:{title:function(e){return e[0].dataset.label},label:function(e){const t=function(e,t){const o=e.filter((e=>"number"==typeof e)).reduce(((e,t)=>e+t),0);if(!o)return"";const s=e[t]/o*100;return s.toFixed(2)}(e.dataset.data,e.dataIndex),s=e.label||e.dataset.label,n=e.parsed.y??e.parsed,r=Jn(n,{format:!i&&n>=1e3?"#,##":i,locale:o});return s?`${s}: ${r} (${t}%)`:`${r} (${t}%)`}}}}function ME(e,t){const{dataSetsValues:o,locale:s,axisFormats:i,labels:n}=t,r=i?.y||i?.y1,a=o.map((e=>e.label));return{enabled:!1,external:LE,callbacks:{label:function(e){const[t,o]=e.raw,i=o-t,l=n.length?Math.floor(e.dataIndex/n.length):0,c=a[l],h=Jn(i,{format:!r&&Math.abs(i)>1e3?"#,##":r,locale:s});return c?`${c}: ${h}`:h}}}}function PE(e,t){const o=DE(e,t);return{...o,callbacks:{...o.callbacks,label:e=>{const t={...e,parsed:{y:e.parsed.y,x:Math.abs(e.parsed.x)}};return(o?.callbacks?.label)(t)}}}}function NE(e,t){const{locale:o,axisFormats:s}=t;return{enabled:!1,external:LE,callbacks:{label:function(e){const t=e.dataset?.label||e.label,i=Jn(e.parsed.r,{format:s?.r,locale:o});return t?`${t}: ${i}`:i}}}}function kE(e,t){const{locale:o,axisFormats:s}=t,i=s?.y||s?.y1;return{filter:function(e){return void 0!==e.raw.value},callbacks:{label:function(e){const t=e.raw,s=t.feature.properties.name,n=t.value,r=Jn(n,{format:!i&&Math.abs(n)>=1e3?"#,##":i,locale:o});return s?`${s}: ${r}`:r}}}}function LE({chart:e,tooltip:t}){if(e.canvas.parentNode.querySelector("div.o-chart-custom-tooltip")?.remove(),0===t.opacity||0===t.dataPoints.length)return;const o=t.body.map(((e,o)=>{let[s,i]=e.lines[0].split(":").map((e=>e.trim()));i||(i=s,s="");const n=t.labelColors[o].backgroundColor;return{label:s,value:i,boxColor:"string"==typeof n?Jt(n,1):n}})),s=_E("o-spreadsheet-CustomTooltip",{labelsMaxWidth:Math.floor(.5*e.canvas.clientWidth)+"px",valuesMaxWidth:Math.floor(.25*e.canvas.clientWidth)+"px",title:t.title[0],tooltipItems:o}),i=Object.assign(document.createElement("template"),{innerHTML:s}).content.firstChild;e.canvas.parentNode?.appendChild(i),Object.assign(i.style,{left:VE(e,t,i.clientWidth)+"px",top:Math.floor(t.caretY-i.clientHeight/2)+"px"})}function VE(e,t,o){const s=t.caretX;return s+o>e.chartArea.right?Math.max(0,s-o):s}var HE=Object.freeze({__proto__:null,INTERACTIVE_LEGEND_CONFIG:dE,canChartParseLabels:Px,getBarChartData:Ix,getBarChartDatasets:Gx,getBarChartLegend:iE,getBarChartScales:gE,getBarChartTooltip:DE,getChartColorsGenerator:tE,getChartLabelFormat:Bx,getChartLayout:oE,getChartShowValues:IE,getChartTitle:RE,getComboChartDatasets:Xx,getComboChartLegend:lE,getData:Vx,getGeoChartData:Dx,getGeoChartDatasets:Jx,getGeoChartScales:SE,getGeoChartTooltip:kE,getLineChartData:Tx,getLineChartDatasets:Zx,getLineChartLegend:nE,getLineChartScales:pE,getLineChartTooltip:OE,getPieChartData:Ax,getPieChartDatasets:Yx,getPieChartLegend:rE,getPieChartTooltip:FE,getPyramidChartData:Rx,getPyramidChartScales:vE,getPyramidChartTooltip:PE,getRadarChartData:_x,getRadarChartDatasets:Kx,getRadarChartLegend:hE,getRadarChartScales:bE,getRadarChartTooltip:NE,getScatterChartDatasets:jx,getScatterChartLegend:aE,getScatterChartScales:mE,getTrendDatasetForBarChart:Ox,getTrendDatasetForLineChart:Fx,getWaterfallChartLegend:cE,getWaterfallChartScales:fE,getWaterfallChartTooltip:ME,getWaterfallDatasetAndLabels:qx});class UE extends dh{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="bar";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.horizontal=e.horizontal,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"bar",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,showValues:e.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new UE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new UE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"bar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:this.horizontal,showValues:this.showValues}}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new UE(i,this.sheetId,this.getters)}}function BE(e,t){const o=e.getDefinition(),s=Ix(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Gx(o,s)},options:{...YS,indexAxis:e.horizontal?"y":"x",layout:oE(),scales:gE(o,s),plugins:{title:RE(o),legend:iE(o),tooltip:DE(o,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}}class zE extends dh{dataSets;labelRange;background;legendPosition;aggregated;dataSetsHaveTitle;dataSetDesign;axesDesign;type="combo";showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId),type:this.dataSetDesign?.[t]?.type??(t?"line":"bar")});return{type:"combo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues}}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new zE(i,this.sheetId,this.getters)}static getDefinitionFromContextCreation(e){const t=(e.range??[]).map(((e,t)=>({...e,type:t?"line":"bar"})));return{background:e.background,dataSets:t,dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated,legendPosition:e.legendPosition??"top",title:e.title||{text:""},labelRange:e.auxiliaryRange||void 0,type:"combo",axesDesign:e.axesDesign,showValues:e.showValues}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new zE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new zE(t,e,this.getters)}}function $E(e){return e.dataRange&&!Uo.test(e.dataRange)?"InvalidGaugeDataRange":"Success"}function WE(e,t){return t((t=>t.sectionRule?e(t.sectionRule.rangeMin,"rangeMin"):"Success"),(t=>t.sectionRule?e(t.sectionRule.rangeMax,"rangeMax"):"Success"))}function GE(e){return e.sectionRule&&Number(e.sectionRule.rangeMin)>=Number(e.sectionRule.rangeMax)?"GaugeRangeMinBiggerThanRangeMax":"Success"}function qE(e,t){if(""===e)switch(t){case"rangeMin":return"EmptyGaugeRangeMin";case"rangeMax":return"EmptyGaugeRangeMax"}return"Success"}function ZE(e,t){if(isNaN(e))switch(t){case"rangeMin":return"GaugeRangeMinNaN";case"rangeMax":return"GaugeRangeMaxNaN";case"lowerInflectionPointValue":return"GaugeLowerInflectionPointNaN";case"upperInflectionPointValue":return"GaugeUpperInflectionPointNaN"}return"Success"}class jE extends dh{dataRange;sectionRule;background;type="gauge";constructor(e,t,o){super(e,t,o),this.dataRange=Vr(this.getters,this.sheetId,e.dataRange),this.sectionRule=e.sectionRule,this.background=e.background}static validateChartDefinition(e,t){return e.checkValidations(t,$E,e.chainValidations(WE(qE,e.batchValidations),WE(ZE,e.batchValidations),GE),e.chainValidations((o=ZE,(0,e.batchValidations)((e=>e.sectionRule?o(e.sectionRule.lowerInflectionPoint.value,"lowerInflectionPointValue"):"Success"),(e=>e.sectionRule?o(e.sectionRule.upperInflectionPoint.value,"upperInflectionPointValue"):"Success")))));var o}static transformDefinition(e,t){let o;return e.dataRange&&(o=gc(jo(e.dataRange),t)),{...e,dataRange:o?Jo(o):void 0}}static getDefinitionFromContextCreation(e){return{background:e.background,title:e.title||{text:""},type:"gauge",dataRange:e.range?e.range[0].dataRange:void 0,sectionRule:{colors:{lowerColor:"#EA6175",middleColor:"#FFD86D",upperColor:"#43C5B1"},rangeMin:"0",rangeMax:"100",lowerInflectionPoint:{type:"percentage",value:"15",operator:"<="},upperInflectionPoint:{type:"percentage",value:"40",operator:"<="}}}}duplicateInDuplicatedSheet(e){const t=Uc(this.sheetId,e,this.dataRange),o=this.getDefinitionWithSpecificRanges(t,e);return new jE(o,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificRanges(this.dataRange,e);return new jE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.dataRange)}getDefinitionWithSpecificRanges(e,t){return{background:this.background,sectionRule:this.sectionRule,title:this.title,type:"gauge",dataRange:e?this.getters.getRangeString(e,t||this.sheetId):void 0}}getDefinitionForExcel(){}getContextCreation(){return{...this,range:this.dataRange?[{dataRange:this.getters.getRangeString(this.dataRange,this.sheetId)}]:void 0}}updateRanges(e){const t=Bc(this.dataRange,e);if(this.dataRange===t)return this;const o=this.getDefinitionWithSpecificRanges(t);return new jE(o,this.sheetId,this.getters)}}function YE(e,t){const o=t.getLocale(),s=e.sectionRule.colors;let i,n,r;const a=e.dataRange;if(void 0!==a){const e=t.getEvaluatedCell({sheetId:a.sheetId,col:a.zone.left,row:a.zone.top});e.type===ni.number&&(i=e.value,n=e.formattedValue,r=e.format)}const l=Number(e.sectionRule.rangeMin),c=Number(e.sectionRule.rangeMax),h=e.sectionRule.lowerInflectionPoint,d=e.sectionRule.upperInflectionPoint,u=XE(h,l,c),g=XE(d,l,c),p=[],m=[];return void 0!==u&&(p.push({value:u,label:Jn(u,{locale:o,format:r}),operator:h.operator}),m.push(s.lowerColor)),void 0!==g&&g!==u&&(p.push({value:g,label:Jn(g,{locale:o,format:r}),operator:d.operator}),m.push(s.middleColor)),void 0!==g&&void 0!==u&&u>g&&(p.reverse(),m.reverse()),m.push(s.upperColor),{background:t.getStyleOfSingleCellChart(e.background,a).background,title:{...e.title,text:Fo(e.title.text??"")},minValue:{value:l,label:Jn(l,{locale:o,format:r})},maxValue:{value:c,label:Jn(c,{locale:o,format:r})},gaugeValue:void 0!==i&&n?{value:i,label:n}:void 0,inflectionValues:p,colors:m}}function XE(e,t,o){if(""===e.value||isNaN(Number(e.value)))return;const s=Number(e.value);return qe("number"===e.type?s:t+(o-t)*s/100,t,o)}class KE extends dh{dataSets;labelRange;background;legendPosition;type="geo";dataSetsHaveTitle;dataSetDesign;colorScale;missingValueColor;region;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.colorScale=e.colorScale,this.missingValueColor=e.missingValueColor,this.region=e.region}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"geo",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new KE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new KE(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"geo",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,colorScale:this.colorScale,missingValueColor:this.missingValueColor,region:this.region}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new KE(i,this.sheetId,this.getters)}}class JE extends dh{dataSets;labelRange;background;legendPosition;labelsAsText;stacked;aggregated;type="line";dataSetsHaveTitle;cumulative;dataSetDesign;axesDesign;fillArea;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.cumulative=e.cumulative,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.fillArea=e.fillArea,this.showValues=e.showValues}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static transformDefinition(e,t){return qc(e,t)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"line",labelRange:e.auxiliaryRange||void 0,stacked:e.stacked??!1,aggregated:e.aggregated??!1,cumulative:e.cumulative??!1,axesDesign:e.axesDesign,fillArea:e.fillArea,showValues:e.showValues}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"line",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,stacked:this.stacked,aggregated:this.aggregated,cumulative:this.cumulative,axesDesign:this.axesDesign,fillArea:this.fillArea,showValues:this.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new JE(i,this.sheetId,this.getters)}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new JE(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new JE(t,e,this.getters)}}function QE(e,t){const o=e.getDefinition(),s=Tx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:Zx(o,s)},options:{...YS,layout:oE(),scales:pE(o,s),plugins:{title:RE(o),legend:nE(o),tooltip:OE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}}class eI extends dh{dataSets;labelRange;background;legendPosition;type="pie";aggregated;dataSetsHaveTitle;isDoughnut;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.isDoughnut=e.isDoughnut,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pie",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,isDoughnut:!1,showValues:e.showValues}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getContextCreation(){return{...this,range:this.dataSets.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,this.sheetId)}))),auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}getDefinitionWithSpecificDataSets(e,t,o){return{type:"pie",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:e.map((e=>({dataRange:this.getters.getRangeString(e.dataRange,o||this.sheetId)}))),legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,isDoughnut:this.isDoughnut,showValues:this.showValues}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new eI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new eI(t,e,this.getters)}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new eI(i,this.sheetId,this.getters)}}function tI(e,t){const o=e.getDefinition(),s=Ax(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:e.isDoughnut?"doughnut":"pie",data:{labels:s.labels,datasets:Yx(0,s)},options:{...YS,layout:oE(),plugins:{title:RE(o),legend:rE(o,s),tooltip:FE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}}class oI extends dh{dataSets;labelRange;background;legendPosition;aggregated;type="pyramid";dataSetsHaveTitle;dataSetDesign;axesDesign;horizontal=!0;stacked=!0;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle).slice(0,2),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"pyramid",labelRange:e.auxiliaryRange||void 0,axesDesign:e.axesDesign,horizontal:!0,stacked:!0,showValues:e.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new oI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new oI(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"pyramid",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,axesDesign:this.axesDesign,horizontal:!0,stacked:!0,showValues:this.showValues}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new oI(i,this.sheetId,this.getters)}}class sI extends dh{dataSets;labelRange;background;legendPosition;stacked;aggregated;type="radar";dataSetsHaveTitle;dataSetDesign;fillArea;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.stacked=e.stacked,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.fillArea=e.fillArea,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,stacked:e.stacked??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"radar",labelRange:e.auxiliaryRange||void 0,fillArea:e.fillArea??!1,showValues:e.showValues??!1}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new sI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new sI(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"radar",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,stacked:this.stacked,aggregated:this.aggregated,fillArea:this.fillArea,showValues:this.showValues}}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range&&e.range!==Ii.InvalidReference)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle));return{...this.getDefinition(),backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new sI(i,this.sheetId,this.getters)}}class iI extends dh{dataSets;labelRange;background;legendPosition;labelsAsText;aggregated;type="scatter";dataSetsHaveTitle;dataSetDesign;axesDesign;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(this.getters,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(this.getters,t,e.labelRange),this.background=e.background,this.legendPosition=e.legendPosition,this.labelsAsText=e.labelsAsText,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static transformDefinition(e,t){return qc(e,t)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range??[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,labelsAsText:e.labelsAsText??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"scatter",labelRange:e.auxiliaryRange||void 0,aggregated:e.aggregated??!1,axesDesign:e.axesDesign,showValues:e.showValues}}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"scatter",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,labelsAsText:this.labelsAsText,aggregated:this.aggregated,axesDesign:this.axesDesign,showValues:this.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new iI(i,this.sheetId,this.getters)}getDefinitionForExcel(){if(this.aggregated)return;const e=this.dataSets.map((e=>Wc(this.getters,e))).filter((e=>""!==e.range)),t=Gc(this.getters,this.labelRange,Kc(this.labelRange,this.dataSets[0],this.dataSetsHaveTitle)),o=this.getDefinition();return{...o,backgroundColor:jS(this.background||m),fontColor:jS(Zc(this.background)),dataSets:e,labelRange:t,verticalAxis:Qc(o)}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new iI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new iI(t,e,this.getters)}}class nI extends dh{dataSets;labelRange;background;verticalAxisPosition;legendPosition;aggregated;type="waterfall";dataSetsHaveTitle;showSubTotals;firstValueAsSubtotal;showConnectorLines;positiveValuesColor;negativeValuesColor;subTotalValuesColor;dataSetDesign;axesDesign;showValues;constructor(e,t,o){super(e,t,o),this.dataSets=zc(o,e.dataSets,t,e.dataSetsHaveTitle),this.labelRange=Vr(o,t,e.labelRange),this.background=e.background,this.verticalAxisPosition=e.verticalAxisPosition,this.legendPosition=e.legendPosition,this.aggregated=e.aggregated,this.dataSetsHaveTitle=e.dataSetsHaveTitle,this.showSubTotals=e.showSubTotals,this.showConnectorLines=e.showConnectorLines,this.positiveValuesColor=e.positiveValuesColor,this.negativeValuesColor=e.negativeValuesColor,this.subTotalValuesColor=e.subTotalValuesColor,this.firstValueAsSubtotal=e.firstValueAsSubtotal,this.dataSetDesign=e.dataSets,this.axesDesign=e.axesDesign,this.showValues=e.showValues}static transformDefinition(e,t){return qc(e,t)}static validateChartDefinition(e,t){return e.checkValidations(t,Yc,Xc)}static getDefinitionFromContextCreation(e){return{background:e.background,dataSets:e.range?e.range:[],dataSetsHaveTitle:e.dataSetsHaveTitle??!1,aggregated:e.aggregated??!1,legendPosition:e.legendPosition??"top",title:e.title||{text:""},type:"waterfall",verticalAxisPosition:"left",labelRange:e.auxiliaryRange||void 0,showSubTotals:e.showSubTotals??!1,showConnectorLines:e.showConnectorLines??!0,firstValueAsSubtotal:e.firstValueAsSubtotal??!1,axesDesign:e.axesDesign,showValues:e.showValues}}getContextCreation(){const e=[];for(const[t,o]of this.dataSets.entries())e.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(o.dataRange,this.sheetId)});return{...this,range:e,auxiliaryRange:this.labelRange?this.getters.getRangeString(this.labelRange,this.sheetId):void 0}}duplicateInDuplicatedSheet(e){const t=Hc(this.sheetId,e,this.dataSets),o=Uc(this.sheetId,e,this.labelRange),s=this.getDefinitionWithSpecificDataSets(t,o,e);return new nI(s,e,this.getters)}copyInSheetId(e){const t=this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange,e);return new nI(t,e,this.getters)}getDefinition(){return this.getDefinitionWithSpecificDataSets(this.dataSets,this.labelRange)}getDefinitionWithSpecificDataSets(e,t,o){const s=[];for(const[t,i]of e.entries())s.push({...this.dataSetDesign?.[t],dataRange:this.getters.getRangeString(i.dataRange,o||this.sheetId)});return{type:"waterfall",dataSetsHaveTitle:!!e.length&&Boolean(e[0].labelCell),background:this.background,dataSets:s,legendPosition:this.legendPosition,verticalAxisPosition:this.verticalAxisPosition,labelRange:t?this.getters.getRangeString(t,o||this.sheetId):void 0,title:this.title,aggregated:this.aggregated,showSubTotals:this.showSubTotals,showConnectorLines:this.showConnectorLines,positiveValuesColor:this.positiveValuesColor,negativeValuesColor:this.negativeValuesColor,subTotalValuesColor:this.subTotalValuesColor,firstValueAsSubtotal:this.firstValueAsSubtotal,axesDesign:this.axesDesign,showValues:this.showValues}}getDefinitionForExcel(){}updateRanges(e){const{dataSets:t,labelRange:o,isStale:s}=Vc(this.getters,e,this.dataSets,this.labelRange);if(!s)return this;const i=this.getDefinitionWithSpecificDataSets(t,o);return new nI(i,this.sheetId,this.getters)}}function rI(e,t){const o=e.getDefinition(),s=Ix(o,e.dataSets,e.labelRange,t),{labels:i,datasets:n}=qx(o,s);return{chartJsConfig:{type:"bar",data:{labels:i,datasets:n},options:{...YS,layout:oE(),scales:fE(o,s),plugins:{title:RE(o),legend:cE(o),tooltip:ME(0,s),chartShowValuesPlugin:IE(o,s),waterfallLinesPlugin:{showConnectorLines:o.showConnectorLines}}}},background:e.background||m}}const aI=new n;aI.add("bar",{match:e=>"bar"===e,createChart:(e,t,o)=>new UE(e,t,o),getChartRuntime:BE,validateChartDefinition:UE.validateChartDefinition,transformDefinition:UE.transformDefinition,getChartDefinitionFromContextCreation:UE.getDefinitionFromContextCreation,sequence:10}),aI.add("combo",{match:e=>"combo"===e,createChart:(e,t,o)=>new zE(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Ix(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Xx(o,s)},options:{...YS,layout:oE(),scales:gE(o,s),plugins:{title:RE(o),legend:lE(o),tooltip:DE(o,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:zE.validateChartDefinition,transformDefinition:zE.transformDefinition,getChartDefinitionFromContextCreation:zE.getDefinitionFromContextCreation,sequence:15}),aI.add("line",{match:e=>"line"===e,createChart:(e,t,o)=>new JE(e,t,o),getChartRuntime:QE,validateChartDefinition:JE.validateChartDefinition,transformDefinition:JE.transformDefinition,getChartDefinitionFromContextCreation:JE.getDefinitionFromContextCreation,sequence:20}),aI.add("pie",{match:e=>"pie"===e,createChart:(e,t,o)=>new eI(e,t,o),getChartRuntime:tI,validateChartDefinition:eI.validateChartDefinition,transformDefinition:eI.transformDefinition,getChartDefinitionFromContextCreation:eI.getDefinitionFromContextCreation,sequence:30}),aI.add("scorecard",{match:e=>"scorecard"===e,createChart:(e,t,o)=>new bh(e,t,o),getChartRuntime:yh,validateChartDefinition:bh.validateChartDefinition,transformDefinition:bh.transformDefinition,getChartDefinitionFromContextCreation:bh.getDefinitionFromContextCreation,sequence:40}),aI.add("gauge",{match:e=>"gauge"===e,createChart:(e,t,o)=>new jE(e,t,o),getChartRuntime:YE,validateChartDefinition:jE.validateChartDefinition,transformDefinition:jE.transformDefinition,getChartDefinitionFromContextCreation:jE.getDefinitionFromContextCreation,sequence:50}),aI.add("scatter",{match:e=>"scatter"===e,createChart:(e,t,o)=>new iI(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Tx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"line",data:{labels:s.labels,datasets:jx(o,s)},options:{...YS,layout:oE(),scales:mE(o,s),plugins:{title:RE(o),legend:aE(o),tooltip:OE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:iI.validateChartDefinition,transformDefinition:iI.transformDefinition,getChartDefinitionFromContextCreation:iI.getDefinitionFromContextCreation,sequence:60}),aI.add("waterfall",{match:e=>"waterfall"===e,createChart:(e,t,o)=>new nI(e,t,o),getChartRuntime:rI,validateChartDefinition:nI.validateChartDefinition,transformDefinition:nI.transformDefinition,getChartDefinitionFromContextCreation:nI.getDefinitionFromContextCreation,sequence:70}),aI.add("pyramid",{match:e=>"pyramid"===e,createChart:(e,t,o)=>new oI(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Rx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"bar",data:{labels:s.labels,datasets:Gx(o,s)},options:{...YS,indexAxis:"y",layout:oE(),scales:vE(o,s),plugins:{title:RE(o),legend:iE(o),tooltip:PE(o,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:oI.validateChartDefinition,transformDefinition:oI.transformDefinition,getChartDefinitionFromContextCreation:oI.getDefinitionFromContextCreation,sequence:80}),aI.add("radar",{match:e=>"radar"===e,createChart:(e,t,o)=>new sI(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=_x(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"radar",data:{labels:s.labels,datasets:Kx(o,s)},options:{...YS,layout:oE(),scales:bE(o,s),plugins:{title:RE(o),legend:hE(o),tooltip:NE(0,s),chartShowValuesPlugin:IE(o,s)}}},background:e.background||m}},validateChartDefinition:sI.validateChartDefinition,transformDefinition:sI.transformDefinition,getChartDefinitionFromContextCreation:sI.getDefinitionFromContextCreation,sequence:80}),aI.add("geo",{match:e=>"geo"===e,createChart:(e,t,o)=>new KE(e,t,o),getChartRuntime:function(e,t){const o=e.getDefinition(),s=Dx(o,e.dataSets,e.labelRange,t);return{chartJsConfig:{type:"choropleth",data:{datasets:Jx(o,s)},options:{...YS,layout:oE(),scales:SE(o,s),plugins:{title:RE(o),tooltip:kE(0,s),legend:{display:!1}}}},background:e.background||m}},validateChartDefinition:KE.validateChartDefinition,transformDefinition:KE.transformDefinition,getChartDefinitionFromContextCreation:KE.getDefinitionFromContextCreation,sequence:90});const lI=new n;lI.add("line",hh),lI.add("bar",hh),lI.add("combo",hh),lI.add("pie",hh),lI.add("gauge",ZS),lI.add("scatter",hh),lI.add("scorecard",Ih),lI.add("waterfall",hh),lI.add("pyramid",hh),lI.add("radar",hh),lI.add("geo",hh);const cI={line:Fo("Line"),column:Fo("Column"),bar:Fo("Bar"),area:Fo("Area"),pie:Fo("Pie"),misc:Fo("Miscellaneous")},hI=new n;hI.add("line",{matcher:e=>"line"===e.type&&!e.stacked&&!e.fillArea,displayName:Fo("Line"),chartType:"line",chartSubtype:"line",subtypeDefinition:{stacked:!1,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.LINE_CHART"}).add("stacked_line",{matcher:e=>"line"===e.type&&!e.fillArea&&!!e.stacked,displayName:Fo("Stacked Line"),chartType:"line",chartSubtype:"stacked_line",subtypeDefinition:{stacked:!0,fillArea:!1},category:"line",preview:"o-spreadsheet-ChartPreview.STACKED_LINE_CHART"}).add("area",{matcher:e=>"line"===e.type&&!e.stacked&&!!e.fillArea,displayName:Fo("Area"),chartType:"line",chartSubtype:"area",subtypeDefinition:{stacked:!1,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.AREA_CHART"}).add("stacked_area",{matcher:e=>"line"===e.type&&e.stacked&&!!e.fillArea,displayName:Fo("Stacked Area"),chartType:"line",chartSubtype:"stacked_area",subtypeDefinition:{stacked:!0,fillArea:!0},category:"area",preview:"o-spreadsheet-ChartPreview.STACKED_AREA_CHART"}).add("scatter",{displayName:Fo("Scatter"),chartType:"scatter",chartSubtype:"scatter",category:"misc",preview:"o-spreadsheet-ChartPreview.SCATTER_CHART"}).add("column",{matcher:e=>"bar"===e.type&&!e.stacked&&!e.horizontal,displayName:Fo("Column"),chartType:"bar",chartSubtype:"column",subtypeDefinition:{stacked:!1,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.COLUMN_CHART"}).add("stacked_column",{matcher:e=>"bar"===e.type&&e.stacked&&!e.horizontal,displayName:Fo("Stacked Column"),chartType:"bar",chartSubtype:"stacked_column",subtypeDefinition:{stacked:!0,horizontal:!1},category:"column",preview:"o-spreadsheet-ChartPreview.STACKED_COLUMN_CHART"}).add("bar",{matcher:e=>"bar"===e.type&&!e.stacked&&!!e.horizontal,displayName:Fo("Bar"),chartType:"bar",chartSubtype:"bar",subtypeDefinition:{horizontal:!0,stacked:!1},category:"bar",preview:"o-spreadsheet-ChartPreview.BAR_CHART"}).add("stacked_bar",{matcher:e=>"bar"===e.type&&e.stacked&&!!e.horizontal,displayName:Fo("Stacked Bar"),chartType:"bar",chartSubtype:"stacked_bar",subtypeDefinition:{horizontal:!0,stacked:!0},category:"bar",preview:"o-spreadsheet-ChartPreview.STACKED_BAR_CHART"}).add("combo",{displayName:Fo("Combo"),chartSubtype:"combo",chartType:"combo",category:"line",preview:"o-spreadsheet-ChartPreview.COMBO_CHART"}).add("pie",{matcher:e=>"pie"===e.type&&!e.isDoughnut,displayName:Fo("Pie"),chartSubtype:"pie",chartType:"pie",subtypeDefinition:{isDoughnut:!1},category:"pie",preview:"o-spreadsheet-ChartPreview.PIE_CHART"}).add("doughnut",{matcher:e=>"pie"===e.type&&!!e.isDoughnut,displayName:Fo("Doughnut"),chartSubtype:"doughnut",chartType:"pie",subtypeDefinition:{isDoughnut:!0},category:"pie",preview:"o-spreadsheet-ChartPreview.DOUGHNUT_CHART"}).add("gauge",{displayName:Fo("Gauge"),chartSubtype:"gauge",chartType:"gauge",category:"misc",preview:"o-spreadsheet-ChartPreview.GAUGE_CHART"}).add("scorecard",{displayName:Fo("Scorecard"),chartSubtype:"scorecard",chartType:"scorecard",category:"misc",preview:"o-spreadsheet-ChartPreview.SCORECARD_CHART"}).add("waterfall",{displayName:Fo("Waterfall"),chartSubtype:"waterfall",chartType:"waterfall",category:"misc",preview:"o-spreadsheet-ChartPreview.WATERFALL_CHART"}).add("pyramid",{displayName:Fo("Population Pyramid"),chartSubtype:"pyramid",chartType:"pyramid",category:"misc",preview:"o-spreadsheet-ChartPreview.POPULATION_PYRAMID_CHART"}).add("radar",{matcher:e=>"radar"===e.type&&!e.fillArea,displayName:Fo("Radar"),chartSubtype:"radar",chartType:"radar",subtypeDefinition:{fillArea:!1},category:"misc",preview:"o-spreadsheet-ChartPreview.RADAR_CHART"}).add("filled_radar",{matcher:e=>"radar"===e.type&&!!e.fillArea,displayName:Fo("Filled Radar"),chartType:"radar",chartSubtype:"filled_radar",subtypeDefinition:{fillArea:!0},category:"misc",preview:"o-spreadsheet-ChartPreview.FILLED_RADAR_CHART"}).add("geo",{displayName:Fo("Geo Chart"),chartSubtype:"geo",chartType:"geo",category:"misc",preview:"o-spreadsheet-ChartPreview.GEO_CHART"});const dI=new n;Mc`
|
|
37
37
|
.o-chart-container {
|
|
38
38
|
width: 100%;
|
|
39
39
|
height: 100%;
|
|
@@ -289,7 +289,7 @@
|
|
|
289
289
|
}
|
|
290
290
|
}
|
|
291
291
|
}
|
|
292
|
-
`;class uR extends t.Component{static template="o-spreadsheet-LinkEditor";static props={cellPosition:Object,onClosed:{type:Function,optional:!0}};static components={Menu:dR};menuItems=JI.getMenuItems();link=t.useState(this.defaultState);menu=t.useState({isOpen:!1});linkEditorRef=t.useRef("linkEditor");position=DI(this.linkEditorRef);urlInput=t.useRef("urlInput");setup(){t.onMounted((()=>this.urlInput.el?.focus()))}get defaultState(){const{col:e,row:t}=this.props.cellPosition,o=this.env.model.getters.getActiveSheetId(),s=this.env.model.getters.getEvaluatedCell({sheetId:o,col:e,row:t});return s.link?{url:s.link.url,label:s.formattedValue,isUrlEditable:s.link.isUrlEditable}:{label:s.formattedValue,url:"",isUrlEditable:!0}}get menuPosition(){return{x:this.position.x+320-12-2,y:this.position.y+100}}onSpecialLink(e){const{detail:t}=e,o=An(t);o&&(this.link.url=o.url,this.link.label=o.label,this.link.isUrlEditable=o.isUrlEditable)}getUrlRepresentation(e){return Rn(e,this.env.model.getters)}openMenu(){this.menu.isOpen=!0}removeLink(){this.link.url="",this.link.isUrlEditable=!0}save(){const{col:e,row:t}=this.props.cellPosition,o=this.env.model.getters.getLocale(),s=this.link.label?Da(this.link.label,o):this.link.url;this.env.model.dispatch("UPDATE_CELL",{col:e,row:t,sheetId:this.env.model.getters.getActiveSheetId(),content:tt(s,this.link.url)}),this.props.onClosed?.()}cancel(){this.props.onClosed?.()}onKeyDown(e){switch(e.key){case"Enter":this.link.url&&this.save(),e.stopPropagation(),e.preventDefault();break;case"Escape":this.cancel(),e.stopPropagation()}}}const gR={onOpen:(e,t)=>({isOpen:!0,props:{cellPosition:e},Component:uR,cellCorner:"BottomLeft"})};function pR(e){const t=aI.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o,s,i){const n=t.find((e=>e.match(s.type)));if(!n)throw new Error(`No builder for this chart: ${s.type}`);return n.createChart(s,i,e)}}function mR(e){const t=aI.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o){const s=t.find((e=>e.match(o.type)));if(!s)throw new Error("No runtime builder for this chart.");return s.getChartRuntime(o,e)}}function fR(e,t){const o=aI.getAll().find((e=>e.match(t.type)));if(!o)throw new Error("Unknown chart type.");return o.validateChartDefinition(e,t)}function vR(e,t){const o=aI.getAll().find((t=>t.match(e.type)));if(!o)throw new Error("Unknown chart type.");return o.transformDefinition(e,t)}function bR(e,t){const o=t.getActiveSheetId();let s=e;const i=1===cs(e).numberOfCols;i||(s={...e,left:e.left+1});const n=Jo(t.getUnboundedZone(o,s)),r=[{dataRange:n,yAxisId:"y"}],a=t.getCell({sheetId:o,col:e.left,row:e.top});if(1===Ss(e)&&a?.content)return{type:"scorecard",title:{},background:a.style?.fillColor||void 0,keyValue:Jo(e),baselineMode:xe,baselineColorUp:Ee,baselineColorDown:Ie};const l=!!t.getEvaluatedCellsInZone(o,{...s,bottom:s.top}).find((e=>e.type!==ni.empty&&e.type!==ni.number));let c;i||(c=Jo(t.getUnboundedZone(o,{...e,right:e.left})));const h=s.right===s.left?"none":"top";if(Px(c?t.getRangeFromSheetXC(o,c):void 0,t))return{title:{},dataSets:r,labelsAsText:!1,stacked:!1,aggregated:!1,cumulative:!1,labelRange:c,type:"line",dataSetsHaveTitle:l,legendPosition:h};const d=zc(t,r,o,l);return i&&Vx(t,d[0]).every((e=>"string"==typeof e&&!ki(e)))?{title:{},dataSets:[{dataRange:n}],aggregated:!0,labelRange:n,type:"pie",legendPosition:"top",dataSetsHaveTitle:!1}:{title:{},dataSets:r,labelRange:c,type:"bar",stacked:!1,aggregated:!1,dataSetsHaveTitle:l,legendPosition:h}}FS.add("ErrorToolTip",kI).add("LinkCell",$I).add("LinkEditor",gR).add("FilterMenu",BI);var SR=Object.freeze({__proto__:null,AbstractChart:dh,BarChart:UE,CHART_AXIS_CHOICES:oh,CHART_COMMON_OPTIONS:YS,GaugeChart:jE,LineChart:JE,PieChart:eI,ScorecardChart:bh,TREND_LINE_XAXIS_ID:Lc,WaterfallChart:nI,adaptChartRange:Bc,chartFactory:pR,chartFontColor:Zc,chartMutedFontColor:jc,chartRuntimeFactory:mR,chartToImage:XS,checkDataset:Yc,checkLabelRange:Xc,createBarChartRuntime:BE,createDataSets:zc,createGaugeChartRuntime:YE,createLineChartRuntime:QE,createPieChartRuntime:tI,createScorecardChartRuntime:yh,createWaterfallChartRuntime:rI,drawScoreChart:Sh,duplicateDataSetsInDuplicatedSheet:Hc,duplicateLabelRangeInDuplicatedSheet:Uc,formatChartDatasetValue:eh,formatTickValue:th,getChartPositionAtCenterOfViewport:Jc,getDefinedAxis:Qc,getPieColors:sh,getSmartChartDefinition:bR,shouldRemoveFirstLabel:Kc,toExcelDataset:Wc,toExcelLabelRange:Gc,transformChartDefinitionWithDataSetsWithZone:qc,transformDefinition:vR,truncateLabel:ih,updateChartRangesWithDataSets:Vc,validateChartDefinition:fR});function yR(e,t,o=QC){let s=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,s);1!==s.length||i||1!==Ss(s[0])||(e.model.selection.selectTableAroundSelection(),s=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,s));const n=s.map((o=>e.model.getters.getRangeDataFromZone(t,o))),r=e.model.dispatch("CREATE_TABLE",{ranges:n,sheetId:t,config:o,tableType:i?"dynamic":"static"});return r.isCancelledBecause("TableOverlap")?e.raiseError(Sx.Errors.TableOverlap):r.isCancelledBecause("NonContinuousTargets")&&e.raiseError(Sx.Errors.NonContinuousTargets),r}function CR(e,t){e.model.dispatch("SET_FORMATTING_WITH_PIVOT",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),format:t})}function wR(e,t){e.model.dispatch("SET_FORMATTING",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),style:t})}const xR=async e=>ER(e,"asValue");async function ER(e,t){const o=await e.clipboard.read();switch(o.status){case"ok":const s=ha(o.content),i=s.data?.clipboardId,n=e.model.getters.getSelectedZones();e.model.getters.getClipboardId()!==i?hx(e,n,s,t):cx(e,n,t),e.model.getters.isCutOperation()&&"asValue"!==t&&await e.clipboard.write({[ri.PlainText]:""});break;case"notImplemented":e.raiseError(Fo("Pasting from the context menu is not supported in this browser. Use keyboard shortcuts ctrl+c / ctrl+v instead."));break;case"permissionDenied":e.raiseError(Fo("Access to the clipboard denied by the browser. Please enable clipboard permission for this page in your browser settings."))}}const IR=(e,t)=>{const o=t.model.getters.getActiveSheetId(),s=t.model.getters.getElementsFromSelection(e),i=t.model.getters.checkElementsIncludeAllVisibleHeaders(o,e,s),n=t.model.getters.checkElementsIncludeAllNonFrozenHeaders(o,e,s);return!i&&!n},RR=e=>{const t=e.model.getters.getActiveRows();let o,s;if(t.size)o=Ot([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.top,s=t.bottom-t.top+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"before",base:o,quantity:s,dimension:"ROW"})},TR=e=>{const t=e.model.getters.getActiveCols();let o,s;if(t.size)o=Ot([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.left,s=t.right-t.left+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"before",dimension:"COL",base:o,quantity:s})},AR=e=>{const t=e.model.getters.getActiveCols();let o,s;if(t.size)o=Dt([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.right,s=t.right-t.left+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"after",dimension:"COL",base:o,quantity:s})};const _R=async e=>{if(e.imageProvider){const t=e.model.getters.getActiveSheetId(),o=e.model.uuidGenerator.uuidv4(),s=await async function(e){try{return await e.imageProvider.requestImage()}catch{return void e.raiseError(Fo("An unexpected error occurred during the image transfer"))}}(e);if(!s)throw new Error("No image provider was given to the environment");const i=pI(e.model.getters,s.size),n=function(e,t){const{x:o,y:s}=e.getMainViewportCoordinates(),{scrollX:i,scrollY:n}=e.getActiveSheetScrollInfo(),r=e.getSheetViewDimension(),a=e.getVisibleRect(e.getActiveMainViewport()),l=Math.min(a.width,r.width-o),c=Math.min(a.height,r.height-s);return{x:o+i+Math.max(0,(l-t.width)/2),y:s+n+Math.max(0,(c-t.height)/2)}}(e.model.getters,i);e.model.dispatch("CREATE_IMAGE",{sheetId:t,figureId:o,position:n,size:i,definition:s})}},DR=e=>{let{col:t,row:o}=e.model.getters.getActivePosition();e.getStore(II).open({col:t,row:o},"LinkEditor")},OR=e=>{const t=e.model.getters.getFirstTableInSelection();return t?.config.hasFilters||!1},FR=e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSelectedZones();return 1===e.model.getters.getTablesOverlappingZones(t,o).length},MR=e=>ys(e.model.getters.getSelectedZones()),PR=e=>1===e.model.getters.getSelectedZones().length,NR=(e,t)=>{if(!PR(e))return!1;const o="COL"===t?e.model.getters.getActiveCols():e.model.getters.getActiveRows(),s="COL"===t?e.model.getters.getActiveRows():e.model.getters.getActiveCols(),i=e.model.getters.getActiveSheetId(),n=ns(e.model.getters.getSelectedZone(),e.model.getters.getSheetZone(i));return xt(o)&&(0===s.size||n)},kR={name:e=>OR(e)?Fo("Remove selected filters"):Fo("Add filters"),isEnabled:e=>MR(e),execute:e=>OR(e)?(e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getFirstTableInSelection();o&&e.model.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{hasFilters:!1}})})(e):(e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getFirstTableInSelection();o?e.model.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{hasFilters:!0}}):yR(e,t,{...QC,hasFilters:!0,bandedRows:!1,styleId:"TableStyleLight11"})})(e),icon:"o-spreadsheet-Icon.FILTER_ICON_ACTIVE"},LR={name:Fo("Undo"),description:"Ctrl+Z",execute:e=>e.model.dispatch("REQUEST_UNDO"),isEnabled:e=>e.model.getters.canUndo(),icon:"o-spreadsheet-Icon.UNDO"},VR={name:Fo("Redo"),description:"Ctrl+Y",execute:e=>e.model.dispatch("REQUEST_REDO"),isEnabled:e=>e.model.getters.canRedo(),icon:"o-spreadsheet-Icon.REDO"},HR={name:Fo("Copy"),description:"Ctrl+C",isReadonlyAllowed:!0,execute:async e=>{e.model.dispatch("COPY"),await e.clipboard.write(e.model.getters.getClipboardContent())},icon:"o-spreadsheet-Icon.CLIPBOARD"},UR={name:Fo("Cut"),description:"Ctrl+X",execute:async e=>{wI(e),await e.clipboard.write(e.model.getters.getClipboardContent())},icon:"o-spreadsheet-Icon.CUT"},BR={name:Fo("Paste"),description:"Ctrl+V",execute:async e=>ER(e),icon:"o-spreadsheet-Icon.PASTE"},zR={name:Fo("Paste special"),isVisible:e=>!e.model.getters.isCutOperation(),icon:"o-spreadsheet-Icon.PASTE"},$R={name:Fo("Paste as value"),description:"Ctrl+Shift+V",execute:xR},WR={name:Fo("Paste format only"),execute:e=>ER(e,"onlyFormat")},GR={name:Fo("Find and replace"),description:"Ctrl+H",isReadonlyAllowed:!0,execute:e=>{e.openSidePanel("FindAndReplace",{})},icon:"o-spreadsheet-Icon.SEARCH"},qR={name:Fo("Delete values"),execute:e=>e.model.dispatch("DELETE_CONTENT",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()})},ZR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Delete rows");let t,o;const s=e.model.getters.getActiveRows();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.top,o=s.bottom}return t===o?Fo("Delete row %s",(t+1).toString()):Fo("Delete rows %s - %s",(t+1).toString(),(o+1).toString())},execute:e=>{let t=[...e.model.getters.getActiveRows()];if(!t.length){const o=e.model.getters.getSelectedZones()[0];for(let e=o.top;e<=o.bottom;e++)t.push(e)}e.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},isVisible:e=>IR("ROW",e)},jR={...ZR,isVisible:PR},YR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Clear rows");let t,o;const s=e.model.getters.getActiveRows();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.top,o=s.bottom}return t===o?Fo("Clear row %s",(t+1).toString()):Fo("Clear rows %s - %s",(t+1).toString(),(o+1).toString())},execute:e=>{const t=e.model.getters.getActiveSheetId(),o=[...e.model.getters.getActiveRows()].map((o=>e.model.getters.getRowsZone(t,o,o)));e.model.dispatch("DELETE_CONTENT",{target:o,sheetId:e.model.getters.getActiveSheetId()})}},XR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Delete columns");let t,o;const s=e.model.getters.getActiveCols();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.left,o=s.right}return t===o?Fo("Delete column %s",fo(t)):Fo("Delete columns %s - %s",fo(t),fo(o))},execute:e=>{let t=[...e.model.getters.getActiveCols()];if(!t.length){const o=e.model.getters.getSelectedZones()[0];for(let e=o.left;e<=o.right;e++)t.push(e)}e.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"COL",elements:t})},isVisible:e=>IR("COL",e)},KR={...XR,isVisible:PR},JR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Clear columns");let t,o;const s=e.model.getters.getActiveCols();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.left,o=s.right}return t===o?Fo("Clear column %s",fo(t)):Fo("Clear columns %s - %s",fo(t),fo(o))},execute:e=>{const t=e.model.getters.getActiveSheetId(),o=[...e.model.getters.getActiveCols()].map((o=>e.model.getters.getColsZone(t,o,o)));e.model.dispatch("DELETE_CONTENT",{target:o,sheetId:e.model.getters.getActiveSheetId()})}},QR={name:Fo("Delete cells"),isVisible:PR},eT={name:Fo("Delete cell and shift up"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("DELETE_CELL",{zone:t,shiftDimension:"ROW"});lx(e,o)}},tT={name:Fo("Delete cell and shift left"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("DELETE_CELL",{zone:t,shiftDimension:"COL"});lx(e,o)}},oT={name:Fo("Merge cells"),isEnabled:e=>!nT(e),isActive:e=>rT(e),execute:e=>function(e){if(nT(e))return;const t=e.model.getters.getSelectedZones(),o=[t[t.length-1]],s=e.model.getters.getActiveSheetId();rT(e)?e.model.dispatch("REMOVE_MERGE",{sheetId:s,target:o}):function(e,t,o){const s=e.model.dispatch("ADD_MERGE",{sheetId:t,target:o});s.isCancelledBecause("MergeInTable")?e.raiseError(xI.MergeInFilter):s.isCancelledBecause("MergeIsDestructive")&&e.askConfirmation(xI.MergeIsDestructive,(()=>{e.model.dispatch("ADD_MERGE",{sheetId:t,target:o,force:!0})}))}(e,s,o)}(e),icon:"o-spreadsheet-Icon.MERGE_CELL"},sT={name:()=>Fo("Edit table"),execute:e=>e.openSidePanel("TableSidePanel",{}),icon:"o-spreadsheet-Icon.EDIT_TABLE"},iT={name:()=>Fo("Delete table"),execute:e=>{const t=e.model.getters.getActivePosition(),o=e.model.getters.getTable(t);o&&e.model.dispatch("REMOVE_TABLE",{sheetId:t.sheetId,target:[o.range.zone]})},icon:"o-spreadsheet-Icon.DELETE_TABLE"};function nT(e){const t=e.model.getters.getSelectedZones(),{top:o,left:s,right:i,bottom:n}=e.model.getters.getSelectedZone(),{sheetId:r}=e.model.getters.getActivePosition(),{xSplit:a,ySplit:l}=e.model.getters.getPaneDivisions(r);return t.length>1||o===n&&s===i||s<a&&a<=i||o<l&&l<=n}function rT(e){if(!nT(e)){const t=e.model.getters.getSelectedZones(),{col:o,row:s,sheetId:i}=e.model.getters.getActivePosition(),n=e.model.getters.expandZone(i,fs({col:o,row:s}));return ns(t[0],n)}return!1}var aT=Object.freeze({__proto__:null,clearCols:JR,clearRows:YR,copy:HR,cut:UR,deleteCellShiftLeft:tT,deleteCellShiftUp:eT,deleteCells:QR,deleteCol:KR,deleteCols:XR,deleteRow:jR,deleteRows:ZR,deleteTable:iT,deleteValues:qR,editTable:sT,findAndReplace:GR,mergeCells:oT,paste:BR,pasteSpecial:zR,pasteSpecialFormat:WR,pasteSpecialValue:$R,redo:VR,undo:LR});const lT={name:e=>{const t=HT(e);return 1===t?Fo("Insert row"):Fo("Insert %s rows",t.toString())},isVisible:e=>NR(e,"ROW"),icon:"o-spreadsheet-Icon.INSERT_ROW"},cT={name:e=>{const t=HT(e);return 1===t?Fo("Insert row above"):Fo("Insert %s rows above",t.toString())},execute:RR,isVisible:e=>NR(e,"ROW"),icon:"o-spreadsheet-Icon.INSERT_ROW_BEFORE"},hT={...cT,name:e=>{const t=HT(e);return 1===t?Fo("Row above"):Fo("%s Rows above",t.toString())}},dT={...cT,name:e=>{const t=HT(e);return 1===t?Fo("Insert row"):Fo("Insert %s rows",t.toString())},isVisible:PR,icon:"o-spreadsheet-Icon.INSERT_ROW_BEFORE"},uT={execute:e=>{const t=e.model.getters.getActiveRows();let o,s;if(t.size)o=Dt([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.bottom,s=t.bottom-t.top+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"after",base:o,quantity:s,dimension:"ROW"})},name:e=>{const t=HT(e);return 1===t?Fo("Insert row below"):Fo("Insert %s rows below",t.toString())},isVisible:e=>NR(e,"ROW"),icon:"o-spreadsheet-Icon.INSERT_ROW_AFTER"},gT={...uT,name:e=>{const t=HT(e);return 1===t?Fo("Row below"):Fo("%s Rows below",t.toString())}},pT={name:e=>{const t=UT(e);return 1===t?Fo("Insert column"):Fo("Insert %s columns",t.toString())},isVisible:e=>NR(e,"COL"),icon:"o-spreadsheet-Icon.INSERT_COL"},mT={name:e=>{const t=UT(e);return 1===t?Fo("Insert column left"):Fo("Insert %s columns left",t.toString())},execute:TR,isVisible:e=>NR(e,"COL"),icon:"o-spreadsheet-Icon.INSERT_COL_BEFORE"},fT={...mT,name:e=>{const t=UT(e);return 1===t?Fo("Column left"):Fo("%s Columns left",t.toString())}},vT={...mT,name:e=>{const t=UT(e);return 1===t?Fo("Insert column"):Fo("Insert %s columns",t.toString())},isVisible:PR,icon:"o-spreadsheet-Icon.INSERT_COL_BEFORE"},bT={name:e=>{const t=UT(e);return 1===t?Fo("Insert column right"):Fo("Insert %s columns right",t.toString())},execute:AR,isVisible:e=>NR(e,"COL"),icon:"o-spreadsheet-Icon.INSERT_COL_AFTER"},ST={...bT,name:e=>{const t=UT(e);return 1===t?Fo("Column right"):Fo("%s Columns right",t.toString())},execute:AR},yT={name:Fo("Insert cells"),isVisible:e=>PR(e)&&0===e.model.getters.getActiveCols().size&&0===e.model.getters.getActiveRows().size,icon:"o-spreadsheet-Icon.INSERT_CELL"},CT={name:Fo("Insert cells and shift down"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("INSERT_CELL",{zone:t,shiftDimension:"ROW"});lx(e,o)},isVisible:e=>0===e.model.getters.getActiveRows().size&&0===e.model.getters.getActiveCols().size,icon:"o-spreadsheet-Icon.INSERT_CELL_SHIFT_DOWN"},wT={name:Fo("Insert cells and shift right"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("INSERT_CELL",{zone:t,shiftDimension:"COL"});lx(e,o)},isVisible:e=>0===e.model.getters.getActiveRows().size&&0===e.model.getters.getActiveCols().size,icon:"o-spreadsheet-Icon.INSERT_CELL_SHIFT_RIGHT"},xT={name:Fo("Chart"),execute:e=>{const t=e.model.getters,o=e.model.uuidGenerator.uuidv4(),s=t.getActiveSheetId();1===Ss(e.model.getters.getSelectedZone())&&e.model.selection.selectTableAroundSelection();const i={width:536,height:335},n=Jc(t,i);e.model.dispatch("CREATE_CHART",{sheetId:s,id:o,position:n,size:i,definition:bR(e.model.getters.getSelectedZone(),e.model.getters)}).isSuccessful&&(e.model.dispatch("SELECT_FIGURE",{id:o}),e.openSidePanel("ChartPanel"))},icon:"o-spreadsheet-Icon.INSERT_CHART"},ET={name:Fo("Pivot table"),execute:e=>{const t=e.model.uuidGenerator.uuidv4(),o=e.model.uuidGenerator.uuidv4();e.model.dispatch("INSERT_NEW_PIVOT",{pivotId:t,newSheetId:o}).isSuccessful&&e.openSidePanel("PivotSidePanel",{pivotId:t})},icon:"o-spreadsheet-Icon.PIVOT"},IT={name:Fo("Image"),description:"Ctrl+O",execute:_R,isVisible:e=>void 0!==e.imageProvider,icon:"o-spreadsheet-Icon.INSERT_IMAGE"},RT={name:()=>Fo("Table"),execute:e=>{const t=e.model.getters.getActiveSheetId();yR(e,t).isSuccessful&&e.openSidePanel("TableSidePanel",{})},isVisible:e=>MR(e)&&!e.model.getters.getFirstTableInSelection(),icon:"o-spreadsheet-Icon.PAINT_TABLE"},TT={name:Fo("Function"),icon:"o-spreadsheet-Icon.FORMULA"},AT={name:Fo("SUM"),execute:e=>e.startCellEdition("=SUM(")},_T={name:Fo("AVERAGE"),execute:e=>e.startCellEdition("=AVERAGE(")},DT={name:Fo("COUNT"),execute:e=>e.startCellEdition("=COUNT(")},OT={name:Fo("MAX"),execute:e=>e.startCellEdition("=MAX(")},FT={name:Fo("MIN"),execute:e=>e.startCellEdition("=MIN(")},MT={name:Fo("All"),children:[function(){return VT($b.getKeys().filter((e=>!$b.get(e).hidden)))}]};const PT={name:Fo("Link"),execute:DR,icon:"o-spreadsheet-Icon.INSERT_LINK"},NT={name:Fo("Checkbox"),execute:e=>{const t=e.model.getters.getSelectedZones(),o=e.model.getters.getActiveSheetId(),s=t.map((t=>e.model.getters.getRangeDataFromZone(o,t)));e.model.dispatch("ADD_DATA_VALIDATION_RULE",{ranges:s,sheetId:o,rule:{id:e.model.uuidGenerator.uuidv4(),criterion:{type:"isBoolean",values:[]}}})},icon:"o-spreadsheet-Icon.INSERT_CHECKBOX"},kT={name:Fo("Dropdown list"),execute:e=>{const t=e.model.getters.getSelectedZones(),o=e.model.getters.getActiveSheetId(),s=t.map((t=>e.model.getters.getRangeDataFromZone(o,t))),i=e.model.uuidGenerator.uuidv4();e.model.dispatch("ADD_DATA_VALIDATION_RULE",{ranges:s,sheetId:o,rule:{id:i,criterion:{type:"isValueInList",values:[],displayStyle:"arrow"}}});const n=e.model.getters.getDataValidationRule(o,i);n&&e.openSidePanel("DataValidationEditor",{rule:Ha(n,e.model.getters.getLocale()),onExit:()=>{e.openSidePanel("DataValidation")}})},icon:"o-spreadsheet-Icon.INSERT_DROPDOWN"},LT={name:Fo("Insert sheet"),execute:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSheetIds().indexOf(t)+1,s=e.model.uuidGenerator.uuidv4();e.model.dispatch("CREATE_SHEET",{sheetId:s,position:o}),e.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t,sheetIdTo:s})},icon:"o-spreadsheet-Icon.INSERT_SHEET"};function VT(e){return e.sort().map(((e,t)=>({name:e,sequence:10*t,execute:t=>t.startCellEdition(`=${e}(`)})))}function HT(e){const t=e.model.getters.getActiveRows();if(t.size)return t.size;{const t=e.model.getters.getSelectedZones()[0];return t.bottom-t.top+1}}function UT(e){const t=e.model.getters.getActiveCols();if(t.size)return t.size;{const t=e.model.getters.getSelectedZones()[0];return t.right-t.left+1}}const BT={name:Fo("See pivot properties"),execute(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);e.openSidePanel("PivotSidePanel",{pivotId:o})},isVisible:e=>{const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);return o&&e.model.getters.isExistingPivot(o)||!1},isReadonlyAllowed:!0,icon:"o-spreadsheet-Icon.PIVOT"},zT={name:Fo("Ascending"),execute:e=>qT(e,"asc"),isActive:e=>ZT(e,"asc")},$T={name:Fo("Descending"),execute:e=>qT(e,"desc"),isActive:e=>ZT(e,"desc")},WT={name:Fo("No sorting"),execute:e=>qT(e,"none"),isActive:e=>ZT(e,"none")},GT={name:Fo("Convert to individual formulas"),execute(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getCorrespondingFormulaCell(t),s=e.model.getters.getPivotIdFromPosition(t);if(!o||!s)return;const{sheetId:i,col:n,row:r}=e.model.getters.getCellPosition(o.id),a=e.model.getters.getPivot(s);a.init(),a.isValid()&&e.model.dispatch("SPLIT_PIVOT_FORMULA",{sheetId:i,col:n,row:r,pivotId:s})},isVisible:e=>{const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);if(!o)return!1;const s=e.model.getters.getPivot(o),i=e.model.getters.getEvaluatedCell(t);return s.isValid()&&e.model.getters.isSpillPivotFormula(t)&&i.type!==ni.error},icon:"o-spreadsheet-Icon.PIVOT"};function qT(e,t){const o=e.model.getters.getActivePosition(),s=e.model.getters.getPivotIdFromPosition(o),i=e.model.getters.getPivotCellFromPosition(o);if("EMPTY"===i.type||"HEADER"===i.type||!s)return;if("none"===t)return void e.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...e.model.getters.getPivotCoreDefinition(s),sortedColumn:void 0}});const n=ml(e.model.getters.getPivot(s),i.domain).colDomain;e.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...e.model.getters.getPivotCoreDefinition(s),sortedColumn:{domain:n,order:t,measure:i.measure}}})}function ZT(e,t){const o=e.model.getters.getActivePosition(),s=e.model.getters.getPivotIdFromPosition(o),i=e.model.getters.getPivotCellFromPosition(o);if("EMPTY"===i.type||"HEADER"===i.type||!s)return!1;const n=e.model.getters.getPivot(s),r=ml(n,i.domain).colDomain,a=n.definition.sortedColumn;return"none"===t?!a:!(!a||a.order!==t)&&(a.measure===i.measure&&mt(a.domain,r))}const jT=new CI;jT.add("cut",{...UR,sequence:10}).add("copy",{...HR,sequence:20}).add("paste",{...BR,sequence:30}).add("paste_special",{...zR,sequence:40,separator:!0}).addChild("paste_value_only",["paste_special"],{...$R,sequence:10}).addChild("paste_format_only",["paste_special"],{...WR,sequence:20}).add("add_row_before",{...dT,sequence:70}).add("add_column_before",{...vT,sequence:90}).add("insert_cell",{...yT,sequence:100,separator:!0}).addChild("insert_cell_down",["insert_cell"],{...CT,name:Fo("Shift down"),sequence:10}).addChild("insert_cell_right",["insert_cell"],{...wT,name:Fo("Shift right"),sequence:20}).add("delete_row",{...jR,sequence:110,icon:"o-spreadsheet-Icon.TRASH"}).add("delete_column",{...KR,sequence:120,icon:"o-spreadsheet-Icon.TRASH"}).add("delete_cell",{...QR,sequence:130,separator:!0,icon:"o-spreadsheet-Icon.TRASH"}).addChild("delete_cell_up",["delete_cell"],{...eT,name:Fo("Shift up"),sequence:10,icon:"o-spreadsheet-Icon.DELETE_CELL_SHIFT_UP"}).addChild("delete_cell_left",["delete_cell"],{...tT,name:Fo("Shift left"),sequence:20,icon:"o-spreadsheet-Icon.DELETE_CELL_SHIFT_LEFT"}).add("edit_table",{...sT,isVisible:FR,sequence:140}).add("delete_table",{...iT,isVisible:FR,sequence:145,separator:!0}).add("insert_link",{...PT,name:e=>{const t=e.model.getters.getActiveSheetId(),{col:o,row:s}=e.model.getters.getActivePosition(),i=e.model.getters.getEvaluatedCell({sheetId:t,col:o,row:s});return i&&i.link?Fo("Edit link"):Fo("Insert link")},sequence:150,separator:!0}).add("pivot_sorting",{name:Fo("Sort pivot"),sequence:155,icon:"o-spreadsheet-Icon.SORT_RANGE",isVisible:function(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);if(!o||!e.model.getters.isExistingPivot(o)||!e.model.getters.isSpillPivotFormula(t))return!1;if(!e.model.getters.getPivot(o).isValid())return!1;const s=e.model.getters.getPivotCellFromPosition(t);return"VALUE"===s.type||"MEASURE_HEADER"===s.type}}).add("pivot_fix_formulas",{...GT,sequence:160}).add("pivot_properties",{...BT,sequence:170,separator:!0}).addChild("pivot_sorting_asc",["pivot_sorting"],{...zT,sequence:10}).addChild("pivot_sorting_desc",["pivot_sorting"],{...$T,sequence:20}).addChild("pivot_sorting_none",["pivot_sorting"],{...WT,sequence:30});const YT={name:Fo("Sort range"),isVisible:PR,icon:"o-spreadsheet-Icon.SORT_RANGE"},XT={name:Fo("Ascending (A ⟶ Z)"),execute:e=>{const{anchor:t,zones:o}=e.model.getters.getSelection(),s=e.model.getters.getActiveSheetId();Ap(e,s,t.cell,o[0],"asc")},icon:"o-spreadsheet-Icon.SORT_ASCENDING"},KT={name:Fo("Data cleanup"),icon:"o-spreadsheet-Icon.DATA_CLEANUP"},JT={name:Fo("Remove duplicates"),execute:e=>{1===Ss(e.model.getters.getSelectedZone())&&e.model.selection.selectTableAroundSelection(),e.openSidePanel("RemoveDuplicates",{})}},QT={name:Fo("Trim whitespace"),execute:e=>{e.model.dispatch("TRIM_WHITESPACE")}},eA={name:Fo("Descending (Z ⟶ A)"),execute:e=>{const{anchor:t,zones:o}=e.model.getters.getSelection(),s=e.model.getters.getActiveSheetId();Ap(e,s,t.cell,o[0],"desc")},icon:"o-spreadsheet-Icon.SORT_DESCENDING"},tA={...kR},oA={...kR,isActive:e=>OR(e)},sA={name:Fo("Split text to columns"),sequence:1,execute:e=>e.openSidePanel("SplitToColumns",{}),isEnabled:e=>e.model.getters.isSingleColSelected(),icon:"o-spreadsheet-Icon.SPLIT_TEXT"},iA={id:"reinsert_dynamic_pivot",name:Fo("Re-insert dynamic pivot"),sequence:1020,icon:"o-spreadsheet-Icon.INSERT_PIVOT",children:[e=>e.model.getters.getPivotIds().map(((t,o)=>({id:`reinsert_dynamic_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:o,execute:e=>{const o=e.model.getters.getSelectedZone(),s=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch("INSERT_PIVOT_WITH_TABLE",{pivotId:t,table:s,col:o.left,row:o.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:"dynamic"}),e.model.dispatch("REFRESH_PIVOT",{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()})))],isVisible:e=>e.model.getters.getPivotIds().some((t=>e.model.getters.getPivot(t).isValid()))},nA={id:"reinsert_static_pivot",name:Fo("Re-insert static pivot"),sequence:1020,icon:"o-spreadsheet-Icon.INSERT_PIVOT",children:[e=>e.model.getters.getPivotIds().map(((t,o)=>({id:`reinsert_static_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:o,execute:e=>{const o=e.model.getters.getSelectedZone(),s=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch("INSERT_PIVOT_WITH_TABLE",{pivotId:t,table:s,col:o.left,row:o.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:"static"}),e.model.dispatch("REFRESH_PIVOT",{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()})))],isVisible:e=>e.model.getters.getPivotIds().some((t=>e.model.getters.getPivot(t).isValid()))};var rA=Object.freeze({__proto__:null,createRemoveFilter:tA,createRemoveFilterTool:oA,dataCleanup:KT,reinsertDynamicPivotMenu:iA,reinsertStaticPivotMenu:nA,removeDuplicates:JT,sortAscending:XT,sortDescending:eA,sortRange:YT,splitToColumns:sA,trimWhitespace:QT});function aA({name:e,format:t,descriptionValue:o}){const s="function"==typeof t?t:()=>t;return{name:e,description:e=>Jn(o,{format:s(e),locale:e.model.getters.getLocale()}),execute:e=>CR(e,s(e)),isActive:e=>s_(e,s(e)),format:t}}const lA={name:Fo("Automatic"),execute:e=>CR(e,""),isActive:e=>function(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotCellFromPosition(t);if("VALUE"===o.type)return!e.model.getters.getEvaluatedCell(t).format;return!e.model.getters.getCell(t)?.format}(e)},cA={name:Fo("Plain text"),execute:e=>CR(e,"@"),isActive:e=>s_(e,"@")},hA=aA({name:Fo("Number"),descriptionValue:1000.12,format:"#,##0.00"}),dA={name:Fo("Format as percent"),execute:e=>CR(e,"0.00%"),icon:"o-spreadsheet-Icon.PERCENT"},uA=aA({name:Fo("Percent"),descriptionValue:.1012,format:"0.00%"}),gA=aA({name:Fo("Currency"),descriptionValue:1000.12,format:e=>ur(e.model.config.defaultCurrency||Le)}),pA={...aA({name:Fo("Currency rounded"),descriptionValue:1e3,format:e=>mr(ur(e.model.config.defaultCurrency||Le))}),isVisible:e=>{const t=ur(e.model.config.defaultCurrency||Le);return t!==mr(t)}},mA=aA({name:Fo("Accounting"),descriptionValue:-1000.12,format:e=>gr(e.model.config.defaultCurrency||Le)}),fA=Rr("2023/09/26 10:43:00 PM",Si),vA={name:Fo("Custom currency"),isVisible:e=>void 0!==e.loadCurrencies,execute:e=>e.openSidePanel("CustomCurrency",{})},bA=aA({name:Fo("Date"),descriptionValue:fA,format:e=>e.model.getters.getLocale().dateFormat}),SA=aA({name:Fo("Time"),descriptionValue:fA,format:e=>e.model.getters.getLocale().timeFormat}),yA=aA({name:Fo("Date time"),descriptionValue:fA,format:e=>za(e.model.getters.getLocale())}),CA=aA({name:Fo("Duration"),descriptionValue:"27:51:38",format:"hhhh:mm:ss"}),wA=aA({name:Fo("Quarter"),descriptionValue:fA,format:"qq yyyy"}),xA=aA({name:Fo("Full quarter"),descriptionValue:fA,format:"qqqq yyyy"}),EA={name:Fo("More date formats"),execute:e=>e.openSidePanel("MoreFormats",{})},IA=aA({name:Fo("Full date time"),format:"dddd d mmmm yyyy hh:mm:ss a",descriptionValue:fA}),RA=aA({name:Fo("Full week day and month"),format:"dddd d mmmm yyyy",descriptionValue:fA}),TA=aA({name:Fo("Day and full month"),format:"d mmmm yyyy",descriptionValue:fA}),AA=aA({name:Fo("Short week day"),format:"ddd d mmm yyyy",descriptionValue:fA}),_A=aA({name:Fo("Day and short month"),format:"d mmm yyyy",descriptionValue:fA}),DA=aA({name:Fo("Full month"),format:"mmmm yyyy",descriptionValue:fA}),OA=aA({name:Fo("Short month"),format:"mmm yyyy",descriptionValue:fA}),FA={name:Fo("Increase decimal places"),icon:"o-spreadsheet-Icon.INCREASE_DECIMAL",execute:e=>e.model.dispatch("SET_DECIMAL",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:1})},MA={name:Fo("Decrease decimal places"),icon:"o-spreadsheet-Icon.DECRASE_DECIMAL",execute:e=>e.model.dispatch("SET_DECIMAL",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:-1})},PA={name:Fo("Bold"),description:"Ctrl+B",execute:e=>wR(e,{bold:!e.model.getters.getCurrentStyle().bold}),icon:"o-spreadsheet-Icon.BOLD",isActive:e=>!!e.model.getters.getCurrentStyle().bold},NA={name:Fo("Italic"),description:"Ctrl+I",execute:e=>wR(e,{italic:!e.model.getters.getCurrentStyle().italic}),icon:"o-spreadsheet-Icon.ITALIC",isActive:e=>!!e.model.getters.getCurrentStyle().italic},kA={name:Fo("Underline"),description:"Ctrl+U",execute:e=>wR(e,{underline:!e.model.getters.getCurrentStyle().underline}),icon:"o-spreadsheet-Icon.UNDERLINE",isActive:e=>!!e.model.getters.getCurrentStyle().underline},LA={name:Fo("Strikethrough"),execute:e=>wR(e,{strikethrough:!e.model.getters.getCurrentStyle().strikethrough}),icon:"o-spreadsheet-Icon.STRIKE",isActive:e=>!!e.model.getters.getCurrentStyle().strikethrough},VA={name:Fo("Font size"),children:Ne.map((e=>({name:e.toString(),sequence:e,id:`font_size_${e}`,execute:t=>wR(t,{fontSize:e}),isActive:t=>function(e,t){const o=e.model.getters.getCurrentStyle().fontSize||me;return o===t}(t,e)}))),icon:"o-spreadsheet-Icon.FONT_SIZE"},HA={name:Fo("Alignment"),icon:"o-spreadsheet-Icon.ALIGN_LEFT"},UA={name:Fo("Horizontal align"),icon:e=>function(e){switch(i_(e)){case"right":return"o-spreadsheet-Icon.ALIGN_RIGHT";case"center":return"o-spreadsheet-Icon.ALIGN_CENTER";default:return"o-spreadsheet-Icon.ALIGN_LEFT"}}(e)},BA={name:Fo("Left"),description:"Ctrl+Shift+L",execute:e=>wR(e,{align:"left"}),isActive:e=>"left"===i_(e),icon:"o-spreadsheet-Icon.ALIGN_LEFT"},zA={name:Fo("Center"),description:"Ctrl+Shift+E",execute:e=>wR(e,{align:"center"}),isActive:e=>"center"===i_(e),icon:"o-spreadsheet-Icon.ALIGN_CENTER"},$A={name:Fo("Right"),description:"Ctrl+Shift+R",execute:e=>wR(e,{align:"right"}),isActive:e=>"right"===i_(e),icon:"o-spreadsheet-Icon.ALIGN_RIGHT"},WA={name:Fo("Vertical align"),icon:e=>function(e){switch(n_(e)){case"top":return"o-spreadsheet-Icon.ALIGN_TOP";case"middle":return"o-spreadsheet-Icon.ALIGN_MIDDLE";default:return"o-spreadsheet-Icon.ALIGN_BOTTOM"}}(e)},GA={name:Fo("Top"),execute:e=>wR(e,{verticalAlign:"top"}),isActive:e=>"top"===n_(e),icon:"o-spreadsheet-Icon.ALIGN_TOP"},qA={name:Fo("Middle"),execute:e=>wR(e,{verticalAlign:"middle"}),isActive:e=>"middle"===n_(e),icon:"o-spreadsheet-Icon.ALIGN_MIDDLE"},ZA={name:Fo("Bottom"),execute:e=>wR(e,{verticalAlign:"bottom"}),isActive:e=>"bottom"===n_(e),icon:"o-spreadsheet-Icon.ALIGN_BOTTOM"},jA={name:Fo("Wrapping"),icon:"o-spreadsheet-Icon.WRAPPING_OVERFLOW"},YA={name:Fo("Wrapping"),icon:e=>function(e){switch(r_(e)){case"wrap":return"o-spreadsheet-Icon.WRAPPING_WRAP";case"clip":return"o-spreadsheet-Icon.WRAPPING_CLIP";default:return"o-spreadsheet-Icon.WRAPPING_OVERFLOW"}}(e)},XA={name:Fo("Overflow"),execute:e=>wR(e,{wrapping:"overflow"}),isActive:e=>"overflow"===r_(e),icon:"o-spreadsheet-Icon.WRAPPING_OVERFLOW"},KA={name:Fo("Wrap"),execute:e=>wR(e,{wrapping:"wrap"}),isActive:e=>"wrap"===r_(e),icon:"o-spreadsheet-Icon.WRAPPING_WRAP"},JA={name:Fo("Clip"),execute:e=>wR(e,{wrapping:"clip"}),isActive:e=>"clip"===r_(e),icon:"o-spreadsheet-Icon.WRAPPING_CLIP"},QA={name:Fo("Text Color"),icon:"o-spreadsheet-Icon.TEXT_COLOR"},e_={name:Fo("Fill Color"),icon:"o-spreadsheet-Icon.FILL_COLOR"},t_={name:Fo("Conditional formatting"),execute:e=>{e.openSidePanel("ConditionalFormatting",{selection:e.model.getters.getSelectedZones()})},icon:"o-spreadsheet-Icon.CONDITIONAL_FORMAT"},o_={name:Fo("Clear formatting"),description:"Ctrl+<",execute:e=>e.model.dispatch("CLEAR_FORMATTING",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()}),icon:"o-spreadsheet-Icon.CLEAR_FORMAT"};function s_(e,t){const o=e.model.getters.getActivePosition();return"VALUE"===e.model.getters.getPivotCellFromPosition(o).type?e.model.getters.getEvaluatedCell(o).format===t:e.model.getters.getCell(o)?.format===t}function i_(e){const t=e.model.getters.getCurrentStyle();if(t.align)return t.align;return e.model.getters.getActiveCell().defaultAlign}function n_(e){const t=e.model.getters.getCurrentStyle();return t.verticalAlign?t.verticalAlign:ue}function r_(e){const t=e.model.getters.getCurrentStyle();return t.wrapping?t.wrapping:ge}var a_=Object.freeze({__proto__:null,EXAMPLE_DATE:fA,clearFormat:o_,createFormatActionSpec:aA,decraseDecimalPlaces:MA,fillColor:e_,formatAlignment:HA,formatAlignmentBottom:ZA,formatAlignmentCenter:zA,formatAlignmentHorizontal:UA,formatAlignmentLeft:BA,formatAlignmentMiddle:qA,formatAlignmentRight:$A,formatAlignmentTop:GA,formatAlignmentVertical:WA,formatBold:PA,formatCF:t_,formatCustomCurrency:vA,formatFontSize:VA,formatItalic:NA,formatNumberAccounting:mA,formatNumberAutomatic:lA,formatNumberCurrency:gA,formatNumberCurrencyRounded:pA,formatNumberDate:bA,formatNumberDateTime:yA,formatNumberDayAndFullMonth:TA,formatNumberDayAndShortMonth:_A,formatNumberDuration:CA,formatNumberFullDateTime:IA,formatNumberFullMonth:DA,formatNumberFullQuarter:xA,formatNumberFullWeekDayAndMonth:RA,formatNumberNumber:hA,formatNumberPercent:uA,formatNumberPlainText:cA,formatNumberQuarter:wA,formatNumberShortMonth:OA,formatNumberShortWeekDay:AA,formatNumberTime:SA,formatPercent:dA,formatStrikethrough:LA,formatUnderline:kA,formatWrapping:YA,formatWrappingClip:JA,formatWrappingIcon:jA,formatWrappingOverflow:XA,formatWrappingWrap:KA,incraseDecimalPlaces:FA,moreFormats:EA,textColor:QA});function l_(e,t,o){const s=e.model.getters.getActiveSheetId(),i="COL"===t?"FREEZE_COLUMNS":"FREEZE_ROWS";e.model.dispatch(i,{sheetId:s,quantity:o}).isCancelledBecause("MergeOverlap")&&e.raiseError(mx)}class c_{map={};constructor(e=[]){for(const[t,o]of e)this.set(t,o)}set({sheetId:e,col:t,row:o},s){const i=this.map;i[e]||(i[e]={}),i[e][t]||(i[e][t]={}),i[e][t][o]=s}get({sheetId:e,col:t,row:o}){return this.map[e]?.[t]?.[o]}getSheet(e){return this.map[e]}has({sheetId:e,col:t,row:o}){return void 0!==this.map[e]?.[t]?.[o]}delete({sheetId:e,col:t,row:o}){delete this.map[e]?.[t]?.[o]}keys(){const e=this.map,t=[];for(const o in e)for(const s in e[o])for(const i in e[o][s])t.push({sheetId:o,col:parseInt(s),row:parseInt(i)});return t}keysForSheet(e){const t=this.map[e];if(!t)return[];const o=[];for(const s in t)for(const i in t[s])o.push({sheetId:e,col:parseInt(s),row:parseInt(i)});return o}*entries(){const e=this.map;for(const t of this.keys()){const{sheetId:o,col:s,row:i}=t;yield[t,e[o][s][i]]}}}class h_ extends Ac{mutators=["enable","disable"];isInvalidated=!1;fingerprintColors={[d_]:"#D9D9D9"};isEnabled=!1;colors=new c_;handle(e){switch(pi(e)&&this.isEnabled&&(this.isInvalidated=!0),e.type){case"UNDO":case"REDO":case"ACTIVATE_SHEET":this.isEnabled&&(this.isInvalidated=!0)}}finalize(){this.isInvalidated&&(this.isInvalidated=!1,this.computeFingerprints())}enable(){this.isEnabled=!0,this.computeFingerprints()}disable(){this.isEnabled=!1,this.colors=new c_}computeFingerprints(){this.colors=new c_;const e=new c_,t=new Set,o=this.getters.getActiveSheetId(),s=this.getters.getCells(o);for(const o in s){const i=this.computeFingerprint(s[o]);if(!i)continue;t.add(i);const n=this.getters.getCellPosition(o);e.set(n,i)}this.assignColors(t);for(const[t,o]of e.entries()){const e=this.fingerprintColors[o];this.colors.set(t,e),this.colorSpreadZone(t,e)}}colorSpreadZone(e,t){const o=this.getters.getSpreadZone(e);if(!o)return;const s=e.sheetId;for(let e=o.top;e<=o.bottom;e++)for(let i=o.left;i<=o.right;i++){const o={sheetId:s,col:i,row:e};this.colors.set(o,t)}}assignColors(e){const t=new uo(e.size);Object.keys(this.fingerprintColors).forEach((()=>t.next()));for(const o of e)this.fingerprintColors[o]||(this.fingerprintColors[o]=Jt(t.next(),.8))}computeFingerprint(e){const t=this.getters.getCellPosition(e.id);return e.isFormula?this.computeFormulaFingerprint(t,e):this.getLiteralFingerprint(t)}computeFormulaFingerprint(e,t){const o=t.compiledFormula.dependencies,s=e.col,i=e.row,n=this.getters.getSheetIds().indexOf(e.sheetId),r={dx:0,dy:0,dSheet:0};for(const e of o){const t=e.zone,[o,a]=e.parts,l=this.getters.getSheetIds().indexOf(e.sheetId);r.dSheet=l-n;const c=e.isFullRow&&!e.unboundedZone.hasHeader,h=e.isFullCol&&!e.unboundedZone.hasHeader,d=c||o?.colFixed?0:s,u=h||o?.rowFixed?0:i,g=!a&&o?.colFixed||a?.colFixed,p=!a&&o.rowFixed||a?.rowFixed,m=void 0===e.unboundedZone.right||g?0:s,f=void 0===e.unboundedZone.bottom||p?0:i,v=gs({top:t.top-u,left:t.left-d,right:t.right-m,bottom:t.bottom-f});for(let e=v.top;e<=v.bottom;e++)for(let t=v.left;t<=v.right;t++)r.dx+=t,r.dy+=e}const a=t.compiledFormula.normalizedFormula.replace(/(|\w)(\d)(|)/g,"$1$3");return l=r,Object.entries(l).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>t)).join(",")+a;var l}getLiteralFingerprint(e){switch(this.getters.getEvaluatedCell(e).type){case ni.number:case ni.boolean:return d_;case ni.text:case ni.empty:case ni.error:return}}}const d_="DATA_FINGERPRINT",u_={name:e=>{const t=e.model.getters.getElementsFromSelection("COL");let o=t[0],s=t[t.length-1];return 1===t.length?Fo("Hide column %s",fo(o).toString()):s-o+1===t.length?Fo("Hide columns %s - %s",fo(o).toString(),fo(s).toString()):Fo("Hide columns")},execute:e=>{const t=e.model.getters.getElementsFromSelection("COL");e.model.dispatch("HIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"COL",elements:t})},isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getElementsFromSelection("COL");return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,"COL",o)},icon:"o-spreadsheet-Icon.HIDE_COL"},g_={name:Fo("Unhide columns"),execute:e=>{const t=e.model.getters.getElementsFromSelection("COL");e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"COL",elements:t})},isVisible:e=>{const t=e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection("COL").some((e=>t.includes(e)))},icon:"o-spreadsheet-Icon.UNHIDE_COL"},p_={name:Fo("Unhide all columns"),execute:e=>{const t=e.model.getters.getActiveSheetId();e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:t,dimension:"COL",elements:Array.from(Array(e.model.getters.getNumberCols(t)).keys())})},isVisible:e=>e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).length>0,icon:"o-spreadsheet-Icon.UNHIDE_COL"},m_={name:e=>{const t=e.model.getters.getElementsFromSelection("ROW");let o=t[0],s=t[t.length-1];return 1===t.length?Fo("Hide row %s",(o+1).toString()):s-o+1===t.length?Fo("Hide rows %s - %s",(o+1).toString(),(s+1).toString()):Fo("Hide rows")},execute:e=>{const t=e.model.getters.getElementsFromSelection("ROW");e.model.dispatch("HIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getElementsFromSelection("ROW");return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,"ROW",o)},icon:"o-spreadsheet-Icon.HIDE_ROW"},f_={name:Fo("Unhide rows"),execute:e=>{const t=e.model.getters.getElementsFromSelection("ROW");e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},isVisible:e=>{const t=e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection("ROW").some((e=>t.includes(e)))},icon:"o-spreadsheet-Icon.UNHIDE_ROW"},v_={name:Fo("Unhide all rows"),execute:e=>{const t=e.model.getters.getActiveSheetId();e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:t,dimension:"ROW",elements:Array.from(Array(e.model.getters.getNumberRows(t)).keys())})},isVisible:e=>e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).length>0,icon:"o-spreadsheet-Icon.UNHIDE_ROW"},b_={name:Fo("Unfreeze"),isVisible:e=>{const{xSplit:t,ySplit:o}=e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId());return t+o>0},execute:e=>e.model.dispatch("UNFREEZE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId()}),icon:"o-spreadsheet-Icon.UNFREEZE"},S_={name:Fo("Freeze"),icon:"o-spreadsheet-Icon.FREEZE"},y_={name:Fo("No rows"),execute:e=>e.model.dispatch("UNFREEZE_ROWS",{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).ySplit},C_={name:Fo("1 row"),execute:e=>l_(e,"ROW",1),isReadonlyAllowed:!0},w_={name:Fo("2 rows"),execute:e=>l_(e,"ROW",2),isReadonlyAllowed:!0},x_={name:Fo("Up to current row"),execute:e=>{const{bottom:t}=e.model.getters.getSelectedZone();l_(e,"ROW",t+1)},isReadonlyAllowed:!0},E_={name:Fo("No columns"),execute:e=>e.model.dispatch("UNFREEZE_COLUMNS",{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).xSplit},I_={name:Fo("1 column"),execute:e=>l_(e,"COL",1),isReadonlyAllowed:!0},R_={name:Fo("2 columns"),execute:e=>l_(e,"COL",2),isReadonlyAllowed:!0},T_={name:Fo("Up to current column"),execute:e=>{const{right:t}=e.model.getters.getSelectedZone();l_(e,"COL",t+1)},isReadonlyAllowed:!0},A_={name:Fo("Gridlines"),execute:e=>{const t=e.model.getters.getActiveSheetId();e.model.dispatch("SET_GRID_LINES_VISIBILITY",{sheetId:t,areGridLinesVisible:!e.model.getters.getGridLinesVisibility(t)})},isActive:e=>{const t=e.model.getters.getActiveSheetId();return e.model.getters.getGridLinesVisibility(t)}},__={name:Fo("Irregularity map"),execute:e=>{const t=e.getStore(h_);t.isEnabled?t.disable():t.enable()},icon:"o-spreadsheet-Icon.IRREGULARITY_MAP"},D_={name:Fo("Formulas"),isActive:e=>e.model.getters.shouldShowFormulas(),execute:e=>e.model.dispatch("SET_FORMULA_VISIBILITY",{show:!e.model.getters.shouldShowFormulas()}),isReadonlyAllowed:!0},O_={name:e=>{const t=e.model.getters.getSelectedZone();return t.left===t.right?Fo("Group column %s",fo(t.left)):Fo("Group columns %s - %s",fo(t.left),fo(t.right))},execute:e=>N_(e,"COL"),isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSelectedZone(),s=e.model.getters.getHeaderGroupsInZone(t,"COL",o);return PR(e)&&!s.some((e=>e.start===o.left&&e.end===o.right))},icon:"o-spreadsheet-Icon.GROUP_COLUMNS"},F_={name:e=>{const t=e.model.getters.getSelectedZone();return t.top===t.bottom?Fo("Group row %s",String(t.top+1)):Fo("Group rows %s - %s",String(t.top+1),String(t.bottom+1))},execute:e=>N_(e,"ROW"),isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSelectedZone(),s=e.model.getters.getHeaderGroupsInZone(t,"ROW",o);return PR(e)&&!s.some((e=>e.start===o.top&&e.end===o.bottom))},icon:"o-spreadsheet-Icon.GROUP_ROWS"},M_={name:e=>{const t=e.model.getters.getSelectedZone();return t.left===t.right?Fo("Ungroup column %s",fo(t.left)):Fo("Ungroup columns %s - %s",fo(t.left),fo(t.right))},execute:e=>k_(e,"COL"),icon:"o-spreadsheet-Icon.UNGROUP_COLUMNS"},P_={name:e=>{const t=e.model.getters.getSelectedZone();return t.top===t.bottom?Fo("Ungroup row %s",String(t.top+1)):Fo("Ungroup rows %s - %s",String(t.top+1),String(t.bottom+1))},execute:e=>k_(e,"ROW"),icon:"o-spreadsheet-Icon.UNGROUP_ROWS"};function N_(e,t){const o=e.model.getters.getSelectedZone(),s=e.model.getters.getActiveSheetId();e.model.dispatch("GROUP_HEADERS",{sheetId:s,dimension:t,start:"COL"===t?o.left:o.top,end:"COL"===t?o.right:o.bottom})}function k_(e,t){const o=e.model.getters.getSelectedZone(),s=e.model.getters.getActiveSheetId();e.model.dispatch("UNGROUP_HEADERS",{sheetId:s,dimension:t,start:"COL"===t?o.left:o.top,end:"COL"===t?o.right:o.bottom})}function L_(e,t){const o=e.model.getters.getActiveSheetId(),s=e.model.getters.getSelectedZones();return 1===s.length&&e.model.getters.getHeaderGroupsInZone(o,t,s[0]).length>0}const V_=new CI;V_.add("cut",{...UR,sequence:10}).add("copy",{...HR,sequence:20}).add("paste",{...BR,sequence:30}).add("paste_special",{...zR,sequence:40,separator:!0}).addChild("paste_value_only",["paste_special"],{...$R,sequence:10}).addChild("paste_format_only",["paste_special"],{...WR,sequence:20}).add("sort_columns",{...YT,name:e=>e.model.getters.getActiveCols().size>1?Fo("Sort columns"):Fo("Sort column"),sequence:50,separator:!0}).addChild("sort_ascending",["sort_columns"],{...XT,sequence:10}).addChild("sort_descending",["sort_columns"],{...eA,sequence:20}).add("add_column_before",{...mT,sequence:70}).add("add_column_after",{...bT,sequence:80}).add("delete_column",{...XR,sequence:90,icon:"o-spreadsheet-Icon.TRASH"}).add("clear_column",{...JR,sequence:100,icon:"o-spreadsheet-Icon.CLEAR"}).add("hide_columns",{...u_,sequence:105,separator:!0}).add("unhide_columns",{...g_,sequence:106,separator:!0}).add("conditional_formatting",{...t_,sequence:110,separator:!0}).add("edit_table",{...sT,isVisible:FR,sequence:120}).add("delete_table",{...iT,isVisible:FR,sequence:125,separator:!0}).add("group_columns",{sequence:150,...O_}).add("ungroup_columns",{sequence:155,...M_,isVisible:e=>L_(e,"COL")});const H_=new n;H_.add("format_number_automatic",{...lA,id:"format_number_automatic",sequence:10}).add("format_number_plain_text",{...cA,id:"format_number_plain_text",sequence:15,separator:!0}).add("format_number_number",{...hA,id:"format_number_number",sequence:20}).add("format_number_percent",{...uA,id:"format_number_percent",sequence:30,separator:!0}).add("format_number_currency",{...gA,id:"format_number_currency",sequence:40}).add("format_number_accounting",{...mA,id:"format_number_accounting",sequence:45}).add("format_number_currency_rounded",{...pA,id:"format_number_currency_rounded",sequence:50}).add("format_custom_currency",{...vA,id:"format_custom_currency",sequence:60,separator:!0}).add("format_number_date",{...bA,id:"format_number_date",sequence:70}).add("format_number_time",{...SA,id:"format_number_time",sequence:80}).add("format_number_date_time",{...yA,id:"format_number_date_time",sequence:90}).add("format_number_duration",{...CA,id:"format_number_duration",sequence:100,separator:!0}).add("more_formats",{...EA,id:"more_formats",sequence:120});const U_=Et((e=>rr(e)?"date":e.includes("[$")?"currency":"number")),B_={name:Fo("More formats"),icon:"o-spreadsheet-Icon.NUMBER_FORMATS",children:[e=>{const t=function(e){const t=new Set(H_.getAll().map((t=>"function"==typeof t.format?t.format(e):t.format))),o=new Map;for(const s of e.model.getters.getSheetIds()){const i=e.model.getters.getEvaluatedCells(s);for(const e in i){const s=i[e];if(s.format&&!o.has(s.format)&&!t.has(s.format)){const e=U_(s.format);"date"!==e&&"currency"!==e||o.set(s.format,aA({descriptionValue:"currency"===e?1e3:fA,format:s.format,name:s.format}))}}}return[...o.values()]}(e).map((e=>({...e,sequence:110})));return t.length>0&&(t[t.length-1].separator=!0),o([...H_.getAll(),...t])}]},z_=new CI;function $_(e,t){const o=e.getActiveSheetId(),s=function(e,t){const o=[],s=e.getActiveSheetId();for(const i of e.getSheetViewVisibleCols())for(const n of e.getSheetViewVisibleRows()){const r={sheetId:s,col:i,row:n};t===e.getPivotIdFromPosition(r)&&o.push(r)}return o}(e,t);return Cs(s.map(fs)).map((e=>({sheetId:o,zone:e,noFill:!0,color:a})))}z_.add("cut",{...UR,sequence:10}).add("copy",{...HR,sequence:20}).add("paste",{...BR,sequence:30}).add("paste_special",{...zR,sequence:40,separator:!0}).addChild("paste_value_only",["paste_special"],{...$R,sequence:10}).addChild("paste_format_only",["paste_special"],{...WR,sequence:20}).add("add_row_before",{...cT,sequence:50}).add("add_row_after",{...uT,sequence:60}).add("delete_row",{...ZR,sequence:70,icon:"o-spreadsheet-Icon.TRASH"}).add("clear_row",{...YR,sequence:80,icon:"o-spreadsheet-Icon.CLEAR"}).add("hide_rows",{...m_,sequence:85,separator:!0}).add("unhide_rows",{...f_,sequence:86,separator:!0}).add("conditional_formatting",{...t_,sequence:90,separator:!0}).add("group_rows",{sequence:100,...F_}).add("ungroup_rows",{sequence:110,...P_,isVisible:e=>L_(e,"ROW")});const W_=new CI;W_.add("file",{name:Fo("File"),sequence:10}).addChild("settings",["file"],{name:Fo("Settings"),sequence:100,execute:e=>e.openSidePanel("Settings"),icon:"o-spreadsheet-Icon.COG"}).add("edit",{name:Fo("Edit"),sequence:20}).addChild("undo",["edit"],{...LR,sequence:10}).addChild("redo",["edit"],{...VR,sequence:20,separator:!0}).addChild("copy",["edit"],{...HR,sequence:30}).addChild("cut",["edit"],{...UR,sequence:40}).addChild("paste",["edit"],{...BR,sequence:50}).addChild("paste_special",["edit"],{...zR,sequence:60,separator:!0}).addChild("paste_special_value",["edit","paste_special"],{...$R,sequence:10}).addChild("paste_special_format",["edit","paste_special"],{...WR,sequence:20}).addChild("edit_table",["edit"],{...sT,isVisible:FR,sequence:60}).addChild("find_and_replace",["edit"],{...GR,sequence:65,separator:!0}).addChild("delete",["edit"],{name:Fo("Delete"),icon:"o-spreadsheet-Icon.TRASH",sequence:70}).addChild("edit_delete_cell_values",["edit","delete"],{...qR,sequence:10}).addChild("edit_delete_row",["edit","delete"],{...ZR,sequence:20}).addChild("edit_delete_column",["edit","delete"],{...XR,sequence:30}).addChild("edit_delete_cell_shift_up",["edit","delete"],{...eT,sequence:40}).addChild("edit_delete_cell_shift_left",["edit","delete"],{...tT,sequence:50}).addChild("edit_unhide_columns",["edit"],{...p_,sequence:80}).addChild("edit_unhide_rows",["edit"],{...v_,sequence:80}).add("view",{name:Fo("View"),sequence:30}).addChild("unfreeze_panes",["view"],{...b_,sequence:4}).addChild("freeze_panes",["view"],{...S_,sequence:5}).addChild("unfreeze_rows",["view","freeze_panes"],{...y_,sequence:5}).addChild("freeze_first_row",["view","freeze_panes"],{...C_,sequence:10}).addChild("freeze_second_row",["view","freeze_panes"],{...w_,sequence:15}).addChild("freeze_current_row",["view","freeze_panes"],{...x_,sequence:20,separator:!0}).addChild("unfreeze_columns",["view","freeze_panes"],{...E_,sequence:25}).addChild("freeze_first_col",["view","freeze_panes"],{...I_,sequence:30}).addChild("freeze_second_col",["view","freeze_panes"],{...R_,sequence:35}).addChild("freeze_current_col",["view","freeze_panes"],{...T_,sequence:40}).addChild("group_headers",["view"],{name:Fo("Group"),sequence:15,separator:!0,icon:"o-spreadsheet-Icon.PLUS_IN_BOX",isVisible:PR}).addChild("group_columns",["view","group_headers"],{...O_,sequence:5}).addChild("ungroup_columns",["view","group_headers"],{...M_,isVisible:e=>L_(e,"COL"),sequence:10}).addChild("group_rows",["view","group_headers"],{...F_,sequence:15}).addChild("ungroup_rows",["view","group_headers"],{...P_,isVisible:e=>L_(e,"ROW"),sequence:20}).addChild("show",["view"],{name:Fo("Show"),sequence:1,icon:"o-spreadsheet-Icon.SHOW"}).addChild("view_gridlines",["view","show"],{...A_,sequence:5}).addChild("view_formulas",["view","show"],{...D_,sequence:10}).addChild("view_irregularity_map",["view"],{...__,sequence:40,separator:!0}).add("insert",{name:Fo("Insert"),sequence:40}).addChild("insert_row",["insert"],{...lT,sequence:10}).addChild("insert_row_before",["insert","insert_row"],{...hT,sequence:10}).addChild("insert_row_after",["insert","insert_row"],{...gT,sequence:20}).addChild("insert_column",["insert"],{...pT,sequence:20}).addChild("insert_column_before",["insert","insert_column"],{...fT,sequence:10}).addChild("insert_column_after",["insert","insert_column"],{...ST,sequence:20}).addChild("insert_cell",["insert"],{...yT,sequence:30}).addChild("insert_cell_down",["insert","insert_cell"],{...CT,name:Fo("Shift down"),sequence:10}).addChild("insert_cell_right",["insert","insert_cell"],{...wT,name:Fo("Shift right"),sequence:20}).addChild("insert_sheet",["insert"],{...LT,sequence:40,separator:!0}).addChild("insert_chart",["insert"],{...xT,sequence:50}).addChild("insert_pivot",["insert"],{...ET,sequence:52}).addChild("insert_image",["insert"],{...IT,sequence:55}).addChild("insert_table",["insert"],{...RT,sequence:57}).addChild("insert_function",["insert"],{...TT,sequence:60}).addChild("insert_function_sum",["insert","insert_function"],{...AT,sequence:0}).addChild("insert_function_average",["insert","insert_function"],{..._T,sequence:10}).addChild("insert_function_count",["insert","insert_function"],{...DT,sequence:20}).addChild("insert_function_max",["insert","insert_function"],{...OT,sequence:30}).addChild("insert_function_min",["insert","insert_function"],{...FT,sequence:40,separator:!0}).addChild("categorie_function_all",["insert","insert_function"],{...MT,sequence:50}).addChild("categories_function_list",["insert","insert_function"],(()=>{const e=$b.content;return[...new Set($b.getAll().filter((e=>!e.hidden)).map((e=>e.category)))].filter(at).sort().map(((t,o)=>{const s=Object.keys(e).filter((o=>e[o].category===t&&!e[o].hidden));return{name:t,children:VT(s)}}))})).addChild("insert_link",["insert"],{...PT,separator:!0,sequence:70}).addChild("insert_checkbox",["insert"],{...NT,sequence:80}).addChild("insert_dropdown",["insert"],{...kT,separator:!0,sequence:90}).add("format",{name:Fo("Format"),sequence:50}).addChild("format_number",["format"],{...B_,name:Fo("Number"),sequence:10,separator:!0}).addChild("format_bold",["format"],{...PA,sequence:20}).addChild("format_italic",["format"],{...NA,sequence:30}).addChild("format_underline",["format"],{...kA,sequence:40}).addChild("format_strikethrough",["format"],{...LA,sequence:50,separator:!0}).addChild("format_font_size",["format"],{...VA,sequence:60,separator:!0}).addChild("format_alignment",["format"],{...HA,sequence:70}).addChild("format_alignment_left",["format","format_alignment"],{...BA,sequence:10}).addChild("format_alignment_center",["format","format_alignment"],{...zA,sequence:20}).addChild("format_alignment_right",["format","format_alignment"],{...$A,sequence:30,separator:!0}).addChild("format_alignment_top",["format","format_alignment"],{...GA,sequence:40}).addChild("format_alignment_middle",["format","format_alignment"],{...qA,sequence:50}).addChild("format_alignment_bottom",["format","format_alignment"],{...ZA,sequence:60,separator:!0}).addChild("format_wrapping",["format"],{...jA,sequence:80,separator:!0}).addChild("format_wrapping_overflow",["format","format_wrapping"],{...XA,sequence:10}).addChild("format_wrapping_wrap",["format","format_wrapping"],{...KA,sequence:20}).addChild("format_wrapping_clip",["format","format_wrapping"],{...JA,sequence:30}).addChild("format_cf",["format"],{...t_,sequence:90,separator:!0}).addChild("format_clearFormat",["format"],{...o_,sequence:100,separator:!0}).add("data",{name:Fo("Data"),sequence:60}).addChild("sort_range",["data"],{...YT,sequence:10,separator:!0}).addChild("sort_ascending",["data","sort_range"],{...XT,sequence:10}).addChild("sort_descending",["data","sort_range"],{...eA,sequence:20}).addChild("data_cleanup",["data"],{...KT,sequence:15}).addChild("remove_duplicates",["data","data_cleanup"],{...JT,sequence:10}).addChild("trim_whitespace",["data","data_cleanup"],{...QT,sequence:20}).addChild("split_to_columns",["data"],{...sA,sequence:20}).addChild("data_validation",["data"],{name:Fo("Data Validation"),execute:e=>{e.openSidePanel("DataValidation")},icon:"o-spreadsheet-Icon.DATA_VALIDATION",sequence:30,separator:!0}).addChild("add_remove_data_filter",["data"],{...tA,sequence:40,separator:!0}).addChild("data_sources_data",["data"],(e=>e.model.getters.getPivotIds().map(((t,o)=>{const s={get highlights(){return $_(e.model.getters,t)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:50+o,isReadonlyAllowed:!0,execute:e=>e.openSidePanel("PivotSidePanel",{pivotId:t}),onStartHover:e=>e.getStore(Xb).register(s),onStopHover:e=>e.getStore(Xb).unRegister(s),icon:"o-spreadsheet-Icon.PIVOT",separator:o===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(t)?"o-spreadsheet-Icon.UNUSED_PIVOT_WARNING":void 0}})))).addChild("reinsert_dynamic_pivot",["data"],iA).addChild("reinsert_static_pivot",["data"],nA);const G_=new class extends n{addTransformation(e,t,o){for(let s of t)this.content[s]||(this.content[s]=new Map),this.content[s].set(e,o);return this}getTransformation(e,t){return this.content[e]&&this.content[e].get(t)}};class q_ extends t.Component{static template="o_spreadsheet.Section";static props={class:{type:String,optional:!0},title:{type:String,optional:!0},slots:Object}}function Z_(e,t,o=(()=>{})){const s=()=>{window.removeEventListener("pointerdown",o),window.removeEventListener("pointerup",i),window.removeEventListener("dragstart",n),window.removeEventListener("pointermove",e),window.removeEventListener("wheel",e)},i=e=>{t(e),s()};function n(e){e.preventDefault()}return window.addEventListener("pointerdown",o),window.addEventListener("pointerup",i),window.addEventListener("dragstart",n),window.addEventListener("pointermove",e),window.addEventListener("wheel",e,{passive:!1}),s}function j_(e,t,o,s=!1){let i,n,r,a,l,c=null;const h=e.model.getters,d=h.getActiveSheetId(),u=oR();let g,p;const m=o=>{if(i=o,c)return;const{x:r,y:f}=h.getMainViewportCoordinates();let{top:v,left:b,bottom:S,right:y}=h.getActiveMainViewport(),{scrollX:C,scrollY:w}=h.getActiveSheetDOMScrollInfo();const{xSplit:x,ySplit:E}=h.getPaneDivisions(d);let I=!1,R=140;const T=i.clientX-u.left;if(g=h.getColIndex(T),"vertical"!==s){const t=n.clientX-u.left,o=h.getEdgeScrollCol(T,t,a);if(o.canEdgeScroll){let t;switch(I=!0,R=Math.min(R,o.delay),o.direction){case"reset":g=x,t=x;break;case 1:g=y,t=b+1;break;case-1:for(g=b-1;e.model.getters.isColHidden(d,g);)g--;t=g}C=h.getColDimensions(d,t).start-r}}const A=i.clientY-u.top;if(p=h.getRowIndex(A),"horizontal"!==s){const t=n.clientY-u.top,o=h.getEdgeScrollRow(A,t,l);if(o.canEdgeScroll){let t;switch(I=!0,R=Math.min(R,o.delay),o.direction){case"reset":p=E,t=E;break;case 1:p=S,t=v+o.direction;break;case-1:for(p=v-1;e.model.getters.isRowHidden(d,p);)p--;t=p}w=e.model.getters.getRowDimensions(d,t).start-f}}I||(-1===p&&(p=A<0?0:h.getNumberRows(d)-1),-1===g&&T<0&&(g=T<0?0:h.getNumberCols(d)-1)),t(g,p,i),I&&(e.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:C,offsetY:w}),c=setTimeout((()=>{c=null,m(i)}),Math.round(R))),n=i};Z_(m,(()=>{clearTimeout(c),o()}),(e=>{n=e,r=e,a=r.clientX-u.left,l=r.clientY-u.top}))}function Y_(){let e;const o=document.body.style.cursor;let s=[];const i=()=>{e=void 0,document.body.style.cursor=o,s.forEach((e=>e())),s=[]};t.onWillUnmount((()=>{i()}));const n=t.useState({itemsStyle:{},draggedItemId:void 0,start:(t,r)=>{n.cancel=()=>{n.draggedItemId=void 0,n.itemsStyle={},document.body.style.cursor=o,r.onCancel?.(),i()};document.body.style.cursor="move",n.draggedItemId=r.draggedItemId;const a="horizontal"===t?new Q_(r.containerEl):new J_(r.containerEl);e=new X_({...r,container:a,onChange:()=>{document.body.style.cursor="move",e&&(Object.assign(n.itemsStyle,e.getItemStyles()),r.onChange?.())},onDragEnd:(e,t)=>{n.draggedItemId=void 0,n.itemsStyle={},document.body.style.cursor=o,r.onDragEnd?.(e,t),i()},onCancel:n.cancel});const l=Z_(e.onMouseMove.bind(e),e.onMouseUp.bind(e));s.push(l);const c=e.onScroll.bind(e);r.containerEl.addEventListener("scroll",c),s.push((()=>r.containerEl.removeEventListener("scroll",c))),s.push(e.destroy.bind(e))},cancel:()=>{}});return n}class X_{draggedItemId;items;container;initialMousePosition;currentMousePosition;initialScroll;minPosition;maxPosition;edgeScrollIntervalId;onChange;onCancel;onDragEnd;deadZone;constructor(e){this.items=e.items.map((e=>({...e,positionAtStart:e.position}))),this.draggedItemId=e.draggedItemId,this.container=e.container,this.onChange=e.onChange,this.onCancel=e.onCancel,this.onDragEnd=e.onDragEnd,this.initialMousePosition=e.initialMousePosition,this.currentMousePosition=e.initialMousePosition,this.initialScroll=this.container.scroll,this.minPosition=this.items[0].position,this.maxPosition=this.items[this.items.length-1].position+this.items[this.items.length-1].size}getItemStyles(){const e={};for(let t of this.items)e[t.id]=this.getItemStyle(t.id);return e}getItemStyle(e){const t=this.container.cssPositionProperty,o={position:"relative"};return o[t]=(this.getItemsPositions()[e]||0)+"px",o.transition=`${t} 0.5s`,o["pointer-events"]="none",this.draggedItemId===e&&(o.transition=`${t} 0s`,o["z-index"]="1000"),kc(o)}onScroll(){this.moveDraggedItemToPosition(this.currentMousePosition+this.scrollOffset)}onMouseMove(e){if(e.button>1)return void this.onCancel();const t=this.container.getMousePosition(e);this.currentMousePosition=t,t<this.container.start||t>this.container.end?this.startEdgeScroll(t<this.container.start?-1:1):(this.stopEdgeScroll(),this.moveDraggedItemToPosition(t+this.scrollOffset))}moveDraggedItemToPosition(e){const t=this.getHoveredItemIndex(e,this.items),o=this.items.findIndex((e=>e.id===this.draggedItemId)),s=this.items[o];if(this.deadZone&&this.isInZone(e,this.deadZone))return void this.onChange(this.getItemsPositions());if(this.isInZone(e,{start:s.position,end:s.position+s.size})&&(this.deadZone=void 0),o===t)return void this.onChange(this.getItemsPositions());const i=Math.min(o,t),n=Math.max(o,t),r=Math.sign(t-o);let a=0;for(let e=i;e<=n;e++)e!==o&&(this.items[e].position-=r*s.size,a+=this.items[e].size);s.position+=r*a,this.items.sort(((e,t)=>e.position-t.position)),this.deadZone=r>0?{start:e,end:s.position}:{start:s.position+s.size,end:e},this.onChange(this.getItemsPositions())}onMouseUp(e){0!==e.button&&this.onCancel(),e.stopPropagation(),e.preventDefault();const t=this.items.findIndex((e=>e.id===this.draggedItemId));return this.onDragEnd(this.draggedItemId,t),this.stopEdgeScroll(),!1}startEdgeScroll(e){this.edgeScrollIntervalId||(this.edgeScrollIntervalId=window.setInterval((()=>{const t=3*e;this.container.scroll+=t}),5))}stopEdgeScroll(){window.clearInterval(this.edgeScrollIntervalId),this.edgeScrollIntervalId=void 0}getHoveredItemIndex(e,t){return e<=this.minPosition?0:e>=this.maxPosition?t.length-1:t.findIndex((t=>t.position+t.size>=e))}getItemsPositions(){const e={};for(let t of this.items){if(t.id!==this.draggedItemId){e[t.id]=t.position-t.positionAtStart;continue}let o=this.currentMousePosition-this.initialMousePosition+this.scrollOffset;o=Math.max(this.minPosition-t.positionAtStart,o),o=Math.min(this.maxPosition-t.positionAtStart-t.size,o),e[t.id]=o}return e}isInZone(e,t){return e>=t.start&&e<=t.end}get scrollOffset(){return this.container.scroll-this.initialScroll}destroy(){this.stopEdgeScroll()}}class K_{el;constructor(e){this.el=e}get containerRect(){return this.el.getBoundingClientRect()}}class J_ extends K_{get start(){return this.containerRect.top}get end(){return this.containerRect.bottom}get cssPositionProperty(){return"top"}get scroll(){return this.el.scrollTop}set scroll(e){this.el.scrollTop=e}getMousePosition(e){return e.clientY}}class Q_ extends K_{get start(){return this.containerRect.left}get end(){return this.containerRect.right}get cssPositionProperty(){return"left"}get scroll(){return this.el.scrollLeft}set scroll(e){this.el.scrollLeft=e}getMousePosition(e){return e.clientX}}const eD={ArrowDown:"down",ArrowLeft:"left",ArrowRight:"right",ArrowUp:"up"};function tD(e,t){const o=eD[e.key];e.shiftKey?t.resizeAnchorZone(o,hR(e)?"end":1):t.moveAnchorCell(o,hR(e)?"end":1)}class oD{mutators=["focus","unfocus"];focusedElement=null;focus(e){this.focusedElement=e}unfocus(e){this.focusedElement&&this.focusedElement===e&&(this.focusedElement=null)}}class sD extends Ac{initialRanges;inputHasSingleRange;colors;mutators=["resetWithRanges","focusById","unfocus","addEmptyRange","removeRange","changeRange","reset","confirm","updateColors"];ranges=[];focusedRangeIndex=null;inputSheetId;focusStore=this.get(oD);highlightStore=this.get(Xb);constructor(e,t=[],o=!1,s=[]){if(super(e),this.initialRanges=t,this.inputHasSingleRange=o,this.colors=s,o&&t.length>1)throw new Error("Input with a single range cannot be instantiated with several range references.");this.inputSheetId=this.getters.getActiveSheetId(),this.resetWithRanges(t),this.highlightStore.register(this),this.onDispose((()=>{this.unfocus(),this.highlightStore.unRegister(this)}))}handleEvent(e){if(null===this.focusedRangeIndex)return;const t=this.inputSheetId,o=this.getters.getActiveSheetId(),s=e.options.unbounded?this.getters.getUnboundedZone(o,e.anchor.zone):e.anchor.zone,i=this.getters.getRangeFromZone(o,s);if("newAnchor"===e.mode&&!this.inputHasSingleRange&&""!==this.ranges[this.focusedRangeIndex].xc.trim()){const e=this.getters.getSelectionRangeString(i,t);this.insertNewRange(this.ranges.length,[e]),this.focusLast()}else{let e=i.parts;const o=this.ranges[this.focusedRangeIndex].xc.trim();o&&(e=this.getters.getRangeFromSheetXC(t,o).parts);const s=i.clone({parts:e}),n=this.getters.getSelectionRangeString(s,t);this.setRange(this.focusedRangeIndex,[n])}}handle(e){switch(e.type){case"ACTIVATE_SHEET":if(e.sheetIdFrom!==e.sheetIdTo){const{col:t,row:o}=this.getters.getNextVisibleCellPosition({sheetId:e.sheetIdTo,col:0,row:0}),s=this.getters.expandZone(e.sheetIdTo,fs({col:t,row:o}));this.model.selection.resetAnchor(this,{cell:{col:t,row:o},zone:s})}break;case"START_CHANGE_HIGHLIGHT":const t=this.getters.getActiveSheetId(),o=this.getters.expandZone(t,e.zone),s=this.ranges.findIndex((e=>{const{xc:s,sheetName:i}=qo(e.xc),n=i||this.getters.getSheetName(this.inputSheetId);if(this.getters.getSheetName(t)!==n)return!1;const r=this.getters.getRangeFromSheetXC(t,s);return ns(this.getters.expandZone(t,r.zone),o)}));if(-1!==s){this.focus(s);const{left:e,top:t}=o;this.model.selection.resetAnchor(this,{cell:{col:e,row:t},zone:o})}}}changeRange(e,t){if(this.inputHasSingleRange&&t.split(",").length>1)return;const o=this.getIndex(e);if(null!==o&&this.focusedRangeIndex!==o&&this.focus(o),null!==o){const e=t.replace(/^,+/,"").split(",").map((e=>e.trim()));this.setRange(o,e),this.captureSelection()}}addEmptyRange(){this.inputHasSingleRange&&1===this.ranges.length||(this.insertNewRange(this.ranges.length,[""]),this.focusLast())}removeRange(e){if(1===this.ranges.length)return;const t=this.getIndex(e);null!==t&&this.removeRangeByIndex(t)}updateColors(e){this.colors=e}confirm(){for(const e of this.selectionInputs)""===e.xc&&this.removeRange(e.id);const e=this.getters.getActiveSheetId();this.inputSheetId!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:this.inputSheetId}),this.selectionInputValues.join()!==this.initialRanges.join()&&this.resetWithRanges(this.selectionInputValues),this.initialRanges=this.selectionInputValues,this.unfocus()}reset(){this.resetWithRanges(this.initialRanges),this.confirm()}get selectionInputValues(){return this.cleanInputs(this.ranges.map((e=>e.xc?e.xc:"")))}get selectionInputs(){const e=new ho(this.ranges.length,this.colors);return this.ranges.map(((t,o)=>Object.assign({},t,{color:this.hasMainFocus&&null!==this.focusedRangeIndex&&this.getters.isRangeValid(t.xc)?e.next():null,isFocused:this.hasMainFocus&&this.focusedRangeIndex===o,isValidRange:""===t.xc||this.getters.isRangeValid(t.xc)})))}get isResettable(){return this.initialRanges.join()!==this.ranges.map((e=>e.xc)).join()}get isConfirmable(){return this.selectionInputs.every((e=>e.isValidRange))}get hasFocus(){return this.selectionInputs.some((e=>e.isFocused))}get hasMainFocus(){const e=this.focusStore.focusedElement;return!!e&&e===this}get highlights(){return this.hasMainFocus?this.ranges.map((e=>this.inputToHighlights(e))).flat():[]}focusById(e){this.focus(this.getIndex(e))}focus(e){this.focusStore.focus(this),this.focusedRangeIndex=e,this.captureSelection()}focusLast(){this.focus(this.ranges.length-1)}unfocus(){this.focusedRangeIndex=null,this.focusStore.unfocus(this),this.model.selection.release(this)}captureSelection(){if(null===this.focusedRangeIndex)return;const e=this.ranges[this.focusedRangeIndex],t=this.getters.getActiveSheetId(),o=this.getters.getRangeFromSheetXC(t,e?.xc||"A1").zone;this.model.selection.capture(this,{cell:{col:o.left,row:o.top},zone:o},{handleEvent:this.handleEvent.bind(this),release:this.unfocus.bind(this)})}resetWithRanges(e){this.ranges=[],this.insertNewRange(0,e),0===this.ranges.length&&(this.insertNewRange(this.ranges.length,[""]),this.focusLast())}setContent(e,t){this.ranges[e]={...this.ranges[e],xc:t}}insertNewRange(e,t){const o=Math.max(0,...this.ranges.map((e=>Number(e.id)))),s=new ho(this.ranges.length,this.colors);for(let t=0;t<e;t++)s.next();this.ranges.splice(e,0,...t.map(((e,t)=>({xc:e,id:o+t+1,color:s.next()}))))}setRange(e,t){const[,...o]=t;this.setContent(e,t[0]),this.insertNewRange(e+1,o),o.length&&this.focus(e+o.length)}removeRangeByIndex(e){this.ranges.splice(e,1),null!==this.focusedRangeIndex&&this.focusLast()}inputToHighlights({xc:e,color:t}){const o=this.cleanInputs([e]).filter((e=>this.getters.isRangeValid(e))).filter((e=>this.shouldBeHighlighted(this.inputSheetId,e)));return o.map((e=>{const{sheetName:o}=qo(e);return{zone:this.getters.getRangeFromSheetXC(this.inputSheetId,e).zone,sheetId:o&&this.getters.getSheetIdByName(o)||this.inputSheetId,color:t,interactive:!0}}))}cleanInputs(e){return e.map((e=>e.split(","))).flat().map((e=>e.trim())).filter((e=>""!==e))}shouldBeHighlighted(e,t){const{sheetName:o}=qo(t),s=this.getters.getSheetIdByName(o),i=this.getters.getActiveSheet().id;return this.getters.isRangeValid(t)&&(s===i||void 0===s&&i===e)}getIndex(e){const t=this.ranges.findIndex((t=>t.id===e));return t>=0?t:null}}Mc`
|
|
292
|
+
`;class uR extends t.Component{static template="o-spreadsheet-LinkEditor";static props={cellPosition:Object,onClosed:{type:Function,optional:!0}};static components={Menu:dR};menuItems=JI.getMenuItems();link=t.useState(this.defaultState);menu=t.useState({isOpen:!1});linkEditorRef=t.useRef("linkEditor");position=DI(this.linkEditorRef);urlInput=t.useRef("urlInput");setup(){t.onMounted((()=>this.urlInput.el?.focus()))}get defaultState(){const{col:e,row:t}=this.props.cellPosition,o=this.env.model.getters.getActiveSheetId(),s=this.env.model.getters.getEvaluatedCell({sheetId:o,col:e,row:t});return s.link?{url:s.link.url,label:s.formattedValue,isUrlEditable:s.link.isUrlEditable}:{label:s.formattedValue,url:"",isUrlEditable:!0}}get menuPosition(){return{x:this.position.x+320-12-2,y:this.position.y+100}}onSpecialLink(e){const{detail:t}=e,o=An(t);o&&(this.link.url=o.url,this.link.label=o.label,this.link.isUrlEditable=o.isUrlEditable)}getUrlRepresentation(e){return Rn(e,this.env.model.getters)}openMenu(){this.menu.isOpen=!0}removeLink(){this.link.url="",this.link.isUrlEditable=!0}save(){const{col:e,row:t}=this.props.cellPosition,o=this.env.model.getters.getLocale(),s=this.link.label?Da(this.link.label,o):this.link.url;this.env.model.dispatch("UPDATE_CELL",{col:e,row:t,sheetId:this.env.model.getters.getActiveSheetId(),content:tt(s,this.link.url)}),this.props.onClosed?.()}cancel(){this.props.onClosed?.()}onKeyDown(e){switch(e.key){case"Enter":this.link.url&&this.save(),e.stopPropagation(),e.preventDefault();break;case"Escape":this.cancel(),e.stopPropagation()}}}const gR={onOpen:(e,t)=>({isOpen:!0,props:{cellPosition:e},Component:uR,cellCorner:"BottomLeft"})};function pR(e){const t=aI.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o,s,i){const n=t.find((e=>e.match(s.type)));if(!n)throw new Error(`No builder for this chart: ${s.type}`);return n.createChart(s,i,e)}}function mR(e){const t=aI.getAll().sort(((e,t)=>e.sequence-t.sequence));return function(o){const s=t.find((e=>e.match(o.type)));if(!s)throw new Error("No runtime builder for this chart.");return s.getChartRuntime(o,e)}}function fR(e,t){const o=aI.getAll().find((e=>e.match(t.type)));if(!o)throw new Error("Unknown chart type.");return o.validateChartDefinition(e,t)}function vR(e,t){const o=aI.getAll().find((t=>t.match(e.type)));if(!o)throw new Error("Unknown chart type.");return o.transformDefinition(e,t)}function bR(e,t){const o=t.getActiveSheetId();let s=e;const i=1===cs(e).numberOfCols;i||(s={...e,left:e.left+1});const n=Jo(t.getUnboundedZone(o,s)),r=[{dataRange:n,yAxisId:"y"}],a=t.getCell({sheetId:o,col:e.left,row:e.top});if(1===Ss(e)&&a?.content)return{type:"scorecard",title:{},background:a.style?.fillColor||void 0,keyValue:Jo(e),baselineMode:xe,baselineColorUp:Ee,baselineColorDown:Ie};const l=!!t.getEvaluatedCellsInZone(o,{...s,bottom:s.top}).find((e=>e.type!==ni.empty&&e.type!==ni.number));let c;i||(c=Jo(t.getUnboundedZone(o,{...e,right:e.left})));const h=s.right===s.left?"none":"top";if(Px(c?t.getRangeFromSheetXC(o,c):void 0,t))return{title:{},dataSets:r,labelsAsText:!1,stacked:!1,aggregated:!1,cumulative:!1,labelRange:c,type:"line",dataSetsHaveTitle:l,legendPosition:h};const d=zc(t,r,o,l);return i&&Vx(t,d[0]).every((e=>"string"==typeof e&&!ki(e)))?{title:{},dataSets:[{dataRange:n}],aggregated:!0,labelRange:n,type:"pie",legendPosition:"top",dataSetsHaveTitle:!1}:{title:{},dataSets:r,labelRange:c,type:"bar",stacked:!1,aggregated:!1,dataSetsHaveTitle:l,legendPosition:h}}FS.add("ErrorToolTip",kI).add("LinkCell",$I).add("LinkEditor",gR).add("FilterMenu",BI);var SR=Object.freeze({__proto__:null,AbstractChart:dh,BarChart:UE,CHART_AXIS_CHOICES:oh,CHART_COMMON_OPTIONS:YS,GaugeChart:jE,LineChart:JE,PieChart:eI,ScorecardChart:bh,TREND_LINE_XAXIS_ID:Lc,WaterfallChart:nI,adaptChartRange:Bc,chartFactory:pR,chartFontColor:Zc,chartMutedFontColor:jc,chartRuntimeFactory:mR,chartToImage:XS,checkDataset:Yc,checkLabelRange:Xc,createBarChartRuntime:BE,createDataSets:zc,createGaugeChartRuntime:YE,createLineChartRuntime:QE,createPieChartRuntime:tI,createScorecardChartRuntime:yh,createWaterfallChartRuntime:rI,drawScoreChart:Sh,duplicateDataSetsInDuplicatedSheet:Hc,duplicateLabelRangeInDuplicatedSheet:Uc,formatChartDatasetValue:eh,formatTickValue:th,getChartPositionAtCenterOfViewport:Jc,getDefinedAxis:Qc,getPieColors:sh,getSmartChartDefinition:bR,shouldRemoveFirstLabel:Kc,toExcelDataset:Wc,toExcelLabelRange:Gc,transformChartDefinitionWithDataSetsWithZone:qc,transformDefinition:vR,truncateLabel:ih,updateChartRangesWithDataSets:Vc,validateChartDefinition:fR});function yR(e,t,o=QC){let s=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,s);1!==s.length||i||1!==Ss(s[0])||(e.model.selection.selectTableAroundSelection(),s=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,s));const n=s.map((o=>e.model.getters.getRangeDataFromZone(t,o))),r=e.model.dispatch("CREATE_TABLE",{ranges:n,sheetId:t,config:o,tableType:i?"dynamic":"static"});return r.isCancelledBecause("TableOverlap")?e.raiseError(Sx.Errors.TableOverlap):r.isCancelledBecause("NonContinuousTargets")&&e.raiseError(Sx.Errors.NonContinuousTargets),r}function CR(e,t){e.model.dispatch("SET_FORMATTING_WITH_PIVOT",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),format:t})}function wR(e,t){e.model.dispatch("SET_FORMATTING",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),style:t})}const xR=async e=>ER(e,"asValue");async function ER(e,t){const o=await e.clipboard.read();switch(o.status){case"ok":const s=ha(o.content),i=s.data?.clipboardId,n=e.model.getters.getSelectedZones();e.model.getters.getClipboardId()!==i?hx(e,n,s,t):cx(e,n,t),e.model.getters.isCutOperation()&&"asValue"!==t&&await e.clipboard.write({[ri.PlainText]:""});break;case"notImplemented":e.raiseError(Fo("Pasting from the context menu is not supported in this browser. Use keyboard shortcuts ctrl+c / ctrl+v instead."));break;case"permissionDenied":e.raiseError(Fo("Access to the clipboard denied by the browser. Please enable clipboard permission for this page in your browser settings."))}}const IR=(e,t)=>{const o=t.model.getters.getActiveSheetId(),s=t.model.getters.getElementsFromSelection(e),i=t.model.getters.checkElementsIncludeAllVisibleHeaders(o,e,s),n=t.model.getters.checkElementsIncludeAllNonFrozenHeaders(o,e,s);return!i&&!n},RR=e=>{const t=e.model.getters.getActiveRows();let o,s;if(t.size)o=Ot([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.top,s=t.bottom-t.top+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"before",base:o,quantity:s,dimension:"ROW"})},TR=e=>{const t=e.model.getters.getActiveCols();let o,s;if(t.size)o=Ot([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.left,s=t.right-t.left+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"before",dimension:"COL",base:o,quantity:s})},AR=e=>{const t=e.model.getters.getActiveCols();let o,s;if(t.size)o=Dt([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.right,s=t.right-t.left+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"after",dimension:"COL",base:o,quantity:s})};const _R=async e=>{if(e.imageProvider){const t=e.model.getters.getActiveSheetId(),o=e.model.uuidGenerator.uuidv4(),s=await async function(e){try{return await e.imageProvider.requestImage()}catch{return void e.raiseError(Fo("An unexpected error occurred during the image transfer"))}}(e);if(!s)throw new Error("No image provider was given to the environment");const i=pI(e.model.getters,s.size),n=function(e,t){const{x:o,y:s}=e.getMainViewportCoordinates(),{scrollX:i,scrollY:n}=e.getActiveSheetScrollInfo(),r=e.getSheetViewDimension(),a=e.getVisibleRect(e.getActiveMainViewport()),l=Math.min(a.width,r.width-o),c=Math.min(a.height,r.height-s);return{x:o+i+Math.max(0,(l-t.width)/2),y:s+n+Math.max(0,(c-t.height)/2)}}(e.model.getters,i);e.model.dispatch("CREATE_IMAGE",{sheetId:t,figureId:o,position:n,size:i,definition:s})}},DR=e=>{let{col:t,row:o}=e.model.getters.getActivePosition();e.getStore(II).open({col:t,row:o},"LinkEditor")},OR=e=>{const t=e.model.getters.getFirstTableInSelection();return t?.config.hasFilters||!1},FR=e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSelectedZones();return 1===e.model.getters.getTablesOverlappingZones(t,o).length},MR=e=>ys(e.model.getters.getSelectedZones()),PR=e=>1===e.model.getters.getSelectedZones().length,NR=(e,t)=>{if(!PR(e))return!1;const o="COL"===t?e.model.getters.getActiveCols():e.model.getters.getActiveRows(),s="COL"===t?e.model.getters.getActiveRows():e.model.getters.getActiveCols(),i=e.model.getters.getActiveSheetId(),n=ns(e.model.getters.getSelectedZone(),e.model.getters.getSheetZone(i));return xt(o)&&(0===s.size||n)},kR={name:e=>OR(e)?Fo("Remove selected filters"):Fo("Add filters"),isEnabled:e=>MR(e),execute:e=>OR(e)?(e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getFirstTableInSelection();o&&e.model.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{hasFilters:!1}})})(e):(e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getFirstTableInSelection();o?e.model.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{hasFilters:!0}}):yR(e,t,{...QC,hasFilters:!0,bandedRows:!1,styleId:"TableStyleLight11"})})(e),icon:"o-spreadsheet-Icon.FILTER_ICON_ACTIVE"},LR={name:Fo("Undo"),description:"Ctrl+Z",execute:e=>e.model.dispatch("REQUEST_UNDO"),isEnabled:e=>e.model.getters.canUndo(),icon:"o-spreadsheet-Icon.UNDO"},VR={name:Fo("Redo"),description:"Ctrl+Y",execute:e=>e.model.dispatch("REQUEST_REDO"),isEnabled:e=>e.model.getters.canRedo(),icon:"o-spreadsheet-Icon.REDO"},HR={name:Fo("Copy"),description:"Ctrl+C",isReadonlyAllowed:!0,execute:async e=>{e.model.dispatch("COPY"),await e.clipboard.write(e.model.getters.getClipboardContent())},icon:"o-spreadsheet-Icon.CLIPBOARD"},UR={name:Fo("Cut"),description:"Ctrl+X",execute:async e=>{wI(e),await e.clipboard.write(e.model.getters.getClipboardContent())},icon:"o-spreadsheet-Icon.CUT"},BR={name:Fo("Paste"),description:"Ctrl+V",execute:async e=>ER(e),icon:"o-spreadsheet-Icon.PASTE"},zR={name:Fo("Paste special"),isVisible:e=>!e.model.getters.isCutOperation(),icon:"o-spreadsheet-Icon.PASTE"},$R={name:Fo("Paste as value"),description:"Ctrl+Shift+V",execute:xR},WR={name:Fo("Paste format only"),execute:e=>ER(e,"onlyFormat")},GR={name:Fo("Find and replace"),description:"Ctrl+H",isReadonlyAllowed:!0,execute:e=>{e.openSidePanel("FindAndReplace",{})},icon:"o-spreadsheet-Icon.SEARCH"},qR={name:Fo("Delete values"),execute:e=>e.model.dispatch("DELETE_CONTENT",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()})},ZR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Delete rows");let t,o;const s=e.model.getters.getActiveRows();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.top,o=s.bottom}return t===o?Fo("Delete row %s",(t+1).toString()):Fo("Delete rows %s - %s",(t+1).toString(),(o+1).toString())},execute:e=>{let t=[...e.model.getters.getActiveRows()];if(!t.length){const o=e.model.getters.getSelectedZones()[0];for(let e=o.top;e<=o.bottom;e++)t.push(e)}e.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},isVisible:e=>IR("ROW",e)},jR={...ZR,isVisible:PR},YR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Clear rows");let t,o;const s=e.model.getters.getActiveRows();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.top,o=s.bottom}return t===o?Fo("Clear row %s",(t+1).toString()):Fo("Clear rows %s - %s",(t+1).toString(),(o+1).toString())},execute:e=>{const t=e.model.getters.getActiveSheetId(),o=[...e.model.getters.getActiveRows()].map((o=>e.model.getters.getRowsZone(t,o,o)));e.model.dispatch("DELETE_CONTENT",{target:o,sheetId:e.model.getters.getActiveSheetId()})}},XR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Delete columns");let t,o;const s=e.model.getters.getActiveCols();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.left,o=s.right}return t===o?Fo("Delete column %s",fo(t)):Fo("Delete columns %s - %s",fo(t),fo(o))},execute:e=>{let t=[...e.model.getters.getActiveCols()];if(!t.length){const o=e.model.getters.getSelectedZones()[0];for(let e=o.left;e<=o.right;e++)t.push(e)}e.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"COL",elements:t})},isVisible:e=>IR("COL",e)},KR={...XR,isVisible:PR},JR={name:e=>{if(e.model.getters.getSelectedZones().length>1)return Fo("Clear columns");let t,o;const s=e.model.getters.getActiveCols();if(0!==s.size)t=Ot([...s]),o=Dt([...s]);else{const s=e.model.getters.getSelectedZones()[0];t=s.left,o=s.right}return t===o?Fo("Clear column %s",fo(t)):Fo("Clear columns %s - %s",fo(t),fo(o))},execute:e=>{const t=e.model.getters.getActiveSheetId(),o=[...e.model.getters.getActiveCols()].map((o=>e.model.getters.getColsZone(t,o,o)));e.model.dispatch("DELETE_CONTENT",{target:o,sheetId:e.model.getters.getActiveSheetId()})}},QR={name:Fo("Delete cells"),isVisible:PR},eT={name:Fo("Delete cell and shift up"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("DELETE_CELL",{zone:t,shiftDimension:"ROW"});lx(e,o)}},tT={name:Fo("Delete cell and shift left"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("DELETE_CELL",{zone:t,shiftDimension:"COL"});lx(e,o)}},oT={name:Fo("Merge cells"),isEnabled:e=>!nT(e),isActive:e=>rT(e),execute:e=>function(e){if(nT(e))return;const t=e.model.getters.getSelectedZones(),o=[t[t.length-1]],s=e.model.getters.getActiveSheetId();rT(e)?e.model.dispatch("REMOVE_MERGE",{sheetId:s,target:o}):function(e,t,o){const s=e.model.dispatch("ADD_MERGE",{sheetId:t,target:o});s.isCancelledBecause("MergeInTable")?e.raiseError(xI.MergeInFilter):s.isCancelledBecause("MergeIsDestructive")&&e.askConfirmation(xI.MergeIsDestructive,(()=>{e.model.dispatch("ADD_MERGE",{sheetId:t,target:o,force:!0})}))}(e,s,o)}(e),icon:"o-spreadsheet-Icon.MERGE_CELL"},sT={name:()=>Fo("Edit table"),execute:e=>e.openSidePanel("TableSidePanel",{}),icon:"o-spreadsheet-Icon.EDIT_TABLE"},iT={name:()=>Fo("Delete table"),execute:e=>{const t=e.model.getters.getActivePosition(),o=e.model.getters.getTable(t);o&&e.model.dispatch("REMOVE_TABLE",{sheetId:t.sheetId,target:[o.range.zone]})},icon:"o-spreadsheet-Icon.DELETE_TABLE"};function nT(e){const t=e.model.getters.getSelectedZones(),{top:o,left:s,right:i,bottom:n}=e.model.getters.getSelectedZone(),{sheetId:r}=e.model.getters.getActivePosition(),{xSplit:a,ySplit:l}=e.model.getters.getPaneDivisions(r);return t.length>1||o===n&&s===i||s<a&&a<=i||o<l&&l<=n}function rT(e){if(!nT(e)){const t=e.model.getters.getSelectedZones(),{col:o,row:s,sheetId:i}=e.model.getters.getActivePosition(),n=e.model.getters.expandZone(i,fs({col:o,row:s}));return ns(t[0],n)}return!1}var aT=Object.freeze({__proto__:null,clearCols:JR,clearRows:YR,copy:HR,cut:UR,deleteCellShiftLeft:tT,deleteCellShiftUp:eT,deleteCells:QR,deleteCol:KR,deleteCols:XR,deleteRow:jR,deleteRows:ZR,deleteTable:iT,deleteValues:qR,editTable:sT,findAndReplace:GR,mergeCells:oT,paste:BR,pasteSpecial:zR,pasteSpecialFormat:WR,pasteSpecialValue:$R,redo:VR,undo:LR});const lT={name:e=>{const t=HT(e);return 1===t?Fo("Insert row"):Fo("Insert %s rows",t.toString())},isVisible:e=>NR(e,"ROW"),icon:"o-spreadsheet-Icon.INSERT_ROW"},cT={name:e=>{const t=HT(e);return 1===t?Fo("Insert row above"):Fo("Insert %s rows above",t.toString())},execute:RR,isVisible:e=>NR(e,"ROW"),icon:"o-spreadsheet-Icon.INSERT_ROW_BEFORE"},hT={...cT,name:e=>{const t=HT(e);return 1===t?Fo("Row above"):Fo("%s Rows above",t.toString())}},dT={...cT,name:e=>{const t=HT(e);return 1===t?Fo("Insert row"):Fo("Insert %s rows",t.toString())},isVisible:PR,icon:"o-spreadsheet-Icon.INSERT_ROW_BEFORE"},uT={execute:e=>{const t=e.model.getters.getActiveRows();let o,s;if(t.size)o=Dt([...t]),s=t.size;else{const t=e.model.getters.getSelectedZones()[0];o=t.bottom,s=t.bottom-t.top+1}e.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),position:"after",base:o,quantity:s,dimension:"ROW"})},name:e=>{const t=HT(e);return 1===t?Fo("Insert row below"):Fo("Insert %s rows below",t.toString())},isVisible:e=>NR(e,"ROW"),icon:"o-spreadsheet-Icon.INSERT_ROW_AFTER"},gT={...uT,name:e=>{const t=HT(e);return 1===t?Fo("Row below"):Fo("%s Rows below",t.toString())}},pT={name:e=>{const t=UT(e);return 1===t?Fo("Insert column"):Fo("Insert %s columns",t.toString())},isVisible:e=>NR(e,"COL"),icon:"o-spreadsheet-Icon.INSERT_COL"},mT={name:e=>{const t=UT(e);return 1===t?Fo("Insert column left"):Fo("Insert %s columns left",t.toString())},execute:TR,isVisible:e=>NR(e,"COL"),icon:"o-spreadsheet-Icon.INSERT_COL_BEFORE"},fT={...mT,name:e=>{const t=UT(e);return 1===t?Fo("Column left"):Fo("%s Columns left",t.toString())}},vT={...mT,name:e=>{const t=UT(e);return 1===t?Fo("Insert column"):Fo("Insert %s columns",t.toString())},isVisible:PR,icon:"o-spreadsheet-Icon.INSERT_COL_BEFORE"},bT={name:e=>{const t=UT(e);return 1===t?Fo("Insert column right"):Fo("Insert %s columns right",t.toString())},execute:AR,isVisible:e=>NR(e,"COL"),icon:"o-spreadsheet-Icon.INSERT_COL_AFTER"},ST={...bT,name:e=>{const t=UT(e);return 1===t?Fo("Column right"):Fo("%s Columns right",t.toString())},execute:AR},yT={name:Fo("Insert cells"),isVisible:e=>PR(e)&&0===e.model.getters.getActiveCols().size&&0===e.model.getters.getActiveRows().size,icon:"o-spreadsheet-Icon.INSERT_CELL"},CT={name:Fo("Insert cells and shift down"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("INSERT_CELL",{zone:t,shiftDimension:"ROW"});lx(e,o)},isVisible:e=>0===e.model.getters.getActiveRows().size&&0===e.model.getters.getActiveCols().size,icon:"o-spreadsheet-Icon.INSERT_CELL_SHIFT_DOWN"},wT={name:Fo("Insert cells and shift right"),execute:e=>{const t=e.model.getters.getSelectedZone(),o=e.model.dispatch("INSERT_CELL",{zone:t,shiftDimension:"COL"});lx(e,o)},isVisible:e=>0===e.model.getters.getActiveRows().size&&0===e.model.getters.getActiveCols().size,icon:"o-spreadsheet-Icon.INSERT_CELL_SHIFT_RIGHT"},xT={name:Fo("Chart"),execute:e=>{const t=e.model.getters,o=e.model.uuidGenerator.uuidv4(),s=t.getActiveSheetId();1===Ss(e.model.getters.getSelectedZone())&&e.model.selection.selectTableAroundSelection();const i={width:536,height:335},n=Jc(t,i);e.model.dispatch("CREATE_CHART",{sheetId:s,id:o,position:n,size:i,definition:bR(e.model.getters.getSelectedZone(),e.model.getters)}).isSuccessful&&(e.model.dispatch("SELECT_FIGURE",{id:o}),e.openSidePanel("ChartPanel"))},icon:"o-spreadsheet-Icon.INSERT_CHART"},ET={name:Fo("Pivot table"),execute:e=>{const t=e.model.uuidGenerator.uuidv4(),o=e.model.uuidGenerator.uuidv4();e.model.dispatch("INSERT_NEW_PIVOT",{pivotId:t,newSheetId:o}).isSuccessful&&e.openSidePanel("PivotSidePanel",{pivotId:t})},icon:"o-spreadsheet-Icon.PIVOT"},IT={name:Fo("Image"),description:"Ctrl+O",execute:_R,isVisible:e=>void 0!==e.imageProvider,icon:"o-spreadsheet-Icon.INSERT_IMAGE"},RT={name:()=>Fo("Table"),execute:e=>{const t=e.model.getters.getActiveSheetId();yR(e,t).isSuccessful&&e.openSidePanel("TableSidePanel",{})},isVisible:e=>MR(e)&&!e.model.getters.getFirstTableInSelection(),icon:"o-spreadsheet-Icon.PAINT_TABLE"},TT={name:Fo("Function"),icon:"o-spreadsheet-Icon.FORMULA"},AT={name:Fo("SUM"),execute:e=>e.startCellEdition("=SUM(")},_T={name:Fo("AVERAGE"),execute:e=>e.startCellEdition("=AVERAGE(")},DT={name:Fo("COUNT"),execute:e=>e.startCellEdition("=COUNT(")},OT={name:Fo("MAX"),execute:e=>e.startCellEdition("=MAX(")},FT={name:Fo("MIN"),execute:e=>e.startCellEdition("=MIN(")},MT={name:Fo("All"),children:[function(){return VT($b.getKeys().filter((e=>!$b.get(e).hidden)))}]};const PT={name:Fo("Link"),execute:DR,icon:"o-spreadsheet-Icon.INSERT_LINK"},NT={name:Fo("Checkbox"),execute:e=>{const t=e.model.getters.getSelectedZones(),o=e.model.getters.getActiveSheetId(),s=t.map((t=>e.model.getters.getRangeDataFromZone(o,t)));e.model.dispatch("ADD_DATA_VALIDATION_RULE",{ranges:s,sheetId:o,rule:{id:e.model.uuidGenerator.uuidv4(),criterion:{type:"isBoolean",values:[]}}})},icon:"o-spreadsheet-Icon.INSERT_CHECKBOX"},kT={name:Fo("Dropdown list"),execute:e=>{const t=e.model.getters.getSelectedZones(),o=e.model.getters.getActiveSheetId(),s=t.map((t=>e.model.getters.getRangeDataFromZone(o,t))),i=e.model.uuidGenerator.uuidv4();e.model.dispatch("ADD_DATA_VALIDATION_RULE",{ranges:s,sheetId:o,rule:{id:i,criterion:{type:"isValueInList",values:[],displayStyle:"arrow"}}});const n=e.model.getters.getDataValidationRule(o,i);n&&e.openSidePanel("DataValidationEditor",{rule:Ha(n,e.model.getters.getLocale()),onExit:()=>{e.openSidePanel("DataValidation")}})},icon:"o-spreadsheet-Icon.INSERT_DROPDOWN"},LT={name:Fo("Insert sheet"),execute:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSheetIds().indexOf(t)+1,s=e.model.uuidGenerator.uuidv4();e.model.dispatch("CREATE_SHEET",{sheetId:s,position:o}),e.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t,sheetIdTo:s})},icon:"o-spreadsheet-Icon.INSERT_SHEET"};function VT(e){return e.sort().map(((e,t)=>({name:e,sequence:10*t,execute:t=>t.startCellEdition(`=${e}(`)})))}function HT(e){const t=e.model.getters.getActiveRows();if(t.size)return t.size;{const t=e.model.getters.getSelectedZones()[0];return t.bottom-t.top+1}}function UT(e){const t=e.model.getters.getActiveCols();if(t.size)return t.size;{const t=e.model.getters.getSelectedZones()[0];return t.right-t.left+1}}const BT={name:Fo("See pivot properties"),execute(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);e.openSidePanel("PivotSidePanel",{pivotId:o})},isVisible:e=>{const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);return o&&e.model.getters.isExistingPivot(o)||!1},isReadonlyAllowed:!0,icon:"o-spreadsheet-Icon.PIVOT"},zT={name:Fo("Ascending"),execute:e=>qT(e,"asc"),isActive:e=>ZT(e,"asc")},$T={name:Fo("Descending"),execute:e=>qT(e,"desc"),isActive:e=>ZT(e,"desc")},WT={name:Fo("No sorting"),execute:e=>qT(e,"none"),isActive:e=>ZT(e,"none")},GT={name:Fo("Convert to individual formulas"),execute(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getCorrespondingFormulaCell(t),s=e.model.getters.getPivotIdFromPosition(t);if(!o||!s)return;const{sheetId:i,col:n,row:r}=e.model.getters.getCellPosition(o.id),a=e.model.getters.getPivot(s);a.init(),a.isValid()&&e.model.dispatch("SPLIT_PIVOT_FORMULA",{sheetId:i,col:n,row:r,pivotId:s})},isVisible:e=>{const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);if(!o)return!1;const s=e.model.getters.getPivot(o),i=e.model.getters.getEvaluatedCell(t);return s.isValid()&&e.model.getters.isSpillPivotFormula(t)&&i.type!==ni.error},icon:"o-spreadsheet-Icon.PIVOT"};function qT(e,t){const o=e.model.getters.getActivePosition(),s=e.model.getters.getPivotIdFromPosition(o),i=e.model.getters.getPivotCellFromPosition(o);if("EMPTY"===i.type||"HEADER"===i.type||!s)return;if("none"===t)return void e.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...e.model.getters.getPivotCoreDefinition(s),sortedColumn:void 0}});const n=ml(e.model.getters.getPivot(s),i.domain).colDomain;e.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...e.model.getters.getPivotCoreDefinition(s),sortedColumn:{domain:n,order:t,measure:i.measure}}})}function ZT(e,t){const o=e.model.getters.getActivePosition(),s=e.model.getters.getPivotIdFromPosition(o),i=e.model.getters.getPivotCellFromPosition(o);if("EMPTY"===i.type||"HEADER"===i.type||!s)return!1;const n=e.model.getters.getPivot(s),r=ml(n,i.domain).colDomain,a=n.definition.sortedColumn;return"none"===t?!a:!(!a||a.order!==t)&&(a.measure===i.measure&&mt(a.domain,r))}const jT=new CI;jT.add("cut",{...UR,sequence:10}).add("copy",{...HR,sequence:20}).add("paste",{...BR,sequence:30}).add("paste_special",{...zR,sequence:40,separator:!0}).addChild("paste_value_only",["paste_special"],{...$R,sequence:10}).addChild("paste_format_only",["paste_special"],{...WR,sequence:20}).add("add_row_before",{...dT,sequence:70}).add("add_column_before",{...vT,sequence:90}).add("insert_cell",{...yT,sequence:100,separator:!0}).addChild("insert_cell_down",["insert_cell"],{...CT,name:Fo("Shift down"),sequence:10}).addChild("insert_cell_right",["insert_cell"],{...wT,name:Fo("Shift right"),sequence:20}).add("delete_row",{...jR,sequence:110,icon:"o-spreadsheet-Icon.TRASH"}).add("delete_column",{...KR,sequence:120,icon:"o-spreadsheet-Icon.TRASH"}).add("delete_cell",{...QR,sequence:130,separator:!0,icon:"o-spreadsheet-Icon.TRASH"}).addChild("delete_cell_up",["delete_cell"],{...eT,name:Fo("Shift up"),sequence:10,icon:"o-spreadsheet-Icon.DELETE_CELL_SHIFT_UP"}).addChild("delete_cell_left",["delete_cell"],{...tT,name:Fo("Shift left"),sequence:20,icon:"o-spreadsheet-Icon.DELETE_CELL_SHIFT_LEFT"}).add("edit_table",{...sT,isVisible:FR,sequence:140}).add("delete_table",{...iT,isVisible:FR,sequence:145,separator:!0}).add("insert_link",{...PT,name:e=>{const t=e.model.getters.getActiveSheetId(),{col:o,row:s}=e.model.getters.getActivePosition(),i=e.model.getters.getEvaluatedCell({sheetId:t,col:o,row:s});return i&&i.link?Fo("Edit link"):Fo("Insert link")},sequence:150,separator:!0}).add("pivot_sorting",{name:Fo("Sort pivot"),sequence:155,icon:"o-spreadsheet-Icon.SORT_RANGE",isVisible:function(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotIdFromPosition(t);if(!o||!e.model.getters.isExistingPivot(o)||!e.model.getters.isSpillPivotFormula(t))return!1;if(!e.model.getters.getPivot(o).isValid())return!1;const s=e.model.getters.getPivotCellFromPosition(t);return"VALUE"===s.type||"MEASURE_HEADER"===s.type}}).add("pivot_fix_formulas",{...GT,sequence:160}).add("pivot_properties",{...BT,sequence:170,separator:!0}).addChild("pivot_sorting_asc",["pivot_sorting"],{...zT,sequence:10}).addChild("pivot_sorting_desc",["pivot_sorting"],{...$T,sequence:20}).addChild("pivot_sorting_none",["pivot_sorting"],{...WT,sequence:30});const YT={name:Fo("Sort range"),isVisible:PR,icon:"o-spreadsheet-Icon.SORT_RANGE"},XT={name:Fo("Ascending (A ⟶ Z)"),execute:e=>{const{anchor:t,zones:o}=e.model.getters.getSelection(),s=e.model.getters.getActiveSheetId();Ap(e,s,t.cell,o[0],"asc")},icon:"o-spreadsheet-Icon.SORT_ASCENDING"},KT={name:Fo("Data cleanup"),icon:"o-spreadsheet-Icon.DATA_CLEANUP"},JT={name:Fo("Remove duplicates"),execute:e=>{1===Ss(e.model.getters.getSelectedZone())&&e.model.selection.selectTableAroundSelection(),e.openSidePanel("RemoveDuplicates",{})}},QT={name:Fo("Trim whitespace"),execute:e=>{e.model.dispatch("TRIM_WHITESPACE")}},eA={name:Fo("Descending (Z ⟶ A)"),execute:e=>{const{anchor:t,zones:o}=e.model.getters.getSelection(),s=e.model.getters.getActiveSheetId();Ap(e,s,t.cell,o[0],"desc")},icon:"o-spreadsheet-Icon.SORT_DESCENDING"},tA={...kR},oA={...kR,isActive:e=>OR(e)},sA={name:Fo("Split text to columns"),sequence:1,execute:e=>e.openSidePanel("SplitToColumns",{}),isEnabled:e=>e.model.getters.isSingleColSelected(),icon:"o-spreadsheet-Icon.SPLIT_TEXT"},iA={id:"reinsert_dynamic_pivot",name:Fo("Re-insert dynamic pivot"),sequence:1020,icon:"o-spreadsheet-Icon.INSERT_PIVOT",children:[e=>e.model.getters.getPivotIds().map(((t,o)=>({id:`reinsert_dynamic_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:o,execute:e=>{const o=e.model.getters.getSelectedZone(),s=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch("INSERT_PIVOT_WITH_TABLE",{pivotId:t,table:s,col:o.left,row:o.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:"dynamic"}),e.model.dispatch("REFRESH_PIVOT",{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()})))],isVisible:e=>e.model.getters.getPivotIds().some((t=>e.model.getters.getPivot(t).isValid()))},nA={id:"reinsert_static_pivot",name:Fo("Re-insert static pivot"),sequence:1020,icon:"o-spreadsheet-Icon.INSERT_PIVOT",children:[e=>e.model.getters.getPivotIds().map(((t,o)=>({id:`reinsert_static_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:o,execute:e=>{const o=e.model.getters.getSelectedZone(),s=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch("INSERT_PIVOT_WITH_TABLE",{pivotId:t,table:s,col:o.left,row:o.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:"static"}),e.model.dispatch("REFRESH_PIVOT",{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()})))],isVisible:e=>e.model.getters.getPivotIds().some((t=>e.model.getters.getPivot(t).isValid()))};var rA=Object.freeze({__proto__:null,createRemoveFilter:tA,createRemoveFilterTool:oA,dataCleanup:KT,reinsertDynamicPivotMenu:iA,reinsertStaticPivotMenu:nA,removeDuplicates:JT,sortAscending:XT,sortDescending:eA,sortRange:YT,splitToColumns:sA,trimWhitespace:QT});function aA({name:e,format:t,descriptionValue:o}){const s="function"==typeof t?t:()=>t;return{name:e,description:e=>Jn(o,{format:s(e),locale:e.model.getters.getLocale()}),execute:e=>CR(e,s(e)),isActive:e=>s_(e,s(e)),format:t}}const lA={name:Fo("Automatic"),execute:e=>CR(e,""),isActive:e=>function(e){const t=e.model.getters.getActivePosition(),o=e.model.getters.getPivotCellFromPosition(t);if("VALUE"===o.type)return!e.model.getters.getEvaluatedCell(t).format;return!e.model.getters.getCell(t)?.format}(e)},cA={name:Fo("Plain text"),execute:e=>CR(e,"@"),isActive:e=>s_(e,"@")},hA=aA({name:Fo("Number"),descriptionValue:1000.12,format:"#,##0.00"}),dA={name:Fo("Format as percent"),execute:e=>CR(e,"0.00%"),icon:"o-spreadsheet-Icon.PERCENT"},uA=aA({name:Fo("Percent"),descriptionValue:.1012,format:"0.00%"}),gA=aA({name:Fo("Currency"),descriptionValue:1000.12,format:e=>ur(e.model.config.defaultCurrency||Le)}),pA={...aA({name:Fo("Currency rounded"),descriptionValue:1e3,format:e=>mr(ur(e.model.config.defaultCurrency||Le))}),isVisible:e=>{const t=ur(e.model.config.defaultCurrency||Le);return t!==mr(t)}},mA=aA({name:Fo("Accounting"),descriptionValue:-1000.12,format:e=>gr(e.model.config.defaultCurrency||Le)}),fA=Rr("2023/09/26 10:43:00 PM",Si),vA={name:Fo("Custom currency"),isVisible:e=>void 0!==e.loadCurrencies,execute:e=>e.openSidePanel("CustomCurrency",{})},bA=aA({name:Fo("Date"),descriptionValue:fA,format:e=>e.model.getters.getLocale().dateFormat}),SA=aA({name:Fo("Time"),descriptionValue:fA,format:e=>e.model.getters.getLocale().timeFormat}),yA=aA({name:Fo("Date time"),descriptionValue:fA,format:e=>za(e.model.getters.getLocale())}),CA=aA({name:Fo("Duration"),descriptionValue:"27:51:38",format:"hhhh:mm:ss"}),wA=aA({name:Fo("Quarter"),descriptionValue:fA,format:"qq yyyy"}),xA=aA({name:Fo("Full quarter"),descriptionValue:fA,format:"qqqq yyyy"}),EA={name:Fo("More date formats"),execute:e=>e.openSidePanel("MoreFormats",{})},IA=aA({name:Fo("Full date time"),format:"dddd d mmmm yyyy hh:mm:ss a",descriptionValue:fA}),RA=aA({name:Fo("Full week day and month"),format:"dddd d mmmm yyyy",descriptionValue:fA}),TA=aA({name:Fo("Day and full month"),format:"d mmmm yyyy",descriptionValue:fA}),AA=aA({name:Fo("Short week day"),format:"ddd d mmm yyyy",descriptionValue:fA}),_A=aA({name:Fo("Day and short month"),format:"d mmm yyyy",descriptionValue:fA}),DA=aA({name:Fo("Full month"),format:"mmmm yyyy",descriptionValue:fA}),OA=aA({name:Fo("Short month"),format:"mmm yyyy",descriptionValue:fA}),FA={name:Fo("Increase decimal places"),icon:"o-spreadsheet-Icon.INCREASE_DECIMAL",execute:e=>e.model.dispatch("SET_DECIMAL",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:1})},MA={name:Fo("Decrease decimal places"),icon:"o-spreadsheet-Icon.DECRASE_DECIMAL",execute:e=>e.model.dispatch("SET_DECIMAL",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:-1})},PA={name:Fo("Bold"),description:"Ctrl+B",execute:e=>wR(e,{bold:!e.model.getters.getCurrentStyle().bold}),icon:"o-spreadsheet-Icon.BOLD",isActive:e=>!!e.model.getters.getCurrentStyle().bold},NA={name:Fo("Italic"),description:"Ctrl+I",execute:e=>wR(e,{italic:!e.model.getters.getCurrentStyle().italic}),icon:"o-spreadsheet-Icon.ITALIC",isActive:e=>!!e.model.getters.getCurrentStyle().italic},kA={name:Fo("Underline"),description:"Ctrl+U",execute:e=>wR(e,{underline:!e.model.getters.getCurrentStyle().underline}),icon:"o-spreadsheet-Icon.UNDERLINE",isActive:e=>!!e.model.getters.getCurrentStyle().underline},LA={name:Fo("Strikethrough"),execute:e=>wR(e,{strikethrough:!e.model.getters.getCurrentStyle().strikethrough}),icon:"o-spreadsheet-Icon.STRIKE",isActive:e=>!!e.model.getters.getCurrentStyle().strikethrough},VA={name:Fo("Font size"),children:Ne.map((e=>({name:e.toString(),sequence:e,id:`font_size_${e}`,execute:t=>wR(t,{fontSize:e}),isActive:t=>function(e,t){const o=e.model.getters.getCurrentStyle().fontSize||me;return o===t}(t,e)}))),icon:"o-spreadsheet-Icon.FONT_SIZE"},HA={name:Fo("Alignment"),icon:"o-spreadsheet-Icon.ALIGN_LEFT"},UA={name:Fo("Horizontal align"),icon:e=>function(e){switch(i_(e)){case"right":return"o-spreadsheet-Icon.ALIGN_RIGHT";case"center":return"o-spreadsheet-Icon.ALIGN_CENTER";default:return"o-spreadsheet-Icon.ALIGN_LEFT"}}(e)},BA={name:Fo("Left"),description:"Ctrl+Shift+L",execute:e=>wR(e,{align:"left"}),isActive:e=>"left"===i_(e),icon:"o-spreadsheet-Icon.ALIGN_LEFT"},zA={name:Fo("Center"),description:"Ctrl+Shift+E",execute:e=>wR(e,{align:"center"}),isActive:e=>"center"===i_(e),icon:"o-spreadsheet-Icon.ALIGN_CENTER"},$A={name:Fo("Right"),description:"Ctrl+Shift+R",execute:e=>wR(e,{align:"right"}),isActive:e=>"right"===i_(e),icon:"o-spreadsheet-Icon.ALIGN_RIGHT"},WA={name:Fo("Vertical align"),icon:e=>function(e){switch(n_(e)){case"top":return"o-spreadsheet-Icon.ALIGN_TOP";case"middle":return"o-spreadsheet-Icon.ALIGN_MIDDLE";default:return"o-spreadsheet-Icon.ALIGN_BOTTOM"}}(e)},GA={name:Fo("Top"),execute:e=>wR(e,{verticalAlign:"top"}),isActive:e=>"top"===n_(e),icon:"o-spreadsheet-Icon.ALIGN_TOP"},qA={name:Fo("Middle"),execute:e=>wR(e,{verticalAlign:"middle"}),isActive:e=>"middle"===n_(e),icon:"o-spreadsheet-Icon.ALIGN_MIDDLE"},ZA={name:Fo("Bottom"),execute:e=>wR(e,{verticalAlign:"bottom"}),isActive:e=>"bottom"===n_(e),icon:"o-spreadsheet-Icon.ALIGN_BOTTOM"},jA={name:Fo("Wrapping"),icon:"o-spreadsheet-Icon.WRAPPING_OVERFLOW"},YA={name:Fo("Wrapping"),icon:e=>function(e){switch(r_(e)){case"wrap":return"o-spreadsheet-Icon.WRAPPING_WRAP";case"clip":return"o-spreadsheet-Icon.WRAPPING_CLIP";default:return"o-spreadsheet-Icon.WRAPPING_OVERFLOW"}}(e)},XA={name:Fo("Overflow"),execute:e=>wR(e,{wrapping:"overflow"}),isActive:e=>"overflow"===r_(e),icon:"o-spreadsheet-Icon.WRAPPING_OVERFLOW"},KA={name:Fo("Wrap"),execute:e=>wR(e,{wrapping:"wrap"}),isActive:e=>"wrap"===r_(e),icon:"o-spreadsheet-Icon.WRAPPING_WRAP"},JA={name:Fo("Clip"),execute:e=>wR(e,{wrapping:"clip"}),isActive:e=>"clip"===r_(e),icon:"o-spreadsheet-Icon.WRAPPING_CLIP"},QA={name:Fo("Text Color"),icon:"o-spreadsheet-Icon.TEXT_COLOR"},e_={name:Fo("Fill Color"),icon:"o-spreadsheet-Icon.FILL_COLOR"},t_={name:Fo("Conditional formatting"),execute:e=>{e.openSidePanel("ConditionalFormatting",{selection:e.model.getters.getSelectedZones()})},icon:"o-spreadsheet-Icon.CONDITIONAL_FORMAT"},o_={name:Fo("Clear formatting"),description:"Ctrl+<",execute:e=>e.model.dispatch("CLEAR_FORMATTING",{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()}),icon:"o-spreadsheet-Icon.CLEAR_FORMAT"};function s_(e,t){const o=e.model.getters.getActivePosition();return"VALUE"===e.model.getters.getPivotCellFromPosition(o).type?e.model.getters.getEvaluatedCell(o).format===t:e.model.getters.getCell(o)?.format===t}function i_(e){const t=e.model.getters.getCurrentStyle();if(t.align)return t.align;return e.model.getters.getActiveCell().defaultAlign}function n_(e){const t=e.model.getters.getCurrentStyle();return t.verticalAlign?t.verticalAlign:ue}function r_(e){const t=e.model.getters.getCurrentStyle();return t.wrapping?t.wrapping:ge}var a_=Object.freeze({__proto__:null,EXAMPLE_DATE:fA,clearFormat:o_,createFormatActionSpec:aA,decraseDecimalPlaces:MA,fillColor:e_,formatAlignment:HA,formatAlignmentBottom:ZA,formatAlignmentCenter:zA,formatAlignmentHorizontal:UA,formatAlignmentLeft:BA,formatAlignmentMiddle:qA,formatAlignmentRight:$A,formatAlignmentTop:GA,formatAlignmentVertical:WA,formatBold:PA,formatCF:t_,formatCustomCurrency:vA,formatFontSize:VA,formatItalic:NA,formatNumberAccounting:mA,formatNumberAutomatic:lA,formatNumberCurrency:gA,formatNumberCurrencyRounded:pA,formatNumberDate:bA,formatNumberDateTime:yA,formatNumberDayAndFullMonth:TA,formatNumberDayAndShortMonth:_A,formatNumberDuration:CA,formatNumberFullDateTime:IA,formatNumberFullMonth:DA,formatNumberFullQuarter:xA,formatNumberFullWeekDayAndMonth:RA,formatNumberNumber:hA,formatNumberPercent:uA,formatNumberPlainText:cA,formatNumberQuarter:wA,formatNumberShortMonth:OA,formatNumberShortWeekDay:AA,formatNumberTime:SA,formatPercent:dA,formatStrikethrough:LA,formatUnderline:kA,formatWrapping:YA,formatWrappingClip:JA,formatWrappingIcon:jA,formatWrappingOverflow:XA,formatWrappingWrap:KA,incraseDecimalPlaces:FA,moreFormats:EA,textColor:QA});function l_(e,t,o){const s=e.model.getters.getActiveSheetId(),i="COL"===t?"FREEZE_COLUMNS":"FREEZE_ROWS";e.model.dispatch(i,{sheetId:s,quantity:o}).isCancelledBecause("MergeOverlap")&&e.raiseError(mx)}class c_{map={};constructor(e=[]){for(const[t,o]of e)this.set(t,o)}set({sheetId:e,col:t,row:o},s){const i=this.map;i[e]||(i[e]={}),i[e][t]||(i[e][t]={}),i[e][t][o]=s}get({sheetId:e,col:t,row:o}){return this.map[e]?.[t]?.[o]}getSheet(e){return this.map[e]}has({sheetId:e,col:t,row:o}){return void 0!==this.map[e]?.[t]?.[o]}delete({sheetId:e,col:t,row:o}){delete this.map[e]?.[t]?.[o]}keys(){const e=this.map,t=[];for(const o in e)for(const s in e[o])for(const i in e[o][s])t.push({sheetId:o,col:parseInt(s),row:parseInt(i)});return t}keysForSheet(e){const t=this.map[e];if(!t)return[];const o=[];for(const s in t)for(const i in t[s])o.push({sheetId:e,col:parseInt(s),row:parseInt(i)});return o}*entries(){const e=this.map;for(const t of this.keys()){const{sheetId:o,col:s,row:i}=t;yield[t,e[o][s][i]]}}}class h_ extends Ac{mutators=["enable","disable"];isInvalidated=!1;fingerprintColors={[d_]:"#D9D9D9"};isEnabled=!1;colors=new c_;handle(e){switch(pi(e)&&this.isEnabled&&(this.isInvalidated=!0),e.type){case"UNDO":case"REDO":case"ACTIVATE_SHEET":this.isEnabled&&(this.isInvalidated=!0)}}finalize(){this.isInvalidated&&(this.isInvalidated=!1,this.computeFingerprints())}enable(){this.isEnabled=!0,this.computeFingerprints()}disable(){this.isEnabled=!1,this.colors=new c_}computeFingerprints(){this.colors=new c_;const e=new c_,t=new Set,o=this.getters.getActiveSheetId(),s=this.getters.getCells(o);for(const o in s){const i=this.computeFingerprint(s[o]);if(!i)continue;t.add(i);const n=this.getters.getCellPosition(o);e.set(n,i)}this.assignColors(t);for(const[t,o]of e.entries()){const e=this.fingerprintColors[o];this.colors.set(t,e),this.colorSpreadZone(t,e)}}colorSpreadZone(e,t){const o=this.getters.getSpreadZone(e);if(!o)return;const s=e.sheetId;for(let e=o.top;e<=o.bottom;e++)for(let i=o.left;i<=o.right;i++){const o={sheetId:s,col:i,row:e};this.colors.set(o,t)}}assignColors(e){const t=new uo(e.size);Object.keys(this.fingerprintColors).forEach((()=>t.next()));for(const o of e)this.fingerprintColors[o]||(this.fingerprintColors[o]=Jt(t.next(),.8))}computeFingerprint(e){const t=this.getters.getCellPosition(e.id);return e.isFormula?this.computeFormulaFingerprint(t,e):this.getLiteralFingerprint(t)}computeFormulaFingerprint(e,t){const o=t.compiledFormula.dependencies,s=e.col,i=e.row,n=this.getters.getSheetIds().indexOf(e.sheetId),r={dx:0,dy:0,dSheet:0};for(const e of o){const t=e.zone,[o,a]=e.parts,l=this.getters.getSheetIds().indexOf(e.sheetId);r.dSheet=l-n;const c=e.isFullRow&&!e.unboundedZone.hasHeader,h=e.isFullCol&&!e.unboundedZone.hasHeader,d=c||o?.colFixed?0:s,u=h||o?.rowFixed?0:i,g=!a&&o?.colFixed||a?.colFixed,p=!a&&o.rowFixed||a?.rowFixed,m=void 0===e.unboundedZone.right||g?0:s,f=void 0===e.unboundedZone.bottom||p?0:i,v=gs({top:t.top-u,left:t.left-d,right:t.right-m,bottom:t.bottom-f});for(let e=v.top;e<=v.bottom;e++)for(let t=v.left;t<=v.right;t++)r.dx+=t,r.dy+=e}const a=t.compiledFormula.normalizedFormula.replace(/(|\w)(\d)(|)/g,"$1$3");return l=r,Object.entries(l).sort((([e],[t])=>e.localeCompare(t))).map((([e,t])=>t)).join(",")+a;var l}getLiteralFingerprint(e){switch(this.getters.getEvaluatedCell(e).type){case ni.number:case ni.boolean:return d_;case ni.text:case ni.empty:case ni.error:return}}}const d_="DATA_FINGERPRINT",u_={name:e=>{const t=e.model.getters.getElementsFromSelection("COL");let o=t[0],s=t[t.length-1];return 1===t.length?Fo("Hide column %s",fo(o).toString()):s-o+1===t.length?Fo("Hide columns %s - %s",fo(o).toString(),fo(s).toString()):Fo("Hide columns")},execute:e=>{const t=e.model.getters.getElementsFromSelection("COL");e.model.dispatch("HIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"COL",elements:t})},isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getElementsFromSelection("COL");return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,"COL",o)},icon:"o-spreadsheet-Icon.HIDE_COL"},g_={name:Fo("Unhide columns"),execute:e=>{const t=e.model.getters.getElementsFromSelection("COL");e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"COL",elements:t})},isVisible:e=>{const t=e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection("COL").some((e=>t.includes(e)))},icon:"o-spreadsheet-Icon.UNHIDE_COL"},p_={name:Fo("Unhide all columns"),execute:e=>{const t=e.model.getters.getActiveSheetId();e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:t,dimension:"COL",elements:Array.from(Array(e.model.getters.getNumberCols(t)).keys())})},isVisible:e=>e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).length>0,icon:"o-spreadsheet-Icon.UNHIDE_COL"},m_={name:e=>{const t=e.model.getters.getElementsFromSelection("ROW");let o=t[0],s=t[t.length-1];return 1===t.length?Fo("Hide row %s",(o+1).toString()):s-o+1===t.length?Fo("Hide rows %s - %s",(o+1).toString(),(s+1).toString()):Fo("Hide rows")},execute:e=>{const t=e.model.getters.getElementsFromSelection("ROW");e.model.dispatch("HIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getElementsFromSelection("ROW");return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,"ROW",o)},icon:"o-spreadsheet-Icon.HIDE_ROW"},f_={name:Fo("Unhide rows"),execute:e=>{const t=e.model.getters.getElementsFromSelection("ROW");e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},isVisible:e=>{const t=e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection("ROW").some((e=>t.includes(e)))},icon:"o-spreadsheet-Icon.UNHIDE_ROW"},v_={name:Fo("Unhide all rows"),execute:e=>{const t=e.model.getters.getActiveSheetId();e.model.dispatch("UNHIDE_COLUMNS_ROWS",{sheetId:t,dimension:"ROW",elements:Array.from(Array(e.model.getters.getNumberRows(t)).keys())})},isVisible:e=>e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).length>0,icon:"o-spreadsheet-Icon.UNHIDE_ROW"},b_={name:Fo("Unfreeze"),isVisible:e=>{const{xSplit:t,ySplit:o}=e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId());return t+o>0},execute:e=>e.model.dispatch("UNFREEZE_COLUMNS_ROWS",{sheetId:e.model.getters.getActiveSheetId()}),icon:"o-spreadsheet-Icon.UNFREEZE"},S_={name:Fo("Freeze"),icon:"o-spreadsheet-Icon.FREEZE"},y_={name:Fo("No rows"),execute:e=>e.model.dispatch("UNFREEZE_ROWS",{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).ySplit},C_={name:Fo("1 row"),execute:e=>l_(e,"ROW",1),isReadonlyAllowed:!0},w_={name:Fo("2 rows"),execute:e=>l_(e,"ROW",2),isReadonlyAllowed:!0},x_={name:Fo("Up to current row"),execute:e=>{const{bottom:t}=e.model.getters.getSelectedZone();l_(e,"ROW",t+1)},isReadonlyAllowed:!0},E_={name:Fo("No columns"),execute:e=>e.model.dispatch("UNFREEZE_COLUMNS",{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).xSplit},I_={name:Fo("1 column"),execute:e=>l_(e,"COL",1),isReadonlyAllowed:!0},R_={name:Fo("2 columns"),execute:e=>l_(e,"COL",2),isReadonlyAllowed:!0},T_={name:Fo("Up to current column"),execute:e=>{const{right:t}=e.model.getters.getSelectedZone();l_(e,"COL",t+1)},isReadonlyAllowed:!0},A_={name:Fo("Gridlines"),execute:e=>{const t=e.model.getters.getActiveSheetId();e.model.dispatch("SET_GRID_LINES_VISIBILITY",{sheetId:t,areGridLinesVisible:!e.model.getters.getGridLinesVisibility(t)})},isActive:e=>{const t=e.model.getters.getActiveSheetId();return e.model.getters.getGridLinesVisibility(t)}},__={name:Fo("Irregularity map"),execute:e=>{const t=e.getStore(h_);t.isEnabled?t.disable():t.enable()},icon:"o-spreadsheet-Icon.IRREGULARITY_MAP"},D_={name:Fo("Formulas"),isActive:e=>e.model.getters.shouldShowFormulas(),execute:e=>e.model.dispatch("SET_FORMULA_VISIBILITY",{show:!e.model.getters.shouldShowFormulas()}),isReadonlyAllowed:!0},O_={name:e=>{const t=e.model.getters.getSelectedZone();return t.left===t.right?Fo("Group column %s",fo(t.left)):Fo("Group columns %s - %s",fo(t.left),fo(t.right))},execute:e=>N_(e,"COL"),isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSelectedZone(),s=e.model.getters.getHeaderGroupsInZone(t,"COL",o);return PR(e)&&!s.some((e=>e.start===o.left&&e.end===o.right))},icon:"o-spreadsheet-Icon.GROUP_COLUMNS"},F_={name:e=>{const t=e.model.getters.getSelectedZone();return t.top===t.bottom?Fo("Group row %s",String(t.top+1)):Fo("Group rows %s - %s",String(t.top+1),String(t.bottom+1))},execute:e=>N_(e,"ROW"),isVisible:e=>{const t=e.model.getters.getActiveSheetId(),o=e.model.getters.getSelectedZone(),s=e.model.getters.getHeaderGroupsInZone(t,"ROW",o);return PR(e)&&!s.some((e=>e.start===o.top&&e.end===o.bottom))},icon:"o-spreadsheet-Icon.GROUP_ROWS"},M_={name:e=>{const t=e.model.getters.getSelectedZone();return t.left===t.right?Fo("Ungroup column %s",fo(t.left)):Fo("Ungroup columns %s - %s",fo(t.left),fo(t.right))},execute:e=>k_(e,"COL"),icon:"o-spreadsheet-Icon.UNGROUP_COLUMNS"},P_={name:e=>{const t=e.model.getters.getSelectedZone();return t.top===t.bottom?Fo("Ungroup row %s",String(t.top+1)):Fo("Ungroup rows %s - %s",String(t.top+1),String(t.bottom+1))},execute:e=>k_(e,"ROW"),icon:"o-spreadsheet-Icon.UNGROUP_ROWS"};function N_(e,t){const o=e.model.getters.getSelectedZone(),s=e.model.getters.getActiveSheetId();e.model.dispatch("GROUP_HEADERS",{sheetId:s,dimension:t,start:"COL"===t?o.left:o.top,end:"COL"===t?o.right:o.bottom})}function k_(e,t){const o=e.model.getters.getSelectedZone(),s=e.model.getters.getActiveSheetId();e.model.dispatch("UNGROUP_HEADERS",{sheetId:s,dimension:t,start:"COL"===t?o.left:o.top,end:"COL"===t?o.right:o.bottom})}function L_(e,t){const o=e.model.getters.getActiveSheetId(),s=e.model.getters.getSelectedZones();return 1===s.length&&e.model.getters.getHeaderGroupsInZone(o,t,s[0]).length>0}const V_=new CI;V_.add("cut",{...UR,sequence:10}).add("copy",{...HR,sequence:20}).add("paste",{...BR,sequence:30}).add("paste_special",{...zR,sequence:40,separator:!0}).addChild("paste_value_only",["paste_special"],{...$R,sequence:10}).addChild("paste_format_only",["paste_special"],{...WR,sequence:20}).add("sort_columns",{...YT,name:e=>e.model.getters.getActiveCols().size>1?Fo("Sort columns"):Fo("Sort column"),sequence:50,separator:!0}).addChild("sort_ascending",["sort_columns"],{...XT,sequence:10}).addChild("sort_descending",["sort_columns"],{...eA,sequence:20}).add("add_column_before",{...mT,sequence:70}).add("add_column_after",{...bT,sequence:80}).add("delete_column",{...XR,sequence:90,icon:"o-spreadsheet-Icon.TRASH"}).add("clear_column",{...JR,sequence:100,icon:"o-spreadsheet-Icon.CLEAR"}).add("hide_columns",{...u_,sequence:105,separator:!0}).add("unhide_columns",{...g_,sequence:106,separator:!0}).add("conditional_formatting",{...t_,sequence:110,separator:!0}).add("edit_table",{...sT,isVisible:FR,sequence:120}).add("delete_table",{...iT,isVisible:FR,sequence:125,separator:!0}).add("group_columns",{sequence:150,...O_}).add("ungroup_columns",{sequence:155,...M_,isVisible:e=>L_(e,"COL")});const H_=new n;H_.add("format_number_automatic",{...lA,id:"format_number_automatic",sequence:10}).add("format_number_plain_text",{...cA,id:"format_number_plain_text",sequence:15,separator:!0}).add("format_number_number",{...hA,id:"format_number_number",sequence:20}).add("format_number_percent",{...uA,id:"format_number_percent",sequence:30,separator:!0}).add("format_number_currency",{...gA,id:"format_number_currency",sequence:40}).add("format_number_accounting",{...mA,id:"format_number_accounting",sequence:45}).add("format_number_currency_rounded",{...pA,id:"format_number_currency_rounded",sequence:50}).add("format_custom_currency",{...vA,id:"format_custom_currency",sequence:60,separator:!0}).add("format_number_date",{...bA,id:"format_number_date",sequence:70}).add("format_number_time",{...SA,id:"format_number_time",sequence:80}).add("format_number_date_time",{...yA,id:"format_number_date_time",sequence:90}).add("format_number_duration",{...CA,id:"format_number_duration",sequence:100,separator:!0}).add("more_formats",{...EA,id:"more_formats",sequence:120});const U_=Et((e=>rr(e)?"date":e.includes("[$")?"currency":"number")),B_={name:Fo("More formats"),icon:"o-spreadsheet-Icon.NUMBER_FORMATS",children:[e=>{const t=function(e){const t=new Set(H_.getAll().map((t=>"function"==typeof t.format?t.format(e):t.format))),o=new Map;for(const s of e.model.getters.getSheetIds()){const i=e.model.getters.getEvaluatedCells(s);for(const e in i){const s=i[e];if(s.format&&!o.has(s.format)&&!t.has(s.format)){const e=U_(s.format);"date"!==e&&"currency"!==e||o.set(s.format,aA({descriptionValue:"currency"===e?1e3:fA,format:s.format,name:s.format}))}}}return[...o.values()]}(e).map((e=>({...e,sequence:110})));return t.length>0&&(t[t.length-1].separator=!0),o([...H_.getAll(),...t])}]},z_=new CI;function $_(e,t){const o=e.getActiveSheetId(),s=function(e,t){const o=[],s=e.getActiveSheetId();for(const i of e.getSheetViewVisibleCols())for(const n of e.getSheetViewVisibleRows()){const r={sheetId:s,col:i,row:n};t===e.getPivotIdFromPosition(r)&&o.push(r)}return o}(e,t);return Cs(s.map(fs)).map((e=>({sheetId:o,zone:e,noFill:!0,color:a})))}z_.add("cut",{...UR,sequence:10}).add("copy",{...HR,sequence:20}).add("paste",{...BR,sequence:30}).add("paste_special",{...zR,sequence:40,separator:!0}).addChild("paste_value_only",["paste_special"],{...$R,sequence:10}).addChild("paste_format_only",["paste_special"],{...WR,sequence:20}).add("add_row_before",{...cT,sequence:50}).add("add_row_after",{...uT,sequence:60}).add("delete_row",{...ZR,sequence:70,icon:"o-spreadsheet-Icon.TRASH"}).add("clear_row",{...YR,sequence:80,icon:"o-spreadsheet-Icon.CLEAR"}).add("hide_rows",{...m_,sequence:85,separator:!0}).add("unhide_rows",{...f_,sequence:86,separator:!0}).add("conditional_formatting",{...t_,sequence:90,separator:!0}).add("group_rows",{sequence:100,...F_}).add("ungroup_rows",{sequence:110,...P_,isVisible:e=>L_(e,"ROW")});const W_=new CI;W_.add("file",{name:Fo("File"),sequence:10}).addChild("settings",["file"],{name:Fo("Settings"),sequence:100,execute:e=>e.openSidePanel("Settings"),icon:"o-spreadsheet-Icon.COG"}).add("edit",{name:Fo("Edit"),sequence:20}).addChild("undo",["edit"],{...LR,sequence:10}).addChild("redo",["edit"],{...VR,sequence:20,separator:!0}).addChild("copy",["edit"],{...HR,sequence:30}).addChild("cut",["edit"],{...UR,sequence:40}).addChild("paste",["edit"],{...BR,sequence:50}).addChild("paste_special",["edit"],{...zR,sequence:60,separator:!0}).addChild("paste_special_value",["edit","paste_special"],{...$R,sequence:10}).addChild("paste_special_format",["edit","paste_special"],{...WR,sequence:20}).addChild("edit_table",["edit"],{...sT,isVisible:FR,sequence:60}).addChild("find_and_replace",["edit"],{...GR,sequence:65,separator:!0}).addChild("delete",["edit"],{name:Fo("Delete"),icon:"o-spreadsheet-Icon.TRASH",sequence:70}).addChild("edit_delete_cell_values",["edit","delete"],{...qR,sequence:10}).addChild("edit_delete_row",["edit","delete"],{...ZR,sequence:20}).addChild("edit_delete_column",["edit","delete"],{...XR,sequence:30}).addChild("edit_delete_cell_shift_up",["edit","delete"],{...eT,sequence:40}).addChild("edit_delete_cell_shift_left",["edit","delete"],{...tT,sequence:50}).addChild("edit_unhide_columns",["edit"],{...p_,sequence:80}).addChild("edit_unhide_rows",["edit"],{...v_,sequence:80}).add("view",{name:Fo("View"),sequence:30}).addChild("unfreeze_panes",["view"],{...b_,sequence:4}).addChild("freeze_panes",["view"],{...S_,sequence:5}).addChild("unfreeze_rows",["view","freeze_panes"],{...y_,sequence:5}).addChild("freeze_first_row",["view","freeze_panes"],{...C_,sequence:10}).addChild("freeze_second_row",["view","freeze_panes"],{...w_,sequence:15}).addChild("freeze_current_row",["view","freeze_panes"],{...x_,sequence:20,separator:!0}).addChild("unfreeze_columns",["view","freeze_panes"],{...E_,sequence:25}).addChild("freeze_first_col",["view","freeze_panes"],{...I_,sequence:30}).addChild("freeze_second_col",["view","freeze_panes"],{...R_,sequence:35}).addChild("freeze_current_col",["view","freeze_panes"],{...T_,sequence:40}).addChild("group_headers",["view"],{name:Fo("Group"),sequence:15,separator:!0,icon:"o-spreadsheet-Icon.PLUS_IN_BOX",isVisible:PR}).addChild("group_columns",["view","group_headers"],{...O_,sequence:5}).addChild("ungroup_columns",["view","group_headers"],{...M_,isVisible:e=>L_(e,"COL"),sequence:10}).addChild("group_rows",["view","group_headers"],{...F_,sequence:15}).addChild("ungroup_rows",["view","group_headers"],{...P_,isVisible:e=>L_(e,"ROW"),sequence:20}).addChild("show",["view"],{name:Fo("Show"),sequence:1,icon:"o-spreadsheet-Icon.SHOW"}).addChild("view_gridlines",["view","show"],{...A_,sequence:5}).addChild("view_formulas",["view","show"],{...D_,sequence:10}).addChild("view_irregularity_map",["view"],{...__,sequence:40,separator:!0}).add("insert",{name:Fo("Insert"),sequence:40}).addChild("insert_row",["insert"],{...lT,sequence:10}).addChild("insert_row_before",["insert","insert_row"],{...hT,sequence:10}).addChild("insert_row_after",["insert","insert_row"],{...gT,sequence:20}).addChild("insert_column",["insert"],{...pT,sequence:20}).addChild("insert_column_before",["insert","insert_column"],{...fT,sequence:10}).addChild("insert_column_after",["insert","insert_column"],{...ST,sequence:20}).addChild("insert_cell",["insert"],{...yT,sequence:30}).addChild("insert_cell_down",["insert","insert_cell"],{...CT,name:Fo("Shift down"),sequence:10}).addChild("insert_cell_right",["insert","insert_cell"],{...wT,name:Fo("Shift right"),sequence:20}).addChild("insert_sheet",["insert"],{...LT,sequence:40,separator:!0}).addChild("insert_chart",["insert"],{...xT,sequence:50}).addChild("insert_pivot",["insert"],{...ET,sequence:52}).addChild("insert_image",["insert"],{...IT,sequence:55}).addChild("insert_table",["insert"],{...RT,sequence:57}).addChild("insert_function",["insert"],{...TT,sequence:60}).addChild("insert_function_sum",["insert","insert_function"],{...AT,sequence:0}).addChild("insert_function_average",["insert","insert_function"],{..._T,sequence:10}).addChild("insert_function_count",["insert","insert_function"],{...DT,sequence:20}).addChild("insert_function_max",["insert","insert_function"],{...OT,sequence:30}).addChild("insert_function_min",["insert","insert_function"],{...FT,sequence:40,separator:!0}).addChild("categorie_function_all",["insert","insert_function"],{...MT,sequence:50}).addChild("categories_function_list",["insert","insert_function"],(()=>{const e=$b.content;return[...new Set($b.getAll().filter((e=>!e.hidden)).map((e=>e.category)))].filter(at).sort().map(((t,o)=>{const s=Object.keys(e).filter((o=>e[o].category===t&&!e[o].hidden));return{name:t,children:VT(s)}}))})).addChild("insert_link",["insert"],{...PT,separator:!0,sequence:70}).addChild("insert_checkbox",["insert"],{...NT,sequence:80}).addChild("insert_dropdown",["insert"],{...kT,separator:!0,sequence:90}).add("format",{name:Fo("Format"),sequence:50}).addChild("format_number",["format"],{...B_,name:Fo("Number"),sequence:10,separator:!0}).addChild("format_bold",["format"],{...PA,sequence:20}).addChild("format_italic",["format"],{...NA,sequence:30}).addChild("format_underline",["format"],{...kA,sequence:40}).addChild("format_strikethrough",["format"],{...LA,sequence:50,separator:!0}).addChild("format_font_size",["format"],{...VA,sequence:60,separator:!0}).addChild("format_alignment",["format"],{...HA,sequence:70}).addChild("format_alignment_left",["format","format_alignment"],{...BA,sequence:10}).addChild("format_alignment_center",["format","format_alignment"],{...zA,sequence:20}).addChild("format_alignment_right",["format","format_alignment"],{...$A,sequence:30,separator:!0}).addChild("format_alignment_top",["format","format_alignment"],{...GA,sequence:40}).addChild("format_alignment_middle",["format","format_alignment"],{...qA,sequence:50}).addChild("format_alignment_bottom",["format","format_alignment"],{...ZA,sequence:60,separator:!0}).addChild("format_wrapping",["format"],{...jA,sequence:80,separator:!0}).addChild("format_wrapping_overflow",["format","format_wrapping"],{...XA,sequence:10}).addChild("format_wrapping_wrap",["format","format_wrapping"],{...KA,sequence:20}).addChild("format_wrapping_clip",["format","format_wrapping"],{...JA,sequence:30}).addChild("format_cf",["format"],{...t_,sequence:90,separator:!0}).addChild("format_clearFormat",["format"],{...o_,sequence:100,separator:!0}).add("data",{name:Fo("Data"),sequence:60}).addChild("sort_range",["data"],{...YT,sequence:10,separator:!0}).addChild("sort_ascending",["data","sort_range"],{...XT,sequence:10}).addChild("sort_descending",["data","sort_range"],{...eA,sequence:20}).addChild("data_cleanup",["data"],{...KT,sequence:15}).addChild("remove_duplicates",["data","data_cleanup"],{...JT,sequence:10}).addChild("trim_whitespace",["data","data_cleanup"],{...QT,sequence:20}).addChild("split_to_columns",["data"],{...sA,sequence:20}).addChild("data_validation",["data"],{name:Fo("Data Validation"),execute:e=>{e.openSidePanel("DataValidation")},icon:"o-spreadsheet-Icon.DATA_VALIDATION",sequence:30,separator:!0}).addChild("add_remove_data_filter",["data"],{...tA,sequence:40,separator:!0}).addChild("data_sources_data",["data"],(e=>e.model.getters.getPivotIds().map(((t,o)=>{const s={get highlights(){return $_(e.model.getters,t)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:50+o,isReadonlyAllowed:!0,execute:e=>e.openSidePanel("PivotSidePanel",{pivotId:t}),onStartHover:e=>e.getStore(Xb).register(s),onStopHover:e=>e.getStore(Xb).unRegister(s),icon:"o-spreadsheet-Icon.PIVOT",separator:o===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(t)?"o-spreadsheet-Icon.UNUSED_PIVOT_WARNING":void 0}})))).addChild("reinsert_dynamic_pivot",["data"],iA).addChild("reinsert_static_pivot",["data"],nA);const G_=new class extends n{addTransformation(e,t,o){for(let s of t)this.content[s]||(this.content[s]=new Map),this.content[s].set(e,o);return this}getTransformation(e,t){return this.content[e]&&this.content[e].get(t)}};class q_ extends t.Component{static template="o_spreadsheet.Section";static props={class:{type:String,optional:!0},title:{type:String,optional:!0},slots:Object}}function Z_(e,t,o=(()=>{})){const s=()=>{window.removeEventListener("pointerdown",o),window.removeEventListener("pointerup",i),window.removeEventListener("dragstart",n),window.removeEventListener("pointermove",e),window.removeEventListener("wheel",e)},i=e=>{t(e),s()};function n(e){e.preventDefault()}return window.addEventListener("pointerdown",o),window.addEventListener("pointerup",i),window.addEventListener("dragstart",n),window.addEventListener("pointermove",e),window.addEventListener("wheel",e,{passive:!1}),s}function j_(e,t,o,s=!1){let i,n,r,a,l,c=null;const h=e.model.getters,d=h.getActiveSheetId(),u=oR();let g,p;const m=o=>{if(i=o,c)return;const{x:r,y:f}=h.getMainViewportCoordinates();let{top:v,left:b,bottom:S,right:y}=h.getActiveMainViewport(),{scrollX:C,scrollY:w}=h.getActiveSheetScrollInfo();const{xSplit:x,ySplit:E}=h.getPaneDivisions(d);let I=!1,R=140;const T=i.clientX-u.left;if(g=h.getColIndex(T),"vertical"!==s){const t=n.clientX-u.left,o=h.getEdgeScrollCol(T,t,a);if(o.canEdgeScroll){let t;switch(I=!0,R=Math.min(R,o.delay),o.direction){case"reset":g=x,t=x;break;case 1:g=y,t=b+1;break;case-1:for(g=b-1;e.model.getters.isColHidden(d,g);)g--;t=g}C=h.getColDimensions(d,t).start-r}}const A=i.clientY-u.top;if(p=h.getRowIndex(A),"horizontal"!==s){const t=n.clientY-u.top,o=h.getEdgeScrollRow(A,t,l);if(o.canEdgeScroll){let t;switch(I=!0,R=Math.min(R,o.delay),o.direction){case"reset":p=E,t=E;break;case 1:p=S,t=v+o.direction;break;case-1:for(p=v-1;e.model.getters.isRowHidden(d,p);)p--;t=p}w=e.model.getters.getRowDimensions(d,t).start-f}}I||(-1===p&&(p=A<0?0:h.getNumberRows(d)-1),-1===g&&T<0&&(g=T<0?0:h.getNumberCols(d)-1)),t(g,p,i),I&&(e.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:C,offsetY:w}),c=setTimeout((()=>{c=null,m(i)}),Math.round(R))),n=i};Z_(m,(()=>{clearTimeout(c),o()}),(e=>{n=e,r=e,a=r.clientX-u.left,l=r.clientY-u.top}))}function Y_(){let e;const o=document.body.style.cursor;let s=[];const i=()=>{e=void 0,document.body.style.cursor=o,s.forEach((e=>e())),s=[]};t.onWillUnmount((()=>{i()}));const n=t.useState({itemsStyle:{},draggedItemId:void 0,start:(t,r)=>{n.cancel=()=>{n.draggedItemId=void 0,n.itemsStyle={},document.body.style.cursor=o,r.onCancel?.(),i()};document.body.style.cursor="move",n.draggedItemId=r.draggedItemId;const a="horizontal"===t?new Q_(r.containerEl):new J_(r.containerEl);e=new X_({...r,container:a,onChange:()=>{document.body.style.cursor="move",e&&(Object.assign(n.itemsStyle,e.getItemStyles()),r.onChange?.())},onDragEnd:(e,t)=>{n.draggedItemId=void 0,n.itemsStyle={},document.body.style.cursor=o,r.onDragEnd?.(e,t),i()},onCancel:n.cancel});const l=Z_(e.onMouseMove.bind(e),e.onMouseUp.bind(e));s.push(l);const c=e.onScroll.bind(e);r.containerEl.addEventListener("scroll",c),s.push((()=>r.containerEl.removeEventListener("scroll",c))),s.push(e.destroy.bind(e))},cancel:()=>{}});return n}class X_{draggedItemId;items;container;initialMousePosition;currentMousePosition;initialScroll;minPosition;maxPosition;edgeScrollIntervalId;onChange;onCancel;onDragEnd;deadZone;constructor(e){this.items=e.items.map((e=>({...e,positionAtStart:e.position}))),this.draggedItemId=e.draggedItemId,this.container=e.container,this.onChange=e.onChange,this.onCancel=e.onCancel,this.onDragEnd=e.onDragEnd,this.initialMousePosition=e.initialMousePosition,this.currentMousePosition=e.initialMousePosition,this.initialScroll=this.container.scroll,this.minPosition=this.items[0].position,this.maxPosition=this.items[this.items.length-1].position+this.items[this.items.length-1].size}getItemStyles(){const e={};for(let t of this.items)e[t.id]=this.getItemStyle(t.id);return e}getItemStyle(e){const t=this.container.cssPositionProperty,o={position:"relative"};return o[t]=(this.getItemsPositions()[e]||0)+"px",o.transition=`${t} 0.5s`,o["pointer-events"]="none",this.draggedItemId===e&&(o.transition=`${t} 0s`,o["z-index"]="1000"),kc(o)}onScroll(){this.moveDraggedItemToPosition(this.currentMousePosition+this.scrollOffset)}onMouseMove(e){if(e.button>1)return void this.onCancel();const t=this.container.getMousePosition(e);this.currentMousePosition=t,t<this.container.start||t>this.container.end?this.startEdgeScroll(t<this.container.start?-1:1):(this.stopEdgeScroll(),this.moveDraggedItemToPosition(t+this.scrollOffset))}moveDraggedItemToPosition(e){const t=this.getHoveredItemIndex(e,this.items),o=this.items.findIndex((e=>e.id===this.draggedItemId)),s=this.items[o];if(this.deadZone&&this.isInZone(e,this.deadZone))return void this.onChange(this.getItemsPositions());if(this.isInZone(e,{start:s.position,end:s.position+s.size})&&(this.deadZone=void 0),o===t)return void this.onChange(this.getItemsPositions());const i=Math.min(o,t),n=Math.max(o,t),r=Math.sign(t-o);let a=0;for(let e=i;e<=n;e++)e!==o&&(this.items[e].position-=r*s.size,a+=this.items[e].size);s.position+=r*a,this.items.sort(((e,t)=>e.position-t.position)),this.deadZone=r>0?{start:e,end:s.position}:{start:s.position+s.size,end:e},this.onChange(this.getItemsPositions())}onMouseUp(e){0!==e.button&&this.onCancel(),e.stopPropagation(),e.preventDefault();const t=this.items.findIndex((e=>e.id===this.draggedItemId));return this.onDragEnd(this.draggedItemId,t),this.stopEdgeScroll(),!1}startEdgeScroll(e){this.edgeScrollIntervalId||(this.edgeScrollIntervalId=window.setInterval((()=>{const t=3*e;this.container.scroll+=t}),5))}stopEdgeScroll(){window.clearInterval(this.edgeScrollIntervalId),this.edgeScrollIntervalId=void 0}getHoveredItemIndex(e,t){return e<=this.minPosition?0:e>=this.maxPosition?t.length-1:t.findIndex((t=>t.position+t.size>=e))}getItemsPositions(){const e={};for(let t of this.items){if(t.id!==this.draggedItemId){e[t.id]=t.position-t.positionAtStart;continue}let o=this.currentMousePosition-this.initialMousePosition+this.scrollOffset;o=Math.max(this.minPosition-t.positionAtStart,o),o=Math.min(this.maxPosition-t.positionAtStart-t.size,o),e[t.id]=o}return e}isInZone(e,t){return e>=t.start&&e<=t.end}get scrollOffset(){return this.container.scroll-this.initialScroll}destroy(){this.stopEdgeScroll()}}class K_{el;constructor(e){this.el=e}get containerRect(){return this.el.getBoundingClientRect()}}class J_ extends K_{get start(){return this.containerRect.top}get end(){return this.containerRect.bottom}get cssPositionProperty(){return"top"}get scroll(){return this.el.scrollTop}set scroll(e){this.el.scrollTop=e}getMousePosition(e){return e.clientY}}class Q_ extends K_{get start(){return this.containerRect.left}get end(){return this.containerRect.right}get cssPositionProperty(){return"left"}get scroll(){return this.el.scrollLeft}set scroll(e){this.el.scrollLeft=e}getMousePosition(e){return e.clientX}}const eD={ArrowDown:"down",ArrowLeft:"left",ArrowRight:"right",ArrowUp:"up"};function tD(e,t){const o=eD[e.key];e.shiftKey?t.resizeAnchorZone(o,hR(e)?"end":1):t.moveAnchorCell(o,hR(e)?"end":1)}class oD{mutators=["focus","unfocus"];focusedElement=null;focus(e){this.focusedElement=e}unfocus(e){this.focusedElement&&this.focusedElement===e&&(this.focusedElement=null)}}class sD extends Ac{initialRanges;inputHasSingleRange;colors;mutators=["resetWithRanges","focusById","unfocus","addEmptyRange","removeRange","changeRange","reset","confirm","updateColors"];ranges=[];focusedRangeIndex=null;inputSheetId;focusStore=this.get(oD);highlightStore=this.get(Xb);constructor(e,t=[],o=!1,s=[]){if(super(e),this.initialRanges=t,this.inputHasSingleRange=o,this.colors=s,o&&t.length>1)throw new Error("Input with a single range cannot be instantiated with several range references.");this.inputSheetId=this.getters.getActiveSheetId(),this.resetWithRanges(t),this.highlightStore.register(this),this.onDispose((()=>{this.unfocus(),this.highlightStore.unRegister(this)}))}handleEvent(e){if(null===this.focusedRangeIndex)return;const t=this.inputSheetId,o=this.getters.getActiveSheetId(),s=e.options.unbounded?this.getters.getUnboundedZone(o,e.anchor.zone):e.anchor.zone,i=this.getters.getRangeFromZone(o,s);if("newAnchor"===e.mode&&!this.inputHasSingleRange&&""!==this.ranges[this.focusedRangeIndex].xc.trim()){const e=this.getters.getSelectionRangeString(i,t);this.insertNewRange(this.ranges.length,[e]),this.focusLast()}else{let e=i.parts;const o=this.ranges[this.focusedRangeIndex].xc.trim();o&&(e=this.getters.getRangeFromSheetXC(t,o).parts);const s=i.clone({parts:e}),n=this.getters.getSelectionRangeString(s,t);this.setRange(this.focusedRangeIndex,[n])}}handle(e){switch(e.type){case"ACTIVATE_SHEET":if(e.sheetIdFrom!==e.sheetIdTo){const{col:t,row:o}=this.getters.getNextVisibleCellPosition({sheetId:e.sheetIdTo,col:0,row:0}),s=this.getters.expandZone(e.sheetIdTo,fs({col:t,row:o}));this.model.selection.resetAnchor(this,{cell:{col:t,row:o},zone:s})}break;case"START_CHANGE_HIGHLIGHT":const t=this.getters.getActiveSheetId(),o=this.getters.expandZone(t,e.zone),s=this.ranges.findIndex((e=>{const{xc:s,sheetName:i}=qo(e.xc),n=i||this.getters.getSheetName(this.inputSheetId);if(this.getters.getSheetName(t)!==n)return!1;const r=this.getters.getRangeFromSheetXC(t,s);return ns(this.getters.expandZone(t,r.zone),o)}));if(-1!==s){this.focus(s);const{left:e,top:t}=o;this.model.selection.resetAnchor(this,{cell:{col:e,row:t},zone:o})}}}changeRange(e,t){if(this.inputHasSingleRange&&t.split(",").length>1)return;const o=this.getIndex(e);if(null!==o&&this.focusedRangeIndex!==o&&this.focus(o),null!==o){const e=t.replace(/^,+/,"").split(",").map((e=>e.trim()));this.setRange(o,e),this.captureSelection()}}addEmptyRange(){this.inputHasSingleRange&&1===this.ranges.length||(this.insertNewRange(this.ranges.length,[""]),this.focusLast())}removeRange(e){if(1===this.ranges.length)return;const t=this.getIndex(e);null!==t&&this.removeRangeByIndex(t)}updateColors(e){this.colors=e}confirm(){for(const e of this.selectionInputs)""===e.xc&&this.removeRange(e.id);const e=this.getters.getActiveSheetId();this.inputSheetId!==e&&this.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e,sheetIdTo:this.inputSheetId}),this.selectionInputValues.join()!==this.initialRanges.join()&&this.resetWithRanges(this.selectionInputValues),this.initialRanges=this.selectionInputValues,this.unfocus()}reset(){this.resetWithRanges(this.initialRanges),this.confirm()}get selectionInputValues(){return this.cleanInputs(this.ranges.map((e=>e.xc?e.xc:"")))}get selectionInputs(){const e=new ho(this.ranges.length,this.colors);return this.ranges.map(((t,o)=>Object.assign({},t,{color:this.hasMainFocus&&null!==this.focusedRangeIndex&&this.getters.isRangeValid(t.xc)?e.next():null,isFocused:this.hasMainFocus&&this.focusedRangeIndex===o,isValidRange:""===t.xc||this.getters.isRangeValid(t.xc)})))}get isResettable(){return this.initialRanges.join()!==this.ranges.map((e=>e.xc)).join()}get isConfirmable(){return this.selectionInputs.every((e=>e.isValidRange))}get hasFocus(){return this.selectionInputs.some((e=>e.isFocused))}get hasMainFocus(){const e=this.focusStore.focusedElement;return!!e&&e===this}get highlights(){return this.hasMainFocus?this.ranges.map((e=>this.inputToHighlights(e))).flat():[]}focusById(e){this.focus(this.getIndex(e))}focus(e){this.focusStore.focus(this),this.focusedRangeIndex=e,this.captureSelection()}focusLast(){this.focus(this.ranges.length-1)}unfocus(){this.focusedRangeIndex=null,this.focusStore.unfocus(this),this.model.selection.release(this)}captureSelection(){if(null===this.focusedRangeIndex)return;const e=this.ranges[this.focusedRangeIndex],t=this.getters.getActiveSheetId(),o=this.getters.getRangeFromSheetXC(t,e?.xc||"A1").zone;this.model.selection.capture(this,{cell:{col:o.left,row:o.top},zone:o},{handleEvent:this.handleEvent.bind(this),release:this.unfocus.bind(this)})}resetWithRanges(e){this.ranges=[],this.insertNewRange(0,e),0===this.ranges.length&&(this.insertNewRange(this.ranges.length,[""]),this.focusLast())}setContent(e,t){this.ranges[e]={...this.ranges[e],xc:t}}insertNewRange(e,t){const o=Math.max(0,...this.ranges.map((e=>Number(e.id)))),s=new ho(this.ranges.length,this.colors);for(let t=0;t<e;t++)s.next();this.ranges.splice(e,0,...t.map(((e,t)=>({xc:e,id:o+t+1,color:s.next()}))))}setRange(e,t){const[,...o]=t;this.setContent(e,t[0]),this.insertNewRange(e+1,o),o.length&&this.focus(e+o.length)}removeRangeByIndex(e){this.ranges.splice(e,1),null!==this.focusedRangeIndex&&this.focusLast()}inputToHighlights({xc:e,color:t}){const o=this.cleanInputs([e]).filter((e=>this.getters.isRangeValid(e))).filter((e=>this.shouldBeHighlighted(this.inputSheetId,e)));return o.map((e=>{const{sheetName:o}=qo(e);return{zone:this.getters.getRangeFromSheetXC(this.inputSheetId,e).zone,sheetId:o&&this.getters.getSheetIdByName(o)||this.inputSheetId,color:t,interactive:!0}}))}cleanInputs(e){return e.map((e=>e.split(","))).flat().map((e=>e.trim())).filter((e=>""!==e))}shouldBeHighlighted(e,t){const{sheetName:o}=qo(t),s=this.getters.getSheetIdByName(o),i=this.getters.getActiveSheet().id;return this.getters.isRangeValid(t)&&(s===i||void 0===s&&i===e)}getIndex(e){const t=this.ranges.findIndex((t=>t.id===e));return t>=0?t:null}}Mc`
|
|
293
293
|
.o-selection {
|
|
294
294
|
.o-selection-input {
|
|
295
295
|
padding: 2px 0px;
|
|
@@ -903,7 +903,7 @@
|
|
|
903
903
|
}
|
|
904
904
|
}
|
|
905
905
|
}
|
|
906
|
-
`;class tO extends t.Component{static template="o-spreadsheet-Composer";static props={focus:{validate:e=>["inactive","cellFocus","contentFocus"].includes(e)},inputStyle:{type:String,optional:!0},rect:{type:Object,optional:!0},delimitation:{type:Object,optional:!0},onComposerCellFocused:{type:Function,optional:!0},onComposerContentFocused:Function,isDefaultFocus:{type:Boolean,optional:!0},onInputContextMenu:{type:Function,optional:!0},composerStore:Object,placeholder:{type:String,optional:!0}};static components={TextValueProvider:qD,FunctionDescriptionProvider:XD};static defaultProps={inputStyle:"",isDefaultFocus:!1};DOMFocusableElementStore;composerRef=t.useRef("o_composer");contentHelper=new jD(this.composerRef.el);composerState=t.useState({positionStart:0,positionEnd:0});autoCompleteState;functionDescriptionState=t.useState({showDescription:!1,functionName:"",functionDescription:{},argToFocus:0});assistant=t.useState({forcedClosed:!1});compositionActive=!1;spreadsheetRect=_I();get assistantStyle(){const e=this.composerRef.el.getBoundingClientRect(),t={};t["min-width"]=`${this.props.rect?.width||JD}px`;const o=this.autoCompleteState.provider?.proposals,s=o?.some((e=>e.description));if((this.functionDescriptionState.showDescription||s)&&(t.width="300px"),this.props.delimitation&&this.props.rect){const{x:e,y:o,height:s}=this.props.rect,i=this.props.delimitation.height-(o+s);if(t["max-height"]=`${i}px`,o>i){const e=o;t["max-height"]=e-9+"px",t.top="-3px",t.transform="translate(0, -100%)"}e+JD>this.props.delimitation.width&&(t.right="0px")}else t["max-height"]=this.spreadsheetRect.height-e.bottom+"px",e.left+JD+ie+9>this.spreadsheetRect.width&&(t.right="9px");return kc(t)}shouldProcessInputEvents=!1;tokens=[];keyMapping={Enter:e=>this.processEnterKey(e,"down"),"Shift+Enter":e=>this.processEnterKey(e,"up"),"Alt+Enter":this.processNewLineEvent,"Ctrl+Enter":this.processNewLineEvent,Escape:this.processEscapeKey,F2:e=>this.toggleEditionMode(e),F4:e=>this.processF4Key(e),Tab:e=>this.processTabKey(e,"right"),"Shift+Tab":e=>this.processTabKey(e,"left")};keyCodeMapping={NumpadDecimal:this.processNumpadDecimal};setup(){this.DOMFocusableElementStore=yc(GD),this.autoCompleteState=Cc(ZD),t.onMounted((()=>{const e=this.composerRef.el;this.props.isDefaultFocus&&this.DOMFocusableElementStore.setFocusableElement(e),this.contentHelper.updateEl(e)})),this.env.model.selection.observe(this,{handleEvent:()=>this.autoCompleteState.hide()}),t.onWillUnmount((()=>{this.env.model.selection.detachObserver(this)})),t.useEffect((()=>{this.processContent(),document.activeElement!==this.contentHelper.el||"inactive"!==this.props.composerStore.editionMode||this.props.isDefaultFocus||this.DOMFocusableElementStore.focusableElement?.focus()})),t.useEffect((()=>{this.processTokenAtCursor()}),(()=>["inactive"!==this.props.composerStore.editionMode]))}processArrowKeys(e){const t=this.props.composerStore.tokenAtCursor;if((this.props.composerStore.isSelectingRange||"inactive"===this.props.composerStore.editionMode)&&(!["ArrowUp","ArrowDown"].includes(e.key)||!this.autoCompleteState.provider||"REFERENCE"===t?.type))return this.functionDescriptionState.showDescription=!1,this.autoCompleteState.hide(),e.preventDefault(),e.stopPropagation(),void tD(e,this.env.model.selection);const o=this.props.composerStore.currentContent;"cellFocus"!==this.props.focus||this.autoCompleteState.provider||o.startsWith("=")?(e.stopPropagation(),this.handleArrowKeysForAutocomplete(e)):this.props.composerStore.stopEdition()}handleArrowKeysForAutocomplete(e){["ArrowUp","ArrowDown"].includes(e.key)&&this.autoCompleteState.provider&&(e.preventDefault(),this.autoCompleteState.moveSelection("ArrowDown"===e.key?"next":"previous"))}processTabKey(e,t){if(e.preventDefault(),e.stopPropagation(),"inactive"!==this.props.composerStore.editionMode){const e=this.autoCompleteState;if(e.provider&&void 0!==e.selectedIndex){const t=e.provider.proposals[e.selectedIndex]?.text;if(t)return void this.autoComplete(t)}this.props.composerStore.stopEdition(t)}}processEnterKey(e,t){e.preventDefault(),e.stopPropagation();const o=this.autoCompleteState;if(o.provider&&void 0!==o.selectedIndex){const e=o.provider.proposals[o.selectedIndex]?.text;if(e)return void this.autoComplete(e)}this.props.composerStore.stopEdition(t)}processNewLineEvent(e){e.preventDefault(),e.stopPropagation();const t=this.contentHelper.getText(),o=this.contentHelper.getCurrentSelection(),s=Math.min(o.start,o.end),i=Math.max(o.start,o.end);this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t.slice(0,s)+Pe+t.slice(i),{start:s+1,end:s+1}),this.processContent()}processEscapeKey(e){this.props.composerStore.cancelEdition(),e.stopPropagation(),e.preventDefault()}processF4Key(e){e.stopPropagation(),this.props.composerStore.cycleReferences(),this.processContent()}toggleEditionMode(e){e.stopPropagation(),this.props.composerStore.toggleEditionMode(),this.processContent()}processNumpadDecimal(e){e.stopPropagation(),e.preventDefault();const t=this.env.model.getters.getLocale(),o=this.contentHelper.getCurrentSelection(),s=this.props.composerStore.currentContent,i=s.slice(0,o.start)+t.decimalSeparator+s.slice(o.end);this.props.composerStore.setCurrentContent(i,{start:o.start+1,end:o.start+1}),this.processContent()}onCompositionStart(){this.compositionActive=!0}onCompositionEnd(){this.compositionActive=!1}onKeydown(e){if("inactive"===this.props.composerStore.editionMode)return;if(e.key.startsWith("Arrow"))return void this.processArrowKeys(e);let t=this.keyMapping[lR(e)]||this.keyCodeMapping[lR(e,"code")];t?t.call(this,e):e.stopPropagation()}onPaste(e){"inactive"!==this.props.composerStore.editionMode?e.stopPropagation():e.preventDefault()}onInput(e){if(!this.shouldProcessInputEvents)return;let t;if(e.stopPropagation(),t="inactive"===this.props.composerStore.editionMode?e.data||"":this.contentHelper.getText(),"inactive"===this.props.focus)return this.props.onComposerCellFocused?.(t);let o=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t,o),this.processTokenAtCursor()}onKeyup(e){if(this.contentHelper.el===document.activeElement){if(this.autoCompleteState.provider&&["ArrowUp","ArrowDown"].includes(e.key))return;if(this.props.composerStore.isSelectingRange&&e.key?.startsWith("Arrow"))return;const{start:t,end:o}=this.props.composerStore.composerSelection,{start:s,end:i}=this.contentHelper.getCurrentSelection();s===t&&i===o||this.props.composerStore.changeComposerCursorSelection(s,i),this.processTokenAtCursor()}}onBlur(e){if("inactive"===this.props.composerStore.editionMode)return;const t=e.relatedTarget;t&&t instanceof HTMLElement?t.attributes.getNamedItem("composerFocusableElement")?this.contentHelper.el.focus():t.classList.contains("o-composer")||this.props.composerStore.stopEdition():this.props.composerStore.stopEdition()}updateAutoCompleteIndex(e){this.autoCompleteState.selectIndex(qe(0,e,10))}onMousedown(e){e.button>0||this.contentHelper.removeSelection()}onClick(){if(this.env.model.getters.isReadonly())return;const e=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection(),this.props.onComposerContentFocused(),this.props.composerStore.changeComposerCursorSelection(e.start,e.end),this.processTokenAtCursor()}onDblClick(){if(this.env.model.getters.isReadonly())return;const e=this.props.composerStore.currentContent;if(e.startsWith("=")){const t=this.props.composerStore.currentTokens,o=this.contentHelper.getCurrentSelection();if(o.start===o.end)return;const s=e.substring(o.start,o.end),i=t.filter((e=>e.value.includes(s)&&e.start<=o.start&&e.end>=o.end))[0];if(!i)return;"REFERENCE"===i.type&&this.props.composerStore.changeComposerCursorSelection(i.start,i.end)}}onContextMenu(e){"inactive"===this.props.composerStore.editionMode&&this.props.onInputContextMenu?.(e)}closeAssistant(){this.assistant.forcedClosed=!0}openAssistant(){this.assistant.forcedClosed=!1}processContent(){if(this.compositionActive)return;this.shouldProcessInputEvents=!1,"inactive"!==this.props.focus&&document.activeElement!==this.contentHelper.el&&this.contentHelper.el.focus();const e=this.getContentLines();if(this.contentHelper.setText(e),0!==e.length&&0!==e.length[0]){if("inactive"!==this.props.focus){const{start:e,end:t}=this.props.composerStore.composerSelection;this.contentHelper.selectRange(e,t)}this.contentHelper.scrollSelectionIntoView()}this.shouldProcessInputEvents=!0}getContentLines(){let e=this.props.composerStore.currentContent;const t=e.startsWith("=");return""===e?[]:t&&"inactive"!==this.props.focus?this.splitHtmlContentIntoLines(this.getHtmlContentFromTokens()):this.splitHtmlContentIntoLines([{value:e}])}getHtmlContentFromTokens(){const e=this.props.composerStore.currentTokens,t=[],{end:o,start:s}=this.props.composerStore.composerSelection;for(const i of e){let e=i.color||Jb;i.isBlurred&&(e=Jt(e,.5)),t.push({value:i.value,color:e}),"REFERENCE"===i.type&&this.props.composerStore.tokenAtCursor===i&&"selecting"===this.props.composerStore.editionMode&&(t[t.length-1].class="text-decoration-underline"),o===s&&i.isParenthesisLinkedToCursor&&(t[t.length-1].class=eO),this.props.composerStore.showSelectionIndicator&&o===s&&o===i.end&&(t[t.length-1].class=QD)}return t}splitHtmlContentIntoLines(e){const t=[];let o=[];for(const s of e)if(s.value.includes(Pe)){const e=s.value.split(Pe),i=e.pop();for(const i of e)o.push({color:s.color,value:i}),t.push(o),o=[];o.push({...s,value:i})}else o.push(s);o.length&&t.push(o);const s=[];for(const e of t)e.every(this.isContentEmpty)?s.push([e[0]]):s.push(e.filter((e=>!this.isContentEmpty(e))));return s}isContentEmpty(e){return!(e.value||e.class)}processTokenAtCursor(){let e=this.props.composerStore.currentContent;this.autoCompleteState.provider&&this.autoCompleteState.hide(),this.functionDescriptionState.showDescription=!1;const t=this.props.composerStore.autocompleteProvider;t&&this.autoCompleteState.useProvider(t);const o=this.props.composerStore.tokenAtCursor;if(e.startsWith("=")&&o&&"SYMBOL"!==o.type){const e=o.functionContext,t=e?.parent.toUpperCase();if(e&&t&&t in KD&&"UNKNOWN"!==o.type){const o=KD[t],s=e.argPosition;this.functionDescriptionState.functionName=t,this.functionDescriptionState.functionDescription=o,this.functionDescriptionState.argToFocus=o.getArgToFocus(s+1)-1,this.functionDescriptionState.showDescription=!0}}}autoComplete(e){e&&!this.assistant.forcedClosed&&(this.autoCompleteState.provider?.selectProposal(e),this.processTokenAtCursor())}}class oO extends tS{args;constructor(e,t){super(e),this.args=t,this._currentContent=this.getComposerContent()}getAutoCompleteProviders(){const e=super.getAutoCompleteProviders(),t=this.args().contextualAutocomplete;return t&&e.push(t),e}getComposerContent(){if("inactive"===this.editionMode){const e=this.args().defaultRangeSheetId;return vf(this.args().content).map((t=>{if("REFERENCE"===t.type){const o=this.getters.getRangeFromSheetXC(e,t.value);return this.getters.getRangeString(o,this.getters.getActiveSheetId())}return t.value})).join("")}return this._currentContent}stopEdition(){this._stopEdition()}confirmEdition(e){this.args().onConfirm(e)}getTokenColor(e){if("SYMBOL"===e.type){const t=this.args().getContextualColoredSymbolToken?.(e);if(t)return t}return super.getTokenColor(e)}}Mc`
|
|
906
|
+
`;class tO extends t.Component{static template="o-spreadsheet-Composer";static props={focus:{validate:e=>["inactive","cellFocus","contentFocus"].includes(e)},inputStyle:{type:String,optional:!0},rect:{type:Object,optional:!0},delimitation:{type:Object,optional:!0},onComposerCellFocused:{type:Function,optional:!0},onComposerContentFocused:Function,isDefaultFocus:{type:Boolean,optional:!0},onInputContextMenu:{type:Function,optional:!0},composerStore:Object,placeholder:{type:String,optional:!0}};static components={TextValueProvider:qD,FunctionDescriptionProvider:XD};static defaultProps={inputStyle:"",isDefaultFocus:!1};DOMFocusableElementStore;composerRef=t.useRef("o_composer");contentHelper=new jD(this.composerRef.el);composerState=t.useState({positionStart:0,positionEnd:0});autoCompleteState;functionDescriptionState=t.useState({showDescription:!1,functionName:"",functionDescription:{},argToFocus:0});assistant=t.useState({forcedClosed:!1});compositionActive=!1;spreadsheetRect=_I();get assistantStyle(){const e=this.composerRef.el.getBoundingClientRect(),t={};t["min-width"]=`${this.props.rect?.width||JD}px`;const o=this.autoCompleteState.provider?.proposals,s=o?.some((e=>e.description));if((this.functionDescriptionState.showDescription||s)&&(t.width="300px"),this.props.delimitation&&this.props.rect){const{x:e,y:o,height:s}=this.props.rect,i=this.props.delimitation.height-(o+s);if(t["max-height"]=`${i}px`,o>i){const e=o;t["max-height"]=e-9+"px",t.top="-3px",t.transform="translate(0, -100%)"}e+JD>this.props.delimitation.width&&(t.right="0px")}else t["max-height"]=this.spreadsheetRect.height-e.bottom+"px",e.left+JD+ie+9>this.spreadsheetRect.width&&(t.right="9px");return kc(t)}shouldProcessInputEvents=!1;tokens=[];keyMapping={Enter:e=>this.processEnterKey(e,"down"),"Shift+Enter":e=>this.processEnterKey(e,"up"),"Alt+Enter":this.processNewLineEvent,"Ctrl+Enter":this.processNewLineEvent,Escape:this.processEscapeKey,F2:e=>this.toggleEditionMode(e),F4:e=>this.processF4Key(e),Tab:e=>this.processTabKey(e,"right"),"Shift+Tab":e=>this.processTabKey(e,"left")};keyCodeMapping={NumpadDecimal:this.processNumpadDecimal};setup(){this.DOMFocusableElementStore=yc(GD),this.autoCompleteState=Cc(ZD),t.onMounted((()=>{const e=this.composerRef.el;this.props.isDefaultFocus&&this.DOMFocusableElementStore.setFocusableElement(e),this.contentHelper.updateEl(e)})),this.env.model.selection.observe(this,{handleEvent:()=>this.autoCompleteState.hide()}),t.onWillUnmount((()=>{this.env.model.selection.detachObserver(this)})),t.useEffect((()=>{this.processContent(),document.activeElement!==this.contentHelper.el||"inactive"!==this.props.composerStore.editionMode||this.props.isDefaultFocus||this.DOMFocusableElementStore.focusableElement?.focus()})),t.useEffect((()=>{this.processTokenAtCursor()}),(()=>["inactive"!==this.props.composerStore.editionMode]))}processArrowKeys(e){const t=this.props.composerStore.tokenAtCursor;if((this.props.composerStore.isSelectingRange||"inactive"===this.props.composerStore.editionMode)&&(!["ArrowUp","ArrowDown"].includes(e.key)||!this.autoCompleteState.provider||"REFERENCE"===t?.type))return this.functionDescriptionState.showDescription=!1,this.autoCompleteState.hide(),e.preventDefault(),e.stopPropagation(),void tD(e,this.env.model.selection);const o=this.props.composerStore.currentContent;"cellFocus"!==this.props.focus||this.autoCompleteState.provider||o.startsWith("=")?(e.stopPropagation(),this.handleArrowKeysForAutocomplete(e)):this.props.composerStore.stopEdition()}handleArrowKeysForAutocomplete(e){["ArrowUp","ArrowDown"].includes(e.key)&&this.autoCompleteState.provider&&(e.preventDefault(),this.autoCompleteState.moveSelection("ArrowDown"===e.key?"next":"previous"))}processTabKey(e,t){if(e.preventDefault(),e.stopPropagation(),"inactive"!==this.props.composerStore.editionMode){const e=this.autoCompleteState;if(e.provider&&void 0!==e.selectedIndex){const t=e.provider.proposals[e.selectedIndex]?.text;if(t)return void this.autoComplete(t)}this.props.composerStore.stopEdition(t)}}processEnterKey(e,t){e.preventDefault(),e.stopPropagation();const o=this.autoCompleteState;if(o.provider&&void 0!==o.selectedIndex){const e=o.provider.proposals[o.selectedIndex]?.text;if(e)return void this.autoComplete(e)}this.props.composerStore.stopEdition(t)}processNewLineEvent(e){e.preventDefault(),e.stopPropagation();const t=this.contentHelper.getText(),o=this.contentHelper.getCurrentSelection(),s=Math.min(o.start,o.end),i=Math.max(o.start,o.end);this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t.slice(0,s)+Pe+t.slice(i),{start:s+1,end:s+1}),this.processContent()}processEscapeKey(e){this.props.composerStore.cancelEdition(),e.stopPropagation(),e.preventDefault()}processF4Key(e){e.stopPropagation(),this.props.composerStore.cycleReferences(),this.processContent()}toggleEditionMode(e){e.stopPropagation(),this.props.composerStore.toggleEditionMode(),this.processContent()}processNumpadDecimal(e){e.stopPropagation(),e.preventDefault();const t=this.env.model.getters.getLocale(),o=this.contentHelper.getCurrentSelection(),s=this.props.composerStore.currentContent,i=s.slice(0,o.start)+t.decimalSeparator+s.slice(o.end);this.props.composerStore.setCurrentContent(i,{start:o.start+1,end:o.start+1}),this.processContent()}onCompositionStart(){this.compositionActive=!0}onCompositionEnd(){this.compositionActive=!1}onKeydown(e){if("inactive"===this.props.composerStore.editionMode)return;if(e.key.startsWith("Arrow"))return void this.processArrowKeys(e);let t=this.keyMapping[lR(e)]||this.keyCodeMapping[lR(e,"code")];t?t.call(this,e):e.stopPropagation()}onPaste(e){"inactive"!==this.props.composerStore.editionMode?e.stopPropagation():e.preventDefault()}onInput(e){if(!this.shouldProcessInputEvents)return;let t;if(e.stopPropagation(),t="inactive"===this.props.composerStore.editionMode?e.data||"":this.contentHelper.getText(),"inactive"===this.props.focus)return this.props.onComposerCellFocused?.(t);let o=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t,o),this.processTokenAtCursor()}onKeyup(e){if(this.contentHelper.el===document.activeElement){if(this.autoCompleteState.provider&&["ArrowUp","ArrowDown"].includes(e.key))return;if(this.props.composerStore.isSelectingRange&&e.key?.startsWith("Arrow"))return;const{start:t,end:o}=this.props.composerStore.composerSelection,{start:s,end:i}=this.contentHelper.getCurrentSelection();s===t&&i===o||this.props.composerStore.changeComposerCursorSelection(s,i),this.processTokenAtCursor()}}onBlur(e){if("inactive"===this.props.composerStore.editionMode)return;const t=e.relatedTarget;t&&t instanceof HTMLElement?t.attributes.getNamedItem("composerFocusableElement")?this.contentHelper.el.focus():t.classList.contains("o-composer")||this.props.composerStore.stopEdition():this.props.composerStore.stopEdition()}updateAutoCompleteIndex(e){this.autoCompleteState.selectIndex(qe(0,e,10))}onMousedown(e){e.button>0||this.contentHelper.removeSelection()}onClick(){if(this.env.model.getters.isReadonly())return;const e=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection(),this.props.onComposerContentFocused(),this.props.composerStore.changeComposerCursorSelection(e.start,e.end),this.processTokenAtCursor()}onDblClick(){if(this.env.model.getters.isReadonly())return;const e=this.props.composerStore.currentContent;if(e.startsWith("=")){const t=this.props.composerStore.currentTokens,o=this.contentHelper.getCurrentSelection();if(o.start===o.end)return;const s=e.substring(o.start,o.end),i=t.filter((e=>e.value.includes(s)&&e.start<=o.start&&e.end>=o.end))[0];if(!i)return;"REFERENCE"===i.type&&this.props.composerStore.changeComposerCursorSelection(i.start,i.end)}}onContextMenu(e){"inactive"===this.props.composerStore.editionMode&&this.props.onInputContextMenu?.(e)}closeAssistant(){this.assistant.forcedClosed=!0}openAssistant(){this.assistant.forcedClosed=!1}processContent(){if(this.compositionActive)return;this.shouldProcessInputEvents=!1,"inactive"!==this.props.focus&&document.activeElement!==this.contentHelper.el&&this.contentHelper.el.focus();const e=this.getContentLines();if(this.contentHelper.setText(e),0!==e.length&&0!==e.length[0]){if("inactive"!==this.props.focus){const{start:e,end:t}=this.props.composerStore.composerSelection;this.contentHelper.selectRange(e,t)}this.contentHelper.scrollSelectionIntoView()}this.shouldProcessInputEvents=!0}getContentLines(){let e=this.props.composerStore.currentContent;const t=e.startsWith("=");return""===e?[]:t&&"inactive"!==this.props.focus?this.splitHtmlContentIntoLines(this.getHtmlContentFromTokens()):this.splitHtmlContentIntoLines([{value:e}])}getHtmlContentFromTokens(){const e=this.props.composerStore.currentTokens,t=[],{end:o,start:s}=this.props.composerStore.composerSelection;for(const i of e){let e=i.color||Jb;i.isBlurred&&(e=Jt(e,.5)),t.push({value:i.value,color:e}),"REFERENCE"===i.type&&this.props.composerStore.tokenAtCursor===i&&"selecting"===this.props.composerStore.editionMode&&(t[t.length-1].class="text-decoration-underline"),o===s&&i.isParenthesisLinkedToCursor&&(t[t.length-1].class=eO),this.props.composerStore.showSelectionIndicator&&o===s&&o===i.end&&(t[t.length-1].class=QD)}return t}splitHtmlContentIntoLines(e){const t=[];let o=[];for(const s of e)if(s.value.includes(Pe)){const e=s.value.split(Pe),i=e.pop();for(const i of e)o.push({color:s.color,value:i}),t.push(o),o=[];o.push({...s,value:i})}else o.push(s);o.length&&t.push(o);const s=[];for(const e of t)e.every(this.isContentEmpty)?s.push([e[0]]):s.push(e.filter((e=>!this.isContentEmpty(e))));return s}isContentEmpty(e){return!(e.value||e.class)}processTokenAtCursor(){let e=this.props.composerStore.currentContent;this.autoCompleteState.provider&&this.autoCompleteState.hide(),this.functionDescriptionState.showDescription=!1;const t=this.props.composerStore.autocompleteProvider;t&&this.autoCompleteState.useProvider(t);const o=this.props.composerStore.tokenAtCursor;if(e.startsWith("=")&&o&&"SYMBOL"!==o.type){const e=o.functionContext,t=e?.parent.toUpperCase();if(e&&t&&t in KD&&"UNKNOWN"!==o.type){const o=KD[t],s=e.argPosition;this.functionDescriptionState.functionName=t,this.functionDescriptionState.functionDescription=o,this.functionDescriptionState.argToFocus=o.getArgToFocus(s+1)-1,this.functionDescriptionState.showDescription=!0}}}autoComplete(e){e&&!this.assistant.forcedClosed&&(this.autoCompleteState.provider?.selectProposal(e),this.processTokenAtCursor())}}class oO extends tS{args;constructor(e,t){super(e),this.args=t,this._currentContent=this.getComposerContent()}getAutoCompleteProviders(){const e=super.getAutoCompleteProviders(),t=this.args().contextualAutocomplete;return t&&e.push(t),e}getZoneReference(e){const t=super.getZoneReference(e);return this.args().defaultStatic?Hf(t,"colrow"):t}getComposerContent(){if("inactive"===this.editionMode){const e=this.args().defaultRangeSheetId;return vf(this.args().content).map((t=>{if("REFERENCE"===t.type){const o=this.getters.getRangeFromSheetXC(e,t.value);return this.getters.getRangeString(o,this.getters.getActiveSheetId())}return t.value})).join("")}return this._currentContent}stopEdition(){this._stopEdition()}confirmEdition(e){this.args().onConfirm(e)}getTokenColor(e){if("SYMBOL"===e.type){const t=this.args().getContextualColoredSymbolToken?.(e);if(t)return t}return super.getTokenColor(e)}}Mc`
|
|
907
907
|
.o-spreadsheet {
|
|
908
908
|
.o-standalone-composer {
|
|
909
909
|
min-height: 24px;
|
|
@@ -927,7 +927,7 @@
|
|
|
927
927
|
}
|
|
928
928
|
}
|
|
929
929
|
}
|
|
930
|
-
`;class sO extends t.Component{static template="o-spreadsheet-StandaloneComposer";static props={composerContent:{type:String,optional:!0},defaultRangeSheetId:{type:String,optional:!0},onConfirm:Function,contextualAutocomplete:{type:Object,optional:!0},placeholder:{type:String,optional:!0},class:{type:String,optional:!0},invalid:{type:Boolean,optional:!0},getContextualColoredSymbolToken:{type:Function,optional:!0}};static components={Composer:tO};static defaultProps={composerContent:""};composerFocusStore;standaloneComposerStore;composerInterface;spreadsheetRect=_I();setup(){this.composerFocusStore=yc(Dc);const e=Cc(oO,(()=>({onConfirm:this.props.onConfirm,content:this.props.composerContent,contextualAutocomplete:this.props.contextualAutocomplete,defaultRangeSheetId:this.props.defaultRangeSheetId,getContextualColoredSymbolToken:this.props.getContextualColoredSymbolToken})));this.standaloneComposerStore=e,this.composerInterface={id:"standaloneComposer",get editionMode(){return e.editionMode},startEdition:this.standaloneComposerStore.startEdition,setCurrentContent:this.standaloneComposerStore.setCurrentContent,stopEdition:this.standaloneComposerStore.stopEdition}}get focus(){return this.composerFocusStore.activeComposer===this.composerInterface?this.composerFocusStore.focusMode:"inactive"}get composerStyle(){return this.props.invalid?kc({padding:"1px 0px 0px 0px"}):kc({padding:"1px 0px"})}get containerClass(){return["inactive"===this.focus?"":"active",this.props.invalid?"o-invalid":"",this.props.class||""].join(" ")}onFocus(e){this.composerFocusStore.focusComposer(this.composerInterface,{selection:e})}}Mc`
|
|
930
|
+
`;class sO extends t.Component{static template="o-spreadsheet-StandaloneComposer";static props={composerContent:{type:String,optional:!0},defaultRangeSheetId:{type:String,optional:!0},defaultStatic:{type:Boolean,optional:!0},onConfirm:Function,contextualAutocomplete:{type:Object,optional:!0},placeholder:{type:String,optional:!0},class:{type:String,optional:!0},invalid:{type:Boolean,optional:!0},getContextualColoredSymbolToken:{type:Function,optional:!0}};static components={Composer:tO};static defaultProps={composerContent:"",defaultStatic:!1};composerFocusStore;standaloneComposerStore;composerInterface;spreadsheetRect=_I();setup(){this.composerFocusStore=yc(Dc);const e=Cc(oO,(()=>({onConfirm:this.props.onConfirm,content:this.props.composerContent,defaultStatic:this.props.defaultStatic??!1,contextualAutocomplete:this.props.contextualAutocomplete,defaultRangeSheetId:this.props.defaultRangeSheetId,getContextualColoredSymbolToken:this.props.getContextualColoredSymbolToken})));this.standaloneComposerStore=e,this.composerInterface={id:"standaloneComposer",get editionMode(){return e.editionMode},startEdition:this.standaloneComposerStore.startEdition,setCurrentContent:this.standaloneComposerStore.setCurrentContent,stopEdition:this.standaloneComposerStore.stopEdition}}get focus(){return this.composerFocusStore.activeComposer===this.composerInterface?this.composerFocusStore.focusMode:"inactive"}get composerStyle(){return this.props.invalid?kc({padding:"1px 0px 0px 0px"}):kc({padding:"1px 0px"})}get containerClass(){return["inactive"===this.focus?"":"active",this.props.invalid?"o-invalid":"",this.props.class||""].join(" ")}onFocus(e){this.composerFocusStore.focusComposer(this.composerInterface,{selection:e})}}Mc`
|
|
931
931
|
.o-icon-picker {
|
|
932
932
|
position: absolute;
|
|
933
933
|
z-index: ${Oe.IconPicker};
|
|
@@ -1104,7 +1104,7 @@
|
|
|
1104
1104
|
color: #6aa84f;
|
|
1105
1105
|
}
|
|
1106
1106
|
}
|
|
1107
|
-
`;class hO extends t.Component{static template="o-spreadsheet-ConditionalFormattingEditor";static props={editedCf:Object,onCancel:Function,onSave:Function};static components={SelectionInput:iD,IconPicker:iO,ColorPickerWidget:vD,ConditionalFormatPreviewList:cO,Section:q_,RoundColorPicker:CD,StandaloneComposer:sO,BadgeSelection:gD,ValidationMessages:rD};icons=yy;cellIsOperators=ux;iconSets=Cy;getTextDecoration=Pc;colorNumberString=Ht;state;setup(){switch(this.state=t.useState({errors:[],currentCFType:this.props.editedCf.rule.type,ranges:this.props.editedCf.ranges,rules:this.getDefaultRules()}),this.props.editedCf.rule.type){case"CellIsRule":this.state.rules.cellIs=this.props.editedCf.rule;break;case"ColorScaleRule":this.state.rules.colorScale=this.props.editedCf.rule;break;case"IconSetRule":this.state.rules.iconSet=this.props.editedCf.rule;break;case"DataBarRule":this.state.rules.dataBar=this.props.editedCf.rule}t.useExternalListener(window,"click",this.closeMenus)}get isRangeValid(){return this.state.errors.includes("EmptyRange")}get errorMessages(){return this.state.errors.map((e=>dx.Errors[e]||dx.Errors.Unexpected))}get cfTypesValues(){return[{value:"CellIsRule",label:Fo("Single color")},{value:"ColorScaleRule",label:Fo("Color scale")},{value:"IconSetRule",label:Fo("Icon set")},{value:"DataBarRule",label:Fo("Data bar")}]}updateConditionalFormat(e){const t=e.ranges||this.state.ranges;if(this.state.ranges.some((e=>!e.match(Uo))))return e.suppressErrors||(this.state.errors=["InvalidRange"]),["InvalidRange"];const o=this.env.model.getters.getActiveSheetId(),s=this.env.model.getters.getLocale(),i=e.rule||this.getEditedRule(this.state.currentCFType),n=this.env.model.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{rule:La(i,s),id:this.props.editedCf.id},ranges:t.map((e=>this.env.model.getters.getRangeDataFromXc(o,e))),sheetId:o}).reasons.filter((e=>"NoChanges"!==e));return e.suppressErrors||(this.state.errors=n),n}getEditedRule(e){switch(e){case"CellIsRule":return this.state.rules.cellIs;case"ColorScaleRule":return this.state.rules.colorScale;case"IconSetRule":return this.state.rules.iconSet;case"DataBarRule":return this.state.rules.dataBar}}onSave(){0===this.updateConditionalFormat({}).length&&this.props.onSave()}getDefaultRules(){return{cellIs:{type:"CellIsRule",operator:"IsNotEmpty",values:[],style:{fillColor:"#b6d7a8"}},colorScale:{type:"ColorScaleRule",minimum:{type:"value",color:Yy("EFF7FF")},midpoint:void 0,maximum:{type:"value",color:6989903}},iconSet:{type:"IconSetRule",icons:{upper:"arrowGood",middle:"arrowNeutral",lower:"arrowBad"},upperInflectionPoint:{type:"percentage",value:"66",operator:"gt"},lowerInflectionPoint:{type:"percentage",value:"33",operator:"gt"}},dataBar:{type:"DataBarRule",color:14281427}}}changeRuleType(e){this.state.currentCFType!==e&&(this.state.errors=[],this.state.currentCFType=e,this.updateConditionalFormat({rule:this.getEditedRule(e),suppressErrors:!0}))}onRangeUpdate(e){this.state.ranges=e}onRangeConfirmed(){this.updateConditionalFormat({ranges:this.state.ranges})}toggleMenu(e){const t=this.state.openedMenu===e;this.closeMenus(),t||(this.state.openedMenu=e)}closeMenus(){this.state.openedMenu=void 0}get isValue1Invalid(){return this.state.errors.includes("FirstArgMissing")||this.state.errors.includes("ValueCellIsInvalidFormula")}get isValue2Invalid(){return this.state.errors.includes("SecondArgMissing")}toggleStyle(e){const t=this.state.rules.cellIs.style;t[e]=!t[e],this.updateConditionalFormat({rule:this.state.rules.cellIs}),this.closeMenus()}onKeydown(e){if("F4"===e.key){const t=e.target,o=Uf({start:t.selectionStart??0,end:t.selectionEnd??0},t.value,this.env.model.getters.getLocale());if(!o)return;t.value=o.content,t.setSelectionRange(o.selection.start,o.selection.end),t.dispatchEvent(new Event("input"))}}setColor(e,t){this.state.rules.cellIs.style[e]=t,this.updateConditionalFormat({rule:this.state.rules.cellIs}),this.closeMenus()}editOperator(e){this.state.rules.cellIs.operator=e,this.updateConditionalFormat({rule:this.state.rules.cellIs,suppressErrors:!0}),this.closeMenus()}isValueInvalid(e){switch(e){case"minimum":return this.state.errors.includes("MinInvalidFormula")||this.state.errors.includes("MinBiggerThanMid")||this.state.errors.includes("MinBiggerThanMax")||this.state.errors.includes("MinNaN");case"midpoint":return this.state.errors.includes("MidInvalidFormula")||this.state.errors.includes("MidNaN")||this.state.errors.includes("MidBiggerThanMax");case"maximum":return this.state.errors.includes("MaxInvalidFormula")||this.state.errors.includes("MaxNaN");default:return!1}}setColorScaleColor(e,t){if(!zt(t))return;const o=this.state.rules.colorScale[e];o&&(o.color=Ut(t)),this.updateConditionalFormat({rule:this.state.rules.colorScale}),this.closeMenus()}getPreviewGradient(){const e=this.state.rules.colorScale,t=Ht(e.minimum.color),o=Ht(e.midpoint?.color||v),s=Ht(e.maximum.color),i="background-image: linear-gradient(to right, ";return void 0===e.midpoint?i+t+", "+s+")":i+t+", "+o+", "+s+")"}getThresholdColor(e){return Ht(e?e.color:v)}onMidpointChange(e){const t=e.target.value,o=this.state.rules.colorScale;o.midpoint="none"===t?void 0:{color:v,value:"",...o.midpoint,type:t},this.updateConditionalFormat({rule:o,suppressErrors:!0})}updateThresholdType(e,t){this.state.rules.colorScale[e].type=t,this.updateConditionalFormat({rule:this.state.rules.colorScale,suppressErrors:!0})}updateThresholdValue(e,t){this.state.rules.colorScale[e].value=t,this.updateConditionalFormat({rule:this.state.rules.colorScale})}isInflectionPointInvalid(e){switch(e){case"lowerInflectionPoint":return this.state.errors.includes("ValueLowerInflectionNaN")||this.state.errors.includes("ValueLowerInvalidFormula")||this.state.errors.includes("LowerBiggerThanUpper");case"upperInflectionPoint":return this.state.errors.includes("ValueUpperInflectionNaN")||this.state.errors.includes("ValueUpperInvalidFormula")||this.state.errors.includes("LowerBiggerThanUpper");default:return!0}}reverseIcons(){const e=this.state.rules.iconSet.icons,t=e.upper;e.upper=e.lower,e.lower=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setIconSet(e){const t=this.state.rules.iconSet.icons;t.upper=this.iconSets[e].good,t.middle=this.iconSets[e].neutral,t.lower=this.iconSets[e].bad,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setIcon(e,t){this.state.rules.iconSet.icons[e]=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setInflectionOperator(e,t){this.state.rules.iconSet[e].operator=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setInflectionValue(e,t){this.state.rules.iconSet[e].value=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setInflectionType(e,t,o){this.state.rules.iconSet[e].type=t,this.updateConditionalFormat({rule:this.state.rules.iconSet,suppressErrors:!0})}getCellIsRuleComposerProps(e){const t=0===e?this.isValue1Invalid:this.isValue2Invalid;return{onConfirm:t=>{this.state.rules.cellIs.values[e]=t,this.updateConditionalFormat({rule:this.state.rules.cellIs})},composerContent:this.state.rules.cellIs.values[e],placeholder:Fo("Value or formula"),invalid:t,class:"o-sidePanel-composer",defaultRangeSheetId:this.env.model.getters.getActiveSheetId()}}getColorScaleComposerProps(e){const t=this.state.rules.colorScale[e];if(!t)throw new Error("Threshold not found");const o=this.isValueInvalid(e);return{onConfirm:e=>{t.value=e,this.updateConditionalFormat({rule:this.state.rules.colorScale})},composerContent:t.value||"",placeholder:Fo("Formula"),invalid:o,class:"o-sidePanel-composer",defaultRangeSheetId:this.env.model.getters.getActiveSheetId()}}getColorIconSetComposerProps(e){const t=this.state.rules.iconSet[e],o=this.isInflectionPointInvalid(e);return{onConfirm:e=>{t.value=e,this.updateConditionalFormat({rule:this.state.rules.iconSet})},composerContent:t.value||"",placeholder:Fo("Formula"),invalid:o,class:"o-sidePanel-composer",defaultRangeSheetId:this.env.model.getters.getActiveSheetId()}}getRangeValues(){return[this.state.rules.dataBar.rangeValues||""]}updateDataBarColor(e){zt(e)&&(this.state.rules.dataBar.color=Number.parseInt(e.slice(1),16),this.updateConditionalFormat({rule:this.state.rules.dataBar}))}onDataBarRangeUpdate(e){this.state.rules.dataBar.rangeValues=e[0]}onDataBarRangeChange(){this.updateConditionalFormat({rule:this.state.rules.dataBar})}}class dO extends t.Component{static template="o-spreadsheet-ConditionalFormattingPanel";static props={selection:{type:Object,optional:!0},onCloseSidePanel:Function};static components={ConditionalFormatPreviewList:cO,ConditionalFormattingEditor:hO,Section:q_};activeSheetId;originalEditedCf=void 0;state=t.useState({mode:"list"});setup(){this.activeSheetId=this.env.model.getters.getActiveSheetId();const e=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getRulesSelection(e,this.props.selection||[]);if(1===o.length){const e=this.conditionalFormats.find((e=>e.id===o[0]));e&&this.editConditionalFormat(e)}t.onWillUpdateProps((e=>{const t=this.env.model.getters.getActiveSheetId();if(t!==this.activeSheetId)this.activeSheetId=t,this.switchToList();else if(e.selection!==this.props.selection){const t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getRulesSelection(t,e.selection||[]);if(1===o.length){const e=this.conditionalFormats.find((e=>e.id===o[0]));e&&this.editConditionalFormat(e)}else this.switchToList()}}))}get conditionalFormats(){return this.env.model.getters.getConditionalFormats(this.env.model.getters.getActiveSheetId()).map((e=>({...e,rule:Va(e.rule,this.env.model.getters.getLocale())})))}switchToList(){this.state.mode="list",this.state.editedCfId=void 0,this.originalEditedCf=void 0}addConditionalFormat(){const e=this.env.model.uuidGenerator.uuidv4();this.env.model.dispatch("ADD_CONDITIONAL_FORMAT",{sheetId:this.activeSheetId,ranges:this.env.model.getters.getSelectedZones().map((e=>this.env.model.getters.getRangeDataFromZone(this.activeSheetId,e))),cf:{id:e,rule:{type:"CellIsRule",operator:"IsNotEmpty",style:{fillColor:"#b6d7a8"},values:[]}}}),this.state.editedCfId=e,this.state.mode="edit",this.originalEditedCf=void 0}editConditionalFormat(e){this.state.mode="edit",this.state.editedCfId=e.id,this.originalEditedCf=e}cancelEdition(){this.originalEditedCf?this.env.model.dispatch("ADD_CONDITIONAL_FORMAT",{sheetId:this.activeSheetId,ranges:this.originalEditedCf.ranges.map((e=>this.env.model.getters.getRangeDataFromXc(this.activeSheetId,e))),cf:this.originalEditedCf}):this.state.editedCfId&&this.env.model.dispatch("REMOVE_CONDITIONAL_FORMAT",{sheetId:this.activeSheetId,id:this.state.editedCfId}),this.switchToList()}get editedCF(){return this.conditionalFormats.find((e=>e.id===this.state.editedCfId))}}Mc`
|
|
1107
|
+
`;class hO extends t.Component{static template="o-spreadsheet-ConditionalFormattingEditor";static props={editedCf:Object,onCancel:Function,onSave:Function};static components={SelectionInput:iD,IconPicker:iO,ColorPickerWidget:vD,ConditionalFormatPreviewList:cO,Section:q_,RoundColorPicker:CD,StandaloneComposer:sO,BadgeSelection:gD,ValidationMessages:rD};icons=yy;cellIsOperators=ux;iconSets=Cy;getTextDecoration=Pc;colorNumberString=Ht;state;setup(){switch(this.state=t.useState({errors:[],currentCFType:this.props.editedCf.rule.type,ranges:this.props.editedCf.ranges,rules:this.getDefaultRules()}),this.props.editedCf.rule.type){case"CellIsRule":this.state.rules.cellIs=this.props.editedCf.rule;break;case"ColorScaleRule":this.state.rules.colorScale=this.props.editedCf.rule;break;case"IconSetRule":this.state.rules.iconSet=this.props.editedCf.rule;break;case"DataBarRule":this.state.rules.dataBar=this.props.editedCf.rule}t.useExternalListener(window,"click",this.closeMenus)}get isRangeValid(){return this.state.errors.includes("EmptyRange")}get errorMessages(){return this.state.errors.map((e=>dx.Errors[e]||dx.Errors.Unexpected))}get cfTypesValues(){return[{value:"CellIsRule",label:Fo("Single color")},{value:"ColorScaleRule",label:Fo("Color scale")},{value:"IconSetRule",label:Fo("Icon set")},{value:"DataBarRule",label:Fo("Data bar")}]}updateConditionalFormat(e){const t=e.ranges||this.state.ranges;if(this.state.ranges.some((e=>!e.match(Uo))))return e.suppressErrors||(this.state.errors=["InvalidRange"]),["InvalidRange"];const o=this.env.model.getters.getActiveSheetId(),s=this.env.model.getters.getLocale(),i=e.rule||this.getEditedRule(this.state.currentCFType),n=this.env.model.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{rule:La(i,s),id:this.props.editedCf.id},ranges:t.map((e=>this.env.model.getters.getRangeDataFromXc(o,e))),sheetId:o}).reasons.filter((e=>"NoChanges"!==e));return e.suppressErrors||(this.state.errors=n),n}getEditedRule(e){switch(e){case"CellIsRule":return this.state.rules.cellIs;case"ColorScaleRule":return this.state.rules.colorScale;case"IconSetRule":return this.state.rules.iconSet;case"DataBarRule":return this.state.rules.dataBar}}onSave(){0===this.updateConditionalFormat({}).length&&this.props.onSave()}getDefaultRules(){return{cellIs:{type:"CellIsRule",operator:"IsNotEmpty",values:[],style:{fillColor:"#b6d7a8"}},colorScale:{type:"ColorScaleRule",minimum:{type:"value",color:Yy("EFF7FF")},midpoint:void 0,maximum:{type:"value",color:6989903}},iconSet:{type:"IconSetRule",icons:{upper:"arrowGood",middle:"arrowNeutral",lower:"arrowBad"},upperInflectionPoint:{type:"percentage",value:"66",operator:"gt"},lowerInflectionPoint:{type:"percentage",value:"33",operator:"gt"}},dataBar:{type:"DataBarRule",color:14281427}}}changeRuleType(e){this.state.currentCFType!==e&&(this.state.errors=[],this.state.currentCFType=e,this.updateConditionalFormat({rule:this.getEditedRule(e),suppressErrors:!0}))}onRangeUpdate(e){this.state.ranges=e}onRangeConfirmed(){this.updateConditionalFormat({ranges:this.state.ranges})}toggleMenu(e){const t=this.state.openedMenu===e;this.closeMenus(),t||(this.state.openedMenu=e)}closeMenus(){this.state.openedMenu=void 0}get isValue1Invalid(){return this.state.errors.includes("FirstArgMissing")||this.state.errors.includes("ValueCellIsInvalidFormula")}get isValue2Invalid(){return this.state.errors.includes("SecondArgMissing")}toggleStyle(e){const t=this.state.rules.cellIs.style;t[e]=!t[e],this.updateConditionalFormat({rule:this.state.rules.cellIs}),this.closeMenus()}onKeydown(e){if("F4"===e.key){const t=e.target,o=Uf({start:t.selectionStart??0,end:t.selectionEnd??0},t.value,this.env.model.getters.getLocale());if(!o)return;t.value=o.content,t.setSelectionRange(o.selection.start,o.selection.end),t.dispatchEvent(new Event("input"))}}setColor(e,t){this.state.rules.cellIs.style[e]=t,this.updateConditionalFormat({rule:this.state.rules.cellIs}),this.closeMenus()}editOperator(e){this.state.rules.cellIs.operator=e,this.updateConditionalFormat({rule:this.state.rules.cellIs,suppressErrors:!0}),this.closeMenus()}isValueInvalid(e){switch(e){case"minimum":return this.state.errors.includes("MinInvalidFormula")||this.state.errors.includes("MinBiggerThanMid")||this.state.errors.includes("MinBiggerThanMax")||this.state.errors.includes("MinNaN");case"midpoint":return this.state.errors.includes("MidInvalidFormula")||this.state.errors.includes("MidNaN")||this.state.errors.includes("MidBiggerThanMax");case"maximum":return this.state.errors.includes("MaxInvalidFormula")||this.state.errors.includes("MaxNaN");default:return!1}}setColorScaleColor(e,t){if(!zt(t))return;const o=this.state.rules.colorScale[e];o&&(o.color=Ut(t)),this.updateConditionalFormat({rule:this.state.rules.colorScale}),this.closeMenus()}getPreviewGradient(){const e=this.state.rules.colorScale,t=Ht(e.minimum.color),o=Ht(e.midpoint?.color||v),s=Ht(e.maximum.color),i="background-image: linear-gradient(to right, ";return void 0===e.midpoint?i+t+", "+s+")":i+t+", "+o+", "+s+")"}getThresholdColor(e){return Ht(e?e.color:v)}onMidpointChange(e){const t=e.target.value,o=this.state.rules.colorScale;o.midpoint="none"===t?void 0:{color:v,value:"",...o.midpoint,type:t},this.updateConditionalFormat({rule:o,suppressErrors:!0})}updateThresholdType(e,t){this.state.rules.colorScale[e].type=t,this.updateConditionalFormat({rule:this.state.rules.colorScale,suppressErrors:!0})}updateThresholdValue(e,t){this.state.rules.colorScale[e].value=t,this.updateConditionalFormat({rule:this.state.rules.colorScale})}isInflectionPointInvalid(e){switch(e){case"lowerInflectionPoint":return this.state.errors.includes("ValueLowerInflectionNaN")||this.state.errors.includes("ValueLowerInvalidFormula")||this.state.errors.includes("LowerBiggerThanUpper");case"upperInflectionPoint":return this.state.errors.includes("ValueUpperInflectionNaN")||this.state.errors.includes("ValueUpperInvalidFormula")||this.state.errors.includes("LowerBiggerThanUpper");default:return!0}}reverseIcons(){const e=this.state.rules.iconSet.icons,t=e.upper;e.upper=e.lower,e.lower=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setIconSet(e){const t=this.state.rules.iconSet.icons;t.upper=this.iconSets[e].good,t.middle=this.iconSets[e].neutral,t.lower=this.iconSets[e].bad,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setIcon(e,t){this.state.rules.iconSet.icons[e]=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setInflectionOperator(e,t){this.state.rules.iconSet[e].operator=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setInflectionValue(e,t){this.state.rules.iconSet[e].value=t,this.updateConditionalFormat({rule:this.state.rules.iconSet})}setInflectionType(e,t,o){this.state.rules.iconSet[e].type=t,this.updateConditionalFormat({rule:this.state.rules.iconSet,suppressErrors:!0})}getCellIsRuleComposerProps(e){const t=0===e?this.isValue1Invalid:this.isValue2Invalid;return{onConfirm:t=>{this.state.rules.cellIs.values[e]=t,this.updateConditionalFormat({rule:this.state.rules.cellIs})},composerContent:this.state.rules.cellIs.values[e],placeholder:Fo("Value or formula"),defaultStatic:!0,invalid:t,class:"o-sidePanel-composer",defaultRangeSheetId:this.env.model.getters.getActiveSheetId()}}getColorScaleComposerProps(e){const t=this.state.rules.colorScale[e];if(!t)throw new Error("Threshold not found");const o=this.isValueInvalid(e);return{onConfirm:e=>{t.value=e,this.updateConditionalFormat({rule:this.state.rules.colorScale})},composerContent:t.value||"",placeholder:Fo("Formula"),defaultStatic:!0,invalid:o,class:"o-sidePanel-composer",defaultRangeSheetId:this.env.model.getters.getActiveSheetId()}}getColorIconSetComposerProps(e){const t=this.state.rules.iconSet[e],o=this.isInflectionPointInvalid(e);return{onConfirm:e=>{t.value=e,this.updateConditionalFormat({rule:this.state.rules.iconSet})},composerContent:t.value||"",placeholder:Fo("Formula"),defaultStatic:!0,invalid:o,class:"o-sidePanel-composer",defaultRangeSheetId:this.env.model.getters.getActiveSheetId()}}getRangeValues(){return[this.state.rules.dataBar.rangeValues||""]}updateDataBarColor(e){zt(e)&&(this.state.rules.dataBar.color=Number.parseInt(e.slice(1),16),this.updateConditionalFormat({rule:this.state.rules.dataBar}))}onDataBarRangeUpdate(e){this.state.rules.dataBar.rangeValues=e[0]}onDataBarRangeChange(){this.updateConditionalFormat({rule:this.state.rules.dataBar})}}class dO extends t.Component{static template="o-spreadsheet-ConditionalFormattingPanel";static props={selection:{type:Object,optional:!0},onCloseSidePanel:Function};static components={ConditionalFormatPreviewList:cO,ConditionalFormattingEditor:hO,Section:q_};activeSheetId;originalEditedCf=void 0;state=t.useState({mode:"list"});setup(){this.activeSheetId=this.env.model.getters.getActiveSheetId();const e=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getRulesSelection(e,this.props.selection||[]);if(1===o.length){const e=this.conditionalFormats.find((e=>e.id===o[0]));e&&this.editConditionalFormat(e)}t.onWillUpdateProps((e=>{const t=this.env.model.getters.getActiveSheetId();if(t!==this.activeSheetId)this.activeSheetId=t,this.switchToList();else if(e.selection!==this.props.selection){const t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getRulesSelection(t,e.selection||[]);if(1===o.length){const e=this.conditionalFormats.find((e=>e.id===o[0]));e&&this.editConditionalFormat(e)}else this.switchToList()}}))}get conditionalFormats(){return this.env.model.getters.getConditionalFormats(this.env.model.getters.getActiveSheetId()).map((e=>({...e,rule:Va(e.rule,this.env.model.getters.getLocale())})))}switchToList(){this.state.mode="list",this.state.editedCfId=void 0,this.originalEditedCf=void 0}addConditionalFormat(){const e=this.env.model.uuidGenerator.uuidv4();this.env.model.dispatch("ADD_CONDITIONAL_FORMAT",{sheetId:this.activeSheetId,ranges:this.env.model.getters.getSelectedZones().map((e=>this.env.model.getters.getRangeDataFromZone(this.activeSheetId,e))),cf:{id:e,rule:{type:"CellIsRule",operator:"IsNotEmpty",style:{fillColor:"#b6d7a8"},values:[]}}}),this.state.editedCfId=e,this.state.mode="edit",this.originalEditedCf=void 0}editConditionalFormat(e){this.state.mode="edit",this.state.editedCfId=e.id,this.originalEditedCf=e}cancelEdition(){this.originalEditedCf?this.env.model.dispatch("ADD_CONDITIONAL_FORMAT",{sheetId:this.activeSheetId,ranges:this.originalEditedCf.ranges.map((e=>this.env.model.getters.getRangeDataFromXc(this.activeSheetId,e))),cf:this.originalEditedCf}):this.state.editedCfId&&this.env.model.dispatch("REMOVE_CONDITIONAL_FORMAT",{sheetId:this.activeSheetId,id:this.state.editedCfId}),this.switchToList()}get editedCF(){return this.conditionalFormats.find((e=>e.id===this.state.editedCfId))}}Mc`
|
|
1108
1108
|
.o-custom-currency {
|
|
1109
1109
|
.o-format-proposals {
|
|
1110
1110
|
color: black;
|
|
@@ -1653,11 +1653,11 @@
|
|
|
1653
1653
|
margin-left: 8px;
|
|
1654
1654
|
}
|
|
1655
1655
|
}
|
|
1656
|
-
`;class fM extends t.Component{static template="o-spreadsheet-GridAddRowsFooter";static props={focusGrid:Function};static components={ValidationMessages:rD};inputRef=t.useRef("inputRef");state=t.useState({inputValue:"100",errorFlag:!1});setup(){t.useExternalListener(window,"click",this.onExternalClick,{capture:!0})}get addRowsPosition(){const e=this.env.model.getters.getActiveSheetId(),{numberOfRows:t}=this.env.model.getters.getSheetSize(e),{scrollY:o}=this.env.model.getters.getActiveSheetScrollInfo();return kc({top:`${this.env.model.getters.getRowDimensions(e,t-1).end-o}px`})}get errorMessages(){return[Fo("Please enter a number between 0 and 10000.")]}onKeydown(e){"ESCAPE"===e.key.toUpperCase()?this.props.focusGrid():"ENTER"===e.key.toUpperCase()&&this.onConfirm()}onInput(e){const t=e.target.value;this.state.inputValue=t;const o=Number(t);this.state.errorFlag=Number.isNaN(o)||o<=0||o>1e4}onConfirm(){if(this.state.errorFlag)return;const e=Number(this.state.inputValue),t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getNumberRows(t);this.env.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:t,position:"after",base:o-1,quantity:e,dimension:"ROW"}),this.props.focusGrid();const{scrollX:s}=this.env.model.getters.
|
|
1656
|
+
`;class fM extends t.Component{static template="o-spreadsheet-GridAddRowsFooter";static props={focusGrid:Function};static components={ValidationMessages:rD};inputRef=t.useRef("inputRef");state=t.useState({inputValue:"100",errorFlag:!1});setup(){t.useExternalListener(window,"click",this.onExternalClick,{capture:!0})}get addRowsPosition(){const e=this.env.model.getters.getActiveSheetId(),{numberOfRows:t}=this.env.model.getters.getSheetSize(e),{scrollY:o}=this.env.model.getters.getActiveSheetScrollInfo();return kc({top:`${this.env.model.getters.getRowDimensions(e,t-1).end-o}px`})}get errorMessages(){return[Fo("Please enter a number between 0 and 10000.")]}onKeydown(e){"ESCAPE"===e.key.toUpperCase()?this.props.focusGrid():"ENTER"===e.key.toUpperCase()&&this.onConfirm()}onInput(e){const t=e.target.value;this.state.inputValue=t;const o=Number(t);this.state.errorFlag=Number.isNaN(o)||o<=0||o>1e4}onConfirm(){if(this.state.errorFlag)return;const e=Number(this.state.inputValue),t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getNumberRows(t);this.env.model.dispatch("ADD_COLUMNS_ROWS",{sheetId:t,position:"after",base:o-1,quantity:e,dimension:"ROW"}),this.props.focusGrid();const{scrollX:s}=this.env.model.getters.getActiveSheetScrollInfo(),{end:i}=this.env.model.getters.getRowDimensions(t,o+e-1);this.env.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:s,offsetY:i})}onExternalClick(e){this.inputRef.el===document.activeElement&&e.target!==this.inputRef.el&&this.props.focusGrid()}}class vM extends Ac{mutators=["activate","cancel","pasteFormat"];highlightStore=this.get(Xb);clipboardHandlers=[new lc(this.getters,this.model.dispatch),new ga(this.getters,this.model.dispatch),new dc(this.getters,this.model.dispatch),new hc(this.getters,this.model.dispatch)];status="inactive";copiedData;constructor(e){super(e),this.highlightStore.register(this),this.onDispose((()=>{this.highlightStore.unRegister(this)}))}handle(e){if("PAINT_FORMAT"===e.type)this.paintFormat(e.sheetId,e.target)}activate(e){this.copiedData=this.copyFormats(),this.status=e.persistent?"persistent":"oneOff"}cancel(){this.status="inactive",this.copiedData=void 0}pasteFormat(e){this.model.dispatch("PAINT_FORMAT",{target:e,sheetId:this.getters.getActiveSheetId()})}get isActive(){return"inactive"!==this.status}copyFormats(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones(),o={};for(const s of this.clipboardHandlers)Object.assign(o,s.copy(la(e,t)));return o}paintFormat(e,t){if(this.copiedData)for(const o of this.clipboardHandlers)o.paste({zones:t,sheetId:e},this.copiedData,{isCutOperation:!1,pasteOption:"onlyFormat"});"oneOff"===this.status&&this.cancel()}get highlights(){const e=this.copiedData;return e?e.zones.map((t=>({zone:t,color:p,dashed:!0,sheetId:e.sheetId,noFill:!0,thinLine:!0,interactive:!1}))):[]}}function bM(e,o,s){let i={col:void 0,row:void 0};const{Date:n}=window;let r,a,l=0;function c(){if(void 0===r||void 0===a)return{col:-1,row:-1};return{col:e.model.getters.getColIndex(r),row:e.model.getters.getRowIndex(a)}}const{pause:h,resume:d}=function(e,o){let s;const{setInterval:i,clearInterval:n}=window;return t.useEffect((()=>(s=i(e,o),()=>n(s))),(()=>[o])),{pause:()=>{n(s),s=void 0},resume:()=>{void 0===s&&(s=i(e,o))}}}((function(){const{col:e,row:t}=c(),o=n.now()-l;o>300&&(e!==i.col||t!==i.row)&&g(void 0,void 0);if(o>300){if(e<0||t<0)return;g(e,t)}}),200);function u(e){o.el===e.target&&(r=e.offsetX,a=e.offsetY,l=n.now())}function g(e,t){e===i.col&&t===i.row||(i.col=e,i.row=t,s({col:e,row:t}))}return nO(o,"pointermove",u),nO(o,"mouseleave",(function(e){const t=e.offsetX,s=e.offsetY,i=sR(o.el);return s<0||s>i.height||t<0||t>i.width?u(e):h()})),nO(o,"mouseenter",d),nO(o,"pointerdown",(function(){const{col:e,row:t}=c();e===i.col&&t===i.row||g(void 0,void 0)})),t.useExternalListener(window,"click",(function(e){const t=e.target;o.el.contains(t)||g(void 0,void 0)})),i}Mc`
|
|
1657
1657
|
.o-paint-format-cursor {
|
|
1658
1658
|
cursor: url("data:image/svg+xml,${encodeURIComponent('\n<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="14" height="16"><path d="M6.5.4c1.3-.8 2.9-.1 3.8 1.4l2.9 5.1c.2.4.9 1.6-.4 2.3l-1.6.9 1.8 3.1c.2.4.1 1-.2 1.2l-1.6 1c-.3.1-.9 0-1.1-.4l-1.8-3.1-1.6 1c-.6.4-1.7 0-2.2-.8L0 4.3"/><path fill="#fff" d="M9.1 2a1.4 1.1 60 0 0-1.7-.6L5.5 2.5l.9 1.6-1 .6-.9-1.6-.6.4 1.8 3.1-1.3.7-1.8-3.1-1 .6 3.8 6.6 6.8-3.98M3.9 8.8 10.82 5l.795 1.4-6.81 3.96"/></svg>\n')}"), auto;
|
|
1659
1659
|
}
|
|
1660
|
-
`;class SM extends t.Component{static template="o-spreadsheet-GridOverlay";static props={onCellHovered:{type:Function,optional:!0},onCellDoubleClicked:{type:Function,optional:!0},onCellClicked:{type:Function,optional:!0},onCellRightClicked:{type:Function,optional:!0},onGridResized:{type:Function,optional:!0},onFigureDeleted:{type:Function,optional:!0},onGridMoved:Function,gridOverlayDimensions:String};static components={FiguresContainer:gM,DataValidationOverlay:iM,GridAddRowsFooter:fM,FilterIconsOverlay:mM};static defaultProps={onCellHovered:()=>{},onCellDoubleClicked:()=>{},onCellClicked:()=>{},onCellRightClicked:()=>{},onGridResized:()=>{},onFigureDeleted:()=>{}};gridOverlay=t.useRef("gridOverlay");gridOverlayRect=DI(this.gridOverlay);cellPopovers;paintFormatStore;setup(){bM(this.env,this.gridOverlay,this.props.onCellHovered);const e=new ResizeObserver((()=>{const e=this.gridOverlayEl.getBoundingClientRect();this.props.onGridResized({x:e.left,y:e.top,height:this.gridOverlayEl.clientHeight,width:this.gridOverlayEl.clientWidth})}));t.onMounted((()=>{e.observe(this.gridOverlayEl)})),t.onWillUnmount((()=>{e.disconnect()})),function(e,t,o){let s=null,i=null;nO(e,"touchstart",(function(e){1===e.touches.length&&(s=e.touches[0].clientX,i=e.touches[0].clientY)})),nO(e,"touchend",(function(){s=null,i=null})),nO(e,"touchmove",(function(e){if(1!==e.touches.length)return;o()&&(e.preventDefault(),e.stopPropagation());const n=e.touches[0].clientX,r=e.touches[0].clientY;t(s-n,i-r),s=n,i=r}))}(this.gridOverlay,this.props.onGridMoved,(()=>{const{scrollY:e}=this.env.model.getters.
|
|
1660
|
+
`;class SM extends t.Component{static template="o-spreadsheet-GridOverlay";static props={onCellHovered:{type:Function,optional:!0},onCellDoubleClicked:{type:Function,optional:!0},onCellClicked:{type:Function,optional:!0},onCellRightClicked:{type:Function,optional:!0},onGridResized:{type:Function,optional:!0},onFigureDeleted:{type:Function,optional:!0},onGridMoved:Function,gridOverlayDimensions:String};static components={FiguresContainer:gM,DataValidationOverlay:iM,GridAddRowsFooter:fM,FilterIconsOverlay:mM};static defaultProps={onCellHovered:()=>{},onCellDoubleClicked:()=>{},onCellClicked:()=>{},onCellRightClicked:()=>{},onGridResized:()=>{},onFigureDeleted:()=>{}};gridOverlay=t.useRef("gridOverlay");gridOverlayRect=DI(this.gridOverlay);cellPopovers;paintFormatStore;setup(){bM(this.env,this.gridOverlay,this.props.onCellHovered);const e=new ResizeObserver((()=>{const e=this.gridOverlayEl.getBoundingClientRect();this.props.onGridResized({x:e.left,y:e.top,height:this.gridOverlayEl.clientHeight,width:this.gridOverlayEl.clientWidth})}));t.onMounted((()=>{e.observe(this.gridOverlayEl)})),t.onWillUnmount((()=>{e.disconnect()})),function(e,t,o){let s=null,i=null;nO(e,"touchstart",(function(e){1===e.touches.length&&(s=e.touches[0].clientX,i=e.touches[0].clientY)})),nO(e,"touchend",(function(){s=null,i=null})),nO(e,"touchmove",(function(e){if(1!==e.touches.length)return;o()&&(e.preventDefault(),e.stopPropagation());const n=e.touches[0].clientX,r=e.touches[0].clientY;t(s-n,i-r),s=n,i=r}))}(this.gridOverlay,this.props.onGridMoved,(()=>{const{scrollY:e}=this.env.model.getters.getActiveSheetScrollInfo();return e>0})),this.cellPopovers=yc(II),this.paintFormatStore=yc(vM)}get gridOverlayEl(){if(!this.gridOverlay.el)throw new Error("GridOverlay el is not defined.");return this.gridOverlay.el}get style(){return this.props.gridOverlayDimensions}get isPaintingFormat(){return this.paintFormatStore.isActive}onMouseDown(e){if(e.button>0)return;e.target===this.gridOverlay.el&&this.cellPopovers.isOpen&&this.cellPopovers.close();const[t,o]=this.getCartesianCoordinates(e);this.props.onCellClicked(t,o,{expandZone:e.shiftKey,addZone:hR(e)})}onDoubleClick(e){const[t,o]=this.getCartesianCoordinates(e);this.props.onCellDoubleClicked(t,o)}onContextMenu(e){const[t,o]=this.getCartesianCoordinates(e);this.props.onCellRightClicked(t,o,{x:e.clientX,y:e.clientY})}getCartesianCoordinates(e){const t=e.clientX-this.gridOverlayRect.x,o=e.clientY-this.gridOverlayRect.y;return[this.env.model.getters.getColIndex(t),this.env.model.getters.getRowIndex(o)]}}class yM extends t.Component{static template="o-spreadsheet-GridPopover";static props={onClosePopover:Function,onMouseWheel:Function,gridRect:Object};static components={Popover:OI};cellPopovers;zIndex=Oe.GridPopover;setup(){this.cellPopovers=yc(II)}get cellPopover(){const e=this.cellPopovers.cellPopover;if(!e.isOpen)return{isOpen:!1};const t=e.anchorRect;return{...e,anchorRect:{...t,x:t.x+this.props.gridRect.x,y:t.y+this.props.gridRect.y}}}}class CM extends t.Component{static props={onOpenContextMenu:Function};composerFocusStore;PADDING=0;MAX_SIZE_MARGIN=0;MIN_ELEMENT_SIZE=0;lastSelectedElementIndex=null;state=t.useState({resizerIsActive:!1,isResizing:!1,isMoving:!1,isSelecting:!1,waitingForMove:!1,activeElement:0,draggerLinePosition:0,draggerShadowPosition:0,draggerShadowThickness:0,delta:0,base:0,position:"before"});setup(){this.composerFocusStore=yc(Dc)}_computeHandleDisplay(e){const t=this._getEvOffset(e),o=this._getElementIndex(t);if(o<0)return;const s=this._getDimensionsInViewport(o);t-s.start<this.PADDING&&o!==this._getViewportOffset()?(this.state.resizerIsActive=!0,this.state.draggerLinePosition=s.start,this.state.activeElement=this._getPreviousVisibleElement(o)):s.end-t<this.PADDING?(this.state.resizerIsActive=!0,this.state.draggerLinePosition=s.end,this.state.activeElement=o):this.state.resizerIsActive=!1}_computeGrabDisplay(e){const t=this._getElementIndex(this._getEvOffset(e)),o=this._getActiveElements(),s=this._getSelectedZoneStart(),i=this._getSelectedZoneEnd();o.has(s)&&s<=t&&t<=i?this.state.waitingForMove=!0:this.state.waitingForMove=!1}onMouseMove(e){this.state.isResizing||this.state.isMoving||this.state.isSelecting||(this._computeHandleDisplay(e),this._computeGrabDisplay(e))}onMouseLeave(){this.state.resizerIsActive=this.state.isResizing,this.state.waitingForMove=!1}onDblClick(e){this._fitElementSize(this.state.activeElement),this.state.isResizing=!1,this._computeHandleDisplay(e),this._computeGrabDisplay(e)}onMouseDown(e){this.state.isResizing=!0,this.state.delta=0;const t=this._getClientPosition(e),o=this.state.draggerLinePosition,s=this._getElementSize(this.state.activeElement),i=o-s+this.MIN_ELEMENT_SIZE,n=this._getMaxSize();Z_((e=>{this.state.delta=this._getClientPosition(e)-t,this.state.draggerLinePosition=o+this.state.delta,this.state.draggerLinePosition<i&&(this.state.draggerLinePosition=i,this.state.delta=this.MIN_ELEMENT_SIZE-s),this.state.draggerLinePosition>n&&(this.state.draggerLinePosition=n,this.state.delta=n-o)}),(e=>{this.state.isResizing=!1,0!==this.state.delta&&this._updateSize()}))}select(e){if(e.button>0)return;const t=this._getElementIndex(this._getEvOffset(e));t<0||(this.state.waitingForMove?this.env.model.getters.isGridSelectionActive()?this.startMovement(e):this._selectElement(t,!1):("editing"===this.composerFocusStore.activeComposer.editionMode&&this.env.model.selection.getBackToDefault(),this.startSelection(e,t)))}startMovement(e){this.state.waitingForMove=!1,this.state.isMoving=!0;const t=this._getDimensionsInViewport(this._getSelectedZoneStart()),o=this._getDimensionsInViewport(this._getSelectedZoneEnd()),s=t.start;this.state.draggerLinePosition=s,this.state.base=this._getSelectedZoneStart(),this.state.draggerShadowPosition=s,this.state.draggerShadowThickness=o.end-t.start;j_(this.env,((e,o)=>{let s="COL"===this._getType()?e:o;if(s>=0){const e=this._getDimensionsInViewport(s);s<=this._getSelectedZoneStart()?(this.state.draggerLinePosition=e.start,this.state.draggerShadowPosition=e.start,this.state.base=s,this.state.position="before"):this._getSelectedZoneEnd()<s?(this.state.draggerLinePosition=e.end,this.state.draggerShadowPosition=e.end-this.state.draggerShadowThickness,this.state.base=s,this.state.position="after"):(this.state.draggerLinePosition=t.start,this.state.draggerShadowPosition=t.start,this.state.base=this._getSelectedZoneStart())}}),(()=>{this.state.isMoving=!1,this.state.base!==this._getSelectedZoneStart()&&this._moveElements(),this._computeGrabDisplay(e)}))}startSelection(e,t){this.state.isSelecting=!0,e.shiftKey?this._increaseSelection(t):this._selectElement(t,hR(e)),this.lastSelectedElementIndex=t;j_(this.env,((e,t)=>{let o="COL"===this._getType()?e:t;o!==this.lastSelectedElementIndex&&-1!==o&&(this._increaseSelection(o),this.lastSelectedElementIndex=o)}),(()=>{this.state.isSelecting=!1,this.lastSelectedElementIndex=null,this._computeGrabDisplay(e)}))}onMouseUp(e){this.lastSelectedElementIndex=null}onContextMenu(e){e.preventDefault();const t=this._getElementIndex(this._getEvOffset(e));if(t<0)return;this._getActiveElements().has(t)||this._selectElement(t,!1);const o=this._getType();this.props.onOpenContextMenu(o,e.clientX,e.clientY)}}Mc`
|
|
1661
1661
|
.o-col-resizer {
|
|
1662
1662
|
position: absolute;
|
|
1663
1663
|
top: 0;
|
|
@@ -1769,7 +1769,7 @@
|
|
|
1769
1769
|
height: ${ee}px;
|
|
1770
1770
|
}
|
|
1771
1771
|
}
|
|
1772
|
-
`;class EM extends t.Component{static props={onOpenContextMenu:Function};static template="o-spreadsheet-HeadersOverlay";static components={ColResizer:wM,RowResizer:xM};selectAll(){this.env.model.selection.selectAll()}}class IM{getters;renderer;fingerprints;constructor(e){this.getters=e(Ic).getters,this.renderer=e(Tc),this.fingerprints=e(h_),this.renderer.register(this)}get renderingLayers(){return["Background","Headers"]}getHeaderOffset(e,t,o){let s=this.getters.getColRowOffsetInViewport(e,t,o);return this.getters.isDashboard()||(s+="ROW"===e?ee:te),s}drawLayer(e,t){switch(t){case"Background":this.drawGlobalBackground(e);for(const t of this.getters.getAllActiveViewportsZones()){const{ctx:o}=e;o.save(),o.beginPath();const s=this.getters.getVisibleRect(t);o.rect(s.x,s.y,s.width,s.height),o.clip();const i=this.getGridBoxes(t);this.drawBackground(e,i),this.drawOverflowingCellBackground(e,i),this.drawCellBackground(e,i),this.drawBorders(e,i),this.drawTexts(e,i),this.drawIcon(e,i),o.restore()}this.drawFrozenPanes(e);break;case"Headers":this.getters.isDashboard()||(this.drawHeaders(e),this.drawFrozenPanesHeaders(e))}}drawGlobalBackground(e){const{ctx:t}=e,{width:o,height:s}=this.getters.getSheetViewDimensionWithHeaders();t.fillStyle="#ffffff",t.fillRect(0,0,o+r,s+r)}drawBackground(e,t){const{ctx:o,thinLineWidth:s}=e,i=!this.getters.isDashboard()&&this.getters.getGridLinesVisibility(this.getters.getActiveSheetId()),n=i?.1*s:0;if(i)for(const e of t)o.strokeStyle="#E2E3E3",o.lineWidth=s,o.strokeRect(e.x+n,e.y+n,e.width-2*n,e.height-2*n)}drawCellBackground(e,t){const{ctx:o}=e;for(const e of t){let t=e.style;if(t.fillColor&&"#ffffff"!==t.fillColor&&(o.fillStyle=t.fillColor||"#ffffff",o.fillRect(e.x,e.y,e.width,e.height)),e.dataBarFill){o.fillStyle=e.dataBarFill.color;const t=e.dataBarFill.percentage,s=e.width*(t/100);o.fillRect(e.x,e.y,s,e.height)}e.isError&&(o.fillStyle="red",o.beginPath(),o.moveTo(e.x+e.width-5,e.y),o.lineTo(e.x+e.width,e.y),o.lineTo(e.x+e.width,e.y+5),o.fill())}}drawOverflowingCellBackground(e,t){const{ctx:o,thinLineWidth:s}=e;for(const e of t)if(e.content&&e.isOverflow){const t=e.content.align||"left";let i,n;const r=e.y+s/2,a=e.height-s,l=Math.min(e.clipRect?.width||1/0,e.content.width);"left"===t?(i=e.x+s/2,n=l-2*s):"right"===t?(i=e.x+e.width-s/2,n=2*s-l):(i=(e.clipRect?.x||e.x+e.width/2-e.content.width/2)+s/2,n=l-2*s),o.fillStyle="#ffffff",o.fillRect(i,r,n,a)}}drawBorders(e,t){const{ctx:o}=e;for(let e of t){const t=e.border;if(t){const{x:o,y:i,width:n,height:r}=e;t.left&&s(t.left,o,i,o,i+r),t.top&&s(t.top,o,i,o+n,i),t.right&&s(t.right,o+n,i,o+n,i+r),t.bottom&&s(t.bottom,o,i+r,o+n,i+r)}}function s({style:e,color:t},s,i,n,r){switch(o.strokeStyle=t,e){case"medium":o.lineWidth=2,i+=(s+=i===r?-.5:.5)===(n+=i===r?1.5:.5)?-.5:.5,r+=s===n?1.5:.5;break;case"thick":o.lineWidth=3,i===r&&(s--,n++),s===n&&(i--,r++);break;case"dashed":o.lineWidth=1,o.setLineDash([1,3]);break;case"dotted":o.lineWidth=1,i===r&&(s+=.5,n+=.5),s===n&&(i+=.5,r+=.5),o.setLineDash([1,1]);break;default:o.lineWidth=1}o.beginPath(),o.moveTo(s,i),o.lineTo(n,r),o.stroke(),o.lineWidth=1,o.setLineDash([])}}drawTexts(e,t){const{ctx:o}=e;let s;o.textBaseline="top";for(let e of t)if(e.content){const t=e.style||{},i=e.content.align||"left",n=Qr(t);n!==s&&(s=n,o.font=n),o.fillStyle=t.textColor||"#000";let r=e.x;if(r+="left"===i?ne+(e.image?e.image.size+4:0):"right"===i?e.width-ne-(e.hasIcon?19:0):e.width/2,o.textAlign=i,e.clipRect){o.save(),o.beginPath();const{x:t,y:s,width:i,height:n}=e.clipRect;o.rect(t,s,i,n),o.clip()}const a=ea(t),l=e.content.textLines.length;let c=this.computeTextYCoordinate(e,a,l);for(let s of e.content.textLines)ra(o,s,{x:Math.round(r),y:Math.round(c)},t.underline,t.strikethrough),c+=ne+a;e.clipRect&&o.restore()}}drawIcon(e,t){const{ctx:o}=e;for(const e of t)if(e.image){const t=e.image.image;if(e.image.clipIcon){o.save(),o.beginPath();const{x:t,y:s,width:i,height:n}=e.image.clipIcon;o.rect(t,s,i,n),o.clip()}const s=e.image.size,i=this.computeTextYCoordinate(e,s);o.drawImage(t,e.x+4,i,s,s),e.image.clipIcon&&o.restore()}}computeTextYCoordinate(e,t,o=1){const s=e.y+1,i=Gr(t,o),n=e.height>i+2*ne,r=e.verticalAlign||ue;if(n){if("middle"===r)return s+(e.height-i)/2;if("bottom"===r)return s+e.height-i-ne}return s+ne}drawHeaders(e){const{ctx:t,thinLineWidth:o}=e,s=this.getters.getSheetViewVisibleCols(),i=s[0],n=s[s.length-1],r=this.getters.getSheetViewVisibleRows(),a=r[0],l=r[r.length-1],{width:g,height:p}=this.getters.getSheetViewDimensionWithHeaders(),m=this.getters.getSelectedZones(),f=function(e){const t=new Set;for(let o of Co(e))for(let e of Ze(o.left,o.right+1))t.add(e);return t}(m),v=function(e){const t=new Set;for(let o of Co(e))for(let e of Ze(o.top,o.bottom+1))t.add(e);return t}(m),b=this.getters.getActiveSheetId(),S=this.getters.getNumberCols(b),y=this.getters.getNumberRows(b),C=this.getters.getActiveCols(),w=this.getters.getActiveRows();t.font=`400 11px ${fe}`,t.textAlign="center",t.textBaseline="middle",t.lineWidth=o,t.strokeStyle="#333";for(let e=i;e<=n;e++){const o={left:e,right:e,top:0,bottom:y-1},{x:s,width:i}=this.getters.getVisibleRect(o),n=C.has(e),r=f.has(e);t.fillStyle=n?d:r?h:c,t.fillRect(s,0,i,ee)}for(let e=a;e<=l;e++){const o={top:e,bottom:e,left:0,right:S-1},{y:s,height:i}=this.getters.getVisibleRect(o),n=w.has(e),r=v.has(e);t.fillStyle=n?d:r?h:c,t.fillRect(0,s,te,i)}t.beginPath(),t.moveTo(te,0),t.lineTo(te,p),t.moveTo(0,ee),t.lineTo(g,ee),t.strokeStyle="#C0C0C0",t.stroke(),t.beginPath();for(const e of s){const o=this.getters.getColSize(b,e),s=fo(e);t.fillStyle=C.has(e)?"#fff":u;let n=this.getHeaderOffset("COL",i,e);t.fillText(s,n+o/2,13),t.moveTo(n+o,0),t.lineTo(n+o,ee)}for(const e of r){const o=this.getters.getRowSize(b,e);t.fillStyle=w.has(e)?"#fff":u;let s=this.getHeaderOffset("ROW",a,e);t.fillText(String(e+1),24,s+o/2),t.moveTo(0,s+o),t.lineTo(te,s+o)}t.stroke()}drawFrozenPanesHeaders(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.isDashboard()?0:te,r=this.getters.isDashboard()?0:ee;t.lineWidth=6*o,t.strokeStyle=E,t.beginPath(),s&&(t.moveTo(n+s,0),t.lineTo(n+s,r)),i&&(t.moveTo(0,r+i),t.lineTo(n,r+i)),t.stroke()}drawFrozenPanes(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.getSheetViewVisibleCols(),r=n[0],a=n[n.length-1],l=this.getters.getSheetViewVisibleRows(),c={left:r,right:a,top:l[0],bottom:l[l.length-1]},h=this.getters.getVisibleRect(c),d=this.getters.isDashboard()?0:te,u=this.getters.isDashboard()?0:ee;t.lineWidth=6*o,t.strokeStyle="#DADFE8",t.beginPath(),s&&(t.moveTo(d+s,u),t.lineTo(d+s,h.height+u)),i&&(t.moveTo(d,u+i),t.lineTo(h.width+d,u+i)),t.stroke()}findNextEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i<t;){const e={sheetId:s,col:i+1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),r=this.getters.doesCellHaveGridIcon(e),a=this.getters.isCellValidCheckbox(e);if(t.type!==ni.empty||this.getters.isInMerge(e)||n?.left||r||a)return i;i++}return i}findPreviousEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i>t;){const e={sheetId:s,col:i-1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),r=this.getters.doesCellHaveGridIcon(e),a=this.getters.isCellValidCheckbox(e);if(t.type!==ni.empty||this.getters.isInMerge(e)||n?.right||r||a)return i;i--}return i}computeCellAlignment(e,t){const o=this.getters.getCell(e);if(o?.isFormula&&this.getters.shouldShowFormulas())return"left";const{align:s}=this.getters.getCellStyle(e),i=this.getters.getEvaluatedCell(e);return t&&i.type===ni.number?"center"!==s?"left":s:s||i.defaultAlign}createZoneBox(e,t,o){const{left:s,right:i}=o,n=t.left,r=t.top,a={sheetId:e,col:n,row:r},l=this.getters.getEvaluatedCell(a),c=this.getters.shouldShowFormulas(),{x:h,y:d,width:u,height:g}=this.getters.getRect(t),{verticalAlign:p}=this.getters.getCellStyle(a);let m=this.getters.getCellComputedStyle(a);if(this.fingerprints.isEnabled){const e=this.fingerprints.colors.get(a);m={...m,fillColor:e}}const f=this.fingerprints.isEnabled?void 0:this.getters.getConditionalDataBar(a),v={x:h,y:d,width:u,height:g,border:this.getters.getCellComputedBorder(a)||void 0,style:m,dataBarFill:f,verticalAlign:p,isError:l.type===ni.error&&!!l.message||this.getters.isDataValidationInvalid(a)},b=this.getters.getCellIconSrc(a),S=ea(v.style),y=b?4+S:0;if(b){const e=RM(b);v.image={type:"icon",size:S,clipIcon:{x:v.x,y:v.y,width:Math.min(y,u),height:g},image:e}}if(l.type===ni.empty||this.getters.isCellValidCheckbox(a))return v;v.hasIcon=this.getters.doesCellHaveGridIcon(a);const C=v.hasIcon?19:0,w=m.wrapping||"overflow",x="wrap"===w&&!c,E=u-2*ne,I=this.getters.getCellMultiLineText(a,{maxWidth:E,wrapText:x}),R=Math.max(...I.map((e=>this.getters.getTextWidth(e,m)+ne))),T=y+R+C,A=this.computeCellAlignment(a,T>u);v.content={textLines:I,width:"overflow"===w?R:u,align:A};const _=T>u||S>g;if(b||v.hasIcon)v.clipRect={x:v.x+y,y:v.y,width:Math.max(0,u-y-C),height:g};else if(_&&"overflow"===w){let e,o;switch(this.getters.isInMerge(a)?(e=this.getters.getMerge(a).right,o=n):(e=v.border?.right?t.right:this.findNextEmptyCol(n,i,r),o=v.border?.left?t.left:this.findPreviousEmptyCol(n,s,r),v.isOverflow=!0),A){case"left":{const o=fs({col:e,row:r}),{x:s,y:i,width:n,height:a}=this.getters.getVisibleRect(ss(t,o));(n<T||S>a||I.length>1)&&(v.clipRect={x:s,y:i,width:n,height:a});break}case"right":{const e=fs({col:o,row:r}),{x:s,y:i,width:n,height:a}=this.getters.getVisibleRect(ss(t,e));(n<T||S>a||I.length>1)&&(v.clipRect={x:s,y:i,width:n,height:a});break}case"center":{const s={...t,left:o,right:e},{x:i,y:n,height:r,width:a}=this.getters.getVisibleRect(s),l=T/2,c=v.x+v.width/2;if(i+a<c+l||i>c-l||S>r||I.length>1){const e=i>c-l?i:c-l,t=i+a-e;v.clipRect={x:e,y:n,width:t,height:r}}break}}}else("clip"===w||"wrap"===w||I.length>1)&&(v.clipRect={x:v.x,y:v.y,width:u,height:g});return v}getGridBoxes(e){const t=[],o=this.getters.getSheetViewVisibleCols().filter((t=>t>=e.left&&t<=e.right)),s=o[0],i=o[o.length-1],n=this.getters.getSheetViewVisibleRows().filter((t=>t>=e.top&&t<=e.bottom)),r={left:s,right:i,top:n[0],bottom:n[n.length-1]},a=this.getters.getActiveSheetId();for(const e of n)for(const s of o){const o={sheetId:a,col:s,row:e};this.getters.isInMerge(o)||t.push(this.createZoneBox(a,fs(o),r))}for(const e of this.getters.getMerges(a))if(!this.getters.isMergeHidden(a,e)&&rs(e,r)){const o=this.createZoneBox(a,e,r),s=this.getters.getCellComputedBorder({sheetId:a,col:e.right,row:e.bottom});o.border={...o.border,bottom:s?s.bottom:void 0,right:s?s.right:void 0},o.isMerge=!0,t.push(o)}return t}}const RM=Et((function(e){const t=new Image;return t.src=e,t}));function TM(e,o,s){const i=t.useRef(e);t.useEffect((function(){const e=i.el,t=window.devicePixelRatio||1,r=e.getContext("2d",{alpha:!1}),a={ctx:r,dpr:t,thinLineWidth:.4*t},{width:l,height:c}=s();e.style.width=`${l}px`,e.style.height=`${c}px`,e.width=l*t,e.height=c*t,e.setAttribute("style",`width:${l}px;height:${c}px;`),r.translate(-.5,-.5),r.scale(t,t);for(const e of Ei())o.drawLayer(a,e),n.drawLayer(a,e)}));const n=yc(Tc);yc(IM)}function AM(e){function t(e,t){return e*(0===t?1:se)}return o=>{const s=t(o.shiftKey&&!cR()?o.deltaY:o.deltaX,o.deltaMode),i=t(o.shiftKey&&!cR()?o.deltaX:o.deltaY,o.deltaMode);e(s,i)}}Mc`
|
|
1772
|
+
`;class EM extends t.Component{static props={onOpenContextMenu:Function};static template="o-spreadsheet-HeadersOverlay";static components={ColResizer:wM,RowResizer:xM};selectAll(){this.env.model.selection.selectAll()}}class IM{getters;renderer;fingerprints;constructor(e){this.getters=e(Ic).getters,this.renderer=e(Tc),this.fingerprints=e(h_),this.renderer.register(this)}get renderingLayers(){return["Background","Headers"]}drawLayer(e,t){switch(t){case"Background":this.drawGlobalBackground(e);for(const{zone:t,rect:o}of this.getters.getAllActiveViewportsZonesAndRect()){const{ctx:s}=e;s.save(),s.beginPath(),s.rect(o.x,o.y,o.width,o.height),s.clip();const i=this.getGridBoxes(t);this.drawBackground(e,i),this.drawOverflowingCellBackground(e,i),this.drawCellBackground(e,i),this.drawBorders(e,i),this.drawTexts(e,i),this.drawIcon(e,i),s.restore()}this.drawFrozenPanes(e);break;case"Headers":this.getters.isDashboard()||(this.drawHeaders(e),this.drawFrozenPanesHeaders(e))}}drawGlobalBackground(e){const{ctx:t}=e,{width:o,height:s}=this.getters.getSheetViewDimensionWithHeaders();t.fillStyle="#ffffff",t.fillRect(0,0,o+r,s+r)}drawBackground(e,t){const{ctx:o,thinLineWidth:s}=e,i=!this.getters.isDashboard()&&this.getters.getGridLinesVisibility(this.getters.getActiveSheetId()),n=i?.1*s:0;if(i)for(const e of t)o.strokeStyle="#E2E3E3",o.lineWidth=s,o.strokeRect(e.x+n,e.y+n,e.width-2*n,e.height-2*n)}drawCellBackground(e,t){const{ctx:o}=e;for(const e of t){let t=e.style;if(t.fillColor&&"#ffffff"!==t.fillColor&&(o.fillStyle=t.fillColor||"#ffffff",o.fillRect(e.x,e.y,e.width,e.height)),e.dataBarFill){o.fillStyle=e.dataBarFill.color;const t=e.dataBarFill.percentage,s=e.width*(t/100);o.fillRect(e.x,e.y,s,e.height)}e.isError&&(o.fillStyle="red",o.beginPath(),o.moveTo(e.x+e.width-5,e.y),o.lineTo(e.x+e.width,e.y),o.lineTo(e.x+e.width,e.y+5),o.fill())}}drawOverflowingCellBackground(e,t){const{ctx:o,thinLineWidth:s}=e;for(const e of t)if(e.content&&e.isOverflow){const t=e.content.align||"left";let i,n;const r=e.y+s/2,a=e.height-s,l=Math.min(e.clipRect?.width||1/0,e.content.width);"left"===t?(i=e.x+s/2,n=l-2*s):"right"===t?(i=e.x+e.width-s/2,n=2*s-l):(i=(e.clipRect?.x||e.x+e.width/2-e.content.width/2)+s/2,n=l-2*s),o.fillStyle="#ffffff",o.fillRect(i,r,n,a)}}drawBorders(e,t){const{ctx:o}=e;for(let e of t){const t=e.border;if(t){const{x:o,y:i,width:n,height:r}=e;t.left&&s(t.left,o,i,o,i+r),t.top&&s(t.top,o,i,o+n,i),t.right&&s(t.right,o+n,i,o+n,i+r),t.bottom&&s(t.bottom,o,i+r,o+n,i+r)}}function s({style:e,color:t},s,i,n,r){switch(o.strokeStyle=t,e){case"medium":o.lineWidth=2,i+=(s+=i===r?-.5:.5)===(n+=i===r?1.5:.5)?-.5:.5,r+=s===n?1.5:.5;break;case"thick":o.lineWidth=3,i===r&&(s--,n++),s===n&&(i--,r++);break;case"dashed":o.lineWidth=1,o.setLineDash([1,3]);break;case"dotted":o.lineWidth=1,i===r&&(s+=.5,n+=.5),s===n&&(i+=.5,r+=.5),o.setLineDash([1,1]);break;default:o.lineWidth=1}o.beginPath(),o.moveTo(s,i),o.lineTo(n,r),o.stroke(),o.lineWidth=1,o.setLineDash([])}}drawTexts(e,t){const{ctx:o}=e;let s;o.textBaseline="top";for(let e of t)if(e.content){const t=e.style||{},i=e.content.align||"left",n=Qr(t);n!==s&&(s=n,o.font=n),o.fillStyle=t.textColor||"#000";let r=e.x;if(r+="left"===i?ne+(e.image?e.image.size+4:0):"right"===i?e.width-ne-(e.hasIcon?19:0):e.width/2,o.textAlign=i,e.clipRect){o.save(),o.beginPath();const{x:t,y:s,width:i,height:n}=e.clipRect;o.rect(t,s,i,n),o.clip()}const a=ea(t),l=e.content.textLines.length;let c=this.computeTextYCoordinate(e,a,l);for(let s of e.content.textLines)ra(o,s,{x:Math.round(r),y:Math.round(c)},t.underline,t.strikethrough),c+=ne+a;e.clipRect&&o.restore()}}drawIcon(e,t){const{ctx:o}=e;for(const e of t)if(e.image){const t=e.image.image;if(e.image.clipIcon){o.save(),o.beginPath();const{x:t,y:s,width:i,height:n}=e.image.clipIcon;o.rect(t,s,i,n),o.clip()}const s=e.image.size,i=this.computeTextYCoordinate(e,s);o.drawImage(t,e.x+4,i,s,s),e.image.clipIcon&&o.restore()}}computeTextYCoordinate(e,t,o=1){const s=e.y+1,i=Gr(t,o),n=e.height>i+2*ne,r=e.verticalAlign||ue;if(n){if("middle"===r)return s+(e.height-i)/2;if("bottom"===r)return s+e.height-i-ne}return s+ne}drawHeaders(e){const{ctx:t,thinLineWidth:o}=e,s=this.getters.getSheetViewVisibleCols(),i=s[0],n=this.getters.getSheetViewVisibleRows(),r=n[0],{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders(),g=this.getters.getSelectedZones(),p=function(e){const t=new Set;for(let o of Co(e))for(let e of Ze(o.left,o.right+1))t.add(e);return t}(g),m=function(e){const t=new Set;for(let o of Co(e))for(let e of Ze(o.top,o.bottom+1))t.add(e);return t}(g),f=this.getters.getActiveSheetId(),v=this.getters.getNumberCols(f),b=this.getters.getNumberRows(f),S=this.getters.getActiveCols(),y=this.getters.getActiveRows();t.font=`400 11px ${fe}`,t.textAlign="center",t.textBaseline="middle",t.lineWidth=o,t.strokeStyle="#333";for(const e of s){const o={left:e,right:e,top:0,bottom:b-1},{x:s,width:i}=this.getters.getVisibleRect(o),n=S.has(e),r=p.has(e);t.fillStyle=n?d:r?h:c,t.fillRect(s,0,i,ee)}for(const e of n){const o={top:e,bottom:e,left:0,right:v-1},{y:s,height:i}=this.getters.getVisibleRect(o),n=y.has(e),r=m.has(e);t.fillStyle=n?d:r?h:c,t.fillRect(0,s,te,i)}t.beginPath(),t.moveTo(te,0),t.lineTo(te,l),t.moveTo(0,ee),t.lineTo(a,ee),t.strokeStyle="#C0C0C0",t.stroke();for(const e of s){const o=fo(e);t.fillStyle=S.has(e)?"#fff":u;const s={left:e,right:e,top:r,bottom:r},{x:i,width:n}=this.getters.getRect(s),{x:a,width:l}=this.getters.getVisibleRect(s);t.save(),t.beginPath(),t.rect(a,0,l,ee),t.clip(),t.fillText(o,i+n/2,13),t.restore(),t.beginPath(),t.moveTo(i+n,0),t.lineTo(i+n,ee),t.stroke()}for(const e of n){t.fillStyle=y.has(e)?"#fff":u;const o={top:e,bottom:e,left:i,right:i},{y:s,height:n}=this.getters.getRect(o),{y:r,height:a}=this.getters.getVisibleRect(o);t.save(),t.beginPath(),t.rect(0,r,te,a),t.clip(),t.fillText(String(e+1),24,s+n/2),t.restore(),t.beginPath(),t.moveTo(0,s+n),t.lineTo(te,s+n),t.stroke()}}drawFrozenPanesHeaders(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.isDashboard()?0:te,r=this.getters.isDashboard()?0:ee;t.lineWidth=6*o,t.strokeStyle=E,t.beginPath(),s&&(t.moveTo(n+s,0),t.lineTo(n+s,r)),i&&(t.moveTo(0,r+i),t.lineTo(n,r+i)),t.stroke()}drawFrozenPanes(e){const{ctx:t,thinLineWidth:o}=e,{x:s,y:i}=this.getters.getMainViewportCoordinates(),n=this.getters.getSheetViewVisibleCols(),r=n[0],a=n[n.length-1],l=this.getters.getSheetViewVisibleRows(),c={left:r,right:a,top:l[0],bottom:l[l.length-1]},h=this.getters.getVisibleRect(c),d=this.getters.isDashboard()?0:te,u=this.getters.isDashboard()?0:ee;t.lineWidth=6*o,t.strokeStyle="#DADFE8",t.beginPath(),s&&(t.moveTo(d+s,u),t.lineTo(d+s,h.height+u)),i&&(t.moveTo(d,u+i),t.lineTo(h.width+d,u+i)),t.stroke()}findNextEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i<t;){const e={sheetId:s,col:i+1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),r=this.getters.doesCellHaveGridIcon(e),a=this.getters.isCellValidCheckbox(e);if(t.type!==ni.empty||this.getters.isInMerge(e)||n?.left||r||a)return i;i++}return i}findPreviousEmptyCol(e,t,o){const s=this.getters.getActiveSheetId();let i=e;for(;i>t;){const e={sheetId:s,col:i-1,row:o},t=this.getters.getEvaluatedCell(e),n=this.getters.getCellComputedBorder(e),r=this.getters.doesCellHaveGridIcon(e),a=this.getters.isCellValidCheckbox(e);if(t.type!==ni.empty||this.getters.isInMerge(e)||n?.right||r||a)return i;i--}return i}computeCellAlignment(e,t){const o=this.getters.getCell(e);if(o?.isFormula&&this.getters.shouldShowFormulas())return"left";const{align:s}=this.getters.getCellStyle(e),i=this.getters.getEvaluatedCell(e);return t&&i.type===ni.number?"center"!==s?"left":s:s||i.defaultAlign}createZoneBox(e,t,o){const{left:s,right:i}=o,n=t.left,r=t.top,a={sheetId:e,col:n,row:r},l=this.getters.getEvaluatedCell(a),c=this.getters.shouldShowFormulas(),{x:h,y:d,width:u,height:g}=this.getters.getRect(t),{verticalAlign:p}=this.getters.getCellStyle(a);let m=this.getters.getCellComputedStyle(a);if(this.fingerprints.isEnabled){const e=this.fingerprints.colors.get(a);m={...m,fillColor:e}}const f=this.fingerprints.isEnabled?void 0:this.getters.getConditionalDataBar(a),v={x:h,y:d,width:u,height:g,border:this.getters.getCellComputedBorder(a)||void 0,style:m,dataBarFill:f,verticalAlign:p,isError:l.type===ni.error&&!!l.message||this.getters.isDataValidationInvalid(a)},b=this.getters.getCellIconSrc(a),S=ea(v.style),y=b?4+S:0;if(b){const e=RM(b);v.image={type:"icon",size:S,clipIcon:{x:v.x,y:v.y,width:Math.min(y,u),height:g},image:e}}if(l.type===ni.empty||this.getters.isCellValidCheckbox(a))return v;v.hasIcon=this.getters.doesCellHaveGridIcon(a);const C=v.hasIcon?19:0,w=m.wrapping||"overflow",x="wrap"===w&&!c,E=u-2*ne,I=this.getters.getCellMultiLineText(a,{maxWidth:E,wrapText:x}),R=Math.max(...I.map((e=>this.getters.getTextWidth(e,m)+ne))),T=y+R+C,A=this.computeCellAlignment(a,T>u);v.content={textLines:I,width:"overflow"===w?R:u,align:A};const _=T>u||S>g;if(b||v.hasIcon)v.clipRect={x:v.x+y,y:v.y,width:Math.max(0,u-y-C),height:g};else if(_&&"overflow"===w){let e,o;switch(this.getters.isInMerge(a)?(e=this.getters.getMerge(a).right,o=n):(e=v.border?.right?t.right:this.findNextEmptyCol(n,i,r),o=v.border?.left?t.left:this.findPreviousEmptyCol(n,s,r),v.isOverflow=!0),A){case"left":{const o=fs({col:e,row:r}),{x:s,y:i,width:n,height:a}=this.getters.getVisibleRect(ss(t,o));(n<T||S>a||I.length>1)&&(v.clipRect={x:s,y:i,width:n,height:a});break}case"right":{const e=fs({col:o,row:r}),{x:s,y:i,width:n,height:a}=this.getters.getVisibleRect(ss(t,e));(n<T||S>a||I.length>1)&&(v.clipRect={x:s,y:i,width:n,height:a});break}case"center":{const s={...t,left:o,right:e},{x:i,y:n,height:r,width:a}=this.getters.getVisibleRect(s),l=T/2,c=v.x+v.width/2;if(i+a<c+l||i>c-l||S>r||I.length>1){const e=i>c-l?i:c-l,t=i+a-e;v.clipRect={x:e,y:n,width:t,height:r}}break}}}else("clip"===w||"wrap"===w||I.length>1)&&(v.clipRect={x:v.x,y:v.y,width:u,height:g});return v}getGridBoxes(e){const t=[],o=this.getters.getSheetViewVisibleCols().filter((t=>t>=e.left&&t<=e.right)),s=o[0],i=o[o.length-1],n=this.getters.getSheetViewVisibleRows().filter((t=>t>=e.top&&t<=e.bottom)),r={left:s,right:i,top:n[0],bottom:n[n.length-1]},a=this.getters.getActiveSheetId();for(const e of n)for(const s of o){const o={sheetId:a,col:s,row:e};this.getters.isInMerge(o)||t.push(this.createZoneBox(a,fs(o),r))}for(const e of this.getters.getMerges(a))if(!this.getters.isMergeHidden(a,e)&&rs(e,r)){const o=this.createZoneBox(a,e,r),s=this.getters.getCellComputedBorder({sheetId:a,col:e.right,row:e.bottom});o.border={...o.border,bottom:s?s.bottom:void 0,right:s?s.right:void 0},o.isMerge=!0,t.push(o)}return t}}const RM=Et((function(e){const t=new Image;return t.src=e,t}));function TM(e,o,s){const i=t.useRef(e);t.useEffect((function(){const e=i.el,t=window.devicePixelRatio||1,r=e.getContext("2d",{alpha:!1}),a={ctx:r,dpr:t,thinLineWidth:.4*t},{width:l,height:c}=s();if(e.style.width=`${l}px`,e.style.height=`${c}px`,e.width=l*t,e.height=c*t,e.setAttribute("style",`width:${l}px;height:${c}px;`),0===l||0===c)return;r.translate(-.5,-.5),r.scale(t,t);for(const e of Ei())o.drawLayer(a,e),n.drawLayer(a,e)}));const n=yc(Tc);yc(IM)}function AM(e){function t(e,t){return e*(0===t?1:se)}return o=>{const s=t(o.shiftKey&&!cR()?o.deltaY:o.deltaX,o.deltaMode),i=t(o.shiftKey&&!cR()?o.deltaX:o.deltaY,o.deltaMode);e(s,i)}}Mc`
|
|
1773
1773
|
.o-border {
|
|
1774
1774
|
position: absolute;
|
|
1775
1775
|
&:hover {
|
|
@@ -1837,7 +1837,7 @@
|
|
|
1837
1837
|
offset="offset"
|
|
1838
1838
|
direction="'horizontal'"
|
|
1839
1839
|
onScroll.bind="onScroll"
|
|
1840
|
-
/>`;static defaultProps={leftOffset:0};get offset(){return this.env.model.getters.
|
|
1840
|
+
/>`;static defaultProps={leftOffset:0};get offset(){return this.env.model.getters.getActiveSheetScrollInfo().scrollX}get width(){return this.env.model.getters.getMainViewportRect().width}get isDisplayed(){const{xRatio:e}=this.env.model.getters.getFrozenSheetViewRatio(this.env.model.getters.getActiveSheetId());return e<1}get position(){const{x:e}=this.env.model.getters.getMainViewportRect();return{left:`${this.props.leftOffset+e}px`,bottom:"0px",height:"15px",right:"0px"}}onScroll(e){const{scrollY:t}=this.env.model.getters.getActiveSheetScrollInfo();this.env.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:e,offsetY:t})}}class PM extends t.Component{static props={topOffset:{type:Number,optional:!0}};static components={ScrollBar:FM};static template=t.xml`
|
|
1841
1841
|
<ScrollBar
|
|
1842
1842
|
t-if="isDisplayed"
|
|
1843
1843
|
height="height"
|
|
@@ -1845,7 +1845,7 @@
|
|
|
1845
1845
|
offset="offset"
|
|
1846
1846
|
direction="'vertical'"
|
|
1847
1847
|
onScroll.bind="onScroll"
|
|
1848
|
-
/>`;static defaultProps={topOffset:0};get offset(){return this.env.model.getters.
|
|
1848
|
+
/>`;static defaultProps={topOffset:0};get offset(){return this.env.model.getters.getActiveSheetScrollInfo().scrollY}get height(){return this.env.model.getters.getMainViewportRect().height}get isDisplayed(){const{yRatio:e}=this.env.model.getters.getFrozenSheetViewRatio(this.env.model.getters.getActiveSheetId());return e<1}get position(){const{y:e}=this.env.model.getters.getMainViewportRect();return{top:`${this.props.topOffset+e}px`,right:"0px",width:"15px",bottom:"0px"}}onScroll(e){const{scrollX:t}=this.env.model.getters.getActiveSheetScrollInfo();this.env.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:t,offsetY:e})}}const NM=350;class kM extends Ac{mutators=["open","toggle","close","changePanelSize","resetPanelSize"];initialPanelProps={};componentTag="";panelSize=NM;get isOpen(){return!!this.componentTag&&this.computeState(this.componentTag,this.initialPanelProps).isOpen}get panelProps(){const e=this.computeState(this.componentTag,this.initialPanelProps);return e.isOpen?e.props??{}:{}}get panelKey(){const e=this.computeState(this.componentTag,this.initialPanelProps);if(e.isOpen)return e.key}open(e,t={}){const o=this.computeState(e,t);o.isOpen&&(this.isOpen&&e!==this.componentTag&&this.initialPanelProps?.onCloseSidePanel?.(),this.componentTag=e,this.initialPanelProps=o.props??{})}toggle(e,t){this.isOpen&&e===this.componentTag?this.close():this.open(e,t)}close(){this.initialPanelProps.onCloseSidePanel?.(),this.initialPanelProps={},this.componentTag=""}changePanelSize(e,t){this.panelSize=e<NM?NM:e>t-150?Math.max(t-150,NM):e}resetPanelSize(){this.panelSize=NM}computeState(e,t){const o=HF.get(e).computeState;return o?o(this.getters,t):{isOpen:!0,props:t}}}const LM="#777";Mc`
|
|
1849
1849
|
.o-table-resizer {
|
|
1850
1850
|
width: ${3}px;
|
|
1851
1851
|
height: ${3}px;
|
|
@@ -1853,7 +1853,7 @@
|
|
|
1853
1853
|
border-right: ${3}px solid ${LM};
|
|
1854
1854
|
cursor: nwse-resize;
|
|
1855
1855
|
}
|
|
1856
|
-
`;class VM extends t.Component{static template="o-spreadsheet-TableResizer";static props={table:Object};state=t.useState({highlightZone:void 0});setup(){aO(this)}get containerStyle(){const e=this.props.table.range.zone,t={...e,left:e.right,top:e.bottom},o=this.env.model.getters.getVisibleRect(t);return 0===o.height||0===o.width?kc({display:"none"}):kc({top:o.y+o.height-6+"px",left:o.x+o.width-6+"px"})}onMouseDown(e){const t=this.props.table.range.zone,o={col:t.left,row:t.top};document.body.style.cursor="nwse-resize";j_(this.env,((e,t,s)=>{this.state.highlightZone={left:o.col,top:o.row,right:Math.max(e,o.col),bottom:Math.max(t,o.row)}}),(()=>{document.body.style.cursor="";const e=this.state.highlightZone;if(!e)return;const t=this.props.table.range.sheetId;this.env.model.dispatch("RESIZE_TABLE",{sheetId:t,zone:this.props.table.range.zone,newTableRange:this.env.model.getters.getRangeDataFromZone(t,e)}),this.state.highlightZone=void 0}))}get highlights(){return this.state.highlightZone?[{zone:this.state.highlightZone,sheetId:this.props.table.range.sheetId,color:LM,noFill:!0}]:[]}}const HM={ROW:z_,COL:V_,CELL:jT,GROUP_HEADERS:GF,UNGROUP_HEADERS:qF};class UM extends t.Component{static template="o-spreadsheet-Grid";static props={exposeFocus:Function};static components={GridComposer:eM,GridOverlay:SM,GridPopover:yM,HeadersOverlay:EM,Menu:dR,Autofill:jF,ClientTag:XF,Highlight:OM,Popover:OI,VerticalScrollBar:PM,HorizontalScrollBar:MM,TableResizer:VM};HEADER_HEIGHT=ee;HEADER_WIDTH=te;menuState;gridRef;highlightStore;cellPopovers;composerFocusStore;DOMFocusableElementStore;paintFormatStore;onMouseWheel;canvasPosition;hoveredCell;sidePanel;setup(){this.highlightStore=yc(Xb),this.menuState=t.useState({isOpen:!1,position:null,menuItems:[]}),this.gridRef=t.useRef("grid"),this.canvasPosition=DI(this.gridRef),this.hoveredCell=yc(EI),this.composerFocusStore=yc(Dc),this.DOMFocusableElementStore=yc(GD),this.sidePanel=yc(kM),this.paintFormatStore=yc(vM),yc(ZF),t.useChildSubEnv({getPopoverContainerRect:()=>this.getGridRect()}),t.useExternalListener(document.body,"cut",this.copy.bind(this,!0)),t.useExternalListener(document.body,"copy",this.copy.bind(this,!1)),t.useExternalListener(document.body,"paste",this.paste),t.onMounted((()=>this.focusDefaultElement())),this.props.exposeFocus((()=>this.focusDefaultElement())),TM("canvas",this.env.model,(()=>this.env.model.getters.getSheetViewDimensionWithHeaders())),this.onMouseWheel=AM(((e,t)=>{this.moveCanvas(e,t),this.hoveredCell.clear()})),this.cellPopovers=yc(II),t.useEffect((()=>{this.sidePanel.isOpen||this.DOMFocusableElementStore.focusableElement?.focus()}),(()=>[this.sidePanel.isOpen]))}onCellHovered({col:e,row:t}){this.hoveredCell.hover({col:e,row:t})}get highlights(){return this.highlightStore.highlights}get gridOverlayDimensions(){return kc({top:"26px",left:"48px",height:"calc(100% - 41px)",width:"calc(100% - 63px)"})}onClosePopover(){this.cellPopovers.isOpen&&this.cellPopovers.close(),this.focusDefaultElement()}keyDownMapping={Enter:()=>{this.env.model.getters.getActiveCell().type===ni.empty?this.onComposerCellFocused():this.onComposerContentFocused()},Tab:()=>this.env.model.selection.moveAnchorCell("right",1),"Shift+Tab":()=>this.env.model.selection.moveAnchorCell("left",1),F2:()=>{this.env.model.getters.getActiveCell().type===ni.empty?this.onComposerCellFocused():this.onComposerContentFocused()},Delete:()=>{this.env.model.dispatch("DELETE_CONTENT",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones()})},Backspace:()=>{this.env.model.dispatch("DELETE_CONTENT",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones()})},Escape:()=>{this.cellPopovers.isOpen?this.cellPopovers.close():this.menuState.isOpen?this.closeMenu():this.paintFormatStore.isActive?this.paintFormatStore.cancel():this.env.model.dispatch("CLEAN_CLIPBOARD_HIGHLIGHT")},"Ctrl+A":()=>this.env.model.selection.loopSelection(),"Ctrl+Z":()=>this.env.model.dispatch("REQUEST_UNDO"),"Ctrl+Y":()=>this.env.model.dispatch("REQUEST_REDO"),F4:()=>this.env.model.dispatch("REQUEST_REDO"),"Ctrl+B":()=>this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{bold:!this.env.model.getters.getCurrentStyle().bold}}),"Ctrl+I":()=>this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{italic:!this.env.model.getters.getCurrentStyle().italic}}),"Ctrl+U":()=>this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{underline:!this.env.model.getters.getCurrentStyle().underline}}),"Ctrl+O":()=>_R(this.env),"Alt+=":()=>{const e=this.env.model.getters.getActiveSheetId(),t=this.env.model.getters.getSelectedZone(),{anchor:o}=this.env.model.getters.getSelection(),s=this.env.model.getters.getAutomaticSums(e,t,o.cell);if(this.env.model.getters.isSingleCellOrMerge(e,t)||this.env.model.getters.isEmpty(e,t)&&s.length<=1){const t=s[0]?.zone,o=t?this.env.model.getters.zoneToXC(e,s[0].zone):"",i=`=SUM(${o})`;this.onComposerCellFocused(i,{start:5,end:5+o.length})}else this.env.model.dispatch("SUM_SELECTION")},"Alt+Enter":()=>{const e=this.env.model.getters.getActiveCell();e.link&&Tn(e.link,this.env)},"Ctrl+Home":()=>{const e=this.env.model.getters.getActiveSheetId(),{col:t,row:o}=this.env.model.getters.getNextVisibleCellPosition({sheetId:e,col:0,row:0});this.env.model.selection.selectCell(t,o)},"Ctrl+End":()=>{const e=this.env.model.getters.getActiveSheetId(),t=this.env.model.getters.findVisibleHeader(e,"COL",this.env.model.getters.getNumberCols(e)-1,0),o=this.env.model.getters.findVisibleHeader(e,"ROW",this.env.model.getters.getNumberRows(e)-1,0);this.env.model.selection.selectCell(t,o)},"Shift+ ":()=>{const e=this.env.model.getters.getActiveSheetId(),t={...this.env.model.getters.getSelectedZone(),left:0,right:this.env.model.getters.getNumberCols(e)-1},o=this.env.model.getters.getActivePosition();this.env.model.selection.selectZone({cell:o,zone:t})},"Ctrl+ ":()=>{const e=this.env.model.getters.getActiveSheetId(),t={...this.env.model.getters.getSelectedZone(),top:0,bottom:this.env.model.getters.getNumberRows(e)-1},o=this.env.model.getters.getActivePosition();this.env.model.selection.selectZone({cell:o,zone:t})},"Ctrl+D":async()=>this.env.model.dispatch("COPY_PASTE_CELLS_ABOVE"),"Ctrl+R":async()=>this.env.model.dispatch("COPY_PASTE_CELLS_ON_LEFT"),"Ctrl+H":()=>this.sidePanel.open("FindAndReplace",{}),"Ctrl+F":()=>this.sidePanel.open("FindAndReplace",{}),"Ctrl+Shift+E":()=>this.setHorizontalAlign("center"),"Ctrl+Shift+L":()=>this.setHorizontalAlign("left"),"Ctrl+Shift+R":()=>this.setHorizontalAlign("right"),"Ctrl+Shift+V":()=>xR(this.env),"Ctrl+Shift+<":()=>this.clearFormatting(),"Ctrl+<":()=>this.clearFormatting(),"Ctrl+Shift+ ":()=>{this.env.model.selection.selectAll()},"Ctrl+Alt+=":()=>{const e=this.env.model.getters.getActiveCols(),t=this.env.model.getters.getActiveRows(),o=1===this.env.model.getters.getSelectedZones().length,s=e.size>0&&o,i=t.size>0&&o;s&&!i?TR(this.env):i&&!s&&RR(this.env)},"Ctrl+Alt+-":()=>{const e=[...this.env.model.getters.getActiveCols()],t=[...this.env.model.getters.getActiveRows()];e.length>0&&0===t.length?this.env.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:this.env.model.getters.getActiveSheetId(),dimension:"COL",elements:e}):t.length>0&&0===e.length&&this.env.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:this.env.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},"Shift+PageDown":()=>{this.env.model.dispatch("ACTIVATE_NEXT_SHEET")},"Shift+PageUp":()=>{this.env.model.dispatch("ACTIVATE_PREVIOUS_SHEET")},PageDown:()=>this.env.model.dispatch("SHIFT_VIEWPORT_DOWN"),PageUp:()=>this.env.model.dispatch("SHIFT_VIEWPORT_UP"),"Ctrl+K":()=>DR(this.env),"Alt+Shift+ArrowRight":()=>this.processHeaderGroupingKey("right"),"Alt+Shift+ArrowLeft":()=>this.processHeaderGroupingKey("left"),"Alt+Shift+ArrowUp":()=>this.processHeaderGroupingKey("up"),"Alt+Shift+ArrowDown":()=>this.processHeaderGroupingKey("down")};focusDefaultElement(){this.env.model.getters.getSelectedFigureId()||"inactive"!==this.composerFocusStore.activeComposer.editionMode||this.DOMFocusableElementStore.focusableElement?.focus()}get gridEl(){if(!this.gridRef.el)throw new Error("Grid el is not defined.");return this.gridRef.el}getAutofillPosition(){const e=this.env.model.getters.getSelectedZone(),t=this.env.model.getters.getVisibleRect(e);return{left:t.x+t.width-4,top:t.y+t.height-4}}get isAutofillVisible(){const e=this.env.model.getters.getSelectedZone(),t=this.env.model.getters.getVisibleRect({left:e.right,right:e.right,top:e.bottom,bottom:e.bottom});return!(0===t.width||0===t.height)}onGridResized({height:e,width:t}){this.env.model.dispatch("RESIZE_SHEETVIEW",{width:t,height:e,gridOffsetX:te,gridOffsetY:ee})}moveCanvas(e,t){const{scrollX:o,scrollY:s}=this.env.model.getters.getActiveSheetDOMScrollInfo();this.env.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:o+e,offsetY:s+t})}getClientPositionKey(e){return`${e.id}-${e.position?.sheetId}-${e.position?.col}-${e.position?.row}`}isCellHovered(e,t){return this.hoveredCell.col===e&&this.hoveredCell.row===t}getGridRect(){return{...this.canvasPosition,...this.env.model.getters.getSheetViewDimensionWithHeaders()}}onCellClicked(e,t,o){"editing"===this.composerFocusStore.activeComposer.editionMode&&this.composerFocusStore.activeComposer.stopEdition(),o.expandZone?this.env.model.selection.setAnchorCorner(e,t):o.addZone?this.env.model.selection.addCellToSelection(e,t):this.env.model.selection.selectCell(e,t);let s=e,i=t;j_(this.env,((e,t,o)=>{o.preventDefault(),(e!==s&&-1!=e||t!==i&&-1!=t)&&(s=-1===e?s:e,i=-1===t?i:t,this.env.model.selection.setAnchorCorner(s,i))}),(()=>{this.paintFormatStore.isActive&&this.paintFormatStore.pasteFormat(this.env.model.getters.getSelectedZones())}))}onCellDoubleClicked(e,t){const o=this.env.model.getters.getActiveSheetId();({col:e,row:t}=this.env.model.getters.getMainCellPosition({sheetId:o,col:e,row:t}));this.env.model.getters.getEvaluatedCell({sheetId:o,col:e,row:t}).type===ni.empty?this.onComposerCellFocused():this.onComposerContentFocused()}processArrows(e){e.preventDefault(),e.stopPropagation(),this.cellPopovers.isOpen&&this.cellPopovers.close(),tD(e,this.env.model.selection),this.paintFormatStore.isActive&&this.paintFormatStore.pasteFormat(this.env.model.getters.getSelectedZones())}onKeydown(e){const t=lR(e),o=this.keyDownMapping[t];if(o)return e.preventDefault(),e.stopPropagation(),void o();e.key.startsWith("Arrow")&&this.processArrows(e)}onInputContextMenu(e){e.preventDefault();const t=this.env.model.getters.getSelectedZone(),{left:o,top:s}=t;let i="CELL";this.composerFocusStore.activeComposer.stopEdition(),this.env.model.getters.getActiveCols().has(o)?i="COL":this.env.model.getters.getActiveRows().has(s)&&(i="ROW");const{x:n,y:r,width:a}=this.env.model.getters.getVisibleRect(t),l=this.getGridRect();this.toggleContextMenu(i,l.x+n+a,l.y+r)}onCellRightClicked(e,t,{x:o,y:s}){const i=this.env.model.getters.getSelectedZones();let n="CELL";as(e,t,i[i.length-1])?this.env.model.getters.getActiveCols().has(e)?n="COL":this.env.model.getters.getActiveRows().has(t)&&(n="ROW"):(this.env.model.selection.getBackToDefault(),this.env.model.selection.selectCell(e,t)),this.toggleContextMenu(n,o,s)}toggleContextMenu(e,t,o){this.cellPopovers.isOpen&&this.cellPopovers.close(),this.menuState.isOpen=!0,this.menuState.position={x:t,y:o},this.menuState.menuItems=HM[e].getMenuItems()}async copy(e,t){if(!this.gridEl.contains(document.activeElement))return;if("inactive"!==this.composerFocusStore.activeComposer.editionMode)return;e?wI(this.env):this.env.model.dispatch("COPY");const o=this.env.model.getters.getClipboardContent(),s=t.clipboardData;for(const e in o)s?.setData(e,o[e]);t.preventDefault()}async paste(e){if(!this.gridEl.contains(document.activeElement))return;e.preventDefault();const t=e.clipboardData;if(!t)return;const o={content:{[ri.PlainText]:t?.getData(ri.PlainText),[ri.Html]:t?.getData(ri.Html)}},s=this.env.model.getters.getSelectedZones(),i=this.env.model.getters.isCutOperation(),n=ha(o.content),r=n.data?.clipboardId;this.env.model.getters.getClipboardId()===r?cx(this.env,s):hx(this.env,s,n),i&&await this.env.clipboard.write({[ri.PlainText]:""})}clearFormatting(){this.env.model.dispatch("CLEAR_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones()})}setHorizontalAlign(e){this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{align:e}})}closeMenu(){this.menuState.isOpen=!1,this.focusDefaultElement()}processHeaderGroupingKey(e){if(1!==this.env.model.getters.getSelectedZones().length)return;const t=this.env.model.getters.getActiveRows().size>0,o=this.env.model.getters.getActiveCols().size>0;o&&t?this.processHeaderGroupingEventOnWholeSheet(e):o?this.processHeaderGroupingEventOnHeaders(e,"COL"):t?this.processHeaderGroupingEventOnHeaders(e,"ROW"):this.processHeaderGroupingEventOnGrid(e)}processHeaderGroupingEventOnHeaders(e,t){const o=this.env.model.getters.getActiveSheetId(),s=this.env.model.getters.getSelectedZone(),i="COL"===t?s.left:s.top,n="COL"===t?s.right:s.bottom;switch(e){case"right":this.env.model.dispatch("GROUP_HEADERS",{sheetId:o,dimension:t,start:i,end:n});break;case"left":this.env.model.dispatch("UNGROUP_HEADERS",{sheetId:o,dimension:t,start:i,end:n});break;case"down":this.env.model.dispatch("UNFOLD_HEADER_GROUPS_IN_ZONE",{sheetId:o,dimension:t,zone:s});break;case"up":this.env.model.dispatch("FOLD_HEADER_GROUPS_IN_ZONE",{sheetId:o,dimension:t,zone:s})}}processHeaderGroupingEventOnWholeSheet(e){const t=this.env.model.getters.getActiveSheetId();"up"===e?(this.env.model.dispatch("FOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"ROW"}),this.env.model.dispatch("FOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"COL"})):"down"===e&&(this.env.model.dispatch("UNFOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"ROW"}),this.env.model.dispatch("UNFOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"COL"}))}processHeaderGroupingEventOnGrid(e){const t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getSelectedZone();switch(e){case"down":this.env.model.dispatch("UNFOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"ROW",zone:o}),this.env.model.dispatch("UNFOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"COL",zone:o});break;case"up":this.env.model.dispatch("FOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"ROW",zone:o}),this.env.model.dispatch("FOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"COL",zone:o});break;case"right":{const{x:e,y:t,width:s}=this.env.model.getters.getVisibleRect(o),i=this.getGridRect();this.toggleContextMenu("GROUP_HEADERS",e+s+i.x,t+i.y);break}case"left":{if(!L_(this.env,"COL")&&!L_(this.env,"ROW"))return;const{x:e,y:t,width:s}=this.env.model.getters.getVisibleRect(o),i=this.getGridRect();this.toggleContextMenu("UNGROUP_HEADERS",e+s+i.x,t+i.y);break}}}onComposerCellFocused(e,t){this.composerFocusStore.focusActiveComposer({content:e,selection:t,focusMode:"cellFocus"})}onComposerContentFocused(){this.composerFocusStore.focusActiveComposer({focusMode:"contentFocus"})}get staticTables(){const e=this.env.model.getters.getActiveSheetId();return this.env.model.getters.getCoreTables(e).filter(IF)}}class BM{static getters=[];history;constructor(e){this.history=Object.assign(Object.create(e),{update:e.addChange.bind(e,this),selectCell:()=>{}})}exportForExcel(e){}allowDispatch(e){return"Success"}beforeHandle(e){}handle(e){}finalize(){}batchValidations(...e){return t=>e.map((e=>e.call(this,t))).flat()}chainValidations(...e){return t=>{for(const o of e){let e=o.call(this,t);Array.isArray(e)||(e=[e]);const s=e.filter((e=>"Success"!==e));if(s.length)return s}return"Success"}}checkValidations(e,...t){return this.batchValidations(...t)(e)}}class zM extends BM{getters;dispatch;canDispatch;constructor({getters:e,stateObserver:t,range:o,dispatch:s,canDispatch:i}){super(t),o.addRangeProvider(this.adaptRanges.bind(this)),this.getters=e,this.dispatch=s,this.canDispatch=i}import(e){}export(e){}adaptRanges(e,t){}garbageCollectExternalResources(){}}class $M{id;format;style;sheetId;getRangeString;isFormula=!0;compiledFormula;constructor(e,t,o,s,i,n,r){this.id=e,this.format=o,this.style=s,this.sheetId=n,this.getRangeString=r;let a=0;const l=t.tokens.map((e=>{if("REFERENCE"===e.type){const e=a++;return new WM(i,e,this.sheetId,this.getRangeString)}return e}));this.compiledFormula={...t,dependencies:i,tokens:l}}get content(){return dt(this.compiledFormula.tokens.map((e=>e.value)))}get contentWithFixedReferences(){let e=0;return dt(this.compiledFormula.tokens.map((t=>{if("REFERENCE"===t.type){const t=e++;return this.getRangeString(this.compiledFormula.dependencies[t],this.sheetId,{useBoundedReference:!0})}return t.value})))}}class WM{ranges;rangeIndex;sheetId;getRangeString;type="REFERENCE";constructor(e,t,o,s){this.ranges=e,this.rangeIndex=t,this.sheetId=o,this.getRangeString=s}get value(){const e=this.ranges[this.rangeIndex];return this.getRangeString(e,this.sheetId)}}function GM(e){return""===e?NaN:Number(e)}function qM(e){return Object.entries(e).map((([e,t])=>t?ZM(parseInt(e,10),t):void 0)).filter(at).map((e=>yo(e.left,e.top)+":"+yo(e.right,e.bottom)))}function ZM(e,t){return{...t.zone,id:e}}class jM{getters;providers=[];constructor(e){this.getters=e}static getters=["extendRange","getRangeString","getRangeFromSheetXC","createAdaptedRanges","getRangeDataFromXc","getRangeDataFromZone","getRangeFromRangeData","getRangeFromZone","getRangesUnion","recomputeRanges","isRangeValid","removeRangesSheetPrefix"];allowDispatch(e){return"MOVE_RANGES"===e.type?1===e.target.length?"Success":"InvalidZones":"Success"}beforeHandle(e){}handle(e){switch(e.type){case"REMOVE_COLUMNS_ROWS":{let t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";const i=[...e.elements];i.sort(((e,t)=>t-e));const n=je(i);this.executeOnAllRanges((i=>{if(i.sheetId!==e.sheetId)return{changeType:"NONE"};let r=i,a="NONE";for(let e of n){const n=Ot(e),l=Dt(e);if(i.zone[t]<=n&&n<=i.zone[o]){const e=Math.min(i.zone[o],l)-n+1;a="RESIZE",r=this.createAdaptedRange(r,s,a,-e)}else if(i.zone[t]>=n&&i.zone[o]<=l)a="REMOVE",r=i.clone({...this.getInvalidRange()});else if(i.zone[t]<=l&&i.zone[o]>=l){const e=l-i.zone[t]+1;a="RESIZE",r=this.createAdaptedRange(r,s,a,-e),r=this.createAdaptedRange(r,s,"MOVE",-(i.zone[t]-n))}else n<i.zone[t]&&(a="MOVE",r=this.createAdaptedRange(r,s,a,-(l-n+1)))}return"NONE"!==a?{changeType:a,range:r}:{changeType:"NONE"}}),e.sheetId);break}case"ADD_COLUMNS_ROWS":{let t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";this.executeOnAllRanges((i=>{if(i.sheetId!==e.sheetId)return{changeType:"NONE"};if("after"===e.position){if(i.zone[t]<=e.base&&e.base<i.zone[o])return{changeType:"RESIZE",range:this.createAdaptedRange(i,s,"RESIZE",e.quantity)};if(e.base<i.zone[t])return{changeType:"MOVE",range:this.createAdaptedRange(i,s,"MOVE",e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[o])return{changeType:"RESIZE",range:this.createAdaptedRange(i,s,"RESIZE",e.quantity)};if(e.base<=i.zone[t])return{changeType:"MOVE",range:this.createAdaptedRange(i,s,"MOVE",e.quantity)}}return{changeType:"NONE"}}),e.sheetId);break}case"DELETE_SHEET":this.executeOnAllRanges((t=>{if(t.sheetId!==e.sheetId)return{changeType:"NONE"};const o=this.getters.getSheetName(e.sheetId);return{changeType:"REMOVE",range:t=t.clone({...this.getInvalidRange(),invalidSheetName:o})}}),e.sheetId);break;case"RENAME_SHEET":this.executeOnAllRanges((t=>{if(t.sheetId===e.sheetId)return{changeType:"CHANGE",range:t};if(e.name&&t.invalidSheetName===e.name){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:t.clone({sheetId:s,invalidSheetName:o})}}return{changeType:"NONE"}}));break;case"MOVE_RANGES":{const t=e.target[0];this.executeOnAllRanges((o=>{if(o.sheetId!==e.sheetId||!ls(o.zone,t))return{changeType:"NONE"};const s=e.targetSheetId,i=e.col-t.left,n=e.row-t.top,r=this.createAdaptedRange(o,"both","MOVE",[i,n]),a=e.sheetId!==s||r.prefixSheet;return{changeType:"MOVE",range:r.clone({sheetId:s,prefixSheet:a})}}));break}}}finalize(){}verifyRangeRemoved(e){return t=>{const o=e(t);return"NONE"===o.changeType||Xo(o.range.zone)?o:{range:o.range,changeType:"REMOVE"}}}createAdaptedRange(e,t,o,s){const i=ps(e.unboundedZone,t,o,s);return e.clone({zone:i})}executeOnAllRanges(e,t){const o=this.verifyRangeRemoved(e);for(const e of this.providers)e(o,t)}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,o,s){const i=e.map((e=>kr.fromRange(e,this.getters)));return i.map((e=>{if(!Xo(e.zone))return e;const i=e.prefixSheet?e.sheetId:s,n={...e.unboundedZone,left:e.isFullRow&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:e.isFullRow?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:e.isFullCol&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:o),bottom:e.isFullCol?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:o)};return e.clone({sheetId:i,zone:n}).orderZone()}))}removeRangesSheetPrefix(e,t){return t.map((t=>{const o=kr.fromRange(t,this.getters);return o.prefixSheet&&o.sheetId===e?o.clone({prefixSheet:!1}):o}))}extendRange(e,t,o){const s=kr.fromRange(e,this.getters),i="COL"===t?s.zone.right+o:s.zone.right,n="ROW"===t?s.zone.bottom+o:s.zone.bottom,r={left:s.zone.left,top:s.zone.top,right:s.isFullRow?void 0:i,bottom:s.isFullCol?void 0:n};return new kr({...s,zone:r},this.getters.getSheetSize).orderZone()}getRangeFromSheetXC(e,t){if(!Uo.test(t)||!this.getters.tryGetSheet(e))return new kr({sheetId:"",zone:{left:-1,top:-1,right:-1,bottom:-1},parts:[],invalidXc:t,prefixSheet:!1},this.getters.getSheetSize);let o,s=t,i=!1;t.includes("!")&&(({xc:s,sheetName:o}=qo(t)),o&&(i=!0));const n=jo(s),r=kr.getRangeParts(s,n),a=o&&!this.getters.getSheetIdByName(o)?o:void 0,l=this.getters.getSheetIdByName(o)||e;return new kr({prefixSheet:i,zone:n,sheetId:l,invalidSheetName:a,parts:r},this.getters.getSheetSize).orderZone()}getRangeString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){if(!e)return Ii.InvalidReference;if(e.invalidXc)return e.invalidXc;if(!this.getters.tryGetSheet(e.sheetId))return Ii.InvalidReference;if(e.zone.bottom-e.zone.top<0||e.zone.right-e.zone.left<0)return Ii.InvalidReference;if(e.zone.left<0||e.zone.top<0)return Ii.InvalidReference;const s=kr.fromRange(e,this.getters);let i=s.sheetId!==t||s.invalidSheetName||s.prefixSheet,n="";if(i&&(n=s.invalidSheetName?s.invalidSheetName:We(this.getters.getSheetName(s.sheetId))),i&&!n)return Ii.InvalidReference;let r=this.getRangePartString(s,0,o);return s.parts&&2===s.parts.length&&(s.zone.top!==s.zone.bottom||s.zone.left!==s.zone.right||s.parts[0].rowFixed||s.parts[0].colFixed||s.parts[1].rowFixed||s.parts[1].colFixed)&&(r+=":",r+=this.getRangePartString(s,1,o)),`${i?n+"!":""}${r}`}getRangeDataFromXc(e,t){return this.getters.getRangeFromSheetXC(e,t).rangeData}getRangeDataFromZone(e,t){return{_sheetId:e,_zone:t=this.getters.getUnboundedZone(e,t)}}getRangeFromZone(e,t){return new kr({sheetId:e,zone:t,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}],prefixSheet:!1},this.getters.getSheetSize)}recomputeRanges(e,t){const o=e.map((e=>kr.fromRange(e,this.getters).unboundedZone)),s=t.map((e=>kr.fromRange(e,this.getters).unboundedZone));return Co(o,s).map((t=>this.getRangeFromZone(e[0].sheetId,t)))}getRangeFromRangeData(e){const t={prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]};return new kr(t,this.getters.getSheetSize)}isRangeValid(e){if(!e)return!1;const{xc:t,sheetName:o}=qo(e);return null!==t.match(Uo)&&(!o||void 0!==this.getters.getSheetIdByName(o))}getRangesUnion(e){const t=e.map((e=>kr.fromRange(e,this.getters).unboundedZone)),o=function(...e){return{top:Math.min(...e.map((e=>e.top))),left:Math.min(...e.map((e=>e.left))),bottom:e.some((e=>void 0===e.bottom))?void 0:Math.max(...e.map((e=>e.bottom))),right:e.some((e=>void 0===e.right))?void 0:Math.max(...e.map((e=>e.right)))}}(...t);return this.getRangeFromZone(e[0].sheetId,o)}getRangePartString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){const s=e.parts[t]?.colFixed||o.useFixedReference?"$":"",i=fo(0===t?e.zone.left:e.zone.right),n=e.parts[t]?.rowFixed||o.useFixedReference?"$":"",r=String(0===t?e.zone.top+1:e.zone.bottom+1);let a="";return a=e.isFullCol&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:s+i:e.isFullRow&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:n+r:s+i+n+r,a}getInvalidRange(){return{parts:[],prefixSheet:!1,zone:{left:-1,top:-1,right:-1,bottom:-1},sheetId:"",invalidXc:Ii.InvalidReference}}}let YM=1;function XM(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}class KM extends BM{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}}const JM=new n;JM.add("pivots",(e=>{for(const t of e.getPivotIds()){const o=e.getPivot(t);dF.get(o.type).onIterationEndEvaluation(o)}}));const QM=$b.mapping;function eP(e,t,o){return new tP(e,t,o).getParameters()}class tP{getters;computeCell;evalContext;rangeCache={};constructor(e,t,o){this.getters=t,this.computeCell=o,this.evalContext=Object.assign(Object.create(QM),e,{getters:this.getters,locale:this.getters.getLocale()})}getParameters(){return{referenceDenormalizer:this.refFn.bind(this),ensureRange:this.range.bind(this),evalContext:this.evalContext}}refFn(e,t){const o=this.getRangeError(e);if(o)return o;if(t){return{value:Zo(this.getters.getSheetName(e.sheetId),Jo(e.zone))}}const s={sheetId:e.sheetId,col:e.zone.left,row:e.zone.top};return this.computeCell(s)}range(e){const t=this.getRangeError(e);if(t)return[[t]];const o=e.sheetId,s=e.zone,i=is(s,this.getters.getSheetZone(o));if(!i)return[[]];const{top:n,left:r,bottom:a,right:l}=s,c=`${o}-${n}-${r}-${a}-${l}`;if(c in this.rangeCache)return this.rangeCache[c];const h=i.bottom-i.top+1,d=i.right-i.left+1,u=new Array(d);for(let e=i.left;e<=i.right;e++){const t=e-i.left;u[t]=new Array(h);for(let s=i.top;s<=i.bottom;s++){const n=s-i.top;u[t][n]=this.computeCell({sheetId:o,col:e,row:s})}}return this.rangeCache[c]=u,u}getRangeError(e){return Xo(e.zone)?e.invalidSheetName?new Ti(Fo("Invalid sheet name: %s",e.invalidSheetName)):void 0:new _i}}function oP(e,t,o,s,i){sP(e,t,o||0,s||e.length-1,i||nP)}function sP(e,t,o,s,i){for(;s>o;){if(s-o>600){var n=s-o+1,r=t-o+1,a=Math.log(n),l=.5*Math.exp(2*a/3),c=.5*Math.sqrt(a*l*(n-l)/n)*(r-n/2<0?-1:1);sP(e,t,Math.max(o,Math.floor(t-r*l/n+c)),Math.min(s,Math.floor(t+(n-r)*l/n+c)),i)}var h=e[t],d=o,u=s;for(iP(e,o,t),i(e[s],h)>0&&iP(e,o,s);d<u;){for(iP(e,d,u),d++,u--;i(e[d],h)<0;)d++;for(;i(e[u],h)>0;)u--}0===i(e[o],h)?iP(e,o,u):iP(e,++u,s),u<=t&&(o=u+1),t<=u&&(s=u-1)}}function iP(e,t,o){var s=e[t];e[t]=e[o],e[o]=s}function nP(e,t){return e<t?-1:e>t?1:0}class rP{constructor(e=9){this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()}all(){return this._all(this.data,[])}search(e){let t=this.data;const o=[];if(!vP(e,t))return o;const s=this.toBBox,i=[];for(;t;){for(let n=0;n<t.children.length;n++){const r=t.children[n],a=t.leaf?s(r):r;vP(e,a)&&(t.leaf?o.push(r):fP(e,a)?this._all(r,o):i.push(r))}t=i.pop()}return o}collides(e){let t=this.data;if(!vP(e,t))return!1;const o=[];for(;t;){for(let s=0;s<t.children.length;s++){const i=t.children[s],n=t.leaf?this.toBBox(i):i;if(vP(e,n)){if(t.leaf||fP(e,n))return!0;o.push(i)}}t=o.pop()}return!1}load(e){if(!e||!e.length)return this;if(e.length<this._minEntries){for(let t=0;t<e.length;t++)this.insert(e[t]);return this}let t=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===t.height)this._splitRoot(this.data,t);else{if(this.data.height<t.height){const e=this.data;this.data=t,t=e}this._insert(t,this.data.height-t.height-1,!0)}else this.data=t;return this}insert(e){return e&&this._insert(e,this.data.height-1),this}clear(){return this.data=bP([]),this}remove(e,t){if(!e)return this;let o=this.data;const s=this.toBBox(e),i=[],n=[];let r,a,l;for(;o||i.length;){if(o||(o=i.pop(),a=i[i.length-1],r=n.pop(),l=!0),o.leaf){const s=aP(e,o.children,t);if(-1!==s)return o.children.splice(s,1),i.push(o),this._condense(i),this}l||o.leaf||!fP(o,s)?a?(r++,o=a.children[r],l=!1):o=null:(i.push(o),n.push(r),r=0,a=o,o=o.children[0])}return this}toBBox(e){return e}compareMinX(e,t){return e.minX-t.minX}compareMinY(e,t){return e.minY-t.minY}toJSON(){return this.data}fromJSON(e){return this.data=e,this}_all(e,t){const o=[];for(;e;)e.leaf?t.push(...e.children):o.push(...e.children),e=o.pop();return t}_build(e,t,o,s){const i=o-t+1;let n,r=this._maxEntries;if(i<=r)return n=bP(e.slice(t,o+1)),lP(n,this.toBBox),n;s||(s=Math.ceil(Math.log(i)/Math.log(r)),r=Math.ceil(i/Math.pow(r,s-1))),n=bP([]),n.leaf=!1,n.height=s;const a=Math.ceil(i/r),l=a*Math.ceil(Math.sqrt(r));SP(e,t,o,l,this.compareMinX);for(let i=t;i<=o;i+=l){const t=Math.min(i+l-1,o);SP(e,i,t,a,this.compareMinY);for(let o=i;o<=t;o+=a){const i=Math.min(o+a-1,t);n.children.push(this._build(e,o,i,s-1))}}return lP(n,this.toBBox),n}_chooseSubtree(e,t,o,s){for(;s.push(t),!t.leaf&&s.length-1!==o;){let o,s=1/0,r=1/0;for(let a=0;a<t.children.length;a++){const l=t.children[a],c=gP(l),h=(i=e,n=l,(Math.max(n.maxX,i.maxX)-Math.min(n.minX,i.minX))*(Math.max(n.maxY,i.maxY)-Math.min(n.minY,i.minY))-c);h<r?(r=h,s=c<s?c:s,o=l):h===r&&c<s&&(s=c,o=l)}t=o||t.children[0]}var i,n;return t}_insert(e,t,o){const s=o?e:this.toBBox(e),i=[],n=this._chooseSubtree(s,this.data,t,i);for(n.children.push(e),hP(n,s);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(s,i,t)}_split(e,t){const o=e[t],s=o.children.length,i=this._minEntries;this._chooseSplitAxis(o,i,s);const n=this._chooseSplitIndex(o,i,s),r=bP(o.children.splice(n,o.children.length-n));r.height=o.height,r.leaf=o.leaf,lP(o,this.toBBox),lP(r,this.toBBox),t?e[t-1].children.push(r):this._splitRoot(o,r)}_splitRoot(e,t){this.data=bP([e,t]),this.data.height=e.height+1,this.data.leaf=!1,lP(this.data,this.toBBox)}_chooseSplitIndex(e,t,o){let s,i=1/0,n=1/0;for(let r=t;r<=o-t;r++){const t=cP(e,0,r,this.toBBox),a=cP(e,r,o,this.toBBox),l=mP(t,a),c=gP(t)+gP(a);l<i?(i=l,s=r,n=c<n?c:n):l===i&&c<n&&(n=c,s=r)}return s||o-t}_chooseSplitAxis(e,t,o){const s=e.leaf?this.compareMinX:dP,i=e.leaf?this.compareMinY:uP;this._allDistMargin(e,t,o,s)<this._allDistMargin(e,t,o,i)&&e.children.sort(s)}_allDistMargin(e,t,o,s){e.children.sort(s);const i=this.toBBox,n=cP(e,0,t,i),r=cP(e,o-t,o,i);let a=pP(n)+pP(r);for(let s=t;s<o-t;s++){const t=e.children[s];hP(n,e.leaf?i(t):t),a+=pP(n)}for(let s=o-t-1;s>=t;s--){const t=e.children[s];hP(r,e.leaf?i(t):t),a+=pP(r)}return a}_adjustParentBBoxes(e,t,o){for(let s=o;s>=0;s--)hP(t[s],e)}_condense(e){for(let t,o=e.length-1;o>=0;o--)0===e[o].children.length?o>0?(t=e[o-1].children,t.splice(t.indexOf(e[o]),1)):this.clear():lP(e[o],this.toBBox)}}function aP(e,t,o){if(!o)return t.indexOf(e);for(let s=0;s<t.length;s++)if(o(e,t[s]))return s;return-1}function lP(e,t){cP(e,0,e.children.length,t,e)}function cP(e,t,o,s,i){i||(i=bP(null)),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(let n=t;n<o;n++){const t=e.children[n];hP(i,e.leaf?s(t):t)}return i}function hP(e,t){return e.minX=Math.min(e.minX,t.minX),e.minY=Math.min(e.minY,t.minY),e.maxX=Math.max(e.maxX,t.maxX),e.maxY=Math.max(e.maxY,t.maxY),e}function dP(e,t){return e.minX-t.minX}function uP(e,t){return e.minY-t.minY}function gP(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function pP(e){return e.maxX-e.minX+(e.maxY-e.minY)}function mP(e,t){const o=Math.max(e.minX,t.minX),s=Math.max(e.minY,t.minY),i=Math.min(e.maxX,t.maxX),n=Math.min(e.maxY,t.maxY);return Math.max(0,i-o)*Math.max(0,n-s)}function fP(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function vP(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function bP(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function SP(e,t,o,s,i){const n=[t,o];for(;n.length;){if((o=n.pop())-(t=n.pop())<=s)continue;const r=t+Math.ceil((o-t)/s/2)*s;oP(e,r,t,o,i),n.push(t,r,r,o)}}class yP{rTrees={};constructor(e=[]){const t={};for(const o of e){const e=o.boundingBox.sheetId;t[e]||(t[e]=[]),t[e].push(o)}for(const e in t)this.rTrees[e]=new CP,this.rTrees[e].load(t[e])}insert(e){const t=e.boundingBox.sheetId;this.rTrees[t]||(this.rTrees[t]=new CP),this.rTrees[t].insert(e)}search({zone:e,sheetId:t}){return this.rTrees[t]?this.rTrees[t].search({minX:e.left,minY:e.top,maxX:e.right,maxY:e.bottom}):[]}remove(e){const t=e.boundingBox.sheetId;this.rTrees[t]&&this.rTrees[t].remove(e,this.rtreeItemComparer)}rtreeItemComparer(e,t){return e.data==t.data&&e.boundingBox.sheetId===t.boundingBox.sheetId&&e.boundingBox?.zone.left===t.boundingBox.zone.left&&e.boundingBox?.zone.top===t.boundingBox.zone.top&&e.boundingBox?.zone.right===t.boundingBox.zone.right&&e.boundingBox?.zone.bottom===t.boundingBox.zone.bottom}}class CP extends rP{toBBox({boundingBox:e}){const t=e.zone;return{minX:t.left,minY:t.top,maxX:t.right,maxY:t.bottom}}compareMinX(e,t){return e.boundingBox.zone.left-t.boundingBox.zone.left}compareMinY(e,t){return e.boundingBox.zone.top-t.boundingBox.zone.top}}class wP{createEmptyPositionSet;dependencies=new c_;rTree;constructor(e,t=[]){this.createEmptyPositionSet=e,this.rTree=new yP(t)}removeAllDependencies(e){const t=this.dependencies.get(e);if(t){for(const e of t)this.rTree.remove(e);this.dependencies.delete(e)}}addDependencies(e,t){const o=t.map((({sheetId:t,zone:o})=>({data:e,boundingBox:{zone:o,sheetId:t}})));for(const e of o)this.rTree.insert(e);const s=this.dependencies.get(e);s?s.push(...o):this.dependencies.set(e,o)}getCellsDependingOn(e){const t=this.createEmptyPositionSet(),o=Array.from(e).reverse();for(;o.length>0;){const e=o.pop(),s=e.zone,i=e.sheetId;for(let e=s.left;e<=s.right;e++)for(let o=s.top;o<=s.bottom;o++)t.add({sheetId:i,col:e,row:o});const n=this.rTree.search(e).map((e=>e.data)),r={};for(const e of n)t.has(e)||(r[e.sheetId]||(r[e.sheetId]=[]),r[e.sheetId].push(fs(e)));for(const e in r){const t=Co(r[e],[]);o.push(...t.map((t=>({sheetId:e,zone:t}))))}}for(const o of e){const e=o.zone,s=o.sheetId;for(let o=e.left;o<=e.right;o++)for(let i=e.top;i<=e.bottom;i++)t.delete({sheetId:s,col:o,row:i})}return t}}class xP extends Uint32Array{columnOffset=0;cols=0;rows=0;static create(e,t){const o=function(e){if(0===e)return-1/0;if(e<0)return NaN;return 32-Math.clz32(--e)}(t),s=new this((e<<o>>5)+1);return s.columnOffset=o,s.cols=t,s.rows=e,s}getValue(e){const[t,o]=this.getCoordinates(e);return this[t]>>o&1}setValue(e,t){const[o,s]=this.getCoordinates(e),i=0===(this[o]>>s&1)&&1===t;return this[o]=this[o]&~(1<<s)|t<<s,i}isEmpty(){return!this.some((e=>0!==e))}fillAllPositions(){this.fill(-1>>>0)}clear(){this.fill(0)}getCoordinates(e){const{row:t,col:o}=e,s=(t<<this.columnOffset)+o,i=s>>5;return[i,s-(i<<5)]}}class EP{sheets={};insertions=[];maxSize=0;constructor(e){for(const t in e){const o=e[t].cols,s=e[t].rows;this.maxSize+=o*s,this.sheets[t]=xP.create(s,o)}}add(e){this.sheets[e.sheetId].setValue(e,1)&&this.insertions.push(e)}addMany(e){for(const t of e)this.add(t)}delete(e){this.sheets[e.sheetId].setValue(e,0)}deleteMany(e){for(const t of e)this.delete(t)}has(e){return 1===this.sheets[e.sheetId].getValue(e)}clear(){const e=[...this];this.insertions=[];for(const e in this.sheets)this.sheets[e].clear();return e}isEmpty(){if(0===this.insertions.length)return!0;for(const e in this.sheets)if(!this.sheets[e].isEmpty())return!1;return!0}fillAllPositions(){this.insertions=new Array(this.maxSize);let e=0;for(const t in this.sheets){const o=this.sheets[t];o.fillAllPositions();for(let s=0;s<o.rows;s++)for(let i=0;i<o.cols;i++)this.insertions[e++]={sheetId:t,row:s,col:i}}}*[Symbol.iterator](){for(const e of this.insertions)1===this.sheets[e.sheetId].getValue(e)&&(yield e)}}class IP{resultsToArrayFormulas=new yP;arrayFormulasToResults=new c_;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map((e=>e.data))||RP}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:fs(e)},data:e}),this.arrayFormulasToResults.delete(e)}addRelation({arrayFormulaPosition:e,resultZone:t}){this.resultsToArrayFormulas.insert({boundingBox:{sheetId:e.sheetId,zone:t},data:e}),this.arrayFormulasToResults.set(e,t)}isArrayFormula(e){return this.arrayFormulasToResults.has(e)}}const RP=[],TP=Tr(new class extends Ti{constructor(e=Fo("Circular reference")){super(e,Ii.CircularDependency)}}),AP=Tr({value:null});class _P{context;getters;compilationParams;evaluatedCells=new c_;formulaDependencies=ut(new wP(this.createEmptyPositionSet.bind(this)));blockedArrayFormulas=new EP({});spreadingRelations=new IP;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=eP(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||AP}getSpreadZone(e,t={ignoreSpillError:!1}){const o=this.spreadingRelations.getArrayResultZone(e);if(!o)return;const s=this.evaluatedCells.get(e);return s?.type!==ni.error||t.ignoreSpillError&&s?.value===Ii.SpilledBlocked?ss(fs(e),o):fs(e)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(!(this.getEvaluatedCell(e).type!==ni.empty&&!this.getters.getCell(e)?.isFormula))return this.spreadingRelations.isArrayFormula(e)?e:void 0;const t=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,fs(e));return Array.from(t).find((e=>!this.blockedArrayFormulas.has(e)))}updateDependencies(e){this.formulaDependencies().removeAllDependencies(e);const t=this.getDirectDependencies(e);this.formulaDependencies().addDependencies(e,t)}addDependencies(e,t){this.formulaDependencies().addDependencies(e,t);for(const e of t){const t=e.sheetId,{left:o,bottom:s,right:i,top:n}=e.zone;for(let e=o;e<=i;e++)for(let o=n;o<=s;o++)this.computeAndSave({sheetId:t,col:e,row:o})}}updateCompilationParameters(){this.compilationParams=eP(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.updateDependencies=this.updateDependencies.bind(this),this.compilationParams.evalContext.addDependencies=this.addDependencies.bind(this)}createEmptyPositionSet(){const e={};for(const t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new EP(e)}evaluateCells(e){const t=performance.now(),o=this.createEmptyPositionSet();o.addMany(e);const s=this.getArrayFormulasImpactedByChangesOf(e);o.addMany(this.getCellsDependingOn(e)),o.addMany(s),o.addMany(this.getCellsDependingOn(s)),this.evaluate(o),console.debug("evaluate Cells",performance.now()-t,"ms")}getArrayFormulasImpactedByChangesOf(e){const t=this.createEmptyPositionSet();for(const o of e){const e=this.getters.getCell(o)?.content,s=this.getArrayFormulaSpreadingOn(o);void 0!==s&&t.add(s),e||t.add(o)}const o=ds(t);for(const e in o)for(const s of o[e])t.addMany(this.getArrayFormulasBlockedBy(e,s));return t}buildDependencyGraph(){this.blockedArrayFormulas=this.createEmptyPositionSet(),this.spreadingRelations=new IP,this.formulaDependencies=ut((()=>{const e=[...this.getAllCells()].flatMap((e=>this.getDirectDependencies(e).filter((e=>!e.invalidSheetName&&!e.invalidXc)).map((t=>({data:e,boundingBox:{zone:t.zone,sheetId:t.sheetId}})))));return new wP(this.createEmptyPositionSet.bind(this),e)}))}evaluateAllCells(){const e=performance.now();this.evaluatedCells=new c_,this.evaluate(this.getAllCells()),console.debug("evaluate all cells",performance.now()-e,"ms")}evaluateFormulaResult(e,t){const o=hS(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return this.updateCompilationParameters(),this.evaluateCompiledFormula(e,{...o,dependencies:s})}evaluateCompiledFormula(e,t,o){try{const s=FP(t,this.compilationParams,e,this.buildSafeGetSymbolValue(o),this.compilationParams.evalContext.__originCellPosition);return Ci(s)?an(s,OP):OP(s)}catch(e){return Gb(e,"")}}getAllCells(){const e=this.createEmptyPositionSet();return e.fillAllPositions(),e}getArrayFormulasBlockedBy(e,t){const o=this.createEmptyPositionSet(),s=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e,t);o.addMany(s);const i=[...s].filter((e=>!this.blockedArrayFormulas.has(e)));return i.length&&o.deleteMany(i),o.addMany(this.getCellsDependingOn(o)),o}nextPositionsToUpdate=new EP({});cellsBeingComputed=new Set;symbolsBeingComputed=new Set;evaluate(e){this.cellsBeingComputed=new Set,this.nextPositionsToUpdate=e;let t=0;for(;!this.nextPositionsToUpdate.isEmpty()&&t++<30;){this.updateCompilationParameters();const e=this.nextPositionsToUpdate.clear();for(let t=0;t<e.length;++t)this.evaluatedCells.delete(e[t]);for(let t=0;t<e.length;++t){const o=e[t];if(this.nextPositionsToUpdate.has(o))continue;const s=this.computeCell(o);s!==AP&&this.evaluatedCells.set(o,s)}JM.getAll().forEach((e=>e(this.getters)))}t>=30&&console.warn("Maximum iteration reached while evaluating cells")}computeCell(e){const t=this.evaluatedCells.get(e);if(t)return t;this.blockedArrayFormulas.has(e)||this.invalidateSpreading(e),this.spreadingRelations.isArrayFormula(e)&&this.spreadingRelations.removeNode(e);const o=this.getters.getCell(e);if(void 0===o)return AP;const s=o.id,i={format:o.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(s)?TP:(this.cellsBeingComputed.add(s),o.isFormula?this.computeFormulaCell(e,o):Ir(o,i))}catch(e){return e.value=e?.value||Ii.GenericError,e.message=e?.message||Zb,Tr(e)}finally{this.cellsBeingComputed.delete(s)}}computeAndSave(e){const t=this.computeCell(e);return this.evaluatedCells.has(e)||this.evaluatedCells.set(e,t),t}computeFormulaCell(e,t){const o=FP(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!Ci(o)){const s=Tr(OP(o),this.getters.getLocale(),t);return s.type===ni.error&&(s.errorOriginPosition=o.errorOriginPosition??e),s}this.assertSheetHasEnoughSpaceToSpreadFormulaResult(e,o);const s=o.length,i=o[0].length,n={top:e.row,bottom:e.row+i-1,left:e.col,right:e.col+s-1};return this.spreadingRelations.addRelation({resultZone:n,arrayFormulaPosition:e}),this.assertNoMergedCellsInSpreadZone(e,o),DP(s,i,this.checkCollision(e)),DP(s,i,this.spreadValues(e,o)),this.invalidatePositionsDependingOnSpread(e.sheetId,n),Tr(OP(o[0][0]),this.getters.getLocale(),t)}invalidatePositionsDependingOnSpread(e,t){const o=this.formulaDependencies().getCellsDependingOn(function(e){const{top:t,left:o,bottom:s,right:i}=e;if(1===Ss(e))return[];const n={top:t+1,bottom:s,left:o,right:o};if(i===o)return[n];const r={top:t,bottom:s,left:o+1,right:i};return t===s?[r]:[n,r]}(t).map((t=>({sheetId:e,zone:t}))));o.delete({sheetId:e,col:t.left,row:t.top}),this.nextPositionsToUpdate.addMany(o)}assertSheetHasEnoughSpaceToSpreadFormulaResult({sheetId:e,col:t,row:o},s){const i=this.getters.getNumberCols(e),n=this.getters.getNumberRows(e),r=t+s.length<=i,a=o+s[0].length<=n;if(!r||!a){if(r)throw new Fi(Fo("Result couldn't be automatically expanded. Please insert more rows."));if(a)throw new Fi(Fo("Result couldn't be automatically expanded. Please insert more columns."));throw new Fi(Fo("Result couldn't be automatically expanded. Please insert more columns and rows."))}}assertNoMergedCellsInSpreadZone({sheetId:e,col:t,row:o},s){if(0!==this.getters.getMergesInZone(e,{top:o,bottom:o+s[0].length-1,left:t,right:t+s.length-1}).length)throw new Fi(Fo("Merged cells found in the spill zone. Please unmerge cells before using array formulas."))}checkCollision(e){const{sheetId:t,col:o,row:s}=e;return(i,n)=>{const r={sheetId:t,col:i+o,row:n+s},a=this.getters.getCell(r);if(a?.content||this.getters.getEvaluatedCell(r).type!==ni.empty)throw this.blockedArrayFormulas.add(e),new Fi(Fo("Array result was not expanded because it would overwrite data in %s.",yo(r.col,r.row)));this.blockedArrayFormulas.delete(e)}}spreadValues({sheetId:e,col:t,row:o},s){return(i,n)=>{const r={sheetId:e,col:i+t,row:n+o},a=this.getters.getCell(r),l=Tr(OP(s[i][n]),this.getters.getLocale(),a);l.type===ni.error&&(l.errorOriginPosition=s[i][n].errorOriginPosition??r),this.evaluatedCells.set(r,l)}}invalidateSpreading(e){const t=this.spreadingRelations.getArrayResultZone(e);if(!t)return;for(let o=t.left;o<=t.right;o++)for(let s=t.top;s<=t.bottom;s++){const t={sheetId:e.sheetId,col:o,row:s},i=this.getters.getCell(t)?.content;i||this.evaluatedCells.delete(t)}const o=e.sheetId;this.invalidatePositionsDependingOnSpread(o,t),this.nextPositionsToUpdate.addMany(this.getArrayFormulasBlockedBy(o,t))}buildSafeGetSymbolValue(e){return t=>{if(this.symbolsBeingComputed.has(t))return TP;this.symbolsBeingComputed.add(t);try{const o=e?.(t);return o||new Ai(Fo("Invalid formula"))}finally{this.symbolsBeingComputed.delete(t)}}}getDirectDependencies(e){const t=this.getters.getCell(e);return t?.isFormula?t.compiledFormula.dependencies:[]}getCellsDependingOn(e){const t=[],o=ds(e);for(const e in o)t.push(...o[e].map((t=>({sheetId:e,zone:t}))));return this.formulaDependencies().getCellsDependingOn(t)}}function DP(e,t,o){for(let s=0;s<e;++s)for(let e=0;e<t;++e)0===s&&0===e||o(s,e)}function OP(e){return null===e.value||void 0===e.value?{...e,value:0}:e}function FP(e,t,o,s,i){return t.evalContext.__originCellPosition=i,t.evalContext.__originSheetId=o,e.execute(e.dependencies,t.referenceDenormalizer,t.ensureRange,s,t.evalContext)}const MP=/"(#[0-9a-fA-F]{6})"/g;const PP={isValid:!0};const NP="0.00%";function kP(e){return class extends e{getters;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t){super(e,t),this.getters=t.getters}init(e){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.init(e)}getPivotCellValueAndFormat(e,t){return this.getMeasureDisplayValue(e,t)}_getPivotCellValueAndFormat(e,t){const o=`${e}-${t.map((e=>e.field+"="+e.value)).join(",")}`;if(this.cache[o])return this.cache[o];const s=this.getMeasure(e),i=s.computedBy?this.computeMeasure(s,t):super.getPivotCellValueAndFormat(e,t);return s.format?this.cache[o]={...i,format:s.format}:this.cache[o]=i,this.cache[o]}computeMeasure(e,t){if(!e.computedBy)return{value:0};const{columns:o,rows:s}=super.definition;if(o.length+s.length!==t.length){const o=this.getValuesToAggregate(e,t),s=Wl[e.aggregator];if(!s)return{value:0};try{return s([o],this.getters.getLocale())}catch(t){return Gb(t,e.aggregator.toUpperCase())}}const i=this.getters.getMeasureCompiledFormula(e),n=this.getters.evaluateCompiledFormula(e.computedBy.sheetId,i,(e=>{const{columns:o,rows:s}=this.definition;if(o.find((t=>t.nameWithGranularity===e))){const{colDomain:o}=ml(this,t),s=o.findIndex((t=>t.field===e));return this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}if(s.find((t=>t.nameWithGranularity===e))){const{rowDomain:o}=ml(this,t),s=o.findIndex((t=>t.field===e));return this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}return this.getPivotCellValueAndFormat(e,t)}));return Ci(n)?n[0][0]:n}getValuesToAggregate(e,t){const{rowDomain:o,colDomain:s}=ml(this,t),i=super.getTableStructure(),n=[];if(0===s.length&&o.length<this.definition.rows.length&&this.definition.rows.length&&this.definition.columns.length){const t=this.treeToLeafDomains(i.getColTree()),s=this.getSubTreeMatchingDomain(i.getRowTree(),o),r=this.treeToLeafDomains(s);for(const s of t)for(const t of r)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t).concat(s)));return n}if(o.length===this.definition.rows.length&&0===s.length){const t=i.getColTree(),r=this.getSubTreeMatchingDomain(t,s),a=this.treeToLeafDomains(r,s);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t)));return n}{const t=i.getRowTree(),r=this.getSubTreeMatchingDomain(t,o),a=this.treeToLeafDomains(r,o);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,t.concat(s)));return n}}getSubTreeMatchingDomain(e,t,o=0){if(o>t.length)return[];if(t.length===o)return e;for(const s of e){const e=Ql(this.definition.getDimension(s.field),t[o]?.value);if(s.field===t[o]?.field&&s.value===e)return this.getSubTreeMatchingDomain(s.children,t,o+1)}return e}treeToLeafDomains(e,t=[]){const o=[];for(const s of e){const e=this.definition.getDimension(s.field),i=[...t,{field:s.field,value:s.value,type:e.type}];0===s.children.length?o.push(i):o.push(...this.treeToLeafDomains(s.children,i))}return o}getMeasureDisplayValue(e,t){const o=this.getMeasure(e),s=this._getPivotCellValueAndFormat(e,t);if(!o.display||"no_calculations"===o.display.type||s.message)return s;const i=o.display.fieldNameWithGranularity;if(i&&!this.isFieldInPivot(i))return{value:Ii.NotAvailable,message:Fo('Field "%s" not found in pivot for measure display calculation',i)};try{const e=o.display;switch(e.type){case"%_of_grand_total":return this.asPercentOfGrandTotal(s,o);case"%_of_col_total":return this.asPercentOfColumnTotal(s,o,t);case"%_of_row_total":return this.asPercentOfRowTotal(s,o,t);case"%_of_parent_row_total":return this.asPercentOfParentRowTotal(s,o,t);case"%_of_parent_col_total":return this.asPercentOfParentColumnTotal(s,o,t);case"index":return this.asIndex(s,o,t);case"%_of_parent_total":return this.asPercentOfParentTotal(s,o,t,e);case"running_total":return this.asRunningTotal(s,o,t,e,"running_total");case"%_running_total":return this.asRunningTotal(s,o,t,e,"%_running_total");case"rank_asc":return this.asRank(s,o,t,e,"asc");case"rank_desc":return this.asRank(s,o,t,e,"desc");case"%_of":return this.asPercentOf(s,o,t,e);case"difference_from":return this.asDifferenceFrom(s,o,t,e);case"%_difference_from":return this.asDifferenceFromInPercent(s,o,t,e)}return s}catch(e){return Gb(e,"COMPUTE_MEASURE_DISPLAY_VALUE")}}asPercentOfGrandTotal(e,t){const o=this.getGrandTotal(t.id);return 0===o?{value:Ii.DivisionByZero}:{value:this.measureValueToNumber(e)/o,format:NP}}asPercentOfRowTotal(e,t,o){const s=this.getRowTotal(t.id,o);return 0===s?{value:Ii.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:NP}}asPercentOfColumnTotal(e,t,o){const s=this.getColumnTotal(t.id,o);return 0===s?{value:Ii.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:NP}}asPercentOfParentRowTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=ml(e,t);return[...o,...s.slice(0,s.length-1)]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:NP}}asPercentOfParentColumnTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=ml(e,t);return[...o.slice(0,o.length-1),...s]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:NP}}asPercentOfParentTotal(e,t,o,s){const{fieldNameWithGranularity:i}=s;if(!i)return e;if(!yl(i,o))return{value:""};const n=function(e,t,o){let{rowDomain:s,colDomain:i}=ml(e,o);if("row"===Cl(e,t)){const e=s.findIndex((e=>e.field===t));if(-1===e)return o;s=s.slice(0,e+1)}else{const e=i.findIndex((e=>e.field===t));if(-1===e)return o;i=i.slice(0,e+1)}return[...s,...i]}(this,i,o),r=this._getPivotCellValueAndFormat(t.id,n),a=this.measureValueToNumber(r);return 0===a?{value:""}:{value:this.measureValueToNumber(e)/a,format:NP}}asIndex(e,t,o){const s=this.measureValueToNumber(e),i=this.getRowTotal(t.id,o),n=this.getColumnTotal(t.id,o),r=this.getGrandTotal(t.id);return 0===i||0===n?{value:Ii.DivisionByZero}:{value:s*r/(n*i),format:void 0}}asRunningTotal(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;const r="running_total"===i?this.runningTotal:this.runningTotalInPercent;let a=r[t.id]?.[n];a||(a=this.computeRunningTotal(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=ml(this,o),h=wl(c),d=wl(l),u=a[h]?.[d];return{value:u??"",format:"running_total"===i?e.format:NP}}asPercentOf(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!yl(i,o))return{value:""};let r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r||"sameValue"===r&&0===a?{value:Ii.DivisionByZero}:!r||"sameValue"===r&&!a?{value:""}:"sameValue"===r?{value:1,format:NP}:void 0===a?{value:Ii.NullError}:{value:a/r,format:NP}}asDifferenceFrom(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!yl(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n)||0;return"sameValue"===r?{value:""}:{value:this.measureValueToNumber(e)-r,format:e.format}}asDifferenceFromInPercent(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!yl(i,o))return{value:""};let r=this.getComparisonValue(t,o,i,n);const a=this.strictMeasureValueToNumber(e);return 0===r?{value:Ii.DivisionByZero}:r&&"sameValue"!==r?void 0===a?{value:Ii.NullError}:{value:(a-r)/r,format:NP}:{value:""}}asRank(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;if(!yl(n,o))return{value:""};const r="asc"===i?this.rankAsc:this.rankDesc;let a=r[t.id]?.[n];a||(a=this.computeRank(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=ml(this,o),h=wl(c),d=wl(l),u=a[h]?.[d];return{value:u??""}}computeRank(e,t,o){const s={},i=Cl(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=ln(r));for(const a of r){const r=wl(fl(this,n,a[0].domain)),l=a.map((t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:fl(this,i,t.domain)}))).filter((e=>yl(t,e.rowDomain))),c=Object.groupBy(l,(e=>El(e.rowDomain,t)));for(const e in c)c[e]=Mt(c[e]||[],(e=>e.value)).filter((e=>void 0!==e.value)).sort(((e,t)=>"asc"===o?e.value-t.value:t.value-e.value));s[r]={};for(const e of l){const o=wl(fl(this,i,e.domain)),n=c[El(e.rowDomain,t)];if(!n)continue;const a=n.findIndex((t=>t.value===e.value));-1!==a&&(s[r][o]=a+1)}}return"row"===i?s:Pt(s)}computeRunningTotal(e,t,o){const s={},i=Cl(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=ln(r));for(const a of r){const r=wl(fl(this,n,a[0].domain));s[r]={};const l={},c=a.map((t=>({...t,rowDomain:fl(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))}))).filter((e=>yl(t,e.rowDomain)));for(const e of c){const o=wl(e.rowDomain),i=Il(e.rowDomain,t),n=(l[i]||0)+e.value;l[i]=n,s[r][o]=n}if("%_running_total"===o)for(const e of c){const o=e.rowDomain,i=wl(o),n=Il(o,t),a=s[r][i]||0,c=l[n];s[r][i]=c?a/c:void 0}}return"row"===i?s:Pt(s)}getGrandTotal(e){const t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){const o=ml(this,t).rowDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}getColumnTotal(e,t){const o=ml(this,t).colDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}isFieldInPivot(e){return this.definition.columns.some((t=>t.nameWithGranularity===e))||this.definition.rows.some((t=>t.nameWithGranularity===e))}getComparisonValue(e,t,o,s){const i=s===gl||s===pl?function(e,t,o,s){const i=Cl(e,o),n="row"===i?e.getTableStructure().getRowTree():e.getTableStructure().getColTree(),r=bl(fl(e,i,t),n,o),a=r?.map((e=>e.value))??[],l=function(e,t){const o=t.find((t=>t.field===e));return o?.value}(o,t);if(void 0===l)return;const c=a.indexOf(l);if(void 0===l||-1===c)return;return Sl(t,o,a[qe(c+(s===gl?-1:1),0,a.length-1)])}(this,t,o,s):Sl(t,o,s);if(mt(i,t))return"sameValue";if(!i||!function(e,t){const{rowDomain:o,colDomain:s}=ml(e,t);return vl(o,e.getTableStructure().getRowTree())&&vl(s,e.getTableStructure().getColTree())}(this,i))throw new Di;const n=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(n)}getPivotValueCells(e){return this.getTableStructure().getPivotCells().map((t=>t.filter((t=>"VALUE"===t.type&&t.measure===e)))).filter((e=>e.length>0))}measureValueToNumber(e){if("number"==typeof e.value)return e.value;if(!e.value)return 0;throw new Error(`Value ${e.value} is not a number`)}strictMeasureValueToNumber(e){if("number"==typeof e.value)return e.value;if(e.value)throw new Error(`Value ${e.value} is not a number`)}getTableStructure(){const e=super.getTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;const t=this.definition.sortedColumn.measure;ac(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,((e,t)=>this._getPivotCellValueAndFormat(e,t)))}}}const LP=["ADD_PIVOT","UPDATE_PIVOT"];function VP(e){return LP.includes(e.type)}class HP extends BM{static layers=[];getters;ui;selection;dispatch;canDispatch;constructor({getters:e,stateObserver:t,dispatch:o,canDispatch:s,uiActions:i,selection:n}){super(t),this.getters=e,this.ui=i,this.selection=n,this.dispatch=o,this.canDispatch=s}drawLayer(e,t){}}class UP{cells;getters;index=0;direction;constructor(e,t,o){this.cells=e,this.getters=t,this.direction=o}next(){const e=this.cells[this.index++%this.cells.length],t=e.rule,{cellData:o,tooltip:s}=ES.get(t.type).apply(t,e.data,this.getters,this.direction);return{cellData:o,tooltip:s,origin:{col:e.data.col,row:e.data.row}}}}function BP(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId!==t.sheetId)return e;const o=gc(e.pivot.dataSet.zone,t),s=o?{...e.pivot.dataSet,zone:o}:void 0;return{...e,pivot:{...e.pivot,dataSet:s}}}function zP(e,t){return{...e,definition:vR(e.definition,t)}}function $P(e,t){if(e.sheetId!==t.sheetId)return e;if(("FREEZE_COLUMNS"===e.type?"COL":"ROW")!==t.dimension)return e;let o=e.quantity;if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));for(let t of e)o>t&&o--}if("ADD_COLUMNS_ROWS"===t.type){o=o>("before"===t.position?t.base-1:t.base)?o+t.quantity:o}return o>0?{...e,quantity:o}:void 0}function WP(e,t){if(e.sheetId!==t.sheetId)return e;const o=gc(e.zone,t);if(!o)return;const s=e.newTableRange?pc(e.newTableRange,t):void 0;return{...e,newTableRange:s,zone:o}}function GP(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let o;if("REMOVE_COLUMNS_ROWS"===t.type)o=Wr(t.elements,[e.base])[0];else if("ADD_COLUMNS_ROWS"===t.type){o=$r(pt(t.position,t.base),t.quantity,[e.base])[0]}return void 0!==o?{...e,base:o}:void 0}function qP(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;const o=Ze(e.start,e.end+1);let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Wr(t.elements,o);else if("ADD_COLUMNS_ROWS"===t.type){s=$r(pt(t.position,t.base),t.quantity,o)}return 0!==s.length?{...e,start:Math.min(...s),end:Math.max(...s)}:void 0}G_.addTransformation("ADD_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],GP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],GP),G_.addTransformation("ADD_COLUMNS_ROWS",["CREATE_CHART","UPDATE_CHART"],zP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["CREATE_CHART","UPDATE_CHART"],zP),G_.addTransformation("DELETE_SHEET",["MOVE_RANGES"],(function(e,t){const o=t.sheetId;if(e.targetSheetId===o||e.sheetId===o)return;return e})),G_.addTransformation("DELETE_FIGURE",["UPDATE_FIGURE","UPDATE_CHART"],(function(e,t){if(e.id===t.id)return;return e})),G_.addTransformation("CREATE_SHEET",["CREATE_SHEET"],(function(e,t){if(e.name===t.name)return{...e,name:e.name?.match(/\d+/)?e.name.replace(/\d+/,(e=>(parseInt(e)+1).toString())):`${e.name}~`,position:e.position+1};return e})),G_.addTransformation("ADD_MERGE",["ADD_MERGE","REMOVE_MERGE"],(function(e,t){if(e.sheetId!==t.sheetId)return e;const o=[];for(const s of e.target)for(const e of t.target)rs(s,e)||o.push({...s});if(o.length)return{...e,target:o};return})),G_.addTransformation("ADD_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],$P),G_.addTransformation("REMOVE_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],$P),G_.addTransformation("ADD_COLUMNS_ROWS",["UPDATE_TABLE"],WP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["UPDATE_TABLE"],WP),G_.addTransformation("REMOVE_TABLE_STYLE",["CREATE_TABLE","UPDATE_TABLE"],(function(e,t){if(e.config?.styleId!==t.tableStyleId)return e;return{...e,config:{...e.config,styleId:QC.styleId}}})),G_.addTransformation("ADD_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],qP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],qP),G_.addTransformation("REMOVE_PIVOT",["RENAME_PIVOT","DUPLICATE_PIVOT","INSERT_PIVOT","UPDATE_PIVOT"],(function(e,t){if(e.pivotId===t.pivotId)return;return e})),G_.addTransformation("DELETE_SHEET",["ADD_PIVOT","UPDATE_PIVOT"],(function(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId===t.sheetId)return{...e,pivot:{...e.pivot,dataSet:void 0}};return e})),G_.addTransformation("ADD_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],BP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],BP);const ZP=[{match:function(e){return"sheetId"in e},fn:XP},{match:function(e){return"target"in e&&"sheetId"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=[];for(const o of e.target){const e=gc(o,t);e&&s.push(e)}if(!s.length)return"IGNORE_COMMAND";return{...e,target:s}}},{match:function(e){return"zone"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=gc(e.zone,t);if(s)return{...e,zone:s};return"IGNORE_COMMAND"}},{match:function(e){return"col"in e&&"row"in e&&"sheetId"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"===t.type||"REMOVE_COLUMNS_ROWS"===t.type)return function(e,t){const o="COL"===t.dimension?"col":"row";let s=e[o];if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));if(e.includes(s))return"IGNORE_COMMAND";for(let t of e)s>=t&&s--}"ADD_COLUMNS_ROWS"===t.type&&(s>t.base||s===t.base&&"before"===t.position)&&(s+=t.quantity);return{...e,[o]:s}}(e,t);if("ADD_MERGE"===t.type)return function(e,t){for(const o of t.target){if(!(e.col===o.left&&e.row===o.top)&&as(e.col,e.row,o))return"IGNORE_COMMAND"}return e}(e,t);return"SKIP_TRANSFORMATION"}},{match:function(e){return"dimension"in e&&"sheetId"in e&&"elements"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"!==t.type&&"REMOVE_COLUMNS_ROWS"!==t.type)return"SKIP_TRANSFORMATION";if(t.dimension!==e.dimension)return e;let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Wr(t.elements,e.elements);else if("ADD_COLUMNS_ROWS"===t.type){s=$r(pt(t.position,t.base),t.quantity,e.elements)}if(0===s.length)return"IGNORE_COMMAND";return{...e,elements:s}}},{match:function(e){return"ranges"in e},fn:function(e,t){if(!("sheetId"in t))return e;const o=e.ranges.map((e=>pc(e,t))).filter(at);if(!o.length)return"IGNORE_COMMAND";return{...e,ranges:o}}}];function jP(e,t){const o=G_.getTransformation(e.type,t.type);return o?o(e,t):function(e,t){for(const{match:o,fn:s}of ZP)if(o(e)){const o=s(e,t);if("SKIP_TRANSFORMATION"===o)continue;if("IGNORE_COMMAND"===o)return;e=o}return e}(e,t)}function YP(e,t){let o=[...e];for(const e of t)o=o.map((t=>jP(t,e))).filter(at);return o}function XP(e,t){if(!("sheetId"in t))return e;const o="DELETE_SHEET"===t.type&&t.sheetId;return e.sheetId===o?"IGNORE_COMMAND":"CREATE_SHEET"===e.type||"CREATE_SHEET"===t.type||e.sheetId!==t.sheetId?e:"SKIP_TRANSFORMATION"}class KP{rootCommand;timestamp;id;clientId;_commands=[];_changes=[];constructor(e,t,o,s,i,n){this.rootCommand=s,this.timestamp=n,this.id=e,this.clientId=t,this._commands=[...o],this._changes=i?[...i]:[]}setChanges(e){this._changes=e}get commands(){return this._commands}get changes(){return this._changes}}class JP extends Error{}class QP extends mc{revisions;transportService;serverRevisionId;clients={};clientId="local";debouncedMove;pendingMessages=[];waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new aa;lastLocalOperation;constructor(e,t,o=Se){super(),this.revisions=e,this.transportService=t,this.serverRevisionId=o,this.debouncedMove=ht(this._move.bind(this),200)}canApplyOptimisticUpdate(){return!this.waitingUndoRedoAck}save(e,t,o){if(!t.length||!o.length||!this.canApplyOptimisticUpdate())return;const s=new KP(this.uuidGenerator.uuidv4(),this.clientId,t,e,o,Date.now());this.revisions.append(s.id,s),"REQUEST_REDO"!==e.type&&(this.lastLocalOperation=s),this.trigger("new-local-state-update",{id:s.id}),this.sendUpdateMessage({type:"REMOTE_REVISION",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:s.id,clientId:s.clientId,commands:s.commands})}undo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_UNDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),undoneRevisionId:e})}redo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_REDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),redoneRevisionId:e})}move(e){this.debouncedMove(e)}join(e){e?(this.clients[e.id]=e,this.clientId=e.id):(this.clients.local={id:"local",name:"local"},this.clientId="local"),this.transportService.onNewMessage(this.clientId,this.onMessageReceived.bind(this))}loadInitialMessages(e){const t=performance.now(),o=e.reduce(((e,t)=>e+("REMOTE_REVISION"===t.type?t.commands.length:1)),0);this.isReplayingInitialRevisions=!0;for(const t of e)this.onMessageReceived(t);this.isReplayingInitialRevisions=!1,console.debug("Replayed",o,"commands in",performance.now()-t,"ms")}async leave(e){e&&1===Object.keys(this.clients).length&&this.lastRevisionMessage&&"SNAPSHOT_CREATED"!==this.lastRevisionMessage?.type&&await this.snapshot(e()),delete this.clients[this.clientId],this.transportService.leave(this.clientId),this.transportService.sendMessage({type:"CLIENT_LEFT",clientId:this.clientId,version:1})}async snapshot(e){if(0!==this.pendingMessages.length)return;const t=this.uuidGenerator.uuidv4();await this.transportService.sendMessage({type:"SNAPSHOT",nextRevisionId:t,serverRevisionId:this.serverRevisionId,data:{...e,revisionId:t},version:1})}getClient(){const e=this.clients[this.clientId];if(!e)throw new JP("The client left the session");return e}getConnectedClients(){return new Set(Object.values(this.clients).filter(at))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return 0===this.pendingMessages.length}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return;const t=this.clients[this.clientId]?.position;if(t?.col===e.col&&t.row===e.row&&t.sheetId===e.sheetId)return;const o=t?"CLIENT_MOVED":"CLIENT_JOINED",s=this.getClient();this.clients[this.clientId]={...s,position:e},this.transportService.sendMessage({type:o,version:1,client:{...s,position:e}})}onMessageReceived(e){if(!this.isAlreadyProcessed(e))if(this.isWrongServerRevisionId(e))this.trigger("unexpected-revision-id");else{switch(e.type){case"CLIENT_MOVED":this.onClientMoved(e);break;case"CLIENT_JOINED":this.onClientJoined(e);break;case"CLIENT_LEFT":this.onClientLeft(e);break;case"REVISION_REDONE":this.revisions.redo(e.redoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-redone",{revisionId:e.redoneRevisionId,commands:this.revisions.get(e.redoneRevisionId).commands});break;case"REVISION_UNDONE":this.revisions.undo(e.undoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-undone",{revisionId:e.undoneRevisionId,commands:this.revisions.get(e.undoneRevisionId).commands});break;case"REMOTE_REVISION":const{clientId:t,commands:o,timestamp:s}=e,i=new KP(e.nextRevisionId,t,o,void 0,void 0,s);if(i.clientId!==this.clientId){this.revisions.insert(i.id,i,e.serverRevisionId);const t=this.pendingMessages.filter((e=>"REMOTE_REVISION"===e.type)).map((e=>e.commands)).flat();this.trigger("remote-revision-received",{commands:YP(o,t)})}break;case"SNAPSHOT_CREATED":{const t=new KP(e.nextRevisionId,"server",[],void 0,void 0,Date.now());this.revisions.insert(t.id,t,e.serverRevisionId),this.dropPendingHistoryMessages(),this.trigger("snapshot"),this.lastLocalOperation=void 0;break}}this.acknowledge(e),this.trigger("collaborative-event-received")}}onClientMoved(e){e.client.id!==this.clientId&&(this.clients[e.client.id]=e.client)}onClientJoined(e){if(e.client.id!==this.clientId){this.clients[e.client.id]=e.client;const t=this.clients[this.clientId];if(t){const{position:e}=t;e&&this.transportService.sendMessage({type:"CLIENT_MOVED",version:1,client:{...t,position:e}})}}}onClientLeft(e){e.clientId!==this.clientId&&delete this.clients[e.clientId]}sendUpdateMessage(e){this.pendingMessages.push(e),this.waitingAck||this.sendPendingMessage()}sendPendingMessage(){let e=this.pendingMessages[0];if(e){if("REMOTE_REVISION"===e.type){const t=this.revisions.get(e.nextRevisionId);if(0===t.commands.length){this.revisions.drop(t.id);const e=this.pendingMessages.filter((e=>"REMOTE_REVISION"===e.type)).map((e=>e.nextRevisionId));return this.trigger("pending-revisions-dropped",{revisionIds:e}),this.waitingAck=!1,this.waitingUndoRedoAck=!1,void(this.pendingMessages=[])}e={...e,clientId:t.clientId,commands:t.commands}}if(this.isReplayingInitialRevisions)throw new Error(`Trying to send a new revision while replaying initial revision. This can lead to endless dispatches every time the spreadsheet is open.\n ${JSON.stringify(e)}`);this.waitingAck=!0,this.transportService.sendMessage({...e,serverRevisionId:this.serverRevisionId})}}acknowledge(e){switch("REVISION_UNDONE"!==e.type&&"REVISION_REDONE"!==e.type||(this.waitingUndoRedoAck=!1),e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId)),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.lastRevisionMessage=e,this.sendPendingMessage()}}isAlreadyProcessed(e){if("CLIENT_MOVED"===e.type&&e.client.id===this.clientId)return!0;switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return this.processedRevisions.has(e.nextRevisionId);default:return!1}}isWrongServerRevisionId(e){switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return e.serverRevisionId!==this.serverRevisionId;default:return!1}}dropPendingHistoryMessages(){this.waitingUndoRedoAck=!1,this.pendingMessages=this.pendingMessages.filter((({type:e})=>"REVISION_REDONE"!==e&&"REVISION_UNDONE"!==e))}}const eN=new Set(["HIDE_COLUMNS_ROWS","UNHIDE_COLUMNS_ROWS","UNFOLD_HEADER_GROUP","UNGROUP_HEADERS","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","FOLD_HEADER_GROUPS_IN_ZONE","UNFOLD_HEADER_GROUPS_IN_ZONE","CREATE_TABLE","UPDATE_TABLE","UPDATE_FILTER","REMOVE_TABLE","RESIZE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE"]);function tN(e){return eN.has(e.type)}const oN=[sN,function(e,t){return"target"in t&&Array.isArray(t.target)?{...Be(t),target:e.getSelectedZones()}:t},function(e,t){if(!("row"in t)||!("col"in t))return t;const{col:o,row:s}=e.getActivePosition();return{...Be(t),col:o,row:s}},function(e,t){return"ranges"in t?{...Be(t),ranges:e.getSelectedZones().map((t=>e.getRangeDataFromZone(e.getActiveSheetId(),t)))}:t}];function sN(e,t){return"sheetId"in t?{...Be(t),sheetId:e.getActiveSheetId()}:t}function iN(e,t){return"zone"in t?{...Be(t),zone:e.getSelectedZone()}:t}const nN=new aa;function rN(e,t){const o=e.getSelectedZone();return{...sN(e,t),elements:"COL"===t.dimension?Ze(o.left,o.right+1):Ze(o.top,o.bottom+1)}}function aN(e,t){const o=e.getSelectedZone();return{...Be(t),zone:o}}function lN(e,t){const o=Be(t),s=e.getSelectedZone(),{top:i,bottom:n,left:r,right:a}=s;return"cols"in o?o.cols=Ze(r,a+1):"rows"in o&&(o.rows=Ze(i,n+1)),o}function cN(e,t){const o=e.getSelectedZone();return{...sN(e,t),start:"COL"===t.dimension?o.left:o.top,end:"COL"===t.dimension?o.right:o.bottom}}const hN=new n;hN.add("UPDATE_CELL",uN),hN.add("CLEAR_CELL",uN),hN.add("CLEAR_CELLS",uN),hN.add("DELETE_CONTENT",uN),hN.add("ADD_MERGE",uN),hN.add("REMOVE_MERGE",uN),hN.add("SET_FORMATTING",uN),hN.add("CLEAR_FORMATTING",uN),hN.add("SET_BORDER",uN),hN.add("CREATE_TABLE",uN),hN.add("REMOVE_TABLE",uN),hN.add("HIDE_SHEET",uN),hN.add("ADD_COLUMNS_ROWS",(function(e,t){const o=e.getActivePosition();return{...sN(e,t),base:"COL"===t.dimension?o.col:o.row}})),hN.add("REMOVE_COLUMNS_ROWS",rN),hN.add("HIDE_COLUMNS_ROWS",rN),hN.add("RESIZE_COLUMNS_ROWS",rN),hN.add("CREATE_SHEET",(function(e,t){const o=Be(t);o.sheetId=nN.uuidv4();const s=t.name||e.getSheet(e.getActiveSheetId()).name,i=s.match(/(.+?)\d*$/)?.[1]||s;return o.name=e.getNextSheetName(i),o})),hN.add("CREATE_FIGURE",(function(e,t){const o=sN(e,t);return o.figure.id=nN.uuidv4(),o})),hN.add("CREATE_CHART",(function(e,t){return{...sN(e,t),id:nN.uuidv4()}})),hN.add("CREATE_IMAGE",(function(e,t){return{...sN(e,t),figureId:nN.uuidv4()}})),hN.add("GROUP_HEADERS",cN),hN.add("UNGROUP_HEADERS",cN),hN.add("UNGROUP_HEADERS",cN),hN.add("UNFOLD_HEADER_GROUPS_IN_ZONE",iN),hN.add("FOLD_HEADER_GROUPS_IN_ZONE",iN);const dN=new n;function uN(e,t){let o=Be(t);for(const t of oN)o=t(e,o);return o}function gN(e,t){if(e.rootCommand&&"object"==typeof e.rootCommand)return pi(e.rootCommand)?function(e,t){if(!t)return;if(!hN.contains(t.type))return;return hN.get(t.type)(e,t)}(t,e.rootCommand):function(e,t,o){if(!dN.contains(t.type))return;return dN.get(t.type)(e,t,o)}(t,e.rootCommand,e.commands)}dN.add("PASTE",(function(e,t){return{type:"REPEAT_PASTE",pasteOption:Be(t.pasteOption),target:e.getSelectedZones()}})),dN.add("INSERT_CELL",aN),dN.add("DELETE_CELL",aN),dN.add("AUTORESIZE_COLUMNS",lN),dN.add("AUTORESIZE_ROWS",lN),dN.add("SORT_CELLS",(function(e,t){const o=e.getSelectedZone();return{...sN(e,t),col:o.left,row:o.top,zone:o}})),dN.add("SUM_SELECTION",uN),dN.add("SET_DECIMAL",uN);class pN{getters;sheetId;boundaries;top;bottom;left;right;offsetX;offsetY;offsetScrollbarX;offsetScrollbarY;canScrollVertically;canScrollHorizontally;viewportWidth;viewportHeight;offsetCorrectionX;offsetCorrectionY;constructor(e,t,o,s,i,n){this.getters=e,this.sheetId=t,this.boundaries=o,this.viewportWidth=s.width,this.viewportHeight=s.height,this.offsetScrollbarX=n.x,this.offsetScrollbarY=n.y,this.canScrollVertically=i.canScrollVertically,this.canScrollHorizontally=i.canScrollHorizontally,this.offsetCorrectionX=this.getters.getColDimensions(this.sheetId,this.boundaries.left).start,this.offsetCorrectionY=this.getters.getRowDimensions(this.sheetId,this.boundaries.top).start,this.adjustViewportOffsetX(),this.adjustViewportOffsetY()}getMaxSize(){const e=this.getters.findLastVisibleColRowIndex(this.sheetId,"COL",{first:this.boundaries.left,last:this.boundaries.right}),t=this.getters.findLastVisibleColRowIndex(this.sheetId,"ROW",{first:this.boundaries.top,last:this.boundaries.bottom}),{end:o,size:s}=this.getters.getColDimensions(this.sheetId,e),{end:i,size:n}=this.getters.getRowDimensions(this.sheetId,t),r=this.searchHeaderIndex("COL",o-this.viewportWidth,0),a=this.getters.getColSize(this.sheetId,r),l=this.searchHeaderIndex("ROW",i-this.viewportHeight,0),c=this.getters.getRowSize(this.sheetId,l);let h=o-this.offsetCorrectionX;this.canScrollHorizontally&&(h+=Math.max(oe,Math.min(a,this.viewportWidth-s)),h=Math.max(h,this.viewportWidth));let d=i-this.offsetCorrectionY;return this.canScrollVertically&&(d+=Math.max(se+5,Math.min(c,this.viewportHeight-n)),d=Math.max(d,this.viewportHeight)),i+ce>d&&!this.getters.isReadonly()&&(d+=ce),{width:h,height:d}}getColIndex(e){return e<this.offsetCorrectionX||e>this.offsetCorrectionX+this.viewportWidth?-1:this.searchHeaderIndex("COL",e-this.offsetCorrectionX,this.left)}getRowIndex(e){return e<this.offsetCorrectionY||e>this.offsetCorrectionY+this.viewportHeight?-1:this.searchHeaderIndex("ROW",e-this.offsetCorrectionY,this.top)}adjustPosition(e){const t=this.sheetId,o=this.getters.getMainCellPosition({sheetId:t,...e}),{col:s,row:i}=this.getters.getNextVisibleCellPosition(o);as(s,this.boundaries.top,this.boundaries)&&this.adjustPositionX(s),as(this.boundaries.left,i,this.boundaries)&&this.adjustPositionY(i)}adjustPositionX(e){const t=this.sheetId,{end:o}=this.getters.getColDimensions(t,e);if(this.offsetX+this.offsetCorrectionX+this.viewportWidth<o){const o=this.getters.getNumberCols(t);let s=e;for(;this.getters.isColHidden(t,s)&&s<o;)s++;const i=this.getters.getColDimensions(t,s).end,n=this.searchHeaderIndex("COL",i-this.viewportWidth-this.offsetCorrectionX,this.boundaries.left);this.offsetScrollbarX=this.getters.getColDimensions(t,n).end-this.offsetCorrectionX}else if(this.left>e){let o=e;for(;this.getters.isColHidden(t,o)&&o>0;)o--;this.offsetScrollbarX=this.getters.getColDimensions(t,o).start-this.offsetCorrectionX}this.adjustViewportZoneX()}adjustPositionY(e){const t=this.sheetId,{end:o}=this.getters.getRowDimensions(t,e);if(this.offsetY+this.viewportHeight+this.offsetCorrectionY<o){const o=this.getters.getNumberRows(t);let s=e;for(;this.getters.isRowHidden(t,s)&&s<o;)s++;const i=this.getters.getRowDimensions(t,s).end,n=this.searchHeaderIndex("ROW",i-this.viewportHeight-this.offsetCorrectionY,this.boundaries.top);this.offsetScrollbarY=this.getters.getRowDimensions(t,n).end-this.offsetCorrectionY}else if(this.top>e){let o=e;for(;this.getters.isRowHidden(t,o)&&o>0;)o--;this.offsetScrollbarY=this.getters.getRowDimensions(t,o).start-this.offsetCorrectionY}this.adjustViewportZoneY()}willNewOffsetScrollViewport(e,t){return this.canScrollHorizontally&&this.offsetScrollbarX!==e||this.canScrollVertically&&this.offsetScrollbarY!==t}setViewportOffset(e,t){this.setViewportOffsetX(e),this.setViewportOffsetY(t)}adjustViewportZone(){this.adjustViewportZoneX(),this.adjustViewportZoneY()}getVisibleRect(e){const t=is(e,this);if(t){return{x:this.getters.getColRowOffset("COL",this.left,t.left)+this.offsetCorrectionX,y:this.getters.getColRowOffset("ROW",this.top,t.top)+this.offsetCorrectionY,width:Math.min(this.getters.getColRowOffset("COL",t.left,t.right+1),this.viewportWidth),height:Math.min(this.getters.getColRowOffset("ROW",t.top,t.bottom+1),this.viewportHeight)}}}getFullRect(e){if(is(e,this)){return{x:this.getters.getColRowOffset("COL",this.left,e.left)+this.offsetCorrectionX,y:this.getters.getColRowOffset("ROW",this.top,e.top)+this.offsetCorrectionY,width:this.getters.getColRowOffset("COL",e.left,e.right+1),height:this.getters.getColRowOffset("ROW",e.top,e.bottom+1)}}}isVisible(e,t){return t<=this.bottom&&t>=this.top&&e>=this.left&&e<=this.right&&!this.getters.isColHidden(this.sheetId,e)&&!this.getters.isRowHidden(this.sheetId,t)}searchHeaderIndex(e,t,o=0){const s=this.sheetId,i=this.getters.getNumberHeaders(s,e);let n=o,r=i;for(;n<=r&&n!==i&&-1!==r;){const i=Math.floor((n+r)/2),a=this.getters.getColRowOffset(e,o,i),l=this.getters.getHeaderSize(s,e,i);if(t>=a&&t<a+l)return i;t>=a+l?n=i+1:r=i-1}return-1}setViewportOffsetX(e){this.canScrollHorizontally&&(this.offsetScrollbarX=e,this.adjustViewportZoneX())}setViewportOffsetY(e){this.canScrollVertically&&(this.offsetScrollbarY=e,this.adjustViewportZoneY())}adjustViewportOffsetX(){if(this.canScrollHorizontally){const{width:e}=this.getMaxSize();this.viewportWidth+this.offsetScrollbarX>e&&(this.offsetScrollbarX=Math.max(0,e-this.viewportWidth))}this.adjustViewportZoneX()}adjustViewportOffsetY(){if(this.canScrollVertically){const{height:e}=this.getMaxSize();this.viewportHeight+this.offsetScrollbarY>e&&(this.offsetScrollbarY=Math.max(0,e-this.viewportHeight))}this.adjustViewportZoneY()}adjustViewportZoneX(){const e=this.sheetId;this.left=this.searchHeaderIndex("COL",this.offsetScrollbarX,this.boundaries.left),this.right=Math.min(this.boundaries.right,this.searchHeaderIndex("COL",this.viewportWidth,this.left)),-1===this.left&&(this.left=this.boundaries.left),-1===this.right&&(this.right=this.getters.getNumberCols(e)-1),this.offsetX=this.getters.getColDimensions(e,this.left).start-this.getters.getColDimensions(e,this.boundaries.left).start}adjustViewportZoneY(){const e=this.sheetId;this.top=this.searchHeaderIndex("ROW",this.offsetScrollbarY,this.boundaries.top),this.bottom=Math.min(this.boundaries.bottom,this.searchHeaderIndex("ROW",this.viewportHeight,this.top)),-1===this.top&&(this.top=this.boundaries.top),-1===this.bottom&&(this.bottom=this.getters.getNumberRows(e)-1),this.offsetY=this.getters.getRowDimensions(e,this.top).start-this.getters.getRowDimensions(e,this.boundaries.top).start}}const mN=(new n).add("settings",class extends zM{static getters=["getLocale"];locale=Si;allowDispatch(e){return"UPDATE_LOCALE"===e.type?_a(e.locale)?"Success":"InvalidLocale":"Success"}handle(e){if("UPDATE_LOCALE"===e.type){const t=this.locale,o=e.locale;this.history.update("locale",o),this.changeCellsDateFormatWithLocale(t,o)}}getLocale(){return this.locale}changeCellsDateFormatWithLocale(e,t){for(const o of this.getters.getSheetIds())for(const[s,i]of Object.entries(this.getters.getCells(o))){let o;if(i.format===e.dateFormat&&(o=t.dateFormat),i.format===e.timeFormat&&(o=t.timeFormat),i.format===za(e)&&(o=za(t)),o){const{col:e,row:t,sheetId:i}=this.getters.getCellPosition(s);this.dispatch("UPDATE_CELL",{col:e,row:t,sheetId:i,format:o})}}}import(e){this.locale=e.settings?.locale??Si}export(e){e.settings={locale:this.locale}}}).add("sheet",class extends zM{static getters=["getSheetName","tryGetSheetName","getSheet","tryGetSheet","getSheetIdByName","getSheetIds","getVisibleSheetIds","isSheetVisible","doesHeaderExist","doesHeadersExist","getCell","getCellPosition","getColsZone","getRowCells","getRowsZone","getNumberCols","getNumberRows","getNumberHeaders","getGridLinesVisibility","getNextSheetName","getSheetSize","getSheetZone","getPaneDivisions","checkZonesExistInSheet","getCommandZones","getUnboundedZone","checkElementsIncludeAllNonFrozenHeaders"];sheetIdsMapName={};orderedSheetIds=[];sheets={};cellPosition={};allowDispatch(e){const t=this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e);if("Success"!==t)return t;switch(e.type){case"HIDE_SHEET":return 1===this.getVisibleSheetIds().length?"NotEnoughSheets":"Success";case"CREATE_SHEET":return this.checkValidations(e,this.checkSheetName,this.checkSheetPosition);case"MOVE_SHEET":try{const t=this.orderedSheetIds.findIndex((t=>t===e.sheetId));return this.findIndexOfTargetSheet(t,e.delta),"Success"}catch(e){return"WrongSheetMove"}case"RENAME_SHEET":return this.isRenameAllowed(e);case"COLOR_SHEET":return!e.color||zt(e.color)?"Success":"InvalidColor";case"DELETE_SHEET":return this.orderedSheetIds.length>1?"Success":"NotEnoughSheets";case"ADD_COLUMNS_ROWS":return this.doesHeaderExist(e.sheetId,e.dimension,e.base)?e.quantity<=0?"InvalidQuantity":"Success":"InvalidHeaderIndex";case"REMOVE_COLUMNS_ROWS":{const t=Ot(e.elements),o=Dt(e.elements);return t<0||!this.doesHeaderExist(e.sheetId,e.dimension,o)?"InvalidHeaderIndex":this.checkElementsIncludeAllNonFrozenHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success"}case"FREEZE_ROWS":return this.checkValidations(e,this.checkRowFreezeQuantity,this.checkRowFreezeOverlapMerge);case"FREEZE_COLUMNS":return this.checkValidations(e,this.checkColFreezeQuantity,this.checkColFreezeOverlapMerge);default:return"Success"}}handle(e){switch(e.type){case"SET_GRID_LINES_VISIBILITY":this.setGridLinesVisibility(e.sheetId,e.areGridLinesVisible);break;case"CREATE_SHEET":const t=this.createSheet(e.sheetId,e.name||this.getNextSheetName(),e.cols||26,e.rows||100,e.position);this.history.update("sheetIdsMapName",t.name,t.id);break;case"MOVE_SHEET":this.moveSheet(e.sheetId,e.delta);break;case"RENAME_SHEET":this.renameSheet(this.sheets[e.sheetId],e.name);break;case"COLOR_SHEET":this.history.update("sheets",e.sheetId,"color",e.color);break;case"HIDE_SHEET":this.hideSheet(e.sheetId);break;case"SHOW_SHEET":this.showSheet(e.sheetId);break;case"DUPLICATE_SHEET":this.duplicateSheet(e.sheetId,e.sheetIdTo);break;case"DELETE_SHEET":this.deleteSheet(this.sheets[e.sheetId]);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.removeColumns(this.sheets[e.sheetId],[...e.elements]):this.removeRows(this.sheets[e.sheetId],[...e.elements]);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.addColumns(this.sheets[e.sheetId],e.base,e.position,e.quantity):this.addRows(this.sheets[e.sheetId],e.base,e.position,e.quantity);break;case"UPDATE_CELL_POSITION":this.updateCellPosition(e);break;case"FREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,e.quantity,"COL");break;case"FREEZE_ROWS":this.setPaneDivisions(e.sheetId,e.quantity,"ROW");break;case"UNFREEZE_ROWS":this.setPaneDivisions(e.sheetId,0,"ROW");break;case"UNFREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,0,"COL");break;case"UNFREEZE_COLUMNS_ROWS":this.setPaneDivisions(e.sheetId,0,"COL"),this.setPaneDivisions(e.sheetId,0,"ROW")}}import(e){for(let t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(let t of e.sheets){const e=t.name||"Sheet"+(Object.keys(this.sheets).length+1),{colNumber:o,rowNumber:s}=this.getImportedSheetSize(t),i={id:t.id,name:e,numberOfCols:o,rows:zr(s),areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,panes:{xSplit:t.panes?.xSplit||0,ySplit:t.panes?.ySplit||0},color:t.color};this.orderedSheetIds.push(i.id),this.sheets[i.id]=i}}exportSheets(e){e.sheets=this.orderedSheetIds.filter(at).map((e=>{const t=this.sheets[e],o={id:t.id,name:t.name,colNumber:t.numberOfCols,rowNumber:this.getters.getNumberRows(t.id),rows:{},cols:{},merges:[],cells:{},styles:{},formats:{},borders:{},conditionalFormats:[],dataValidationRules:[],figures:[],tables:[],areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,color:t.color};return(t.panes.xSplit||t.panes.ySplit)&&(o.panes=t.panes),o}))}export(e){this.exportSheets(e)}exportForExcel(e){this.exportSheets(e)}getGridLinesVisibility(e){return this.getSheet(e).areGridLinesVisible}tryGetSheet(e){return this.sheets[e]}getSheet(e){const t=this.sheets[e];if(!t)throw new Error(`Sheet ${e} not found.`);return t}isSheetVisible(e){return this.getSheet(e).isVisible}getSheetName(e){return this.getSheet(e).name}tryGetSheetName(e){return this.tryGetSheet(e)?.name}getSheetIdByName(e){if(e){const t=ze(e);for(const e in this.sheetIdsMapName)if(e.toUpperCase()===t.toUpperCase())return this.sheetIdsMapName[e]}}getSheetIds(){return this.orderedSheetIds}getVisibleSheetIds(){return this.orderedSheetIds.filter(this.isSheetVisible.bind(this))}doesHeaderExist(e,t,o){return"COL"===t?o>=0&&o<this.getNumberCols(e):o>=0&&o<this.getNumberRows(e)}doesHeadersExist(e,t,o){return o.every((o=>this.doesHeaderExist(e,t,o)))}getCell({sheetId:e,col:t,row:o}){const s=this.tryGetSheet(e),i=s?.rows[o]?.cells[t];if(void 0!==i)return this.getters.getCellById(i)}getColsZone(e,t,o){return{top:0,bottom:this.getNumberRows(e)-1,left:t,right:o}}getRowCells(e,t){return Object.values(this.getSheet(e).rows[t]?.cells).filter(at)}getRowsZone(e,t,o){return{top:t,bottom:o,left:0,right:this.getSheet(e).numberOfCols-1}}getCellPosition(e){const t=this.cellPosition[e];if(!t)throw new Error(`asking for a cell position that doesn't exist, cell id: ${e}`);return t}getNumberCols(e){return this.getSheet(e).numberOfCols}getNumberRows(e){return this.getSheet(e).rows.length}getNumberHeaders(e,t){return"COL"===t?this.getNumberCols(e):this.getNumberRows(e)}getNextSheetName(e="Sheet"){return Nt(e,this.orderedSheetIds.map(this.getSheetName.bind(this)),{compute:(e,t)=>`${e}${t}`,computeFirstOne:!0})}getSheetSize(e){return{numberOfRows:this.getNumberRows(e),numberOfCols:this.getNumberCols(e)}}getSheetZone(e){return{top:0,left:0,bottom:this.getNumberRows(e)-1,right:this.getNumberCols(e)-1}}getUnboundedZone(e,t){if(void 0===t.bottom||void 0===t.right)return t;const o=0===t.left&&t.right===this.getNumberCols(e)-1,s=0===t.top&&t.bottom===this.getNumberRows(e)-1;return{...t,bottom:s?void 0:t.bottom,right:o&&!s?void 0:t.right}}getPaneDivisions(e){return this.getSheet(e).panes}setPaneDivisions(e,t,o){const s={...this.getPaneDivisions(e)};"COL"===o?s.xSplit=t:"ROW"===o&&(s.ySplit=t),this.history.update("sheets",e,"panes",s)}checkElementsIncludeAllNonFrozenHeaders(e,t,o){const s=this.getters.getPaneDivisions(e),i="ROW"===t?s.ySplit:s.xSplit,n=this.getters.getNumberHeaders(e,t);if(!i)return!1;return vt(o,Ze(i,n))}getCommandZones(e){const t=[];return"zone"in e&&t.push(e.zone),"target"in e&&t.push(...e.target),"ranges"in e&&t.push(...e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone))),"col"in e&&"row"in e&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(Xo))return"InvalidRange";if(t.length){const o=this.getSheetZone(e);return t.every((e=>ls(e,o)))?"Success":"TargetOutOfSheet"}return"Success"}updateCellPosition(e){const{sheetId:t,cellId:o,col:s,row:i}=e;o?this.setNewPosition(o,t,s,i):this.clearPosition(t,s,i)}setNewPosition(e,t,o,s){const i=this.cellPosition[e];i&&this.clearPosition(t,i.col,i.row),this.history.update("cellPosition",e,{row:s,col:o,sheetId:t}),this.history.update("sheets",t,"rows",s,"cells",o,e)}clearPosition(e,t,o){const s=this.sheets[e]?.rows[o].cells[t];s&&(this.history.update("cellPosition",s,void 0),this.history.update("sheets",e,"rows",o,"cells",t,void 0))}setGridLinesVisibility(e,t){this.history.update("sheets",e,"areGridLinesVisible",t)}createSheet(e,t,o,s,i){const n={id:e,name:t,numberOfCols:o,rows:zr(s),areGridLinesVisible:!0,isVisible:!0,panes:{xSplit:0,ySplit:0}},r=this.orderedSheetIds.slice();r.splice(i,0,n.id);const a=this.sheets;return this.history.update("orderedSheetIds",r),this.history.update("sheets",Object.assign({},a,{[n.id]:n})),n}moveSheet(e,t){const o=this.orderedSheetIds.slice(),s=o.findIndex((t=>t===e)),i=o.splice(s,1);let n=this.findIndexOfTargetSheet(s,t);o.splice(n,0,i[0]),this.history.update("orderedSheetIds",o)}findIndexOfTargetSheet(e,t){for(;0!=t&&0<=e&&e<=this.orderedSheetIds.length;)t>0?(e++,this.isSheetVisible(this.orderedSheetIds[e])&&t--):t<0&&(e--,this.isSheetVisible(this.orderedSheetIds[e])&&t++);if(0===t)return e;throw new Error(Fo("There is not enough visible sheets"))}checkSheetName(e){const t=this.getters.tryGetSheetName(e.sheetId);if(void 0!==t&&e.name===t)return"UnchangedSheetName";const{orderedSheetIds:o,sheets:s}=this,i=e.name&&e.name.trim().toLowerCase();return o.find((t=>s[t]?.name.toLowerCase()===i&&t!==e.sheetId))?"DuplicatedSheetName":_e.test(i)?"ForbiddenCharactersInSheetName":"Success"}checkSheetPosition(e){const{orderedSheetIds:t}=this;return e.position>t.length||e.position<0?"WrongSheetPosition":"Success"}checkRowFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberRows(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkColFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberCols(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkRowFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(let o of t)if(o.top<e.quantity&&e.quantity<=o.bottom)return"MergeOverlap";return"Success"}checkColFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(let o of t)if(o.left<e.quantity&&e.quantity<=o.right)return"MergeOverlap";return"Success"}isRenameAllowed(e){return e.name&&e.name.trim().toLowerCase()?this.checkSheetName(e):"MissingSheetName"}renameSheet(e,t){const o=e.name;this.history.update("sheets",e.id,"name",t.trim());const s=Object.assign({},this.sheetIdsMapName);delete s[o],s[t]=e.id,this.history.update("sheetIdsMapName",s)}hideSheet(e){this.history.update("sheets",e,"isVisible",!1)}showSheet(e){this.history.update("sheets",e,"isVisible",!0)}duplicateSheet(e,t){const o=this.getSheet(e),s=this.getDuplicateSheetName(o.name),i=Be(o);i.id=t,i.name=s;for(let e=0;e<=i.numberOfCols;e++)for(let t=0;t<=i.rows.length;t++)i.rows[t]&&(i.rows[t].cells[e]=void 0);const n=this.orderedSheetIds.slice(),r=n.indexOf(e);n.splice(r+1,0,i.id),this.history.update("orderedSheetIds",n),this.history.update("sheets",Object.assign({},this.sheets,{[i.id]:i}));for(const t of Object.values(this.getters.getCells(e))){const{col:e,row:o}=this.getCellPosition(t.id);this.dispatch("UPDATE_CELL",{sheetId:i.id,col:e,row:o,content:t.content,format:t.format,style:t.style})}const a=Object.assign({},this.sheetIdsMapName);a[i.name]=i.id,this.history.update("sheetIdsMapName",a)}getDuplicateSheetName(e){const t=this.orderedSheetIds.map(this.getSheetName.bind(this));return Nt(Fo("Copy of %s",e).toString(),t)}deleteSheet(e){const t=e.name,o=Object.assign({},this.sheets);delete o[e.id],this.history.update("sheets",o);const s=this.orderedSheetIds.slice(),i=s.indexOf(e.id);s.splice(i,1),this.history.update("orderedSheetIds",s);const n=Object.assign({},this.sheetIdsMapName);delete n[t],this.history.update("sheetIdsMapName",n)}removeColumns(e,t){t.sort(((e,t)=>t-e));for(let o of t)this.moveCellOnColumnsDeletion(e,o);const o=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",o-t.length);const s=t.filter((t=>t<e.panes.xSplit)).length;s&&this.setPaneDivisions(e.id,e.panes.xSplit-s,"COL")}removeRows(e,t){t.sort(((e,t)=>t-e));for(let o of je(t)){const t=o[o.length-1],s=o[0];this.moveCellOnRowsDeletion(e,t,s),this.updateRowsStructureOnDeletion(e,t,s)}const o=t.filter((t=>t<e.panes.ySplit)).length;o&&this.setPaneDivisions(e.id,e.panes.ySplit-o,"ROW")}addColumns(e,t,o,s){const i="before"===o?t:t+1;this.moveCellsOnAddition(e,i,s,"columns");const n=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",n+s),i<e.panes.xSplit&&this.setPaneDivisions(e.id,e.panes.xSplit+s,"COL")}addRows(e,t,o,s){const i="before"===o?t:t+1;this.addEmptyRows(e,s),this.moveCellsOnAddition(e,i,s,"rows"),i<e.panes.ySplit&&this.setPaneDivisions(e.id,e.panes.ySplit+s,"ROW")}moveCellOnColumnsDeletion(e,t){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:t,top:0,right:t,bottom:e.rows.length-1}]});for(let o=0;o<e.rows.length;o++){const s=e.rows[o];for(let i in s.cells){const n=Number(i),r=s.cells[i];r&&n>t&&this.setNewPosition(r,e.id,n-1,o)}}}moveCellsOnAddition(e,t,o,s){const i=[];for(let n=0;n<e.rows.length;n++){const r=e.rows[n];if("rows"!==s||n>=t)for(let a in r.cells){const l=Number(a),c=r.cells[a];c&&("rows"===s||l>=t)&&i.push({sheetId:e.id,cellId:c,col:l+("columns"===s?o:0),row:n+("rows"===s?o:0),type:"UPDATE_CELL_POSITION"})}}for(let e of i.reverse())this.updateCellPosition(e)}moveCellOnRowsDeletion(e,t,o){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:0,top:t,right:this.getters.getNumberCols(e.id),bottom:o}]});const s=o-t+1;for(let t=0;t<e.rows.length;t++){const i=e.rows[t];if(t>o)for(let o in i.cells){const n=Number(o),r=i.cells[o];r&&this.setNewPosition(r,e.id,n,t-s)}}}updateRowsStructureOnDeletion(e,t,o){const s=[],i=e.rows.map((e=>e.cells)).reverse();for(let n in e.rows){const e=Number(n);e>=t&&e<=o||s.push({cells:i.pop()})}this.history.update("sheets",e.id,"rows",s)}addEmptyRows(e,t){const o=e.rows.slice();for(let e=0;e<t;e++)o.push({cells:{}});this.history.update("sheets",e.id,"rows",o)}getImportedSheetSize(e){const t=Object.keys(e.cells).map(So);let o=e.rowNumber,s=e.colNumber;for(let{col:e,row:i}of t)o=Math.max(o,i+1),s=Math.max(s,e+1);return{rowNumber:o,colNumber:s}}checkSheetExists(e){return"CREATE_SHEET"!==e.type&&"sheetId"in e&&void 0===this.sheets[e.sheetId]?"InvalidSheetId":"CREATE_SHEET"===e.type&&void 0!==this.sheets[e.sheetId]?"DuplicatedSheetId":"Success"}checkZonesAreInSheet(e){return"sheetId"in e?this.checkZonesExistInSheet(e.sheetId,this.getCommandZones(e)):"Success"}}).add("header grouping",class extends zM{static getters=["getHeaderGroups","getGroupsLayers","getVisibleGroupLayers","getHeaderGroup","getHeaderGroupsInZone","isGroupFolded","isRowFolded","isColFolded"];groups={};allowDispatch(e){switch(e.type){case"GROUP_HEADERS":{const{start:t,end:o}=e;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";if(this.findGroupWithStartEnd(e.sheetId,e.dimension,t,o))return"HeaderGroupAlreadyExists";break}case"UNGROUP_HEADERS":{const{start:t,end:o}=e;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";break}case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUP":const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return"UnknownHeaderGroup";if(Ze(0,this.getters.getNumberHeaders(e.sheetId,e.dimension)).every((o=>o>=t.start&&o<=t.end||this.getters.isHeaderHiddenByUser(e.sheetId,e.dimension,o))))return"NotEnoughElements"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("groups",e.sheetId,{ROW:[],COL:[]});break;case"GROUP_HEADERS":this.groupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"UNGROUP_HEADERS":this.unGroupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"DUPLICATE_SHEET":{const t=Be(this.groups[e.sheetId]);this.history.update("groups",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.groups};delete t[e.sheetId],this.history.update("groups",t);break}case"ADD_COLUMNS_ROWS":const t=pt(e.position,e.base);this.moveGroupsOnHeaderInsertion(e.sheetId,e.dimension,t,e.quantity);break;case"REMOVE_COLUMNS_ROWS":this.moveGroupsOnHeaderDeletion(e.sheetId,e.dimension,e.elements);break;case"UNFOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.unfoldHeaderGroup(e.sheetId,e.dimension,t);break}case"FOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.foldHeaderGroup(e.sheetId,e.dimension,t);break}case"UNFOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.unfoldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.foldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":{const t="UNFOLD_HEADER_GROUPS_IN_ZONE"===e.type?"unfold":"fold",o=this.getGroupsLayers(e.sheetId,e.dimension);"fold"===t&&o.reverse();const s=o.flat(),i="ROW"===e.dimension?e.zone.top:e.zone.left,n="ROW"===e.dimension?e.zone.bottom:e.zone.right,r=new Set;for(let e=i;e<=n;e++){const o=s.filter((t=>t.start-1<=e&&e<=t.end));for(const e of o)if(!("fold"===t&&e.isFolded||"unfold"===t&&!e.isFolded)){r.add(e);break}}for(const o of r)"unfold"===t?this.unfoldHeaderGroup(e.sheetId,e.dimension,o):this.foldHeaderGroup(e.sheetId,e.dimension,o);break}}}getHeaderGroups(e,t){return this.groups[e][t]}getHeaderGroup(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}getHeaderGroupsInZone(e,t,o){return this.getHeaderGroups(e,t).filter((e=>{const s="ROW"===t?o.top:o.left,i="ROW"===t?o.bottom:o.right;return this.doGroupOverlap(e,s,i)}))}getGroupsLayers(e,t){const o=this.getHeaderGroups(e,t);return this.bricksFallingAlgorithm(o,0,0)}getVisibleGroupLayers(e,t){const o=this.getGroupsLayers(e,t);for(const s of o)for(let o=s.length-1;o>=0;o--){const i=s[o];if(0===i.start)continue;Ze(i.start-1,i.end+1).every((o=>this.getters.isHeaderHiddenByUser(e,t,o)))&&s.splice(o,1)}return o.filter((e=>e.length>0))}isGroupFolded(e,t,o,s){return this.getHeaderGroup(e,t,o,s)?.isFolded||!1}isRowFolded(e,t){return this.getters.getHeaderGroups(e,"ROW").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}isColFolded(e,t){return this.getters.getHeaderGroups(e,"COL").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}getGroupId(e){return`${e.start}-${e.end}}`}bricksFallingAlgorithm(e,t,o,s=0){const i={};for(const t of e)i[this.getGroupId(t)]=t.isFolded;const n={};for(const t of e)for(let e=t.start;e<=t.end;e++)n[e]=n[e]?n[e]+1:1;for(let e=t;e<=o;e++)n[e]=n[e]?n[e]+s:s;const r=Math.max(...Object.values(n),0),a=Array.from({length:r},(()=>[])),l=Math.max(o,...e.map((e=>e.end)));for(let o=Math.min(t,...e.map((e=>e.start)));o<=l;o++){const e=n[o]||0;for(let t=0;t<e;t++){const e=a[t].at(-1);if(e&&xt([e.end,o]))e.end++;else{const e={start:o,end:o};a[t].push(e)}}}for(const e of a)for(const t of e)t.isFolded=i[this.getGroupId(t)];return a}groupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}unGroupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,-1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}moveGroupsOnHeaderInsertion(e,t,o,s){const i=this.groups[e][t];for(let n=0;n<i.length;n++){const r=i[n],[a,l]=$r(o,s,[r.start,r.end]);a===r.start&&l===r.end||this.history.update("groups",e,t,n,{...r,start:a,end:l})}}moveGroupsOnHeaderDeletion(e,t,o){const s=this.getHeaderGroups(e,t),i=[];for(const e of s){const t=Wr(o,Ze(e.start,e.end+1));0!==t.length&&i.push({...e,start:Math.min(...t),end:Math.max(...t)})}this.history.update("groups",e,t,this.bricksFallingAlgorithm(i,0,0).flat())}doGroupOverlap(e,t,o){return e.start<=o&&e.end>=t}removeDuplicateGroups(e){const t={};for(const o of e)t[this.getGroupId(o)]=o;return Object.values(t)}findGroupWithStartEnd(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}foldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!0);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end<=o.end&&this.history.update("groups",e,t,s,"isFolded",!0)}}unfoldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!1);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end>=o.end&&this.history.update("groups",e,t,s,"isFolded",!1)}}getGroupIndex(e,t,o,s){const i=this.groups[e][t].findIndex((e=>e.start===o&&e.end===s));return-1===i?void 0:i}import(e){for(const t of e.sheets)if(this.groups[t.id]={ROW:[],COL:[]},t.headerGroups)for(const e of["ROW","COL"])for(const o of t.headerGroups[e]||[])this.groups[t.id][e].push({...o})}export(e){for(const t of e.sheets)t.headerGroups=this.groups[t.id]}exportForExcel(e){for(const t of e.sheets)for(const e of["ROW","COL"]){const o=this.getGroupsLayers(t.id,e);for(let s=0;s<o.length;s++){const i=o[s];for(const o of i){for(let i=o.start;i<=o.end;i++){const n=Qy(t,e,i);n.outlineLevel=s+1,o.isFolded&&(n.isHidden=!0)}if(o.isFolded){Qy(t,e,o.end+1).collapsed=!0}}}}}}).add("header visibility",class extends zM{static getters=["checkElementsIncludeAllVisibleHeaders","getHiddenColsGroups","getHiddenRowsGroups","isHeaderHiddenByUser","isRowHiddenByUser","isColHiddenByUser"];hiddenHeaders={};allowDispatch(e){switch(e.type){case"HIDE_COLUMNS_ROWS":{if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t="COL"===e.dimension?this.getHiddenColsGroups(e.sheetId):this.getHiddenRowsGroups(e.sheetId),o="COL"===e.dimension?this.getters.getNumberCols(e.sheetId):this.getters.getNumberRows(e.sheetId);return new Set((t||[]).flat().concat(e.elements)).size>=o?"TooManyHiddenElements":Ot(e.elements)<0||Dt(e.elements)>o?"InvalidHeaderIndex":"Success"}case"REMOVE_COLUMNS_ROWS":return this.getters.tryGetSheet(e.sheetId)?this.checkElementsIncludeAllVisibleHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success":"InvalidSheetId"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":const t={COL:Array(this.getters.getNumberCols(e.sheetId)).fill(!1),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(!1)};this.history.update("hiddenHeaders",e.sheetId,t);break;case"DUPLICATE_SHEET":this.history.update("hiddenHeaders",e.sheetIdTo,Be(this.hiddenHeaders[e.sheetId]));break;case"DELETE_SHEET":this.history.update("hiddenHeaders",e.sheetId,void 0);break;case"REMOVE_COLUMNS_ROWS":{const t=[...this.hiddenHeaders[e.sheetId][e.dimension]];for(let o of[...e.elements].sort(((e,t)=>t-e)))t.splice(o,1);this.history.update("hiddenHeaders",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=[...this.hiddenHeaders[e.sheetId][e.dimension]],o=pt(e.position,e.base);t.splice(o,0,...Array(e.quantity).fill(!1)),this.history.update("hiddenHeaders",e.sheetId,e.dimension,t);break}case"HIDE_COLUMNS_ROWS":for(let t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!0);break;case"UNHIDE_COLUMNS_ROWS":for(let t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!1)}}checkElementsIncludeAllVisibleHeaders(e,t,o){return vt(o,this.getAllVisibleHeaders(e,t))}isHeaderHiddenByUser(e,t,o){return"COL"===t?this.isColHiddenByUser(e,o):this.isRowHiddenByUser(e,o)}isRowHiddenByUser(e,t){return this.hiddenHeaders[e].ROW[t]||this.getters.isRowFolded(e,t)}isColHiddenByUser(e,t){return this.hiddenHeaders[e].COL[t]||this.getters.isColFolded(e,t)}getHiddenColsGroups(e){const t=[[]],o=this.hiddenHeaders[e].COL;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getHiddenRowsGroups(e){const t=[[]],o=this.hiddenHeaders[e].ROW;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getAllVisibleHeaders(e,t){const o=Ze(0,this.getters.getNumberHeaders(e,t)),s=[];return this.getters.getHeaderGroups(e,t).forEach((e=>{e.isFolded&&s.push(...Ze(e.start,e.end+1))})),o.filter((o=>!this.hiddenHeaders[e][t][o]&&!s.includes(o)))}import(e){for(let t of e.sheets){this.hiddenHeaders[t.id]={COL:[],ROW:[]};for(let e=0;e<t.rowNumber;e++)this.hiddenHeaders[t.id].ROW[e]=Boolean(t.rows[e]?.isHidden);for(let e=0;e<t.colNumber;e++)this.hiddenHeaders[t.id].COL[e]=Boolean(t.cols[e]?.isHidden)}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let o of e.sheets){void 0===o.rows&&(o.rows={});for(let e=0;e<this.getters.getNumberRows(o.id);e++)(t||this.hiddenHeaders[o.id].ROW[e])&&(void 0===o.rows[e]&&(o.rows[e]={}),o.rows[e].isHidden||=this.hiddenHeaders[o.id].ROW[e]);void 0===o.cols&&(o.cols={});for(let e=0;e<this.getters.getNumberCols(o.id);e++)(t||this.hiddenHeaders[o.id].COL[e])&&(void 0===o.cols[e]&&(o.cols[e]={}),o.cols[e].isHidden||=this.hiddenHeaders[o.id].COL[e])}}}).add("tables",class extends zM{static getters=["getCoreTable","getCoreTables","getCoreTableMatchingTopLeft"];tables={};adaptRanges(e,t){const o=t?[t]:this.getters.getSheetIds();for(const t of o)for(const o of this.getCoreTables(t))this.applyRangeChangeOnTable(t,o,e)}allowDispatch(e){switch(e.type){case"CREATE_TABLE":const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone));return ys(t)?this.checkValidations(e,(e=>this.getTablesOverlappingZones(e.sheetId,t).length?"TableOverlap":"Success"),(e=>this.checkTableConfigUpdateIsValid(e.config))):"NonContinuousTargets";case"UPDATE_TABLE":return this.getCoreTableMatchingTopLeft(e.sheetId,e.zone)?this.checkValidations(e,this.checkUpdatedTableZoneIsValid,(e=>this.checkTableConfigUpdateIsValid(e.config))):"TableNotFound";case"ADD_MERGE":for(const t of this.getCoreTables(e.sheetId)){const o=t.range.zone;for(const t of e.target)if(rs(o,t))return"MergeInTable"}}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("tables",e.sheetId,{});break;case"DELETE_SHEET":{const t={...this.tables};delete t[e.sheetId],this.history.update("tables",t);break}case"DUPLICATE_SHEET":{const t={};for(const o of this.getCoreTables(e.sheetId))t[o.id]="dynamic"===o.type?this.copyDynamicTableForSheet(e.sheetIdTo,o):this.copyStaticTableForSheet(e.sheetIdTo,o);this.history.update("tables",e.sheetIdTo,t);break}case"CREATE_TABLE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=this.getters.getRangesUnion(t),s=this.getters.getMergesInZone(e.sheetId,o.zone);this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:s});const i=""+YM++,n=e.config||QC,r="dynamic"===e.tableType?this.createDynamicTable(i,o,n):this.createStaticTable(i,e.tableType,o,n);this.history.update("tables",e.sheetId,r.id,r);break}case"REMOVE_TABLE":{const t={};for(const o of this.getCoreTables(e.sheetId))e.target.every((e=>!is(o.range.zone,e)))&&(t[o.id]=o);this.history.update("tables",e.sheetId,t);break}case"UPDATE_TABLE":this.updateTable(e);break;case"UPDATE_CELL":{const t=e.sheetId;for(const o of this.getCoreTables(t)){if("dynamic"===o.type)continue;const s=this.canUpdateCellCmdExtendTable(e,o);"down"===s?this.extendTableDown(t,o):"right"===s&&this.extendTableRight(t,o)}break}case"DELETE_CONTENT":{const t={...this.tables[e.sheetId]};for(const o in t){const s=t[o];s&&e.target.some((e=>ls(s.range.zone,e)))&&this.dispatch("REMOVE_TABLE",{sheetId:e.sheetId,target:[s.range.zone]})}break}}}getCoreTables(e){return this.tables[e]?Object.values(this.tables[e]).filter(at):[]}getCoreTable({sheetId:e,col:t,row:o}){return this.getCoreTables(e).find((e=>as(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter((e=>t.some((t=>rs(e.range.zone,t)))))}extendTableDown(e,t){const o=this.getters.extendRange(t.range,"ROW",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}extendTableRight(e,t){const o=this.getters.extendRange(t.range,"COL",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}canUpdateCellCmdExtendTable({content:e,sheetId:t,col:o,row:s},i){if(!e)return"none";const n=i.range.zone;let r="none";if(n.bottom+1===s&&o>=n.left&&o<=n.right?r="down":n.right+1===o&&s>=n.top&&s<=n.bottom&&(r="right"),"none"===r)return"none";const a="down"===r?{...n,bottom:n.bottom+1,top:n.bottom+1}:{...n,right:n.right+1,left:n.right+1};for(const e of us(a)){const o={sheetId:t,...e},s=this.getters.getCell(o)?.content;if(s||this.getters.isInMerge(o)||this.getTablesOverlappingZones(t,[fs(e)]).length)return"none"}return r}getCoreTableMatchingTopLeft(e,t){for(const o of this.getCoreTables(e)){const e=o.range.zone;if(e.left===t.left&&e.top===t.top)return o}}checkUpdatedTableZoneIsValid(e){if(!e.newTableRange)return"Success";const t=this.getters.getRangeFromRangeData(e.newTableRange).zone,o=this.getters.checkZonesExistInSheet(e.sheetId,[t]);if("Success"!==o)return o;const s=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!s)return"TableNotFound";return this.getTablesOverlappingZones(e.sheetId,[t]).filter((e=>e.id!==s.id)).length?"TableOverlap":"Success"}checkTableConfigUpdateIsValid(e){return e&&(void 0!==e.numberOfHeaders&&e.numberOfHeaders<0||e.hasFilters&&0===e.numberOfHeaders)?"InvalidTableConfig":"Success"}createStaticTable(e,t,o,s,i){const n=o.zone;if(!i){i=[];for(const e of Ze(n.left,n.right+1)){const t={...n,left:e,right:e},r=""+YM++;i.push(this.createFilterFromZone(r,o.sheetId,t,s))}}return{id:e,range:o,filters:i,config:s,type:t}}createDynamicTable(e,t,o){const s=vs(t.zone);return{id:e,range:this.getters.getRangeFromZone(t.sheetId,s),config:o,type:"dynamic"}}updateTable(e){const t=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return;const o=e.newTableRange?this.getters.getRangeFromRangeData(e.newTableRange):void 0;if(o){const t=this.getters.getMergesInZone(e.sheetId,o.zone);this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:t})}const s=o||t.range,i=this.updateTableConfig(e.config,t.config),n=e.tableType??t.type;if("dynamic"===n&&"dynamic"!==t.type||"dynamic"!==n&&"dynamic"===t.type){const o="dynamic"===n?this.createDynamicTable(t.id,s,i):this.createStaticTable(t.id,n,s,i);this.history.update("tables",e.sheetId,t.id,o)}else{const o="dynamic"===t.type?this.updateDynamicTable(t,s,i):this.updateStaticTable(t,s,i,n);this.history.update("tables",e.sheetId,t.id,o)}}updateStaticTable(e,t,o,s=e.type){if("dynamic"===s)throw new Error("Cannot use updateStaticTable to update a dynamic table");const i=t||e.range,n=i.zone,r=this.updateTableConfig(o,e.config),a=r||e.config,l=[];if(t||r&&"numberOfHeaders"in r)for(const t of Ze(n.left,n.right+1)){const o=n.top===e.range.zone.top?e.filters.find((e=>e.col===t)):void 0,s={...n,left:t,right:t},r=o?.id||""+YM++;l.push(this.createFilterFromZone(r,i.sheetId,s,a))}return{...e,range:i,config:a,filters:l.length?l:e.filters,type:s}}updateDynamicTable(e,t,o){const s=t?this.getters.getRangeFromZone(t.sheetId,vs(t.zone)):e.range,i=o||e.config;return{...e,range:s,config:i}}updateTableConfig(e,t){if(!e)return t;const o={...t,...e};return 0===e.numberOfHeaders?o.hasFilters=!1:!0===e.hasFilters&&(o.numberOfHeaders||=1),o}createFilterFromZone(e,t,o,s){return EF(e,this.getters.getRangeFromZone(t,o),s,this.getters.getRangeFromZone)}copyStaticTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone),s=t.filters.map((o=>{const s=this.getters.getRangeFromZone(e,o.rangeWithHeaders.zone);return EF(o.id,s,t.config,this.getters.getRangeFromZone)}));return{id:t.id,range:o,filters:s,config:Be(t.config),type:t.type}}copyDynamicTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:o,config:Be(t.config),type:"dynamic"}}applyRangeChangeOnTable(e,t,o){const s=o(t.range);let i;switch(s.changeType){case"REMOVE":return void this.history.update("tables",e,t.id,void 0);case"NONE":return;default:i=s.range}if("dynamic"===t.type){const o=this.updateDynamicTable(t,i);return void this.history.update("tables",e,t.id,o)}const n=[];for(const e of t.filters){const s=o(e.rangeWithHeaders);switch(s.changeType){case"REMOVE":continue;case"NONE":n.push(e);break;default:const o=s.range,i=EF(e.id,o,t.config,this.getters.getRangeFromZone);n.push(i)}}const r=i.zone;if(n.length<cs(r).numberOfCols){for(let o=r.left;o<=r.right;o++)if(!n.find((e=>e.col===o))){const s=""+YM++,i={...r,left:o,right:o};n.push(this.createFilterFromZone(s,e,i,t.config))}n.sort(((e,t)=>e.col-t.col))}const a=this.createStaticTable(t.id,t.type,i,t.config,n);this.history.update("tables",e,t.id,a)}import(e){for(const t of e.sheets)for(const e of t.tables||[]){const o=""+YM++,s=e.config||QC,i=this.getters.getRangeFromSheetXC(t.id,e.range),n=e.type||"static",r="dynamic"===n?this.createDynamicTable(o,i,s):this.createStaticTable(o,n,i,s);this.history.update("tables",t.id,r.id,r)}}export(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o={range:Jo(e.range.zone),type:e.type};mt(e.config,QC)||(o.config=e.config),t.tables.push(o)}}exportForExcel(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o=Jo(e.range.zone);t.tables.push({range:o,filters:[],config:e.config})}}}).add("dataValidation",class extends zM{static getters=["cellHasListDataValidationIcon","getDataValidationRule","getDataValidationRules","getValidationRuleForCell"];rules={};adaptRanges(e,t){const o=t?[t]:Object.keys(this.rules);for(const t of o)this.loopThroughRangesOfSheet(t,e)}loopThroughRangesOfSheet(e,t){for(let o=this.rules[e].length-1;o>=0;o--){const s=this.rules[e][o];for(let i=s.ranges.length-1;i>=0;i--){const n=t(s.ranges[i]);switch(n.changeType){case"REMOVE":if(1===s.ranges.length)this.removeDataValidationRule(e,s.id);else{const t=s.ranges.slice();t.splice(i,1),this.history.update("rules",e,o,"ranges",t)}break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("rules",e,o,"ranges",i,n.range)}}}}allowDispatch(e){switch(e.type){case"ADD_DATA_VALIDATION_RULE":return this.checkValidations(e,this.chainValidations(this.checkEmptyRange,this.checkValidRange,this.checkCriterionTypeIsValid,this.checkCriterionHasValidNumberOfValues,this.checkCriterionValuesAreValid));case"REMOVE_DATA_VALIDATION_RULE":if(!this.rules[e.sheetId].find((t=>t.id===e.id)))return"UnknownDataValidationRule"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("rules",e.sheetId,[]);break;case"DUPLICATE_SHEET":{const t=Be(this.rules[e.sheetId]).map((t=>({...t,ranges:t.ranges.map((t=>Lr(e.sheetId,e.sheetIdTo,t)))})));this.history.update("rules",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.rules};delete t[e.sheetId],this.history.update("rules",t);break}case"REMOVE_DATA_VALIDATION_RULE":this.removeDataValidationRule(e.sheetId,e.id);break;case"ADD_DATA_VALIDATION_RULE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));this.addDataValidationRule(e.sheetId,{...e.rule,ranges:t});break}case"DELETE_CONTENT":{const t=Co(e.target),o=e.sheetId;for(const e of t)for(let t=e.top;t<=e.bottom;t++)for(let s=e.left;s<=e.right;s++){const e=this.getValidationRuleForCell({sheetId:o,col:s,row:t});if(e&&("isBoolean"===e.criterion.type||"isValueInList"===e.criterion.type&&!this.getters.getCell({sheetId:o,col:s,row:t})?.content)){const e=this.rules[o],i=[this.getters.getRangeFromSheetXC(o,yo(s,t))],n=this.removeRangesFromRules(o,i,e);this.history.update("rules",o,n)}}}}}getDataValidationRules(e){return this.rules[e]}getDataValidationRule(e,t){return this.rules[e].find((e=>e.id===t))}getValidationRuleForCell({sheetId:e,col:t,row:o}){if(this.rules[e])for(const s of this.rules[e])for(const e of s.ranges)if(as(t,o,e.zone))return s}cellHasListDataValidationIcon(e){const t=this.getValidationRuleForCell(e);return!!t&&(("isValueInList"===t.criterion.type||"isValueInRange"===t.criterion.type)&&"arrow"===t.criterion.displayStyle)}addDataValidationRule(e,t){const o=this.rules[e];"isBoolean"===t.criterion.type?this.setCenterStyleToBooleanCells(t):"isValueInList"===t.criterion.type&&(t.criterion.values=Array.from(new Set(t.criterion.values)));const s=this.removeRangesFromRules(e,t.ranges,o),i=s.findIndex((e=>e.id===t.id));-1!==i?(s[i]=t,this.history.update("rules",e,s)):this.history.update("rules",e,[...s,t])}removeRangesFromRules(e,t,o){o=Be(o);for(const e of o)e.ranges=this.getters.recomputeRanges(e.ranges,t);return o.filter((e=>e.ranges.length>0))}removeDataValidationRule(e,t){const o=this.rules[e].filter((e=>e.id!==t));this.history.update("rules",e,o)}setCenterStyleToBooleanCells(e){for(const t of Ur(e.ranges)){const e=this.getters.getCell(t),o={...e?.style,align:e?.style?.align??"center",verticalAlign:e?.style?.verticalAlign??"middle"};this.dispatch("UPDATE_CELL",{...t,style:o})}}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}import(e){for(const t of e.sheets)if(this.rules[t.id]=[],t.dataValidationRules)for(const e of t.dataValidationRules)this.rules[t.id].push({...e,ranges:e.ranges.map((e=>this.getters.getRangeFromSheetXC(t.id,e)))})}export(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id])t.dataValidationRules.push({...e,ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id)))})}}exportForExcel(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id]){const o={...Be(e),ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id,{useBoundedReference:!0})))};"isValueInRange"===e.criterion.type&&(o.criterion.values=e.criterion.values.map((e=>{const o=this.getters.getRangeFromSheetXC(t.id,e);return this.getters.getRangeString(o,t.id,{useBoundedReference:!0,useFixedReference:!0})}))),t.dataValidationRules.push(o)}}}checkCriterionTypeIsValid(e){return gO.contains(e.rule.criterion.type)?"Success":"UnknownDataValidationCriterionType"}checkCriterionHasValidNumberOfValues(e){const t=e.rule.criterion,o=gO.get(t.type).numberOfValues(t);return void 0!==o&&t.values.length!==o?"InvalidNumberOfCriterionValues":"Success"}checkCriterionValuesAreValid(e){const t=e.rule.criterion,o=gO.get(t.type);return t.values.some((e=>"onlyFormulas"===o.allowedValues&&!e.startsWith("=")||(e.startsWith("=")?"onlyLiterals"===o.allowedValues||hS(e).isBadExpression:!o.isCriterionValueValid(e))))?"InvalidDataValidationCriterionValue":"Success"}checkValidRange(e){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=t.map((t=>this.getters.getRangeString(t,e.sheetId)));return o.some((e=>!this.getters.isRangeValid(e)))?"InvalidRange":"Success"}}).add("cell",class extends zM{static getters=["zoneToXC","getCells","getTranslatedCellFormula","getCellStyle","getCellById","getFormulaString","getFormulaMovedInSheet"];nextId=1;cells={};adaptRanges(e,t){for(const o of Object.keys(this.cells))for(const s of Object.values(this.cells[o]||{}))if(s.isFormula)for(const i of s.compiledFormula.dependencies)if(!t||i.sheetId===t){const t=e(i);"NONE"!==t.changeType&&this.history.update("cells",o,s.id,"compiledFormula","dependencies",s.compiledFormula.dependencies.indexOf(i),t.range)}}allowDispatch(e){switch(e.type){case"UPDATE_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessUpdateCell);case"CLEAR_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessClearCell);default:return"Success"}}handle(e){switch(e.type){case"SET_FORMATTING":"style"in e&&this.setStyle(e.sheetId,e.target,e.style),"format"in e&&void 0!==e.format&&this.setFormatter(e.sheetId,e.target,e.format);break;case"CLEAR_FORMATTING":this.clearFormatting(e.sheetId,e.target);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.handleAddColumnsRows(e,this.copyColumnStyle.bind(this)):this.handleAddColumnsRows(e,this.copyRowStyle.bind(this));break;case"UPDATE_CELL":this.updateCell(e.sheetId,e.col,e.row,e);break;case"CLEAR_CELL":this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col,row:e.row,content:"",style:null,format:""});break;case"CLEAR_CELLS":this.clearCells(e.sheetId,e.target);break;case"DELETE_CONTENT":this.clearZones(e.sheetId,e.target)}}clearZones(e,t){for(let o of Co(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++){const o=this.getters.getCell({sheetId:e,col:t,row:s});(o?.isFormula||o?.content)&&this.dispatch("UPDATE_CELL",{sheetId:e,content:"",col:t,row:s})}}setFormatter(e,t,o){for(let s of Co(t))for(let t=s.top;t<=s.bottom;t++)for(let i=s.left;i<=s.right;i++)this.dispatch("UPDATE_CELL",{sheetId:e,col:i,row:t,format:o})}clearFormatting(e,t){for(let o of Co(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,style:null,format:""})}clearCells(e,t){for(const o of t)for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:"",style:null,format:""})}handleAddColumnsRows(e,t){let o,s;"before"===e.position?(o=Ze(e.base,e.base+e.quantity),s=e.base+e.quantity):(o=Ze(e.base+1,e.base+e.quantity+1),s=e.base),t(e.sheetId,s,o)}import(e){for(let t of e.sheets){const o=t.id,s=new c_;for(const e in t.cells)if(t.cells[e]){const{col:o,row:i}=So(e),n={sheetId:t.id,col:o,row:i};s.set(n,{content:t.cells[e]})}for(const[e,o]of[["style",t.styles],["format",t.formats]])for(const[i,n]of Es(t.id,o)){const t=s.get(i);t?t[e]=n:s.set(i,{[e]:n})}for(const i of s.keysForSheet(o)){const o=s.get(i);if(o?.content||o?.format||o?.style){const s=this.importCell(t.id,o?.content,o?.style?e.styles[o?.style]:void 0,o?.format?e.formats[o?.format]:void 0);this.history.update("cells",t.id,s.id,s),this.dispatch("UPDATE_CELL_POSITION",{cellId:s.id,...i})}}}}export(e){const t={},o={};for(let s of e.sheets){const e=[],i=[],n={},r=Object.keys(this.cells[s.id]||{}).map((e=>this.getters.getCellPosition(e))).sort(((e,t)=>e.col===t.col?e.row-t.row:e.col-t.col));for(const s of r){const r=this.getters.getCell(s),a=yo(s.col,s.row),l=this.removeDefaultStyleValues(r.style);if(Object.keys(l).length){const o=ws(l,t);e[o]??=[],e[o].push(s)}if(r.format){const e=ws(r.format,o);i[e]??=[],i[e].push(s)}r.content&&(n[a]=r.content)}s.styles=xs(e),s.formats=xs(i),s.cells=n}e.styles=t,e.formats=o}importCell(e,t,o,s){const i=this.getNextUid();return this.createCell(i,t||"",s,o,e)}exportForExcel(e){this.export(e);const t=[];for(const o in e.formats||[])xr(e.formats[o])||(t.push(Number(o)),delete e.formats[o]);if(t.length)for(const o of e.sheets)for(const e in o.formats){const s=o.formats[e];s&&t.includes(s)&&delete o.formats[e]}}removeDefaultStyleValues(e){const t={...e};for(const e in de)t[e]===de[e]&&delete t[e];return t}getCells(e){return this.cells[e]||{}}getCellById(e){const t=this.getters.getCellPosition(e);return this.cells[t.sheetId][e]}getFormulaString(e,t,o,s=!1){if(!o.length)return dt(t.map((e=>e.value)));let i=0;return dt(t.map((t=>{if("REFERENCE"===t.type){const t=o[i++];return this.getters.getRangeString(t,e,{useBoundedReference:s})}return t.value})))}getTranslatedCellFormula(e,t,o,s){const i=this.getters.createAdaptedRanges(dS(s).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),t,o,e);return this.getFormulaString(e,s,i)}getFormulaMovedInSheet(e,t,o){const s=dS(o).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),i=this.getters.removeRangesSheetPrefix(t,s);return this.getFormulaString(t,o,i)}getCellStyle(e){return this.getters.getCell(e)?.style||{}}zoneToXC(e,t,o=[{colFixed:!1,rowFixed:!1}]){const s=yo((t=this.getters.expandZone(e,t)).left,t.top,o[0]),i=yo(t.right,t.bottom,o.length>1?o[1]:o[0]),n=this.getters.getMainCellPosition({sheetId:e,col:t.left,row:t.top}),r=this.getters.getMainCellPosition({sheetId:e,col:t.right,row:t.bottom}),a=n.col===r.col&&n.row===r.row;return s==i||a?s:s+":"+i}setStyle(e,t,o){for(let s of Co(t))for(let t=s.left;t<=s.right;t++)for(let i=s.top;i<=s.bottom;i++){const s=this.getters.getCell({sheetId:e,col:t,row:i});this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:i,style:o?{...s?.style,...o}:void 0})}}copyColumnStyle(e,t,o){for(let s=0;s<this.getters.getNumberRows(e);s++){const i=this.getFormat(e,t,s);if(i.style||i.format)for(let t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,...i})}}copyRowStyle(e,t,o){for(let s=0;s<this.getters.getNumberCols(e);s++){const i=this.getFormat(e,s,t);if(i.style||i.format)for(let t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:s,row:t,...i})}}getFormat(e,t,o){const s={},i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.getters.getCell(i);return n&&(n.style&&(s.style=n.style),n.format&&(s.format=n.format)),s}getNextUid(){const e=this.nextId.toString();return this.history.update("nextId",this.nextId+1),e}updateCell(e,t,o,s){const i=this.getters.getCell({sheetId:e,col:t,row:o}),n="content"in s||"formula"in s,r=n?wt(s?.content):i?.content||"";let a;a=void 0!==s.style?s.style||void 0:i?i.style:void 0;const l="format"in s?s.format:i&&i.format;if((n&&!r&&!s.formula||!n&&(!i||""===i.content))&&!a&&!l)return void(i&&(this.history.update("cells",e,i.id,void 0),this.dispatch("UPDATE_CELL_POSITION",{cellId:void 0,col:t,row:o,sheetId:e})));const c=i?.id||this.getNextUid(),h=this.createCell(c,r,l,a,e);this.history.update("cells",e,h.id,h),this.dispatch("UPDATE_CELL_POSITION",{cellId:h.id,col:t,row:o,sheetId:e})}createCell(e,t,o,s,i){return t.startsWith("=")?this.createFormulaCell(e,t,o,s,i):this.createLiteralCell(e,t,o,s)}createLiteralCell(e,t,o,s){const i=this.getters.getLocale(),n=Rr(t,i);return Er(o=o||("number"==typeof n?hr(t,i)||dr(t):void 0))||ki(t)||(t=qi(n)),{id:e,content:t,style:s,format:o,isFormula:!1,parsedValue:n}}createFormulaCell(e,t,o,s,i){const n=hS(t);return n.dependencies.length?this.createFormulaCellWithDependencies(e,n,o,s,i):{id:e,content:t,style:s,format:o,isFormula:!0,compiledFormula:{...n,dependencies:[]}}}createFormulaCellWithDependencies(e,t,o,s,i){const n=[];for(const e of t.dependencies)n.push(this.getters.getRangeFromSheetXC(i,e));return new $M(e,t,o,s,n,i,this.getters.getRangeString)}checkCellOutOfSheet(e){const{sheetId:t,col:o,row:s}=e;if(!this.getters.tryGetSheet(t))return"InvalidSheetId";return as(o,s,this.getters.getSheetZone(t))?"Success":"TargetOutOfSheet"}checkUselessClearCell(e){const t=this.getters.getCell(e);return t&&(t.content||t.style||t.format)?"Success":"NoChanges"}checkUselessUpdateCell(e){const t=this.getters.getCell(e),o="style"in e,s="format"in e;return("content"in e||"formula"in e)&&t?.content!==e.content||o&&!mt(t?.style,e.style)||s&&t?.format!==e.format?"Success":"NoChanges"}}).add("merge",class extends zM{static getters=["isInMerge","isInSameMerge","isMergeHidden","getMainCellPosition","expandZone","doesIntersectMerge","doesColumnsHaveCommonMerges","doesRowsHaveCommonMerges","getMerges","getMerge","getMergesInZone","isSingleCellOrMerge","getSelectionRangeString","isMainCellPosition"];nextId=1;merges={};mergeCellMap={};allowDispatch(e){const t="force"in e&&!!e.force;switch(e.type){case"ADD_MERGE":return t?this.checkValidations(e,this.checkFrozenPanes):this.checkValidations(e,this.checkDestructiveMerge,this.checkOverlap,this.checkFrozenPanes);case"UPDATE_CELL":return this.checkMergedContentUpdate(e);case"REMOVE_MERGE":return this.checkMergeExists(e);default:return"Success"}}handle(e){switch(e.type){case"CREATE_SHEET":case"DELETE_SHEET":this.history.update("merges",e.sheetId,{}),this.history.update("mergeCellMap",e.sheetId,{});break;case"DUPLICATE_SHEET":const t=this.merges[e.sheetId];if(!t)break;for(const o of Object.values(t).filter(at))this.addMerge(e.sheetIdTo,o.zone);break;case"ADD_MERGE":for(const t of e.target)this.addMerge(e.sheetId,t);break;case"REMOVE_MERGE":for(const t of e.target)this.removeMerge(e.sheetId,t)}}adaptRanges(e,t){const o=t?[t]:Object.keys(this.merges);for(const t of o)this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map((t=>this.getMergeById(e,parseInt(t,10)))).filter(at)}getMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e],i=s?t in s&&s[t]?.[o]:void 0;return i?this.getMergeById(e,i):void 0}getMergesInZone(e,t){const o=this.mergeCellMap[e];if(!o)return[];const s=new Set;for(let e=t.left;e<=t.right;e++)for(let i=t.top;i<=t.bottom;i++){const t=o[e]?.[i];t&&s.add(t)}return Array.from(s).map((t=>this.getMergeById(e,t))).filter(at)}getSelectionRangeString(e,t){const o=kr.fromRange(e,this.getters),s=this.getters.expandZone(o.sheetId,o.zone),i=o.clone({zone:{...s,bottom:o.isFullCol?void 0:s.bottom,right:o.isFullRow?void 0:s.right}}),n=this.getters.getRangeString(i,t);if(this.isSingleCellOrMerge(o.sheetId,o.zone)){const{sheetName:e,xc:t}=qo(n);return Zo(e,t.split(":")[0])}return n}doesIntersectMerge(e,t){for(const o of this.getMerges(e))if(rs(t,o))return!0;return!1}doesColumnsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<this.getters.getNumberRows(e);i++)if(this.isInSameMerge(s.id,t,i,o,i))return!0;return!1}doesRowsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<=this.getters.getNumberCols(e);i++)if(this.isInSameMerge(s.id,i,t,i,o))return!0;return!1}expandZone(e,t){let{left:o,right:s,top:i,bottom:n}=t,r={left:o,right:s,top:i,bottom:n};for(let t in this.merges[e]){const o=this.getMergeById(e,parseInt(t));o&&rs(o,r)&&(r=ss(o,r))}return ns(r,t)?r:this.expandZone(e,r)}isInSameMerge(e,t,o,s,i){const n=this.getMerge({sheetId:e,col:t,row:o}),r=this.getMerge({sheetId:e,col:s,row:i});return!(!n||!r)&&ns(n,r)}isInMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e];return!!s&&(t in s&&Boolean(s[t]?.[o]))}getMainCellPosition(e){const t=this.getMerge(e);return t?{sheetId:e.sheetId,col:t.left,row:t.top}:e}isMergeHidden(e,t){const o=this.getters.getHiddenColsGroups(e),s=this.getters.getHiddenRowsGroups(e);for(let e of o)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(let e of s)if(t.top>=e[0]&&t.bottom<=e[e.length-1])return!0;return!1}isSingleCellOrMerge(e,t){const o=this.getMerge({sheetId:e,col:t.left,row:t.top});if(o)return ns(t,o);const{numberOfCols:s,numberOfRows:i}=cs(t);return 1===s&&1===i}isMainCellPosition(e){return mt(this.getMainCellPosition(e),e)}isMergeDestructive(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=qe(s,0,this.getters.getNumberCols(e)-1),n=qe(n,0,this.getters.getNumberRows(e)-1);for(let t=i;t<=n;t++)for(let n=o;n<=s;n++)if(n!==o||t!==i){const o=this.getters.getCell({sheetId:e,col:n,row:t});if(o&&""!==o.content)return!0}return!1}getMergeById(e,t){const o=this.merges[e]?.[t];return void 0!==o?ZM(t,o):void 0}checkDestructiveMerge({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";return t.some((t=>this.isMergeDestructive(e,t)))?"MergeIsDestructive":"Success"}checkOverlap({target:e}){for(const t of e)for(const o of e)if(t!==o&&rs(t,o))return"MergeOverlap";return"Success"}checkFrozenPanes({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";const{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e);for(const e of t)if(e.left<o&&e.right>=o||e.top<s&&e.bottom>=s)return"FrozenPaneOverlap";return"Success"}checkMergedContentUpdate(e){const{col:t,row:o,content:s}=e;if(void 0===s)return"Success";const{col:i,row:n}=this.getMainCellPosition(e);return i===t&&n===o?"Success":"CellIsMerged"}checkMergeExists(e){const{sheetId:t,target:o}=e;for(const e of o){const{left:o,top:s}=e,i=this.getMerge({sheetId:t,col:o,row:s});if(void 0===i||!ns(e,i))return"InvalidTarget"}return"Success"}addMerge(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=qe(s,0,this.getters.getNumberCols(e)-1),n=qe(n,0,this.getters.getNumberRows(e)-1);if(yo(o,i)===yo(s,n))return;const r=this.getters.getCell({sheetId:e,col:o,row:i});let a=this.nextId++;this.history.update("merges",e,a,this.getters.getRangeFromSheetXC(e,Jo({left:o,top:i,right:s,bottom:n})));let l=new Set;for(let t=i;t<=n;t++)for(let n=o;n<=s;n++){n===o&&t===i||this.dispatch("UPDATE_CELL",{sheetId:e,col:n,row:t,style:r?r.style:null,content:""});const s=this.getMerge({sheetId:e,col:n,row:t});s&&l.add(s.id),this.history.update("mergeCellMap",e,n,t,a)}for(let t of l){const{top:o,bottom:s,left:i,right:n}=this.getMergeById(e,t);for(let t=o;t<=s;t++)for(let o=i;o<=n;o++){const s={sheetId:e,col:o,row:t},i=this.getMerge(s);i&&i.id===a||(this.history.update("mergeCellMap",e,o,t,void 0),this.dispatch("CLEAR_CELL",s))}this.history.update("merges",e,t,void 0)}}removeMerge(e,t){const{left:o,top:s,bottom:i,right:n}=t,r=this.getMerge({sheetId:e,col:o,row:s});if(void 0!==r&&ns(t,r)){this.history.update("merges",e,r.id,void 0);for(let t=s;t<=i;t++)for(let s=o;s<=n;s++)this.history.update("mergeCellMap",e,s,t,void 0)}}applyRangeChangeOnSheet(e,t){const o=Object.entries(this.merges[e]||{});for(const[s,i]of o)if(i){const o=i.zone,n=t(i);switch(n.changeType){case"NONE":break;case"REMOVE":this.removeMerge(e,o);break;default:const{numberOfCols:t,numberOfRows:i}=cs(n.range.zone);1===t&&1===i?this.removeMerge(e,o):this.history.update("merges",e,parseInt(s,10),n.range)}}this.history.update("mergeCellMap",e,{});for(const t of this.getMerges(e))for(const{col:o,row:s}of us(t))this.history.update("mergeCellMap",e,o,s,t.id)}import(e){const t=e.sheets||[];for(let e of t)this.history.update("merges",e.id,{}),this.history.update("mergeCellMap",e.id,{}),e.merges&&this.importMerges(e.id,e.merges)}importMerges(e,t){for(let o of t)this.addMerge(e,Yo(o))}export(e){for(let t of e.sheets){const e=this.merges[t.id];e&&t.merges.push(...qM(e))}}exportForExcel(e){this.export(e)}}).add("headerSize",class extends zM{static getters=["getUserRowSize","getColSize"];sizes={};handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("sizes",e.sheetId,{COL:Array(this.getters.getNumberCols(e.sheetId)).fill(void 0),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(void 0)});break;case"DUPLICATE_SHEET":this.history.update("sizes",e.sheetIdTo,Be(this.sizes[e.sheetId]));break;case"DELETE_SHEET":const t={...this.sizes};delete t[e.sheetId],this.history.update("sizes",t);break;case"REMOVE_COLUMNS_ROWS":{const t=It(this.sizes[e.sheetId][e.dimension],e.elements);this.history.update("sizes",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{let t=[...this.sizes[e.sheetId][e.dimension]];const o=pt(e.position,e.base),s=t[e.base];t.splice(o,0,...Array(e.quantity).fill(s)),this.history.update("sizes",e.sheetId,e.dimension,t);break}case"RESIZE_COLUMNS_ROWS":if("ROW"===e.dimension)for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0);else for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0)}}getColSize(e,t){return Math.round(this.sizes[e]?.COL[t]||oe)}getUserRowSize(e,t){const o=this.sizes[e]?.ROW[t];return o?Math.round(o):void 0}import(e){for(let t of e.sheets){const e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(let[o,s]of Object.entries(t.rows))s.size&&(e.ROW[o]=s.size);for(let[o,s]of Object.entries(t.cols))s.size&&(e.COL[o]=s.size);this.sizes[t.id]=e}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let o of e.sheets){void 0===o.rows&&(o.rows={});for(const e of Ze(0,this.getters.getNumberRows(o.id)))(t||this.sizes[o.id].ROW[e])&&(o.rows[e]={...o.rows[e],size:this.getUserRowSize(o.id,e)??se});void 0===o.cols&&(o.cols={});for(let e of Ze(0,this.getters.getNumberCols(o.id)))(t||this.sizes[o.id].COL[e])&&(o.cols[e]={...o.cols[e],size:this.getColSize(o.id,e)})}}}).add("borders",class extends zM{static getters=["getCellBorder","getBordersColors"];borders={};allowDispatch(e){return"SET_BORDER"===e.type?this.checkBordersUnchanged(e):"Success"}handle(e){switch(e.type){case"ADD_MERGE":for(const t of e.target)this.addBordersToMerge(e.sheetId,t);break;case"DUPLICATE_SHEET":const t=this.borders[e.sheetId];if(t){const o=t.slice().map((e=>e?.slice().map((e=>Be(e)))));this.history.update("borders",e.sheetIdTo,o)}break;case"DELETE_SHEET":const o={...this.borders};delete o[e.sheetId],this.history.update("borders",o);break;case"SET_BORDER":this.setBorder(e.sheetId,e.col,e.row,e.border);break;case"SET_ZONE_BORDERS":if(e.border){const t=e.target.map((t=>this.getters.expandZone(e.sheetId,t)));this.setBorders(e.sheetId,t,e.border.position,""===e.border.color?void 0:{style:e.border.style||ve,color:e.border.color||be})}break;case"CLEAR_FORMATTING":this.clearBorders(e.sheetId,e.target);break;case"REMOVE_COLUMNS_ROWS":const s=[...e.elements].sort(((e,t)=>t-e));for(const t of je(s))if("COL"===e.dimension){const o=this.getters.getColsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[o]),this.shiftBordersHorizontally(e.sheetId,t[0]+1,-t.length)}else{const o=this.getters.getRowsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[o]),this.shiftBordersVertically(e.sheetId,t[0]+1,-t.length)}break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.handleAddColumns(e):this.handleAddRows(e)}}handleAddColumns(e){let t,o;"before"===e.position?(this.shiftBordersHorizontally(e.sheetId,e.base,e.quantity),t=e.base-1,o=e.base+e.quantity):(this.shiftBordersHorizontally(e.sheetId,e.base+1,e.quantity),t=e.base,o=e.base+e.quantity+1),this.ensureColumnBorderContinuity(e.sheetId,t,o)}handleAddRows(e){let t,o;"before"===e.position?(this.shiftBordersVertically(e.sheetId,e.base,e.quantity),t=e.base-1,o=e.base+e.quantity):(this.shiftBordersVertically(e.sheetId,e.base+1,e.quantity),t=e.base,o=e.base+e.quantity+1),this.ensureRowBorderContinuity(e.sheetId,t,o)}getCellBorder({sheetId:e,col:t,row:o}){const s=this.borders[e]?.[t]?.[o];return s?.top||s?.bottom||s?.left||s?.right?Be(s):null}getBordersColors(e){const t=[],o=this.borders[e];if(o)for(const e of o.filter(at))for(const o of e)if(o)for(const e of["top","bottom","left","right"]){const s=o[e]?.color;s&&t.push(s)}return t}ensureColumnBorderContinuity(e,t,o){const s=Ze(t+1,o);for(let i=0;i<this.getters.getNumberRows(e);i++){const n=this.getCellBorder({sheetId:e,col:t,row:i}),r=this.getCellBorder({sheetId:e,col:o,row:i});if(n&&r){const t=this.getCommonSides(n,r);for(let o of s)this.addBorder(e,o,i,t)}}}ensureRowBorderContinuity(e,t,o){const s=Ze(t+1,o);for(let i=0;i<this.getters.getNumberCols(e);i++){const n=this.getCellBorder({sheetId:e,col:i,row:t}),r=this.getCellBorder({sheetId:e,col:i,row:o});if(n&&r){const t=this.getCommonSides(n,r);for(let o of s)this.addBorder(e,i,o,t)}}}getCommonSides(e,t){const o={};for(let s of["top","bottom","left","right"])e[s]&&mt(e[s],t[s])&&(o[s]=e[s]);return o}getColumnsWithBorders(e){const t=this.borders[e];return t?Object.keys(t).map((e=>parseInt(e,10))):[]}getRowsWithBorders(e){const t=this.borders[e]?.filter(at);if(!t)return[];const o=new Set;for(const e of t)for(const t in e)o.add(parseInt(t,10));return Array.from(o)}getRowsRange(e){return this.borders[e]?Ze(0,this.getters.getNumberRows(e)+1):[]}shiftBordersHorizontally(e,t,o){this.borders[e]&&this.getColumnsWithBorders(e).filter((e=>e>=t)).sort(((e,t)=>o<0?e-t:t-e)).forEach((t=>{this.moveBordersOfColumn(e,t,o)}))}shiftBordersVertically(e,t,o){this.borders[e]&&(o<0&&this.moveBordersOfRow(e,t,o,{destructive:!1}),this.getRowsWithBorders(e).filter((e=>e>=t)).sort(((e,t)=>o<0?e-t:t-e)).forEach((t=>{this.moveBordersOfRow(e,t,o)})))}moveBordersOfRow(e,t,o,{destructive:s}={destructive:!0}){const i=this.borders[e];i&&this.getColumnsWithBorders(e).forEach((n=>{const r=i[n]?.[t+o],a=i[n]?.[t];this.history.update("borders",e,n,t+o,s?a:a||r),this.history.update("borders",e,n,t,void 0)}))}moveBordersOfColumn(e,t,o,{destructive:s}={destructive:!0}){const i=this.borders[e];i&&this.getRowsRange(e).forEach((n=>{const r=i[t+o]?.[n],a=i[t]?.[n];this.history.update("borders",e,t+o,n,s?a:a||r),s&&this.history.update("borders",e,t,n,void 0)}))}setBorder(e,t,o,s,i=!0){const n=this.getters.getNumberCols(e)-1,r=this.getters.getNumberRows(e)-1;!i&&this.borders[e]?.[t]?.[o]?.left||(this.history.update("borders",e,t,o,"left",s?.left),s?.left&&t>0&&!mt(this.getCellBorder({sheetId:e,col:t-1,row:o})?.right,s?.left)&&this.history.update("borders",e,t-1,o,"right",void 0)),!i&&this.borders[e]?.[t]?.[o]?.top||(this.history.update("borders",e,t,o,"top",s?.top),s?.top&&o>0&&!mt(this.getCellBorder({sheetId:e,col:t,row:o-1})?.bottom,s?.top)&&this.history.update("borders",e,t,o-1,"bottom",void 0)),!i&&this.borders[e]?.[t]?.[o]?.right||(this.history.update("borders",e,t,o,"right",s?.right),s?.right&&t<n&&!mt(this.getCellBorder({sheetId:e,col:t+1,row:o})?.left,s?.right)&&this.history.update("borders",e,t+1,o,"left",void 0)),!i&&this.borders[e]?.[t]?.[o]?.bottom||(this.history.update("borders",e,t,o,"bottom",s?.bottom),s?.bottom&&o<r&&!mt(this.getCellBorder({sheetId:e,col:t,row:o+1})?.top,s?.bottom)&&this.history.update("borders",e,t,o+1,"top",void 0))}clearBorders(e,t,o=!1){const s=this.getters.getNumberCols(e)-1,i=this.getters.getNumberRows(e)-1;for(let n of Co(t))for(let t=n.top;t<=n.bottom;t++){o&&(n.left>0&&this.history.update("borders",e,n.left-1,t,"right",void 0),n.right<s&&this.history.update("borders",e,n.right+1,t,"left",void 0));for(let s=n.left;s<=n.right;s++)this.history.update("borders",e,s,t,void 0),o&&(n.top>0&&this.history.update("borders",e,s,n.top-1,"bottom",void 0),n.bottom<i&&this.history.update("borders",e,s,n.bottom+1,"top",void 0))}}clearInsideBorders(e,t){for(let o of t)for(let t=o.top;t<=o.bottom;t++)for(let s=o.left;s<=o.right;s++)this.history.update("borders",e,s,t,void 0)}addBorder(e,t,o,s){this.setBorder(e,t,o,{...this.getCellBorder({sheetId:e,col:t,row:o}),...s})}setBorders(e,t,o,s){if("clear"===o)return this.clearBorders(e,t,!0);for(let i of Co(t)){if("all"===o)for(let t=i.top;t<=i.bottom;t++)for(let o=i.left;o<=i.right;o++)this.addBorder(e,o,t,{top:s,right:s,bottom:s,left:s});if("h"===o||"hv"===o){if(i.top===i.bottom)continue;for(let t=i.left;t<=i.right;t++){this.addBorder(e,t,i.top,{bottom:s});for(let o=i.top+1;o<i.bottom;o++)this.addBorder(e,t,o,{top:s,bottom:s});this.addBorder(e,t,i.bottom,{top:s})}}if("v"===o||"hv"===o){if(i.left===i.right)continue;for(let t=i.top;t<=i.bottom;t++){this.addBorder(e,i.left,t,{right:s});for(let o=i.left+1;o<i.right;o++)this.addBorder(e,o,t,{left:s,right:s});this.addBorder(e,i.right,t,{left:s})}}if("left"===o||"external"===o)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.left,t,{left:s});if("right"===o||"external"===o)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.right,t,{right:s});if("top"===o||"external"===o)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.top,{top:s});if("bottom"===o||"external"===o)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.bottom,{bottom:s})}}addBordersToMerge(e,t){const{left:o,right:s,top:i,bottom:n}=t,r=this.getCellBorder({sheetId:e,col:o,row:i}),a=this.getCellBorder({sheetId:e,col:s,row:n});this.clearBorders(e,[t]),r?.top&&this.setBorders(e,[{...t,bottom:i}],"top",r.top),r?.left&&this.setBorders(e,[{...t,right:o}],"left",r.left),a?.bottom?this.setBorders(e,[{...t,top:n}],"bottom",a.bottom):r?.bottom&&this.setBorders(e,[{...t,top:n}],"bottom",r.bottom),a?.right?this.setBorders(e,[{...t,left:s}],"right",a.right):r?.right&&this.setBorders(e,[{...t,left:s}],"right",r.right)}checkBordersUnchanged(e){const t=this.getCellBorder(e),o=!(e.border?.bottom||e.border?.left||e.border?.right||e.border?.top);return!t&&o||mt(t,e.border)?"NoChanges":"Success"}import(e){if(Object.keys(e.borders||{}).length)for(const t of e.sheets)for(const[o,s]of Es(t.id,t.borders)){const{sheetId:t,col:i,row:n}=o,r=e.borders[s];this.setBorder(t,i,n,r,!1)}for(let t of e.sheets)if(t.merges)for(let e of t.merges)this.addBordersToMerge(t.id,Yo(e))}export(e){const t={};for(let o of e.sheets){const e={};for(let s=0;s<o.colNumber;s++)for(let i=0;i<o.rowNumber;i++){const n=this.getCellBorder({sheetId:o.id,col:s,row:i});if(n){const r=ws(n,t),a={sheetId:o.id,col:s,row:i};e[r]??=[],e[r].push(a)}}o.borders=xs(e)}e.borders=t}exportForExcel(e){this.export(e)}}).add("conditional formatting",class extends zM{static getters=["getConditionalFormats","getRulesSelection","getRulesByCell","getAdaptedCfRanges"];cfRules={};loopThroughRangesOfSheet(e,t){for(const o of this.cfRules[e]){if("DataBarRule"===o.rule.type&&o.rule.rangeValues){const s=t(o.rule.rangeValues);switch(s.changeType){case"REMOVE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"rule","rangeValues",void 0);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"rule","rangeValues",s.range)}}for(const s of o.ranges){const i=t(s);switch(i.changeType){case"REMOVE":let t=o.ranges.slice();t.splice(o.ranges.indexOf(s),1),t.length>=1?this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",t):this.removeConditionalFormatting(o.id,e);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",o.ranges.indexOf(s),i.range)}}}}adaptRanges(e,t){if(t)this.loopThroughRangesOfSheet(t,e);else for(const t of Object.keys(this.cfRules))this.loopThroughRangesOfSheet(t,e)}allowDispatch(e){switch(e.type){case"ADD_CONDITIONAL_FORMAT":return this.checkValidations(e,this.checkCFRule,this.checkEmptyRange,this.checkCFHasChanged);case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":return this.checkValidPriorityChange(e.cfId,e.delta,e.sheetId)}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.cfRules[e.sheetId]=[];break;case"DUPLICATE_SHEET":this.history.update("cfRules",e.sheetIdTo,[]);for(const t of this.getConditionalFormats(e.sheetId))this.addConditionalFormatting(t,e.sheetIdTo);break;case"DELETE_SHEET":const t=Object.assign({},this.cfRules);delete t[e.sheetId],this.history.update("cfRules",t);break;case"ADD_CONDITIONAL_FORMAT":const o={...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))};this.addConditionalFormatting(o,e.sheetId);break;case"REMOVE_CONDITIONAL_FORMAT":this.removeConditionalFormatting(e.id,e.sheetId);break;case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":this.changeCFPriority(e.cfId,e.delta,e.sheetId)}}import(e){for(let t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map((e=>this.mapToConditionalFormatInternal(t.id,e)))}export(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e))))}exportForExcel(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e,{useBoundedReference:!0}))))}getConditionalFormats(e){return this.cfRules[e]?.map((t=>this.mapToConditionalFormat(e,t)))||[]}getRulesSelection(e,t){const o=new Set;return t.forEach((t=>{this.getRulesByZone(e,t).forEach((e=>{o.add(e)}))})),Array.from(o)}getRulesByZone(e,t){const o=new Set;for(let s=t.top;s<=t.bottom;s++)for(let i=t.left;i<=t.right;i++){this.getRulesByCell(e,i,s).forEach((e=>{o.add(e.id)}))}return o}getRulesByCell(e,t,o){const s=[];for(let i of this.cfRules[e])for(let e of i.ranges)as(t,o,e.zone)&&s.push(i);return new Set(s.map((t=>this.mapToConditionalFormat(e,t))))}getAdaptedCfRanges(e,t,o,s){if(0===o.length&&0===s.length)return;const i=this.getters.getConditionalFormats(e),n=i.findIndex((e=>e.id===t.id));let r=[];n>-1&&(r=i[n].ranges.map(jo));const a=Co(r,s);return Co([...o,...a],[]).map((t=>this.getters.getRangeDataFromZone(e,t)))}mapToConditionalFormat(e,t,{useBoundedReference:o}={useBoundedReference:!1}){const s=t.ranges.map((t=>this.getters.getRangeString(t,e,{useBoundedReference:o})));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:s}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues&&this.getters.getRangeString(t.rule.rangeValues,e,{useBoundedReference:o})},ranges:s}}mapToConditionalFormatInternal(e,t){const o=t.ranges.map((t=>this.getters.getRangeFromSheetXC(e,t)));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:o}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues?this.getters.getRangeFromSheetXC(e,t.rule.rangeValues):void 0},ranges:o}}addConditionalFormatting(e,t){const o=this.cfRules[t].slice(),s=o.findIndex((t=>t.id===e.id)),i=this.mapToConditionalFormatInternal(t,e);s>-1?o.splice(s,1,i):o.push(i),this.history.update("cfRules",t,o)}checkValidPriorityChange(e,t,o){if(!this.cfRules[o])return"InvalidSheetId";const s=this.cfRules[o].findIndex((t=>t.id===e));if(-1===s)return"InvalidConditionalFormatId";const i=s-t;return i<0||i>=this.cfRules[o].length?"InvalidConditionalFormatId":"Success"}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}checkCFRule(e){const t=e.cf.rule;switch(t.type){case"CellIsRule":return this.checkValidations(t,this.checkOperatorArgsNumber(2,["Between","NotBetween"]),this.checkOperatorArgsNumber(1,["BeginsWith","ContainsText","EndsWith","GreaterThan","GreaterThanOrEqual","LessThan","LessThanOrEqual","NotContains","Equal","NotEqual"]),this.checkOperatorArgsNumber(0,["IsEmpty","IsNotEmpty"]),this.checkCFValues);case"ColorScaleRule":return this.checkValidations(t,this.chainValidations(this.checkThresholds(this.checkFormulaCompilation)),this.chainValidations(this.checkThresholds(this.checkNaN),this.batchValidations(this.checkMinBiggerThanMax,this.checkMinBiggerThanMid,this.checkMidBiggerThanMax)));case"IconSetRule":return this.checkValidations(t,this.chainValidations(this.checkInflectionPoints(this.checkNaN),this.checkLowerBiggerThanUpper),this.chainValidations(this.checkInflectionPoints(this.checkFormulaCompilation)))}return"Success"}checkCFHasChanged(e){const t=this.mapToConditionalFormatInternal(e.sheetId,{...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))}),o=this.cfRules[e.sheetId]?.find((t=>t.id===e.cf.id));return o&&mt(t,o)?"NoChanges":"Success"}checkOperatorArgsNumber(e,t){if(e>2)throw new Error("Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.");return o=>{if(t.includes(o.operator)){const t=[],s=e=>void 0===e||""===e;return e>=1&&s(o.values[0])&&t.push("FirstArgMissing"),e>=2&&s(o.values[1])&&t.push("SecondArgMissing"),t.length?t:"Success"}return"Success"}}checkNaN(e,t){if(["number","percentage","percentile"].includes(e.type)&&(""===e.value||isNaN(e.value)))switch(t){case"min":return"MinNaN";case"max":return"MaxNaN";case"mid":return"MidNaN";case"upperInflectionPoint":return"ValueUpperInflectionNaN";case"lowerInflectionPoint":return"ValueLowerInflectionNaN"}return"Success"}checkFormulaCompilation(e,t){if("formula"!==e.type)return"Success";if(hS(e.value||"").isBadExpression)switch(t){case"min":return"MinInvalidFormula";case"max":return"MaxInvalidFormula";case"mid":return"MidInvalidFormula";case"upperInflectionPoint":return"ValueUpperInvalidFormula";case"lowerInflectionPoint":return"ValueLowerInvalidFormula"}return"Success"}checkThresholds(e){return this.batchValidations((t=>e(t.minimum,"min")),(t=>e(t.maximum,"max")),(t=>t.midpoint?e(t.midpoint,"mid"):"Success"))}checkInflectionPoints(e){return this.batchValidations((t=>e(t.lowerInflectionPoint,"lowerInflectionPoint")),(t=>e(t.upperInflectionPoint,"upperInflectionPoint")))}checkLowerBiggerThanUpper(e){const t=e.lowerInflectionPoint.value,o=e.upperInflectionPoint.value;return["number","percentage","percentile"].includes(e.lowerInflectionPoint.type)&&e.lowerInflectionPoint.type===e.upperInflectionPoint.type&&Number(t)>Number(o)?"LowerBiggerThanUpper":"Success"}checkMinBiggerThanMax(e){const t=e.minimum.value,o=e.maximum.value;return["number","percentage","percentile"].includes(e.minimum.type)&&e.minimum.type===e.maximum.type&&GM(t)>=GM(o)?"MinBiggerThanMax":"Success"}checkMidBiggerThanMax(e){const t=e.midpoint?.value,o=e.maximum.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.midpoint.type===e.maximum.type&&GM(t)>=GM(o)?"MidBiggerThanMax":"Success"}checkMinBiggerThanMid(e){const t=e.minimum.value,o=e.midpoint?.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.minimum.type===e.midpoint.type&&GM(t)>=GM(o)?"MinBiggerThanMid":"Success"}checkCFValues(e){for(const t of e.values){if(!t.startsWith("="))continue;if(hS(t||"").isBadExpression)return"ValueCellIsInvalidFormula"}return"Success"}removeConditionalFormatting(e,t){const o=this.cfRules[t].findIndex((t=>t.id===e));if(-1!==o){const e=this.cfRules[t].slice();e.splice(o,1),this.history.update("cfRules",t,e)}}changeCFPriority(e,t,o){const s=this.cfRules[o].findIndex((t=>t.id===e)),i=this.cfRules[o][s],n=s-t,r=[...this.cfRules[o]];r.splice(s,1),r.splice(n,0,i),this.history.update("cfRules",o,r)}}).add("figures",class extends zM{static getters=["getFigures","getFigure","getFigureSheetId"];figures={};allowDispatch(e){switch(e.type){case"CREATE_FIGURE":return this.checkFigureDuplicate(e.figure.id);case"UPDATE_FIGURE":case"DELETE_FIGURE":return this.checkFigureExists(e.sheetId,e.id);default:return"Success"}}beforeHandle(e){if("DELETE_SHEET"===e.type)this.getters.getFigures(e.sheetId).forEach((t=>{this.dispatch("DELETE_FIGURE",{id:t.id,sheetId:e.sheetId})}))}handle(e){switch(e.type){case"CREATE_SHEET":this.figures[e.sheetId]={};break;case"DELETE_SHEET":this.deleteSheet(e.sheetId);break;case"CREATE_FIGURE":this.addFigure(e.figure,e.sheetId);break;case"UPDATE_FIGURE":const{type:t,sheetId:o,...s}=e,i=s;this.updateFigure(o,i);break;case"DELETE_FIGURE":this.removeFigure(e.id,e.sheetId);break;case"REMOVE_COLUMNS_ROWS":this.onRowColDelete(e.sheetId,e.dimension)}}onRowColDelete(e,t){"ROW"===t?this.onRowDeletion(e):this.onColDeletion(e)}onRowDeletion(e){const t=this.getters.getNumberRows(e);let o=0;for(let s=0;s<t;s++)o+=this.getters.getUserRowSize(e,s)||se;const s=this.getters.getFigures(e);for(const t of s){const s=Math.min(t.y,o-t.height);s!==t.y&&this.dispatch("UPDATE_FIGURE",{sheetId:e,id:t.id,y:s})}}onColDeletion(e){const t=this.getters.getNumberCols(e);let o=0;for(let s=0;s<t;s++)o+=this.getters.getColSize(e,s);const s=this.getters.getFigures(e);for(const t of s){const s=Math.min(t.x,o-t.width);s!==t.x&&this.dispatch("UPDATE_FIGURE",{sheetId:e,id:t.id,x:s})}}updateFigure(e,t){if("id"in t)for(const[o,s]of Object.entries(t))switch(o){case"x":case"y":void 0!==s&&this.history.update("figures",e,t.id,o,Math.max(s,0));break;case"width":case"height":void 0!==s&&this.history.update("figures",e,t.id,o,s)}}addFigure(e,t){this.history.update("figures",t,e.id,e)}deleteSheet(e){this.history.update("figures",e,void 0)}removeFigure(e,t){this.history.update("figures",t,e,void 0)}checkFigureExists(e,t){return void 0===this.figures[e]?.[t]?"FigureDoesNotExist":"Success"}checkFigureDuplicate(e){return Object.values(this.figures).find((t=>t?.[e]))?"DuplicatedFigureId":"Success"}getFigures(e){return Object.values(this.figures[e]||{}).filter(at)}getFigure(e,t){return this.figures[e]?.[t]}getFigureSheetId(e){return Object.keys(this.figures).find((t=>void 0!==this.figures[t]?.[e]))}import(e){for(let t of e.sheets){const e={};t.figures.forEach((t=>{e[t.id]=t})),this.figures[t.id]=e}}export(e){for(const t of e.sheets)for(const e of this.getFigures(t.id)){const o=void 0;t.figures.push({...e,data:o})}}exportForExcel(e){this.export(e)}}).add("chart",class extends zM{static getters=["isChartDefined","getChartDefinition","getChartType","getChartIds","getChart","getContextCreationChart"];charts={};createChart=pR(this.getters);validateChartDefinition=e=>fR(this,e.definition);adaptRanges(e){for(const[t,o]of Object.entries(this.charts))this.history.update("charts",t,o?.updateRanges(e))}allowDispatch(e){switch(e.type){case"CREATE_CHART":return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartDuplicate));case"UPDATE_CHART":return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartExists));default:return"Success"}}handle(e){switch(e.type){case"CREATE_CHART":this.addFigure(e.id,e.sheetId,e.position,e.size),this.addChart(e.id,e.definition);break;case"UPDATE_CHART":this.addChart(e.id,e.definition);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("chart"===o.tag){const t=o.id.split(we).pop(),s=`${e.sheetIdTo}${we}${t}`,i=this.charts[o.id]?.duplicateInDuplicatedSheet(e.sheetIdTo);i&&this.dispatch("CREATE_CHART",{id:s,position:{x:o.x,y:o.y},size:{width:o.width,height:o.height},definition:i.getDefinition(),sheetId:e.sheetIdTo})}break}case"DELETE_FIGURE":this.history.update("charts",e.id,void 0);break;case"DELETE_SHEET":for(let t of this.getChartIds(e.sheetId))this.history.update("charts",t,void 0)}}getContextCreationChart(e){return this.charts[e]?.getContextCreation()}getChart(e){return this.charts[e]}getChartType(e){const t=this.charts[e]?.type;if(!t)throw new Error("Chart not defined.");return t}isChartDefined(e){return e in this.charts&&void 0!==this.charts}getChartIds(e){return Object.entries(this.charts).filter((([,t])=>t?.sheetId===e)).map((([e])=>e))}getChartDefinition(e){const t=this.charts[e]?.getDefinition();if(!t)throw new Error(`There is no chart with the given figureId: ${e}`);return t}import(e){for(let t of e.sheets)if(t.figures)for(let e of t.figures)"chart"===e.tag&&(this.charts[e.id]=this.createChart(e.id,e.data,t.id))}export(e){if(e.sheets)for(let t of e.sheets){const e=this.getters.getFigures(t.id),o=[];for(let t of e){const e=t;if(e&&"chart"===e.tag){const t=this.charts[e.id]?.getDefinition();t&&(e.data=t,o.push(e))}else o.push(e)}t.figures=o}}addFigure(e,t,o={x:0,y:0},s={width:536,height:335}){if(this.getters.getFigure(t,e))return;const i={id:e,x:o.x,y:o.y,width:s.width,height:s.height,tag:"chart"};this.dispatch("CREATE_FIGURE",{sheetId:t,figure:i})}addChart(e,t){const o=this.getters.getFigureSheetId(e);o&&this.history.update("charts",e,this.createChart(e,t,o))}checkChartDuplicate(e){return this.getters.getFigureSheetId(e.id)?"DuplicatedChartId":"Success"}checkChartExists(e){return this.getters.getFigureSheetId(e.id)?"Success":"ChartDoesNotExist"}}).add("image",class extends zM{static getters=["getImage","getImagePath","getImageSize"];fileStore;images={};syncedImages=new Set;constructor(e){super(e),this.fileStore=e.external.fileStore}allowDispatch(e){return"CREATE_IMAGE"===e.type&&this.getters.getFigure(e.sheetId,e.figureId)?"InvalidFigureId":"Success"}handle(e){switch(e.type){case"CREATE_IMAGE":this.addImage(e.figureId,e.sheetId,e.position,e.size),this.history.update("images",e.sheetId,e.figureId,e.definition),this.syncedImages.add(e.definition.path);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("image"===o.tag){const t=o.id.split(we).pop(),s=`${e.sheetIdTo}${we}${t}`,i=this.getImage(o.id);if(i){const t={width:o.width,height:o.height};this.dispatch("CREATE_IMAGE",{sheetId:e.sheetIdTo,figureId:s,position:{x:o.x,y:o.y},size:t,definition:Be(i)})}}break}case"DELETE_FIGURE":this.history.update("images",e.sheetId,e.id,void 0);break;case"DELETE_SHEET":this.history.update("images",e.sheetId,void 0)}}garbageCollectExternalResources(){const e=new Set(this.getAllImages().map((e=>e.path)));for(const t of this.syncedImages)e.has(t)||this.fileStore?.delete(t)}getImage(e){for(const t of Object.values(this.images))if(t&&t[e])return t[e];throw new Error(`There is no image with the given figureId: ${e}`)}getImagePath(e){return this.getImage(e).path}getImageSize(e){return this.getImage(e).size}addImage(e,t,o,s){const i={id:e,x:o.x,y:o.y,width:s.width,height:s.height,tag:"image"};this.dispatch("CREATE_FIGURE",{sheetId:t,figure:i})}import(e){for(const t of e.sheets){const e=(t.figures||[]).filter((e=>"image"===e.tag));for(const o of e)this.history.update("images",t.id,o.id,o.data),this.syncedImages.add(o.data.path)}}export(e){for(const t of e.sheets){const e=t.figures.filter((e=>"image"===e.tag));for(const o of e)o.data=this.images[t.id]?.[o.id]}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const t of e)if("image"===t?.tag){const e=this.getImage(t.id);e&&o.push({...t,data:Be(e)})}t.images=[...t.images,...o]}}getAllImages(){const e=[];for(const t in this.images)e.push(...Object.values(this.images[t]||{}).filter(at));return e}}).add("pivot_core",class extends zM{static getters=["getPivotCoreDefinition","getPivotDisplayName","getPivotId","getPivotFormulaId","getPivotIds","getMeasureCompiledFormula","getPivotName","isExistingPivot"];nextFormulaId=1;pivots={};formulaIds={};compiledMeasureFormulas={};allowDispatch(e){switch(e.type){case"ADD_PIVOT":return this.checkDuplicatedMeasureIds(e.pivot);case"UPDATE_PIVOT":return mt(e.pivot,this.pivots[e.pivotId]?.definition)?"NoChanges":""===e.pivot.name?"EmptyName":this.checkDuplicatedMeasureIds(e.pivot);case"RENAME_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound";if(""===e.name)return"EmptyName";break;case"INSERT_PIVOT":case"DUPLICATE_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound"}return"Success"}handle(e){switch(e.type){case"ADD_PIVOT":{const{pivotId:t,pivot:o}=e;this.addPivot(t,o);break}case"INSERT_PIVOT":{const{sheetId:t,col:o,row:s,pivotId:i,table:n}=e,r={sheetId:t,col:o,row:s},{cols:a,rows:l,measures:c,fieldsType:h}=n,d=new QO(a,l,c,h||{}),u=this.getPivotFormulaId(i);this.insertPivot(r,u,d);break}case"RENAME_PIVOT":this.history.update("pivots",e.pivotId,"definition","name",e.name);break;case"REMOVE_PIVOT":{const t={...this.pivots};delete t[e.pivotId];const o=this.getPivotFormulaId(e.pivotId);this.history.update("formulaIds",o,void 0),this.history.update("pivots",t);break}case"DUPLICATE_PIVOT":{const{pivotId:t,newPivotId:o}=e,s=Be(this.getPivotCore(t).definition);s.name=e.duplicatedPivotName??s.name+" (copy)",this.addPivot(o,s);break}case"UPDATE_PIVOT":this.history.update("pivots",e.pivotId,"definition",e.pivot),this.compileCalculatedMeasures(e.pivot.measures)}}adaptRanges(e){for(const t in this.compiledMeasureFormulas)for(const o in this.compiledMeasureFormulas[t]){const s=this.compiledMeasureFormulas[t][o],i=[];for(const t of s.dependencies){const o=e(t);"NONE"===o.changeType?i.push(t):i.push(o.range)}const n=this.getters.getFormulaString(t,s.tokens,i);n!==o&&this.replaceMeasureFormula(t,o,n)}}getPivotDisplayName(e){return`(#${this.getPivotFormulaId(e)}) ${this.getPivotName(e)}`}getPivotName(e){return this.getPivotCore(e).definition.name}getPivotCoreDefinition(e){return this.getPivotCore(e).definition}getPivotId(e){return this.formulaIds[e]}getPivotFormulaId(e){return this.getPivotCore(e).formulaId}getPivotIds(){return Object.keys(this.pivots)}isExistingPivot(e){return e in this.pivots}getMeasureCompiledFormula(e){if(!e.computedBy)throw new Error(`Measure ${e.fieldName} is not computed by formula`);const t=e.computedBy.sheetId;return this.compiledMeasureFormulas[t][e.computedBy.formula]}addPivot(e,t,o=this.nextFormulaId.toString()){this.history.update("pivots",e,{definition:t,formulaId:o}),this.compileCalculatedMeasures(t.measures),this.history.update("formulaIds",o,e),this.history.update("nextFormulaId",this.nextFormulaId+1)}compileCalculatedMeasures(e){for(const t of e)if(t.computedBy){const e=t.computedBy.sheetId,o=this.compileMeasureFormula(t.computedBy.sheetId,t.computedBy.formula);this.history.update("compiledMeasureFormulas",e,t.computedBy.formula,o)}}insertPivot(e,t,o){this.resizeSheet(e.sheetId,e,o);const s=o.getPivotCells();for(let o=0;o<s.length;o++)for(let i=0;i<s[o].length;i++){const n=s[o][i];this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col+o,row:e.row+i,content:Jl(t,n)})}}resizeSheet(e,{col:t,row:o},s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,quantity:a-c,position:"after"})}getPivotCore(e){const t=this.pivots[e];if(!t)throw new Error(`Pivot with id ${e} not found`);return t}compileMeasureFormula(e,t){const o=hS(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return{...o,dependencies:s}}replaceMeasureFormula(e,t,o){this.history.update("compiledMeasureFormulas",e,t,void 0),this.history.update("compiledMeasureFormulas",e,o,this.compileMeasureFormula(e,o));for(const s in this.pivots){const i=this.pivots[s];if(i)for(const n of i.definition.measures)if(n.computedBy?.formula===t){const t=i.definition.measures.indexOf(n);this.history.update("pivots",s,"definition","measures",t,"computedBy",{formula:o,sheetId:e})}}}checkDuplicatedMeasureIds(e){const t=new Set(e.measures.map((e=>e.id)));return e.measures.length!==t.size?"InvalidDefinition":"Success"}import(e){if(e.pivots)for(const[t,o]of Object.entries(e.pivots))this.addPivot(t,o,o.formulaId);this.history.update("nextFormulaId",e.pivotNextId||Gl(this.pivots)+1)}export(e){e.pivots={};for(const t in this.pivots)e.pivots[t]={...this.getPivotCoreDefinition(t),formulaId:this.getPivotFormulaId(t)};e.pivotNextId=this.nextFormulaId}}).add("spreadsheet_pivot_core",class extends zM{adaptRanges(e){for(const t of this.getters.getPivotIds()){const o=this.getters.getPivotCoreDefinition(t);if("SPREADSHEET"===o.type&&o.dataSet){const{sheetId:s,zone:i}=o.dataSet,n=XM(this.getters.getRangeFromZone(s,i),e),r=n&&{sheetId:n.sheetId,zone:n.zone};this.dispatch("UPDATE_PIVOT",{pivotId:t,pivot:{...o,dataSet:r}})}}}}).add("tableStyle",class extends zM{static getters=["getNewCustomTableStyleName","getTableStyle","getTableStyles","isTableStyleEditable"];styles={};allowDispatch(e){switch(e.type){case"CREATE_TABLE":case"UPDATE_TABLE":if(e.config?.styleId&&!this.styles[e.config.styleId])return"InvalidTableConfig";break;case"CREATE_TABLE_STYLE":if(!fw[e.templateName])return"InvalidTableStyle";try{Bt(e.primaryColor)}catch(e){return"InvalidTableStyle"}}return"Success"}handle(e){switch(e.type){case"CREATE_TABLE_STYLE":const t=vw(e.tableStyleName,e.templateName,e.primaryColor);this.history.update("styles",e.tableStyleId,t);break;case"REMOVE_TABLE_STYLE":const o={...this.styles};delete o[e.tableStyleId],this.history.update("styles",o);for(const t of this.getters.getSheetIds())for(const o of this.getters.getCoreTables(t))o.config.styleId===e.tableStyleId&&this.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{styleId:QC.styleId}})}}getTableStyle(e){if(!this.styles[e])throw new Error(`Table style ${e} does not exist`);return this.styles[e]}getTableStyles(){return this.styles}getNewCustomTableStyleName(){return Nt(Fo("Custom Table Style"),Object.values(this.styles).map((e=>e.displayName)),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!mw[e]}import(e){for(const e in mw)this.styles[e]=mw[e];for(const t in e.customTableStyles){const o=e.customTableStyles[t];this.styles[t]=vw(o.displayName,o.templateName,o.primaryColor)}}export(e){const t={};for(const e in this.styles)mw[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}}),fN=(new n).add("ui_sheet",class extends HP{static getters=["doesCellHaveGridIcon","getCellWidth","getCellIconSrc","getTextWidth","getCellText","getCellMultiLineText","getContiguousZone"];ctx=document.createElement("canvas").getContext("2d");allowDispatch(e){return this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e)}handle(e){switch(e.type){case"AUTORESIZE_COLUMNS":for(let t of e.cols){const o=this.getColMaxWidth(e.sheetId,t);0!==o&&this.dispatch("RESIZE_COLUMNS_ROWS",{elements:[t],dimension:"COL",size:o,sheetId:e.sheetId})}break;case"AUTORESIZE_ROWS":this.dispatch("RESIZE_COLUMNS_ROWS",{elements:e.rows,dimension:"ROW",size:null,sheetId:e.sheetId})}}getCellWidth(e){const t=this.getters.getCellComputedStyle(e);let o=0;const s=this.getters.getEvaluatedCell(e).formattedValue;if(s){const e=oa(this.ctx,s,t,void 0);o+=Math.max(...e.map((e=>jr(this.ctx,e,t))))}if(this.getters.getCellIconSrc(e)&&(o+=function(e){return ea(e)+8}(t)),this.getters.doesCellHaveGridIcon(e)&&(o+=20),0===o)return 0;if(o+=2*re,"wrap"===t.wrapping){const t=this.getters.getColSize(this.getters.getActiveSheetId(),e.col);return Math.min(t,o)}return o}getCellIconSrc(e){const t=by.getAll();for(const o of t){const t=o(this.getters,e);if(t)return t}}getTextWidth(e,t){return jr(this.ctx,e,t)}getCellText(e,t){const o=this.getters.getCell(e),s=this.getters.getLocale();if(t?.showFormula&&o?.isFormula)return Pa(o.content,s);if(t?.showFormula&&!o?.content)return"";{const i=this.getters.getEvaluatedCell(e),n=t?.availableWidth?{availableWidth:t.availableWidth,measureText:e=>jr(this.ctx,e,o?.style||{})}:void 0;return Jn(i.value,{format:i.format,locale:s,formatWidth:n})}}getCellMultiLineText(e,t){const o=this.getters.getCellStyle(e),s=this.getters.getCellText(e,{showFormula:this.getters.shouldShowFormulas(),availableWidth:t.maxWidth});return oa(this.ctx,s,o,t.wrapText?t.maxWidth:void 0)}doesCellHaveGridIcon(e){const t=this.getters.isFilterHeader(e),o=!this.getters.isReadonly()&&this.getters.cellHasListDataValidationIcon(e);return t||o}getContiguousZone(e,t){const o=t=>{for(const o of Ze(t.left,t.right+1)){if(!this.isCellEmpty({sheetId:e,col:o,row:t.top-1}))return{...t,top:t.top-1};if(!this.isCellEmpty({sheetId:e,col:o,row:t.bottom+1}))return{...t,bottom:t.bottom+1}}for(const o of Ze(t.top,t.bottom+1)){if(!this.isCellEmpty({sheetId:e,col:t.left-1,row:o}))return{...t,left:t.left-1};if(!this.isCellEmpty({sheetId:e,col:t.right+1,row:o}))return{...t,right:t.right+1}}return t};let s=!1,i=t;do{s=!1;const e=o(i);ns(i,e)||(s=!0,i=e)}while(s);return i}isCellEmpty(e){const t=this.getters.getMainCellPosition(e);return this.getters.getEvaluatedCell(t).type===ni.empty}getColMaxWidth(e,t){const o=us(this.getters.getColsZone(e,t,t)).map((t=>this.getCellWidth({sheetId:e,...t})));return Math.max(0,Dt(o))}checkSheetExists(e){return"sheetId"in e&&void 0===this.getters.tryGetSheet(e.sheetId)?"InvalidSheetId":"Success"}checkZonesAreInSheet(e){const t="sheetId"in e?e.sheetId:this.getters.tryGetActiveSheetId(),o=this.getters.getCommandZones(e);return!t&&o.length>0?"NoActiveSheet":t&&o.length>0?this.getters.checkZonesExistInSheet(t,o):"Success"}}).add("ui_options",class extends HP{static getters=["shouldShowFormulas"];showFormulas=!1;handle(e){if("SET_FORMULA_VISIBILITY"===e.type)this.showFormulas=e.show}shouldShowFormulas(){return this.showFormulas}}).add("autofill",class extends HP{static layers=["Autofill"];static getters=["getAutofillTooltip"];autofillZone;steps;lastCellSelected={};direction;tooltip;allowDispatch(e){if("AUTOFILL_SELECT"===e.type){const t=this.getters.getActiveSheetId();return this.lastCellSelected.col=-1===e.col?this.lastCellSelected.col:qe(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=-1===e.row?this.lastCellSelected.row:qe(e.row,0,this.getters.getNumberRows(t)),void 0!==this.lastCellSelected.col&&void 0!==this.lastCellSelected.row?"Success":"InvalidAutofillSelection"}return"Success"}handle(e){switch(e.type){case"AUTOFILL":this.autofill(!0);break;case"AUTOFILL_SELECT":this.select(e.col,e.row);break;case"AUTOFILL_AUTO":this.autofillAuto();break;case"AUTOFILL_CELL":this.autoFillMerge(e.originCol,e.originRow,e.col,e.row);const t=this.getters.getActiveSheetId();this.dispatch("UPDATE_CELL",{sheetId:t,col:e.col,row:e.row,style:e.style||null,content:e.content||"",format:e.format||""}),this.dispatch("SET_BORDER",{sheetId:t,col:e.col,row:e.row,border:e.border}),this.autofillCF(e.originCol,e.originRow,e.col,e.row),this.autofillDV(e.originCol,e.originRow,e.col,e.row)}}getAutofillTooltip(){return this.tooltip}autofill(e){if(!this.autofillZone||!this.steps||void 0===this.direction)return void(this.tooltip=void 0);const t=this.getters.getSelectedZone(),o=this.autofillZone;switch(this.direction){case"down":for(let s=t.left;s<=t.right;s++){const i=[];for(let e=t.top;e<=t.bottom;e++)i.push(yo(s,e));const n=this.createGenerator(i);for(let t=o.top;t<=o.bottom;t++)this.computeNewCell(n,s,t,e)}break;case"up":for(let s=t.left;s<=t.right;s++){const i=[];for(let e=t.bottom;e>=t.top;e--)i.push(yo(s,e));const n=this.createGenerator(i);for(let t=o.bottom;t>=o.top;t--)this.computeNewCell(n,s,t,e)}break;case"left":for(let s=t.top;s<=t.bottom;s++){const i=[];for(let e=t.right;e>=t.left;e--)i.push(yo(e,s));const n=this.createGenerator(i);for(let t=o.right;t>=o.left;t--)this.computeNewCell(n,t,s,e)}break;case"right":for(let s=t.top;s<=t.bottom;s++){const i=[];for(let e=t.left;e<=t.right;e++)i.push(yo(e,s));const n=this.createGenerator(i);for(let t=o.left;t<=o.right;t++)this.computeNewCell(n,t,s,e)}}e&&(this.autofillZone=void 0,this.selection.resizeAnchorZone(this.direction,this.steps),this.lastCellSelected={},this.direction=void 0,this.steps=0,this.tooltip=void 0)}select(e,t){const o=this.getters.getSelectedZone();if(as(e,t,o))this.autofillZone=void 0;else{switch(this.direction=this.getDirection(e,t),this.direction){case"up":this.saveZone(t,o.top-1,o.left,o.right),this.steps=o.top-t;break;case"down":this.saveZone(o.bottom+1,t,o.left,o.right),this.steps=t-o.bottom;break;case"left":this.saveZone(o.top,o.bottom,e,o.left-1),this.steps=o.left-e;break;case"right":this.saveZone(o.top,o.bottom,o.right+1,e),this.steps=e-o.right}this.autofill(!1)}}autofillAuto(){const e=this.getters.getActivePosition(),t=this.getters.getTable(e);let o=t?t.range.zone.bottom:this.getAutofillAutoLastRow();const s=this.getters.getSelectedZone();for(let t=s.bottom+1;t<=o;t++)if(this.getters.getEvaluatedCell({...e,row:t}).type!==ni.empty){o=t-1;break}o>s.bottom&&(this.select(e.col,o),this.autofill(!0))}getAutofillAutoLastRow(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();let o=e.left,s=e.bottom;if(o>0){let e={sheetId:t,col:o-1,row:s};for(;this.getters.getEvaluatedCell(e).type!==ni.empty;)s+=1,e={sheetId:t,col:o-1,row:s}}if(s===e.bottom&&(o=e.right,o<=this.getters.getNumberCols(t))){let e={sheetId:t,col:o+1,row:s};for(;this.getters.getEvaluatedCell(e).type!==ni.empty;)s+=1,e={sheetId:t,col:o+1,row:s}}return s-1}computeNewCell(e,t,o,s){const{cellData:i,tooltip:n,origin:r}=e.next(),{content:a,style:l,border:c,format:h}=i;this.tooltip=n,s&&this.dispatch("AUTOFILL_CELL",{originCol:r.col,originRow:r.row,col:t,row:o,content:a,style:l,border:c,format:h})}getRule(e,t){const o=IS.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((o=>o.condition(e,t)));return o&&o.generateRule(e,t)}createGenerator(e){const t=[],o=[],s=this.getters.getActiveSheetId();for(let t of e){const{col:e,row:i}=So(t),n=this.getters.getCell({sheetId:s,col:e,row:i});o.push({col:e,row:i,cell:n,sheetId:s})}const i=o.map((e=>e.cell));for(let e of o){let o={type:"COPY_MODIFIER"};if(e&&e.cell){o=this.getRule(e.cell,i)||o}const s=this.getters.getCellBorder(e)||void 0;t.push({data:{...e,border:s},rule:o})}return new UP(t,this.getters,this.direction)}saveZone(e,t,o,s){this.autofillZone={top:e,bottom:t,left:o,right:s}}getDirection(e,t){const o=this.getters.getSelectedZone(),s={up:{number:o.top-t,value:"up"},down:{number:t-o.bottom,value:"down"},left:{number:o.left-e,value:"left"},right:{number:e-o.right,value:"right"}};if(1===Object.values(s).map((e=>e.number>0?1:0)).reduce(((e,t)=>e+t)))return Object.values(s).find((e=>e.number>0?1:0)).value;const i=s.up.number>0?"up":"down",n=s.left.number>0?"left":"right";return Math.abs(s[i].number)>=Math.abs(s[n].number)?s[i].value:s[n].value}autoFillMerge(e,t,o,s){const i=this.getters.getActiveSheetId(),n={sheetId:i,col:o,row:s},r={sheetId:i,col:e,row:t};if(this.getters.isInMerge(n)&&!this.getters.isInMerge(r)){const e=this.getters.getMerge(n);e&&this.dispatch("REMOVE_MERGE",{sheetId:i,target:[e]})}const a=this.getters.getMerge(r);a?.left===e&&a?.top===t&&this.dispatch("ADD_MERGE",{sheetId:i,target:[{top:s,bottom:s+a.bottom-a.top,left:o,right:o+a.right-a.left}]})}autofillCF(e,t,o,s){const i=this.getters.getActiveSheetId(),n=this.getters.getRulesByCell(i,e,t);for(const e of n){const t=this.getters.getAdaptedCfRanges(i,e,[fs({col:o,row:s})],[]);t&&this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:Be(e),ranges:t,sheetId:i})}}autofillDV(e,t,o,s){const i=this.getters.getActiveSheetId(),n={sheetId:i,col:e,row:t},r=this.getters.getValidationRuleForCell(n);if(!r)return;const a=r.ranges.map((e=>e.zone)),l=Co(a.concat(fs({col:o,row:s})),[]);this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:r,ranges:l.map((e=>this.getters.getRangeDataFromZone(i,e))),sheetId:i})}drawLayer(e){if(!this.autofillZone)return;const{ctx:t,thinLineWidth:o}=e,{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(this.autofillZone);n>0&&r>0&&(t.strokeStyle="black",t.lineWidth=o,t.setLineDash([3]),t.strokeRect(s,i,n,r),t.setLineDash([]))}}).add("sort",class extends HP{allowDispatch(e){return"SORT_CELLS"===e.type?as(e.col,e.row,e.zone)?this.checkValidations(e,this.checkMerge,this.checkMergeSizes,this.checkArrayFormulaInSortZone):"InvalidSortAnchor":"Success"}handle(e){if("SORT_CELLS"===e.type)this.sortZone(e.sheetId,e,e.zone,e.sortDirection,e.sortOptions||{})}checkMerge({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";return us(t).some((({col:t,row:o})=>!this.getters.isInMerge({sheetId:e,col:t,row:o})))?"InvalidSortZone":"Success"}checkMergeSizes({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";const o=this.getters.getMerges(e).filter((e=>rs(e,t))),s=cs(o[0]);let[i,n]=[s.numberOfCols,s.numberOfRows];return o.every((e=>{let[t,o]=[e.right-e.left+1,e.bottom-e.top+1];return t===i&&o===n}))?"Success":"InvalidSortZone"}checkArrayFormulaInSortZone({sheetId:e,zone:t}){return us(t).some((({col:t,row:o})=>this.getters.getArrayFormulaSpreadingOn({sheetId:e,col:t,row:o})))?"SortZoneWithArrayFormulas":"Success"}hasHeader(e,t){if(1===t[0].length)return!1;let o=t.map((t=>t.map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).type))));return o[0][0]===ni.empty&&(o=o.slice(1)),!o.some((e=>e[0]===ni.empty))&&!!o.some((e=>e[1]!==ni.empty&&e[0]!==e[1]))}sortZone(e,t,o,s,i){const[n,r]=this.mainCellsSteps(e,o);let a=this.getters.getMainCellPosition({sheetId:e,col:t.col,row:t.row}).col,l=Object.assign({},o),c=this.mainCells(e,o);!i.sortHeaders&&this.hasHeader(e,c)&&(l.top+=r),c=this.mainCells(e,l);const h=function(e,t,o){const s=e.map(((e,t)=>({index:t,type:e.type,value:e.value})));return(o?s.map((e=>e.type===ni.empty?{...e,type:ni.number,value:0}:e)):s).sort(Tp(t))}(c[a-l.left].map((e=>this.getters.getEvaluatedCell(e))),s,Boolean(i.emptyCellAsZero)),d=h.map((e=>e.index)),[u,g]=[c.length,c[0].length],p=[];for(let e=0;e<u;e++)for(let t=0;t<g;t++){let{col:o,row:s,sheetId:i}=c[e][d[t]];const a=this.getters.getCell({sheetId:i,col:o,row:s});let h=l.left+e*n,u=l.top+t*r,g={sheetId:i,col:h,row:u,content:""};if(a){let e=a.content;if(a.isFormula){const t=this.getters.getCellPosition(a.id);e=this.getters.getTranslatedCellFormula(i,0,u-t.row,a.compiledFormula.tokens)}g.style=a.style,g.content=e,g.format=a.format}p.push(g)}p.forEach((e=>this.dispatch("UPDATE_CELL",e)))}mainCellsSteps(e,t){const o=this.getters.getMerge({sheetId:e,col:t.left,row:t.top});return[o?o.right-o.left+1:1,o?o.bottom-o.top+1:1]}mainCells(e,t){const[o,s]=this.mainCellsSteps(e,t),i=[],n=Ze(t.left,t.right+1,o),r=Ze(t.top,t.bottom+1,s);for(const t of n){const o=[];i.push(o);for(const s of r)o.push({sheetId:e,col:t,row:s})}return i}}).add("automatic_sum",class extends HP{static getters=["getAutomaticSums"];handle(e){if("SUM_SELECTION"===e.type){const e=this.getters.getActiveSheetId(),{zones:t,anchor:o}=this.getters.getSelection();for(const s of t){const t=this.getAutomaticSums(e,s,o.cell);this.dispatchCellUpdates(e,t)}}}getAutomaticSums(e,t,o){return this.shouldFindData(e,t)?this.sumAdjacentData(e,t,o):this.sumData(e,t)}sumData(e,t){const o=this.dimensionsToSum(e,t),s=this.sumDimensions(e,t,o).filter((({zone:t})=>!this.getters.isEmpty(e,t)));return o.has("ROW")&&o.has("COL")&&s.push(this.sumTotal(t)),s}sumAdjacentData(e,t,o){const{col:s,row:i}=as(o.col,o.row,t)?o:{col:t.left,row:t.top},n=this.findAdjacentData(e,s,i);return n?this.getters.isSingleCellOrMerge(e,t)||hs(ss(n,t))?[{position:{col:s,row:i},zone:n}]:this.sumDimensions(e,ss(n,t),this.transpose(this.dimensionsToSum(e,t))):[]}findAdjacentData(e,t,o){const s=this.getters.getSheet(e),i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.findSuitableZoneToSum(s,i.col,i.row);if(n)return this.getters.expandZone(e,n)}findSuitableZoneToSum(e,t,o){const s=this.getters.getEvaluatedCell({sheetId:e.id,col:t,row:o-1}),i=this.getters.getEvaluatedCell({sheetId:e.id,col:t-1,row:o});if(this.isNumber(i)&&!this.isNumber(s))return this.findHorizontalZone(e,t,o);const n=this.findVerticalZone(e,t,o);if(this.isZoneValid(n))return n;const r=this.findHorizontalZone(e,t,o);return this.isZoneValid(r)?r:void 0}findVerticalZone(e,t,o){const s={top:0,bottom:o-1,left:t,right:t},i=this.reduceZoneStart(e,s,s.bottom);return{...s,top:i}}findHorizontalZone(e,t,o){const s={top:o,bottom:o,left:0,right:t-1},i=this.reduceZoneStart(e,s,s.right);return{...s,left:i}}reduceZoneStart(e,t,o){const s=this.getters.getEvaluatedCellsInZone(e.id,t),i=Ze(o,-1,-1),n=Dt(i.filter((e=>s[e]&&!s[e].isAutoSummable))),r=je(i.filter((e=>this.isNumber(s[e]))))[0]||[];return Dt(r)<n?1/0:Ot(r)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===ni.number&&!(e.format&&rr(e.format))}isZoneValid(e){return e.bottom>=e.top&&e.right>=e.left}lastColIsEmpty(e,t){return this.getters.isEmpty(e,{...t,left:t.right})}lastRowIsEmpty(e,t){return this.getters.isEmpty(e,{...t,top:t.bottom})}dimensionsToSum(e,t){const o=new Set;return hs(t)?(o.add(1===cs(t).numberOfCols?"COL":"ROW"),o):(this.lastColIsEmpty(e,t)&&o.add("ROW"),this.lastRowIsEmpty(e,t)&&o.add("COL"),0===o.size&&o.add("COL"),o)}sumDimensions(e,t,o){return[...o.has("COL")?this.sumColumns(t,e):[],...o.has("ROW")?this.sumRows(t,e):[]]}sumTotal(e){const{bottom:t,right:o}=e;return{position:{col:o,row:t},zone:{...e,top:t,right:o-1}}}sumColumns(e,t){const o=this.nextEmptyRow(t,{...e,bottom:e.bottom-1});return e={...e,bottom:Math.min(e.bottom,o.bottom-1)},us(o).map((t=>({position:t,zone:{...e,right:t.col,left:t.col}})))}sumRows(e,t){const o=this.nextEmptyCol(t,{...e,right:e.right-1});return e={...e,right:Math.min(e.right,o.right-1)},us(o).map((t=>({position:t,zone:{...e,top:t.row,bottom:t.row}})))}dispatchCellUpdates(e,t){for(const o of t){const{col:t,row:s}=o.position;this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:`=SUM(${this.getters.zoneToXC(e,o.zone)})`})}}nextEmptyRow(e,t){let o=t.bottom+1;const{left:s,right:i}=t;for(;!this.getters.isEmpty(e,{bottom:o,top:o,left:s,right:i});)o++;return{...t,top:o,bottom:o}}nextEmptyCol(e,t){let o=t.right+1;const{top:s,bottom:i}=t;for(;!this.getters.isEmpty(e,{left:o,right:o,top:s,bottom:i});)o++;return{...t,left:o,right:o}}transpose(e){return new Set([...e.values()].map((e=>"COL"===e?"ROW":"COL")))}}).add("format",class extends HP{handle(e){switch(e.type){case"SET_DECIMAL":this.setDecimal(e.sheetId,e.target,e.step);break;case"SET_FORMATTING_WITH_PIVOT":this.setContextualFormat(e.sheetId,e.target,e.format)}}setContextualFormat(e,t,o){const s=[],i={};for(const o of Co(t))for(let t=o.left;t<=o.right;t++)for(let n=o.top;n<=o.bottom;n++){const o={sheetId:e,col:t,row:n},r=this.getters.getPivotCellFromPosition(o);if(this.isSpilledPivotValueFormula(o,r)){s.push(o);const e=this.getters.getPivotIdFromPosition(o)||"";i[e]??=new Set,i[e].add(r.measure)}}const n=Co(s.map(fs));for(const e in i){const t=i[e],s=this.getters.getPivotCoreDefinition(e);this.dispatch("UPDATE_PIVOT",{pivotId:e,pivot:{...s,measures:s.measures.map((e=>t.has(e.id)?{...e,format:o}:e))}})}this.dispatch("SET_FORMATTING",{sheetId:e,target:n,format:""}),this.dispatch("SET_FORMATTING",{sheetId:e,target:Co(t,n),format:o})}isSpilledPivotValueFormula(e,t){const o=this.getters.getCell(e);return"VALUE"===t.type&&!o?.isFormula}setDecimal(e,t,o){const s={};for(const i of Co(t))for(const t of us(i)){const i=this.getCellNumberFormat({sheetId:e,...t});if(void 0!==i){const e=Cr(i,o);s[e]=s[e]||[],s[e].push(t)}}for(const t in s){const o=Co(s[t].map((e=>fs(e))));this.setContextualFormat(e,o,t)}}getCellNumberFormat(e){for(const t of[e]){const e=this.getters.getEvaluatedCell(t);if(!(e.type!==ni.number||e.format&&rr(e.format)))return e.format||cr(e.value)}}}).add("insert_pivot",class extends HP{static getters=[];allowDispatch(e){if("DUPLICATE_PIVOT_IN_NEW_SHEET"===e.type){if(!this.getters.isExistingPivot(e.pivotId))return"PivotIdNotFound";if(!this.getters.getPivot(e.pivotId).isValid())return"PivotInError"}return"Success"}handle(e){switch(e.type){case"INSERT_NEW_PIVOT":this.insertNewPivot(e.pivotId,e.newSheetId);break;case"DUPLICATE_PIVOT_IN_NEW_SHEET":this.duplicatePivotInNewSheet(e.pivotId,e.newPivotId,e.newSheetId);break;case"INSERT_PIVOT_WITH_TABLE":this.insertPivotWithTable(e.sheetId,e.col,e.row,e.pivotId,e.table,e.pivotMode);break;case"SPLIT_PIVOT_FORMULA":this.splitPivotFormula(e.sheetId,e.col,e.row,e.pivotId)}}insertNewPivot(e,t){1===Ss(this.getters.getSelectedZone())&&this.selection.selectTableAroundSelection();const o=this.getters.getActiveSheetId();this.dispatch("ADD_PIVOT",{pivotId:e,pivot:{dataSet:{zone:this.getters.getSelectedZone(),sheetId:o},columns:[],rows:[],measures:[],name:Fo("New pivot"),type:"SPREADSHEET"}});const s=this.getters.getSheetIds().findIndex((e=>e===o))+1,i=this.getters.getPivotFormulaId(e);this.dispatch("CREATE_SHEET",{sheetId:t,name:Fo("Pivot #%(formulaId)s",{formulaId:i}),position:s}),this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:o,sheetIdTo:t});const n=this.getters.getPivot(e);this.insertPivotWithTable(t,0,0,e,n.getTableStructure().export(),"dynamic")}duplicatePivotInNewSheet(e,t,o){this.dispatch("DUPLICATE_PIVOT",{pivotId:e,newPivotId:t,duplicatedPivotName:Fo("%s (copy)",this.getters.getPivotCoreDefinition(e).name)});const s=this.getters.getActiveSheetId(),i=this.getters.getSheetIds().indexOf(s)+1,n=this.getters.getPivotFormulaId(t),r=this.getters.getPivotName(t);if(this.dispatch("CREATE_SHEET",{sheetId:o,name:this.getPivotDuplicateSheetName(Fo("%(newPivotName)s (Pivot #%(formulaId)s)",{newPivotName:r,formulaId:n})),position:i}).isSuccessful){this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:s,sheetIdTo:o});const i=this.getters.getPivot(e);this.insertPivotWithTable(o,0,0,t,i.getTableStructure().export(),"dynamic")}}getPivotDuplicateSheetName(e){const t=this.getters.getSheetIds().map((e=>this.getters.getSheetName(e)));return Nt(Ge(e),t)}insertPivotWithTable(e,t,o,s,i,n){const{cols:r,rows:a,measures:l,fieldsType:c}=i,h=new QO(r,a,l,c||{}),d=h.columns.length-1;this.resizeSheet(e,t,o,h);const u=this.getters.getPivotFormulaId(s);let g;"dynamic"===n?(this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:o,content:`=PIVOT(${u})`}),g={left:t,right:t,top:o,bottom:o}):(this.dispatch("INSERT_PIVOT",{sheetId:e,col:t,row:o,pivotId:s,table:h.export()}),g={left:t,right:t+h.getNumberOfDataColumns(),top:o,bottom:o+d+h.rows.length}),this.dispatch("CREATE_TABLE",{tableType:n,sheetId:e,ranges:[this.getters.getRangeDataFromZone(e,g)],config:{...ke,numberOfHeaders:d}})}resizeSheet(e,t,o,s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,quantity:a-c,position:"after"})}splitPivotFormula(e,t,o,s){const i=this.getters.getSpreadZone({sheetId:e,col:t,row:o});if(!i)return;const n=this.getters.getPivotFormulaId(s),r=new Map;for(let t=i.left;t<=i.right;t++)for(let o=i.top;o<=i.bottom;o++){const s={sheetId:e,col:t,row:o};r.set(s,this.getters.getPivotCellFromPosition(s))}for(const[e,t]of r)this.dispatch("UPDATE_CELL",{...e,content:Jl(n,t)});const a=this.getters.getCoreTable({sheetId:e,col:t,row:o});if("dynamic"===a?.type){const s=fs({col:t,row:o}),n=this.getters.getRangeDataFromZone(e,i);this.dispatch("UPDATE_TABLE",{sheetId:e,zone:s,newTableRange:n,tableType:"static"})}}}).add("split_to_columns",class extends HP{static getters=["getAutomaticSeparator"];allowDispatch(e){return"SPLIT_TEXT_INTO_COLUMNS"===e.type?this.chainValidations(this.batchValidations(this.checkSingleColSelected,this.checkNonEmptySelector),this.batchValidations(this.checkNotOverwritingContent,this.checkSeparatorInSelection))(e):"Success"}handle(e){if("SPLIT_TEXT_INTO_COLUMNS"===e.type)this.splitIntoColumns(e)}getAutomaticSeparator(){const e=this.getters.getSelectedCells();for(const t of e)if(t.value&&t.type===ni.text){const e=this.getAutoSeparatorForString(t.value);if(e)return e}return" "}getAutoSeparatorForString(e){const t=[Pe,";",","," ","."];for(const o of t)if(e.includes(o))return o}splitIntoColumns({separator:e,addNewColumns:t}){const o=this.getters.getSelectedZone(),s=this.getters.getActiveSheetId(),i=this.getSplittedCols(o,e);t&&this.addColsToAvoidCollisions(o,i),this.removeMergesInSplitZone(o,i),this.addColumnsToNotOverflowSheet(o,i);for(let e=0;e<i.length;e++){const t=o.top+e,n=i[e],r=o.left,a=this.getters.getCell({sheetId:s,col:r,row:t});if(1!==n.length||n[0]!==a?.content)for(const[e,o]of n.entries())this.dispatch("UPDATE_CELL",{sheetId:s,col:r+e,row:t,content:Da(o,this.getters.getLocale()),format:"",style:a?.style||null})}}getSplittedCols(e,t){if(!t)throw new Error("Separator cannot be empty");const o=this.getters.getActiveSheetId(),s=[];for(const i of Ze(e.top,e.bottom+1)){const n=this.getters.getEvaluatedCell({sheetId:o,col:e.left,row:i}).formattedValue;s.push(this.splitAndRemoveTrailingEmpty(n,t))}return s}splitAndRemoveTrailingEmpty(e,t){const o=e.split(t);for(;o.length>1&&""===o[o.length-1];)o.pop();return o}willSplittedColsOverwriteContent(e,t){const o=this.getters.getActiveSheetId();for(const s of Ze(e.top,e.bottom+1)){const i=t[s-e.top];for(let t=1;t<i.length;t++){const i=this.getters.getCell({sheetId:o,col:e.left+t,row:s});if(i&&i.content)return!0}}return!1}removeMergesInSplitZone(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length))),i={...e,right:e.left+s-1},n=this.getters.getMergesInZone(o,i);this.dispatch("REMOVE_MERGE",{sheetId:o,target:n})}addColsToAvoidCollisions(e,t){const o=this.getters.getActiveSheetId();let s=0;for(const i of Ze(e.top,e.bottom+1)){const n={sheetId:o,col:e.left,row:i},r=t[i-e.top],a=this.getColsToAddToAvoidCollision(n,r);s=Math.max(s,a)}s&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:e.left,sheetId:o,quantity:s,position:"after"})}getColsToAddToAvoidCollision(e,t){const o=t.length;for(let t=1;t<o;t++){const s=e.col+t,i=this.getters.getCell({...e,col:s});if(i&&i.content)return o-t}return 0}addColumnsToNotOverflowSheet(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length-1))),i=this.getters.getNumberCols(o)-1;e.left+s>i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:i,sheetId:o,quantity:e.left+s-i,position:"after"})}checkSingleColSelected(){return this.getters.isSingleColSelected()?"Success":"MoreThanOneColumnSelected"}checkNonEmptySelector(e){return""===e.separator?"EmptySplitSeparator":"Success"}checkNotOverwritingContent(e){if(e.addNewColumns||e.force)return"Success";const t=this.getters.getSelectedZones()[0],o=this.getSplittedCols(t,e.separator);return this.willSplittedColsOverwriteContent(t,o)?"SplitWillOverwriteContent":"Success"}checkSeparatorInSelection({separator:e}){const t=this.getters.getSelectedCells();for(const o of t)if(o.formattedValue.includes(e))return"Success";return"NoSplitSeparatorInSelection"}}).add("collaborative",class extends HP{static getters=["getClientsToDisplay","getClient","getConnectedClients","isFullySynchronized"];static layers=["Selection"];availableColors=new uo(12);colors={};session;constructor(e){super(e),this.session=e.session}isPositionValid(e){return e.row<this.getters.getNumberRows(e.sheetId)&&e.col<this.getters.getNumberCols(e.sheetId)}getClient(){return this.session.getClient()}getConnectedClients(){return this.session.getConnectedClients()}isFullySynchronized(){return this.session.isFullySynchronized()}getClientsToDisplay(){try{this.getters.getClient()}catch(e){if(e instanceof JP)return[];throw e}const e=this.getters.getActiveSheetId(),t=[];for(const o of this.getters.getConnectedClients())if(o.id!==this.getters.getClient().id&&o.position&&o.position.sheetId===e&&this.isPositionValid(o.position)){const e=o.position;this.colors[o.id]||(this.colors[o.id]=this.availableColors.next());const s=this.colors[o.id];t.push({...o,position:e,color:s})}return t}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getters.getActiveSheetId();for(const e of this.getClientsToDisplay()){const{row:i,col:n}=e.position,r=this.getters.expandZone(s,{top:i,bottom:i,left:n,right:n}),{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);if(c<=0||h<=0)continue;const d=e.color;t.fillStyle=`${d}10`,t.lineWidth=4*o,t.strokeStyle=d,t.globalCompositeOperation="multiply",t.fillRect(a,l,c,h),t.globalCompositeOperation="source-over",t.strokeRect(a,l,c,h),t.font=`bold ${me+1}px ${fe}`}}}).add("history",class extends HP{static getters=["canUndo","canRedo"];undoStack=[];redoStack=[];session;constructor(e){super(e),this.session=e.session,this.session.on("new-local-state-update",this,this.onNewLocalStateUpdate),this.session.on("pending-revisions-dropped",this,(({revisionIds:e})=>this.drop(e))),this.session.on("snapshot",this,(()=>{this.undoStack=[],this.redoStack=[]}))}allowDispatch(e){switch(e.type){case"REQUEST_UNDO":if(!this.canUndo())return"EmptyUndoStack";break;case"REQUEST_REDO":if(!this.canRedo())return"EmptyRedoStack"}return"Success"}handle(e){switch(e.type){case"REQUEST_UNDO":case"REQUEST_REDO":this.requestHistoryChange("REQUEST_UNDO"===e.type?"UNDO":"REDO")}}finalize(){}requestHistoryChange(e){const t="UNDO"===e?this.undoStack.pop():this.redoStack.pop();if(t)"UNDO"===e?(this.session.undo(t),this.redoStack.push(t)):(this.session.redo(t),this.undoStack.push(t));else{const e=this.getPossibleRevisionToRepeat();if(!e)return;const t=gN(e,this.getters);if(!t)return;if(!Array.isArray(t))return void this.dispatch(t.type,t);for(const e of t)this.dispatch(e.type,e)}}canUndo(){return this.undoStack.length>0}canRedo(){if(this.redoStack.length>0)return!0;const e=this.getPossibleRevisionToRepeat();return!(!(t=e)||!t.rootCommand||"object"!=typeof t.rootCommand)&&(pi(t.rootCommand)?hN.contains(t.rootCommand.type):dN.contains(t.rootCommand.type));var t}drop(e){this.undoStack=this.undoStack.filter((t=>!e.includes(t))),this.redoStack=[]}onNewLocalStateUpdate({id:e}){this.undoStack.push(e),this.redoStack=[],this.undoStack.length>99&&this.undoStack.shift()}getPossibleRevisionToRepeat(){return this.session.getLastLocalNonEmptyRevision()}}).add("data_cleanup",class extends HP{allowDispatch(e){return"REMOVE_DUPLICATES"===e.type?this.checkValidations(e,this.chainValidations(this.checkSingleRangeSelected,this.checkNoMergeInZone,this.checkRangeContainsValues,this.checkColumnsIncludedInZone),this.chainValidations(this.checkNoColumnProvided,this.checkColumnsAreUnique)):"Success"}handle(e){switch(e.type){case"REMOVE_DUPLICATES":this.removeDuplicates(e.columns,e.hasHeader);break;case"TRIM_WHITESPACE":this.trimWhitespace()}}removeDuplicates(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.getSelectedZone();t&&(s.top+=1);const i=this.getUniqueRowsIndexes(o,s.top,s.bottom,e),n=i.length;if(n===cs(s).numberOfRows)return void this.notifyRowsRemovedAndRemaining(0,n);const r=i.map((e=>({left:s.left,top:e,right:s.right,bottom:e}))),a=new lc(this.getters,this.dispatch),l=a.copy(la(o,r));if(!l)return;this.dispatch("CLEAR_CELLS",{target:[s],sheetId:o});const c={left:s.left,top:s.top,right:s.left,bottom:s.top};a.paste({zones:[c],sheetId:o},l,{isCutOperation:!1});const h={left:s.left,top:s.top-(t?1:0),right:s.right,bottom:s.top+n-1};this.selection.selectZone({cell:{col:h.left,row:h.top},zone:h});const d=s.bottom-s.top+1-n;this.notifyRowsRemovedAndRemaining(d,n)}getUniqueRowsIndexes(e,t,o,s){const i=new Map;for(const n of Ze(t,o+1)){const t=s.map((t=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}).value));!Object.values(i).some((e=>mt(e,t)))&&(i[n]=t)}return Object.keys(i).map((e=>parseInt(e)))}notifyRowsRemovedAndRemaining(e,t){this.ui.notifyUI({type:"info",text:Fo("%s duplicate rows found and removed.\n%s unique rows remain.",e.toString(),t.toString()),sticky:!1})}checkSingleRangeSelected(){return 1!==this.getters.getSelectedZones().length?"MoreThanOneRangeSelected":"Success"}checkNoMergeInZone(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZone();return this.getters.getMergesInZone(e,t).length>0?"WillRemoveExistingMerge":"Success"}checkRangeContainsValues(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedZone();e.hasHeader&&(o.top+=1);return this.getters.getEvaluatedCellsInZone(t,o).every((e=>"empty"===e.type))?"EmptyTarget":"Success"}checkNoColumnProvided(e){return 0===e.columns.length?"NoColumnsProvided":"Success"}checkColumnsIncludedInZone(e){const t=this.getters.getSelectedZone();return e.columns.some((e=>e<t.left||e>t.right))?"ColumnsNotIncludedInZone":"Success"}checkColumnsAreUnique(e){return e.columns.length!==new Set(e.columns).size?"DuplicatesColumnsSelected":"Success"}trimWhitespace(){const e=Co(this.getters.getSelectedZones()),t=this.getters.getActiveSheetId();let o=0;for(const{col:s,row:i}of e.map(us).flat()){const e=this.getters.getCell({col:s,row:i,sheetId:t});if(!e)continue;const n=Tt(e.content);n!==e.content&&(o+=1,this.dispatch("UPDATE_CELL",{sheetId:t,col:s,row:i,content:n}))}const s=o?Fo("Trimmed whitespace from %s cells.",o):Fo("No selected cells had whitespace trimmed.");this.ui.notifyUI({type:"info",text:s,sticky:!1})}}).add("table_autofill",class extends HP{handle(e){if("AUTOFILL_TABLE_COLUMN"===e.type){const t=this.getters.getCoreTable(e),o=this.getters.getCell(e);if(!t?.config.automaticAutofill||"dynamic"===t.type||!o?.isFormula)return;const{col:s,row:i}=e,n=function(e,t){const o=t.numberOfHeaders,s={...e,top:e.top+o};return s.top<=s.bottom?s:void 0}(t.range.zone,t.config);if(n&&as(s,i,n)){const t=e.autofillRowStart??n.top,o=e.autofillRowEnd??n.bottom,s={...n,top:t,bottom:o};this.autofillTableZone(e,s)}}}autofillTableZone(e,t){if(t.top===t.bottom)return;const{col:o,row:s,sheetId:i}=e;for(let e=t.top;e<=t.bottom;e++)if(e!==s&&this.getters.getEvaluatedCell({col:o,row:e,sheetId:i}).type!==ni.empty)return;const n={zone:this.getters.getSelectedZone(),cell:this.getters.getActivePosition()};this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.bottom}),this.dispatch("AUTOFILL"),this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.top}),this.dispatch("AUTOFILL"),this.selection.selectZone(n)}}).add("table_ui_resize",class extends HP{allowDispatch(e){if("RESIZE_TABLE"===e.type){const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return"TableNotFound";const o=t.range.zone,s=this.getters.getRangeFromRangeData(e.newTableRange).zone;return s.top!==o.top||s.left!==o.left?"InvalidTableResize":this.canDispatch("UPDATE_TABLE",{...e}).reasons}return"Success"}handle(e){switch(e.type){case"RESIZE_TABLE":{const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(this.dispatch("UPDATE_TABLE",{...e}),!t)return;const o=this.getters.getRangeFromRangeData(e.newTableRange).zone;if(this.selection.selectCell(o.right,o.bottom),!t.config.automaticAutofill)return;const s=t.range.zone;if(o.bottom>=s.bottom){for(let t=o.left;t<=o.right;t++){const i={col:t,row:s.bottom,sheetId:e.sheetId};this.getters.getCell(i)?.content.startsWith("=")&&this.dispatch("AUTOFILL_TABLE_COLUMN",{...i,autofillRowStart:s.bottom,autofillRowEnd:o.bottom})}break}}}}}).add("datavalidation_insert",class extends HP{handle(e){if("ADD_DATA_VALIDATION_RULE"===e.type)if("isBoolean"===e.rule.criterion.type){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));for(const e of Ur(t)){const t=this.getters.getCell(e),o=this.getters.getEvaluatedCell(e);if(t?.content)if(t?.content&&o.type===ni.empty){let o;if(t.content.startsWith("=")){const s=this.getters.evaluateFormula(e.sheetId,t.content);o=(Ci(s)?s[0][0]:s)?.toString()}else o=t.content;o&&Xe(o)||this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}else o.type!==ni.boolean&&this.dispatch("UPDATE_CELL",{...e,content:"FALSE"});else this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}}}}).add("geo_features",class extends HP{static getters=["getGeoJsonFeatures","geoFeatureNameToId","getGeoChartAvailableRegions"];geoJsonService;geoJsonCache={};constructor(e){super(e),this.geoJsonService=e.external.geoJsonService}getGeoChartAvailableRegions(){return this.geoJsonService?this.geoJsonService.getAvailableRegions()||[]:(console.error("No geoJsonService provided to the model"),[])}getGeoJsonFeatures(e){if(!this.geoJsonService)return void console.error("No geoJsonService provided to the model");const t=this.geoJsonCache[e];return t instanceof Promise?void 0:void 0!==t?t??void 0:void(this.geoJsonCache[e]=new Promise((async t=>{const o=await(this.geoJsonService?.getTopoJson(e));this.geoJsonCache[e]=this.convertToGeoJson(o),this.dispatch("EVALUATE_CHARTS"),t()})))}geoFeatureNameToId(e,t){if(this.geoJsonService)return this.geoJsonService.geoFeatureNameToId(e,t);console.error("No geoJsonService provided to the model")}convertToGeoJson(e){if(!e)return null;if("Topology"===e.type){const t=window.ChartGeo.topojson.feature(e,Object.values(e.objects)[0]);return"FeatureCollection"===t.type?t.features:[t]}if("FeatureCollection"===e.type)return e.features;throw new Error("Invalid TopoJSON")}}),vN=(new n).add("selection",class extends HP{static layers=["Selection"];static getters=["getActiveSheet","getActiveSheetId","getActiveCell","getActiveCols","getActiveRows","getCurrentStyle","getSelectedZones","getSelectedZone","getSelectedCells","getSelectedFigureId","getSelection","getActivePosition","getSheetPosition","isSingleColSelected","getElementsFromSelection","tryGetActiveSheetId","isGridSelectionActive"];gridSelection={anchor:{cell:{col:0,row:0},zone:{top:0,left:0,bottom:0,right:0}},zones:[{top:0,left:0,bottom:0,right:0}]};selectedFigureId=null;sheetsData={};moveClient;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient}allowDispatch(e){switch(e.type){case"ACTIVATE_SHEET":try{if(!this.getters.getSheet(e.sheetIdTo).isVisible)return"SheetIsHidden";break}catch(e){return"InvalidSheetId"}case"MOVE_COLUMNS_ROWS":return this.isMoveElementAllowed(e)}return"Success"}handleEvent(e){const t=e.anchor;let o=[];switch(e.mode){case"overrideSelection":o=[t.zone];break;case"updateAnchor":o=[...this.gridSelection.zones];const s=o.findIndex((t=>ns(t,e.previousAnchor.zone)));s>=0&&(o[s]=t.zone);break;case"newAnchor":o=[...this.gridSelection.zones,t.zone]}this.setSelectionMixin(e.anchor,o),this.selection.resetDefaultAnchor(this,Be(this.gridSelection.anchor));const{col:s,row:i}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:s,row:i}),this.selectedFigureId=null}handle(e){switch(e.type){case"ACTIVATE_SHEET":this.selectedFigureId=null;break;case"DELETE_FIGURE":this.selectedFigureId===e.id&&(this.selectedFigureId=null);break;case"DELETE_SHEET":this.selectedFigureId&&this.getters.getFigure(e.sheetId,this.selectedFigureId)&&(this.selectedFigureId=null)}switch(e.type){case"START":const t=this.getters.getVisibleSheetIds()[0];this.activateSheet(t,t);const{col:o,row:s}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(o,s),this.selection.registerAsDefault(this,this.gridSelection.anchor,{handleEvent:this.handleEvent.bind(this)}),this.moveClient({sheetId:t,col:0,row:0});break;case"ACTIVATE_SHEET":this.activateSheet(e.sheetIdFrom,e.sheetIdTo);break;case"REMOVE_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){"COL"===e.dimension?this.onColumnsRemoved(e):this.onRowsRemoved(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"ADD_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){this.onAddElements(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"MOVE_COLUMNS_ROWS":e.sheetId===this.getActiveSheetId()&&this.onMoveElements(e);break;case"SELECT_FIGURE":this.selectedFigureId=e.id;break;case"ACTIVATE_NEXT_SHEET":this.activateNextSheet("right");break;case"ACTIVATE_PREVIOUS_SHEET":this.activateNextSheet("left");break;case"HIDE_SHEET":e.sheetId===this.getActiveSheetId()&&this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e.sheetId,sheetIdTo:this.getters.getVisibleSheetIds()[0]});break;case"UNDO":case"REDO":case"DELETE_SHEET":const i=Object.keys(this.sheetsData).filter((e=>!this.getters.tryGetSheet(e)));for(const e of i)delete this.sheetsData[e];for(const e in this.sheetsData){const t=this.clipSelection(e,this.sheetsData[e].gridSelection);this.sheetsData[e]={gridSelection:Be(t)}}if(!this.getters.tryGetSheet(this.getters.getActiveSheetId())){const e=this.getters.getVisibleSheetIds();if(this.activeSheet=this.getters.getSheet(e[0]),this.activeSheet.id in this.sheetsData){const{anchor:e}=this.clipSelection(this.activeSheet.id,this.sheetsData[this.activeSheet.id].gridSelection);this.selectCell(e.cell.col,e.cell.row)}else this.selectCell(0,0);const{col:t,row:o}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:t,row:o})}const n=this.getters.getActiveSheetId();this.gridSelection.zones=this.gridSelection.zones.map((e=>this.getters.expandZone(n,e))),this.gridSelection.anchor.zone=this.getters.expandZone(n,this.gridSelection.anchor.zone),this.setSelectionMixin(this.gridSelection.anchor,this.gridSelection.zones),this.selectedFigureId=null}}finalize(){this.selection.resetDefaultAnchor(this,Be(this.gridSelection.anchor))}isGridSelectionActive(){return this.selection.isListening(this)}getActiveSheet(){return this.activeSheet}getActiveSheetId(){return this.activeSheet.id}tryGetActiveSheetId(){return this.activeSheet?.id}getActiveCell(){return this.getters.getEvaluatedCell(this.getActivePosition())}getActiveCols(){const e=new Set;for(let t of this.gridSelection.zones)if(0===t.top&&t.bottom===this.getters.getNumberRows(this.getters.getActiveSheetId())-1)for(let o=t.left;o<=t.right;o++)e.add(o);return e}getActiveRows(){const e=new Set,t=this.getters.getActiveSheetId();for(let o of this.gridSelection.zones)if(0===o.left&&o.right===this.getters.getNumberCols(t)-1)for(let t=o.top;t<=o.bottom;t++)e.add(t);return e}getCurrentStyle(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();return this.getters.getCellStyle({sheetId:t,col:e.left,row:e.top})}getSelectedZones(){return Be(this.gridSelection.zones)}getSelectedZone(){return Be(this.gridSelection.anchor.zone)}getSelection(){return Be(this.gridSelection)}getSelectedCells(){const e=this.getters.getActiveSheetId(),t=[];for(const o of this.gridSelection.zones)t.push(...this.getters.getEvaluatedCellsInZone(e,o));return t}getSelectedFigureId(){return this.selectedFigureId}getActivePosition(){return this.getters.getMainCellPosition({sheetId:this.getActiveSheetId(),col:this.gridSelection.anchor.cell.col,row:this.gridSelection.anchor.cell.row})}getSheetPosition(e){if(e===this.getters.getActiveSheetId())return this.getActivePosition();{const t=this.sheetsData[e];return t?{sheetId:e,col:t.gridSelection.anchor.cell.col,row:t.gridSelection.anchor.cell.row}:this.getters.getNextVisibleCellPosition({sheetId:e,col:0,row:0})}}isSingleColSelected(){const e=this.getters.getSelectedZones();return 1===e.length&&e[0].left===e[0].right}getElementsFromSelection(e){if("COL"===e&&0===this.getters.getActiveCols().size)return[];if("ROW"===e&&0===this.getters.getActiveRows().size)return[];const t=this.getters.getSelectedZones();let o=[];const s="COL"===e?"left":"top",i="COL"===e?"right":"bottom";for(const e of t){const t=Array.from({length:e[i]-e[s]+1},((t,o)=>e[s]+o));o=o.concat(t)}return[...new Set(o)].sort()}activateSheet(e,t){if(this.setActiveSheet(t),this.sheetsData[e]={gridSelection:Be(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,Be(this.gridSelection.anchor));else{const{col:e,row:o}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,o)}}setSelectionMixin(e,t){const{anchor:o,zones:s}=this.clipSelection(this.getters.getActiveSheetId(),{anchor:e,zones:t});this.gridSelection.anchor=o,this.gridSelection.zones=function(e){return e.reverse().filter(((e,t,o)=>t===o.findIndex((t=>t.top===e.top&&t.bottom===e.bottom&&t.left===e.left&&t.right===e.right)))).reverse()}(s)}selectCell(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.expandZone(o,{left:e,right:e,top:t,bottom:t});this.setSelectionMixin({zone:s,cell:{col:e,row:t}},[s])}setActiveSheet(e){this.activeSheet=this.getters.getSheet(e)}activateNextSheet(e){const t=this.getters.getSheetIds(),o=(t.findIndex((e=>e===this.activeSheet.id))+("left"===e?t.length-1:1))%t.length;this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getActiveSheetId(),sheetIdTo:t[o]})}onColumnsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=ts(o,"left",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=ts(i,"left",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>ts(t,"left",[...e.elements])));this.setSelectionMixin(n,r)}onRowsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=ts(o,"top",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=ts(i,"top",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>ts(t,"top",[...e.elements])));this.setSelectionMixin(n,r)}onAddElements(e){const t="COL"===e.dimension?"left":"top",o=es(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),s=this.gridSelection.zones.map((o=>es(o,t,e.base,e.position,e.quantity))),i={cell:{col:o.left,row:o.top},zone:o};this.setSelectionMixin(i,s)}onMoveElements(e){const t=e.elements.length;this.dispatch("ADD_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,base:e.base,quantity:t,position:e.position});const o="COL"===e.dimension,s=e.elements[0],i=e.elements[t-1],n=e.base<s,r=n&&o?t:0,a=n&&!o?t:0,l=[{left:o?s+r:0,right:o?i+r:this.getters.getNumberCols(e.sheetId)-1,top:o?0:s+a,bottom:o?this.getters.getNumberRows(e.sheetId)-1:i+a}],c=this.getActiveSheetId(),h=new lc(this.getters,this.dispatch),d=h.copy(la(c,l));if(!d)return;const u=n?e.base:e.base+1,g=[{left:o?u:0,right:o?u+t-1:this.getters.getNumberCols(e.sheetId)-1,top:o?0:u,bottom:o?this.getters.getNumberRows(e.sheetId)-1:u+t-1}];h.paste({zones:g,sheetId:c},d,{isCutOperation:!0});const p=g[0],m=p.left,f=p.top;this.setSelectionMixin({zone:p,cell:{col:m,row:f}},[p]);const v=n?e.elements.map((e=>e+t)):e.elements;let b=n?e.base:e.base+1;const S={};for(const t of v){const o=this.getters.getHeaderSize(e.sheetId,e.dimension,t);o!=this.getters.getHeaderSize(e.sheetId,e.dimension,b)&&(S[o]??=[],S[o].push(b),b+=1)}for(const t in S)this.dispatch("RESIZE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,size:parseInt(t,10),elements:S[t]});this.dispatch("REMOVE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,elements:v})}isMoveElementAllowed(e){const t="COL"===e.dimension,o=e.elements[0],s=e.elements[e.elements.length-1],i=e.sheetId,n=t?this.getters.doesColumnsHaveCommonMerges:this.getters.doesRowsHaveCommonMerges;if(n(i,o-1,o)||n(i,s,s+1)||n(i,e.base-1,e.base))return"WillRemoveExistingMerge";const r=[e.base,...e.elements],a=t?this.getters.getNumberCols(i):this.getters.getNumberRows(i);return r.some((e=>e<0||e>=a))?"InvalidHeaderIndex":"Success"}clipSelection(e,t){const o=this.getters.getNumberCols(e)-1,s=this.getters.getNumberRows(e)-1;return{zones:t.zones.map((e=>({left:qe(e.left,0,o),right:qe(e.right,0,o),top:qe(e.top,0,s),bottom:qe(e.bottom,0,s)}))),anchor:{cell:{col:qe(t.anchor.cell.col,0,o),row:qe(t.anchor.cell.row,0,s)},zone:{left:qe(t.anchor.zone.left,0,o),right:qe(t.anchor.zone.right,0,o),top:qe(t.anchor.zone.top,0,s),bottom:qe(t.anchor.zone.bottom,0,s)}}}}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getSelectedZones();t.fillStyle="#f3f7fe";const i=1===s.length&&s[0].left===s[0].right&&s[0].top===s[0].bottom;t.fillStyle=i?"#f3f7fe":"#e9f0ff",t.strokeStyle=p,t.lineWidth=1.5*o;for(const e of s){const{x:o,y:s,width:i,height:n}=this.getters.getVisibleRect(e);t.globalCompositeOperation="multiply",t.fillRect(o,s,i,n),t.globalCompositeOperation="source-over",t.strokeRect(o,s,i,n)}t.globalCompositeOperation="source-over";const n=this.getActivePosition();let r;t.strokeStyle=p,t.lineWidth=3*o,r=this.getters.isInMerge(n)?this.getters.getMerge(n):fs(n);const{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);c>0&&h>0&&t.strokeRect(a,l,c,h)}}).add("evaluation_filter",class extends HP{static getters=["getFilterHiddenValues","getFirstTableInSelection","isRowFiltered","isFilterActive"];filterValues={};hiddenRows={};isEvaluationDirty=!1;allowDispatch(e){if("UPDATE_FILTER"===e.type)if(!this.getters.getFilterId(e))return"FilterNotFound";return"Success"}handle(e){switch(e.type){case"UNDO":case"REDO":case"UPDATE_CELL":case"EVALUATE_CELLS":case"ACTIVATE_SHEET":case"REMOVE_TABLE":case"ADD_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":case"UPDATE_TABLE":this.isEvaluationDirty=!0;break;case"START":for(const e of this.getters.getSheetIds())this.filterValues[e]={};break;case"CREATE_SHEET":this.filterValues[e.sheetId]={};break;case"HIDE_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"GROUP_HEADERS":case"UNGROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_ALL_HEADER_GROUPS":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":this.updateHiddenRows(e.sheetId);break;case"UPDATE_FILTER":this.updateFilter(e),this.updateHiddenRows(e.sheetId);break;case"DUPLICATE_SHEET":this.filterValues[e.sheetIdTo]=Be(this.filterValues[e.sheetId])}}finalize(){if(this.isEvaluationDirty){for(const e of this.getters.getSheetIds())this.updateHiddenRows(e);this.isEvaluationDirty=!1}}isRowFiltered(e,t){return!!this.hiddenRows[e]?.has(t)}getFilterHiddenValues(e){const t=this.getters.getFilterId(e),o=e.sheetId;return t&&this.filterValues[o]&&this.filterValues[o][t]||[]}isFilterActive(e){const t=this.getters.getFilterId(e),o=e.sheetId;return Boolean(t&&this.filterValues[o]?.[t]?.length)}getFirstTableInSelection(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,hiddenValues:o,sheetId:s}){const i=this.getters.getFilterId({sheetId:s,col:e,row:t});i&&(this.filterValues[s]||(this.filterValues[s]={}),this.filterValues[s][i]=o)}updateHiddenRows(e){const t=this.getters.getFilters(e).sort(((e,t)=>e.rangeWithHeaders.zone.top-t.rangeWithHeaders.zone.top)),o=new Set;for(let s of t){if(o.has(s.rangeWithHeaders.zone.top)||this.getters.isRowHiddenByUser(e,s.rangeWithHeaders.zone.top))continue;const t=this.filterValues[e]?.[s.id]?.map(sa),i=s.filteredRange?.zone;if(t&&i)for(let n=i.top;n<=i.bottom;n++){const i=this.getCellValueAsString(e,s.col,n);t.includes(i)&&o.add(n)}}this.hiddenRows[e]=o}getCellValueAsString(e,t,o){return this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).formattedValue.toLowerCase()}exportForExcel(e){for(const t of e.sheets){const e=t.id;for(const o of t.tables){const s=Yo(o.range),i=[],n=[];for(const o of Ze(0,cs(s).numberOfCols)){const r={sheetId:t.id,col:s.left+o,row:s.top},a=this.getFilterHiddenValues(r),l=this.getters.getFilter(r),c=l?.filteredRange?us(l.filteredRange.zone).map((t=>this.getters.getEvaluatedCell({sheetId:e,...t}).formattedValue)):[];if(a.length){const e=c.filter((e=>e)).filter((e=>!a.includes(e)));i.push({colId:o,displayedValues:[...new Set(e)],displayBlanks:!a.includes("")&&c.some((e=>!e))})}const h=this.getters.getEvaluatedCell(r).formattedValue,d=this.getUniqueColNameForExcel(o,h,n);n.push(d);const u=yo(r.col,r.row);t.cells[u]=d,t.cellValues[u]=d}o.filters=i}}}getUniqueColNameForExcel(e,t,o){return t||(t=`Column${e}`),Nt(t,o,{compute:(e,o)=>t+String(o),start:2})}}).add("header_visibility_ui",class extends HP{static getters=["getNextVisibleCellPosition","findVisibleHeader","findLastVisibleColRowIndex","findFirstVisibleColRowIndex","isRowHidden","isColHidden","isHeaderHidden"];isRowHidden(e,t){return this.getters.isRowHiddenByUser(e,t)||this.getters.isRowFiltered(e,t)}isColHidden(e,t){return this.getters.isColHiddenByUser(e,t)}isHeaderHidden(e,t,o){return"COL"===t?this.isColHidden(e,o):this.isRowHidden(e,o)}getNextVisibleCellPosition({sheetId:e,col:t,row:o}){return{sheetId:e,col:this.findVisibleHeader(e,"COL",t,this.getters.getNumberCols(e)-1),row:this.findVisibleHeader(e,"ROW",o,this.getters.getNumberRows(e)-1)}}findVisibleHeader(e,t,o,s){if(o<=s)for(let i=o;i<=s;i++)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i;if(o>s)for(let i=o;i>=s;i--)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i}findLastVisibleColRowIndex(e,t,{last:o,first:s}){return Ze(o,s,-1).find((o=>!this.isHeaderHidden(e,t,o)))||s}findFirstVisibleColRowIndex(e,t){const o=this.getters.getNumberHeaders(e,t);for(let s=0;s<o;s++){if("COL"===t&&!this.isColHidden(e,s))return s;if("ROW"===t&&!this.isRowHidden(e,s))return s}}exportForExcel(e){for(const t of e.sheets)for(const[e,o]of Object.entries(t.rows))o.isHidden=this.isRowHidden(t.id,Number(e))}}).add("cell_computed_style",class extends HP{static getters=["getCellComputedBorder","getCellComputedStyle"];styles={};borders={};handle(e){if(ai.has(e.type)||"UPDATE_CELL"===e.type||"SET_FORMATTING"===e.type||"EVALUATE_CELLS"===e.type)return this.styles={},void(this.borders={});tN(e)?"sheetId"in e?(delete this.styles[e.sheetId],delete this.borders[e.sheetId]):(this.styles={},this.borders={}):hi.has(e.type)?this.styles={}:di.has(e.type)&&(this.borders={})}getCellComputedBorder(e){const{sheetId:t,row:o,col:s}=e;return void 0!==this.borders[t]?.[o]?.[s]||(this.borders[t]||(this.borders[t]={}),this.borders[t][o]||(this.borders[t][o]={}),this.borders[t][o][s]||(this.borders[t][o][s]=this.computeCellBorder(e))),this.borders[t][o][s]}getCellComputedStyle(e){const{sheetId:t,row:o,col:s}=e;return void 0!==this.styles[t]?.[o]?.[s]||(this.styles[t]||(this.styles[t]={}),this.styles[t][o]||(this.styles[t][o]={}),this.styles[t][o][s]||(this.styles[t][o][s]=this.computeCellStyle(e))),this.styles[t][o][s]}computeCellBorder(e){const t=this.getters.getCellBorder(e)||{},o={...bt(this.getters.getCellTableBorder(e)||{}),...bt(t)};return ct(o)?null:o}computeCellStyle(e){const t=this.getters.getCell(e),o=this.getters.getCellConditionalFormatStyle(e),s={...bt(this.getters.getCellTableStyle(e)),...bt(t?.style),...bt(o)};return this.getters.getEvaluatedCell(e).link&&!s.textColor&&(s.textColor=b),s}}).add("table_computed_style",class extends HP{static getters=["getCellTableStyle","getCellTableBorder"];tableStyles={};handle(e){ai.has(e.type)||"UPDATE_CELL"===e.type&&"content"in e||"EVALUATE_CELLS"===e.type?this.tableStyles={}:tN(e)&&("sheetId"in e?delete this.tableStyles[e.sheetId]:this.tableStyles={})}finalize(){for(const e of this.getters.getSheetIds()){this.tableStyles[e]||(this.tableStyles[e]={});for(const t of this.getters.getTables(e))this.tableStyles[e][t.id]||(this.tableStyles[e][t.id]=this.computeTableStyle(e,t))}}getCellTableStyle(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().styles[e.col]?.[e.row]}getCellTableBorder(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().borders[e.col]?.[e.row]}computeTableStyle(e,t){return ut((()=>{const{config:o,numberOfCols:s,numberOfRows:i}=this.getTableRuntimeConfig(e,t),n=RF(o,this.getters.getTableStyle(t.config.styleId),s,i),r=this.getTableMapping(e,t),a={borders:{},styles:{}};for(let e=0;e<s;e++){const t=r.colMapping[e];a.borders[t]={},a.styles[t]={};for(let o=0;o<i;o++){const s=r.rowMapping[o];a.borders[t][s]=n.borders[e][o],a.styles[t][s]=n.styles[e][o]}}return a}))}getTableRuntimeConfig(e,t){const o=t.range.zone,s={...t.config};let i=o.right-o.left+1,n=o.bottom-o.top+1;for(let i=o.top;i<=o.bottom;i++)this.getters.isRowHidden(e,i)&&(n--,i-o.top<t.config.numberOfHeaders&&(s.numberOfHeaders--,s.numberOfHeaders<0&&(s.numberOfHeaders=0)),i===o.bottom&&(s.totalRow=!1));for(let t=o.left;t<=o.right;t++)this.getters.isColHidden(e,t)&&(i--,t===o.left&&(s.firstColumn=!1),t===o.right&&(s.lastColumn=!1));return{config:s,numberOfCols:i,numberOfRows:n}}getTableMapping(e,t){const o={},s={};let i=0,n=0;const r=t.range.zone;for(let t=r.left;t<=r.right;t++)if(!this.getters.isColHidden(e,t)){o[i]=t,i++;for(let t=r.top;t<=r.bottom;t++)this.getters.isRowHidden(e,t)||(s[n]=t,n++)}return{colMapping:o,rowMapping:s}}}).add("header_positions",class extends HP{static getters=["getColDimensions","getRowDimensions","getColRowOffset"];headerPositions={};isDirty=!0;handle(e){switch(ai.has(e.type)&&(this.headerPositions={},this.isDirty=!0),e.type){case"START":for(const e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);break;case"UPDATE_CELL":case"UPDATE_FILTER":case"UPDATE_TABLE":case"REMOVE_TABLE":this.headerPositions={},this.isDirty=!0;break;case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"CREATE_SHEET":this.headerPositions[e.sheetId]=this.computeHeaderPositionsOfSheet(e.sheetId);break;case"DUPLICATE_SHEET":this.headerPositions[e.sheetIdTo]=Be(this.headerPositions[e.sheetId])}}finalize(){if(this.isDirty){for(const e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);this.isDirty=!1}}getColDimensions(e,t){const o=this.headerPositions[e].COL[t],s=this.getters.getColSize(e,t);return{start:o,size:s,end:o+(this.getters.isColHidden(e,t)?0:s)}}getRowDimensions(e,t){const o=this.headerPositions[e].ROW[t],s=this.getters.getRowSize(e,t);return{start:o,size:s,end:o+(this.getters.isRowHidden(e,t)?0:s)}}getColRowOffset(e,t,o,s=this.getters.getActiveSheetId()){const i=this.headerPositions[s][e][t];return this.headerPositions[s][e][o]-i}computeHeaderPositionsOfSheet(e){return{COL:this.computePositions(e,"COL"),ROW:this.computePositions(e,"ROW")}}computePositions(e,t){const o={};let s=0;for(let i=0;i<this.getters.getNumberHeaders(e,t)+1;i++)o[i]=s,this.getters.isHeaderHidden(e,t,i)||(s+=this.getters.getHeaderSize(e,t,i));return o}}).add("viewport",class extends HP{static getters=["getColIndex","getRowIndex","getActiveMainViewport","getSheetViewDimension","getSheetViewDimensionWithHeaders","getMainViewportRect","isVisibleInViewport","getEdgeScrollCol","getEdgeScrollRow","getVisibleFigures","getVisibleRect","getVisibleRectWithoutHeaders","getVisibleCellPositions","getColRowOffsetInViewport","getMainViewportCoordinates","getActiveSheetScrollInfo","getActiveSheetDOMScrollInfo","getSheetViewVisibleCols","getSheetViewVisibleRows","getFrozenSheetViewRatio","isPixelPositionVisible","getColDimensionsInViewport","getRowDimensionsInViewport","getAllActiveViewportsZones","getRect"];viewports={};sheetViewWidth=Me();sheetViewHeight=Me();gridOffsetX=0;gridOffsetY=0;sheetsWithDirtyViewports=new Set;shouldAdjustViewports=!1;allowDispatch(e){switch(e.type){case"SET_VIEWPORT_OFFSET":return this.chainValidations(this.checkScrollingDirection,this.checkIfViewportsWillChange)(e);case"RESIZE_SHEETVIEW":return this.chainValidations(this.checkValuesAreDifferent,this.checkPositiveDimension)(e);default:return"Success"}}handleEvent(e){const t=this.getters.getActiveSheetId();if(e.options.scrollIntoView){let{col:o,row:s}=ms(e.previousAnchor.zone,e.anchor.zone);if("updateAnchor"===e.mode){const i=e.previousAnchor.zone,n=e.anchor.zone,{top:r,bottom:a,left:l,right:c}=this.getMainInternalViewport(t);i.left===n.left&&i.right===n.right&&(o=l>o||o>c?l:o),i.top===n.top&&i.bottom===n.bottom&&(s=r>s||s>a?r:s)}o=Math.min(o,this.getters.getNumberCols(t)-1),s=Math.min(s,this.getters.getNumberRows(t)-1),this.sheetsWithDirtyViewports.has(t)||this.refreshViewport(this.getters.getActiveSheetId(),{col:o,row:s})}}handle(e){if(ai.has(e.type))for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);switch(e.type){case"START":this.selection.observe(this,{handleEvent:this.handleEvent.bind(this)}),this.resetViewports(this.getters.getActiveSheetId());break;case"UNDO":case"REDO":this.cleanViewports();for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);this.shouldAdjustViewports=!0;break;case"RESIZE_SHEETVIEW":this.resizeSheetView(e.height,e.width,e.gridOffsetX,e.gridOffsetY);break;case"SET_VIEWPORT_OFFSET":this.setSheetViewOffset(e.offsetX,e.offsetY);break;case"SHIFT_VIEWPORT_DOWN":const t=this.getters.getActiveSheetId(),{top:o,viewportHeight:s,offsetCorrectionY:i}=this.getMainInternalViewport(t),n=this.getters.getRowDimensions(t,o);this.shiftVertically(n.start+s-i);break;case"SHIFT_VIEWPORT_UP":{const e=this.getters.getActiveSheetId(),{top:t,viewportHeight:o,offsetCorrectionY:s}=this.getMainInternalViewport(e),i=this.getters.getRowDimensions(e,t);this.shiftVertically(i.end-s-o);break}case"REMOVE_TABLE":case"UPDATE_TABLE":case"UPDATE_FILTER":this.sheetsWithDirtyViewports.add(e.sheetId);break;case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":{const t="sheetId"in e?e.sheetId:this.getters.getActiveSheetId();this.sheetsWithDirtyViewports.add(t);break}case"UPDATE_CELL":if("content"in e||"format"in e||void 0!==e.style?.fontSize)for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);break;case"DELETE_SHEET":this.cleanViewports(),this.sheetsWithDirtyViewports.delete(e.sheetId);break;case"ACTIVATE_SHEET":this.sheetsWithDirtyViewports.add(e.sheetIdTo);break;case"UNFREEZE_ROWS":case"UNFREEZE_COLUMNS":case"FREEZE_COLUMNS":case"FREEZE_ROWS":case"UNFREEZE_COLUMNS_ROWS":this.resetViewports(this.getters.getActiveSheetId());break;case"SCROLL_TO_CELL":this.refreshViewport(this.getters.getActiveSheetId(),{col:e.col,row:e.row})}}finalize(){for(const e of this.sheetsWithDirtyViewports)if(this.resetViewports(e),this.shouldAdjustViewports){const t=this.getters.getSheetPosition(e);this.getSubViewports(e).forEach((e=>{e.adjustPosition(t)}))}this.sheetsWithDirtyViewports=new Set,this.shouldAdjustViewports=!1,this.setViewports()}setViewports(){const e=this.getters.getSheetIds();for(const t of e)this.viewports[t]?.bottomRight||this.resetViewports(t)}getColIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getColIndex(e))))}getRowIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getRowIndex(e))))}getSheetViewDimensionWithHeaders(){return{width:this.sheetViewWidth+this.gridOffsetX,height:this.sheetViewHeight+this.gridOffsetY}}getSheetViewDimension(){return{width:this.sheetViewWidth,height:this.sheetViewHeight}}getActiveMainViewport(){const e=this.getters.getActiveSheetId();return this.getMainViewport(e)}getActiveSheetScrollInfo(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e);return{scrollX:t.offsetX,scrollY:t.offsetY}}getActiveSheetDOMScrollInfo(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e);return{scrollX:t.offsetScrollbarX,scrollY:t.offsetScrollbarY}}getSheetViewVisibleCols(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ze(e.left,e.right+1))).flat())].filter((t=>!this.getters.isHeaderHidden(e,"COL",t)))}getSheetViewVisibleRows(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ze(e.top,e.bottom+1))).flat())].filter((t=>!this.getters.isHeaderHidden(e,"ROW",t)))}getVisibleCellPositions(){const e=this.getSheetViewVisibleCols(),t=this.getSheetViewVisibleRows(),o=this.getters.getActiveSheetId(),s=[];for(const i of e)for(const e of t){const t={sheetId:o,col:i,row:e},n=this.getters.getMainCellPosition(t);n.row===e&&n.col===i&&s.push(t)}return s}getMainViewportRect(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e),{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e);let{width:i,height:n}=t.getMaxSize();return{x:this.getters.getColDimensions(e,o).start,y:this.getters.getRowDimensions(e,s).start,width:i,height:n}}getMaximumSheetOffset(){const e=this.getters.getActiveSheetId(),{width:t,height:o}=this.getMainViewportRect(),s=this.getMainInternalViewport(e);return{maxOffsetX:Math.max(0,t-s.viewportWidth+1),maxOffsetY:Math.max(0,o-s.viewportHeight+1)}}getColRowOffsetInViewport(e,t,o){const s=this.getters.getActiveSheetId(),i=this.getters.getSheetViewVisibleCols(),n=this.getters.getSheetViewVisibleRows();if(o<t)return-this.getColRowOffsetInViewport(e,o,t);let r=0;const a="COL"===e?i:n;for(let i=t;i<o;i++)a.includes(i)&&(r+=this.getters.getHeaderSize(s,e,i));return r}isVisibleInViewport({sheetId:e,col:t,row:o}){return this.getSubViewports(e).some((e=>e.isVisible(t,o)))}getEdgeScrollCol(e,t,o){let s=!1,i=0,n=0;const{xSplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{width:a}=this.getSheetViewDimension(),{x:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollX;return e>a?(s=!0,n=Nr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=Nr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=Nr(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getEdgeScrollRow(e,t,o){let s=!1,i=0,n=0;const{ySplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{height:a}=this.getSheetViewDimension(),{y:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollY;return e>a?(s=!0,n=Nr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=Nr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=Nr(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getVisibleRect(e){const t=this.getVisibleRectWithoutHeaders(e);return{...t,x:t.x+this.gridOffsetX,y:t.y+this.gridOffsetY}}getVisibleRectWithoutHeaders(e){const t=this.getters.getActiveSheetId(),o=this.getSubViewports(t).map((t=>t.getVisibleRect(e))).filter(at);return 0===o.length?{x:0,y:0,width:0,height:0}:this.recomposeRect(o)}getRect(e){const t=this.getters.getActiveSheetId(),o=this.getSubViewports(t).map((t=>t.getFullRect(e))).filter(at);if(0===o.length)return{x:0,y:0,width:0,height:0};const s=this.recomposeRect(o);return{...s,x:s.x+this.gridOffsetX,y:s.y+this.gridOffsetY}}getMainViewportCoordinates(){const e=this.getters.getActiveSheetId(),{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e);return{x:this.getters.getColDimensions(e,t).start,y:this.getters.getRowDimensions(e,o).start}}getColDimensionsInViewport(e,t){const o=Ot(this.getters.getSheetViewVisibleCols()),s=this.getters.getColRowOffsetInViewport("COL",o,t),i=this.getters.getColSize(e,t);return{start:s,size:i,end:s+(this.getters.isColHidden(e,t)?0:i)}}getRowDimensionsInViewport(e,t){const o=Ot(this.getters.getSheetViewVisibleRows()),s=this.getters.getColRowOffsetInViewport("ROW",o,t),i=this.getters.getRowSize(e,t);return{start:s,size:i,end:s+(this.getters.isRowHidden(e,t)?0:i)}}getAllActiveViewportsZones(){const e=this.getters.getActiveSheetId();return this.getSubViewports(e)}ensureMainViewportExist(e){this.viewports[e]||this.resetViewports(e)}getSubViewports(e){return this.ensureMainViewportExist(e),Object.values(this.viewports[e]).filter(at)}checkPositiveDimension(e){return e.width<0||e.height<0?"InvalidViewportSize":"Success"}checkValuesAreDifferent(e){const{height:t,width:o}=this.getSheetViewDimension();return e.gridOffsetX===this.gridOffsetX&&e.gridOffsetY===this.gridOffsetY&&e.width===o&&e.height===t?"ValuesNotChanged":"Success"}checkScrollingDirection({offsetX:e,offsetY:t}){const o=this.getMainInternalViewport(this.getters.getActiveSheetId());return!o.canScrollHorizontally&&e>0||!o.canScrollVertically&&t>0?"InvalidScrollingDirection":"Success"}checkIfViewportsWillChange({offsetX:e,offsetY:t}){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();return this.getSubViewports(o).some((o=>o.willNewOffsetScrollViewport(qe(e,0,s),qe(t,0,i))))?"Success":"ViewportScrollLimitsReached"}getMainViewport(e){const t=this.getMainInternalViewport(e);return{top:t.top,left:t.left,bottom:t.bottom,right:t.right}}getMainInternalViewport(e){return this.ensureMainViewportExist(e),this.viewports[e].bottomRight}cleanViewports(){const e=this.getters.getSheetIds();for(let t of Object.keys(this.viewports))e.includes(t)||delete this.viewports[t]}resizeSheetView(e,t,o=0,s=0){this.sheetViewHeight=e,this.sheetViewWidth=t,this.gridOffsetX=o,this.gridOffsetY=s,this.recomputeViewports()}recomputeViewports(){for(let e of Object.keys(this.viewports))this.resetViewports(e)}setSheetViewOffset(e,t){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();this.getSubViewports(o).forEach((o=>o.setViewportOffset(qe(e,0,s),qe(t,0,i))))}getViewportOffset(e){return{x:this.viewports[e]?.bottomRight.offsetScrollbarX||0,y:this.viewports[e]?.bottomRight.offsetScrollbarY||0}}resetViewports(e){if(!this.getters.tryGetSheet(e))return;const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getNumberCols(e),i=this.getters.getNumberRows(e),n=this.getters.getColRowOffset("COL",0,t,e),r=this.getters.getColRowOffset("ROW",0,o,e),{xRatio:a,yRatio:l}=this.getFrozenSheetViewRatio(e),c=a<1,h=l<1,d=this.getViewportOffset(e),u={topLeft:o&&t&&new pN(this.getters,e,{left:0,right:t-1,top:0,bottom:o-1},{width:n,height:r},{canScrollHorizontally:!1,canScrollVertically:!1},{x:0,y:0})||void 0,topRight:o&&new pN(this.getters,e,{left:t,right:s-1,top:0,bottom:o-1},{width:this.sheetViewWidth-n,height:r},{canScrollHorizontally:c,canScrollVertically:!1},{x:c?d.x:0,y:0})||void 0,bottomLeft:t&&new pN(this.getters,e,{left:0,right:t-1,top:o,bottom:i-1},{width:n,height:this.sheetViewHeight-r},{canScrollHorizontally:!1,canScrollVertically:h},{x:0,y:h?d.y:0})||void 0,bottomRight:new pN(this.getters,e,{left:t,right:s-1,top:o,bottom:i-1},{width:this.sheetViewWidth-n,height:this.sheetViewHeight-r},{canScrollHorizontally:c,canScrollVertically:h},{x:c?d.x:0,y:h?d.y:0})};this.viewports[e]=u}refreshViewport(e,t){this.getSubViewports(e).forEach((e=>{e.adjustViewportZone(),e.adjustPosition(t)}))}shiftVertically(e){const t=this.getters.getActiveSheetId(),{top:o}=this.getMainInternalViewport(t),{scrollX:s}=this.getActiveSheetScrollInfo();this.setSheetViewOffset(s,e);const{anchor:i}=this.getters.getSelection();if(i.cell.row>=this.getters.getPaneDivisions(t).ySplit){const e=this.getMainInternalViewport(t).top-o;this.selection.selectCell(i.cell.col,i.cell.row+e)}}getVisibleFigures(){const e=this.getters.getActiveSheetId(),t=[],o=this.getters.getFigures(e),{scrollX:s,scrollY:i}=this.getActiveSheetScrollInfo(),{x:n,y:r}=this.getters.getMainViewportCoordinates(),{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders();for(const e of o)e.x>=n&&(e.x+e.width<=n+s||e.x>=a+s+n)||e.y>=r&&(e.y+e.height<=r+i||e.y>=l+i+r)||t.push(e);return t}isPixelPositionVisible(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),{x:s,y:i}=this.getters.getMainViewportCoordinates(),{width:n,height:r}=this.getters.getSheetViewDimension();return!(e.x>=s&&(e.x<s+t||e.x>n+t+s))&&!(e.y>=i&&(e.y<i+o||e.y>r+o+i))}getFrozenSheetViewRatio(e){const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getColDimensions(e,t).start,i=this.getters.getRowDimensions(e,o).start;return{xRatio:s/(this.sheetViewWidth+this.gridOffsetX),yRatio:i/(this.sheetViewHeight+this.gridOffsetY)}}recomposeRect(e){const t=Math.min(...e.map((e=>e.x))),o=Math.min(...e.map((e=>e.y)));return{x:t,y:o,width:Math.max(...e.map((e=>e.x+e.width)))-t,height:Math.max(...e.map((e=>e.y+e.height)))-o}}}).add("clipboard",class extends HP{static layers=["Clipboard"];static getters=["getClipboardContent","getClipboardId","getClipboardTextContent","isCutOperation"];status="invisible";originSheetId;copiedData;_isCutOperation=!1;clipboardId=(new aa).uuidv4();allowDispatch(e){switch(e.type){case"CUT":const t=this.getters.getSelectedZones();return this.isCutAllowedOn(t);case"PASTE_FROM_OS_CLIPBOARD":{const t=this.convertTextToClipboardData(e.clipboardContent.text??""),o=e.pasteOption;return this.isPasteAllowed(e.target,t,{pasteOption:o,isCutOperation:!1})}case"PASTE":{if(!this.copiedData)return"EmptyClipboard";const t=e.pasteOption;return this.isPasteAllowed(e.target,this.copiedData,{pasteOption:t,isCutOperation:this._isCutOperation})}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].top&&0===e[0].bottom)return"InvalidCopyPasteSelection";break}case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].left&&0===e[0].right)return"InvalidCopyPasteSelection";break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t);return this.isPasteAllowed(o,s,{isCutOperation:!0})}case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension),s=this.copy(t);return this.isPasteAllowed(o,s,{isCutOperation:!0})}}return"Success"}handle(e){switch(e.type){case"COPY":case"CUT":const t=this.getters.getSelectedZones();this.status="visible",this.originSheetId=this.getters.getActiveSheetId(),this.copiedData=this.copy(t),this._isCutOperation="CUT"===e.type;break;case"PASTE_FROM_OS_CLIPBOARD":{this._isCutOperation=!1,this.copiedData=e.clipboardContent.data||this.convertTextToClipboardData(e.clipboardContent.text??"");const t=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:t,selectTarget:!0,isCutOperation:!1}),this.status="invisible";break}case"PASTE":{const t=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:t,selectTarget:!0,isCutOperation:this._isCutOperation}),this.status="invisible",this._isCutOperation&&(this.copiedData=void 0,this._isCutOperation=!1);break}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZone(),t=e.top!==e.bottom,o={...e,bottom:t?e.top:e.top-1,top:t?e.top:e.top-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZone(),t=e.left!==e.right,o={...e,right:t?e.left:e.left-1,left:t?e.left:e.left-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"CLEAN_CLIPBOARD_HIGHLIGHT":this.status="invisible";break;case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension);if(!Xo(t[0])){this.dispatch("CLEAR_CELLS",{target:[e.zone],sheetId:this.getters.getActiveSheetId()});break}const s=this.copy(t);this.paste(o,s,{isCutOperation:!0});break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t);this.paste(o,s,{isCutOperation:!0});break}case"ADD_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;this.isColRowDirtyingClipboard("before"===e.position?e.base:e.base+1,e.dimension)&&(this.copiedData=void 0);break;case"REMOVE_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;for(let t of e.elements){if(this.isColRowDirtyingClipboard(t,e.dimension)){this.copiedData=void 0;break}}this.status="invisible";break;case"REPEAT_PASTE":this.paste(e.target,this.copiedData,{isCutOperation:!1,pasteOption:e.pasteOption,selectTarget:!0});break;case"DELETE_SHEET":if(!this._isCutOperation)return;this.originSheetId===e.sheetId&&(this.copiedData=void 0,this.status="invisible");break;default:pi(e)&&(this.status="invisible")}}convertTextToClipboardData(e){const t=this.selectClipboardHandlers({figureId:!0}).concat(this.selectClipboardHandlers({}));let o={};for(const{handlerName:s,handler:i}of t){const t=i.convertTextToClipboardData(e);o[s]=t;const n=["sheetId","cells","zones","figureId"];for(const e of n)t&&e in t&&(o[e]=t[e])}return o}selectClipboardHandlers(e){const t="figureId"in e?uc.figureHandlers:uc.cellHandlers;return t.getKeys().map((e=>({handlerName:e,handler:new(t.get(e))(this.getters,this.dispatch)})))}isCutAllowedOn(e){const t=this.getClipboardData(e);for(const{handler:e}of this.selectClipboardHandlers(t)){const o=e.isCutAllowed(t);if("Success"!==o)return o}return"Success"}isPasteAllowed(e,t,o){for(const{handler:s}of this.selectClipboardHandlers(t)){const i=s.isPasteAllowed(this.getters.getActiveSheetId(),e,t,{...o});if("Success"!==i)return i}return"Success"}isColRowDirtyingClipboard(e,t){if(!this.copiedData||!this.copiedData.zones)return!1;const{zones:o}=this.copiedData;for(let s of o){if("COL"===t&&e<=s.right)return!0;if("ROW"===t&&e<=s.bottom)return!0}return!1}copy(e){let t={};const o=this.getClipboardData(e);for(const{handlerName:e,handler:s}of this.selectClipboardHandlers(o)){const i=s.copy(o);t[e]=i;const n=["sheetId","cells","zones","figureId"];for(const e of n)i&&e in i&&(t[e]=i[e])}return t}paste(e,t,o){if(!t)return;let s,i=[];const n=this.getters.getActiveSheetId();let r={sheetId:n,zones:e};const a=this.selectClipboardHandlers(t);for(const{handlerName:l,handler:c}of a){const a=t[l];if(!a)continue;const h=c.getPasteTarget(n,e,a,o);h.figureId&&(r.figureId=h.figureId);for(const e of h.zones)i.push(e),s=void 0!==s?ss(s,e):e}if(void 0!==s&&this.addMissingDimensions(this.getters.getActiveSheetId(),s.right-s.left+1,s.bottom-s.top+1,s.left,s.top),a.forEach((({handlerName:e,handler:s})=>{const i=t[e];i&&s.paste(r,i,o)})),!o?.selectTarget)return;const l=e[0],c=l.left,h=l.top;this.selection.getBackToDefault(),this.selection.selectZone({cell:{col:c,row:h},zone:ss(...i)},{scrollIntoView:!1})}addMissingDimensions(e,t,o,s,i){const n=o+i-this.getters.getNumberRows(e);n>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:this.getters.getNumberRows(e)-1,sheetId:e,quantity:n,position:"after"});const r=t+s-this.getters.getNumberCols(e);r>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:this.getters.getNumberCols(e)-1,sheetId:e,quantity:r,position:"after"})}getClipboardTextContent(){return this.getPlainTextContent()}getClipboardId(){return this.clipboardId}getClipboardContent(){return{[ri.PlainText]:this.getPlainTextContent(),[ri.Html]:this.getHTMLContent()}}getSheetData(){const e={version:Qw,clipboardId:this.clipboardId};return this.copiedData&&"figureId"in this.copiedData?e:{...e,...this.copiedData}}getPlainTextContent(){return this.copiedData?.cells&&this.copiedData.cells.map((e=>e.map((e=>this.getters.shouldShowFormulas()&&e?.tokens?.length?e?.content||"":e.evaluatedCell?.formattedValue||"")).join("\t"))).join("\n")||"\t"}getHTMLContent(){let e="";const t=this.copiedData?.cells;if(t)if(1===t.length&&1===t[0].length)e=`${this.getters.getCellText(t[0][0].position)}`;else{if(!t[0][0])return"";{let o='<table border="1" style="border-collapse:collapse">';for(const e of t){o+="<tr>";for(const t of e){if(!t)continue;o+=`<td style="${kc(Nc(this.getters.getCellComputedStyle(t.position)))}">`+xw(this.getters.getCellText(t.position))+"</td>"}o+="</tr>"}o+="</table>",e=o}}else e="\t";return`<div data-osheet-clipboard='${xw(JSON.stringify(this.getSheetData()))}'>${e}</div>`}isCutOperation(){return this._isCutOperation??!1}getDeleteCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s;return s="COL"===t?{...e,left:e.right+1,right:this.getters.getNumberCols(o)-1}:{...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1},{cut:[s],paste:[e]}}getInsertCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s,i;return"COL"===t?(s={...e,right:this.getters.getNumberCols(o)-1},i={...e,left:e.right+1,right:e.right+1}):(s={...e,bottom:this.getters.getNumberRows(o)-1},i={...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1}),{cut:[s],paste:[i]}}getClipboardData(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedFigureId();return o?{figureId:o,sheetId:t}:la(t,e)}drawLayer(e){if("visible"!==this.status||!this.copiedData)return;const{sheetId:t,zones:o}=this.copiedData;if(t!==this.getters.getActiveSheetId()||!o||!o.length)return;const{ctx:s,thinLineWidth:i}=e;s.setLineDash([8,5]),s.strokeStyle=p,s.lineWidth=3.3*i;for(const e of o){const{x:t,y:o,width:i,height:n}=this.getters.getVisibleRect(e);i>0&&n>0&&s.strokeRect(t,o,i,n)}}}),bN=(new n).add("evaluation",class extends KM{static getters=["evaluateFormula","evaluateFormulaResult","evaluateCompiledFormula","getCorrespondingFormulaCell","getRangeFormattedValues","getRangeValues","getRangeFormats","getEvaluatedCell","getEvaluatedCells","getEvaluatedCellsInZone","getEvaluatedCellsPositions","getSpreadZone","getArrayFormulaSpreadingOn","isEmpty"];shouldRebuildDependenciesGraph=!0;evaluator;positionsToUpdate=[];constructor(e){super(e),this.evaluator=new _P(e.custom,this.getters)}beforeHandle(e){(ai.has(e.type)||ci.has(e.type))&&(this.shouldRebuildDependenciesGraph=!0)}handle(e){switch(e.type){case"UPDATE_CELL":if(!("content"in e)&&!("format"in e)||this.shouldRebuildDependenciesGraph)return;const t={sheetId:e.sheetId,row:e.row,col:e.col};this.positionsToUpdate.push(t),"content"in e&&this.evaluator.updateDependencies(t);break;case"EVALUATE_CELLS":this.evaluator.evaluateAllCells()}}finalize(){this.shouldRebuildDependenciesGraph?(this.evaluator.buildDependencyGraph(),this.evaluator.evaluateAllCells(),this.shouldRebuildDependenciesGraph=!1):this.positionsToUpdate.length&&this.evaluator.evaluateCells(this.positionsToUpdate),this.positionsToUpdate=[]}evaluateFormula(e,t){const o=this.evaluateFormulaResult(e,t);return Ci(o)?an(o,(e=>e.value)):o.value}evaluateFormulaResult(e,t){return this.evaluator.evaluateFormulaResult(e,t)}evaluateCompiledFormula(e,t,o){return this.evaluator.evaluateCompiledFormula(e,t,o)}getRangeFormattedValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).formattedValue))}getRangeValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).value))}getRangeFormats(e){const t=this.getters.tryGetSheet(e.sheetId);return void 0===t?[]:this.getters.getEvaluatedCellsInZone(t.id,e.zone).map((e=>e.format))}getEvaluatedCell(e){return this.evaluator.getEvaluatedCell(e)}getEvaluatedCells(e){return this.evaluator.getEvaluatedPositionsInSheet(e).map((e=>this.getEvaluatedCell(e)))}getEvaluatedCellsPositions(e){return this.evaluator.getEvaluatedPositionsInSheet(e)}getEvaluatedCellsInZone(e,t){return us(t).map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o})))}getSpreadZone(e,t={ignoreSpillError:!1}){return this.evaluator.getSpreadZone(e,t)}getArrayFormulaSpreadingOn(e){return this.evaluator.getArrayFormulaSpreadingOn(e)}isEmpty(e,t){return us(t).map((({col:t,row:o})=>this.getEvaluatedCell({sheetId:e,col:t,row:o}))).every((e=>e.type===ni.empty))}mapVisiblePositions(e,t){const{sheetId:o,zone:s}=e;return us(s).reduce(((e,s)=>{const{col:i,row:n}=s;return this.getters.isColHidden(o,i)||this.getters.isRowHidden(o,n)||e.push(t({sheetId:o,...s})),e}),[])}exportForExcel(e){for(const t of e.sheets)t.cellValues={};for(const t of this.evaluator.getEvaluatedPositions()){const o=this.evaluator.getEvaluatedCell(t),s=yo(t.col,t.row),i=o.value;let n,r=!1,a=!0;const l=e.sheets.find((e=>e.id===t.sheetId)),c=this.getCorrespondingFormulaCell(t);if(c&&(a=pS(c.compiledFormula.tokens),r=a,!a&&""!==i)){n=(i??"").toString();const t=o.format;if(t){const o=ws(t,e.formats);l.formats[s]=o}}const h=l.cells[s];let d;d=a&&r&&c instanceof $M?c.contentWithFixedReferences:a?h:n,l.cells[s]=d,l.cellValues[s]=i}}getCorrespondingFormulaCell(e){const t=this.getters.getCell(e);if(t&&t.isFormula)return t.compiledFormula.isBadExpression?void 0:t;if(t&&t.content)return;const o=this.getArrayFormulaSpreadingOn(e);if(void 0===o)return;const s=this.getters.getCell(o);return s?.isFormula?s:void 0}}).add("evaluation_chart",class extends KM{static getters=["getChartRuntime","getStyleOfSingleCellChart"];charts={};createRuntimeChart=mR(this.getters);handle(e){if(ai.has(e.type)||hi.has(e.type)||li.has(e.type))for(const e in this.charts)this.charts[e]=void 0;switch(e.type){case"UPDATE_CHART":case"CREATE_CHART":case"DELETE_FIGURE":this.charts[e.id]=void 0;break;case"DELETE_SHEET":for(let e in this.charts)this.getters.isChartDefined(e)||(this.charts[e]=void 0)}}getChartRuntime(e){if(!this.charts[e]){const t=this.getters.getChart(e);if(!t)throw new Error(`No chart for the given id: ${e}`);this.charts[e]=this.createRuntimeChart(t)}return this.charts[e]}getStyleOfSingleCellChart(e,t){if(e)return{background:e,fontColor:Zc(e)};if(!t)return{background:m,fontColor:Zc(m)};const o=t.zone.left,s=t.zone.top,i=t.sheetId,n=this.getters.getCellComputedStyle({sheetId:i,col:o,row:s}),r=n.fillColor||m;return{background:r,fontColor:n.textColor||Zc(r)}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const s of e){if(!s||"chart"!==s.tag)continue;const e=s.id,i=this.getters.getChart(e)?.getDefinitionForExcel();if(i)o.push({...s,data:i});else{if(!this.getters.getChart(e))continue;const o=this.getters.getChartType(e),i=XS(this.getters.getChartRuntime(e),s,o);i&&t.images.push({...s,tag:"image",data:{mimetype:"image/png",path:i,size:{width:s.width,height:s.height}}})}}t.charts=o}}}).add("evaluation_cf",class extends KM{static getters=["getConditionalIcon","getCellConditionalFormatStyle","getConditionalDataBar"];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(ai.has(e.type)||hi.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))&&(this.isStale=!0)}finalize(){if(this.isStale){for(const e of this.getters.getSheetIds())this.computedStyles[e]=ut((()=>this.getComputedStyles(e))),this.computedIcons[e]=ut((()=>this.getComputedIcons(e))),this.computedDataBars[e]=ut((()=>this.getComputedDataBars(e)));this.isStale=!1}}getCellConditionalFormatStyle(e){const{sheetId:t,col:o,row:s}=e,i=this.computedStyles[t]();return i&&i[o]?.[s]}getConditionalIcon({sheetId:e,col:t,row:o}){const s=this.computedIcons[e]();return s&&s[t]?.[o]}getConditionalDataBar({sheetId:e,col:t,row:o}){const s=this.computedDataBars[e]();return s&&s[t]?.[o]}getComputedStyles(e){const t={};for(let o of this.getters.getConditionalFormats(e).reverse())switch(o.rule.type){case"ColorScaleRule":for(let s of o.ranges)this.applyColorScale(e,s,o.rule,t);break;case"CellIsRule":const s=o.rule.values.map((e=>e.startsWith("=")?hS(e):void 0));for(let i of o.ranges){const n=this.getters.getRangeFromSheetXC(e,i).zone;for(let i=n.top;i<=n.bottom;i++)for(let r=n.left;r<=n.right;r++){const a=this.rulePredicate[o.rule.type],l={sheetId:e,col:r,row:i},c=o.rule.values.map(((t,o)=>{const a=s[o];return a?this.getters.getTranslatedCellFormula(e,r-n.left,i-n.top,a.tokens):t}));a&&a(l,{...o.rule,values:c})&&(t[r]||(t[r]=[]),t[r][i]=Object.assign(t[r]?.[i]||{},o.rule.style))}}}return t}getComputedIcons(e){const t={};for(let o of this.getters.getConditionalFormats(e).reverse())if("IconSetRule"===o.rule.type)for(let s of o.ranges)this.applyIcon(e,s,o.rule,t);return t}getComputedDataBars(e){const t={};for(let o of this.getters.getConditionalFormats(e).reverse())if("DataBarRule"===o.rule.type)for(let s of o.ranges)this.applyDataBar(e,s,o.rule,t);return t}parsePoint(e,t,o,s){const i=this.getters.getEvaluatedCellsInZone(e,this.getters.getRangeFromSheetXC(e,t).zone).filter((e=>e.type===ni.number)).map((e=>e.value));switch(o.type){case"value":return"max"===s?Dt(i):Ot(i);case"number":return Number(o.value);case"percentage":const t=Ot(i);return t+(Dt(i)-t)*Number(o.value)/100;case"percentile":return ii(i,Number(o.value)/100,!0);case"formula":const n=o.value&&this.getters.evaluateFormula(e,o.value);return"number"==typeof n?n:null;default:return null}}applyIcon(e,t,o,s){const i=this.parsePoint(e,t,o.lowerInflectionPoint),n=this.parsePoint(e,t,o.upperInflectionPoint);if(null===i||null===n||i>n)return;const r=this.getters.getRangeFromSheetXC(e,t).zone,a=[o.icons.upper,o.icons.middle,o.icons.lower];for(let t=r.top;t<=r.bottom;t++)for(let l=r.left;l<=r.right;l++){const r=this.getters.getEvaluatedCell({sheetId:e,col:l,row:t});if(r.type!==ni.number)continue;const c=this.computeIcon(r.value,n,o.upperInflectionPoint.operator,i,o.lowerInflectionPoint.operator,a);s[l]||(s[l]=[]),s[l][t]=c}}computeIcon(e,t,o,s,i,n){return"ge"===o&&e>=t||"gt"===o&&e>t?n[0]:"ge"===i&&e>=s||"gt"===i&&e>s?n[1]:n[2]}applyDataBar(e,t,o,s){const i=this.getters.getRangeFromSheetXC(e,o.rangeValues||t),n=Dt(this.getters.getEvaluatedCellsInZone(e,i.zone).filter((e=>e.type===ni.number)).map((e=>e.value)));if(n<=0)return;const r=o.color,a=this.getters.getRangeFromSheetXC(e,t).zone,l=i.zone;for(let t=a.top;t<=a.bottom;t++)for(let o=a.left;o<=a.right;o++){const i=o-a.left+l.left,c=t-a.top+l.top,h=this.getters.getEvaluatedCell({sheetId:e,col:i,row:c});!as(i,c,l)||h.type!==ni.number||h.value<=0||(s[o]||(s[o]=[]),s[o][t]={color:Ht(r),percentage:100*h.value/n})}}applyColorScale(e,t,o,s){const i=this.parsePoint(e,t,o.minimum,"min"),n=o.midpoint?this.parsePoint(e,t,o.midpoint):null,r=this.parsePoint(e,t,o.maximum,"max");if(null===i||null===r||i>=r||n&&(i>=n||n>=r))return;const a=this.getters.getRangeFromSheetXC(e,t).zone,l=[{value:i,color:o.minimum.color}];o.midpoint&&n&&l.push({value:n,color:o.midpoint.color}),l.push({value:r,color:o.maximum.color});const c=go(l);for(let t=a.top;t<=a.bottom;t++)for(let o=a.left;o<=a.right;o++){const n=this.getters.getEvaluatedCell({sheetId:e,col:o,row:t});if(n.type===ni.number){const e=qe(n.value,i,r);s[o]||(s[o]=[]),s[o][t]=s[o]?.[t]||{},s[o][t].fillColor=c(e)}}}rulePredicate={CellIsRule:(e,t)=>{const o=this.getters.getEvaluatedCell(e);if(o.type===ni.error)return!1;let[s,i]=t.values.map((t=>t.startsWith("=")?this.getters.evaluateFormula(e.sheetId,t)??"":Rr(t,Si)));if(Ci(s)||Ci(i))return!1;const n=o.value??"";switch(s=s??"",i=i??"",t.operator){case"IsEmpty":return""===n.toString().trim();case"IsNotEmpty":return""!==n.toString().trim();case"BeginsWith":return""!==s&&n.toString().startsWith(s.toString());case"EndsWith":return""!==s&&n.toString().endsWith(s.toString());case"Between":return n>=s&&n<=i;case"NotBetween":return!(n>=s&&n<=i);case"ContainsText":return n.toString().indexOf(s.toString())>-1;case"NotContains":return!n||-1===n.toString().indexOf(s.toString());case"GreaterThan":return n>s;case"GreaterThanOrEqual":return n>=s;case"LessThan":return n<s;case"LessThanOrEqual":return n<=s;case"NotEqual":return""!==s&&n!==s;case"Equal":return""===s||n===s;default:console.warn(Fo("Not implemented operator %s for kind of conditional formatting: %s",t.operator,t.type))}return!1}}}).add("row_size",class extends KM{static getters=["getRowSize","getHeaderSize"];tallestCellInRow={};ctx=document.createElement("canvas").getContext("2d");handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())this.initializeSheet(e);break;case"CREATE_SHEET":this.initializeSheet(e.sheetId);break;case"DUPLICATE_SHEET":{const t=Be(this.tallestCellInRow[e.sheetId]);this.history.update("tallestCellInRow",e.sheetIdTo,t);break}case"DELETE_SHEET":const t={...this.tallestCellInRow};delete t[e.sheetId],this.history.update("tallestCellInRow",t);break;case"REMOVE_COLUMNS_ROWS":{if("COL"===e.dimension)return;const t=It(this.tallestCellInRow[e.sheetId],e.elements);this.history.update("tallestCellInRow",e.sheetId,t);break}case"ADD_COLUMNS_ROWS":{if("COL"===e.dimension)return;const t=pt(e.position,e.base),o=Array(e.quantity).fill(void 0),s=Rt(this.tallestCellInRow[e.sheetId],o,t);this.history.update("tallestCellInRow",e.sheetId,s);break}case"RESIZE_COLUMNS_ROWS":{const t=e.sheetId;if("ROW"===e.dimension)for(const o of e.elements){const e=this.getRowTallestCell(t,o);this.history.update("tallestCellInRow",t,o,e)}else for(const o of Ze(0,this.getters.getNumberRows(t)))for(const s of e.elements)this.updateRowSizeForCellChange(t,o,s)}break;case"UPDATE_CELL":this.updateRowSizeForCellChange(e.sheetId,e.row,e.col);break;case"ADD_MERGE":case"REMOVE_MERGE":for(const t of e.target)for(const o of us(t))this.updateRowSizeForCellChange(e.sheetId,o.row,o.col)}}getRowSize(e,t){return Math.round(this.getters.getUserRowSize(e,t)??this.tallestCellInRow[e][t]?.size??se)}getHeaderSize(e,t,o){return this.getters.isHeaderHidden(e,t,o)?0:"ROW"===t?this.getRowSize(e,o):this.getters.getColSize(e,o)}updateRowSizeForCellChange(e,t,o){const s=this.tallestCellInRow[e]?.[t];if(s?.cell.col===o){const o=this.getRowTallestCell(e,t);this.history.update("tallestCellInRow",e,t,o)}const i=this.getCellHeight({sheetId:e,col:o,row:t});if(!(i<=se)&&(!s&&i>se||s&&i>s.size)){const s={cell:{sheetId:e,col:o,row:t},size:i};this.history.update("tallestCellInRow",e,t,s)}}initializeSheet(e){const t=[];for(let o=0;o<this.getters.getNumberRows(e);o++){const s=this.getRowTallestCell(e,o);t.push(s)}this.history.update("tallestCellInRow",e,t)}getCellHeight(e){if(this.isInMultiRowMerge(e))return se;const t=this.getters.getCell(e),o=this.getters.getColSize(e.sheetId,e.col);return function(e,t,o){if(!t||!t.isFormula&&!t.content)return se;const s="wrap"===t.style?.wrapping?o-2*ne:void 0,i=t.isFormula?1:oa(e,t.content,t.style,s).length;return Gr(ea(t.style),i)+6}(this.ctx,t,o)}isInMultiRowMerge(e){const t=this.getters.getMerge(e);return!!t&&t.bottom!==t.top}getRowTallestCell(e,t){if(void 0!==this.getters.getUserRowSize(e,t))return;const o=this.getters.getRowCells(e,t);let s,i=0;for(let e=0;e<o.length;e++){const t=this.getters.getCellById(o[e]);if(!t)continue;const n=this.getters.getCellPosition(t.id),r=this.getCellHeight(n);r>i&&r>se&&(i=r,s={cell:n,size:r})}return s&&s.size>se?s:void 0}}).add("data_validation_ui",class extends KM{static getters=["getDataValidationInvalidCriterionValueMessage","getInvalidDataValidationMessage","getValidationResultForCellValue","isCellValidCheckbox","isDataValidationInvalid"];validationResults={};handle(e){if(ai.has(e.type)||"EVALUATE_CELLS"===e.type||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))this.validationResults={};else switch(e.type){case"ADD_DATA_VALIDATION_RULE":case"REMOVE_DATA_VALIDATION_RULE":delete this.validationResults[e.sheetId]}}isDataValidationInvalid(e){return!this.getValidationResultForCell(e).isValid}getInvalidDataValidationMessage(e){const t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){const o=gO.get(e);return t.startsWith("=")?"onlyLiterals"===o.allowedValues?Fo("The value must not be a formula"):this.isValidFormula(t)?void 0:bx.CriterionError.validFormula:"onlyFormulas"===o.allowedValues?Fo("The value must be a formula"):o.isCriterionValueValid(t)?void 0:o.criterionValueErrorString}isCellValidCheckbox(e){if(!this.getters.isMainCellPosition(e))return!1;const t=this.getters.getValidationRuleForCell(e);return!(!t||"isBoolean"!==t.criterion.type)&&this.getValidationResultForCell(e).isValid}getValidationResultForCellValue(e,t){const o=this.getters.getValidationRuleForCell(t);if(!o)return PP;const s=this.getRuleErrorForCellValue(e,t,o);return s?{error:s,rule:o,isValid:!1}:PP}isValidFormula(e){return!hS(e).isBadExpression}getValidationResultForCell(e){const{col:t,row:o,sheetId:s}=e;return this.validationResults[s]||(this.validationResults[s]=this.computeSheetValidationResults(s)),this.validationResults[s][t]?.[o]?.()||PP}computeSheetValidationResults(e){const t={},o=this.getters.getDataValidationRules(e).map((e=>e.ranges));for(const e of Ur(o.flat())){const{col:o,row:s}=e;t[o]||(t[o]=[]),t[o][s]=ut((()=>{const t=this.getters.getEvaluatedCell(e);return t.type===ni.empty?PP:this.getValidationResultForCellValue(t.value,e)}))}return t}getRuleErrorForCellValue(e,t,o){const{sheetId:s}=t,i=o.criterion,n=gO.get(i.type),r=this.getCellOffsetInRule(t,o),a=this.getEvaluatedCriterionValues(s,r,i),l={...i,values:a};if(!n.isValueValid(e,l,this.getters,s))return n.getErrorString(l,this.getters,s)}getCellOffsetInRule(e,t){const o=t.ranges.find((t=>as(e.col,e.row,t.zone)));if(!o)throw new Error("The cell is not in any range of the rule");return{col:e.col-o.zone.left,row:e.row-o.zone.top}}getEvaluatedCriterionValues(e,t,o){return o.values.map((o=>{if(!o.startsWith("="))return o;const s=hS(o),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,s.tokens),n=this.getters.evaluateFormula(e,i);return n&&!Ci(n)?n.toString():""}))}}).add("dynamic_tables",class extends KM{static getters=["canCreateDynamicTableOnZones","doesZonesContainFilter","getFilter","getFilters","getTable","getTables","getTablesOverlappingZones","getFilterId","getFilterHeaders","isFilterHeader"];tables={};handle(e){if(ai.has(e.type)||"UPDATE_CELL"===e.type&&"content"in e||"EVALUATE_CELLS"===e.type)this.tables={};else switch(e.type){case"CREATE_TABLE":case"REMOVE_TABLE":case"UPDATE_TABLE":case"DELETE_CONTENT":this.tables={}}}finalize(){for(const e of this.getters.getSheetIds())this.tables[e]||(this.tables[e]=this.computeTables(e))}computeTables(e){const t=[],o=this.getters.getCoreTables(e);for(const e of o)"dynamic"!==e.type&&t.push(e);const s=[...t];for(const i of o){if("dynamic"!==i.type)continue;const o=this.coreTableToTable(e,i);let n=o.range.zone;for(const e of s)rs(n,e.range.zone)&&(n={...n,right:e.range.zone.left-1});t.push({...o,range:this.getters.getRangeFromZone(e,n)})}return t}getFilters(e){return this.getTables(e).filter((e=>e.config.hasFilters)).map((e=>e.filters)).flat()}getTables(e){return this.tables[e]||[]}getFilter(e){const t=this.getTable(e);if(t&&t.config.hasFilters)return t.filters.find((t=>t.col===e.col))}getFilterId(e){return this.getFilter(e)?.id}getTable({sheetId:e,col:t,row:o}){return this.getTables(e).find((e=>as(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getTables(e).filter((e=>t.some((t=>rs(e.range.zone,t)))))}doesZonesContainFilter(e,t){return this.getTablesOverlappingZones(e,t).some((e=>e.config.hasFilters))}getFilterHeaders(e){const t=[];for(const o of this.getTables(e)){if(!o.config.hasFilters)continue;const s=o.range.zone,i=s.top;for(let o=s.left;o<=s.right;o++)t.push({sheetId:e,col:o,row:i})}return t}isFilterHeader({sheetId:e,col:t,row:o}){return this.getFilterHeaders(e).some((e=>e.col===t&&e.row===o))}canCreateDynamicTableOnZones(e,t){if(!ys(t))return!1;const o=ss(...t),s={col:o.left,row:o.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(s);if(!i)return!1;if(mt(i,s)&&1===Ss(o))return!0;return mt(o,this.getters.getSpreadZone(i))}coreTableToTable(e,t){if("dynamic"!==t.type)return t;const o=t.range.zone,s={sheetId:e,col:o.left,row:o.top},i=this.getters.getSpreadZone(s)??t.range.zone,n=this.getters.getRangeFromZone(e,i),r=this.getDynamicTableFilters(e,t,i);return{id:t.id,range:n,filters:r,config:t.config}}getDynamicTableFilters(e,t,o){const s=[],{top:i,bottom:n,left:r,right:a}=o;for(let o=r;o<=a;o++){const a=o-r,l={left:o,right:o,top:i,bottom:n},c=EF(this.getDynamicTableFilterId(t.id,a),this.getters.getRangeFromZone(e,l),t.config,this.getters.getRangeFromZone);s.push(c)}return s}getDynamicTableFilterId(e,t){return e+"_"+t}exportForExcel(e){for(const t of e.sheets)for(const e of t.tables){const o=Yo(e.range),s={sheetId:t.id,col:o.left,row:o.top},i=this.getters.getCoreTable(s),n=this.getTable(s);"dynamic"===i?.type&&n&&(e.range=Jo(n.range.zone))}}}).add("custom_colors",class extends KM{customColors={};shouldUpdateColors=!0;static getters=["getCustomColors"];constructor(e){super(e),this.tryToAddColors(e.customColors??[])}handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())for(const t of this.getters.getChartIds(e))this.tryToAddColors(this.getChartColors(t));break;case"UPDATE_CHART":case"CREATE_CHART":this.tryToAddColors(this.getChartColors(e.id));break;case"UPDATE_CELL":case"ADD_CONDITIONAL_FORMAT":case"SET_BORDER":case"SET_ZONE_BORDERS":case"SET_FORMATTING":case"CREATE_TABLE":case"UPDATE_TABLE":this.history.update("shouldUpdateColors",!0)}}finalize(){this.shouldUpdateColors&&(this.history.update("shouldUpdateColors",!1),this.tryToAddColors(this.computeCustomColors()))}getCustomColors(){return function(e){const t=[{leadColor:Wt(255,0,0),colors:[]},{leadColor:Wt(255,128,0),colors:[]},{leadColor:Wt(128,128,0),colors:[]},{leadColor:Wt(128,255,0),colors:[]},{leadColor:Wt(0,255,0),colors:[]},{leadColor:Wt(0,255,128),colors:[]},{leadColor:Wt(0,255,255),colors:[]},{leadColor:Wt(0,127,255),colors:[]},{leadColor:Wt(0,0,255),colors:[]},{leadColor:Wt(127,0,255),colors:[]},{leadColor:Wt(128,0,128),colors:[]},{leadColor:Wt(255,0,128),colors:[]}];for(const o of e.map(Zt)){let e=500,s=0;t.forEach(((t,i)=>{const n=(r=o,a=t.leadColor,Math.sqrt(Math.pow(r.r-a.r,2)+Math.pow(r.g-a.g,2)+Math.pow(r.b-a.b,2)));var r,a;e>n&&(e=n,s=i)})),t[s].colors.push(o)}return t.map((e=>e.colors.sort(((e,t)=>Yt(e).s-Yt(t).s)))).flat().map(qt)}(Object.keys(this.customColors))}computeCustomColors(){let e=[];for(const t of this.getters.getSheetIds())e=e.concat(this.getColorsFromCells(t),this.getFormattingColors(t),this.getTableColors(t));return[...new Set([...e])]}getColorsFromCells(e){const t=Object.values(this.getters.getCells(e)),o=new Set;for(const e of t)e.style?.textColor&&o.add(e.style.textColor),e.style?.fillColor&&o.add(e.style.fillColor);for(const t of this.getters.getBordersColors(e))o.add(t);return[...o]}getFormattingColors(e){const t=this.getters.getConditionalFormats(e),o=[];for(const e of t){const t=e.rule;"CellIsRule"===t.type?(o.push(t.style.textColor),o.push(t.style.fillColor)):"ColorScaleRule"===t.type&&(o.push(Ht(t.minimum.color)),o.push(t.midpoint?Ht(t.midpoint.color):void 0),o.push(Ht(t.maximum.color)))}return o.filter(at)}getChartColors(e){const t=this.getters.getChart(e);if(void 0===t)return[];return[...JSON.stringify(t.getDefinition()).matchAll(MP)].map((e=>e[1]))}getTableColors(e){return this.getters.getTables(e).flatMap((e=>{const t=e.config,o=this.getters.getTableStyle(t.styleId);return[this.getTableStyleElementColors(o.wholeTable),t.numberOfHeaders>0?this.getTableStyleElementColors(o.headerRow):[],t.totalRow?this.getTableStyleElementColors(o.totalRow):[],t.bandedColumns?this.getTableStyleElementColors(o.firstColumnStripe):[],t.bandedColumns?this.getTableStyleElementColors(o.secondColumnStripe):[],t.bandedRows?this.getTableStyleElementColors(o.firstRowStripe):[],t.bandedRows?this.getTableStyleElementColors(o.secondRowStripe):[],t.firstColumn?this.getTableStyleElementColors(o.firstColumn):[],t.lastColumn?this.getTableStyleElementColors(o.lastColumn):[]].flat()}))}getTableStyleElementColors(e){return e?[e.style?.fillColor,e.style?.textColor,e.border?.bottom?.color,e.border?.top?.color,e.border?.left?.color,e.border?.right?.color,e.border?.horizontal?.color,e.border?.vertical?.color].filter(at):[]}tryToAddColors(e){for(const t of e){if(!zt(t))continue;const e=Bt(t);t&&!Q.includes(e)&&this.history.update("customColors",e,!0)}}}).add("pivot_ui",class extends KM{static getters=["getPivot","getFirstPivotFunction","getPivotIdFromPosition","getPivotCellFromPosition","generateNewCalculatedMeasureName","isPivotUnused","isSpillPivotFormula"];pivots={};unusedPivots;custom;constructor(e){super(e),this.custom=e.custom}beforeHandle(e){if("START"===e.type)for(const e of this.getters.getPivotIds())this.setupPivot(e)}handle(e){if(ai.has(e.type))for(const e of this.getters.getPivotIds())dF.get(this.getters.getPivotCoreDefinition(e).type).externalData||this.setupPivot(e,{recreate:!0});switch(e.type){case"REFRESH_PIVOT":this.refreshPivot(e.id);break;case"ADD_PIVOT":this.setupPivot(e.pivotId);break;case"DUPLICATE_PIVOT":this.setupPivot(e.newPivotId);break;case"UPDATE_PIVOT":this.setupPivot(e.pivotId,{recreate:!0});break;case"DELETE_SHEET":case"UPDATE_CELL":this.unusedPivots=void 0;break;case"UNDO":case"REDO":{this.unusedPivots=void 0;const t=e.commands.filter(VP);for(const e of t){const t=e.pivotId;this.getters.isExistingPivot(t)&&this.setupPivot(t,{recreate:!0})}break}case"UPDATE_LOCALE":!function(){for(const e in cF)cF[e].set.clear(),cF[e].values={}}()}}getPivotIdFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(o){const e=o.args[0]?.toString();return e&&this.getters.getPivotId(e)}}}isSpillPivotFormula(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);return"PIVOT"===o?.functionName}return!1}getFirstPivotFunction(e,t){const o=CS(t);if(!o)return;const{functionName:s,args:i}=o;return{functionName:s,args:i.map((t=>{if("EMPTY"==t.type)return;if("STRING"===t.type||"BOOLEAN"===t.type||"NUMBER"===t.type)return t.value;const o=Mf(t);return this.getters.evaluateFormula(e,o)}))}}getPivotCellFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||0===wS(t.compiledFormula.tokens))return eF;const o=this.getters.getCellPosition(t.id),s=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!s)return eF;const{functionName:i,args:n}=s,r=n[0];if(!r)return eF;const a=this.getters.getPivotId(r.toString());if(!a)return eF;const l=this.getPivot(a);if(!l.isValid())return eF;if("PIVOT"===i&&!t.content.replaceAll(" ","").toUpperCase().startsWith("=PIVOT"))return eF;if("PIVOT"===i){const t=Ja(n[2]),s=void 0===t||Yi(t),i=Ja(n[3]),r=void 0===i||Yi(i),a=l.getTableStructure().getPivotCells(s,r),c=e.col-o.col,h=e.row-o.row;return a[c][h]}try{if("PIVOT.HEADER"===i&&"measure"===n.at(-2)){return{type:"MEASURE_HEADER",domain:l.parseArgsToPivotDomain(n.slice(1,-2).map((e=>({value:e})))),measure:n.at(-1)?.toString()||""}}if("PIVOT.HEADER"===i){return{type:"HEADER",domain:l.parseArgsToPivotDomain(n.slice(1).map((e=>({value:e}))))}}const[e,...t]=n.slice(1);return{type:"VALUE",domain:l.parseArgsToPivotDomain(t.map((e=>({value:e})))),measure:e?.toString()||""}}catch(e){return eF}}generateNewCalculatedMeasureName(e){const t=e.map((e=>e.fieldName));return Nt(Fo("Calculated measure 1"),t,{compute:(e,t)=>Fo("Calculated measure %s",t)})}getPivot(e){if(!this.getters.isExistingPivot(e))throw new Error(`pivot ${e} not found`);return this.pivots[e]}isPivotUnused(e){return this._getUnusedPivots().includes(e)}refreshPivot(e){this.getters.getPivot(e).init({reload:!0})}setupPivot(e,{recreate:t}={recreate:!1}){const o=this.getters.getPivotCoreDefinition(e);if(e in this.pivots)t&&this.pivots[e].onDefinitionChange(o);else{const t=kP(dF.get(o.type).ui);this.pivots[e]=new t(this.custom,{definition:o,getters:this.getters})}}_getUnusedPivots(){if(void 0!==this.unusedPivots)return this.unusedPivots;const e=new Set(this.getters.getPivotIds());for(const t of this.getters.getSheetIds())for(const o in this.getters.getCells(t)){const t=this.getters.getCellPosition(o),s=this.getPivotIdFromPosition(t);if(s&&(e.delete(s),!e.size))return this.unusedPivots=[],[]}return this.unusedPivots=[...e],this.unusedPivots}}),SN=new n;SN.add("link",{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t)=>Tn(t.model.getters.getEvaluatedCell(e).link,t),sequence:5});class yN{fileStore;constructor(e){this.fileStore=e}async requestImage(){const e=await this.getImageFromUser(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}getImageFromUser(){return new Promise(((e,t)=>{const o=document.createElement("input");o.setAttribute("type","file"),o.setAttribute("accept","image/*"),o.addEventListener("change",(async()=>{null===o.files||1!=o.files.length?t():e(o.files[0])})),o.click()}))}getImageOriginalSize(e){return new Promise(((t,o)=>{const s=new Image;s.src=e,s.addEventListener("load",(()=>{const e={width:s.width,height:s.height};t(e)})),s.addEventListener("error",o)}))}}const CN=[{transform:"scale(0)"},{transform:"scale(0.8)",offset:.33},{opacity:"0",transform:"scale(1)",offset:1}];Mc`
|
|
1856
|
+
`;class VM extends t.Component{static template="o-spreadsheet-TableResizer";static props={table:Object};state=t.useState({highlightZone:void 0});setup(){aO(this)}get containerStyle(){const e=this.props.table.range.zone,t={...e,left:e.right,top:e.bottom},o=this.env.model.getters.getVisibleRect(t);return 0===o.height||0===o.width?kc({display:"none"}):kc({top:o.y+o.height-6+"px",left:o.x+o.width-6+"px"})}onMouseDown(e){const t=this.props.table.range.zone,o={col:t.left,row:t.top};document.body.style.cursor="nwse-resize";j_(this.env,((e,t,s)=>{this.state.highlightZone={left:o.col,top:o.row,right:Math.max(e,o.col),bottom:Math.max(t,o.row)}}),(()=>{document.body.style.cursor="";const e=this.state.highlightZone;if(!e)return;const t=this.props.table.range.sheetId;this.env.model.dispatch("RESIZE_TABLE",{sheetId:t,zone:this.props.table.range.zone,newTableRange:this.env.model.getters.getRangeDataFromZone(t,e)}),this.state.highlightZone=void 0}))}get highlights(){return this.state.highlightZone?[{zone:this.state.highlightZone,sheetId:this.props.table.range.sheetId,color:LM,noFill:!0}]:[]}}const HM={ROW:z_,COL:V_,CELL:jT,GROUP_HEADERS:GF,UNGROUP_HEADERS:qF};class UM extends t.Component{static template="o-spreadsheet-Grid";static props={exposeFocus:Function};static components={GridComposer:eM,GridOverlay:SM,GridPopover:yM,HeadersOverlay:EM,Menu:dR,Autofill:jF,ClientTag:XF,Highlight:OM,Popover:OI,VerticalScrollBar:PM,HorizontalScrollBar:MM,TableResizer:VM};HEADER_HEIGHT=ee;HEADER_WIDTH=te;menuState;gridRef;highlightStore;cellPopovers;composerFocusStore;DOMFocusableElementStore;paintFormatStore;onMouseWheel;canvasPosition;hoveredCell;sidePanel;setup(){this.highlightStore=yc(Xb),this.menuState=t.useState({isOpen:!1,position:null,menuItems:[]}),this.gridRef=t.useRef("grid"),this.canvasPosition=DI(this.gridRef),this.hoveredCell=yc(EI),this.composerFocusStore=yc(Dc),this.DOMFocusableElementStore=yc(GD),this.sidePanel=yc(kM),this.paintFormatStore=yc(vM),yc(ZF),t.useChildSubEnv({getPopoverContainerRect:()=>this.getGridRect()}),t.useExternalListener(document.body,"cut",this.copy.bind(this,!0)),t.useExternalListener(document.body,"copy",this.copy.bind(this,!1)),t.useExternalListener(document.body,"paste",this.paste),t.onMounted((()=>this.focusDefaultElement())),this.props.exposeFocus((()=>this.focusDefaultElement())),TM("canvas",this.env.model,(()=>this.env.model.getters.getSheetViewDimensionWithHeaders())),this.onMouseWheel=AM(((e,t)=>{this.moveCanvas(e,t),this.hoveredCell.clear()})),this.cellPopovers=yc(II),t.useEffect((()=>{this.sidePanel.isOpen||this.DOMFocusableElementStore.focusableElement?.focus()}),(()=>[this.sidePanel.isOpen]))}onCellHovered({col:e,row:t}){this.hoveredCell.hover({col:e,row:t})}get highlights(){return this.highlightStore.highlights}get gridOverlayDimensions(){return kc({top:"26px",left:"48px",height:"calc(100% - 41px)",width:"calc(100% - 63px)"})}onClosePopover(){this.cellPopovers.isOpen&&this.cellPopovers.close(),this.focusDefaultElement()}keyDownMapping={Enter:()=>{this.env.model.getters.getActiveCell().type===ni.empty?this.onComposerCellFocused():this.onComposerContentFocused()},Tab:()=>this.env.model.selection.moveAnchorCell("right",1),"Shift+Tab":()=>this.env.model.selection.moveAnchorCell("left",1),F2:()=>{this.env.model.getters.getActiveCell().type===ni.empty?this.onComposerCellFocused():this.onComposerContentFocused()},Delete:()=>{this.env.model.dispatch("DELETE_CONTENT",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones()})},Backspace:()=>{this.env.model.dispatch("DELETE_CONTENT",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones()})},Escape:()=>{this.cellPopovers.isOpen?this.cellPopovers.close():this.menuState.isOpen?this.closeMenu():this.paintFormatStore.isActive?this.paintFormatStore.cancel():this.env.model.dispatch("CLEAN_CLIPBOARD_HIGHLIGHT")},"Ctrl+A":()=>this.env.model.selection.loopSelection(),"Ctrl+Z":()=>this.env.model.dispatch("REQUEST_UNDO"),"Ctrl+Y":()=>this.env.model.dispatch("REQUEST_REDO"),F4:()=>this.env.model.dispatch("REQUEST_REDO"),"Ctrl+B":()=>this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{bold:!this.env.model.getters.getCurrentStyle().bold}}),"Ctrl+I":()=>this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{italic:!this.env.model.getters.getCurrentStyle().italic}}),"Ctrl+U":()=>this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{underline:!this.env.model.getters.getCurrentStyle().underline}}),"Ctrl+O":()=>_R(this.env),"Alt+=":()=>{const e=this.env.model.getters.getActiveSheetId(),t=this.env.model.getters.getSelectedZone(),{anchor:o}=this.env.model.getters.getSelection(),s=this.env.model.getters.getAutomaticSums(e,t,o.cell);if(this.env.model.getters.isSingleCellOrMerge(e,t)||this.env.model.getters.isEmpty(e,t)&&s.length<=1){const t=s[0]?.zone,o=t?this.env.model.getters.zoneToXC(e,s[0].zone):"",i=`=SUM(${o})`;this.onComposerCellFocused(i,{start:5,end:5+o.length})}else this.env.model.dispatch("SUM_SELECTION")},"Alt+Enter":()=>{const e=this.env.model.getters.getActiveCell();e.link&&Tn(e.link,this.env)},"Ctrl+Home":()=>{const e=this.env.model.getters.getActiveSheetId(),{col:t,row:o}=this.env.model.getters.getNextVisibleCellPosition({sheetId:e,col:0,row:0});this.env.model.selection.selectCell(t,o)},"Ctrl+End":()=>{const e=this.env.model.getters.getActiveSheetId(),t=this.env.model.getters.findVisibleHeader(e,"COL",this.env.model.getters.getNumberCols(e)-1,0),o=this.env.model.getters.findVisibleHeader(e,"ROW",this.env.model.getters.getNumberRows(e)-1,0);this.env.model.selection.selectCell(t,o)},"Shift+ ":()=>{const e=this.env.model.getters.getActiveSheetId(),t={...this.env.model.getters.getSelectedZone(),left:0,right:this.env.model.getters.getNumberCols(e)-1},o=this.env.model.getters.getActivePosition();this.env.model.selection.selectZone({cell:o,zone:t})},"Ctrl+ ":()=>{const e=this.env.model.getters.getActiveSheetId(),t={...this.env.model.getters.getSelectedZone(),top:0,bottom:this.env.model.getters.getNumberRows(e)-1},o=this.env.model.getters.getActivePosition();this.env.model.selection.selectZone({cell:o,zone:t})},"Ctrl+D":async()=>this.env.model.dispatch("COPY_PASTE_CELLS_ABOVE"),"Ctrl+R":async()=>this.env.model.dispatch("COPY_PASTE_CELLS_ON_LEFT"),"Ctrl+H":()=>this.sidePanel.open("FindAndReplace",{}),"Ctrl+F":()=>this.sidePanel.open("FindAndReplace",{}),"Ctrl+Shift+E":()=>this.setHorizontalAlign("center"),"Ctrl+Shift+L":()=>this.setHorizontalAlign("left"),"Ctrl+Shift+R":()=>this.setHorizontalAlign("right"),"Ctrl+Shift+V":()=>xR(this.env),"Ctrl+Shift+<":()=>this.clearFormatting(),"Ctrl+<":()=>this.clearFormatting(),"Ctrl+Shift+ ":()=>{this.env.model.selection.selectAll()},"Ctrl+Alt+=":()=>{const e=this.env.model.getters.getActiveCols(),t=this.env.model.getters.getActiveRows(),o=1===this.env.model.getters.getSelectedZones().length,s=e.size>0&&o,i=t.size>0&&o;s&&!i?TR(this.env):i&&!s&&RR(this.env)},"Ctrl+Alt+-":()=>{const e=[...this.env.model.getters.getActiveCols()],t=[...this.env.model.getters.getActiveRows()];e.length>0&&0===t.length?this.env.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:this.env.model.getters.getActiveSheetId(),dimension:"COL",elements:e}):t.length>0&&0===e.length&&this.env.model.dispatch("REMOVE_COLUMNS_ROWS",{sheetId:this.env.model.getters.getActiveSheetId(),dimension:"ROW",elements:t})},"Shift+PageDown":()=>{this.env.model.dispatch("ACTIVATE_NEXT_SHEET")},"Shift+PageUp":()=>{this.env.model.dispatch("ACTIVATE_PREVIOUS_SHEET")},PageDown:()=>this.env.model.dispatch("SHIFT_VIEWPORT_DOWN"),PageUp:()=>this.env.model.dispatch("SHIFT_VIEWPORT_UP"),"Ctrl+K":()=>DR(this.env),"Alt+Shift+ArrowRight":()=>this.processHeaderGroupingKey("right"),"Alt+Shift+ArrowLeft":()=>this.processHeaderGroupingKey("left"),"Alt+Shift+ArrowUp":()=>this.processHeaderGroupingKey("up"),"Alt+Shift+ArrowDown":()=>this.processHeaderGroupingKey("down")};focusDefaultElement(){this.env.model.getters.getSelectedFigureId()||"inactive"!==this.composerFocusStore.activeComposer.editionMode||this.DOMFocusableElementStore.focusableElement?.focus()}get gridEl(){if(!this.gridRef.el)throw new Error("Grid el is not defined.");return this.gridRef.el}getAutofillPosition(){const e=this.env.model.getters.getSelectedZone(),t=this.env.model.getters.getVisibleRect(e);return{left:t.x+t.width-4,top:t.y+t.height-4}}get isAutofillVisible(){const e=this.env.model.getters.getSelectedZone(),t=this.env.model.getters.getVisibleRect({left:e.right,right:e.right,top:e.bottom,bottom:e.bottom});return!(0===t.width||0===t.height)}onGridResized({height:e,width:t}){this.env.model.dispatch("RESIZE_SHEETVIEW",{width:t,height:e,gridOffsetX:te,gridOffsetY:ee})}moveCanvas(e,t){const{scrollX:o,scrollY:s}=this.env.model.getters.getActiveSheetScrollInfo();this.env.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:o+e,offsetY:s+t})}getClientPositionKey(e){return`${e.id}-${e.position?.sheetId}-${e.position?.col}-${e.position?.row}`}isCellHovered(e,t){return this.hoveredCell.col===e&&this.hoveredCell.row===t}getGridRect(){return{...this.canvasPosition,...this.env.model.getters.getSheetViewDimensionWithHeaders()}}onCellClicked(e,t,o){"editing"===this.composerFocusStore.activeComposer.editionMode&&this.composerFocusStore.activeComposer.stopEdition(),o.expandZone?this.env.model.selection.setAnchorCorner(e,t):o.addZone?this.env.model.selection.addCellToSelection(e,t):this.env.model.selection.selectCell(e,t);let s=e,i=t;j_(this.env,((e,t,o)=>{o.preventDefault(),(e!==s&&-1!=e||t!==i&&-1!=t)&&(s=-1===e?s:e,i=-1===t?i:t,this.env.model.selection.setAnchorCorner(s,i))}),(()=>{this.paintFormatStore.isActive&&this.paintFormatStore.pasteFormat(this.env.model.getters.getSelectedZones())}))}onCellDoubleClicked(e,t){const o=this.env.model.getters.getActiveSheetId();({col:e,row:t}=this.env.model.getters.getMainCellPosition({sheetId:o,col:e,row:t}));this.env.model.getters.getEvaluatedCell({sheetId:o,col:e,row:t}).type===ni.empty?this.onComposerCellFocused():this.onComposerContentFocused()}processArrows(e){e.preventDefault(),e.stopPropagation(),this.cellPopovers.isOpen&&this.cellPopovers.close(),tD(e,this.env.model.selection),this.paintFormatStore.isActive&&this.paintFormatStore.pasteFormat(this.env.model.getters.getSelectedZones())}onKeydown(e){const t=lR(e),o=this.keyDownMapping[t];if(o)return e.preventDefault(),e.stopPropagation(),void o();e.key.startsWith("Arrow")&&this.processArrows(e)}onInputContextMenu(e){e.preventDefault();const t=this.env.model.getters.getSelectedZone(),{left:o,top:s}=t;let i="CELL";this.composerFocusStore.activeComposer.stopEdition(),this.env.model.getters.getActiveCols().has(o)?i="COL":this.env.model.getters.getActiveRows().has(s)&&(i="ROW");const{x:n,y:r,width:a}=this.env.model.getters.getVisibleRect(t),l=this.getGridRect();this.toggleContextMenu(i,l.x+n+a,l.y+r)}onCellRightClicked(e,t,{x:o,y:s}){const i=this.env.model.getters.getSelectedZones();let n="CELL";as(e,t,i[i.length-1])?this.env.model.getters.getActiveCols().has(e)?n="COL":this.env.model.getters.getActiveRows().has(t)&&(n="ROW"):(this.env.model.selection.getBackToDefault(),this.env.model.selection.selectCell(e,t)),this.toggleContextMenu(n,o,s)}toggleContextMenu(e,t,o){this.cellPopovers.isOpen&&this.cellPopovers.close(),this.menuState.isOpen=!0,this.menuState.position={x:t,y:o},this.menuState.menuItems=HM[e].getMenuItems()}async copy(e,t){if(!this.gridEl.contains(document.activeElement))return;if("inactive"!==this.composerFocusStore.activeComposer.editionMode)return;e?wI(this.env):this.env.model.dispatch("COPY");const o=this.env.model.getters.getClipboardContent(),s=t.clipboardData;for(const e in o)s?.setData(e,o[e]);t.preventDefault()}async paste(e){if(!this.gridEl.contains(document.activeElement))return;e.preventDefault();const t=e.clipboardData;if(!t)return;const o={content:{[ri.PlainText]:t?.getData(ri.PlainText),[ri.Html]:t?.getData(ri.Html)}},s=this.env.model.getters.getSelectedZones(),i=this.env.model.getters.isCutOperation(),n=ha(o.content),r=n.data?.clipboardId;this.env.model.getters.getClipboardId()===r?cx(this.env,s):hx(this.env,s,n),i&&await this.env.clipboard.write({[ri.PlainText]:""})}clearFormatting(){this.env.model.dispatch("CLEAR_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones()})}setHorizontalAlign(e){this.env.model.dispatch("SET_FORMATTING",{sheetId:this.env.model.getters.getActiveSheetId(),target:this.env.model.getters.getSelectedZones(),style:{align:e}})}closeMenu(){this.menuState.isOpen=!1,this.focusDefaultElement()}processHeaderGroupingKey(e){if(1!==this.env.model.getters.getSelectedZones().length)return;const t=this.env.model.getters.getActiveRows().size>0,o=this.env.model.getters.getActiveCols().size>0;o&&t?this.processHeaderGroupingEventOnWholeSheet(e):o?this.processHeaderGroupingEventOnHeaders(e,"COL"):t?this.processHeaderGroupingEventOnHeaders(e,"ROW"):this.processHeaderGroupingEventOnGrid(e)}processHeaderGroupingEventOnHeaders(e,t){const o=this.env.model.getters.getActiveSheetId(),s=this.env.model.getters.getSelectedZone(),i="COL"===t?s.left:s.top,n="COL"===t?s.right:s.bottom;switch(e){case"right":this.env.model.dispatch("GROUP_HEADERS",{sheetId:o,dimension:t,start:i,end:n});break;case"left":this.env.model.dispatch("UNGROUP_HEADERS",{sheetId:o,dimension:t,start:i,end:n});break;case"down":this.env.model.dispatch("UNFOLD_HEADER_GROUPS_IN_ZONE",{sheetId:o,dimension:t,zone:s});break;case"up":this.env.model.dispatch("FOLD_HEADER_GROUPS_IN_ZONE",{sheetId:o,dimension:t,zone:s})}}processHeaderGroupingEventOnWholeSheet(e){const t=this.env.model.getters.getActiveSheetId();"up"===e?(this.env.model.dispatch("FOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"ROW"}),this.env.model.dispatch("FOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"COL"})):"down"===e&&(this.env.model.dispatch("UNFOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"ROW"}),this.env.model.dispatch("UNFOLD_ALL_HEADER_GROUPS",{sheetId:t,dimension:"COL"}))}processHeaderGroupingEventOnGrid(e){const t=this.env.model.getters.getActiveSheetId(),o=this.env.model.getters.getSelectedZone();switch(e){case"down":this.env.model.dispatch("UNFOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"ROW",zone:o}),this.env.model.dispatch("UNFOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"COL",zone:o});break;case"up":this.env.model.dispatch("FOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"ROW",zone:o}),this.env.model.dispatch("FOLD_HEADER_GROUPS_IN_ZONE",{sheetId:t,dimension:"COL",zone:o});break;case"right":{const{x:e,y:t,width:s}=this.env.model.getters.getVisibleRect(o),i=this.getGridRect();this.toggleContextMenu("GROUP_HEADERS",e+s+i.x,t+i.y);break}case"left":{if(!L_(this.env,"COL")&&!L_(this.env,"ROW"))return;const{x:e,y:t,width:s}=this.env.model.getters.getVisibleRect(o),i=this.getGridRect();this.toggleContextMenu("UNGROUP_HEADERS",e+s+i.x,t+i.y);break}}}onComposerCellFocused(e,t){this.composerFocusStore.focusActiveComposer({content:e,selection:t,focusMode:"cellFocus"})}onComposerContentFocused(){this.composerFocusStore.focusActiveComposer({focusMode:"contentFocus"})}get staticTables(){const e=this.env.model.getters.getActiveSheetId();return this.env.model.getters.getCoreTables(e).filter(IF)}}class BM{static getters=[];history;constructor(e){this.history=Object.assign(Object.create(e),{update:e.addChange.bind(e,this),selectCell:()=>{}})}exportForExcel(e){}allowDispatch(e){return"Success"}beforeHandle(e){}handle(e){}finalize(){}batchValidations(...e){return t=>e.map((e=>e.call(this,t))).flat()}chainValidations(...e){return t=>{for(const o of e){let e=o.call(this,t);Array.isArray(e)||(e=[e]);const s=e.filter((e=>"Success"!==e));if(s.length)return s}return"Success"}}checkValidations(e,...t){return this.batchValidations(...t)(e)}}class zM extends BM{getters;dispatch;canDispatch;constructor({getters:e,stateObserver:t,range:o,dispatch:s,canDispatch:i}){super(t),o.addRangeProvider(this.adaptRanges.bind(this)),this.getters=e,this.dispatch=s,this.canDispatch=i}import(e){}export(e){}adaptRanges(e,t){}garbageCollectExternalResources(){}}class $M{id;format;style;sheetId;getRangeString;isFormula=!0;compiledFormula;constructor(e,t,o,s,i,n,r){this.id=e,this.format=o,this.style=s,this.sheetId=n,this.getRangeString=r;let a=0;const l=t.tokens.map((e=>{if("REFERENCE"===e.type){const e=a++;return new WM(i,e,this.sheetId,this.getRangeString)}return e}));this.compiledFormula={...t,dependencies:i,tokens:l}}get content(){return dt(this.compiledFormula.tokens.map((e=>e.value)))}get contentWithFixedReferences(){let e=0;return dt(this.compiledFormula.tokens.map((t=>{if("REFERENCE"===t.type){const t=e++;return this.getRangeString(this.compiledFormula.dependencies[t],this.sheetId,{useBoundedReference:!0})}return t.value})))}}class WM{ranges;rangeIndex;sheetId;getRangeString;type="REFERENCE";constructor(e,t,o,s){this.ranges=e,this.rangeIndex=t,this.sheetId=o,this.getRangeString=s}get value(){const e=this.ranges[this.rangeIndex];return this.getRangeString(e,this.sheetId)}}function GM(e){return""===e?NaN:Number(e)}function qM(e){return Object.entries(e).map((([e,t])=>t?ZM(parseInt(e,10),t):void 0)).filter(at).map((e=>yo(e.left,e.top)+":"+yo(e.right,e.bottom)))}function ZM(e,t){return{...t.zone,id:e}}class jM{getters;providers=[];constructor(e){this.getters=e}static getters=["extendRange","getRangeString","getRangeFromSheetXC","createAdaptedRanges","getRangeDataFromXc","getRangeDataFromZone","getRangeFromRangeData","getRangeFromZone","getRangesUnion","recomputeRanges","isRangeValid","removeRangesSheetPrefix"];allowDispatch(e){return"MOVE_RANGES"===e.type?1===e.target.length?"Success":"InvalidZones":"Success"}beforeHandle(e){}handle(e){switch(e.type){case"REMOVE_COLUMNS_ROWS":{let t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";const i=[...e.elements];i.sort(((e,t)=>t-e));const n=je(i);this.executeOnAllRanges((i=>{if(i.sheetId!==e.sheetId)return{changeType:"NONE"};let r=i,a="NONE";for(let e of n){const n=Ot(e),l=Dt(e);if(i.zone[t]<=n&&n<=i.zone[o]){const e=Math.min(i.zone[o],l)-n+1;a="RESIZE",r=this.createAdaptedRange(r,s,a,-e)}else if(i.zone[t]>=n&&i.zone[o]<=l)a="REMOVE",r=i.clone({...this.getInvalidRange()});else if(i.zone[t]<=l&&i.zone[o]>=l){const e=l-i.zone[t]+1;a="RESIZE",r=this.createAdaptedRange(r,s,a,-e),r=this.createAdaptedRange(r,s,"MOVE",-(i.zone[t]-n))}else n<i.zone[t]&&(a="MOVE",r=this.createAdaptedRange(r,s,a,-(l-n+1)))}return"NONE"!==a?{changeType:a,range:r}:{changeType:"NONE"}}),e.sheetId);break}case"ADD_COLUMNS_ROWS":{let t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";this.executeOnAllRanges((i=>{if(i.sheetId!==e.sheetId)return{changeType:"NONE"};if("after"===e.position){if(i.zone[t]<=e.base&&e.base<i.zone[o])return{changeType:"RESIZE",range:this.createAdaptedRange(i,s,"RESIZE",e.quantity)};if(e.base<i.zone[t])return{changeType:"MOVE",range:this.createAdaptedRange(i,s,"MOVE",e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[o])return{changeType:"RESIZE",range:this.createAdaptedRange(i,s,"RESIZE",e.quantity)};if(e.base<=i.zone[t])return{changeType:"MOVE",range:this.createAdaptedRange(i,s,"MOVE",e.quantity)}}return{changeType:"NONE"}}),e.sheetId);break}case"DELETE_SHEET":this.executeOnAllRanges((t=>{if(t.sheetId!==e.sheetId)return{changeType:"NONE"};const o=this.getters.getSheetName(e.sheetId);return{changeType:"REMOVE",range:t=t.clone({...this.getInvalidRange(),invalidSheetName:o})}}),e.sheetId);break;case"RENAME_SHEET":this.executeOnAllRanges((t=>{if(t.sheetId===e.sheetId)return{changeType:"CHANGE",range:t};if(e.name&&t.invalidSheetName===e.name){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:t.clone({sheetId:s,invalidSheetName:o})}}return{changeType:"NONE"}}));break;case"MOVE_RANGES":{const t=e.target[0];this.executeOnAllRanges((o=>{if(o.sheetId!==e.sheetId||!ls(o.zone,t))return{changeType:"NONE"};const s=e.targetSheetId,i=e.col-t.left,n=e.row-t.top,r=this.createAdaptedRange(o,"both","MOVE",[i,n]),a=e.sheetId!==s||r.prefixSheet;return{changeType:"MOVE",range:r.clone({sheetId:s,prefixSheet:a})}}));break}}}finalize(){}verifyRangeRemoved(e){return t=>{const o=e(t);return"NONE"===o.changeType||Xo(o.range.zone)?o:{range:o.range,changeType:"REMOVE"}}}createAdaptedRange(e,t,o,s){const i=ps(e.unboundedZone,t,o,s);return e.clone({zone:i})}executeOnAllRanges(e,t){const o=this.verifyRangeRemoved(e);for(const e of this.providers)e(o,t)}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,o,s){const i=e.map((e=>kr.fromRange(e,this.getters)));return i.map((e=>{if(!Xo(e.zone))return e;const i=e.prefixSheet?e.sheetId:s,n={...e.unboundedZone,left:e.isFullRow&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:e.isFullRow?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:e.isFullCol&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:o),bottom:e.isFullCol?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:o)};return e.clone({sheetId:i,zone:n}).orderZone()}))}removeRangesSheetPrefix(e,t){return t.map((t=>{const o=kr.fromRange(t,this.getters);return o.prefixSheet&&o.sheetId===e?o.clone({prefixSheet:!1}):o}))}extendRange(e,t,o){const s=kr.fromRange(e,this.getters),i="COL"===t?s.zone.right+o:s.zone.right,n="ROW"===t?s.zone.bottom+o:s.zone.bottom,r={left:s.zone.left,top:s.zone.top,right:s.isFullRow?void 0:i,bottom:s.isFullCol?void 0:n};return new kr({...s,zone:r},this.getters.getSheetSize).orderZone()}getRangeFromSheetXC(e,t){if(!Uo.test(t)||!this.getters.tryGetSheet(e))return new kr({sheetId:"",zone:{left:-1,top:-1,right:-1,bottom:-1},parts:[],invalidXc:t,prefixSheet:!1},this.getters.getSheetSize);let o,s=t,i=!1;t.includes("!")&&(({xc:s,sheetName:o}=qo(t)),o&&(i=!0));const n=jo(s),r=kr.getRangeParts(s,n),a=o&&!this.getters.getSheetIdByName(o)?o:void 0,l=this.getters.getSheetIdByName(o)||e;return new kr({prefixSheet:i,zone:n,sheetId:l,invalidSheetName:a,parts:r},this.getters.getSheetSize).orderZone()}getRangeString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){if(!e)return Ii.InvalidReference;if(e.invalidXc)return e.invalidXc;if(!this.getters.tryGetSheet(e.sheetId))return Ii.InvalidReference;if(e.zone.bottom-e.zone.top<0||e.zone.right-e.zone.left<0)return Ii.InvalidReference;if(e.zone.left<0||e.zone.top<0)return Ii.InvalidReference;const s=kr.fromRange(e,this.getters);let i=s.sheetId!==t||s.invalidSheetName||s.prefixSheet,n="";if(i&&(n=s.invalidSheetName?s.invalidSheetName:We(this.getters.getSheetName(s.sheetId))),i&&!n)return Ii.InvalidReference;let r=this.getRangePartString(s,0,o);return s.parts&&2===s.parts.length&&(s.zone.top!==s.zone.bottom||s.zone.left!==s.zone.right||s.parts[0].rowFixed||s.parts[0].colFixed||s.parts[1].rowFixed||s.parts[1].colFixed)&&(r+=":",r+=this.getRangePartString(s,1,o)),`${i?n+"!":""}${r}`}getRangeDataFromXc(e,t){return this.getters.getRangeFromSheetXC(e,t).rangeData}getRangeDataFromZone(e,t){return{_sheetId:e,_zone:t=this.getters.getUnboundedZone(e,t)}}getRangeFromZone(e,t){return new kr({sheetId:e,zone:t,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}],prefixSheet:!1},this.getters.getSheetSize)}recomputeRanges(e,t){const o=e.map((e=>kr.fromRange(e,this.getters).unboundedZone)),s=t.map((e=>kr.fromRange(e,this.getters).unboundedZone));return Co(o,s).map((t=>this.getRangeFromZone(e[0].sheetId,t)))}getRangeFromRangeData(e){const t={prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]};return new kr(t,this.getters.getSheetSize)}isRangeValid(e){if(!e)return!1;const{xc:t,sheetName:o}=qo(e);return null!==t.match(Uo)&&(!o||void 0!==this.getters.getSheetIdByName(o))}getRangesUnion(e){const t=e.map((e=>kr.fromRange(e,this.getters).unboundedZone)),o=function(...e){return{top:Math.min(...e.map((e=>e.top))),left:Math.min(...e.map((e=>e.left))),bottom:e.some((e=>void 0===e.bottom))?void 0:Math.max(...e.map((e=>e.bottom))),right:e.some((e=>void 0===e.right))?void 0:Math.max(...e.map((e=>e.right)))}}(...t);return this.getRangeFromZone(e[0].sheetId,o)}getRangePartString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){const s=e.parts[t]?.colFixed||o.useFixedReference?"$":"",i=fo(0===t?e.zone.left:e.zone.right),n=e.parts[t]?.rowFixed||o.useFixedReference?"$":"",r=String(0===t?e.zone.top+1:e.zone.bottom+1);let a="";return a=e.isFullCol&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:s+i:e.isFullRow&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:n+r:s+i+n+r,a}getInvalidRange(){return{parts:[],prefixSheet:!1,zone:{left:-1,top:-1,right:-1,bottom:-1},sheetId:"",invalidXc:Ii.InvalidReference}}}let YM=1;function XM(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}class KM extends BM{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}}const JM=new n;JM.add("pivots",(e=>{for(const t of e.getPivotIds()){const o=e.getPivot(t);dF.get(o.type).onIterationEndEvaluation(o)}}));const QM=$b.mapping;function eP(e,t,o){return new tP(e,t,o).getParameters()}class tP{getters;computeCell;evalContext;rangeCache={};constructor(e,t,o){this.getters=t,this.computeCell=o,this.evalContext=Object.assign(Object.create(QM),e,{getters:this.getters,locale:this.getters.getLocale()})}getParameters(){return{referenceDenormalizer:this.refFn.bind(this),ensureRange:this.range.bind(this),evalContext:this.evalContext}}refFn(e,t){const o=this.getRangeError(e);if(o)return o;if(t){return{value:Zo(this.getters.getSheetName(e.sheetId),Jo(e.zone))}}const s={sheetId:e.sheetId,col:e.zone.left,row:e.zone.top};return this.computeCell(s)}range(e){const t=this.getRangeError(e);if(t)return[[t]];const o=e.sheetId,s=e.zone,i=is(s,this.getters.getSheetZone(o));if(!i)return[[]];const{top:n,left:r,bottom:a,right:l}=s,c=`${o}-${n}-${r}-${a}-${l}`;if(c in this.rangeCache)return this.rangeCache[c];const h=i.bottom-i.top+1,d=i.right-i.left+1,u=new Array(d);for(let e=i.left;e<=i.right;e++){const t=e-i.left;u[t]=new Array(h);for(let s=i.top;s<=i.bottom;s++){const n=s-i.top;u[t][n]=this.computeCell({sheetId:o,col:e,row:s})}}return this.rangeCache[c]=u,u}getRangeError(e){return Xo(e.zone)?e.invalidSheetName?new Ti(Fo("Invalid sheet name: %s",e.invalidSheetName)):void 0:new _i}}function oP(e,t,o,s,i){sP(e,t,o||0,s||e.length-1,i||nP)}function sP(e,t,o,s,i){for(;s>o;){if(s-o>600){var n=s-o+1,r=t-o+1,a=Math.log(n),l=.5*Math.exp(2*a/3),c=.5*Math.sqrt(a*l*(n-l)/n)*(r-n/2<0?-1:1);sP(e,t,Math.max(o,Math.floor(t-r*l/n+c)),Math.min(s,Math.floor(t+(n-r)*l/n+c)),i)}var h=e[t],d=o,u=s;for(iP(e,o,t),i(e[s],h)>0&&iP(e,o,s);d<u;){for(iP(e,d,u),d++,u--;i(e[d],h)<0;)d++;for(;i(e[u],h)>0;)u--}0===i(e[o],h)?iP(e,o,u):iP(e,++u,s),u<=t&&(o=u+1),t<=u&&(s=u-1)}}function iP(e,t,o){var s=e[t];e[t]=e[o],e[o]=s}function nP(e,t){return e<t?-1:e>t?1:0}class rP{constructor(e=9){this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()}all(){return this._all(this.data,[])}search(e){let t=this.data;const o=[];if(!vP(e,t))return o;const s=this.toBBox,i=[];for(;t;){for(let n=0;n<t.children.length;n++){const r=t.children[n],a=t.leaf?s(r):r;vP(e,a)&&(t.leaf?o.push(r):fP(e,a)?this._all(r,o):i.push(r))}t=i.pop()}return o}collides(e){let t=this.data;if(!vP(e,t))return!1;const o=[];for(;t;){for(let s=0;s<t.children.length;s++){const i=t.children[s],n=t.leaf?this.toBBox(i):i;if(vP(e,n)){if(t.leaf||fP(e,n))return!0;o.push(i)}}t=o.pop()}return!1}load(e){if(!e||!e.length)return this;if(e.length<this._minEntries){for(let t=0;t<e.length;t++)this.insert(e[t]);return this}let t=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===t.height)this._splitRoot(this.data,t);else{if(this.data.height<t.height){const e=this.data;this.data=t,t=e}this._insert(t,this.data.height-t.height-1,!0)}else this.data=t;return this}insert(e){return e&&this._insert(e,this.data.height-1),this}clear(){return this.data=bP([]),this}remove(e,t){if(!e)return this;let o=this.data;const s=this.toBBox(e),i=[],n=[];let r,a,l;for(;o||i.length;){if(o||(o=i.pop(),a=i[i.length-1],r=n.pop(),l=!0),o.leaf){const s=aP(e,o.children,t);if(-1!==s)return o.children.splice(s,1),i.push(o),this._condense(i),this}l||o.leaf||!fP(o,s)?a?(r++,o=a.children[r],l=!1):o=null:(i.push(o),n.push(r),r=0,a=o,o=o.children[0])}return this}toBBox(e){return e}compareMinX(e,t){return e.minX-t.minX}compareMinY(e,t){return e.minY-t.minY}toJSON(){return this.data}fromJSON(e){return this.data=e,this}_all(e,t){const o=[];for(;e;)e.leaf?t.push(...e.children):o.push(...e.children),e=o.pop();return t}_build(e,t,o,s){const i=o-t+1;let n,r=this._maxEntries;if(i<=r)return n=bP(e.slice(t,o+1)),lP(n,this.toBBox),n;s||(s=Math.ceil(Math.log(i)/Math.log(r)),r=Math.ceil(i/Math.pow(r,s-1))),n=bP([]),n.leaf=!1,n.height=s;const a=Math.ceil(i/r),l=a*Math.ceil(Math.sqrt(r));SP(e,t,o,l,this.compareMinX);for(let i=t;i<=o;i+=l){const t=Math.min(i+l-1,o);SP(e,i,t,a,this.compareMinY);for(let o=i;o<=t;o+=a){const i=Math.min(o+a-1,t);n.children.push(this._build(e,o,i,s-1))}}return lP(n,this.toBBox),n}_chooseSubtree(e,t,o,s){for(;s.push(t),!t.leaf&&s.length-1!==o;){let o,s=1/0,r=1/0;for(let a=0;a<t.children.length;a++){const l=t.children[a],c=gP(l),h=(i=e,n=l,(Math.max(n.maxX,i.maxX)-Math.min(n.minX,i.minX))*(Math.max(n.maxY,i.maxY)-Math.min(n.minY,i.minY))-c);h<r?(r=h,s=c<s?c:s,o=l):h===r&&c<s&&(s=c,o=l)}t=o||t.children[0]}var i,n;return t}_insert(e,t,o){const s=o?e:this.toBBox(e),i=[],n=this._chooseSubtree(s,this.data,t,i);for(n.children.push(e),hP(n,s);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(s,i,t)}_split(e,t){const o=e[t],s=o.children.length,i=this._minEntries;this._chooseSplitAxis(o,i,s);const n=this._chooseSplitIndex(o,i,s),r=bP(o.children.splice(n,o.children.length-n));r.height=o.height,r.leaf=o.leaf,lP(o,this.toBBox),lP(r,this.toBBox),t?e[t-1].children.push(r):this._splitRoot(o,r)}_splitRoot(e,t){this.data=bP([e,t]),this.data.height=e.height+1,this.data.leaf=!1,lP(this.data,this.toBBox)}_chooseSplitIndex(e,t,o){let s,i=1/0,n=1/0;for(let r=t;r<=o-t;r++){const t=cP(e,0,r,this.toBBox),a=cP(e,r,o,this.toBBox),l=mP(t,a),c=gP(t)+gP(a);l<i?(i=l,s=r,n=c<n?c:n):l===i&&c<n&&(n=c,s=r)}return s||o-t}_chooseSplitAxis(e,t,o){const s=e.leaf?this.compareMinX:dP,i=e.leaf?this.compareMinY:uP;this._allDistMargin(e,t,o,s)<this._allDistMargin(e,t,o,i)&&e.children.sort(s)}_allDistMargin(e,t,o,s){e.children.sort(s);const i=this.toBBox,n=cP(e,0,t,i),r=cP(e,o-t,o,i);let a=pP(n)+pP(r);for(let s=t;s<o-t;s++){const t=e.children[s];hP(n,e.leaf?i(t):t),a+=pP(n)}for(let s=o-t-1;s>=t;s--){const t=e.children[s];hP(r,e.leaf?i(t):t),a+=pP(r)}return a}_adjustParentBBoxes(e,t,o){for(let s=o;s>=0;s--)hP(t[s],e)}_condense(e){for(let t,o=e.length-1;o>=0;o--)0===e[o].children.length?o>0?(t=e[o-1].children,t.splice(t.indexOf(e[o]),1)):this.clear():lP(e[o],this.toBBox)}}function aP(e,t,o){if(!o)return t.indexOf(e);for(let s=0;s<t.length;s++)if(o(e,t[s]))return s;return-1}function lP(e,t){cP(e,0,e.children.length,t,e)}function cP(e,t,o,s,i){i||(i=bP(null)),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(let n=t;n<o;n++){const t=e.children[n];hP(i,e.leaf?s(t):t)}return i}function hP(e,t){return e.minX=Math.min(e.minX,t.minX),e.minY=Math.min(e.minY,t.minY),e.maxX=Math.max(e.maxX,t.maxX),e.maxY=Math.max(e.maxY,t.maxY),e}function dP(e,t){return e.minX-t.minX}function uP(e,t){return e.minY-t.minY}function gP(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function pP(e){return e.maxX-e.minX+(e.maxY-e.minY)}function mP(e,t){const o=Math.max(e.minX,t.minX),s=Math.max(e.minY,t.minY),i=Math.min(e.maxX,t.maxX),n=Math.min(e.maxY,t.maxY);return Math.max(0,i-o)*Math.max(0,n-s)}function fP(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function vP(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function bP(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function SP(e,t,o,s,i){const n=[t,o];for(;n.length;){if((o=n.pop())-(t=n.pop())<=s)continue;const r=t+Math.ceil((o-t)/s/2)*s;oP(e,r,t,o,i),n.push(t,r,r,o)}}class yP{rTrees={};constructor(e=[]){const t={};for(const o of e){const e=o.boundingBox.sheetId;t[e]||(t[e]=[]),t[e].push(o)}for(const e in t)this.rTrees[e]=new CP,this.rTrees[e].load(t[e])}insert(e){const t=e.boundingBox.sheetId;this.rTrees[t]||(this.rTrees[t]=new CP),this.rTrees[t].insert(e)}search({zone:e,sheetId:t}){return this.rTrees[t]?this.rTrees[t].search({minX:e.left,minY:e.top,maxX:e.right,maxY:e.bottom}):[]}remove(e){const t=e.boundingBox.sheetId;this.rTrees[t]&&this.rTrees[t].remove(e,this.rtreeItemComparer)}rtreeItemComparer(e,t){return e.data==t.data&&e.boundingBox.sheetId===t.boundingBox.sheetId&&e.boundingBox?.zone.left===t.boundingBox.zone.left&&e.boundingBox?.zone.top===t.boundingBox.zone.top&&e.boundingBox?.zone.right===t.boundingBox.zone.right&&e.boundingBox?.zone.bottom===t.boundingBox.zone.bottom}}class CP extends rP{toBBox({boundingBox:e}){const t=e.zone;return{minX:t.left,minY:t.top,maxX:t.right,maxY:t.bottom}}compareMinX(e,t){return e.boundingBox.zone.left-t.boundingBox.zone.left}compareMinY(e,t){return e.boundingBox.zone.top-t.boundingBox.zone.top}}class wP{createEmptyPositionSet;dependencies=new c_;rTree;constructor(e,t=[]){this.createEmptyPositionSet=e,this.rTree=new yP(t)}removeAllDependencies(e){const t=this.dependencies.get(e);if(t){for(const e of t)this.rTree.remove(e);this.dependencies.delete(e)}}addDependencies(e,t){const o=t.map((({sheetId:t,zone:o})=>({data:e,boundingBox:{zone:o,sheetId:t}})));for(const e of o)this.rTree.insert(e);const s=this.dependencies.get(e);s?s.push(...o):this.dependencies.set(e,o)}getCellsDependingOn(e){const t=this.createEmptyPositionSet(),o=Array.from(e).reverse();for(;o.length>0;){const e=o.pop(),s=e.zone,i=e.sheetId;for(let e=s.left;e<=s.right;e++)for(let o=s.top;o<=s.bottom;o++)t.add({sheetId:i,col:e,row:o});const n=this.rTree.search(e).map((e=>e.data)),r={};for(const e of n)t.has(e)||(r[e.sheetId]||(r[e.sheetId]=[]),r[e.sheetId].push(fs(e)));for(const e in r){const t=Co(r[e],[]);o.push(...t.map((t=>({sheetId:e,zone:t}))))}}for(const o of e){const e=o.zone,s=o.sheetId;for(let o=e.left;o<=e.right;o++)for(let i=e.top;i<=e.bottom;i++)t.delete({sheetId:s,col:o,row:i})}return t}}class xP extends Uint32Array{columnOffset=0;cols=0;rows=0;static create(e,t){const o=function(e){if(0===e)return-1/0;if(e<0)return NaN;return 32-Math.clz32(--e)}(t),s=new this((e<<o>>5)+1);return s.columnOffset=o,s.cols=t,s.rows=e,s}getValue(e){const[t,o]=this.getCoordinates(e);return this[t]>>o&1}setValue(e,t){const[o,s]=this.getCoordinates(e),i=0===(this[o]>>s&1)&&1===t;return this[o]=this[o]&~(1<<s)|t<<s,i}isEmpty(){return!this.some((e=>0!==e))}fillAllPositions(){this.fill(-1>>>0)}clear(){this.fill(0)}getCoordinates(e){const{row:t,col:o}=e,s=(t<<this.columnOffset)+o,i=s>>5;return[i,s-(i<<5)]}}class EP{sheets={};insertions=[];maxSize=0;constructor(e){for(const t in e){const o=e[t].cols,s=e[t].rows;this.maxSize+=o*s,this.sheets[t]=xP.create(s,o)}}add(e){this.sheets[e.sheetId].setValue(e,1)&&this.insertions.push(e)}addMany(e){for(const t of e)this.add(t)}delete(e){this.sheets[e.sheetId].setValue(e,0)}deleteMany(e){for(const t of e)this.delete(t)}has(e){return 1===this.sheets[e.sheetId].getValue(e)}clear(){const e=[...this];this.insertions=[];for(const e in this.sheets)this.sheets[e].clear();return e}isEmpty(){if(0===this.insertions.length)return!0;for(const e in this.sheets)if(!this.sheets[e].isEmpty())return!1;return!0}fillAllPositions(){this.insertions=new Array(this.maxSize);let e=0;for(const t in this.sheets){const o=this.sheets[t];o.fillAllPositions();for(let s=0;s<o.rows;s++)for(let i=0;i<o.cols;i++)this.insertions[e++]={sheetId:t,row:s,col:i}}}*[Symbol.iterator](){for(const e of this.insertions)1===this.sheets[e.sheetId].getValue(e)&&(yield e)}}class IP{resultsToArrayFormulas=new yP;arrayFormulasToResults=new c_;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map((e=>e.data))||RP}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:fs(e)},data:e}),this.arrayFormulasToResults.delete(e)}addRelation({arrayFormulaPosition:e,resultZone:t}){this.resultsToArrayFormulas.insert({boundingBox:{sheetId:e.sheetId,zone:t},data:e}),this.arrayFormulasToResults.set(e,t)}isArrayFormula(e){return this.arrayFormulasToResults.has(e)}}const RP=[],TP=Tr(new class extends Ti{constructor(e=Fo("Circular reference")){super(e,Ii.CircularDependency)}}),AP=Tr({value:null});class _P{context;getters;compilationParams;evaluatedCells=new c_;formulaDependencies=ut(new wP(this.createEmptyPositionSet.bind(this)));blockedArrayFormulas=new EP({});spreadingRelations=new IP;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=eP(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||AP}getSpreadZone(e,t={ignoreSpillError:!1}){const o=this.spreadingRelations.getArrayResultZone(e);if(!o)return;const s=this.evaluatedCells.get(e);return s?.type!==ni.error||t.ignoreSpillError&&s?.value===Ii.SpilledBlocked?ss(fs(e),o):fs(e)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(!(this.getEvaluatedCell(e).type!==ni.empty&&!this.getters.getCell(e)?.isFormula))return this.spreadingRelations.isArrayFormula(e)?e:void 0;const t=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,fs(e));return Array.from(t).find((e=>!this.blockedArrayFormulas.has(e)))}updateDependencies(e){this.formulaDependencies().removeAllDependencies(e);const t=this.getDirectDependencies(e);this.formulaDependencies().addDependencies(e,t)}addDependencies(e,t){this.formulaDependencies().addDependencies(e,t);for(const e of t){const t=e.sheetId,{left:o,bottom:s,right:i,top:n}=e.zone;for(let e=o;e<=i;e++)for(let o=n;o<=s;o++)this.computeAndSave({sheetId:t,col:e,row:o})}}updateCompilationParameters(){this.compilationParams=eP(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.updateDependencies=this.updateDependencies.bind(this),this.compilationParams.evalContext.addDependencies=this.addDependencies.bind(this)}createEmptyPositionSet(){const e={};for(const t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new EP(e)}evaluateCells(e){const t=performance.now(),o=this.createEmptyPositionSet();o.addMany(e);const s=this.getArrayFormulasImpactedByChangesOf(e);o.addMany(this.getCellsDependingOn(e)),o.addMany(s),o.addMany(this.getCellsDependingOn(s)),this.evaluate(o),console.debug("evaluate Cells",performance.now()-t,"ms")}getArrayFormulasImpactedByChangesOf(e){const t=this.createEmptyPositionSet();for(const o of e){const e=this.getters.getCell(o)?.content,s=this.getArrayFormulaSpreadingOn(o);void 0!==s&&t.add(s),e||t.add(o)}const o=ds(t);for(const e in o)for(const s of o[e])t.addMany(this.getArrayFormulasBlockedBy(e,s));return t}buildDependencyGraph(){this.blockedArrayFormulas=this.createEmptyPositionSet(),this.spreadingRelations=new IP,this.formulaDependencies=ut((()=>{const e=[...this.getAllCells()].flatMap((e=>this.getDirectDependencies(e).filter((e=>!e.invalidSheetName&&!e.invalidXc)).map((t=>({data:e,boundingBox:{zone:t.zone,sheetId:t.sheetId}})))));return new wP(this.createEmptyPositionSet.bind(this),e)}))}evaluateAllCells(){const e=performance.now();this.evaluatedCells=new c_,this.evaluate(this.getAllCells()),console.debug("evaluate all cells",performance.now()-e,"ms")}evaluateFormulaResult(e,t){const o=hS(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return this.updateCompilationParameters(),this.evaluateCompiledFormula(e,{...o,dependencies:s})}evaluateCompiledFormula(e,t,o){try{const s=FP(t,this.compilationParams,e,this.buildSafeGetSymbolValue(o),this.compilationParams.evalContext.__originCellPosition);return Ci(s)?an(s,OP):OP(s)}catch(e){return Gb(e,"")}}getAllCells(){const e=this.createEmptyPositionSet();return e.fillAllPositions(),e}getArrayFormulasBlockedBy(e,t){const o=this.createEmptyPositionSet(),s=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e,t);o.addMany(s);const i=[...s].filter((e=>!this.blockedArrayFormulas.has(e)));return i.length&&o.deleteMany(i),o.addMany(this.getCellsDependingOn(o)),o}nextPositionsToUpdate=new EP({});cellsBeingComputed=new Set;symbolsBeingComputed=new Set;evaluate(e){this.cellsBeingComputed=new Set,this.nextPositionsToUpdate=e;let t=0;for(;!this.nextPositionsToUpdate.isEmpty()&&t++<30;){this.updateCompilationParameters();const e=this.nextPositionsToUpdate.clear();for(let t=0;t<e.length;++t)this.evaluatedCells.delete(e[t]);for(let t=0;t<e.length;++t){const o=e[t];if(this.nextPositionsToUpdate.has(o))continue;const s=this.computeCell(o);s!==AP&&this.evaluatedCells.set(o,s)}JM.getAll().forEach((e=>e(this.getters)))}t>=30&&console.warn("Maximum iteration reached while evaluating cells")}computeCell(e){const t=this.evaluatedCells.get(e);if(t)return t;this.blockedArrayFormulas.has(e)||this.invalidateSpreading(e),this.spreadingRelations.isArrayFormula(e)&&this.spreadingRelations.removeNode(e);const o=this.getters.getCell(e);if(void 0===o)return AP;const s=o.id,i={format:o.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(s)?TP:(this.cellsBeingComputed.add(s),o.isFormula?this.computeFormulaCell(e,o):Ir(o,i))}catch(e){return e.value=e?.value||Ii.GenericError,e.message=e?.message||Zb,Tr(e)}finally{this.cellsBeingComputed.delete(s)}}computeAndSave(e){const t=this.computeCell(e);return this.evaluatedCells.has(e)||this.evaluatedCells.set(e,t),t}computeFormulaCell(e,t){const o=FP(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!Ci(o)){const s=Tr(OP(o),this.getters.getLocale(),t);return s.type===ni.error&&(s.errorOriginPosition=o.errorOriginPosition??e),s}this.assertSheetHasEnoughSpaceToSpreadFormulaResult(e,o);const s=o.length,i=o[0].length,n={top:e.row,bottom:e.row+i-1,left:e.col,right:e.col+s-1};return this.spreadingRelations.addRelation({resultZone:n,arrayFormulaPosition:e}),this.assertNoMergedCellsInSpreadZone(e,o),DP(s,i,this.checkCollision(e)),DP(s,i,this.spreadValues(e,o)),this.invalidatePositionsDependingOnSpread(e.sheetId,n),Tr(OP(o[0][0]),this.getters.getLocale(),t)}invalidatePositionsDependingOnSpread(e,t){const o=this.formulaDependencies().getCellsDependingOn(function(e){const{top:t,left:o,bottom:s,right:i}=e;if(1===Ss(e))return[];const n={top:t+1,bottom:s,left:o,right:o};if(i===o)return[n];const r={top:t,bottom:s,left:o+1,right:i};return t===s?[r]:[n,r]}(t).map((t=>({sheetId:e,zone:t}))));o.delete({sheetId:e,col:t.left,row:t.top}),this.nextPositionsToUpdate.addMany(o)}assertSheetHasEnoughSpaceToSpreadFormulaResult({sheetId:e,col:t,row:o},s){const i=this.getters.getNumberCols(e),n=this.getters.getNumberRows(e),r=t+s.length<=i,a=o+s[0].length<=n;if(!r||!a){if(r)throw new Fi(Fo("Result couldn't be automatically expanded. Please insert more rows."));if(a)throw new Fi(Fo("Result couldn't be automatically expanded. Please insert more columns."));throw new Fi(Fo("Result couldn't be automatically expanded. Please insert more columns and rows."))}}assertNoMergedCellsInSpreadZone({sheetId:e,col:t,row:o},s){if(0!==this.getters.getMergesInZone(e,{top:o,bottom:o+s[0].length-1,left:t,right:t+s.length-1}).length)throw new Fi(Fo("Merged cells found in the spill zone. Please unmerge cells before using array formulas."))}checkCollision(e){const{sheetId:t,col:o,row:s}=e;return(i,n)=>{const r={sheetId:t,col:i+o,row:n+s},a=this.getters.getCell(r);if(a?.content||this.getters.getEvaluatedCell(r).type!==ni.empty)throw this.blockedArrayFormulas.add(e),new Fi(Fo("Array result was not expanded because it would overwrite data in %s.",yo(r.col,r.row)));this.blockedArrayFormulas.delete(e)}}spreadValues({sheetId:e,col:t,row:o},s){return(i,n)=>{const r={sheetId:e,col:i+t,row:n+o},a=this.getters.getCell(r),l=Tr(OP(s[i][n]),this.getters.getLocale(),a);l.type===ni.error&&(l.errorOriginPosition=s[i][n].errorOriginPosition??r),this.evaluatedCells.set(r,l)}}invalidateSpreading(e){const t=this.spreadingRelations.getArrayResultZone(e);if(!t)return;for(let o=t.left;o<=t.right;o++)for(let s=t.top;s<=t.bottom;s++){const t={sheetId:e.sheetId,col:o,row:s},i=this.getters.getCell(t)?.content;i||this.evaluatedCells.delete(t)}const o=e.sheetId;this.invalidatePositionsDependingOnSpread(o,t),this.nextPositionsToUpdate.addMany(this.getArrayFormulasBlockedBy(o,t))}buildSafeGetSymbolValue(e){return t=>{if(this.symbolsBeingComputed.has(t))return TP;this.symbolsBeingComputed.add(t);try{const o=e?.(t);return o||new Ai(Fo("Invalid formula"))}finally{this.symbolsBeingComputed.delete(t)}}}getDirectDependencies(e){const t=this.getters.getCell(e);return t?.isFormula?t.compiledFormula.dependencies:[]}getCellsDependingOn(e){const t=[],o=ds(e);for(const e in o)t.push(...o[e].map((t=>({sheetId:e,zone:t}))));return this.formulaDependencies().getCellsDependingOn(t)}}function DP(e,t,o){for(let s=0;s<e;++s)for(let e=0;e<t;++e)0===s&&0===e||o(s,e)}function OP(e){return null===e.value||void 0===e.value?{...e,value:0}:e}function FP(e,t,o,s,i){return t.evalContext.__originCellPosition=i,t.evalContext.__originSheetId=o,e.execute(e.dependencies,t.referenceDenormalizer,t.ensureRange,s,t.evalContext)}const MP=/"(#[0-9a-fA-F]{6})"/g;const PP={isValid:!0};const NP="0.00%";function kP(e){return class extends e{getters;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t){super(e,t),this.getters=t.getters}init(e){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.init(e)}getPivotCellValueAndFormat(e,t){return this.getMeasureDisplayValue(e,t)}_getPivotCellValueAndFormat(e,t){const o=`${e}-${t.map((e=>e.field+"="+e.value)).join(",")}`;if(this.cache[o])return this.cache[o];const s=this.getMeasure(e),i=s.computedBy?this.computeMeasure(s,t):super.getPivotCellValueAndFormat(e,t);return s.format?this.cache[o]={...i,format:s.format}:this.cache[o]=i,this.cache[o]}computeMeasure(e,t){if(!e.computedBy)return{value:0};const{columns:o,rows:s}=super.definition;if(o.length+s.length!==t.length){const o=this.getValuesToAggregate(e,t),s=Wl[e.aggregator];if(!s)return{value:0};try{return s([o],this.getters.getLocale())}catch(t){return Gb(t,e.aggregator.toUpperCase())}}const i=this.getters.getMeasureCompiledFormula(e),n=this.getters.evaluateCompiledFormula(e.computedBy.sheetId,i,(e=>{const{columns:o,rows:s}=this.definition;if(o.find((t=>t.nameWithGranularity===e))){const{colDomain:o}=ml(this,t),s=o.findIndex((t=>t.field===e));return this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}if(s.find((t=>t.nameWithGranularity===e))){const{rowDomain:o}=ml(this,t),s=o.findIndex((t=>t.field===e));return this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}return this.getPivotCellValueAndFormat(e,t)}));return Ci(n)?n[0][0]:n}getValuesToAggregate(e,t){const{rowDomain:o,colDomain:s}=ml(this,t),i=super.getTableStructure(),n=[];if(0===s.length&&o.length<this.definition.rows.length&&this.definition.rows.length&&this.definition.columns.length){const t=this.treeToLeafDomains(i.getColTree()),s=this.getSubTreeMatchingDomain(i.getRowTree(),o),r=this.treeToLeafDomains(s);for(const s of t)for(const t of r)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t).concat(s)));return n}if(o.length===this.definition.rows.length&&0===s.length){const t=i.getColTree(),r=this.getSubTreeMatchingDomain(t,s),a=this.treeToLeafDomains(r,s);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,o.concat(t)));return n}{const t=i.getRowTree(),r=this.getSubTreeMatchingDomain(t,o),a=this.treeToLeafDomains(r,o);for(const t of a)n.push(this._getPivotCellValueAndFormat(e.id,t.concat(s)));return n}}getSubTreeMatchingDomain(e,t,o=0){if(o>t.length)return[];if(t.length===o)return e;for(const s of e){const e=Ql(this.definition.getDimension(s.field),t[o]?.value);if(s.field===t[o]?.field&&s.value===e)return this.getSubTreeMatchingDomain(s.children,t,o+1)}return e}treeToLeafDomains(e,t=[]){const o=[];for(const s of e){const e=this.definition.getDimension(s.field),i=[...t,{field:s.field,value:s.value,type:e.type}];0===s.children.length?o.push(i):o.push(...this.treeToLeafDomains(s.children,i))}return o}getMeasureDisplayValue(e,t){const o=this.getMeasure(e),s=this._getPivotCellValueAndFormat(e,t);if(!o.display||"no_calculations"===o.display.type||s.message)return s;const i=o.display.fieldNameWithGranularity;if(i&&!this.isFieldInPivot(i))return{value:Ii.NotAvailable,message:Fo('Field "%s" not found in pivot for measure display calculation',i)};try{const e=o.display;switch(e.type){case"%_of_grand_total":return this.asPercentOfGrandTotal(s,o);case"%_of_col_total":return this.asPercentOfColumnTotal(s,o,t);case"%_of_row_total":return this.asPercentOfRowTotal(s,o,t);case"%_of_parent_row_total":return this.asPercentOfParentRowTotal(s,o,t);case"%_of_parent_col_total":return this.asPercentOfParentColumnTotal(s,o,t);case"index":return this.asIndex(s,o,t);case"%_of_parent_total":return this.asPercentOfParentTotal(s,o,t,e);case"running_total":return this.asRunningTotal(s,o,t,e,"running_total");case"%_running_total":return this.asRunningTotal(s,o,t,e,"%_running_total");case"rank_asc":return this.asRank(s,o,t,e,"asc");case"rank_desc":return this.asRank(s,o,t,e,"desc");case"%_of":return this.asPercentOf(s,o,t,e);case"difference_from":return this.asDifferenceFrom(s,o,t,e);case"%_difference_from":return this.asDifferenceFromInPercent(s,o,t,e)}return s}catch(e){return Gb(e,"COMPUTE_MEASURE_DISPLAY_VALUE")}}asPercentOfGrandTotal(e,t){const o=this.getGrandTotal(t.id);return 0===o?{value:Ii.DivisionByZero}:{value:this.measureValueToNumber(e)/o,format:NP}}asPercentOfRowTotal(e,t,o){const s=this.getRowTotal(t.id,o);return 0===s?{value:Ii.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:NP}}asPercentOfColumnTotal(e,t,o){const s=this.getColumnTotal(t.id,o);return 0===s?{value:Ii.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:NP}}asPercentOfParentRowTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=ml(e,t);return[...o,...s.slice(0,s.length-1)]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:NP}}asPercentOfParentColumnTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=ml(e,t);return[...o.slice(0,o.length-1),...s]}(this,o),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,s));return 0===i?{value:""}:{value:this.measureValueToNumber(e)/i,format:NP}}asPercentOfParentTotal(e,t,o,s){const{fieldNameWithGranularity:i}=s;if(!i)return e;if(!yl(i,o))return{value:""};const n=function(e,t,o){let{rowDomain:s,colDomain:i}=ml(e,o);if("row"===Cl(e,t)){const e=s.findIndex((e=>e.field===t));if(-1===e)return o;s=s.slice(0,e+1)}else{const e=i.findIndex((e=>e.field===t));if(-1===e)return o;i=i.slice(0,e+1)}return[...s,...i]}(this,i,o),r=this._getPivotCellValueAndFormat(t.id,n),a=this.measureValueToNumber(r);return 0===a?{value:""}:{value:this.measureValueToNumber(e)/a,format:NP}}asIndex(e,t,o){const s=this.measureValueToNumber(e),i=this.getRowTotal(t.id,o),n=this.getColumnTotal(t.id,o),r=this.getGrandTotal(t.id);return 0===i||0===n?{value:Ii.DivisionByZero}:{value:s*r/(n*i),format:void 0}}asRunningTotal(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;const r="running_total"===i?this.runningTotal:this.runningTotalInPercent;let a=r[t.id]?.[n];a||(a=this.computeRunningTotal(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=ml(this,o),h=wl(c),d=wl(l),u=a[h]?.[d];return{value:u??"",format:"running_total"===i?e.format:NP}}asPercentOf(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!yl(i,o))return{value:""};let r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r||"sameValue"===r&&0===a?{value:Ii.DivisionByZero}:!r||"sameValue"===r&&!a?{value:""}:"sameValue"===r?{value:1,format:NP}:void 0===a?{value:Ii.NullError}:{value:a/r,format:NP}}asDifferenceFrom(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!yl(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n)||0;return"sameValue"===r?{value:""}:{value:this.measureValueToNumber(e)-r,format:e.format}}asDifferenceFromInPercent(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!yl(i,o))return{value:""};let r=this.getComparisonValue(t,o,i,n);const a=this.strictMeasureValueToNumber(e);return 0===r?{value:Ii.DivisionByZero}:r&&"sameValue"!==r?void 0===a?{value:Ii.NullError}:{value:(a-r)/r,format:NP}:{value:""}}asRank(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;if(!yl(n,o))return{value:""};const r="asc"===i?this.rankAsc:this.rankDesc;let a=r[t.id]?.[n];a||(a=this.computeRank(t,n,i),r[t.id]||(r[t.id]={}),r[t.id][n]=a);const{rowDomain:l,colDomain:c}=ml(this,o),h=wl(c),d=wl(l),u=a[h]?.[d];return{value:u??""}}computeRank(e,t,o){const s={},i=Cl(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=ln(r));for(const a of r){const r=wl(fl(this,n,a[0].domain)),l=a.map((t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:fl(this,i,t.domain)}))).filter((e=>yl(t,e.rowDomain))),c=Object.groupBy(l,(e=>El(e.rowDomain,t)));for(const e in c)c[e]=Mt(c[e]||[],(e=>e.value)).filter((e=>void 0!==e.value)).sort(((e,t)=>"asc"===o?e.value-t.value:t.value-e.value));s[r]={};for(const e of l){const o=wl(fl(this,i,e.domain)),n=c[El(e.rowDomain,t)];if(!n)continue;const a=n.findIndex((t=>t.value===e.value));-1!==a&&(s[r][o]=a+1)}}return"row"===i?s:Pt(s)}computeRunningTotal(e,t,o){const s={},i=Cl(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=ln(r));for(const a of r){const r=wl(fl(this,n,a[0].domain));s[r]={};const l={},c=a.map((t=>({...t,rowDomain:fl(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))}))).filter((e=>yl(t,e.rowDomain)));for(const e of c){const o=wl(e.rowDomain),i=Il(e.rowDomain,t),n=(l[i]||0)+e.value;l[i]=n,s[r][o]=n}if("%_running_total"===o)for(const e of c){const o=e.rowDomain,i=wl(o),n=Il(o,t),a=s[r][i]||0,c=l[n];s[r][i]=c?a/c:void 0}}return"row"===i?s:Pt(s)}getGrandTotal(e){const t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){const o=ml(this,t).rowDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}getColumnTotal(e,t){const o=ml(this,t).colDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}isFieldInPivot(e){return this.definition.columns.some((t=>t.nameWithGranularity===e))||this.definition.rows.some((t=>t.nameWithGranularity===e))}getComparisonValue(e,t,o,s){const i=s===gl||s===pl?function(e,t,o,s){const i=Cl(e,o),n="row"===i?e.getTableStructure().getRowTree():e.getTableStructure().getColTree(),r=bl(fl(e,i,t),n,o),a=r?.map((e=>e.value))??[],l=function(e,t){const o=t.find((t=>t.field===e));return o?.value}(o,t);if(void 0===l)return;const c=a.indexOf(l);if(void 0===l||-1===c)return;return Sl(t,o,a[qe(c+(s===gl?-1:1),0,a.length-1)])}(this,t,o,s):Sl(t,o,s);if(mt(i,t))return"sameValue";if(!i||!function(e,t){const{rowDomain:o,colDomain:s}=ml(e,t);return vl(o,e.getTableStructure().getRowTree())&&vl(s,e.getTableStructure().getColTree())}(this,i))throw new Di;const n=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(n)}getPivotValueCells(e){return this.getTableStructure().getPivotCells().map((t=>t.filter((t=>"VALUE"===t.type&&t.measure===e)))).filter((e=>e.length>0))}measureValueToNumber(e){if("number"==typeof e.value)return e.value;if(!e.value)return 0;throw new Error(`Value ${e.value} is not a number`)}strictMeasureValueToNumber(e){if("number"==typeof e.value)return e.value;if(e.value)throw new Error(`Value ${e.value} is not a number`)}getTableStructure(){const e=super.getTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;const t=this.definition.sortedColumn.measure;ac(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,((e,t)=>this._getPivotCellValueAndFormat(e,t)))}}}const LP=["ADD_PIVOT","UPDATE_PIVOT"];function VP(e){return LP.includes(e.type)}class HP extends BM{static layers=[];getters;ui;selection;dispatch;canDispatch;constructor({getters:e,stateObserver:t,dispatch:o,canDispatch:s,uiActions:i,selection:n}){super(t),this.getters=e,this.ui=i,this.selection=n,this.dispatch=o,this.canDispatch=s}drawLayer(e,t){}}class UP{cells;getters;index=0;direction;constructor(e,t,o){this.cells=e,this.getters=t,this.direction=o}next(){const e=this.cells[this.index++%this.cells.length],t=e.rule,{cellData:o,tooltip:s}=ES.get(t.type).apply(t,e.data,this.getters,this.direction);return{cellData:o,tooltip:s,origin:{col:e.data.col,row:e.data.row}}}}function BP(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId!==t.sheetId)return e;const o=gc(e.pivot.dataSet.zone,t),s=o?{...e.pivot.dataSet,zone:o}:void 0;return{...e,pivot:{...e.pivot,dataSet:s}}}function zP(e,t){return{...e,definition:vR(e.definition,t)}}function $P(e,t){if(e.sheetId!==t.sheetId)return e;if(("FREEZE_COLUMNS"===e.type?"COL":"ROW")!==t.dimension)return e;let o=e.quantity;if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));for(let t of e)o>t&&o--}if("ADD_COLUMNS_ROWS"===t.type){o=o>("before"===t.position?t.base-1:t.base)?o+t.quantity:o}return o>0?{...e,quantity:o}:void 0}function WP(e,t){if(e.sheetId!==t.sheetId)return e;const o=gc(e.zone,t);if(!o)return;const s=e.newTableRange?pc(e.newTableRange,t):void 0;return{...e,newTableRange:s,zone:o}}function GP(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let o;if("REMOVE_COLUMNS_ROWS"===t.type)o=Wr(t.elements,[e.base])[0];else if("ADD_COLUMNS_ROWS"===t.type){o=$r(pt(t.position,t.base),t.quantity,[e.base])[0]}return void 0!==o?{...e,base:o}:void 0}function qP(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;const o=Ze(e.start,e.end+1);let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Wr(t.elements,o);else if("ADD_COLUMNS_ROWS"===t.type){s=$r(pt(t.position,t.base),t.quantity,o)}return 0!==s.length?{...e,start:Math.min(...s),end:Math.max(...s)}:void 0}G_.addTransformation("ADD_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],GP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],GP),G_.addTransformation("ADD_COLUMNS_ROWS",["CREATE_CHART","UPDATE_CHART"],zP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["CREATE_CHART","UPDATE_CHART"],zP),G_.addTransformation("DELETE_SHEET",["MOVE_RANGES"],(function(e,t){const o=t.sheetId;if(e.targetSheetId===o||e.sheetId===o)return;return e})),G_.addTransformation("DELETE_FIGURE",["UPDATE_FIGURE","UPDATE_CHART"],(function(e,t){if(e.id===t.id)return;return e})),G_.addTransformation("CREATE_SHEET",["CREATE_SHEET"],(function(e,t){if(e.name===t.name)return{...e,name:e.name?.match(/\d+/)?e.name.replace(/\d+/,(e=>(parseInt(e)+1).toString())):`${e.name}~`,position:e.position+1};return e})),G_.addTransformation("ADD_MERGE",["ADD_MERGE","REMOVE_MERGE"],(function(e,t){if(e.sheetId!==t.sheetId)return e;const o=[];for(const s of e.target)for(const e of t.target)rs(s,e)||o.push({...s});if(o.length)return{...e,target:o};return})),G_.addTransformation("ADD_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],$P),G_.addTransformation("REMOVE_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],$P),G_.addTransformation("ADD_COLUMNS_ROWS",["UPDATE_TABLE"],WP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["UPDATE_TABLE"],WP),G_.addTransformation("REMOVE_TABLE_STYLE",["CREATE_TABLE","UPDATE_TABLE"],(function(e,t){if(e.config?.styleId!==t.tableStyleId)return e;return{...e,config:{...e.config,styleId:QC.styleId}}})),G_.addTransformation("ADD_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],qP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],qP),G_.addTransformation("REMOVE_PIVOT",["RENAME_PIVOT","DUPLICATE_PIVOT","INSERT_PIVOT","UPDATE_PIVOT"],(function(e,t){if(e.pivotId===t.pivotId)return;return e})),G_.addTransformation("DELETE_SHEET",["ADD_PIVOT","UPDATE_PIVOT"],(function(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId===t.sheetId)return{...e,pivot:{...e.pivot,dataSet:void 0}};return e})),G_.addTransformation("ADD_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],BP),G_.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],BP);const ZP=[{match:function(e){return"sheetId"in e},fn:XP},{match:function(e){return"target"in e&&"sheetId"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=[];for(const o of e.target){const e=gc(o,t);e&&s.push(e)}if(!s.length)return"IGNORE_COMMAND";return{...e,target:s}}},{match:function(e){return"zone"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=gc(e.zone,t);if(s)return{...e,zone:s};return"IGNORE_COMMAND"}},{match:function(e){return"col"in e&&"row"in e&&"sheetId"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"===t.type||"REMOVE_COLUMNS_ROWS"===t.type)return function(e,t){const o="COL"===t.dimension?"col":"row";let s=e[o];if("REMOVE_COLUMNS_ROWS"===t.type){const e=[...t.elements].sort(((e,t)=>t-e));if(e.includes(s))return"IGNORE_COMMAND";for(let t of e)s>=t&&s--}"ADD_COLUMNS_ROWS"===t.type&&(s>t.base||s===t.base&&"before"===t.position)&&(s+=t.quantity);return{...e,[o]:s}}(e,t);if("ADD_MERGE"===t.type)return function(e,t){for(const o of t.target){if(!(e.col===o.left&&e.row===o.top)&&as(e.col,e.row,o))return"IGNORE_COMMAND"}return e}(e,t);return"SKIP_TRANSFORMATION"}},{match:function(e){return"dimension"in e&&"sheetId"in e&&"elements"in e},fn:function(e,t){const o=XP(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;if("ADD_COLUMNS_ROWS"!==t.type&&"REMOVE_COLUMNS_ROWS"!==t.type)return"SKIP_TRANSFORMATION";if(t.dimension!==e.dimension)return e;let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=Wr(t.elements,e.elements);else if("ADD_COLUMNS_ROWS"===t.type){s=$r(pt(t.position,t.base),t.quantity,e.elements)}if(0===s.length)return"IGNORE_COMMAND";return{...e,elements:s}}},{match:function(e){return"ranges"in e},fn:function(e,t){if(!("sheetId"in t))return e;const o=e.ranges.map((e=>pc(e,t))).filter(at);if(!o.length)return"IGNORE_COMMAND";return{...e,ranges:o}}}];function jP(e,t){const o=G_.getTransformation(e.type,t.type);return o?o(e,t):function(e,t){for(const{match:o,fn:s}of ZP)if(o(e)){const o=s(e,t);if("SKIP_TRANSFORMATION"===o)continue;if("IGNORE_COMMAND"===o)return;e=o}return e}(e,t)}function YP(e,t){let o=[...e];for(const e of t)o=o.map((t=>jP(t,e))).filter(at);return o}function XP(e,t){if(!("sheetId"in t))return e;const o="DELETE_SHEET"===t.type&&t.sheetId;return e.sheetId===o?"IGNORE_COMMAND":"CREATE_SHEET"===e.type||"CREATE_SHEET"===t.type||e.sheetId!==t.sheetId?e:"SKIP_TRANSFORMATION"}class KP{rootCommand;timestamp;id;clientId;_commands=[];_changes=[];constructor(e,t,o,s,i,n){this.rootCommand=s,this.timestamp=n,this.id=e,this.clientId=t,this._commands=[...o],this._changes=i?[...i]:[]}setChanges(e){this._changes=e}get commands(){return this._commands}get changes(){return this._changes}}class JP extends Error{}class QP extends mc{revisions;transportService;serverRevisionId;clients={};clientId="local";debouncedMove;pendingMessages=[];waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new aa;lastLocalOperation;constructor(e,t,o=Se){super(),this.revisions=e,this.transportService=t,this.serverRevisionId=o,this.debouncedMove=ht(this._move.bind(this),200)}canApplyOptimisticUpdate(){return!this.waitingUndoRedoAck}save(e,t,o){if(!t.length||!o.length||!this.canApplyOptimisticUpdate())return;const s=new KP(this.uuidGenerator.uuidv4(),this.clientId,t,e,o,Date.now());this.revisions.append(s.id,s),"REQUEST_REDO"!==e.type&&(this.lastLocalOperation=s),this.trigger("new-local-state-update",{id:s.id}),this.sendUpdateMessage({type:"REMOTE_REVISION",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:s.id,clientId:s.clientId,commands:s.commands})}undo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_UNDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),undoneRevisionId:e})}redo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:"REVISION_REDONE",version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),redoneRevisionId:e})}move(e){this.debouncedMove(e)}join(e){e?(this.clients[e.id]=e,this.clientId=e.id):(this.clients.local={id:"local",name:"local"},this.clientId="local"),this.transportService.onNewMessage(this.clientId,this.onMessageReceived.bind(this))}loadInitialMessages(e){const t=performance.now(),o=e.reduce(((e,t)=>e+("REMOTE_REVISION"===t.type?t.commands.length:1)),0);this.isReplayingInitialRevisions=!0;for(const t of e)this.onMessageReceived(t);this.isReplayingInitialRevisions=!1,console.debug("Replayed",o,"commands in",performance.now()-t,"ms")}async leave(e){e&&1===Object.keys(this.clients).length&&this.lastRevisionMessage&&"SNAPSHOT_CREATED"!==this.lastRevisionMessage?.type&&await this.snapshot(e()),delete this.clients[this.clientId],this.transportService.leave(this.clientId),this.transportService.sendMessage({type:"CLIENT_LEFT",clientId:this.clientId,version:1})}async snapshot(e){if(0!==this.pendingMessages.length)return;const t=this.uuidGenerator.uuidv4();await this.transportService.sendMessage({type:"SNAPSHOT",nextRevisionId:t,serverRevisionId:this.serverRevisionId,data:{...e,revisionId:t},version:1})}getClient(){const e=this.clients[this.clientId];if(!e)throw new JP("The client left the session");return e}getConnectedClients(){return new Set(Object.values(this.clients).filter(at))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return 0===this.pendingMessages.length}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return;const t=this.clients[this.clientId]?.position;if(t?.col===e.col&&t.row===e.row&&t.sheetId===e.sheetId)return;const o=t?"CLIENT_MOVED":"CLIENT_JOINED",s=this.getClient();this.clients[this.clientId]={...s,position:e},this.transportService.sendMessage({type:o,version:1,client:{...s,position:e}})}onMessageReceived(e){if(!this.isAlreadyProcessed(e))if(this.isWrongServerRevisionId(e))this.trigger("unexpected-revision-id");else{switch(e.type){case"CLIENT_MOVED":this.onClientMoved(e);break;case"CLIENT_JOINED":this.onClientJoined(e);break;case"CLIENT_LEFT":this.onClientLeft(e);break;case"REVISION_REDONE":this.revisions.redo(e.redoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-redone",{revisionId:e.redoneRevisionId,commands:this.revisions.get(e.redoneRevisionId).commands});break;case"REVISION_UNDONE":this.revisions.undo(e.undoneRevisionId,e.nextRevisionId,e.serverRevisionId),this.trigger("revision-undone",{revisionId:e.undoneRevisionId,commands:this.revisions.get(e.undoneRevisionId).commands});break;case"REMOTE_REVISION":const{clientId:t,commands:o,timestamp:s}=e,i=new KP(e.nextRevisionId,t,o,void 0,void 0,s);if(i.clientId!==this.clientId){this.revisions.insert(i.id,i,e.serverRevisionId);const t=this.pendingMessages.filter((e=>"REMOTE_REVISION"===e.type)).map((e=>e.commands)).flat();this.trigger("remote-revision-received",{commands:YP(o,t)})}break;case"SNAPSHOT_CREATED":{const t=new KP(e.nextRevisionId,"server",[],void 0,void 0,Date.now());this.revisions.insert(t.id,t,e.serverRevisionId),this.dropPendingHistoryMessages(),this.trigger("snapshot"),this.lastLocalOperation=void 0;break}}this.acknowledge(e),this.trigger("collaborative-event-received")}}onClientMoved(e){e.client.id!==this.clientId&&(this.clients[e.client.id]=e.client)}onClientJoined(e){if(e.client.id!==this.clientId){this.clients[e.client.id]=e.client;const t=this.clients[this.clientId];if(t){const{position:e}=t;e&&this.transportService.sendMessage({type:"CLIENT_MOVED",version:1,client:{...t,position:e}})}}}onClientLeft(e){e.clientId!==this.clientId&&delete this.clients[e.clientId]}sendUpdateMessage(e){this.pendingMessages.push(e),this.waitingAck||this.sendPendingMessage()}sendPendingMessage(){let e=this.pendingMessages[0];if(e){if("REMOTE_REVISION"===e.type){const t=this.revisions.get(e.nextRevisionId);if(0===t.commands.length){this.revisions.drop(t.id);const e=this.pendingMessages.filter((e=>"REMOTE_REVISION"===e.type)).map((e=>e.nextRevisionId));return this.trigger("pending-revisions-dropped",{revisionIds:e}),this.waitingAck=!1,this.waitingUndoRedoAck=!1,void(this.pendingMessages=[])}e={...e,clientId:t.clientId,commands:t.commands}}if(this.isReplayingInitialRevisions)throw new Error(`Trying to send a new revision while replaying initial revision. This can lead to endless dispatches every time the spreadsheet is open.\n ${JSON.stringify(e)}`);this.waitingAck=!0,this.transportService.sendMessage({...e,serverRevisionId:this.serverRevisionId})}}acknowledge(e){switch("REVISION_UNDONE"!==e.type&&"REVISION_REDONE"!==e.type||(this.waitingUndoRedoAck=!1),e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId)),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.lastRevisionMessage=e,this.sendPendingMessage()}}isAlreadyProcessed(e){if("CLIENT_MOVED"===e.type&&e.client.id===this.clientId)return!0;switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return this.processedRevisions.has(e.nextRevisionId);default:return!1}}isWrongServerRevisionId(e){switch(e.type){case"REMOTE_REVISION":case"REVISION_REDONE":case"REVISION_UNDONE":case"SNAPSHOT_CREATED":return e.serverRevisionId!==this.serverRevisionId;default:return!1}}dropPendingHistoryMessages(){this.waitingUndoRedoAck=!1,this.pendingMessages=this.pendingMessages.filter((({type:e})=>"REVISION_REDONE"!==e&&"REVISION_UNDONE"!==e))}}const eN=new Set(["HIDE_COLUMNS_ROWS","UNHIDE_COLUMNS_ROWS","UNFOLD_HEADER_GROUP","UNGROUP_HEADERS","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","FOLD_HEADER_GROUPS_IN_ZONE","UNFOLD_HEADER_GROUPS_IN_ZONE","CREATE_TABLE","UPDATE_TABLE","UPDATE_FILTER","REMOVE_TABLE","RESIZE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE"]);function tN(e){return eN.has(e.type)}const oN=[sN,function(e,t){return"target"in t&&Array.isArray(t.target)?{...Be(t),target:e.getSelectedZones()}:t},function(e,t){if(!("row"in t)||!("col"in t))return t;const{col:o,row:s}=e.getActivePosition();return{...Be(t),col:o,row:s}},function(e,t){return"ranges"in t?{...Be(t),ranges:e.getSelectedZones().map((t=>e.getRangeDataFromZone(e.getActiveSheetId(),t)))}:t}];function sN(e,t){return"sheetId"in t?{...Be(t),sheetId:e.getActiveSheetId()}:t}function iN(e,t){return"zone"in t?{...Be(t),zone:e.getSelectedZone()}:t}const nN=new aa;function rN(e,t){const o=e.getSelectedZone();return{...sN(e,t),elements:"COL"===t.dimension?Ze(o.left,o.right+1):Ze(o.top,o.bottom+1)}}function aN(e,t){const o=e.getSelectedZone();return{...Be(t),zone:o}}function lN(e,t){const o=Be(t),s=e.getSelectedZone(),{top:i,bottom:n,left:r,right:a}=s;return"cols"in o?o.cols=Ze(r,a+1):"rows"in o&&(o.rows=Ze(i,n+1)),o}function cN(e,t){const o=e.getSelectedZone();return{...sN(e,t),start:"COL"===t.dimension?o.left:o.top,end:"COL"===t.dimension?o.right:o.bottom}}const hN=new n;hN.add("UPDATE_CELL",uN),hN.add("CLEAR_CELL",uN),hN.add("CLEAR_CELLS",uN),hN.add("DELETE_CONTENT",uN),hN.add("ADD_MERGE",uN),hN.add("REMOVE_MERGE",uN),hN.add("SET_FORMATTING",uN),hN.add("CLEAR_FORMATTING",uN),hN.add("SET_BORDER",uN),hN.add("CREATE_TABLE",uN),hN.add("REMOVE_TABLE",uN),hN.add("HIDE_SHEET",uN),hN.add("ADD_COLUMNS_ROWS",(function(e,t){const o=e.getActivePosition();return{...sN(e,t),base:"COL"===t.dimension?o.col:o.row}})),hN.add("REMOVE_COLUMNS_ROWS",rN),hN.add("HIDE_COLUMNS_ROWS",rN),hN.add("RESIZE_COLUMNS_ROWS",rN),hN.add("CREATE_SHEET",(function(e,t){const o=Be(t);o.sheetId=nN.uuidv4();const s=t.name||e.getSheet(e.getActiveSheetId()).name,i=s.match(/(.+?)\d*$/)?.[1]||s;return o.name=e.getNextSheetName(i),o})),hN.add("CREATE_FIGURE",(function(e,t){const o=sN(e,t);return o.figure.id=nN.uuidv4(),o})),hN.add("CREATE_CHART",(function(e,t){return{...sN(e,t),id:nN.uuidv4()}})),hN.add("CREATE_IMAGE",(function(e,t){return{...sN(e,t),figureId:nN.uuidv4()}})),hN.add("GROUP_HEADERS",cN),hN.add("UNGROUP_HEADERS",cN),hN.add("UNGROUP_HEADERS",cN),hN.add("UNFOLD_HEADER_GROUPS_IN_ZONE",iN),hN.add("FOLD_HEADER_GROUPS_IN_ZONE",iN);const dN=new n;function uN(e,t){let o=Be(t);for(const t of oN)o=t(e,o);return o}function gN(e,t){if(e.rootCommand&&"object"==typeof e.rootCommand)return pi(e.rootCommand)?function(e,t){if(!t)return;if(!hN.contains(t.type))return;return hN.get(t.type)(e,t)}(t,e.rootCommand):function(e,t,o){if(!dN.contains(t.type))return;return dN.get(t.type)(e,t,o)}(t,e.rootCommand,e.commands)}dN.add("PASTE",(function(e,t){return{type:"REPEAT_PASTE",pasteOption:Be(t.pasteOption),target:e.getSelectedZones()}})),dN.add("INSERT_CELL",aN),dN.add("DELETE_CELL",aN),dN.add("AUTORESIZE_COLUMNS",lN),dN.add("AUTORESIZE_ROWS",lN),dN.add("SORT_CELLS",(function(e,t){const o=e.getSelectedZone();return{...sN(e,t),col:o.left,row:o.top,zone:o}})),dN.add("SUM_SELECTION",uN),dN.add("SET_DECIMAL",uN);class pN{getters;sheetId;boundaries;top;bottom;left;right;offsetX;offsetY;canScrollVertically;canScrollHorizontally;viewportWidth;viewportHeight;offsetCorrectionX;offsetCorrectionY;constructor(e,t,o,s,i,n){if(this.getters=e,this.sheetId=t,this.boundaries=o,s.width<0||s.height<0)throw new Error("Viewport size cannot be negative");this.viewportWidth=s.height&&s.width,this.viewportHeight=s.width&&s.height,this.top=o.top,this.bottom=o.bottom,this.left=o.left,this.right=o.right,this.offsetX=n.x,this.offsetY=n.y,this.canScrollVertically=i.canScrollVertically,this.canScrollHorizontally=i.canScrollHorizontally,this.offsetCorrectionX=this.getters.getColDimensions(this.sheetId,this.boundaries.left).start,this.offsetCorrectionY=this.getters.getRowDimensions(this.sheetId,this.boundaries.top).start,this.adjustViewportOffsetX(),this.adjustViewportOffsetY()}getMaxSize(){const e=this.getters.findLastVisibleColRowIndex(this.sheetId,"COL",{first:this.boundaries.left,last:this.boundaries.right}),t=this.getters.findLastVisibleColRowIndex(this.sheetId,"ROW",{first:this.boundaries.top,last:this.boundaries.bottom}),{end:o,size:s}=this.getters.getColDimensions(this.sheetId,e),{end:i,size:n}=this.getters.getRowDimensions(this.sheetId,t),r=this.searchHeaderIndex("COL",o-this.viewportWidth,0),a=this.getters.getColSize(this.sheetId,r),l=this.searchHeaderIndex("ROW",i-this.viewportHeight,0),c=this.getters.getRowSize(this.sheetId,l);let h=o-this.offsetCorrectionX;this.canScrollHorizontally&&(h+=Math.max(oe,Math.min(a,this.viewportWidth-s)),h=Math.max(h,this.viewportWidth));let d=i-this.offsetCorrectionY;return this.canScrollVertically&&(d+=Math.max(se+5,Math.min(c,this.viewportHeight-n)),d=Math.max(d,this.viewportHeight),i+ce>d&&!this.getters.isReadonly()&&(d+=ce)),{width:h,height:d}}getColIndex(e){return e<this.offsetCorrectionX||e>this.offsetCorrectionX+this.viewportWidth?-1:this.searchHeaderIndex("COL",e-this.offsetCorrectionX+this.snapCorrection.x,this.left)}getRowIndex(e){return e<this.offsetCorrectionY||e>this.offsetCorrectionY+this.viewportHeight?-1:this.searchHeaderIndex("ROW",e-this.offsetCorrectionY+this.snapCorrection.y,this.top)}adjustPosition(e){const t=this.sheetId,o=this.getters.getMainCellPosition({sheetId:t,...e}),{col:s,row:i}=this.getters.getNextVisibleCellPosition(o);as(s,this.boundaries.top,this.boundaries)&&this.adjustPositionX(s),as(this.boundaries.left,i,this.boundaries)&&this.adjustPositionY(i)}adjustPositionX(e){const t=this.sheetId,{start:o,end:s}=this.getters.getColDimensions(t,e);this.offsetX+this.viewportWidth+this.offsetCorrectionX<s?this.offsetX=s-this.viewportWidth:this.offsetX+this.offsetCorrectionX>o&&(this.offsetX=o-this.offsetCorrectionX),this.adjustViewportZoneX()}adjustPositionY(e){const t=this.sheetId,{start:o,end:s}=this.getters.getRowDimensions(t,e);this.offsetY+this.viewportHeight+this.offsetCorrectionY<s?this.offsetY=s-this.viewportHeight:this.offsetY+this.offsetCorrectionY>o&&(this.offsetY=o-this.offsetCorrectionY),this.adjustViewportZoneY()}willNewOffsetScrollViewport(e,t){return this.canScrollHorizontally&&this.offsetX!==e||this.canScrollVertically&&this.offsetY!==t}setViewportOffset(e,t){this.setViewportOffsetX(e),this.setViewportOffsetY(t)}adjustViewportZone(){this.adjustViewportZoneX(),this.adjustViewportZoneY()}getVisibleRect(e){const t=is(e,this),o=this.snapCorrection.x,s=this.snapCorrection.y;if(t){return{x:this.getters.getColRowOffset("COL",this.left,t.left)+this.offsetCorrectionX-(this.left!==t.left?o:0),y:this.getters.getColRowOffset("ROW",this.top,t.top)+this.offsetCorrectionY-(this.top!==t.top?s:0),width:Math.min(this.getters.getColRowOffset("COL",t.left,t.right+1)-(this.left===t.left?o:0),this.viewportWidth),height:Math.min(this.getters.getColRowOffset("ROW",t.top,t.bottom+1)-(this.top===t.top?s:0),this.viewportHeight)}}}getFullRect(e){const t=is(e,this),o=this.snapCorrection.x,s=this.snapCorrection.y;if(t){return{x:this.getters.getColRowOffset("COL",this.left,e.left)+this.offsetCorrectionX-o,y:this.getters.getColRowOffset("ROW",this.top,e.top)+this.offsetCorrectionY-s,width:this.getters.getColRowOffset("COL",e.left,e.right+1),height:this.getters.getColRowOffset("ROW",e.top,e.bottom+1)}}}isVisible(e,t){return t<=this.bottom&&t>=this.top&&e>=this.left&&e<=this.right&&!this.getters.isColHidden(this.sheetId,e)&&!this.getters.isRowHidden(this.sheetId,t)}searchHeaderIndex(e,t,o=0){if(this.viewportWidth<=0||this.viewportHeight<=0)return-1;const s=this.sheetId,i=this.getters.getNumberHeaders(s,e);let n=o,r=i;for(;n<=r&&n!==i&&-1!==r;){const i=Math.floor((n+r)/2),a=this.getters.getColRowOffset(e,o,i),l=this.getters.getHeaderSize(s,e,i);if(t>=a&&t<a+l)return i;t>=a+l?n=i+1:r=i-1}return-1}setViewportOffsetX(e){this.canScrollHorizontally&&(this.offsetX=e,this.adjustViewportZoneX())}setViewportOffsetY(e){this.canScrollVertically&&(this.offsetY=e,this.adjustViewportZoneY())}adjustViewportOffsetX(){if(this.canScrollHorizontally){const{width:e}=this.getMaxSize();this.viewportWidth+this.offsetX>e&&(this.offsetX=Math.max(0,e-this.viewportWidth))}this.adjustViewportZoneX()}adjustViewportOffsetY(){if(this.canScrollVertically){const{height:e}=this.getMaxSize();this.viewportHeight+this.offsetY>e&&(this.offsetY=Math.max(0,e-this.viewportHeight))}this.adjustViewportZoneY()}adjustViewportZoneX(){this.left=this.searchHeaderIndex("COL",this.offsetX,this.boundaries.left),this.right=Math.min(this.boundaries.right,this.searchHeaderIndex("COL",Math.max(this.viewportWidth+this.snapCorrection.x-.1),this.left)),this.viewportWidth&&(-1===this.left&&(this.left=this.boundaries.left),-1===this.right&&(this.right=this.boundaries.right))}adjustViewportZoneY(){this.top=this.searchHeaderIndex("ROW",this.offsetY,this.boundaries.top),this.bottom=Math.min(this.boundaries.bottom,this.searchHeaderIndex("ROW",Math.max(this.viewportHeight+this.snapCorrection.y-.1,0),this.top)),this.viewportHeight&&(-1===this.top&&(this.top=this.boundaries.top),-1===this.bottom&&(this.bottom=this.boundaries.bottom))}get snapCorrection(){return{x:Math.abs(this.offsetX-this.getters.getColRowOffset("COL",this.boundaries.left,Math.max(0,this.left))),y:Math.abs(this.offsetY-this.getters.getColRowOffset("ROW",this.boundaries.top,Math.max(0,this.top)))}}}const mN=(new n).add("settings",class extends zM{static getters=["getLocale"];locale=Si;allowDispatch(e){return"UPDATE_LOCALE"===e.type?_a(e.locale)?"Success":"InvalidLocale":"Success"}handle(e){if("UPDATE_LOCALE"===e.type){const t=this.locale,o=e.locale;this.history.update("locale",o),this.changeCellsDateFormatWithLocale(t,o)}}getLocale(){return this.locale}changeCellsDateFormatWithLocale(e,t){for(const o of this.getters.getSheetIds())for(const[s,i]of Object.entries(this.getters.getCells(o))){let o;if(i.format===e.dateFormat&&(o=t.dateFormat),i.format===e.timeFormat&&(o=t.timeFormat),i.format===za(e)&&(o=za(t)),o){const{col:e,row:t,sheetId:i}=this.getters.getCellPosition(s);this.dispatch("UPDATE_CELL",{col:e,row:t,sheetId:i,format:o})}}}import(e){this.locale=e.settings?.locale??Si}export(e){e.settings={locale:this.locale}}}).add("sheet",class extends zM{static getters=["getSheetName","tryGetSheetName","getSheet","tryGetSheet","getSheetIdByName","getSheetIds","getVisibleSheetIds","isSheetVisible","doesHeaderExist","doesHeadersExist","getCell","getCellPosition","getColsZone","getRowCells","getRowsZone","getNumberCols","getNumberRows","getNumberHeaders","getGridLinesVisibility","getNextSheetName","getSheetSize","getSheetZone","getPaneDivisions","checkZonesExistInSheet","getCommandZones","getUnboundedZone","checkElementsIncludeAllNonFrozenHeaders"];sheetIdsMapName={};orderedSheetIds=[];sheets={};cellPosition={};allowDispatch(e){const t=this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e);if("Success"!==t)return t;switch(e.type){case"HIDE_SHEET":return 1===this.getVisibleSheetIds().length?"NotEnoughSheets":"Success";case"CREATE_SHEET":return this.checkValidations(e,this.checkSheetName,this.checkSheetPosition);case"MOVE_SHEET":try{const t=this.orderedSheetIds.findIndex((t=>t===e.sheetId));return this.findIndexOfTargetSheet(t,e.delta),"Success"}catch(e){return"WrongSheetMove"}case"RENAME_SHEET":return this.isRenameAllowed(e);case"COLOR_SHEET":return!e.color||zt(e.color)?"Success":"InvalidColor";case"DELETE_SHEET":return this.orderedSheetIds.length>1?"Success":"NotEnoughSheets";case"ADD_COLUMNS_ROWS":return this.doesHeaderExist(e.sheetId,e.dimension,e.base)?e.quantity<=0?"InvalidQuantity":"Success":"InvalidHeaderIndex";case"REMOVE_COLUMNS_ROWS":{const t=Ot(e.elements),o=Dt(e.elements);return t<0||!this.doesHeaderExist(e.sheetId,e.dimension,o)?"InvalidHeaderIndex":this.checkElementsIncludeAllNonFrozenHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success"}case"FREEZE_ROWS":return this.checkValidations(e,this.checkRowFreezeQuantity,this.checkRowFreezeOverlapMerge);case"FREEZE_COLUMNS":return this.checkValidations(e,this.checkColFreezeQuantity,this.checkColFreezeOverlapMerge);default:return"Success"}}handle(e){switch(e.type){case"SET_GRID_LINES_VISIBILITY":this.setGridLinesVisibility(e.sheetId,e.areGridLinesVisible);break;case"CREATE_SHEET":const t=this.createSheet(e.sheetId,e.name||this.getNextSheetName(),e.cols||26,e.rows||100,e.position);this.history.update("sheetIdsMapName",t.name,t.id);break;case"MOVE_SHEET":this.moveSheet(e.sheetId,e.delta);break;case"RENAME_SHEET":this.renameSheet(this.sheets[e.sheetId],e.name);break;case"COLOR_SHEET":this.history.update("sheets",e.sheetId,"color",e.color);break;case"HIDE_SHEET":this.hideSheet(e.sheetId);break;case"SHOW_SHEET":this.showSheet(e.sheetId);break;case"DUPLICATE_SHEET":this.duplicateSheet(e.sheetId,e.sheetIdTo);break;case"DELETE_SHEET":this.deleteSheet(this.sheets[e.sheetId]);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.removeColumns(this.sheets[e.sheetId],[...e.elements]):this.removeRows(this.sheets[e.sheetId],[...e.elements]);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.addColumns(this.sheets[e.sheetId],e.base,e.position,e.quantity):this.addRows(this.sheets[e.sheetId],e.base,e.position,e.quantity);break;case"UPDATE_CELL_POSITION":this.updateCellPosition(e);break;case"FREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,e.quantity,"COL");break;case"FREEZE_ROWS":this.setPaneDivisions(e.sheetId,e.quantity,"ROW");break;case"UNFREEZE_ROWS":this.setPaneDivisions(e.sheetId,0,"ROW");break;case"UNFREEZE_COLUMNS":this.setPaneDivisions(e.sheetId,0,"COL");break;case"UNFREEZE_COLUMNS_ROWS":this.setPaneDivisions(e.sheetId,0,"COL"),this.setPaneDivisions(e.sheetId,0,"ROW")}}import(e){for(let t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(let t of e.sheets){const e=t.name||"Sheet"+(Object.keys(this.sheets).length+1),{colNumber:o,rowNumber:s}=this.getImportedSheetSize(t),i={id:t.id,name:e,numberOfCols:o,rows:zr(s),areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,panes:{xSplit:t.panes?.xSplit||0,ySplit:t.panes?.ySplit||0},color:t.color};this.orderedSheetIds.push(i.id),this.sheets[i.id]=i}}exportSheets(e){e.sheets=this.orderedSheetIds.filter(at).map((e=>{const t=this.sheets[e],o={id:t.id,name:t.name,colNumber:t.numberOfCols,rowNumber:this.getters.getNumberRows(t.id),rows:{},cols:{},merges:[],cells:{},styles:{},formats:{},borders:{},conditionalFormats:[],dataValidationRules:[],figures:[],tables:[],areGridLinesVisible:void 0===t.areGridLinesVisible||t.areGridLinesVisible,isVisible:t.isVisible,color:t.color};return(t.panes.xSplit||t.panes.ySplit)&&(o.panes=t.panes),o}))}export(e){this.exportSheets(e)}exportForExcel(e){this.exportSheets(e)}getGridLinesVisibility(e){return this.getSheet(e).areGridLinesVisible}tryGetSheet(e){return this.sheets[e]}getSheet(e){const t=this.sheets[e];if(!t)throw new Error(`Sheet ${e} not found.`);return t}isSheetVisible(e){return this.getSheet(e).isVisible}getSheetName(e){return this.getSheet(e).name}tryGetSheetName(e){return this.tryGetSheet(e)?.name}getSheetIdByName(e){if(e){const t=ze(e);for(const e in this.sheetIdsMapName)if(e.toUpperCase()===t.toUpperCase())return this.sheetIdsMapName[e]}}getSheetIds(){return this.orderedSheetIds}getVisibleSheetIds(){return this.orderedSheetIds.filter(this.isSheetVisible.bind(this))}doesHeaderExist(e,t,o){return"COL"===t?o>=0&&o<this.getNumberCols(e):o>=0&&o<this.getNumberRows(e)}doesHeadersExist(e,t,o){return o.every((o=>this.doesHeaderExist(e,t,o)))}getCell({sheetId:e,col:t,row:o}){const s=this.tryGetSheet(e),i=s?.rows[o]?.cells[t];if(void 0!==i)return this.getters.getCellById(i)}getColsZone(e,t,o){return{top:0,bottom:this.getNumberRows(e)-1,left:t,right:o}}getRowCells(e,t){return Object.values(this.getSheet(e).rows[t]?.cells).filter(at)}getRowsZone(e,t,o){return{top:t,bottom:o,left:0,right:this.getSheet(e).numberOfCols-1}}getCellPosition(e){const t=this.cellPosition[e];if(!t)throw new Error(`asking for a cell position that doesn't exist, cell id: ${e}`);return t}getNumberCols(e){return this.getSheet(e).numberOfCols}getNumberRows(e){return this.getSheet(e).rows.length}getNumberHeaders(e,t){return"COL"===t?this.getNumberCols(e):this.getNumberRows(e)}getNextSheetName(e="Sheet"){return Nt(e,this.orderedSheetIds.map(this.getSheetName.bind(this)),{compute:(e,t)=>`${e}${t}`,computeFirstOne:!0})}getSheetSize(e){return{numberOfRows:this.getNumberRows(e),numberOfCols:this.getNumberCols(e)}}getSheetZone(e){return{top:0,left:0,bottom:this.getNumberRows(e)-1,right:this.getNumberCols(e)-1}}getUnboundedZone(e,t){if(void 0===t.bottom||void 0===t.right)return t;const o=0===t.left&&t.right===this.getNumberCols(e)-1,s=0===t.top&&t.bottom===this.getNumberRows(e)-1;return{...t,bottom:s?void 0:t.bottom,right:o&&!s?void 0:t.right}}getPaneDivisions(e){return this.getSheet(e).panes}setPaneDivisions(e,t,o){const s={...this.getPaneDivisions(e)};"COL"===o?s.xSplit=t:"ROW"===o&&(s.ySplit=t),this.history.update("sheets",e,"panes",s)}checkElementsIncludeAllNonFrozenHeaders(e,t,o){const s=this.getters.getPaneDivisions(e),i="ROW"===t?s.ySplit:s.xSplit,n=this.getters.getNumberHeaders(e,t);if(!i)return!1;return vt(o,Ze(i,n))}getCommandZones(e){const t=[];return"zone"in e&&t.push(e.zone),"target"in e&&t.push(...e.target),"ranges"in e&&t.push(...e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone))),"col"in e&&"row"in e&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(Xo))return"InvalidRange";if(t.length){const o=this.getSheetZone(e);return t.every((e=>ls(e,o)))?"Success":"TargetOutOfSheet"}return"Success"}updateCellPosition(e){const{sheetId:t,cellId:o,col:s,row:i}=e;o?this.setNewPosition(o,t,s,i):this.clearPosition(t,s,i)}setNewPosition(e,t,o,s){const i=this.cellPosition[e];i&&this.clearPosition(t,i.col,i.row),this.history.update("cellPosition",e,{row:s,col:o,sheetId:t}),this.history.update("sheets",t,"rows",s,"cells",o,e)}clearPosition(e,t,o){const s=this.sheets[e]?.rows[o].cells[t];s&&(this.history.update("cellPosition",s,void 0),this.history.update("sheets",e,"rows",o,"cells",t,void 0))}setGridLinesVisibility(e,t){this.history.update("sheets",e,"areGridLinesVisible",t)}createSheet(e,t,o,s,i){const n={id:e,name:t,numberOfCols:o,rows:zr(s),areGridLinesVisible:!0,isVisible:!0,panes:{xSplit:0,ySplit:0}},r=this.orderedSheetIds.slice();r.splice(i,0,n.id);const a=this.sheets;return this.history.update("orderedSheetIds",r),this.history.update("sheets",Object.assign({},a,{[n.id]:n})),n}moveSheet(e,t){const o=this.orderedSheetIds.slice(),s=o.findIndex((t=>t===e)),i=o.splice(s,1);let n=this.findIndexOfTargetSheet(s,t);o.splice(n,0,i[0]),this.history.update("orderedSheetIds",o)}findIndexOfTargetSheet(e,t){for(;0!=t&&0<=e&&e<=this.orderedSheetIds.length;)t>0?(e++,this.isSheetVisible(this.orderedSheetIds[e])&&t--):t<0&&(e--,this.isSheetVisible(this.orderedSheetIds[e])&&t++);if(0===t)return e;throw new Error(Fo("There is not enough visible sheets"))}checkSheetName(e){const t=this.getters.tryGetSheetName(e.sheetId);if(void 0!==t&&e.name===t)return"UnchangedSheetName";const{orderedSheetIds:o,sheets:s}=this,i=e.name&&e.name.trim().toLowerCase();return o.find((t=>s[t]?.name.toLowerCase()===i&&t!==e.sheetId))?"DuplicatedSheetName":_e.test(i)?"ForbiddenCharactersInSheetName":"Success"}checkSheetPosition(e){const{orderedSheetIds:t}=this;return e.position>t.length||e.position<0?"WrongSheetPosition":"Success"}checkRowFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberRows(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkColFreezeQuantity(e){return e.quantity>=1&&e.quantity<this.getNumberCols(e.sheetId)?"Success":"InvalidFreezeQuantity"}checkRowFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(let o of t)if(o.top<e.quantity&&e.quantity<=o.bottom)return"MergeOverlap";return"Success"}checkColFreezeOverlapMerge(e){const t=this.getters.getMerges(e.sheetId);for(let o of t)if(o.left<e.quantity&&e.quantity<=o.right)return"MergeOverlap";return"Success"}isRenameAllowed(e){return e.name&&e.name.trim().toLowerCase()?this.checkSheetName(e):"MissingSheetName"}renameSheet(e,t){const o=e.name;this.history.update("sheets",e.id,"name",t.trim());const s=Object.assign({},this.sheetIdsMapName);delete s[o],s[t]=e.id,this.history.update("sheetIdsMapName",s)}hideSheet(e){this.history.update("sheets",e,"isVisible",!1)}showSheet(e){this.history.update("sheets",e,"isVisible",!0)}duplicateSheet(e,t){const o=this.getSheet(e),s=this.getDuplicateSheetName(o.name),i=Be(o);i.id=t,i.name=s;for(let e=0;e<=i.numberOfCols;e++)for(let t=0;t<=i.rows.length;t++)i.rows[t]&&(i.rows[t].cells[e]=void 0);const n=this.orderedSheetIds.slice(),r=n.indexOf(e);n.splice(r+1,0,i.id),this.history.update("orderedSheetIds",n),this.history.update("sheets",Object.assign({},this.sheets,{[i.id]:i}));for(const t of Object.values(this.getters.getCells(e))){const{col:e,row:o}=this.getCellPosition(t.id);this.dispatch("UPDATE_CELL",{sheetId:i.id,col:e,row:o,content:t.content,format:t.format,style:t.style})}const a=Object.assign({},this.sheetIdsMapName);a[i.name]=i.id,this.history.update("sheetIdsMapName",a)}getDuplicateSheetName(e){const t=this.orderedSheetIds.map(this.getSheetName.bind(this));return Nt(Fo("Copy of %s",e).toString(),t)}deleteSheet(e){const t=e.name,o=Object.assign({},this.sheets);delete o[e.id],this.history.update("sheets",o);const s=this.orderedSheetIds.slice(),i=s.indexOf(e.id);s.splice(i,1),this.history.update("orderedSheetIds",s);const n=Object.assign({},this.sheetIdsMapName);delete n[t],this.history.update("sheetIdsMapName",n)}removeColumns(e,t){t.sort(((e,t)=>t-e));for(let o of t)this.moveCellOnColumnsDeletion(e,o);const o=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",o-t.length);const s=t.filter((t=>t<e.panes.xSplit)).length;s&&this.setPaneDivisions(e.id,e.panes.xSplit-s,"COL")}removeRows(e,t){t.sort(((e,t)=>t-e));for(let o of je(t)){const t=o[o.length-1],s=o[0];this.moveCellOnRowsDeletion(e,t,s),this.updateRowsStructureOnDeletion(e,t,s)}const o=t.filter((t=>t<e.panes.ySplit)).length;o&&this.setPaneDivisions(e.id,e.panes.ySplit-o,"ROW")}addColumns(e,t,o,s){const i="before"===o?t:t+1;this.moveCellsOnAddition(e,i,s,"columns");const n=this.sheets[e.id].numberOfCols;this.history.update("sheets",e.id,"numberOfCols",n+s),i<e.panes.xSplit&&this.setPaneDivisions(e.id,e.panes.xSplit+s,"COL")}addRows(e,t,o,s){const i="before"===o?t:t+1;this.addEmptyRows(e,s),this.moveCellsOnAddition(e,i,s,"rows"),i<e.panes.ySplit&&this.setPaneDivisions(e.id,e.panes.ySplit+s,"ROW")}moveCellOnColumnsDeletion(e,t){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:t,top:0,right:t,bottom:e.rows.length-1}]});for(let o=0;o<e.rows.length;o++){const s=e.rows[o];for(let i in s.cells){const n=Number(i),r=s.cells[i];r&&n>t&&this.setNewPosition(r,e.id,n-1,o)}}}moveCellsOnAddition(e,t,o,s){const i=[];for(let n=0;n<e.rows.length;n++){const r=e.rows[n];if("rows"!==s||n>=t)for(let a in r.cells){const l=Number(a),c=r.cells[a];c&&("rows"===s||l>=t)&&i.push({sheetId:e.id,cellId:c,col:l+("columns"===s?o:0),row:n+("rows"===s?o:0),type:"UPDATE_CELL_POSITION"})}}for(let e of i.reverse())this.updateCellPosition(e)}moveCellOnRowsDeletion(e,t,o){this.dispatch("CLEAR_CELLS",{sheetId:e.id,target:[{left:0,top:t,right:this.getters.getNumberCols(e.id),bottom:o}]});const s=o-t+1;for(let t=0;t<e.rows.length;t++){const i=e.rows[t];if(t>o)for(let o in i.cells){const n=Number(o),r=i.cells[o];r&&this.setNewPosition(r,e.id,n,t-s)}}}updateRowsStructureOnDeletion(e,t,o){const s=[],i=e.rows.map((e=>e.cells)).reverse();for(let n in e.rows){const e=Number(n);e>=t&&e<=o||s.push({cells:i.pop()})}this.history.update("sheets",e.id,"rows",s)}addEmptyRows(e,t){const o=e.rows.slice();for(let e=0;e<t;e++)o.push({cells:{}});this.history.update("sheets",e.id,"rows",o)}getImportedSheetSize(e){const t=Object.keys(e.cells).map(So);let o=e.rowNumber,s=e.colNumber;for(let{col:e,row:i}of t)o=Math.max(o,i+1),s=Math.max(s,e+1);return{rowNumber:o,colNumber:s}}checkSheetExists(e){return"CREATE_SHEET"!==e.type&&"sheetId"in e&&void 0===this.sheets[e.sheetId]?"InvalidSheetId":"CREATE_SHEET"===e.type&&void 0!==this.sheets[e.sheetId]?"DuplicatedSheetId":"Success"}checkZonesAreInSheet(e){return"sheetId"in e?this.checkZonesExistInSheet(e.sheetId,this.getCommandZones(e)):"Success"}}).add("header grouping",class extends zM{static getters=["getHeaderGroups","getGroupsLayers","getVisibleGroupLayers","getHeaderGroup","getHeaderGroupsInZone","isGroupFolded","isRowFolded","isColFolded"];groups={};allowDispatch(e){switch(e.type){case"GROUP_HEADERS":{const{start:t,end:o}=e;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";if(this.findGroupWithStartEnd(e.sheetId,e.dimension,t,o))return"HeaderGroupAlreadyExists";break}case"UNGROUP_HEADERS":{const{start:t,end:o}=e;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,o]))return"InvalidHeaderGroupStartEnd";if(t>o)return"InvalidHeaderGroupStartEnd";break}case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUP":const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return"UnknownHeaderGroup";if(Ze(0,this.getters.getNumberHeaders(e.sheetId,e.dimension)).every((o=>o>=t.start&&o<=t.end||this.getters.isHeaderHiddenByUser(e.sheetId,e.dimension,o))))return"NotEnoughElements"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("groups",e.sheetId,{ROW:[],COL:[]});break;case"GROUP_HEADERS":this.groupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"UNGROUP_HEADERS":this.unGroupHeaders(e.sheetId,e.dimension,e.start,e.end);break;case"DUPLICATE_SHEET":{const t=Be(this.groups[e.sheetId]);this.history.update("groups",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.groups};delete t[e.sheetId],this.history.update("groups",t);break}case"ADD_COLUMNS_ROWS":const t=pt(e.position,e.base);this.moveGroupsOnHeaderInsertion(e.sheetId,e.dimension,t,e.quantity);break;case"REMOVE_COLUMNS_ROWS":this.moveGroupsOnHeaderDeletion(e.sheetId,e.dimension,e.elements);break;case"UNFOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.unfoldHeaderGroup(e.sheetId,e.dimension,t);break}case"FOLD_HEADER_GROUP":{const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.foldHeaderGroup(e.sheetId,e.dimension,t);break}case"UNFOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.unfoldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_ALL_HEADER_GROUPS":{const t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(const o of t)this.foldHeaderGroup(e.sheetId,e.dimension,o);break}case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":{const t="UNFOLD_HEADER_GROUPS_IN_ZONE"===e.type?"unfold":"fold",o=this.getGroupsLayers(e.sheetId,e.dimension);"fold"===t&&o.reverse();const s=o.flat(),i="ROW"===e.dimension?e.zone.top:e.zone.left,n="ROW"===e.dimension?e.zone.bottom:e.zone.right,r=new Set;for(let e=i;e<=n;e++){const o=s.filter((t=>t.start-1<=e&&e<=t.end));for(const e of o)if(!("fold"===t&&e.isFolded||"unfold"===t&&!e.isFolded)){r.add(e);break}}for(const o of r)"unfold"===t?this.unfoldHeaderGroup(e.sheetId,e.dimension,o):this.foldHeaderGroup(e.sheetId,e.dimension,o);break}}}getHeaderGroups(e,t){return this.groups[e][t]}getHeaderGroup(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}getHeaderGroupsInZone(e,t,o){return this.getHeaderGroups(e,t).filter((e=>{const s="ROW"===t?o.top:o.left,i="ROW"===t?o.bottom:o.right;return this.doGroupOverlap(e,s,i)}))}getGroupsLayers(e,t){const o=this.getHeaderGroups(e,t);return this.bricksFallingAlgorithm(o,0,0)}getVisibleGroupLayers(e,t){const o=this.getGroupsLayers(e,t);for(const s of o)for(let o=s.length-1;o>=0;o--){const i=s[o];if(0===i.start)continue;Ze(i.start-1,i.end+1).every((o=>this.getters.isHeaderHiddenByUser(e,t,o)))&&s.splice(o,1)}return o.filter((e=>e.length>0))}isGroupFolded(e,t,o,s){return this.getHeaderGroup(e,t,o,s)?.isFolded||!1}isRowFolded(e,t){return this.getters.getHeaderGroups(e,"ROW").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}isColFolded(e,t){return this.getters.getHeaderGroups(e,"COL").some((e=>e.start<=t&&t<=e.end&&e.isFolded))}getGroupId(e){return`${e.start}-${e.end}}`}bricksFallingAlgorithm(e,t,o,s=0){const i={};for(const t of e)i[this.getGroupId(t)]=t.isFolded;const n={};for(const t of e)for(let e=t.start;e<=t.end;e++)n[e]=n[e]?n[e]+1:1;for(let e=t;e<=o;e++)n[e]=n[e]?n[e]+s:s;const r=Math.max(...Object.values(n),0),a=Array.from({length:r},(()=>[])),l=Math.max(o,...e.map((e=>e.end)));for(let o=Math.min(t,...e.map((e=>e.start)));o<=l;o++){const e=n[o]||0;for(let t=0;t<e;t++){const e=a[t].at(-1);if(e&&xt([e.end,o]))e.end++;else{const e={start:o,end:o};a[t].push(e)}}}for(const e of a)for(const t of e)t.isFolded=i[this.getGroupId(t)];return a}groupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}unGroupHeaders(e,t,o,s){const i=this.getHeaderGroups(e,t),n=this.bricksFallingAlgorithm(i,o,s,-1).flat();this.history.update("groups",e,t,this.removeDuplicateGroups(n))}moveGroupsOnHeaderInsertion(e,t,o,s){const i=this.groups[e][t];for(let n=0;n<i.length;n++){const r=i[n],[a,l]=$r(o,s,[r.start,r.end]);a===r.start&&l===r.end||this.history.update("groups",e,t,n,{...r,start:a,end:l})}}moveGroupsOnHeaderDeletion(e,t,o){const s=this.getHeaderGroups(e,t),i=[];for(const e of s){const t=Wr(o,Ze(e.start,e.end+1));0!==t.length&&i.push({...e,start:Math.min(...t),end:Math.max(...t)})}this.history.update("groups",e,t,this.bricksFallingAlgorithm(i,0,0).flat())}doGroupOverlap(e,t,o){return e.start<=o&&e.end>=t}removeDuplicateGroups(e){const t={};for(const o of e)t[this.getGroupId(o)]=o;return Object.values(t)}findGroupWithStartEnd(e,t,o,s){return this.getHeaderGroups(e,t).find((e=>e.start===o&&e.end===s))}foldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!0);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end<=o.end&&this.history.update("groups",e,t,s,"isFolded",!0)}}unfoldHeaderGroup(e,t,o){const s=this.getGroupIndex(e,t,o.start,o.end);if(void 0===s)return;this.history.update("groups",e,t,s,"isFolded",!1);const i=this.getters.getHeaderGroups(e,t);for(let s=0;s<i.length;s++){const n=i[s];n.start===o.start&&n.end>=o.end&&this.history.update("groups",e,t,s,"isFolded",!1)}}getGroupIndex(e,t,o,s){const i=this.groups[e][t].findIndex((e=>e.start===o&&e.end===s));return-1===i?void 0:i}import(e){for(const t of e.sheets)if(this.groups[t.id]={ROW:[],COL:[]},t.headerGroups)for(const e of["ROW","COL"])for(const o of t.headerGroups[e]||[])this.groups[t.id][e].push({...o})}export(e){for(const t of e.sheets)t.headerGroups=this.groups[t.id]}exportForExcel(e){for(const t of e.sheets)for(const e of["ROW","COL"]){const o=this.getGroupsLayers(t.id,e);for(let s=0;s<o.length;s++){const i=o[s];for(const o of i){for(let i=o.start;i<=o.end;i++){const n=Qy(t,e,i);n.outlineLevel=s+1,o.isFolded&&(n.isHidden=!0)}if(o.isFolded){Qy(t,e,o.end+1).collapsed=!0}}}}}}).add("header visibility",class extends zM{static getters=["checkElementsIncludeAllVisibleHeaders","getHiddenColsGroups","getHiddenRowsGroups","isHeaderHiddenByUser","isRowHiddenByUser","isColHiddenByUser"];hiddenHeaders={};allowDispatch(e){switch(e.type){case"HIDE_COLUMNS_ROWS":{if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t="COL"===e.dimension?this.getHiddenColsGroups(e.sheetId):this.getHiddenRowsGroups(e.sheetId),o="COL"===e.dimension?this.getters.getNumberCols(e.sheetId):this.getters.getNumberRows(e.sheetId);return new Set((t||[]).flat().concat(e.elements)).size>=o?"TooManyHiddenElements":Ot(e.elements)<0||Dt(e.elements)>o?"InvalidHeaderIndex":"Success"}case"REMOVE_COLUMNS_ROWS":return this.getters.tryGetSheet(e.sheetId)?this.checkElementsIncludeAllVisibleHeaders(e.sheetId,e.dimension,e.elements)?"NotEnoughElements":"Success":"InvalidSheetId"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":const t={COL:Array(this.getters.getNumberCols(e.sheetId)).fill(!1),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(!1)};this.history.update("hiddenHeaders",e.sheetId,t);break;case"DUPLICATE_SHEET":this.history.update("hiddenHeaders",e.sheetIdTo,Be(this.hiddenHeaders[e.sheetId]));break;case"DELETE_SHEET":this.history.update("hiddenHeaders",e.sheetId,void 0);break;case"REMOVE_COLUMNS_ROWS":{const t=[...this.hiddenHeaders[e.sheetId][e.dimension]];for(let o of[...e.elements].sort(((e,t)=>t-e)))t.splice(o,1);this.history.update("hiddenHeaders",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=[...this.hiddenHeaders[e.sheetId][e.dimension]],o=pt(e.position,e.base);t.splice(o,0,...Array(e.quantity).fill(!1)),this.history.update("hiddenHeaders",e.sheetId,e.dimension,t);break}case"HIDE_COLUMNS_ROWS":for(let t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!0);break;case"UNHIDE_COLUMNS_ROWS":for(let t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!1)}}checkElementsIncludeAllVisibleHeaders(e,t,o){return vt(o,this.getAllVisibleHeaders(e,t))}isHeaderHiddenByUser(e,t,o){return"COL"===t?this.isColHiddenByUser(e,o):this.isRowHiddenByUser(e,o)}isRowHiddenByUser(e,t){return this.hiddenHeaders[e].ROW[t]||this.getters.isRowFolded(e,t)}isColHiddenByUser(e,t){return this.hiddenHeaders[e].COL[t]||this.getters.isColFolded(e,t)}getHiddenColsGroups(e){const t=[[]],o=this.hiddenHeaders[e].COL;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getHiddenRowsGroups(e){const t=[[]],o=this.hiddenHeaders[e].ROW;for(let e=0;e<o.length;e++){o[e]?t[t.length-1].push(e):0!==t[t.length-1].length&&t.push([])}return 0===t[t.length-1].length&&t.pop(),t}getAllVisibleHeaders(e,t){const o=Ze(0,this.getters.getNumberHeaders(e,t)),s=[];return this.getters.getHeaderGroups(e,t).forEach((e=>{e.isFolded&&s.push(...Ze(e.start,e.end+1))})),o.filter((o=>!this.hiddenHeaders[e][t][o]&&!s.includes(o)))}import(e){for(let t of e.sheets){this.hiddenHeaders[t.id]={COL:[],ROW:[]};for(let e=0;e<t.rowNumber;e++)this.hiddenHeaders[t.id].ROW[e]=Boolean(t.rows[e]?.isHidden);for(let e=0;e<t.colNumber;e++)this.hiddenHeaders[t.id].COL[e]=Boolean(t.cols[e]?.isHidden)}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let o of e.sheets){void 0===o.rows&&(o.rows={});for(let e=0;e<this.getters.getNumberRows(o.id);e++)(t||this.hiddenHeaders[o.id].ROW[e])&&(void 0===o.rows[e]&&(o.rows[e]={}),o.rows[e].isHidden||=this.hiddenHeaders[o.id].ROW[e]);void 0===o.cols&&(o.cols={});for(let e=0;e<this.getters.getNumberCols(o.id);e++)(t||this.hiddenHeaders[o.id].COL[e])&&(void 0===o.cols[e]&&(o.cols[e]={}),o.cols[e].isHidden||=this.hiddenHeaders[o.id].COL[e])}}}).add("tables",class extends zM{static getters=["getCoreTable","getCoreTables","getCoreTableMatchingTopLeft"];tables={};adaptRanges(e,t){const o=t?[t]:this.getters.getSheetIds();for(const t of o)for(const o of this.getCoreTables(t))this.applyRangeChangeOnTable(t,o,e)}allowDispatch(e){switch(e.type){case"CREATE_TABLE":const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone));return ys(t)?this.checkValidations(e,(e=>this.getTablesOverlappingZones(e.sheetId,t).length?"TableOverlap":"Success"),(e=>this.checkTableConfigUpdateIsValid(e.config))):"NonContinuousTargets";case"UPDATE_TABLE":return this.getCoreTableMatchingTopLeft(e.sheetId,e.zone)?this.checkValidations(e,this.checkUpdatedTableZoneIsValid,(e=>this.checkTableConfigUpdateIsValid(e.config))):"TableNotFound";case"ADD_MERGE":for(const t of this.getCoreTables(e.sheetId)){const o=t.range.zone;for(const t of e.target)if(rs(o,t))return"MergeInTable"}}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("tables",e.sheetId,{});break;case"DELETE_SHEET":{const t={...this.tables};delete t[e.sheetId],this.history.update("tables",t);break}case"DUPLICATE_SHEET":{const t={};for(const o of this.getCoreTables(e.sheetId))t[o.id]="dynamic"===o.type?this.copyDynamicTableForSheet(e.sheetIdTo,o):this.copyStaticTableForSheet(e.sheetIdTo,o);this.history.update("tables",e.sheetIdTo,t);break}case"CREATE_TABLE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=this.getters.getRangesUnion(t),s=this.getters.getMergesInZone(e.sheetId,o.zone);this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:s});const i=""+YM++,n=e.config||QC,r="dynamic"===e.tableType?this.createDynamicTable(i,o,n):this.createStaticTable(i,e.tableType,o,n);this.history.update("tables",e.sheetId,r.id,r);break}case"REMOVE_TABLE":{const t={};for(const o of this.getCoreTables(e.sheetId))e.target.every((e=>!is(o.range.zone,e)))&&(t[o.id]=o);this.history.update("tables",e.sheetId,t);break}case"UPDATE_TABLE":this.updateTable(e);break;case"UPDATE_CELL":{const t=e.sheetId;for(const o of this.getCoreTables(t)){if("dynamic"===o.type)continue;const s=this.canUpdateCellCmdExtendTable(e,o);"down"===s?this.extendTableDown(t,o):"right"===s&&this.extendTableRight(t,o)}break}case"DELETE_CONTENT":{const t={...this.tables[e.sheetId]};for(const o in t){const s=t[o];s&&e.target.some((e=>ls(s.range.zone,e)))&&this.dispatch("REMOVE_TABLE",{sheetId:e.sheetId,target:[s.range.zone]})}break}}}getCoreTables(e){return this.tables[e]?Object.values(this.tables[e]).filter(at):[]}getCoreTable({sheetId:e,col:t,row:o}){return this.getCoreTables(e).find((e=>as(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter((e=>t.some((t=>rs(e.range.zone,t)))))}extendTableDown(e,t){const o=this.getters.extendRange(t.range,"ROW",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}extendTableRight(e,t){const o=this.getters.extendRange(t.range,"COL",1);this.history.update("tables",e,t.id,this.updateStaticTable(t,o))}canUpdateCellCmdExtendTable({content:e,sheetId:t,col:o,row:s},i){if(!e)return"none";const n=i.range.zone;let r="none";if(n.bottom+1===s&&o>=n.left&&o<=n.right?r="down":n.right+1===o&&s>=n.top&&s<=n.bottom&&(r="right"),"none"===r)return"none";const a="down"===r?{...n,bottom:n.bottom+1,top:n.bottom+1}:{...n,right:n.right+1,left:n.right+1};for(const e of us(a)){const o={sheetId:t,...e},s=this.getters.getCell(o)?.content;if(s||this.getters.isInMerge(o)||this.getTablesOverlappingZones(t,[fs(e)]).length)return"none"}return r}getCoreTableMatchingTopLeft(e,t){for(const o of this.getCoreTables(e)){const e=o.range.zone;if(e.left===t.left&&e.top===t.top)return o}}checkUpdatedTableZoneIsValid(e){if(!e.newTableRange)return"Success";const t=this.getters.getRangeFromRangeData(e.newTableRange).zone,o=this.getters.checkZonesExistInSheet(e.sheetId,[t]);if("Success"!==o)return o;const s=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!s)return"TableNotFound";return this.getTablesOverlappingZones(e.sheetId,[t]).filter((e=>e.id!==s.id)).length?"TableOverlap":"Success"}checkTableConfigUpdateIsValid(e){return e&&(void 0!==e.numberOfHeaders&&e.numberOfHeaders<0||e.hasFilters&&0===e.numberOfHeaders)?"InvalidTableConfig":"Success"}createStaticTable(e,t,o,s,i){const n=o.zone;if(!i){i=[];for(const e of Ze(n.left,n.right+1)){const t={...n,left:e,right:e},r=""+YM++;i.push(this.createFilterFromZone(r,o.sheetId,t,s))}}return{id:e,range:o,filters:i,config:s,type:t}}createDynamicTable(e,t,o){const s=vs(t.zone);return{id:e,range:this.getters.getRangeFromZone(t.sheetId,s),config:o,type:"dynamic"}}updateTable(e){const t=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return;const o=e.newTableRange?this.getters.getRangeFromRangeData(e.newTableRange):void 0;if(o){const t=this.getters.getMergesInZone(e.sheetId,o.zone);this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:t})}const s=o||t.range,i=this.updateTableConfig(e.config,t.config),n=e.tableType??t.type;if("dynamic"===n&&"dynamic"!==t.type||"dynamic"!==n&&"dynamic"===t.type){const o="dynamic"===n?this.createDynamicTable(t.id,s,i):this.createStaticTable(t.id,n,s,i);this.history.update("tables",e.sheetId,t.id,o)}else{const o="dynamic"===t.type?this.updateDynamicTable(t,s,i):this.updateStaticTable(t,s,i,n);this.history.update("tables",e.sheetId,t.id,o)}}updateStaticTable(e,t,o,s=e.type){if("dynamic"===s)throw new Error("Cannot use updateStaticTable to update a dynamic table");const i=t||e.range,n=i.zone,r=this.updateTableConfig(o,e.config),a=r||e.config,l=[];if(t||r&&"numberOfHeaders"in r)for(const t of Ze(n.left,n.right+1)){const o=n.top===e.range.zone.top?e.filters.find((e=>e.col===t)):void 0,s={...n,left:t,right:t},r=o?.id||""+YM++;l.push(this.createFilterFromZone(r,i.sheetId,s,a))}return{...e,range:i,config:a,filters:l.length?l:e.filters,type:s}}updateDynamicTable(e,t,o){const s=t?this.getters.getRangeFromZone(t.sheetId,vs(t.zone)):e.range,i=o||e.config;return{...e,range:s,config:i}}updateTableConfig(e,t){if(!e)return t;const o={...t,...e};return 0===e.numberOfHeaders?o.hasFilters=!1:!0===e.hasFilters&&(o.numberOfHeaders||=1),o}createFilterFromZone(e,t,o,s){return EF(e,this.getters.getRangeFromZone(t,o),s,this.getters.getRangeFromZone)}copyStaticTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone),s=t.filters.map((o=>{const s=this.getters.getRangeFromZone(e,o.rangeWithHeaders.zone);return EF(o.id,s,t.config,this.getters.getRangeFromZone)}));return{id:t.id,range:o,filters:s,config:Be(t.config),type:t.type}}copyDynamicTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:o,config:Be(t.config),type:"dynamic"}}applyRangeChangeOnTable(e,t,o){const s=o(t.range);let i;switch(s.changeType){case"REMOVE":return void this.history.update("tables",e,t.id,void 0);case"NONE":return;default:i=s.range}if("dynamic"===t.type){const o=this.updateDynamicTable(t,i);return void this.history.update("tables",e,t.id,o)}const n=[];for(const e of t.filters){const s=o(e.rangeWithHeaders);switch(s.changeType){case"REMOVE":continue;case"NONE":n.push(e);break;default:const o=s.range,i=EF(e.id,o,t.config,this.getters.getRangeFromZone);n.push(i)}}const r=i.zone;if(n.length<cs(r).numberOfCols){for(let o=r.left;o<=r.right;o++)if(!n.find((e=>e.col===o))){const s=""+YM++,i={...r,left:o,right:o};n.push(this.createFilterFromZone(s,e,i,t.config))}n.sort(((e,t)=>e.col-t.col))}const a=this.createStaticTable(t.id,t.type,i,t.config,n);this.history.update("tables",e,t.id,a)}import(e){for(const t of e.sheets)for(const e of t.tables||[]){const o=""+YM++,s=e.config||QC,i=this.getters.getRangeFromSheetXC(t.id,e.range),n=e.type||"static",r="dynamic"===n?this.createDynamicTable(o,i,s):this.createStaticTable(o,n,i,s);this.history.update("tables",t.id,r.id,r)}}export(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o={range:Jo(e.range.zone),type:e.type};mt(e.config,QC)||(o.config=e.config),t.tables.push(o)}}exportForExcel(e){for(const t of e.sheets)for(const e of this.getCoreTables(t.id)){const o=Jo(e.range.zone);t.tables.push({range:o,filters:[],config:e.config})}}}).add("dataValidation",class extends zM{static getters=["cellHasListDataValidationIcon","getDataValidationRule","getDataValidationRules","getValidationRuleForCell"];rules={};adaptRanges(e,t){const o=t?[t]:Object.keys(this.rules);for(const t of o)this.loopThroughRangesOfSheet(t,e)}loopThroughRangesOfSheet(e,t){for(let o=this.rules[e].length-1;o>=0;o--){const s=this.rules[e][o];for(let i=s.ranges.length-1;i>=0;i--){const n=t(s.ranges[i]);switch(n.changeType){case"REMOVE":if(1===s.ranges.length)this.removeDataValidationRule(e,s.id);else{const t=s.ranges.slice();t.splice(i,1),this.history.update("rules",e,o,"ranges",t)}break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("rules",e,o,"ranges",i,n.range)}}}}allowDispatch(e){switch(e.type){case"ADD_DATA_VALIDATION_RULE":return this.checkValidations(e,this.chainValidations(this.checkEmptyRange,this.checkValidRange,this.checkCriterionTypeIsValid,this.checkCriterionHasValidNumberOfValues,this.checkCriterionValuesAreValid));case"REMOVE_DATA_VALIDATION_RULE":if(!this.rules[e.sheetId].find((t=>t.id===e.id)))return"UnknownDataValidationRule"}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("rules",e.sheetId,[]);break;case"DUPLICATE_SHEET":{const t=Be(this.rules[e.sheetId]).map((t=>({...t,ranges:t.ranges.map((t=>Lr(e.sheetId,e.sheetIdTo,t)))})));this.history.update("rules",e.sheetIdTo,t);break}case"DELETE_SHEET":{const t={...this.rules};delete t[e.sheetId],this.history.update("rules",t);break}case"REMOVE_DATA_VALIDATION_RULE":this.removeDataValidationRule(e.sheetId,e.id);break;case"ADD_DATA_VALIDATION_RULE":{const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));this.addDataValidationRule(e.sheetId,{...e.rule,ranges:t});break}case"DELETE_CONTENT":{const t=Co(e.target),o=e.sheetId;for(const e of t)for(let t=e.top;t<=e.bottom;t++)for(let s=e.left;s<=e.right;s++){const e=this.getValidationRuleForCell({sheetId:o,col:s,row:t});if(e&&("isBoolean"===e.criterion.type||"isValueInList"===e.criterion.type&&!this.getters.getCell({sheetId:o,col:s,row:t})?.content)){const e=this.rules[o],i=[this.getters.getRangeFromSheetXC(o,yo(s,t))],n=this.removeRangesFromRules(o,i,e);this.history.update("rules",o,n)}}}}}getDataValidationRules(e){return this.rules[e]}getDataValidationRule(e,t){return this.rules[e].find((e=>e.id===t))}getValidationRuleForCell({sheetId:e,col:t,row:o}){if(this.rules[e])for(const s of this.rules[e])for(const e of s.ranges)if(as(t,o,e.zone))return s}cellHasListDataValidationIcon(e){const t=this.getValidationRuleForCell(e);return!!t&&(("isValueInList"===t.criterion.type||"isValueInRange"===t.criterion.type)&&"arrow"===t.criterion.displayStyle)}addDataValidationRule(e,t){const o=this.rules[e];"isBoolean"===t.criterion.type?this.setCenterStyleToBooleanCells(t):"isValueInList"===t.criterion.type&&(t.criterion.values=Array.from(new Set(t.criterion.values)));const s=this.removeRangesFromRules(e,t.ranges,o),i=s.findIndex((e=>e.id===t.id));-1!==i?(s[i]=t,this.history.update("rules",e,s)):this.history.update("rules",e,[...s,t])}removeRangesFromRules(e,t,o){o=Be(o);for(const e of o)e.ranges=this.getters.recomputeRanges(e.ranges,t);return o.filter((e=>e.ranges.length>0))}removeDataValidationRule(e,t){const o=this.rules[e].filter((e=>e.id!==t));this.history.update("rules",e,o)}setCenterStyleToBooleanCells(e){for(const t of Ur(e.ranges)){const e=this.getters.getCell(t),o={...e?.style,align:e?.style?.align??"center",verticalAlign:e?.style?.verticalAlign??"middle"};this.dispatch("UPDATE_CELL",{...t,style:o})}}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}import(e){for(const t of e.sheets)if(this.rules[t.id]=[],t.dataValidationRules)for(const e of t.dataValidationRules)this.rules[t.id].push({...e,ranges:e.ranges.map((e=>this.getters.getRangeFromSheetXC(t.id,e)))})}export(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id])t.dataValidationRules.push({...e,ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id)))})}}exportForExcel(e){if(e.sheets)for(const t of e.sheets){t.dataValidationRules=[];for(const e of this.rules[t.id]){const o={...Be(e),ranges:e.ranges.map((e=>this.getters.getRangeString(e,t.id,{useBoundedReference:!0})))};"isValueInRange"===e.criterion.type&&(o.criterion.values=e.criterion.values.map((e=>{const o=this.getters.getRangeFromSheetXC(t.id,e);return this.getters.getRangeString(o,t.id,{useBoundedReference:!0,useFixedReference:!0})}))),t.dataValidationRules.push(o)}}}checkCriterionTypeIsValid(e){return gO.contains(e.rule.criterion.type)?"Success":"UnknownDataValidationCriterionType"}checkCriterionHasValidNumberOfValues(e){const t=e.rule.criterion,o=gO.get(t.type).numberOfValues(t);return void 0!==o&&t.values.length!==o?"InvalidNumberOfCriterionValues":"Success"}checkCriterionValuesAreValid(e){const t=e.rule.criterion,o=gO.get(t.type);return t.values.some((e=>"onlyFormulas"===o.allowedValues&&!e.startsWith("=")||(e.startsWith("=")?"onlyLiterals"===o.allowedValues||hS(e).isBadExpression:!o.isCriterionValueValid(e))))?"InvalidDataValidationCriterionValue":"Success"}checkValidRange(e){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e))),o=t.map((t=>this.getters.getRangeString(t,e.sheetId)));return o.some((e=>!this.getters.isRangeValid(e)))?"InvalidRange":"Success"}}).add("cell",class extends zM{static getters=["zoneToXC","getCells","getTranslatedCellFormula","getCellStyle","getCellById","getFormulaString","getFormulaMovedInSheet"];nextId=1;cells={};adaptRanges(e,t){for(const o of Object.keys(this.cells))for(const s of Object.values(this.cells[o]||{}))if(s.isFormula)for(const i of s.compiledFormula.dependencies)if(!t||i.sheetId===t){const t=e(i);"NONE"!==t.changeType&&this.history.update("cells",o,s.id,"compiledFormula","dependencies",s.compiledFormula.dependencies.indexOf(i),t.range)}}allowDispatch(e){switch(e.type){case"UPDATE_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessUpdateCell);case"CLEAR_CELL":return this.checkValidations(e,this.checkCellOutOfSheet,this.checkUselessClearCell);default:return"Success"}}handle(e){switch(e.type){case"SET_FORMATTING":"style"in e&&this.setStyle(e.sheetId,e.target,e.style),"format"in e&&void 0!==e.format&&this.setFormatter(e.sheetId,e.target,e.format);break;case"CLEAR_FORMATTING":this.clearFormatting(e.sheetId,e.target);break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.handleAddColumnsRows(e,this.copyColumnStyle.bind(this)):this.handleAddColumnsRows(e,this.copyRowStyle.bind(this));break;case"UPDATE_CELL":this.updateCell(e.sheetId,e.col,e.row,e);break;case"CLEAR_CELL":this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col,row:e.row,content:"",style:null,format:""});break;case"CLEAR_CELLS":this.clearCells(e.sheetId,e.target);break;case"DELETE_CONTENT":this.clearZones(e.sheetId,e.target)}}clearZones(e,t){for(let o of Co(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++){const o=this.getters.getCell({sheetId:e,col:t,row:s});(o?.isFormula||o?.content)&&this.dispatch("UPDATE_CELL",{sheetId:e,content:"",col:t,row:s})}}setFormatter(e,t,o){for(let s of Co(t))for(let t=s.top;t<=s.bottom;t++)for(let i=s.left;i<=s.right;i++)this.dispatch("UPDATE_CELL",{sheetId:e,col:i,row:t,format:o})}clearFormatting(e,t){for(let o of Co(t))for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,style:null,format:""})}clearCells(e,t){for(const o of t)for(let t=o.left;t<=o.right;t++)for(let s=o.top;s<=o.bottom;s++)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:"",style:null,format:""})}handleAddColumnsRows(e,t){let o,s;"before"===e.position?(o=Ze(e.base,e.base+e.quantity),s=e.base+e.quantity):(o=Ze(e.base+1,e.base+e.quantity+1),s=e.base),t(e.sheetId,s,o)}import(e){for(let t of e.sheets){const o=t.id,s=new c_;for(const e in t.cells)if(t.cells[e]){const{col:o,row:i}=So(e),n={sheetId:t.id,col:o,row:i};s.set(n,{content:t.cells[e]})}for(const[e,o]of[["style",t.styles],["format",t.formats]])for(const[i,n]of Es(t.id,o)){const t=s.get(i);t?t[e]=n:s.set(i,{[e]:n})}for(const i of s.keysForSheet(o)){const o=s.get(i);if(o?.content||o?.format||o?.style){const s=this.importCell(t.id,o?.content,o?.style?e.styles[o?.style]:void 0,o?.format?e.formats[o?.format]:void 0);this.history.update("cells",t.id,s.id,s),this.dispatch("UPDATE_CELL_POSITION",{cellId:s.id,...i})}}}}export(e){const t={},o={};for(let s of e.sheets){const e=[],i=[],n={},r=Object.keys(this.cells[s.id]||{}).map((e=>this.getters.getCellPosition(e))).sort(((e,t)=>e.col===t.col?e.row-t.row:e.col-t.col));for(const s of r){const r=this.getters.getCell(s),a=yo(s.col,s.row),l=this.removeDefaultStyleValues(r.style);if(Object.keys(l).length){const o=ws(l,t);e[o]??=[],e[o].push(s)}if(r.format){const e=ws(r.format,o);i[e]??=[],i[e].push(s)}r.content&&(n[a]=r.content)}s.styles=xs(e),s.formats=xs(i),s.cells=n}e.styles=t,e.formats=o}importCell(e,t,o,s){const i=this.getNextUid();return this.createCell(i,t||"",s,o,e)}exportForExcel(e){this.export(e);const t=[];for(const o in e.formats||[])xr(e.formats[o])||(t.push(Number(o)),delete e.formats[o]);if(t.length)for(const o of e.sheets)for(const e in o.formats){const s=o.formats[e];s&&t.includes(s)&&delete o.formats[e]}}removeDefaultStyleValues(e){const t={...e};for(const e in de)t[e]===de[e]&&delete t[e];return t}getCells(e){return this.cells[e]||{}}getCellById(e){const t=this.getters.getCellPosition(e);return this.cells[t.sheetId][e]}getFormulaString(e,t,o,s=!1){if(!o.length)return dt(t.map((e=>e.value)));let i=0;return dt(t.map((t=>{if("REFERENCE"===t.type){const t=o[i++];return this.getters.getRangeString(t,e,{useBoundedReference:s})}return t.value})))}getTranslatedCellFormula(e,t,o,s){const i=this.getters.createAdaptedRanges(dS(s).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),t,o,e);return this.getFormulaString(e,s,i)}getFormulaMovedInSheet(e,t,o){const s=dS(o).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),i=this.getters.removeRangesSheetPrefix(t,s);return this.getFormulaString(t,o,i)}getCellStyle(e){return this.getters.getCell(e)?.style||{}}zoneToXC(e,t,o=[{colFixed:!1,rowFixed:!1}]){const s=yo((t=this.getters.expandZone(e,t)).left,t.top,o[0]),i=yo(t.right,t.bottom,o.length>1?o[1]:o[0]),n=this.getters.getMainCellPosition({sheetId:e,col:t.left,row:t.top}),r=this.getters.getMainCellPosition({sheetId:e,col:t.right,row:t.bottom}),a=n.col===r.col&&n.row===r.row;return s==i||a?s:s+":"+i}setStyle(e,t,o){for(let s of Co(t))for(let t=s.left;t<=s.right;t++)for(let i=s.top;i<=s.bottom;i++){const s=this.getters.getCell({sheetId:e,col:t,row:i});this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:i,style:o?{...s?.style,...o}:void 0})}}copyColumnStyle(e,t,o){for(let s=0;s<this.getters.getNumberRows(e);s++){const i=this.getFormat(e,t,s);if(i.style||i.format)for(let t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,...i})}}copyRowStyle(e,t,o){for(let s=0;s<this.getters.getNumberCols(e);s++){const i=this.getFormat(e,s,t);if(i.style||i.format)for(let t of o)this.dispatch("UPDATE_CELL",{sheetId:e,col:s,row:t,...i})}}getFormat(e,t,o){const s={},i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.getters.getCell(i);return n&&(n.style&&(s.style=n.style),n.format&&(s.format=n.format)),s}getNextUid(){const e=this.nextId.toString();return this.history.update("nextId",this.nextId+1),e}updateCell(e,t,o,s){const i=this.getters.getCell({sheetId:e,col:t,row:o}),n="content"in s||"formula"in s,r=n?wt(s?.content):i?.content||"";let a;a=void 0!==s.style?s.style||void 0:i?i.style:void 0;const l="format"in s?s.format:i&&i.format;if((n&&!r&&!s.formula||!n&&(!i||""===i.content))&&!a&&!l)return void(i&&(this.history.update("cells",e,i.id,void 0),this.dispatch("UPDATE_CELL_POSITION",{cellId:void 0,col:t,row:o,sheetId:e})));const c=i?.id||this.getNextUid(),h=this.createCell(c,r,l,a,e);this.history.update("cells",e,h.id,h),this.dispatch("UPDATE_CELL_POSITION",{cellId:h.id,col:t,row:o,sheetId:e})}createCell(e,t,o,s,i){return t.startsWith("=")?this.createFormulaCell(e,t,o,s,i):this.createLiteralCell(e,t,o,s)}createLiteralCell(e,t,o,s){const i=this.getters.getLocale(),n=Rr(t,i);return Er(o=o||("number"==typeof n?hr(t,i)||dr(t):void 0))||ki(t)||(t=qi(n)),{id:e,content:t,style:s,format:o,isFormula:!1,parsedValue:n}}createFormulaCell(e,t,o,s,i){const n=hS(t);return n.dependencies.length?this.createFormulaCellWithDependencies(e,n,o,s,i):{id:e,content:t,style:s,format:o,isFormula:!0,compiledFormula:{...n,dependencies:[]}}}createFormulaCellWithDependencies(e,t,o,s,i){const n=[];for(const e of t.dependencies)n.push(this.getters.getRangeFromSheetXC(i,e));return new $M(e,t,o,s,n,i,this.getters.getRangeString)}checkCellOutOfSheet(e){const{sheetId:t,col:o,row:s}=e;if(!this.getters.tryGetSheet(t))return"InvalidSheetId";return as(o,s,this.getters.getSheetZone(t))?"Success":"TargetOutOfSheet"}checkUselessClearCell(e){const t=this.getters.getCell(e);return t&&(t.content||t.style||t.format)?"Success":"NoChanges"}checkUselessUpdateCell(e){const t=this.getters.getCell(e),o="style"in e,s="format"in e;return("content"in e||"formula"in e)&&t?.content!==e.content||o&&!mt(t?.style,e.style)||s&&t?.format!==e.format?"Success":"NoChanges"}}).add("merge",class extends zM{static getters=["isInMerge","isInSameMerge","isMergeHidden","getMainCellPosition","expandZone","doesIntersectMerge","doesColumnsHaveCommonMerges","doesRowsHaveCommonMerges","getMerges","getMerge","getMergesInZone","isSingleCellOrMerge","getSelectionRangeString","isMainCellPosition"];nextId=1;merges={};mergeCellMap={};allowDispatch(e){const t="force"in e&&!!e.force;switch(e.type){case"ADD_MERGE":return t?this.checkValidations(e,this.checkFrozenPanes):this.checkValidations(e,this.checkDestructiveMerge,this.checkOverlap,this.checkFrozenPanes);case"UPDATE_CELL":return this.checkMergedContentUpdate(e);case"REMOVE_MERGE":return this.checkMergeExists(e);default:return"Success"}}handle(e){switch(e.type){case"CREATE_SHEET":case"DELETE_SHEET":this.history.update("merges",e.sheetId,{}),this.history.update("mergeCellMap",e.sheetId,{});break;case"DUPLICATE_SHEET":const t=this.merges[e.sheetId];if(!t)break;for(const o of Object.values(t).filter(at))this.addMerge(e.sheetIdTo,o.zone);break;case"ADD_MERGE":for(const t of e.target)this.addMerge(e.sheetId,t);break;case"REMOVE_MERGE":for(const t of e.target)this.removeMerge(e.sheetId,t)}}adaptRanges(e,t){const o=t?[t]:Object.keys(this.merges);for(const t of o)this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map((t=>this.getMergeById(e,parseInt(t,10)))).filter(at)}getMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e],i=s?t in s&&s[t]?.[o]:void 0;return i?this.getMergeById(e,i):void 0}getMergesInZone(e,t){const o=this.mergeCellMap[e];if(!o)return[];const s=new Set;for(let e=t.left;e<=t.right;e++)for(let i=t.top;i<=t.bottom;i++){const t=o[e]?.[i];t&&s.add(t)}return Array.from(s).map((t=>this.getMergeById(e,t))).filter(at)}getSelectionRangeString(e,t){const o=kr.fromRange(e,this.getters),s=this.getters.expandZone(o.sheetId,o.zone),i=o.clone({zone:{...s,bottom:o.isFullCol?void 0:s.bottom,right:o.isFullRow?void 0:s.right}}),n=this.getters.getRangeString(i,t);if(this.isSingleCellOrMerge(o.sheetId,o.zone)){const{sheetName:e,xc:t}=qo(n);return Zo(e,t.split(":")[0])}return n}doesIntersectMerge(e,t){for(const o of this.getMerges(e))if(rs(t,o))return!0;return!1}doesColumnsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<this.getters.getNumberRows(e);i++)if(this.isInSameMerge(s.id,t,i,o,i))return!0;return!1}doesRowsHaveCommonMerges(e,t,o){const s=this.getters.getSheet(e);for(let i=0;i<=this.getters.getNumberCols(e);i++)if(this.isInSameMerge(s.id,i,t,i,o))return!0;return!1}expandZone(e,t){let{left:o,right:s,top:i,bottom:n}=t,r={left:o,right:s,top:i,bottom:n};for(let t in this.merges[e]){const o=this.getMergeById(e,parseInt(t));o&&rs(o,r)&&(r=ss(o,r))}return ns(r,t)?r:this.expandZone(e,r)}isInSameMerge(e,t,o,s,i){const n=this.getMerge({sheetId:e,col:t,row:o}),r=this.getMerge({sheetId:e,col:s,row:i});return!(!n||!r)&&ns(n,r)}isInMerge({sheetId:e,col:t,row:o}){const s=this.mergeCellMap[e];return!!s&&(t in s&&Boolean(s[t]?.[o]))}getMainCellPosition(e){const t=this.getMerge(e);return t?{sheetId:e.sheetId,col:t.left,row:t.top}:e}isMergeHidden(e,t){const o=this.getters.getHiddenColsGroups(e),s=this.getters.getHiddenRowsGroups(e);for(let e of o)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(let e of s)if(t.top>=e[0]&&t.bottom<=e[e.length-1])return!0;return!1}isSingleCellOrMerge(e,t){const o=this.getMerge({sheetId:e,col:t.left,row:t.top});if(o)return ns(t,o);const{numberOfCols:s,numberOfRows:i}=cs(t);return 1===s&&1===i}isMainCellPosition(e){return mt(this.getMainCellPosition(e),e)}isMergeDestructive(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=qe(s,0,this.getters.getNumberCols(e)-1),n=qe(n,0,this.getters.getNumberRows(e)-1);for(let t=i;t<=n;t++)for(let n=o;n<=s;n++)if(n!==o||t!==i){const o=this.getters.getCell({sheetId:e,col:n,row:t});if(o&&""!==o.content)return!0}return!1}getMergeById(e,t){const o=this.merges[e]?.[t];return void 0!==o?ZM(t,o):void 0}checkDestructiveMerge({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";return t.some((t=>this.isMergeDestructive(e,t)))?"MergeIsDestructive":"Success"}checkOverlap({target:e}){for(const t of e)for(const o of e)if(t!==o&&rs(t,o))return"MergeOverlap";return"Success"}checkFrozenPanes({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return"Success";const{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e);for(const e of t)if(e.left<o&&e.right>=o||e.top<s&&e.bottom>=s)return"FrozenPaneOverlap";return"Success"}checkMergedContentUpdate(e){const{col:t,row:o,content:s}=e;if(void 0===s)return"Success";const{col:i,row:n}=this.getMainCellPosition(e);return i===t&&n===o?"Success":"CellIsMerged"}checkMergeExists(e){const{sheetId:t,target:o}=e;for(const e of o){const{left:o,top:s}=e,i=this.getMerge({sheetId:t,col:o,row:s});if(void 0===i||!ns(e,i))return"InvalidTarget"}return"Success"}addMerge(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=qe(s,0,this.getters.getNumberCols(e)-1),n=qe(n,0,this.getters.getNumberRows(e)-1);if(yo(o,i)===yo(s,n))return;const r=this.getters.getCell({sheetId:e,col:o,row:i});let a=this.nextId++;this.history.update("merges",e,a,this.getters.getRangeFromSheetXC(e,Jo({left:o,top:i,right:s,bottom:n})));let l=new Set;for(let t=i;t<=n;t++)for(let n=o;n<=s;n++){n===o&&t===i||this.dispatch("UPDATE_CELL",{sheetId:e,col:n,row:t,style:r?r.style:null,content:""});const s=this.getMerge({sheetId:e,col:n,row:t});s&&l.add(s.id),this.history.update("mergeCellMap",e,n,t,a)}for(let t of l){const{top:o,bottom:s,left:i,right:n}=this.getMergeById(e,t);for(let t=o;t<=s;t++)for(let o=i;o<=n;o++){const s={sheetId:e,col:o,row:t},i=this.getMerge(s);i&&i.id===a||(this.history.update("mergeCellMap",e,o,t,void 0),this.dispatch("CLEAR_CELL",s))}this.history.update("merges",e,t,void 0)}}removeMerge(e,t){const{left:o,top:s,bottom:i,right:n}=t,r=this.getMerge({sheetId:e,col:o,row:s});if(void 0!==r&&ns(t,r)){this.history.update("merges",e,r.id,void 0);for(let t=s;t<=i;t++)for(let s=o;s<=n;s++)this.history.update("mergeCellMap",e,s,t,void 0)}}applyRangeChangeOnSheet(e,t){const o=Object.entries(this.merges[e]||{});for(const[s,i]of o)if(i){const o=i.zone,n=t(i);switch(n.changeType){case"NONE":break;case"REMOVE":this.removeMerge(e,o);break;default:const{numberOfCols:t,numberOfRows:i}=cs(n.range.zone);1===t&&1===i?this.removeMerge(e,o):this.history.update("merges",e,parseInt(s,10),n.range)}}this.history.update("mergeCellMap",e,{});for(const t of this.getMerges(e))for(const{col:o,row:s}of us(t))this.history.update("mergeCellMap",e,o,s,t.id)}import(e){const t=e.sheets||[];for(let e of t)this.history.update("merges",e.id,{}),this.history.update("mergeCellMap",e.id,{}),e.merges&&this.importMerges(e.id,e.merges)}importMerges(e,t){for(let o of t)this.addMerge(e,Yo(o))}export(e){for(let t of e.sheets){const e=this.merges[t.id];e&&t.merges.push(...qM(e))}}exportForExcel(e){this.export(e)}}).add("headerSize",class extends zM{static getters=["getUserRowSize","getColSize"];sizes={};handle(e){switch(e.type){case"CREATE_SHEET":this.history.update("sizes",e.sheetId,{COL:Array(this.getters.getNumberCols(e.sheetId)).fill(void 0),ROW:Array(this.getters.getNumberRows(e.sheetId)).fill(void 0)});break;case"DUPLICATE_SHEET":this.history.update("sizes",e.sheetIdTo,Be(this.sizes[e.sheetId]));break;case"DELETE_SHEET":const t={...this.sizes};delete t[e.sheetId],this.history.update("sizes",t);break;case"REMOVE_COLUMNS_ROWS":{const t=It(this.sizes[e.sheetId][e.dimension],e.elements);this.history.update("sizes",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{let t=[...this.sizes[e.sheetId][e.dimension]];const o=pt(e.position,e.base),s=t[e.base];t.splice(o,0,...Array(e.quantity).fill(s)),this.history.update("sizes",e.sheetId,e.dimension,t);break}case"RESIZE_COLUMNS_ROWS":if("ROW"===e.dimension)for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0);else for(const t of e.elements)this.history.update("sizes",e.sheetId,e.dimension,t,e.size||void 0)}}getColSize(e,t){return Math.round(this.sizes[e]?.COL[t]||oe)}getUserRowSize(e,t){const o=this.sizes[e]?.ROW[t];return o?Math.round(o):void 0}import(e){for(let t of e.sheets){const e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(let[o,s]of Object.entries(t.rows))s.size&&(e.ROW[o]=s.size);for(let[o,s]of Object.entries(t.cols))s.size&&(e.COL[o]=s.size);this.sizes[t.id]=e}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let o of e.sheets){void 0===o.rows&&(o.rows={});for(const e of Ze(0,this.getters.getNumberRows(o.id)))(t||this.sizes[o.id].ROW[e])&&(o.rows[e]={...o.rows[e],size:this.getUserRowSize(o.id,e)??se});void 0===o.cols&&(o.cols={});for(let e of Ze(0,this.getters.getNumberCols(o.id)))(t||this.sizes[o.id].COL[e])&&(o.cols[e]={...o.cols[e],size:this.getColSize(o.id,e)})}}}).add("borders",class extends zM{static getters=["getCellBorder","getBordersColors"];borders={};allowDispatch(e){return"SET_BORDER"===e.type?this.checkBordersUnchanged(e):"Success"}handle(e){switch(e.type){case"ADD_MERGE":for(const t of e.target)this.addBordersToMerge(e.sheetId,t);break;case"DUPLICATE_SHEET":const t=this.borders[e.sheetId];if(t){const o=t.slice().map((e=>e?.slice().map((e=>Be(e)))));this.history.update("borders",e.sheetIdTo,o)}break;case"DELETE_SHEET":const o={...this.borders};delete o[e.sheetId],this.history.update("borders",o);break;case"SET_BORDER":this.setBorder(e.sheetId,e.col,e.row,e.border);break;case"SET_ZONE_BORDERS":if(e.border){const t=e.target.map((t=>this.getters.expandZone(e.sheetId,t)));this.setBorders(e.sheetId,t,e.border.position,""===e.border.color?void 0:{style:e.border.style||ve,color:e.border.color||be})}break;case"CLEAR_FORMATTING":this.clearBorders(e.sheetId,e.target);break;case"REMOVE_COLUMNS_ROWS":const s=[...e.elements].sort(((e,t)=>t-e));for(const t of je(s))if("COL"===e.dimension){const o=this.getters.getColsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[o]),this.shiftBordersHorizontally(e.sheetId,t[0]+1,-t.length)}else{const o=this.getters.getRowsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[o]),this.shiftBordersVertically(e.sheetId,t[0]+1,-t.length)}break;case"ADD_COLUMNS_ROWS":"COL"===e.dimension?this.handleAddColumns(e):this.handleAddRows(e)}}handleAddColumns(e){let t,o;"before"===e.position?(this.shiftBordersHorizontally(e.sheetId,e.base,e.quantity),t=e.base-1,o=e.base+e.quantity):(this.shiftBordersHorizontally(e.sheetId,e.base+1,e.quantity),t=e.base,o=e.base+e.quantity+1),this.ensureColumnBorderContinuity(e.sheetId,t,o)}handleAddRows(e){let t,o;"before"===e.position?(this.shiftBordersVertically(e.sheetId,e.base,e.quantity),t=e.base-1,o=e.base+e.quantity):(this.shiftBordersVertically(e.sheetId,e.base+1,e.quantity),t=e.base,o=e.base+e.quantity+1),this.ensureRowBorderContinuity(e.sheetId,t,o)}getCellBorder({sheetId:e,col:t,row:o}){const s=this.borders[e]?.[t]?.[o];return s?.top||s?.bottom||s?.left||s?.right?Be(s):null}getBordersColors(e){const t=[],o=this.borders[e];if(o)for(const e of o.filter(at))for(const o of e)if(o)for(const e of["top","bottom","left","right"]){const s=o[e]?.color;s&&t.push(s)}return t}ensureColumnBorderContinuity(e,t,o){const s=Ze(t+1,o);for(let i=0;i<this.getters.getNumberRows(e);i++){const n=this.getCellBorder({sheetId:e,col:t,row:i}),r=this.getCellBorder({sheetId:e,col:o,row:i});if(n&&r){const t=this.getCommonSides(n,r);for(let o of s)this.addBorder(e,o,i,t)}}}ensureRowBorderContinuity(e,t,o){const s=Ze(t+1,o);for(let i=0;i<this.getters.getNumberCols(e);i++){const n=this.getCellBorder({sheetId:e,col:i,row:t}),r=this.getCellBorder({sheetId:e,col:i,row:o});if(n&&r){const t=this.getCommonSides(n,r);for(let o of s)this.addBorder(e,i,o,t)}}}getCommonSides(e,t){const o={};for(let s of["top","bottom","left","right"])e[s]&&mt(e[s],t[s])&&(o[s]=e[s]);return o}getColumnsWithBorders(e){const t=this.borders[e];return t?Object.keys(t).map((e=>parseInt(e,10))):[]}getRowsWithBorders(e){const t=this.borders[e]?.filter(at);if(!t)return[];const o=new Set;for(const e of t)for(const t in e)o.add(parseInt(t,10));return Array.from(o)}getRowsRange(e){return this.borders[e]?Ze(0,this.getters.getNumberRows(e)+1):[]}shiftBordersHorizontally(e,t,o){this.borders[e]&&this.getColumnsWithBorders(e).filter((e=>e>=t)).sort(((e,t)=>o<0?e-t:t-e)).forEach((t=>{this.moveBordersOfColumn(e,t,o)}))}shiftBordersVertically(e,t,o){this.borders[e]&&(o<0&&this.moveBordersOfRow(e,t,o,{destructive:!1}),this.getRowsWithBorders(e).filter((e=>e>=t)).sort(((e,t)=>o<0?e-t:t-e)).forEach((t=>{this.moveBordersOfRow(e,t,o)})))}moveBordersOfRow(e,t,o,{destructive:s}={destructive:!0}){const i=this.borders[e];i&&this.getColumnsWithBorders(e).forEach((n=>{const r=i[n]?.[t+o],a=i[n]?.[t];this.history.update("borders",e,n,t+o,s?a:a||r),this.history.update("borders",e,n,t,void 0)}))}moveBordersOfColumn(e,t,o,{destructive:s}={destructive:!0}){const i=this.borders[e];i&&this.getRowsRange(e).forEach((n=>{const r=i[t+o]?.[n],a=i[t]?.[n];this.history.update("borders",e,t+o,n,s?a:a||r),s&&this.history.update("borders",e,t,n,void 0)}))}setBorder(e,t,o,s,i=!0){const n=this.getters.getNumberCols(e)-1,r=this.getters.getNumberRows(e)-1;!i&&this.borders[e]?.[t]?.[o]?.left||(this.history.update("borders",e,t,o,"left",s?.left),s?.left&&t>0&&!mt(this.getCellBorder({sheetId:e,col:t-1,row:o})?.right,s?.left)&&this.history.update("borders",e,t-1,o,"right",void 0)),!i&&this.borders[e]?.[t]?.[o]?.top||(this.history.update("borders",e,t,o,"top",s?.top),s?.top&&o>0&&!mt(this.getCellBorder({sheetId:e,col:t,row:o-1})?.bottom,s?.top)&&this.history.update("borders",e,t,o-1,"bottom",void 0)),!i&&this.borders[e]?.[t]?.[o]?.right||(this.history.update("borders",e,t,o,"right",s?.right),s?.right&&t<n&&!mt(this.getCellBorder({sheetId:e,col:t+1,row:o})?.left,s?.right)&&this.history.update("borders",e,t+1,o,"left",void 0)),!i&&this.borders[e]?.[t]?.[o]?.bottom||(this.history.update("borders",e,t,o,"bottom",s?.bottom),s?.bottom&&o<r&&!mt(this.getCellBorder({sheetId:e,col:t,row:o+1})?.top,s?.bottom)&&this.history.update("borders",e,t,o+1,"top",void 0))}clearBorders(e,t,o=!1){const s=this.getters.getNumberCols(e)-1,i=this.getters.getNumberRows(e)-1;for(let n of Co(t))for(let t=n.top;t<=n.bottom;t++){o&&(n.left>0&&this.history.update("borders",e,n.left-1,t,"right",void 0),n.right<s&&this.history.update("borders",e,n.right+1,t,"left",void 0));for(let s=n.left;s<=n.right;s++)this.history.update("borders",e,s,t,void 0),o&&(n.top>0&&this.history.update("borders",e,s,n.top-1,"bottom",void 0),n.bottom<i&&this.history.update("borders",e,s,n.bottom+1,"top",void 0))}}clearInsideBorders(e,t){for(let o of t)for(let t=o.top;t<=o.bottom;t++)for(let s=o.left;s<=o.right;s++)this.history.update("borders",e,s,t,void 0)}addBorder(e,t,o,s){this.setBorder(e,t,o,{...this.getCellBorder({sheetId:e,col:t,row:o}),...s})}setBorders(e,t,o,s){if("clear"===o)return this.clearBorders(e,t,!0);for(let i of Co(t)){if("all"===o)for(let t=i.top;t<=i.bottom;t++)for(let o=i.left;o<=i.right;o++)this.addBorder(e,o,t,{top:s,right:s,bottom:s,left:s});if("h"===o||"hv"===o){if(i.top===i.bottom)continue;for(let t=i.left;t<=i.right;t++){this.addBorder(e,t,i.top,{bottom:s});for(let o=i.top+1;o<i.bottom;o++)this.addBorder(e,t,o,{top:s,bottom:s});this.addBorder(e,t,i.bottom,{top:s})}}if("v"===o||"hv"===o){if(i.left===i.right)continue;for(let t=i.top;t<=i.bottom;t++){this.addBorder(e,i.left,t,{right:s});for(let o=i.left+1;o<i.right;o++)this.addBorder(e,o,t,{left:s,right:s});this.addBorder(e,i.right,t,{left:s})}}if("left"===o||"external"===o)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.left,t,{left:s});if("right"===o||"external"===o)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.right,t,{right:s});if("top"===o||"external"===o)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.top,{top:s});if("bottom"===o||"external"===o)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.bottom,{bottom:s})}}addBordersToMerge(e,t){const{left:o,right:s,top:i,bottom:n}=t,r=this.getCellBorder({sheetId:e,col:o,row:i}),a=this.getCellBorder({sheetId:e,col:s,row:n});this.clearBorders(e,[t]),r?.top&&this.setBorders(e,[{...t,bottom:i}],"top",r.top),r?.left&&this.setBorders(e,[{...t,right:o}],"left",r.left),a?.bottom?this.setBorders(e,[{...t,top:n}],"bottom",a.bottom):r?.bottom&&this.setBorders(e,[{...t,top:n}],"bottom",r.bottom),a?.right?this.setBorders(e,[{...t,left:s}],"right",a.right):r?.right&&this.setBorders(e,[{...t,left:s}],"right",r.right)}checkBordersUnchanged(e){const t=this.getCellBorder(e),o=!(e.border?.bottom||e.border?.left||e.border?.right||e.border?.top);return!t&&o||mt(t,e.border)?"NoChanges":"Success"}import(e){if(Object.keys(e.borders||{}).length)for(const t of e.sheets)for(const[o,s]of Es(t.id,t.borders)){const{sheetId:t,col:i,row:n}=o,r=e.borders[s];this.setBorder(t,i,n,r,!1)}for(let t of e.sheets)if(t.merges)for(let e of t.merges)this.addBordersToMerge(t.id,Yo(e))}export(e){const t={};for(let o of e.sheets){const e={};for(let s=0;s<o.colNumber;s++)for(let i=0;i<o.rowNumber;i++){const n=this.getCellBorder({sheetId:o.id,col:s,row:i});if(n){const r=ws(n,t),a={sheetId:o.id,col:s,row:i};e[r]??=[],e[r].push(a)}}o.borders=xs(e)}e.borders=t}exportForExcel(e){this.export(e)}}).add("conditional formatting",class extends zM{static getters=["getConditionalFormats","getRulesSelection","getRulesByCell","getAdaptedCfRanges"];cfRules={};loopThroughRangesOfSheet(e,t){for(const o of this.cfRules[e]){if("DataBarRule"===o.rule.type&&o.rule.rangeValues){const s=t(o.rule.rangeValues);switch(s.changeType){case"REMOVE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"rule","rangeValues",void 0);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"rule","rangeValues",s.range)}}for(const s of o.ranges){const i=t(s);switch(i.changeType){case"REMOVE":let t=o.ranges.slice();t.splice(o.ranges.indexOf(s),1),t.length>=1?this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",t):this.removeConditionalFormatting(o.id,e);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",e,this.cfRules[e].indexOf(o),"ranges",o.ranges.indexOf(s),i.range)}}}}adaptRanges(e,t){if(t)this.loopThroughRangesOfSheet(t,e);else for(const t of Object.keys(this.cfRules))this.loopThroughRangesOfSheet(t,e)}allowDispatch(e){switch(e.type){case"ADD_CONDITIONAL_FORMAT":return this.checkValidations(e,this.checkCFRule,this.checkEmptyRange,this.checkCFHasChanged);case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":return this.checkValidPriorityChange(e.cfId,e.delta,e.sheetId)}return"Success"}handle(e){switch(e.type){case"CREATE_SHEET":this.cfRules[e.sheetId]=[];break;case"DUPLICATE_SHEET":this.history.update("cfRules",e.sheetIdTo,[]);for(const t of this.getConditionalFormats(e.sheetId))this.addConditionalFormatting(t,e.sheetIdTo);break;case"DELETE_SHEET":const t=Object.assign({},this.cfRules);delete t[e.sheetId],this.history.update("cfRules",t);break;case"ADD_CONDITIONAL_FORMAT":const o={...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))};this.addConditionalFormatting(o,e.sheetId);break;case"REMOVE_CONDITIONAL_FORMAT":this.removeConditionalFormatting(e.id,e.sheetId);break;case"CHANGE_CONDITIONAL_FORMAT_PRIORITY":this.changeCFPriority(e.cfId,e.delta,e.sheetId)}}import(e){for(let t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map((e=>this.mapToConditionalFormatInternal(t.id,e)))}export(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e))))}exportForExcel(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map((e=>this.mapToConditionalFormat(t.id,e,{useBoundedReference:!0}))))}getConditionalFormats(e){return this.cfRules[e]?.map((t=>this.mapToConditionalFormat(e,t)))||[]}getRulesSelection(e,t){const o=new Set;return t.forEach((t=>{this.getRulesByZone(e,t).forEach((e=>{o.add(e)}))})),Array.from(o)}getRulesByZone(e,t){const o=new Set;for(let s=t.top;s<=t.bottom;s++)for(let i=t.left;i<=t.right;i++){this.getRulesByCell(e,i,s).forEach((e=>{o.add(e.id)}))}return o}getRulesByCell(e,t,o){const s=[];for(let i of this.cfRules[e])for(let e of i.ranges)as(t,o,e.zone)&&s.push(i);return new Set(s.map((t=>this.mapToConditionalFormat(e,t))))}getAdaptedCfRanges(e,t,o,s){if(0===o.length&&0===s.length)return;const i=this.getters.getConditionalFormats(e),n=i.findIndex((e=>e.id===t.id));let r=[];n>-1&&(r=i[n].ranges.map(jo));const a=Co(r,s);return Co([...o,...a],[]).map((t=>this.getters.getRangeDataFromZone(e,t)))}mapToConditionalFormat(e,t,{useBoundedReference:o}={useBoundedReference:!1}){const s=t.ranges.map((t=>this.getters.getRangeString(t,e,{useBoundedReference:o})));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:s}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues&&this.getters.getRangeString(t.rule.rangeValues,e,{useBoundedReference:o})},ranges:s}}mapToConditionalFormatInternal(e,t){const o=t.ranges.map((t=>this.getters.getRangeFromSheetXC(e,t)));return"DataBarRule"!==t.rule.type?{...t,rule:{...t.rule},ranges:o}:{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues?this.getters.getRangeFromSheetXC(e,t.rule.rangeValues):void 0},ranges:o}}addConditionalFormatting(e,t){const o=this.cfRules[t].slice(),s=o.findIndex((t=>t.id===e.id)),i=this.mapToConditionalFormatInternal(t,e);s>-1?o.splice(s,1,i):o.push(i),this.history.update("cfRules",t,o)}checkValidPriorityChange(e,t,o){if(!this.cfRules[o])return"InvalidSheetId";const s=this.cfRules[o].findIndex((t=>t.id===e));if(-1===s)return"InvalidConditionalFormatId";const i=s-t;return i<0||i>=this.cfRules[o].length?"InvalidConditionalFormatId":"Success"}checkEmptyRange(e){return e.ranges.length?"Success":"EmptyRange"}checkCFRule(e){const t=e.cf.rule;switch(t.type){case"CellIsRule":return this.checkValidations(t,this.checkOperatorArgsNumber(2,["Between","NotBetween"]),this.checkOperatorArgsNumber(1,["BeginsWith","ContainsText","EndsWith","GreaterThan","GreaterThanOrEqual","LessThan","LessThanOrEqual","NotContains","Equal","NotEqual"]),this.checkOperatorArgsNumber(0,["IsEmpty","IsNotEmpty"]),this.checkCFValues);case"ColorScaleRule":return this.checkValidations(t,this.chainValidations(this.checkThresholds(this.checkFormulaCompilation)),this.chainValidations(this.checkThresholds(this.checkNaN),this.batchValidations(this.checkMinBiggerThanMax,this.checkMinBiggerThanMid,this.checkMidBiggerThanMax)));case"IconSetRule":return this.checkValidations(t,this.chainValidations(this.checkInflectionPoints(this.checkNaN),this.checkLowerBiggerThanUpper),this.chainValidations(this.checkInflectionPoints(this.checkFormulaCompilation)))}return"Success"}checkCFHasChanged(e){const t=this.mapToConditionalFormatInternal(e.sheetId,{...e.cf,ranges:e.ranges.map((t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId)))}),o=this.cfRules[e.sheetId]?.find((t=>t.id===e.cf.id));return o&&mt(t,o)?"NoChanges":"Success"}checkOperatorArgsNumber(e,t){if(e>2)throw new Error("Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.");return o=>{if(t.includes(o.operator)){const t=[],s=e=>void 0===e||""===e;return e>=1&&s(o.values[0])&&t.push("FirstArgMissing"),e>=2&&s(o.values[1])&&t.push("SecondArgMissing"),t.length?t:"Success"}return"Success"}}checkNaN(e,t){if(["number","percentage","percentile"].includes(e.type)&&(""===e.value||isNaN(e.value)))switch(t){case"min":return"MinNaN";case"max":return"MaxNaN";case"mid":return"MidNaN";case"upperInflectionPoint":return"ValueUpperInflectionNaN";case"lowerInflectionPoint":return"ValueLowerInflectionNaN"}return"Success"}checkFormulaCompilation(e,t){if("formula"!==e.type)return"Success";if(hS(e.value||"").isBadExpression)switch(t){case"min":return"MinInvalidFormula";case"max":return"MaxInvalidFormula";case"mid":return"MidInvalidFormula";case"upperInflectionPoint":return"ValueUpperInvalidFormula";case"lowerInflectionPoint":return"ValueLowerInvalidFormula"}return"Success"}checkThresholds(e){return this.batchValidations((t=>e(t.minimum,"min")),(t=>e(t.maximum,"max")),(t=>t.midpoint?e(t.midpoint,"mid"):"Success"))}checkInflectionPoints(e){return this.batchValidations((t=>e(t.lowerInflectionPoint,"lowerInflectionPoint")),(t=>e(t.upperInflectionPoint,"upperInflectionPoint")))}checkLowerBiggerThanUpper(e){const t=e.lowerInflectionPoint.value,o=e.upperInflectionPoint.value;return["number","percentage","percentile"].includes(e.lowerInflectionPoint.type)&&e.lowerInflectionPoint.type===e.upperInflectionPoint.type&&Number(t)>Number(o)?"LowerBiggerThanUpper":"Success"}checkMinBiggerThanMax(e){const t=e.minimum.value,o=e.maximum.value;return["number","percentage","percentile"].includes(e.minimum.type)&&e.minimum.type===e.maximum.type&&GM(t)>=GM(o)?"MinBiggerThanMax":"Success"}checkMidBiggerThanMax(e){const t=e.midpoint?.value,o=e.maximum.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.midpoint.type===e.maximum.type&&GM(t)>=GM(o)?"MidBiggerThanMax":"Success"}checkMinBiggerThanMid(e){const t=e.minimum.value,o=e.midpoint?.value;return e.midpoint&&["number","percentage","percentile"].includes(e.midpoint.type)&&e.minimum.type===e.midpoint.type&&GM(t)>=GM(o)?"MinBiggerThanMid":"Success"}checkCFValues(e){for(const t of e.values){if(!t.startsWith("="))continue;if(hS(t||"").isBadExpression)return"ValueCellIsInvalidFormula"}return"Success"}removeConditionalFormatting(e,t){const o=this.cfRules[t].findIndex((t=>t.id===e));if(-1!==o){const e=this.cfRules[t].slice();e.splice(o,1),this.history.update("cfRules",t,e)}}changeCFPriority(e,t,o){const s=this.cfRules[o].findIndex((t=>t.id===e)),i=this.cfRules[o][s],n=s-t,r=[...this.cfRules[o]];r.splice(s,1),r.splice(n,0,i),this.history.update("cfRules",o,r)}}).add("figures",class extends zM{static getters=["getFigures","getFigure","getFigureSheetId"];figures={};allowDispatch(e){switch(e.type){case"CREATE_FIGURE":return this.checkFigureDuplicate(e.figure.id);case"UPDATE_FIGURE":case"DELETE_FIGURE":return this.checkFigureExists(e.sheetId,e.id);default:return"Success"}}beforeHandle(e){if("DELETE_SHEET"===e.type)this.getters.getFigures(e.sheetId).forEach((t=>{this.dispatch("DELETE_FIGURE",{id:t.id,sheetId:e.sheetId})}))}handle(e){switch(e.type){case"CREATE_SHEET":this.figures[e.sheetId]={};break;case"DELETE_SHEET":this.deleteSheet(e.sheetId);break;case"CREATE_FIGURE":this.addFigure(e.figure,e.sheetId);break;case"UPDATE_FIGURE":const{type:t,sheetId:o,...s}=e,i=s;this.updateFigure(o,i);break;case"DELETE_FIGURE":this.removeFigure(e.id,e.sheetId);break;case"REMOVE_COLUMNS_ROWS":this.onRowColDelete(e.sheetId,e.dimension)}}onRowColDelete(e,t){"ROW"===t?this.onRowDeletion(e):this.onColDeletion(e)}onRowDeletion(e){const t=this.getters.getNumberRows(e);let o=0;for(let s=0;s<t;s++)o+=this.getters.getUserRowSize(e,s)||se;const s=this.getters.getFigures(e);for(const t of s){const s=Math.min(t.y,o-t.height);s!==t.y&&this.dispatch("UPDATE_FIGURE",{sheetId:e,id:t.id,y:s})}}onColDeletion(e){const t=this.getters.getNumberCols(e);let o=0;for(let s=0;s<t;s++)o+=this.getters.getColSize(e,s);const s=this.getters.getFigures(e);for(const t of s){const s=Math.min(t.x,o-t.width);s!==t.x&&this.dispatch("UPDATE_FIGURE",{sheetId:e,id:t.id,x:s})}}updateFigure(e,t){if("id"in t)for(const[o,s]of Object.entries(t))switch(o){case"x":case"y":void 0!==s&&this.history.update("figures",e,t.id,o,Math.max(s,0));break;case"width":case"height":void 0!==s&&this.history.update("figures",e,t.id,o,s)}}addFigure(e,t){this.history.update("figures",t,e.id,e)}deleteSheet(e){this.history.update("figures",e,void 0)}removeFigure(e,t){this.history.update("figures",t,e,void 0)}checkFigureExists(e,t){return void 0===this.figures[e]?.[t]?"FigureDoesNotExist":"Success"}checkFigureDuplicate(e){return Object.values(this.figures).find((t=>t?.[e]))?"DuplicatedFigureId":"Success"}getFigures(e){return Object.values(this.figures[e]||{}).filter(at)}getFigure(e,t){return this.figures[e]?.[t]}getFigureSheetId(e){return Object.keys(this.figures).find((t=>void 0!==this.figures[t]?.[e]))}import(e){for(let t of e.sheets){const e={};t.figures.forEach((t=>{e[t.id]=t})),this.figures[t.id]=e}}export(e){for(const t of e.sheets)for(const e of this.getFigures(t.id)){const o=void 0;t.figures.push({...e,data:o})}}exportForExcel(e){this.export(e)}}).add("chart",class extends zM{static getters=["isChartDefined","getChartDefinition","getChartType","getChartIds","getChart","getContextCreationChart"];charts={};createChart=pR(this.getters);validateChartDefinition=e=>fR(this,e.definition);adaptRanges(e){for(const[t,o]of Object.entries(this.charts))this.history.update("charts",t,o?.updateRanges(e))}allowDispatch(e){switch(e.type){case"CREATE_CHART":return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartDuplicate));case"UPDATE_CHART":return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartExists));default:return"Success"}}handle(e){switch(e.type){case"CREATE_CHART":this.addFigure(e.id,e.sheetId,e.position,e.size),this.addChart(e.id,e.definition);break;case"UPDATE_CHART":this.addChart(e.id,e.definition);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("chart"===o.tag){const t=o.id.split(we).pop(),s=`${e.sheetIdTo}${we}${t}`,i=this.charts[o.id]?.duplicateInDuplicatedSheet(e.sheetIdTo);i&&this.dispatch("CREATE_CHART",{id:s,position:{x:o.x,y:o.y},size:{width:o.width,height:o.height},definition:i.getDefinition(),sheetId:e.sheetIdTo})}break}case"DELETE_FIGURE":this.history.update("charts",e.id,void 0);break;case"DELETE_SHEET":for(let t of this.getChartIds(e.sheetId))this.history.update("charts",t,void 0)}}getContextCreationChart(e){return this.charts[e]?.getContextCreation()}getChart(e){return this.charts[e]}getChartType(e){const t=this.charts[e]?.type;if(!t)throw new Error("Chart not defined.");return t}isChartDefined(e){return e in this.charts&&void 0!==this.charts}getChartIds(e){return Object.entries(this.charts).filter((([,t])=>t?.sheetId===e)).map((([e])=>e))}getChartDefinition(e){const t=this.charts[e]?.getDefinition();if(!t)throw new Error(`There is no chart with the given figureId: ${e}`);return t}import(e){for(let t of e.sheets)if(t.figures)for(let e of t.figures)"chart"===e.tag&&(this.charts[e.id]=this.createChart(e.id,e.data,t.id))}export(e){if(e.sheets)for(let t of e.sheets){const e=this.getters.getFigures(t.id),o=[];for(let t of e){const e=t;if(e&&"chart"===e.tag){const t=this.charts[e.id]?.getDefinition();t&&(e.data=t,o.push(e))}else o.push(e)}t.figures=o}}addFigure(e,t,o={x:0,y:0},s={width:536,height:335}){if(this.getters.getFigure(t,e))return;const i={id:e,x:o.x,y:o.y,width:s.width,height:s.height,tag:"chart"};this.dispatch("CREATE_FIGURE",{sheetId:t,figure:i})}addChart(e,t){const o=this.getters.getFigureSheetId(e);o&&this.history.update("charts",e,this.createChart(e,t,o))}checkChartDuplicate(e){return this.getters.getFigureSheetId(e.id)?"DuplicatedChartId":"Success"}checkChartExists(e){return this.getters.getFigureSheetId(e.id)?"Success":"ChartDoesNotExist"}}).add("image",class extends zM{static getters=["getImage","getImagePath","getImageSize"];fileStore;images={};syncedImages=new Set;constructor(e){super(e),this.fileStore=e.external.fileStore}allowDispatch(e){return"CREATE_IMAGE"===e.type&&this.getters.getFigure(e.sheetId,e.figureId)?"InvalidFigureId":"Success"}handle(e){switch(e.type){case"CREATE_IMAGE":this.addImage(e.figureId,e.sheetId,e.position,e.size),this.history.update("images",e.sheetId,e.figureId,e.definition),this.syncedImages.add(e.definition.path);break;case"DUPLICATE_SHEET":{const t=this.getters.getFigures(e.sheetId);for(const o of t)if("image"===o.tag){const t=o.id.split(we).pop(),s=`${e.sheetIdTo}${we}${t}`,i=this.getImage(o.id);if(i){const t={width:o.width,height:o.height};this.dispatch("CREATE_IMAGE",{sheetId:e.sheetIdTo,figureId:s,position:{x:o.x,y:o.y},size:t,definition:Be(i)})}}break}case"DELETE_FIGURE":this.history.update("images",e.sheetId,e.id,void 0);break;case"DELETE_SHEET":this.history.update("images",e.sheetId,void 0)}}garbageCollectExternalResources(){const e=new Set(this.getAllImages().map((e=>e.path)));for(const t of this.syncedImages)e.has(t)||this.fileStore?.delete(t)}getImage(e){for(const t of Object.values(this.images))if(t&&t[e])return t[e];throw new Error(`There is no image with the given figureId: ${e}`)}getImagePath(e){return this.getImage(e).path}getImageSize(e){return this.getImage(e).size}addImage(e,t,o,s){const i={id:e,x:o.x,y:o.y,width:s.width,height:s.height,tag:"image"};this.dispatch("CREATE_FIGURE",{sheetId:t,figure:i})}import(e){for(const t of e.sheets){const e=(t.figures||[]).filter((e=>"image"===e.tag));for(const o of e)this.history.update("images",t.id,o.id,o.data),this.syncedImages.add(o.data.path)}}export(e){for(const t of e.sheets){const e=t.figures.filter((e=>"image"===e.tag));for(const o of e)o.data=this.images[t.id]?.[o.id]}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const t of e)if("image"===t?.tag){const e=this.getImage(t.id);e&&o.push({...t,data:Be(e)})}t.images=[...t.images,...o]}}getAllImages(){const e=[];for(const t in this.images)e.push(...Object.values(this.images[t]||{}).filter(at));return e}}).add("pivot_core",class extends zM{static getters=["getPivotCoreDefinition","getPivotDisplayName","getPivotId","getPivotFormulaId","getPivotIds","getMeasureCompiledFormula","getPivotName","isExistingPivot"];nextFormulaId=1;pivots={};formulaIds={};compiledMeasureFormulas={};allowDispatch(e){switch(e.type){case"ADD_PIVOT":return this.checkDuplicatedMeasureIds(e.pivot);case"UPDATE_PIVOT":return mt(e.pivot,this.pivots[e.pivotId]?.definition)?"NoChanges":""===e.pivot.name?"EmptyName":this.checkDuplicatedMeasureIds(e.pivot);case"RENAME_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound";if(""===e.name)return"EmptyName";break;case"INSERT_PIVOT":case"DUPLICATE_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound"}return"Success"}handle(e){switch(e.type){case"ADD_PIVOT":{const{pivotId:t,pivot:o}=e;this.addPivot(t,o);break}case"INSERT_PIVOT":{const{sheetId:t,col:o,row:s,pivotId:i,table:n}=e,r={sheetId:t,col:o,row:s},{cols:a,rows:l,measures:c,fieldsType:h}=n,d=new QO(a,l,c,h||{}),u=this.getPivotFormulaId(i);this.insertPivot(r,u,d);break}case"RENAME_PIVOT":this.history.update("pivots",e.pivotId,"definition","name",e.name);break;case"REMOVE_PIVOT":{const t={...this.pivots};delete t[e.pivotId];const o=this.getPivotFormulaId(e.pivotId);this.history.update("formulaIds",o,void 0),this.history.update("pivots",t);break}case"DUPLICATE_PIVOT":{const{pivotId:t,newPivotId:o}=e,s=Be(this.getPivotCore(t).definition);s.name=e.duplicatedPivotName??s.name+" (copy)",this.addPivot(o,s);break}case"UPDATE_PIVOT":this.history.update("pivots",e.pivotId,"definition",e.pivot),this.compileCalculatedMeasures(e.pivot.measures)}}adaptRanges(e){for(const t in this.compiledMeasureFormulas)for(const o in this.compiledMeasureFormulas[t]){const s=this.compiledMeasureFormulas[t][o],i=[];for(const t of s.dependencies){const o=e(t);"NONE"===o.changeType?i.push(t):i.push(o.range)}const n=this.getters.getFormulaString(t,s.tokens,i);n!==o&&this.replaceMeasureFormula(t,o,n)}}getPivotDisplayName(e){return`(#${this.getPivotFormulaId(e)}) ${this.getPivotName(e)}`}getPivotName(e){return this.getPivotCore(e).definition.name}getPivotCoreDefinition(e){return this.getPivotCore(e).definition}getPivotId(e){return this.formulaIds[e]}getPivotFormulaId(e){return this.getPivotCore(e).formulaId}getPivotIds(){return Object.keys(this.pivots)}isExistingPivot(e){return e in this.pivots}getMeasureCompiledFormula(e){if(!e.computedBy)throw new Error(`Measure ${e.fieldName} is not computed by formula`);const t=e.computedBy.sheetId;return this.compiledMeasureFormulas[t][e.computedBy.formula]}addPivot(e,t,o=this.nextFormulaId.toString()){this.history.update("pivots",e,{definition:t,formulaId:o}),this.compileCalculatedMeasures(t.measures),this.history.update("formulaIds",o,e),this.history.update("nextFormulaId",this.nextFormulaId+1)}compileCalculatedMeasures(e){for(const t of e)if(t.computedBy){const e=t.computedBy.sheetId,o=this.compileMeasureFormula(t.computedBy.sheetId,t.computedBy.formula);this.history.update("compiledMeasureFormulas",e,t.computedBy.formula,o)}}insertPivot(e,t,o){this.resizeSheet(e.sheetId,e,o);const s=o.getPivotCells();for(let o=0;o<s.length;o++)for(let i=0;i<s[o].length;i++){const n=s[o][i];this.dispatch("UPDATE_CELL",{sheetId:e.sheetId,col:e.col+o,row:e.row+i,content:Jl(t,n)})}}resizeSheet(e,{col:t,row:o},s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,quantity:a-c,position:"after"})}getPivotCore(e){const t=this.pivots[e];if(!t)throw new Error(`Pivot with id ${e} not found`);return t}compileMeasureFormula(e,t){const o=hS(t),s=o.dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t)));return{...o,dependencies:s}}replaceMeasureFormula(e,t,o){this.history.update("compiledMeasureFormulas",e,t,void 0),this.history.update("compiledMeasureFormulas",e,o,this.compileMeasureFormula(e,o));for(const s in this.pivots){const i=this.pivots[s];if(i)for(const n of i.definition.measures)if(n.computedBy?.formula===t){const t=i.definition.measures.indexOf(n);this.history.update("pivots",s,"definition","measures",t,"computedBy",{formula:o,sheetId:e})}}}checkDuplicatedMeasureIds(e){const t=new Set(e.measures.map((e=>e.id)));return e.measures.length!==t.size?"InvalidDefinition":"Success"}import(e){if(e.pivots)for(const[t,o]of Object.entries(e.pivots))this.addPivot(t,o,o.formulaId);this.history.update("nextFormulaId",e.pivotNextId||Gl(this.pivots)+1)}export(e){e.pivots={};for(const t in this.pivots)e.pivots[t]={...this.getPivotCoreDefinition(t),formulaId:this.getPivotFormulaId(t)};e.pivotNextId=this.nextFormulaId}}).add("spreadsheet_pivot_core",class extends zM{adaptRanges(e){for(const t of this.getters.getPivotIds()){const o=this.getters.getPivotCoreDefinition(t);if("SPREADSHEET"===o.type&&o.dataSet){const{sheetId:s,zone:i}=o.dataSet,n=XM(this.getters.getRangeFromZone(s,i),e),r=n&&{sheetId:n.sheetId,zone:n.zone};this.dispatch("UPDATE_PIVOT",{pivotId:t,pivot:{...o,dataSet:r}})}}}}).add("tableStyle",class extends zM{static getters=["getNewCustomTableStyleName","getTableStyle","getTableStyles","isTableStyleEditable"];styles={};allowDispatch(e){switch(e.type){case"CREATE_TABLE":case"UPDATE_TABLE":if(e.config?.styleId&&!this.styles[e.config.styleId])return"InvalidTableConfig";break;case"CREATE_TABLE_STYLE":if(!fw[e.templateName])return"InvalidTableStyle";try{Bt(e.primaryColor)}catch(e){return"InvalidTableStyle"}}return"Success"}handle(e){switch(e.type){case"CREATE_TABLE_STYLE":const t=vw(e.tableStyleName,e.templateName,e.primaryColor);this.history.update("styles",e.tableStyleId,t);break;case"REMOVE_TABLE_STYLE":const o={...this.styles};delete o[e.tableStyleId],this.history.update("styles",o);for(const t of this.getters.getSheetIds())for(const o of this.getters.getCoreTables(t))o.config.styleId===e.tableStyleId&&this.dispatch("UPDATE_TABLE",{sheetId:t,zone:o.range.zone,config:{styleId:QC.styleId}})}}getTableStyle(e){if(!this.styles[e])throw new Error(`Table style ${e} does not exist`);return this.styles[e]}getTableStyles(){return this.styles}getNewCustomTableStyleName(){return Nt(Fo("Custom Table Style"),Object.values(this.styles).map((e=>e.displayName)),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!mw[e]}import(e){for(const e in mw)this.styles[e]=mw[e];for(const t in e.customTableStyles){const o=e.customTableStyles[t];this.styles[t]=vw(o.displayName,o.templateName,o.primaryColor)}}export(e){const t={};for(const e in this.styles)mw[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}}),fN=(new n).add("ui_sheet",class extends HP{static getters=["doesCellHaveGridIcon","getCellWidth","getCellIconSrc","getTextWidth","getCellText","getCellMultiLineText","getContiguousZone"];ctx=document.createElement("canvas").getContext("2d");allowDispatch(e){return this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e)}handle(e){switch(e.type){case"AUTORESIZE_COLUMNS":for(let t of e.cols){const o=this.getColMaxWidth(e.sheetId,t);0!==o&&this.dispatch("RESIZE_COLUMNS_ROWS",{elements:[t],dimension:"COL",size:o,sheetId:e.sheetId})}break;case"AUTORESIZE_ROWS":this.dispatch("RESIZE_COLUMNS_ROWS",{elements:e.rows,dimension:"ROW",size:null,sheetId:e.sheetId})}}getCellWidth(e){const t=this.getters.getCellComputedStyle(e);let o=0;const s=this.getters.getEvaluatedCell(e).formattedValue;if(s){const e=oa(this.ctx,s,t,void 0);o+=Math.max(...e.map((e=>jr(this.ctx,e,t))))}if(this.getters.getCellIconSrc(e)&&(o+=function(e){return ea(e)+8}(t)),this.getters.doesCellHaveGridIcon(e)&&(o+=20),0===o)return 0;if(o+=2*re,"wrap"===t.wrapping){const t=this.getters.getColSize(this.getters.getActiveSheetId(),e.col);return Math.min(t,o)}return o}getCellIconSrc(e){const t=by.getAll();for(const o of t){const t=o(this.getters,e);if(t)return t}}getTextWidth(e,t){return jr(this.ctx,e,t)}getCellText(e,t){const o=this.getters.getCell(e),s=this.getters.getLocale();if(t?.showFormula&&o?.isFormula)return Pa(o.content,s);if(t?.showFormula&&!o?.content)return"";{const i=this.getters.getEvaluatedCell(e),n=t?.availableWidth?{availableWidth:t.availableWidth,measureText:e=>jr(this.ctx,e,o?.style||{})}:void 0;return Jn(i.value,{format:i.format,locale:s,formatWidth:n})}}getCellMultiLineText(e,t){const o=this.getters.getCellStyle(e),s=this.getters.getCellText(e,{showFormula:this.getters.shouldShowFormulas(),availableWidth:t.maxWidth});return oa(this.ctx,s,o,t.wrapText?t.maxWidth:void 0)}doesCellHaveGridIcon(e){const t=this.getters.isFilterHeader(e),o=!this.getters.isReadonly()&&this.getters.cellHasListDataValidationIcon(e);return t||o}getContiguousZone(e,t){const o=t=>{for(const o of Ze(t.left,t.right+1)){if(!this.isCellEmpty({sheetId:e,col:o,row:t.top-1}))return{...t,top:t.top-1};if(!this.isCellEmpty({sheetId:e,col:o,row:t.bottom+1}))return{...t,bottom:t.bottom+1}}for(const o of Ze(t.top,t.bottom+1)){if(!this.isCellEmpty({sheetId:e,col:t.left-1,row:o}))return{...t,left:t.left-1};if(!this.isCellEmpty({sheetId:e,col:t.right+1,row:o}))return{...t,right:t.right+1}}return t};let s=!1,i=t;do{s=!1;const e=o(i);ns(i,e)||(s=!0,i=e)}while(s);return i}isCellEmpty(e){const t=this.getters.getMainCellPosition(e);return this.getters.getEvaluatedCell(t).type===ni.empty}getColMaxWidth(e,t){const o=us(this.getters.getColsZone(e,t,t)).map((t=>this.getCellWidth({sheetId:e,...t})));return Math.max(0,Dt(o))}checkSheetExists(e){return"sheetId"in e&&void 0===this.getters.tryGetSheet(e.sheetId)?"InvalidSheetId":"Success"}checkZonesAreInSheet(e){const t="sheetId"in e?e.sheetId:this.getters.tryGetActiveSheetId(),o=this.getters.getCommandZones(e);return!t&&o.length>0?"NoActiveSheet":t&&o.length>0?this.getters.checkZonesExistInSheet(t,o):"Success"}}).add("ui_options",class extends HP{static getters=["shouldShowFormulas"];showFormulas=!1;handle(e){if("SET_FORMULA_VISIBILITY"===e.type)this.showFormulas=e.show}shouldShowFormulas(){return this.showFormulas}}).add("autofill",class extends HP{static layers=["Autofill"];static getters=["getAutofillTooltip"];autofillZone;steps;lastCellSelected={};direction;tooltip;allowDispatch(e){if("AUTOFILL_SELECT"===e.type){const t=this.getters.getActiveSheetId();return this.lastCellSelected.col=-1===e.col?this.lastCellSelected.col:qe(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=-1===e.row?this.lastCellSelected.row:qe(e.row,0,this.getters.getNumberRows(t)),void 0!==this.lastCellSelected.col&&void 0!==this.lastCellSelected.row?"Success":"InvalidAutofillSelection"}return"Success"}handle(e){switch(e.type){case"AUTOFILL":this.autofill(!0);break;case"AUTOFILL_SELECT":this.select(e.col,e.row);break;case"AUTOFILL_AUTO":this.autofillAuto();break;case"AUTOFILL_CELL":this.autoFillMerge(e.originCol,e.originRow,e.col,e.row);const t=this.getters.getActiveSheetId();this.dispatch("UPDATE_CELL",{sheetId:t,col:e.col,row:e.row,style:e.style||null,content:e.content||"",format:e.format||""}),this.dispatch("SET_BORDER",{sheetId:t,col:e.col,row:e.row,border:e.border}),this.autofillCF(e.originCol,e.originRow,e.col,e.row),this.autofillDV(e.originCol,e.originRow,e.col,e.row)}}getAutofillTooltip(){return this.tooltip}autofill(e){if(!this.autofillZone||!this.steps||void 0===this.direction)return void(this.tooltip=void 0);const t=this.getters.getSelectedZone(),o=this.autofillZone;switch(this.direction){case"down":for(let s=t.left;s<=t.right;s++){const i=[];for(let e=t.top;e<=t.bottom;e++)i.push(yo(s,e));const n=this.createGenerator(i);for(let t=o.top;t<=o.bottom;t++)this.computeNewCell(n,s,t,e)}break;case"up":for(let s=t.left;s<=t.right;s++){const i=[];for(let e=t.bottom;e>=t.top;e--)i.push(yo(s,e));const n=this.createGenerator(i);for(let t=o.bottom;t>=o.top;t--)this.computeNewCell(n,s,t,e)}break;case"left":for(let s=t.top;s<=t.bottom;s++){const i=[];for(let e=t.right;e>=t.left;e--)i.push(yo(e,s));const n=this.createGenerator(i);for(let t=o.right;t>=o.left;t--)this.computeNewCell(n,t,s,e)}break;case"right":for(let s=t.top;s<=t.bottom;s++){const i=[];for(let e=t.left;e<=t.right;e++)i.push(yo(e,s));const n=this.createGenerator(i);for(let t=o.left;t<=o.right;t++)this.computeNewCell(n,t,s,e)}}e&&(this.autofillZone=void 0,this.selection.resizeAnchorZone(this.direction,this.steps),this.lastCellSelected={},this.direction=void 0,this.steps=0,this.tooltip=void 0)}select(e,t){const o=this.getters.getSelectedZone();if(as(e,t,o))this.autofillZone=void 0;else{switch(this.direction=this.getDirection(e,t),this.direction){case"up":this.saveZone(t,o.top-1,o.left,o.right),this.steps=o.top-t;break;case"down":this.saveZone(o.bottom+1,t,o.left,o.right),this.steps=t-o.bottom;break;case"left":this.saveZone(o.top,o.bottom,e,o.left-1),this.steps=o.left-e;break;case"right":this.saveZone(o.top,o.bottom,o.right+1,e),this.steps=e-o.right}this.autofill(!1)}}autofillAuto(){const e=this.getters.getActivePosition(),t=this.getters.getTable(e);let o=t?t.range.zone.bottom:this.getAutofillAutoLastRow();const s=this.getters.getSelectedZone();for(let t=s.bottom+1;t<=o;t++)if(this.getters.getEvaluatedCell({...e,row:t}).type!==ni.empty){o=t-1;break}o>s.bottom&&(this.select(e.col,o),this.autofill(!0))}getAutofillAutoLastRow(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();let o=e.left,s=e.bottom;if(o>0){let e={sheetId:t,col:o-1,row:s};for(;this.getters.getEvaluatedCell(e).type!==ni.empty;)s+=1,e={sheetId:t,col:o-1,row:s}}if(s===e.bottom&&(o=e.right,o<=this.getters.getNumberCols(t))){let e={sheetId:t,col:o+1,row:s};for(;this.getters.getEvaluatedCell(e).type!==ni.empty;)s+=1,e={sheetId:t,col:o+1,row:s}}return s-1}computeNewCell(e,t,o,s){const{cellData:i,tooltip:n,origin:r}=e.next(),{content:a,style:l,border:c,format:h}=i;this.tooltip=n,s&&this.dispatch("AUTOFILL_CELL",{originCol:r.col,originRow:r.row,col:t,row:o,content:a,style:l,border:c,format:h})}getRule(e,t){const o=IS.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((o=>o.condition(e,t)));return o&&o.generateRule(e,t)}createGenerator(e){const t=[],o=[],s=this.getters.getActiveSheetId();for(let t of e){const{col:e,row:i}=So(t),n=this.getters.getCell({sheetId:s,col:e,row:i});o.push({col:e,row:i,cell:n,sheetId:s})}const i=o.map((e=>e.cell));for(let e of o){let o={type:"COPY_MODIFIER"};if(e&&e.cell){o=this.getRule(e.cell,i)||o}const s=this.getters.getCellBorder(e)||void 0;t.push({data:{...e,border:s},rule:o})}return new UP(t,this.getters,this.direction)}saveZone(e,t,o,s){this.autofillZone={top:e,bottom:t,left:o,right:s}}getDirection(e,t){const o=this.getters.getSelectedZone(),s={up:{number:o.top-t,value:"up"},down:{number:t-o.bottom,value:"down"},left:{number:o.left-e,value:"left"},right:{number:e-o.right,value:"right"}};if(1===Object.values(s).map((e=>e.number>0?1:0)).reduce(((e,t)=>e+t)))return Object.values(s).find((e=>e.number>0?1:0)).value;const i=s.up.number>0?"up":"down",n=s.left.number>0?"left":"right";return Math.abs(s[i].number)>=Math.abs(s[n].number)?s[i].value:s[n].value}autoFillMerge(e,t,o,s){const i=this.getters.getActiveSheetId(),n={sheetId:i,col:o,row:s},r={sheetId:i,col:e,row:t};if(this.getters.isInMerge(n)&&!this.getters.isInMerge(r)){const e=this.getters.getMerge(n);e&&this.dispatch("REMOVE_MERGE",{sheetId:i,target:[e]})}const a=this.getters.getMerge(r);a?.left===e&&a?.top===t&&this.dispatch("ADD_MERGE",{sheetId:i,target:[{top:s,bottom:s+a.bottom-a.top,left:o,right:o+a.right-a.left}]})}autofillCF(e,t,o,s){const i=this.getters.getActiveSheetId(),n=this.getters.getRulesByCell(i,e,t);for(const e of n){const t=this.getters.getAdaptedCfRanges(i,e,[fs({col:o,row:s})],[]);t&&this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:Be(e),ranges:t,sheetId:i})}}autofillDV(e,t,o,s){const i=this.getters.getActiveSheetId(),n={sheetId:i,col:e,row:t},r=this.getters.getValidationRuleForCell(n);if(!r)return;const a=r.ranges.map((e=>e.zone)),l=Co(a.concat(fs({col:o,row:s})),[]);this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:r,ranges:l.map((e=>this.getters.getRangeDataFromZone(i,e))),sheetId:i})}drawLayer(e){if(!this.autofillZone)return;const{ctx:t,thinLineWidth:o}=e,{x:s,y:i,width:n,height:r}=this.getters.getVisibleRect(this.autofillZone);n>0&&r>0&&(t.strokeStyle="black",t.lineWidth=o,t.setLineDash([3]),t.strokeRect(s,i,n,r),t.setLineDash([]))}}).add("sort",class extends HP{allowDispatch(e){return"SORT_CELLS"===e.type?as(e.col,e.row,e.zone)?this.checkValidations(e,this.checkMerge,this.checkMergeSizes,this.checkArrayFormulaInSortZone):"InvalidSortAnchor":"Success"}handle(e){if("SORT_CELLS"===e.type)this.sortZone(e.sheetId,e,e.zone,e.sortDirection,e.sortOptions||{})}checkMerge({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";return us(t).some((({col:t,row:o})=>!this.getters.isInMerge({sheetId:e,col:t,row:o})))?"InvalidSortZone":"Success"}checkMergeSizes({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return"Success";const o=this.getters.getMerges(e).filter((e=>rs(e,t))),s=cs(o[0]);let[i,n]=[s.numberOfCols,s.numberOfRows];return o.every((e=>{let[t,o]=[e.right-e.left+1,e.bottom-e.top+1];return t===i&&o===n}))?"Success":"InvalidSortZone"}checkArrayFormulaInSortZone({sheetId:e,zone:t}){return us(t).some((({col:t,row:o})=>this.getters.getArrayFormulaSpreadingOn({sheetId:e,col:t,row:o})))?"SortZoneWithArrayFormulas":"Success"}hasHeader(e,t){if(1===t[0].length)return!1;let o=t.map((t=>t.map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).type))));return o[0][0]===ni.empty&&(o=o.slice(1)),!o.some((e=>e[0]===ni.empty))&&!!o.some((e=>e[1]!==ni.empty&&e[0]!==e[1]))}sortZone(e,t,o,s,i){const[n,r]=this.mainCellsSteps(e,o);let a=this.getters.getMainCellPosition({sheetId:e,col:t.col,row:t.row}).col,l=Object.assign({},o),c=this.mainCells(e,o);!i.sortHeaders&&this.hasHeader(e,c)&&(l.top+=r),c=this.mainCells(e,l);const h=function(e,t,o){const s=e.map(((e,t)=>({index:t,type:e.type,value:e.value})));return(o?s.map((e=>e.type===ni.empty?{...e,type:ni.number,value:0}:e)):s).sort(Tp(t))}(c[a-l.left].map((e=>this.getters.getEvaluatedCell(e))),s,Boolean(i.emptyCellAsZero)),d=h.map((e=>e.index)),[u,g]=[c.length,c[0].length],p=[];for(let e=0;e<u;e++)for(let t=0;t<g;t++){let{col:o,row:s,sheetId:i}=c[e][d[t]];const a=this.getters.getCell({sheetId:i,col:o,row:s});let h=l.left+e*n,u=l.top+t*r,g={sheetId:i,col:h,row:u,content:""};if(a){let e=a.content;if(a.isFormula){const t=this.getters.getCellPosition(a.id);e=this.getters.getTranslatedCellFormula(i,0,u-t.row,a.compiledFormula.tokens)}g.style=a.style,g.content=e,g.format=a.format}p.push(g)}p.forEach((e=>this.dispatch("UPDATE_CELL",e)))}mainCellsSteps(e,t){const o=this.getters.getMerge({sheetId:e,col:t.left,row:t.top});return[o?o.right-o.left+1:1,o?o.bottom-o.top+1:1]}mainCells(e,t){const[o,s]=this.mainCellsSteps(e,t),i=[],n=Ze(t.left,t.right+1,o),r=Ze(t.top,t.bottom+1,s);for(const t of n){const o=[];i.push(o);for(const s of r)o.push({sheetId:e,col:t,row:s})}return i}}).add("automatic_sum",class extends HP{static getters=["getAutomaticSums"];handle(e){if("SUM_SELECTION"===e.type){const e=this.getters.getActiveSheetId(),{zones:t,anchor:o}=this.getters.getSelection();for(const s of t){const t=this.getAutomaticSums(e,s,o.cell);this.dispatchCellUpdates(e,t)}}}getAutomaticSums(e,t,o){return this.shouldFindData(e,t)?this.sumAdjacentData(e,t,o):this.sumData(e,t)}sumData(e,t){const o=this.dimensionsToSum(e,t),s=this.sumDimensions(e,t,o).filter((({zone:t})=>!this.getters.isEmpty(e,t)));return o.has("ROW")&&o.has("COL")&&s.push(this.sumTotal(t)),s}sumAdjacentData(e,t,o){const{col:s,row:i}=as(o.col,o.row,t)?o:{col:t.left,row:t.top},n=this.findAdjacentData(e,s,i);return n?this.getters.isSingleCellOrMerge(e,t)||hs(ss(n,t))?[{position:{col:s,row:i},zone:n}]:this.sumDimensions(e,ss(n,t),this.transpose(this.dimensionsToSum(e,t))):[]}findAdjacentData(e,t,o){const s=this.getters.getSheet(e),i=this.getters.getMainCellPosition({sheetId:e,col:t,row:o}),n=this.findSuitableZoneToSum(s,i.col,i.row);if(n)return this.getters.expandZone(e,n)}findSuitableZoneToSum(e,t,o){const s=this.getters.getEvaluatedCell({sheetId:e.id,col:t,row:o-1}),i=this.getters.getEvaluatedCell({sheetId:e.id,col:t-1,row:o});if(this.isNumber(i)&&!this.isNumber(s))return this.findHorizontalZone(e,t,o);const n=this.findVerticalZone(e,t,o);if(this.isZoneValid(n))return n;const r=this.findHorizontalZone(e,t,o);return this.isZoneValid(r)?r:void 0}findVerticalZone(e,t,o){const s={top:0,bottom:o-1,left:t,right:t},i=this.reduceZoneStart(e,s,s.bottom);return{...s,top:i}}findHorizontalZone(e,t,o){const s={top:o,bottom:o,left:0,right:t-1},i=this.reduceZoneStart(e,s,s.right);return{...s,left:i}}reduceZoneStart(e,t,o){const s=this.getters.getEvaluatedCellsInZone(e.id,t),i=Ze(o,-1,-1),n=Dt(i.filter((e=>s[e]&&!s[e].isAutoSummable))),r=je(i.filter((e=>this.isNumber(s[e]))))[0]||[];return Dt(r)<n?1/0:Ot(r)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===ni.number&&!(e.format&&rr(e.format))}isZoneValid(e){return e.bottom>=e.top&&e.right>=e.left}lastColIsEmpty(e,t){return this.getters.isEmpty(e,{...t,left:t.right})}lastRowIsEmpty(e,t){return this.getters.isEmpty(e,{...t,top:t.bottom})}dimensionsToSum(e,t){const o=new Set;return hs(t)?(o.add(1===cs(t).numberOfCols?"COL":"ROW"),o):(this.lastColIsEmpty(e,t)&&o.add("ROW"),this.lastRowIsEmpty(e,t)&&o.add("COL"),0===o.size&&o.add("COL"),o)}sumDimensions(e,t,o){return[...o.has("COL")?this.sumColumns(t,e):[],...o.has("ROW")?this.sumRows(t,e):[]]}sumTotal(e){const{bottom:t,right:o}=e;return{position:{col:o,row:t},zone:{...e,top:t,right:o-1}}}sumColumns(e,t){const o=this.nextEmptyRow(t,{...e,bottom:e.bottom-1});return e={...e,bottom:Math.min(e.bottom,o.bottom-1)},us(o).map((t=>({position:t,zone:{...e,right:t.col,left:t.col}})))}sumRows(e,t){const o=this.nextEmptyCol(t,{...e,right:e.right-1});return e={...e,right:Math.min(e.right,o.right-1)},us(o).map((t=>({position:t,zone:{...e,top:t.row,bottom:t.row}})))}dispatchCellUpdates(e,t){for(const o of t){const{col:t,row:s}=o.position;this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:s,content:`=SUM(${this.getters.zoneToXC(e,o.zone)})`})}}nextEmptyRow(e,t){let o=t.bottom+1;const{left:s,right:i}=t;for(;!this.getters.isEmpty(e,{bottom:o,top:o,left:s,right:i});)o++;return{...t,top:o,bottom:o}}nextEmptyCol(e,t){let o=t.right+1;const{top:s,bottom:i}=t;for(;!this.getters.isEmpty(e,{left:o,right:o,top:s,bottom:i});)o++;return{...t,left:o,right:o}}transpose(e){return new Set([...e.values()].map((e=>"COL"===e?"ROW":"COL")))}}).add("format",class extends HP{handle(e){switch(e.type){case"SET_DECIMAL":this.setDecimal(e.sheetId,e.target,e.step);break;case"SET_FORMATTING_WITH_PIVOT":this.setContextualFormat(e.sheetId,e.target,e.format)}}setContextualFormat(e,t,o){const s=[],i={};for(const o of Co(t))for(let t=o.left;t<=o.right;t++)for(let n=o.top;n<=o.bottom;n++){const o={sheetId:e,col:t,row:n},r=this.getters.getPivotCellFromPosition(o);if(this.isSpilledPivotValueFormula(o,r)){s.push(o);const e=this.getters.getPivotIdFromPosition(o)||"";i[e]??=new Set,i[e].add(r.measure)}}const n=Co(s.map(fs));for(const e in i){const t=i[e],s=this.getters.getPivotCoreDefinition(e);this.dispatch("UPDATE_PIVOT",{pivotId:e,pivot:{...s,measures:s.measures.map((e=>t.has(e.id)?{...e,format:o}:e))}})}this.dispatch("SET_FORMATTING",{sheetId:e,target:n,format:""}),this.dispatch("SET_FORMATTING",{sheetId:e,target:Co(t,n),format:o})}isSpilledPivotValueFormula(e,t){const o=this.getters.getCell(e);return"VALUE"===t.type&&!o?.isFormula}setDecimal(e,t,o){const s={};for(const i of Co(t))for(const t of us(i)){const i=this.getCellNumberFormat({sheetId:e,...t});if(void 0!==i){const e=Cr(i,o);s[e]=s[e]||[],s[e].push(t)}}for(const t in s){const o=Co(s[t].map((e=>fs(e))));this.setContextualFormat(e,o,t)}}getCellNumberFormat(e){for(const t of[e]){const e=this.getters.getEvaluatedCell(t);if(!(e.type!==ni.number||e.format&&rr(e.format)))return e.format||cr(e.value)}}}).add("insert_pivot",class extends HP{static getters=[];allowDispatch(e){if("DUPLICATE_PIVOT_IN_NEW_SHEET"===e.type){if(!this.getters.isExistingPivot(e.pivotId))return"PivotIdNotFound";if(!this.getters.getPivot(e.pivotId).isValid())return"PivotInError"}return"Success"}handle(e){switch(e.type){case"INSERT_NEW_PIVOT":this.insertNewPivot(e.pivotId,e.newSheetId);break;case"DUPLICATE_PIVOT_IN_NEW_SHEET":this.duplicatePivotInNewSheet(e.pivotId,e.newPivotId,e.newSheetId);break;case"INSERT_PIVOT_WITH_TABLE":this.insertPivotWithTable(e.sheetId,e.col,e.row,e.pivotId,e.table,e.pivotMode);break;case"SPLIT_PIVOT_FORMULA":this.splitPivotFormula(e.sheetId,e.col,e.row,e.pivotId)}}insertNewPivot(e,t){1===Ss(this.getters.getSelectedZone())&&this.selection.selectTableAroundSelection();const o=this.getters.getActiveSheetId();this.dispatch("ADD_PIVOT",{pivotId:e,pivot:{dataSet:{zone:this.getters.getSelectedZone(),sheetId:o},columns:[],rows:[],measures:[],name:Fo("New pivot"),type:"SPREADSHEET"}});const s=this.getters.getSheetIds().findIndex((e=>e===o))+1,i=this.getters.getPivotFormulaId(e);this.dispatch("CREATE_SHEET",{sheetId:t,name:Fo("Pivot #%(formulaId)s",{formulaId:i}),position:s}),this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:o,sheetIdTo:t});const n=this.getters.getPivot(e);this.insertPivotWithTable(t,0,0,e,n.getTableStructure().export(),"dynamic")}duplicatePivotInNewSheet(e,t,o){this.dispatch("DUPLICATE_PIVOT",{pivotId:e,newPivotId:t,duplicatedPivotName:Fo("%s (copy)",this.getters.getPivotCoreDefinition(e).name)});const s=this.getters.getActiveSheetId(),i=this.getters.getSheetIds().indexOf(s)+1,n=this.getters.getPivotFormulaId(t),r=this.getters.getPivotName(t);if(this.dispatch("CREATE_SHEET",{sheetId:o,name:this.getPivotDuplicateSheetName(Fo("%(newPivotName)s (Pivot #%(formulaId)s)",{newPivotName:r,formulaId:n})),position:i}).isSuccessful){this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:s,sheetIdTo:o});const i=this.getters.getPivot(e);this.insertPivotWithTable(o,0,0,t,i.getTableStructure().export(),"dynamic")}}getPivotDuplicateSheetName(e){const t=this.getters.getSheetIds().map((e=>this.getters.getSheetName(e)));return Nt(Ge(e),t)}insertPivotWithTable(e,t,o,s,i,n){const{cols:r,rows:a,measures:l,fieldsType:c}=i,h=new QO(r,a,l,c||{}),d=h.columns.length-1;this.resizeSheet(e,t,o,h);const u=this.getters.getPivotFormulaId(s);let g;"dynamic"===n?(this.dispatch("UPDATE_CELL",{sheetId:e,col:t,row:o,content:`=PIVOT(${u})`}),g={left:t,right:t,top:o,bottom:o}):(this.dispatch("INSERT_PIVOT",{sheetId:e,col:t,row:o,pivotId:s,table:h.export()}),g={left:t,right:t+h.getNumberOfDataColumns(),top:o,bottom:o+d+h.rows.length}),this.dispatch("CREATE_TABLE",{tableType:n,sheetId:e,ranges:[this.getters.getRangeDataFromZone(e,g)],config:{...ke,numberOfHeaders:d}})}resizeSheet(e,t,o,s){const i=s.getNumberOfDataColumns()+1,n=this.getters.getNumberCols(e),r=n-t;r<i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:n-1,sheetId:e,quantity:i-r,position:"after"});const a=s.columns.length+s.rows.length,l=this.getters.getNumberRows(e),c=l-o;c<a&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:l-1,sheetId:e,quantity:a-c,position:"after"})}splitPivotFormula(e,t,o,s){const i=this.getters.getSpreadZone({sheetId:e,col:t,row:o});if(!i)return;const n=this.getters.getPivotFormulaId(s),r=new Map;for(let t=i.left;t<=i.right;t++)for(let o=i.top;o<=i.bottom;o++){const s={sheetId:e,col:t,row:o};r.set(s,this.getters.getPivotCellFromPosition(s))}for(const[e,t]of r)this.dispatch("UPDATE_CELL",{...e,content:Jl(n,t)});const a=this.getters.getCoreTable({sheetId:e,col:t,row:o});if("dynamic"===a?.type){const s=fs({col:t,row:o}),n=this.getters.getRangeDataFromZone(e,i);this.dispatch("UPDATE_TABLE",{sheetId:e,zone:s,newTableRange:n,tableType:"static"})}}}).add("split_to_columns",class extends HP{static getters=["getAutomaticSeparator"];allowDispatch(e){return"SPLIT_TEXT_INTO_COLUMNS"===e.type?this.chainValidations(this.batchValidations(this.checkSingleColSelected,this.checkNonEmptySelector),this.batchValidations(this.checkNotOverwritingContent,this.checkSeparatorInSelection))(e):"Success"}handle(e){if("SPLIT_TEXT_INTO_COLUMNS"===e.type)this.splitIntoColumns(e)}getAutomaticSeparator(){const e=this.getters.getSelectedCells();for(const t of e)if(t.value&&t.type===ni.text){const e=this.getAutoSeparatorForString(t.value);if(e)return e}return" "}getAutoSeparatorForString(e){const t=[Pe,";",","," ","."];for(const o of t)if(e.includes(o))return o}splitIntoColumns({separator:e,addNewColumns:t}){const o=this.getters.getSelectedZone(),s=this.getters.getActiveSheetId(),i=this.getSplittedCols(o,e);t&&this.addColsToAvoidCollisions(o,i),this.removeMergesInSplitZone(o,i),this.addColumnsToNotOverflowSheet(o,i);for(let e=0;e<i.length;e++){const t=o.top+e,n=i[e],r=o.left,a=this.getters.getCell({sheetId:s,col:r,row:t});if(1!==n.length||n[0]!==a?.content)for(const[e,o]of n.entries())this.dispatch("UPDATE_CELL",{sheetId:s,col:r+e,row:t,content:Da(o,this.getters.getLocale()),format:"",style:a?.style||null})}}getSplittedCols(e,t){if(!t)throw new Error("Separator cannot be empty");const o=this.getters.getActiveSheetId(),s=[];for(const i of Ze(e.top,e.bottom+1)){const n=this.getters.getEvaluatedCell({sheetId:o,col:e.left,row:i}).formattedValue;s.push(this.splitAndRemoveTrailingEmpty(n,t))}return s}splitAndRemoveTrailingEmpty(e,t){const o=e.split(t);for(;o.length>1&&""===o[o.length-1];)o.pop();return o}willSplittedColsOverwriteContent(e,t){const o=this.getters.getActiveSheetId();for(const s of Ze(e.top,e.bottom+1)){const i=t[s-e.top];for(let t=1;t<i.length;t++){const i=this.getters.getCell({sheetId:o,col:e.left+t,row:s});if(i&&i.content)return!0}}return!1}removeMergesInSplitZone(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length))),i={...e,right:e.left+s-1},n=this.getters.getMergesInZone(o,i);this.dispatch("REMOVE_MERGE",{sheetId:o,target:n})}addColsToAvoidCollisions(e,t){const o=this.getters.getActiveSheetId();let s=0;for(const i of Ze(e.top,e.bottom+1)){const n={sheetId:o,col:e.left,row:i},r=t[i-e.top],a=this.getColsToAddToAvoidCollision(n,r);s=Math.max(s,a)}s&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:e.left,sheetId:o,quantity:s,position:"after"})}getColsToAddToAvoidCollision(e,t){const o=t.length;for(let t=1;t<o;t++){const s=e.col+t,i=this.getters.getCell({...e,col:s});if(i&&i.content)return o-t}return 0}addColumnsToNotOverflowSheet(e,t){const o=this.getters.getActiveSheetId(),s=Math.max(...t.map((e=>e.length-1))),i=this.getters.getNumberCols(o)-1;e.left+s>i&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:i,sheetId:o,quantity:e.left+s-i,position:"after"})}checkSingleColSelected(){return this.getters.isSingleColSelected()?"Success":"MoreThanOneColumnSelected"}checkNonEmptySelector(e){return""===e.separator?"EmptySplitSeparator":"Success"}checkNotOverwritingContent(e){if(e.addNewColumns||e.force)return"Success";const t=this.getters.getSelectedZones()[0],o=this.getSplittedCols(t,e.separator);return this.willSplittedColsOverwriteContent(t,o)?"SplitWillOverwriteContent":"Success"}checkSeparatorInSelection({separator:e}){const t=this.getters.getSelectedCells();for(const o of t)if(o.formattedValue.includes(e))return"Success";return"NoSplitSeparatorInSelection"}}).add("collaborative",class extends HP{static getters=["getClientsToDisplay","getClient","getConnectedClients","isFullySynchronized"];static layers=["Selection"];availableColors=new uo(12);colors={};session;constructor(e){super(e),this.session=e.session}isPositionValid(e){return e.row<this.getters.getNumberRows(e.sheetId)&&e.col<this.getters.getNumberCols(e.sheetId)}getClient(){return this.session.getClient()}getConnectedClients(){return this.session.getConnectedClients()}isFullySynchronized(){return this.session.isFullySynchronized()}getClientsToDisplay(){try{this.getters.getClient()}catch(e){if(e instanceof JP)return[];throw e}const e=this.getters.getActiveSheetId(),t=[];for(const o of this.getters.getConnectedClients())if(o.id!==this.getters.getClient().id&&o.position&&o.position.sheetId===e&&this.isPositionValid(o.position)){const e=o.position;this.colors[o.id]||(this.colors[o.id]=this.availableColors.next());const s=this.colors[o.id];t.push({...o,position:e,color:s})}return t}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getters.getActiveSheetId();for(const e of this.getClientsToDisplay()){const{row:i,col:n}=e.position,r=this.getters.expandZone(s,{top:i,bottom:i,left:n,right:n}),{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);if(c<=0||h<=0)continue;const d=e.color;t.fillStyle=`${d}10`,t.lineWidth=4*o,t.strokeStyle=d,t.globalCompositeOperation="multiply",t.fillRect(a,l,c,h),t.globalCompositeOperation="source-over",t.strokeRect(a,l,c,h),t.font=`bold ${me+1}px ${fe}`}}}).add("history",class extends HP{static getters=["canUndo","canRedo"];undoStack=[];redoStack=[];session;constructor(e){super(e),this.session=e.session,this.session.on("new-local-state-update",this,this.onNewLocalStateUpdate),this.session.on("pending-revisions-dropped",this,(({revisionIds:e})=>this.drop(e))),this.session.on("snapshot",this,(()=>{this.undoStack=[],this.redoStack=[]}))}allowDispatch(e){switch(e.type){case"REQUEST_UNDO":if(!this.canUndo())return"EmptyUndoStack";break;case"REQUEST_REDO":if(!this.canRedo())return"EmptyRedoStack"}return"Success"}handle(e){switch(e.type){case"REQUEST_UNDO":case"REQUEST_REDO":this.requestHistoryChange("REQUEST_UNDO"===e.type?"UNDO":"REDO")}}finalize(){}requestHistoryChange(e){const t="UNDO"===e?this.undoStack.pop():this.redoStack.pop();if(t)"UNDO"===e?(this.session.undo(t),this.redoStack.push(t)):(this.session.redo(t),this.undoStack.push(t));else{const e=this.getPossibleRevisionToRepeat();if(!e)return;const t=gN(e,this.getters);if(!t)return;if(!Array.isArray(t))return void this.dispatch(t.type,t);for(const e of t)this.dispatch(e.type,e)}}canUndo(){return this.undoStack.length>0}canRedo(){if(this.redoStack.length>0)return!0;const e=this.getPossibleRevisionToRepeat();return!(!(t=e)||!t.rootCommand||"object"!=typeof t.rootCommand)&&(pi(t.rootCommand)?hN.contains(t.rootCommand.type):dN.contains(t.rootCommand.type));var t}drop(e){this.undoStack=this.undoStack.filter((t=>!e.includes(t))),this.redoStack=[]}onNewLocalStateUpdate({id:e}){this.undoStack.push(e),this.redoStack=[],this.undoStack.length>99&&this.undoStack.shift()}getPossibleRevisionToRepeat(){return this.session.getLastLocalNonEmptyRevision()}}).add("data_cleanup",class extends HP{allowDispatch(e){return"REMOVE_DUPLICATES"===e.type?this.checkValidations(e,this.chainValidations(this.checkSingleRangeSelected,this.checkNoMergeInZone,this.checkRangeContainsValues,this.checkColumnsIncludedInZone),this.chainValidations(this.checkNoColumnProvided,this.checkColumnsAreUnique)):"Success"}handle(e){switch(e.type){case"REMOVE_DUPLICATES":this.removeDuplicates(e.columns,e.hasHeader);break;case"TRIM_WHITESPACE":this.trimWhitespace()}}removeDuplicates(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.getSelectedZone();t&&(s.top+=1);const i=this.getUniqueRowsIndexes(o,s.top,s.bottom,e),n=i.length;if(n===cs(s).numberOfRows)return void this.notifyRowsRemovedAndRemaining(0,n);const r=i.map((e=>({left:s.left,top:e,right:s.right,bottom:e}))),a=new lc(this.getters,this.dispatch),l=a.copy(la(o,r));if(!l)return;this.dispatch("CLEAR_CELLS",{target:[s],sheetId:o});const c={left:s.left,top:s.top,right:s.left,bottom:s.top};a.paste({zones:[c],sheetId:o},l,{isCutOperation:!1});const h={left:s.left,top:s.top-(t?1:0),right:s.right,bottom:s.top+n-1};this.selection.selectZone({cell:{col:h.left,row:h.top},zone:h});const d=s.bottom-s.top+1-n;this.notifyRowsRemovedAndRemaining(d,n)}getUniqueRowsIndexes(e,t,o,s){const i=new Map;for(const n of Ze(t,o+1)){const t=s.map((t=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}).value));!Object.values(i).some((e=>mt(e,t)))&&(i[n]=t)}return Object.keys(i).map((e=>parseInt(e)))}notifyRowsRemovedAndRemaining(e,t){this.ui.notifyUI({type:"info",text:Fo("%s duplicate rows found and removed.\n%s unique rows remain.",e.toString(),t.toString()),sticky:!1})}checkSingleRangeSelected(){return 1!==this.getters.getSelectedZones().length?"MoreThanOneRangeSelected":"Success"}checkNoMergeInZone(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZone();return this.getters.getMergesInZone(e,t).length>0?"WillRemoveExistingMerge":"Success"}checkRangeContainsValues(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedZone();e.hasHeader&&(o.top+=1);return this.getters.getEvaluatedCellsInZone(t,o).every((e=>"empty"===e.type))?"EmptyTarget":"Success"}checkNoColumnProvided(e){return 0===e.columns.length?"NoColumnsProvided":"Success"}checkColumnsIncludedInZone(e){const t=this.getters.getSelectedZone();return e.columns.some((e=>e<t.left||e>t.right))?"ColumnsNotIncludedInZone":"Success"}checkColumnsAreUnique(e){return e.columns.length!==new Set(e.columns).size?"DuplicatesColumnsSelected":"Success"}trimWhitespace(){const e=Co(this.getters.getSelectedZones()),t=this.getters.getActiveSheetId();let o=0;for(const{col:s,row:i}of e.map(us).flat()){const e=this.getters.getCell({col:s,row:i,sheetId:t});if(!e)continue;const n=Tt(e.content);n!==e.content&&(o+=1,this.dispatch("UPDATE_CELL",{sheetId:t,col:s,row:i,content:n}))}const s=o?Fo("Trimmed whitespace from %s cells.",o):Fo("No selected cells had whitespace trimmed.");this.ui.notifyUI({type:"info",text:s,sticky:!1})}}).add("table_autofill",class extends HP{handle(e){if("AUTOFILL_TABLE_COLUMN"===e.type){const t=this.getters.getCoreTable(e),o=this.getters.getCell(e);if(!t?.config.automaticAutofill||"dynamic"===t.type||!o?.isFormula)return;const{col:s,row:i}=e,n=function(e,t){const o=t.numberOfHeaders,s={...e,top:e.top+o};return s.top<=s.bottom?s:void 0}(t.range.zone,t.config);if(n&&as(s,i,n)){const t=e.autofillRowStart??n.top,o=e.autofillRowEnd??n.bottom,s={...n,top:t,bottom:o};this.autofillTableZone(e,s)}}}autofillTableZone(e,t){if(t.top===t.bottom)return;const{col:o,row:s,sheetId:i}=e;for(let e=t.top;e<=t.bottom;e++)if(e!==s&&this.getters.getEvaluatedCell({col:o,row:e,sheetId:i}).type!==ni.empty)return;const n={zone:this.getters.getSelectedZone(),cell:this.getters.getActivePosition()};this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.bottom}),this.dispatch("AUTOFILL"),this.selection.selectCell(o,s),this.dispatch("AUTOFILL_SELECT",{col:o,row:t.top}),this.dispatch("AUTOFILL"),this.selection.selectZone(n)}}).add("table_ui_resize",class extends HP{allowDispatch(e){if("RESIZE_TABLE"===e.type){const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return"TableNotFound";const o=t.range.zone,s=this.getters.getRangeFromRangeData(e.newTableRange).zone;return s.top!==o.top||s.left!==o.left?"InvalidTableResize":this.canDispatch("UPDATE_TABLE",{...e}).reasons}return"Success"}handle(e){switch(e.type){case"RESIZE_TABLE":{const t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(this.dispatch("UPDATE_TABLE",{...e}),!t)return;const o=this.getters.getRangeFromRangeData(e.newTableRange).zone;if(this.selection.selectCell(o.right,o.bottom),!t.config.automaticAutofill)return;const s=t.range.zone;if(o.bottom>=s.bottom){for(let t=o.left;t<=o.right;t++){const i={col:t,row:s.bottom,sheetId:e.sheetId};this.getters.getCell(i)?.content.startsWith("=")&&this.dispatch("AUTOFILL_TABLE_COLUMN",{...i,autofillRowStart:s.bottom,autofillRowEnd:o.bottom})}break}}}}}).add("datavalidation_insert",class extends HP{handle(e){if("ADD_DATA_VALIDATION_RULE"===e.type)if("isBoolean"===e.rule.criterion.type){const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e)));for(const e of Ur(t)){const t=this.getters.getCell(e),o=this.getters.getEvaluatedCell(e);if(t?.content)if(t?.content&&o.type===ni.empty){let o;if(t.content.startsWith("=")){const s=this.getters.evaluateFormula(e.sheetId,t.content);o=(Ci(s)?s[0][0]:s)?.toString()}else o=t.content;o&&Xe(o)||this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}else o.type!==ni.boolean&&this.dispatch("UPDATE_CELL",{...e,content:"FALSE"});else this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}}}}).add("geo_features",class extends HP{static getters=["getGeoJsonFeatures","geoFeatureNameToId","getGeoChartAvailableRegions"];geoJsonService;geoJsonCache={};constructor(e){super(e),this.geoJsonService=e.external.geoJsonService}getGeoChartAvailableRegions(){return this.geoJsonService?this.geoJsonService.getAvailableRegions()||[]:(console.error("No geoJsonService provided to the model"),[])}getGeoJsonFeatures(e){if(!this.geoJsonService)return void console.error("No geoJsonService provided to the model");const t=this.geoJsonCache[e];return t instanceof Promise?void 0:void 0!==t?t??void 0:void(this.geoJsonCache[e]=new Promise((async t=>{const o=await(this.geoJsonService?.getTopoJson(e));this.geoJsonCache[e]=this.convertToGeoJson(o),this.dispatch("EVALUATE_CHARTS"),t()})))}geoFeatureNameToId(e,t){if(this.geoJsonService)return this.geoJsonService.geoFeatureNameToId(e,t);console.error("No geoJsonService provided to the model")}convertToGeoJson(e){if(!e)return null;if("Topology"===e.type){const t=window.ChartGeo.topojson.feature(e,Object.values(e.objects)[0]);return"FeatureCollection"===t.type?t.features:[t]}if("FeatureCollection"===e.type)return e.features;throw new Error("Invalid TopoJSON")}}),vN=(new n).add("selection",class extends HP{static layers=["Selection"];static getters=["getActiveSheet","getActiveSheetId","getActiveCell","getActiveCols","getActiveRows","getCurrentStyle","getSelectedZones","getSelectedZone","getSelectedCells","getSelectedFigureId","getSelection","getActivePosition","getSheetPosition","isSingleColSelected","getElementsFromSelection","tryGetActiveSheetId","isGridSelectionActive"];gridSelection={anchor:{cell:{col:0,row:0},zone:{top:0,left:0,bottom:0,right:0}},zones:[{top:0,left:0,bottom:0,right:0}]};selectedFigureId=null;sheetsData={};moveClient;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient}allowDispatch(e){switch(e.type){case"ACTIVATE_SHEET":try{if(!this.getters.getSheet(e.sheetIdTo).isVisible)return"SheetIsHidden";break}catch(e){return"InvalidSheetId"}case"MOVE_COLUMNS_ROWS":return this.isMoveElementAllowed(e)}return"Success"}handleEvent(e){const t=e.anchor;let o=[];switch(e.mode){case"overrideSelection":o=[t.zone];break;case"updateAnchor":o=[...this.gridSelection.zones];const s=o.findIndex((t=>ns(t,e.previousAnchor.zone)));s>=0&&(o[s]=t.zone);break;case"newAnchor":o=[...this.gridSelection.zones,t.zone]}this.setSelectionMixin(e.anchor,o),this.selection.resetDefaultAnchor(this,Be(this.gridSelection.anchor));const{col:s,row:i}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:s,row:i}),this.selectedFigureId=null}handle(e){switch(e.type){case"ACTIVATE_SHEET":this.selectedFigureId=null;break;case"DELETE_FIGURE":this.selectedFigureId===e.id&&(this.selectedFigureId=null);break;case"DELETE_SHEET":this.selectedFigureId&&this.getters.getFigure(e.sheetId,this.selectedFigureId)&&(this.selectedFigureId=null)}switch(e.type){case"START":const t=this.getters.getVisibleSheetIds()[0];this.activateSheet(t,t);const{col:o,row:s}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(o,s),this.selection.registerAsDefault(this,this.gridSelection.anchor,{handleEvent:this.handleEvent.bind(this)}),this.moveClient({sheetId:t,col:0,row:0});break;case"ACTIVATE_SHEET":this.activateSheet(e.sheetIdFrom,e.sheetIdTo);break;case"REMOVE_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){"COL"===e.dimension?this.onColumnsRemoved(e):this.onRowsRemoved(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"ADD_COLUMNS_ROWS":{const t=this.getters.getActiveSheetId();if(e.sheetId===t){this.onAddElements(e);const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:o,row:s})}break}case"MOVE_COLUMNS_ROWS":e.sheetId===this.getActiveSheetId()&&this.onMoveElements(e);break;case"SELECT_FIGURE":this.selectedFigureId=e.id;break;case"ACTIVATE_NEXT_SHEET":this.activateNextSheet("right");break;case"ACTIVATE_PREVIOUS_SHEET":this.activateNextSheet("left");break;case"HIDE_SHEET":e.sheetId===this.getActiveSheetId()&&this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:e.sheetId,sheetIdTo:this.getters.getVisibleSheetIds()[0]});break;case"UNDO":case"REDO":case"DELETE_SHEET":const i=Object.keys(this.sheetsData).filter((e=>!this.getters.tryGetSheet(e)));for(const e of i)delete this.sheetsData[e];for(const e in this.sheetsData){const t=this.clipSelection(e,this.sheetsData[e].gridSelection);this.sheetsData[e]={gridSelection:Be(t)}}if(!this.getters.tryGetSheet(this.getters.getActiveSheetId())){const e=this.getters.getVisibleSheetIds();if(this.activeSheet=this.getters.getSheet(e[0]),this.activeSheet.id in this.sheetsData){const{anchor:e}=this.clipSelection(this.activeSheet.id,this.sheetsData[this.activeSheet.id].gridSelection);this.selectCell(e.cell.col,e.cell.row)}else this.selectCell(0,0);const{col:t,row:o}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:t,row:o})}const n=this.getters.getActiveSheetId();this.gridSelection.zones=this.gridSelection.zones.map((e=>this.getters.expandZone(n,e))),this.gridSelection.anchor.zone=this.getters.expandZone(n,this.gridSelection.anchor.zone),this.setSelectionMixin(this.gridSelection.anchor,this.gridSelection.zones),this.selectedFigureId=null}}finalize(){this.selection.resetDefaultAnchor(this,Be(this.gridSelection.anchor))}isGridSelectionActive(){return this.selection.isListening(this)}getActiveSheet(){return this.activeSheet}getActiveSheetId(){return this.activeSheet.id}tryGetActiveSheetId(){return this.activeSheet?.id}getActiveCell(){return this.getters.getEvaluatedCell(this.getActivePosition())}getActiveCols(){const e=new Set;for(let t of this.gridSelection.zones)if(0===t.top&&t.bottom===this.getters.getNumberRows(this.getters.getActiveSheetId())-1)for(let o=t.left;o<=t.right;o++)e.add(o);return e}getActiveRows(){const e=new Set,t=this.getters.getActiveSheetId();for(let o of this.gridSelection.zones)if(0===o.left&&o.right===this.getters.getNumberCols(t)-1)for(let t=o.top;t<=o.bottom;t++)e.add(t);return e}getCurrentStyle(){const e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();return this.getters.getCellStyle({sheetId:t,col:e.left,row:e.top})}getSelectedZones(){return Be(this.gridSelection.zones)}getSelectedZone(){return Be(this.gridSelection.anchor.zone)}getSelection(){return Be(this.gridSelection)}getSelectedCells(){const e=this.getters.getActiveSheetId(),t=[];for(const o of this.gridSelection.zones)t.push(...this.getters.getEvaluatedCellsInZone(e,o));return t}getSelectedFigureId(){return this.selectedFigureId}getActivePosition(){return this.getters.getMainCellPosition({sheetId:this.getActiveSheetId(),col:this.gridSelection.anchor.cell.col,row:this.gridSelection.anchor.cell.row})}getSheetPosition(e){if(e===this.getters.getActiveSheetId())return this.getActivePosition();{const t=this.sheetsData[e];return t?{sheetId:e,col:t.gridSelection.anchor.cell.col,row:t.gridSelection.anchor.cell.row}:this.getters.getNextVisibleCellPosition({sheetId:e,col:0,row:0})}}isSingleColSelected(){const e=this.getters.getSelectedZones();return 1===e.length&&e[0].left===e[0].right}getElementsFromSelection(e){if("COL"===e&&0===this.getters.getActiveCols().size)return[];if("ROW"===e&&0===this.getters.getActiveRows().size)return[];const t=this.getters.getSelectedZones();let o=[];const s="COL"===e?"left":"top",i="COL"===e?"right":"bottom";for(const e of t){const t=Array.from({length:e[i]-e[s]+1},((t,o)=>e[s]+o));o=o.concat(t)}return[...new Set(o)].sort()}activateSheet(e,t){if(this.setActiveSheet(t),this.sheetsData[e]={gridSelection:Be(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,Be(this.gridSelection.anchor));else{const{col:e,row:o}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,o)}}setSelectionMixin(e,t){const{anchor:o,zones:s}=this.clipSelection(this.getters.getActiveSheetId(),{anchor:e,zones:t});this.gridSelection.anchor=o,this.gridSelection.zones=function(e){return e.reverse().filter(((e,t,o)=>t===o.findIndex((t=>t.top===e.top&&t.bottom===e.bottom&&t.left===e.left&&t.right===e.right)))).reverse()}(s)}selectCell(e,t){const o=this.getters.getActiveSheetId(),s=this.getters.expandZone(o,{left:e,right:e,top:t,bottom:t});this.setSelectionMixin({zone:s,cell:{col:e,row:t}},[s])}setActiveSheet(e){this.activeSheet=this.getters.getSheet(e)}activateNextSheet(e){const t=this.getters.getSheetIds(),o=(t.findIndex((e=>e===this.activeSheet.id))+("left"===e?t.length-1:1))%t.length;this.dispatch("ACTIVATE_SHEET",{sheetIdFrom:this.getActiveSheetId(),sheetIdTo:t[o]})}onColumnsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=ts(o,"left",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=ts(i,"left",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>ts(t,"left",[...e.elements])));this.setSelectionMixin(n,r)}onRowsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=ts(o,"top",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=ts(i,"top",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>ts(t,"top",[...e.elements])));this.setSelectionMixin(n,r)}onAddElements(e){const t="COL"===e.dimension?"left":"top",o=es(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),s=this.gridSelection.zones.map((o=>es(o,t,e.base,e.position,e.quantity))),i={cell:{col:o.left,row:o.top},zone:o};this.setSelectionMixin(i,s)}onMoveElements(e){const t=e.elements.length;this.dispatch("ADD_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,base:e.base,quantity:t,position:e.position});const o="COL"===e.dimension,s=e.elements[0],i=e.elements[t-1],n=e.base<s,r=n&&o?t:0,a=n&&!o?t:0,l=[{left:o?s+r:0,right:o?i+r:this.getters.getNumberCols(e.sheetId)-1,top:o?0:s+a,bottom:o?this.getters.getNumberRows(e.sheetId)-1:i+a}],c=this.getActiveSheetId(),h=new lc(this.getters,this.dispatch),d=h.copy(la(c,l));if(!d)return;const u=n?e.base:e.base+1,g=[{left:o?u:0,right:o?u+t-1:this.getters.getNumberCols(e.sheetId)-1,top:o?0:u,bottom:o?this.getters.getNumberRows(e.sheetId)-1:u+t-1}];h.paste({zones:g,sheetId:c},d,{isCutOperation:!0});const p=g[0],m=p.left,f=p.top;this.setSelectionMixin({zone:p,cell:{col:m,row:f}},[p]);const v=n?e.elements.map((e=>e+t)):e.elements;let b=n?e.base:e.base+1;const S={};for(const t of v){const o=this.getters.getHeaderSize(e.sheetId,e.dimension,t);o!=this.getters.getHeaderSize(e.sheetId,e.dimension,b)&&(S[o]??=[],S[o].push(b),b+=1)}for(const t in S)this.dispatch("RESIZE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,size:parseInt(t,10),elements:S[t]});this.dispatch("REMOVE_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,elements:v})}isMoveElementAllowed(e){const t="COL"===e.dimension,o=e.elements[0],s=e.elements[e.elements.length-1],i=e.sheetId,n=t?this.getters.doesColumnsHaveCommonMerges:this.getters.doesRowsHaveCommonMerges;if(n(i,o-1,o)||n(i,s,s+1)||n(i,e.base-1,e.base))return"WillRemoveExistingMerge";const r=[e.base,...e.elements],a=t?this.getters.getNumberCols(i):this.getters.getNumberRows(i);return r.some((e=>e<0||e>=a))?"InvalidHeaderIndex":"Success"}clipSelection(e,t){const o=this.getters.getNumberCols(e)-1,s=this.getters.getNumberRows(e)-1;return{zones:t.zones.map((e=>({left:qe(e.left,0,o),right:qe(e.right,0,o),top:qe(e.top,0,s),bottom:qe(e.bottom,0,s)}))),anchor:{cell:{col:qe(t.anchor.cell.col,0,o),row:qe(t.anchor.cell.row,0,s)},zone:{left:qe(t.anchor.zone.left,0,o),right:qe(t.anchor.zone.right,0,o),top:qe(t.anchor.zone.top,0,s),bottom:qe(t.anchor.zone.bottom,0,s)}}}}drawLayer(e){if(this.getters.isDashboard())return;const{ctx:t,thinLineWidth:o}=e,s=this.getSelectedZones();t.fillStyle="#f3f7fe";const i=1===s.length&&s[0].left===s[0].right&&s[0].top===s[0].bottom;t.fillStyle=i?"#f3f7fe":"#e9f0ff",t.strokeStyle=p,t.lineWidth=1.5*o;for(const e of s){const{x:o,y:s,width:i,height:n}=this.getters.getVisibleRect(e);t.globalCompositeOperation="multiply",t.fillRect(o,s,i,n),t.globalCompositeOperation="source-over",t.strokeRect(o,s,i,n)}t.globalCompositeOperation="source-over";const n=this.getActivePosition();let r;t.strokeStyle=p,t.lineWidth=3*o,r=this.getters.isInMerge(n)?this.getters.getMerge(n):fs(n);const{x:a,y:l,width:c,height:h}=this.getters.getVisibleRect(r);c>0&&h>0&&t.strokeRect(a,l,c,h)}}).add("evaluation_filter",class extends HP{static getters=["getFilterHiddenValues","getFirstTableInSelection","isRowFiltered","isFilterActive"];filterValues={};hiddenRows={};isEvaluationDirty=!1;allowDispatch(e){if("UPDATE_FILTER"===e.type)if(!this.getters.getFilterId(e))return"FilterNotFound";return"Success"}handle(e){switch(e.type){case"UNDO":case"REDO":case"UPDATE_CELL":case"EVALUATE_CELLS":case"ACTIVATE_SHEET":case"REMOVE_TABLE":case"ADD_COLUMNS_ROWS":case"REMOVE_COLUMNS_ROWS":case"UPDATE_TABLE":this.isEvaluationDirty=!0;break;case"START":for(const e of this.getters.getSheetIds())this.filterValues[e]={};break;case"CREATE_SHEET":this.filterValues[e.sheetId]={};break;case"HIDE_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"GROUP_HEADERS":case"UNGROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_ALL_HEADER_GROUPS":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":this.updateHiddenRows(e.sheetId);break;case"UPDATE_FILTER":this.updateFilter(e),this.updateHiddenRows(e.sheetId);break;case"DUPLICATE_SHEET":this.filterValues[e.sheetIdTo]=Be(this.filterValues[e.sheetId])}}finalize(){if(this.isEvaluationDirty){for(const e of this.getters.getSheetIds())this.updateHiddenRows(e);this.isEvaluationDirty=!1}}isRowFiltered(e,t){return!!this.hiddenRows[e]?.has(t)}getFilterHiddenValues(e){const t=this.getters.getFilterId(e),o=e.sheetId;return t&&this.filterValues[o]&&this.filterValues[o][t]||[]}isFilterActive(e){const t=this.getters.getFilterId(e),o=e.sheetId;return Boolean(t&&this.filterValues[o]?.[t]?.length)}getFirstTableInSelection(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,hiddenValues:o,sheetId:s}){const i=this.getters.getFilterId({sheetId:s,col:e,row:t});i&&(this.filterValues[s]||(this.filterValues[s]={}),this.filterValues[s][i]=o)}updateHiddenRows(e){const t=this.getters.getFilters(e).sort(((e,t)=>e.rangeWithHeaders.zone.top-t.rangeWithHeaders.zone.top)),o=new Set;for(let s of t){if(o.has(s.rangeWithHeaders.zone.top)||this.getters.isRowHiddenByUser(e,s.rangeWithHeaders.zone.top))continue;const t=this.filterValues[e]?.[s.id]?.map(sa),i=s.filteredRange?.zone;if(t&&i)for(let n=i.top;n<=i.bottom;n++){const i=this.getCellValueAsString(e,s.col,n);t.includes(i)&&o.add(n)}}this.hiddenRows[e]=o}getCellValueAsString(e,t,o){return this.getters.getEvaluatedCell({sheetId:e,col:t,row:o}).formattedValue.toLowerCase()}exportForExcel(e){for(const t of e.sheets){const e=t.id;for(const o of t.tables){const s=Yo(o.range),i=[],n=[];for(const o of Ze(0,cs(s).numberOfCols)){const r={sheetId:t.id,col:s.left+o,row:s.top},a=this.getFilterHiddenValues(r),l=this.getters.getFilter(r),c=l?.filteredRange?us(l.filteredRange.zone).map((t=>this.getters.getEvaluatedCell({sheetId:e,...t}).formattedValue)):[];if(a.length){const e=c.filter((e=>e)).filter((e=>!a.includes(e)));i.push({colId:o,displayedValues:[...new Set(e)],displayBlanks:!a.includes("")&&c.some((e=>!e))})}const h=this.getters.getEvaluatedCell(r).formattedValue,d=this.getUniqueColNameForExcel(o,h,n);n.push(d);const u=yo(r.col,r.row);t.cells[u]=d,t.cellValues[u]=d}o.filters=i}}}getUniqueColNameForExcel(e,t,o){return t||(t=`Column${e}`),Nt(t,o,{compute:(e,o)=>t+String(o),start:2})}}).add("header_visibility_ui",class extends HP{static getters=["getNextVisibleCellPosition","findVisibleHeader","findLastVisibleColRowIndex","findFirstVisibleColRowIndex","isRowHidden","isColHidden","isHeaderHidden"];isRowHidden(e,t){return this.getters.isRowHiddenByUser(e,t)||this.getters.isRowFiltered(e,t)}isColHidden(e,t){return this.getters.isColHiddenByUser(e,t)}isHeaderHidden(e,t,o){return"COL"===t?this.isColHidden(e,o):this.isRowHidden(e,o)}getNextVisibleCellPosition({sheetId:e,col:t,row:o}){return{sheetId:e,col:this.findVisibleHeader(e,"COL",t,this.getters.getNumberCols(e)-1),row:this.findVisibleHeader(e,"ROW",o,this.getters.getNumberRows(e)-1)}}findVisibleHeader(e,t,o,s){if(o<=s)for(let i=o;i<=s;i++)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i;if(o>s)for(let i=o;i>=s;i--)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i}findLastVisibleColRowIndex(e,t,{last:o,first:s}){return Ze(o,s,-1).find((o=>!this.isHeaderHidden(e,t,o)))||s}findFirstVisibleColRowIndex(e,t){const o=this.getters.getNumberHeaders(e,t);for(let s=0;s<o;s++){if("COL"===t&&!this.isColHidden(e,s))return s;if("ROW"===t&&!this.isRowHidden(e,s))return s}}exportForExcel(e){for(const t of e.sheets)for(const[e,o]of Object.entries(t.rows))o.isHidden=this.isRowHidden(t.id,Number(e))}}).add("cell_computed_style",class extends HP{static getters=["getCellComputedBorder","getCellComputedStyle"];styles={};borders={};handle(e){if(ai.has(e.type)||"UPDATE_CELL"===e.type||"SET_FORMATTING"===e.type||"EVALUATE_CELLS"===e.type)return this.styles={},void(this.borders={});tN(e)?"sheetId"in e?(delete this.styles[e.sheetId],delete this.borders[e.sheetId]):(this.styles={},this.borders={}):hi.has(e.type)?this.styles={}:di.has(e.type)&&(this.borders={})}getCellComputedBorder(e){const{sheetId:t,row:o,col:s}=e;return void 0!==this.borders[t]?.[o]?.[s]||(this.borders[t]||(this.borders[t]={}),this.borders[t][o]||(this.borders[t][o]={}),this.borders[t][o][s]||(this.borders[t][o][s]=this.computeCellBorder(e))),this.borders[t][o][s]}getCellComputedStyle(e){const{sheetId:t,row:o,col:s}=e;return void 0!==this.styles[t]?.[o]?.[s]||(this.styles[t]||(this.styles[t]={}),this.styles[t][o]||(this.styles[t][o]={}),this.styles[t][o][s]||(this.styles[t][o][s]=this.computeCellStyle(e))),this.styles[t][o][s]}computeCellBorder(e){const t=this.getters.getCellBorder(e)||{},o={...bt(this.getters.getCellTableBorder(e)||{}),...bt(t)};return ct(o)?null:o}computeCellStyle(e){const t=this.getters.getCell(e),o=this.getters.getCellConditionalFormatStyle(e),s={...bt(this.getters.getCellTableStyle(e)),...bt(t?.style),...bt(o)};return this.getters.getEvaluatedCell(e).link&&!s.textColor&&(s.textColor=b),s}}).add("table_computed_style",class extends HP{static getters=["getCellTableStyle","getCellTableBorder"];tableStyles={};handle(e){ai.has(e.type)||"UPDATE_CELL"===e.type&&"content"in e||"EVALUATE_CELLS"===e.type?this.tableStyles={}:tN(e)&&("sheetId"in e?delete this.tableStyles[e.sheetId]:this.tableStyles={})}finalize(){for(const e of this.getters.getSheetIds()){this.tableStyles[e]||(this.tableStyles[e]={});for(const t of this.getters.getTables(e))this.tableStyles[e][t.id]||(this.tableStyles[e][t.id]=this.computeTableStyle(e,t))}}getCellTableStyle(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().styles[e.col]?.[e.row]}getCellTableBorder(e){const t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().borders[e.col]?.[e.row]}computeTableStyle(e,t){return ut((()=>{const{config:o,numberOfCols:s,numberOfRows:i}=this.getTableRuntimeConfig(e,t),n=RF(o,this.getters.getTableStyle(t.config.styleId),s,i),r=this.getTableMapping(e,t),a={borders:{},styles:{}};for(let e=0;e<s;e++){const t=r.colMapping[e];a.borders[t]={},a.styles[t]={};for(let o=0;o<i;o++){const s=r.rowMapping[o];a.borders[t][s]=n.borders[e][o],a.styles[t][s]=n.styles[e][o]}}return a}))}getTableRuntimeConfig(e,t){const o=t.range.zone,s={...t.config};let i=o.right-o.left+1,n=o.bottom-o.top+1;for(let i=o.top;i<=o.bottom;i++)this.getters.isRowHidden(e,i)&&(n--,i-o.top<t.config.numberOfHeaders&&(s.numberOfHeaders--,s.numberOfHeaders<0&&(s.numberOfHeaders=0)),i===o.bottom&&(s.totalRow=!1));for(let t=o.left;t<=o.right;t++)this.getters.isColHidden(e,t)&&(i--,t===o.left&&(s.firstColumn=!1),t===o.right&&(s.lastColumn=!1));return{config:s,numberOfCols:i,numberOfRows:n}}getTableMapping(e,t){const o={},s={};let i=0,n=0;const r=t.range.zone;for(let t=r.left;t<=r.right;t++)if(!this.getters.isColHidden(e,t)){o[i]=t,i++;for(let t=r.top;t<=r.bottom;t++)this.getters.isRowHidden(e,t)||(s[n]=t,n++)}return{colMapping:o,rowMapping:s}}}).add("header_positions",class extends HP{static getters=["getColDimensions","getRowDimensions","getColRowOffset"];headerPositions={};isDirty=!0;handle(e){switch(ai.has(e.type)&&(this.headerPositions={},this.isDirty=!0),e.type){case"START":for(const e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);break;case"UPDATE_CELL":case"UPDATE_FILTER":case"UPDATE_TABLE":case"REMOVE_TABLE":this.headerPositions={},this.isDirty=!0;break;case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"CREATE_SHEET":this.headerPositions[e.sheetId]=this.computeHeaderPositionsOfSheet(e.sheetId);break;case"DUPLICATE_SHEET":this.headerPositions[e.sheetIdTo]=Be(this.headerPositions[e.sheetId])}}finalize(){if(this.isDirty){for(const e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);this.isDirty=!1}}getColDimensions(e,t){const o=this.headerPositions[e].COL[t],s=this.getters.getColSize(e,t);return{start:o,size:s,end:o+(this.getters.isColHidden(e,t)?0:s)}}getRowDimensions(e,t){const o=this.headerPositions[e].ROW[t],s=this.getters.getRowSize(e,t);return{start:o,size:s,end:o+(this.getters.isRowHidden(e,t)?0:s)}}getColRowOffset(e,t,o,s=this.getters.getActiveSheetId()){const i=this.headerPositions[s][e][t];return this.headerPositions[s][e][o]-i}computeHeaderPositionsOfSheet(e){return{COL:this.computePositions(e,"COL"),ROW:this.computePositions(e,"ROW")}}computePositions(e,t){const o={};let s=0;for(let i=0;i<this.getters.getNumberHeaders(e,t)+1;i++)o[i]=s,this.getters.isHeaderHidden(e,t,i)||(s+=this.getters.getHeaderSize(e,t,i));return o}}).add("viewport",class extends HP{static getters=["getColIndex","getRowIndex","getActiveMainViewport","getSheetViewDimension","getSheetViewDimensionWithHeaders","getMainViewportRect","isVisibleInViewport","getEdgeScrollCol","getEdgeScrollRow","getVisibleFigures","getVisibleRect","getVisibleRectWithoutHeaders","getVisibleCellPositions","getColRowOffsetInViewport","getMainViewportCoordinates","getActiveSheetScrollInfo","getSheetViewVisibleCols","getSheetViewVisibleRows","getFrozenSheetViewRatio","isPixelPositionVisible","getColDimensionsInViewport","getRowDimensionsInViewport","getAllActiveViewportsZonesAndRect","getRect"];viewports={};sheetViewWidth=Me();sheetViewHeight=Me();gridOffsetX=0;gridOffsetY=0;sheetsWithDirtyViewports=new Set;shouldAdjustViewports=!1;allowDispatch(e){switch(e.type){case"SET_VIEWPORT_OFFSET":return this.chainValidations(this.checkScrollingDirection,this.checkIfViewportsWillChange)(e);case"RESIZE_SHEETVIEW":return this.chainValidations(this.checkValuesAreDifferent,this.checkPositiveDimension)(e);default:return"Success"}}handleEvent(e){const t=this.getters.getActiveSheetId();if(e.options.scrollIntoView){let{col:o,row:s}=ms(e.previousAnchor.zone,e.anchor.zone);if("updateAnchor"===e.mode){const i=e.previousAnchor.zone,n=e.anchor.zone,{top:r,bottom:a,left:l,right:c}=this.getMainInternalViewport(t);i.left===n.left&&i.right===n.right&&(o=l>o||o>c?l:o),i.top===n.top&&i.bottom===n.bottom&&(s=r>s||s>a?r:s)}o=Math.min(o,this.getters.getNumberCols(t)-1),s=Math.min(s,this.getters.getNumberRows(t)-1),this.sheetsWithDirtyViewports.has(t)||this.refreshViewport(this.getters.getActiveSheetId(),{col:o,row:s})}}handle(e){if(ai.has(e.type))for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);switch(e.type){case"START":this.selection.observe(this,{handleEvent:this.handleEvent.bind(this)}),this.resetViewports(this.getters.getActiveSheetId());break;case"UNDO":case"REDO":this.cleanViewports();for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);this.shouldAdjustViewports=!0;break;case"RESIZE_SHEETVIEW":this.resizeSheetView(e.height,e.width,e.gridOffsetX,e.gridOffsetY);break;case"SET_VIEWPORT_OFFSET":this.setSheetViewOffset(e.offsetX,e.offsetY);break;case"SHIFT_VIEWPORT_DOWN":const t=this.getters.getActiveSheetId(),{top:o,viewportHeight:s,offsetCorrectionY:i}=this.getMainInternalViewport(t),n=this.getters.getRowDimensions(t,o);this.shiftVertically(n.start+s-i);break;case"SHIFT_VIEWPORT_UP":{const e=this.getters.getActiveSheetId(),{top:t,viewportHeight:o,offsetCorrectionY:s}=this.getMainInternalViewport(e),i=this.getters.getRowDimensions(e,t);this.shiftVertically(i.end-s-o);break}case"REMOVE_TABLE":case"UPDATE_TABLE":case"UPDATE_FILTER":this.sheetsWithDirtyViewports.add(e.sheetId);break;case"REMOVE_COLUMNS_ROWS":case"RESIZE_COLUMNS_ROWS":case"HIDE_COLUMNS_ROWS":case"ADD_COLUMNS_ROWS":case"UNHIDE_COLUMNS_ROWS":case"UNGROUP_HEADERS":case"GROUP_HEADERS":case"FOLD_HEADER_GROUP":case"UNFOLD_HEADER_GROUP":case"FOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_HEADER_GROUPS_IN_ZONE":case"UNFOLD_ALL_HEADER_GROUPS":case"FOLD_ALL_HEADER_GROUPS":{const t="sheetId"in e?e.sheetId:this.getters.getActiveSheetId();this.sheetsWithDirtyViewports.add(t);break}case"UPDATE_CELL":if("content"in e||"format"in e||void 0!==e.style?.fontSize)for(const e of this.getters.getSheetIds())this.sheetsWithDirtyViewports.add(e);break;case"DELETE_SHEET":this.cleanViewports(),this.sheetsWithDirtyViewports.delete(e.sheetId);break;case"ACTIVATE_SHEET":this.sheetsWithDirtyViewports.add(e.sheetIdTo);break;case"UNFREEZE_ROWS":case"UNFREEZE_COLUMNS":case"FREEZE_COLUMNS":case"FREEZE_ROWS":case"UNFREEZE_COLUMNS_ROWS":this.resetViewports(this.getters.getActiveSheetId());break;case"SCROLL_TO_CELL":this.refreshViewport(this.getters.getActiveSheetId(),{col:e.col,row:e.row})}}finalize(){for(const e of this.sheetsWithDirtyViewports)if(this.resetViewports(e),this.shouldAdjustViewports){const t=this.getters.getSheetPosition(e);this.getSubViewports(e).forEach((e=>{e.adjustPosition(t)}))}this.sheetsWithDirtyViewports=new Set,this.shouldAdjustViewports=!1,this.setViewports()}setViewports(){const e=this.getters.getSheetIds();for(const t of e)this.viewports[t]?.bottomRight||this.resetViewports(t)}getColIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getColIndex(e))))}getRowIndex(e){const t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map((t=>t.getRowIndex(e))))}getSheetViewDimensionWithHeaders(){return{width:this.sheetViewWidth+this.gridOffsetX,height:this.sheetViewHeight+this.gridOffsetY}}getSheetViewDimension(){return{width:this.sheetViewWidth,height:this.sheetViewHeight}}getActiveMainViewport(){const e=this.getters.getActiveSheetId();return this.getMainViewport(e)}getActiveSheetScrollInfo(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e);return{scrollX:t.offsetX,scrollY:t.offsetY}}getSheetViewVisibleCols(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ze(e.left,e.right+1))).flat())].filter((t=>t>=0&&!this.getters.isHeaderHidden(e,"COL",t)))}getSheetViewVisibleRows(){const e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map((e=>Ze(e.top,e.bottom+1))).flat())].filter((t=>t>=0&&!this.getters.isHeaderHidden(e,"ROW",t)))}getVisibleCellPositions(){const e=this.getSheetViewVisibleCols(),t=this.getSheetViewVisibleRows(),o=this.getters.getActiveSheetId(),s=[];for(const i of e)for(const e of t){const t={sheetId:o,col:i,row:e},n=this.getters.getMainCellPosition(t);n.row===e&&n.col===i&&s.push(t)}return s}getMainViewportRect(){const e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e),{xSplit:o,ySplit:s}=this.getters.getPaneDivisions(e);let{width:i,height:n}=t.getMaxSize();return{x:this.getters.getColDimensions(e,o).start,y:this.getters.getRowDimensions(e,s).start,width:i,height:n}}getMaximumSheetOffset(){const e=this.getters.getActiveSheetId(),{width:t,height:o}=this.getMainViewportRect(),s=this.getMainInternalViewport(e);return{maxOffsetX:Math.max(0,t-s.viewportWidth+1),maxOffsetY:Math.max(0,o-s.viewportHeight+1)}}getColRowOffsetInViewport(e,t,o){if(o<t)return-this.getColRowOffsetInViewport(e,o,t);const s=this.getters.getActiveSheetId(),i="COL"===e?this.getters.getSheetViewVisibleCols():this.getters.getSheetViewVisibleRows(),n=i.findIndex((e=>t>=e)),r=i.findIndex((e=>o<=e)),a=i.slice(n,r);let l=0;for(const t of a)l+=this.getters.getHeaderSize(s,e,t);return l}isVisibleInViewport({sheetId:e,col:t,row:o}){return this.getSubViewports(e).some((e=>e.isVisible(t,o)))}getEdgeScrollCol(e,t,o){let s=!1,i=0,n=0;const{xSplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{width:a}=this.getSheetViewDimension(),{x:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollX;return e>a?(s=!0,n=Nr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=Nr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=Nr(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getEdgeScrollRow(e,t,o){let s=!1,i=0,n=0;const{ySplit:r}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{height:a}=this.getSheetViewDimension(),{y:l}=this.getMainViewportCoordinates(),c=this.getActiveSheetScrollInfo().scrollY;return e>a?(s=!0,n=Nr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=Nr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=Nr(e),i="reset"),{canEdgeScroll:s,direction:i,delay:n}}getVisibleRect(e){const t=this.getVisibleRectWithoutHeaders(e);return{...t,x:t.x+this.gridOffsetX,y:t.y+this.gridOffsetY}}getVisibleRectWithoutHeaders(e){const t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,(t=>t.getVisibleRect(e)))}getRect(e){const t=this.getters.getActiveSheetId(),o=this.mapViewportsToRect(t,(t=>t.getFullRect(e)));return{...o,x:o.x+this.gridOffsetX,y:o.y+this.gridOffsetY}}getMainViewportCoordinates(){const e=this.getters.getActiveSheetId(),{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e);return{x:this.getters.getColDimensions(e,t).start,y:this.getters.getRowDimensions(e,o).start}}getColDimensionsInViewport(e,t){const o={left:t,right:t,top:0,bottom:this.getters.getNumberRows(e)-1},{x:s,width:i}=this.getVisibleRect(o),n=s-this.gridOffsetX;return{start:n,size:i,end:n+i}}getRowDimensionsInViewport(e,t){const o={left:0,right:this.getters.getNumberCols(e)-1,top:t,bottom:t},{y:s,height:i}=this.getVisibleRect(o),n=s-this.gridOffsetY;return{start:n,size:i,end:n+i}}getAllActiveViewportsZonesAndRect(){const e=this.getters.getActiveSheetId();return this.getSubViewports(e).map((e=>({zone:e,rect:{x:e.offsetCorrectionX+this.gridOffsetX,y:e.offsetCorrectionY+this.gridOffsetY,...e.getMaxSize()}})))}ensureMainViewportExist(e){this.viewports[e]||this.resetViewports(e)}getSubViewports(e){return this.ensureMainViewportExist(e),Object.values(this.viewports[e]).filter(at)}checkPositiveDimension(e){return e.width<0||e.height<0?"InvalidViewportSize":"Success"}checkValuesAreDifferent(e){const{height:t,width:o}=this.getSheetViewDimension();return e.gridOffsetX===this.gridOffsetX&&e.gridOffsetY===this.gridOffsetY&&e.width===o&&e.height===t?"ValuesNotChanged":"Success"}checkScrollingDirection({offsetX:e,offsetY:t}){const o=this.getMainInternalViewport(this.getters.getActiveSheetId());return!o.canScrollHorizontally&&e>0||!o.canScrollVertically&&t>0?"InvalidScrollingDirection":"Success"}checkIfViewportsWillChange({offsetX:e,offsetY:t}){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();return this.getSubViewports(o).some((o=>o.willNewOffsetScrollViewport(qe(e,0,s),qe(t,0,i))))?"Success":"ViewportScrollLimitsReached"}getMainViewport(e){const t=this.getMainInternalViewport(e);return{top:t.top,left:t.left,bottom:t.bottom,right:t.right}}getMainInternalViewport(e){return this.ensureMainViewportExist(e),this.viewports[e].bottomRight}cleanViewports(){const e={};for(const t of this.getters.getSheetIds())e[t]=this.viewports[t];this.viewports=e}resizeSheetView(e,t,o=0,s=0){this.sheetViewHeight=e,this.sheetViewWidth=t,this.gridOffsetX=o,this.gridOffsetY=s,this.recomputeViewports()}recomputeViewports(){for(const e of this.getters.getSheetIds())this.resetViewports(e)}setSheetViewOffset(e,t){const o=this.getters.getActiveSheetId(),{maxOffsetX:s,maxOffsetY:i}=this.getMaximumSheetOffset();this.getSubViewports(o).forEach((o=>o.setViewportOffset(qe(e,0,s),qe(t,0,i))))}getViewportOffset(e){return{x:this.viewports[e]?.bottomRight.offsetX||0,y:this.viewports[e]?.bottomRight.offsetY||0}}resetViewports(e){if(!this.getters.tryGetSheet(e))return;const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getNumberCols(e),i=this.getters.getNumberRows(e),n=Math.min(this.getters.getColRowOffset("COL",0,t,e),this.sheetViewWidth),r=Math.min(this.getters.getColRowOffset("ROW",0,o,e),this.sheetViewHeight),a=Math.max(this.sheetViewWidth-n,0),l=Math.max(this.sheetViewHeight-r,0),{xRatio:c,yRatio:h}=this.getFrozenSheetViewRatio(e),d=c<1,u=h<1,g=this.getViewportOffset(e),p={topLeft:o&&t&&new pN(this.getters,e,{left:0,right:t-1,top:0,bottom:o-1},{width:n,height:r},{canScrollHorizontally:!1,canScrollVertically:!1},{x:0,y:0})||void 0,topRight:o&&new pN(this.getters,e,{left:t,right:s-1,top:0,bottom:o-1},{width:a,height:r},{canScrollHorizontally:d,canScrollVertically:!1},{x:d?g.x:0,y:0})||void 0,bottomLeft:t&&new pN(this.getters,e,{left:0,right:t-1,top:o,bottom:i-1},{width:n,height:l},{canScrollHorizontally:!1,canScrollVertically:u},{x:0,y:u?g.y:0})||void 0,bottomRight:new pN(this.getters,e,{left:t,right:s-1,top:o,bottom:i-1},{width:a,height:l},{canScrollHorizontally:d,canScrollVertically:u},{x:d?g.x:0,y:u?g.y:0})};this.viewports[e]=p}refreshViewport(e,t){this.getSubViewports(e).forEach((e=>{e.adjustViewportZone(),e.adjustPosition(t)}))}shiftVertically(e){const t=this.getters.getActiveSheetId(),{top:o}=this.getMainInternalViewport(t),{scrollX:s}=this.getActiveSheetScrollInfo();this.setSheetViewOffset(s,e);const{anchor:i}=this.getters.getSelection();if(i.cell.row>=this.getters.getPaneDivisions(t).ySplit){const e=this.getMainInternalViewport(t).top-o;this.selection.selectCell(i.cell.col,i.cell.row+e)}}getVisibleFigures(){const e=this.getters.getActiveSheetId(),t=[],o=this.getters.getFigures(e),{scrollX:s,scrollY:i}=this.getActiveSheetScrollInfo(),{x:n,y:r}=this.getters.getMainViewportCoordinates(),{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders();for(const e of o)e.x>=n&&(e.x+e.width<=n+s||e.x>=a+s+n)||e.y>=r&&(e.y+e.height<=r+i||e.y>=l+i+r)||t.push(e);return t}isPixelPositionVisible(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),{x:s,y:i}=this.getters.getMainViewportCoordinates(),{width:n,height:r}=this.getters.getSheetViewDimension();return!(e.x>=s&&(e.x<s+t||e.x>n+t+s))&&!(e.y>=i&&(e.y<i+o||e.y>r+o+i))}getFrozenSheetViewRatio(e){const{xSplit:t,ySplit:o}=this.getters.getPaneDivisions(e),s=this.getters.getColDimensions(e,t).start,i=this.getters.getRowDimensions(e,o).start;return{xRatio:s/(this.sheetViewWidth+this.gridOffsetX),yRatio:i/(this.sheetViewHeight+this.gridOffsetY)}}mapViewportsToRect(e,t){let o=1/0,s=1/0,i=0,n=0,r=!1;for(const a of this.getSubViewports(e)){const e=t(a);e&&(r=!0,o=Math.min(o,e.x),s=Math.min(s,e.y),i=Math.max(i,e.x+e.width),n=Math.max(n,e.y+e.height))}return r?{x:o,y:s,width:i-o,height:n-s}:{x:0,y:0,width:0,height:0}}}).add("clipboard",class extends HP{static layers=["Clipboard"];static getters=["getClipboardContent","getClipboardId","getClipboardTextContent","isCutOperation"];status="invisible";originSheetId;copiedData;_isCutOperation=!1;clipboardId=(new aa).uuidv4();allowDispatch(e){switch(e.type){case"CUT":const t=this.getters.getSelectedZones();return this.isCutAllowedOn(t);case"PASTE_FROM_OS_CLIPBOARD":{const t=this.convertTextToClipboardData(e.clipboardContent.text??""),o=e.pasteOption;return this.isPasteAllowed(e.target,t,{pasteOption:o,isCutOperation:!1})}case"PASTE":{if(!this.copiedData)return"EmptyClipboard";const t=e.pasteOption;return this.isPasteAllowed(e.target,this.copiedData,{pasteOption:t,isCutOperation:this._isCutOperation})}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].top&&0===e[0].bottom)return"InvalidCopyPasteSelection";break}case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZones();if(e.length>1||0===e[0].left&&0===e[0].right)return"InvalidCopyPasteSelection";break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t);return this.isPasteAllowed(o,s,{isCutOperation:!0})}case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension),s=this.copy(t);return this.isPasteAllowed(o,s,{isCutOperation:!0})}}return"Success"}handle(e){switch(e.type){case"COPY":case"CUT":const t=this.getters.getSelectedZones();this.status="visible",this.originSheetId=this.getters.getActiveSheetId(),this.copiedData=this.copy(t),this._isCutOperation="CUT"===e.type;break;case"PASTE_FROM_OS_CLIPBOARD":{this._isCutOperation=!1,this.copiedData=e.clipboardContent.data||this.convertTextToClipboardData(e.clipboardContent.text??"");const t=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:t,selectTarget:!0,isCutOperation:!1}),this.status="invisible";break}case"PASTE":{const t=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:t,selectTarget:!0,isCutOperation:this._isCutOperation}),this.status="invisible",this._isCutOperation&&(this.copiedData=void 0,this._isCutOperation=!1);break}case"COPY_PASTE_CELLS_ABOVE":{const e=this.getters.getSelectedZone(),t=e.top!==e.bottom,o={...e,bottom:t?e.top:e.top-1,top:t?e.top:e.top-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"COPY_PASTE_CELLS_ON_LEFT":{const e=this.getters.getSelectedZone(),t=e.left!==e.right,o={...e,right:t?e.left:e.left-1,left:t?e.left:e.left-1};this.originSheetId=this.getters.getActiveSheetId();const s=this.copy([o]);this.paste([e],s,{isCutOperation:!1,selectTarget:!0})}break;case"CLEAN_CLIPBOARD_HIGHLIGHT":this.status="invisible";break;case"DELETE_CELL":{const{cut:t,paste:o}=this.getDeleteCellsTargets(e.zone,e.shiftDimension);if(!Xo(t[0])){this.dispatch("CLEAR_CELLS",{target:[e.zone],sheetId:this.getters.getActiveSheetId()});break}const s=this.copy(t);this.paste(o,s,{isCutOperation:!0});break}case"INSERT_CELL":{const{cut:t,paste:o}=this.getInsertCellsTargets(e.zone,e.shiftDimension),s=this.copy(t);this.paste(o,s,{isCutOperation:!0});break}case"ADD_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;this.isColRowDirtyingClipboard("before"===e.position?e.base:e.base+1,e.dimension)&&(this.copiedData=void 0);break;case"REMOVE_COLUMNS_ROWS":if(this.status="invisible",!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;for(let t of e.elements){if(this.isColRowDirtyingClipboard(t,e.dimension)){this.copiedData=void 0;break}}this.status="invisible";break;case"REPEAT_PASTE":this.paste(e.target,this.copiedData,{isCutOperation:!1,pasteOption:e.pasteOption,selectTarget:!0});break;case"DELETE_SHEET":if(!this._isCutOperation)return;this.originSheetId===e.sheetId&&(this.copiedData=void 0,this.status="invisible");break;default:pi(e)&&(this.status="invisible")}}convertTextToClipboardData(e){const t=this.selectClipboardHandlers({figureId:!0}).concat(this.selectClipboardHandlers({}));let o={};for(const{handlerName:s,handler:i}of t){const t=i.convertTextToClipboardData(e);o[s]=t;const n=["sheetId","cells","zones","figureId"];for(const e of n)t&&e in t&&(o[e]=t[e])}return o}selectClipboardHandlers(e){const t="figureId"in e?uc.figureHandlers:uc.cellHandlers;return t.getKeys().map((e=>({handlerName:e,handler:new(t.get(e))(this.getters,this.dispatch)})))}isCutAllowedOn(e){const t=this.getClipboardData(e);for(const{handler:e}of this.selectClipboardHandlers(t)){const o=e.isCutAllowed(t);if("Success"!==o)return o}return"Success"}isPasteAllowed(e,t,o){for(const{handler:s}of this.selectClipboardHandlers(t)){const i=s.isPasteAllowed(this.getters.getActiveSheetId(),e,t,{...o});if("Success"!==i)return i}return"Success"}isColRowDirtyingClipboard(e,t){if(!this.copiedData||!this.copiedData.zones)return!1;const{zones:o}=this.copiedData;for(let s of o){if("COL"===t&&e<=s.right)return!0;if("ROW"===t&&e<=s.bottom)return!0}return!1}copy(e){let t={};const o=this.getClipboardData(e);for(const{handlerName:e,handler:s}of this.selectClipboardHandlers(o)){const i=s.copy(o);t[e]=i;const n=["sheetId","cells","zones","figureId"];for(const e of n)i&&e in i&&(t[e]=i[e])}return t}paste(e,t,o){if(!t)return;let s,i=[];const n=this.getters.getActiveSheetId();let r={sheetId:n,zones:e};const a=this.selectClipboardHandlers(t);for(const{handlerName:l,handler:c}of a){const a=t[l];if(!a)continue;const h=c.getPasteTarget(n,e,a,o);h.figureId&&(r.figureId=h.figureId);for(const e of h.zones)i.push(e),s=void 0!==s?ss(s,e):e}if(void 0!==s&&this.addMissingDimensions(this.getters.getActiveSheetId(),s.right-s.left+1,s.bottom-s.top+1,s.left,s.top),a.forEach((({handlerName:e,handler:s})=>{const i=t[e];i&&s.paste(r,i,o)})),!o?.selectTarget)return;const l=e[0],c=l.left,h=l.top;this.selection.getBackToDefault(),this.selection.selectZone({cell:{col:c,row:h},zone:ss(...i)},{scrollIntoView:!1})}addMissingDimensions(e,t,o,s,i){const n=o+i-this.getters.getNumberRows(e);n>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"ROW",base:this.getters.getNumberRows(e)-1,sheetId:e,quantity:n,position:"after"});const r=t+s-this.getters.getNumberCols(e);r>0&&this.dispatch("ADD_COLUMNS_ROWS",{dimension:"COL",base:this.getters.getNumberCols(e)-1,sheetId:e,quantity:r,position:"after"})}getClipboardTextContent(){return this.getPlainTextContent()}getClipboardId(){return this.clipboardId}getClipboardContent(){return{[ri.PlainText]:this.getPlainTextContent(),[ri.Html]:this.getHTMLContent()}}getSheetData(){const e={version:Qw,clipboardId:this.clipboardId};return this.copiedData&&"figureId"in this.copiedData?e:{...e,...this.copiedData}}getPlainTextContent(){return this.copiedData?.cells&&this.copiedData.cells.map((e=>e.map((e=>this.getters.shouldShowFormulas()&&e?.tokens?.length?e?.content||"":e.evaluatedCell?.formattedValue||"")).join("\t"))).join("\n")||"\t"}getHTMLContent(){let e="";const t=this.copiedData?.cells;if(t)if(1===t.length&&1===t[0].length)e=`${this.getters.getCellText(t[0][0].position)}`;else{if(!t[0][0])return"";{let o='<table border="1" style="border-collapse:collapse">';for(const e of t){o+="<tr>";for(const t of e){if(!t)continue;o+=`<td style="${kc(Nc(this.getters.getCellComputedStyle(t.position)))}">`+xw(this.getters.getCellText(t.position))+"</td>"}o+="</tr>"}o+="</table>",e=o}}else e="\t";return`<div data-osheet-clipboard='${xw(JSON.stringify(this.getSheetData()))}'>${e}</div>`}isCutOperation(){return this._isCutOperation??!1}getDeleteCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s;return s="COL"===t?{...e,left:e.right+1,right:this.getters.getNumberCols(o)-1}:{...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1},{cut:[s],paste:[e]}}getInsertCellsTargets(e,t){const o=this.getters.getActiveSheetId();let s,i;return"COL"===t?(s={...e,right:this.getters.getNumberCols(o)-1},i={...e,left:e.right+1,right:e.right+1}):(s={...e,bottom:this.getters.getNumberRows(o)-1},i={...e,top:e.bottom+1,bottom:this.getters.getNumberRows(o)-1}),{cut:[s],paste:[i]}}getClipboardData(e){const t=this.getters.getActiveSheetId(),o=this.getters.getSelectedFigureId();return o?{figureId:o,sheetId:t}:la(t,e)}drawLayer(e){if("visible"!==this.status||!this.copiedData)return;const{sheetId:t,zones:o}=this.copiedData;if(t!==this.getters.getActiveSheetId()||!o||!o.length)return;const{ctx:s,thinLineWidth:i}=e;s.setLineDash([8,5]),s.strokeStyle=p,s.lineWidth=3.3*i;for(const e of o){const{x:t,y:o,width:i,height:n}=this.getters.getVisibleRect(e);i>0&&n>0&&s.strokeRect(t,o,i,n)}}}),bN=(new n).add("evaluation",class extends KM{static getters=["evaluateFormula","evaluateFormulaResult","evaluateCompiledFormula","getCorrespondingFormulaCell","getRangeFormattedValues","getRangeValues","getRangeFormats","getEvaluatedCell","getEvaluatedCells","getEvaluatedCellsInZone","getEvaluatedCellsPositions","getSpreadZone","getArrayFormulaSpreadingOn","isEmpty"];shouldRebuildDependenciesGraph=!0;evaluator;positionsToUpdate=[];constructor(e){super(e),this.evaluator=new _P(e.custom,this.getters)}beforeHandle(e){(ai.has(e.type)||ci.has(e.type))&&(this.shouldRebuildDependenciesGraph=!0)}handle(e){switch(e.type){case"UPDATE_CELL":if(!("content"in e)&&!("format"in e)||this.shouldRebuildDependenciesGraph)return;const t={sheetId:e.sheetId,row:e.row,col:e.col};this.positionsToUpdate.push(t),"content"in e&&this.evaluator.updateDependencies(t);break;case"EVALUATE_CELLS":this.evaluator.evaluateAllCells()}}finalize(){this.shouldRebuildDependenciesGraph?(this.evaluator.buildDependencyGraph(),this.evaluator.evaluateAllCells(),this.shouldRebuildDependenciesGraph=!1):this.positionsToUpdate.length&&this.evaluator.evaluateCells(this.positionsToUpdate),this.positionsToUpdate=[]}evaluateFormula(e,t){const o=this.evaluateFormulaResult(e,t);return Ci(o)?an(o,(e=>e.value)):o.value}evaluateFormulaResult(e,t){return this.evaluator.evaluateFormulaResult(e,t)}evaluateCompiledFormula(e,t,o){return this.evaluator.evaluateCompiledFormula(e,t,o)}getRangeFormattedValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).formattedValue))}getRangeValues(e){return void 0===this.getters.tryGetSheet(e.sheetId)?[]:this.mapVisiblePositions(e,(e=>this.getters.getEvaluatedCell(e).value))}getRangeFormats(e){const t=this.getters.tryGetSheet(e.sheetId);return void 0===t?[]:this.getters.getEvaluatedCellsInZone(t.id,e.zone).map((e=>e.format))}getEvaluatedCell(e){return this.evaluator.getEvaluatedCell(e)}getEvaluatedCells(e){return this.evaluator.getEvaluatedPositionsInSheet(e).map((e=>this.getEvaluatedCell(e)))}getEvaluatedCellsPositions(e){return this.evaluator.getEvaluatedPositionsInSheet(e)}getEvaluatedCellsInZone(e,t){return us(t).map((({col:t,row:o})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:o})))}getSpreadZone(e,t={ignoreSpillError:!1}){return this.evaluator.getSpreadZone(e,t)}getArrayFormulaSpreadingOn(e){return this.evaluator.getArrayFormulaSpreadingOn(e)}isEmpty(e,t){return us(t).map((({col:t,row:o})=>this.getEvaluatedCell({sheetId:e,col:t,row:o}))).every((e=>e.type===ni.empty))}mapVisiblePositions(e,t){const{sheetId:o,zone:s}=e;return us(s).reduce(((e,s)=>{const{col:i,row:n}=s;return this.getters.isColHidden(o,i)||this.getters.isRowHidden(o,n)||e.push(t({sheetId:o,...s})),e}),[])}exportForExcel(e){for(const t of e.sheets)t.cellValues={};for(const t of this.evaluator.getEvaluatedPositions()){const o=this.evaluator.getEvaluatedCell(t),s=yo(t.col,t.row),i=o.value;let n,r=!1,a=!0;const l=e.sheets.find((e=>e.id===t.sheetId)),c=this.getCorrespondingFormulaCell(t);if(c&&(a=pS(c.compiledFormula.tokens),r=a,!a&&""!==i)){n=(i??"").toString();const t=o.format;if(t){const o=ws(t,e.formats);l.formats[s]=o}}const h=l.cells[s];let d;d=a&&r&&c instanceof $M?c.contentWithFixedReferences:a?h:n,l.cells[s]=d,l.cellValues[s]=i}}getCorrespondingFormulaCell(e){const t=this.getters.getCell(e);if(t&&t.isFormula)return t.compiledFormula.isBadExpression?void 0:t;if(t&&t.content)return;const o=this.getArrayFormulaSpreadingOn(e);if(void 0===o)return;const s=this.getters.getCell(o);return s?.isFormula?s:void 0}}).add("evaluation_chart",class extends KM{static getters=["getChartRuntime","getStyleOfSingleCellChart"];charts={};createRuntimeChart=mR(this.getters);handle(e){if(ai.has(e.type)||hi.has(e.type)||li.has(e.type))for(const e in this.charts)this.charts[e]=void 0;switch(e.type){case"UPDATE_CHART":case"CREATE_CHART":case"DELETE_FIGURE":this.charts[e.id]=void 0;break;case"DELETE_SHEET":for(let e in this.charts)this.getters.isChartDefined(e)||(this.charts[e]=void 0)}}getChartRuntime(e){if(!this.charts[e]){const t=this.getters.getChart(e);if(!t)throw new Error(`No chart for the given id: ${e}`);this.charts[e]=this.createRuntimeChart(t)}return this.charts[e]}getStyleOfSingleCellChart(e,t){if(e)return{background:e,fontColor:Zc(e)};if(!t)return{background:m,fontColor:Zc(m)};const o=t.zone.left,s=t.zone.top,i=t.sheetId,n=this.getters.getCellComputedStyle({sheetId:i,col:o,row:s}),r=n.fillColor||m;return{background:r,fontColor:n.textColor||Zc(r)}}exportForExcel(e){for(const t of e.sheets){t.images||(t.images=[]);const e=this.getters.getFigures(t.id),o=[];for(const s of e){if(!s||"chart"!==s.tag)continue;const e=s.id,i=this.getters.getChart(e)?.getDefinitionForExcel();if(i)o.push({...s,data:i});else{if(!this.getters.getChart(e))continue;const o=this.getters.getChartType(e),i=XS(this.getters.getChartRuntime(e),s,o);i&&t.images.push({...s,tag:"image",data:{mimetype:"image/png",path:i,size:{width:s.width,height:s.height}}})}}t.charts=o}}}).add("evaluation_cf",class extends KM{static getters=["getConditionalIcon","getCellConditionalFormatStyle","getConditionalDataBar"];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(ai.has(e.type)||hi.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))&&(this.isStale=!0)}finalize(){if(this.isStale){for(const e of this.getters.getSheetIds())this.computedStyles[e]=ut((()=>this.getComputedStyles(e))),this.computedIcons[e]=ut((()=>this.getComputedIcons(e))),this.computedDataBars[e]=ut((()=>this.getComputedDataBars(e)));this.isStale=!1}}getCellConditionalFormatStyle(e){const{sheetId:t,col:o,row:s}=e,i=this.computedStyles[t]();return i&&i[o]?.[s]}getConditionalIcon({sheetId:e,col:t,row:o}){const s=this.computedIcons[e]();return s&&s[t]?.[o]}getConditionalDataBar({sheetId:e,col:t,row:o}){const s=this.computedDataBars[e]();return s&&s[t]?.[o]}getComputedStyles(e){const t={};for(let o of this.getters.getConditionalFormats(e).reverse())switch(o.rule.type){case"ColorScaleRule":for(let s of o.ranges)this.applyColorScale(e,s,o.rule,t);break;case"CellIsRule":const s=o.rule.values.map((e=>e.startsWith("=")?hS(e):void 0));for(let i of o.ranges){const n=this.getters.getRangeFromSheetXC(e,i).zone;for(let i=n.top;i<=n.bottom;i++)for(let r=n.left;r<=n.right;r++){const a=this.rulePredicate[o.rule.type],l={sheetId:e,col:r,row:i},c=o.rule.values.map(((t,o)=>{const a=s[o];return a?this.getters.getTranslatedCellFormula(e,r-n.left,i-n.top,a.tokens):t}));a&&a(l,{...o.rule,values:c})&&(t[r]||(t[r]=[]),t[r][i]=Object.assign(t[r]?.[i]||{},o.rule.style))}}}return t}getComputedIcons(e){const t={};for(let o of this.getters.getConditionalFormats(e).reverse())if("IconSetRule"===o.rule.type)for(let s of o.ranges)this.applyIcon(e,s,o.rule,t);return t}getComputedDataBars(e){const t={};for(let o of this.getters.getConditionalFormats(e).reverse())if("DataBarRule"===o.rule.type)for(let s of o.ranges)this.applyDataBar(e,s,o.rule,t);return t}parsePoint(e,t,o,s){const i=this.getters.getEvaluatedCellsInZone(e,this.getters.getRangeFromSheetXC(e,t).zone).filter((e=>e.type===ni.number)).map((e=>e.value));switch(o.type){case"value":return"max"===s?Dt(i):Ot(i);case"number":return Number(o.value);case"percentage":const t=Ot(i);return t+(Dt(i)-t)*Number(o.value)/100;case"percentile":return ii(i,Number(o.value)/100,!0);case"formula":const n=o.value&&this.getters.evaluateFormula(e,o.value);return"number"==typeof n?n:null;default:return null}}applyIcon(e,t,o,s){const i=this.parsePoint(e,t,o.lowerInflectionPoint),n=this.parsePoint(e,t,o.upperInflectionPoint);if(null===i||null===n||i>n)return;const r=this.getters.getRangeFromSheetXC(e,t).zone,a=[o.icons.upper,o.icons.middle,o.icons.lower];for(let t=r.top;t<=r.bottom;t++)for(let l=r.left;l<=r.right;l++){const r=this.getters.getEvaluatedCell({sheetId:e,col:l,row:t});if(r.type!==ni.number)continue;const c=this.computeIcon(r.value,n,o.upperInflectionPoint.operator,i,o.lowerInflectionPoint.operator,a);s[l]||(s[l]=[]),s[l][t]=c}}computeIcon(e,t,o,s,i,n){return"ge"===o&&e>=t||"gt"===o&&e>t?n[0]:"ge"===i&&e>=s||"gt"===i&&e>s?n[1]:n[2]}applyDataBar(e,t,o,s){const i=this.getters.getRangeFromSheetXC(e,o.rangeValues||t),n=Dt(this.getters.getEvaluatedCellsInZone(e,i.zone).filter((e=>e.type===ni.number)).map((e=>e.value)));if(n<=0)return;const r=o.color,a=this.getters.getRangeFromSheetXC(e,t).zone,l=i.zone;for(let t=a.top;t<=a.bottom;t++)for(let o=a.left;o<=a.right;o++){const i=o-a.left+l.left,c=t-a.top+l.top,h=this.getters.getEvaluatedCell({sheetId:e,col:i,row:c});!as(i,c,l)||h.type!==ni.number||h.value<=0||(s[o]||(s[o]=[]),s[o][t]={color:Ht(r),percentage:100*h.value/n})}}applyColorScale(e,t,o,s){const i=this.parsePoint(e,t,o.minimum,"min"),n=o.midpoint?this.parsePoint(e,t,o.midpoint):null,r=this.parsePoint(e,t,o.maximum,"max");if(null===i||null===r||i>=r||n&&(i>=n||n>=r))return;const a=this.getters.getRangeFromSheetXC(e,t).zone,l=[{value:i,color:o.minimum.color}];o.midpoint&&n&&l.push({value:n,color:o.midpoint.color}),l.push({value:r,color:o.maximum.color});const c=go(l);for(let t=a.top;t<=a.bottom;t++)for(let o=a.left;o<=a.right;o++){const n=this.getters.getEvaluatedCell({sheetId:e,col:o,row:t});if(n.type===ni.number){const e=qe(n.value,i,r);s[o]||(s[o]=[]),s[o][t]=s[o]?.[t]||{},s[o][t].fillColor=c(e)}}}rulePredicate={CellIsRule:(e,t)=>{const o=this.getters.getEvaluatedCell(e);if(o.type===ni.error)return!1;let[s,i]=t.values.map((t=>t.startsWith("=")?this.getters.evaluateFormula(e.sheetId,t)??"":Rr(t,Si)));if(Ci(s)||Ci(i))return!1;const n=o.value??"";switch(s=s??"",i=i??"",t.operator){case"IsEmpty":return""===n.toString().trim();case"IsNotEmpty":return""!==n.toString().trim();case"BeginsWith":return""!==s&&n.toString().startsWith(s.toString());case"EndsWith":return""!==s&&n.toString().endsWith(s.toString());case"Between":return n>=s&&n<=i;case"NotBetween":return!(n>=s&&n<=i);case"ContainsText":return n.toString().indexOf(s.toString())>-1;case"NotContains":return!n||-1===n.toString().indexOf(s.toString());case"GreaterThan":return n>s;case"GreaterThanOrEqual":return n>=s;case"LessThan":return n<s;case"LessThanOrEqual":return n<=s;case"NotEqual":return""!==s&&n!==s;case"Equal":return""===s||n===s;default:console.warn(Fo("Not implemented operator %s for kind of conditional formatting: %s",t.operator,t.type))}return!1}}}).add("row_size",class extends KM{static getters=["getRowSize","getHeaderSize"];tallestCellInRow={};ctx=document.createElement("canvas").getContext("2d");handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())this.initializeSheet(e);break;case"CREATE_SHEET":this.initializeSheet(e.sheetId);break;case"DUPLICATE_SHEET":{const t=Be(this.tallestCellInRow[e.sheetId]);this.history.update("tallestCellInRow",e.sheetIdTo,t);break}case"DELETE_SHEET":const t={...this.tallestCellInRow};delete t[e.sheetId],this.history.update("tallestCellInRow",t);break;case"REMOVE_COLUMNS_ROWS":{if("COL"===e.dimension)return;const t=It(this.tallestCellInRow[e.sheetId],e.elements);this.history.update("tallestCellInRow",e.sheetId,t);break}case"ADD_COLUMNS_ROWS":{if("COL"===e.dimension)return;const t=pt(e.position,e.base),o=Array(e.quantity).fill(void 0),s=Rt(this.tallestCellInRow[e.sheetId],o,t);this.history.update("tallestCellInRow",e.sheetId,s);break}case"RESIZE_COLUMNS_ROWS":{const t=e.sheetId;if("ROW"===e.dimension)for(const o of e.elements){const e=this.getRowTallestCell(t,o);this.history.update("tallestCellInRow",t,o,e)}else for(const o of Ze(0,this.getters.getNumberRows(t)))for(const s of e.elements)this.updateRowSizeForCellChange(t,o,s)}break;case"UPDATE_CELL":this.updateRowSizeForCellChange(e.sheetId,e.row,e.col);break;case"ADD_MERGE":case"REMOVE_MERGE":for(const t of e.target)for(const o of us(t))this.updateRowSizeForCellChange(e.sheetId,o.row,o.col)}}getRowSize(e,t){return Math.round(this.getters.getUserRowSize(e,t)??this.tallestCellInRow[e][t]?.size??se)}getHeaderSize(e,t,o){return this.getters.isHeaderHidden(e,t,o)?0:"ROW"===t?this.getRowSize(e,o):this.getters.getColSize(e,o)}updateRowSizeForCellChange(e,t,o){const s=this.tallestCellInRow[e]?.[t];if(s?.cell.col===o){const o=this.getRowTallestCell(e,t);this.history.update("tallestCellInRow",e,t,o)}const i=this.getCellHeight({sheetId:e,col:o,row:t});if(!(i<=se)&&(!s&&i>se||s&&i>s.size)){const s={cell:{sheetId:e,col:o,row:t},size:i};this.history.update("tallestCellInRow",e,t,s)}}initializeSheet(e){const t=[];for(let o=0;o<this.getters.getNumberRows(e);o++){const s=this.getRowTallestCell(e,o);t.push(s)}this.history.update("tallestCellInRow",e,t)}getCellHeight(e){if(this.isInMultiRowMerge(e))return se;const t=this.getters.getCell(e),o=this.getters.getColSize(e.sheetId,e.col);return function(e,t,o){if(!t||!t.isFormula&&!t.content)return se;const s="wrap"===t.style?.wrapping?o-2*ne:void 0,i=t.isFormula?1:oa(e,t.content,t.style,s).length;return Gr(ea(t.style),i)+6}(this.ctx,t,o)}isInMultiRowMerge(e){const t=this.getters.getMerge(e);return!!t&&t.bottom!==t.top}getRowTallestCell(e,t){if(void 0!==this.getters.getUserRowSize(e,t))return;const o=this.getters.getRowCells(e,t);let s,i=0;for(let e=0;e<o.length;e++){const t=this.getters.getCellById(o[e]);if(!t)continue;const n=this.getters.getCellPosition(t.id),r=this.getCellHeight(n);r>i&&r>se&&(i=r,s={cell:n,size:r})}return s&&s.size>se?s:void 0}}).add("data_validation_ui",class extends KM{static getters=["getDataValidationInvalidCriterionValueMessage","getInvalidDataValidationMessage","getValidationResultForCellValue","isCellValidCheckbox","isDataValidationInvalid"];validationResults={};handle(e){if(ai.has(e.type)||"EVALUATE_CELLS"===e.type||"UPDATE_CELL"===e.type&&("content"in e||"format"in e))this.validationResults={};else switch(e.type){case"ADD_DATA_VALIDATION_RULE":case"REMOVE_DATA_VALIDATION_RULE":delete this.validationResults[e.sheetId]}}isDataValidationInvalid(e){return!this.getValidationResultForCell(e).isValid}getInvalidDataValidationMessage(e){const t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){const o=gO.get(e);return t.startsWith("=")?"onlyLiterals"===o.allowedValues?Fo("The value must not be a formula"):this.isValidFormula(t)?void 0:bx.CriterionError.validFormula:"onlyFormulas"===o.allowedValues?Fo("The value must be a formula"):o.isCriterionValueValid(t)?void 0:o.criterionValueErrorString}isCellValidCheckbox(e){if(!this.getters.isMainCellPosition(e))return!1;const t=this.getters.getValidationRuleForCell(e);return!(!t||"isBoolean"!==t.criterion.type)&&this.getValidationResultForCell(e).isValid}getValidationResultForCellValue(e,t){const o=this.getters.getValidationRuleForCell(t);if(!o)return PP;const s=this.getRuleErrorForCellValue(e,t,o);return s?{error:s,rule:o,isValid:!1}:PP}isValidFormula(e){return!hS(e).isBadExpression}getValidationResultForCell(e){const{col:t,row:o,sheetId:s}=e;return this.validationResults[s]||(this.validationResults[s]=this.computeSheetValidationResults(s)),this.validationResults[s][t]?.[o]?.()||PP}computeSheetValidationResults(e){const t={},o=this.getters.getDataValidationRules(e).map((e=>e.ranges));for(const e of Ur(o.flat())){const{col:o,row:s}=e;t[o]||(t[o]=[]),t[o][s]=ut((()=>{const t=this.getters.getEvaluatedCell(e);return t.type===ni.empty?PP:this.getValidationResultForCellValue(t.value,e)}))}return t}getRuleErrorForCellValue(e,t,o){const{sheetId:s}=t,i=o.criterion,n=gO.get(i.type),r=this.getCellOffsetInRule(t,o),a=this.getEvaluatedCriterionValues(s,r,i),l={...i,values:a};if(!n.isValueValid(e,l,this.getters,s))return n.getErrorString(l,this.getters,s)}getCellOffsetInRule(e,t){const o=t.ranges.find((t=>as(e.col,e.row,t.zone)));if(!o)throw new Error("The cell is not in any range of the rule");return{col:e.col-o.zone.left,row:e.row-o.zone.top}}getEvaluatedCriterionValues(e,t,o){return o.values.map((o=>{if(!o.startsWith("="))return o;const s=hS(o),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,s.tokens),n=this.getters.evaluateFormula(e,i);return n&&!Ci(n)?n.toString():""}))}}).add("dynamic_tables",class extends KM{static getters=["canCreateDynamicTableOnZones","doesZonesContainFilter","getFilter","getFilters","getTable","getTables","getTablesOverlappingZones","getFilterId","getFilterHeaders","isFilterHeader"];tables={};handle(e){if(ai.has(e.type)||"UPDATE_CELL"===e.type&&"content"in e||"EVALUATE_CELLS"===e.type)this.tables={};else switch(e.type){case"CREATE_TABLE":case"REMOVE_TABLE":case"UPDATE_TABLE":case"DELETE_CONTENT":this.tables={}}}finalize(){for(const e of this.getters.getSheetIds())this.tables[e]||(this.tables[e]=this.computeTables(e))}computeTables(e){const t=[],o=this.getters.getCoreTables(e);for(const e of o)"dynamic"!==e.type&&t.push(e);const s=[...t];for(const i of o){if("dynamic"!==i.type)continue;const o=this.coreTableToTable(e,i);let n=o.range.zone;for(const e of s)rs(n,e.range.zone)&&(n={...n,right:e.range.zone.left-1});t.push({...o,range:this.getters.getRangeFromZone(e,n)})}return t}getFilters(e){return this.getTables(e).filter((e=>e.config.hasFilters)).map((e=>e.filters)).flat()}getTables(e){return this.tables[e]||[]}getFilter(e){const t=this.getTable(e);if(t&&t.config.hasFilters)return t.filters.find((t=>t.col===e.col))}getFilterId(e){return this.getFilter(e)?.id}getTable({sheetId:e,col:t,row:o}){return this.getTables(e).find((e=>as(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getTables(e).filter((e=>t.some((t=>rs(e.range.zone,t)))))}doesZonesContainFilter(e,t){return this.getTablesOverlappingZones(e,t).some((e=>e.config.hasFilters))}getFilterHeaders(e){const t=[];for(const o of this.getTables(e)){if(!o.config.hasFilters)continue;const s=o.range.zone,i=s.top;for(let o=s.left;o<=s.right;o++)t.push({sheetId:e,col:o,row:i})}return t}isFilterHeader({sheetId:e,col:t,row:o}){return this.getFilterHeaders(e).some((e=>e.col===t&&e.row===o))}canCreateDynamicTableOnZones(e,t){if(!ys(t))return!1;const o=ss(...t),s={col:o.left,row:o.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(s);if(!i)return!1;if(mt(i,s)&&1===Ss(o))return!0;return mt(o,this.getters.getSpreadZone(i))}coreTableToTable(e,t){if("dynamic"!==t.type)return t;const o=t.range.zone,s={sheetId:e,col:o.left,row:o.top},i=this.getters.getSpreadZone(s)??t.range.zone,n=this.getters.getRangeFromZone(e,i),r=this.getDynamicTableFilters(e,t,i);return{id:t.id,range:n,filters:r,config:t.config}}getDynamicTableFilters(e,t,o){const s=[],{top:i,bottom:n,left:r,right:a}=o;for(let o=r;o<=a;o++){const a=o-r,l={left:o,right:o,top:i,bottom:n},c=EF(this.getDynamicTableFilterId(t.id,a),this.getters.getRangeFromZone(e,l),t.config,this.getters.getRangeFromZone);s.push(c)}return s}getDynamicTableFilterId(e,t){return e+"_"+t}exportForExcel(e){for(const t of e.sheets)for(const e of t.tables){const o=Yo(e.range),s={sheetId:t.id,col:o.left,row:o.top},i=this.getters.getCoreTable(s),n=this.getTable(s);"dynamic"===i?.type&&n&&(e.range=Jo(n.range.zone))}}}).add("custom_colors",class extends KM{customColors={};shouldUpdateColors=!0;static getters=["getCustomColors"];constructor(e){super(e),this.tryToAddColors(e.customColors??[])}handle(e){switch(e.type){case"START":for(const e of this.getters.getSheetIds())for(const t of this.getters.getChartIds(e))this.tryToAddColors(this.getChartColors(t));break;case"UPDATE_CHART":case"CREATE_CHART":this.tryToAddColors(this.getChartColors(e.id));break;case"UPDATE_CELL":case"ADD_CONDITIONAL_FORMAT":case"SET_BORDER":case"SET_ZONE_BORDERS":case"SET_FORMATTING":case"CREATE_TABLE":case"UPDATE_TABLE":this.history.update("shouldUpdateColors",!0)}}finalize(){this.shouldUpdateColors&&(this.history.update("shouldUpdateColors",!1),this.tryToAddColors(this.computeCustomColors()))}getCustomColors(){return function(e){const t=[{leadColor:Wt(255,0,0),colors:[]},{leadColor:Wt(255,128,0),colors:[]},{leadColor:Wt(128,128,0),colors:[]},{leadColor:Wt(128,255,0),colors:[]},{leadColor:Wt(0,255,0),colors:[]},{leadColor:Wt(0,255,128),colors:[]},{leadColor:Wt(0,255,255),colors:[]},{leadColor:Wt(0,127,255),colors:[]},{leadColor:Wt(0,0,255),colors:[]},{leadColor:Wt(127,0,255),colors:[]},{leadColor:Wt(128,0,128),colors:[]},{leadColor:Wt(255,0,128),colors:[]}];for(const o of e.map(Zt)){let e=500,s=0;t.forEach(((t,i)=>{const n=(r=o,a=t.leadColor,Math.sqrt(Math.pow(r.r-a.r,2)+Math.pow(r.g-a.g,2)+Math.pow(r.b-a.b,2)));var r,a;e>n&&(e=n,s=i)})),t[s].colors.push(o)}return t.map((e=>e.colors.sort(((e,t)=>Yt(e).s-Yt(t).s)))).flat().map(qt)}(Object.keys(this.customColors))}computeCustomColors(){let e=[];for(const t of this.getters.getSheetIds())e=e.concat(this.getColorsFromCells(t),this.getFormattingColors(t),this.getTableColors(t));return[...new Set([...e])]}getColorsFromCells(e){const t=Object.values(this.getters.getCells(e)),o=new Set;for(const e of t)e.style?.textColor&&o.add(e.style.textColor),e.style?.fillColor&&o.add(e.style.fillColor);for(const t of this.getters.getBordersColors(e))o.add(t);return[...o]}getFormattingColors(e){const t=this.getters.getConditionalFormats(e),o=[];for(const e of t){const t=e.rule;"CellIsRule"===t.type?(o.push(t.style.textColor),o.push(t.style.fillColor)):"ColorScaleRule"===t.type&&(o.push(Ht(t.minimum.color)),o.push(t.midpoint?Ht(t.midpoint.color):void 0),o.push(Ht(t.maximum.color)))}return o.filter(at)}getChartColors(e){const t=this.getters.getChart(e);if(void 0===t)return[];return[...JSON.stringify(t.getDefinition()).matchAll(MP)].map((e=>e[1]))}getTableColors(e){return this.getters.getTables(e).flatMap((e=>{const t=e.config,o=this.getters.getTableStyle(t.styleId);return[this.getTableStyleElementColors(o.wholeTable),t.numberOfHeaders>0?this.getTableStyleElementColors(o.headerRow):[],t.totalRow?this.getTableStyleElementColors(o.totalRow):[],t.bandedColumns?this.getTableStyleElementColors(o.firstColumnStripe):[],t.bandedColumns?this.getTableStyleElementColors(o.secondColumnStripe):[],t.bandedRows?this.getTableStyleElementColors(o.firstRowStripe):[],t.bandedRows?this.getTableStyleElementColors(o.secondRowStripe):[],t.firstColumn?this.getTableStyleElementColors(o.firstColumn):[],t.lastColumn?this.getTableStyleElementColors(o.lastColumn):[]].flat()}))}getTableStyleElementColors(e){return e?[e.style?.fillColor,e.style?.textColor,e.border?.bottom?.color,e.border?.top?.color,e.border?.left?.color,e.border?.right?.color,e.border?.horizontal?.color,e.border?.vertical?.color].filter(at):[]}tryToAddColors(e){for(const t of e){if(!zt(t))continue;const e=Bt(t);t&&!Q.includes(e)&&this.history.update("customColors",e,!0)}}}).add("pivot_ui",class extends KM{static getters=["getPivot","getFirstPivotFunction","getPivotIdFromPosition","getPivotCellFromPosition","generateNewCalculatedMeasureName","isPivotUnused","isSpillPivotFormula"];pivots={};unusedPivots;custom;constructor(e){super(e),this.custom=e.custom}beforeHandle(e){if("START"===e.type)for(const e of this.getters.getPivotIds())this.setupPivot(e)}handle(e){if(ai.has(e.type))for(const e of this.getters.getPivotIds())dF.get(this.getters.getPivotCoreDefinition(e).type).externalData||this.setupPivot(e,{recreate:!0});switch(e.type){case"REFRESH_PIVOT":this.refreshPivot(e.id);break;case"ADD_PIVOT":this.setupPivot(e.pivotId);break;case"DUPLICATE_PIVOT":this.setupPivot(e.newPivotId);break;case"UPDATE_PIVOT":this.setupPivot(e.pivotId,{recreate:!0});break;case"DELETE_SHEET":case"UPDATE_CELL":this.unusedPivots=void 0;break;case"UNDO":case"REDO":{this.unusedPivots=void 0;const t=e.commands.filter(VP);for(const e of t){const t=e.pivotId;this.getters.isExistingPivot(t)&&this.setupPivot(t,{recreate:!0})}break}case"UPDATE_LOCALE":!function(){for(const e in cF)cF[e].set.clear(),cF[e].values={}}()}}getPivotIdFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(o){const e=o.args[0]?.toString();return e&&this.getters.getPivotId(e)}}}isSpillPivotFormula(e){const t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){const o=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);return"PIVOT"===o?.functionName}return!1}getFirstPivotFunction(e,t){const o=CS(t);if(!o)return;const{functionName:s,args:i}=o;return{functionName:s,args:i.map((t=>{if("EMPTY"==t.type)return;if("STRING"===t.type||"BOOLEAN"===t.type||"NUMBER"===t.type)return t.value;const o=Mf(t);return this.getters.evaluateFormula(e,o)}))}}getPivotCellFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||0===wS(t.compiledFormula.tokens))return eF;const o=this.getters.getCellPosition(t.id),s=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!s)return eF;const{functionName:i,args:n}=s,r=n[0];if(!r)return eF;const a=this.getters.getPivotId(r.toString());if(!a)return eF;const l=this.getPivot(a);if(!l.isValid())return eF;if("PIVOT"===i&&!t.content.replaceAll(" ","").toUpperCase().startsWith("=PIVOT"))return eF;if("PIVOT"===i){const t=Ja(n[2]),s=void 0===t||Yi(t),i=Ja(n[3]),r=void 0===i||Yi(i),a=l.getTableStructure().getPivotCells(s,r),c=e.col-o.col,h=e.row-o.row;return a[c][h]}try{if("PIVOT.HEADER"===i&&"measure"===n.at(-2)){return{type:"MEASURE_HEADER",domain:l.parseArgsToPivotDomain(n.slice(1,-2).map((e=>({value:e})))),measure:n.at(-1)?.toString()||""}}if("PIVOT.HEADER"===i){return{type:"HEADER",domain:l.parseArgsToPivotDomain(n.slice(1).map((e=>({value:e}))))}}const[e,...t]=n.slice(1);return{type:"VALUE",domain:l.parseArgsToPivotDomain(t.map((e=>({value:e})))),measure:e?.toString()||""}}catch(e){return eF}}generateNewCalculatedMeasureName(e){const t=e.map((e=>e.fieldName));return Nt(Fo("Calculated measure 1"),t,{compute:(e,t)=>Fo("Calculated measure %s",t)})}getPivot(e){if(!this.getters.isExistingPivot(e))throw new Error(`pivot ${e} not found`);return this.pivots[e]}isPivotUnused(e){return this._getUnusedPivots().includes(e)}refreshPivot(e){this.getters.getPivot(e).init({reload:!0})}setupPivot(e,{recreate:t}={recreate:!1}){const o=this.getters.getPivotCoreDefinition(e);if(e in this.pivots)t&&this.pivots[e].onDefinitionChange(o);else{const t=kP(dF.get(o.type).ui);this.pivots[e]=new t(this.custom,{definition:o,getters:this.getters})}}_getUnusedPivots(){if(void 0!==this.unusedPivots)return this.unusedPivots;const e=new Set(this.getters.getPivotIds());for(const t of this.getters.getSheetIds())for(const o in this.getters.getCells(t)){const t=this.getters.getCellPosition(o),s=this.getPivotIdFromPosition(t);if(s&&(e.delete(s),!e.size))return this.unusedPivots=[],[]}return this.unusedPivots=[...e],this.unusedPivots}}),SN=new n;SN.add("link",{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t)=>Tn(t.model.getters.getEvaluatedCell(e).link,t),sequence:5});class yN{fileStore;constructor(e){this.fileStore=e}async requestImage(){const e=await this.getImageFromUser(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}getImageFromUser(){return new Promise(((e,t)=>{const o=document.createElement("input");o.setAttribute("type","file"),o.setAttribute("accept","image/*"),o.addEventListener("change",(async()=>{null===o.files||1!=o.files.length?t():e(o.files[0])})),o.click()}))}getImageOriginalSize(e){return new Promise(((t,o)=>{const s=new Image;s.src=e,s.addEventListener("load",(()=>{const e={width:s.width,height:s.height};t(e)})),s.addEventListener("error",o)}))}}const CN=[{transform:"scale(0)"},{transform:"scale(0.8)",offset:.33},{opacity:"0",transform:"scale(1)",offset:1}];Mc`
|
|
1857
1857
|
.o-ripple {
|
|
1858
1858
|
z-index: 1;
|
|
1859
1859
|
}
|
|
@@ -1973,7 +1973,7 @@
|
|
|
1973
1973
|
position: absolute;
|
|
1974
1974
|
cursor: pointer;
|
|
1975
1975
|
}
|
|
1976
|
-
`;class DN extends t.Component{static template="o-spreadsheet-SpreadsheetDashboard";static props={};static components={GridOverlay:SM,GridPopover:yM,Popover:OI,VerticalScrollBar:PM,HorizontalScrollBar:MM};cellPopovers;onMouseWheel;canvasPosition;hoveredCell;clickableCellsStore;setup(){const e=t.useRef("grid");this.canvasPosition=DI(e),this.hoveredCell=yc(EI),this.clickableCellsStore=yc(_N),t.useChildSubEnv({getPopoverContainerRect:()=>this.getGridRect()}),TM("canvas",this.env.model,(()=>this.env.model.getters.getSheetViewDimension())),this.onMouseWheel=AM(((e,t)=>{this.moveCanvas(e,t),this.hoveredCell.clear()})),this.cellPopovers=yc(II)}onCellHovered({col:e,row:t}){this.hoveredCell.hover({col:e,row:t})}get gridContainer(){const e=this.env.model.getters.getActiveSheetId(),{right:t}=this.env.model.getters.getSheetZone(e),{end:o}=this.env.model.getters.getColDimensions(e,t);return kc({"max-width":`${o}px`})}get gridOverlayDimensions(){return kc({height:"100%",width:"100%"})}getCellClickableStyle(e){return kc({top:`${e.y}px`,left:`${e.x}px`,width:`${e.width}px`,height:`${e.height}px`})}getClickableCells(){return t.toRaw(this.clickableCellsStore.clickableCells)}selectClickableCell(e){const{position:t,action:o}=e;o(t,this.env)}onClosePopover(){this.cellPopovers.close()}onGridResized({height:e,width:t}){this.env.model.dispatch("RESIZE_SHEETVIEW",{width:t,height:e,gridOffsetX:0,gridOffsetY:0})}moveCanvas(e,t){const{scrollX:o,scrollY:s}=this.env.model.getters.
|
|
1976
|
+
`;class DN extends t.Component{static template="o-spreadsheet-SpreadsheetDashboard";static props={};static components={GridOverlay:SM,GridPopover:yM,Popover:OI,VerticalScrollBar:PM,HorizontalScrollBar:MM};cellPopovers;onMouseWheel;canvasPosition;hoveredCell;clickableCellsStore;setup(){const e=t.useRef("grid");this.canvasPosition=DI(e),this.hoveredCell=yc(EI),this.clickableCellsStore=yc(_N),t.useChildSubEnv({getPopoverContainerRect:()=>this.getGridRect()}),TM("canvas",this.env.model,(()=>this.env.model.getters.getSheetViewDimension())),this.onMouseWheel=AM(((e,t)=>{this.moveCanvas(e,t),this.hoveredCell.clear()})),this.cellPopovers=yc(II)}onCellHovered({col:e,row:t}){this.hoveredCell.hover({col:e,row:t})}get gridContainer(){const e=this.env.model.getters.getActiveSheetId(),{right:t}=this.env.model.getters.getSheetZone(e),{end:o}=this.env.model.getters.getColDimensions(e,t);return kc({"max-width":`${o}px`})}get gridOverlayDimensions(){return kc({height:"100%",width:"100%"})}getCellClickableStyle(e){return kc({top:`${e.y}px`,left:`${e.x}px`,width:`${e.width}px`,height:`${e.height}px`})}getClickableCells(){return t.toRaw(this.clickableCellsStore.clickableCells)}selectClickableCell(e){const{position:t,action:o}=e;o(t,this.env)}onClosePopover(){this.cellPopovers.close()}onGridResized({height:e,width:t}){this.env.model.dispatch("RESIZE_SHEETVIEW",{width:t,height:e,gridOffsetX:0,gridOffsetY:0})}moveCanvas(e,t){const{scrollX:o,scrollY:s}=this.env.model.getters.getActiveSheetScrollInfo();this.env.model.dispatch("SET_VIEWPORT_OFFSET",{offsetX:o+e,offsetY:s+t})}getGridRect(){return{...this.canvasPosition,...this.env.model.getters.getSheetViewDimensionWithHeaders()}}}Mc`
|
|
1977
1977
|
.o-header-group {
|
|
1978
1978
|
.o-header-group-header {
|
|
1979
1979
|
z-index: ${Oe.HeaderGroupingButton};
|
|
@@ -3269,4 +3269,4 @@
|
|
|
3269
3269
|
<tableParts count="${e.tables.length}">
|
|
3270
3270
|
${Aw(a)}
|
|
3271
3271
|
</tableParts>
|
|
3272
|
-
`}var iL;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(iL||(iL={}));function nL(e,t={}){const o=Be(t);return o.type=e,o}const rL={},aL={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:ee,HEADER_WIDTH:te,BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:oe,DEFAULT_CELL_HEIGHT:se,SCROLLBAR_WIDTH:ie},lL={autoCompleteProviders:Rh,autofillModifiersRegistry:ES,autofillRulesRegistry:IS,cellMenuRegistry:jT,colMenuRegistry:V_,errorTypes:Ri,linkMenuRegistry:JI,functionRegistry:$b,featurePluginRegistry:fN,iconsOnCellRegistry:by,statefulUIPluginRegistry:vN,coreViewsPluginRegistry:bN,corePluginRegistry:mN,rowMenuRegistry:z_,sidePanelRegistry:HF,figureRegistry:mI,chartSidePanelComponentRegistry:BD,chartComponentRegistry:lI,chartRegistry:aI,chartSubtypeRegistry:hI,topbarMenuRegistry:W_,topbarComponentRegistry:UF,clickableCellRegistry:SN,otRegistry:G_,inverseCommandRegistry:SI,urlRegistry:wn,cellPopoverRegistry:FS,numberFormatMenuRegistry:H_,repeatLocalCommandTransformRegistry:dN,repeatCommandTransformRegistry:hN,clipboardHandlersRegistries:uc,pivotRegistry:dF,pivotTimeAdapterRegistry:Tl,pivotSidePanelRegistry:mF,pivotNormalizationValueRegistry:sc,supportedPivotPositionalFormulaRegistry:xS,pivotToFunctionValueRegistry:ic,migrationStepRegistry:Kw},cL={arg:Dh,isEvaluationError:ki,toBoolean:Yi,toJsDate:Xi,toNumber:Vi,toString:qi,toNormalizedPivotValue:Ql,toXC:yo,toZone:Yo,toUnboundedZone:jo,toCartesian:So,numberToLetters:fo,lettersToNumber:vo,UuidGenerator:aa,formatValue:Jn,createCurrencyFormat:ur,ColorGenerator:ho,computeTextWidth:jr,createEmptyWorkbookData:nx,createEmptySheet:ix,createEmptyExcelSheet:rx,rgbaToHex:qt,colorToRGBA:Zt,positionToZone:fs,isDefined:at,isMatrix:Ci,lazy:ut,genericRepeat:uN,createAction:i,createActions:o,transformRangeData:pc,deepEquals:mt,overlap:rs,union:ss,isInside:as,deepCopy:Be,expandZoneOnInsertion:Qo,reduceZoneOnDeletion:os,unquote:$e,getMaxObjectId:Gl,getFunctionsFromTokens:mS,getFirstPivotFunction:CS,getNumberOfPivotFunctions:wS,parseDimension:jl,isDateOrDatetimeField:Yl,makeFieldProposal:vS,insertTokenAfterArgSeparator:bS,insertTokenAfterLeftParenthesis:SS,mergeContiguousZones:Cs,getPivotHighlights:$_,pivotTimeAdapter:Al,UNDO_REDO_PIVOT_COMMANDS:LP,createPivotFormula:Jl,areDomainArgsFieldsValid:Kl,splitReference:qo,sanitizeSheetName:Ge,getUniqueText:Nt,isNumber:ti,isDateTime:Vs},hL={isMarkdownLink:Qe,parseMarkdownLink:ot,markdownLink:tt,openLink:Tn,urlRepresentation:Rn},dL={Checkbox:LI,Section:q_,RoundColorPicker:CD,ChartDataSeries:nD,ChartErrorSection:aD,ChartLabelRange:lD,ChartTitle:SD,ChartPanel:WD,ChartFigure:uI,ChartJsComponent:hh,Grid:UM,GridOverlay:SM,ScorecardChart:Ih,LineConfigPanel:ND,BarConfigPanel:hD,PieChartDesignPanel:kD,GenericChartConfigPanel:cD,ChartWithAxisDesignPanel:TD,GaugeChartConfigPanel:_D,GaugeChartDesignPanel:DD,ScorecardChartConfigPanel:VD,ScorecardChartDesignPanel:HD,RadarChartDesignPanel:LD,WaterfallChartDesignPanel:UD,ComboChartDesignPanel:AD,ChartTypePicker:zD,FigureComponent:BF,Menu:dR,Popover:OI,SelectionInput:iD,ValidationMessages:rD,AddDimensionButton:UO,PivotDimensionGranularity:WO,PivotDimensionOrder:GO,PivotDimension:$O,PivotLayoutConfigurator:jO,PivotDeferUpdate:HO,PivotTitleSection:YO,CogWheelMenu:zO,TextInput:BO,SidePanelCollapsible:uD,RadioSelection:ED},uL={useDragAndDropListItems:Y_,useHighlights:aO,useHighlightsOnHover:rO},gL={useStoreProvider:Sc,DependencyContainer:fc,CellPopoverStore:II,ComposerFocusStore:Dc,CellComposerStore:JF,FindAndReplaceStore:MO,HighlightStore:Xb,HoveredCellStore:EI,ModelStore:Ic,NotificationStore:Kb,RendererStore:Tc,SelectionInputStore:sD,SpreadsheetStore:Ac,useStore:yc,useLocalStore:Cc,SidePanelStore:kM,PivotSidePanelStore:gF,PivotMeasureDisplayPanelStore:LO};const pL={DEFAULT_LOCALE:Si,HIGHLIGHT_COLOR:a,PIVOT_TABLE_CONFIG:ke,ChartTerms:gx},mL={...SR,...HE};e.AbstractCellClipboardHandler=ua,e.AbstractChart=dh,e.AbstractFigureClipboardHandler=cc,e.CellErrorType=Ii,e.CorePlugin=zM,e.CoreViewPlugin=KM,e.DispatchResult=mi,e.EvaluationError=Ti,e.Model=class extends mc{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;coreViewPluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},o={},s=[],i=new aa,n=!1){const r=performance.now();console.debug("##### Model creation #####"),super(),_o===To&&Do===Ao&&(Do=()=>!0),s=ox(e,s);const a=tx(e,n);this.state=new nk,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new jM(this.coreGetters),this.coreGetters.getRangeString=this.range.getRangeString.bind(this.range),this.coreGetters.getRangeFromSheetXC=this.range.getRangeFromSheetXC.bind(this.range),this.coreGetters.createAdaptedRanges=this.range.createAdaptedRanges.bind(this.range),this.coreGetters.getRangeDataFromXc=this.range.getRangeDataFromXc.bind(this.range),this.coreGetters.getRangeDataFromZone=this.range.getRangeDataFromZone.bind(this.range),this.coreGetters.getRangeFromRangeData=this.range.getRangeFromRangeData.bind(this.range),this.coreGetters.getRangeFromZone=this.range.getRangeFromZone.bind(this.range),this.coreGetters.recomputeRanges=this.range.recomputeRanges.bind(this.range),this.coreGetters.isRangeValid=this.range.isRangeValid.bind(this.range),this.coreGetters.extendRange=this.range.extendRange.bind(this.range),this.coreGetters.getRangesUnion=this.range.getRangesUnion.bind(this.range),this.coreGetters.removeRangesSheetPrefix=this.range.removeRangesSheetPrefix.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new sk(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.coreViewPluginConfig=this.setupCoreViewPluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(let e of mN.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(let e of bN.getAll()){const t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(let e of vN.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(let e of fN.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t)}if(this.dispatch("START"),this.selection.observe(this,{handleEvent:()=>this.trigger("update")}),this.setupSessionEvents(),this.joinSession(),o.snapshotRequested||e["[Content_Types].xml"]&&!this.getters.isReadonly()){const e=performance.now();console.debug("Snapshot requested"),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug("Snapshot taken in",performance.now()-e,"ms")}t.markRaw(this),console.debug("Model created in",performance.now()-r,"ms"),console.debug("######")}joinSession(){this.session.join(this.config.client)}async leaveSession(){const e=this.getters.isReadonly()?void 0:ut((()=>this.exportData()));await this.session.leave(e)}setupUiPlugin(e){const t=new e(this.uiPluginConfig);for(let o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}for(const o of e.layers)this.renderers[o]||(this.renderers[o]=[]),this.renderers[o].push(t);return t}setupCoreViewPlugin(e){const t=new e(this.coreViewPluginConfig);for(let o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}return t}setupCorePlugin(e,t){const o=new e(this.corePluginConfig);for(let t of e.getters){if(!(t in o))throw new Error(`Invalid getter name: ${t} for plugin ${o.constructor}`);if(t in this.coreGetters)throw new Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=o[t].bind(o)}o.import(t),this.corePlugins.push(o),this.coreHandlers.push(o),this.handlers.push(o)}onRemoteRevisionReceived({commands:e}){for(let t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new QP(ek({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{this.checkDispatchAllowed(e).isSuccessful&&(this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1)}}),this.config.transportService,e)}setupSessionEvents(){this.session.on("remote-revision-received",this,this.onRemoteRevisionReceived),this.session.on("revision-undone",this,(({commands:e})=>{this.dispatchFromCorePlugin("UNDO",{commands:e}),this.finalize()})),this.session.on("revision-redone",this,(({commands:e})=>{this.dispatchFromCorePlugin("REDO",{commands:e}),this.finalize()})),this.session.on("unexpected-revision-id",this,(()=>this.trigger("unexpected-revision-id"))),this.session.on("collaborative-event-received",this,(()=>{this.trigger("update")}))}setupConfig(e){const t=e.client||{id:this.uuidGenerator.uuidv4(),name:Fo("Anonymous").toString()},o=e.transportService||new qN;return{...e,mode:e.mode||"normal",custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:o,client:t,moveClient:()=>{},snapshotRequested:!1,notifyUI:e=>this.trigger("notify-ui",e),raiseBlockingErrorUI:e=>this.trigger("raise-error-ui",{text:e}),customColors:e.customColors||[]}}setupExternalConfig(e){const t=e.loadLocales||(()=>Promise.resolve(bi));return{...e,loadLocales:t}}setupCorePluginConfig(){return{getters:this.coreGetters,stateObserver:this.state,range:this.range,dispatch:this.dispatchFromCorePlugin,canDispatch:this.canDispatch,custom:this.config.custom,external:this.config.external}}setupCoreViewPluginConfig(){return{getters:this.getters,stateObserver:this.state,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}setupUiPluginConfig(){return{getters:this.getters,stateObserver:this.state,dispatch:this.dispatch,canDispatch:this.canDispatch,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}checkDispatchAllowed(e){const t=pi(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new mi(t.flat()):mi.Success}checkDispatchAllowedCoreCommand(e){const t=this.corePlugins.map((t=>t.allowDispatch(e)));return t.push(this.range.allowDispatch(e)),t}checkDispatchAllowedLocalCommand(e){return this.uiHandlers.map((t=>t.allowDispatch(e)))}finalize(){this.status=3;for(const e of this.handlers)e.finalize();this.status=0,this.trigger("command-finalized")}canDispatch=(e,t)=>this.checkDispatchAllowed(nL(e,t));dispatch=(e,t)=>{const o=nL(e,t);let s=this.status;if(this.getters.isReadonly()&&(i=o,!ui.has(i.type)))return new mi("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new mi("WaitingSessionConfirmation");switch(s){case 0:const t=this.checkDispatchAllowed(o);if(!t.isSuccessful)return this.trigger("update"),t;this.status=1;const{changes:s,commands:i}=this.state.recordChanges((()=>{const t=performance.now();pi(o)&&this.state.addCommand(o),this.dispatchToHandlers(this.handlers,o),this.finalize();const s=performance.now()-t;s>5&&console.debug(e,s,"ms")}));this.session.save(o,i,s),this.status=0,this.trigger("update");break;case 1:if(pi(o)){const e=this.checkDispatchAllowed(o);if(!e.isSuccessful)return e;this.state.addCommand(o)}this.dispatchToHandlers(this.handlers,o);break;case 3:throw new Error("Cannot dispatch commands in the finalize state");case 2:if(pi(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return mi.Success};dispatchFromCorePlugin=(e,t)=>{const o=nL(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,mi.Success};dispatchToHandlers(e,t){const o=pi(t);for(const s of e)!o&&s instanceof zM||s.beforeHandle(t);for(const s of e)!o&&s instanceof zM||s.handle(t);this.trigger("command-dispatched",t)}drawLayer(e,t){const o=this.renderers[t];if(o)for(const s of o)e.ctx.save(),s.drawLayer(e,t),e.ctx.restore()}exportData(){let e=nx();for(let t of this.handlers)t instanceof zM&&t.export(e);return e.revisionId=this.session.getRevisionId()||Se,e=Be(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...nx(),sheets:[rx(ex,"Sheet1")]};for(let t of this.handlers)t instanceof BM&&t.exportForExcel(e);return e=Be(e),oL(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=XO,e.Registry=n,e.Revision=KP,e.SPREADSHEET_DIMENSIONS=aL,e.Spreadsheet=GN,e.SpreadsheetPivotTable=QO,e.UIPlugin=HP,e.__info__=rL,e.addFunction=function e(t,o){return $b.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(xi[e])throw new Error(`Layer ${e} already exists`);xi[e]=t},e.astToFormula=Mf,e.chartHelpers=mL,e.compile=hS,e.compileTokens=dS,e.components=dL,e.constants=pL,e.convertAstNodes=_f,e.coreTypes=gi,e.findCellInNewZone=ms,e.functionCache=cS,e.helpers=cL,e.hooks=uL,e.invalidateCFEvaluationCommands=hi,e.invalidateDependenciesCommands=ci,e.invalidateEvaluationCommands=ai,e.iterateAstNodes=Df,e.links=hL,e.load=tx,e.parse=Tf,e.parseTokens=Af,e.readonlyAllowedCommands=ui,e.registries=lL,e.setDefaultSheetViewSize=function(e){Fe=e},e.setTranslationMethod=function(e,t=(()=>!0)){_o=e,Do=t},e.stores=gL,e.tokenColors=eS,e.tokenize=fa,rL.version="18.2.0-alpha.5",rL.date="2025-01-31T07:59:30.667Z",rL.hash="efce841"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|
|
3272
|
+
`}var iL;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(iL||(iL={}));function nL(e,t={}){const o=Be(t);return o.type=e,o}const rL={},aL={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:ee,HEADER_WIDTH:te,BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:oe,DEFAULT_CELL_HEIGHT:se,SCROLLBAR_WIDTH:ie},lL={autoCompleteProviders:Rh,autofillModifiersRegistry:ES,autofillRulesRegistry:IS,cellMenuRegistry:jT,colMenuRegistry:V_,errorTypes:Ri,linkMenuRegistry:JI,functionRegistry:$b,featurePluginRegistry:fN,iconsOnCellRegistry:by,statefulUIPluginRegistry:vN,coreViewsPluginRegistry:bN,corePluginRegistry:mN,rowMenuRegistry:z_,sidePanelRegistry:HF,figureRegistry:mI,chartSidePanelComponentRegistry:BD,chartComponentRegistry:lI,chartRegistry:aI,chartSubtypeRegistry:hI,topbarMenuRegistry:W_,topbarComponentRegistry:UF,clickableCellRegistry:SN,otRegistry:G_,inverseCommandRegistry:SI,urlRegistry:wn,cellPopoverRegistry:FS,numberFormatMenuRegistry:H_,repeatLocalCommandTransformRegistry:dN,repeatCommandTransformRegistry:hN,clipboardHandlersRegistries:uc,pivotRegistry:dF,pivotTimeAdapterRegistry:Tl,pivotSidePanelRegistry:mF,pivotNormalizationValueRegistry:sc,supportedPivotPositionalFormulaRegistry:xS,pivotToFunctionValueRegistry:ic,migrationStepRegistry:Kw},cL={arg:Dh,isEvaluationError:ki,toBoolean:Yi,toJsDate:Xi,toNumber:Vi,toString:qi,toNormalizedPivotValue:Ql,toXC:yo,toZone:Yo,toUnboundedZone:jo,toCartesian:So,numberToLetters:fo,lettersToNumber:vo,UuidGenerator:aa,formatValue:Jn,createCurrencyFormat:ur,ColorGenerator:ho,computeTextWidth:jr,createEmptyWorkbookData:nx,createEmptySheet:ix,createEmptyExcelSheet:rx,rgbaToHex:qt,colorToRGBA:Zt,positionToZone:fs,isDefined:at,isMatrix:Ci,lazy:ut,genericRepeat:uN,createAction:i,createActions:o,transformRangeData:pc,deepEquals:mt,overlap:rs,union:ss,isInside:as,deepCopy:Be,expandZoneOnInsertion:Qo,reduceZoneOnDeletion:os,unquote:$e,getMaxObjectId:Gl,getFunctionsFromTokens:mS,getFirstPivotFunction:CS,getNumberOfPivotFunctions:wS,parseDimension:jl,isDateOrDatetimeField:Yl,makeFieldProposal:vS,insertTokenAfterArgSeparator:bS,insertTokenAfterLeftParenthesis:SS,mergeContiguousZones:Cs,getPivotHighlights:$_,pivotTimeAdapter:Al,UNDO_REDO_PIVOT_COMMANDS:LP,createPivotFormula:Jl,areDomainArgsFieldsValid:Kl,splitReference:qo,sanitizeSheetName:Ge,getUniqueText:Nt,isNumber:ti,isDateTime:Vs},hL={isMarkdownLink:Qe,parseMarkdownLink:ot,markdownLink:tt,openLink:Tn,urlRepresentation:Rn},dL={Checkbox:LI,Section:q_,RoundColorPicker:CD,ChartDataSeries:nD,ChartErrorSection:aD,ChartLabelRange:lD,ChartTitle:SD,ChartPanel:WD,ChartFigure:uI,ChartJsComponent:hh,Grid:UM,GridOverlay:SM,ScorecardChart:Ih,LineConfigPanel:ND,BarConfigPanel:hD,PieChartDesignPanel:kD,GenericChartConfigPanel:cD,ChartWithAxisDesignPanel:TD,GaugeChartConfigPanel:_D,GaugeChartDesignPanel:DD,ScorecardChartConfigPanel:VD,ScorecardChartDesignPanel:HD,RadarChartDesignPanel:LD,WaterfallChartDesignPanel:UD,ComboChartDesignPanel:AD,ChartTypePicker:zD,FigureComponent:BF,Menu:dR,Popover:OI,SelectionInput:iD,ValidationMessages:rD,AddDimensionButton:UO,PivotDimensionGranularity:WO,PivotDimensionOrder:GO,PivotDimension:$O,PivotLayoutConfigurator:jO,PivotDeferUpdate:HO,PivotTitleSection:YO,CogWheelMenu:zO,TextInput:BO,SidePanelCollapsible:uD,RadioSelection:ED},uL={useDragAndDropListItems:Y_,useHighlights:aO,useHighlightsOnHover:rO},gL={useStoreProvider:Sc,DependencyContainer:fc,CellPopoverStore:II,ComposerFocusStore:Dc,CellComposerStore:JF,FindAndReplaceStore:MO,HighlightStore:Xb,HoveredCellStore:EI,ModelStore:Ic,NotificationStore:Kb,RendererStore:Tc,SelectionInputStore:sD,SpreadsheetStore:Ac,useStore:yc,useLocalStore:Cc,SidePanelStore:kM,PivotSidePanelStore:gF,PivotMeasureDisplayPanelStore:LO};const pL={DEFAULT_LOCALE:Si,HIGHLIGHT_COLOR:a,PIVOT_TABLE_CONFIG:ke,ChartTerms:gx},mL={...SR,...HE};e.AbstractCellClipboardHandler=ua,e.AbstractChart=dh,e.AbstractFigureClipboardHandler=cc,e.CellErrorType=Ii,e.CorePlugin=zM,e.CoreViewPlugin=KM,e.DispatchResult=mi,e.EvaluationError=Ti,e.Model=class extends mc{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;coreViewPluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},o={},s=[],i=new aa,n=!1){const r=performance.now();console.debug("##### Model creation #####"),super(),_o===To&&Do===Ao&&(Do=()=>!0),s=ox(e,s);const a=tx(e,n);this.state=new nk,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new jM(this.coreGetters),this.coreGetters.getRangeString=this.range.getRangeString.bind(this.range),this.coreGetters.getRangeFromSheetXC=this.range.getRangeFromSheetXC.bind(this.range),this.coreGetters.createAdaptedRanges=this.range.createAdaptedRanges.bind(this.range),this.coreGetters.getRangeDataFromXc=this.range.getRangeDataFromXc.bind(this.range),this.coreGetters.getRangeDataFromZone=this.range.getRangeDataFromZone.bind(this.range),this.coreGetters.getRangeFromRangeData=this.range.getRangeFromRangeData.bind(this.range),this.coreGetters.getRangeFromZone=this.range.getRangeFromZone.bind(this.range),this.coreGetters.recomputeRanges=this.range.recomputeRanges.bind(this.range),this.coreGetters.isRangeValid=this.range.isRangeValid.bind(this.range),this.coreGetters.extendRange=this.range.extendRange.bind(this.range),this.coreGetters.getRangesUnion=this.range.getRangesUnion.bind(this.range),this.coreGetters.removeRangesSheetPrefix=this.range.removeRangesSheetPrefix.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new sk(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.coreViewPluginConfig=this.setupCoreViewPluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(let e of mN.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(let e of bN.getAll()){const t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(let e of vN.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(let e of fN.getAll()){const t=this.setupUiPlugin(e);this.handlers.push(t),this.uiHandlers.push(t)}if(this.dispatch("START"),this.selection.observe(this,{handleEvent:()=>this.trigger("update")}),this.setupSessionEvents(),this.joinSession(),o.snapshotRequested||e["[Content_Types].xml"]&&!this.getters.isReadonly()){const e=performance.now();console.debug("Snapshot requested"),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug("Snapshot taken in",performance.now()-e,"ms")}t.markRaw(this),console.debug("Model created in",performance.now()-r,"ms"),console.debug("######")}joinSession(){this.session.join(this.config.client)}async leaveSession(){const e=this.getters.isReadonly()?void 0:ut((()=>this.exportData()));await this.session.leave(e)}setupUiPlugin(e){const t=new e(this.uiPluginConfig);for(let o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}for(const o of e.layers)this.renderers[o]||(this.renderers[o]=[]),this.renderers[o].push(t);return t}setupCoreViewPlugin(e){const t=new e(this.coreViewPluginConfig);for(let o of e.getters){if(!(o in t))throw new Error(`Invalid getter name: ${o} for plugin ${t.constructor}`);if(o in this.getters)throw new Error(`Getter "${o}" is already defined.`);this.getters[o]=t[o].bind(t)}return t}setupCorePlugin(e,t){const o=new e(this.corePluginConfig);for(let t of e.getters){if(!(t in o))throw new Error(`Invalid getter name: ${t} for plugin ${o.constructor}`);if(t in this.coreGetters)throw new Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=o[t].bind(o)}o.import(t),this.corePlugins.push(o),this.coreHandlers.push(o),this.handlers.push(o)}onRemoteRevisionReceived({commands:e}){for(let t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new QP(ek({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{this.checkDispatchAllowed(e).isSuccessful&&(this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1)}}),this.config.transportService,e)}setupSessionEvents(){this.session.on("remote-revision-received",this,this.onRemoteRevisionReceived),this.session.on("revision-undone",this,(({commands:e})=>{this.dispatchFromCorePlugin("UNDO",{commands:e}),this.finalize()})),this.session.on("revision-redone",this,(({commands:e})=>{this.dispatchFromCorePlugin("REDO",{commands:e}),this.finalize()})),this.session.on("unexpected-revision-id",this,(()=>this.trigger("unexpected-revision-id"))),this.session.on("collaborative-event-received",this,(()=>{this.trigger("update")}))}setupConfig(e){const t=e.client||{id:this.uuidGenerator.uuidv4(),name:Fo("Anonymous").toString()},o=e.transportService||new qN;return{...e,mode:e.mode||"normal",custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:o,client:t,moveClient:()=>{},snapshotRequested:!1,notifyUI:e=>this.trigger("notify-ui",e),raiseBlockingErrorUI:e=>this.trigger("raise-error-ui",{text:e}),customColors:e.customColors||[]}}setupExternalConfig(e){const t=e.loadLocales||(()=>Promise.resolve(bi));return{...e,loadLocales:t}}setupCorePluginConfig(){return{getters:this.coreGetters,stateObserver:this.state,range:this.range,dispatch:this.dispatchFromCorePlugin,canDispatch:this.canDispatch,custom:this.config.custom,external:this.config.external}}setupCoreViewPluginConfig(){return{getters:this.getters,stateObserver:this.state,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}setupUiPluginConfig(){return{getters:this.getters,stateObserver:this.state,dispatch:this.dispatch,canDispatch:this.canDispatch,selection:this.selection,moveClient:this.session.move.bind(this.session),custom:this.config.custom,uiActions:this.config,session:this.session,defaultCurrency:this.config.defaultCurrency,customColors:this.config.customColors||[],external:this.config.external}}checkDispatchAllowed(e){const t=pi(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new mi(t.flat()):mi.Success}checkDispatchAllowedCoreCommand(e){const t=this.corePlugins.map((t=>t.allowDispatch(e)));return t.push(this.range.allowDispatch(e)),t}checkDispatchAllowedLocalCommand(e){return this.uiHandlers.map((t=>t.allowDispatch(e)))}finalize(){this.status=3;for(const e of this.handlers)e.finalize();this.status=0,this.trigger("command-finalized")}canDispatch=(e,t)=>this.checkDispatchAllowed(nL(e,t));dispatch=(e,t)=>{const o=nL(e,t);let s=this.status;if(this.getters.isReadonly()&&(i=o,!ui.has(i.type)))return new mi("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new mi("WaitingSessionConfirmation");switch(s){case 0:const t=this.checkDispatchAllowed(o);if(!t.isSuccessful)return this.trigger("update"),t;this.status=1;const{changes:s,commands:i}=this.state.recordChanges((()=>{const t=performance.now();pi(o)&&this.state.addCommand(o),this.dispatchToHandlers(this.handlers,o),this.finalize();const s=performance.now()-t;s>5&&console.debug(e,s,"ms")}));this.session.save(o,i,s),this.status=0,this.trigger("update");break;case 1:if(pi(o)){const e=this.checkDispatchAllowed(o);if(!e.isSuccessful)return e;this.state.addCommand(o)}this.dispatchToHandlers(this.handlers,o);break;case 3:throw new Error("Cannot dispatch commands in the finalize state");case 2:if(pi(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return mi.Success};dispatchFromCorePlugin=(e,t)=>{const o=nL(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,mi.Success};dispatchToHandlers(e,t){const o=pi(t);for(const s of e)!o&&s instanceof zM||s.beforeHandle(t);for(const s of e)!o&&s instanceof zM||s.handle(t);this.trigger("command-dispatched",t)}drawLayer(e,t){const o=this.renderers[t];if(o)for(const s of o)e.ctx.save(),s.drawLayer(e,t),e.ctx.restore()}exportData(){let e=nx();for(let t of this.handlers)t instanceof zM&&t.export(e);return e.revisionId=this.session.getRevisionId()||Se,e=Be(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...nx(),sheets:[rx(ex,"Sheet1")]};for(let t of this.handlers)t instanceof BM&&t.exportForExcel(e);return e=Be(e),oL(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=XO,e.Registry=n,e.Revision=KP,e.SPREADSHEET_DIMENSIONS=aL,e.Spreadsheet=GN,e.SpreadsheetPivotTable=QO,e.UIPlugin=HP,e.__info__=rL,e.addFunction=function e(t,o){return $b.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(xi[e])throw new Error(`Layer ${e} already exists`);xi[e]=t},e.astToFormula=Mf,e.chartHelpers=mL,e.compile=hS,e.compileTokens=dS,e.components=dL,e.constants=pL,e.convertAstNodes=_f,e.coreTypes=gi,e.findCellInNewZone=ms,e.functionCache=cS,e.helpers=cL,e.hooks=uL,e.invalidateCFEvaluationCommands=hi,e.invalidateDependenciesCommands=ci,e.invalidateEvaluationCommands=ai,e.iterateAstNodes=Df,e.links=hL,e.load=tx,e.parse=Tf,e.parseTokens=Af,e.readonlyAllowedCommands=ui,e.registries=lL,e.setDefaultSheetViewSize=function(e){Fe=e},e.setTranslationMethod=function(e,t=(()=>!0)){_o=e,Do=t},e.stores=gL,e.tokenColors=eS,e.tokenize=fa,rL.version="18.2.0-alpha.6",rL.date="2025-02-05T06:50:47.008Z",rL.hash="dae9ab2"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|