@odoo/o-spreadsheet 18.4.12 → 18.4.13
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 +25 -33
- package/dist/o-spreadsheet.d.ts +2 -0
- package/dist/o-spreadsheet.esm.js +25 -33
- package/dist/o-spreadsheet.iife.js +25 -33
- package/dist/o-spreadsheet.iife.min.js +6 -14
- package/dist/o_spreadsheet.xml +21 -4
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
!function(e,t){"use strict";function o(e){return e.map(i).sort(((e,t)=>e.sequence-t.sequence))}let s=1;function i(e){const t=e.name,o=e.children,n=e.description,r=e.icon,a=e.secondaryIcon,l=e.id||s++,c=e.isEnabled?e.isEnabled:()=>!0;return{id:l.toString(),name:"function"==typeof t?t:()=>t,isVisible:e.isVisible?e.isVisible:()=>!0,isEnabled:c,isActive:e.isActive,execute:e.execute?(t,o)=>{if(c(t))return e.execute(t,o)}:void 0,children:o?e=>o.map((t=>"function"==typeof t?t(e):t)).flat().map(i):()=>[],isReadonlyAllowed:e.isReadonlyAllowed||!1,separator:e.separator||!1,icon:"function"==typeof r?r:()=>r||"",iconColor:e.iconColor,secondaryIcon:"function"==typeof a?a:()=>a||"",description:"function"==typeof n?n:()=>n||"",textColor:e.textColor,sequence:e.sequence||0,onStartHover:e.onStartHover,onStopHover:e.onStopHover}}class n{content={};add(e,t){if(e in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){return this.content[e]=t,this}get(e){const t=this.content[e];if(!t&&!(e in this.content))throw new Error(`Cannot find ${e} in this registry!`);return t}contains(e){return e in this.content}getAll(){return Object.values(this.content)}getKeys(){return Object.keys(this.content)}remove(e){delete this.content[e]}}const r=.5,a="#017E84",l="#f5f5f5",c="#F8F9FA",h="#E8EAED",d="#595959",u="#666666",g="#c9ccd2",p="#3266ca",m="#FFFFFF",f="#CACACA",v=11982760,b=a,S="#188038",C="#E0E2E4",y="#4A4F59",w="#999",I="#E2E3E3",x="#BCBCBC",E="#9B359B",R="#00000000",T="#4EA7F2",A="#EA6175",D="#AAAAAA",_="#111827",O="#D8DADD",F="#E7E9ED",P="#F9FAFB",M="#374151",N=M+"C2",k="#111827",V="#714B67",L=F,H=O,U="#111827",B="#e6f2f3",z="#111827",$=a,G="#D44C591A",W="#C34A41",q="#98DBE2",Z="#E6F2F3",j=20,Y=10,X=15,K=16,J=12,Q="#F28C28",ee=["#000000","#434343","#666666","#999999","#B7B7B7","#CCCCCC","#D9D9D9","#EFEFEF","#F3F3F3","#FFFFFF","#980000","#FF0000","#FF9900","#FFFF00","#00FF00","#00FFFF","#4A86E8","#0000FF","#9900FF","#FF00FF","#E6B8AF","#F4CCCC","#FCE5CD","#FFF2CC","#D9EAD3","#D0E0E3","#C9DAF8","#CFE2F3","#D9D2E9","#EAD1DC","#DD7E6B","#EA9999","#F9CB9C","#FFE599","#B6D7A8","#A2C4C9","#A4C2F4","#9FC5E8","#B4A7D6","#D5A6BD","#CC4125","#E06666","#F6B26B","#FFD966","#93C47D","#76A5AF","#6D9EEB","#6FA8DC","#8E7CC3","#C27BA0","#A61C00","#CC0000","#E69138","#F1C232","#6AA84F","#45818E","#3C78D8","#3D85C6","#674EA7","#A64D79","#85200C","#990000","#B45F06","#BF9000","#38761D","#134F5C","#1155CC","#0B5394","#351C75","#741B47","#5B0F00","#660000","#783F04","#7F6000","#274E13","#0C343D","#1C4587","#073763","#20124D","#4C1130"],te=26,oe=48,se=96,ie=23,ne=15,re=4,ae=3,le=re,ce=21,he=2*ie,de={align:"left",verticalAlign:"bottom",wrapping:"overflow",bold:!1,italic:!1,strikethrough:!1,underline:!1,fontSize:10,fillColor:"",textColor:""},ue=de.verticalAlign,ge=de.wrapping,pe="400",me=de.fontSize,fe="'Roboto', arial",ve="thin",be="#000000",Se="START_REVISION",Ce=1,ye=20,we="??",Ie="difference",xe="#43C5B1",Ee="#EA6175",Re=.4,Te=3,Ae=2,De=["'","*","?","/","\\","[","]"],_e=/'|\*|\?|\/|\\|\[|\]/,Oe="|";var Fe;!function(e){e[e.Grid=0]="Grid",e[e.Highlight=5]="Highlight",e[e.HeaderGroupingButton=6]="HeaderGroupingButton",e[e.Figure=10]="Figure",e[e.ScrollBar=15]="ScrollBar",e[e.GridPopover=19]="GridPopover",e[e.GridComposer=20]="GridComposer",e[e.IconPicker=25]="IconPicker",e[e.TopBarComposer=30]="TopBarComposer",e[e.Popover=35]="Popover",e[e.FigureAnchor=1e3]="FigureAnchor",e[e.FigureSnapLine=1001]="FigureSnapLine",e[e.FigureTooltip=1002]="FigureTooltip"}(Fe||(Fe={}));let Pe=0;function Me(){return Pe}const Ne="\n",ke=[6,7,8,9,10,11,12,14,18,24,36],Ve={hasFilters:!1,totalRow:!1,firstColumn:!0,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,styleId:"TableStyleMedium5",automaticAutofill:!1},Le={symbol:"$",position:"before",decimalPlaces:2,code:"",name:"Dollar"},He=new RegExp(_e,"g");function Ue(e){return'"'===e[0]&&(e=e.slice(1)),'"'===e[e.length-1]&&"\\"!==e[e.length-2]?e.slice(0,e.length-1):e}function Be(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function ze(e){switch(typeof e){case"object":{if(null===e)return e;if(function(e){return"clone"in e&&e.clone instanceof Function}(e))return e.clone();if(!(function(e){return"object"==typeof e&&null!==e&&(e?.constructor===Object||void 0===e?.constructor)}(e)||e instanceof Array))throw new Error("Unsupported type: only objects and arrays are supported");const t=Array.isArray(e)?new Array(e.length):{};if(Array.isArray(e))for(let o=0,s=e.length;o<s;o++)o in e&&(t[o]=ze(e[o]));else for(const o in e)t[o]=ze(e[o]);return t}case"number":case"string":case"boolean":case"function":case"undefined":return e;default:throw new Error("Unsupported type: "+typeof e)}}function $e(e){return Ge(e,"'")}function Ge(e,t='"'){return e.startsWith(t)&&(e=e.slice(1)),e.endsWith(t)&&(e=e.slice(0,-1)),e}function We(e){return e.match(/\w/g)?.length!==e.length&&(e=`'${e}'`),e}function qe(e,t=" "){return e.replace(He,t)}function Ze(e,t,o){return e<t?t:e>o?o:e}function je(e,t,o=1){if(t<=e&&o>0)return[];if(0===o)throw new Error("range() step must not be zero");const s=Math.ceil(Math.abs((t-e)/o)),i=Array(s);for(let t=0;t<s;t++)i[t]=e+t*o;return i}function Ye(e){return e.reduce(((e,t,o,s)=>{if(1===Math.abs(t-s[o-1])){e[e.length-1].push(t)}else e.push([t]);return e}),[])}function*Xe(e,t){t.next();for(const o of e){const e=t.next();yield{...o,next:e.done?void 0:e.value}}}function Ke(e){const t=e.toUpperCase();return"TRUE"===t||"FALSE"===t}const Je=/^\[(.+)\]\((.+)\)$/,Qe=/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)$/;function et(e){return Je.test(e)}function tt(e){return Qe.test(e)}function ot(e,t){return`[${e}](${t})`}function st(e){const t=e.match(Je)||[],o=t[1],s=t[2];if(!o||!s)throw new Error(`Could not parse markdown link ${e}.`);return{label:o,url:s}}const it="o-spreadsheet://";function nt(e){return e.startsWith(it)}function rt(e){return`${it}${e}`}function at(e){if(e.startsWith(it))return e.slice(it.length);throw new Error(`${e} is not a valid sheet link`)}function lt(e){return void 0!==e}function ct(e){return void 0===e||Object.values(e).every((e=>"object"==typeof e?ct(e):!e))}function ht(e,t,o){let s;const i=function(){const i=this,n=Array.from(arguments);const r=o&&!s;clearTimeout(s),s=setTimeout((function(){s=void 0,o||e.apply(i,n)}),t),r&&e.apply(i,n)};return i.isDebouncePending=()=>void 0!==s,i.stopDebounce=()=>{clearTimeout(s)},i}function dt(e){let t="";for(let o=0,s=e.length;o<s;o++)t+=e[o];return t}function ut(e){let t,o=!1;const s=()=>(o||(t=e instanceof Function?e():e,o=!0),t);return s.map=e=>ut((()=>e(s()))),s}function gt(e,t){let o=e.slice(t).find((e=>e));return o||(o=e.slice(0,t).reverse().find((e=>e))),o||""}function pt(e,t){return"after"===e?t+1:t}function mt(e,t){if(e===t)return!0;if(e&&!t||t&&!e)return!1;if(typeof e!=typeof t)return!1;if("object"!=typeof e)return!1;for(const o in t)if(!(o in e)&&void 0!==t[o])return!1;for(const o in e){if(typeof e[o]!=typeof t[o])return!1;if("object"==typeof e[o]){if(!mt(e[o],t[o]))return!1}else if(e[o]!==t[o])return!1}return!0}function ft(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++)if(!mt(e[o],t[o]))return!1;return!0}function vt(e,t){if(e.length<t.length)return!1;const o=new Set(e);return t.every((e=>o.has(e)))}function bt(e){if(!e)return e;const t={...e};return Object.keys(t).forEach((e=>!t[e]&&delete t[e])),t}const St=["\t","\f","\v",String.fromCharCode(parseInt("00a0",16)),String.fromCharCode(parseInt("1680",16)),String.fromCharCode(parseInt("2000",16)),String.fromCharCode(parseInt("200a",16)),String.fromCharCode(parseInt("2028",16)),String.fromCharCode(parseInt("2029",16)),String.fromCharCode(parseInt("202f",16)),String.fromCharCode(parseInt("205f",16)),String.fromCharCode(parseInt("3000",16)),String.fromCharCode(parseInt("feff",16))],Ct=new RegExp(St.join("|"),"g"),yt=/(\r\n|\r)/g,wt=St.concat([" "]);function It(e){return e?e.replace(yt,Ne):""}function xt(e){const t=Array.from(e).sort(((e,t)=>e-t));for(let e=1;e<t.length;e++)if(t[e]-t[e-1]!=1)return!1;return!0}function Et(e){const t=new Map,o=e.name?e.name+" (memoized)":"memoized";return{[o]:(...o)=>(t.has(o[0])||t.set(o[0],e(...o)),t.get(o[0]))}[o]}function Rt(e,t){const o=new Set(t),s=[];for(let t=0;t<e.length;t++)o.has(t)||s.push(e[t]);return s}function Tt(e,t,o){const s=[...e];return s.splice(o,0,...t),s}function At(e,t,o){const s=[...e];return s[o]=t,s}function Dt(e){return e.split("\n").map((e=>e.replace(/\s+/g," ").trim())).join("\n")}function _t(e,t,o){return t>o?_t(e,o,t):e>=t&&e<=o}function Ot(e,t){let o=Be(e);const s=t.matchCase?"":"i";return t.exactMatch&&(o=`^${o}$`),RegExp(o,s)}function Ft(e){let t=e.length;if(t<1e5)return Math.max(...e);let o=-1/0;for(;t--;)o=e[t]>o?e[t]:o;return o}function Pt(e){let t=e.length;if(t<1e5)return Math.min(...e);let o=1/0;for(;t--;)o=e[t]<o?e[t]:o;return o}class Mt{text;currentIndex=0;current;constructor(e){this.text=e,this.current=e[0]}shift(){const e=this.current,t=this.text[++this.currentIndex];return this.current=t,e}advanceBy(e){this.currentIndex+=e,this.current=this.text[this.currentIndex]}isOver(){return this.currentIndex>=this.text.length}remaining(){return this.text.substring(this.currentIndex)}currentStartsWith(e){if(this.current!==e[0])return!1;for(let t=1;t<e.length;t++)if(this.text[this.currentIndex+t]!==e[t])return!1;return!0}}function Nt(e,t=(e=>e)){const o=new Set;return e.filter((e=>{const s=t(e);return!o.has(s)&&(o.add(s),!0)}))}function kt(e){const t={};for(const o in e)for(const s in e[o])t[s]||(t[s]={}),t[s][o]=e[o][s];return t}function Vt(e,t,o={}){const s=o.compute??((e,t)=>`${e} (${t})`),i=o.computeFirstOne??!1;let n=o.start??1,r=i?s(e,n):e;for(;t.includes(r);)r=s(e,n++);return r}function Lt(e){return e.startsWith("=")||e.startsWith("+")}const Ht=/rgba?\(|\s+|\)/gi,Ut=/^#([A-F\d]{2}){3,4}$/,Bt=["#eb6d00","#0074d9","#ad8e00","#169ed4","#b10dc9","#00a82d","#00a3a3","#f012be","#3d9970","#111111","#62A300","#ff4136","#949494","#85144b","#001f3f"];function zt(e,t=1){const o=1!==t?Math.round(255*t).toString(16).padStart(2,"0"):"";return Gt(e.toString(16).padStart(6,"0"))+o}function $t(e){return"number"==typeof e?e:Number.parseInt(Gt(e).slice(1,7),16)}function Gt(e){let t=e;if(e.startsWith("rgb")?t=function(e){const t=e.replace(Ht,"").split(",");let o=255;if(3!==t.length&&4!==t.length)throw new Error("invalid color");if(4===t.length){const e=parseFloat(t.pop()||"1");if(isNaN(e))throw new Error("invalid alpha value");o=Math.round(255*e)}const s=t.map((e=>parseInt(e,10)));255!==o&&s.push(o);return"#"+dt(s.map((e=>e.toString(16).padStart(2,"0")))).toUpperCase()}(e):(t=e.replace("#","").toUpperCase(),3!==t.length&&4!==t.length||(t=t.split("").reduce(((e,t)=>e+t+t),"")),t=`#${t}`),!Ut.test(t))throw new Error(`invalid color input: ${e}`);return t}function Wt(e){try{return Gt(e),!0}catch(e){return!1}}const qt=e=>e>=0&&e<=255;function Zt(e,t,o,s=1){if(!qt(e)||!qt(t)||!qt(o)||s<0||s>1)throw new Error(`Invalid RGBA values ${[e,t,o,s]}`);return{a:s,b:o,g:t,r:e}}function jt(e){let{r:t,g:o,b:s}=Xt(e);t/=255,o/=255,s/=255;const i=e=>e<=.03928?e/12.92:((e+.055)/1.055)**2.4;return.2126*i(t)+.7152*i(o)+.0722*i(s)}function Yt(e){let t=e.r.toString(16),o=e.g.toString(16),s=e.b.toString(16),i=Math.round(255*e.a).toString(16);return 1===t.length&&(t="0"+t),1===o.length&&(o="0"+o),1===s.length&&(s="0"+s),1===i.length&&(i="0"+i),"ff"===i&&(i=""),("#"+t+o+s+i).toUpperCase()}function Xt(e){let t,o,s,i;if(7===(e=Gt(e)).length)t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=255;else{if(9!==e.length)throw new Error("Invalid color");t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=parseInt(e[7]+e[8],16)}return i=+(i/255).toFixed(3),{a:i,r:t,g:o,b:s}}function Kt(e){(e={...e}).s/=100,e.l/=100;const t=(1-Math.abs(2*e.l-1))*e.s,o=t*(1-Math.abs(e.h/60%2-1)),s=e.l-t/2;let i=0,n=0,r=0;return 0<=e.h&&e.h<60?(i=t,n=o,r=0):60<=e.h&&e.h<120?(i=o,n=t,r=0):120<=e.h&&e.h<180?(i=0,n=t,r=o):180<=e.h&&e.h<240?(i=0,n=o,r=t):240<=e.h&&e.h<300?(i=o,n=0,r=t):300<=e.h&&e.h<360&&(i=t,n=0,r=o),i=Math.round(255*(i+s)),n=Math.round(255*(n+s)),r=Math.round(255*(r+s)),{a:e.a,r:i,g:n,b:r}}function Jt(e){const t=e.r/255,o=e.g/255,s=e.b/255,i=Math.min(t,o,s),n=Math.max(t,o,s),r=n-i;let a=0,l=0,c=0;return a=0===r?0:n===t?(o-s)/r%6:n===o?(s-t)/r+2:(t-o)/r+4,a=Math.round(60*a),a<0&&(a+=360),c=(n+i)/2,l=0===r?0:r/(1-Math.abs(2*c-1)),l=+(100*l).toFixed(1),c=+(100*c).toFixed(1),{a:e.a,h:a,s:l,l:c}}function Qt(e){return Yt(Kt(e))}function eo(e){return Jt(Xt(e))}function to(e){return Xt("number"==typeof e?zt(e):e)}function oo(e,t){return 1===t?Gt(e).slice(0,7):Yt({...Xt(e),a:t})}function so(e,t){const o=eo(e);return 1===t?"#fff":(o.l=t*(100-o.l)+o.l,Qt(o))}function io(e,t){const o=eo(e);return 1===t?"#000":(o.s=Math.min(100,t*o.s+o.s),o.l=o.l-t*o.l,Qt(o))}function no(e){return jt(e)<.6?so(e,.9):io(e,.75)}const ro=["#4EA7F2","#EA6175","#43C5B1","#F4A261","#8481DD","#FFD86D"],ao=["#4EA7F2","#3188E6","#43C5B1","#00A78D","#EA6175","#CE4257","#F4A261","#F48935","#8481DD","#5752D1","#FFD86D","#FFBC2C"],lo=["#4EA7F2","#3188E6","#056BD9","#A76DBC","#7F4295","#6D2387","#EA6175","#CE4257","#982738","#43C5B1","#00A78D","#0E8270","#F4A261","#F48935","#BE5D10","#8481DD","#5752D1","#3A3580","#A4A8B6","#7E8290","#545B70","#FFD86D","#FFBC2C","#C08A16"],co=["#4EA7F2","#3188E6","#056BD9","#155193","#A76DBC","#7F4295","#6D2387","#4F1565","#EA6175","#CE4257","#982738","#791B29","#43C5B1","#00A78D","#0E8270","#105F53","#F4A261","#F48935","#BE5D10","#7D380D","#8481DD","#5752D1","#3A3580","#26235F","#A4A8B6","#7E8290","#545B70","#3F4250","#FFD86D","#FFBC2C","#C08A16","#936A12"],ho=["#4EA7F2","#43C5B1","#EA6175","#F4A261","#8481DD","#FFD86D","#3188E6","#00A78D","#CE4257","#F48935","#5752D1","#FFBC2C"],uo=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16"],go=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16","#155193","#4F1565","#791B29","#105F53","#7D380D","#26235F","#3F4250","#936A12"];function po(e,t){return t[e%t.length]}function mo(e){return e<=6?ro:e<=12?ao:e<=24?lo:co}class fo{preferredColors;currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=mo(e).filter((e=>!t.includes(e)))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:po(this.currentColorIndex++,this.palette)}}class vo extends fo{constructor(e,t=[]){var o;super(e,t),this.palette=(o=e,o<=6?ro:o<=12?ho:o<=24?uo:go).filter((e=>!t.includes(e)))}}class bo{availableColors;colors={};constructor(e=12){this.availableColors=new vo(e)}get(e){return this.colors[e]||(this.colors[e]=this.availableColors.next()),this.colors[e]}}function So(e){if(e.length<2)throw new Error("Color scale must have at least 2 points");const t=[...e.sort(((e,t)=>e.value-t.value))],o=[];for(let e=1;e<t.length;e++){const s=to(t[e-1].color).a,i=to(t[e].color).a,n=$t(t[e-1].color),r=$t(t[e].color);o.push({min:t[e-1].value,max:t[e].value,minColor:n,maxColor:r,minColorAlpha:s,maxColorAlpha:i,colorDiff:Co(t[e-1].value,t[e].value,n,r)})}return e=>{if(e<o[0].min)return zt(o[0].minColor,o[0].minColorAlpha);for(const t of o)if(e>=t.min&&e<=t.max)return zt(yo(e,t.min,t.minColor,t.colorDiff),t.maxColorAlpha);return zt(o[o.length-1].maxColor,o[o.length-1].maxColorAlpha)}}function Co(e,t,o,s){const i=t-e;return[((o>>16)%256-(s>>16)%256)/i,((o>>8)%256-(s>>8)%256)/i,(o%256-s%256)/i]}function yo(e,t,o,s){const[i,n,r]=s;return Math.round((o>>16)%256-i*(e-t))<<16|Math.round((o>>8)%256-n*(e-t))<<8|Math.round(o%256-r*(e-t))}function wo(e){if(e<0)throw new Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):wo(Math.floor(e/26)-1)+wo(e%26)}function Io(e){let t=0;const o=e.length;for(let s=0;s<o;s++){t=26*t+xo(e[s])}return t-1}function xo(e){const t=e.charCodeAt(0);return t>=65&&t<=90?t-64:t-96}function Eo(e){return e>="A"&&e<="Z"||e>="a"&&e<="z"}function Ro(e){return e>="0"&&e<="9"}const To=Io("ZZZ"),Ao=9999998;function Do(e){for(;" "===e.current;)e.advanceBy(1)}function _o(e){if("$"===e.current&&e.advanceBy(1),!e.current||!Eo(e.current))return-1;let t=0;for(;e.current&&Eo(e.current);)t=26*t+xo(e.shift());return t}function Oo(e){if("$"===e.current&&e.advanceBy(1),!e.current||!Ro(e.current))return-1;let t=0;for(;e.current&&Ro(e.current);)t=10*t+Number(e.shift());return t}function Fo(e){const t=new Mt(e);Do(t);const o=_o(t);if(-1===o||!t.current)throw new Error(`Invalid cell description: ${e}`);const s=Oo(t);Do(t);const i=o-1,n=s-1;if(!t.isOver()||i>To||n>Ao)throw new Error(`Invalid cell description: ${e}`);return{col:i,row:n}}function Po(e,t,o={colFixed:!1,rowFixed:!1}){return(o.colFixed?"$":"")+wo(e)+(o.rowFixed?"$":"")+String(t+1)}const Mo=e=>e,No=()=>!1;let ko=Mo,Vo=No;function Lo(e,...t){if(1!==t.length||"object"!=typeof t[0]||t[0]instanceof String)t.length>0&&(e=e.replace(/\%s/g,(()=>t.shift())));else{const o=t[0];e=e.replace(/\%\(([^\)]+)\)s/g,((e,t)=>o[t]))}return e}const Ho=function(e,...t){return Vo()?Lo(ko(e),...t):new Uo(e,t)};class Uo extends String{values;constructor(e,t){super(e),this.values=t}valueOf(){const e=super.valueOf();return Vo()?Lo(ko(e),...this.values):Lo(e,...this.values)}toString(){return this.valueOf()}}function Bo(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}const zo=new n;function $o(e,t){return{url:e=Bo(e),label:t||e,isExternal:!0,isUrlEditable:!0}}zo.add("sheet_URL",{match:e=>nt(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){const o=at(e);return t.tryGetSheetName(o)||Ho("Invalid sheet")},open(e,t){const o=at(e);t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:o}).isCancelledBecause("SheetIsHidden")&&t.notifyUser({type:"warning",sticky:!1,text:Ho("Cannot open the link because the linked sheet is hidden.")})},sequence:0});const Go={createLink:$o,match:e=>tt(e),open:e=>window.open(e,"_blank"),urlRepresentation:e=>e,sequence:0};function Wo(e){return zo.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((t=>t.match(e)))||Go}function qo(e,t){return Wo(e.url).urlRepresentation(e.url,t)}function Zo(e,t,o){Wo(e.url).open(e.url,t,o)}function jo(e){if("string"==typeof e){if(et(e)){const{label:t,url:o}=st(e);return Wo(o).createLink(o,t)}return tt(e)?$o(e):void 0}}class Yo{jsDate;constructor(e,t,o,s=0,i=0,n=0){this.jsDate=new Date(Date.UTC(e,t,o,s,i,n,0))}static fromTimestamp(e){const t=new Date(e);return new Yo(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds())}static now(){const e=new Date;return new Yo(e.getFullYear(),e.getMonth(),e.getDate(),e.getHours(),e.getMinutes(),e.getSeconds())}toString(){return this.jsDate.toString()}toLocaleDateString(){return this.jsDate.toLocaleDateString()}getTime(){return this.jsDate.getTime()}getFullYear(){return this.jsDate.getUTCFullYear()}getMonth(){return this.jsDate.getUTCMonth()}getQuarter(){return Math.floor(this.getMonth()/3)+1}getDate(){return this.jsDate.getUTCDate()}getDay(){return this.jsDate.getUTCDay()}getHours(){return this.jsDate.getUTCHours()}getMinutes(){return this.jsDate.getUTCMinutes()}getSeconds(){return this.jsDate.getUTCSeconds()}getIsoWeek(){const e=new Date(this.jsDate.getTime()),t=e.getUTCDay()||7;e.setUTCDate(e.getUTCDate()+4-t);const o=new Date(Date.UTC(e.getUTCFullYear(),0,1));return Math.ceil(((e.getTime()-o.getTime())/864e5+1)/7)}setFullYear(e){return this.jsDate.setUTCFullYear(e)}setMonth(e){return this.jsDate.setUTCMonth(e)}setDate(e){return this.jsDate.setUTCDate(e)}setHours(e){return this.jsDate.setUTCHours(e)}setMinutes(e){return this.jsDate.setUTCMinutes(e)}setSeconds(e){return this.jsDate.setUTCSeconds(e)}}const Xo=new Yo(1899,11,30),Ko=864e5,Jo=2e3,Qo=Yo.now().getFullYear(),es=Yo.now().getMonth(),ts=Yo.fromTimestamp(0).getTime()-Xo.getTime(),os=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,ss=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,is=wt.join(""),ns=new RegExp(`/|-|${wt.join("|")}`),rs=new RegExp(`^(\\d{1,4})[/${is}-](\\d{1,4})([/${is}-](\\d{1,4}))?$`),as=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function ls(e,t){switch(typeof e){case"number":return e;case"string":return cs(e,t)?ds(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function cs(e,t){return null!==ds(e,t)}const hs=new Map;function ds(e,t){return hs.has(t)||hs.set(t,new Map),hs.get(t).has(e)||hs.get(t).set(e,function(e,t){e=e.trim();let o=null;const s=e.match(as);if(s){if(o=function(e){if(e=e.trim(),as.test(e)){const t=/AM/i.test(e),o=/PM/i.test(e),s=(t||o?e.substring(0,e.length-2).trim():e).split(/:/),i=s.length>=2,n=3===s.length;let r=Number(s[0]),a=i?Number(s[1]):0,l=n?Number(s[2]):0,c=n?"hh:mm:ss":"hh:mm";if(t||o)c+=" a";else if(!i)return null;r>=12&&t?r-=12:r<12&&o&&(r+=12),a+=Math.floor(l/60),l%=60,r+=Math.floor(a/60),a%=60,r>=24&&(c="hhhh:mm:ss");return{value:r/24+a/1440+l/86400,format:c,jsDate:new Yo(1899,11,30,r,a,l)}}return null}(s[0]),null===o)return null;e=e.replace(s[0],"").trim()}let i=null;const n=function(e,t){const o=e.match(rs);if(!o)return null;const[,s,i,,n]=o;if(s.length>2&&n&&n.length>2)return null;if(s.length>2)return{year:s,month:i,day:n,dateString:e,type:"ymd"};const r=function(e){switch(e.dateFormat[0]){case"d":return"dmy";case"m":return"mdy";case"y":return"ymd"}throw new Error("Invalid date format in locale")}(t);if(!n)return i.length>2?{month:s,year:i,day:void 0,dateString:e,type:r}:"dmy"===r?{day:s,month:i,year:n,dateString:e,type:"dmy"}:{month:s,day:i,year:n,dateString:e,type:"mdy"};if(n.length>2)return"mdy"===r?{month:s,day:i,year:n,dateString:e,type:"mdy"}:{day:s,month:i,year:n,dateString:e,type:"dmy"};if("mdy"===r)return{month:s,day:i,year:n,dateString:e,type:"mdy"};if("ymd"===r)return{year:s,month:i,day:n,dateString:e,type:"ymd"};if("dmy"===r)return{day:s,month:i,year:n,dateString:e,type:"dmy"};return null}(e,t);if(n){const t=n.dateString.match(ns)[0];if(i=function(e,t){const{year:o,month:s,day:i}=e,n=function(e){if(!e)return es;const t=Number(e);if(t>=1&&t<=12)return t-1;return null}(s),r=function(e){if(!e)return 1;const t=Number(e);if(t>=0&&t<=31)return t;return null}(i),a=function(e){if(!e)return Qo;const t=Number(e);switch(e.length){case 1:return Jo+t;case 2:return Jo+(Jo+t>Qo+10?-100:0)+t;case 3:case 4:return t}return null}(o);if(null===a||null===n||null===r)return null;const l=2===s?.length&&n+1<10||2===i?.length&&r<10,c=2!==o?.length,h=new Yo(a,n,r);if(h.getMonth()!==n||h.getDate()!==r)return null;const d=h.getTime()-Xo.getTime(),u=function(e,t,o,s){const i=e.year?s?"yyyy":"yy":void 0,n=e.month?o?"mm":"m":void 0,r=e.day?o?"dd":"d":void 0;switch(e.type){case"mdy":return[n,r,i].filter(lt).join(t);case"ymd":return[i,n,r].filter(lt).join(t);case"dmy":return[r,n,i].filter(lt).join(t)}}(e,t,l,c);return{value:Math.round(d/Ko),format:u,jsDate:h}}(n,t),null===i)return null;e=e.replace(n.dateString,"").trim()}if(""!==e||!i&&!o)return null;if(i&&i.jsDate&&o&&o.jsDate)return{value:i.value+o.value,format:i.format+" "+("hhhh:mm:ss"===o.format?"hh:mm:ss":o.format),jsDate:new Yo(i.jsDate.getFullYear()+o.jsDate.getFullYear()-1899,i.jsDate.getMonth()+o.jsDate.getMonth()-11,i.jsDate.getDate()+o.jsDate.getDate()-30,i.jsDate.getHours()+o.jsDate.getHours(),i.jsDate.getMinutes()+o.jsDate.getMinutes(),i.jsDate.getSeconds()+o.jsDate.getSeconds())};return i||o}(e,t)),hs.get(t).get(e)}function us(e){const t=Math.trunc(e),o=Yo.fromTimestamp(t*Ko-ts);let s=e-t;s=s<0?1+s:s;const i=Math.round(24*s),n=Math.round(24*(s-i/24)*60),r=Math.round(24*(s-i/24-n/24/60)*60*60);return o.setHours(i),o.setMinutes(n),o.setSeconds(r),o}function gs(e){return Math.round(ps(e))}function ps(e){return(e.getTime()-Xo.getTime())/Ko}function ms(e){return new Yo(e.getFullYear(),e.getMonth()+1,0).getDate()}function fs(e){return ms(e)===e.getDate()}function vs(e,t,o){const s=e.getFullYear(),i=e.getMonth(),n=e.getDate(),r=new Yo(s,i+t,1);return o&&n===ms(e)||n>ms(r)?r.setDate(ms(r)):r.setDate(n),r}function bs(e){const t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function Ss(e,t,o){if(e===t)return 0;if(e>t){const o=t;t=e,e=o}const s=us(e),i=us(t);let n=s.getDate(),r=i.getDate();const a=s.getMonth(),l=i.getMonth(),c=s.getFullYear(),h=i.getFullYear();let d=0,u=0;switch(o){case 0:31===n&&(n=30),30===n&&31===r&&(r=30),1===a&&n===(bs(c)?29:28)&&(n=30,1===l&&r===(bs(h)?29:28)&&(r=30)),d=c+(30*a+n)/360,u=h+(30*l+r)/360;break;case 1:let o=365;const s=c===h;if(!s&&!(c+1===h)||!s&&a<l||!s&&a===l&&n<r){let e=0,t=0;for(let o=c;o<=h;o++)e++,t+=bs(o)?366:365;o=t/e}else s?bs(c)&&(o=366):(bs(c)&&a<2&&(o=366),bs(h)&&(l>1||1===l&&29===r)&&(o=366));d=e/o,u=t/o;break;case 2:d=e/360,u=t/360;break;case 3:d=e/365,u=t/365;break;case 4:31===n&&(n=30),31===r&&(r=30),d=c+(30*a+n)/360,u=h+(30*l+r)/360}return u-d}function Cs(e,t){const o=12*(t.getFullYear()-e.getFullYear())+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?o-1:o}function ys(e,t){const o=e.getTime(),s=t.getTime();return Math.floor((s-o)/Ko)}function ws(e,t){const o=t.getFullYear()-e.getFullYear(),s=e.getMonth(),i=t.getMonth(),n=e.getDate(),r=t.getDate();return i>s||i===s&&r>=n?o:o-1}function Is(e,t,o){return t>o?Is(e,o,t):(e=Math.trunc(e),t=Math.trunc(t),o=Math.trunc(o),e>=t&&e<=o)}const xs=Et((function(e){return e=Be(e),new RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e(\\+|-)?\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)})),Es=Et((function(e){const t=Be(e.decimalSeparator),o="(?:\\s*"+`(?:\\d+(?:${Be(e.thousandsSeparator||"")}\\d{3,})*(?:${t}\\d*)?)`+"|"+`(?:${t}\\d+)`+")(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?",s="(?:\\s*-)?",i="(?:\\s*[\\$€])?",n="^(?:(?:"+[s+i+o,s+o+i,i+s+o].join(")|(?:")+"))$";return new RegExp(n,"i")}));function Rs(e,t){return!!e&&Es(t).test(e.trim())}const Ts=Et((function(e){return new RegExp(`[$€${Be(e.thousandsSeparator||"")}]`,"g")}));function As(e,t){e=e.replace(Ts(t),""),"."!==t.decimalSeparator&&(e=e.replace(t.decimalSeparator,"."));let o=Number(e);return isNaN(o)&&e.includes("%")&&(o=Number(e.split("%")[0]),!isNaN(o))?o/100:o}function Ds(e,t,o){const s=[...e].sort(((e,t)=>e-t));let i=(s.length+(o?-1:1))*t;if(o||i--,Number.isInteger(i))return s[i];const n=Math.ceil(i),r=Math.floor(i);return s[n]*(i-r)+s[r]*(n-i)}var _s,Os;!function(e){e.boolean="boolean",e.number="number",e.text="text",e.empty="empty",e.error="error"}(_s||(_s={})),function(e){e.PlainText="text/plain",e.Html="text/html",e.Image="image"}(Os||(Os={}));const Fs=new Set(["RENAME_SHEET","DELETE_SHEET","CREATE_SHEET","DUPLICATE_SHEET","ADD_COLUMNS_ROWS","REMOVE_COLUMNS_ROWS","UNDO","REDO","ADD_MERGE","REMOVE_MERGE","DUPLICATE_SHEET","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]),Ps=new Set(["EVALUATE_CELLS","EVALUATE_CHARTS","UPDATE_CELL","UNHIDE_COLUMNS_ROWS","HIDE_COLUMNS_ROWS","GROUP_HEADERS","UNGROUP_HEADERS","FOLD_ALL_HEADER_GROUPS","FOLD_HEADER_GROUP","FOLD_HEADER_GROUPS_IN_ZONE","UNFOLD_ALL_HEADER_GROUPS","UNFOLD_HEADER_GROUP","UNFOLD_HEADER_GROUPS_IN_ZONE","UPDATE_TABLE","UPDATE_FILTER","UNDO","REDO"]),Ms=new Set(["MOVE_RANGES"]),Ns=new Set(["EVALUATE_CELLS","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY"]),ks=new Set(["AUTOFILL_CELL","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET"]),Vs=new Set(["START","ACTIVATE_SHEET","COPY","RESIZE_SHEETVIEW","SET_VIEWPORT_OFFSET","EVALUATE_CELLS","EVALUATE_CHARTS","SET_FORMULA_VISIBILITY","UPDATE_FILTER","UPDATE_CHART"]),Ls=new Set(["UPDATE_CELL","UPDATE_CELL_POSITION","CLEAR_CELL","CLEAR_CELLS","DELETE_CONTENT","ADD_COLUMNS_ROWS","REMOVE_COLUMNS_ROWS","RESIZE_COLUMNS_ROWS","HIDE_COLUMNS_ROWS","UNHIDE_COLUMNS_ROWS","SET_GRID_LINES_VISIBILITY","UNFREEZE_COLUMNS","UNFREEZE_ROWS","FREEZE_COLUMNS","FREEZE_ROWS","UNFREEZE_COLUMNS_ROWS","ADD_MERGE","REMOVE_MERGE","CREATE_SHEET","DELETE_SHEET","DUPLICATE_SHEET","MOVE_SHEET","RENAME_SHEET","COLOR_SHEET","HIDE_SHEET","SHOW_SHEET","MOVE_RANGES","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY","CREATE_FIGURE","DELETE_FIGURE","UPDATE_FIGURE","SET_FORMATTING","CLEAR_FORMATTING","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET","CREATE_CHART","UPDATE_CHART","CREATE_TABLE","REMOVE_TABLE","UPDATE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE","CREATE_IMAGE","GROUP_HEADERS","UNGROUP_HEADERS","UNFOLD_HEADER_GROUP","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","UNFOLD_HEADER_GROUPS_IN_ZONE","FOLD_HEADER_GROUPS_IN_ZONE","ADD_DATA_VALIDATION_RULE","REMOVE_DATA_VALIDATION_RULE","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]);function Hs(e){return Ls.has(e.type)}class Us{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter((e=>"Success"!==e))}static get Success(){return Bs}get isSuccessful(){return 0===this.reasons.length}isCancelledBecause(e){return this.reasons.includes(e)}}const Bs=new Us;var zs;e.CommandResult=void 0,(zs=e.CommandResult||(e.CommandResult={})).Success="Success",zs.CancelledForUnknownReason="CancelledForUnknownReason",zs.WillRemoveExistingMerge="WillRemoveExistingMerge",zs.CannotMoveTableHeader="CannotMoveTableHeader",zs.MergeIsDestructive="MergeIsDestructive",zs.CellIsMerged="CellIsMerged",zs.InvalidTarget="InvalidTarget",zs.EmptyUndoStack="EmptyUndoStack",zs.EmptyRedoStack="EmptyRedoStack",zs.NotEnoughElements="NotEnoughElements",zs.NotEnoughSheets="NotEnoughSheets",zs.MissingSheetName="MissingSheetName",zs.UnchangedSheetName="UnchangedSheetName",zs.DuplicatedSheetName="DuplicatedSheetName",zs.DuplicatedSheetId="DuplicatedSheetId",zs.ForbiddenCharactersInSheetName="ForbiddenCharactersInSheetName",zs.WrongSheetMove="WrongSheetMove",zs.WrongSheetPosition="WrongSheetPosition",zs.InvalidAnchorZone="InvalidAnchorZone",zs.SelectionOutOfBound="SelectionOutOfBound",zs.TargetOutOfSheet="TargetOutOfSheet",zs.WrongCutSelection="WrongCutSelection",zs.WrongPasteSelection="WrongPasteSelection",zs.WrongPasteOption="WrongPasteOption",zs.WrongFigurePasteOption="WrongFigurePasteOption",zs.EmptyClipboard="EmptyClipboard",zs.EmptyRange="EmptyRange",zs.InvalidRange="InvalidRange",zs.InvalidZones="InvalidZones",zs.InvalidSheetId="InvalidSheetId",zs.InvalidCellId="InvalidCellId",zs.InvalidFigureId="InvalidFigureId",zs.InputAlreadyFocused="InputAlreadyFocused",zs.MaximumRangesReached="MaximumRangesReached",zs.MinimumRangesReached="MinimumRangesReached",zs.InvalidChartDefinition="InvalidChartDefinition",zs.InvalidDataSet="InvalidDataSet",zs.InvalidLabelRange="InvalidLabelRange",zs.InvalidScorecardKeyValue="InvalidScorecardKeyValue",zs.InvalidScorecardBaseline="InvalidScorecardBaseline",zs.InvalidGaugeDataRange="InvalidGaugeDataRange",zs.EmptyGaugeRangeMin="EmptyGaugeRangeMin",zs.GaugeRangeMinNaN="GaugeRangeMinNaN",zs.EmptyGaugeRangeMax="EmptyGaugeRangeMax",zs.GaugeRangeMaxNaN="GaugeRangeMaxNaN",zs.GaugeLowerInflectionPointNaN="GaugeLowerInflectionPointNaN",zs.GaugeUpperInflectionPointNaN="GaugeUpperInflectionPointNaN",zs.InvalidAutofillSelection="InvalidAutofillSelection",zs.MinBiggerThanMax="MinBiggerThanMax",zs.LowerBiggerThanUpper="LowerBiggerThanUpper",zs.MidBiggerThanMax="MidBiggerThanMax",zs.MinBiggerThanMid="MinBiggerThanMid",zs.FirstArgMissing="FirstArgMissing",zs.SecondArgMissing="SecondArgMissing",zs.MinNaN="MinNaN",zs.MidNaN="MidNaN",zs.MaxNaN="MaxNaN",zs.ValueUpperInflectionNaN="ValueUpperInflectionNaN",zs.ValueLowerInflectionNaN="ValueLowerInflectionNaN",zs.MinInvalidFormula="MinInvalidFormula",zs.MidInvalidFormula="MidInvalidFormula",zs.MaxInvalidFormula="MaxInvalidFormula",zs.ValueUpperInvalidFormula="ValueUpperInvalidFormula",zs.ValueLowerInvalidFormula="ValueLowerInvalidFormula",zs.InvalidSortAnchor="InvalidSortAnchor",zs.InvalidSortZone="InvalidSortZone",zs.SortZoneWithArrayFormulas="SortZoneWithArrayFormulas",zs.WaitingSessionConfirmation="WaitingSessionConfirmation",zs.MergeOverlap="MergeOverlap",zs.TooManyHiddenElements="TooManyHiddenElements",zs.Readonly="Readonly",zs.InvalidViewportSize="InvalidViewportSize",zs.InvalidScrollingDirection="InvalidScrollingDirection",zs.ViewportScrollLimitsReached="ViewportScrollLimitsReached",zs.FigureDoesNotExist="FigureDoesNotExist",zs.InvalidConditionalFormatId="InvalidConditionalFormatId",zs.InvalidCellPopover="InvalidCellPopover",zs.EmptyTarget="EmptyTarget",zs.InvalidFreezeQuantity="InvalidFreezeQuantity",zs.FrozenPaneOverlap="FrozenPaneOverlap",zs.ValuesNotChanged="ValuesNotChanged",zs.InvalidFilterZone="InvalidFilterZone",zs.TableNotFound="TableNotFound",zs.TableOverlap="TableOverlap",zs.InvalidTableConfig="InvalidTableConfig",zs.InvalidTableStyle="InvalidTableStyle",zs.FilterNotFound="FilterNotFound",zs.MergeInTable="MergeInTable",zs.NonContinuousTargets="NonContinuousTargets",zs.DuplicatedFigureId="DuplicatedFigureId",zs.InvalidSelectionStep="InvalidSelectionStep",zs.DuplicatedChartId="DuplicatedChartId",zs.ChartDoesNotExist="ChartDoesNotExist",zs.InvalidHeaderIndex="InvalidHeaderIndex",zs.InvalidQuantity="InvalidQuantity",zs.MoreThanOneColumnSelected="MoreThanOneColumnSelected",zs.EmptySplitSeparator="EmptySplitSeparator",zs.SplitWillOverwriteContent="SplitWillOverwriteContent",zs.NoSplitSeparatorInSelection="NoSplitSeparatorInSelection",zs.NoActiveSheet="NoActiveSheet",zs.InvalidLocale="InvalidLocale",zs.MoreThanOneRangeSelected="MoreThanOneRangeSelected",zs.NoColumnsProvided="NoColumnsProvided",zs.ColumnsNotIncludedInZone="ColumnsNotIncludedInZone",zs.DuplicatesColumnsSelected="DuplicatesColumnsSelected",zs.InvalidHeaderGroupStartEnd="InvalidHeaderGroupStartEnd",zs.HeaderGroupAlreadyExists="HeaderGroupAlreadyExists",zs.UnknownHeaderGroup="UnknownHeaderGroup",zs.UnknownDataValidationRule="UnknownDataValidationRule",zs.UnknownDataValidationCriterionType="UnknownDataValidationCriterionType",zs.InvalidDataValidationCriterionValue="InvalidDataValidationCriterionValue",zs.InvalidNumberOfCriterionValues="InvalidNumberOfCriterionValues",zs.InvalidCopyPasteSelection="InvalidCopyPasteSelection",zs.NoChanges="NoChanges",zs.InvalidInputId="InvalidInputId",zs.SheetIsHidden="SheetIsHidden",zs.InvalidTableResize="InvalidTableResize",zs.PivotIdNotFound="PivotIdNotFound",zs.PivotInError="PivotInError",zs.EmptyName="EmptyName",zs.ValueCellIsInvalidFormula="ValueCellIsInvalidFormula",zs.InvalidDefinition="InvalidDefinition",zs.InvalidColor="InvalidColor",zs.InvalidPivotDataSet="InvalidPivotDataSet";const $s=new Set(["containsText","notContainsText","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","beginsWithText","endsWithText","isNotEmpty","isEmpty","isNotEqual","isEqual"]),Gs=new Set(["containsText","notContainsText","isEqualText","isEmail","isLink","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","dateIsValid","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isBoolean","isValueInList","isValueInRange","customFormula"]),Ws=[{name:"English (US)",code:"en_US",thousandsSeparator:",",decimalSeparator:".",weekStart:7,dateFormat:"m/d/yyyy",timeFormat:"hh:mm:ss a",formulaArgSeparator:","},{name:"French",code:"fr_FR",thousandsSeparator:" ",decimalSeparator:",",weekStart:1,dateFormat:"dd/mm/yyyy",timeFormat:"hh:mm:ss",formulaArgSeparator:";"}],qs=Ws[0],Zs=["thin","medium","thick","dashed","dotted"];function js(e){return Array.isArray(e)&&Array.isArray(e[0])}var Ys;!function(e){e.UP="up",e.DOWN="down",e.LEFT="left",e.RIGHT="right"}(Ys||(Ys={}));const Xs={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},Ks=Et((()=>Object.keys(Xs).sort(((e,t)=>Xs[e]-Xs[t]))));new Set(["containsText","notContainsText","isEqualText","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","customFormula","beginsWithText","endsWithText","isNotEmpty","isEmpty"]);const Js=["containsText","notContainsText","isEqualText","isEmpty","isNotEmpty","beginsWithText","endsWithText"],Qs=["isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isEmpty","isNotEmpty"],ei=["dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEmpty","isNotEmpty"],ti={NotAvailable:"#N/A",InvalidReference:"#REF",BadExpression:"#BAD_EXPR",CircularDependency:"#CYCLE",UnknownFunction:"#NAME?",DivisionByZero:"#DIV/0!",SpilledBlocked:"#SPILL!",GenericError:"#ERROR",NullError:"#NULL!"},oi=new Set(Object.values(ti));class si{message;value;constructor(e=Ho("Error"),t=ti.GenericError){this.message=e,this.value=t,this.message=e.toString()}}class ii extends si{constructor(e=Ho("Invalid expression")){super(e,ti.BadExpression)}}class ni extends si{constructor(e=Ho("Circular reference")){super(e,ti.CircularDependency)}}class ri extends si{constructor(e=Ho("Invalid reference")){super(e,ti.InvalidReference)}}class ai extends si{constructor(e=Ho("Data not available")){super(e,ti.NotAvailable)}}class li extends si{constructor(e=Ho("Unknown function")){super(e,ti.UnknownFunction)}}class ci extends si{constructor(e=Ho("Spill range is not empty")){super(e,ti.SpilledBlocked)}}class hi extends si{constructor(e=Ho("Division by zero")){super(e,ti.DivisionByZero)}}const di=["number","string","boolean","undefined"];function ui(e){if(void 0!==e)return js(e)?e[0][0]?.format:e.format}function gi(e){return"string"==typeof e&&oi.has(e)}function pi(e){return{value:ti.NotAvailable,message:Ho("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",wi(e))}}const mi=e=>Ho("The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.",e);function fi(e,t){const o=Ti(e);switch(typeof o){case"number":return o;case"boolean":return o?1:0;case"string":if(Rs(o,t)||""===o)return As(o,t);const e=ds(o,t);if(e)return e.value;throw new si(mi(o));default:return 0}}function vi(e,t){try{return fi(e,t)}catch(e){return}}function bi(e,t){return ji(e).map((e=>e.map((e=>{if("number"!=typeof e.value)throw new si(Ho("Function [[FUNCTION_NAME]] expects number values for %s, but got a %s.",t,typeof e.value));return e.value}))))}function Si(e,t){const o=Ti(e);if(""===o)throw new si(mi(o));return fi(o,t)}function Ci(e,t){return Math.trunc(fi(e,t))}function yi(e,t){return Math.trunc(Si(e,t))}function wi(e){const t=Ti(e);switch(typeof t){case"string":return t;case"number":return t.toString();case"boolean":return t?"TRUE":"FALSE";default:return""}}const Ii=Et((function(e){return e.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g,"")})),xi=e=>Ho("The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.",e);function Ei(e){const t=Ti(e);switch(typeof t){case"boolean":return t;case"string":if(t){const e=t.toUpperCase();if("TRUE"===e)return!0;if("FALSE"===e)return!1;throw new si(xi(t))}return!1;case"number":return!!t;default:return!1}}function Ri(e,t){return us(fi(Ti(e),t))}function Ti(e){if("object"==typeof e&&null!==e&&"value"in e){if(gi(e.value))throw e;return e.value}if(gi(e))throw new si("",e);return e}function Ai(e,t,o){for(const s of e)if(js(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)t(s[o][i])}else o(s)}function Di(e,t){Ai(e,(e=>{if(gi(e.value))throw e;t(e)}),(e=>{if(gi(e?.value))throw e;t(e)}))}function _i(e,t,o){Ai(e,(e=>{if("number"==typeof e?.value&&t(e),gi(e?.value))throw e}),(e=>{t({value:Si(e,o),format:e?.format})}))}function Oi(e,t,o,s,i="rowFirst"){let n=s;for(const s of e)if(js(s)){const e=s.length,o=s[0].length;if("rowFirst"===i)for(let i=0;i<o;i++)for(let o=0;o<e;o++)n=t(n,s[o][i]);else for(let i=0;i<e;i++)for(let e=0;e<o;e++)n=t(n,s[i][e])}else n=o(n,s);return n}function Fi(e,t,o,s="rowFirst"){return Oi(e,t,t,o,s)}function Pi(e,t,o,s){return Oi(e,((e,o)=>{const s=o?.value;if("number"==typeof s)return t(e,s);if(gi(s))throw o;return e}),((e,o)=>t(e,Si(o,s))),o)}function Mi(e,t,o,s){return Oi(e,((e,o)=>{const i=o?.value;if(null!=i){if("number"==typeof i)return t(e,i);if("boolean"==typeof i)return t(e,fi(i,s));if(gi(i))throw o;return t(e,0)}return e}),((e,o)=>t(e,fi(o,s))),o)}function Ni(e,t,o){const s=Array(e);for(let i=0;i<e;i++){s[i]=Array(t);for(let e=0;e<t;e++)s[i][e]=o(i,e)}return s}function ki(e,t){return 0===e.length?[]:Ni(e.length,e[0].length,((o,s)=>t(e[o][s])))}function Vi(e){return e.length?Ni(e[0].length,e.length,((t,o)=>e[o][t])):[]}function Li(e,t,o=void 0){let s,i=1,n=1,r=1/0,a=1/0;for(let e=0;e<t.length;e++){const l=t[e];if(js(l)&&(void 0===o||o[e])){const o=l.length,c=l[0].length;1!==o||1!==c?(s??=new Array(t.length),1!==o&&1!==c?(s[e]="matrix",i=Math.max(i,o),n=Math.max(n,c),r=Math.min(r,o),a=Math.min(a,c)):1!==o?(s[e]="horizontal",i=Math.max(i,o),r=Math.min(r,o)):1!==c&&(s[e]="vertical",n=Math.max(n,c),a=Math.min(a,c))):t[e]=l[0][0]}}if(1===i&&1===n)return e(...t);return Ni(i,n,((o,i)=>{if(o>r-1||i>a-1)return new ai(Ho("Array arguments to [[FUNCTION_NAME]] are of different size."));const n=e(...(l=o,c=i,t.map(((e,t)=>{switch(s?.[t]){case"matrix":return e[l][c];case"horizontal":return e[l][0];case"vertical":return e[0][c];case void 0:return e}}))));var l,c;return js(n)?n[0][0]:n}))}function Hi(e,t){return function(e,t,o){for(const s of e)if(js(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)if(!t(s[o][i]??void 0))return}else if(!o(s))return}(e,(e=>{const o=e?.value;if("boolean"==typeof o)return t(o);if("number"==typeof o)return t(!!o);if(gi(o))throw e;return!0}),(e=>void 0===e||null===e.value||t(function(e){const t=Ti(e);if(""===t)throw new si(xi(t));return Ei(t)}(e))))}function Ui(e,t){let o,s,i=e.substring(0,2);return"<="===i||">="===i||"<>"===i?(o=i,s=e.substring(2)):(i=e.substring(0,1),"<"===i||">"===i||"="===i?(o=i,s=e.substring(1)):(o="=",s=e)),Rs(s,t)||cs(s,t)?s=fi(s,t):"TRUE"!==s&&"FALSE"!==s||(s=Ei(s)),{operator:o,operand:s}}const Bi=Et((function(e){if("*"===e)return/.+/;let t="",o="";for(const s of e)"?"===s&&"~"!==o?t+=".":"*"===s&&"~"!==o?t+=".*":("*"!==s&&"?"!==s||(t=t.slice(0,-1)),["^",".","[","]","$","(",")","*","+","?","|","{","}","\\"].includes(s)&&(t+="\\"),t+=s),o=s;return new RegExp("^"+t+"$","i")}));function zi(e="",t,o){const{operator:s,operand:i}=t;if(void 0===i||null===e||null===i)return!1;if("number"==typeof i&&"="===s)return"string"==typeof e&&(Rs(e,o)||cs(e,o))?fi(e,o)===i:e===i;if("<>"===s||"="===s){let t;return t=typeof e==typeof i&&("string"==typeof e&&"string"==typeof i?Bi(i).test(e):e===i),"="===s?t:!t}if(typeof e==typeof i)switch(s){case"<":return e<i;case">":return e>i;case"<=":return e<=i;case">=":return e>=i}return!1}function $i(e,t,o,s=!1){const i=e.length;if(i%2==1)throw new si(Ho("Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs."));const n=ji(e[0]),r=n.length,a=n[0].length,l=[];for(let t=0;t<i-1;t+=2){const i=ji(e[t]);if(i.length!==r||i[0].length!==a)throw new si(Ho("Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension"));const n=Ui(wi(e[t+1]),o);s&&"string"==typeof n.operand&&(n.operand+="*"),l.push(n)}for(let s=0;s<r;s++)for(let n=0;n<a;n++){let r=!0;for(let t=0;t<i-1;t+=2){if(r=zi(ji(e[t])[s][n].value??void 0,l[t/2],o),!r)break}r&&t(s,n)}}function Gi(e,t,o,s,i,n){if(void 0===t||null===t.value)return-1;if(gi(t.value))throw t;const r=qi(t.value),a=typeof r;let l,c,h,d,u,g,p=0,m=i-1;const f="desc"===s?t=>qi(n(e,i-t-1)):t=>qi(n(e,t));for(;m-p>=0;){for(h=Math.floor((p+m)/2),d=h,u=f(d),g=typeof u;p<d&&a!==g;)d--,u=f(d),g=typeof u;g===a&&null!=u?("strict"===o&&u===r?(l=u,c=d):"nextSmaller"===o&&u<=r?(null==l||l<u||l===u&&c<d)&&(l=u,c=d):"nextGreater"===o&&u>=r&&(void 0===l||l>u||l===u&&c<d)&&(l=u,c=d),u>r||"strict"===o&&u===r?m=d-1:p=h+1):p=h+1}return void 0===c?-1:"desc"===s?i-c-1:c}function Wi(e,t,o,s,i,n,r=!1){if(void 0===t||null===t.value)return-1;if(gi(t.value))throw t;const a=qi(t.value),l=r?(e,t)=>qi(i(e,s-t-1)):(e,t)=>qi(i(e,t)),c="wildcard"!==o||"string"!=typeof a||!(a.includes("*")||a.includes("?"));if(n&&c){const t=r?"reverseSearch":"forwardSearch";let i=n[t].get(e);if(void 0===i){i=new Map;for(let t=0;t<s;t++){const o=l(e,t)??null;i.has(o)||i.set(o,t)}n[t].set(e,i)}if(i.has(a)){const e=i.get(a);return r?s-e-1:e}if("strict"===o)return-1}const h=function(e,t,o,s,i){let n=o=>i(e,o)===t;if("wildcard"===o&&"string"==typeof t&&(t.includes("*")||t.includes("?"))){const o=Bi(t);n=t=>{const s=i(e,t);return"string"==typeof s&&o.test(s)}}let r,a=-1;"nextSmaller"===o&&(n=o=>{const s=i(e,o);return(!r&&Zi(t,s)>=0||Zi(t,s)>=0&&Zi(s,r)>0)&&(r=s,a=o),s===t});"nextGreater"===o&&(n=o=>{const s=i(e,o);return(!r&&Zi(t,s)<=0||Zi(t,s)<=0&&Zi(s,r)<0)&&(r=s,a=o),s===t});for(let e=0;e<s;e++)if(n(e))return e;return a}(e,a,o,s,l);return r&&-1!==h?s-h-1:h}function qi(e){return"string"==typeof e?Ii(e):e}function Zi(e,t){let o=di.indexOf(typeof e)-di.indexOf(typeof t);return 0===o&&("string"==typeof e&&"string"==typeof t?o=e.localeCompare(t):"number"==typeof e&&"number"==typeof t?o=e-t:"boolean"==typeof e&&"boolean"==typeof t&&(o=Number(e)-Number(t))),o}function ji(e){return void 0===e?[[]]:js(e)?e:[[e]]}function Yi(e,t){return Fi(e,((e,o)=>(e.push(t(o)),e)),[],"rowFirst")}function Xi(e){if(void 0===e)return!1;const{value:t}=e;return null!==t&&""!==t}const Ki=Ho("[[FUNCTION_NAME]] has no valid input data.");function Ji(e){return Ho("[[FUNCTION_NAME]] expects the provided values of %(argName)s to be a non-empty matrix.",{argName:e})}function Qi(e){let t;if('"'===e.current?(e.shift(),t='"'):e.currentStartsWith("[$")&&(e.advanceBy(2),t="]"),!t)return null;let o="";for(;e.current&&e.current!==t;)o+=e.shift();if(e.current!==t)throw new Error("Unterminated string in format");return e.shift(),{type:"STRING",value:o}}const en=new Set("$+-/():!^&~{}<>= ");function tn(e){if("\\"===e.current){e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"CHAR",value:t}}return en.has(e.current)?{type:"CHAR",value:e.shift()}:null}function on(e){return","===e.current?(e.shift(),{type:"THOUSANDS_SEPARATOR",value:","}):null}function sn(e){return"@"===e.current?(e.shift(),{type:"TEXT_PLACEHOLDER",value:"@"}):null}function nn(e){return"."===e.current?(e.shift(),{type:"DECIMAL_POINT",value:"."}):null}function rn(e){return"%"===e.current?(e.shift(),{type:"PERCENT",value:"%"}):null}function an(e){if("0"===e.current||"#"===e.current){const t=e.current;return e.shift(),{type:"DIGIT",value:t}}return null}const ln=new Set("dmqyhsa");function cn(e){if(!ln.has(e.current))return null;const t=e.current;let o="";for(;e.current===t;)o+=e.shift();return{type:"DATE_PART",value:o}}function hn(e){if("*"!==e.current)return null;e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"REPEATED_CHAR",value:t}}const dn=20,un={};function gn(e){let t=un[e];return void 0===t&&(t=function(e){const t=function(e){const t=new Mt(e),o=[];let s=[];for(o.push(s);!t.isOver();){if(";"===t.current){s=[],o.push(s),t.shift();continue}const e=an(t)||Qi(t)||tn(t)||on(t)||nn(t)||rn(t)||cn(t)||sn(t)||hn(t);if(!e)throw new Error("Unknown token at "+t.remaining());s.push(e)}return o}(e);for(const e of t){const t=e.filter((e=>"REPEATED_CHAR"===e.type));for(const e of t.slice(1))e.type="CHAR"}const o=mn(t[0])||pn(t[0])||fn(t[0]);if(!o)throw new Error("Invalid first format part of: "+e);if(t.length>1&&"text"===o.type)throw new Error("The first format in a multi-part format must be a number format: "+e);const s=mn(t[1])||pn(t[1]);if(t[1]?.length&&!s)throw new Error("Invalid second format part of: "+e);const i=mn(t[2])||pn(t[2]);if(t[2]?.length&&!i)throw new Error("Invalid third format part of: "+e);const n=fn(t[3]);if(t[3]?.length&&!n)throw new Error("Invalid fourth format part of: "+e);return{positive:o,negative:s,zero:i,text:n}}(e),un[e]=t),t}function pn(e){if(!e||!function(e){return e.every((e=>"DIGIT"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"PERCENT"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e))return;const t=[];let o,s=t,i=0,n=0,r=e.findLastIndex((e=>"DIGIT"===e.type)),a=!1,l=0;for(let c=0;c<e.length;c++){const h=e[c];switch(h.type){case"DIGIT":s===t?s.push(h):l<dn&&(s.push(h),l++);break;case"DECIMAL_POINT":if(s!==t)throw new Error("Multiple decimal points in a number format");o=[],s=o;break;case"REPEATED_CHAR":case"CHAR":case"STRING":s.push(h);break;case"PERCENT":i++,s.push(h);break;case"THOUSANDS_SEPARATOR":c-1===r?(n+=1,r++,s.push(h)):"DIGIT"===e[c+1]?.type&&"DIGIT"===e[c-1]?.type?(s===t&&(a=!0),s.push(h)):s.push({type:"CHAR",value:","})}}return{type:"number",integerPart:t,decimalPart:o,percentSymbols:i,thousandsSeparator:a,magnitude:n}}function mn(e){const t=e&&function(e){return e.every((e=>"DATE_PART"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"date",tokens:e}:void 0;if(!t)return;if(t.tokens.length&&t.tokens.every((e=>"DATE_PART"===e.type&&"a"===e.value)))throw new Error("Invalid date format");const o=function(e){const t=e.filter((e=>"DATE_PART"===e.type));for(let e=0;e<t.length;e++)!t[e].value.startsWith("m")||t[e].value.length>2||(t[e-1]?.value.startsWith("h")||t[e+1]?.value.startsWith("s"))&&(t[e].value=t[e].value.replaceAll("m","M"));return e}(t.tokens.map((e=>"THOUSANDS_SEPARATOR"===e.type||"DECIMAL_POINT"===e.type?{type:"CHAR",value:e.value}:e)));return{type:"date",tokens:o}}function fn(e){return e&&function(e){return e.every((e=>"STRING"===e.type||"TEXT_PLACEHOLDER"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"text",tokens:e}:void 0}function vn(e){return[bn(e.positive),bn(e.negative),bn(e.zero),bn(e.text)].filter(lt).join(";")}function bn(e){if(!e)return;let t="";const o="number"!==e.type?e.tokens:function(e){const t=[...e.integerPart];e.decimalPart&&(t.push({type:"DECIMAL_POINT",value:"."}),t.push(...e.decimalPart));return t}(e);for(const e of o)switch(e.type){case"STRING":t+=`[$${e.value}]`;break;case"CHAR":t+=(s=e.value,en.has(s)?e.value:`\\${e.value}`);break;case"REPEATED_CHAR":t+="*"+e.value;break;default:t+=e.value}var s;return t}const Sn=11,Cn="REPEATED_CHAR_PLACEHOLDER_",yn={0:Ho("January"),1:Ho("February"),2:Ho("March"),3:Ho("April"),4:Ho("May"),5:Ho("June"),6:Ho("July"),7:Ho("August"),8:Ho("September"),9:Ho("October"),10:Ho("November"),11:Ho("December")},wn={0:Ho("Sunday"),1:Ho("Monday"),2:Ho("Tuesday"),3:Ho("Wednesday"),4:Ho("Thursday"),5:Ho("Friday"),6:Ho("Saturday")};function In(e,{format:t,locale:o,formatWidth:s}){switch("boolean"==typeof e&&(e=e?"TRUE":"FALSE"),typeof e){case"string":{if(e.includes('\\"')&&(e=e.replaceAll(/\\"/g,'"')),!t)return e;const o=gn(t),i=o.text||o.positive;return i&&"text"===i.type?xn(e,i,s):e}case"number":t||(t=Mn(e));const i=gn(t);if("text"===i.positive.type)return xn(e.toString(),i.positive,s);let n=i.positive;if(e<0&&i.negative?(n=i.negative,e=-e):0===e&&i.zero&&(n=i.zero),"date"===n.type)return En(function(e,t){const o=us(e),s=t.tokens.some((e=>"DATE_PART"===e.type&&"a"===e.value));let i="";for(const e of t.tokens)switch(e.type){case"DATE_PART":i+=Fn(o,e.value,s);break;case"REPEATED_CHAR":i+=Cn+e.value;break;default:i+=e.value}return i}(e,n),s);const r=e<0,a=En(function(e,t,o){if(e===1/0)return"∞"+(t.percentSymbols?"%":"");const s=2*t.percentSymbols-3*t.magnitude;e*=10**s;let i=0;void 0!==t.decimalPart&&(i=t.decimalPart.filter((e=>"DIGIT"===e.type)).length);const{integerDigits:n,decimalDigits:r}=Tn(Math.abs(e),i);let a=function(e,t,o){let s=t.integerPart;s.some((e=>"DIGIT"===e.type))||(s=[...s,{type:"DIGIT",value:"#"}]);"0"===e&&(e="");let i="";const n=s.findIndex((e=>"DIGIT"===e.type));let r=e.length-1;function a(t,s){if("0"===s&&(t=t||"0"),!t)return;const n=e.length-1-r;i=o&&n>0&&n%3==0?t+o+i:t+i}for(let t=s.length-1;t>=0;t--){const o=s[t];switch(o.type){case"DIGIT":if(a(e[r],o.value),r--,n===t)for(;r>=0;)a(e[r],"0"),r--;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":i=Cn+o.value+i;break;default:i=o.value+i}}return i}(n,t,t.thousandsSeparator?o.thousandsSeparator:void 0);void 0!==t.decimalPart&&(a+=o.decimalSeparator+function(e,t){if(!t.decimalPart)return"";let o="",s=0;for(const i of t.decimalPart)switch(i.type){case"DIGIT":o+="#"===i.value?e[s]||"":e[s]||"0",s++;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":o+=Cn+i.value;break;default:o+=i.value}return o}(r||"",t));return a}(Math.abs(e),n,o),s);return r?"-"+a:a;case"object":return""}}function xn(e,t,o){let s="";for(const o of t.tokens)switch(o.type){case"TEXT_PLACEHOLDER":s+=e;break;case"CHAR":case"STRING":s+=o.value;break;case"REPEATED_CHAR":s+=Cn+o.value}return En(s,o)}function En(e,t){const o=e.indexOf(Cn);if(-1===o)return e;const s=e.slice(0,o),i=e.slice(o+Cn.length+1),n=e[o+Cn.length];const{timesToRepeat:r,padding:a}=function(){if(!t)return{timesToRepeat:0,padding:""};const e=t.measureText(s+i),o=t.measureText(n),r=t.availableWidth-e;if(r<=0)return{timesToRepeat:0,padding:""};const a=Math.floor(r/o),l=r-a*o,c=t.measureText(" ");return{timesToRepeat:a,padding:" ".repeat(Math.floor(l/c))}}();return s+n.repeat(r)+a+i}const Rn=[];function Tn(e,t=dn){const o=e.toString();if(o.includes("e"))return function(e,t=dn){let o=Rn[t];o||(o=new Intl.NumberFormat("en-US",{maximumFractionDigits:t,useGrouping:!1}),Rn[t]=o);const[s,i]=o.format(e).split(".");return{integerDigits:s,decimalDigits:i}}(e,t);if(Number.isInteger(e))return{integerDigits:o,decimalDigits:void 0};const s=o.indexOf(".");let i=o.substring(0,s),n=o.substring(s+1);if(0===t)return Number(n[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(n.length>t){const{integerDigits:e,decimalDigits:o}=function(e,t){let o="0",s=e;const i=e.slice(0,t),n=t;if(Number(e[n])<5)return{integerDigits:o,decimalDigits:i};const r=i.match(Dn)?.[0]||"",a=(Number(i)+1).toString(),l=i.slice(r.length),c=a.length>l.length;c&&!r?(o="1",s=void 0):s=c?r.slice(0,-1)+a:r+a;return{integerDigits:o,decimalDigits:s}}(n,t);n=o,"0"!==e&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:An(n||"")}}function An(e){let t=e.length-1;for(;t>=0&&"0"===e[t];)t--;return e.slice(0,t+1)||void 0}const Dn=/^0+/;function _n(e,t){const{integerDigits:o,decimalDigits:s}=Tn(e,20);return s?o+t+s:o}const On=Et((function(e){if(!e)return!1;try{return"date"===gn(e).positive.type}catch(e){return!1}}));function Fn(e,t,o){switch(t){case"d":return e.getDate();case"dd":return e.getDate().toString().padStart(2,"0");case"ddd":return wn[e.getDay()].slice(0,3);case"dddd":return wn[e.getDay()].toString();case"m":return e.getMonth()+1;case"mm":return String(e.getMonth()+1).padStart(2,"0");case"mmm":return yn[e.getMonth()].slice(0,3);case"mmmm":return yn[e.getMonth()].toString();case"mmmmm":return yn[e.getMonth()].slice(0,1);case"qq":return Ho("Q%(quarter)s",{quarter:e.getQuarter()}).toString();case"qqqq":return Ho("Quarter %(quarter)s",{quarter:e.getQuarter()}).toString();case"yy":const s=String(e.getFullYear()).replace("-","").padStart(2,"0");return s.slice(s.length-2);case"yyyy":return e.getFullYear();case"hhhh":return Math.floor((e.getTime()-Xo.getTime())/36e5).toString();case"hh":let i=e.getHours();return o&&(i=0===i?12:i>12?i-12:i),i.toString().padStart(2,"0");case"MM":return e.getMinutes().toString().padStart(2,"0");case"ss":return e.getSeconds().toString().padStart(2,"0");case"a":return e.getHours()>=12?"PM":"AM";default:throw new Error(`invalid date format token: ${t}`)}}const Pn=Et((function(e){return new RegExp(`[0-9]+${Be(e.decimalSeparator)}[0-9]`)}));function Mn(e){let{integerDigits:t,decimalDigits:o}=Tn(e);if(!o)return"0";const s=t.replace("-","").length;if(s+2>Sn)return"0";const i=Sn-s-1;return({decimalDigits:o}=Tn(e,Math.min(i,o.length))),o?"0."+"0".repeat(o.length):"0"}function Nn(e,t){if(!cs(e,t))return;return ds(e,t).format}function kn(e){const t=e.includes(".")?"0.00":"0",o=e.match(/[\$€]/);if(o){const s=e.match(/[\d]/),i="[$"+o.values().next().value+"]";return s.index<o.index?"#,##"+t+i:i+"#,##"+t}if(e.includes("%"))return t+"%"}function Vn(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();return"after"===o&&s&&(r=" "+r),function(e,t,o){const s=`[$${e}]`;return"before"===t?s+o:o+s}(r,o,n)}function Ln(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();"after"===o&&s&&(r=" "+r);return[Hn(r,o,` ${n} `),Hn(r,o,`(${n})`),Hn(r,o," - ")].join(";")}function Hn(e,t,o){const s=`[$${e}]`;return"before"===t?s+"* "+o:o+"* "+s}function Un(e){const t=gn(e);return vn({positive:Bn(t.positive),negative:t.negative?Bn(t.negative):void 0,zero:t.zero?Bn(t.zero):void 0,text:t.text})}function Bn(e){if("number"!==e.type||!e.decimalPart)return e;const t=e.decimalPart.filter((e=>"DIGIT"!==e.type));return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...t]}}function zn({value:e,format:t},o){return In(e,{format:$n({value:e,format:t},void 0,o),locale:o})}function $n(e,t,o){let s=0;try{s=Math.abs(fi(e?.value,o))}catch(e){return""}const i=e?.format;if(void 0!==t){const e=t?.value;switch(e){case"k":return Gn(i,1,"k");case"m":return Gn(i,2,"m");case"b":return Gn(i,3,"b");default:throw new si(Ho("The formatting unit should be 'k', 'm' or 'b'."))}}return s<1e5?Gn(i,0,""):s<1e8?Gn(i,1,"k"):s<1e11?Gn(i,2,"m"):Gn(i,3,"b")}function Gn(e,t,o,s){const i=gn(e||"#,##0");return vn({positive:Wn(i.positive,t,o),negative:i.negative?Wn(i.negative,t,o):void 0,zero:i.zero?Wn(i.zero,t,o):void 0,text:i.text})}function Wn(e,t,o){if("number"!==e.type)return e;const s={type:"STRING",value:o};let i=[...e.integerPart];const n=i.findLastIndex((e=>"DIGIT"===e.type));if(-1===n)throw new Error("Cannot create a large number format from a format with no digit.");for(;"THOUSANDS_SEPARATOR"===i[n+1]?.type;)i=Rt(i,[n+1]);const r=i[n+1];i="STRING"===r?.type&&["m","k","b"].includes(r.value)?At(i,s,n+1):Tt(i,[s],n+1),t>0&&(i=Tt(i,Array(t).fill({type:"THOUSANDS_SEPARATOR",value:","}),n+1));const a=e.percentSymbols-i.filter((e=>"PERCENT"===e.type)).length;return i.push(...new Array(a).fill({type:"PERCENT",value:"%"})),{...e,integerPart:i,decimalPart:void 0,magnitude:t}}function qn(e,t){const o=gn(e);return vn(gn(vn({positive:Zn(o.positive,t),negative:o.negative?Zn(o.negative,t):void 0,zero:o.zero?Zn(o.zero,t):void 0,text:o.text})))}function Zn(e,t){return"number"!==e.type?e:t>0?function(e,t){let o=e.integerPart,s=e.decimalPart;if(!s){const e=o.findLastIndex((e=>"DIGIT"===e.type));s=o.slice(e+1),o=o.slice(0,e+1)}const i=je(0,t).map((()=>({type:"DIGIT",value:"0"}))),n=s.findLastIndex((e=>"DIGIT"===e.type));s=-1===n?[...i,...s]:Tt(s,i,n+1);return{...e,decimalPart:s,integerPart:o}}(e,t):function(e,t){let o=e.decimalPart;if(!o)return e;const s=[];let i=0;for(let e=o.length-1;e>=0&&!(i>=Math.abs(t));e--)"DIGIT"===o[e].type&&(i++,s.push(e));if(o=Rt(o,s),o.some((e=>"DIGIT"===e.type)))return{...e,decimalPart:o};return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...o]}}(e,Math.abs(t))}function jn(e){const t=gn(e);for(const e of[t.positive,t.negative,t.zero])if(e&&"date"===e.type&&e.tokens.some((e=>"DATE_PART"===e.type&&e.value.includes("q"))))return!1;return!0}function Yn(e){if(!e)return!1;try{return"text"===gn(e).positive.type}catch{return!1}}function Xn(e,t){return Jn({value:Yn(t.format)&&null!==e.parsedValue?e.content:e.parsedValue,format:t.format},t.locale)}function Kn(e,t){if(e.startsWith("="))throw new Error(`Cannot parse "${e}" because it's not a literal value. It's a formula`);if(""===e)return null;if(Rs(e,qs))return As(e,qs);const o=ds(e,t);return o?o.value:Ke(e)?"TRUE"===e.toUpperCase():e}function Jn(e,t=qs,o){const s=jo(e.value);if(!s)return Qn(e,t,o);const i=Kn(s.label,t);return{...Qn({value:i,format:e.format||("number"==typeof i?Nn(s.label,t)||kn(s.label):void 0)},t,o),link:s}}function Qn(e,t,o){let{value:s,format:i,message:n}=e;i=o?.format||i;const r=In(s,{format:i,locale:t});return gi(s)?function(e,t){return{value:e,formattedValue:e,message:t,type:_s.error,isAutoSummable:!1,defaultAlign:"center"}}(s,n):null===s?tr(i):Yn(i)?er(wi(s),i,r):"number"==typeof s?On(i||"")?function(e,t,o){return{value:e,format:t,formattedValue:o,type:_s.number,isAutoSummable:!1,defaultAlign:"right"}}(s,i,r):function(e,t,o){return{value:e||0,format:t,formattedValue:o,type:_s.number,isAutoSummable:!0,defaultAlign:"right"}}(s,i,r):"boolean"==typeof s?function(e,t,o){return{value:e,format:t,formattedValue:o,type:_s.boolean,isAutoSummable:!1,defaultAlign:"center"}}(s,i,r):er(s,i,r)}function er(e,t,o){return{value:e,format:t,formattedValue:o,type:_s.text,isAutoSummable:!0,defaultAlign:"left"}}const tr=Et((function(e){return{value:null,format:e,formattedValue:"",type:_s.empty,isAutoSummable:!0,defaultAlign:"left"}}));function or(e){const t=Yo.now();switch(e){case"today":return ps(t);case"yesterday":return ps(Yo.fromTimestamp(t.setDate(t.getDate()-1)));case"tomorrow":return ps(Yo.fromTimestamp(t.setDate(t.getDate()+1)));case"lastWeek":return ps(Yo.fromTimestamp(t.setDate(t.getDate()-7)));case"lastMonth":return ps(Yo.fromTimestamp(t.setMonth(t.getMonth()-1)));case"lastYear":return ps(Yo.fromTimestamp(t.setFullYear(t.getFullYear()-1)))}}function sr(e,t){return"dateValue"in e&&"exactDate"!==e.dateValue?[or(e.dateValue)]:e.values.map((e=>ls(e,t)))}function ir(e,t){return e.map((e=>{if(e.startsWith("="))return e;const o=Kn(e,t);return"number"==typeof o?In(o,{format:t.dateFormat,locale:t}):""}))}function nr(e,t=[]){if(e.length<=1&&0===t.length)return e;const o=[0],s=new Map([[0,[]]]);return rr(o,s,e,!1),rr(o,s,t,!0),function(e,t){const o=[];let s=[];for(let i=0;i<e.length;i++){const n=e[i],r=t.get(n);if(!r||0===r.length){o.push(...s),s=[];continue}let a=e[i+1];void 0!==a&&a--;const l=[];for(let e=0;e<r.length;e+=2){const t=r[e];let o=r[e+1];void 0!==o&&o--;const i={top:t,left:n,bottom:o,right:a,hasHeader:void 0===o&&0!==t||void 0===a&&0!==n};let c=!1;for(let e=s.length-1;e>=0;e--){const t=s[e];if(t.top===i.top&&t.bottom===i.bottom){t.right=i.right,s.splice(e,1),l.push(t),c=!0;break}}c||l.push(i)}o.push(...s),s=l}return o.push(...s),o}(o,s)}function rr(e,t,o,s=!1){for(const i of o){const o=i.left,n=void 0===i.right?void 0:i.right+1,r=ar(e,t,o,!0,0),a=ar(e,t,n,!1,r);for(let o=r;o<=a;o++){lr(t.get(e[o]),i,s)}cr(e,t,r,a)}}function ar(e,t,o,s,i){if(void 0===o)return e.length-1;const n=hr(e,o,i);return o!==e[n]?(e.splice(n+1,0,o),t.set(o,[...t.get(e[n])]),s?n+1:n):s?n:n-1}function lr(e,t,o=!1){const s=t.top,i=void 0===t.bottom?void 0:t.bottom+1,n=[],r=hr(e,s,0,!1);if((r%2!=0&&!o||r%2==0&&o)&&n.push(s),void 0===i)return e.splice(r+1),void e.push(...n);const a=function(e,t,o=0,s=!0){let i=e.length-1,n=e.length;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]>t?(n=r,i=r-1):o=r+1}return n}(e,i,0,!1);(a%2==0&&!o||a%2!=0&&o)&&n.push(i),e.splice(r+1,a-r-1,...n)}function cr(e,t,o,s){const i=o-1==-1?0:o-1;for(let o=s===e.length-1?s:s+1;o>i;o--)ft(t.get(e[o]),t.get(e[o-1]))&&(t.delete(e[o]),e.splice(o,1))}function hr(e,t,o=0,s=!0){let i=e.length-1,n=-1;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]<t?(n=r,o=r+1):i=r-1}return n}function dr(e){const t=function(e){const t=new Mt(e);Do(t);const o=e.indexOf("!");-1!==o&&t.advanceBy(o+1);const s=_o(t),i=Oo(t);let n,r,a,l,c=!1,h=!1,d=!1;if(-1===i?(a=l=s-1,n=r=0,c=!0):-1===s?(n=r=i-1,a=l=0,h=!0):(a=l=s-1,n=r=i-1,d=!0),Do(t),":"===t.current){t.advanceBy(1),Do(t);const e=_o(t),o=Oo(t);-1===o?(l=e-1,c=!0):-1===e?(r=o-1,h=!0):(l=e-1,r=o-1,n=c?r:n,a=h?l:a,d=!0)}const u={top:n,left:a,bottom:c?void 0:r,right:h?void 0:l};return d=d&&(h||c),d&&(u.hasHeader=d),u}(e),o=Or(t),s=o.bottom,i=o.right;if(void 0!==s&&s>Ao||void 0!==i&&i>To)throw new Error(`Range string out of bounds: ${e}`);if(void 0===s&&void 0===i)throw new Error("Wrong zone xc. The zone cannot be at the same time a full column and a full row");return o}function ur(e){const t=dr(e);if(void 0===t.bottom||void 0===t.right)throw new Error("This does not support unbounded ranges");return t}function gr(e){try{return function(e){return pr(dr(e))}(e)}catch(e){return!1}}function pr(e){const{bottom:t,top:o,left:s,right:i}=e;return!(void 0!==t&&isNaN(t)||isNaN(o)||isNaN(s)||void 0!==i&&isNaN(i))&&(mr(e)&&e.top>=0&&e.left>=0)}function mr(e){return(void 0===e.bottom||e.bottom>=e.top&&e.bottom>=0)&&(void 0===e.right||e.right>=e.left&&e.right>=0)}function fr(e){const{top:t,bottom:o,left:s,right:i}=e,n="hasHeader"in e&&e.hasHeader,r=t===o&&s===i;if(void 0===o&&void 0!==i)return 0!==t||n?`${Po(s,t)}:${wo(i)}`:`${wo(s)}:${wo(i)}`;if(void 0===i&&void 0!==o)return 0!==s||n?`${Po(s,t)}:${o+1}`:`${t+1}:${o+1}`;if(void 0!==o&&void 0!==i)return r?Po(s,t):`${Po(s,t)}:${Po(i,o)}`;throw new Error("Bad zone format")}function vr(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a=e["left"===t?"right":"bottom"];return e[t]<=r&&a&&a>r?Fr(e,n,"RESIZE",i):r<e[t]?Fr(e,n,"MOVE",i):{...e}}function br(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a="left"===t?"right":"bottom";return e[t]<=r&&e[a]>r?Fr(e,n,"RESIZE",i):r<e[t]?Fr(e,n,"MOVE",i):{...e}}function Sr(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];for(const r of o.sort(((e,t)=>t-e)))e[t]>r&&(i--,n--),e[t]<r&&e[s]>=r&&n--;return{...e,[t]:i,[s]:n}}function Cr(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];const r=e[s];for(const s of o.sort(((e,t)=>t-e)))e[t]>s&&(i--,void 0!==n&&n--),void 0!==r&&void 0!==n&&e[t]<=s&&r>=s&&n--;if(!(void 0!==n&&i>n))return{...e,[t]:i,[s]:n}}function yr(...e){return{top:Math.min(...e.map((e=>e.top))),left:Math.min(...e.map((e=>e.left))),bottom:Math.max(...e.map((e=>e.bottom))),right:Math.max(...e.map((e=>e.right)))}}function wr(e,t){if(xr(e,t))return{top:Math.max(e.top,t.top),left:Math.max(e.left,t.left),bottom:Math.min(e.bottom,t.bottom),right:Math.min(e.right,t.right)}}function Ir(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom}function xr(e,t){return!(e.bottom<t.top||t.bottom<e.top)&&!(e.right<t.left||t.right<e.left)}function Er(e,t,o){const{left:s,right:i,top:n,bottom:r}=o;return e>=s&&e<=i&&t>=n&&t<=r}function Rr(e,t){return Ir(yr(t,e),t)}function Tr(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function Ar(e){const{numberOfCols:t,numberOfRows:o}=Tr(e);return 1===t||1===o}function Dr(e){const t={};for(const o of e)t[o.sheetId]??=[],t[o.sheetId].push(Mr(o));for(const e in t)t[e]=nr(t[e]);return t}function _r(e){const t=[],{left:o,right:s,top:i,bottom:n}=Or(e);for(const e of je(o,s+1))for(const o of je(i,n+1))t.push({col:e,row:o});return t}function Or(e){return void 0!==e.right&&e.left>e.right&&(e={...e,left:e.right,right:e.left}),void 0!==e.bottom&&e.top>e.bottom&&(e={...e,top:e.bottom,bottom:e.top}),e}function Fr(e,t,o,s){const i="both"===t?s[0]:"columns"===t?s:0,n="both"===t?s[1]:"rows"===t?s:0,r="hasHeader"in e&&e.hasHeader;let a;a=Vr(e)&&!r?"rows"!==t:!(kr(e)&&!r)||"columns"!==t;const l={...e};return a&&"MOVE"===o&&(l.left+=i,l.top+=n),void 0!==l.right&&(l.right+=i),void 0!==l.bottom&&(l.bottom+=n),l}function Pr(e,t){let o,s;const{left:i,right:n,top:r,bottom:a}=e,{left:l,right:c,top:h,bottom:d}=t;return o=l!==i?l:c!==n?c:l,s=h!==r?h:d!==a?d:h,{col:o,row:s}}function Mr(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function Nr(e){return{...e,right:e.left,bottom:e.top}}function kr(e){return void 0===e.right}function Vr(e){return void 0===e.bottom}function Lr(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function Hr(e,t,o){return e.some((e=>function(e,t,o){return e.left<t&&t<=e.right||e.top<o&&o<=e.bottom}(e,t,o)))}function Ur(e){return e.length<2||1===nr(e).length}function Br(e){const t=[...e];let o=!0;for(;o;){o=!1;for(let e=0;e<t.length;e++){const s=t[e],i=t.findIndex(((t,o)=>{return e!==o&&(n=s,((i=t).right+1===n.left||i.left===n.right+1?i.top<=n.bottom&&i.top>=n.top||n.top<=i.bottom&&n.top>=i.top:(i.bottom+1===n.top||i.top===n.bottom+1)&&(i.left<=n.right&&i.left>=n.left||n.left<=i.right&&n.left>=i.left))||xr(t,s));var i,n}));if(-1!==i){t[e]=yr(t[i],s),t.splice(i,1),o=!0;break}}}return t}const zr=new WeakMap,$r=new WeakMap;function Gr(e,t){zr.has(t)||(zr.set(t,new Map),$r.set(t,0));const o=zr.get(t),s=Zr(e);if(o.has(s)){const i=o.get(s);return t[i]=e,i}const i=$r.get(t)+1;return o.set(s,i),$r.set(t,i),t[i]=e,i}function Wr(e){const t={};for(const o in e){const s=nr(e[o].map(Mr));for(const e of s)t[fr(e)]=Number(o)}return t}function*qr(e,t){for(const o in t){const s=ur(o),i=t[o];for(let t=s.top;t<=s.bottom;t++)for(let o=s.left;o<=s.right;o++){const s={sheetId:e,col:o,row:t};yield[s,i]}}}function Zr(e){if(null===e)return"null";if(void 0===e)return"undefined";if("object"!=typeof e)return String(e);if(Array.isArray(e)){const t=e.length;let o="[";for(let s=0;s<t;s++)s>0&&(o+=","),o+=Zr(e[s]);return o+"]"}const t=Object.keys(e).sort();let o="{";for(const s of t)void 0!==e[s]&&(o+=`"${s}":${Zr(e[s])},`);return o+="}",o}function jr(e){return 20+120*Math.exp(-.035*(e-1))}const Yr=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,"i"),Xr=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,"i"),Kr=new RegExp(/^\$?([A-Z]{1,3})+$/,"i"),Jr=new RegExp(/^\$?([0-9]{1,7})+$/,"i"),Qr=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,"i"),ea=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,"i"),ta=new RegExp(/^\s*('.+'!|[^']+!)?/.source+"("+[Yr.source,/(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*:\s*(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*/i.source,/\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*:\s*\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*/i.source].join("|")+")"+/$/.source,"i");function oa(e){return ea.test(e)}function sa(e){return Kr.test(e)}function ia(e){return Jr.test(e)}function na(e){return Xr.test(e)}function ra(e){if(!e.includes("!"))return{xc:e};const t=e.split("!"),o=t.pop();return{sheetName:$e(t.join("!"))||void 0,xc:o}}function aa(e,t){return void 0!==e?`${We(e)}!${t}`:t}function la(e){const t=[];for(let o=0;o<e;o++){const e={cells:{}};t.push(e)}return t}function ca(e,t,o){return o.map((o=>o>=e?o+t:o))}function ha(e,t){return e=[...e].sort(((e,t)=>t-e)),t.map((t=>{for(const o of e)if(t>o)t--;else if(t===o)return;return t})).filter(lt)}function da(e,t="Sheet"){let o=1,s=`${t}${o}`;for(;e.includes(s);)s=`${t}${o}`,o++;return s}function ua(e,t){let o=1;const s=Ho("Copy of %s",e);let i=s.toString();for(;t.includes(i);)i=`${s} (${o})`,o++;return i}function ga(e,t){return void 0!==e&&void 0!==t&&$e(e.trim().toUpperCase())===$e(t.trim().toUpperCase())}function pa(e,t){const o=e.zone,s=function(e,t){const{left:o,top:s,bottom:i,right:n}=e;if(void 0!==n&&void 0!==i)return e;if(void 0===i&&void 0!==n)return{right:n,top:s,left:o,bottom:t.numberOfRows-1};if(void 0===n&&void 0!==i)return{bottom:i,left:o,top:s,right:t.numberOfCols-1};throw new Error("Bad zone format")}(o,t(e.sheetId));let i=e.parts;return 1===e.parts.length&&Lr(s)>1?i=[e.parts[0],e.parts[0]]:2===e.parts.length&&1===Lr(s)&&(i=[e.parts[0]]),{unboundedZone:o,zone:s,parts:i,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function ma(e,t){const o=e.xc,{xc:s,sheetName:i}=ra(o),n=dr(s),r=function(e,t){const o=e.split(":").map((e=>{const t=oa(e);return{colFixed:!t&&e.startsWith("$"),rowFixed:t?e.startsWith("$"):e.includes("$",1)}})),s=void 0===t.bottom,i=void 0===t.right;s&&(o[0].rowFixed=o[0].rowFixed||o[1].rowFixed,o[1].rowFixed=o[0].rowFixed||o[1].rowFixed);i&&(o[0].colFixed=o[0].colFixed||o[1].colFixed,o[1].colFixed=o[0].colFixed||o[1].colFixed);return o}(s,n);return pa({zone:n,parts:r,sheetId:e.sheetId,prefixSheet:Boolean(i),invalidSheetName:e.invalidSheetName},t)}function fa(e){const t={left:-1,top:-1,right:-1,bottom:-1};return{sheetId:"",zone:t,unboundedZone:t,parts:[],invalidXc:e,prefixSheet:!1}}function va(e){return Vr(e.unboundedZone)}function ba(e){return kr(e.unboundedZone)}function Sa(e,t,o,s={useBoundedReference:!1,useFixedReference:!1}){if(e.invalidXc)return e.invalidXc;if(e.zone.bottom-e.zone.top<0||e.zone.right-e.zone.left<0)return ti.InvalidReference;if(e.zone.left<0||e.zone.top<0)return ti.InvalidReference;const i=e.sheetId!==t||e.invalidSheetName||e.prefixSheet;let n="";if(i&&(n=e.invalidSheetName?e.invalidSheetName:We(o(e.sheetId))),i&&!n)return ti.InvalidReference;let r=Oa(e,0,s);return e.parts&&2===e.parts.length&&(e.zone.top!==e.zone.bottom||e.zone.left!==e.zone.right||e.parts[0].rowFixed||e.parts[0].colFixed||e.parts[1].rowFixed||e.parts[1].colFixed)&&(r+=":",r+=Oa(e,1,s)),`${i?n+"!":""}${r}`}function Ca(e,t,o){const s=o.sheetId===e?t:o.sheetId;return{...o,sheetId:s}}function ya(e,t,o){if(!o)return;const s=e.getRangeFromSheetXC(t,o);return s.invalidSheetName||s.invalidXc?void 0:s}function wa(e){const t=[];for(const o of e)for(const e of _r(o.zone))t.push({...e,sheetId:o.sheetId});return t}function Ia(e){return xa.get(e.type)?.(e)}const xa=new class extends n{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};function Ea(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows",i=[...e.elements];i.sort(((e,t)=>t-e));const n=Ye(i);return i=>{if(!ga(i.sheetId,e.sheetId))return{changeType:"NONE"};let r=i,a="NONE";for(const e of n){const n=Pt(e),l=Ft(e);if(i.zone[t]<=n&&n<=i.zone[o]){const e=Math.min(i.zone[o],l)-n+1;a="RESIZE",r=_a(r,s,a,-e)}else if(i.zone[t]>=n&&i.zone[o]<=l)a="REMOVE",r=fa(ti.InvalidReference);else if(i.zone[t]<=l&&i.zone[o]>=l){const e=l-i.zone[t]+1;a="RESIZE",r=_a(r,s,a,-e),r=_a(r,s,"MOVE",-(i.zone[t]-n))}else n<i.zone[t]&&(a="MOVE",r=_a(r,s,a,-(l-n+1)))}return"NONE"!==a?{changeType:a,range:r}:{changeType:"NONE"}}}function Ra(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";return 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:_a(i,s,"RESIZE",e.quantity)};if(e.base<i.zone[t])return{changeType:"MOVE",range:_a(i,s,"MOVE",e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[o])return{changeType:"RESIZE",range:_a(i,s,"RESIZE",e.quantity)};if(e.base<=i.zone[t])return{changeType:"MOVE",range:_a(i,s,"MOVE",e.quantity)}}return{changeType:"NONE"}}}function Ta(e){return t=>{if(t.sheetId!==e.sheetId&&t.invalidSheetName!==e.sheetName)return{changeType:"NONE"};const o=e.sheetName;return{changeType:"REMOVE",range:t={...fa(ti.InvalidReference),invalidSheetName:o}}}}function Aa(e){return t=>{if(t.sheetId===e.sheetId)return{changeType:"CHANGE",range:t};if(e.newName&&t.invalidSheetName===e.newName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}if(e.oldName&&t.invalidSheetName===e.oldName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}return{changeType:"NONE"}}}function Da(e){const t=e.target[0];return o=>{if(o.sheetId!==e.sheetId||!Rr(o.zone,t))return{changeType:"NONE"};const s=e.targetSheetId,i=_a(o,"both","MOVE",[e.col-t.left,e.row-t.top]),n=e.sheetId!==s||i.prefixSheet;return{changeType:"MOVE",range:{...i,sheetId:s,prefixSheet:n}}}}function _a(e,t,o,s){return{...e,unboundedZone:Fr(e.unboundedZone,t,o,s),zone:Fr(e.zone,t,o,s)}}function Oa(e,t,o={useBoundedReference:!1,useFixedReference:!1}){const s=e.parts[t]?.colFixed||o.useFixedReference?"$":"",i=wo(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=Vr(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:s+i:kr(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:n+r:s+i+n+r,a}function Fa(e,t,o){const s=[];return t.forEach((t=>{const i=function(e,t){e=e.toLocaleLowerCase();let o=0,s=0;const i=(t=t.toLocaleLowerCase()).length;let n=0;for(let r=0;r<i;r++)t[r]===e[n]?(n++,s+=100+s-r/200):s=0,o+=s;return n===e.length?o:0}(e,o(t));i>0&&s.push({score:i,elem:t})})),s.sort(((e,t)=>t.score-e.score)),s.map((e=>e.elem))}function Pa(e,t=1){return t*(e+re)-re}function Ma(e,t,o,s){const i=Wa(e,t,o,"wrap"===o?.wrapping?s-2*re:void 0).length;return Pa($a(o),i)+2*ae}function Na(e,t=!1,o=!1){return`${o?"italic":""} ${t?"bold":""} ${e}px ${fe}`}xa.add("REMOVE_COLUMNS_ROWS",(e=>({applyChange:Ea(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("ADD_COLUMNS_ROWS",(e=>({applyChange:Ra(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("DELETE_SHEET",(e=>({applyChange:Ta(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("RENAME_SHEET",(e=>({applyChange:Aa(e),sheetId:e.sheetId,sheetName:{old:e.oldName,current:e.newName}}))).add("MOVE_RANGES",(e=>({applyChange:Da(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})));const ka={};function Va(e,t,o,s="pt"){return La(e,t,za(o,s))}function La(e,t,o){if(ka[o]||(ka[o]={}),void 0===ka[o][t]){const s=e.font;e.font=o,ka[o][t]=e.measureText(t).width,e.font=s}return ka[o][t]}const Ha={};function Ua(e,t,o,s="pt"){const i=za(o,s);e.save(),e.font=i;const n=function(e,t){const o=e.font;Ha[o]||(Ha[o]={});if(void 0===Ha[o][t]){const s=e.measureText(t),i=s.width,n=s.fontBoundingBoxAscent+s.fontBoundingBoxDescent;Ha[o][t]={width:i,height:n}}return Ha[o][t]}(e,t);return e.restore(),n}function Ba(e){return Math.round(96*e/72)}function za(e,t="pt"){return`${e.italic?"italic ":""}${e.bold?"bold":pe} ${("pt"===t?$a(e):e.fontSize)??me}px ${fe}`}function $a(e){return Ba(e?.fontSize||me)}function Ga(e,t,o,s){if(Va(e,t,s)<=o)return[t];const i=[];let n="";for(const r of t){Va(e,n+r,s)>o?(i.push(n),n=r):n+=r}return i.push(n),i}function Wa(e,t,o,s){o||(o={}),et(t)&&(t=st(t).label);const i=[],n=t.includes(Ne)?t.split(Ne):[t];for(const t of n){const n=t.includes(" ")?t.split(" "):[t];if(!s){i.push(t);continue}let r="",a=s;for(const t of n){const n=Ga(e,t,s,o),l=n.pop(),c=Va(e,l,o);if(n.length)""!==r&&(i.push(r),r="",a=s),n.forEach((e=>{i.push(e)})),r=l,a=s-c;else{const t=""===r?l:" "+l,n=Va(e,t,o);n<=a?(r+=t,a-=n):(i.push(r),r=l,a=s-c)}}""!==r&&i.push(r)}return i}function qa(e){return e?e.toLowerCase():""}const Za=/([0-9\.]*)px/;function ja(e,t,o){let s=La(e,t,e.font);if(s<=o)return t;const i=La(e,"…",e.font);if(s<=i)return t;let n=t.length;for(;s>=o-i&&n-- >0;)s=La(e,t=t.substring(0,n),e.font);return t+"…"}function Ya(e,t,o,s=!1,i=!1,n=function(e){return Number(e.match(Za)?.[1])}(e.font)/10){if(e.fillText(t,o.x,o.y),!s&&!i)return;const r=e.measureText(t),a=r.width,l=r.actualBoundingBoxAscent+r.actualBoundingBoxDescent,c=r.fontBoundingBoxAscent+r.fontBoundingBoxDescent;let{x:h,y:d}=o,u=d,g=d;switch(e.textAlign){case"center":h-=a/2;break;case"right":h-=a}switch(e.textBaseline){case"top":g+=c-2*n,u+=c/2-n;break;case"middle":g+=c/2-n;break;case"alphabetic":g+=2*n,u-=3*n;break;case"bottom":g=d,u-=l/2-n/2}s&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,g),e.lineTo(h+a,g),e.stroke()),i&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,u),e.lineTo(h+a,u),e.stroke())}function Xa(e,t,o,s,i="pt"){if(Va(e,o,s,i)<=t)return o;const n=Va(e,"...",s,i);if(n>=t)return"";let r,a=1,l=o.length;for(;a<=l;){const c=Math.floor((a+l)/2);r=Va(e,o.slice(0,c),s,i),r+n>t?l=c-1:a=c+1}const c=o.slice(0,Math.max(0,a-1));return c?c+"...":""}class Ka{smallUuid(){return window.crypto?"10000000-1000".replace(/[01]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}uuidv4(){return window.crypto?"10000000-1000-4000-8000-100000000000".replace(/[018]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}}const Ja=["image/avif","image/bmp","image/gif","image/vnd.microsoft.icon","image/jpeg","image/png","image/tiff","image/webp"];function Qa(e,t){const o=new Set(t.map((e=>e.left))),s=new Set(t.map((e=>e.right))),i=new Set(t.map((e=>e.top))),n=new Set(t.map((e=>e.bottom))),r=1===i.size&&1===n.size||1===o.size&&1===s.size?function(e){return e.reduce(((e,t)=>{const o=e.length;for(let s=0;s<o;s++)if(xr(e[s],t))return e[s]=yr(e[s],t),e;return e[o]=t,e}),[])}(t):[t[t.length-1]],a=r.map((e=>_r(e))).flat();return{sheetId:e,zones:t,clippedZones:r,columnsIndexes:[...new Set(a.map((e=>e.col)))].sort(((e,t)=>e-t)),rowsIndexes:[...new Set(a.map((e=>e.row)))].sort(((e,t)=>e-t))}}function el(e,t){if(!t.length||!t[0].length)return e;const o=t[0].length,s=t.length;return e.map((e=>function(e,t,o){const s=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-o+1,e.top),n=[];for(let r=e.left;r<=s;r+=t)for(let s=e.top;s<=i;s+=o)n.push({left:r,top:s,bottom:s+o-1,right:r+t-1});return n}(e,o,s))).flat()}function tl(e){let t;if(e[Os.Html]){t=function(e){const t=[...e.documentElement.attributes];if(t.some((e=>e.value.includes("microsoft"))))return;const o=e.querySelector("div")?.getAttribute("data-osheet-clipboard");return o&&JSON.parse(o)}((new DOMParser).parseFromString(e[Os.Html],"text/html"))}const o=e[Os.PlainText]||"";let s;if(!o.trim())for(const t of Ja)if(e[t]){s=e[t];break}return{text:o,data:t,imageBlob:s}}const ol=(e,t,o,s)=>{e.forEach((({handlerName:e,handler:i})=>{const n=t[e];n&&i.paste(o,n,s)}))};function sl(e,t,o,s,i){let n;const r=[],a={sheetId:e,zones:t};for(const{handlerName:l,handler:c}of s){const s=o[l];if(!s)continue;const h=c.getPasteTarget(e,t,s,i);h.figureId&&(a.figureId=h.figureId);for(const e of h.zones)r.push(e),n=void 0!==n?yr(n,e):e}return{target:a,zone:n,selectedZones:r}}const il=(e,t,o)=>{const s={col:t[0].left,row:t[0].top};e.getBackToDefault(),e.selectZone({cell:s,zone:yr(...o)},{scrollIntoView:!1})};class nl{getters;dispatch;constructor(e,t){this.getters=e,this.dispatch=t}copy(e,t,o="copyPaste"){}paste(e,t,o){}isPasteAllowed(e,t,o,s){return"Success"}isCutAllowed(e){return"Success"}getPasteTarget(e,t,o,s){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}}class rl extends nl{copy(e,t,o="copyPaste"){}pasteFromCopy(e,t,o,s){if(1===t.length)for(const i of el(t,o))this.pasteZone(e,i.left,i.top,o,s);else for(const i of nr(t))for(let t=i.left;t<=i.right;t++)for(let n=i.top;n<=i.bottom;n++)this.pasteZone(e,t,n,o,s)}pasteZone(e,t,o,s,i){}}const al=["%"],ll="+,-,*,/,:,=,<>,>=,>,<=,<,^,&".split(",").concat(al);function cl(e,t=qs){e=It(e);const o=new Mt(e),s=[],i=Ct.test(e)?yl:wl;for(;!o.isOver();){let e=Il(o)||i(o)||gl(o,t)||ul(o)||pl(o)||vl(o)||hl(o)||xl(o)||fl(o,t)||Cl(o);e||(e={type:"UNKNOWN",value:o.shift()}),s.push(e)}return s}function hl(e){return"?"===e.current?(e.shift(),{type:"DEBUGGER",value:"?"}):null}const dl={"(":{type:"LEFT_PAREN",value:"("},")":{type:"RIGHT_PAREN",value:")"}};function ul(e){if("("===e.current||")"===e.current){const t=e.shift();return dl[t]}return null}function gl(e,t){if(e.current===t.formulaArgSeparator){return{type:"ARG_SEPARATOR",value:e.shift()}}return null}function pl(e){for(const t of ll)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:"OPERATOR",value:t};return null}const ml=new Set("0123456789");function fl(e,t){if(!ml.has(e.current)&&e.current!==t.decimalSeparator)return null;const o=e.remaining().match(xs(t.decimalSeparator));return o?(e.advanceBy(o[0].length),{type:"NUMBER",value:o[0]}):null}function vl(e){if('"'===e.current){const t=e.shift();let o=t;for(;e.current&&(e.current!==t||"\\"===o[o.length-1]);)o+=e.shift();return'"'===e.current&&(o+=e.shift()),{type:"STRING",value:o}}return null}const bl=/\p{L}|\p{N}|_|\.|!|\$/u,Sl=new Set("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$");function Cl(e){let t="";if("'"===e.current){let o=e.shift();for(t+=o;e.current;)if(o=e.shift(),t+=o,"'"===o){if(!e.current||"'"!==e.current)break;o=e.shift(),t+=o}if("'"!==o)return{type:"UNKNOWN",value:t}}for(;e.current&&(Sl.has(e.current)||e.current.match(bl));)t+=e.shift();if(t.length){const e=t;return ta.test(e)?{type:"REFERENCE",value:e}:{type:"SYMBOL",value:e}}return null}function yl(e){let t="";for(;" "===e.current||e.current&&e.current.match(Ct);)t+=e.shift();return t?{type:"SPACE",value:t}:null}function wl(e){let t="";for(;" "===e.current;)t+=e.shift();return t?{type:"SPACE",value:t}:null}function Il(e){let t=0;for(;e.current===Ne;)t++,e.shift();return t?{type:"SPACE",value:Ne.repeat(t)}:null}function xl(e){return e.currentStartsWith(ti.InvalidReference)?(e.advanceBy(ti.InvalidReference.length),{type:"INVALID_REFERENCE",value:ti.InvalidReference}):null}function El(e){if(!e||"object"!=typeof e||e.thousandsSeparator&&"string"!=typeof e.thousandsSeparator)return!1;for(const t of["code","name","decimalSeparator","dateFormat","timeFormat","formulaArgSeparator"])if(!e[t]||"string"!=typeof e[t])return!1;if(e.formulaArgSeparator===e.decimalSeparator)return!1;if(e.thousandsSeparator===e.decimalSeparator)return!1;try{In(1,{locale:e,format:"#,##0.00"}),In(1,{locale:e,format:e.dateFormat}),In(1,{locale:e,format:e.timeFormat})}catch{return!1}return!0}function Rl(e,t){return Lt(e)?_l(e,t):Pl(e,t)}function Tl(e,t){return Lt(e)?_l(e,t):function(e,t){if(cs(e,t)){const o=fi(e,t);let s=qs.dateFormat;return Number.isInteger(o)||(s+=" "+qs.timeFormat),In(o,{locale:qs,format:s})}return Pl(e,t)}(e,t)}function Al(e,t){return e.startsWith("=")?Ol(e,t):function(e,t){if(cs(e,qs)){const o=fi(e,qs);let s=t.dateFormat;return Number.isInteger(o)||(s+=" "+t.timeFormat),In(o,{locale:t,format:s})}return function(e,t){if("."===t.decimalSeparator||!Rs(e,qs))return e;const o=Pn(qs);return e.replace(o,(e=>e.replace(".",t.decimalSeparator)))}(e,t)}(e,t)}function Dl(e,t){return Lt(e)?_l(e,t):Pl(e,t)}function _l(e,t){return Fl(e.startsWith("+")?"="+e.slice(1):e,t,qs)}function Ol(e,t){return Fl(e,qs,t)}function Fl(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=cl(e,t);let i="";for(const e of s)"NUMBER"===e.type?i+=e.value.replace(t.decimalSeparator,o.decimalSeparator):"ARG_SEPARATOR"===e.type?i+=o.formulaArgSeparator:i+=e.value;return i}function Pl(e,t){return"."!==t.decimalSeparator&&Rs(e,t)?(t.thousandsSeparator&&(e=e.replaceAll(t.thousandsSeparator,"")),e.replace(t.decimalSeparator,".")):e}function Ml(e,t){return Vl(e,(e=>Tl(e,t)))}function Nl(e,t){return Vl(e,(e=>Al(e,t)))}function kl(e,t){const o=ze(e);return o.criterion.values=o.criterion.values.map((e=>Al(e,t))),o}function Vl(e,t){switch((e=ze(e)).type){case"CellIsRule":switch(e.operator){case"isBetween":case"isNotBetween":case"isEqual":case"isNotEqual":case"isGreaterThan":case"isGreaterOrEqualTo":case"isLessThan":case"isLessOrEqualTo":return e.values=e.values.map((e=>t(e))),e;case"beginsWithText":case"containsText":case"endsWithText":case"notContainsText":case"isEmpty":case"isNotEmpty":return e}case"DataBarRule":return e;case"ColorScaleRule":return e.minimum=Ll(e.minimum,t),e.maximum=Ll(e.maximum,t),e.midpoint&&(e.midpoint=Ll(e.midpoint,t)),e;case"IconSetRule":return e.lowerInflectionPoint.value=t(e.lowerInflectionPoint.value),e.upperInflectionPoint.value=t(e.upperInflectionPoint.value),e}}function Ll(e,t){if(!e?.value)return e;const o=t("formula"===e.type?"="+e.value:e.value),s="formula"===e.type?o.slice(1):o;return{...e,value:s}}function Hl(e){return e.dateFormat+" "+e.timeFormat}function Ul(e){let t=!1,o=!0;return Hi(e,(e=>(t=!0,o=o&&e,o))),{foundBoolean:t,result:o}}function Bl(e){let t=!1,o=!1;return Hi(e,(e=>(t=!0,o=o||e,!o))),{foundBoolean:t,result:o}}function zl(e,t){return Pi(e,((e,t)=>e+t),0,t)}function $l(e){return Fi(e,((e,t)=>Xi(t)?e.add(t?.value):e),new Set).size}function Gl(e,t){if(!e)throw new si(t)}function Wl(e,t=Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")){if(0===e)throw new hi(t)}function ql(e){return 1===e.length||1===e[0].length}function Zl(...e){if(e.every(js)){const t=e[0].length,o=e[0][0].length;for(const s of e)if(s.length!==t||s[0].length!==o)return!1;return!0}return!e.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length)))}function jl(e){return e.length===e[0].length}const Yl=e=>Ho("The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.",e);function Xl(e){const t=Array(e);for(let o=0;o<e;o++)t[o]=Array(e).fill(0),t[o][o]=1;return t}function Kl(e){if(e.length<1||e[0].length<1)throw new Error("invertMatrix: an empty matrix cannot be inverted.");if(e.length!==e[0].length)throw new Error("invertMatrix: only square matrices are invertible");let t=1;const o=e.length,s=Xl(o),i=e.map((e=>e.slice()));for(let e=0;e<o;e++){let n=i[e][e];if(0===n){for(let n=e+1;n<o;n++)if(0!==i[e][n]){Jl(i,e,n),Jl(s,e,n),t*=-1;break}if(n=i[e][e],0===n)return{determinant:0}}for(let t=0;t<o;t++)i[t][e]=i[t][e]/n,s[t][e]=s[t][e]/n;t*=n;for(let t=0;t<o;t++){if(t===e)continue;const n=i[e][t];for(let r=0;r<o;r++)i[r][t]-=n*i[r][e],s[r][t]-=n*s[r][e]}}return{inverted:s,determinant:t}}function Jl(e,t,o){for(let s=0;s<e.length;s++){const i=e[s][t];e[s][t]=e[s][o],e[s][o]=i}}function Ql(e,t){if(e.length<1||t.length<1)throw new Error("multiplyMatrices: empty matrices cannot be multiplied.");if(e.length!==t[0].length)throw new Error("multiplyMatrices: incompatible matrices size.");const o=e[0].length,s=t.length,i=e.length,n=Array(s);for(let r=0;r<s;r++){n[r]=Array(o);for(let s=0;s<o;s++){let o=0;for(let n=0;n<i;n++)o+=e[n][s]*t[r][n];n[r][s]=o}}return n}function ec(e){if(!js(e))return e;if(!tc(e))throw new Error("The value should be a scalar or a 1x1 matrix");return e[0][0]}function tc(e){return 1===e.length&&1===e[0].length}function oc(e){return js(e)&&!tc(e)}function sc(...e){const t=e[0].length;e.forEach(((e,o)=>Gl(e.length===t,Ho("[[FUNCTION_NAME]] has mismatched dimensions for argument %s (%s vs %s).",o.toString(),t.toString(),e.length.toString()))))}function ic(e,t){let o=0;const s=Pi(e,((e,t)=>(o+=1,e+t)),0,t);return Wl(o),s/o}function nc(e,t){let o=0;for(const s of e)if(js(s))for(const e of s)for(const t of e)"number"==typeof t.value&&(o+=1);else{const e=s?.value;gi(e)||"string"==typeof e&&!Rs(e,t)&&!ds(e,t)||(o+=1)}return o}function rc(e){return Fi(e,((e,t)=>void 0!==t&&null!==t.value?e+1:e),0)}function ac(e,t){let o={value:-1/0};return _i(e,(e=>{e.value>=o.value&&(o=e)}),t),o.value===-1/0?{value:0}:o}function lc(e,t){let o={value:1/0};return _i(e,(e=>{e.value<=o.value&&(o=e)}),t),o.value===1/0?{value:0}:o}function cc(e,t,o){const s=e[0].length?e:[je(1,t.flat().length+1)],i=s.length;let n=o[0].length?o:s;return n=n.length===i?Vi(n):n,{_X:s,_newX:n}}function hc(e,t,o=!0,s=!1){const i=t.flat(),n=i.length;let{_X:r}=cc(e,t,[[]]);r=r.length===n?Vi(r):r.slice(),sc(r[0],i);const a=r.length,l=n-a-(o?1:0),c=[i],h=Vi(r.reverse()),d=[];for(let e=0;e<a;e++)if(d.push(0),o){for(const t of r[e])d[e]+=t;d[e]/=n}let u=0;if(o){for(const e of i)u+=e;u/=n}const g=h.map((e=>e.map(((e,t)=>e-d[t]))));o&&h.forEach((e=>e.push(1)));const p=uc(h,c);if(o||p.push([0]),!s)return p;const m=Ql(g,Vi(g)),{inverted:f}=Kl(m);if(void 0===f)throw new si(Ho("Matrix is not invertible"));let v=0,b=0;for(let e=0;e<n;e++){const t=i[e]-u;let o=0;for(let t=0;t<a;t++){o+=g[e][t]*p[t][0]}const s=t-o;v+=s*s,b+=o*o}const S=Math.sqrt(v/l),C=b/(b+v),y=b/a/(v/l),w=[];for(let e=0;e<a;e++)w.push(S*Math.sqrt(f[e][e]));if(o){const e=Ql(f,[d]),t=Ql(Vi([d]),e);w.push(S*Math.sqrt(t[0][0]+1/i.length))}const I=[[p[0][0],w[0],C,y,b],[p[1][0],w[1],S,l,v]];for(let e=2;e<a;e++)I.push([p[e][0],w[e],"","",""]);return o?I.push([p[a][0],w[a],"","",""]):I.push([0,"","","",""]),I}function dc(e,t,o,s){sc(t,e),Gl(o>=1,Ho("Function [[FUNCTION_NAME]] A regression of order less than 1 cannot be possible."));const i=[e],n=t.map((e=>je(0,o).map((t=>Math.pow(e,o-t)))));s&&n.forEach((e=>e.push(1)));const r=uc(n,i);return s||r.push([0]),r}function uc(e,t){const o=Ql(e,Vi(e)),{inverted:s}=Kl(o);if(void 0===s)throw new si(Ho("Matrix is not invertible"));const i=Ql(e,t);return Vi(Ql(s,i))}function gc(e,t,o){return e.reduce(((e,s,i)=>e+s*Math.pow(t,o-i)),0)}function pc(e){return e.map((e=>e.map((e=>Math.exp(e)))))}function mc(e){return e.map((e=>e.map((e=>Math.log(e)))))}function fc(e,t,o,s){const{_X:i,_newX:n}=cc(t,e,o),r=hc(i,e,s,!1),a=r.length-1,l=n.map((e=>{let t=0;for(let o=0;o<a;o++)t+=r[o][0]*e[a-o-1];return t+=r[a][0],[t]}));return l.length===o.length?l:Vi(l)}const vc=new n;function bc(e){return vc.get(e)}const Sc={normalizeFunctionValue:e=>fi(e,qs),toValueAndFormat:(e,t)=>({value:fi(e,qs),format:"dd mmm yyyy"}),toFunctionValue(e){const t=Ri(e,qs);return`DATE(${t.getFullYear()},${t.getMonth()+1},${t.getDate()})`}},Cc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>31)throw new si(Ho("%s is not a valid day of month (it should be a number between 1 and 31)",t));return t},toValueAndFormat:e=>({value:fi(e,qs),format:"0"}),toFunctionValue:e=>`${e}`},yc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>7)throw new si(Ho("%s is not a valid day of week (it should be a number between 1 and 7)",t));return t},toValueAndFormat(e,t){const o=(e-1+(t||qs).weekStart)%7;return{value:wn[o].toString(),format:"@"}},toFunctionValue:e=>`${e}`},wc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>53)throw new si(Ho("%s is not a valid week (it should be a number between 0 and 53)",t));return t},toValueAndFormat:e=>({value:fi(e,qs),format:"0"}),toFunctionValue:e=>`${e}`},Ic={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>12)throw new si(Ho("%s is not a valid month (it should be a number between 1 and 12)",t));return t},toValueAndFormat:e=>({value:yn[fi(e,qs)-1].toString(),format:"@"}),toFunctionValue:e=>`${e}`},xc={normalizeFunctionValue:e=>In(fi(e,qs),{locale:qs,format:"mm/yyyy"}),toValueAndFormat:e=>({value:fi(e,qs),format:"mmmm yyyy"}),toFunctionValue(e){const t=Ri(e,qs);return`DATE(${t.getFullYear()},${t.getMonth()+1},1)`}},Ec={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>4)throw new si(Ho("%s is not a valid quarter (it should be a number between 1 and 4)",t));return t},toValueAndFormat:e=>({value:Ho("Q%(quarter_number)s",{quarter_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Rc={normalizeFunctionValue(e){const t=fi(e,qs);return t>3e3?Ri(t,qs).getFullYear():t},toValueAndFormat:e=>({value:fi(e,qs),format:"0"}),toFunctionValue:e=>`${e}`},Tc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>23)throw new si(Ho("%s is not a valid hour (it should be a number between 0 and 23)",t));return t},toValueAndFormat:e=>({value:Ho("%(hour_number)sh",{hour_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Ac={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>59)throw new si(Ho("%s is not a valid minute (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Ho("%(minute_number)s'",{minute_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Dc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>59)throw new si(Ho("%s is not a valid second (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Ho("%(second_number)s''",{second_number:e}),format:"@"}),toFunctionValue:e=>`${e}`};function _c(e){return{normalizeFunctionValue:t=>null===t?null:e.normalizeFunctionValue(t),toValueAndFormat:(t,o)=>null===t?{value:Ho("(Undefined)")}:e.toValueAndFormat(t,o),toFunctionValue:t=>null===t?"false":e.toFunctionValue(t)}}vc.add("day",_c(Sc)).add("year",_c(Rc)).add("day_of_month",_c(Cc)).add("iso_week_number",_c(wc)).add("month_number",_c(Ic)).add("month",_c(xc)).add("quarter_number",_c(Ec)).add("day_of_week",_c(yc)).add("hour_number",_c(Tc)).add("minute_number",_c(Ac)).add("second_number",_c(Dc));const Oc={count:Ho("Count"),count_distinct:Ho("Count Distinct"),bool_and:Ho("Boolean And"),bool_or:Ho("Boolean Or"),max:Ho("Maximum"),min:Ho("Minimum"),avg:Ho("Average"),sum:Ho("Sum")},Fc=["max","min","avg","sum","count_distinct","count"],Pc={integer:Fc,char:Fc,datetime:Fc,boolean:["count_distinct","count","bool_and","bool_or"]},Mc={};for(const e in Pc){Mc[e]={};for(const t of Pc[e])Mc[e][t]=Oc[t]}const Nc={count:e=>({value:rc([e]),format:"0"}),count_distinct:e=>({value:$l([e]),format:"0"}),bool_and:e=>({value:Ul([e]).result}),bool_or:e=>({value:Bl([e]).result}),max:(e,t)=>ac([e],t),min:(e,t)=>lc([e],t),avg:(e,t)=>({value:ic([e],t),format:ui(e)}),sum:(e,t)=>({value:zl([e],t),format:ui(e)})};function kc(e){const t=Object.keys(e);if(!t.length)return 0;const o=t.map((e=>parseInt(e,10)));return Math.max(...o)}const Vc={year:Ho("Year"),quarter:Ho("Quarter & Year"),month:Ho("Month & Year"),week:Ho("Week & Year"),day:Ho("Day"),quarter_number:Ho("Quarter"),month_number:Ho("Month"),iso_week_number:Ho("Week"),day_of_month:Ho("Day of Month"),day_of_week:Ho("Day of Week"),hour_number:Ho("Hour"),minute_number:Ho("Minute"),second_number:Ho("Second")},Lc=["date","datetime"];function Hc(e){const[t,o]=e.split(":");return o?{fieldName:t,granularity:o}:{fieldName:t}}function Uc(e){return Lc.includes(e.type)}function Bc(e,t,o){const s=[e];o&&s.push(`"${o}"`);for(const{field:e,value:o,type:i}of t){if("measure"===e){s.push('"measure"',`"${o}"`);continue}const{granularity:t}=Hc(e),n=qc(o,{type:i,granularity:t});s.push(`"${e}"`,n)}return s}function zc(e,t){let o=0,s=0;const i=t.columns.map((e=>e.nameWithGranularity)),n=t.rows.map((e=>e.nameWithGranularity));for(;void 0!==e[o]&&e[o]===n[s];)o++,s++;for(s=0;void 0!==e[o]&&e[o]===i[s];)o++,s++;return e.length===o}function $c(e,t){switch(t.type){case"HEADER":return`=PIVOT.HEADER(${Bc(e,t.domain).join(",")})`;case"VALUE":return`=PIVOT.VALUE(${Bc(e,t.domain,t.measure).join(",")})`;case"MEASURE_HEADER":return`=PIVOT.HEADER(${Bc(e,[...t.domain,{field:"measure",value:t.measure,type:"char"}]).join(",")})`}return""}function Gc(e,t){if(null===t||"null"===t)return null;const o="object"==typeof t?t.value:t;if(gi(o))return o;const s="boolean"==typeof t?wi(t).toLocaleLowerCase():wi(t);if("null"===s)return null;if(!jc.contains(e.type))throw new si(Ho("Field %(field)s is not supported because of its type (%(type)s)",{field:e.displayName,type:e.type}));if("false"===s.toLowerCase())return!1;return jc.get(e.type)(s,e.granularity)}function Wc(e,t){return bc(t??"month").normalizeFunctionValue(e)}function qc(e,t){return null===e?'"null"':Yc.contains(t.type)?Yc.get(t.type)(e,t.granularity):`"${e}"`}function Zc(e,t){return bc(t??"month").toFunctionValue(e)}const jc=new n;jc.add("date",Wc).add("datetime",Wc).add("integer",(e=>fi(e,qs))).add("boolean",(e=>Ei(e))).add("char",(e=>wi(e)));const Yc=new n;function Xc(e){return e.displayName+(e.granularity?` (${Vc[e.granularity]})`:"")}function Kc(e,t){try{if(!t.getMeasure(e.measure))return!1;const o=t.definition.columns;for(let s=0;s<e.domain.length;s++){if(o[s].nameWithGranularity!==e.domain[s].field)return!1;const i=t.getPossibleFieldValues(o[s]).map((e=>e.value));if(!(i.includes(e.domain[s].value)||null===e.domain[s].value&&i.includes("")))return!1}return!0}catch(e){return!1}}Yc.add("date",Zc).add("datetime",Zc).add("integer",(e=>`${fi(e,qs)}`)).add("boolean",(e=>Ei(e)?"TRUE":"FALSE")).add("char",(e=>`"${wi(e).replace(/"/g,'\\"')}"`));class Jc extends rl{isCutAllowed(e){return 1!==e.zones.length?"WrongCutSelection":"Success"}copy(e,t,o="copyPaste"){const s=e.sheetId,{clippedZones:i,rowsIndexes:n,columnsIndexes:r}=e,a=[],l=1===n.length&&1===r.length;for(const t of n){const i=[];for(const a of r){const c={col:a,row:t,sheetId:s};let h=this.getters.getCell(c);const d=this.getters.getEvaluatedCell(c),u=this.getters.getPivotIdFromPosition(c),g=this.getters.getArrayFormulaSpreadingOn(c);if("shiftCells"!==o&&u&&g){const t=this.getters.getSpreadZone(g);if((!mt(g,c)||!l)&&t&&!e.zones.some((e=>Rr(t,e)))){const e=this.getters.getPivotCellFromPosition(c),t=$c(this.getters.getPivotFormulaId(u),e);h={id:h?.id||"",style:h?.style,format:h?.format,content:t,isFormula:!1,parsedValue:d.value}}}else if("shiftCells"!==o&&g&&!mt(g,c)){const e=n.includes(g.row)&&r.includes(g.col)?"":In(d.value,{locale:this.getters.getLocale()});h={id:h?.id||"",style:h?.style,format:d.format,content:e,isFormula:!1,parsedValue:d.value}}i.push({content:h?.content??"",style:h?.style,format:h?.format,tokens:h?.isFormula?h.compiledFormula.tokens.map((({value:e,type:t})=>({value:e,type:t}))):[],border:this.getters.getCellBorder(c)||void 0,evaluatedCell:d,position:c})}a.push(i)}return{cells:a,zones:i,sheetId:e.sheetId}}isPasteAllowed(e,t,o,s){if(!o.cells)return"Success";if(s?.isCutOperation&&void 0!==s?.pasteOption)return"WrongPasteOption";if(t.length>1&&(o.cells.length>1||o.cells[0].length>1))return"WrongPasteSelection";const i=o.cells.length,n=o.cells[0].length;for(const s of el(t,o.cells))if(this.getters.doesIntersectMerge(e,s)&&(t.length>1||!this.getters.isSingleCellOrMerge(e,t[0])||i*n!=1))return"WillRemoveExistingMerge";return"Success"}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.cells,o)}getPasteTarget(e,t,o,s){const i=o.cells[0].length,n=o.cells.length;return s?.isCutOperation?{sheetId:e,zones:[{left:t[0].left,top:t[0].top,right:t[0].left+i-1,bottom:t[0].top+n-1}]}:1===i&&1===n?{zones:[],sheetId:e}:{sheetId:e,zones:el(t,o.cells)}}pasteFromCut(e,t,o,s){this.clearClippedZones(o);const i=t[0];this.pasteZone(e,i.left,i.top,o.cells,s)}clearClippedZones(e){this.dispatch("CLEAR_CELLS",{sheetId:e.sheetId,target:e.zones}),this.dispatch("CLEAR_FORMATTING",{sheetId:e.sheetId,target:e.zones})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){if(!a)continue;const r={col:t+s,row:o+n,sheetId:e};this.pasteCell(a,r,i)}}pasteCell(e,t,o){const{sheetId:s,col:i,row:n}=t,r=this.getters.getEvaluatedCell(t),a=e?.format??e.evaluatedCell.format;if("asValue"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,content:e.evaluatedCell.value?.toString()||"",format:a});if("onlyFormat"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,style:e?.style??null,format:a??r.format});let l=e?.content;e?.tokens&&e.tokens.length>0&&!o?.isCutOperation?l=this.getters.getTranslatedCellFormula(s,i-e.position.col,n-e.position.row,e.tokens):e?.tokens&&e.tokens.length>0&&(l=this.getters.getFormulaMovedInSheet(e.position.sheetId,s,e.tokens)),""!==l||e?.format||e?.style?this.dispatch("UPDATE_CELL",{...t,content:l,style:e?.style||null,format:e?.format}):r&&this.dispatch("CLEAR_CELL",t)}convertTextToClipboardData(e){const t=this.getters.getLocale(),o={cells:[]},s=[];let i=0;for(const[t,o]of e.replace(/\r/g,"").split("\n").entries())s.push(o.split("\t")),s[t].length>i&&(i=s[t].length);for(const e of s){const s=[];for(let o=0;o<i;o++){const i=Dl(e[o]||"",t);s.push({content:i,evaluatedCell:{formattedValue:i}})}o.cells.push(s)}return o}}class Qc extends nl{copy(e){}}const eh={figureHandlers:new n,cellHandlers:new n};function th(e,t){return"REMOVE_COLUMNS_ROWS"===t.type?Cr(e,"COL"===t.dimension?"left":"top",t.elements):"ADD_COLUMNS_ROWS"===t.type?vr(e,"COL"===t.dimension?"left":"top",t.base,t.position,t.quantity):e}function oh(e,t){const o="DELETE_SHEET"===t.type&&t.sheetId;if("sheetId"in t&&e._sheetId!==t.sheetId)return e;{const s=th(e._zone,t);if(s&&o!==e._sheetId)return{...e,_zone:s}}}eh.figureHandlers.add("chart",class extends Qc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);if("chart"!==o.tag)return;const s={...o},i=this.getters.getChart(e.figureId);if(!i)throw new Error(`No chart for the given id: ${e.figureId}`);const n=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:s,copiedChart:n}}getPasteTarget(e,t,o,s){return{zones:[],figureId:(new Ka).smallUuid(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=e.sheetId,{width:r,height:a}=t.copiedFigure,l=t.copiedChart.copyInSheetId(n),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_CHART",{figureId:i,sheetId:n,definition:l.getDefinition(),col:h,row:d,offset:u,size:{height:a,width:r}}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedChart.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("image",class extends Qc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);const s={...o};if("image"!==o.tag)return;const i=ze(this.getters.getImage(e.figureId));return{figureId:e.figureId,copiedFigure:s,copiedImage:i,sheetId:t}}getPasteTarget(e,t,o,s){return{sheetId:e,zones:[],figureId:(new Ka).smallUuid()}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=this.getters.getActiveSheetId(),{width:r,height:a}=t.copiedFigure,l=ze(t.copiedImage),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_IMAGE",{figureId:i,sheetId:n,col:h,row:d,offset:u,size:{height:a,width:r},definition:l}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}),eh.cellHandlers.add("dataValidation",class extends rl{uuidGenerator=new Ka;queuedChanges={};copy(e){const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o={sheetId:s,col:i,row:e},n=this.getters.getValidationRuleForCell(o);t.push({position:o,rule:n})}i.push(t)}return{dvRules:i}}paste(e,t,o){if(this.queuedChanges={},o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.dvRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteDataValidation(a,r,i?.isCutOperation)}}pasteDataValidation(e,t,o){if(e){const s=Mr(t),i=Mr(e.position),n=e.rule;if(!n){const e=this.getters.getValidationRuleForCell(t);return void(e&&this.adaptDataValidationRule(t.sheetId,e,[],[s]))}const r=[];if(o&&r.push(i),e.position.sheetId===t.sheetId){const o=this.getDataValidationRuleToCopyTo(t.sheetId,n,!1);this.adaptDataValidationRule(e.position.sheetId,o,[s],r)}else{const o=this.getters.getValidationRuleForCell(e.position);o&&this.adaptDataValidationRule(e.position.sheetId,o,[],r);const i=this.getDataValidationRuleToCopyTo(t.sheetId,n);this.adaptDataValidationRule(t.sheetId,i,[s],[])}}}getDataValidationRuleToCopyTo(e,t,o=!0){let s=this.getters.getDataValidationRules(e).find((e=>mt(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking));const i=this.queuedChanges[e];return!s&&i&&(s=i.find((e=>mt(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking))?.rule),s||{...t,id:o?this.uuidGenerator.smallUuid():t.id,ranges:[]}}adaptDataValidationRule(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.rule.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,rule:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,rule:s}of this.queuedChanges[e]){const i=s.ranges.map((e=>e.zone)),n=nr(i,o),r=nr([...n,...t],[]);0!==r.length?this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:{id:s.id,criterion:s.criterion,isBlocking:s.isBlocking},ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e}):this.dispatch("REMOVE_DATA_VALIDATION_RULE",{sheetId:e,id:s.id})}}}).add("cell",Jc).add("sheet",class extends rl{isPasteAllowed(e,t,o,s){if(!("cells"in o))return"Success";const{xSplit:i,ySplit:n}=this.getters.getPaneDivisions(e);return Hr(el(t,o.cells),i,n)?"FrozenPaneOverlap":"Success"}}).add("merge",class extends rl{copy(e){const t=this.getters.getActiveSheetId(),{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getMerge(s))}i.push(o)}return{merges:i,sheetId:t}}paste(e,t,o){if(o.isCutOperation){const e=t.merges.flat().filter(lt);this.dispatch("REMOVE_MERGE",{sheetId:t.sheetId,target:e})}this.pasteFromCopy(e.sheetId,e.zones,t.merges,o)}pasteZone(e,t,o,s){for(const[i,n]of s.entries())for(const[s,r]of n.entries()){const n={col:t+s,row:o+i,sheetId:e};this.pasteMerge(r,n)}}pasteMerge(e,t){if(!e)return;if(this.getters.isInMerge(t))return;const{sheetId:o,col:s,row:i}=t;this.dispatch("ADD_MERGE",{sheetId:o,force:!0,target:[{left:s,top:i,right:s+e.right-e.left,bottom:i+e.bottom-e.top}]})}}).add("border",class extends rl{queuedBordersToAdd={};copy(e){const t=e.sheetId;if(0===e.zones.length)return;const{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getCellBorder(s))}i.push(o)}return{borders:i}}paste(e,t,o){const s=e.sheetId;if("asValue"===o.pasteOption)return;const i=e.zones;if(o.isCutOperation){const{left:e,top:o}=i[0];this.pasteZone(s,e,o,t.borders)}else this.pasteFromCopy(s,i,t.borders);this.executeQueuedChanges(s)}pasteZone(e,t,o,s){for(const[i,n]of s.entries())for(const[s,r]of n.entries()){const n={col:t+s,row:o+i,sheetId:e};this.pasteBorder(r,n)}}pasteBorder(e,t){const o={...this.getters.getCellBorder(t),...e},s=JSON.stringify(o);this.queuedBordersToAdd[s]||(this.queuedBordersToAdd[s]=[]),this.queuedBordersToAdd[s].push(Mr(t))}executeQueuedChanges(e){for(const t in this.queuedBordersToAdd){const o=this.queuedBordersToAdd[t],s=JSON.parse(t),i=nr(o,[]);this.dispatch("SET_BORDERS_ON_TARGET",{sheetId:e,target:i,border:s})}this.queuedBordersToAdd={}}}).add("table",class extends rl{copy(e,t,o="copyPaste"){const s=e.sheetId,{rowsIndexes:i,columnsIndexes:n,zones:r}=e,a=new Set,l=[];for(const e of i){const c=[];l.push(c);for(const l of n){const n={col:l,row:e,sheetId:s},h=this.getters.getTable(n);if(!h){c.push({});continue}const d=this.getters.getCoreTable(n),u=d?.range.zone;let g;if(!a.has(h.id)&&d&&u&&r.some((e=>Rr(u,e)))){a.add(h.id);let{numberOfRows:e}=Tr(u);for(let o=u.top;o<=u.bottom;o++)t||i.includes(o)||e--;const o=d.range,s=this.getters.extendRange(d.range,"ROW",o.zone.top+e-1-o.zone.bottom);g={range:this.getters.getRangeData(s),config:d.config,type:d.type}}"shiftCells"!==o&&c.push({table:g,style:this.getTableStyleToCopy(n),isWholeTableCopied:a.has(h.id)})}}return{tableCells:l,sheetId:e.sheetId}}getTableStyleToCopy(e){const t=this.getters.getCellTableStyle(e),o=this.getters.getCellStyle(e),s=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...bt(o)},border:{...s,...bt(i)}}}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.tableCells,o)}pasteFromCut(e,t,o,s){for(const e of o.tableCells)for(const t of e)t.table&&this.dispatch("REMOVE_TABLE",{sheetId:o.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});const i=t[0];this.pasteZone(e,i.left,i.top,o.tableCells,s)}pasteZone(e,t,o,s,i){for(let n=0;n<s.length;n++){const r=s[n];for(let s=0;s<r.length;s++){const a=r[s];if(!a)continue;const l={col:t+s,row:o+n,sheetId:e};this.pasteTableCell(e,a,l,i)}}if(1===s.length)for(let i=0;i<s[0].length;i++)this.dispatch("AUTOFILL_TABLE_COLUMN",{col:t+i,row:o,sheetId:e})}pasteTableCell(e,t,o,s){if(t.table&&!s?.pasteOption){const{range:s}=t.table,i=Tr(this.getters.getRangeFromRangeData(s).zone),n={left:o.col,top:o.row,right:o.col+i.numberOfCols-1,bottom:o.row+i.numberOfRows-1};this.dispatch("CREATE_TABLE",{sheetId:o.sheetId,ranges:[this.getters.getRangeDataFromZone(e,n)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(o)||"asValue"===s?.pasteOption||(s?.pasteOption||t.isWholeTableCopied)&&"onlyFormat"!==s?.pasteOption||(t.style?.style&&this.dispatch("UPDATE_CELL",{...o,style:t.style.style}),t.style?.border&&this.dispatch("SET_BORDER",{...o,border:t.style.border}))}}).add("conditionalFormat",class extends rl{uuidGenerator=new Ka;queuedChanges={};copy(e){if(!e.zones.length)return;const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o=Array.from(this.getters.getRulesByCell(s,i,e));t.push({position:{col:i,row:e,sheetId:s},rules:o})}i.push(t)}return{cfRules:i}}paste(e,t,o){if(this.queuedChanges={},"asValue"===o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.cfRules,o),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.cfRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteCf(a,r,i?.isCutOperation)}}pasteCf(e,t,o){if(e?.rules&&e.rules.length>0){const s=Mr(e.position),i=Mr(t);for(const n of e.rules){const r=[];if(o&&r.push(s),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,n,[i],r);else{this.adaptCFRules(e.position.sheetId,n,[],r);const o=this.getCFToCopyTo(t.sheetId,n);this.adaptCFRules(t.sheetId,o,[i],[])}}}}adaptCFRules(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.cf.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,cf:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,cf:s}of this.queuedChanges[e]){const i=this.getters.getAdaptedCfRanges(e,s,t,o);i&&(0!==i.length?this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:s.id,rule:s.rule,stopIfTrue:s.stopIfTrue},ranges:i,sheetId:e}):this.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:s.id,sheetId:e}))}}getCFToCopyTo(e,t){let o=this.getters.getConditionalFormats(e).find((e=>e.stopIfTrue===t.stopIfTrue&&mt(e.rule,t.rule)));const s=this.queuedChanges[e];return!o&&s&&(o=s.find((e=>e.cf.stopIfTrue===t.stopIfTrue&&mt(e.cf.rule,t.rule)))?.cf),o||{...t,id:this.uuidGenerator.smallUuid(),ranges:[]}}}).add("references",class extends rl{copy(e){return{zones:e.clippedZones,sheetId:e.sheetId}}paste(e,t,o){if(o.isCutOperation){const o=e.zones[0];this.dispatch("MOVE_RANGES",{target:t.zones,sheetId:t.sheetId,sheetName:this.getters.getSheetName(t.sheetId),targetSheetId:e.sheetId,col:o.left,row:o.top})}}});class sh{subscriptions={};on(e,t,o){if(!o)throw new Error("Missing callback");this.subscriptions[e]||(this.subscriptions[e]=[]),this.subscriptions[e].push({owner:t,callback:o})}trigger(e,t){const o=this.subscriptions[e]||[];for(let e=0,s=o.length;e<s;e++){const s=o[e];s.callback.call(s.owner,t)}}off(e,t){const o=this.subscriptions[e];o&&(this.subscriptions[e]=o.filter((e=>e.owner!==t)))}clear(){this.subscriptions={}}}class ih extends sh{dependencies=new Map;factory=new nh(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw new Error(`Store ${e.name} already has an instance`);this.dependencies.set(e,t)}get(e){return this.dependencies.has(e)||this.dependencies.set(e,this.instantiate(e)),this.dependencies.get(e)}instantiate(e,...t){return this.factory.build(e,...t)}resetStores(){this.dependencies.clear()}dispose(){for(const e of this.dependencies.values())"dispose"in e&&"function"==typeof e.dispose&&e.dispose()}}class nh{get;pendingBuilds=new Set;constructor(e){this.get=e}build(e,...t){if(this.pendingBuilds.has(e))throw new Error(`Circular dependency detected: ${[...this.pendingBuilds,e].map((e=>e.name)).join(" -> ")}`);this.pendingBuilds.add(e);const o=new e(this.get,...t);return this.pendingBuilds.delete(e),o}}class rh{get;disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach((e=>e()))}}function ah(){const e=t.useEnv();if(e.__spreadsheet_stores__ instanceof ih)return e.__spreadsheet_stores__;const o=new ih;return t.useSubEnv({__spreadsheet_stores__:o,getStore:e=>dh(o.get(e),(()=>o.trigger("store-updated")))}),t.onWillUnmount((()=>o.dispose())),o}function lh(e){const o=uh(t.useEnv()),s=o.get(e);return hh(o,s)}function ch(e,...o){const s=uh(t.useEnv()),i=s.instantiate(e,...o);return t.onWillUnmount((()=>i.dispose())),hh(s,i)}function hh(e,o){const s=t.useComponent();return dh(o,(()=>{"mounted"===t.status(s)&&e.trigger("store-updated")}))}function dh(e,t){return new Proxy(e,{get(o,s,i){const n=o,r=Reflect.get(o,s,n);if(e.mutators?.includes(s)){const e=new Proxy(r,{apply(e,o,s){"noStateChange"!==Reflect.apply(e,n,s)&&t()}});return e}return r}})}function uh(e){const t=e.__spreadsheet_stores__;if(!(t instanceof ih))throw new Error("No store provider found. Did you forget to call useStoreProvider()?");return t}const gh=(ph="Model",class{constructor(e){throw new Error(`This is a abstract store for ${ph}, it cannot be instantiated.\nDid you forget to inject your store instance?\n\nconst stores = useStoreProvider();\nstores.inject(MyMetaStore, storeInstance);\n`)}});var ph;class mh{mutators=["register","unRegister","draw","startAnimation","stopAnimation"];renderers={};model;context=void 0;animationFrameId=null;registeredAnimations=new Set;constructor(e){this.model=e(gh)}register(e){if(e.renderingLayers.length)for(const t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(const t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter((t=>t!==e))}drawLayer(e,t,o){const s=this.renderers[t];if(s)for(const i of s)e.ctx.save(),i.drawLayer(e,t,o),e.ctx.restore();return"noStateChange"}draw(e,t){if(!(e=e||this.context))throw new Error("Rendering context is not defined");this.context=e;for(const o of Ks())this.model.drawLayer(e,o),this.drawLayer(e,o,t);return"noStateChange"}startAnimation(e){if(this.registeredAnimations.add(e),!this.animationFrameId){const e=t=>{this.animationFrameId=requestAnimationFrame(e),this.draw(void 0,t)};this.animationFrameId=requestAnimationFrame(e)}return"noStateChange"}stopAnimation(e){return this.registeredAnimations.delete(e),0===this.registeredAnimations.size&&null!==this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null),"noStateChange"}dispose(){this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null)}}class fh extends rh{model=this.get(gh);getters=this.model.getters;renderer=this.get(mh);constructor(e){super(e),this.model.on("command-dispatched",this,this.handle),this.model.on("command-finalized",this,this.finalize),this.renderer.register(this),this.onDispose((()=>{this.model.off("command-dispatched",this),this.model.off("command-finalized",this),this.renderer.unRegister(this)}))}get renderingLayers(){return[]}handle(e){}finalize(){}drawLayer(e,t,o){}}const vh={id:"void-composer",get editionMode(){return"inactive"},startEdition:()=>{throw new Error("No composer is registered")},stopEdition:()=>{throw new Error("No composer is registered")},setCurrentContent:()=>{throw new Error("No composer is registered")}};class bh extends fh{mutators=["focusComposer","focusActiveComposer"];activeComposer=vh;_focusMode="inactive";get focusMode(){return"inactive"===this.activeComposer.editionMode?"inactive":this._focusMode}focusComposer(e,t){if(this.activeComposer=e,this.getters.isReadonly())return"noStateChange";this._focusMode=t.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(t)}focusActiveComposer(e){if(this.getters.isReadonly())return"noStateChange";if(!this.activeComposer)throw new Error("No composer is registered");this._focusMode=e.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(e)}setComposerContent({content:e,selection:t}){"inactive"===this.activeComposer.editionMode?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}}const Sh={};let Ch=0;function yh(e,...t){const o="__sheet__"+Ch++;return function(e,t){const o=document.createElement("style");o.textContent=function(e){const t=e.split(/(\{|\}|;)/).map((e=>e.trim())),o=[],s=[];let i=[];function n(e,t){const s=[];for(const i of o[e]){let r=t&&t+" "+i||i;r.includes("&")&&(r=i.replace(/&/g,t||"")),e<o.length-1&&(r=n(e+1,r)),s.push(r)}return s.join(", ")}function r(){i.length&&(s.push(n(0)+" {"),s.push(...i),s.push("}"),i=[])}for(;t.length;){const e=t.shift();"}"===e?(r(),o.pop()):("{"===t[0]&&(r(),o.push(e.split(/\s*,\s*/)),t.shift()),";"===t[0]&&i.push(" "+e+";"))}return s.join("\n")}(t),Sh[e]=o}(o,String.raw(e,...t)),function(e){const t=Sh[e];t.setAttribute("component",e),document.head.appendChild(t)}(o),o}function wh({strikethrough:e,underline:t}){return e||t?`${e?"line-through":""} ${t?"underline":""}`:"none"}function Ih(e){const t=function(e){const t={};if(!e)return t;e.bold&&(t["font-weight"]="bold");e.italic&&(t["font-style"]="italic");if(e.strikethrough||e.underline){let o=e.strikethrough?"line-through":"";o=e.underline?o+" underline":o,t["text-decoration"]=o}e.textColor&&(t.color=e.textColor);return t}(e);return e?(e.fillColor&&(t.background=e.fillColor),t):t}function xh(e){let t="";for(const o in e)e[o]&&(t+=`${o}:${e[o]}; `);return t}const Eh=new n;function Rh(){if(window.Chart&&!window.Chart.registry.plugins.get("chartShowValuesPlugin"))for(const e of Eh.getAll())e.register(window.Chart)}class Th extends fh{mutators=["disableAnimationForChart","enableAnimationForChart"];animationPlayed={};disableAnimationForChart(e,t){return this.animationPlayed[e]=t,"noStateChange"}enableAnimationForChart(e){return this.animationPlayed[e]=void 0,"noStateChange"}}function Ah(){return class extends window.Chart.BarController{static id="funnel";static defaults={...window.Chart?.BarController.defaults,dataElementType:"funnel",animation:{duration:e=>{if("data"!==e.type)return 1e3;return e.raw[1]/Math.max(...e.dataset.data.map((e=>e[1])))*1e3}}};updateElements(e,t,o,s){super.updateElements(e,t,o,s);for(let i=t;i<t+o;i++){const t=e[i];this.updateElement(t,i,{nextElement:e[i+1]},s)}}}}function Dh(){return class extends window.Chart.BarElement{static id="funnel";draw(e){e.save();const{x:t,y:o,height:s,nextElement:i,base:n,options:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=_h(this),l=(a-(i?_h(i):0))/2,c=Math.min(t,n),h=o-s/2;e.fillStyle=r.backgroundColor,e.beginPath(),e.moveTo(c,h),e.lineTo(c+a,h),e.lineTo(c+a-l,h+s),e.lineTo(c+l,h+s),e.closePath(),e.fill(),r.borderWidth&&(e.strokeStyle=r.borderColor,e.lineWidth=r.borderWidth,e.stroke()),e.restore()}inRange(e,t){const{x:o,y:s,height:i,nextElement:n,base:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=_h(this),l=n?_h(n):0,c=Math.min(o,r),h=s-i/2;if(t<h||t>h+i)return!1;const d=(a-l)/2;return!(e<c+d*(t-h)/i||e>c+a-d*(t-h)/i)}}}function _h(e){const{x:t,base:o}=e.getProps(["x","base"]),s=Math.min(t,o);return Math.max(t,o)-s}const Oh=function(e){if(!e.length)return{x:0,y:0};const t=e[0].element,{x:o,y:s,base:i,width:n,height:r}=t.getProps(["x","y","width","height","base"]);return{x:Math.min(o,i)+2*n/3,y:s-r/2+r/2}},Fh="000000",Ph={arrows:"3Arrows",smiley:"3Symbols",dots:"3TrafficLights1"},Mh={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"},Nh="http://schemas.openxmlformats.org/drawingml/2006/main",kh="http://schemas.openxmlformats.org/drawingml/2006/chart",Vh={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",macroEnabledWorkbook:"application/vnd.ms-excel.sheet.macroEnabled.main+xml",templateWorkbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml",macroEnabledTemplateWorkbook:"application/vnd.ms-excel.template.macroEnabled.main+xml",excelAddInWorkbook:"application/vnd.ms-excel.addin.macroEnabled.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",metadata:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+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"},Lh={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",metadata:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sheetMetadata",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"},Hh="bdbb8cdc-fa1e-496e-a857-3c3f30c029c3",Uh="http://schemas.openxmlformats.org/officeDocument/2006/relationships",Bh=.75,zh=.143,$h=8.43,Gh=12.75,Wh=30,qh=100,Zh=164,jh={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}]},Yh=["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"],Xh="[Content_Types].xml",Kh=/(.*?)\((.*?)\)(.*)/,Jh=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META"];function Qh(e,t=""){return function(e,t){const o=e.match(Kh),s=o[1].trim();if(!s)throw new Error(`Function argument definition is missing a name: '${e}'.`);const i=[];let n,r=!1,a=!1;for(const e of o[2].split(",")){const t=e.trim().toUpperCase(),o=Jh.find((e=>t===e));o?i.push(o):"RANGE<ANY>"===t?i.push("RANGE"):"OPTIONAL"===t?r=!0:"REPEATING"===t?a=!0:t.startsWith("DEFAULT=")&&(n=e.trim().slice(8))}const l={name:s,description:t,type:i};(i.includes("ANY")||i.includes("RANGE"))&&(l.acceptErrors=!0);r&&(l.optional=!0);a&&(l.repeating=!0);void 0!==n&&(l.default=!0,l.defaultValue=n);i.some((e=>e.startsWith("RANGE")))&&(l.acceptMatrix=!0);i.every((e=>e.startsWith("RANGE")))&&(l.acceptMatrixOnly=!0);return l}(e,t)}const ed={};function td(e,t){const o=e.name,s=ed[o]?.[t];return s||(ed[o]||(ed[o]={}),ed[o][t]||(ed[o][t]=function(e,t){const o={},s=e.nbrArgRepeating?Math.floor((t-e.minArgRequired)/e.nbrArgRepeating):0,i=e.nbrArgRepeating*s,n=t-e.minArgRequired-i;let r=0,a=0;for(let t=0;t<e.args.length;t++){const i=e.args[t];if(i.optional||i.default)a<n&&(o[r]=t,r++),a++;else if(i.repeating){for(let i=0;i<s;i++)for(let s=0;s<e.nbrArgRepeating;s++)o[r]=t+s,r++;t+=e.nbrArgRepeating-1}else o[r]=t,r++}return e=>o[e]}(e,t)),ed[o][t])}const od={description:Ho("Returns a result array constrained to a specific width and height."),args:[Qh("input_range (any, range<any>)",Ho("The range to constrain.")),Qh("rows (number)",Ho("The number of rows in the constrained array.")),Qh("columns (number)",Ho("The number of columns in the constrained array."))],compute:function(e,t,o){const s=ji(e),i=Ci(t?.value,this.locale),n=Ci(o?.value,this.locale);if(i<=0)return new si(Ho("The rows argument (%s) must be strictly positive.",i.toString()));if(n<=0)return new si(Ho("The columns argument (%s) must be strictly positive.",n.toString()));const r=Math.min(i,s[0].length);return Ni(Math.min(n,s.length),r,((e,t)=>s[e][t]))},isExported:!1},sd={description:Ho("Creates a new array from the selected columns in the existing range."),args:[Qh("array (any, range<any>)",Ho("The array that contains the columns to be returned.")),Qh("col_num (number, range<number>)",Ho("The first column index of the columns to be returned.")),Qh("col_num2 (number, range<number>, repeating)",Ho("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=ji(e),s=Yi(t,(e=>Ci(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));if(0!==i.length)return new si(Ho("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},id={description:Ho("Creates a new array from the selected rows in the existing range."),args:[Qh("array (any, range<any>)",Ho("The array that contains the rows to be returned.")),Qh("row_num (number, range<number>)",Ho("The first row index of the rows to be returned.")),Qh("row_num2 (number, range<number>, repeating)",Ho("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=ji(e),s=Yi(t,(e=>Ci(e?.value,this.locale))),i=o.length,n=s.filter((e=>0===e||o[0].length<Math.abs(e)));return 0!==n.length?new si(Ho("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),n.join(","))):Ni(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},nd={description:Ho("Expands or pads an array to specified row and column dimensions."),args:[Qh("array (any, range<any>)",Ho("The array to expand.")),Qh("rows (number)",Ho("The number of rows in the expanded array. If missing, rows will not be expanded.")),Qh("columns (number, optional)",Ho("The number of columns in the expanded array. If missing, columns will not be expanded.")),Qh("pad_with (any, default=0)",Ho("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=ji(e),n=Ci(t?.value,this.locale),r=void 0!==o?Ci(o.value,this.locale):i.length;return n<i[0].length?new si(Ho("The rows arguments (%s) must be greater or equal than the number of rows of the array.",n.toString())):r<i.length?new si(Ho("The columns arguments (%s) must be greater or equal than the number of columns of the array.",r.toString())):Ni(r,n,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},rd={description:Ho("Flattens all the values from one or more ranges into a single column."),args:[Qh("range (any, range<any>)",Ho("The first range to flatten.")),Qh("range2 (any, range<any>, repeating)",Ho("Additional ranges to flatten."))],compute:function(...e){return[Yi(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},ad={description:Ho("Calculates the frequency distribution of a range."),args:[Qh("data (range<number>)",Ho("The array of ranges containing the values to be counted.")),Qh("classes (number, range<number>)",Ho("The range containing the set of classes."))],compute:function(e,t){const o=Yi([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=Yi([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},ld={description:Ho("Appends ranges horizontally and in sequence to return a larger array."),args:[Qh("range1 (any, range<any>)",Ho("The first range to be appended.")),Qh("range2 (any, range<any>, repeating)",Ho("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=ji(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},cd={description:Ho("Returns the matrix determinant of a square matrix."),args:[Qh("square_matrix (number, range<number>)",Ho("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=bi(e,"square_matrix");return jl(t)?Kl(t).determinant:new si(Ho("The argument square_matrix must have the same number of columns and rows."))},isExported:!0},hd={description:Ho("Returns the multiplicative inverse of a square matrix."),args:[Qh("square_matrix (number, range<number>)",Ho("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=bi(e,"square_matrix");if(!jl(t))return new si(Ho("The argument square_matrix must have the same number of columns and rows."));const{inverted:o}=Kl(t);return o||new si(Ho("The matrix is not invertible."))},isExported:!0},dd={description:Ho("Calculates the matrix product of two matrices."),args:[Qh("matrix1 (number, range<number>)",Ho("The first matrix in the matrix multiplication operation.")),Qh("matrix2 (number, range<number>)",Ho("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=bi(e,"matrix1"),s=bi(t,"matrix2");return 0===o.length||0===s.length?new si(Ho("The first and second arguments of [[FUNCTION_NAME]] must be non-empty matrices.")):o.length!==s[0].length?new si(Ho("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())):Ql(o,s)},isExported:!0},ud={description:Ho("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[Qh("range1 (number, range<number>)",Ho("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),Qh("range2 (number, range<number>, repeating)",Ho("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){if(!Zl(...e))return new si(Ho("All the ranges must have the same dimensions."));const t=e.map(ji);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*=fi(o[e][s],this.locale);o+=i}return o},isExported:!0};function gd(e,t,o){if(!Zl(e,t))return new si(Ho("The arguments array_x and array_y must have the same dimensions."));const s=ji(e),i=ji(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 si(Ho("The arguments array_x and array_y must contain at least one pair of numbers."))}const pd={description:Ho("Calculates the sum of the difference of the squares of the values in two array."),args:[Qh("array_x (number, range<number>)",Ho("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),Qh("array_y (number, range<number>)",Ho("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 gd(e,t,((e,t)=>e**2-t**2))},isExported:!0},md={description:Ho("Calculates the sum of the sum of the squares of the values in two array."),args:[Qh("array_x (number, range<number>)",Ho("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),Qh("array_y (number, range<number>)",Ho("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 gd(e,t,((e,t)=>e**2+t**2))},isExported:!0},fd={description:Ho("Calculates the sum of squares of the differences of values in two array."),args:[Qh("array_x (number, range<number>)",Ho("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),Qh("array_y (number, range<number>)",Ho("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 gd(e,t,((e,t)=>(e-t)**2))},isExported:!0},vd=!1,bd=[Qh("array (any, range<any>)",Ho("The array which will be transformed.")),Qh("ignore (number, default=0)",Ho("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.")),Qh("scan_by_column (number, default=false)",Ho("Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row."))];function Sd(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!gi(e.value);if(3===t)return e=>null!==e.value&&!gi(e.value);throw new si(Ho("Argument ignore must be between 0 and 3"))}const Cd={description:Ho("Transforms a range of cells into a single column."),args:bd,compute:function(e,t={value:0},o={value:vd}){const s=ji(e),i=fi(t.value,this.locale),n=(Ei(o.value)?s:Vi(s)).flat().filter(Sd(i));return 0===n.length?new ai(Ho("No results for the given arguments of TOCOL.")):[n]},isExported:!0},yd={description:Ho("Transforms a range of cells into a single row."),args:bd,compute:function(e,t={value:0},o={value:vd}){const s=ji(e),i=fi(t.value,this.locale),n=(Ei(o.value)?s:Vi(s)).flat().filter(Sd(i)).map((e=>[e]));return 0===n.length||0===n[0].length?new ai(Ho("No results for the given arguments of TOROW.")):n},isExported:!0},wd={description:Ho("Transposes the rows and columns of a range."),args:[Qh("range (any, range<any>)",Ho("The range to be transposed."))],compute:function(e){const t=ji(e);return Ni(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},Id={description:Ho("Appends ranges vertically and in sequence to return a larger array."),args:[Qh("range1 (any, range<any>)",Ho("The first range to be appended.")),Qh("range2 (any, range<any>, repeating)",Ho("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>ji(e).length))),o=e.reduce(((e,t)=>e+ji(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=ji(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},xd={description:Ho("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[Qh("range (any, range<any>)",Ho("The range to wrap.")),Qh("wrap_count (number)",Ho("The maximum number of cells for each column, rounded down to the nearest whole number.")),Qh("pad_with (any, default=0)",Ho("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=ji(e),i=Ci(t?.value,this.locale);if(!ql(s))return new si(Ho("Argument range must be a single row or column."));const n=s.flat();return Ni(Math.ceil(n.length/i),i,((e,t)=>{const s=e*i+t;return s<n.length?n[s]:o}))},isExported:!0},Ed={description:Ho("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[Qh("range (any, range<any>)",Ho("The range to wrap.")),Qh("wrap_count (number)",Ho("The maximum number of cells for each row, rounded down to the nearest whole number.")),Qh("pad_with (any, default=0)",Ho("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=ji(e),i=Ci(t?.value,this.locale);if(!ql(s))return new si(Ho("Argument range must be a single row or column."));const n=s.flat(),r=Math.ceil(n.length/i);return Ni(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:od,CHOOSECOLS:sd,CHOOSEROWS:id,EXPAND:nd,FLATTEN:rd,FREQUENCY:ad,HSTACK:ld,MDETERM:cd,MINVERSE:hd,MMULT:dd,SUMPRODUCT:ud,SUMX2MY2:pd,SUMX2PY2:md,SUMXMY2:fd,TOCOL:Cd,TOROW:yd,TRANSPOSE:wd,VSTACK:Id,WRAPCOLS:xd,WRAPROWS:Ed});const Td={description:Ho("Apply a large number format"),args:[Qh("value (number)",Ho("The number.")),Qh("unit (string, optional)",Ho("The formatting unit. Use 'k', 'm', or 'b' to force the unit"))],compute:function(e,t){return{value:fi(e,this.locale),format:$n(e,t,this.locale)}}};var Ad=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:Td});const Dd=/^-?[a-z0-9]+$/i,_d={description:Ho("Absolute value of a number."),args:[Qh("value (number)",Ho("The number of which to return the absolute value."))],compute:function(e){return Math.abs(fi(e,this.locale))},isExported:!0},Od={description:Ho("Inverse cosine of a value, in radians."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)>1?new si(Ho("The value (%s) must be between -1 and 1 inclusive.",t)):Math.acos(t)},isExported:!0},Fd={description:Ho("Inverse hyperbolic cosine of a number."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=fi(e,this.locale);return t<1?new si(Ho("The value (%s) must be greater than or equal to 1.",t)):Math.acosh(t)},isExported:!0},Pd={description:Ho("Inverse cotangent of a value."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=fi(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},Md={description:Ho("Inverse hyperbolic cotangent of a value."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)<=1?new si(Ho("The value (%s) cannot be between -1 and 1 inclusive.",t)):Math.log((t+1)/(t-1))/2},isExported:!0},Nd={description:Ho("Inverse sine of a value, in radians."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)>1?new si(Ho("The value (%s) must be between -1 and 1 inclusive.",t)):Math.asin(t)},isExported:!0},kd={description:Ho("Inverse hyperbolic sine of a number."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(fi(e,this.locale))},isExported:!0},Vd={description:Ho("Inverse tangent of a value, in radians."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(fi(e,this.locale))},isExported:!0},Ld={description:Ho("Angle from the X axis to a point (x,y), in radians."),args:[Qh("x (number)",Ho("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),Qh("y (number)",Ho("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=fi(e,this.locale),s=fi(t,this.locale);return 0===o&&0===s?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):Math.atan2(s,o)},isExported:!0},Hd={description:Ho("Inverse hyperbolic tangent of a number."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)>=1?new si(Ho("The value (%s) must be between -1 and 1 exclusive.",t)):Math.atanh(t)},isExported:!0},Ud={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("value (number)",Ho("The value to round up to the nearest integer multiple of factor.")),Qh("factor (number, default=1)",Ho("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=fi(e,this.locale),s=fi(t,this.locale);return s<0&&o>0?new si(Ho("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function Bd(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 zd={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round up to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Qh("mode (number, default=0)",Ho("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=fi(t,this.locale);return{value:Bd(fi(e,this.locale),s,fi(o,this.locale)),format:e?.format}},isExported:!0},$d={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round up to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=fi(t,this.locale);return{value:Bd(fi(e,this.locale),o),format:e?.format}},isExported:!0},Gd={description:Ho("Cosine of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(fi(e,this.locale))},isExported:!0},Wd={description:Ho("Hyperbolic cosine of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(fi(e,this.locale))},isExported:!0},qd={description:Ho("Cotangent of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the cotangent of, in radians."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tan(t)},isExported:!0},Zd={description:Ho("Hyperbolic cotangent of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tanh(t)},isExported:!0},jd={description:Ho("Number of empty values."),args:[Qh("value1 (any, range)",Ho("The first value or range in which to count the number of blanks.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return Fi(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},Yd={description:Ho("A conditional count across a range."),args:[Qh("range (range)",Ho("The range that is tested against criterion.")),Qh("criterion (string)",Ho("The pattern or test to apply to range."))],compute:function(...e){let t=0;return $i(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Xd={description:Ho("Count values depending on multiple criteria."),args:[Qh("criteria_range1 (range)",Ho("The range to check against criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("Additional criteria to check."))],compute:function(...e){let t=0;return $i(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Kd={description:Ho("Counts number of unique values in a range."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider for uniqueness.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return $l(e)}},Jd={description:Ho("Counts number of unique values in a range, filtered by a set of criteria."),args:[Qh("range (range)",Ho("The range of cells from which the number of unique values will be counted.")),Qh("criteria_range1 (range)",Ho("The range of cells over which to evaluate criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=new Set;return $i(t,((t,s)=>{const i=e[t]?.[s];Xi(i)&&o.add(i.value)}),this.locale),o.size}},Qd={description:Ho("Cosecant of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the cosecant of, in radians."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sin(t)},isExported:!0},eu={description:Ho("Hyperbolic cosecant of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sinh(t)},isExported:!0},tu={description:Ho("Converts from another base to decimal."),args:[Qh("value (string)",Ho("The number to convert.")),Qh("base (number)",Ho("The base to convert the value from."))],compute:function(e,t){let o=fi(t,this.locale);if(o=Math.floor(o),2>o||o>36)return new si(Ho("The base (%s) must be between 2 and 36 inclusive.",o));const s=wi(e);if(""===s)return 0;if(!Dd.test(s))return new si(Ho("The value (%s) must be a valid base %s representation.",s,o));const i=parseInt(s,o);return isNaN(i)?new si(Ho("The value (%s) must be a valid base %s representation.",s,o)):i},isExported:!0},ou={description:Ho("Converts an angle value in radians to degrees."),args:[Qh("angle (number)",Ho("The angle to convert from radians to degrees."))],compute:function(e){return 180*fi(e,this.locale)/Math.PI},isExported:!0},su={description:Ho("Euler's number, e (~2.718) raised to a power."),args:[Qh("value (number)",Ho("The exponent to raise e."))],compute:function(e){return Math.exp(fi(e,this.locale))},isExported:!0},iu={description:Ho("Rounds number down to nearest multiple of factor."),args:[Qh("value (number)",Ho("The value to round down to the nearest integer multiple of factor.")),Qh("factor (number, default=1)",Ho("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=fi(e,this.locale),s=fi(t,this.locale);return s<0&&o>0?new si(Ho("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function nu(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 ru={description:Ho("Rounds number down to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round down to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Qh("mode (number, default=0)",Ho("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=fi(t,this.locale);return{value:nu(fi(e,this.locale),s,fi(o,this.locale)),format:e?.format}},isExported:!0},au={description:Ho("Rounds number down to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round down to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=fi(t,this.locale);return{value:nu(fi(e,this.locale),o),format:e?.format}},isExported:!0},lu={description:Ho("Whether the provided value is even."),args:[Qh("value (number)",Ho("The value to be verified as even."))],compute:function(e){const t=Si(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},cu={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round up to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:Bd(fi(e,this.locale),fi(t,this.locale)),format:e?.format}},isExported:!0},hu={description:Ho("Whether the provided value is even."),args:[Qh("value (number)",Ho("The value to be verified as even."))],compute:function(e){const t=Si(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},du={description:Ho("The logarithm of a number, base e (euler's number)."),args:[Qh("value (number)",Ho("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=fi(e,this.locale);return t<=0?new si(Ho("The value (%s) must be strictly positive.",t)):Math.log(t)},isExported:!0},uu={description:Ho("The logarithm of a number, for a given base."),args:[Qh("value (number)",Ho("The value for which to calculate the logarithm.")),Qh("base (number, default=10)",Ho("The base of the logarithm."))],compute:function(e,t={value:10}){const o=fi(e,this.locale),s=fi(t,this.locale);return o<=0?new si(Ho("The value (%s) must be strictly positive.",o)):s<=0?new si(Ho("The base (%s) must be strictly positive.",s)):1===s?new si(Ho("The base must be different from 1.")):Math.log10(o)/Math.log10(s)},isExported:!0};function gu(e,t){Wl(t,Ho("The divisor must be different from 0."));const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const pu={description:Ho("Modulo (remainder) operator."),args:[Qh("dividend (number)",Ho("The number to be divided to find the remainder.")),Qh("divisor (number)",Ho("The number to divide by."))],compute:function(e,t){const o=fi(t,this.locale);return{value:gu(fi(e,this.locale),o),format:e?.format}},isExported:!0},mu={description:Ho("Returns a n x n unit matrix, where n is the input dimension."),args:[Qh("dimension (number)",Ho("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=Ci(e,this.locale);return t<1?new si(Ho("The argument dimension must be positive")):Xl(t)},isExported:!0},fu={description:Ho("Rounds a number up to the nearest odd integer."),args:[Qh("value (number)",Ho("The value to round to the next greatest odd number."))],compute:function(e){const t=fi(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},vu={description:Ho("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},bu={description:Ho("A number raised to a power."),args:[Qh("base (number)",Ho("The number to raise to the exponent power.")),Qh("exponent (number)",Ho("The exponent to raise base to."))],compute:function(e,t){const o=fi(e,this.locale),s=fi(t,this.locale);return o<0&&!Number.isInteger(s)?new si(Ho("The exponent (%s) must be an integer when the base is negative.",s)):{value:Math.pow(o,s),format:e?.format}},isExported:!0},Su={description:Ho("Result of multiplying a series of numbers together."),args:[Qh("factor1 (number, range<number>)",Ho("The first number or range to calculate for the product.")),Qh("factor2 (number, range<number>, repeating)",Ho("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(const s of e)if(js(s))for(const e of s)for(const s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),gi(e))return s}else void 0!==s&&null!==s.value&&(o*=Si(s,this.locale),t+=1);return{value:0===t?0:o,format:ui(e[0])}},isExported:!0},Cu={description:Ho("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},yu={description:Ho("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[Qh("rows (number, default=1)",Ho("The number of rows to be returned.")),Qh("columns (number, default=1)",Ho("The number of columns to be returned.")),Qh("min (number, default=0)",Ho("The minimum number you would like returned.")),Qh("max (number, default=1)",Ho("The maximum number you would like returned.")),Qh("whole_number (number, default=FALSE)",Ho("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=Ci(t,this.locale),r=Ci(e,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=Ei(i);if(n<1)return new si(Ho("The number of columns (%s) must be positive.",n));if(r<1)return new si(Ho("The number of rows (%s) must be positive.",r));if(a>l)return new si(Ho("The maximum (%s) must be greater than or equal to the minimum (%s).",l,a));if(c&&(!Number.isInteger(a)||!Number.isInteger(l)))return new si(Ho("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},wu={description:Ho("Random integer between two values, inclusive."),args:[Qh("low (number)",Ho("The low end of the random range.")),Qh("high (number)",Ho("The high end of the random range."))],compute:function(e,t){let o=fi(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=fi(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),o>s?new si(Ho("The high (%s) must be greater than or equal to the low (%s).",s,o)):{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},Iu={description:Ho("Rounds a number according to standard rules."),args:[Qh("value (number)",Ho("The value to round to places number of places.")),Qh("places (number, default=0)",Ho("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=fi(e,this.locale);let s=fi(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},xu={description:Ho("Rounds down a number."),args:[Qh("value (number)",Ho("The value to round to places number of places, always rounding down.")),Qh("places (number, default=0)",Ho("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=fi(e,this.locale);let s=fi(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},Eu={description:Ho("Rounds up a number."),args:[Qh("value (number)",Ho("The value to round to places number of places, always rounding up.")),Qh("places (number, default=0)",Ho("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=fi(e,this.locale);let s=fi(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},Ru={description:Ho("Secant of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(fi(e,this.locale))},isExported:!0},Tu={description:Ho("Hyperbolic secant of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(fi(e,this.locale))},isExported:!0},Au={description:Ho("Returns a sequence of numbers."),args:[Qh("rows (number)",Ho("The number of rows to return")),Qh("columns (number, optional, default=1)",Ho("The number of columns to return")),Qh("start (number, optional, default=1)",Ho("The first number in the sequence")),Qh("step (number, optional, default=1)",Ho("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=fi(o,this.locale),n=fi(s,this.locale),r=Ci(e,this.locale),a=Ci(t,this.locale);return a<1?new si(Ho("The number of columns (%s) must be positive.",a)):r<1?new si(Ho("The number of rows (%s) must be positive.",r)):Ni(a,r,((e,t)=>({value:i+t*a*n+e*n})))},isExported:!0},Du={description:Ho("Sine of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(fi(e,this.locale))},isExported:!0},_u={description:Ho("Hyperbolic sine of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(fi(e,this.locale))},isExported:!0},Ou={description:Ho("Positive square root of a positive number."),args:[Qh("value (number)",Ho("The number for which to calculate the positive square root."))],compute:function(e){const t=fi(e,this.locale);return t<0?new si(Ho("The value (%s) must be positive or null.",t)):{value:Math.sqrt(t),format:e?.format}},isExported:!0},Fu={description:Ho("Sum of a series of numbers and/or cells."),args:[Qh("value1 (number, range<number>)",Ho("The first number or range to add together.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:zl(e,this.locale),format:ui(t)}},isExported:!0},Pu={description:Ho("A conditional sum across a range."),args:[Qh("criteria_range (range)",Ho("The range which is tested against criterion.")),Qh("criterion (string)",Ho("The pattern or test to apply to range.")),Qh("sum_range (range, default=criteria_range)",Ho("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return $i([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},Mu={description:Ho("Sums a range depending on multiple criteria."),args:[Qh("sum_range (range)",Ho("The range to sum.")),Qh("criteria_range1 (range)",Ho("The range to check against criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1.")),Qh("criteria_range2 (any, range, repeating)",Ho("Additional ranges to check.")),Qh("criterion2 (string, repeating)",Ho("Additional criteria to check."))],compute:function(e,...t){let o=0;return $i(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},Nu={description:Ho("Tangent of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(fi(e,this.locale))},isExported:!0},ku={description:Ho("Hyperbolic tangent of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(fi(e,this.locale))},isExported:!0};function Vu(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 Lu={description:Ho("Truncates a number."),args:[Qh("value (number)",Ho("The value to be truncated.")),Qh("places (number, default=0)",Ho("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:Vu(fi(e,this.locale),fi(t,this.locale)),format:e?.format}},isExported:!0},Hu={description:Ho("Rounds a number down to the nearest integer that is less than or equal to it."),args:[Qh("value (number)",Ho("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(fi(e,this.locale))},isExported:!0};var Uu=Object.freeze({__proto__:null,ABS:_d,ACOS:Od,ACOSH:Fd,ACOT:Pd,ACOTH:Md,ASIN:Nd,ASINH:kd,ATAN:Vd,ATAN2:Ld,ATANH:Hd,CEILING:Ud,CEILING_MATH:zd,CEILING_PRECISE:$d,COS:Gd,COSH:Wd,COT:qd,COTH:Zd,COUNTBLANK:jd,COUNTIF:Yd,COUNTIFS:Xd,COUNTUNIQUE:Kd,COUNTUNIQUEIFS:Jd,CSC:Qd,CSCH:eu,DECIMAL:tu,DEGREES:ou,EXP:su,FLOOR:iu,FLOOR_MATH:ru,FLOOR_PRECISE:au,INT:Hu,ISEVEN:lu,ISODD:hu,ISO_CEILING:cu,LN:du,LOG:uu,MOD:pu,MUNIT:mu,ODD:fu,PI:vu,POWER:bu,PRODUCT:Su,RAND:Cu,RANDARRAY:yu,RANDBETWEEN:wu,ROUND:Iu,ROUNDDOWN:xu,ROUNDUP:Eu,SEC:Ru,SECH:Tu,SEQUENCE:Au,SIN:Du,SINH:_u,SQRT:Ou,SUM:Fu,SUMIF:Pu,SUMIFS:Mu,TAN:Nu,TANH:ku,TRUNC:Lu});function Bu(e,t){const o=[],s=[];let i=0,n=0;Di([e],(e=>{o.push(e),i+=1})),Di([t],(e=>{s.push(e),n+=1})),Gl(i===n,Ho("[[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 zu(e,t,o){const{flatDataX:s,flatDataY:i}=Bu(e,t),n=i.length;Wl(n),o&&Wl(n-1);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 $u(e,t,o,s){let i=0;const n=o?Mi:Pi,r=n(e,((e,t)=>(i+=1,e+t)),0,s);Wl(i),t&&Wl(i-1);const a=r/i;return n(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function Gu(e,t,o,s){const i=fi(t,s);Gl(o?0<=i&&i<=1:0<i&&i<1,Ho("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));const n=[];let r,a=0;return Di(e,(e=>{const t=e?.value;"number"==typeof t&&(r=Gi(n,e,"nextSmaller","asc",n.length,((e,t)=>e[t])),n.splice(r+1,0,t),a++)})),Gl(0!==a,Ki),o||Gl(1/(a+1)<=i&&i<=a/(a+1),Ho("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),Ds(n,i,o)}const Wu={description:Ho("Average magnitude of deviations from mean."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=Pi(e,((e,o)=>(t+=1,e+o)),0,this.locale);if(0===t)return new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."));const s=o/t;return Pi(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},qu={description:Ho("Numerical average value in a dataset, ignoring text."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the average value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:ic(e,this.locale),format:ui(e[0])}},isExported:!0},Zu=Ho("[[FUNCTION_NAME]] has mismatched range sizes."),ju=Ho("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),Yu={description:Ho("Weighted average."),args:[Qh("values (number, range<number>)",Ho("Values to average.")),Qh("weights (number, range<number>)",Ho("Weights for each corresponding value.")),Qh("additional_values (number, range<number>, repeating)",Ho("Additional values to average.")),Qh("additional_weights (number, range<number>, repeating)",Ho("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(!Zl(i,n))return new si(Zu);if(js(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=js(n)?n?.[e][s].value:fi(n,this.locale),l="number"==typeof r,c="number"==typeof a;if(l&&c){if(a<0)return new si(ju);t+=r*a,o+=a}else if(l!==c)return new si(Ho("[[FUNCTION_NAME]] expects number values."))}else{const e=fi(i,this.locale),s=js(n)?n?.[0][0].value:fi(n,this.locale);if("number"==typeof s){if(s<0)return new si(ju);t+=e*s,o+=s}}}return 0===o?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:t/o,format:ui(e[0])}}},Xu={description:Ho("Numerical average value in a dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the average value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=Mi(e,((e,o)=>(t+=1,e+o)),0,this.locale);return 0===t?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:o/t,format:ui(e[0])}},isExported:!0},Ku={description:Ho("Average of values depending on criteria."),args:[Qh("criteria_range (number, range<number>)",Ho("The range to check against criterion.")),Qh("criterion (string)",Ho("The pattern or test to apply to criteria_range.")),Qh("average_range (number, range<number>, default=criteria_range)",Ho("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=ji(void 0===o?e:o);let i=0,n=0;return $i([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,n+=o)}),this.locale),0===i?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):n/i},isExported:!0},Ju={description:Ho("Average of values depending on multiple criteria."),args:[Qh("average_range (range)",Ho("The range to average.")),Qh("criteria_range1 (range)",Ho("The range to check against criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1.")),Qh("criteria_range2 (any, range, repeating)",Ho("Additional criteria_range and criterion to check.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=ji(e);let s=0,i=0;return $i(t,((e,t)=>{const n=o[e]?.[t]?.value;"number"==typeof n&&(s+=1,i+=n)}),this.locale),0===s?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):i/s},isExported:!0},Qu={description:Ho("The number of numeric values in dataset."),args:[Qh("value1 (number, any, range<number>)",Ho("The first value or range to consider when counting.")),Qh("value2 (number, any, range<number>, repeating)",Ho("Additional values or ranges to consider when counting."))],compute:function(...e){return nc(e,this.locale)},isExported:!0},eg={description:Ho("The number of values in a dataset."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider when counting.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider when counting."))],compute:function(...e){return rc(e)},isExported:!0},tg={description:Ho("The covariance of a dataset."),args:[Qh("data_y (any, range)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (any, range)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return zu(e,t,!1)},isExported:!0},og={description:Ho("The covariance of a dataset."),args:[Qh("data_y (any, range)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (any, range)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return zu(e,t,!1)},isExported:!0},sg={description:Ho("The sample covariance of a dataset."),args:[Qh("data_y (any, range)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (any, range)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return zu(e,t,!0)},isExported:!0},ig={description:Ho("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[Qh("x (number, range<number>)",Ho("The value(s) on the x-axis to forecast.")),Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=Bu(t,o);return 0===s.length||0===i.length?new ai(Ki):fc([i],[s],ki(ji(e),(e=>fi(e,this.locale))),!0)},isExported:!0},ng={description:Ho("Fits points to exponential growth trend."),args:[Qh("known_data_y (range<number>)",Ho("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),Qh("known_data_x (range<number>, default={1;2;3;...})",Ho("The values of the independent variable(s) corresponding with known_data_y.")),Qh("new_data_x (any, range, default=known_data_x)",Ho("The data points to return the y values for on the ideal curve fit.")),Qh("b (boolean, default=TRUE)",Ho("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 0===e.length||0===e[0].length?new si(Ji("known_data_y")):pc(fc(mc(bi(e,"the first argument (known_data_y)")),bi(t,"the second argument (known_data_x)"),bi(o,"the third argument (new_data_y)"),Ei(s)))}},rg={description:Ho("Compute the intercept of the linear regression."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);const[[],[i]]=hc([o],[s]);return i},isExported:!0},ag={description:Ho("Nth largest element from a data set."),args:[Qh("data (any, range)",Ho("Array or range containing the dataset to consider.")),Qh("n (number)",Ho("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(fi(t?.value,this.locale)),s=[];let i,n=0;Di([e],(e=>{"number"==typeof e?.value&&(i=Gi(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.shift(),n--))}));const r=s.shift();return void 0===r?new si(Ki):n<o?new si(Ho("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},lg={description:Ho("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>, default={1;2;3;...})",Ho("The range representing the array or matrix of independent data.")),Qh("calculate_b (boolean, default=TRUE)",Ho("A flag specifying wheter to compute the slope or not")),Qh("verbose (boolean, default=FALSE)",Ho("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 0===e.length||0===e[0].length?new si(Ji("data_y")):hc(bi(t,"the first argument (data_y)"),bi(e,"the second argument (data_x)"),Ei(o),Ei(s))},isExported:!0},cg={description:Ho("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>, optional, default={1;2;3;...})",Ho("The range representing the array or matrix of independent data.")),Qh("calculate_b (boolean, default=TRUE)",Ho("A flag specifying wheter to compute the slope or not")),Qh("verbose (boolean, default=FALSE)",Ho("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}){if(0===e.length||0===e[0].length)return new si(Ji("data_y"));const i=hc(bi(t,"the second argument (data_x)"),mc(bi(e,"the first argument (data_y)")),Ei(o),Ei(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},hg={description:Ho("Compute the Matthews correlation coefficient of a dataset."),args:[Qh("data_x (range)",Ho("The range representing the array or matrix of observed data.")),Qh("data_y (range)",Ho("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(sc(o,s),0===o.length||0===s.length)return new ai(Ki);const i=o.length;let n=0,r=0,a=0,l=0;for(let e=0;e<i;++e){const t=Ei(o[e]);t===Ei(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},dg={description:Ho("Maximum value in a numeric dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the maximum value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return ac(e,this.locale)},isExported:!0},ug={description:Ho("Maximum numeric value in a dataset."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider when calculating the maximum value.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=Mi(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:ui(e[0])}},isExported:!0},gg={description:Ho("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[Qh("range (range)",Ho("The range of cells from which the maximum will be determined.")),Qh("criteria_range1 (range)",Ho("The range of cells over which to evaluate criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return $i(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},pg={description:Ho("Median value in a numeric dataset."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider when calculating the median value.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){const t=[];return _i(e,(e=>{t.push(e)}),this.locale),{value:Gu(t,{value:.5},!0,this.locale),format:ui(t[0])}},isExported:!0},mg={description:Ho("Minimum value in a numeric dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the minimum value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return lc(e,this.locale)},isExported:!0},fg={description:Ho("Minimum numeric value in a dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the minimum value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=Mi(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:ui(e[0])}},isExported:!0},vg={description:Ho("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[Qh("range (range)",Ho("The range of cells from which the minimum will be determined.")),Qh("criteria_range1 (range)",Ho("The range of cells over which to evaluate criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return $i(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 bg(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);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 Sg={description:Ho("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return bg(e,t)},isExported:!0},Cg=Sg,yg={description:Ho("Value at a given percentile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("percentile (number)",Ho("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return Ig.compute.bind(this)(e,t)},isExported:!0},wg={description:Ho("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("percentile (number)",Ho("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:Gu([e],t,!1,this.locale),format:ui(e)}},isExported:!0},Ig={description:Ho("Value at a given percentile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("percentile (number)",Ho("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:Gu([e],t,!0,this.locale),format:ui(e)}},isExported:!0},xg={description:Ho("Compute the coefficients of polynomial regression of the dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data.")),Qh("order (number)",Ho("The order of the polynomial to fit the data, between 1 and 6.")),Qh("intercept (boolean, default=TRUE)",Ho("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:n}=Bu(e,t);return 0===i.length||0===n.length?new ai(Ki):dc(n,i,fi(o,this.locale),Ei(s))},isExported:!1},Eg={description:Ho("Predict value by computing a polynomial regression of the dataset."),args:[Qh("x (number, range<number>)",Ho("The value(s) on the x-axis to forecast.")),Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data.")),Qh("order (number)",Ho("The order of the polynomial to fit the data, between 1 and 6.")),Qh("intercept (boolean, default=TRUE)",Ho("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s,i={value:!0}){const n=fi(s,this.locale),{flatDataX:r,flatDataY:a}=Bu(t,o);if(0===r.length||0===a.length)return new ai(Ki);const l=dc(a,r,n,Ei(i)).flat();return ki(ji(e),(e=>gc(l,fi(e,this.locale),n)))},isExported:!1},Rg={description:Ho("Value nearest to a specific quartile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("quartile_number (number)",Ho("Which quartile value to return."))],compute:function(e,t){return Ag.compute.bind(this)(e,t)},isExported:!0},Tg={description:Ho("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("quartile_number (number)",Ho("Which quartile value, exclusive of 0 and 4, to return."))],compute:function(e,t){return{value:Gu([e],{value:.25*Math.trunc(fi(t,this.locale))},!1,this.locale),format:ui(e)}},isExported:!0},Ag={description:Ho("Value nearest to a specific quartile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("quartile_number (number)",Ho("Which quartile value to return."))],compute:function(e,t){return{value:Gu([e],{value:.25*Math.trunc(fi(t,this.locale))},!0,this.locale),format:ui(e)}},isExported:!0},Dg={description:Ho("Returns the rank of a specified value in a dataset."),args:[Qh("value (number)",Ho("The value whose rank will be determined.")),Qh("data (range)",Ho("The range containing the dataset to consider.")),Qh("is_ascending (boolean, default=FALSE)",Ho("Whether to consider the values in data in descending or ascending order."))],compute:function(e,t,o={value:!1}){const s=Ei(o),i=fi(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=fi(t,this.locale);e===i?r=!0:e>i!==s&&n++}return r?n:new ai(Ho("Value not found in the given data."))},isExported:!0},_g={description:Ho("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const o=bg(e,t);if(o instanceof Error)throw o;return Math.pow(o,2)},isExported:!0},Og={description:Ho("Compute the slope of the linear regression."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);const[[i]]=hc([o],[s]);return i},isExported:!0},Fg={description:Ho("Nth smallest element in a data set."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("n (number)",Ho("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(fi(t?.value,this.locale)),s=[];let i,n=0;Di([e],(e=>{"number"==typeof e?.value&&(i=Gi(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.pop(),n--))}));const r=s.pop();return void 0===r?new si(Ki):n<o?new si(Ho("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},Pg={description:Ho("Compute the Spearman rank correlation coefficient of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(t,e);if(0===o.length||0===s.length)return new ai(Ki);const 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},Mg={description:Ho("Standard deviation."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(zg.compute.bind(this)(...e))},isExported:!0},Ng={description:Ho("Standard deviation of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt($g.compute.bind(this)(...e))},isExported:!0},kg={description:Ho("Standard deviation."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Gg.compute.bind(this)(...e))},isExported:!0},Vg={description:Ho("Standard deviation of sample (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Wg.compute.bind(this)(...e))},isExported:!0},Lg={description:Ho("Standard deviation of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(qg.compute.bind(this)(...e))},isExported:!0},Hg={description:Ho("Standard deviation of entire population (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Zg.compute.bind(this)(...e))},isExported:!0},Ug={description:Ho("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);return hc([o],[s],!0,!0)[1][2]},isExported:!0},Bg={description:Ho("Fits points to linear trend derived via least-squares."),args:[Qh("known_data_y (number, range<number>)",Ho("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),Qh("known_data_x (number, range<number>, optional, default={1;2;3;...})",Ho("The values of the independent variable(s) corresponding with known_data_y.")),Qh("new_data_x (number, range<number>, optional, default=known_data_x)",Ho("The data points to return the y values for on the ideal curve fit.")),Qh("b (boolean, optional, default=TRUE)",Ho("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 0===e.length||0===e[0].length?new si(Ji("known_data_y")):fc(bi(e,"the first argument (known_data_y)"),bi(t,"the second argument (known_data_x)"),bi(o,"the third argument (new_data_y)"),Ei(s))}},zg={description:Ho("Variance."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return $u(e,!0,!1,this.locale)},isExported:!0},$g={description:Ho("Variance of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return $u(e,!1,!1,this.locale)},isExported:!0},Gg={description:Ho("Variance."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return $u(e,!0,!1,this.locale)},isExported:!0},Wg={description:Ho("Variance of sample (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return $u(e,!0,!0,this.locale)},isExported:!0},qg={description:Ho("Variance of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return $u(e,!1,!1,this.locale)},isExported:!0},Zg={description:Ho("Variance of entire population (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return $u(e,!1,!0,this.locale)},isExported:!0};var jg=Object.freeze({__proto__:null,AVEDEV:Wu,AVERAGE:qu,AVERAGEA:Xu,AVERAGEIF:Ku,AVERAGEIFS:Ju,AVERAGE_WEIGHTED:Yu,CORREL:Cg,COUNT:Qu,COUNTA:eg,COVAR:tg,COVARIANCE_P:og,COVARIANCE_S:sg,FORECAST:ig,GROWTH:ng,INTERCEPT:rg,LARGE:ag,LINEST:lg,LOGEST:cg,MATTHEWS:hg,MAX:dg,MAXA:ug,MAXIFS:gg,MEDIAN:pg,MIN:mg,MINA:fg,MINIFS:vg,PEARSON:Sg,PERCENTILE:yg,PERCENTILE_EXC:wg,PERCENTILE_INC:Ig,POLYFIT_COEFFS:xg,POLYFIT_FORECAST:Eg,QUARTILE:Rg,QUARTILE_EXC:Tg,QUARTILE_INC:Ag,RANK:Dg,RSQ:_g,SLOPE:Og,SMALL:Fg,SPEARMAN:Pg,STDEV:Mg,STDEVA:Vg,STDEVP:Lg,STDEVPA:Hg,STDEV_P:Ng,STDEV_S:kg,STEYX:Ug,TREND:Bg,VAR:zg,VARA:Wg,VARP:qg,VARPA:Zg,VAR_P:$g,VAR_S:Gg});function Yg(e,t,o,s){const i=new Map,n=e.length;for(let t=n-1;t>=0;t--)i.set(wi(e[t][0]).toUpperCase(),t);const r=t?.value;if("number"!=typeof r&&"string"!=typeof r)throw new si(Ho("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 si(Ho("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=wi(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new si(Ho("The field (%s) must be one of %s.",wi(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new si(Ho("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++){const n=[];let r=!0;for(let s=0;s<o.length;s++){const a=wi(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}$i(n,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const Xg=[Qh("database (range)",Ho("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.")),Qh("field (number, string)",Ho("Indicates which column in database contains the values to be extracted and operated on.")),Qh("criteria (range)",Ho("An array or range containing zero or more criteria to filter the database values by before operating."))],Kg={description:Ho("Average of a set of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return qu.compute.bind(this)([s])},isExported:!0},Jg={description:Ho("Counts values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Qu.compute.bind(this)([s])},isExported:!0},Qg={description:Ho("Counts values and text from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return eg.compute.bind(this)([s])},isExported:!0},ep={description:Ho("Single value from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return 1!==s.length?new si(Ho("More than one match found in DGET evaluation.")):s[0]},isExported:!0},tp={description:Ho("Maximum of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return dg.compute.bind(this)([s])},isExported:!0},op={description:Ho("Minimum of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return mg.compute.bind(this)([s])},isExported:!0},sp={description:Ho("Product of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Su.compute.bind(this)([s])},isExported:!0},ip={description:Ho("Standard deviation of population sample from table."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Mg.compute.bind(this)([s])},isExported:!0},np={description:Ho("Standard deviation of entire population from table."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Lg.compute.bind(this)([s])},isExported:!0},rp={description:Ho("Sum of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Fu.compute.bind(this)([s])},isExported:!0},ap={description:Ho("Variance of population sample from table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return zg.compute.bind(this)([s])},isExported:!0},lp={description:Ho("Variance of a population from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return qg.compute.bind(this)([s])},isExported:!0};var cp=Object.freeze({__proto__:null,DAVERAGE:Kg,DCOUNT:Jg,DCOUNTA:Qg,DGET:ep,DMAX:tp,DMIN:op,DPRODUCT:sp,DSTDEV:ip,DSTDEVP:np,DSUM:rp,DVAR:ap,DVARP:lp});var hp;!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"}(hp||(hp={}));const dp={description:Ho("Converts year/month/day into a date."),args:[Qh("year (number)",Ho("The year component of the date.")),Qh("month (number)",Ho("The month component of the date.")),Qh("day (number)",Ho("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(fi(e,this.locale));const i=Math.trunc(fi(t,this.locale)),n=Math.trunc(fi(o,this.locale));if(s<0||s>9999)return new si(Ho("The year (%s) must be between 0 and 9999 inclusive.",s.toString()));s<1900&&(s+=1900);const r=gs(new Yo(s,i-1,n));return r<0?new si(Ho("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")):{value:r,format:this.locale.dateFormat}},isExported:!0},up={description:Ho("Calculates the number of days, months, or years between two dates."),args:[Qh("start_date (date)",Ho("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.")),Qh("end_date (date)",Ho("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.")),Qh("unit (string)",Ho('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=wi(o).toUpperCase();if(!Object.values(hp).includes(s))return new si(((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return Ho("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values(hp),wi(o)));const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=us(i),a=us(n);if(n<i)return new si(Ho("start_date (%s) should be on or before end_date (%s).",r.toLocaleDateString(),a.toLocaleDateString()));switch(s){case hp.WHOLE_YEARS:return ws(r,a);case hp.WHOLE_MONTHS:return Cs(r,a);case hp.WHOLE_DAYS:return ys(r,a);case hp.MONTH_WITHOUT_WHOLE_YEARS:return Cs(r,a)-12*ws(r,a);case hp.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-r.getDate();if(e<0){e=ms(new Yo(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case hp.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return Ss(e,t,1)<1}(i,n))return ys(r,a);const e=new Yo(r.getFullYear(),a.getMonth(),a.getDate());let t=ys(r,e);return t<0&&(e.setFullYear(r.getFullYear()+1),t=ys(r,e)),t}}},isExported:!0},gp={description:Ho("Converts a date string to a date value."),args:[Qh("date_string (string)",Ho("The string representing the date."))],compute:function(e){const t=wi(e),o=ds(t,this.locale);return null===o?new si(Ho("The date_string (%s) cannot be parsed to date/time.",t.toString())):Math.trunc(o.value)},isExported:!0},pp={description:Ho("Day of the month that a specific date falls on."),args:[Qh("date (string)",Ho("The date from which to extract the day."))],compute:function(e){return Ri(e,this.locale).getDate()},isExported:!0},mp={description:Ho("Number of days between two dates."),args:[Qh("end_date (date)",Ho("The end of the date range.")),Qh("start_date (date)",Ho("The start of the date range."))],compute:function(e,t){const o=Ri(e,this.locale),s=Ri(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/Ko)},isExported:!0},fp={description:Ho("Number of days between two dates on a 360-day year (months of 30 days)."),args:[Qh("start_date (date)",Ho("The start date to consider in the calculation.")),Qh("end_date (date)",Ho("The end date to consider in the calculation.")),Qh("method (number, default=0)",Ho("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(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=Ss(s,i,Ei(o)?4:0);return Math.sign(i-s)*Math.round(360*n)},isExported:!0},vp={description:Ho("Date a number of months before/after another date."),args:[Qh("start_date (date)",Ho("The date from which to calculate the result.")),Qh("months (number)",Ho("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:gs(vs(Ri(e,this.locale),Math.trunc(fi(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},bp={description:Ho("Last day of a month before or after a date."),args:[Qh("start_date (date)",Ho("The date from which to calculate the result.")),Qh("months (number)",Ho("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Ri(e,this.locale),s=Math.trunc(fi(t,this.locale)),i=o.getFullYear(),n=o.getMonth();return{value:gs(new Yo(i,n+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Sp={description:Ho("Hour component of a specific time."),args:[Qh("time (date)",Ho("The time from which to calculate the hour component."))],compute:function(e){return Ri(e,this.locale).getHours()},isExported:!0},Cp={description:Ho("ISO week number of the year."),args:[Qh("date (date)",Ho("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=Ri(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new Yo(o,0,s).getDay();)s+=1;const i=new Yo(o,0,s-3);let n=31;for(;4!==new Yo(o,11,n).getDay();)n-=1;const r=new Yo(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 Yo(o,11,n+3+1);break;case-1:let e=1;for(;4!==new Yo(o-1,0,e).getDay();)e+=1;l=new Yo(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/Ko;return Math.floor(c/7)+1},isExported:!0},yp={description:Ho("Minute component of a specific time."),args:[Qh("time (date)",Ho("The time from which to calculate the minute component."))],compute:function(e){return Ri(e,this.locale).getMinutes()},isExported:!0},wp={description:Ho("Month of the year a specific date falls in"),args:[Qh("date (date)",Ho("The date from which to extract the month."))],compute:function(e){return Ri(e,this.locale).getMonth()+1},isExported:!0},Ip={description:Ho("Net working days between two provided days."),args:[Qh("start_date (date)",Ho("The start date of the period from which to calculate the number of net working days.")),Qh("end_date (date)",Ho("The end date of the period from which to calculate the number of net working days.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return Ep.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function xp(e){const t=e?.value;if("string"==typeof t){Gl(7===t.length&&[...t].every((e=>"0"===e||"1"===e)),Ho('When weekend is a string (%s) it must be composed of "0" or "1".',t));const e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return Gl(1<=t&&t<=7||11<=t&&t<=17,Ho("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 si(Ho("The weekend must be a number or a string."))}const Ep={description:Ho("Net working days between two dates (specifying weekends)."),args:[Qh("start_date (date)",Ho("The start date of the period from which to calculate the number of net working days.")),Qh("end_date (date)",Ho("The end date of the period from which to calculate the number of net working days.")),Qh("weekend (any, default=1)",Ho("A number or string representing which days of the week are considered weekends.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Ri(e,this.locale),n=Ri(t,this.locale),r=xp(o),a=new Set;void 0!==s&&Di([s],(e=>{const t=Ri(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>n.getTime(),c=Yo.fromTimestamp((l?i:n).getTime()),h=Yo.fromTimestamp((l?n:i).getTime()),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},Rp={description:Ho("Current date and time as a date value."),args:[],compute:function(){const e=Yo.now(),t=e.getTime()-Xo.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/Ko)+o,format:Hl(this.locale)}},isExported:!0},Tp={description:Ho("Minute component of a specific time."),args:[Qh("time (date)",Ho("The time from which to calculate the second component."))],compute:function(e){return Ri(e,this.locale).getSeconds()},isExported:!0},Ap={description:Ho("Converts hour/minute/second into a time."),args:[Qh("hour (number)",Ho("The hour component of the time.")),Qh("minute (number)",Ho("The minute component of the time.")),Qh("second (number)",Ho("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=Math.trunc(fi(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,s<0?new si(Ho("The function [[FUNCTION_NAME]] result cannot be negative")):{value:s/24+i/1440+n/86400,format:this.locale.timeFormat}},isExported:!0},Dp={description:Ho("Converts a time string into its serial number representation."),args:[Qh("time_string (string)",Ho("The string that holds the time representation."))],compute:function(e){const t=wi(e),o=ds(t,this.locale);if(null===o)return new si(Ho("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},_p={description:Ho("Current date as a date value."),args:[],compute:function(){const e=Yo.now();return{value:gs(new Yo(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},Op={description:Ho("Day of the week of the date provided (as number)."),args:[Qh("date (date)",Ho("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.")),Qh("type (number, default=1)",Ho("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=Ri(e,this.locale),s=Math.round(fi(t,this.locale)),i=o.getDay();return[1,2,3].includes(s)?1===s?i+1:2===s?0===i?7:i:0===i?6:i-1:new si(Ho("The type (%s) must be 1, 2 or 3.",s))},isExported:!0},Fp={description:Ho("Week number of the year."),args:[Qh("date (date)",Ho("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.")),Qh("type (number, default=1)",Ho("A number representing the day that a week starts on. Sunday = 1."))],compute:function(e,t={value:1}){const o=Ri(e,this.locale),s=Math.round(fi(t,this.locale));if(![1,2,11,12,13,14,15,16,17,21].includes(s))return new si(Ho("The type (%s) is out of range.",s.toString()));if(21===s)return Cp.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 Yo(n,0,r);for(;a.getDay()!==i;)r+=1,a=new Yo(n,0,r);const l=(o.getTime()-a.getTime())/Ko;return l<0?1:Math.floor(l/7)+(1===r?1:2)},isExported:!0},Pp={description:Ho("Date after a number of workdays."),args:[Qh("start_date (date)",Ho("The date from which to begin counting.")),Qh("num_days (number)",Ho("The number of working days to advance from start_date. If negative, counts backwards.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return Mp.compute.bind(this)(e,t,{value:1},o)},isExported:!0},Mp={description:Ho("Date after a number of workdays (specifying weekends)."),args:[Qh("start_date (date)",Ho("The date from which to begin counting.")),Qh("num_days (number)",Ho("The number of working days to advance from start_date. If negative, counts backwards.")),Qh("weekend (any, default=1)",Ho("A number or string representing which days of the week are considered weekends.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){const i=Ri(e,this.locale),n=Math.trunc(fi(t,this.locale));if("1111111"===o.value)return new si(Ho("The weekend must be different from '1111111'."));const r=xp(o),a=new Set;void 0!==s&&Di([s],(e=>{const t=Ri(e,this.locale);a.add(t.getTime())}));const l=Yo.fromTimestamp(i.getTime());let 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-Xo.getTime();return{value:Math.round(u/Ko),format:this.locale.dateFormat}},isExported:!0},Np={description:Ho("Year specified by a given date."),args:[Qh("date (date)",Ho("The date from which to extract the year."))],compute:function(e){return Ri(e,this.locale).getFullYear()},isExported:!0},kp={description:Ho("Exact number of years between two dates."),args:[Qh("start_date (date)",Ho("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.")),Qh("end_date (date)",Ho("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.")),Qh("day_count_convention (number, default=0)",Ho("An indicator of what day count method to use."))],compute:function(e,t,o={value:0}){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=Math.trunc(fi(o,this.locale));return s<0?new si(Ho("The start_date (%s) must be positive or null.",s)):i<0?new si(Ho("The end_date (%s) must be positive or null.",i)):0>n||n>4?new si(Ho("The day_count_convention (%s) must be between 0 and 4 inclusive.",n)):Ss(s,i,n)}},Vp={description:Ho("First day of the month preceding a date."),args:[Qh("date (date)",Ho("The date from which to calculate the result."))],compute:function(e){const t=Ri(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:gs(new Yo(o,s,1)),format:this.locale.dateFormat}}},Lp={description:Ho("Last day of the month following a date."),args:[Qh("date (date)",Ho("The date from which to calculate the result."))],compute:function(e){return bp.compute.bind(this)(e,{value:0})}},Hp={description:Ho("Quarter of the year a specific date falls in"),args:[Qh("date (date)",Ho("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Ri(e,this.locale).getMonth()+1)/3)}},Up={description:Ho("First day of the quarter of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the start of quarter."))],compute:function(e){const t=Hp.compute.bind(this)(e),o=Np.compute.bind(this)(e);return{value:gs(new Yo(o,3*(t-1),1)),format:this.locale.dateFormat}}},Bp={description:Ho("Last day of the quarter of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the end of quarter."))],compute:function(e){const t=Hp.compute.bind(this)(e),o=Np.compute.bind(this)(e);return{value:gs(new Yo(o,3*t,0)),format:this.locale.dateFormat}}},zp={description:Ho("First day of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the start of the year."))],compute:function(e){const t=Np.compute.bind(this)(e);return{value:gs(new Yo(t,0,1)),format:this.locale.dateFormat}}},$p={description:Ho("Last day of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the end of the year."))],compute:function(e){const t=Np.compute.bind(this)(e);return{value:gs(new Yo(t+1,0,0)),format:this.locale.dateFormat}}};var Gp=Object.freeze({__proto__:null,DATE:dp,DATEDIF:up,DATEVALUE:gp,DAY:pp,DAYS:mp,DAYS360:fp,EDATE:vp,EOMONTH:bp,HOUR:Sp,ISOWEEKNUM:Cp,MINUTE:yp,MONTH:wp,MONTH_END:Lp,MONTH_START:Vp,NETWORKDAYS:Ip,NETWORKDAYS_INTL:Ep,NOW:Rp,QUARTER:Hp,QUARTER_END:Bp,QUARTER_START:Up,SECOND:Tp,TIME:Ap,TIMEVALUE:Dp,TODAY:_p,WEEKDAY:Op,WEEKNUM:Fp,WORKDAY:Pp,WORKDAY_INTL:Mp,YEAR:Np,YEARFRAC:kp,YEAR_END:$p,YEAR_START:zp});const Wp={description:Ho("Compare two numeric values, returning 1 if they're equal."),args:[Qh("number1 (number)",Ho("The first number to compare.")),Qh("number2 (number, default=0)",Ho("The second number to compare."))],compute:function(e,t={value:0}){return fi(e,this.locale)===fi(t,this.locale)?1:0},isExported:!0};var qp=Object.freeze({__proto__:null,DELTA:Wp});const Zp=[_s.number,_s.error,_s.text,_s.boolean];function jp(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===_s.empty)return o.type===_s.empty?0:1;if(o.type===_s.empty)return-1;let s=Zp.indexOf(e.type)-Zp.indexOf(o.type);return 0===s&&(s=e.type===_s.text||e.type===_s.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function Yp(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++){const 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 Xp(e,t,o,s,i);const r=e.model.getters.getContiguousZone(t,s);Ir(r,s)?Xp(e,t,o,s,i):e.askConfirmation(Ho("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?"),(()=>Xp(e,t,o,r,i)),(()=>Xp(e,t,o,s,i)))}function Xp(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(Ho("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(Ho("Cannot sort a zone with array formulas."))}}function Kp(e,t,...o){for(let e=0;e<o.length;e++){const t=e%2==0?"sort_column":"is_ascending";Gl(void 0!==o[e],Ho("Value for parameter %s is missing in [[FUNCTION_NAME]].",t))}const s=[],i=[],n=e.length;for(let r=0;r<o.length;r+=2){s.push(Ei(ec(o[r+1])?.value)?"asc":"desc");const a=o[r];if(js(a)&&(a.length>1||a[0].length>1))Gl(1===a.length&&a[0].length===n,Ho("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=fi(ec(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:jp("desc"),asc:jp("asc")},a=je(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?_s.empty:"string"==typeof i?_s.text:typeof i},c={value:a,type:null===a?_s.empty:"string"==typeof a?_s.text:typeof a},h=r[s[o]](l,c);if(0!==h)return h}return 0})),a.map((t=>e[t]))}const Jp={description:Ho("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[Qh("range (any, range<any>)",Ho("The data to be filtered.")),Qh("condition1 (boolean, range<boolean>)",Ho("A column or row containing true or false values corresponding to the first column or row of range.")),Qh("condition2 (boolean, range<boolean>, repeating)",Ho("Additional column or row containing true or false values."))],compute:function(e,...t){let o=ji(e);const s=t.map((e=>ki(ji(e),(e=>e.value))));for(const e of s)if(!ql(e))return new si(Ho("The arguments condition must be a single column or row."));if(!Zl(...t))return new si(Ho("The arguments conditions must have the same dimensions."));const i=s.map((e=>e.flat())),n=1===s[0].length?"row":"col";if(o="row"===n?Vi(o):o,i.some((e=>e.length!==o.length)))return new si(Ho("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?Vi(r):r:new ai(Ho("No match found in FILTER evaluation"))},isExported:!1},Qp={description:Ho("Sorts the rows of a given array or range by the values in one or more columns."),args:[Qh("range (range)",Ho("The data to be sorted.")),Qh("sort_column (any, range<number>, repeating)",Ho("The index of the column in range or a range outside of range containing the values by which to sort.")),Qh("is_ascending (boolean, repeating)",Ho("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,...t){const o=Vi(e);return Vi(Kp(o,this.locale,...t))},isExported:!0},em={description:Ho("Returns the first n items in a data set after performing a sort."),args:[Qh("range (range)",Ho("The data to be sorted.")),Qh("n (number)",Ho("The number of items to return.")),Qh("display_ties_mode (number, default=0)",Ho("A number representing the way to display ties.")),Qh("sort_column (number, range<number>, repeating)",Ho("The index of the column in range or a range outside of range containing the values by which to sort.")),Qh("is_ascending (boolean, repeating)",Ho("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,t,...o){const s=fi(t?.value??1,this.locale),i=o.length%2==0?0:fi(o[0]?.value,this.locale),n=o.length%2==0?o:o.slice(1);if(s<0)return new si(Ho("Wrong value of 'n'. Expected a positive number. Got %s.",s));if(i<0||i>3)return new si(Ho("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",i));const r=Kp(Vi(e),this.locale,...n),a=(e,t)=>JSON.stringify(r[e].map((e=>e.value)))===JSON.stringify(r[t].map((e=>e.value)));switch(i){case 0:return Vi(r.slice(0,s));case 1:for(let e=s;e<r.length;e++)if(!a(e,s-1))return Vi(r.slice(0,e));return Vi(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 Vi(e.slice(0,s))}case 3:{const e=[r[0]];let t=1;for(let o=1;o<r.length&&(a(o,o-1)||t++,!(t>s));o++)e.push(r[o]);return Vi(e)}}},isExported:!1},tm={description:Ho("Unique rows in the provided source range."),args:[Qh("range (any, range<any>)",Ho("The data to filter by unique entries.")),Qh("by_column (boolean, default=FALSE)",Ho("Whether to filter the data by columns or by rows.")),Qh("exactly_once (boolean, default=FALSE)",Ho("Whether to return only entries with no duplicates."))],compute:function(e={value:""},t,o){if(!js(e))return[[e]];const s=Ei(t?.value)||!1,i=Ei(o?.value)||!1;s||(e=Vi(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);return r.length?s?r:Vi(r):new si(Ho("No unique values found"))},isExported:!0};var om=Object.freeze({__proto__:null,FILTER:Jp,SORT:Qp,SORTN:em,UNIQUE:tm});const sm=Ho("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."),im=Ho("There must be both positive and negative values in cashflow_amounts."),nm=e=>Ho("The cost (%s) must be positive or null.",e),rm=e=>Ho("The frequency (%s) must be one of %s",e,[1,2,4].toString()),am=e=>Ho("The day_count_convention (%s) must be between 0 and 4 inclusive.",e),lm=e=>Ho("The depreciation factor (%s) must be strictly positive.",e),cm=e=>Ho("The discount (%s) must be strictly positive.",e),hm=e=>Ho("The discount (%s) must be smaller than 1.",e),dm=e=>Ho("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e),um=(e,t)=>Ho("The first_period (%(first)s) must be smaller or equal to the last_period (%(last)s).",{first:e,last:t}),gm=e=>Ho("The first_period (%s) must be strictly positive.",e),pm=e=>Ho("The investment (%s) must be strictly positive.",e),mm=(e,t)=>Ho("The last_period (%(last)s) must be smaller or equal to the number_of_periods (%(nPeriods)s).",{last:e,nPeriods:t}),fm=e=>Ho("The last_period (%s) must be strictly positive.",e),vm=e=>Ho("The life (%s) must be strictly positive.",e),bm=(e,t)=>Ho("The maturity (%(maturity)s) must be strictly greater than the settlement (%(settlement)s).",{maturity:t,settlement:e}),Sm=e=>Ho("The number_of_periods (%s) must be strictly positive.",e),Cm=e=>Ho("The period must be between 1 and number_of_periods (%s)",e),ym=e=>Ho("The periods_by_year (%s) must be strictly positive.",e),wm=(e,t)=>Ho("The period (%(period)s) must be less than or equal life (%(life)s).",{period:e,life:t}),Im=e=>Ho("The period (%s) must be strictly positive.",e),xm=e=>Ho("The present_value (%s) must be strictly positive.",e),Em=e=>Ho("The price (%s) must be strictly positive.",e),Rm=e=>Ho("The rate_guess (%s) must be strictly greater than -1.",e),Tm=e=>Ho("The rate (%s) must be positive or null.",e),Am=e=>Ho("The rate (%s) must be strictly positive.",e),Dm=e=>Ho("The redemption (%s) must be strictly positive.",e),_m=e=>Ho("The salvage (%s) must be positive or null.",e),Om=(e,t)=>Ho("The settlement date (%(settlement)s) must at most one year after the maturity date (%(maturity)s).",{settlement:e,maturity:t}),Fm=e=>Ho("The unit (%s) must be strictly positive.",e),Pm=e=>Ho("The yield (%s) must be positive or null.",e);function Mm(e){return e.some((e=>e>0))&&e.some((e=>e<0))}function Nm(e){return![0,1,2,3,4].includes(e)}function km(e){return![1,2,4].includes(e)}function Vm(e,t,o){const s=Ri(e,o),i=Ri(t,o),n=Ri(e,o);return n.setFullYear(s.getFullYear()+1),i.getTime()<=n.getTime()}const Lm=[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))];function Hm(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)?(Gl(u<s&&void 0!==n,Ho("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,Gl(u<s,Ho("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const Um={description:Ho("Accrued interest of security paying at maturity."),args:[Qh("issue (date)",Ho("The date the security was initially issued.")),Qh("maturity (date)",Ho("The maturity date of the security.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(s,this.locale),l=fi(o,this.locale),c=Math.trunc(fi(i,this.locale));if(n<0)return new si((e=>Ho("The issue (%s) must be positive or null.",e))(n));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(Dm(a));if(l<=0)return new si(Am(l));return a*l*Ss(n,r,c)},isExported:!0},Bm={description:Ho("Depreciation for an accounting period."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("purchase_date (date)",Ho("The date the asset was purchased.")),Qh("first_period_end (date)",Ho("The date the first period ended.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation.")),Qh("rate (number)",Ho("The deprecation rate.")),Qh("day_count_convention (number, optional)",Ho("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=fi(e,this.locale),l=Math.trunc(fi(t,this.locale)),c=Math.trunc(fi(o,this.locale)),h=fi(s,this.locale),d=fi(i,this.locale),u=fi(n,this.locale),g=Math.trunc(fi(r,this.locale));if(a<=0)return new si((e=>Ho("The cost (%s) must be strictly positive.",e))(a));if(l<0)return new si((e=>Ho("The purchase_date (%s) must be positive or null.",e))(l));if(h<0)return new si(_m(h));if(h>a)return new si(((e,t)=>Ho("The salvage (%(salvage)s) must be smaller or equal than the cost (%(cost)s).",{salvage:e,cost:t}))(h,a));if(d<0)return new si((e=>Ho("The period (%s) must be positive or null.",e))(d));if(u<=0)return new si(Am(u));if(Nm(g))return new si(am(g));if(l>c)return new si(((e,t)=>Ho("The purchase_date (%(purchaseDate)s) must be before the first_period_end (%(firstPeriodEnd)s).",{purchaseDate:e,firstPeriodEnd:t}))(l,c));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=Ss(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},zm={description:Ho("Days in coupon period containing settlement date."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));if(1===a){const i=Zm.compute.bind(this)(e,t,o,s).value;return fi(Wm.compute.bind(this)(e,t,o,s).value,this.locale)-fi(i,this.locale)}return(3===a?365:360)/r},isExported:!0},$m={description:Ho("Days from settlement until next coupon."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=fi(Zm.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return i-l;if(4===a){const e=Ss(l,i,a);return Math.round(360*e)}const c=Ri(i,this.locale),h=Ri(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&&fs(h)&&fs(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&fs(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},Gm={description:Ho("Days from settlement until next coupon."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=fi(Wm.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return l-i;if(4===a){const e=Ss(i,l,a);return Math.round(360*e)}const c=$m.compute.bind(this)(e,t,o,s);return fi(zm.compute.bind(this)(e,t,o,s),this.locale)-fi(c,this.locale)},isExported:!0},Wm={description:Ho("Next coupon date after the settlement date."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=12/r,c=qm.compute.bind(this)(e,t,o,s);return{value:gs(vs(Ri(n,this.locale),-(fi(c,this.locale)-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},qm={description:Ho("Number of coupons between settlement and maturity."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));let l=1,c=n;const h=12/r;for(;c>i;)c=gs(vs(Ri(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},Zm={description:Ho("Last coupon date prior to or on the settlement date."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=12/r,c=qm.compute.bind(this)(e,t,o,s);return{value:gs(vs(Ri(n,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},jm={description:Ho("Cumulative interest paid over a set of periods."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("first_period (number)",Ho("The number of the payment period to begin the cumulative calculation.")),Qh("last_period (number)",Ho("The number of the payment period to end the cumulative calculation.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(s,this.locale),a=fi(i,this.locale),l=fi(e,this.locale),c=fi(o,this.locale),h=fi(t,this.locale),d=Ei(n)?1:0;if(h<=0)return new si(Sm(h));if(r<=0)return new si(gm(r));if(a<=0)return new si(fm(a));if(r>a)return new si(um(r,a));if(a>h)return new si(mm(a,h));if(l<=0)return new si(Am(l));if(c<=0)return new si(xm(c));let u=0;for(let e=r;e<=a;e++)u+=cf(l,e,h,c,0,d);return u},isExported:!0},Ym={description:Ho("Cumulative principal paid over a set of periods."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("first_period (number)",Ho("The number of the payment period to begin the cumulative calculation.")),Qh("last_period (number)",Ho("The number of the payment period to end the cumulative calculation.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(s,this.locale),a=fi(i,this.locale),l=fi(e,this.locale),c=fi(o,this.locale),h=fi(t,this.locale),d=Ei(n)?1:0;if(h<=0)return new si(Sm(h));if(r<=0)return new si(gm(r));if(a<=0)return new si(fm(a));if(r>a)return new si(um(r,a));if(a>h)return new si(mm(a,h));if(l<=0)return new si(Am(l));if(c<=0)return new si(xm(c));let u=0;for(let e=r;e<=a;e++)u+=wf(l,e,h,c,0,d);return u},isExported:!0},Xm={description:Ho("Depreciation via declining balance method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation.")),Qh("month (number, optional)",Ho("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const n=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=Math.trunc(fi(s,this.locale)),c=i.length?Math.trunc(fi(i[0],this.locale)):12,h=a+(12===c?0:1);if(n<0)return new si(nm(n));if(r<0)return new si(_m(r));if(l<=0)return new si(Im(l));if(a<=0)return new si(vm(a));if(1>c||c>12)return new si(Ho("The month (%s) must be between 1 and 12 inclusive.",c));if(l>h)return new si(((e,t)=>Ho("The period (%(period)s) must be less than or equal to %(lifeLimit)s.",{period:e,lifeLimit:t}))(l,h));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},Km="#,##0.00",Jm={description:Ho("Depreciation via double-declining balance method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation.")),Qh("factor (number, default=2)",Ho("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){const n=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=fi(i,this.locale);if(n<0)return new si(nm(n));if(r<0)return new si(_m(r));if(l<=0)return new si(Im(l));if(a<=0)return new si(vm(a));if(l>a)return new si(wm(l,a));if(c<=0)return new si(lm(c));if(0===n||r>=n)return{value:0,format:Km};const h=c/a;if(h>1)return{value:1===l?n-r:0,format:Km};if(l<=1)return{value:n*h,format:Km};const d=n*Math.pow(1-h,l-1),u=n*Math.pow(1-h,l),g=u<r?d-r:d-u;return{value:Math.max(g,0),format:Km}},isExported:!0},Qm={description:Ho("Discount rate of a security based on price."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(Em(a));if(l<=0)return new si(Dm(l));return(l-a)/l/Ss(n,r,c)},isExported:!0},ef={description:Ho("Convert a decimal fraction to decimal value."),args:[Qh("fractional_price (number)",Ho("The price quotation given using fractional decimal conventions.")),Qh("unit (number)",Ho("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));if(s<=0)return new si(Fm(s));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},tf={description:Ho("Convert a decimal value to decimal fraction."),args:[Qh("decimal_price (number)",Ho("The price quotation given as a decimal value.")),Qh("unit (number)",Ho("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));if(s<=0)return new si(Fm(s));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},of={description:Ho("Number of periods for an investment to reach a value."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=Math.trunc(fi(e,this.locale)),a=Math.trunc(fi(t,this.locale)),l=fi(o,this.locale),c=fi(s,this.locale),h=Math.trunc(fi(i,this.locale)),d=Math.trunc(fi(n,this.locale));if(r>=a)return new si(bm(r,a));if(km(h))return new si(rm(h));if(Nm(d))return new si(am(d));if(l<0)return new si(Tm(l));if(c<0)return new si(Pm(c));const u=Ss(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},sf={description:Ho("Annual effective interest rate."),args:[Qh("nominal_rate (number)",Ho("The nominal interest rate per year.")),Qh("periods_per_year (number)",Ho("The number of compounding periods per year."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));return o<=0?new si(Ho("The nominal_rate (%s) must be strictly positive.",o)):s<=0?new si(ym(s)):Math.pow(1+o/s,s)-1},isExported:!0};function nf(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 rf={description:Ho("Future value of an annuity investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("payment_amount (number)",Ho("The amount per period to be paid.")),Qh("present_value (number, default=0)",Ho("The current value of the annuity.")),Qh("end_or_beginning (number, default=0)",Ho("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:nf(fi(e,this.locale),fi(t,this.locale),fi(o,this.locale),fi(s,this.locale),Ei(i)?1:0),format:"#,##0.00"}},isExported:!0},af={description:Ho("Future value of principal from series of rates."),args:[Qh("principal (number)",Ho("The amount of initial capital or value to compound against.")),Qh("rate_schedule (number, range<number>)",Ho("A series of interest rates to compound against the principal."))],compute:function(e,t){return Fi([t],((e,t)=>e*(1+fi(t,this.locale))),fi(e,this.locale))},isExported:!0},lf={description:Ho("Calculates effective interest rate."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("investment (number)",Ho("The amount invested in the security.")),Qh("redemption (number)",Ho("The amount to be received at maturity.")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(s,this.locale),l=fi(o,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(l<=0)return new si(pm(l));if(a<=0)return new si(Dm(a));if(Nm(c))return new si(am(c));return(a-l)/l/Ss(n,r,c)},isExported:!0};function cf(e,t,o,s,i,n){return Cf(e,o,s,i,n)-wf(e,t,o,s,i,n)}const hf={description:Ho("Payment on the principal of an investment."),args:[Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("period (number)",Ho("The amortization period, in terms of number of periods.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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:cf(fi(e,this.locale),fi(t,this.locale),fi(o,this.locale),fi(s,this.locale),fi(i,this.locale),Ei(n)?1:0),format:"#,##0.00"}},isExported:!0},df={description:Ho("Internal rate of return given periodic cashflows."),args:[Qh("cashflow_amounts (number, range<number>)",Ho("An array or range containing the income or payments associated with the investment.")),Qh("rate_guess (number, default=0.1)",Ho("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=fi(t,this.locale);if(o<=-1)return new si(Rm(o));let s=!1,i=!1;const n=[];if(_i([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),n.push(e)}),this.locale),!s||!i)return new si(im);const r=n.shift();return{value:Hm((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},uf={description:Ho("Returns the interest paid at a particular period of an investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("period (number)",Ho("The period for which you want to view the interest payment.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity."))],compute:function(e,t,o,s){const i=fi(e,this.locale),n=fi(t,this.locale),r=fi(o,this.locale),a=fi(s,this.locale);if(0===r)return new si(Ho("The number_of_periods (%s) must be different from zero.",r));return-1*(a-a*(n/r))*i},isExported:!0},gf={description:Ho("Modified Macaulay duration."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=of.compute.bind(this)(e,t,o,s,i,n),a=fi(s,this.locale),l=Math.trunc(fi(i,this.locale));return fi(r,this.locale)/(1+a/l)},isExported:!0},pf={description:Ho("Modified internal rate of return."),args:[Qh("cashflow_amounts (range<number>)",Ho("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),Qh("financing_rate (number)",Ho("The interest rate paid on funds invested.")),Qh("reinvestment_return_rate (number)",Ho("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=fi(t,this.locale),i=fi(o,this.locale),n=Vi(e).flat().filter((e=>null!==e.value)).map((e=>fi(e,this.locale))),r=n.length;let a=0,l=0;for(const e of je(0,r)){const t=n[e];t>=0?a+=t*(i+1)**(r-e-1):l+=t/(s+1)**e}if(0===l||0===a)return new si(im);return(-a/l)**(1/(r-1))-1},isExported:!0},mf={description:Ho("Annual nominal interest rate."),args:[Qh("effective_rate (number)",Ho("The effective interest rate per year.")),Qh("periods_per_year (number)",Ho("The number of compounding periods per year."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));return o<=0?new si(Ho("The effective_rate (%s) must be strictly positive.",o)):s<=0?new si(ym(s)):(Math.pow(o+1,1/s)-1)*s},isExported:!0},ff={description:Ho("Number of payment periods for an investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("payment_amount (number)",Ho("The amount of each payment made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=Ei(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 vf(e,t,o,s){let i=0;return Pi(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const bf={description:Ho("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[Qh("discount (number)",Ho("The discount rate of the investment over one period.")),Qh("cashflow1 (number, range<number>)",Ho("The first future cash flow.")),Qh("cashflow2 (number, range<number>, repeating)",Ho("Additional future cash flows."))],compute:function(e,...t){const o=fi(e,this.locale);return-1===o?new si((e=>Ho("The discount (%s) must be different from -1.",e))(o)):{value:vf(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},Sf={description:Ho("Computes the number of periods needed for an investment to reach a value."),args:[Qh("rate (number)",Ho("The rate at which the investment grows each period.")),Qh("present_value (number)",Ho("The investment's current value.")),Qh("future_value (number)",Ho("The investment's desired future value."))],compute:function(e,t,o){const s=fi(e,this.locale),i=fi(t,this.locale),n=fi(o,this.locale);return s<=0?new si(Am(s)):i<=0?new si(xm(i)):n<=0?new si(Ho("The future_value (%s) must be strictly positive.",n)):(Math.log(n)-Math.log(i))/Math.log(1+s)},isExported:!0};function Cf(e,t,o,s,i){if(t<=0)throw new si(Sm(t));if(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 yf={description:Ho("Periodic payment for an annuity investment."),args:[Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(t,this.locale),r=fi(e,this.locale),a=Ei(i)?1:0,l=fi(s,this.locale);return{value:Cf(r,n,fi(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function wf(e,t,o,s,i,n){if(o<=0)throw new si(Sm(o));if(t<=0||t>o)throw new si(Cm(o));const r=Cf(e,o,s,i,n);if(1===n&&1===t)return r;return r+-nf(e,0===n?t-1:t-2,r,s+r*n,0)*e}const If={description:Ho("Payment on the principal of an investment."),args:[Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("period (number)",Ho("The amortization period, in terms of number of periods.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(o,this.locale),a=fi(e,this.locale),l=fi(t,this.locale),c=Ei(n)?1:0,h=fi(i,this.locale);return{value:wf(a,l,r,fi(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},xf={description:Ho("Present value of an annuity investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("payment_amount (number)",Ho("The amount per period to be paid.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=Ei(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},Ef={description:Ho("Price of a security paying periodic interest."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),l=Math.trunc(fi(t,this.locale)),c=fi(o,this.locale),h=fi(s,this.locale),d=fi(i,this.locale),u=Math.trunc(fi(n,this.locale)),g=Math.trunc(fi(r,this.locale));if(a>=l)return new si(bm(a,l));if(km(u))return new si(rm(u));if(Nm(g))return new si(am(g));if(c<0)return new si(Tm(c));if(h<0)return new si(Pm(h));if(d<=0)return new si(Dm(d));const p=Ss(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},Rf={description:Ho("Price of a discount security."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("discount (number)",Ho("The discount rate of the security at time of purchase.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(cm(a));if(l<=0)return new si(Dm(l));return l-a*l*Ss(n,r,c)},isExported:!0},Tf={description:Ho("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("issue (date)",Ho("The date the security was initially issued.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),a=Math.trunc(fi(t,this.locale)),l=Math.trunc(fi(o,this.locale)),c=fi(s,this.locale),h=fi(i,this.locale),d=Math.trunc(fi(n,this.locale));if(r<=l)return new si(((e,t)=>Ho("The settlement date (%(settlement)s) must be strictly greater than the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(r>=a)return new si(bm(r,a));if(Nm(d))return new si(am(d));if(c<0)return new si(Tm(c));if(h<0)return new si(Pm(h));const u=Ss(r,a,d),g=Ss(r,l,d);return(100+Ss(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},Af=.1,Df={description:Ho("Interest rate of an annuity investment."),args:[Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("payment_per_period (number)",Ho("The amount per period to be paid.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("Whether payments are due at the end (0) or beginning (1) of each period.")),Qh("rate_guess (number, default=0.1)",Ho("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},n={value:Af}){const r=fi(e,this.locale),a=fi(t,this.locale),l=Ei(i)?1:0,c=fi(n,this.locale)||Af;let h=fi(s,this.locale),d=fi(o,this.locale);if(r<=0)return new si(Sm(r));if(!Mm([a,d,h]))return new si(Ho("There must be both positive and negative values in [payment_amount, present_value, future_value]."));if(c<=-1)return new si(Rm(c));h-=a*l,d+=a*l;return{value:Hm((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},_f={description:Ho("Amount received at maturity for a security."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("investment (number)",Ho("The amount invested (irrespective of face value of each security).")),Qh("discount (number)",Ho("The discount rate of the security invested in.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(pm(a));if(l<=0)return new si(cm(l));return a/(1-l*Ss(n,r,c))},isExported:!0},Of={description:Ho("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[Qh("number_of_periods (number)",Ho("The number of periods.")),Qh("present_value (number)",Ho("The present value of the investment.")),Qh("future_value (number)",Ho("The future value of the investment."))],compute:function(e,t,o){const s=fi(e,this.locale),i=fi(t,this.locale),n=fi(o,this.locale);return s<=0?new si(Sm(s)):(n/i)**(1/s)-1},isExported:!0},Ff={description:Ho("Depreciation of an asset using the straight-line method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(fi(e,this.locale)-fi(t,this.locale))/fi(o,this.locale),format:"#,##0.00"}},isExported:!0},Pf={description:Ho("Depreciation via sum of years digit method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=fi(e,this.locale),n=fi(t,this.locale),r=fi(o,this.locale),a=fi(s,this.locale);if(a<=0)return new si(Im(a));if(r<=0)return new si(vm(r));if(a>r)return new si(wm(a,r));return{value:(r-a+1)/(r*(r+1)/2)*(i-n),format:"#,##0.00"}},isExported:!0};function Mf(e,t,o){return 100*(1-o*Ss(e,t,2))}const Nf={description:Ho("Price of a US Treasury bill."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("discount (number)",Ho("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=fi(o,this.locale);return s>=i?new si(bm(s,i)):Vm(s,i,this.locale)?n<=0?new si(cm(n)):n>=1?new si(hm(n)):Mf(s,i,n):new si(Om(s,i))},isExported:!0},kf={description:Ho("Equivalent rate of return for a US Treasury bill."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("discount (number)",Ho("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=fi(o,this.locale);if(s>=i)return new si(bm(s,i));if(!Vm(s,i,this.locale))return new si(Om(s,i));if(n<=0)return new si(cm(n));if(n>=1)return new si(hm(n));const r=mp.compute.bind(this)({value:i},{value:s});if(r<=182)return 365*n/(360-n*r);const a=Mf(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},Vf={description:Ho("The yield of a US Treasury bill based on price."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=fi(o,this.locale);if(s>=i)return new si(bm(s,i));if(!Vm(s,i,this.locale))return new si(Om(s,i));if(n<=0)return new si(Em(n));return(100-n)/n*(1/Ss(s,i,2))},isExported:!0},Lf={description:Ho("Variable declining balance. WARNING : does not handle decimal periods."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("start (number)",Ho("Starting period to calculate depreciation.")),Qh("end (number)",Ho("Ending period to calculate depreciation.")),Qh("factor (number, default=2)",Ho("The number of months in the first year of depreciation.")),Qh("no_switch (number, default=false)",Ho("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=fi(e,this.locale),l=fi(t,this.locale),c=fi(o,this.locale),h=Math.trunc(fi(s,this.locale)),d=Math.trunc(fi(i,this.locale)),u=fi(n,this.locale),g=Ei(r);if(a<0)return new si(nm(a));if(l<0)return new si(_m(l));if(c<=0)return new si(vm(c));if(h<0)return new si((e=>Ho("The start_period (%s) must be positive or null.",e))(h));if(d<0)return new si((e=>Ho("The end_period (%s) must be positive or null.",e))(d));if(h>d)return new si(Ho("The start_period (%(start)s) must be smaller or equal to the end_period (%(end)s).",{start:h,end:d}));if(d>c)return new si(((e,t)=>Ho("The end_period (%(end)s) must be smaller or equal to the life (%(life)s).",{end:e,life:t}))(d,c));if(u<=0)return new si(lm(u));if(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},Hf={description:Ho("Internal rate of return given non-periodic cash flows."),args:[Qh("cashflow_amounts (range<number>)",Ho("An range containing the income or payments associated with the investment.")),Qh("cashflow_dates (range<number>)",Ho("An range with dates corresponding to the cash flows in cashflow_amounts.")),Qh("rate_guess (number, default=0.1)",Ho("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:Af}){const s=fi(o,this.locale);if(!Zl(e,t))return new si(sm);const i=e.flat().map((e=>fi(e,this.locale))),n=t.flat().map((e=>fi(e,this.locale)));if(!Mm(i))return new si(im);if(n.some((e=>e<n[0])))return new si(dm(n[0]));if(s<=-1)return new si(Rm(s));const r=new Map;for(const e of je(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)));return Hm((e=>{let t=l[0];for(const o of je(1,l.length)){const s=(a[0]-a[o])/365;t+=l[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of je(1,l.length)){const s=(a[0]-a[o])/365;t+=s*l[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},Uf={description:Ho("Net present value given to non-periodic cash flows.."),args:[Qh("discount (number)",Ho("The discount rate of the investment over one period.")),Qh("cashflow_amounts (number, range<number>)",Ho("An range containing the income or payments associated with the investment.")),Qh("cashflow_dates (number, range<number>)",Ho("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=fi(e,this.locale);if(!Zl(t,o))return new si(sm);const i=ji(t).flat().map((e=>Si(e,this.locale))),n=ji(o).flat().map((e=>Si(e,this.locale)));if(n.some((e=>e<n[0])))return new si(dm(n[0]));if(s<=0)return new si(Am(s));if(1===i.length)return i[0];const r=new Map;for(const e of je(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 je(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},Bf={description:Ho("Annual yield of a security paying periodic interest."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),l=Math.trunc(fi(t,this.locale)),c=fi(o,this.locale),h=fi(s,this.locale),d=fi(i,this.locale),u=Math.trunc(fi(n,this.locale)),g=Math.trunc(fi(r,this.locale));if(a>=l)return new si(bm(a,l));if(km(u))return new si(rm(u));if(Nm(g))return new si(am(g));if(c<0)return new si(Tm(c));if(h<=0)return new si(Em(h));if(d<=0)return new si(Dm(d));const p=Ss(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=Hm((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},zf={description:Ho("Annual yield of a discount security."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(Em(a));if(l<=0)return new si(Dm(l));return(l/a-1)/Ss(n,r,c)},isExported:!0},$f={description:Ho("Annual yield of a security paying interest at maturity."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("issue (date)",Ho("The date the security was initially issued.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("price (number)",Ho("The price at which the security is bought.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),a=Math.trunc(fi(t,this.locale)),l=Math.trunc(fi(o,this.locale)),c=fi(s,this.locale),h=fi(i,this.locale),d=Math.trunc(fi(n,this.locale));if(r>=a)return new si(bm(r,a));if(Nm(d))return new si(am(d));if(r<l)return new si(((e,t)=>Ho("The settlement date (%(settlement)s) must be greater or equal to the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(c<0)return new si(Tm(c));if(h<=0)return new si(Em(h));return(100*(1+c*Ss(l,a,d))/(h+100*c*Ss(l,r,d))-1)/Ss(r,a,d)},isExported:!0};var Gf,Wf=Object.freeze({__proto__:null,ACCRINTM:Um,AMORLINC:Bm,COUPDAYBS:$m,COUPDAYS:zm,COUPDAYSNC:Gm,COUPNCD:Wm,COUPNUM:qm,COUPPCD:Zm,CUMIPMT:jm,CUMPRINC:Ym,DB:Xm,DDB:Jm,DISC:Qm,DOLLARDE:ef,DOLLARFR:tf,DURATION:of,EFFECT:sf,FV:rf,FVSCHEDULE:af,INTRATE:lf,IPMT:hf,IRR:df,ISPMT:uf,MDURATION:gf,MIRR:pf,NOMINAL:mf,NPER:ff,NPV:bf,PDURATION:Sf,PMT:yf,PPMT:If,PRICE:Ef,PRICEDISC:Rf,PRICEMAT:Tf,PV:xf,RATE:Df,RECEIVED:_f,RRI:Of,SLN:Ff,SYD:Pf,TBILLEQ:kf,TBILLPRICE:Nf,TBILLYIELD:Vf,VDB:Lf,XIRR:Hf,XNPV:Uf,YIELD:Bf,YIELDDISC:zf,YIELDMAT:$f});!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"}(Gf||(Gf={}));const qf=(e,t=(()=>!0))=>[{goTo:e,guard:t}],Zf=(e,t=(()=>!0))=>({goTo:e,guard:t}),jf={[Gf.LeftRef]:{REFERENCE:qf(Gf.Separator),NUMBER:qf(Gf.FullRowSeparator),SYMBOL:[Zf(Gf.FullColumnSeparator,(e=>{return t=e.value,Qr.test(t);var t})),Zf(Gf.FullRowSeparator,(e=>oa(e.value)))]},[Gf.FullColumnSeparator]:{SPACE:qf(Gf.FullColumnSeparator),OPERATOR:qf(Gf.RightColumnRef,(e=>":"===e.value))},[Gf.FullRowSeparator]:{SPACE:qf(Gf.FullRowSeparator),OPERATOR:qf(Gf.RightRowRef,(e=>":"===e.value))},[Gf.Separator]:{SPACE:qf(Gf.Separator),OPERATOR:qf(Gf.RightRef,(e=>":"===e.value))},[Gf.RightRef]:{SPACE:qf(Gf.RightRef),NUMBER:qf(Gf.Found),REFERENCE:qf(Gf.Found,(e=>na(e.value))),SYMBOL:qf(Gf.Found,(e=>sa(e.value)||ia(e.value)))},[Gf.RightColumnRef]:{SPACE:qf(Gf.RightColumnRef),SYMBOL:qf(Gf.Found,(e=>sa(e.value))),REFERENCE:qf(Gf.Found,(e=>na(e.value)))},[Gf.RightRowRef]:{SPACE:qf(Gf.RightRowRef),NUMBER:qf(Gf.Found),REFERENCE:qf(Gf.Found,(e=>na(e.value))),SYMBOL:qf(Gf.Found,(e=>ia(e.value)))},[Gf.Found]:{}};function Yf(e){let t=0,o=jf[Gf.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 Gf.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=jf[r],s+=i.value}}return null}function Xf(e,t=qs){const o=cl(e,t),s=[];for(;o.length;)s.push(Yf(o)||o.shift());return s}const Kf=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Jf=["-","+"],Qf=["%"],ev=["*","+","&"];class tv{tokens;currentIndex=0;current;length;constructor(e){this.tokens=e,this.current=e[0],this.length=e.length}shift(){const e=this.tokens[this.currentIndex];return this.current=this.tokens[++this.currentIndex],e}get next(){return this.tokens[this.currentIndex+1]}}const ov={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function sv(e){const t=e.shift();if(!t)throw new ii;switch(t.type){case"DEBUGGER":const o=rv(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:As(t.value,qs),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"STRING":return{type:"STRING",value:Ue(t.value),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"INVALID_REFERENCE":return{type:"REFERENCE",value:ti.InvalidReference,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"REFERENCE":if(":"===e.current?.value&&"REFERENCE"===e.next?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenIndex}}return{type:"REFERENCE",value:t.value,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"SYMBOL":const s=t.value,i=e.current;if("LEFT_PAREN"===i?.type&&Kf.test(t.value)&&s===Ge(s,"'")){const{args:o,rightParen:i}=function(e){nv(e,"LEFT_PAREN",Ho("Missing opening parenthesis"));const t=e.current;if("RIGHT_PAREN"===t?.type){return{args:[],rightParen:nv(e,"RIGHT_PAREN")}}const o=[];o.push(iv(e));for(;"RIGHT_PAREN"!==e.current?.type;)nv(e,"ARG_SEPARATOR",Ho("Wrong function call")),o.push(iv(e));const s=nv(e,"RIGHT_PAREN");return{args:o,rightParen:s}}(e);return{type:"FUNCALL",value:s,args:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:i.tokenIndex}}const n=s.toUpperCase();return"TRUE"===n||"FALSE"===n?{type:"BOOLEAN",value:"TRUE"===n,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:{type:"SYMBOL",value:Ge(t.value,"'"),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"LEFT_PAREN":const r=rv(e),a=nv(e,"RIGHT_PAREN",Ho("Missing closing parenthesis"));return{...r,tokenStartIndex:t.tokenIndex,tokenEndIndex:a.tokenIndex};case"OPERATOR":const l=t.value;if(Jf.includes(l)){const o=rv(e,ov[l]);return{type:"UNARY_OPERATION",value:l,operand:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenEndIndex}}throw new ii(Ho("Unexpected token: %s",t.value));default:throw new ii(Ho("Unexpected token: %s",t.value))}}function iv(e){const t=e.current;return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:"",tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:rv(e)}function nv(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new ii(o);return s}function rv(e,t=0){if(0===e.length)throw new ii;let o=sv(e);for(;"OPERATOR"===e.current?.type&&ov[e.current.value]>t;){const t=e.shift(),s=t.value;if(Qf.includes(s))o={type:"UNARY_OPERATION",value:s,operand:o,postfix:!0,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenIndex};else{const t=rv(e,ov[s]);o={type:"BIN_OPERATION",value:s,left:o,right:t,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenEndIndex}}}return o}function av(e){return lv(Xf(e))}function lv(e){const t=e.map(((e,t)=>({type:e.type,value:e.value,tokenIndex:t}))).filter((e=>"SPACE"!==e.type)),o=new tv(t);"="===o.current?.value&&o.shift();const s=rv(o);if(o.current)throw new ii;return s}function cv(e,t,o){return uv(e,(e=>e.type===t?o(e):e))}function hv(e){return Array.from(dv(e))}function*dv(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*dv(t);break;case"UNARY_OPERATION":yield*dv(e.operand);break;case"BIN_OPERATION":yield*dv(e.left),yield*dv(e.right)}}function uv(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>uv(e,t)))};case"UNARY_OPERATION":return{...e,operand:uv(e.operand,t)};case"BIN_OPERATION":return{...e,right:uv(e.right,t),left:uv(e.left,t)};default:return e}}function gv(e){switch(e.type){case"FUNCALL":const t=e.args.map((e=>gv(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?pv(e)+e.value:e.value+mv(e);case"BIN_OPERATION":return pv(e)+e.value+mv(e)}}function pv(e){const t=e.value,o="left"in e?e.left:e.operand,s=o.value;return"BIN_OPERATION"===o.type&&ov[s]<ov[t]?`(${gv(o)})`:gv(o)}function mv(e){const t=e.value,o="right"in e?e.right:e.operand,s=ov[o.value],i=ov[t];let n=!1;return"BIN_OPERATION"!==o.type?n=!1:s<i?n=!0:s!==i||ev.includes(t)||(n=!0),n?`(${gv(o)})`:gv(o)}function fv(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(0)?.type&&(e=e.slice(1));try{o.push(lv(e))}catch(e){o.push(void 0)}}}return e}(function(e){const t=[];let 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":t.length&&t[t.length-1].argPosition++,s(e);break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){const t=[];let 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}))}(Xf(e,t)))))}function vv(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=ra(e.value),[s,i]=t.split(":"),n=bv(s),r=i?`:${bv(i)}`:"";return{...e,value:aa(o,n+r)}}function bv(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=Sv(e,"colrow");break;case"colrow":e=Sv(e,"row");break;case"row":e=Sv(e,"col");break;case"col":e=Sv(e,"none")}return e}function Sv(e,t){let o;({sheetName:o,xc:e}=ra(e)),o=o?o+"!":"";const s=(e=e.replace(/\$/g,"")).indexOf(":");return s>=0?`${o}${Cv(e.slice(0,s),t)}:${Cv(e.slice(s+1),t)}`:o+Cv(e,t)}function Cv(e,t){const o=e.search(/[0-9]/),s=0!==o,i=o>=0;switch(t){case"col":return s?"$"+e:e;case"row":return i?e.slice(0,o)+"$"+e.slice(o):e;case"colrow":return i&&s?"$"+e.slice(0,o)+"$"+e.slice(o):"$"+e;case"none":return e}}function yv(e,t,o){const s=(t.startsWith("=")?fv(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(vv).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 wv=["address","col","contents","format","row","type"],Iv={description:Ho("Gets information about a cell."),args:[Qh("info_type (string)",Ho("The type of information requested. Can be one of %s",wv.join(", "))),Qh("reference (meta)",Ho("The reference to the cell."))],compute:function(e,t){const o=wi(e).toLowerCase();if(!wv.includes(o))return new si(Ho("The info_type should be one of %s.",wv.join(", ")));const s=this.__originSheetId,i=wi(t),n=i.includes(":")?i.split(":")[0]:i;let{sheetName:r,xc:a}=ra(n);r=r===this.getters.getSheetName(s)?void 0:r;const l=aa(r,Sv(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===_s.empty?"b":t===_s.text?"l":"v"}}return""},isExported:!0},xv={description:Ho("Whether a value is an error other than #N/A."),args:[Qh("value (any)",Ho("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return gi(t)&&t!==ti.NotAvailable},isExported:!0},Ev={description:Ho("Whether a value is an error."),args:[Qh("value (any)",Ho("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return gi(t)},isExported:!0},Rv={description:Ho("Whether a value is `true` or `false`."),args:[Qh("value (any)",Ho("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},Tv={description:Ho("Whether a value is the error #N/A."),args:[Qh("value (any)",Ho("The value to be verified as an error type."))],compute:function(e){return e?.value===ti.NotAvailable},isExported:!0},Av={description:Ho("Whether a value is non-textual."),args:[Qh("value (any)",Ho("The value to be checked."))],compute:function(e){return!_v.compute.bind(this)(e)},isExported:!0},Dv={description:Ho("Whether a value is a number."),args:[Qh("value (any)",Ho("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},_v={description:Ho("Whether a value is text."),args:[Qh("value (any)",Ho("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===gi(e?.value)},isExported:!0},Ov={description:Ho("Whether the referenced cell is empty"),args:[Qh("value (any)",Ho("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},Fv={description:Ho("Returns the error value #N/A."),args:[],compute:function(){return{value:ti.NotAvailable}},isExported:!0};var Pv=Object.freeze({__proto__:null,CELL:Iv,ISBLANK:Ov,ISERR:xv,ISERROR:Ev,ISLOGICAL:Rv,ISNA:Tv,ISNONTEXT:Av,ISNUMBER:Dv,ISTEXT:_v,NA:Fv});const Mv={description:Ho("Logical `and` operator."),args:[Qh("logical_expression1 (boolean, range<boolean>)",Ho("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.")),Qh("logical_expression2 (boolean, range<boolean>, repeating)",Ho("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Ul(e);return o?t:new si(Ki)},isExported:!0},Nv={description:Ho("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},kv={description:Ho("Returns value depending on logical expression."),args:[Qh("logical_expression (boolean, range<boolean>)",Ho("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),Qh("value_if_true (any, range)",Ho("The value the function returns if logical_expression is TRUE.")),Qh("value_if_false (any, range, default=FALSE)",Ho("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){if(oc(e))return Li(kv.compute,[e,t,o]);return(Ei(ec(e))?t:o)??{value:0}},isExported:!0},Vv={description:Ho("Value if it is not an error, otherwise 2nd argument."),args:[Qh("value (any, range)",Ho("The value to return if value itself is not an error.")),Qh('value_if_error (any, range, default="empty")',Ho("The value the function returns if value is an error."))],compute:function(e,t){if(oc(e))return Li(Vv.compute,[e,t]);return(gi(ec(e)?.value)?t:e)??{value:0}},isExported:!0},Lv={description:Ho("Value if it is not an #N/A error, otherwise 2nd argument."),args:[Qh("value (any, range)",Ho("The value to return if value itself is not #N/A an error.")),Qh('value_if_error (any, range, default="empty")',Ho("The value the function returns if value is an #N/A error."))],compute:function(e,t){if(oc(e))return Li(Lv.compute,[e,t]);return(ec(e)?.value===ti.NotAvailable?t:e)??{value:0}},isExported:!0},Hv={description:Ho("Returns a value depending on multiple logical expressions."),args:[Qh("condition1 (boolean, range<boolean>)",Ho("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),Qh("value1 (any, range)",Ho("The returned value if condition1 is TRUE.")),Qh("condition2 (boolean, any, range, repeating)",Ho("Additional conditions to be evaluated if the previous ones are FALSE.")),Qh("value2 (any, range, repeating)",Ho("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){if(e.length%2!=0)return new si(Ho("Wrong number of arguments. Expected an even number of arguments."));for(;e.length>0;){if(oc(e[0]))return Li(Hv.compute,e);const t=Ei(ec(e.shift())),o=e.shift();if(t)return o??{value:0}}return new si(Ho("No match."))},isExported:!0},Uv={description:Ho("Returns opposite of provided logical value."),args:[Qh("logical_expression (boolean)",Ho("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!Ei(e)},isExported:!0},Bv={description:Ho("Logical `or` operator."),args:[Qh("logical_expression1 (boolean, range<boolean>)",Ho("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.")),Qh("logical_expression2 (boolean, range<boolean>, repeating)",Ho("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Bl(e);return o?t:new si(Ki)},isExported:!0},zv={description:Ho("Returns a value by comparing cases to an expression."),args:[Qh("expression (number, boolean, string)",Ho("The value to be checked.")),Qh("case1 (number, boolean, string)",Ho("The first case to be checked against expression.")),Qh("value1 (any)",Ho("The corresponding value to be returned if case1 matches expression.")),Qh("case2 (any, repeating)",Ho("Additional cases to try if the previous ones don't match expression.")),Qh("value2 (any, repeating)",Ho("Additional values to be returned if their corresponding cases match expression.")),Qh('default (any, default="empty")',Ho("An optional default value to be returned if none of the cases match expression."))],compute:function(e,...t){const o=t.length%2==0?pi(e):t.pop();for(let o=0;o<t.length;o+=2){const s=t[o];if(s&&gi(s.value))return s;if(e?.value===s?.value)return t[o+1]||{value:0}}return o||{value:0}},isExported:!0},$v={description:Ho("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},Gv={description:Ho("Logical `xor` operator."),args:[Qh("logical_expression1 (boolean, range<boolean>)",Ho("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.")),Qh("logical_expression2 (boolean, range<boolean>, repeating)",Ho("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return Hi(e,(e=>(t=!0,o=o?!e:e,!0))),t?o:new si(Ki)},isExported:!0};var Wv=Object.freeze({__proto__:null,AND:Mv,FALSE:Nv,IF:kv,IFERROR:Vv,IFNA:Lv,IFS:Hv,NOT:Uv,OR:Bv,SWITCH:zv,TRUE:$v,XOR:Gv});function qv(e,t){const o=t.getPivotId(e);if(!o)throw new si(Ho('There is no pivot with id "%s"',e));return o}function Zv(e){if(e.length%2!=0)throw new si(Ho("Function PIVOT takes an even number of arguments."))}function jv(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,n=fr(i),r=e.getters.getRangeFromSheetXC(o,n);if(void 0===r||r.invalidXc||r.invalidSheetName)throw new ri;if(e.__originCellPosition&&r.sheetId===e.__originSheetId&&Rr(Mr(e.__originCellPosition),i))throw new ni;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 Yv=!0,Xv={description:Ho("Returns a cell reference as a string. "),args:[Qh("row (number)",Ho("The row number of the cell reference. ")),Qh("column (number)",Ho("The column number (not name) of the cell reference. A is column number 1. ")),Qh("absolute_relative_mode (number, default=1)",Ho("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).")),Qh("use_a1_notation (boolean, default=TRUE)",Ho("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).")),Qh("sheet (string, optional)",Ho("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=yi(e,this.locale),r=yi(t,this.locale);if(n<1)return new si(Yl(n));if(r<1)return new si(Yl(r));const a=yi(o,this.locale);if(![1,2,3,4].includes(a))return new si((l=4,c=a,Ho("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));var l,c;let h;if(Ei(s)){h=Po(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?aa(wi(i),h):h},isExported:!0},Kv={description:Ho("Column number of a specified cell."),args:[Qh("cell_reference (meta, default='this cell')",Ho("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(gi(e?.value))return e;if(void 0===e)return void 0===this.__originCellPosition?.col?new si(Ho("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.col+1;const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.left===t.right?t.left+1:Ni(t.right-t.left+1,1,((e,o)=>({value:t.left+e+1})))},isExported:!0},Jv={description:Ho("Number of columns in a specified array or range."),args:[Qh("range (meta)",Ho("The range whose column count will be returned."))],compute:function(e){if(gi(e?.value))return e;const t=ur(e.value);return t.right-t.left+1},isExported:!0},Qv={description:Ho("Horizontal lookup"),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("range (any, range)",Ho("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),Qh("index (number)",Ho("The row index of the value to be returned, where the first row in range is numbered 1.")),Qh("is_sorted (boolean, default=true)",Ho("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:Yv}){const i=Math.trunc(fi(o?.value,this.locale)),n=ji(t);if(1>i||i>n[0].length)return new si(Ho("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[t][0].value,a=n[Ei(s.value)?Gi(n,e,"nextSmaller","asc",n.length,r):Wi(n,e,"wildcard",n.length,r,this.lookupCaches)];return void 0===a?pi(e):a[i-1]},isExported:!0},eb={description:Ho("Returns the content of a cell, specified by row and column offset."),args:[Qh("reference (any, range)",Ho("The range of cells from which the values are returned.")),Qh("row (number, default=0)",Ho("The index of the row to be returned from within the reference range of cells.")),Qh("column (number, default=0)",Ho("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=ji(e),i=fi(t.value,this.locale),n=fi(o.value,this.locale);return n<0||n-1>=s.length||i<0||i-1>=s[0].length?new si(Ho("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},tb={description:Ho("Returns the content of a cell, specified by a string."),args:[Qh("reference (string)",Ho("The range of cells from which the values are returned.")),Qh("use_a1_notation (boolean, default=TRUE)",Ho("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."))],compute:function(e,t={value:!0}){const o=e?.value?.toString();if(!o)return new ri(Ho("Reference should be defined."));if(!Ei(t))return new si(Ho("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 ri;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},ob={description:Ho("Look up a value."),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("search_array (any, range)",Ho("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.")),Qh("result_range (any, range, optional)",Ho("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=ji(t),i=ji(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=Gi(s,e,"nextSmaller","asc",a?r:n,l);return-1===c||a&&void 0===s[0][c]||!a&&void 0===s[c][r-1]?pi(e):0===i[0].length?a?s[n-1][c]:s[c][r-1]:(n=i.length,r=i[0].length,1!==n&&1!==r?new si(Ho("The result_range must be a single row or a single column.")):n>1?c>n-1?new si(Ho("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",c+1)):i[c][0]:c>r-1?new si(Ho("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",c+1)):i[0][c])},isExported:!0},sb={description:Ho("Position of item in range that matches value."),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("range (any, range)",Ho("The one-dimensional array to be searched.")),Qh("search_type (number, default=1)",Ho("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=fi(o,this.locale);const i=ji(t),n=i.length,r=i[0].length;if(1!==n&&1!==r)return new si(Ho("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=Gi(i,e,"nextSmaller","asc",c,l);break;case 0:a=Wi(i,e,"wildcard",c,l,this.lookupCaches);break;case-1:a=Gi(i,e,"nextGreater","desc",c,l)}return 1===n&&void 0===i[0][a]||1!==n&&void 0===i[a]?pi(e):a+1},isExported:!0},ib={description:Ho("Row number of a specified cell."),args:[Qh("cell_reference (meta, default='this cell')",Ho("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(gi(e?.value))return e;if(void 0===e)return void 0===this.__originCellPosition?.row?new si(Ho("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.row+1;const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.top===t.bottom?t.top+1:Ni(1,t.bottom-t.top+1,((e,o)=>({value:t.top+o+1})))},isExported:!0},nb={description:Ho("Number of rows in a specified array or range."),args:[Qh("range (meta)",Ho("The range whose row count will be returned."))],compute:function(e){if(gi(e?.value))return e;const t=ur(e.value);return t.bottom-t.top+1},isExported:!0},rb={description:Ho("Vertical lookup."),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("range (any, range)",Ho("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),Qh("index (number)",Ho("The column index of the value to be returned, where the first column in range is numbered 1.")),Qh("is_sorted (boolean, default=true)",Ho("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:Yv}){const i=Math.trunc(fi(o?.value,this.locale)),n=ji(t);if(1>i||i>n.length)return new si(Ho("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[0][t].value,a=Ei(s.value)?Gi(n,e,"nextSmaller","asc",n[0].length,r):Wi(n,e,"wildcard",n[0].length,r,this.lookupCaches),l=n[i-1][a];return void 0===l?pi(e):l},isExported:!0},ab={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},lb={description:Ho("Search a range for a match and return the corresponding item from a second range."),args:[Qh("search_key (string,number,boolean)",Ho("The value to search for.")),Qh("lookup_range (any, range)",Ho("The range to consider for the search. Should be a single column or a single row.")),Qh("return_range (any, range)",Ho("The range containing the return value. Should have the same dimensions as lookup_range.")),Qh("if_not_found (any, optional)",Ho("If a valid match is not found, return this value.")),Qh("match_mode (any, default=0)",Ho("(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.")),Qh("search_mode (any, default=1)",Ho("(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(fi(i.value,this.locale)),a=Math.trunc(fi(n.value,this.locale)),l=ji(t),c=ji(o);if(1!==l.length&&1!==l[0].length)return new si(Ho("lookup_range should be either a single row or single column."));if(![1,-1,2,-2].includes(a))return new si(Ho("search_mode should be a value in [-1, 1, -2, 2]."));if(![-1,0,1,2].includes(r))return new si(Ho("match_mode should be a value in [-1, 0, 1, 2]."));const h=1===l.length?"col":"row";if(2===r&&[-2,2].includes(a))return new si(Ho("The search and match mode combination is not supported for XLOOKUP evaluation."));if("col"===h?c[0].length!==l[0].length:c.length!==l.length)return new si(Ho("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=ab[r],p=-1===a,m=2===a||-2===a?Gi(l,e,g,2===a?"asc":"desc",u,d):Wi(l,e,g,u,d,this.lookupCaches,p);return-1!==m?"col"===h?c.map((e=>[e[m]])):[c[m]]:void 0===s?pi(e):[[s]]},isExported:!0},cb={description:Ho("Get the value from a pivot."),args:[Qh("pivot_id (number,string)",Ho("ID of the pivot.")),Qh("measure_name (string)",Ho("Name of the measure.")),Qh("domain_field_name (string,repeating)",Ho("Field name.")),Qh("domain_value (number,string,boolean,repeating)",Ho("Value."))],compute:function(e,t,...o){const s=wi(e),i=wi(t),n=qv(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 si(Ho("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(n,i,this.getters),Zv(o);const r=this.getters.getPivot(n),a=this.getters.getPivotCoreDefinition(n);jv(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=Ho("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:ti.GenericError,message:Ho("Dimensions don't match the pivot definition")+". "+e}}const c=r.parseArgsToPivotDomain(o);return this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(n)?.trackValue(i,c),r.getPivotCellValueAndFormat(i,c)}},hb={description:Ho("Get the header of a pivot."),args:[Qh("pivot_id (number,string)",Ho("ID of the pivot.")),Qh("domain_field_name (string,repeating)",Ho("Field name.")),Qh("domain_value (number,string,value,repeating)",Ho("Value."))],compute:function(e,...t){const o=wi(e),s=qv(o,this.getters);Zv(t);const i=this.getters.getPivot(s);jv(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=Ho("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:ti.GenericError,message:Ho("Dimensions don't match the pivot definition")+". "+e}}const r=i.parseArgsToPivotDomain(t);this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(s)?.trackHeader(r);const a=r.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(wi(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}}},db={description:Ho("Get a pivot table."),args:[Qh("pivot_id (string)",Ho("ID of the pivot.")),Qh("row_count (number, optional)",Ho("number of rows")),Qh("include_total (boolean, default=TRUE)",Ho("Whether to include total/sub-totals or not.")),Qh("include_column_titles (boolean, default=TRUE)",Ho("Whether to include the column titles or not.")),Qh("column_count (number, optional)",Ho("number of columns")),Qh("include_measure_titles (boolean, default=TRUE)",Ho("Whether to include the measure titles row or not."))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE},n={value:!0}){const r=wi(e),a=fi(t,this.locale);if(a<0)return new si(Ho("The number of rows must be positive."));const l=fi(i,this.locale);if(l<0)return new si(Ho("The number of columns must be positive."));const c={displayColumnHeaders:Ei(s),displayTotals:Ei(o),displayMeasuresRow:Ei(n)},h=qv(r,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);jv(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getCollapsedTableStructure(),m=p.getPivotCells(c);let f=0;c.displayColumnHeaders&&(f=p.columns.length-1),c.displayMeasuresRow&&f++;const v=this.getters.getPivotName(h),b=Math.min(f+a,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+l,m.length),C=[];for(const e of je(0,S)){C[e]=[];for(const t of je(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":C[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);C[e].push((y=o.domain,w=t,0===y.length?w:{...w,format:(w.format||"@")+"* "}));break;case"MEASURE_HEADER":C[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":C[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}var y,w;return(c.displayColumnHeaders||c.displayMeasuresRow)&&(C[0][0]={value:v}),C}},ub={description:Ho("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[Qh("cell_reference (meta)",Ho("The starting point from which to count the offset rows and columns.")),Qh("offset_rows (number)",Ho("The number of rows to offset by.")),Qh("offset_columns (number)",Ho("The number of columns to offset by.")),Qh("height (number, default='height of cell_reference')",Ho("The number of rows of the range to return starting at the offset target.")),Qh("width (number, default='width of cell_reference')",Ho("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(gi(e?.value))return e;const n=e?.value;if(!n)return new si("In this context, the function OFFSET needs to have a cell or range in parameter.");const r=ur(n);let a=r.bottom-r.top+1,l=r.right-r.left+1;if(s){const e=fi(s,this.locale);if(e<1)return new si(Ho("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}));a=e}if(i){const e=fi(i,this.locale);if(e<1)return new si(Ho("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}));l=e}const{sheetName:c}=ra(n),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=fi(t,this.locale),u=fi(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 ri(Ho("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(h,f);return v.invalidXc||v.invalidSheetName?new ri:(g&&this.addDependencies?.(g,[v]),Ni(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var gb=Object.freeze({__proto__:null,ADDRESS:Xv,COLUMN:Kv,COLUMNS:Jv,HLOOKUP:Qv,INDEX:eb,INDIRECT:tb,LOOKUP:ob,MATCH:sb,OFFSET:ub,PIVOT:db,PIVOT_HEADER:hb,PIVOT_VALUE:cb,ROW:ib,ROWS:nb,VLOOKUP:rb,XLOOKUP:lb});const pb={description:Ho("Sum of two numbers."),args:[Qh("value1 (number)",Ho("The first addend.")),Qh("value2 (number)",Ho("The second addend."))],compute:function(e,t){return{value:fi(e,this.locale)+fi(t,this.locale),format:e?.format||t?.format}}},mb={description:Ho("Concatenation of two values."),args:[Qh("value1 (string)",Ho("The value to which value2 will be appended.")),Qh("value2 (string)",Ho("The value to append to value1."))],compute:function(e,t){return wi(e)+wi(t)},isExported:!0},fb={description:Ho("One number divided by another."),args:[Qh("dividend (number)",Ho("The number to be divided.")),Qh("divisor (number)",Ho("The number to divide by."))],compute:function(e,t){const o=fi(t,this.locale);return 0===o?new hi(Ho("The divisor must be different from zero.")):{value:fi(e,this.locale)/o,format:e?.format||t?.format}}};function vb(e){return void 0===e||null===e.value}const bb={number:0,string:"",boolean:!1};function Sb(e,t,o=2e-16){return Math.abs(e-t)<o}const Cb={description:Ho("Equal."),args:[Qh("value1 (string, number, boolean)",Ho("The first value.")),Qh("value2 (string, number, boolean)",Ho("The value to test against value1 for equality."))],compute:function(e,t){if(gi(e?.value))return e;if(gi(t?.value))return t;let o=vb(e)?bb[typeof t?.value]:e?.value,s=vb(t)?bb[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),"number"==typeof o&&"number"==typeof s?{value:Sb(o,s)}:{value:o===s}}};function yb(e,t,o){if(gi(e?.value))return e;if(gi(t?.value))return t;let s=vb(e)?bb[typeof t?.value]:e?.value,i=vb(t)?bb[typeof e?.value]:t?.value;"number"!=typeof s&&(s=wi(s).toUpperCase()),"number"!=typeof i&&(i=wi(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 wb={description:Ho("Strictly greater than."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being greater than value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){return yb(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?!Sb(e,t)&&e>t:e>t))}},Ib={description:Ho("Greater than or equal to."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being greater than or equal to value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){return yb(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?Sb(e,t)||e>t:e>=t))}},xb={description:Ho("Less than."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being less than value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){const o=Ib.compute.bind(this)(e,t);return gi(o.value)?o:{value:!o.value}}},Eb={description:Ho("Less than or equal to."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being less than or equal to value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){const o=wb.compute.bind(this)(e,t);return gi(o.value)?o:{value:!o.value}}},Rb={description:Ho("Difference of two numbers."),args:[Qh("value1 (number)",Ho("The minuend, or number to be subtracted from.")),Qh("value2 (number)",Ho("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:fi(e,this.locale)-fi(t,this.locale),format:e?.format||t?.format}}},Tb={description:Ho("Product of two numbers"),args:[Qh("factor1 (number)",Ho("The first multiplicand.")),Qh("factor2 (number)",Ho("The second multiplicand."))],compute:function(e,t){return{value:fi(e,this.locale)*fi(t,this.locale),format:e?.format||t?.format}}},Ab={description:Ho("Not equal."),args:[Qh("value1 (string, number, boolean)",Ho("The first value.")),Qh("value2 (string, number, boolean)",Ho("The value to test against value1 for inequality."))],compute:function(e,t){const o=Cb.compute.bind(this)(e,t);return gi(o.value)?o:{value:!o.value}}},Db={description:Ho("A number raised to a power."),args:[Qh("base (number)",Ho("The number to raise to the exponent power.")),Qh("exponent (number)",Ho("The exponent to raise base to."))],compute:function(e,t){return bu.compute.bind(this)(e,t)}},_b={description:Ho("A number with the sign reversed."),args:[Qh("value (number)",Ho("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-fi(e,this.locale),format:e?.format}}},Ob={description:Ho("Value interpreted as a percentage."),args:[Qh("percentage (number)",Ho("The value to interpret as a percentage."))],compute:function(e){return fi(e,this.locale)/100}},Fb={description:Ho("A specified number, unchanged."),args:[Qh("value (any)",Ho("The number to return."))],compute:function(e={value:null}){return e}};var Pb=Object.freeze({__proto__:null,ADD:pb,CONCAT:mb,DIVIDE:fb,EQ:Cb,GT:wb,GTE:Ib,LT:xb,LTE:Eb,MINUS:Rb,MULTIPLY:Tb,NE:Ab,POW:Db,UMINUS:_b,UNARY_PERCENT:Ob,UPLUS:Fb});const Mb=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),Nb={transform:e=>e,inverseTransform:e=>e},kb=1e-10,Vb=.0254,Lb=Vb/72,Hb=.3048,Ub=.9144,Bb=1609.34,zb=1852,$b=946073047258e4,Gb={g:{...Nb,category:"weight"},u:{...Mb(166053e-29),category:"weight"},grain:{...Mb(.0647989),category:"weight"},ozm:{...Mb(28.3495),category:"weight"},lbm:{...Mb(453.592),category:"weight"},stone:{...Mb(6350.29),category:"weight"},sg:{...Mb(14593.90294),category:"weight"},cwt:{...Mb(45359.237),category:"weight"},uk_cwt:{...Mb(50802.3),category:"weight"},ton:{...Mb(907184.74),category:"weight"},uk_ton:{...Mb(1016046.9),category:"weight"},m:{...Nb,category:"distance"},km:{...Mb(1e3),category:"distance"},ang:{...Mb(kb),category:"distance"},Picapt:{...Mb(Lb),category:"distance"},pica:{...Mb(Vb/6),category:"distance"},in:{...Mb(Vb),category:"distance"},ft:{...Mb(Hb),category:"distance"},yd:{...Mb(Ub),category:"distance"},ell:{...Mb(1.143),category:"distance"},mi:{...Mb(Bb),category:"distance"},survey_mi:{...Mb(1609.34),category:"distance"},Nmi:{...Mb(zb),category:"distance"},ly:{...Mb($b),category:"distance"},parsec:{...Mb(0x6da012f95c9fd0),category:"distance"},sec:{...Nb,category:"time"},min:{...Mb(60),category:"time"},hr:{...Mb(3600),category:"time"},day:{...Mb(86400),category:"time"},yr:{...Mb(31556952),category:"time"},Pa:{...Nb,category:"pressure"},bar:{...Mb(1e5),category:"pressure"},mmHg:{...Mb(133.322),category:"pressure"},Torr:{...Mb(133.322),category:"pressure"},psi:{...Mb(6894.76),category:"pressure"},atm:{...Mb(101325),category:"pressure"},N:{...Nb,category:"force"},dyn:{...Mb(1e-5),category:"force"},pond:{...Mb(.00980665),category:"force"},lbf:{...Mb(4.44822),category:"force"},J:{...Nb,category:"energy"},eV:{...Mb(160218e-24),category:"energy"},e:{...Mb(1e-7),category:"energy"},flb:{...Mb(1.3558179483),category:"energy"},c:{...Mb(4.184),category:"energy"},cal:{...Mb(4.1868),category:"energy"},BTU:{...Mb(1055.06),category:"energy"},Wh:{...Mb(3600),category:"energy"},HPh:{...Mb(2684520),category:"energy"},W:{...Nb,category:"power"},PS:{...Mb(735.499),category:"power"},HP:{...Mb(745.7),category:"power"},T:{...Nb,category:"magnetism"},ga:{...Mb(1e-4),category:"magnetism"},K:{...Nb,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:{...Mb(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...Nb,category:"volume",order:3},"ang^3":{...Mb(Math.pow(kb,3)),category:"volume",order:3},"Picapt^3":{...Mb(Math.pow(Lb,3)),category:"volume",order:3},tsp:{...Mb(492892e-11),category:"volume"},tspm:{...Mb(5e-6),category:"volume"},tbs:{...Mb(14786764825785619e-21),category:"volume"},"in^3":{...Mb(Math.pow(Vb,3)),category:"volume",order:3},oz:{...Mb(295735295625e-16),category:"volume"},cup:{...Mb(237e-6),category:"volume"},pt:{...Mb(.0004731765),category:"volume"},uk_pt:{...Mb(568261e-9),category:"volume"},qt:{...Mb(.0009463529),category:"volume"},l:{...Mb(.001),category:"volume"},uk_qt:{...Mb(.0011365225),category:"volume"},gal:{...Mb(.0037854118),category:"volume"},uk_gal:{...Mb(.00454609),category:"volume"},"ft^3":{...Mb(Math.pow(Hb,3)),category:"volume",order:3},bushel:{...Mb(.0352390704),category:"volume"},barrel:{...Mb(.158987295),category:"volume"},"yd^3":{...Mb(Math.pow(Ub,3)),category:"volume",order:3},MTON:{...Mb(1.13267386368),category:"volume"},GRT:{...Mb(2.83168),category:"volume"},"mi^3":{...Mb(Math.pow(Bb,3)),category:"volume",order:3},"Nmi^3":{...Mb(Math.pow(zb,3)),category:"volume",order:3},"ly^3":{...Mb(Math.pow($b,3)),category:"volume",order:3},"m^2":{...Nb,category:"area",order:2},"ang^2":{...Mb(Math.pow(kb,2)),category:"area",order:2},"Picapt^2":{...Mb(Math.pow(Lb,2)),category:"area",order:2},"in^2":{...Mb(Math.pow(Vb,2)),category:"area",order:2},"ft^2":{...Mb(Math.pow(Hb,2)),category:"area",order:2},"yd^2":{...Mb(Math.pow(Ub,2)),category:"area",order:2},ar:{...Mb(100),category:"area"},Morgen:{...Mb(2500),category:"area"},uk_acre:{...Mb(4046.8564224),category:"area"},us_acre:{...Mb(4046.8726098743),category:"area"},ha:{...Mb(1e4),category:"area"},"mi^2":{...Mb(Math.pow(Bb,2)),category:"area",order:2},"Nmi^2":{...Mb(Math.pow(zb,2)),category:"area",order:2},"ly^2":{...Mb(Math.pow($b,2)),category:"area",order:2},bit:{...Nb,category:"information"},byte:{...Mb(8),category:"information"},"m/s":{...Nb,category:"speed"},"m/hr":{...Mb(1/3600),category:"speed"},"km/hr":{...Mb(1/3.6),category:"speed"},mph:{...Mb(.44704),category:"speed"},kn:{...Mb(.5144444444),category:"speed"},admkn:{...Mb(.5147733333),category:"speed"}},Wb={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"},qb={"":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)},Zb={weight:Ho("Weight"),distance:Ho("Distance"),time:Ho("Time"),pressure:Ho("Pressure"),force:Ho("Force"),energy:Ho("Energy"),power:Ho("Power"),magnetism:Ho("Magnetism"),temperature:Ho("Temperature"),volume:Ho("Volume"),area:Ho("Area"),information:Ho("Information"),speed:Ho("Speed")};function jb(e){return Zb[e]??""}function Yb(e){for(const[t,o]of Object.entries(qb)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=Gb[s];if(!i&&Wb[s]&&(i=Gb[Wb[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const Xb={description:Ho("Converts a numeric value to a different unit of measure."),args:[Qh("value (number)",Ho("the numeric value in start_unit to convert to end_unit")),Qh("start_unit (string)",Ho("The starting unit, the unit currently assigned to value")),Qh("end_unit (string)",Ho("The unit of measure into which to convert value"))],compute:function(e,t,o){const s=fi(e,this.locale),i=wi(t),n=wi(o),r=Yb(i),a=Yb(n);return r?a?r.category!==a.category?{value:ti.GenericError,message:Ho("Incompatible units of measure ('%s' vs '%s')",jb(r.category),jb(a.category))}:{value:a.inverseTransform(r.factor*r.transform(s))/a.factor,format:e?.format}:{value:ti.GenericError,message:Ho("Invalid units of measure ('%s')",n)}:{value:ti.GenericError,message:Ho("Invalid units of measure ('%s')",i)}},isExported:!0};var Kb=Object.freeze({__proto__:null,CONVERT:Xb});const Jb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,Qb={description:Ho("Gets character associated with number."),args:[Qh("table_number (number)",Ho("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(fi(e,this.locale));return t<1?new si(Ho("The table_number (%s) is out of range.",t)):String.fromCharCode(t)},isExported:!0},eS={description:Ho("Remove non-printable characters from a piece of text."),args:[Qh("text (string)",Ho("The text whose non-printable characters are to be removed."))],compute:function(e){const t=wi(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},tS={description:Ho("Appends strings to one another."),args:[Qh("string1 (string, range<string>)",Ho("The initial string.")),Qh("string2 (string, range<string>, repeating)",Ho("More strings to append in sequence."))],compute:function(...e){return Fi(e,((e,t)=>e+wi(t)),"")},isExported:!0},oS={description:Ho("Tests whether two strings are identical."),args:[Qh("string1 (string)",Ho("The first string to compare.")),Qh("string2 (string)",Ho("The second string to compare."))],compute:function(e,t){return wi(e)===wi(t)},isExported:!0},sS={description:Ho("First position of string found in text, case-sensitive."),args:[Qh("search_for (string)",Ho("The string to look for within text_to_search.")),Qh("text_to_search (string)",Ho("The text to search for the first occurrence of search_for.")),Qh("starting_at (number, default=1)",Ho("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=wi(e),i=wi(t),n=fi(o,this.locale);if(""===i)return new si(Ho("The text_to_search must be non-empty."));if(n<1)return new si(Ho("The starting_at (%s) must be greater than or equal to 1.",n));const r=i.indexOf(s,n-1);return-1===r?new si(Ho("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)):r+1},isExported:!0},iS={description:Ho("Concatenates elements of arrays with delimiter."),args:[Qh("delimiter (string)",Ho("The character or string to place between each concatenated value.")),Qh("value_or_array1 (string, range<string>)",Ho("The value or values to be appended using delimiter.")),Qh("value_or_array2 (string, range<string>, repeating)",Ho("More values to be appended using delimiter."))],compute:function(e,...t){const o=wi(e);return Fi(t,((e,t)=>(e?e+o:"")+wi(t)),"")}},nS={description:Ho("Substring from beginning of specified string."),args:[Qh("text (string)",Ho("The string from which the left portion will be returned.")),Qh("number_of_characters (number, optional)",Ho("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?fi(t[0],this.locale):1;return o<0?new si(Ho("The number_of_characters (%s) must be positive or null.",o)):wi(e).substring(0,o)},isExported:!0},rS={description:Ho("Length of a string."),args:[Qh("text (string)",Ho("The string whose length will be returned."))],compute:function(e){return wi(e).length},isExported:!0},aS={description:Ho("Converts a specified string to lowercase."),args:[Qh("text (string)",Ho("The string to convert to lowercase."))],compute:function(e){return wi(e).toLowerCase()},isExported:!0},lS={description:Ho("A segment of a string."),args:[Qh("text (string)",Ho("The string to extract a segment from.")),Qh("starting_at (number)",Ho("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),Qh("extract_length (number)",Ho("The length of the segment to extract."))],compute:function(e,t,o){const s=wi(e),i=fi(t,this.locale),n=fi(o,this.locale);return i<1?new si(Ho("The starting_at argument (%s) must be positive greater than one.",i.toString())):n<0?new si(Ho("The extract_length argument (%s) must be positive or null.",n)):s.slice(i-1,i+n-1)},isExported:!0},cS={description:Ho("Capitalizes each word in a specified string."),args:[Qh("text_to_capitalize (string)",Ho("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 wi(e).replace(Jb,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},hS={description:Ho("Replaces part of a text string with different text."),args:[Qh("text (string)",Ho("The text, a part of which will be replaced.")),Qh("position (number)",Ho("The position where the replacement will begin (starting from 1).")),Qh("length (number)",Ho("The number of characters in the text to be replaced.")),Qh("new_text (string)",Ho("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=fi(t,this.locale);if(i<1)return new si(Ho("The position (%s) must be greater than or equal to 1.",i));const n=wi(e),r=fi(o,this.locale),a=wi(s);return n.substring(0,i-1)+a+n.substring(i-1+r)},isExported:!0},dS={description:Ho("A substring from the end of a specified string."),args:[Qh("text (string)",Ho("The string from which the right portion will be returned.")),Qh("number_of_characters (number, optional)",Ho("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?fi(t[0],this.locale):1;if(o<0)return new si(Ho("The number_of_characters (%s) must be positive or null.",o));const s=wi(e),i=s.length;return s.substring(i-o,i)},isExported:!0},uS={description:Ho("First position of string found in text, ignoring case."),args:[Qh("search_for (string)",Ho("The string to look for within text_to_search.")),Qh("text_to_search (string)",Ho("The text to search for the first occurrence of search_for.")),Qh("starting_at (number, default=1)",Ho("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=wi(e).toLowerCase(),i=wi(t).toLowerCase(),n=fi(o,this.locale);if(""===i)return{value:ti.GenericError,message:Ho("The text_to_search must be non-empty.")};if(n<1)return{value:ti.GenericError,message:Ho("The starting_at (%s) must be greater than or equal to 1.",n)};const r=i.indexOf(s,n-1);return-1===r?{value:ti.GenericError,message:Ho("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)}:{value:r+1}},isExported:!0},gS={description:Ho("Split text by specific character delimiter(s)."),args:[Qh("text (string)",Ho("The text to divide.")),Qh("delimiter (string)",Ho("The character or characters to use to split text.")),Qh("split_by_each (boolean, default=true})",Ho("Whether or not to divide text around each character contained in delimiter.")),Qh("remove_empty_text (boolean, default=true)",Ho("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=wi(e),n=Be(wi(t)),r=Ei(o),a=Ei(s);if(n.length<=0)return new si(Ho("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))),Vi([c])},isExported:!1},pS={description:Ho("Replaces existing text with new text in a string."),args:[Qh("text_to_search (string)",Ho("The text within which to search and replace.")),Qh("search_for (string)",Ho("The string to search for within text_to_search.")),Qh("replace_with (string)",Ho("The string that will replace search_for.")),Qh("occurrence_number (number, optional)",Ho("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=fi(s,this.locale);if(i<0)return new si(Ho("The occurrenceNumber (%s) must be positive or null.",i));const n=wi(e),r=wi(t);if(""===r)return n;const a=wi(o),l=new RegExp(Be(r),"g");if(0===i)return n.replace(l,a);let c=0;return n.replace(l,(e=>++c===i?a:e))},isExported:!0},mS={description:Ho("Combines text from multiple strings and/or arrays."),args:[Qh("delimiter (string)",Ho(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),Qh("ignore_empty (boolean)",Ho("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.")),Qh("text1 (string, range<string>)",Ho("Any text item. This could be a string, or an array of strings in a range.")),Qh("text2 (string, range<string>, repeating)",Ho("Additional text item(s)."))],compute:function(e,t,...o){const s=wi(e),i=Ei(t);let n=0;return Fi(o,((e,t)=>i&&""===wi(t)?e:(n++?e+s:"")+wi(t)),"")},isExported:!0},fS={description:Ho("Splits text into rows or columns using specified column and row delimiters."),args:[Qh("text (string)",Ho("The text to split.")),Qh("col_delimiter (string, range<string>)",Ho("Character or string to split columns by.")),Qh("row_delimiter (string, range<string>, optional)",Ho("Character or string to split rows by.")),Qh("ignore_empty (boolean, default=false)",Ho("Whether to ignore empty cells.")),Qh("match_mode (number, default=0)",Ho("Searches the text for a delimiter match. 0 = case-sensitive, 1 = case-insensitive.")),Qh(`pad_with (string, default="${ti.NotAvailable}")`,Ho("The value to use for padding empty cells."))],compute:function(e,t,o,s={value:false},i={value:0},n=new ai){const r=wi(e);if(r.length<=0)return new si(Ho("No text to split."));if(void 0===t&&void 0===o)return new si(Ho("At least one delimiter must be provided."));const a=ji(t).flat().map((e=>Be(wi(e)))),l=ji(o).flat().map((e=>Be(wi(e))));if(a.some((e=>""===e))||l.some((e=>""===e)))return new si(Ho("The delimiters cannot be empty values."));const c=Ei(s),h=fi(i,this.locale);if(![0,1].includes(h))return new si(Ho("match_mode should be a value of 0 or 1."));const d=[],u=1===h?"gi":"g",g=l.filter((e=>!a.includes(e)));let p=g.length?r.split(new RegExp(g.join("|"),u)):[r];c&&(p=p.filter((e=>""!==e)));const m=new RegExp(a.join("|"),u);for(const e of p){let t=a.length?e.split(m):[e];c&&(t=t.filter((e=>""!==e))),d.push(t.map((e=>({value:e}))))}const f=Math.max(...d.map((e=>e.length)));for(const e of d)for(;e.length<f;)e.push(n);return Vi(d)},isExported:!0},vS={description:Ho("Removes space characters."),args:[Qh("text (string)",Ho("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return Dt(wi(e))},isExported:!0},bS={description:Ho("Converts a specified string to uppercase."),args:[Qh("text (string)",Ho("The string to convert to uppercase."))],compute:function(e){return wi(e).toUpperCase()},isExported:!0},SS={description:Ho("Converts a number to text according to a specified format."),args:[Qh("number (number)",Ho("The number, date or time to format.")),Qh("format (string)",Ho('The case-sensitive format of the result, enclosed in quotation marks. Examples: "0.00" rounded to 2 decimal places, "hh:mm:ss" for hour:minutes:seconds.'))],compute:function(e,t){return In(fi(e,this.locale),{format:wi(t),locale:this.locale})},isExported:!0},CS={description:Ho("Converts a string to a numeric value."),args:[Qh("value (number)",Ho("the string to be converted"))],compute:function(e){return fi(e,this.locale)},isExported:!0};var yS=Object.freeze({__proto__:null,CHAR:Qb,CLEAN:eS,CONCATENATE:tS,EXACT:oS,FIND:sS,JOIN:iS,LEFT:nS,LEN:rS,LOWER:aS,MID:lS,PROPER:cS,REPLACE:hS,RIGHT:dS,SEARCH:uS,SPLIT:gS,SUBSTITUTE:pS,TEXT:SS,TEXTJOIN:mS,TEXTSPLIT:fS,TRIM:vS,UPPER:bS,VALUE:CS});const wS={description:Ho("Creates a hyperlink in a cell."),args:[Qh("url (string)",Ho("The full URL of the link enclosed in quotation marks.")),Qh("link_label (string, optional)",Ho("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=wi(e).trim(),s=wi(t)||o;return""===o?s:ot(s,o)},isExported:!0};var IS=Object.freeze({__proto__:null,HYPERLINK:wS});const xS=[{name:Ho("Array"),functions:Rd},{name:Ho("Database"),functions:cp},{name:Ho("Date"),functions:Gp},{name:Ho("Filter"),functions:om},{name:Ho("Financial"),functions:Wf},{name:Ho("Info"),functions:Pv},{name:Ho("Lookup"),functions:gb},{name:Ho("Logical"),functions:Wv},{name:Ho("Math"),functions:Uu},{name:Ho("Misc"),functions:Ad},{name:Ho("Operator"),functions:Pb},{name:Ho("Statistical"),functions:jg},{name:Ho("Text"),functions:yS},{name:Ho("Engineering"),functions:qp},{name:Ho("Web"),functions:IS},{name:Ho("Parser"),functions:Kb}],ES=/^[A-Z0-9\_\.]+$/;const RS=new class extends n{mapping={};add(e,t){if((e=e.toUpperCase())in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){if(e=e.toUpperCase(),!ES.test(e))throw new Error(Ho("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=function(e,t){let o=0,s=0,i=0,n=0;for(const e of t.args)o++,e.optional||e.repeating||e.default||s++,e.repeating&&i++,(e.optional||e.default)&&n++;const r=t;return r.minArgRequired=s,r.maxArgPossible=i?1/0:o,r.nbrArgRepeating=i,r.nbrArgOptional=n,r.hidden=t.hidden||!1,r.name=e,r}(e,t);return function(e){if(e.nbrArgRepeating&&e.nbrArgOptional>=e.nbrArgRepeating)throw new Error(`Function ${e.name} has more optional arguments than repeatable ones.`);let t=!1,o=!1;for(const s of e.args){if(s.type.includes("META")&&s.type.length>1)throw new Error(`Function ${e.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(s.repeating){if(!o&&t)throw new Error(`Function ${e.name} has non-consecutive repeating arguments. All repeating arguments must be declared consecutively.`);t=!0,o=!0}else o=!1}}(o),this.mapping[e]=function(e){function t(...t){const s=[],i=td(e,t.length);for(let o=0;o<t.length;o++){const n=i(o)??-1,r=e.args[n];if(!js(t[o])&&r.acceptMatrixOnly)throw new ii(Ho("Function %s expects the parameter '%s' to be reference to a cell or range.",e.name,(o+1).toString()));s.push(!r.acceptMatrix)}return Li(o.bind(this),t,s)}function o(...t){for(let o=0;o<t.length;o++){const s=t[o],i=td(e,t.length);if(!e.args[i(o)||o].acceptErrors&&!js(s)&&gi(s?.value))return s}try{return s.apply(this,t)}catch(t){return TS(t,e.name)}}function s(...t){this.debug;const o=e.compute.apply(this,t);return js(o)?"object"==typeof o[0][0]&&null!==o[0][0]&&"value"in o[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])}(o,(t=>AS(t,e.name))),o):ki(o,(e=>({value:e}))):"object"==typeof o&&null!==o&&"value"in o?(AS(o,e.name),o):{value:o}}return t}(o),super.replace(e,o),this}};for(const e of xS){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),RS.add(o,{isExported:!1,...s})}}function TS(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&gi(e.value)?(_S(e)&&AS(e,t),e):(console.error(e),new si(DS+(_S(e)?" "+e.message:"")));var o}function AS(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const DS=Ho("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function _S(e){return void 0!==e?.message&&"string"==typeof e.message}class OS{scope;code="";constructor(e=new PS){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new FS(this.scope,this.code,e)}toString(){return MS(this.code)}}class FS{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=MS(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 PS{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function MS(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 NS=RS.content,kS={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},VS={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},LS={};function HS(e){return US(Xf(e))}function US(e){try{return function(e){const{dependencies:t,literalValues: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=Ue(i.value);t.strings.push({value:e});break;case"NUMBER":{const e=As(i.value,qs);t.numbers.push({value:e});break}case"SYMBOL":s.push(Ge(i.value,"'"))}return{dependencies:o,literalValues:t,symbols:s}}(e),i=function(e){let t="";for(const o of e)switch(o.type){case"STRING":t+="|S|";break;case"NUMBER":t+="|N|";break;case"REFERENCE":case"INVALID_REFERENCE":o.value.includes(":")?t+="|R|":t+="|C|";break;case"SPACE":break;default:t+=o.value}return t}(e);if(!LS[i]){const r=lv([...e]),a=new PS;let l=0,c=0,h=0;if("BIN_OPERATION"===r.type&&":"===r.value)throw new ii(Ho("Invalid formula"));if("EMPTY"===r.type)throw new ii(Ho("Invalid formula"));const d=m(r),u=new OS;u.append(`// ${i}`),u.append(d),u.append(`return ${d.returnExpression};`);const g=new Function("deps","ref","range","getSymbolValue","ctx",u.toString());function p(e){const{args:t}=e,o=e.value.toUpperCase(),s=NS[o];if(!s)throw new li(Ho('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=NS[o],{nbrArgRepeating:i,minArgRequired:n}=s;if(t<n)throw new ii(Ho("Invalid number of arguments for the %(functionName)s function. Expected %(minArgRequired)s minimum, but got %(nbrArgSupplied)s instead.",{functionName:o,minArgRequired:n,nbrArgSupplied:t}));if(t>s.maxArgPossible)throw new ii(Ho("Invalid number of arguments for the %(functionName)s function. Expected %(maxArgPossible)s maximum, but got %(nbrArgSupplied)s instead.",{functionName:o,maxArgPossible:s.maxArgPossible,nbrArgSupplied:t}));if(i>1){const e=t-n-i*Math.floor((t-n)/i)-s.nbrArgOptional;if(e>0)throw new ii(Ho("Invalid number of arguments for the %(functionName)s function. Repeatable arguments should be supplied in groups of %(nbrArgRepeating)s, with up to %(nbrArgOptional)s optional. Got %(nbrValueRemaining)s too many.",{functionName:o,nbrArgRepeating:i,nbrArgOptional:s.nbrArgOptional,nbrValueRemaining:e}))}}(e);const i=[],n=td(s,t.length);for(let e=0;e<t.length;e++){const o=s.args[n(e)??-1],r=t[e],a=o.type||[],l=a.includes("META"),c=a.some((e=>BS(e)));i.push(m(r,l,c))}return i}function m(e,t=!1,o=!1){const i=new OS(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&t)throw new ii(Ho("Argument must be a reference to a cell or range."));switch(e.debug&&(i.append("debugger;"),i.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return i.return(`{ value: ${e.value} }`);case"NUMBER":return i.return(`this.literalValues.numbers[${c++}]`);case"STRING":return i.return(`this.literalValues.strings[${l++}]`);case"REFERENCE":return!t&&e.value.includes(":")||o?i.return(`range(deps[${h++}])`):i.return(`ref(deps[${h++}], ${t?"true":"false"})`);case"FUNCALL":const n=p(e).map((e=>e.assignResultToVariable()));i.append(...n);const r=e.value.toUpperCase();return i.return(`ctx['${r}'](${n.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=VS[e.value],o=m(e.operand,!1,!1).assignResultToVariable();return i.append(o),i.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=kS[e.value],o=m(e.left,!1,!1).assignResultToVariable(),s=m(e.right,!1,!1).assignResultToVariable();return i.append(o),i.append(s),i.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const a=s.indexOf(e.value);return i.return(`getSymbolValue(this.symbols[${a}])`);case"EMPTY":return i.return("undefined")}}LS[i]=g}const n={execute:LS[i],dependencies:t,literalValues: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 BS(e){return e.startsWith("RANGE")}const zS=RS.content;function $S(e){try{return 0===hv(lv(e)).filter((e=>"FUNCALL"===e.type&&!zS[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function GS(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=lv(e)}catch{return[]}return function(e,t){return hv(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}function WS(e,t,o){if(!t.startsWith("="))return t;const s=Xf(t);for(let t=1;t<s.length;t++){if("REFERENCE"!==s[t].type)continue;const i=s[t].value,n=qS(e,i,o);i!==n&&(s[t]={value:n,type:"REFERENCE"})}return dt(s.map((e=>e.value)))}function qS(e,t,o){const s=ra(t).sheetName;if(s?!ga(s,o.sheetName.old):e!==o.sheetId)return t;const i=function(e,t){if(!ta.test(e))return fa(e);return ma({xc:e,sheetId:t},ZS)}(t,s?o.sheetId:e);if(i.invalidXc)return t;const n=o.applyChange(i);return"NONE"===n.changeType||"REMOVE"===n.changeType?t:Sa(n.range,e,function(e){return t=>t===e.sheetId?e.sheetName.current:""}(o))}function ZS(e){return{numberOfRows:Number.MAX_SAFE_INTEGER,numberOfCols:Number.MAX_SAFE_INTEGER}}const jS="x1",YS="xMovingAverage",XS={exponential:"exp",logarithmic:"log",polynomial:"poly",trailingMovingAverage:"movingAvg"};function KS(e,t,o,s){let i=!1;const n=[];for(const s in o){let r=o[s];if(r.labelCell){const e=eC(r.labelCell,t);r.labelCell!==e&&(i=!0,r={...r,labelCell:e})}const a=eC(r.dataRange,t);void 0===a||e.getRangeString(a,a.sheetId)===ti.InvalidReference?(i=!0,r=void 0):a!==r.dataRange&&(i=!0,r={...r,dataRange:a}),n[s]=r}let r=s;const a=eC(r,t);a!==r&&(i=!0,r=a);return{isStale:i,dataSets:n.filter(lt),labelRange:r}}function JS(e,t,o){return o.map((o=>({dataRange:Ca(e,t,o.dataRange),labelCell:o.labelCell?Ca(e,t,o.labelCell):void 0})))}function QS(e,t,o){return o?Ca(e,t,o):void 0}function eC(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}function tC(e,t,o,s){const i=[];for(const n of t){const t=e.getRangeFromSheetXC(o,n.dataRange),{unboundedZone:r,sheetId:a,invalidSheetName:l,invalidXc:c}=t;if(!l&&!c)if(r.left!==r.right&&r.top!==r.bottom){if(void 0===r.right)continue;for(let t=r.left;t<=r.right;t++){const o={...r,left:t,right:t};i.push({...oC(e,a,o,s?{top:o.top,bottom:o.top,left:o.left,right:o.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}}else i.push({...oC(e,a,r,s?{top:r.top,bottom:r.top,left:r.left,right:r.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}return i}function oC(e,t,o,s){if(o.left!==o.right&&o.top!==o.bottom)throw new Error(`Zone should be a single column or row: ${fr(o)}`);if(s){const i=fr(o),n=fr(s);return{labelCell:e.getRangeFromSheetXC(t,n),dataRange:e.getRangeFromSheetXC(t,i)}}return{labelCell:void 0,dataRange:e.getRangeFromSheetXC(t,fr(o))}}function sC(e,t){const o=t.labelCell?.zone;let s=t.dataRange.zone;if(o){const{numberOfRows:e,numberOfCols:t}=Tr(s);1===e?s={...s,left:s.left+1}:1===t&&(s={...s,top:s.top+1})}const i=pa({...t.dataRange,zone:s},e.getSheetSize);let n,r={};return t.customLabel?r={text:t.customLabel}:t.labelCell&&(r={reference:e.getRangeString(t.labelCell,"forceSheetReference",{useBoundedReference:!0})}),t.trend?.type&&(n={type:"polynomial"===t.trend.type&&1===t.trend.order?"linear":XS[t.trend.type],color:t.trend.color,order:t.trend.order?Math.min(t.trend.order,6):void 0,window:t.trend.window||Ae}),{label:r,range:e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0}),backgroundColor:t.backgroundColor,rightYAxis:t.rightYAxis,trend:n}}function iC(e,t,o){if(!t)return;const s={...t.zone};o&&t.zone.bottom>t.zone.top&&(s.top=s.top+1);const i=pa({...t,zone:s},e.getSheetSize);return e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0})}function nC(e,t,o){let s;if(t.labelRange){const i=qS(e,t.labelRange,o);i!==ti.InvalidReference&&(s=i)}const i=[];for(const s of t.dataSets){const t={...s},n=qS(e,s.dataRange,o);n!==ti.InvalidReference&&(t.dataRange=n,i.push(t))}return{...t,dataSets:i,labelRange:s}}function rC(e){return e&&jt(e)<.3?"#FFFFFF":"#000000"}function aC(e){return e&&jt(e)<.3?"#C8C8C8":"#666666"}function lC(e){if(e.dataSets){const t=void 0!==e.dataSets.find((e=>!ta.test(e.dataRange)));if(t)return"InvalidDataSet";if(e.dataSets.map((e=>dr(e.dataRange))).some((e=>e.top!==e.bottom&&kr(e))))return"InvalidDataSet"}return"Success"}function cC(e){if(e.labelRange){if(!ta.test(e.labelRange||""))return"InvalidLabelRange"}return"Success"}function hC(e,t,o){if(!o)return!1;if(!e)return!1;if(!t)return!0;const s=Lr(t.dataRange.zone);return!(Lr(e.zone)<s)}function dC(e){let t=!1,o=!1;if("horizontal"in e&&e.horizontal)return{useLeftAxis:!0,useRightAxis:!1};for(const s of e.dataSets||[])"y1"===s.yAxisId?o=!0:t=!0;return t||=!o,{useLeftAxis:t,useRightAxis:o}}function uC(e,t){return(o,s)=>{const i=e?.[s];return gC({format:i,locale:t})(o)}}function gC(e){return t=>{if(t=Number(t),isNaN(t))return t;const{locale:o,format:s}=e;return fC(In(t,{locale:o,format:!s&&Math.abs(t)>=1e3?"#,##":s}))}}const pC=[{value:"left",label:Ho("Left")},{value:"right",label:Ho("Right")}];function mC(e,t){const o=[],s=Ft(t.map((e=>e.data.length)));for(let t=0;t<=s;t++)o.push(e.next());return o}function fC(e){return e?e.length>ye?e.substring(0,ye)+"…":e:""}function vC(e){return e===jS||e===YS}const bC={id:"chartShowValuesPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;switch(i.save(),i.textAlign="center",i.textBaseline="middle",i.miterLimit=1,e.config.type){case"pie":case"doughnut":!function(e,t,o){for(const s of e._metasets)for(let e=0;e<s._parsed.length;e++){const i=Number(s._parsed[e]);if(isNaN(i)||0===i)continue;const n=s.data[e],{startAngle:r,endAngle:a,innerRadius:l,outerRadius:c}=n,h=(r+a)/2,d=(l+c)/2,u=n.x+d*Math.cos(h),g=n.y+d*Math.sin(h),p=t.callback(i,s,e),m=12,f=Va(o,p,{fontSize:m},"px"),v=c-l;if(f>=v||v<m)continue;const b=a-r,S=2*d*Math.tan(b/2);b<Math.PI/2&&(f>=S||S<m)||(o.fillStyle=rC(t.background),o.strokeStyle=t.background||"#ffffff",SC(p,u,g,o))}}(e,o,i);break;case"bar":case"line":case"radar":o.horizontal?CC(e,o,i):function(e,t,o){const s=e.chartArea.bottom,i=e.chartArea.top,n={};for(const r of e._metasets){if(vC(r.xAxisID)||r.hidden)continue;const a=e.scales[r.yAxisID];for(let l=0;l<r._parsed.length;l++){const c=r._parsed[l],h=Number("radar"===e.config.type?c.r:c.y);if(isNaN(h))continue;const d=r.data[l],u=d.x;let g=0;if("line"===e.config.type||"radar"===e.config.type)g=h<0?d.y+10:d.y-10;else{const e=a.getPixelForValue(0),t=12;g=Math.abs(e-d.y)<t?h<0?e+t/2:e-t/2:h<0?d.y-d.height/2:d.y+d.height/2}g=Math.min(g,s),g=Math.max(g,i),n[u]||(n[u]=[]);for(const e of n[u]||[])Math.abs(e-g)<13&&(g=h<0?e+13:e-13);n[u].push(g),o.fillStyle=d.options.backgroundColor,o.strokeStyle=t.background||"#ffffff";SC(t.callback(Number(h),r,l),u,g,o)}}}(e,o,i);break;case"funnel":CC(e,o,i)}i.restore()}};function SC(e,t,o,s){s.lineWidth=3,s.strokeText(e,t,o),s.lineWidth=1,s.fillText(e,t,o)}function CC(e,t,o){const s=e.chartArea.right,i=e.chartArea.left,n={};for(const r of e._metasets){if(vC(r.xAxisID))return;const a=e.scales[r.xAxisID].getPixelForValue(0);for(let e=0;e<r._parsed.length;e++){const l=Number(r._parsed[e].x);if(isNaN(l))continue;const c=t.callback(l,r,e),h=r.data[e],d=h.y,u=Va(o,c,{fontSize:12},"px"),g=3;let p;Math.abs(h.x-a)<u?p=l<0?a-u/2-g:a+u/2+g:(p=l<0?h.x+h.width/2:h.x-h.width/2,p=Math.min(p,s),p=Math.max(p,i)),n[d]||(n[d]=[]);for(const e of n[d])Math.abs(e-p)<u&&(p=l<0?e-u-g:e+u+g);n[d].push(p),o.fillStyle=h.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",SC(c,p,d,o)}}}const yC={showHeaders:!0,headerDesign:{align:"center",fillColor:"#808080",bold:!0,fontSize:15},showValues:!0,showLabels:!0,valuesDesign:{align:"left",verticalAlign:"bottom",fontSize:12},coloringOptions:{type:"categoryColor",colors:[],useValueBasedGradient:!0}},wC="nullValue";function IC(e,t){const{dataSetsValues:o}=t,s=[],i=BC(e,o.length),n=[];for(const r in o){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=i.next(),d={label:a,data:l,hidden:c,borderColor:e.background||m,borderWidth:e.stacked?1:0,backgroundColor:h,yAxisID:e.horizontal?"y":e.dataSets?.[r].yAxisId||"y",xAxisID:"x"};s.push(d);const u=e.dataSets?.[r].trend,g=t.trendDataSetsValues?.[r];u?.display&&!e.horizontal&&g&&n.push(HC(d,u,g))}return s.push(...n),s}function xC(e,t){const{dataSetsValues:o,labels:s}=t,i=e.negativeValuesColor||A,n=e.positiveValuesColor||T,r=e.subTotalValuesColor||D,a=[],l=[],c={label:"",data:l,backgroundColor:a},h=[];let d=0;for(const t of o)if(!t.hidden){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(Ho("Subtotal")),l.push([0,d]),a.push(r))}return{datasets:[c],labels:h}}function EC(e,t){const{dataSetsValues:o,axisType:s,labels:i}=t,n=[],r=!!e.fillArea,a=!!e.stacked,l=[],c=BC(e,o.length);for(let h=0;h<o.length;h++){let{label:d,data:u,hidden:g}=o[h];d=e.dataSets?.[h].label||d;const p=c.next();s&&["linear","time"].includes(s)&&(u=u.map(((e,t)=>({x:i[t]||void 0,y:e}))));const m={label:d,data:u,hidden:g,tension:0,borderColor:p,backgroundColor:r?oo(p,Re):p,pointBackgroundColor:p,fill:!!r&&UC(h,a),pointRadius:e.hideDataMarkers?0:Te,yAxisID:e.dataSets?.[h].yAxisId||"y"};n.push(m);const f=e.dataSets?.[h].trend,v=t.trendDataSetsValues?.[h];f?.display&&v&&l.push(HC(m,f,v))}return n.push(...l),n}function RC(e,t){const o=EC(e,t);for(const e of o)vC(e.xAxisID)||(e.showLine=!1);return o}function TC(e,t){const{dataSetsValues:o}=t,s=[],i=Math.max(0,...o.map((e=>e?.data?.length??0))),n=mC(new fo(i),o);for(const{label:t,data:i,hidden:r}of o){if(r)continue;const o={label:t,data:i,borderColor:e.background||"#FFFFFF",backgroundColor:n,hoverOffset:10};s.push(o)}return s}function AC(e,t){const{dataSetsValues:o}=t,s=[],i=BC(e,o.length),n=[];for(let r=0;r<o.length;r++){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=e.dataSets?.[r],d=i.next(),u=h?.type??"line",g={label:a,data:l,hidden:c,borderColor:d,backgroundColor:d,yAxisID:e.dataSets?.[r].yAxisId||"y",xAxisID:"x",type:u,order:"bar"===u?o.length+r:r,pointRadius:e.hideDataMarkers?0:Te};s.push(g);const p=e.dataSets?.[r].trend,m=t.trendDataSetsValues?.[r];p?.display&&m&&n.push(HC(g,p,m))}return s.push(...n),s}function DC(e,t){const{dataSetsValues:o}=t,s=[],i=e.fillArea??!1,n=BC(e,o.length);for(let t=0;t<o.length;t++){let{label:r,data:a,hidden:l}=o[t];e.dataSets?.[t]?.label&&(r=e.dataSets[t].label);const c=n.next(),h={label:r,data:a,hidden:l,borderColor:c,backgroundColor:c,pointRadius:e.hideDataMarkers?0:Te};i&&(h.backgroundColor=oo(c,Re),h.fill="start"),s.push(h)}return s}function _C(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 OC(e,t){const o=t.dataSetsValues[0],s=t.labels;if(!o)return[];let{label:i,data:n}=o;i=e.dataSets?.[0].label||i;return[{label:i,data:n.map((e=>e<=0?[0,0]:[-e,e])),backgroundColor:FC(s,e.funnelColors),yAxisID:"y",xAxisID:"x",barPercentage:1,categoryPercentage:1,borderColor:e.background||m,borderWidth:3}]}function FC(e,t){const o=new fo(e.length,t);return e.map((()=>o.next()))}function PC(e,t){const{dataSetsValues:o,labels:s}=t,i=kC(MC(o,s)),n=i[0]||[],r=new fo(n.length,e.groupColors||[]),a=n.map((e=>({label:e.label,color:r.next()}))),l=[];for(let t=i.length-1;t>=0;t--){const o={groupColors:a,parsing:{key:"value"},data:i[t],borderColor:t=>{const o="data"===t.type?t.raw:void 0;return o&&o.label!==wC?e.background||m:R},backgroundColor:e=>{const t="data"===e.type?e.raw:void 0;if(!t||t.label===wC)return R;const o=t.groups[0];return a.find((e=>e.label===o))?.color},hoverOffset:10};l.push(o)}return l}function MC(e,t){const o=function(e,t){const o=[],s=Math.max(...e.map((e=>e.data.length)));for(let i=0;i<s;i++){o[i]={};for(let t=0;t<e.length;t++){const s=null===e[t].data[i]?wC:String(e[t].data[i]);o[i][t]=s}o[i].value=Number(t[i])}return o}(e,t);return NC(o,0,e.length,[])}function NC(e,t,o,s){if(t>=o)return[];const i=Object.groupBy(e,(e=>e[t]));return Object.keys(i).map((e=>{const n=i[e]?.reduce(((e,t)=>e+Number(t.value)),0)||0,r=[...s,e];return{label:e,value:n,children:NC(i[e]||[],t+1,o,[...s,e]),groups:r,depth:t}})).sort(((e,t)=>t.value-e.value))}function kC(e){const t=[],o=[...e];for(;o.length>0;){const e=o.shift();e&&(t[e.depth]||(t[e.depth]=[]),t[e.depth].push(e),e.children&&o.push(...e.children))}return t}function VC(e,t){const{dataSetsValues:o,labels:s,locale:i,axisFormats:n}=t,r={locale:i,format:n?.y};if(0===o.length)return[];const a=MC(o,s).sort(((e,t)=>t.value-e.value)),l=function(e,t){const o="categoryColor"===e.coloringOptions?.type?e.coloringOptions.colors:[],s=new fo(t.length,o);return t.map((e=>({label:e.label,color:s.next()})))}(e,a),c=[],h=Math.max(...o.map((e=>e.data.length)));for(let e=0;e<h;e++){c[e]={};for(let t=0;t<o.length;t++)c[e][t]=o[t].data[e]?String(o[t].data[e]):void 0;c[e].value=Number(s[e])}const d=e.showLabels??yC.showLabels,u=e.showValues??yC.showValues,g=e.coloringOptions||yC.coloringOptions;let p;"colorScale"===g?.type&&(p=function(e,t){const o=kC(e),s=o[o.length-1],i=Math.min(...s.map((e=>e.value))),n=Math.max(...s.map((e=>e.value)));if(Number.isFinite(i)&&Number.isFinite(n)){const e=[{value:i,color:t.minColor}];if(t.midColor){const o=(i+n)/2;e.push({value:o,color:t.midColor})}return e.push({value:n,color:t.maxColor}),So(e)}return}(a,g));const m=[{data:[],tree:c,labels:{display:d||u,overflow:"hidden",...LC(e.valuesDesign,yC.valuesDesign),formatter:e=>[d?e.raw.g:void 0,u?In(e.raw.v,r):void 0].filter(lt)},captions:{display:e.showHeaders??yC.showHeaders,padding:6,...LC(e.headerDesign,yC.headerDesign)},key:"value",groups:je(0,o.length).map((e=>String(e))),borderWidth:0,spacing:1,displayMode:"headerBoxes",groupColors:l,backgroundColor:t=>{if("data"!==t.type)return"transparent";if(!t.raw.isLeaf)return e.headerDesign?.fillColor||yC.headerDesign?.fillColor;if("colorScale"===g.type)return p?.(t.raw.v)||"#FF0000";if("categoryColor"===g.type)return function(e,t,o,s){const i=e.raw._data.children[0][0],n=s.find((e=>e.label===i))?.color;if(!n||!o.useValueBasedGradient)return n||"#FF0000";const r=t.find((e=>e.label===i));if(!r||!r.children.length)return n;const a=kC(r.children),l=a[a.length-1],c=Math.max(...l.map((e=>e.value))),h=Math.min(...l.map((e=>e.value)));if(h===c||!isFinite(h)||!isFinite(c))return n;const d=Number(e.raw.v)||0,u=(d-c)/(h-c)*.5;return so(n,u)}(t,a,g,l);throw new Error("Unsupported coloring option type}")}}];return m}function LC(e,t){const o=e=>jt(e.element.options.backgroundColor)>.7?"#666666":"#FFFFFF";return{align:e?.align??t?.align,position:e?.verticalAlign??t?.verticalAlign,color:e?.color||o,hoverColor:e?.color||o,font:{weight:e?.bold??t?.bold?"bold":"normal",style:e?.italic??t?.italic?"italic":"normal",size:e?.fontSize??t?.fontSize}}}function HC(e,t,o){const s=Xt(e.backgroundColor);s.a=1;const i=t.color||so(Yt(s),.5);return{type:"line",xAxisID:"trailingMovingAverage"===t.type?YS:jS,yAxisID:e.yAxisID,label:e.label?Ho("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 UC(e,t){return t?0===e?"origin":"-1":"origin"}function BC(e,t){return new fo(t,e.dataSets?.map((e=>e.backgroundColor))||[])}const zC={id:"sunburstHoverPlugin",afterEvent(e,t,o){if(!o.enabled)return;const s=e.getActiveElements();let i=s.map((e=>({datasetIndex:e.datasetIndex,index:e.index})));for(const t of s){const o=e.data.datasets[t.datasetIndex].data[t.index];for(let t=0;t<e.data.datasets.length;t++){const s=e.data.datasets[t];for(let e=0;e<s.data.length;e++){const n=s.data[e];$C(o.groups,n.groups)&&i.push({datasetIndex:t,index:e})}}}i=i.filter((t=>{const{datasetIndex:o,index:s}=t;return e.data.datasets[o].data[s].label!==wC})),e.setActiveElements(i);for(const t of e.getSortedVisibleDatasetMetas())for(const e of t.data){const t=e.$context,{datasetIndex:o,index:s,dataset:n,raw:r}=t;if(r.label===wC)continue;const a="function"==typeof n.backgroundColor?n.backgroundColor(t):n.backgroundColor;i.length&&!i.some((e=>e.datasetIndex===o&&e.index===s))?e.options.backgroundColor=so(a,.5):e.options.backgroundColor=a}}};function $C(e,t){return t.length>e.length&&e.every(((e,o)=>e===t[o]))}const GC={id:"sunburstLabelsPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues&&!o.showLabels||"doughnut"!==e.config.type)return;!function(e,t,o){const s=t.style,i=s.fontSize||13,n=i+3;for(const r of e._metasets)for(let a=0;a<r._dataset.data.length;a++){const l=r._dataset.data[a];if(l.label===wC)continue;const c=[t.showLabels?l.label:void 0,t.showValues?t.callback(l.value,"y"):void 0].filter(lt),h=r.data[a];let{startAngle:d,endAngle:u,innerRadius:g,outerRadius:p,circumference:m}=h;const f=h.options.offset/4,v=f*(1-Math.sin(Math.min(Math.PI,m||0)));g+=v,p+=v;const b=(d+u)/2,S=(g+p)/2,C=.9*(p-g),y=u-d;if((y>=Math.PI?p:Math.sin(y/2)*g*2)<c.length*n)continue;o.save();const w={x:Math.cos(b)*f,y:Math.sin(b)*f},I=e.chartArea.left+e.chartArea.width/2+w.x,x=e.chartArea.top+e.chartArea.height/2+w.y;let E;o.translate(I,x),b>Math.PI/2?(o.rotate(b-Math.PI),E=-S):(E=S,o.rotate(b));const R=jt(h.options.backgroundColor)>.7?"#666666":"#FFFFFF";o.fillStyle=s.textColor||R,o.textAlign="center",o.textBaseline="middle",o.font=Na(i,s.bold,s.italic);const T=-(c.length-1)*n/2;for(let e=0;e<c.length;e++){const t=Xa(o,C,c[e],s,"px");o.fillText(t,E,T+e*n)}o.restore()}}(e,o,e.ctx)}};const WC={id:"waterfallLinesPlugin",beforeDraw(e,t,o){if(!o.showConnectorLines)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;i.save(),i.setLineDash([3,2]);for(let e=0;e<s.length;e++){const t=s[e];if(0===t.height)continue;const o=ZC(s,e);if(!o)break;const n=qC(t),r=qC(o),a=t.$context.raw,l=a[1]-a[0],c=Math.round(l<0?n.bottom-1:n.top),h=Math.round(n.right),d=Math.round(r.left);i.strokeStyle="#999",i.beginPath(),i.moveTo(h+1,c+.5),i.lineTo(d,c+.5),i.stroke()}i.restore()}};function qC(e){const t=e.base<e.y;return{left:e.x-e.width/2,right:e.x+e.width/2,bottom:t?e.base+e.height:e.y+e.height,top:t?e.base:e.y}}function ZC(e,t){return e.find(((e,o)=>o>t&&0!==e.height))}yh`
|
|
1
|
+
!function(e,t){"use strict";function o(e){return e.map(i).sort(((e,t)=>e.sequence-t.sequence))}let s=1;function i(e){const t=e.name,o=e.children,n=e.description,r=e.icon,a=e.secondaryIcon,l=e.id||s++,c=e.isEnabled?e.isEnabled:()=>!0;return{id:l.toString(),name:"function"==typeof t?t:()=>t,isVisible:e.isVisible?e.isVisible:()=>!0,isEnabled:c,isActive:e.isActive,execute:e.execute?(t,o)=>{if(c(t))return e.execute(t,o)}:void 0,children:o?e=>o.map((t=>"function"==typeof t?t(e):t)).flat().map(i):()=>[],isReadonlyAllowed:e.isReadonlyAllowed||!1,separator:e.separator||!1,icon:"function"==typeof r?r:()=>r||"",iconColor:e.iconColor,secondaryIcon:"function"==typeof a?a:()=>a||"",description:"function"==typeof n?n:()=>n||"",textColor:e.textColor,sequence:e.sequence||0,onStartHover:e.onStartHover,onStopHover:e.onStopHover}}class n{content={};add(e,t){if(e in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){return this.content[e]=t,this}get(e){const t=this.content[e];if(!t&&!(e in this.content))throw new Error(`Cannot find ${e} in this registry!`);return t}contains(e){return e in this.content}getAll(){return Object.values(this.content)}getKeys(){return Object.keys(this.content)}remove(e){delete this.content[e]}}const r=.5,a="#017E84",l="#f5f5f5",c="#F8F9FA",h="#E8EAED",d="#595959",u="#666666",g="#c9ccd2",p="#3266ca",m="#FFFFFF",f="#CACACA",v=11982760,b=a,S="#188038",C="#E0E2E4",y="#4A4F59",w="#999",I="#E2E3E3",x="#BCBCBC",E="#9B359B",R="#00000000",T="#4EA7F2",A="#EA6175",D="#AAAAAA",_="#111827",O="#D8DADD",F="#E7E9ED",P="#F9FAFB",M="#374151",N=M+"C2",k="#111827",V="#714B67",L=F,H=O,U="#111827",B="#e6f2f3",z="#111827",$=a,G="#D44C591A",W="#C34A41",q="#98DBE2",Z="#E6F2F3",j=20,Y=10,X=15,K=16,J=12,Q="#F28C28",ee=["#000000","#434343","#666666","#999999","#B7B7B7","#CCCCCC","#D9D9D9","#EFEFEF","#F3F3F3","#FFFFFF","#980000","#FF0000","#FF9900","#FFFF00","#00FF00","#00FFFF","#4A86E8","#0000FF","#9900FF","#FF00FF","#E6B8AF","#F4CCCC","#FCE5CD","#FFF2CC","#D9EAD3","#D0E0E3","#C9DAF8","#CFE2F3","#D9D2E9","#EAD1DC","#DD7E6B","#EA9999","#F9CB9C","#FFE599","#B6D7A8","#A2C4C9","#A4C2F4","#9FC5E8","#B4A7D6","#D5A6BD","#CC4125","#E06666","#F6B26B","#FFD966","#93C47D","#76A5AF","#6D9EEB","#6FA8DC","#8E7CC3","#C27BA0","#A61C00","#CC0000","#E69138","#F1C232","#6AA84F","#45818E","#3C78D8","#3D85C6","#674EA7","#A64D79","#85200C","#990000","#B45F06","#BF9000","#38761D","#134F5C","#1155CC","#0B5394","#351C75","#741B47","#5B0F00","#660000","#783F04","#7F6000","#274E13","#0C343D","#1C4587","#073763","#20124D","#4C1130"],te=26,oe=48,se=96,ie=23,ne=15,re=4,ae=3,le=re,ce=21,he=2*ie,de={align:"left",verticalAlign:"bottom",wrapping:"overflow",bold:!1,italic:!1,strikethrough:!1,underline:!1,fontSize:10,fillColor:"",textColor:""},ue=de.verticalAlign,ge=de.wrapping,pe="400",me=de.fontSize,fe="'Roboto', arial",ve="thin",be="#000000",Se="START_REVISION",Ce=1,ye=20,we="??",Ie="difference",xe="#43C5B1",Ee="#EA6175",Re=.4,Te=3,Ae=2,De=["'","*","?","/","\\","[","]"],_e=/'|\*|\?|\/|\\|\[|\]/,Oe="|";var Fe;!function(e){e[e.Grid=0]="Grid",e[e.Highlight=5]="Highlight",e[e.HeaderGroupingButton=6]="HeaderGroupingButton",e[e.Figure=10]="Figure",e[e.ScrollBar=15]="ScrollBar",e[e.GridPopover=19]="GridPopover",e[e.GridComposer=20]="GridComposer",e[e.IconPicker=25]="IconPicker",e[e.TopBarComposer=30]="TopBarComposer",e[e.Popover=35]="Popover",e[e.FigureAnchor=1e3]="FigureAnchor",e[e.FigureSnapLine=1001]="FigureSnapLine",e[e.FigureTooltip=1002]="FigureTooltip"}(Fe||(Fe={}));let Pe=0;function Me(){return Pe}const Ne="\n",ke=[6,7,8,9,10,11,12,14,18,24,36],Ve={hasFilters:!1,totalRow:!1,firstColumn:!0,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,styleId:"TableStyleMedium5",automaticAutofill:!1},Le={symbol:"$",position:"before",decimalPlaces:2,code:"",name:"Dollar"},He=new RegExp(_e,"g");function Ue(e){return'"'===e[0]&&(e=e.slice(1)),'"'===e[e.length-1]&&"\\"!==e[e.length-2]?e.slice(0,e.length-1):e}function Be(e){return e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}function ze(e){switch(typeof e){case"object":{if(null===e)return e;if(function(e){return"clone"in e&&e.clone instanceof Function}(e))return e.clone();if(!(function(e){return"object"==typeof e&&null!==e&&(e?.constructor===Object||void 0===e?.constructor)}(e)||e instanceof Array))throw new Error("Unsupported type: only objects and arrays are supported");const t=Array.isArray(e)?new Array(e.length):{};if(Array.isArray(e))for(let o=0,s=e.length;o<s;o++)o in e&&(t[o]=ze(e[o]));else for(const o in e)t[o]=ze(e[o]);return t}case"number":case"string":case"boolean":case"function":case"undefined":return e;default:throw new Error("Unsupported type: "+typeof e)}}function $e(e){return Ge(e,"'")}function Ge(e,t='"'){return e.startsWith(t)&&(e=e.slice(1)),e.endsWith(t)&&(e=e.slice(0,-1)),e}function We(e){return e.match(/\w/g)?.length!==e.length&&(e=`'${e}'`),e}function qe(e,t=" "){return e.replace(He,t)}function Ze(e,t,o){return e<t?t:e>o?o:e}function je(e,t,o=1){if(t<=e&&o>0)return[];if(0===o)throw new Error("range() step must not be zero");const s=Math.ceil(Math.abs((t-e)/o)),i=Array(s);for(let t=0;t<s;t++)i[t]=e+t*o;return i}function Ye(e){return e.reduce(((e,t,o,s)=>{if(1===Math.abs(t-s[o-1])){e[e.length-1].push(t)}else e.push([t]);return e}),[])}function*Xe(e,t){t.next();for(const o of e){const e=t.next();yield{...o,next:e.done?void 0:e.value}}}function Ke(e){const t=e.toUpperCase();return"TRUE"===t||"FALSE"===t}const Je=/^\[(.+)\]\((.+)\)$/,Qe=/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)$/;function et(e){return Je.test(e)}function tt(e){return Qe.test(e)}function ot(e,t){return`[${e}](${t})`}function st(e){const t=e.match(Je)||[],o=t[1],s=t[2];if(!o||!s)throw new Error(`Could not parse markdown link ${e}.`);return{label:o,url:s}}const it="o-spreadsheet://";function nt(e){return e.startsWith(it)}function rt(e){return`${it}${e}`}function at(e){if(e.startsWith(it))return e.slice(it.length);throw new Error(`${e} is not a valid sheet link`)}function lt(e){return void 0!==e}function ct(e){return void 0===e||Object.values(e).every((e=>"object"==typeof e?ct(e):!e))}function ht(e,t,o){let s;const i=function(){const i=this,n=Array.from(arguments);const r=o&&!s;clearTimeout(s),s=setTimeout((function(){s=void 0,o||e.apply(i,n)}),t),r&&e.apply(i,n)};return i.isDebouncePending=()=>void 0!==s,i.stopDebounce=()=>{clearTimeout(s)},i}function dt(e){let t="";for(let o=0,s=e.length;o<s;o++)t+=e[o];return t}function ut(e){let t,o=!1;const s=()=>(o||(t=e instanceof Function?e():e,o=!0),t);return s.map=e=>ut((()=>e(s()))),s}function gt(e,t){let o=e.slice(t).find((e=>e));return o||(o=e.slice(0,t).reverse().find((e=>e))),o||""}function pt(e,t){return"after"===e?t+1:t}function mt(e,t){if(e===t)return!0;if(e&&!t||t&&!e)return!1;if(typeof e!=typeof t)return!1;if("object"!=typeof e)return!1;for(const o in t)if(!(o in e)&&void 0!==t[o])return!1;for(const o in e){if(typeof e[o]!=typeof t[o])return!1;if("object"==typeof e[o]){if(!mt(e[o],t[o]))return!1}else if(e[o]!==t[o])return!1}return!0}function ft(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++)if(!mt(e[o],t[o]))return!1;return!0}function vt(e,t){if(e.length<t.length)return!1;const o=new Set(e);return t.every((e=>o.has(e)))}function bt(e){if(!e)return e;const t={...e};return Object.keys(t).forEach((e=>!t[e]&&delete t[e])),t}const St=["\t","\f","\v",String.fromCharCode(parseInt("00a0",16)),String.fromCharCode(parseInt("1680",16)),String.fromCharCode(parseInt("2000",16)),String.fromCharCode(parseInt("200a",16)),String.fromCharCode(parseInt("2028",16)),String.fromCharCode(parseInt("2029",16)),String.fromCharCode(parseInt("202f",16)),String.fromCharCode(parseInt("205f",16)),String.fromCharCode(parseInt("3000",16)),String.fromCharCode(parseInt("feff",16))],Ct=new RegExp(St.join("|"),"g"),yt=/(\r\n|\r)/g,wt=St.concat([" "]);function It(e){return e?e.replace(yt,Ne):""}function xt(e){const t=Array.from(e).sort(((e,t)=>e-t));for(let e=1;e<t.length;e++)if(t[e]-t[e-1]!=1)return!1;return!0}function Et(e){const t=new Map,o=e.name?e.name+" (memoized)":"memoized";return{[o]:(...o)=>(t.has(o[0])||t.set(o[0],e(...o)),t.get(o[0]))}[o]}function Rt(e,t){const o=new Set(t),s=[];for(let t=0;t<e.length;t++)o.has(t)||s.push(e[t]);return s}function Tt(e,t,o){return e.slice(0,o).concat(t).concat(e.slice(o))}function At(e,t,o){const s=[...e];return s[o]=t,s}function Dt(e){return e.split("\n").map((e=>e.replace(/\s+/g," ").trim())).join("\n")}function _t(e,t,o){return t>o?_t(e,o,t):e>=t&&e<=o}function Ot(e,t){let o=Be(e);const s=t.matchCase?"":"i";return t.exactMatch&&(o=`^${o}$`),RegExp(o,s)}function Ft(e){let t=e.length;if(t<1e5)return Math.max(...e);let o=-1/0;for(;t--;)o=e[t]>o?e[t]:o;return o}function Pt(e){let t=e.length;if(t<1e5)return Math.min(...e);let o=1/0;for(;t--;)o=e[t]<o?e[t]:o;return o}class Mt{text;currentIndex=0;current;constructor(e){this.text=e,this.current=e[0]}shift(){const e=this.current,t=this.text[++this.currentIndex];return this.current=t,e}advanceBy(e){this.currentIndex+=e,this.current=this.text[this.currentIndex]}isOver(){return this.currentIndex>=this.text.length}remaining(){return this.text.substring(this.currentIndex)}currentStartsWith(e){if(this.current!==e[0])return!1;for(let t=1;t<e.length;t++)if(this.text[this.currentIndex+t]!==e[t])return!1;return!0}}function Nt(e,t=(e=>e)){const o=new Set;return e.filter((e=>{const s=t(e);return!o.has(s)&&(o.add(s),!0)}))}function kt(e){const t={};for(const o in e)for(const s in e[o])t[s]||(t[s]={}),t[s][o]=e[o][s];return t}function Vt(e,t,o={}){const s=o.compute??((e,t)=>`${e} (${t})`),i=o.computeFirstOne??!1;let n=o.start??1,r=i?s(e,n):e;for(;t.includes(r);)r=s(e,n++);return r}function Lt(e){return e.startsWith("=")||e.startsWith("+")}const Ht=/rgba?\(|\s+|\)/gi,Ut=/^#([A-F\d]{2}){3,4}$/,Bt=["#eb6d00","#0074d9","#ad8e00","#169ed4","#b10dc9","#00a82d","#00a3a3","#f012be","#3d9970","#111111","#62A300","#ff4136","#949494","#85144b","#001f3f"];function zt(e,t=1){const o=1!==t?Math.round(255*t).toString(16).padStart(2,"0"):"";return Gt(e.toString(16).padStart(6,"0"))+o}function $t(e){return"number"==typeof e?e:Number.parseInt(Gt(e).slice(1,7),16)}function Gt(e){let t=e;if(e.startsWith("rgb")?t=function(e){const t=e.replace(Ht,"").split(",");let o=255;if(3!==t.length&&4!==t.length)throw new Error("invalid color");if(4===t.length){const e=parseFloat(t.pop()||"1");if(isNaN(e))throw new Error("invalid alpha value");o=Math.round(255*e)}const s=t.map((e=>parseInt(e,10)));255!==o&&s.push(o);return"#"+dt(s.map((e=>e.toString(16).padStart(2,"0")))).toUpperCase()}(e):(t=e.replace("#","").toUpperCase(),3!==t.length&&4!==t.length||(t=t.split("").reduce(((e,t)=>e+t+t),"")),t=`#${t}`),!Ut.test(t))throw new Error(`invalid color input: ${e}`);return t}function Wt(e){try{return Gt(e),!0}catch(e){return!1}}const qt=e=>e>=0&&e<=255;function Zt(e,t,o,s=1){if(!qt(e)||!qt(t)||!qt(o)||s<0||s>1)throw new Error(`Invalid RGBA values ${[e,t,o,s]}`);return{a:s,b:o,g:t,r:e}}function jt(e){let{r:t,g:o,b:s}=Xt(e);t/=255,o/=255,s/=255;const i=e=>e<=.03928?e/12.92:((e+.055)/1.055)**2.4;return.2126*i(t)+.7152*i(o)+.0722*i(s)}function Yt(e){let t=e.r.toString(16),o=e.g.toString(16),s=e.b.toString(16),i=Math.round(255*e.a).toString(16);return 1===t.length&&(t="0"+t),1===o.length&&(o="0"+o),1===s.length&&(s="0"+s),1===i.length&&(i="0"+i),"ff"===i&&(i=""),("#"+t+o+s+i).toUpperCase()}function Xt(e){let t,o,s,i;if(7===(e=Gt(e)).length)t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=255;else{if(9!==e.length)throw new Error("Invalid color");t=parseInt(e[1]+e[2],16),o=parseInt(e[3]+e[4],16),s=parseInt(e[5]+e[6],16),i=parseInt(e[7]+e[8],16)}return i=+(i/255).toFixed(3),{a:i,r:t,g:o,b:s}}function Kt(e){(e={...e}).s/=100,e.l/=100;const t=(1-Math.abs(2*e.l-1))*e.s,o=t*(1-Math.abs(e.h/60%2-1)),s=e.l-t/2;let i=0,n=0,r=0;return 0<=e.h&&e.h<60?(i=t,n=o,r=0):60<=e.h&&e.h<120?(i=o,n=t,r=0):120<=e.h&&e.h<180?(i=0,n=t,r=o):180<=e.h&&e.h<240?(i=0,n=o,r=t):240<=e.h&&e.h<300?(i=o,n=0,r=t):300<=e.h&&e.h<360&&(i=t,n=0,r=o),i=Math.round(255*(i+s)),n=Math.round(255*(n+s)),r=Math.round(255*(r+s)),{a:e.a,r:i,g:n,b:r}}function Jt(e){const t=e.r/255,o=e.g/255,s=e.b/255,i=Math.min(t,o,s),n=Math.max(t,o,s),r=n-i;let a=0,l=0,c=0;return a=0===r?0:n===t?(o-s)/r%6:n===o?(s-t)/r+2:(t-o)/r+4,a=Math.round(60*a),a<0&&(a+=360),c=(n+i)/2,l=0===r?0:r/(1-Math.abs(2*c-1)),l=+(100*l).toFixed(1),c=+(100*c).toFixed(1),{a:e.a,h:a,s:l,l:c}}function Qt(e){return Yt(Kt(e))}function eo(e){return Jt(Xt(e))}function to(e){return Xt("number"==typeof e?zt(e):e)}function oo(e,t){return 1===t?Gt(e).slice(0,7):Yt({...Xt(e),a:t})}function so(e,t){const o=eo(e);return 1===t?"#fff":(o.l=t*(100-o.l)+o.l,Qt(o))}function io(e,t){const o=eo(e);return 1===t?"#000":(o.s=Math.min(100,t*o.s+o.s),o.l=o.l-t*o.l,Qt(o))}function no(e){return jt(e)<.6?so(e,.9):io(e,.75)}const ro=["#4EA7F2","#EA6175","#43C5B1","#F4A261","#8481DD","#FFD86D"],ao=["#4EA7F2","#3188E6","#43C5B1","#00A78D","#EA6175","#CE4257","#F4A261","#F48935","#8481DD","#5752D1","#FFD86D","#FFBC2C"],lo=["#4EA7F2","#3188E6","#056BD9","#A76DBC","#7F4295","#6D2387","#EA6175","#CE4257","#982738","#43C5B1","#00A78D","#0E8270","#F4A261","#F48935","#BE5D10","#8481DD","#5752D1","#3A3580","#A4A8B6","#7E8290","#545B70","#FFD86D","#FFBC2C","#C08A16"],co=["#4EA7F2","#3188E6","#056BD9","#155193","#A76DBC","#7F4295","#6D2387","#4F1565","#EA6175","#CE4257","#982738","#791B29","#43C5B1","#00A78D","#0E8270","#105F53","#F4A261","#F48935","#BE5D10","#7D380D","#8481DD","#5752D1","#3A3580","#26235F","#A4A8B6","#7E8290","#545B70","#3F4250","#FFD86D","#FFBC2C","#C08A16","#936A12"],ho=["#4EA7F2","#43C5B1","#EA6175","#F4A261","#8481DD","#FFD86D","#3188E6","#00A78D","#CE4257","#F48935","#5752D1","#FFBC2C"],uo=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16"],go=["#4EA7F2","#A76DBC","#EA6175","#43C5B1","#F4A261","#8481DD","#A4A8B6","#FFD86D","#3188E6","#7F4295","#CE4257","#00A78D","#F48935","#5752D1","#7E8290","#FFBC2C","#056BD9","#6D2387","#982738","#0E8270","#BE5D10","#3A3580","#545B70","#C08A16","#155193","#4F1565","#791B29","#105F53","#7D380D","#26235F","#3F4250","#936A12"];function po(e,t){return t[e%t.length]}function mo(e){return e<=6?ro:e<=12?ao:e<=24?lo:co}class fo{preferredColors;currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=mo(e).filter((e=>!t.includes(e)))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:po(this.currentColorIndex++,this.palette)}}class vo extends fo{constructor(e,t=[]){var o;super(e,t),this.palette=(o=e,o<=6?ro:o<=12?ho:o<=24?uo:go).filter((e=>!t.includes(e)))}}class bo{availableColors;colors={};constructor(e=12){this.availableColors=new vo(e)}get(e){return this.colors[e]||(this.colors[e]=this.availableColors.next()),this.colors[e]}}function So(e){if(e.length<2)throw new Error("Color scale must have at least 2 points");const t=[...e.sort(((e,t)=>e.value-t.value))],o=[];for(let e=1;e<t.length;e++){const s=to(t[e-1].color).a,i=to(t[e].color).a,n=$t(t[e-1].color),r=$t(t[e].color);o.push({min:t[e-1].value,max:t[e].value,minColor:n,maxColor:r,minColorAlpha:s,maxColorAlpha:i,colorDiff:Co(t[e-1].value,t[e].value,n,r)})}return e=>{if(e<o[0].min)return zt(o[0].minColor,o[0].minColorAlpha);for(const t of o)if(e>=t.min&&e<=t.max)return zt(yo(e,t.min,t.minColor,t.colorDiff),t.maxColorAlpha);return zt(o[o.length-1].maxColor,o[o.length-1].maxColorAlpha)}}function Co(e,t,o,s){const i=t-e;return[((o>>16)%256-(s>>16)%256)/i,((o>>8)%256-(s>>8)%256)/i,(o%256-s%256)/i]}function yo(e,t,o,s){const[i,n,r]=s;return Math.round((o>>16)%256-i*(e-t))<<16|Math.round((o>>8)%256-n*(e-t))<<8|Math.round(o%256-r*(e-t))}function wo(e){if(e<0)throw new Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):wo(Math.floor(e/26)-1)+wo(e%26)}function Io(e){let t=0;const o=e.length;for(let s=0;s<o;s++){t=26*t+xo(e[s])}return t-1}function xo(e){const t=e.charCodeAt(0);return t>=65&&t<=90?t-64:t-96}function Eo(e){return e>="A"&&e<="Z"||e>="a"&&e<="z"}function Ro(e){return e>="0"&&e<="9"}const To=Io("ZZZ"),Ao=9999998;function Do(e){for(;" "===e.current;)e.advanceBy(1)}function _o(e){if("$"===e.current&&e.advanceBy(1),!e.current||!Eo(e.current))return-1;let t=0;for(;e.current&&Eo(e.current);)t=26*t+xo(e.shift());return t}function Oo(e){if("$"===e.current&&e.advanceBy(1),!e.current||!Ro(e.current))return-1;let t=0;for(;e.current&&Ro(e.current);)t=10*t+Number(e.shift());return t}function Fo(e){const t=new Mt(e);Do(t);const o=_o(t);if(-1===o||!t.current)throw new Error(`Invalid cell description: ${e}`);const s=Oo(t);Do(t);const i=o-1,n=s-1;if(!t.isOver()||i>To||n>Ao)throw new Error(`Invalid cell description: ${e}`);return{col:i,row:n}}function Po(e,t,o={colFixed:!1,rowFixed:!1}){return(o.colFixed?"$":"")+wo(e)+(o.rowFixed?"$":"")+String(t+1)}const Mo=e=>e,No=()=>!1;let ko=Mo,Vo=No;function Lo(e,...t){if(1!==t.length||"object"!=typeof t[0]||t[0]instanceof String)t.length>0&&(e=e.replace(/\%s/g,(()=>t.shift())));else{const o=t[0];e=e.replace(/\%\(([^\)]+)\)s/g,((e,t)=>o[t]))}return e}const Ho=function(e,...t){return Vo()?Lo(ko(e),...t):new Uo(e,t)};class Uo extends String{values;constructor(e,t){super(e),this.values=t}valueOf(){const e=super.valueOf();return Vo()?Lo(ko(e),...this.values):Lo(e,...this.values)}toString(){return this.valueOf()}}function Bo(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}const zo=new n;function $o(e,t){return{url:e=Bo(e),label:t||e,isExternal:!0,isUrlEditable:!0}}zo.add("sheet_URL",{match:e=>nt(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){const o=at(e);return t.tryGetSheetName(o)||Ho("Invalid sheet")},open(e,t){const o=at(e);t.model.dispatch("ACTIVATE_SHEET",{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:o}).isCancelledBecause("SheetIsHidden")&&t.notifyUser({type:"warning",sticky:!1,text:Ho("Cannot open the link because the linked sheet is hidden.")})},sequence:0});const Go={createLink:$o,match:e=>tt(e),open:e=>window.open(e,"_blank"),urlRepresentation:e=>e,sequence:0};function Wo(e){return zo.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((t=>t.match(e)))||Go}function qo(e,t){return Wo(e.url).urlRepresentation(e.url,t)}function Zo(e,t,o){Wo(e.url).open(e.url,t,o)}function jo(e){if("string"==typeof e){if(et(e)){const{label:t,url:o}=st(e);return Wo(o).createLink(o,t)}return tt(e)?$o(e):void 0}}class Yo{jsDate;constructor(e,t,o,s=0,i=0,n=0){this.jsDate=new Date(Date.UTC(e,t,o,s,i,n,0))}static fromTimestamp(e){const t=new Date(e);return new Yo(t.getUTCFullYear(),t.getUTCMonth(),t.getUTCDate(),t.getUTCHours(),t.getUTCMinutes(),t.getUTCSeconds())}static now(){const e=new Date;return new Yo(e.getFullYear(),e.getMonth(),e.getDate(),e.getHours(),e.getMinutes(),e.getSeconds())}toString(){return this.jsDate.toString()}toLocaleDateString(){return this.jsDate.toLocaleDateString()}getTime(){return this.jsDate.getTime()}getFullYear(){return this.jsDate.getUTCFullYear()}getMonth(){return this.jsDate.getUTCMonth()}getQuarter(){return Math.floor(this.getMonth()/3)+1}getDate(){return this.jsDate.getUTCDate()}getDay(){return this.jsDate.getUTCDay()}getHours(){return this.jsDate.getUTCHours()}getMinutes(){return this.jsDate.getUTCMinutes()}getSeconds(){return this.jsDate.getUTCSeconds()}getIsoWeek(){const e=new Date(this.jsDate.getTime()),t=e.getUTCDay()||7;e.setUTCDate(e.getUTCDate()+4-t);const o=new Date(Date.UTC(e.getUTCFullYear(),0,1));return Math.ceil(((e.getTime()-o.getTime())/864e5+1)/7)}setFullYear(e){return this.jsDate.setUTCFullYear(e)}setMonth(e){return this.jsDate.setUTCMonth(e)}setDate(e){return this.jsDate.setUTCDate(e)}setHours(e){return this.jsDate.setUTCHours(e)}setMinutes(e){return this.jsDate.setUTCMinutes(e)}setSeconds(e){return this.jsDate.setUTCSeconds(e)}}const Xo=new Yo(1899,11,30),Ko=864e5,Jo=2e3,Qo=Yo.now().getFullYear(),es=Yo.now().getMonth(),ts=Yo.fromTimestamp(0).getTime()-Xo.getTime(),os=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,ss=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,is=wt.join(""),ns=new RegExp(`/|-|${wt.join("|")}`),rs=new RegExp(`^(\\d{1,4})[/${is}-](\\d{1,4})([/${is}-](\\d{1,4}))?$`),as=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function ls(e,t){switch(typeof e){case"number":return e;case"string":return cs(e,t)?ds(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function cs(e,t){return null!==ds(e,t)}const hs=new Map;function ds(e,t){return hs.has(t)||hs.set(t,new Map),hs.get(t).has(e)||hs.get(t).set(e,function(e,t){e=e.trim();let o=null;const s=e.match(as);if(s){if(o=function(e){if(e=e.trim(),as.test(e)){const t=/AM/i.test(e),o=/PM/i.test(e),s=(t||o?e.substring(0,e.length-2).trim():e).split(/:/),i=s.length>=2,n=3===s.length;let r=Number(s[0]),a=i?Number(s[1]):0,l=n?Number(s[2]):0,c=n?"hh:mm:ss":"hh:mm";if(t||o)c+=" a";else if(!i)return null;r>=12&&t?r-=12:r<12&&o&&(r+=12),a+=Math.floor(l/60),l%=60,r+=Math.floor(a/60),a%=60,r>=24&&(c="hhhh:mm:ss");return{value:r/24+a/1440+l/86400,format:c,jsDate:new Yo(1899,11,30,r,a,l)}}return null}(s[0]),null===o)return null;e=e.replace(s[0],"").trim()}let i=null;const n=function(e,t){const o=e.match(rs);if(!o)return null;const[,s,i,,n]=o;if(s.length>2&&n&&n.length>2)return null;if(s.length>2)return{year:s,month:i,day:n,dateString:e,type:"ymd"};const r=function(e){switch(e.dateFormat[0]){case"d":return"dmy";case"m":return"mdy";case"y":return"ymd"}throw new Error("Invalid date format in locale")}(t);if(!n)return i.length>2?{month:s,year:i,day:void 0,dateString:e,type:r}:"dmy"===r?{day:s,month:i,year:n,dateString:e,type:"dmy"}:{month:s,day:i,year:n,dateString:e,type:"mdy"};if(n.length>2)return"mdy"===r?{month:s,day:i,year:n,dateString:e,type:"mdy"}:{day:s,month:i,year:n,dateString:e,type:"dmy"};if("mdy"===r)return{month:s,day:i,year:n,dateString:e,type:"mdy"};if("ymd"===r)return{year:s,month:i,day:n,dateString:e,type:"ymd"};if("dmy"===r)return{day:s,month:i,year:n,dateString:e,type:"dmy"};return null}(e,t);if(n){const t=n.dateString.match(ns)[0];if(i=function(e,t){const{year:o,month:s,day:i}=e,n=function(e){if(!e)return es;const t=Number(e);if(t>=1&&t<=12)return t-1;return null}(s),r=function(e){if(!e)return 1;const t=Number(e);if(t>=0&&t<=31)return t;return null}(i),a=function(e){if(!e)return Qo;const t=Number(e);switch(e.length){case 1:return Jo+t;case 2:return Jo+(Jo+t>Qo+10?-100:0)+t;case 3:case 4:return t}return null}(o);if(null===a||null===n||null===r)return null;const l=2===s?.length&&n+1<10||2===i?.length&&r<10,c=2!==o?.length,h=new Yo(a,n,r);if(h.getMonth()!==n||h.getDate()!==r)return null;const d=h.getTime()-Xo.getTime(),u=function(e,t,o,s){const i=e.year?s?"yyyy":"yy":void 0,n=e.month?o?"mm":"m":void 0,r=e.day?o?"dd":"d":void 0;switch(e.type){case"mdy":return[n,r,i].filter(lt).join(t);case"ymd":return[i,n,r].filter(lt).join(t);case"dmy":return[r,n,i].filter(lt).join(t)}}(e,t,l,c);return{value:Math.round(d/Ko),format:u,jsDate:h}}(n,t),null===i)return null;e=e.replace(n.dateString,"").trim()}if(""!==e||!i&&!o)return null;if(i&&i.jsDate&&o&&o.jsDate)return{value:i.value+o.value,format:i.format+" "+("hhhh:mm:ss"===o.format?"hh:mm:ss":o.format),jsDate:new Yo(i.jsDate.getFullYear()+o.jsDate.getFullYear()-1899,i.jsDate.getMonth()+o.jsDate.getMonth()-11,i.jsDate.getDate()+o.jsDate.getDate()-30,i.jsDate.getHours()+o.jsDate.getHours(),i.jsDate.getMinutes()+o.jsDate.getMinutes(),i.jsDate.getSeconds()+o.jsDate.getSeconds())};return i||o}(e,t)),hs.get(t).get(e)}function us(e){const t=Math.trunc(e),o=Yo.fromTimestamp(t*Ko-ts);let s=e-t;s=s<0?1+s:s;const i=Math.round(24*s),n=Math.round(24*(s-i/24)*60),r=Math.round(24*(s-i/24-n/24/60)*60*60);return o.setHours(i),o.setMinutes(n),o.setSeconds(r),o}function gs(e){return Math.round(ps(e))}function ps(e){return(e.getTime()-Xo.getTime())/Ko}function ms(e){return new Yo(e.getFullYear(),e.getMonth()+1,0).getDate()}function fs(e){return ms(e)===e.getDate()}function vs(e,t,o){const s=e.getFullYear(),i=e.getMonth(),n=e.getDate(),r=new Yo(s,i+t,1);return o&&n===ms(e)||n>ms(r)?r.setDate(ms(r)):r.setDate(n),r}function bs(e){const t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function Ss(e,t,o){if(e===t)return 0;if(e>t){const o=t;t=e,e=o}const s=us(e),i=us(t);let n=s.getDate(),r=i.getDate();const a=s.getMonth(),l=i.getMonth(),c=s.getFullYear(),h=i.getFullYear();let d=0,u=0;switch(o){case 0:31===n&&(n=30),30===n&&31===r&&(r=30),1===a&&n===(bs(c)?29:28)&&(n=30,1===l&&r===(bs(h)?29:28)&&(r=30)),d=c+(30*a+n)/360,u=h+(30*l+r)/360;break;case 1:let o=365;const s=c===h;if(!s&&!(c+1===h)||!s&&a<l||!s&&a===l&&n<r){let e=0,t=0;for(let o=c;o<=h;o++)e++,t+=bs(o)?366:365;o=t/e}else s?bs(c)&&(o=366):(bs(c)&&a<2&&(o=366),bs(h)&&(l>1||1===l&&29===r)&&(o=366));d=e/o,u=t/o;break;case 2:d=e/360,u=t/360;break;case 3:d=e/365,u=t/365;break;case 4:31===n&&(n=30),31===r&&(r=30),d=c+(30*a+n)/360,u=h+(30*l+r)/360}return u-d}function Cs(e,t){const o=12*(t.getFullYear()-e.getFullYear())+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?o-1:o}function ys(e,t){const o=e.getTime(),s=t.getTime();return Math.floor((s-o)/Ko)}function ws(e,t){const o=t.getFullYear()-e.getFullYear(),s=e.getMonth(),i=t.getMonth(),n=e.getDate(),r=t.getDate();return i>s||i===s&&r>=n?o:o-1}function Is(e,t,o){return t>o?Is(e,o,t):(e=Math.trunc(e),t=Math.trunc(t),o=Math.trunc(o),e>=t&&e<=o)}const xs=Et((function(e){return e=Be(e),new RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e(\\+|-)?\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)})),Es=Et((function(e){const t=Be(e.decimalSeparator),o="(?:\\s*"+`(?:\\d+(?:${Be(e.thousandsSeparator||"")}\\d{3,})*(?:${t}\\d*)?)`+"|"+`(?:${t}\\d+)`+")(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?",s="(?:\\s*-)?",i="(?:\\s*[\\$€])?",n="^(?:(?:"+[s+i+o,s+o+i,i+s+o].join(")|(?:")+"))$";return new RegExp(n,"i")}));function Rs(e,t){return!!e&&Es(t).test(e.trim())}const Ts=Et((function(e){return new RegExp(`[$€${Be(e.thousandsSeparator||"")}]`,"g")}));function As(e,t){e=e.replace(Ts(t),""),"."!==t.decimalSeparator&&(e=e.replace(t.decimalSeparator,"."));let o=Number(e);return isNaN(o)&&e.includes("%")&&(o=Number(e.split("%")[0]),!isNaN(o))?o/100:o}function Ds(e,t,o){const s=[...e].sort(((e,t)=>e-t));let i=(s.length+(o?-1:1))*t;if(o||i--,Number.isInteger(i))return s[i];const n=Math.ceil(i),r=Math.floor(i);return s[n]*(i-r)+s[r]*(n-i)}var _s,Os;!function(e){e.boolean="boolean",e.number="number",e.text="text",e.empty="empty",e.error="error"}(_s||(_s={})),function(e){e.PlainText="text/plain",e.Html="text/html",e.Image="image"}(Os||(Os={}));const Fs=new Set(["RENAME_SHEET","DELETE_SHEET","CREATE_SHEET","DUPLICATE_SHEET","ADD_COLUMNS_ROWS","REMOVE_COLUMNS_ROWS","UNDO","REDO","ADD_MERGE","REMOVE_MERGE","DUPLICATE_SHEET","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]),Ps=new Set(["EVALUATE_CELLS","EVALUATE_CHARTS","UPDATE_CELL","UNHIDE_COLUMNS_ROWS","HIDE_COLUMNS_ROWS","GROUP_HEADERS","UNGROUP_HEADERS","FOLD_ALL_HEADER_GROUPS","FOLD_HEADER_GROUP","FOLD_HEADER_GROUPS_IN_ZONE","UNFOLD_ALL_HEADER_GROUPS","UNFOLD_HEADER_GROUP","UNFOLD_HEADER_GROUPS_IN_ZONE","UPDATE_TABLE","UPDATE_FILTER","UNDO","REDO"]),Ms=new Set(["MOVE_RANGES"]),Ns=new Set(["EVALUATE_CELLS","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY"]),ks=new Set(["AUTOFILL_CELL","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET"]),Vs=new Set(["START","ACTIVATE_SHEET","COPY","RESIZE_SHEETVIEW","SET_VIEWPORT_OFFSET","EVALUATE_CELLS","EVALUATE_CHARTS","SET_FORMULA_VISIBILITY","UPDATE_FILTER","UPDATE_CHART"]),Ls=new Set(["UPDATE_CELL","UPDATE_CELL_POSITION","CLEAR_CELL","CLEAR_CELLS","DELETE_CONTENT","ADD_COLUMNS_ROWS","REMOVE_COLUMNS_ROWS","RESIZE_COLUMNS_ROWS","HIDE_COLUMNS_ROWS","UNHIDE_COLUMNS_ROWS","SET_GRID_LINES_VISIBILITY","UNFREEZE_COLUMNS","UNFREEZE_ROWS","FREEZE_COLUMNS","FREEZE_ROWS","UNFREEZE_COLUMNS_ROWS","ADD_MERGE","REMOVE_MERGE","CREATE_SHEET","DELETE_SHEET","DUPLICATE_SHEET","MOVE_SHEET","RENAME_SHEET","COLOR_SHEET","HIDE_SHEET","SHOW_SHEET","MOVE_RANGES","ADD_CONDITIONAL_FORMAT","REMOVE_CONDITIONAL_FORMAT","CHANGE_CONDITIONAL_FORMAT_PRIORITY","CREATE_FIGURE","DELETE_FIGURE","UPDATE_FIGURE","SET_FORMATTING","CLEAR_FORMATTING","SET_BORDER","SET_ZONE_BORDERS","SET_BORDERS_ON_TARGET","CREATE_CHART","UPDATE_CHART","CREATE_TABLE","REMOVE_TABLE","UPDATE_TABLE","CREATE_TABLE_STYLE","REMOVE_TABLE_STYLE","CREATE_IMAGE","GROUP_HEADERS","UNGROUP_HEADERS","UNFOLD_HEADER_GROUP","FOLD_HEADER_GROUP","FOLD_ALL_HEADER_GROUPS","UNFOLD_ALL_HEADER_GROUPS","UNFOLD_HEADER_GROUPS_IN_ZONE","FOLD_HEADER_GROUPS_IN_ZONE","ADD_DATA_VALIDATION_RULE","REMOVE_DATA_VALIDATION_RULE","UPDATE_LOCALE","ADD_PIVOT","UPDATE_PIVOT","INSERT_PIVOT","RENAME_PIVOT","REMOVE_PIVOT","DUPLICATE_PIVOT"]);function Hs(e){return Ls.has(e.type)}class Us{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter((e=>"Success"!==e))}static get Success(){return Bs}get isSuccessful(){return 0===this.reasons.length}isCancelledBecause(e){return this.reasons.includes(e)}}const Bs=new Us;var zs;e.CommandResult=void 0,(zs=e.CommandResult||(e.CommandResult={})).Success="Success",zs.CancelledForUnknownReason="CancelledForUnknownReason",zs.WillRemoveExistingMerge="WillRemoveExistingMerge",zs.CannotMoveTableHeader="CannotMoveTableHeader",zs.MergeIsDestructive="MergeIsDestructive",zs.CellIsMerged="CellIsMerged",zs.InvalidTarget="InvalidTarget",zs.EmptyUndoStack="EmptyUndoStack",zs.EmptyRedoStack="EmptyRedoStack",zs.NotEnoughElements="NotEnoughElements",zs.NotEnoughSheets="NotEnoughSheets",zs.MissingSheetName="MissingSheetName",zs.UnchangedSheetName="UnchangedSheetName",zs.DuplicatedSheetName="DuplicatedSheetName",zs.DuplicatedSheetId="DuplicatedSheetId",zs.ForbiddenCharactersInSheetName="ForbiddenCharactersInSheetName",zs.WrongSheetMove="WrongSheetMove",zs.WrongSheetPosition="WrongSheetPosition",zs.InvalidAnchorZone="InvalidAnchorZone",zs.SelectionOutOfBound="SelectionOutOfBound",zs.TargetOutOfSheet="TargetOutOfSheet",zs.WrongCutSelection="WrongCutSelection",zs.WrongPasteSelection="WrongPasteSelection",zs.WrongPasteOption="WrongPasteOption",zs.WrongFigurePasteOption="WrongFigurePasteOption",zs.EmptyClipboard="EmptyClipboard",zs.EmptyRange="EmptyRange",zs.InvalidRange="InvalidRange",zs.InvalidZones="InvalidZones",zs.InvalidSheetId="InvalidSheetId",zs.InvalidCellId="InvalidCellId",zs.InvalidFigureId="InvalidFigureId",zs.InputAlreadyFocused="InputAlreadyFocused",zs.MaximumRangesReached="MaximumRangesReached",zs.MinimumRangesReached="MinimumRangesReached",zs.InvalidChartDefinition="InvalidChartDefinition",zs.InvalidDataSet="InvalidDataSet",zs.InvalidLabelRange="InvalidLabelRange",zs.InvalidScorecardKeyValue="InvalidScorecardKeyValue",zs.InvalidScorecardBaseline="InvalidScorecardBaseline",zs.InvalidGaugeDataRange="InvalidGaugeDataRange",zs.EmptyGaugeRangeMin="EmptyGaugeRangeMin",zs.GaugeRangeMinNaN="GaugeRangeMinNaN",zs.EmptyGaugeRangeMax="EmptyGaugeRangeMax",zs.GaugeRangeMaxNaN="GaugeRangeMaxNaN",zs.GaugeLowerInflectionPointNaN="GaugeLowerInflectionPointNaN",zs.GaugeUpperInflectionPointNaN="GaugeUpperInflectionPointNaN",zs.InvalidAutofillSelection="InvalidAutofillSelection",zs.MinBiggerThanMax="MinBiggerThanMax",zs.LowerBiggerThanUpper="LowerBiggerThanUpper",zs.MidBiggerThanMax="MidBiggerThanMax",zs.MinBiggerThanMid="MinBiggerThanMid",zs.FirstArgMissing="FirstArgMissing",zs.SecondArgMissing="SecondArgMissing",zs.MinNaN="MinNaN",zs.MidNaN="MidNaN",zs.MaxNaN="MaxNaN",zs.ValueUpperInflectionNaN="ValueUpperInflectionNaN",zs.ValueLowerInflectionNaN="ValueLowerInflectionNaN",zs.MinInvalidFormula="MinInvalidFormula",zs.MidInvalidFormula="MidInvalidFormula",zs.MaxInvalidFormula="MaxInvalidFormula",zs.ValueUpperInvalidFormula="ValueUpperInvalidFormula",zs.ValueLowerInvalidFormula="ValueLowerInvalidFormula",zs.InvalidSortAnchor="InvalidSortAnchor",zs.InvalidSortZone="InvalidSortZone",zs.SortZoneWithArrayFormulas="SortZoneWithArrayFormulas",zs.WaitingSessionConfirmation="WaitingSessionConfirmation",zs.MergeOverlap="MergeOverlap",zs.TooManyHiddenElements="TooManyHiddenElements",zs.Readonly="Readonly",zs.InvalidViewportSize="InvalidViewportSize",zs.InvalidScrollingDirection="InvalidScrollingDirection",zs.ViewportScrollLimitsReached="ViewportScrollLimitsReached",zs.FigureDoesNotExist="FigureDoesNotExist",zs.InvalidConditionalFormatId="InvalidConditionalFormatId",zs.InvalidCellPopover="InvalidCellPopover",zs.EmptyTarget="EmptyTarget",zs.InvalidFreezeQuantity="InvalidFreezeQuantity",zs.FrozenPaneOverlap="FrozenPaneOverlap",zs.ValuesNotChanged="ValuesNotChanged",zs.InvalidFilterZone="InvalidFilterZone",zs.TableNotFound="TableNotFound",zs.TableOverlap="TableOverlap",zs.InvalidTableConfig="InvalidTableConfig",zs.InvalidTableStyle="InvalidTableStyle",zs.FilterNotFound="FilterNotFound",zs.MergeInTable="MergeInTable",zs.NonContinuousTargets="NonContinuousTargets",zs.DuplicatedFigureId="DuplicatedFigureId",zs.InvalidSelectionStep="InvalidSelectionStep",zs.DuplicatedChartId="DuplicatedChartId",zs.ChartDoesNotExist="ChartDoesNotExist",zs.InvalidHeaderIndex="InvalidHeaderIndex",zs.InvalidQuantity="InvalidQuantity",zs.MoreThanOneColumnSelected="MoreThanOneColumnSelected",zs.EmptySplitSeparator="EmptySplitSeparator",zs.SplitWillOverwriteContent="SplitWillOverwriteContent",zs.NoSplitSeparatorInSelection="NoSplitSeparatorInSelection",zs.NoActiveSheet="NoActiveSheet",zs.InvalidLocale="InvalidLocale",zs.MoreThanOneRangeSelected="MoreThanOneRangeSelected",zs.NoColumnsProvided="NoColumnsProvided",zs.ColumnsNotIncludedInZone="ColumnsNotIncludedInZone",zs.DuplicatesColumnsSelected="DuplicatesColumnsSelected",zs.InvalidHeaderGroupStartEnd="InvalidHeaderGroupStartEnd",zs.HeaderGroupAlreadyExists="HeaderGroupAlreadyExists",zs.UnknownHeaderGroup="UnknownHeaderGroup",zs.UnknownDataValidationRule="UnknownDataValidationRule",zs.UnknownDataValidationCriterionType="UnknownDataValidationCriterionType",zs.InvalidDataValidationCriterionValue="InvalidDataValidationCriterionValue",zs.InvalidNumberOfCriterionValues="InvalidNumberOfCriterionValues",zs.InvalidCopyPasteSelection="InvalidCopyPasteSelection",zs.NoChanges="NoChanges",zs.InvalidInputId="InvalidInputId",zs.SheetIsHidden="SheetIsHidden",zs.InvalidTableResize="InvalidTableResize",zs.PivotIdNotFound="PivotIdNotFound",zs.PivotInError="PivotInError",zs.EmptyName="EmptyName",zs.ValueCellIsInvalidFormula="ValueCellIsInvalidFormula",zs.InvalidDefinition="InvalidDefinition",zs.InvalidColor="InvalidColor",zs.InvalidPivotDataSet="InvalidPivotDataSet";const $s=new Set(["containsText","notContainsText","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","beginsWithText","endsWithText","isNotEmpty","isEmpty","isNotEqual","isEqual"]),Gs=new Set(["containsText","notContainsText","isEqualText","isEmail","isLink","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","dateIsValid","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isBoolean","isValueInList","isValueInRange","customFormula"]),Ws=[{name:"English (US)",code:"en_US",thousandsSeparator:",",decimalSeparator:".",weekStart:7,dateFormat:"m/d/yyyy",timeFormat:"hh:mm:ss a",formulaArgSeparator:","},{name:"French",code:"fr_FR",thousandsSeparator:" ",decimalSeparator:",",weekStart:1,dateFormat:"dd/mm/yyyy",timeFormat:"hh:mm:ss",formulaArgSeparator:";"}],qs=Ws[0],Zs=["thin","medium","thick","dashed","dotted"];function js(e){return Array.isArray(e)&&Array.isArray(e[0])}var Ys;!function(e){e.UP="up",e.DOWN="down",e.LEFT="left",e.RIGHT="right"}(Ys||(Ys={}));const Xs={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},Ks=Et((()=>Object.keys(Xs).sort(((e,t)=>Xs[e]-Xs[t]))));new Set(["containsText","notContainsText","isEqualText","dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","customFormula","beginsWithText","endsWithText","isNotEmpty","isEmpty"]);const Js=["containsText","notContainsText","isEqualText","isEmpty","isNotEmpty","beginsWithText","endsWithText"],Qs=["isEqual","isNotEqual","isGreaterThan","isGreaterOrEqualTo","isLessThan","isLessOrEqualTo","isBetween","isNotBetween","isEmpty","isNotEmpty"],ei=["dateIs","dateIsBefore","dateIsOnOrBefore","dateIsAfter","dateIsOnOrAfter","dateIsBetween","dateIsNotBetween","isEmpty","isNotEmpty"],ti={NotAvailable:"#N/A",InvalidReference:"#REF",BadExpression:"#BAD_EXPR",CircularDependency:"#CYCLE",UnknownFunction:"#NAME?",DivisionByZero:"#DIV/0!",SpilledBlocked:"#SPILL!",GenericError:"#ERROR",NullError:"#NULL!"},oi=new Set(Object.values(ti));class si{message;value;constructor(e=Ho("Error"),t=ti.GenericError){this.message=e,this.value=t,this.message=e.toString()}}class ii extends si{constructor(e=Ho("Invalid expression")){super(e,ti.BadExpression)}}class ni extends si{constructor(e=Ho("Circular reference")){super(e,ti.CircularDependency)}}class ri extends si{constructor(e=Ho("Invalid reference")){super(e,ti.InvalidReference)}}class ai extends si{constructor(e=Ho("Data not available")){super(e,ti.NotAvailable)}}class li extends si{constructor(e=Ho("Unknown function")){super(e,ti.UnknownFunction)}}class ci extends si{constructor(e=Ho("Spill range is not empty")){super(e,ti.SpilledBlocked)}}class hi extends si{constructor(e=Ho("Division by zero")){super(e,ti.DivisionByZero)}}const di=["number","string","boolean","undefined"];function ui(e){if(void 0!==e)return js(e)?e[0][0]?.format:e.format}function gi(e){return"string"==typeof e&&oi.has(e)}function pi(e){return{value:ti.NotAvailable,message:Ho("Did not find value '%s' in [[FUNCTION_NAME]] evaluation.",wi(e))}}const mi=e=>Ho("The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.",e);function fi(e,t){const o=Ti(e);switch(typeof o){case"number":return o;case"boolean":return o?1:0;case"string":if(Rs(o,t)||""===o)return As(o,t);const e=ds(o,t);if(e)return e.value;throw new si(mi(o));default:return 0}}function vi(e,t){try{return fi(e,t)}catch(e){return}}function bi(e,t){return ji(e).map((e=>e.map((e=>{if("number"!=typeof e.value)throw new si(Ho("Function [[FUNCTION_NAME]] expects number values for %s, but got a %s.",t,typeof e.value));return e.value}))))}function Si(e,t){const o=Ti(e);if(""===o)throw new si(mi(o));return fi(o,t)}function Ci(e,t){return Math.trunc(fi(e,t))}function yi(e,t){return Math.trunc(Si(e,t))}function wi(e){const t=Ti(e);switch(typeof t){case"string":return t;case"number":return t.toString();case"boolean":return t?"TRUE":"FALSE";default:return""}}const Ii=Et((function(e){return e.toLowerCase().normalize("NFD").replace(/[\u0300-\u036f]/g,"")})),xi=e=>Ho("The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.",e);function Ei(e){const t=Ti(e);switch(typeof t){case"boolean":return t;case"string":if(t){const e=t.toUpperCase();if("TRUE"===e)return!0;if("FALSE"===e)return!1;throw new si(xi(t))}return!1;case"number":return!!t;default:return!1}}function Ri(e,t){return us(fi(Ti(e),t))}function Ti(e){if("object"==typeof e&&null!==e&&"value"in e){if(gi(e.value))throw e;return e.value}if(gi(e))throw new si("",e);return e}function Ai(e,t,o){for(const s of e)if(js(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)t(s[o][i])}else o(s)}function Di(e,t){Ai(e,(e=>{if(gi(e.value))throw e;t(e)}),(e=>{if(gi(e?.value))throw e;t(e)}))}function _i(e,t,o){Ai(e,(e=>{if("number"==typeof e?.value&&t(e),gi(e?.value))throw e}),(e=>{t({value:Si(e,o),format:e?.format})}))}function Oi(e,t,o,s,i="rowFirst"){let n=s;for(const s of e)if(js(s)){const e=s.length,o=s[0].length;if("rowFirst"===i)for(let i=0;i<o;i++)for(let o=0;o<e;o++)n=t(n,s[o][i]);else for(let i=0;i<e;i++)for(let e=0;e<o;e++)n=t(n,s[i][e])}else n=o(n,s);return n}function Fi(e,t,o,s="rowFirst"){return Oi(e,t,t,o,s)}function Pi(e,t,o,s){return Oi(e,((e,o)=>{const s=o?.value;if("number"==typeof s)return t(e,s);if(gi(s))throw o;return e}),((e,o)=>t(e,Si(o,s))),o)}function Mi(e,t,o,s){return Oi(e,((e,o)=>{const i=o?.value;if(null!=i){if("number"==typeof i)return t(e,i);if("boolean"==typeof i)return t(e,fi(i,s));if(gi(i))throw o;return t(e,0)}return e}),((e,o)=>t(e,fi(o,s))),o)}function Ni(e,t,o){const s=Array(e);for(let i=0;i<e;i++){s[i]=Array(t);for(let e=0;e<t;e++)s[i][e]=o(i,e)}return s}function ki(e,t){return 0===e.length?[]:Ni(e.length,e[0].length,((o,s)=>t(e[o][s])))}function Vi(e){return e.length?Ni(e[0].length,e.length,((t,o)=>e[o][t])):[]}function Li(e,t,o=void 0){let s,i=1,n=1,r=1/0,a=1/0;for(let e=0;e<t.length;e++){const l=t[e];if(js(l)&&(void 0===o||o[e])){const o=l.length,c=l[0].length;1!==o||1!==c?(s??=new Array(t.length),1!==o&&1!==c?(s[e]="matrix",i=Math.max(i,o),n=Math.max(n,c),r=Math.min(r,o),a=Math.min(a,c)):1!==o?(s[e]="horizontal",i=Math.max(i,o),r=Math.min(r,o)):1!==c&&(s[e]="vertical",n=Math.max(n,c),a=Math.min(a,c))):t[e]=l[0][0]}}if(1===i&&1===n)return e(...t);return Ni(i,n,((o,i)=>{if(o>r-1||i>a-1)return new ai(Ho("Array arguments to [[FUNCTION_NAME]] are of different size."));const n=e(...(l=o,c=i,t.map(((e,t)=>{switch(s?.[t]){case"matrix":return e[l][c];case"horizontal":return e[l][0];case"vertical":return e[0][c];case void 0:return e}}))));var l,c;return js(n)?n[0][0]:n}))}function Hi(e,t){return function(e,t,o){for(const s of e)if(js(s)){const e=s.length,o=s[0].length;for(let i=0;i<o;i++)for(let o=0;o<e;o++)if(!t(s[o][i]??void 0))return}else if(!o(s))return}(e,(e=>{const o=e?.value;if("boolean"==typeof o)return t(o);if("number"==typeof o)return t(!!o);if(gi(o))throw e;return!0}),(e=>void 0===e||null===e.value||t(function(e){const t=Ti(e);if(""===t)throw new si(xi(t));return Ei(t)}(e))))}function Ui(e,t){let o,s,i=e.substring(0,2);return"<="===i||">="===i||"<>"===i?(o=i,s=e.substring(2)):(i=e.substring(0,1),"<"===i||">"===i||"="===i?(o=i,s=e.substring(1)):(o="=",s=e)),Rs(s,t)||cs(s,t)?s=fi(s,t):"TRUE"!==s&&"FALSE"!==s||(s=Ei(s)),{operator:o,operand:s}}const Bi=Et((function(e){if("*"===e)return/.+/;let t="",o="";for(const s of e)"?"===s&&"~"!==o?t+=".":"*"===s&&"~"!==o?t+=".*":("*"!==s&&"?"!==s||(t=t.slice(0,-1)),["^",".","[","]","$","(",")","*","+","?","|","{","}","\\"].includes(s)&&(t+="\\"),t+=s),o=s;return new RegExp("^"+t+"$","i")}));function zi(e="",t,o){const{operator:s,operand:i}=t;if(void 0===i||null===e||null===i)return!1;if("number"==typeof i&&"="===s)return"string"==typeof e&&(Rs(e,o)||cs(e,o))?fi(e,o)===i:e===i;if("<>"===s||"="===s){let t;return t=typeof e==typeof i&&("string"==typeof e&&"string"==typeof i?Bi(i).test(e):e===i),"="===s?t:!t}if(typeof e==typeof i)switch(s){case"<":return e<i;case">":return e>i;case"<=":return e<=i;case">=":return e>=i}return!1}function $i(e,t,o,s=!1){const i=e.length;if(i%2==1)throw new si(Ho("Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs."));const n=ji(e[0]),r=n.length,a=n[0].length,l=[];for(let t=0;t<i-1;t+=2){const i=ji(e[t]);if(i.length!==r||i[0].length!==a)throw new si(Ho("Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension"));const n=Ui(wi(e[t+1]),o);s&&"string"==typeof n.operand&&(n.operand+="*"),l.push(n)}for(let s=0;s<r;s++)for(let n=0;n<a;n++){let r=!0;for(let t=0;t<i-1;t+=2){if(r=zi(ji(e[t])[s][n].value??void 0,l[t/2],o),!r)break}r&&t(s,n)}}function Gi(e,t,o,s,i,n){if(void 0===t||null===t.value)return-1;if(gi(t.value))throw t;const r=qi(t.value),a=typeof r;let l,c,h,d,u,g,p=0,m=i-1;const f="desc"===s?t=>qi(n(e,i-t-1)):t=>qi(n(e,t));for(;m-p>=0;){for(h=Math.floor((p+m)/2),d=h,u=f(d),g=typeof u;p<d&&a!==g;)d--,u=f(d),g=typeof u;g===a&&null!=u?("strict"===o&&u===r?(l=u,c=d):"nextSmaller"===o&&u<=r?(null==l||l<u||l===u&&c<d)&&(l=u,c=d):"nextGreater"===o&&u>=r&&(void 0===l||l>u||l===u&&c<d)&&(l=u,c=d),u>r||"strict"===o&&u===r?m=d-1:p=h+1):p=h+1}return void 0===c?-1:"desc"===s?i-c-1:c}function Wi(e,t,o,s,i,n,r=!1){if(void 0===t||null===t.value)return-1;if(gi(t.value))throw t;const a=qi(t.value),l=r?(e,t)=>qi(i(e,s-t-1)):(e,t)=>qi(i(e,t)),c="wildcard"!==o||"string"!=typeof a||!(a.includes("*")||a.includes("?"));if(n&&c){const t=r?"reverseSearch":"forwardSearch";let i=n[t].get(e);if(void 0===i){i=new Map;for(let t=0;t<s;t++){const o=l(e,t)??null;i.has(o)||i.set(o,t)}n[t].set(e,i)}if(i.has(a)){const e=i.get(a);return r?s-e-1:e}if("strict"===o)return-1}const h=function(e,t,o,s,i){let n=o=>i(e,o)===t;if("wildcard"===o&&"string"==typeof t&&(t.includes("*")||t.includes("?"))){const o=Bi(t);n=t=>{const s=i(e,t);return"string"==typeof s&&o.test(s)}}let r,a=-1;"nextSmaller"===o&&(n=o=>{const s=i(e,o);return(!r&&Zi(t,s)>=0||Zi(t,s)>=0&&Zi(s,r)>0)&&(r=s,a=o),s===t});"nextGreater"===o&&(n=o=>{const s=i(e,o);return(!r&&Zi(t,s)<=0||Zi(t,s)<=0&&Zi(s,r)<0)&&(r=s,a=o),s===t});for(let e=0;e<s;e++)if(n(e))return e;return a}(e,a,o,s,l);return r&&-1!==h?s-h-1:h}function qi(e){return"string"==typeof e?Ii(e):e}function Zi(e,t){let o=di.indexOf(typeof e)-di.indexOf(typeof t);return 0===o&&("string"==typeof e&&"string"==typeof t?o=e.localeCompare(t):"number"==typeof e&&"number"==typeof t?o=e-t:"boolean"==typeof e&&"boolean"==typeof t&&(o=Number(e)-Number(t))),o}function ji(e){return void 0===e?[[]]:js(e)?e:[[e]]}function Yi(e,t){return Fi(e,((e,o)=>(e.push(t(o)),e)),[],"rowFirst")}function Xi(e){if(void 0===e)return!1;const{value:t}=e;return null!==t&&""!==t}const Ki=Ho("[[FUNCTION_NAME]] has no valid input data.");function Ji(e){return Ho("[[FUNCTION_NAME]] expects the provided values of %(argName)s to be a non-empty matrix.",{argName:e})}function Qi(e){let t;if('"'===e.current?(e.shift(),t='"'):e.currentStartsWith("[$")&&(e.advanceBy(2),t="]"),!t)return null;let o="";for(;e.current&&e.current!==t;)o+=e.shift();if(e.current!==t)throw new Error("Unterminated string in format");return e.shift(),{type:"STRING",value:o}}const en=new Set("$+-/():!^&~{}<>= ");function tn(e){if("\\"===e.current){e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"CHAR",value:t}}return en.has(e.current)?{type:"CHAR",value:e.shift()}:null}function on(e){return","===e.current?(e.shift(),{type:"THOUSANDS_SEPARATOR",value:","}):null}function sn(e){return"@"===e.current?(e.shift(),{type:"TEXT_PLACEHOLDER",value:"@"}):null}function nn(e){return"."===e.current?(e.shift(),{type:"DECIMAL_POINT",value:"."}):null}function rn(e){return"%"===e.current?(e.shift(),{type:"PERCENT",value:"%"}):null}function an(e){if("0"===e.current||"#"===e.current){const t=e.current;return e.shift(),{type:"DIGIT",value:t}}return null}const ln=new Set("dmqyhsa");function cn(e){if(!ln.has(e.current))return null;const t=e.current;let o="";for(;e.current===t;)o+=e.shift();return{type:"DATE_PART",value:o}}function hn(e){if("*"!==e.current)return null;e.shift();const t=e.shift();if(!t)throw new Error("Unexpected end of format string");return{type:"REPEATED_CHAR",value:t}}const dn=20,un={};function gn(e){let t=un[e];return void 0===t&&(t=function(e){const t=function(e){const t=new Mt(e),o=[];let s=[];for(o.push(s);!t.isOver();){if(";"===t.current){s=[],o.push(s),t.shift();continue}const e=an(t)||Qi(t)||tn(t)||on(t)||nn(t)||rn(t)||cn(t)||sn(t)||hn(t);if(!e)throw new Error("Unknown token at "+t.remaining());s.push(e)}return o}(e);for(const e of t){const t=e.filter((e=>"REPEATED_CHAR"===e.type));for(const e of t.slice(1))e.type="CHAR"}const o=mn(t[0])||pn(t[0])||fn(t[0]);if(!o)throw new Error("Invalid first format part of: "+e);if(t.length>1&&"text"===o.type)throw new Error("The first format in a multi-part format must be a number format: "+e);const s=mn(t[1])||pn(t[1]);if(t[1]?.length&&!s)throw new Error("Invalid second format part of: "+e);const i=mn(t[2])||pn(t[2]);if(t[2]?.length&&!i)throw new Error("Invalid third format part of: "+e);const n=fn(t[3]);if(t[3]?.length&&!n)throw new Error("Invalid fourth format part of: "+e);return{positive:o,negative:s,zero:i,text:n}}(e),un[e]=t),t}function pn(e){if(!e||!function(e){return e.every((e=>"DIGIT"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"PERCENT"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e))return;const t=[];let o,s=t,i=0,n=0,r=e.findLastIndex((e=>"DIGIT"===e.type)),a=!1,l=0;for(let c=0;c<e.length;c++){const h=e[c];switch(h.type){case"DIGIT":s===t?s.push(h):l<dn&&(s.push(h),l++);break;case"DECIMAL_POINT":if(s!==t)throw new Error("Multiple decimal points in a number format");o=[],s=o;break;case"REPEATED_CHAR":case"CHAR":case"STRING":s.push(h);break;case"PERCENT":i++,s.push(h);break;case"THOUSANDS_SEPARATOR":c-1===r?(n+=1,r++,s.push(h)):"DIGIT"===e[c+1]?.type&&"DIGIT"===e[c-1]?.type?(s===t&&(a=!0),s.push(h)):s.push({type:"CHAR",value:","})}}return{type:"number",integerPart:t,decimalPart:o,percentSymbols:i,thousandsSeparator:a,magnitude:n}}function mn(e){const t=e&&function(e){return e.every((e=>"DATE_PART"===e.type||"DECIMAL_POINT"===e.type||"THOUSANDS_SEPARATOR"===e.type||"STRING"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"date",tokens:e}:void 0;if(!t)return;if(t.tokens.length&&t.tokens.every((e=>"DATE_PART"===e.type&&"a"===e.value)))throw new Error("Invalid date format");const o=function(e){const t=e.filter((e=>"DATE_PART"===e.type));for(let e=0;e<t.length;e++)!t[e].value.startsWith("m")||t[e].value.length>2||(t[e-1]?.value.startsWith("h")||t[e+1]?.value.startsWith("s"))&&(t[e].value=t[e].value.replaceAll("m","M"));return e}(t.tokens.map((e=>"THOUSANDS_SEPARATOR"===e.type||"DECIMAL_POINT"===e.type?{type:"CHAR",value:e.value}:e)));return{type:"date",tokens:o}}function fn(e){return e&&function(e){return e.every((e=>"STRING"===e.type||"TEXT_PLACEHOLDER"===e.type||"CHAR"===e.type||"REPEATED_CHAR"===e.type))}(e)?{type:"text",tokens:e}:void 0}function vn(e){return[bn(e.positive),bn(e.negative),bn(e.zero),bn(e.text)].filter(lt).join(";")}function bn(e){if(!e)return;let t="";const o="number"!==e.type?e.tokens:function(e){const t=[...e.integerPart];e.decimalPart&&(t.push({type:"DECIMAL_POINT",value:"."}),t.push(...e.decimalPart));return t}(e);for(const e of o)switch(e.type){case"STRING":t+=`[$${e.value}]`;break;case"CHAR":t+=(s=e.value,en.has(s)?e.value:`\\${e.value}`);break;case"REPEATED_CHAR":t+="*"+e.value;break;case"DATE_PART":t+="MM"===e.value?"mm":e.value;break;default:t+=e.value}var s;return t}const Sn=11,Cn="REPEATED_CHAR_PLACEHOLDER_",yn={0:Ho("January"),1:Ho("February"),2:Ho("March"),3:Ho("April"),4:Ho("May"),5:Ho("June"),6:Ho("July"),7:Ho("August"),8:Ho("September"),9:Ho("October"),10:Ho("November"),11:Ho("December")},wn={0:Ho("Sunday"),1:Ho("Monday"),2:Ho("Tuesday"),3:Ho("Wednesday"),4:Ho("Thursday"),5:Ho("Friday"),6:Ho("Saturday")};function In(e,{format:t,locale:o,formatWidth:s}){switch("boolean"==typeof e&&(e=e?"TRUE":"FALSE"),typeof e){case"string":{if(e.includes('\\"')&&(e=e.replaceAll(/\\"/g,'"')),!t)return e;const o=gn(t),i=o.text||o.positive;return i&&"text"===i.type?xn(e,i,s):e}case"number":t||(t=Mn(e));const i=gn(t);if("text"===i.positive.type)return xn(e.toString(),i.positive,s);let n=i.positive;if(e<0&&i.negative?(n=i.negative,e=-e):0===e&&i.zero&&(n=i.zero),"date"===n.type)return En(function(e,t){const o=us(e),s=t.tokens.some((e=>"DATE_PART"===e.type&&"a"===e.value));let i="";for(const e of t.tokens)switch(e.type){case"DATE_PART":i+=Fn(o,e.value,s);break;case"REPEATED_CHAR":i+=Cn+e.value;break;default:i+=e.value}return i}(e,n),s);const r=e<0,a=En(function(e,t,o){if(e===1/0)return"∞"+(t.percentSymbols?"%":"");const s=2*t.percentSymbols-3*t.magnitude;e*=10**s;let i=0;void 0!==t.decimalPart&&(i=t.decimalPart.filter((e=>"DIGIT"===e.type)).length);const{integerDigits:n,decimalDigits:r}=Tn(Math.abs(e),i);let a=function(e,t,o){let s=t.integerPart;s.some((e=>"DIGIT"===e.type))||(s=[...s,{type:"DIGIT",value:"#"}]);"0"===e&&(e="");let i="";const n=s.findIndex((e=>"DIGIT"===e.type));let r=e.length-1;function a(t,s){if("0"===s&&(t=t||"0"),!t)return;const n=e.length-1-r;i=o&&n>0&&n%3==0?t+o+i:t+i}for(let t=s.length-1;t>=0;t--){const o=s[t];switch(o.type){case"DIGIT":if(a(e[r],o.value),r--,n===t)for(;r>=0;)a(e[r],"0"),r--;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":i=Cn+o.value+i;break;default:i=o.value+i}}return i}(n,t,t.thousandsSeparator?o.thousandsSeparator:void 0);void 0!==t.decimalPart&&(a+=o.decimalSeparator+function(e,t){if(!t.decimalPart)return"";let o="",s=0;for(const i of t.decimalPart)switch(i.type){case"DIGIT":o+="#"===i.value?e[s]||"":e[s]||"0",s++;break;case"THOUSANDS_SEPARATOR":break;case"REPEATED_CHAR":o+=Cn+i.value;break;default:o+=i.value}return o}(r||"",t));return a}(Math.abs(e),n,o),s);return r?"-"+a:a;case"object":return""}}function xn(e,t,o){let s="";for(const o of t.tokens)switch(o.type){case"TEXT_PLACEHOLDER":s+=e;break;case"CHAR":case"STRING":s+=o.value;break;case"REPEATED_CHAR":s+=Cn+o.value}return En(s,o)}function En(e,t){const o=e.indexOf(Cn);if(-1===o)return e;const s=e.slice(0,o),i=e.slice(o+Cn.length+1),n=e[o+Cn.length];const{timesToRepeat:r,padding:a}=function(){if(!t)return{timesToRepeat:0,padding:""};const e=t.measureText(s+i),o=t.measureText(n),r=t.availableWidth-e;if(r<=0)return{timesToRepeat:0,padding:""};const a=Math.floor(r/o),l=r-a*o,c=t.measureText(" ");return{timesToRepeat:a,padding:" ".repeat(Math.floor(l/c))}}();return s+n.repeat(r)+a+i}const Rn=[];function Tn(e,t=dn){const o=e.toString();if(o.includes("e"))return function(e,t=dn){let o=Rn[t];o||(o=new Intl.NumberFormat("en-US",{maximumFractionDigits:t,useGrouping:!1}),Rn[t]=o);const[s,i]=o.format(e).split(".");return{integerDigits:s,decimalDigits:i}}(e,t);if(Number.isInteger(e))return{integerDigits:o,decimalDigits:void 0};const s=o.indexOf(".");let i=o.substring(0,s),n=o.substring(s+1);if(0===t)return Number(n[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(n.length>t){const{integerDigits:e,decimalDigits:o}=function(e,t){let o="0",s=e;const i=e.slice(0,t),n=t;if(Number(e[n])<5)return{integerDigits:o,decimalDigits:i};const r=i.match(Dn)?.[0]||"",a=(Number(i)+1).toString(),l=i.slice(r.length),c=a.length>l.length;c&&!r?(o="1",s=void 0):s=c?r.slice(0,-1)+a:r+a;return{integerDigits:o,decimalDigits:s}}(n,t);n=o,"0"!==e&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:An(n||"")}}function An(e){let t=e.length-1;for(;t>=0&&"0"===e[t];)t--;return e.slice(0,t+1)||void 0}const Dn=/^0+/;function _n(e,t){const{integerDigits:o,decimalDigits:s}=Tn(e,20);return s?o+t+s:o}const On=Et((function(e){if(!e)return!1;try{return"date"===gn(e).positive.type}catch(e){return!1}}));function Fn(e,t,o){switch(t){case"d":return e.getDate();case"dd":return e.getDate().toString().padStart(2,"0");case"ddd":return wn[e.getDay()].slice(0,3);case"dddd":return wn[e.getDay()].toString();case"m":return e.getMonth()+1;case"mm":return String(e.getMonth()+1).padStart(2,"0");case"mmm":return yn[e.getMonth()].slice(0,3);case"mmmm":return yn[e.getMonth()].toString();case"mmmmm":return yn[e.getMonth()].slice(0,1);case"qq":return Ho("Q%(quarter)s",{quarter:e.getQuarter()}).toString();case"qqqq":return Ho("Quarter %(quarter)s",{quarter:e.getQuarter()}).toString();case"yy":const s=String(e.getFullYear()).replace("-","").padStart(2,"0");return s.slice(s.length-2);case"yyyy":return e.getFullYear();case"hhhh":return Math.floor((e.getTime()-Xo.getTime())/36e5).toString();case"hh":let i=e.getHours();return o&&(i=0===i?12:i>12?i-12:i),i.toString().padStart(2,"0");case"MM":return e.getMinutes().toString().padStart(2,"0");case"ss":return e.getSeconds().toString().padStart(2,"0");case"a":return e.getHours()>=12?"PM":"AM";default:throw new Error(`invalid date format token: ${t}`)}}const Pn=Et((function(e){return new RegExp(`[0-9]+${Be(e.decimalSeparator)}[0-9]`)}));function Mn(e){let{integerDigits:t,decimalDigits:o}=Tn(e);if(!o)return"0";const s=t.replace("-","").length;if(s+2>Sn)return"0";const i=Sn-s-1;return({decimalDigits:o}=Tn(e,Math.min(i,o.length))),o?"0."+"0".repeat(o.length):"0"}function Nn(e,t){if(!cs(e,t))return;return ds(e,t).format}function kn(e){const t=e.includes(".")?"0.00":"0",o=e.match(/[\$€]/);if(o){const s=e.match(/[\d]/),i="[$"+o.values().next().value+"]";return s.index<o.index?"#,##"+t+i:i+"#,##"+t}if(e.includes("%"))return t+"%"}function Vn(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();return"after"===o&&s&&(r=" "+r),function(e,t,o){const s=`[$${e}]`;return"before"===t?s+o:o+s}(r,o,n)}function Ln(e){const t=e.decimalPlaces??2,o=e.position??"before",s=e.code??"",i=e.symbol??"",n="#,##0"+(t?"."+"0".repeat(t):"");let r=`${s} ${i}`.trim();"after"===o&&s&&(r=" "+r);return[Hn(r,o,` ${n} `),Hn(r,o,`(${n})`),Hn(r,o," - ")].join(";")}function Hn(e,t,o){const s=`[$${e}]`;return"before"===t?s+"* "+o:o+"* "+s}function Un(e){const t=gn(e);return vn({positive:Bn(t.positive),negative:t.negative?Bn(t.negative):void 0,zero:t.zero?Bn(t.zero):void 0,text:t.text})}function Bn(e){if("number"!==e.type||!e.decimalPart)return e;const t=e.decimalPart.filter((e=>"DIGIT"!==e.type));return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...t]}}function zn({value:e,format:t},o){return In(e,{format:$n({value:e,format:t},void 0,o),locale:o})}function $n(e,t,o){let s=0;try{s=Math.abs(fi(e?.value,o))}catch(e){return""}const i=e?.format;if(void 0!==t){const e=t?.value;switch(e){case"k":return Gn(i,1,"k");case"m":return Gn(i,2,"m");case"b":return Gn(i,3,"b");default:throw new si(Ho("The formatting unit should be 'k', 'm' or 'b'."))}}return s<1e5?Gn(i,0,""):s<1e8?Gn(i,1,"k"):s<1e11?Gn(i,2,"m"):Gn(i,3,"b")}function Gn(e,t,o,s){const i=gn(e||"#,##0");return vn({positive:Wn(i.positive,t,o),negative:i.negative?Wn(i.negative,t,o):void 0,zero:i.zero?Wn(i.zero,t,o):void 0,text:i.text})}function Wn(e,t,o){if("number"!==e.type)return e;const s={type:"STRING",value:o};let i=[...e.integerPart];const n=i.findLastIndex((e=>"DIGIT"===e.type));if(-1===n)throw new Error("Cannot create a large number format from a format with no digit.");for(;"THOUSANDS_SEPARATOR"===i[n+1]?.type;)i=Rt(i,[n+1]);const r=i[n+1];i="STRING"===r?.type&&["m","k","b"].includes(r.value)?At(i,s,n+1):Tt(i,[s],n+1),t>0&&(i=Tt(i,Array(t).fill({type:"THOUSANDS_SEPARATOR",value:","}),n+1));const a=e.percentSymbols-i.filter((e=>"PERCENT"===e.type)).length;return i.push(...new Array(a).fill({type:"PERCENT",value:"%"})),{...e,integerPart:i,decimalPart:void 0,magnitude:t}}function qn(e,t){const o=gn(e);return vn(gn(vn({positive:Zn(o.positive,t),negative:o.negative?Zn(o.negative,t):void 0,zero:o.zero?Zn(o.zero,t):void 0,text:o.text})))}function Zn(e,t){return"number"!==e.type?e:t>0?function(e,t){let o=e.integerPart,s=e.decimalPart;if(!s){const e=o.findLastIndex((e=>"DIGIT"===e.type));s=o.slice(e+1),o=o.slice(0,e+1)}const i=je(0,t).map((()=>({type:"DIGIT",value:"0"}))),n=s.findLastIndex((e=>"DIGIT"===e.type));s=-1===n?[...i,...s]:Tt(s,i,n+1);return{...e,decimalPart:s,integerPart:o}}(e,t):function(e,t){let o=e.decimalPart;if(!o)return e;const s=[];let i=0;for(let e=o.length-1;e>=0&&!(i>=Math.abs(t));e--)"DIGIT"===o[e].type&&(i++,s.push(e));if(o=Rt(o,s),o.some((e=>"DIGIT"===e.type)))return{...e,decimalPart:o};return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...o]}}(e,Math.abs(t))}function jn(e){const t=gn(e);for(const e of[t.positive,t.negative,t.zero])if(e&&"date"===e.type&&e.tokens.some((e=>"DATE_PART"===e.type&&e.value.includes("q"))))return!1;return!0}function Yn(e){if(!e)return!1;try{return"text"===gn(e).positive.type}catch{return!1}}function Xn(e,t){return Jn({value:Yn(t.format)&&null!==e.parsedValue?e.content:e.parsedValue,format:t.format},t.locale)}function Kn(e,t){if(e.startsWith("="))throw new Error(`Cannot parse "${e}" because it's not a literal value. It's a formula`);if(""===e)return null;if(Rs(e,qs))return As(e,qs);const o=ds(e,t);return o?o.value:Ke(e)?"TRUE"===e.toUpperCase():e}function Jn(e,t=qs,o){const s=jo(e.value);if(!s)return Qn(e,t,o);const i=Kn(s.label,t);return{...Qn({value:i,format:e.format||("number"==typeof i?Nn(s.label,t)||kn(s.label):void 0)},t,o),link:s}}function Qn(e,t,o){let{value:s,format:i,message:n}=e;i=o?.format||i;const r=In(s,{format:i,locale:t});return gi(s)?function(e,t){return{value:e,formattedValue:e,message:t,type:_s.error,isAutoSummable:!1,defaultAlign:"center"}}(s,n):null===s?tr(i):Yn(i)?er(wi(s),i,r):"number"==typeof s?On(i||"")?function(e,t,o){return{value:e,format:t,formattedValue:o,type:_s.number,isAutoSummable:!1,defaultAlign:"right"}}(s,i,r):function(e,t,o){return{value:e||0,format:t,formattedValue:o,type:_s.number,isAutoSummable:!0,defaultAlign:"right"}}(s,i,r):"boolean"==typeof s?function(e,t,o){return{value:e,format:t,formattedValue:o,type:_s.boolean,isAutoSummable:!1,defaultAlign:"center"}}(s,i,r):er(s,i,r)}function er(e,t,o){return{value:e,format:t,formattedValue:o,type:_s.text,isAutoSummable:!0,defaultAlign:"left"}}const tr=Et((function(e){return{value:null,format:e,formattedValue:"",type:_s.empty,isAutoSummable:!0,defaultAlign:"left"}}));function or(e){const t=Yo.now();switch(e){case"today":return ps(t);case"yesterday":return ps(Yo.fromTimestamp(t.setDate(t.getDate()-1)));case"tomorrow":return ps(Yo.fromTimestamp(t.setDate(t.getDate()+1)));case"lastWeek":return ps(Yo.fromTimestamp(t.setDate(t.getDate()-7)));case"lastMonth":return ps(Yo.fromTimestamp(t.setMonth(t.getMonth()-1)));case"lastYear":return ps(Yo.fromTimestamp(t.setFullYear(t.getFullYear()-1)))}}function sr(e,t){return"dateValue"in e&&"exactDate"!==e.dateValue?[or(e.dateValue)]:e.values.map((e=>ls(e,t)))}function ir(e,t){return e.map((e=>{if(e.startsWith("="))return e;const o=Kn(e,t);return"number"==typeof o?In(o,{format:t.dateFormat,locale:t}):""}))}function nr(e,t=[]){if(e.length<=1&&0===t.length)return e;const o=[0],s=new Map([[0,[]]]);return rr(o,s,e,!1),rr(o,s,t,!0),function(e,t){const o=[];let s=[];for(let i=0;i<e.length;i++){const n=e[i],r=t.get(n);if(!r||0===r.length){o.push(...s),s=[];continue}let a=e[i+1];void 0!==a&&a--;const l=[];for(let e=0;e<r.length;e+=2){const t=r[e];let o=r[e+1];void 0!==o&&o--;const i={top:t,left:n,bottom:o,right:a,hasHeader:void 0===o&&0!==t||void 0===a&&0!==n};let c=!1;for(let e=s.length-1;e>=0;e--){const t=s[e];if(t.top===i.top&&t.bottom===i.bottom){t.right=i.right,s.splice(e,1),l.push(t),c=!0;break}}c||l.push(i)}o.push(...s),s=l}return o.push(...s),o}(o,s)}function rr(e,t,o,s=!1){for(const i of o){const o=i.left,n=void 0===i.right?void 0:i.right+1,r=ar(e,t,o,!0,0),a=ar(e,t,n,!1,r);for(let o=r;o<=a;o++){lr(t.get(e[o]),i,s)}cr(e,t,r,a)}}function ar(e,t,o,s,i){if(void 0===o)return e.length-1;const n=hr(e,o,i);return o!==e[n]?(e.splice(n+1,0,o),t.set(o,[...t.get(e[n])]),s?n+1:n):s?n:n-1}function lr(e,t,o=!1){const s=t.top,i=void 0===t.bottom?void 0:t.bottom+1,n=[],r=hr(e,s,0,!1);if((r%2!=0&&!o||r%2==0&&o)&&n.push(s),void 0===i)return e.splice(r+1),void e.push(...n);const a=function(e,t,o=0,s=!0){let i=e.length-1,n=e.length;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]>t?(n=r,i=r-1):o=r+1}return n}(e,i,0,!1);(a%2==0&&!o||a%2!=0&&o)&&n.push(i),e.splice(r+1,a-r-1,...n)}function cr(e,t,o,s){const i=o-1==-1?0:o-1;for(let o=s===e.length-1?s:s+1;o>i;o--)ft(t.get(e[o]),t.get(e[o-1]))&&(t.delete(e[o]),e.splice(o,1))}function hr(e,t,o=0,s=!0){let i=e.length-1,n=-1;for(;o<=i;){const r=Math.floor((o+i)/2);if(e[r]===t&&s)return r;e[r]<t?(n=r,o=r+1):i=r-1}return n}function dr(e){const t=function(e){const t=new Mt(e);Do(t);const o=e.indexOf("!");-1!==o&&t.advanceBy(o+1);const s=_o(t),i=Oo(t);let n,r,a,l,c=!1,h=!1,d=!1;if(-1===i?(a=l=s-1,n=r=0,c=!0):-1===s?(n=r=i-1,a=l=0,h=!0):(a=l=s-1,n=r=i-1,d=!0),Do(t),":"===t.current){t.advanceBy(1),Do(t);const e=_o(t),o=Oo(t);-1===o?(l=e-1,c=!0):-1===e?(r=o-1,h=!0):(l=e-1,r=o-1,n=c?r:n,a=h?l:a,d=!0)}const u={top:n,left:a,bottom:c?void 0:r,right:h?void 0:l};return d=d&&(h||c),d&&(u.hasHeader=d),u}(e),o=Or(t),s=o.bottom,i=o.right;if(void 0!==s&&s>Ao||void 0!==i&&i>To)throw new Error(`Range string out of bounds: ${e}`);if(void 0===s&&void 0===i)throw new Error("Wrong zone xc. The zone cannot be at the same time a full column and a full row");return o}function ur(e){const t=dr(e);if(void 0===t.bottom||void 0===t.right)throw new Error("This does not support unbounded ranges");return t}function gr(e){try{return function(e){return pr(dr(e))}(e)}catch(e){return!1}}function pr(e){const{bottom:t,top:o,left:s,right:i}=e;return!(void 0!==t&&isNaN(t)||isNaN(o)||isNaN(s)||void 0!==i&&isNaN(i))&&(mr(e)&&e.top>=0&&e.left>=0)}function mr(e){return(void 0===e.bottom||e.bottom>=e.top&&e.bottom>=0)&&(void 0===e.right||e.right>=e.left&&e.right>=0)}function fr(e){const{top:t,bottom:o,left:s,right:i}=e,n="hasHeader"in e&&e.hasHeader,r=t===o&&s===i;if(void 0===o&&void 0!==i)return 0!==t||n?`${Po(s,t)}:${wo(i)}`:`${wo(s)}:${wo(i)}`;if(void 0===i&&void 0!==o)return 0!==s||n?`${Po(s,t)}:${o+1}`:`${t+1}:${o+1}`;if(void 0!==o&&void 0!==i)return r?Po(s,t):`${Po(s,t)}:${Po(i,o)}`;throw new Error("Bad zone format")}function vr(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a=e["left"===t?"right":"bottom"];return e[t]<=r&&a&&a>r?Fr(e,n,"RESIZE",i):r<e[t]?Fr(e,n,"MOVE",i):{...e}}function br(e,t,o,s,i){const n="left"===t?"columns":"rows",r="before"===s?o-1:o,a="left"===t?"right":"bottom";return e[t]<=r&&e[a]>r?Fr(e,n,"RESIZE",i):r<e[t]?Fr(e,n,"MOVE",i):{...e}}function Sr(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];for(const r of o.sort(((e,t)=>t-e)))e[t]>r&&(i--,n--),e[t]<r&&e[s]>=r&&n--;return{...e,[t]:i,[s]:n}}function Cr(e,t,o){const s="left"===t?"right":"bottom";let i=e[t],n=e[s];const r=e[s];for(const s of o.sort(((e,t)=>t-e)))e[t]>s&&(i--,void 0!==n&&n--),void 0!==r&&void 0!==n&&e[t]<=s&&r>=s&&n--;if(!(void 0!==n&&i>n))return{...e,[t]:i,[s]:n}}function yr(...e){return{top:Math.min(...e.map((e=>e.top))),left:Math.min(...e.map((e=>e.left))),bottom:Math.max(...e.map((e=>e.bottom))),right:Math.max(...e.map((e=>e.right)))}}function wr(e,t){if(xr(e,t))return{top:Math.max(e.top,t.top),left:Math.max(e.left,t.left),bottom:Math.min(e.bottom,t.bottom),right:Math.min(e.right,t.right)}}function Ir(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom}function xr(e,t){return!(e.bottom<t.top||t.bottom<e.top)&&!(e.right<t.left||t.right<e.left)}function Er(e,t,o){const{left:s,right:i,top:n,bottom:r}=o;return e>=s&&e<=i&&t>=n&&t<=r}function Rr(e,t){return Ir(yr(t,e),t)}function Tr(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function Ar(e){const{numberOfCols:t,numberOfRows:o}=Tr(e);return 1===t||1===o}function Dr(e){const t={};for(const o of e)t[o.sheetId]??=[],t[o.sheetId].push(Mr(o));for(const e in t)t[e]=nr(t[e]);return t}function _r(e){const t=[],{left:o,right:s,top:i,bottom:n}=Or(e);for(const e of je(o,s+1))for(const o of je(i,n+1))t.push({col:e,row:o});return t}function Or(e){return void 0!==e.right&&e.left>e.right&&(e={...e,left:e.right,right:e.left}),void 0!==e.bottom&&e.top>e.bottom&&(e={...e,top:e.bottom,bottom:e.top}),e}function Fr(e,t,o,s){const i="both"===t?s[0]:"columns"===t?s:0,n="both"===t?s[1]:"rows"===t?s:0,r="hasHeader"in e&&e.hasHeader;let a;a=Vr(e)&&!r?"rows"!==t:!(kr(e)&&!r)||"columns"!==t;const l={...e};return a&&"MOVE"===o&&(l.left+=i,l.top+=n),void 0!==l.right&&(l.right+=i),void 0!==l.bottom&&(l.bottom+=n),l}function Pr(e,t){let o,s;const{left:i,right:n,top:r,bottom:a}=e,{left:l,right:c,top:h,bottom:d}=t;return o=l!==i?l:c!==n?c:l,s=h!==r?h:d!==a?d:h,{col:o,row:s}}function Mr(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function Nr(e){return{...e,right:e.left,bottom:e.top}}function kr(e){return void 0===e.right}function Vr(e){return void 0===e.bottom}function Lr(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function Hr(e,t,o){return e.some((e=>function(e,t,o){return e.left<t&&t<=e.right||e.top<o&&o<=e.bottom}(e,t,o)))}function Ur(e){return e.length<2||1===nr(e).length}function Br(e){const t=[...e];let o=!0;for(;o;){o=!1;for(let e=0;e<t.length;e++){const s=t[e],i=t.findIndex(((t,o)=>{return e!==o&&(n=s,((i=t).right+1===n.left||i.left===n.right+1?i.top<=n.bottom&&i.top>=n.top||n.top<=i.bottom&&n.top>=i.top:(i.bottom+1===n.top||i.top===n.bottom+1)&&(i.left<=n.right&&i.left>=n.left||n.left<=i.right&&n.left>=i.left))||xr(t,s));var i,n}));if(-1!==i){t[e]=yr(t[i],s),t.splice(i,1),o=!0;break}}}return t}const zr=new WeakMap,$r=new WeakMap;function Gr(e,t){zr.has(t)||(zr.set(t,new Map),$r.set(t,0));const o=zr.get(t),s=Zr(e);if(o.has(s)){const i=o.get(s);return t[i]=e,i}const i=$r.get(t)+1;return o.set(s,i),$r.set(t,i),t[i]=e,i}function Wr(e){const t={};for(const o in e){const s=nr(e[o].map(Mr));for(const e of s)t[fr(e)]=Number(o)}return t}function*qr(e,t){for(const o in t){const s=ur(o),i=t[o];for(let t=s.top;t<=s.bottom;t++)for(let o=s.left;o<=s.right;o++){const s={sheetId:e,col:o,row:t};yield[s,i]}}}function Zr(e){if(null===e)return"null";if(void 0===e)return"undefined";if("object"!=typeof e)return String(e);if(Array.isArray(e)){const t=e.length;let o="[";for(let s=0;s<t;s++)s>0&&(o+=","),o+=Zr(e[s]);return o+"]"}const t=Object.keys(e).sort();let o="{";for(const s of t)void 0!==e[s]&&(o+=`"${s}":${Zr(e[s])},`);return o+="}",o}function jr(e){return 20+120*Math.exp(-.035*(e-1))}const Yr=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,"i"),Xr=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,"i"),Kr=new RegExp(/^\$?([A-Z]{1,3})+$/,"i"),Jr=new RegExp(/^\$?([0-9]{1,7})+$/,"i"),Qr=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,"i"),ea=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,"i"),ta=new RegExp(/^\s*('.+'!|[^']+!)?/.source+"("+[Yr.source,/(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*:\s*(\$?[A-Z]{1,3})?\$?[0-9]{1,7}\s*/i.source,/\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*:\s*\$?[A-Z]{1,3}(\$?[0-9]{1,7})?\s*/i.source].join("|")+")"+/$/.source,"i");function oa(e){return ea.test(e)}function sa(e){return Kr.test(e)}function ia(e){return Jr.test(e)}function na(e){return Xr.test(e)}function ra(e){if(!e.includes("!"))return{xc:e};const t=e.split("!"),o=t.pop();return{sheetName:$e(t.join("!"))||void 0,xc:o}}function aa(e,t){return void 0!==e?`${We(e)}!${t}`:t}function la(e){const t=[];for(let o=0;o<e;o++){const e={cells:{}};t.push(e)}return t}function ca(e,t,o){return o.map((o=>o>=e?o+t:o))}function ha(e,t){return e=[...e].sort(((e,t)=>t-e)),t.map((t=>{for(const o of e)if(t>o)t--;else if(t===o)return;return t})).filter(lt)}function da(e,t="Sheet"){let o=1,s=`${t}${o}`;for(;e.includes(s);)s=`${t}${o}`,o++;return s}function ua(e,t){let o=1;const s=Ho("Copy of %s",e);let i=s.toString();for(;t.includes(i);)i=`${s} (${o})`,o++;return i}function ga(e,t){return void 0!==e&&void 0!==t&&$e(e.trim().toUpperCase())===$e(t.trim().toUpperCase())}function pa(e,t){const o=e.zone,s=function(e,t){const{left:o,top:s,bottom:i,right:n}=e;if(void 0!==n&&void 0!==i)return e;if(void 0===i&&void 0!==n)return{right:n,top:s,left:o,bottom:t.numberOfRows-1};if(void 0===n&&void 0!==i)return{bottom:i,left:o,top:s,right:t.numberOfCols-1};throw new Error("Bad zone format")}(o,t(e.sheetId));let i=e.parts;return 1===e.parts.length&&Lr(s)>1?i=[e.parts[0],e.parts[0]]:2===e.parts.length&&1===Lr(s)&&(i=[e.parts[0]]),{unboundedZone:o,zone:s,parts:i,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function ma(e,t){const o=e.xc,{xc:s,sheetName:i}=ra(o),n=dr(s),r=function(e,t){const o=e.split(":").map((e=>{const t=oa(e);return{colFixed:!t&&e.startsWith("$"),rowFixed:t?e.startsWith("$"):e.includes("$",1)}})),s=void 0===t.bottom,i=void 0===t.right;s&&(o[0].rowFixed=o[0].rowFixed||o[1].rowFixed,o[1].rowFixed=o[0].rowFixed||o[1].rowFixed);i&&(o[0].colFixed=o[0].colFixed||o[1].colFixed,o[1].colFixed=o[0].colFixed||o[1].colFixed);return o}(s,n);return pa({zone:n,parts:r,sheetId:e.sheetId,prefixSheet:Boolean(i),invalidSheetName:e.invalidSheetName},t)}function fa(e){const t={left:-1,top:-1,right:-1,bottom:-1};return{sheetId:"",zone:t,unboundedZone:t,parts:[],invalidXc:e,prefixSheet:!1}}function va(e){return Vr(e.unboundedZone)}function ba(e){return kr(e.unboundedZone)}function Sa(e,t,o,s={useBoundedReference:!1,useFixedReference:!1}){if(e.invalidXc)return e.invalidXc;if(e.zone.bottom-e.zone.top<0||e.zone.right-e.zone.left<0)return ti.InvalidReference;if(e.zone.left<0||e.zone.top<0)return ti.InvalidReference;const i=e.sheetId!==t||e.invalidSheetName||e.prefixSheet;let n="";if(i&&(n=e.invalidSheetName?e.invalidSheetName:We(o(e.sheetId))),i&&!n)return ti.InvalidReference;let r=Oa(e,0,s);return e.parts&&2===e.parts.length&&(e.zone.top!==e.zone.bottom||e.zone.left!==e.zone.right||e.parts[0].rowFixed||e.parts[0].colFixed||e.parts[1].rowFixed||e.parts[1].colFixed)&&(r+=":",r+=Oa(e,1,s)),`${i?n+"!":""}${r}`}function Ca(e,t,o){const s=o.sheetId===e?t:o.sheetId;return{...o,sheetId:s}}function ya(e,t,o){if(!o)return;const s=e.getRangeFromSheetXC(t,o);return s.invalidSheetName||s.invalidXc?void 0:s}function wa(e){const t=[];for(const o of e)for(const e of _r(o.zone))t.push({...e,sheetId:o.sheetId});return t}function Ia(e){return xa.get(e.type)?.(e)}const xa=new class extends n{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};function Ea(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows",i=[...e.elements];i.sort(((e,t)=>t-e));const n=Ye(i);return i=>{if(!ga(i.sheetId,e.sheetId))return{changeType:"NONE"};let r=i,a="NONE";for(const e of n){const n=Pt(e),l=Ft(e);if(i.zone[t]<=n&&n<=i.zone[o]){const e=Math.min(i.zone[o],l)-n+1;a="RESIZE",r=_a(r,s,a,-e)}else if(i.zone[t]>=n&&i.zone[o]<=l)a="REMOVE",r=fa(ti.InvalidReference);else if(i.zone[t]<=l&&i.zone[o]>=l){const e=l-i.zone[t]+1;a="RESIZE",r=_a(r,s,a,-e),r=_a(r,s,"MOVE",-(i.zone[t]-n))}else n<i.zone[t]&&(a="MOVE",r=_a(r,s,a,-(l-n+1)))}return"NONE"!==a?{changeType:a,range:r}:{changeType:"NONE"}}}function Ra(e){const t="COL"===e.dimension?"left":"top",o="COL"===e.dimension?"right":"bottom",s="COL"===e.dimension?"columns":"rows";return 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:_a(i,s,"RESIZE",e.quantity)};if(e.base<i.zone[t])return{changeType:"MOVE",range:_a(i,s,"MOVE",e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[o])return{changeType:"RESIZE",range:_a(i,s,"RESIZE",e.quantity)};if(e.base<=i.zone[t])return{changeType:"MOVE",range:_a(i,s,"MOVE",e.quantity)}}return{changeType:"NONE"}}}function Ta(e){return t=>{if(t.sheetId!==e.sheetId&&t.invalidSheetName!==e.sheetName)return{changeType:"NONE"};const o=e.sheetName;return{changeType:"REMOVE",range:t={...fa(ti.InvalidReference),invalidSheetName:o}}}}function Aa(e){return t=>{if(t.sheetId===e.sheetId)return{changeType:"CHANGE",range:t};if(e.newName&&t.invalidSheetName===e.newName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}if(e.oldName&&t.invalidSheetName===e.oldName){const o=void 0,s=e.sheetId;return{changeType:"CHANGE",range:{...t,sheetId:s,invalidSheetName:o}}}return{changeType:"NONE"}}}function Da(e){const t=e.target[0];return o=>{if(o.sheetId!==e.sheetId||!Rr(o.zone,t))return{changeType:"NONE"};const s=e.targetSheetId,i=_a(o,"both","MOVE",[e.col-t.left,e.row-t.top]),n=e.sheetId!==s||i.prefixSheet;return{changeType:"MOVE",range:{...i,sheetId:s,prefixSheet:n}}}}function _a(e,t,o,s){return{...e,unboundedZone:Fr(e.unboundedZone,t,o,s),zone:Fr(e.zone,t,o,s)}}function Oa(e,t,o={useBoundedReference:!1,useFixedReference:!1}){const s=e.parts[t]?.colFixed||o.useFixedReference?"$":"",i=wo(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=Vr(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:s+i:kr(e.unboundedZone)&&!o.useBoundedReference?0===t&&e.unboundedZone.hasHeader?s+i+n+r:n+r:s+i+n+r,a}function Fa(e,t,o){const s=[];return t.forEach((t=>{const i=function(e,t){e=e.toLocaleLowerCase();let o=0,s=0;const i=(t=t.toLocaleLowerCase()).length;let n=0;for(let r=0;r<i;r++)t[r]===e[n]?(n++,s+=100+s-r/200):s=0,o+=s;return n===e.length?o:0}(e,o(t));i>0&&s.push({score:i,elem:t})})),s.sort(((e,t)=>t.score-e.score)),s.map((e=>e.elem))}function Pa(e,t=1){return t*(e+re)-re}function Ma(e,t,o,s){const i=Wa(e,t,o,"wrap"===o?.wrapping?s-2*re:void 0).length;return Pa($a(o),i)+2*ae}function Na(e,t=!1,o=!1){return`${o?"italic":""} ${t?"bold":""} ${e}px ${fe}`}xa.add("REMOVE_COLUMNS_ROWS",(e=>({applyChange:Ea(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("ADD_COLUMNS_ROWS",(e=>({applyChange:Ra(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("DELETE_SHEET",(e=>({applyChange:Ta(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}))).add("RENAME_SHEET",(e=>({applyChange:Aa(e),sheetId:e.sheetId,sheetName:{old:e.oldName,current:e.newName}}))).add("MOVE_RANGES",(e=>({applyChange:Da(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})));const ka={};function Va(e,t,o,s="pt"){return La(e,t,za(o,s))}function La(e,t,o){if(ka[o]||(ka[o]={}),void 0===ka[o][t]){const s=e.font;e.font=o,ka[o][t]=e.measureText(t).width,e.font=s}return ka[o][t]}const Ha={};function Ua(e,t,o,s="pt"){const i=za(o,s);e.save(),e.font=i;const n=function(e,t){const o=e.font;Ha[o]||(Ha[o]={});if(void 0===Ha[o][t]){const s=e.measureText(t),i=s.width,n=s.fontBoundingBoxAscent+s.fontBoundingBoxDescent;Ha[o][t]={width:i,height:n}}return Ha[o][t]}(e,t);return e.restore(),n}function Ba(e){return Math.round(96*e/72)}function za(e,t="pt"){return`${e.italic?"italic ":""}${e.bold?"bold":pe} ${("pt"===t?$a(e):e.fontSize)??me}px ${fe}`}function $a(e){return Ba(e?.fontSize||me)}function Ga(e,t,o,s){if(Va(e,t,s)<=o)return[t];const i=[];let n="";for(const r of t){Va(e,n+r,s)>o?(i.push(n),n=r):n+=r}return i.push(n),i}function Wa(e,t,o,s){o||(o={}),et(t)&&(t=st(t).label);const i=[],n=t.includes(Ne)?t.split(Ne):[t];for(const t of n){const n=t.includes(" ")?t.split(" "):[t];if(!s){i.push(t);continue}let r="",a=s;for(const t of n){const n=Ga(e,t,s,o),l=n.pop(),c=Va(e,l,o);if(n.length)""!==r&&(i.push(r),r="",a=s),n.forEach((e=>{i.push(e)})),r=l,a=s-c;else{const t=""===r?l:" "+l,n=Va(e,t,o);n<=a?(r+=t,a-=n):(i.push(r),r=l,a=s-c)}}""!==r&&i.push(r)}return i}function qa(e){return e?e.toLowerCase():""}const Za=/([0-9\.]*)px/;function ja(e,t,o){let s=La(e,t,e.font);if(s<=o)return t;const i=La(e,"…",e.font);if(s<=i)return t;let n=t.length;for(;s>=o-i&&n-- >0;)s=La(e,t=t.substring(0,n),e.font);return t+"…"}function Ya(e,t,o,s=!1,i=!1,n=function(e){return Number(e.match(Za)?.[1])}(e.font)/10){if(e.fillText(t,o.x,o.y),!s&&!i)return;const r=e.measureText(t),a=r.width,l=r.actualBoundingBoxAscent+r.actualBoundingBoxDescent,c=r.fontBoundingBoxAscent+r.fontBoundingBoxDescent;let{x:h,y:d}=o,u=d,g=d;switch(e.textAlign){case"center":h-=a/2;break;case"right":h-=a}switch(e.textBaseline){case"top":g+=c-2*n,u+=c/2-n;break;case"middle":g+=c/2-n;break;case"alphabetic":g+=2*n,u-=3*n;break;case"bottom":g=d,u-=l/2-n/2}s&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,g),e.lineTo(h+a,g),e.stroke()),i&&(e.lineWidth=n,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(h,u),e.lineTo(h+a,u),e.stroke())}function Xa(e,t,o,s,i="pt"){if(Va(e,o,s,i)<=t)return o;const n=Va(e,"...",s,i);if(n>=t)return"";let r,a=1,l=o.length;for(;a<=l;){const c=Math.floor((a+l)/2);r=Va(e,o.slice(0,c),s,i),r+n>t?l=c-1:a=c+1}const c=o.slice(0,Math.max(0,a-1));return c?c+"...":""}class Ka{smallUuid(){return window.crypto?"10000000-1000".replace(/[01]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}uuidv4(){return window.crypto?"10000000-1000-4000-8000-100000000000".replace(/[018]/g,(e=>{const t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)})):"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,(function(e){const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)}))}}const Ja=["image/avif","image/bmp","image/gif","image/vnd.microsoft.icon","image/jpeg","image/png","image/tiff","image/webp"];function Qa(e,t){const o=new Set(t.map((e=>e.left))),s=new Set(t.map((e=>e.right))),i=new Set(t.map((e=>e.top))),n=new Set(t.map((e=>e.bottom))),r=1===i.size&&1===n.size||1===o.size&&1===s.size?function(e){return e.reduce(((e,t)=>{const o=e.length;for(let s=0;s<o;s++)if(xr(e[s],t))return e[s]=yr(e[s],t),e;return e[o]=t,e}),[])}(t):[t[t.length-1]],a=r.map((e=>_r(e))).flat();return{sheetId:e,zones:t,clippedZones:r,columnsIndexes:[...new Set(a.map((e=>e.col)))].sort(((e,t)=>e-t)),rowsIndexes:[...new Set(a.map((e=>e.row)))].sort(((e,t)=>e-t))}}function el(e,t){if(!t.length||!t[0].length)return e;const o=t[0].length,s=t.length;return e.map((e=>function(e,t,o){const s=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-o+1,e.top),n=[];for(let r=e.left;r<=s;r+=t)for(let s=e.top;s<=i;s+=o)n.push({left:r,top:s,bottom:s+o-1,right:r+t-1});return n}(e,o,s))).flat()}function tl(e){let t;if(e[Os.Html]){t=function(e){const t=[...e.documentElement.attributes];if(t.some((e=>e.value.includes("microsoft"))))return;const o=e.querySelector("div")?.getAttribute("data-osheet-clipboard");return o&&JSON.parse(o)}((new DOMParser).parseFromString(e[Os.Html],"text/html"))}const o=e[Os.PlainText]||"";let s;if(!o.trim())for(const t of Ja)if(e[t]){s=e[t];break}return{text:o,data:t,imageBlob:s}}const ol=(e,t,o,s)=>{e.forEach((({handlerName:e,handler:i})=>{const n=t[e];n&&i.paste(o,n,s)}))};function sl(e,t,o,s,i){let n;const r=[],a={sheetId:e,zones:t};for(const{handlerName:l,handler:c}of s){const s=o[l];if(!s)continue;const h=c.getPasteTarget(e,t,s,i);h.figureId&&(a.figureId=h.figureId);for(const e of h.zones)r.push(e),n=void 0!==n?yr(n,e):e}return{target:a,zone:n,selectedZones:r}}const il=(e,t,o)=>{const s={col:t[0].left,row:t[0].top};e.getBackToDefault(),e.selectZone({cell:s,zone:yr(...o)},{scrollIntoView:!1})};class nl{getters;dispatch;constructor(e,t){this.getters=e,this.dispatch=t}copy(e,t,o="copyPaste"){}paste(e,t,o){}isPasteAllowed(e,t,o,s){return"Success"}isCutAllowed(e){return"Success"}getPasteTarget(e,t,o,s){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}}class rl extends nl{copy(e,t,o="copyPaste"){}pasteFromCopy(e,t,o,s){if(1===t.length)for(const i of el(t,o))this.pasteZone(e,i.left,i.top,o,s);else for(const i of nr(t))for(let t=i.left;t<=i.right;t++)for(let n=i.top;n<=i.bottom;n++)this.pasteZone(e,t,n,o,s)}pasteZone(e,t,o,s,i){}}const al=["%"],ll="+,-,*,/,:,=,<>,>=,>,<=,<,^,&".split(",").concat(al);function cl(e,t=qs){e=It(e);const o=new Mt(e),s=[],i=Ct.test(e)?yl:wl;for(;!o.isOver();){let e=Il(o)||i(o)||gl(o,t)||ul(o)||pl(o)||vl(o)||hl(o)||xl(o)||fl(o,t)||Cl(o);e||(e={type:"UNKNOWN",value:o.shift()}),s.push(e)}return s}function hl(e){return"?"===e.current?(e.shift(),{type:"DEBUGGER",value:"?"}):null}const dl={"(":{type:"LEFT_PAREN",value:"("},")":{type:"RIGHT_PAREN",value:")"}};function ul(e){if("("===e.current||")"===e.current){const t=e.shift();return dl[t]}return null}function gl(e,t){if(e.current===t.formulaArgSeparator){return{type:"ARG_SEPARATOR",value:e.shift()}}return null}function pl(e){for(const t of ll)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:"OPERATOR",value:t};return null}const ml=new Set("0123456789");function fl(e,t){if(!ml.has(e.current)&&e.current!==t.decimalSeparator)return null;const o=e.remaining().match(xs(t.decimalSeparator));return o?(e.advanceBy(o[0].length),{type:"NUMBER",value:o[0]}):null}function vl(e){if('"'===e.current){const t=e.shift();let o=t;for(;e.current&&(e.current!==t||"\\"===o[o.length-1]);)o+=e.shift();return'"'===e.current&&(o+=e.shift()),{type:"STRING",value:o}}return null}const bl=/\p{L}|\p{N}|_|\.|!|\$/u,Sl=new Set("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$");function Cl(e){let t="";if("'"===e.current){let o=e.shift();for(t+=o;e.current;)if(o=e.shift(),t+=o,"'"===o){if(!e.current||"'"!==e.current)break;o=e.shift(),t+=o}if("'"!==o)return{type:"UNKNOWN",value:t}}for(;e.current&&(Sl.has(e.current)||e.current.match(bl));)t+=e.shift();if(t.length){const e=t;return ta.test(e)?{type:"REFERENCE",value:e}:{type:"SYMBOL",value:e}}return null}function yl(e){let t="";for(;" "===e.current||e.current&&e.current.match(Ct);)t+=e.shift();return t?{type:"SPACE",value:t}:null}function wl(e){let t="";for(;" "===e.current;)t+=e.shift();return t?{type:"SPACE",value:t}:null}function Il(e){let t=0;for(;e.current===Ne;)t++,e.shift();return t?{type:"SPACE",value:Ne.repeat(t)}:null}function xl(e){return e.currentStartsWith(ti.InvalidReference)?(e.advanceBy(ti.InvalidReference.length),{type:"INVALID_REFERENCE",value:ti.InvalidReference}):null}function El(e){if(!e||"object"!=typeof e||e.thousandsSeparator&&"string"!=typeof e.thousandsSeparator)return!1;for(const t of["code","name","decimalSeparator","dateFormat","timeFormat","formulaArgSeparator"])if(!e[t]||"string"!=typeof e[t])return!1;if(e.formulaArgSeparator===e.decimalSeparator)return!1;if(e.thousandsSeparator===e.decimalSeparator)return!1;try{In(1,{locale:e,format:"#,##0.00"}),In(1,{locale:e,format:e.dateFormat}),In(1,{locale:e,format:e.timeFormat})}catch{return!1}return!0}function Rl(e,t){return Lt(e)?_l(e,t):Pl(e,t)}function Tl(e,t){return Lt(e)?_l(e,t):function(e,t){if(cs(e,t)){const o=fi(e,t);let s=qs.dateFormat;return Number.isInteger(o)||(s+=" "+qs.timeFormat),In(o,{locale:qs,format:s})}return Pl(e,t)}(e,t)}function Al(e,t){return e.startsWith("=")?Ol(e,t):function(e,t){if(cs(e,qs)){const o=fi(e,qs);let s=t.dateFormat;return Number.isInteger(o)||(s+=" "+t.timeFormat),In(o,{locale:t,format:s})}return function(e,t){if("."===t.decimalSeparator||!Rs(e,qs))return e;const o=Pn(qs);return e.replace(o,(e=>e.replace(".",t.decimalSeparator)))}(e,t)}(e,t)}function Dl(e,t){return Lt(e)?_l(e,t):Pl(e,t)}function _l(e,t){return Fl(e.startsWith("+")?"="+e.slice(1):e,t,qs)}function Ol(e,t){return Fl(e,qs,t)}function Fl(e,t,o){if(t.formulaArgSeparator===o.formulaArgSeparator&&t.decimalSeparator===o.decimalSeparator)return e;const s=cl(e,t);let i="";for(const e of s)"NUMBER"===e.type?i+=e.value.replace(t.decimalSeparator,o.decimalSeparator):"ARG_SEPARATOR"===e.type?i+=o.formulaArgSeparator:i+=e.value;return i}function Pl(e,t){return"."!==t.decimalSeparator&&Rs(e,t)?(t.thousandsSeparator&&(e=e.replaceAll(t.thousandsSeparator,"")),e.replace(t.decimalSeparator,".")):e}function Ml(e,t){return Vl(e,(e=>Tl(e,t)))}function Nl(e,t){return Vl(e,(e=>Al(e,t)))}function kl(e,t){const o=ze(e);return o.criterion.values=o.criterion.values.map((e=>Al(e,t))),o}function Vl(e,t){switch((e=ze(e)).type){case"CellIsRule":switch(e.operator){case"isBetween":case"isNotBetween":case"isEqual":case"isNotEqual":case"isGreaterThan":case"isGreaterOrEqualTo":case"isLessThan":case"isLessOrEqualTo":return e.values=e.values.map((e=>t(e))),e;case"beginsWithText":case"containsText":case"endsWithText":case"notContainsText":case"isEmpty":case"isNotEmpty":return e}case"DataBarRule":return e;case"ColorScaleRule":return e.minimum=Ll(e.minimum,t),e.maximum=Ll(e.maximum,t),e.midpoint&&(e.midpoint=Ll(e.midpoint,t)),e;case"IconSetRule":return e.lowerInflectionPoint.value=t(e.lowerInflectionPoint.value),e.upperInflectionPoint.value=t(e.upperInflectionPoint.value),e}}function Ll(e,t){if(!e?.value)return e;const o=t("formula"===e.type?"="+e.value:e.value),s="formula"===e.type?o.slice(1):o;return{...e,value:s}}function Hl(e){return e.dateFormat+" "+e.timeFormat}function Ul(e){let t=!1,o=!0;return Hi(e,(e=>(t=!0,o=o&&e,o))),{foundBoolean:t,result:o}}function Bl(e){let t=!1,o=!1;return Hi(e,(e=>(t=!0,o=o||e,!o))),{foundBoolean:t,result:o}}function zl(e,t){return Pi(e,((e,t)=>e+t),0,t)}function $l(e){return Fi(e,((e,t)=>Xi(t)?e.add(t?.value):e),new Set).size}function Gl(e,t){if(!e)throw new si(t)}function Wl(e,t=Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")){if(0===e)throw new hi(t)}function ql(e){return 1===e.length||1===e[0].length}function Zl(...e){if(e.every(js)){const t=e[0].length,o=e[0][0].length;for(const s of e)if(s.length!==t||s[0].length!==o)return!1;return!0}return!e.some((e=>Array.isArray(e)&&(1!==e.length||1!==e[0].length)))}function jl(e){return e.length===e[0].length}const Yl=e=>Ho("The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.",e);function Xl(e){const t=Array(e);for(let o=0;o<e;o++)t[o]=Array(e).fill(0),t[o][o]=1;return t}function Kl(e){if(e.length<1||e[0].length<1)throw new Error("invertMatrix: an empty matrix cannot be inverted.");if(e.length!==e[0].length)throw new Error("invertMatrix: only square matrices are invertible");let t=1;const o=e.length,s=Xl(o),i=e.map((e=>e.slice()));for(let e=0;e<o;e++){let n=i[e][e];if(0===n){for(let n=e+1;n<o;n++)if(0!==i[e][n]){Jl(i,e,n),Jl(s,e,n),t*=-1;break}if(n=i[e][e],0===n)return{determinant:0}}for(let t=0;t<o;t++)i[t][e]=i[t][e]/n,s[t][e]=s[t][e]/n;t*=n;for(let t=0;t<o;t++){if(t===e)continue;const n=i[e][t];for(let r=0;r<o;r++)i[r][t]-=n*i[r][e],s[r][t]-=n*s[r][e]}}return{inverted:s,determinant:t}}function Jl(e,t,o){for(let s=0;s<e.length;s++){const i=e[s][t];e[s][t]=e[s][o],e[s][o]=i}}function Ql(e,t){if(e.length<1||t.length<1)throw new Error("multiplyMatrices: empty matrices cannot be multiplied.");if(e.length!==t[0].length)throw new Error("multiplyMatrices: incompatible matrices size.");const o=e[0].length,s=t.length,i=e.length,n=Array(s);for(let r=0;r<s;r++){n[r]=Array(o);for(let s=0;s<o;s++){let o=0;for(let n=0;n<i;n++)o+=e[n][s]*t[r][n];n[r][s]=o}}return n}function ec(e){if(!js(e))return e;if(!tc(e))throw new Error("The value should be a scalar or a 1x1 matrix");return e[0][0]}function tc(e){return 1===e.length&&1===e[0].length}function oc(e){return js(e)&&!tc(e)}function sc(...e){const t=e[0].length;e.forEach(((e,o)=>Gl(e.length===t,Ho("[[FUNCTION_NAME]] has mismatched dimensions for argument %s (%s vs %s).",o.toString(),t.toString(),e.length.toString()))))}function ic(e,t){let o=0;const s=Pi(e,((e,t)=>(o+=1,e+t)),0,t);return Wl(o),s/o}function nc(e,t){let o=0;for(const s of e)if(js(s))for(const e of s)for(const t of e)"number"==typeof t.value&&(o+=1);else{const e=s?.value;gi(e)||"string"==typeof e&&!Rs(e,t)&&!ds(e,t)||(o+=1)}return o}function rc(e){return Fi(e,((e,t)=>void 0!==t&&null!==t.value?e+1:e),0)}function ac(e,t){let o={value:-1/0};return _i(e,(e=>{e.value>=o.value&&(o=e)}),t),o.value===-1/0?{value:0}:o}function lc(e,t){let o={value:1/0};return _i(e,(e=>{e.value<=o.value&&(o=e)}),t),o.value===1/0?{value:0}:o}function cc(e,t,o){const s=e[0].length?e:[je(1,t.flat().length+1)],i=s.length;let n=o[0].length?o:s;return n=n.length===i?Vi(n):n,{_X:s,_newX:n}}function hc(e,t,o=!0,s=!1){const i=t.flat(),n=i.length;let{_X:r}=cc(e,t,[[]]);r=r.length===n?Vi(r):r.slice(),sc(r[0],i);const a=r.length,l=n-a-(o?1:0),c=[i],h=Vi(r.reverse()),d=[];for(let e=0;e<a;e++)if(d.push(0),o){for(const t of r[e])d[e]+=t;d[e]/=n}let u=0;if(o){for(const e of i)u+=e;u/=n}const g=h.map((e=>e.map(((e,t)=>e-d[t]))));o&&h.forEach((e=>e.push(1)));const p=uc(h,c);if(o||p.push([0]),!s)return p;const m=Ql(g,Vi(g)),{inverted:f}=Kl(m);if(void 0===f)throw new si(Ho("Matrix is not invertible"));let v=0,b=0;for(let e=0;e<n;e++){const t=i[e]-u;let o=0;for(let t=0;t<a;t++){o+=g[e][t]*p[t][0]}const s=t-o;v+=s*s,b+=o*o}const S=Math.sqrt(v/l),C=b/(b+v),y=b/a/(v/l),w=[];for(let e=0;e<a;e++)w.push(S*Math.sqrt(f[e][e]));if(o){const e=Ql(f,[d]),t=Ql(Vi([d]),e);w.push(S*Math.sqrt(t[0][0]+1/i.length))}const I=[[p[0][0],w[0],C,y,b],[p[1][0],w[1],S,l,v]];for(let e=2;e<a;e++)I.push([p[e][0],w[e],"","",""]);return o?I.push([p[a][0],w[a],"","",""]):I.push([0,"","","",""]),I}function dc(e,t,o,s){sc(t,e),Gl(o>=1,Ho("Function [[FUNCTION_NAME]] A regression of order less than 1 cannot be possible."));const i=[e],n=t.map((e=>je(0,o).map((t=>Math.pow(e,o-t)))));s&&n.forEach((e=>e.push(1)));const r=uc(n,i);return s||r.push([0]),r}function uc(e,t){const o=Ql(e,Vi(e)),{inverted:s}=Kl(o);if(void 0===s)throw new si(Ho("Matrix is not invertible"));const i=Ql(e,t);return Vi(Ql(s,i))}function gc(e,t,o){return e.reduce(((e,s,i)=>e+s*Math.pow(t,o-i)),0)}function pc(e){return e.map((e=>e.map((e=>Math.exp(e)))))}function mc(e){return e.map((e=>e.map((e=>Math.log(e)))))}function fc(e,t,o,s){const{_X:i,_newX:n}=cc(t,e,o),r=hc(i,e,s,!1),a=r.length-1,l=n.map((e=>{let t=0;for(let o=0;o<a;o++)t+=r[o][0]*e[a-o-1];return t+=r[a][0],[t]}));return l.length===o.length?l:Vi(l)}const vc=new n;function bc(e){return vc.get(e)}const Sc={normalizeFunctionValue:e=>fi(e,qs),toValueAndFormat:(e,t)=>({value:fi(e,qs),format:"dd mmm yyyy"}),toFunctionValue(e){const t=Ri(e,qs);return`DATE(${t.getFullYear()},${t.getMonth()+1},${t.getDate()})`}},Cc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>31)throw new si(Ho("%s is not a valid day of month (it should be a number between 1 and 31)",t));return t},toValueAndFormat:e=>({value:fi(e,qs),format:"0"}),toFunctionValue:e=>`${e}`},yc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>7)throw new si(Ho("%s is not a valid day of week (it should be a number between 1 and 7)",t));return t},toValueAndFormat(e,t){const o=(e-1+(t||qs).weekStart)%7;return{value:wn[o].toString(),format:"@"}},toFunctionValue:e=>`${e}`},wc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>53)throw new si(Ho("%s is not a valid week (it should be a number between 0 and 53)",t));return t},toValueAndFormat:e=>({value:fi(e,qs),format:"0"}),toFunctionValue:e=>`${e}`},Ic={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>12)throw new si(Ho("%s is not a valid month (it should be a number between 1 and 12)",t));return t},toValueAndFormat:e=>({value:yn[fi(e,qs)-1].toString(),format:"@"}),toFunctionValue:e=>`${e}`},xc={normalizeFunctionValue:e=>In(fi(e,qs),{locale:qs,format:"mm/yyyy"}),toValueAndFormat:e=>({value:fi(e,qs),format:"mmmm yyyy"}),toFunctionValue(e){const t=Ri(e,qs);return`DATE(${t.getFullYear()},${t.getMonth()+1},1)`}},Ec={normalizeFunctionValue(e){const t=fi(e,qs);if(t<1||t>4)throw new si(Ho("%s is not a valid quarter (it should be a number between 1 and 4)",t));return t},toValueAndFormat:e=>({value:Ho("Q%(quarter_number)s",{quarter_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Rc={normalizeFunctionValue(e){const t=fi(e,qs);return t>3e3?Ri(t,qs).getFullYear():t},toValueAndFormat:e=>({value:fi(e,qs),format:"0"}),toFunctionValue:e=>`${e}`},Tc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>23)throw new si(Ho("%s is not a valid hour (it should be a number between 0 and 23)",t));return t},toValueAndFormat:e=>({value:Ho("%(hour_number)sh",{hour_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Ac={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>59)throw new si(Ho("%s is not a valid minute (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Ho("%(minute_number)s'",{minute_number:e}),format:"@"}),toFunctionValue:e=>`${e}`},Dc={normalizeFunctionValue(e){const t=fi(e,qs);if(t<0||t>59)throw new si(Ho("%s is not a valid second (it should be a number between 0 and 59)",t));return t},toValueAndFormat:e=>({value:Ho("%(second_number)s''",{second_number:e}),format:"@"}),toFunctionValue:e=>`${e}`};function _c(e){return{normalizeFunctionValue:t=>null===t?null:e.normalizeFunctionValue(t),toValueAndFormat:(t,o)=>null===t?{value:Ho("(Undefined)")}:e.toValueAndFormat(t,o),toFunctionValue:t=>null===t?"false":e.toFunctionValue(t)}}vc.add("day",_c(Sc)).add("year",_c(Rc)).add("day_of_month",_c(Cc)).add("iso_week_number",_c(wc)).add("month_number",_c(Ic)).add("month",_c(xc)).add("quarter_number",_c(Ec)).add("day_of_week",_c(yc)).add("hour_number",_c(Tc)).add("minute_number",_c(Ac)).add("second_number",_c(Dc));const Oc={count:Ho("Count"),count_distinct:Ho("Count Distinct"),bool_and:Ho("Boolean And"),bool_or:Ho("Boolean Or"),max:Ho("Maximum"),min:Ho("Minimum"),avg:Ho("Average"),sum:Ho("Sum")},Fc=["max","min","avg","sum","count_distinct","count"],Pc={integer:Fc,char:Fc,datetime:Fc,boolean:["count_distinct","count","bool_and","bool_or"]},Mc={};for(const e in Pc){Mc[e]={};for(const t of Pc[e])Mc[e][t]=Oc[t]}const Nc={count:e=>({value:rc([e]),format:"0"}),count_distinct:e=>({value:$l([e]),format:"0"}),bool_and:e=>({value:Ul([e]).result}),bool_or:e=>({value:Bl([e]).result}),max:(e,t)=>ac([e],t),min:(e,t)=>lc([e],t),avg:(e,t)=>({value:ic([e],t),format:ui(e)}),sum:(e,t)=>({value:zl([e],t),format:ui(e)})};function kc(e){const t=Object.keys(e);if(!t.length)return 0;const o=t.map((e=>parseInt(e,10)));return Math.max(...o)}const Vc={year:Ho("Year"),quarter:Ho("Quarter & Year"),month:Ho("Month & Year"),week:Ho("Week & Year"),day:Ho("Day"),quarter_number:Ho("Quarter"),month_number:Ho("Month"),iso_week_number:Ho("Week"),day_of_month:Ho("Day of Month"),day_of_week:Ho("Day of Week"),hour_number:Ho("Hour"),minute_number:Ho("Minute"),second_number:Ho("Second")},Lc=["date","datetime"];function Hc(e){const[t,o]=e.split(":");return o?{fieldName:t,granularity:o}:{fieldName:t}}function Uc(e){return Lc.includes(e.type)}function Bc(e,t,o){const s=[e];o&&s.push(`"${o}"`);for(const{field:e,value:o,type:i}of t){if("measure"===e){s.push('"measure"',`"${o}"`);continue}const{granularity:t}=Hc(e),n=qc(o,{type:i,granularity:t});s.push(`"${e}"`,n)}return s}function zc(e,t){let o=0,s=0;const i=t.columns.map((e=>e.nameWithGranularity)),n=t.rows.map((e=>e.nameWithGranularity));for(;void 0!==e[o]&&e[o]===n[s];)o++,s++;for(s=0;void 0!==e[o]&&e[o]===i[s];)o++,s++;return e.length===o}function $c(e,t){switch(t.type){case"HEADER":return`=PIVOT.HEADER(${Bc(e,t.domain).join(",")})`;case"VALUE":return`=PIVOT.VALUE(${Bc(e,t.domain,t.measure).join(",")})`;case"MEASURE_HEADER":return`=PIVOT.HEADER(${Bc(e,[...t.domain,{field:"measure",value:t.measure,type:"char"}]).join(",")})`}return""}function Gc(e,t){if(null===t||"null"===t)return null;const o="object"==typeof t?t.value:t;if(gi(o))return o;const s="boolean"==typeof t?wi(t).toLocaleLowerCase():wi(t);if("null"===s)return null;if(!jc.contains(e.type))throw new si(Ho("Field %(field)s is not supported because of its type (%(type)s)",{field:e.displayName,type:e.type}));if("false"===s.toLowerCase())return!1;return jc.get(e.type)(s,e.granularity)}function Wc(e,t){return bc(t??"month").normalizeFunctionValue(e)}function qc(e,t){return null===e?'"null"':Yc.contains(t.type)?Yc.get(t.type)(e,t.granularity):`"${e}"`}function Zc(e,t){return bc(t??"month").toFunctionValue(e)}const jc=new n;jc.add("date",Wc).add("datetime",Wc).add("integer",(e=>fi(e,qs))).add("boolean",(e=>Ei(e))).add("char",(e=>wi(e)));const Yc=new n;function Xc(e){return e.displayName+(e.granularity?` (${Vc[e.granularity]})`:"")}function Kc(e,t){try{if(!t.getMeasure(e.measure))return!1;const o=t.definition.columns;for(let s=0;s<e.domain.length;s++){if(o[s].nameWithGranularity!==e.domain[s].field)return!1;const i=t.getPossibleFieldValues(o[s]).map((e=>e.value));if(!(i.includes(e.domain[s].value)||null===e.domain[s].value&&i.includes("")))return!1}return!0}catch(e){return!1}}Yc.add("date",Zc).add("datetime",Zc).add("integer",(e=>`${fi(e,qs)}`)).add("boolean",(e=>Ei(e)?"TRUE":"FALSE")).add("char",(e=>`"${wi(e).replace(/"/g,'\\"')}"`));class Jc extends rl{isCutAllowed(e){return 1!==e.zones.length?"WrongCutSelection":"Success"}copy(e,t,o="copyPaste"){const s=e.sheetId,{clippedZones:i,rowsIndexes:n,columnsIndexes:r}=e,a=[],l=1===n.length&&1===r.length;for(const t of n){const i=[];for(const a of r){const c={col:a,row:t,sheetId:s};let h=this.getters.getCell(c);const d=this.getters.getEvaluatedCell(c),u=this.getters.getPivotIdFromPosition(c),g=this.getters.getArrayFormulaSpreadingOn(c);if("shiftCells"!==o&&u&&g){const t=this.getters.getSpreadZone(g);if((!mt(g,c)||!l)&&t&&!e.zones.some((e=>Rr(t,e)))){const e=this.getters.getPivotCellFromPosition(c),t=$c(this.getters.getPivotFormulaId(u),e);h={id:h?.id||"",style:h?.style,format:h?.format,content:t,isFormula:!1,parsedValue:d.value}}}else if("shiftCells"!==o&&g&&!mt(g,c)){const e=n.includes(g.row)&&r.includes(g.col)?"":In(d.value,{locale:this.getters.getLocale()});h={id:h?.id||"",style:h?.style,format:d.format,content:e,isFormula:!1,parsedValue:d.value}}i.push({content:h?.content??"",style:h?.style,format:h?.format,tokens:h?.isFormula?h.compiledFormula.tokens.map((({value:e,type:t})=>({value:e,type:t}))):[],border:this.getters.getCellBorder(c)||void 0,evaluatedCell:d,position:c})}a.push(i)}return{cells:a,zones:i,sheetId:e.sheetId}}isPasteAllowed(e,t,o,s){if(!o.cells)return"Success";if(s?.isCutOperation&&void 0!==s?.pasteOption)return"WrongPasteOption";if(t.length>1&&(o.cells.length>1||o.cells[0].length>1))return"WrongPasteSelection";const i=o.cells.length,n=o.cells[0].length;for(const s of el(t,o.cells))if(this.getters.doesIntersectMerge(e,s)&&(t.length>1||!this.getters.isSingleCellOrMerge(e,t[0])||i*n!=1))return"WillRemoveExistingMerge";return"Success"}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.cells,o)}getPasteTarget(e,t,o,s){const i=o.cells[0].length,n=o.cells.length;return s?.isCutOperation?{sheetId:e,zones:[{left:t[0].left,top:t[0].top,right:t[0].left+i-1,bottom:t[0].top+n-1}]}:1===i&&1===n?{zones:[],sheetId:e}:{sheetId:e,zones:el(t,o.cells)}}pasteFromCut(e,t,o,s){this.clearClippedZones(o);const i=t[0];this.pasteZone(e,i.left,i.top,o.cells,s)}clearClippedZones(e){this.dispatch("CLEAR_CELLS",{sheetId:e.sheetId,target:e.zones}),this.dispatch("CLEAR_FORMATTING",{sheetId:e.sheetId,target:e.zones})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){if(!a)continue;const r={col:t+s,row:o+n,sheetId:e};this.pasteCell(a,r,i)}}pasteCell(e,t,o){const{sheetId:s,col:i,row:n}=t,r=this.getters.getEvaluatedCell(t),a=e?.format??e.evaluatedCell.format;if("asValue"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,content:e.evaluatedCell.value?.toString()||"",format:a});if("onlyFormat"===o?.pasteOption)return void this.dispatch("UPDATE_CELL",{...t,style:e?.style??null,format:a??r.format});let l=e?.content;e?.tokens&&e.tokens.length>0&&!o?.isCutOperation?l=this.getters.getTranslatedCellFormula(s,i-e.position.col,n-e.position.row,e.tokens):e?.tokens&&e.tokens.length>0&&(l=this.getters.getFormulaMovedInSheet(e.position.sheetId,s,e.tokens)),""!==l||e?.format||e?.style?this.dispatch("UPDATE_CELL",{...t,content:l,style:e?.style||null,format:e?.format}):r&&this.dispatch("CLEAR_CELL",t)}convertTextToClipboardData(e){const t=this.getters.getLocale(),o={cells:[]},s=[];let i=0;for(const[t,o]of e.replace(/\r/g,"").split("\n").entries())s.push(o.split("\t")),s[t].length>i&&(i=s[t].length);for(const e of s){const s=[];for(let o=0;o<i;o++){const i=Dl(e[o]||"",t);s.push({content:i,evaluatedCell:{formattedValue:i}})}o.cells.push(s)}return o}}class Qc extends nl{copy(e){}}const eh={figureHandlers:new n,cellHandlers:new n};function th(e,t){return"REMOVE_COLUMNS_ROWS"===t.type?Cr(e,"COL"===t.dimension?"left":"top",t.elements):"ADD_COLUMNS_ROWS"===t.type?vr(e,"COL"===t.dimension?"left":"top",t.base,t.position,t.quantity):e}function oh(e,t){const o="DELETE_SHEET"===t.type&&t.sheetId;if("sheetId"in t&&e._sheetId!==t.sheetId)return e;{const s=th(e._zone,t);if(s&&o!==e._sheetId)return{...e,_zone:s}}}eh.figureHandlers.add("chart",class extends Qc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);if("chart"!==o.tag)return;const s={...o},i=this.getters.getChart(e.figureId);if(!i)throw new Error(`No chart for the given id: ${e.figureId}`);const n=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:s,copiedChart:n}}getPasteTarget(e,t,o,s){return{zones:[],figureId:(new Ka).smallUuid(),sheetId:e}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=e.sheetId,{width:r,height:a}=t.copiedFigure,l=t.copiedChart.copyInSheetId(n),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_CHART",{figureId:i,sheetId:n,definition:l.getDefinition(),col:h,row:d,offset:u,size:{height:a,width:r}}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.copiedChart.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}).add("image",class extends Qc{copy(e){const t=e.sheetId,o=this.getters.getFigure(t,e.figureId);if(!o)throw new Error(`No figure for the given id: ${e.figureId}`);const s={...o};if("image"!==o.tag)return;const i=ze(this.getters.getImage(e.figureId));return{figureId:e.figureId,copiedFigure:s,copiedImage:i,sheetId:t}}getPasteTarget(e,t,o,s){return{sheetId:e,zones:[],figureId:(new Ka).smallUuid()}}paste(e,t,o){if(!e.figureId)return;const{zones:s,figureId:i}=e,n=this.getters.getActiveSheetId(),{width:r,height:a}=t.copiedFigure,l=ze(t.copiedImage),c=this.getters.getMaxAnchorOffset(n,a,r);let{left:h,top:d}=s[0];const u={x:0,y:0};h>c.col&&(h=c.col,u.x=c.offset.x),d>c.row&&(d=c.row,u.y=c.offset.y),this.dispatch("CREATE_IMAGE",{figureId:i,sheetId:n,col:h,row:d,offset:u,size:{height:a,width:r},definition:l}),o.isCutOperation&&this.dispatch("DELETE_FIGURE",{sheetId:t.sheetId,figureId:t.copiedFigure.id}),this.dispatch("SELECT_FIGURE",{figureId:i})}isPasteAllowed(e,t,o,s){return 0===t.length?"EmptyTarget":void 0!==s?.pasteOption?"WrongFigurePasteOption":"Success"}}),eh.cellHandlers.add("dataValidation",class extends rl{uuidGenerator=new Ka;queuedChanges={};copy(e){const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o={sheetId:s,col:i,row:e},n=this.getters.getValidationRuleForCell(o);t.push({position:o,rule:n})}i.push(t)}return{dvRules:i}}paste(e,t,o){if(this.queuedChanges={},o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.dvRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteDataValidation(a,r,i?.isCutOperation)}}pasteDataValidation(e,t,o){if(e){const s=Mr(t),i=Mr(e.position),n=e.rule;if(!n){const e=this.getters.getValidationRuleForCell(t);return void(e&&this.adaptDataValidationRule(t.sheetId,e,[],[s]))}const r=[];if(o&&r.push(i),e.position.sheetId===t.sheetId){const o=this.getDataValidationRuleToCopyTo(t.sheetId,n,!1);this.adaptDataValidationRule(e.position.sheetId,o,[s],r)}else{const o=this.getters.getValidationRuleForCell(e.position);o&&this.adaptDataValidationRule(e.position.sheetId,o,[],r);const i=this.getDataValidationRuleToCopyTo(t.sheetId,n);this.adaptDataValidationRule(t.sheetId,i,[s],[])}}}getDataValidationRuleToCopyTo(e,t,o=!0){let s=this.getters.getDataValidationRules(e).find((e=>mt(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking));const i=this.queuedChanges[e];return!s&&i&&(s=i.find((e=>mt(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking))?.rule),s||{...t,id:o?this.uuidGenerator.smallUuid():t.id,ranges:[]}}adaptDataValidationRule(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.rule.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,rule:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,rule:s}of this.queuedChanges[e]){const i=s.ranges.map((e=>e.zone)),n=nr(i,o),r=nr([...n,...t],[]);0!==r.length?this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:{id:s.id,criterion:s.criterion,isBlocking:s.isBlocking},ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e}):this.dispatch("REMOVE_DATA_VALIDATION_RULE",{sheetId:e,id:s.id})}}}).add("cell",Jc).add("sheet",class extends rl{isPasteAllowed(e,t,o,s){if(!("cells"in o))return"Success";const{xSplit:i,ySplit:n}=this.getters.getPaneDivisions(e);return Hr(el(t,o.cells),i,n)?"FrozenPaneOverlap":"Success"}}).add("merge",class extends rl{copy(e){const t=this.getters.getActiveSheetId(),{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getMerge(s))}i.push(o)}return{merges:i,sheetId:t}}paste(e,t,o){if(o.isCutOperation){const e=t.merges.flat().filter(lt);this.dispatch("REMOVE_MERGE",{sheetId:t.sheetId,target:e})}this.pasteFromCopy(e.sheetId,e.zones,t.merges,o)}pasteZone(e,t,o,s){for(const[i,n]of s.entries())for(const[s,r]of n.entries()){const n={col:t+s,row:o+i,sheetId:e};this.pasteMerge(r,n)}}pasteMerge(e,t){if(!e)return;if(this.getters.isInMerge(t))return;const{sheetId:o,col:s,row:i}=t;this.dispatch("ADD_MERGE",{sheetId:o,force:!0,target:[{left:s,top:i,right:s+e.right-e.left,bottom:i+e.bottom-e.top}]})}}).add("border",class extends rl{queuedBordersToAdd={};copy(e){const t=e.sheetId;if(0===e.zones.length)return;const{rowsIndexes:o,columnsIndexes:s}=e,i=[];for(const e of o){const o=[];for(const i of s){const s={col:i,row:e,sheetId:t};o.push(this.getters.getCellBorder(s))}i.push(o)}return{borders:i}}paste(e,t,o){const s=e.sheetId;if("asValue"===o.pasteOption)return;const i=e.zones;if(o.isCutOperation){const{left:e,top:o}=i[0];this.pasteZone(s,e,o,t.borders)}else this.pasteFromCopy(s,i,t.borders);this.executeQueuedChanges(s)}pasteZone(e,t,o,s){for(const[i,n]of s.entries())for(const[s,r]of n.entries()){const n={col:t+s,row:o+i,sheetId:e};this.pasteBorder(r,n)}}pasteBorder(e,t){const o={...this.getters.getCellBorder(t),...e},s=JSON.stringify(o);this.queuedBordersToAdd[s]||(this.queuedBordersToAdd[s]=[]),this.queuedBordersToAdd[s].push(Mr(t))}executeQueuedChanges(e){for(const t in this.queuedBordersToAdd){const o=this.queuedBordersToAdd[t],s=JSON.parse(t),i=nr(o,[]);this.dispatch("SET_BORDERS_ON_TARGET",{sheetId:e,target:i,border:s})}this.queuedBordersToAdd={}}}).add("table",class extends rl{copy(e,t,o="copyPaste"){const s=e.sheetId,{rowsIndexes:i,columnsIndexes:n,zones:r}=e,a=new Set,l=[];for(const e of i){const c=[];l.push(c);for(const l of n){const n={col:l,row:e,sheetId:s},h=this.getters.getTable(n);if(!h){c.push({});continue}const d=this.getters.getCoreTable(n),u=d?.range.zone;let g;if(!a.has(h.id)&&d&&u&&r.some((e=>Rr(u,e)))){a.add(h.id);let{numberOfRows:e}=Tr(u);for(let o=u.top;o<=u.bottom;o++)t||i.includes(o)||e--;const o=d.range,s=this.getters.extendRange(d.range,"ROW",o.zone.top+e-1-o.zone.bottom);g={range:this.getters.getRangeData(s),config:d.config,type:d.type}}"shiftCells"!==o&&c.push({table:g,style:this.getTableStyleToCopy(n),isWholeTableCopied:a.has(h.id)})}}return{tableCells:l,sheetId:e.sheetId}}getTableStyleToCopy(e){const t=this.getters.getCellTableStyle(e),o=this.getters.getCellStyle(e),s=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...bt(o)},border:{...s,...bt(i)}}}paste(e,t,o){const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t,o):this.pasteFromCopy(i,s,t.tableCells,o)}pasteFromCut(e,t,o,s){for(const e of o.tableCells)for(const t of e)t.table&&this.dispatch("REMOVE_TABLE",{sheetId:o.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});const i=t[0];this.pasteZone(e,i.left,i.top,o.tableCells,s)}pasteZone(e,t,o,s,i){for(let n=0;n<s.length;n++){const r=s[n];for(let s=0;s<r.length;s++){const a=r[s];if(!a)continue;const l={col:t+s,row:o+n,sheetId:e};this.pasteTableCell(e,a,l,i)}}if(1===s.length)for(let i=0;i<s[0].length;i++)this.dispatch("AUTOFILL_TABLE_COLUMN",{col:t+i,row:o,sheetId:e})}pasteTableCell(e,t,o,s){if(t.table&&!s?.pasteOption){const{range:s}=t.table,i=Tr(this.getters.getRangeFromRangeData(s).zone),n={left:o.col,top:o.row,right:o.col+i.numberOfCols-1,bottom:o.row+i.numberOfRows-1};this.dispatch("CREATE_TABLE",{sheetId:o.sheetId,ranges:[this.getters.getRangeDataFromZone(e,n)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(o)||"asValue"===s?.pasteOption||(s?.pasteOption||t.isWholeTableCopied)&&"onlyFormat"!==s?.pasteOption||(t.style?.style&&this.dispatch("UPDATE_CELL",{...o,style:t.style.style}),t.style?.border&&this.dispatch("SET_BORDER",{...o,border:t.style.border}))}}).add("conditionalFormat",class extends rl{uuidGenerator=new Ka;queuedChanges={};copy(e){if(!e.zones.length)return;const{rowsIndexes:t,columnsIndexes:o}=e,s=e.sheetId,i=[];for(const e of t){const t=[];for(const i of o){const o=Array.from(this.getters.getRulesByCell(s,i,e));t.push({position:{col:i,row:e,sheetId:s},rules:o})}i.push(t)}return{cfRules:i}}paste(e,t,o){if(this.queuedChanges={},"asValue"===o.pasteOption)return;const s=e.zones,i=e.sheetId;o.isCutOperation?this.pasteFromCut(i,s,t):this.pasteFromCopy(i,s,t.cfRules,o),this.executeQueuedChanges()}pasteFromCut(e,t,o){const s=t[0];this.pasteZone(e,s.left,s.top,o.cfRules,{isCutOperation:!0})}pasteZone(e,t,o,s,i){for(const[n,r]of s.entries())for(const[s,a]of r.entries()){const r={col:t+s,row:o+n,sheetId:e};this.pasteCf(a,r,i?.isCutOperation)}}pasteCf(e,t,o){if(e?.rules&&e.rules.length>0){const s=Mr(e.position),i=Mr(t);for(const n of e.rules){const r=[];if(o&&r.push(s),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,n,[i],r);else{this.adaptCFRules(e.position.sheetId,n,[],r);const o=this.getCFToCopyTo(t.sheetId,n);this.adaptCFRules(t.sheetId,o,[i],[])}}}}adaptCFRules(e,t,o,s){this.queuedChanges[e]||(this.queuedChanges[e]=[]);const i=this.queuedChanges[e].find((e=>e.cf.id===t.id));i?(i.toAdd.push(...o),i.toRemove.push(...s)):this.queuedChanges[e].push({toAdd:o,toRemove:s,cf:t})}executeQueuedChanges(){for(const e in this.queuedChanges)for(const{toAdd:t,toRemove:o,cf:s}of this.queuedChanges[e]){const i=this.getters.getAdaptedCfRanges(e,s,t,o);i&&(0!==i.length?this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:s.id,rule:s.rule,stopIfTrue:s.stopIfTrue},ranges:i,sheetId:e}):this.dispatch("REMOVE_CONDITIONAL_FORMAT",{id:s.id,sheetId:e}))}}getCFToCopyTo(e,t){let o=this.getters.getConditionalFormats(e).find((e=>e.stopIfTrue===t.stopIfTrue&&mt(e.rule,t.rule)));const s=this.queuedChanges[e];return!o&&s&&(o=s.find((e=>e.cf.stopIfTrue===t.stopIfTrue&&mt(e.cf.rule,t.rule)))?.cf),o||{...t,id:this.uuidGenerator.smallUuid(),ranges:[]}}}).add("references",class extends rl{copy(e){return{zones:e.clippedZones,sheetId:e.sheetId}}paste(e,t,o){if(o.isCutOperation){const o=e.zones[0];this.dispatch("MOVE_RANGES",{target:t.zones,sheetId:t.sheetId,sheetName:this.getters.getSheetName(t.sheetId),targetSheetId:e.sheetId,col:o.left,row:o.top})}}});class sh{subscriptions={};on(e,t,o){if(!o)throw new Error("Missing callback");this.subscriptions[e]||(this.subscriptions[e]=[]),this.subscriptions[e].push({owner:t,callback:o})}trigger(e,t){const o=this.subscriptions[e]||[];for(let e=0,s=o.length;e<s;e++){const s=o[e];s.callback.call(s.owner,t)}}off(e,t){const o=this.subscriptions[e];o&&(this.subscriptions[e]=o.filter((e=>e.owner!==t)))}clear(){this.subscriptions={}}}class ih extends sh{dependencies=new Map;factory=new nh(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw new Error(`Store ${e.name} already has an instance`);this.dependencies.set(e,t)}get(e){return this.dependencies.has(e)||this.dependencies.set(e,this.instantiate(e)),this.dependencies.get(e)}instantiate(e,...t){return this.factory.build(e,...t)}resetStores(){this.dependencies.clear()}dispose(){for(const e of this.dependencies.values())"dispose"in e&&"function"==typeof e.dispose&&e.dispose()}}class nh{get;pendingBuilds=new Set;constructor(e){this.get=e}build(e,...t){if(this.pendingBuilds.has(e))throw new Error(`Circular dependency detected: ${[...this.pendingBuilds,e].map((e=>e.name)).join(" -> ")}`);this.pendingBuilds.add(e);const o=new e(this.get,...t);return this.pendingBuilds.delete(e),o}}class rh{get;disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach((e=>e()))}}function ah(){const e=t.useEnv();if(e.__spreadsheet_stores__ instanceof ih)return e.__spreadsheet_stores__;const o=new ih;return t.useSubEnv({__spreadsheet_stores__:o,getStore:e=>dh(o.get(e),(()=>o.trigger("store-updated")))}),t.onWillUnmount((()=>o.dispose())),o}function lh(e){const o=uh(t.useEnv()),s=o.get(e);return hh(o,s)}function ch(e,...o){const s=uh(t.useEnv()),i=s.instantiate(e,...o);return t.onWillUnmount((()=>i.dispose())),hh(s,i)}function hh(e,o){const s=t.useComponent();return dh(o,(()=>{"mounted"===t.status(s)&&e.trigger("store-updated")}))}function dh(e,t){return new Proxy(e,{get(o,s,i){const n=o,r=Reflect.get(o,s,n);if(e.mutators?.includes(s)){const e=new Proxy(r,{apply(e,o,s){"noStateChange"!==Reflect.apply(e,n,s)&&t()}});return e}return r}})}function uh(e){const t=e.__spreadsheet_stores__;if(!(t instanceof ih))throw new Error("No store provider found. Did you forget to call useStoreProvider()?");return t}const gh=(ph="Model",class{constructor(e){throw new Error(`This is a abstract store for ${ph}, it cannot be instantiated.\nDid you forget to inject your store instance?\n\nconst stores = useStoreProvider();\nstores.inject(MyMetaStore, storeInstance);\n`)}});var ph;class mh{mutators=["register","unRegister","draw","startAnimation","stopAnimation"];renderers={};model;context=void 0;animationFrameId=null;registeredAnimations=new Set;constructor(e){this.model=e(gh)}register(e){if(e.renderingLayers.length)for(const t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(const t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter((t=>t!==e))}drawLayer(e,t,o){const s=this.renderers[t];if(s)for(const i of s)e.ctx.save(),i.drawLayer(e,t,o),e.ctx.restore();return"noStateChange"}draw(e,t){if(!(e=e||this.context))throw new Error("Rendering context is not defined");this.context=e;for(const o of Ks())this.model.drawLayer(e,o),this.drawLayer(e,o,t);return"noStateChange"}startAnimation(e){if(this.registeredAnimations.add(e),!this.animationFrameId){const e=t=>{this.animationFrameId=requestAnimationFrame(e),this.draw(void 0,t)};this.animationFrameId=requestAnimationFrame(e)}return"noStateChange"}stopAnimation(e){return this.registeredAnimations.delete(e),0===this.registeredAnimations.size&&null!==this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null),"noStateChange"}dispose(){this.animationFrameId&&(cancelAnimationFrame(this.animationFrameId),this.animationFrameId=null)}}class fh extends rh{model=this.get(gh);getters=this.model.getters;renderer=this.get(mh);constructor(e){super(e),this.model.on("command-dispatched",this,this.handle),this.model.on("command-finalized",this,this.finalize),this.renderer.register(this),this.onDispose((()=>{this.model.off("command-dispatched",this),this.model.off("command-finalized",this),this.renderer.unRegister(this)}))}get renderingLayers(){return[]}handle(e){}finalize(){}drawLayer(e,t,o){}}const vh={id:"void-composer",get editionMode(){return"inactive"},startEdition:()=>{throw new Error("No composer is registered")},stopEdition:()=>{throw new Error("No composer is registered")},setCurrentContent:()=>{throw new Error("No composer is registered")}};class bh extends fh{mutators=["focusComposer","focusActiveComposer"];activeComposer=vh;_focusMode="inactive";get focusMode(){return"inactive"===this.activeComposer.editionMode?"inactive":this._focusMode}focusComposer(e,t){if(this.activeComposer=e,this.getters.isReadonly())return"noStateChange";this._focusMode=t.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(t)}focusActiveComposer(e){if(this.getters.isReadonly())return"noStateChange";if(!this.activeComposer)throw new Error("No composer is registered");this._focusMode=e.focusMode||"contentFocus","inactive"!==this._focusMode&&this.setComposerContent(e)}setComposerContent({content:e,selection:t}){"inactive"===this.activeComposer.editionMode?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}}const Sh={};let Ch=0;function yh(e,...t){const o="__sheet__"+Ch++;return function(e,t){const o=document.createElement("style");o.textContent=function(e){const t=e.split(/(\{|\}|;)/).map((e=>e.trim())),o=[],s=[];let i=[];function n(e,t){const s=[];for(const i of o[e]){let r=t&&t+" "+i||i;r.includes("&")&&(r=i.replace(/&/g,t||"")),e<o.length-1&&(r=n(e+1,r)),s.push(r)}return s.join(", ")}function r(){i.length&&(s.push(n(0)+" {"),s.push(...i),s.push("}"),i=[])}for(;t.length;){const e=t.shift();"}"===e?(r(),o.pop()):("{"===t[0]&&(r(),o.push(e.split(/\s*,\s*/)),t.shift()),";"===t[0]&&i.push(" "+e+";"))}return s.join("\n")}(t),Sh[e]=o}(o,String.raw(e,...t)),function(e){const t=Sh[e];t.setAttribute("component",e),document.head.appendChild(t)}(o),o}function wh({strikethrough:e,underline:t}){return e||t?`${e?"line-through":""} ${t?"underline":""}`:"none"}function Ih(e){const t=function(e){const t={};if(!e)return t;e.bold&&(t["font-weight"]="bold");e.italic&&(t["font-style"]="italic");if(e.strikethrough||e.underline){let o=e.strikethrough?"line-through":"";o=e.underline?o+" underline":o,t["text-decoration"]=o}e.textColor&&(t.color=e.textColor);return t}(e);return e?(e.fillColor&&(t.background=e.fillColor),t):t}function xh(e){let t="";for(const o in e)e[o]&&(t+=`${o}:${e[o]}; `);return t}const Eh=new n;function Rh(){if(window.Chart&&!window.Chart.registry.plugins.get("chartShowValuesPlugin"))for(const e of Eh.getAll())e.register(window.Chart)}class Th extends fh{mutators=["disableAnimationForChart","enableAnimationForChart"];animationPlayed={};disableAnimationForChart(e,t){return this.animationPlayed[e]=t,"noStateChange"}enableAnimationForChart(e){return this.animationPlayed[e]=void 0,"noStateChange"}}function Ah(){return class extends window.Chart.BarController{static id="funnel";static defaults={...window.Chart?.BarController.defaults,dataElementType:"funnel",animation:{duration:e=>{if("data"!==e.type)return 1e3;return e.raw[1]/Math.max(...e.dataset.data.map((e=>e[1])))*1e3}}};updateElements(e,t,o,s){super.updateElements(e,t,o,s);for(let i=t;i<t+o;i++){const t=e[i];this.updateElement(t,i,{nextElement:e[i+1]},s)}}}}function Dh(){return class extends window.Chart.BarElement{static id="funnel";draw(e){e.save();const{x:t,y:o,height:s,nextElement:i,base:n,options:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=_h(this),l=(a-(i?_h(i):0))/2,c=Math.min(t,n),h=o-s/2;e.fillStyle=r.backgroundColor,e.beginPath(),e.moveTo(c,h),e.lineTo(c+a,h),e.lineTo(c+a-l,h+s),e.lineTo(c+l,h+s),e.closePath(),e.fill(),r.borderWidth&&(e.strokeStyle=r.borderColor,e.lineWidth=r.borderWidth,e.stroke()),e.restore()}inRange(e,t){const{x:o,y:s,height:i,nextElement:n,base:r}=this.getProps(["x","y","width","height","nextElement","base","options"]),a=_h(this),l=n?_h(n):0,c=Math.min(o,r),h=s-i/2;if(t<h||t>h+i)return!1;const d=(a-l)/2;return!(e<c+d*(t-h)/i||e>c+a-d*(t-h)/i)}}}function _h(e){const{x:t,base:o}=e.getProps(["x","base"]),s=Math.min(t,o);return Math.max(t,o)-s}const Oh=function(e){if(!e.length)return{x:0,y:0};const t=e[0].element,{x:o,y:s,base:i,width:n,height:r}=t.getProps(["x","y","width","height","base"]);return{x:Math.min(o,i)+2*n/3,y:s-r/2+r/2}},Fh="000000",Ph={arrows:"3Arrows",smiley:"3Symbols",dots:"3TrafficLights1"},Mh={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"},Nh="http://schemas.openxmlformats.org/drawingml/2006/main",kh="http://schemas.openxmlformats.org/drawingml/2006/chart",Vh={workbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml",macroEnabledWorkbook:"application/vnd.ms-excel.sheet.macroEnabled.main+xml",templateWorkbook:"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml",macroEnabledTemplateWorkbook:"application/vnd.ms-excel.template.macroEnabled.main+xml",excelAddInWorkbook:"application/vnd.ms-excel.addin.macroEnabled.main+xml",sheet:"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml",metadata:"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+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"},Lh={document:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument",sheet:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet",metadata:"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sheetMetadata",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"},Hh="bdbb8cdc-fa1e-496e-a857-3c3f30c029c3",Uh="http://schemas.openxmlformats.org/officeDocument/2006/relationships",Bh=.75,zh=.143,$h=8.43,Gh=12.75,Wh=30,qh=100,Zh=164,jh={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}]},Yh=["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"],Xh="[Content_Types].xml",Kh=/(.*?)\((.*?)\)(.*)/,Jh=["ANY","BOOLEAN","DATE","NUMBER","STRING","RANGE","RANGE<BOOLEAN>","RANGE<DATE>","RANGE<NUMBER>","RANGE<STRING>","META"];function Qh(e,t=""){return function(e,t){const o=e.match(Kh),s=o[1].trim();if(!s)throw new Error(`Function argument definition is missing a name: '${e}'.`);const i=[];let n,r=!1,a=!1;for(const e of o[2].split(",")){const t=e.trim().toUpperCase(),o=Jh.find((e=>t===e));o?i.push(o):"RANGE<ANY>"===t?i.push("RANGE"):"OPTIONAL"===t?r=!0:"REPEATING"===t?a=!0:t.startsWith("DEFAULT=")&&(n=e.trim().slice(8))}const l={name:s,description:t,type:i};(i.includes("ANY")||i.includes("RANGE"))&&(l.acceptErrors=!0);r&&(l.optional=!0);a&&(l.repeating=!0);void 0!==n&&(l.default=!0,l.defaultValue=n);i.some((e=>e.startsWith("RANGE")))&&(l.acceptMatrix=!0);i.every((e=>e.startsWith("RANGE")))&&(l.acceptMatrixOnly=!0);return l}(e,t)}const ed={};function td(e,t){const o=e.name,s=ed[o]?.[t];return s||(ed[o]||(ed[o]={}),ed[o][t]||(ed[o][t]=function(e,t){const o={},s=e.nbrArgRepeating?Math.floor((t-e.minArgRequired)/e.nbrArgRepeating):0,i=e.nbrArgRepeating*s,n=t-e.minArgRequired-i;let r=0,a=0;for(let t=0;t<e.args.length;t++){const i=e.args[t];if(i.optional||i.default)a<n&&(o[r]=t,r++),a++;else if(i.repeating){for(let i=0;i<s;i++)for(let s=0;s<e.nbrArgRepeating;s++)o[r]=t+s,r++;t+=e.nbrArgRepeating-1}else o[r]=t,r++}return e=>o[e]}(e,t)),ed[o][t])}const od={description:Ho("Returns a result array constrained to a specific width and height."),args:[Qh("input_range (any, range<any>)",Ho("The range to constrain.")),Qh("rows (number)",Ho("The number of rows in the constrained array.")),Qh("columns (number)",Ho("The number of columns in the constrained array."))],compute:function(e,t,o){const s=ji(e),i=Ci(t?.value,this.locale),n=Ci(o?.value,this.locale);if(i<=0)return new si(Ho("The rows argument (%s) must be strictly positive.",i.toString()));if(n<=0)return new si(Ho("The columns argument (%s) must be strictly positive.",n.toString()));const r=Math.min(i,s[0].length);return Ni(Math.min(n,s.length),r,((e,t)=>s[e][t]))},isExported:!1},sd={description:Ho("Creates a new array from the selected columns in the existing range."),args:[Qh("array (any, range<any>)",Ho("The array that contains the columns to be returned.")),Qh("col_num (number, range<number>)",Ho("The first column index of the columns to be returned.")),Qh("col_num2 (number, range<number>, repeating)",Ho("The columns indexes of the columns to be returned."))],compute:function(e,...t){const o=ji(e),s=Yi(t,(e=>Ci(e?.value,this.locale))),i=s.filter((e=>0===e||o.length<Math.abs(e)));if(0!==i.length)return new si(Ho("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},id={description:Ho("Creates a new array from the selected rows in the existing range."),args:[Qh("array (any, range<any>)",Ho("The array that contains the rows to be returned.")),Qh("row_num (number, range<number>)",Ho("The first row index of the rows to be returned.")),Qh("row_num2 (number, range<number>, repeating)",Ho("The rows indexes of the rows to be returned."))],compute:function(e,...t){const o=ji(e),s=Yi(t,(e=>Ci(e?.value,this.locale))),i=o.length,n=s.filter((e=>0===e||o[0].length<Math.abs(e)));return 0!==n.length?new si(Ho("The rows arguments must be between -%s and %s (got %s), excluding 0.",o[0].length.toString(),o[0].length.toString(),n.join(","))):Ni(i,s.length,((e,t)=>s[t]>0?o[e][s[t]-1]:o[e][o[e].length+s[t]]))},isExported:!0},nd={description:Ho("Expands or pads an array to specified row and column dimensions."),args:[Qh("array (any, range<any>)",Ho("The array to expand.")),Qh("rows (number)",Ho("The number of rows in the expanded array. If missing, rows will not be expanded.")),Qh("columns (number, optional)",Ho("The number of columns in the expanded array. If missing, columns will not be expanded.")),Qh("pad_with (any, default=0)",Ho("The value with which to pad."))],compute:function(e,t,o,s={value:0}){const i=ji(e),n=Ci(t?.value,this.locale),r=void 0!==o?Ci(o.value,this.locale):i.length;return n<i[0].length?new si(Ho("The rows arguments (%s) must be greater or equal than the number of rows of the array.",n.toString())):r<i.length?new si(Ho("The columns arguments (%s) must be greater or equal than the number of columns of the array.",r.toString())):Ni(r,n,((e,t)=>e>=i.length||t>=i[e].length?s:i[e][t]))},isExported:!0},rd={description:Ho("Flattens all the values from one or more ranges into a single column."),args:[Qh("range (any, range<any>)",Ho("The first range to flatten.")),Qh("range2 (any, range<any>, repeating)",Ho("Additional ranges to flatten."))],compute:function(...e){return[Yi(e,(e=>void 0===e?{value:""}:e))]},isExported:!1},ad={description:Ho("Calculates the frequency distribution of a range."),args:[Qh("data (range<number>)",Ho("The array of ranges containing the values to be counted.")),Qh("classes (number, range<number>)",Ho("The range containing the set of classes."))],compute:function(e,t){const o=Yi([e],(e=>e.value)).filter((e=>"number"==typeof e)),s=Yi([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},ld={description:Ho("Appends ranges horizontally and in sequence to return a larger array."),args:[Qh("range1 (any, range<any>)",Ho("The first range to be appended.")),Qh("range2 (any, range<any>, repeating)",Ho("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=ji(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},cd={description:Ho("Returns the matrix determinant of a square matrix."),args:[Qh("square_matrix (number, range<number>)",Ho("An range with an equal number of rows and columns representing a matrix whose determinant will be calculated."))],compute:function(e){const t=bi(e,"square_matrix");return jl(t)?Kl(t).determinant:new si(Ho("The argument square_matrix must have the same number of columns and rows."))},isExported:!0},hd={description:Ho("Returns the multiplicative inverse of a square matrix."),args:[Qh("square_matrix (number, range<number>)",Ho("An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated."))],compute:function(e){const t=bi(e,"square_matrix");if(!jl(t))return new si(Ho("The argument square_matrix must have the same number of columns and rows."));const{inverted:o}=Kl(t);return o||new si(Ho("The matrix is not invertible."))},isExported:!0},dd={description:Ho("Calculates the matrix product of two matrices."),args:[Qh("matrix1 (number, range<number>)",Ho("The first matrix in the matrix multiplication operation.")),Qh("matrix2 (number, range<number>)",Ho("The second matrix in the matrix multiplication operation."))],compute:function(e,t){const o=bi(e,"matrix1"),s=bi(t,"matrix2");return 0===o.length||0===s.length?new si(Ho("The first and second arguments of [[FUNCTION_NAME]] must be non-empty matrices.")):o.length!==s[0].length?new si(Ho("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())):Ql(o,s)},isExported:!0},ud={description:Ho("Calculates the sum of the products of corresponding entries in equal-sized ranges."),args:[Qh("range1 (number, range<number>)",Ho("The first range whose entries will be multiplied with corresponding entries in the other ranges.")),Qh("range2 (number, range<number>, repeating)",Ho("The other range whose entries will be multiplied with corresponding entries in the other ranges."))],compute:function(...e){if(!Zl(...e))return new si(Ho("All the ranges must have the same dimensions."));const t=e.map(ji);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*=fi(o[e][s],this.locale);o+=i}return o},isExported:!0};function gd(e,t,o){if(!Zl(e,t))return new si(Ho("The arguments array_x and array_y must have the same dimensions."));const s=ji(e),i=ji(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 si(Ho("The arguments array_x and array_y must contain at least one pair of numbers."))}const pd={description:Ho("Calculates the sum of the difference of the squares of the values in two array."),args:[Qh("array_x (number, range<number>)",Ho("The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.")),Qh("array_y (number, range<number>)",Ho("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 gd(e,t,((e,t)=>e**2-t**2))},isExported:!0},md={description:Ho("Calculates the sum of the sum of the squares of the values in two array."),args:[Qh("array_x (number, range<number>)",Ho("The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.")),Qh("array_y (number, range<number>)",Ho("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 gd(e,t,((e,t)=>e**2+t**2))},isExported:!0},fd={description:Ho("Calculates the sum of squares of the differences of values in two array."),args:[Qh("array_x (number, range<number>)",Ho("The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.")),Qh("array_y (number, range<number>)",Ho("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 gd(e,t,((e,t)=>(e-t)**2))},isExported:!0},vd=!1,bd=[Qh("array (any, range<any>)",Ho("The array which will be transformed.")),Qh("ignore (number, default=0)",Ho("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.")),Qh("scan_by_column (number, default=false)",Ho("Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row."))];function Sd(e){const t=Math.trunc(e);if(0===t)return()=>!0;if(1===t)return e=>null!==e.value;if(2===t)return e=>!gi(e.value);if(3===t)return e=>null!==e.value&&!gi(e.value);throw new si(Ho("Argument ignore must be between 0 and 3"))}const Cd={description:Ho("Transforms a range of cells into a single column."),args:bd,compute:function(e,t={value:0},o={value:vd}){const s=ji(e),i=fi(t.value,this.locale),n=(Ei(o.value)?s:Vi(s)).flat().filter(Sd(i));return 0===n.length?new ai(Ho("No results for the given arguments of TOCOL.")):[n]},isExported:!0},yd={description:Ho("Transforms a range of cells into a single row."),args:bd,compute:function(e,t={value:0},o={value:vd}){const s=ji(e),i=fi(t.value,this.locale),n=(Ei(o.value)?s:Vi(s)).flat().filter(Sd(i)).map((e=>[e]));return 0===n.length||0===n[0].length?new ai(Ho("No results for the given arguments of TOROW.")):n},isExported:!0},wd={description:Ho("Transposes the rows and columns of a range."),args:[Qh("range (any, range<any>)",Ho("The range to be transposed."))],compute:function(e){const t=ji(e);return Ni(t[0].length,t.length,((e,o)=>t[o][e]))},isExported:!0},Id={description:Ho("Appends ranges vertically and in sequence to return a larger array."),args:[Qh("range1 (any, range<any>)",Ho("The first range to be appended.")),Qh("range2 (any, range<any>, repeating)",Ho("Additional ranges to add to range1."))],compute:function(...e){const t=Math.max(...e.map((e=>ji(e).length))),o=e.reduce(((e,t)=>e+ji(t)[0].length),0),s=Array(t).fill([]).map((()=>Array(o).fill({value:0})));let i=0;for(const t of e){const e=ji(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},xd={description:Ho("Wraps the provided row or column of cells by columns after a specified number of elements to form a new array."),args:[Qh("range (any, range<any>)",Ho("The range to wrap.")),Qh("wrap_count (number)",Ho("The maximum number of cells for each column, rounded down to the nearest whole number.")),Qh("pad_with (any, default=0)",Ho("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=ji(e),i=Ci(t?.value,this.locale);if(!ql(s))return new si(Ho("Argument range must be a single row or column."));const n=s.flat();return Ni(Math.ceil(n.length/i),i,((e,t)=>{const s=e*i+t;return s<n.length?n[s]:o}))},isExported:!0},Ed={description:Ho("Wraps the provided row or column of cells by rows after a specified number of elements to form a new array."),args:[Qh("range (any, range<any>)",Ho("The range to wrap.")),Qh("wrap_count (number)",Ho("The maximum number of cells for each row, rounded down to the nearest whole number.")),Qh("pad_with (any, default=0)",Ho("The value with which to fill the extra cells in the range."))],compute:function(e,t,o={value:0}){const s=ji(e),i=Ci(t?.value,this.locale);if(!ql(s))return new si(Ho("Argument range must be a single row or column."));const n=s.flat(),r=Math.ceil(n.length/i);return Ni(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:od,CHOOSECOLS:sd,CHOOSEROWS:id,EXPAND:nd,FLATTEN:rd,FREQUENCY:ad,HSTACK:ld,MDETERM:cd,MINVERSE:hd,MMULT:dd,SUMPRODUCT:ud,SUMX2MY2:pd,SUMX2PY2:md,SUMXMY2:fd,TOCOL:Cd,TOROW:yd,TRANSPOSE:wd,VSTACK:Id,WRAPCOLS:xd,WRAPROWS:Ed});const Td={description:Ho("Apply a large number format"),args:[Qh("value (number)",Ho("The number.")),Qh("unit (string, optional)",Ho("The formatting unit. Use 'k', 'm', or 'b' to force the unit"))],compute:function(e,t){return{value:fi(e,this.locale),format:$n(e,t,this.locale)}}};var Ad=Object.freeze({__proto__:null,FORMAT_LARGE_NUMBER:Td});const Dd=/^-?[a-z0-9]+$/i,_d={description:Ho("Absolute value of a number."),args:[Qh("value (number)",Ho("The number of which to return the absolute value."))],compute:function(e){return Math.abs(fi(e,this.locale))},isExported:!0},Od={description:Ho("Inverse cosine of a value, in radians."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)>1?new si(Ho("The value (%s) must be between -1 and 1 inclusive.",t)):Math.acos(t)},isExported:!0},Fd={description:Ho("Inverse hyperbolic cosine of a number."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1."))],compute:function(e){const t=fi(e,this.locale);return t<1?new si(Ho("The value (%s) must be greater than or equal to 1.",t)):Math.acosh(t)},isExported:!0},Pd={description:Ho("Inverse cotangent of a value."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse cotangent."))],compute:function(e){const t=fi(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},Md={description:Ho("Inverse hyperbolic cotangent of a value."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)<=1?new si(Ho("The value (%s) cannot be between -1 and 1 inclusive.",t)):Math.log((t+1)/(t-1))/2},isExported:!0},Nd={description:Ho("Inverse sine of a value, in radians."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)>1?new si(Ho("The value (%s) must be between -1 and 1 inclusive.",t)):Math.asin(t)},isExported:!0},kd={description:Ho("Inverse hyperbolic sine of a number."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic sine."))],compute:function(e){return Math.asinh(fi(e,this.locale))},isExported:!0},Vd={description:Ho("Inverse tangent of a value, in radians."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse tangent."))],compute:function(e){return Math.atan(fi(e,this.locale))},isExported:!0},Ld={description:Ho("Angle from the X axis to a point (x,y), in radians."),args:[Qh("x (number)",Ho("The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.")),Qh("y (number)",Ho("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=fi(e,this.locale),s=fi(t,this.locale);return 0===o&&0===s?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):Math.atan2(s,o)},isExported:!0},Hd={description:Ho("Inverse hyperbolic tangent of a number."),args:[Qh("value (number)",Ho("The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive."))],compute:function(e){const t=fi(e,this.locale);return Math.abs(t)>=1?new si(Ho("The value (%s) must be between -1 and 1 exclusive.",t)):Math.atanh(t)},isExported:!0},Ud={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("value (number)",Ho("The value to round up to the nearest integer multiple of factor.")),Qh("factor (number, default=1)",Ho("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=fi(e,this.locale),s=fi(t,this.locale);return s<0&&o>0?new si(Ho("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.ceil(o/s)*s:0,format:e?.format}},isExported:!0};function Bd(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 zd={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round up to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Qh("mode (number, default=0)",Ho("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=fi(t,this.locale);return{value:Bd(fi(e,this.locale),s,fi(o,this.locale)),format:e?.format}},isExported:!0},$d={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round up to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=fi(t,this.locale);return{value:Bd(fi(e,this.locale),o),format:e?.format}},isExported:!0},Gd={description:Ho("Cosine of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the cosine of, in radians."))],compute:function(e){return Math.cos(fi(e,this.locale))},isExported:!0},Wd={description:Ho("Hyperbolic cosine of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic cosine of."))],compute:function(e){return Math.cosh(fi(e,this.locale))},isExported:!0},qd={description:Ho("Cotangent of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the cotangent of, in radians."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tan(t)},isExported:!0},Zd={description:Ho("Hyperbolic cotangent of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic cotangent of."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.tanh(t)},isExported:!0},jd={description:Ho("Number of empty values."),args:[Qh("value1 (any, range)",Ho("The first value or range in which to count the number of blanks.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges in which to count the number of blanks."))],compute:function(...e){return Fi(e,((e,t)=>void 0===t||null===t.value||""===t.value?e+1:e),0)},isExported:!0},Yd={description:Ho("A conditional count across a range."),args:[Qh("range (range)",Ho("The range that is tested against criterion.")),Qh("criterion (string)",Ho("The pattern or test to apply to range."))],compute:function(...e){let t=0;return $i(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Xd={description:Ho("Count values depending on multiple criteria."),args:[Qh("criteria_range1 (range)",Ho("The range to check against criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("Additional criteria to check."))],compute:function(...e){let t=0;return $i(e,((e,o)=>{t+=1}),this.locale),t},isExported:!0},Kd={description:Ho("Counts number of unique values in a range."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider for uniqueness.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider for uniqueness."))],compute:function(...e){return $l(e)}},Jd={description:Ho("Counts number of unique values in a range, filtered by a set of criteria."),args:[Qh("range (range)",Ho("The range of cells from which the number of unique values will be counted.")),Qh("criteria_range1 (range)",Ho("The range of cells over which to evaluate criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=new Set;return $i(t,((t,s)=>{const i=e[t]?.[s];Xi(i)&&o.add(i.value)}),this.locale),o.size}},Qd={description:Ho("Cosecant of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the cosecant of, in radians."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sin(t)},isExported:!0},eu={description:Ho("Hyperbolic cosecant of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic cosecant of."))],compute:function(e){const t=fi(e,this.locale);return 0===t?new hi(Ho("Function [[FUNCTION_NAME]] caused a divide by zero error.")):1/Math.sinh(t)},isExported:!0},tu={description:Ho("Converts from another base to decimal."),args:[Qh("value (string)",Ho("The number to convert.")),Qh("base (number)",Ho("The base to convert the value from."))],compute:function(e,t){let o=fi(t,this.locale);if(o=Math.floor(o),2>o||o>36)return new si(Ho("The base (%s) must be between 2 and 36 inclusive.",o));const s=wi(e);if(""===s)return 0;if(!Dd.test(s))return new si(Ho("The value (%s) must be a valid base %s representation.",s,o));const i=parseInt(s,o);return isNaN(i)?new si(Ho("The value (%s) must be a valid base %s representation.",s,o)):i},isExported:!0},ou={description:Ho("Converts an angle value in radians to degrees."),args:[Qh("angle (number)",Ho("The angle to convert from radians to degrees."))],compute:function(e){return 180*fi(e,this.locale)/Math.PI},isExported:!0},su={description:Ho("Euler's number, e (~2.718) raised to a power."),args:[Qh("value (number)",Ho("The exponent to raise e."))],compute:function(e){return Math.exp(fi(e,this.locale))},isExported:!0},iu={description:Ho("Rounds number down to nearest multiple of factor."),args:[Qh("value (number)",Ho("The value to round down to the nearest integer multiple of factor.")),Qh("factor (number, default=1)",Ho("The number to whose multiples value will be rounded."))],compute:function(e,t={value:1}){const o=fi(e,this.locale),s=fi(t,this.locale);return s<0&&o>0?new si(Ho("The factor (%s) must be positive when the value (%s) is positive.",s,o)):{value:s?Math.floor(o/s)*s:0,format:e?.format}},isExported:!0};function nu(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 ru={description:Ho("Rounds number down to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round down to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded. The sign of significance will be ignored.")),Qh("mode (number, default=0)",Ho("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=fi(t,this.locale);return{value:nu(fi(e,this.locale),s,fi(o,this.locale)),format:e?.format}},isExported:!0},au={description:Ho("Rounds number down to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round down to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){const o=fi(t,this.locale);return{value:nu(fi(e,this.locale),o),format:e?.format}},isExported:!0},lu={description:Ho("Whether the provided value is even."),args:[Qh("value (number)",Ho("The value to be verified as even."))],compute:function(e){const t=Si(e,this.locale);return!(1&Math.floor(Math.abs(t)))},isExported:!0},cu={description:Ho("Rounds number up to nearest multiple of factor."),args:[Qh("number (number)",Ho("The value to round up to the nearest integer multiple of significance.")),Qh("significance (number, default=1)",Ho("The number to whose multiples number will be rounded."))],compute:function(e,t={value:1}){return{value:Bd(fi(e,this.locale),fi(t,this.locale)),format:e?.format}},isExported:!0},hu={description:Ho("Whether the provided value is even."),args:[Qh("value (number)",Ho("The value to be verified as even."))],compute:function(e){const t=Si(e,this.locale);return!!(1&Math.floor(Math.abs(t)))},isExported:!0},du={description:Ho("The logarithm of a number, base e (euler's number)."),args:[Qh("value (number)",Ho("The value for which to calculate the logarithm, base e."))],compute:function(e){const t=fi(e,this.locale);return t<=0?new si(Ho("The value (%s) must be strictly positive.",t)):Math.log(t)},isExported:!0},uu={description:Ho("The logarithm of a number, for a given base."),args:[Qh("value (number)",Ho("The value for which to calculate the logarithm.")),Qh("base (number, default=10)",Ho("The base of the logarithm."))],compute:function(e,t={value:10}){const o=fi(e,this.locale),s=fi(t,this.locale);return o<=0?new si(Ho("The value (%s) must be strictly positive.",o)):s<=0?new si(Ho("The base (%s) must be strictly positive.",s)):1===s?new si(Ho("The base must be different from 1.")):Math.log10(o)/Math.log10(s)},isExported:!0};function gu(e,t){Wl(t,Ho("The divisor must be different from 0."));const o=e%t;return o>0&&t<0||o<0&&t>0?o+t:o}const pu={description:Ho("Modulo (remainder) operator."),args:[Qh("dividend (number)",Ho("The number to be divided to find the remainder.")),Qh("divisor (number)",Ho("The number to divide by."))],compute:function(e,t){const o=fi(t,this.locale);return{value:gu(fi(e,this.locale),o),format:e?.format}},isExported:!0},mu={description:Ho("Returns a n x n unit matrix, where n is the input dimension."),args:[Qh("dimension (number)",Ho("An integer specifying the dimension size of the unit matrix. It must be positive."))],compute:function(e){const t=Ci(e,this.locale);return t<1?new si(Ho("The argument dimension must be positive")):Xl(t)},isExported:!0},fu={description:Ho("Rounds a number up to the nearest odd integer."),args:[Qh("value (number)",Ho("The value to round to the next greatest odd number."))],compute:function(e){const t=fi(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},vu={description:Ho("The number pi."),args:[],compute:function(){return Math.PI},isExported:!0},bu={description:Ho("A number raised to a power."),args:[Qh("base (number)",Ho("The number to raise to the exponent power.")),Qh("exponent (number)",Ho("The exponent to raise base to."))],compute:function(e,t){const o=fi(e,this.locale),s=fi(t,this.locale);return o<0&&!Number.isInteger(s)?new si(Ho("The exponent (%s) must be an integer when the base is negative.",s)):{value:Math.pow(o,s),format:e?.format}},isExported:!0},Su={description:Ho("Result of multiplying a series of numbers together."),args:[Qh("factor1 (number, range<number>)",Ho("The first number or range to calculate for the product.")),Qh("factor2 (number, range<number>, repeating)",Ho("More numbers or ranges to calculate for the product."))],compute:function(...e){let t=0,o=1;for(const s of e)if(js(s))for(const e of s)for(const s of e){const e=s.value;if("number"==typeof e&&(o*=e,t+=1),gi(e))return s}else void 0!==s&&null!==s.value&&(o*=Si(s,this.locale),t+=1);return{value:0===t?0:o,format:ui(e[0])}},isExported:!0},Cu={description:Ho("A random number between 0 inclusive and 1 exclusive."),args:[],compute:function(){return Math.random()},isExported:!0},yu={description:Ho("Returns a grid of random numbers between 0 inclusive and 1 exclusive."),args:[Qh("rows (number, default=1)",Ho("The number of rows to be returned.")),Qh("columns (number, default=1)",Ho("The number of columns to be returned.")),Qh("min (number, default=0)",Ho("The minimum number you would like returned.")),Qh("max (number, default=1)",Ho("The maximum number you would like returned.")),Qh("whole_number (number, default=FALSE)",Ho("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=Ci(t,this.locale),r=Ci(e,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=Ei(i);if(n<1)return new si(Ho("The number of columns (%s) must be positive.",n));if(r<1)return new si(Ho("The number of rows (%s) must be positive.",r));if(a>l)return new si(Ho("The maximum (%s) must be greater than or equal to the minimum (%s).",l,a));if(c&&(!Number.isInteger(a)||!Number.isInteger(l)))return new si(Ho("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},wu={description:Ho("Random integer between two values, inclusive."),args:[Qh("low (number)",Ho("The low end of the random range.")),Qh("high (number)",Ho("The high end of the random range."))],compute:function(e,t){let o=fi(e,this.locale);Number.isInteger(o)||(o=Math.ceil(o));let s=fi(t,this.locale);return Number.isInteger(s)||(s=Math.floor(s)),o>s?new si(Ho("The high (%s) must be greater than or equal to the low (%s).",s,o)):{value:o+Math.ceil((s-o+1)*Math.random())-1,format:e?.format}},isExported:!0},Iu={description:Ho("Rounds a number according to standard rules."),args:[Qh("value (number)",Ho("The value to round to places number of places.")),Qh("places (number, default=0)",Ho("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=fi(e,this.locale);let s=fi(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},xu={description:Ho("Rounds down a number."),args:[Qh("value (number)",Ho("The value to round to places number of places, always rounding down.")),Qh("places (number, default=0)",Ho("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=fi(e,this.locale);let s=fi(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},Eu={description:Ho("Rounds up a number."),args:[Qh("value (number)",Ho("The value to round to places number of places, always rounding up.")),Qh("places (number, default=0)",Ho("The number of decimal places to which to round."))],compute:function(e,t={value:0}){const o=fi(e,this.locale);let s=fi(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},Ru={description:Ho("Secant of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the secant of, in radians."))],compute:function(e){return 1/Math.cos(fi(e,this.locale))},isExported:!0},Tu={description:Ho("Hyperbolic secant of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic secant of."))],compute:function(e){return 1/Math.cosh(fi(e,this.locale))},isExported:!0},Au={description:Ho("Returns a sequence of numbers."),args:[Qh("rows (number)",Ho("The number of rows to return")),Qh("columns (number, optional, default=1)",Ho("The number of columns to return")),Qh("start (number, optional, default=1)",Ho("The first number in the sequence")),Qh("step (number, optional, default=1)",Ho("The amount to increment each value in the sequence"))],compute:function(e,t={value:1},o={value:1},s={value:1}){const i=fi(o,this.locale),n=fi(s,this.locale),r=Ci(e,this.locale),a=Ci(t,this.locale);return a<1?new si(Ho("The number of columns (%s) must be positive.",a)):r<1?new si(Ho("The number of rows (%s) must be positive.",r)):Ni(a,r,((e,t)=>({value:i+t*a*n+e*n})))},isExported:!0},Du={description:Ho("Sine of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the sine of, in radians."))],compute:function(e){return Math.sin(fi(e,this.locale))},isExported:!0},_u={description:Ho("Hyperbolic sine of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic sine of."))],compute:function(e){return Math.sinh(fi(e,this.locale))},isExported:!0},Ou={description:Ho("Positive square root of a positive number."),args:[Qh("value (number)",Ho("The number for which to calculate the positive square root."))],compute:function(e){const t=fi(e,this.locale);return t<0?new si(Ho("The value (%s) must be positive or null.",t)):{value:Math.sqrt(t),format:e?.format}},isExported:!0},Fu={description:Ho("Sum of a series of numbers and/or cells."),args:[Qh("value1 (number, range<number>)",Ho("The first number or range to add together.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional numbers or ranges to add to value1."))],compute:function(...e){const t=e[0];return{value:zl(e,this.locale),format:ui(t)}},isExported:!0},Pu={description:Ho("A conditional sum across a range."),args:[Qh("criteria_range (range)",Ho("The range which is tested against criterion.")),Qh("criterion (string)",Ho("The pattern or test to apply to range.")),Qh("sum_range (range, default=criteria_range)",Ho("The range to be summed, if different from range."))],compute:function(e,t,o){void 0===o&&(o=e);let s=0;return $i([e,t],((e,t)=>{const i=o[e]?.[t]?.value;"number"==typeof i&&(s+=i)}),this.locale),s},isExported:!0},Mu={description:Ho("Sums a range depending on multiple criteria."),args:[Qh("sum_range (range)",Ho("The range to sum.")),Qh("criteria_range1 (range)",Ho("The range to check against criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1.")),Qh("criteria_range2 (any, range, repeating)",Ho("Additional ranges to check.")),Qh("criterion2 (string, repeating)",Ho("Additional criteria to check."))],compute:function(e,...t){let o=0;return $i(t,((t,s)=>{const i=e[t]?.[s]?.value;"number"==typeof i&&(o+=i)}),this.locale),o},isExported:!0},Nu={description:Ho("Tangent of an angle provided in radians."),args:[Qh("angle (number)",Ho("The angle to find the tangent of, in radians."))],compute:function(e){return Math.tan(fi(e,this.locale))},isExported:!0},ku={description:Ho("Hyperbolic tangent of any real number."),args:[Qh("value (number)",Ho("Any real value to calculate the hyperbolic tangent of."))],compute:function(e){return Math.tanh(fi(e,this.locale))},isExported:!0};function Vu(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 Lu={description:Ho("Truncates a number."),args:[Qh("value (number)",Ho("The value to be truncated.")),Qh("places (number, default=0)",Ho("The number of significant digits to the right of the decimal point to retain."))],compute:function(e,t={value:0}){return{value:Vu(fi(e,this.locale),fi(t,this.locale)),format:e?.format}},isExported:!0},Hu={description:Ho("Rounds a number down to the nearest integer that is less than or equal to it."),args:[Qh("value (number)",Ho("The number to round down to the nearest integer."))],compute:function(e){return Math.floor(fi(e,this.locale))},isExported:!0};var Uu=Object.freeze({__proto__:null,ABS:_d,ACOS:Od,ACOSH:Fd,ACOT:Pd,ACOTH:Md,ASIN:Nd,ASINH:kd,ATAN:Vd,ATAN2:Ld,ATANH:Hd,CEILING:Ud,CEILING_MATH:zd,CEILING_PRECISE:$d,COS:Gd,COSH:Wd,COT:qd,COTH:Zd,COUNTBLANK:jd,COUNTIF:Yd,COUNTIFS:Xd,COUNTUNIQUE:Kd,COUNTUNIQUEIFS:Jd,CSC:Qd,CSCH:eu,DECIMAL:tu,DEGREES:ou,EXP:su,FLOOR:iu,FLOOR_MATH:ru,FLOOR_PRECISE:au,INT:Hu,ISEVEN:lu,ISODD:hu,ISO_CEILING:cu,LN:du,LOG:uu,MOD:pu,MUNIT:mu,ODD:fu,PI:vu,POWER:bu,PRODUCT:Su,RAND:Cu,RANDARRAY:yu,RANDBETWEEN:wu,ROUND:Iu,ROUNDDOWN:xu,ROUNDUP:Eu,SEC:Ru,SECH:Tu,SEQUENCE:Au,SIN:Du,SINH:_u,SQRT:Ou,SUM:Fu,SUMIF:Pu,SUMIFS:Mu,TAN:Nu,TANH:ku,TRUNC:Lu});function Bu(e,t){const o=[],s=[];let i=0,n=0;Di([e],(e=>{o.push(e),i+=1})),Di([t],(e=>{s.push(e),n+=1})),Gl(i===n,Ho("[[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 zu(e,t,o){const{flatDataX:s,flatDataY:i}=Bu(e,t),n=i.length;Wl(n),o&&Wl(n-1);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 $u(e,t,o,s){let i=0;const n=o?Mi:Pi,r=n(e,((e,t)=>(i+=1,e+t)),0,s);Wl(i),t&&Wl(i-1);const a=r/i;return n(e,((e,t)=>e+Math.pow(t-a,2)),0,s)/(i-(t?1:0))}function Gu(e,t,o,s){const i=fi(t,s);Gl(o?0<=i&&i<=1:0<i&&i<1,Ho("Function [[FUNCTION_NAME]] parameter 2 value is out of range."));const n=[];let r,a=0;return Di(e,(e=>{const t=e?.value;"number"==typeof t&&(r=Gi(n,e,"nextSmaller","asc",n.length,((e,t)=>e[t])),n.splice(r+1,0,t),a++)})),Gl(0!==a,Ki),o||Gl(1/(a+1)<=i&&i<=a/(a+1),Ho("Function [[FUNCTION_NAME]] parameter 2 value is out of range.")),Ds(n,i,o)}const Wu={description:Ho("Average magnitude of deviations from mean."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){let t=0;const o=Pi(e,((e,o)=>(t+=1,e+o)),0,this.locale);if(0===t)return new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error."));const s=o/t;return Pi(e,((e,t)=>e+Math.abs(s-t)),0,this.locale)/t},isExported:!0},qu={description:Ho("Numerical average value in a dataset, ignoring text."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the average value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){return{value:ic(e,this.locale),format:ui(e[0])}},isExported:!0},Zu=Ho("[[FUNCTION_NAME]] has mismatched range sizes."),ju=Ho("[[FUNCTION_NAME]] expects the weight to be positive or equal to 0."),Yu={description:Ho("Weighted average."),args:[Qh("values (number, range<number>)",Ho("Values to average.")),Qh("weights (number, range<number>)",Ho("Weights for each corresponding value.")),Qh("additional_values (number, range<number>, repeating)",Ho("Additional values to average.")),Qh("additional_weights (number, range<number>, repeating)",Ho("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(!Zl(i,n))return new si(Zu);if(js(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=js(n)?n?.[e][s].value:fi(n,this.locale),l="number"==typeof r,c="number"==typeof a;if(l&&c){if(a<0)return new si(ju);t+=r*a,o+=a}else if(l!==c)return new si(Ho("[[FUNCTION_NAME]] expects number values."))}else{const e=fi(i,this.locale),s=js(n)?n?.[0][0].value:fi(n,this.locale);if("number"==typeof s){if(s<0)return new si(ju);t+=e*s,o+=s}}}return 0===o?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:t/o,format:ui(e[0])}}},Xu={description:Ho("Numerical average value in a dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the average value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the average value."))],compute:function(...e){let t=0;const o=Mi(e,((e,o)=>(t+=1,e+o)),0,this.locale);return 0===t?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):{value:o/t,format:ui(e[0])}},isExported:!0},Ku={description:Ho("Average of values depending on criteria."),args:[Qh("criteria_range (number, range<number>)",Ho("The range to check against criterion.")),Qh("criterion (string)",Ho("The pattern or test to apply to criteria_range.")),Qh("average_range (number, range<number>, default=criteria_range)",Ho("The range to average. If not included, criteria_range is used for the average instead."))],compute:function(e,t,o){const s=ji(void 0===o?e:o);let i=0,n=0;return $i([e,t],((e,t)=>{const o=s[e]?.[t]?.value;"number"==typeof o&&(i+=1,n+=o)}),this.locale),0===i?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):n/i},isExported:!0},Ju={description:Ho("Average of values depending on multiple criteria."),args:[Qh("average_range (range)",Ho("The range to average.")),Qh("criteria_range1 (range)",Ho("The range to check against criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1.")),Qh("criteria_range2 (any, range, repeating)",Ho("Additional criteria_range and criterion to check.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){const o=ji(e);let s=0,i=0;return $i(t,((e,t)=>{const n=o[e]?.[t]?.value;"number"==typeof n&&(s+=1,i+=n)}),this.locale),0===s?new hi(Ho("Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.")):i/s},isExported:!0},Qu={description:Ho("The number of numeric values in dataset."),args:[Qh("value1 (number, any, range<number>)",Ho("The first value or range to consider when counting.")),Qh("value2 (number, any, range<number>, repeating)",Ho("Additional values or ranges to consider when counting."))],compute:function(...e){return nc(e,this.locale)},isExported:!0},eg={description:Ho("The number of values in a dataset."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider when counting.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider when counting."))],compute:function(...e){return rc(e)},isExported:!0},tg={description:Ho("The covariance of a dataset."),args:[Qh("data_y (any, range)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (any, range)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return zu(e,t,!1)},isExported:!0},og={description:Ho("The covariance of a dataset."),args:[Qh("data_y (any, range)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (any, range)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return zu(e,t,!1)},isExported:!0},sg={description:Ho("The sample covariance of a dataset."),args:[Qh("data_y (any, range)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (any, range)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return zu(e,t,!0)},isExported:!0},ig={description:Ho("Calculates the expected y-value for a specified x based on a linear regression of a dataset."),args:[Qh("x (number, range<number>)",Ho("The value(s) on the x-axis to forecast.")),Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t,o){const{flatDataX:s,flatDataY:i}=Bu(t,o);return 0===s.length||0===i.length?new ai(Ki):fc([i],[s],ki(ji(e),(e=>fi(e,this.locale))),!0)},isExported:!0},ng={description:Ho("Fits points to exponential growth trend."),args:[Qh("known_data_y (range<number>)",Ho("The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.")),Qh("known_data_x (range<number>, default={1;2;3;...})",Ho("The values of the independent variable(s) corresponding with known_data_y.")),Qh("new_data_x (any, range, default=known_data_x)",Ho("The data points to return the y values for on the ideal curve fit.")),Qh("b (boolean, default=TRUE)",Ho("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 0===e.length||0===e[0].length?new si(Ji("known_data_y")):pc(fc(mc(bi(e,"the first argument (known_data_y)")),bi(t,"the second argument (known_data_x)"),bi(o,"the third argument (new_data_y)"),Ei(s)))}},rg={description:Ho("Compute the intercept of the linear regression."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);const[[],[i]]=hc([o],[s]);return i},isExported:!0},ag={description:Ho("Nth largest element from a data set."),args:[Qh("data (any, range)",Ho("Array or range containing the dataset to consider.")),Qh("n (number)",Ho("The rank from largest to smallest of the element to return."))],compute:function(e,t){const o=Math.trunc(fi(t?.value,this.locale)),s=[];let i,n=0;Di([e],(e=>{"number"==typeof e?.value&&(i=Gi(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.shift(),n--))}));const r=s.shift();return void 0===r?new si(Ki):n<o?new si(Ho("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},lg={description:Ho("Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>, default={1;2;3;...})",Ho("The range representing the array or matrix of independent data.")),Qh("calculate_b (boolean, default=TRUE)",Ho("A flag specifying wheter to compute the slope or not")),Qh("verbose (boolean, default=FALSE)",Ho("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 0===e.length||0===e[0].length?new si(Ji("data_y")):hc(bi(t,"the first argument (data_y)"),bi(e,"the second argument (data_x)"),Ei(o),Ei(s))},isExported:!0},cg={description:Ho("Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>, optional, default={1;2;3;...})",Ho("The range representing the array or matrix of independent data.")),Qh("calculate_b (boolean, default=TRUE)",Ho("A flag specifying wheter to compute the slope or not")),Qh("verbose (boolean, default=FALSE)",Ho("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}){if(0===e.length||0===e[0].length)return new si(Ji("data_y"));const i=hc(bi(t,"the second argument (data_x)"),mc(bi(e,"the first argument (data_y)")),Ei(o),Ei(s));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},hg={description:Ho("Compute the Matthews correlation coefficient of a dataset."),args:[Qh("data_x (range)",Ho("The range representing the array or matrix of observed data.")),Qh("data_y (range)",Ho("The range representing the array or matrix of predicted data."))],compute:function(e,t){const o=e.flat(),s=t.flat();if(sc(o,s),0===o.length||0===s.length)return new ai(Ki);const i=o.length;let n=0,r=0,a=0,l=0;for(let e=0;e<i;++e){const t=Ei(o[e]);t===Ei(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},dg={description:Ho("Maximum value in a numeric dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the maximum value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){return ac(e,this.locale)},isExported:!0},ug={description:Ho("Maximum numeric value in a dataset."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider when calculating the maximum value.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider when calculating the maximum value."))],compute:function(...e){const t=Mi(e,((e,t)=>Math.max(t,e)),-1/0,this.locale);return{value:t===-1/0?0:t,format:ui(e[0])}},isExported:!0},gg={description:Ho("Returns the maximum value in a range of cells, filtered by a set of criteria."),args:[Qh("range (range)",Ho("The range of cells from which the maximum will be determined.")),Qh("criteria_range1 (range)",Ho("The range of cells over which to evaluate criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=-1/0;return $i(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},pg={description:Ho("Median value in a numeric dataset."),args:[Qh("value1 (any, range)",Ho("The first value or range to consider when calculating the median value.")),Qh("value2 (any, range, repeating)",Ho("Additional values or ranges to consider when calculating the median value."))],compute:function(...e){const t=[];return _i(e,(e=>{t.push(e)}),this.locale),{value:Gu(t,{value:.5},!0,this.locale),format:ui(t[0])}},isExported:!0},mg={description:Ho("Minimum value in a numeric dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the minimum value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){return lc(e,this.locale)},isExported:!0},fg={description:Ho("Minimum numeric value in a dataset."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range to consider when calculating the minimum value.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to consider when calculating the minimum value."))],compute:function(...e){const t=Mi(e,((e,t)=>Math.min(t,e)),1/0,this.locale);return{value:t===1/0?0:t,format:ui(e[0])}},isExported:!0},vg={description:Ho("Returns the minimum value in a range of cells, filtered by a set of criteria."),args:[Qh("range (range)",Ho("The range of cells from which the minimum will be determined.")),Qh("criteria_range1 (range)",Ho("The range of cells over which to evaluate criterion1.")),Qh("criterion1 (string)",Ho("The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.")),Qh("criteria_range2 (any, range, repeating)",Ho("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.")),Qh("criterion2 (string, repeating)",Ho("The pattern or test to apply to criteria_range2."))],compute:function(e,...t){let o=1/0;return $i(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 bg(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);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 Sg={description:Ho("Compute the Pearson product-moment correlation coefficient of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){return bg(e,t)},isExported:!0},Cg=Sg,yg={description:Ho("Value at a given percentile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("percentile (number)",Ho("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return Ig.compute.bind(this)(e,t)},isExported:!0},wg={description:Ho("Value at a given percentile of a dataset exclusive of 0 and 1."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("percentile (number)",Ho("The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned."))],compute:function(e,t){return{value:Gu([e],t,!1,this.locale),format:ui(e)}},isExported:!0},Ig={description:Ho("Value at a given percentile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("percentile (number)",Ho("The percentile whose value within data will be calculated and returned."))],compute:function(e,t){return{value:Gu([e],t,!0,this.locale),format:ui(e)}},isExported:!0},xg={description:Ho("Compute the coefficients of polynomial regression of the dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data.")),Qh("order (number)",Ho("The order of the polynomial to fit the data, between 1 and 6.")),Qh("intercept (boolean, default=TRUE)",Ho("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s={value:!0}){const{flatDataX:i,flatDataY:n}=Bu(e,t);return 0===i.length||0===n.length?new ai(Ki):dc(n,i,fi(o,this.locale),Ei(s))},isExported:!1},Eg={description:Ho("Predict value by computing a polynomial regression of the dataset."),args:[Qh("x (number, range<number>)",Ho("The value(s) on the x-axis to forecast.")),Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data.")),Qh("order (number)",Ho("The order of the polynomial to fit the data, between 1 and 6.")),Qh("intercept (boolean, default=TRUE)",Ho("A flag specifying whether to compute the intercept or not."))],compute:function(e,t,o,s,i={value:!0}){const n=fi(s,this.locale),{flatDataX:r,flatDataY:a}=Bu(t,o);if(0===r.length||0===a.length)return new ai(Ki);const l=dc(a,r,n,Ei(i)).flat();return ki(ji(e),(e=>gc(l,fi(e,this.locale),n)))},isExported:!1},Rg={description:Ho("Value nearest to a specific quartile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("quartile_number (number)",Ho("Which quartile value to return."))],compute:function(e,t){return Ag.compute.bind(this)(e,t)},isExported:!0},Tg={description:Ho("Value nearest to a specific quartile of a dataset exclusive of 0 and 4."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("quartile_number (number)",Ho("Which quartile value, exclusive of 0 and 4, to return."))],compute:function(e,t){return{value:Gu([e],{value:.25*Math.trunc(fi(t,this.locale))},!1,this.locale),format:ui(e)}},isExported:!0},Ag={description:Ho("Value nearest to a specific quartile of a dataset."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("quartile_number (number)",Ho("Which quartile value to return."))],compute:function(e,t){return{value:Gu([e],{value:.25*Math.trunc(fi(t,this.locale))},!0,this.locale),format:ui(e)}},isExported:!0},Dg={description:Ho("Returns the rank of a specified value in a dataset."),args:[Qh("value (number)",Ho("The value whose rank will be determined.")),Qh("data (range)",Ho("The range containing the dataset to consider.")),Qh("is_ascending (boolean, default=FALSE)",Ho("Whether to consider the values in data in descending or ascending order."))],compute:function(e,t,o={value:!1}){const s=Ei(o),i=fi(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=fi(t,this.locale);e===i?r=!0:e>i!==s&&n++}return r?n:new ai(Ho("Value not found in the given data."))},isExported:!0},_g={description:Ho("Compute the square of r, the Pearson product-moment correlation coefficient of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const o=bg(e,t);if(o instanceof Error)throw o;return Math.pow(o,2)},isExported:!0},Og={description:Ho("Compute the slope of the linear regression."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);const[[i]]=hc([o],[s]);return i},isExported:!0},Fg={description:Ho("Nth smallest element in a data set."),args:[Qh("data (any, range)",Ho("The array or range containing the dataset to consider.")),Qh("n (number)",Ho("The rank from smallest to largest of the element to return."))],compute:function(e,t){const o=Math.trunc(fi(t?.value,this.locale)),s=[];let i,n=0;Di([e],(e=>{"number"==typeof e?.value&&(i=Gi(s,e,"nextSmaller","asc",s.length,((e,t)=>e[t].value)),s.splice(i+1,0,e),n++,n>o&&(s.pop(),n--))}));const r=s.pop();return void 0===r?new si(Ki):n<o?new si(Ho("Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.",o)):r},isExported:!0},Pg={description:Ho("Compute the Spearman rank correlation coefficient of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(t,e);if(0===o.length||0===s.length)return new ai(Ki);const 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},Mg={description:Ho("Standard deviation."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(zg.compute.bind(this)(...e))},isExported:!0},Ng={description:Ho("Standard deviation of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt($g.compute.bind(this)(...e))},isExported:!0},kg={description:Ho("Standard deviation."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Gg.compute.bind(this)(...e))},isExported:!0},Vg={description:Ho("Standard deviation of sample (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return Math.sqrt(Wg.compute.bind(this)(...e))},isExported:!0},Lg={description:Ho("Standard deviation of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(qg.compute.bind(this)(...e))},isExported:!0},Hg={description:Ho("Standard deviation of entire population (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return Math.sqrt(Zg.compute.bind(this)(...e))},isExported:!0},Ug={description:Ho("Calculates the standard error of the predicted y-value for each x in the regression of a dataset."),args:[Qh("data_y (range<number>)",Ho("The range representing the array or matrix of dependent data.")),Qh("data_x (range<number>)",Ho("The range representing the array or matrix of independent data."))],compute:function(e,t){const{flatDataX:o,flatDataY:s}=Bu(e,t);if(0===o.length||0===s.length)return new ai(Ki);return hc([o],[s],!0,!0)[1][2]},isExported:!0},Bg={description:Ho("Fits points to linear trend derived via least-squares."),args:[Qh("known_data_y (number, range<number>)",Ho("The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.")),Qh("known_data_x (number, range<number>, optional, default={1;2;3;...})",Ho("The values of the independent variable(s) corresponding with known_data_y.")),Qh("new_data_x (number, range<number>, optional, default=known_data_x)",Ho("The data points to return the y values for on the ideal curve fit.")),Qh("b (boolean, optional, default=TRUE)",Ho("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 0===e.length||0===e[0].length?new si(Ji("known_data_y")):fc(bi(e,"the first argument (known_data_y)"),bi(t,"the second argument (known_data_x)"),bi(o,"the third argument (new_data_y)"),Ei(s))}},zg={description:Ho("Variance."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return $u(e,!0,!1,this.locale)},isExported:!0},$g={description:Ho("Variance of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return $u(e,!1,!1,this.locale)},isExported:!0},Gg={description:Ho("Variance."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return $u(e,!0,!1,this.locale)},isExported:!0},Wg={description:Ho("Variance of sample (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the sample.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the sample."))],compute:function(...e){return $u(e,!0,!0,this.locale)},isExported:!0},qg={description:Ho("Variance of entire population."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return $u(e,!1,!1,this.locale)},isExported:!0},Zg={description:Ho("Variance of entire population (text as 0)."),args:[Qh("value1 (number, range<number>)",Ho("The first value or range of the population.")),Qh("value2 (number, range<number>, repeating)",Ho("Additional values or ranges to include in the population."))],compute:function(...e){return $u(e,!1,!0,this.locale)},isExported:!0};var jg=Object.freeze({__proto__:null,AVEDEV:Wu,AVERAGE:qu,AVERAGEA:Xu,AVERAGEIF:Ku,AVERAGEIFS:Ju,AVERAGE_WEIGHTED:Yu,CORREL:Cg,COUNT:Qu,COUNTA:eg,COVAR:tg,COVARIANCE_P:og,COVARIANCE_S:sg,FORECAST:ig,GROWTH:ng,INTERCEPT:rg,LARGE:ag,LINEST:lg,LOGEST:cg,MATTHEWS:hg,MAX:dg,MAXA:ug,MAXIFS:gg,MEDIAN:pg,MIN:mg,MINA:fg,MINIFS:vg,PEARSON:Sg,PERCENTILE:yg,PERCENTILE_EXC:wg,PERCENTILE_INC:Ig,POLYFIT_COEFFS:xg,POLYFIT_FORECAST:Eg,QUARTILE:Rg,QUARTILE_EXC:Tg,QUARTILE_INC:Ag,RANK:Dg,RSQ:_g,SLOPE:Og,SMALL:Fg,SPEARMAN:Pg,STDEV:Mg,STDEVA:Vg,STDEVP:Lg,STDEVPA:Hg,STDEV_P:Ng,STDEV_S:kg,STEYX:Ug,TREND:Bg,VAR:zg,VARA:Wg,VARP:qg,VARPA:Zg,VAR_P:$g,VAR_S:Gg});function Yg(e,t,o,s){const i=new Map,n=e.length;for(let t=n-1;t>=0;t--)i.set(wi(e[t][0]).toUpperCase(),t);const r=t?.value;if("number"!=typeof r&&"string"!=typeof r)throw new si(Ho("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 si(Ho("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=wi(t).toUpperCase();if(a=i.get(e)??-1,-1===a)throw new si(Ho("The field (%s) must be one of %s.",wi(t),[...i.keys()].toString()))}const l=o[0].length;if(l<2)throw new si(Ho("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++){const n=[];let r=!0;for(let s=0;s<o.length;s++){const a=wi(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}$i(n,((e,t)=>{c.add(t)}),s,!0)}}const d=e[a];return[...c].map((e=>d[e+1]))}const Xg=[Qh("database (range)",Ho("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.")),Qh("field (number, string)",Ho("Indicates which column in database contains the values to be extracted and operated on.")),Qh("criteria (range)",Ho("An array or range containing zero or more criteria to filter the database values by before operating."))],Kg={description:Ho("Average of a set of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return qu.compute.bind(this)([s])},isExported:!0},Jg={description:Ho("Counts values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Qu.compute.bind(this)([s])},isExported:!0},Qg={description:Ho("Counts values and text from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return eg.compute.bind(this)([s])},isExported:!0},ep={description:Ho("Single value from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return 1!==s.length?new si(Ho("More than one match found in DGET evaluation.")):s[0]},isExported:!0},tp={description:Ho("Maximum of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return dg.compute.bind(this)([s])},isExported:!0},op={description:Ho("Minimum of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return mg.compute.bind(this)([s])},isExported:!0},sp={description:Ho("Product of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Su.compute.bind(this)([s])},isExported:!0},ip={description:Ho("Standard deviation of population sample from table."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Mg.compute.bind(this)([s])},isExported:!0},np={description:Ho("Standard deviation of entire population from table."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Lg.compute.bind(this)([s])},isExported:!0},rp={description:Ho("Sum of values from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return Fu.compute.bind(this)([s])},isExported:!0},ap={description:Ho("Variance of population sample from table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return zg.compute.bind(this)([s])},isExported:!0},lp={description:Ho("Variance of a population from a table-like range."),args:Xg,compute:function(e,t,o){const s=Yg(e,t,o,this.locale);return qg.compute.bind(this)([s])},isExported:!0};var cp=Object.freeze({__proto__:null,DAVERAGE:Kg,DCOUNT:Jg,DCOUNTA:Qg,DGET:ep,DMAX:tp,DMIN:op,DPRODUCT:sp,DSTDEV:ip,DSTDEVP:np,DSUM:rp,DVAR:ap,DVARP:lp});var hp;!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"}(hp||(hp={}));const dp={description:Ho("Converts year/month/day into a date."),args:[Qh("year (number)",Ho("The year component of the date.")),Qh("month (number)",Ho("The month component of the date.")),Qh("day (number)",Ho("The day component of the date."))],compute:function(e,t,o){let s=Math.trunc(fi(e,this.locale));const i=Math.trunc(fi(t,this.locale)),n=Math.trunc(fi(o,this.locale));if(s<0||s>9999)return new si(Ho("The year (%s) must be between 0 and 9999 inclusive.",s.toString()));s<1900&&(s+=1900);const r=gs(new Yo(s,i-1,n));return r<0?new si(Ho("The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.")):{value:r,format:this.locale.dateFormat}},isExported:!0},up={description:Ho("Calculates the number of days, months, or years between two dates."),args:[Qh("start_date (date)",Ho("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.")),Qh("end_date (date)",Ho("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.")),Qh("unit (string)",Ho('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=wi(o).toUpperCase();if(!Object.values(hp).includes(s))return new si(((e,t)=>{const o=e.map((e=>`'${e}'`)).join(", ");return Ho("The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.",t,o)})(Object.values(hp),wi(o)));const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=us(i),a=us(n);if(n<i)return new si(Ho("start_date (%s) should be on or before end_date (%s).",r.toLocaleDateString(),a.toLocaleDateString()));switch(s){case hp.WHOLE_YEARS:return ws(r,a);case hp.WHOLE_MONTHS:return Cs(r,a);case hp.WHOLE_DAYS:return ys(r,a);case hp.MONTH_WITHOUT_WHOLE_YEARS:return Cs(r,a)-12*ws(r,a);case hp.DAYS_WITHOUT_WHOLE_MONTHS:let e=a.getDate()-r.getDate();if(e<0){e=ms(new Yo(a.getFullYear(),a.getMonth()-1,1))-Math.abs(e)}return e;case hp.DAYS_BETWEEN_NO_MORE_THAN_ONE_YEAR:{if(function(e,t){return Ss(e,t,1)<1}(i,n))return ys(r,a);const e=new Yo(r.getFullYear(),a.getMonth(),a.getDate());let t=ys(r,e);return t<0&&(e.setFullYear(r.getFullYear()+1),t=ys(r,e)),t}}},isExported:!0},gp={description:Ho("Converts a date string to a date value."),args:[Qh("date_string (string)",Ho("The string representing the date."))],compute:function(e){const t=wi(e),o=ds(t,this.locale);return null===o?new si(Ho("The date_string (%s) cannot be parsed to date/time.",t.toString())):Math.trunc(o.value)},isExported:!0},pp={description:Ho("Day of the month that a specific date falls on."),args:[Qh("date (string)",Ho("The date from which to extract the day."))],compute:function(e){return Ri(e,this.locale).getDate()},isExported:!0},mp={description:Ho("Number of days between two dates."),args:[Qh("end_date (date)",Ho("The end of the date range.")),Qh("start_date (date)",Ho("The start of the date range."))],compute:function(e,t){const o=Ri(e,this.locale),s=Ri(t,this.locale),i=o.getTime()-s.getTime();return Math.round(i/Ko)},isExported:!0},fp={description:Ho("Number of days between two dates on a 360-day year (months of 30 days)."),args:[Qh("start_date (date)",Ho("The start date to consider in the calculation.")),Qh("end_date (date)",Ho("The end date to consider in the calculation.")),Qh("method (number, default=0)",Ho("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(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=Ss(s,i,Ei(o)?4:0);return Math.sign(i-s)*Math.round(360*n)},isExported:!0},vp={description:Ho("Date a number of months before/after another date."),args:[Qh("start_date (date)",Ho("The date from which to calculate the result.")),Qh("months (number)",Ho("The number of months before (negative) or after (positive) 'start_date' to calculate."))],compute:function(e,t){return{value:gs(vs(Ri(e,this.locale),Math.trunc(fi(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},bp={description:Ho("Last day of a month before or after a date."),args:[Qh("start_date (date)",Ho("The date from which to calculate the result.")),Qh("months (number)",Ho("The number of months before (negative) or after (positive) 'start_date' to consider."))],compute:function(e,t){const o=Ri(e,this.locale),s=Math.trunc(fi(t,this.locale)),i=o.getFullYear(),n=o.getMonth();return{value:gs(new Yo(i,n+s+1,0)),format:this.locale.dateFormat}},isExported:!0},Sp={description:Ho("Hour component of a specific time."),args:[Qh("time (date)",Ho("The time from which to calculate the hour component."))],compute:function(e){return Ri(e,this.locale).getHours()},isExported:!0},Cp={description:Ho("ISO week number of the year."),args:[Qh("date (date)",Ho("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=Ri(e,this.locale),o=t.getFullYear();let s=1;for(;4!==new Yo(o,0,s).getDay();)s+=1;const i=new Yo(o,0,s-3);let n=31;for(;4!==new Yo(o,11,n).getDay();)n-=1;const r=new Yo(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 Yo(o,11,n+3+1);break;case-1:let e=1;for(;4!==new Yo(o-1,0,e).getDay();)e+=1;l=new Yo(o-1,0,e-3)}const c=(t.getTime()-l.getTime())/Ko;return Math.floor(c/7)+1},isExported:!0},yp={description:Ho("Minute component of a specific time."),args:[Qh("time (date)",Ho("The time from which to calculate the minute component."))],compute:function(e){return Ri(e,this.locale).getMinutes()},isExported:!0},wp={description:Ho("Month of the year a specific date falls in"),args:[Qh("date (date)",Ho("The date from which to extract the month."))],compute:function(e){return Ri(e,this.locale).getMonth()+1},isExported:!0},Ip={description:Ho("Net working days between two provided days."),args:[Qh("start_date (date)",Ho("The start date of the period from which to calculate the number of net working days.")),Qh("end_date (date)",Ho("The end date of the period from which to calculate the number of net working days.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the date serial numbers to consider holidays."))],compute:function(e,t,o){return Ep.compute.bind(this)(e,t,{value:1},o)},isExported:!0};function xp(e){const t=e?.value;if("string"==typeof t){Gl(7===t.length&&[...t].every((e=>"0"===e||"1"===e)),Ho('When weekend is a string (%s) it must be composed of "0" or "1".',t));const e=[];for(let o=0;o<7;o++)"1"===t[o]&&e.push((o+1)%7);return e}if("number"==typeof t)return Gl(1<=t&&t<=7||11<=t&&t<=17,Ho("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 si(Ho("The weekend must be a number or a string."))}const Ep={description:Ho("Net working days between two dates (specifying weekends)."),args:[Qh("start_date (date)",Ho("The start date of the period from which to calculate the number of net working days.")),Qh("end_date (date)",Ho("The end date of the period from which to calculate the number of net working days.")),Qh("weekend (any, default=1)",Ho("A number or string representing which days of the week are considered weekends.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the dates to consider as holidays."))],compute:function(e,t,o={value:1},s){const i=Ri(e,this.locale),n=Ri(t,this.locale),r=xp(o),a=new Set;void 0!==s&&Di([s],(e=>{const t=Ri(e,this.locale);a.add(t.getTime())}));const l=i.getTime()>n.getTime(),c=Yo.fromTimestamp((l?i:n).getTime()),h=Yo.fromTimestamp((l?n:i).getTime()),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},Rp={description:Ho("Current date and time as a date value."),args:[],compute:function(){const e=Yo.now(),t=e.getTime()-Xo.getTime(),o=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/Ko)+o,format:Hl(this.locale)}},isExported:!0},Tp={description:Ho("Minute component of a specific time."),args:[Qh("time (date)",Ho("The time from which to calculate the second component."))],compute:function(e){return Ri(e,this.locale).getSeconds()},isExported:!0},Ap={description:Ho("Converts hour/minute/second into a time."),args:[Qh("hour (number)",Ho("The hour component of the time.")),Qh("minute (number)",Ho("The minute component of the time.")),Qh("second (number)",Ho("The second component of the time."))],compute:function(e,t,o){let s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=Math.trunc(fi(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,s<0?new si(Ho("The function [[FUNCTION_NAME]] result cannot be negative")):{value:s/24+i/1440+n/86400,format:this.locale.timeFormat}},isExported:!0},Dp={description:Ho("Converts a time string into its serial number representation."),args:[Qh("time_string (string)",Ho("The string that holds the time representation."))],compute:function(e){const t=wi(e),o=ds(t,this.locale);if(null===o)return new si(Ho("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},_p={description:Ho("Current date as a date value."),args:[],compute:function(){const e=Yo.now();return{value:gs(new Yo(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},Op={description:Ho("Day of the week of the date provided (as number)."),args:[Qh("date (date)",Ho("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.")),Qh("type (number, default=1)",Ho("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=Ri(e,this.locale),s=Math.round(fi(t,this.locale)),i=o.getDay();return[1,2,3].includes(s)?1===s?i+1:2===s?0===i?7:i:0===i?6:i-1:new si(Ho("The type (%s) must be 1, 2 or 3.",s))},isExported:!0},Fp={description:Ho("Week number of the year."),args:[Qh("date (date)",Ho("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.")),Qh("type (number, default=1)",Ho("A number representing the day that a week starts on. Sunday = 1."))],compute:function(e,t={value:1}){const o=Ri(e,this.locale),s=Math.round(fi(t,this.locale));if(![1,2,11,12,13,14,15,16,17,21].includes(s))return new si(Ho("The type (%s) is out of range.",s.toString()));if(21===s)return Cp.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 Yo(n,0,r);for(;a.getDay()!==i;)r+=1,a=new Yo(n,0,r);const l=(o.getTime()-a.getTime())/Ko;return l<0?1:Math.floor(l/7)+(1===r?1:2)},isExported:!0},Pp={description:Ho("Date after a number of workdays."),args:[Qh("start_date (date)",Ho("The date from which to begin counting.")),Qh("num_days (number)",Ho("The number of working days to advance from start_date. If negative, counts backwards.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:null}){return Mp.compute.bind(this)(e,t,{value:1},o)},isExported:!0},Mp={description:Ho("Date after a number of workdays (specifying weekends)."),args:[Qh("start_date (date)",Ho("The date from which to begin counting.")),Qh("num_days (number)",Ho("The number of working days to advance from start_date. If negative, counts backwards.")),Qh("weekend (any, default=1)",Ho("A number or string representing which days of the week are considered weekends.")),Qh("holidays (date, range<date>, optional)",Ho("A range or array constant containing the dates to consider holidays."))],compute:function(e,t,o={value:1},s){const i=Ri(e,this.locale),n=Math.trunc(fi(t,this.locale));if("1111111"===o.value)return new si(Ho("The weekend must be different from '1111111'."));const r=xp(o),a=new Set;void 0!==s&&Di([s],(e=>{const t=Ri(e,this.locale);a.add(t.getTime())}));const l=Yo.fromTimestamp(i.getTime());let 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-Xo.getTime();return{value:Math.round(u/Ko),format:this.locale.dateFormat}},isExported:!0},Np={description:Ho("Year specified by a given date."),args:[Qh("date (date)",Ho("The date from which to extract the year."))],compute:function(e){return Ri(e,this.locale).getFullYear()},isExported:!0},kp={description:Ho("Exact number of years between two dates."),args:[Qh("start_date (date)",Ho("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.")),Qh("end_date (date)",Ho("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.")),Qh("day_count_convention (number, default=0)",Ho("An indicator of what day count method to use."))],compute:function(e,t,o={value:0}){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=Math.trunc(fi(o,this.locale));return s<0?new si(Ho("The start_date (%s) must be positive or null.",s)):i<0?new si(Ho("The end_date (%s) must be positive or null.",i)):0>n||n>4?new si(Ho("The day_count_convention (%s) must be between 0 and 4 inclusive.",n)):Ss(s,i,n)}},Vp={description:Ho("First day of the month preceding a date."),args:[Qh("date (date)",Ho("The date from which to calculate the result."))],compute:function(e){const t=Ri(e,this.locale),o=t.getFullYear(),s=t.getMonth();return{value:gs(new Yo(o,s,1)),format:this.locale.dateFormat}}},Lp={description:Ho("Last day of the month following a date."),args:[Qh("date (date)",Ho("The date from which to calculate the result."))],compute:function(e){return bp.compute.bind(this)(e,{value:0})}},Hp={description:Ho("Quarter of the year a specific date falls in"),args:[Qh("date (date)",Ho("The date from which to extract the quarter."))],compute:function(e){return Math.ceil((Ri(e,this.locale).getMonth()+1)/3)}},Up={description:Ho("First day of the quarter of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the start of quarter."))],compute:function(e){const t=Hp.compute.bind(this)(e),o=Np.compute.bind(this)(e);return{value:gs(new Yo(o,3*(t-1),1)),format:this.locale.dateFormat}}},Bp={description:Ho("Last day of the quarter of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the end of quarter."))],compute:function(e){const t=Hp.compute.bind(this)(e),o=Np.compute.bind(this)(e);return{value:gs(new Yo(o,3*t,0)),format:this.locale.dateFormat}}},zp={description:Ho("First day of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the start of the year."))],compute:function(e){const t=Np.compute.bind(this)(e);return{value:gs(new Yo(t,0,1)),format:this.locale.dateFormat}}},$p={description:Ho("Last day of the year a specific date falls in."),args:[Qh("date (date)",Ho("The date from which to calculate the end of the year."))],compute:function(e){const t=Np.compute.bind(this)(e);return{value:gs(new Yo(t+1,0,0)),format:this.locale.dateFormat}}};var Gp=Object.freeze({__proto__:null,DATE:dp,DATEDIF:up,DATEVALUE:gp,DAY:pp,DAYS:mp,DAYS360:fp,EDATE:vp,EOMONTH:bp,HOUR:Sp,ISOWEEKNUM:Cp,MINUTE:yp,MONTH:wp,MONTH_END:Lp,MONTH_START:Vp,NETWORKDAYS:Ip,NETWORKDAYS_INTL:Ep,NOW:Rp,QUARTER:Hp,QUARTER_END:Bp,QUARTER_START:Up,SECOND:Tp,TIME:Ap,TIMEVALUE:Dp,TODAY:_p,WEEKDAY:Op,WEEKNUM:Fp,WORKDAY:Pp,WORKDAY_INTL:Mp,YEAR:Np,YEARFRAC:kp,YEAR_END:$p,YEAR_START:zp});const Wp={description:Ho("Compare two numeric values, returning 1 if they're equal."),args:[Qh("number1 (number)",Ho("The first number to compare.")),Qh("number2 (number, default=0)",Ho("The second number to compare."))],compute:function(e,t={value:0}){return fi(e,this.locale)===fi(t,this.locale)?1:0},isExported:!0};var qp=Object.freeze({__proto__:null,DELTA:Wp});const Zp=[_s.number,_s.error,_s.text,_s.boolean];function jp(e){const t="asc"===e?1:-1;return(e,o)=>{if(e.type===_s.empty)return o.type===_s.empty?0:1;if(o.type===_s.empty)return-1;let s=Zp.indexOf(e.type)-Zp.indexOf(o.type);return 0===s&&(s=e.type===_s.text||e.type===_s.error?e.value.localeCompare(o.value):e.value-o.value),t*s}}function Yp(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++){const 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 Xp(e,t,o,s,i);const r=e.model.getters.getContiguousZone(t,s);Ir(r,s)?Xp(e,t,o,s,i):e.askConfirmation(Ho("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?"),(()=>Xp(e,t,o,r,i)),(()=>Xp(e,t,o,s,i)))}function Xp(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(Ho("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(Ho("Cannot sort a zone with array formulas."))}}function Kp(e,t,...o){for(let e=0;e<o.length;e++){const t=e%2==0?"sort_column":"is_ascending";Gl(void 0!==o[e],Ho("Value for parameter %s is missing in [[FUNCTION_NAME]].",t))}const s=[],i=[],n=e.length;for(let r=0;r<o.length;r+=2){s.push(Ei(ec(o[r+1])?.value)?"asc":"desc");const a=o[r];if(js(a)&&(a.length>1||a[0].length>1))Gl(1===a.length&&a[0].length===n,Ho("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=fi(ec(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:jp("desc"),asc:jp("asc")},a=je(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?_s.empty:"string"==typeof i?_s.text:typeof i},c={value:a,type:null===a?_s.empty:"string"==typeof a?_s.text:typeof a},h=r[s[o]](l,c);if(0!==h)return h}return 0})),a.map((t=>e[t]))}const Jp={description:Ho("Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions."),args:[Qh("range (any, range<any>)",Ho("The data to be filtered.")),Qh("condition1 (boolean, range<boolean>)",Ho("A column or row containing true or false values corresponding to the first column or row of range.")),Qh("condition2 (boolean, range<boolean>, repeating)",Ho("Additional column or row containing true or false values."))],compute:function(e,...t){let o=ji(e);const s=t.map((e=>ki(ji(e),(e=>e.value))));for(const e of s)if(!ql(e))return new si(Ho("The arguments condition must be a single column or row."));if(!Zl(...t))return new si(Ho("The arguments conditions must have the same dimensions."));const i=s.map((e=>e.flat())),n=1===s[0].length?"row":"col";if(o="row"===n?Vi(o):o,i.some((e=>e.length!==o.length)))return new si(Ho("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?Vi(r):r:new ai(Ho("No match found in FILTER evaluation"))},isExported:!1},Qp={description:Ho("Sorts the rows of a given array or range by the values in one or more columns."),args:[Qh("range (range)",Ho("The data to be sorted.")),Qh("sort_column (any, range<number>, repeating)",Ho("The index of the column in range or a range outside of range containing the values by which to sort.")),Qh("is_ascending (boolean, repeating)",Ho("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,...t){const o=Vi(e);return Vi(Kp(o,this.locale,...t))},isExported:!0},em={description:Ho("Returns the first n items in a data set after performing a sort."),args:[Qh("range (range)",Ho("The data to be sorted.")),Qh("n (number)",Ho("The number of items to return.")),Qh("display_ties_mode (number, default=0)",Ho("A number representing the way to display ties.")),Qh("sort_column (number, range<number>, repeating)",Ho("The index of the column in range or a range outside of range containing the values by which to sort.")),Qh("is_ascending (boolean, repeating)",Ho("TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order."))],compute:function(e,t,...o){const s=fi(t?.value??1,this.locale),i=o.length%2==0?0:fi(o[0]?.value,this.locale),n=o.length%2==0?o:o.slice(1);if(s<0)return new si(Ho("Wrong value of 'n'. Expected a positive number. Got %s.",s));if(i<0||i>3)return new si(Ho("Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.",i));const r=Kp(Vi(e),this.locale,...n),a=(e,t)=>JSON.stringify(r[e].map((e=>e.value)))===JSON.stringify(r[t].map((e=>e.value)));switch(i){case 0:return Vi(r.slice(0,s));case 1:for(let e=s;e<r.length;e++)if(!a(e,s-1))return Vi(r.slice(0,e));return Vi(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 Vi(e.slice(0,s))}case 3:{const e=[r[0]];let t=1;for(let o=1;o<r.length&&(a(o,o-1)||t++,!(t>s));o++)e.push(r[o]);return Vi(e)}}},isExported:!1},tm={description:Ho("Unique rows in the provided source range."),args:[Qh("range (any, range<any>)",Ho("The data to filter by unique entries.")),Qh("by_column (boolean, default=FALSE)",Ho("Whether to filter the data by columns or by rows.")),Qh("exactly_once (boolean, default=FALSE)",Ho("Whether to return only entries with no duplicates."))],compute:function(e={value:""},t,o){if(!js(e))return[[e]];const s=Ei(t?.value)||!1,i=Ei(o?.value)||!1;s||(e=Vi(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);return r.length?s?r:Vi(r):new si(Ho("No unique values found"))},isExported:!0};var om=Object.freeze({__proto__:null,FILTER:Jp,SORT:Qp,SORTN:em,UNIQUE:tm});const sm=Ho("The cashflow_amounts and cashflow_dates ranges must have the same dimensions."),im=Ho("There must be both positive and negative values in cashflow_amounts."),nm=e=>Ho("The cost (%s) must be positive or null.",e),rm=e=>Ho("The frequency (%s) must be one of %s",e,[1,2,4].toString()),am=e=>Ho("The day_count_convention (%s) must be between 0 and 4 inclusive.",e),lm=e=>Ho("The depreciation factor (%s) must be strictly positive.",e),cm=e=>Ho("The discount (%s) must be strictly positive.",e),hm=e=>Ho("The discount (%s) must be smaller than 1.",e),dm=e=>Ho("All the dates should be greater or equal to the first date in cashflow_dates (%s).",e),um=(e,t)=>Ho("The first_period (%(first)s) must be smaller or equal to the last_period (%(last)s).",{first:e,last:t}),gm=e=>Ho("The first_period (%s) must be strictly positive.",e),pm=e=>Ho("The investment (%s) must be strictly positive.",e),mm=(e,t)=>Ho("The last_period (%(last)s) must be smaller or equal to the number_of_periods (%(nPeriods)s).",{last:e,nPeriods:t}),fm=e=>Ho("The last_period (%s) must be strictly positive.",e),vm=e=>Ho("The life (%s) must be strictly positive.",e),bm=(e,t)=>Ho("The maturity (%(maturity)s) must be strictly greater than the settlement (%(settlement)s).",{maturity:t,settlement:e}),Sm=e=>Ho("The number_of_periods (%s) must be strictly positive.",e),Cm=e=>Ho("The period must be between 1 and number_of_periods (%s)",e),ym=e=>Ho("The periods_by_year (%s) must be strictly positive.",e),wm=(e,t)=>Ho("The period (%(period)s) must be less than or equal life (%(life)s).",{period:e,life:t}),Im=e=>Ho("The period (%s) must be strictly positive.",e),xm=e=>Ho("The present_value (%s) must be strictly positive.",e),Em=e=>Ho("The price (%s) must be strictly positive.",e),Rm=e=>Ho("The rate_guess (%s) must be strictly greater than -1.",e),Tm=e=>Ho("The rate (%s) must be positive or null.",e),Am=e=>Ho("The rate (%s) must be strictly positive.",e),Dm=e=>Ho("The redemption (%s) must be strictly positive.",e),_m=e=>Ho("The salvage (%s) must be positive or null.",e),Om=(e,t)=>Ho("The settlement date (%(settlement)s) must at most one year after the maturity date (%(maturity)s).",{settlement:e,maturity:t}),Fm=e=>Ho("The unit (%s) must be strictly positive.",e),Pm=e=>Ho("The yield (%s) must be positive or null.",e);function Mm(e){return e.some((e=>e>0))&&e.some((e=>e<0))}function Nm(e){return![0,1,2,3,4].includes(e)}function km(e){return![1,2,4].includes(e)}function Vm(e,t,o){const s=Ri(e,o),i=Ri(t,o),n=Ri(e,o);return n.setFullYear(s.getFullYear()+1),i.getTime()<=n.getTime()}const Lm=[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))];function Hm(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)?(Gl(u<s&&void 0!==n,Ho("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,Gl(u<s,Ho("Function [[FUNCTION_NAME]] didn't find any result.")),u++)}while(!d);return h}const Um={description:Ho("Accrued interest of security paying at maturity."),args:[Qh("issue (date)",Ho("The date the security was initially issued.")),Qh("maturity (date)",Ho("The maturity date of the security.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(s,this.locale),l=fi(o,this.locale),c=Math.trunc(fi(i,this.locale));if(n<0)return new si((e=>Ho("The issue (%s) must be positive or null.",e))(n));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(Dm(a));if(l<=0)return new si(Am(l));return a*l*Ss(n,r,c)},isExported:!0},Bm={description:Ho("Depreciation for an accounting period."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("purchase_date (date)",Ho("The date the asset was purchased.")),Qh("first_period_end (date)",Ho("The date the first period ended.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation.")),Qh("rate (number)",Ho("The deprecation rate.")),Qh("day_count_convention (number, optional)",Ho("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=fi(e,this.locale),l=Math.trunc(fi(t,this.locale)),c=Math.trunc(fi(o,this.locale)),h=fi(s,this.locale),d=fi(i,this.locale),u=fi(n,this.locale),g=Math.trunc(fi(r,this.locale));if(a<=0)return new si((e=>Ho("The cost (%s) must be strictly positive.",e))(a));if(l<0)return new si((e=>Ho("The purchase_date (%s) must be positive or null.",e))(l));if(h<0)return new si(_m(h));if(h>a)return new si(((e,t)=>Ho("The salvage (%(salvage)s) must be smaller or equal than the cost (%(cost)s).",{salvage:e,cost:t}))(h,a));if(d<0)return new si((e=>Ho("The period (%s) must be positive or null.",e))(d));if(u<=0)return new si(Am(u));if(Nm(g))return new si(am(g));if(l>c)return new si(((e,t)=>Ho("The purchase_date (%(purchaseDate)s) must be before the first_period_end (%(firstPeriodEnd)s).",{purchaseDate:e,firstPeriodEnd:t}))(l,c));const p=d<1&&d>0?1:Math.trunc(d),m=a*u,f=Ss(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},zm={description:Ho("Days in coupon period containing settlement date."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));if(1===a){const i=Zm.compute.bind(this)(e,t,o,s).value;return fi(Wm.compute.bind(this)(e,t,o,s).value,this.locale)-fi(i,this.locale)}return(3===a?365:360)/r},isExported:!0},$m={description:Ho("Days from settlement until next coupon."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=fi(Zm.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return i-l;if(4===a){const e=Ss(l,i,a);return Math.round(360*e)}const c=Ri(i,this.locale),h=Ri(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&&fs(h)&&fs(c)&&(f=30),31!==f||30!==m&&31!==m||(f=30),2===g&&fs(h)&&(m=30),31===m&&(m=30),360*(u-d)+30*(p-g)+(f-m)},isExported:!0},Gm={description:Ho("Days from settlement until next coupon."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=fi(Wm.compute.bind(this)(e,t,o,s).value,this.locale);if([1,2,3].includes(a))return l-i;if(4===a){const e=Ss(i,l,a);return Math.round(360*e)}const c=$m.compute.bind(this)(e,t,o,s);return fi(zm.compute.bind(this)(e,t,o,s),this.locale)-fi(c,this.locale)},isExported:!0},Wm={description:Ho("Next coupon date after the settlement date."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=12/r,c=qm.compute.bind(this)(e,t,o,s);return{value:gs(vs(Ri(n,this.locale),-(fi(c,this.locale)-1)*l,!0)),format:this.locale.dateFormat}},isExported:!0},qm={description:Ho("Number of coupons between settlement and maturity."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));let l=1,c=n;const h=12/r;for(;c>i;)c=gs(vs(Ri(c,this.locale),-h,!1)),l++;return l-1},isExported:!0},Zm={description:Ho("Last coupon date prior to or on the settlement date."),args:Lm,compute:function(e,t,o,s={value:0}){s=s||0;const i=Math.trunc(fi(e,this.locale)),n=Math.trunc(fi(t,this.locale)),r=Math.trunc(fi(o,this.locale)),a=Math.trunc(fi(s,this.locale));if(i>=n)return new si(bm(i,n));if(km(r))return new si(rm(r));if(Nm(a))return new si(am(a));const l=12/r,c=qm.compute.bind(this)(e,t,o,s);return{value:gs(vs(Ri(n,this.locale),-c*l,!0)),format:this.locale.dateFormat}},isExported:!0},jm={description:Ho("Cumulative interest paid over a set of periods."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("first_period (number)",Ho("The number of the payment period to begin the cumulative calculation.")),Qh("last_period (number)",Ho("The number of the payment period to end the cumulative calculation.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(s,this.locale),a=fi(i,this.locale),l=fi(e,this.locale),c=fi(o,this.locale),h=fi(t,this.locale),d=Ei(n)?1:0;if(h<=0)return new si(Sm(h));if(r<=0)return new si(gm(r));if(a<=0)return new si(fm(a));if(r>a)return new si(um(r,a));if(a>h)return new si(mm(a,h));if(l<=0)return new si(Am(l));if(c<=0)return new si(xm(c));let u=0;for(let e=r;e<=a;e++)u+=cf(l,e,h,c,0,d);return u},isExported:!0},Ym={description:Ho("Cumulative principal paid over a set of periods."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("first_period (number)",Ho("The number of the payment period to begin the cumulative calculation.")),Qh("last_period (number)",Ho("The number of the payment period to end the cumulative calculation.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(s,this.locale),a=fi(i,this.locale),l=fi(e,this.locale),c=fi(o,this.locale),h=fi(t,this.locale),d=Ei(n)?1:0;if(h<=0)return new si(Sm(h));if(r<=0)return new si(gm(r));if(a<=0)return new si(fm(a));if(r>a)return new si(um(r,a));if(a>h)return new si(mm(a,h));if(l<=0)return new si(Am(l));if(c<=0)return new si(xm(c));let u=0;for(let e=r;e<=a;e++)u+=wf(l,e,h,c,0,d);return u},isExported:!0},Xm={description:Ho("Depreciation via declining balance method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation.")),Qh("month (number, optional)",Ho("The number of months in the first year of depreciation."))],compute:function(e,t,o,s,...i){const n=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=Math.trunc(fi(s,this.locale)),c=i.length?Math.trunc(fi(i[0],this.locale)):12,h=a+(12===c?0:1);if(n<0)return new si(nm(n));if(r<0)return new si(_m(r));if(l<=0)return new si(Im(l));if(a<=0)return new si(vm(a));if(1>c||c>12)return new si(Ho("The month (%s) must be between 1 and 12 inclusive.",c));if(l>h)return new si(((e,t)=>Ho("The period (%(period)s) must be less than or equal to %(lifeLimit)s.",{period:e,lifeLimit:t}))(l,h));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},Km="#,##0.00",Jm={description:Ho("Depreciation via double-declining balance method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation.")),Qh("factor (number, default=2)",Ho("The factor by which depreciation decreases."))],compute:function(e,t,o,s,i={value:2}){const n=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=fi(i,this.locale);if(n<0)return new si(nm(n));if(r<0)return new si(_m(r));if(l<=0)return new si(Im(l));if(a<=0)return new si(vm(a));if(l>a)return new si(wm(l,a));if(c<=0)return new si(lm(c));if(0===n||r>=n)return{value:0,format:Km};const h=c/a;if(h>1)return{value:1===l?n-r:0,format:Km};if(l<=1)return{value:n*h,format:Km};const d=n*Math.pow(1-h,l-1),u=n*Math.pow(1-h,l),g=u<r?d-r:d-u;return{value:Math.max(g,0),format:Km}},isExported:!0},Qm={description:Ho("Discount rate of a security based on price."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(Em(a));if(l<=0)return new si(Dm(l));return(l-a)/l/Ss(n,r,c)},isExported:!0},ef={description:Ho("Convert a decimal fraction to decimal value."),args:[Qh("fractional_price (number)",Ho("The price quotation given using fractional decimal conventions.")),Qh("unit (number)",Ho("The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));if(s<=0)return new si(Fm(s));const i=Math.trunc(o);return i+(o-i)*(10**Math.ceil(Math.log10(s))/s)},isExported:!0},tf={description:Ho("Convert a decimal value to decimal fraction."),args:[Qh("decimal_price (number)",Ho("The price quotation given as a decimal value.")),Qh("unit (number)",Ho("The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));if(s<=0)return new si(Fm(s));const i=Math.trunc(o);return i+(o-i)*(s/10**Math.ceil(Math.log10(s)))},isExported:!0},of={description:Ho("Number of periods for an investment to reach a value."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=Math.trunc(fi(e,this.locale)),a=Math.trunc(fi(t,this.locale)),l=fi(o,this.locale),c=fi(s,this.locale),h=Math.trunc(fi(i,this.locale)),d=Math.trunc(fi(n,this.locale));if(r>=a)return new si(bm(r,a));if(km(h))return new si(rm(h));if(Nm(d))return new si(am(d));if(l<0)return new si(Tm(l));if(c<0)return new si(Pm(c));const u=Ss(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},sf={description:Ho("Annual effective interest rate."),args:[Qh("nominal_rate (number)",Ho("The nominal interest rate per year.")),Qh("periods_per_year (number)",Ho("The number of compounding periods per year."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));return o<=0?new si(Ho("The nominal_rate (%s) must be strictly positive.",o)):s<=0?new si(ym(s)):Math.pow(1+o/s,s)-1},isExported:!0};function nf(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 rf={description:Ho("Future value of an annuity investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("payment_amount (number)",Ho("The amount per period to be paid.")),Qh("present_value (number, default=0)",Ho("The current value of the annuity.")),Qh("end_or_beginning (number, default=0)",Ho("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:nf(fi(e,this.locale),fi(t,this.locale),fi(o,this.locale),fi(s,this.locale),Ei(i)?1:0),format:"#,##0.00"}},isExported:!0},af={description:Ho("Future value of principal from series of rates."),args:[Qh("principal (number)",Ho("The amount of initial capital or value to compound against.")),Qh("rate_schedule (number, range<number>)",Ho("A series of interest rates to compound against the principal."))],compute:function(e,t){return Fi([t],((e,t)=>e*(1+fi(t,this.locale))),fi(e,this.locale))},isExported:!0},lf={description:Ho("Calculates effective interest rate."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("investment (number)",Ho("The amount invested in the security.")),Qh("redemption (number)",Ho("The amount to be received at maturity.")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i={value:0}){const n=Math.trunc(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(s,this.locale),l=fi(o,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(l<=0)return new si(pm(l));if(a<=0)return new si(Dm(a));if(Nm(c))return new si(am(c));return(a-l)/l/Ss(n,r,c)},isExported:!0};function cf(e,t,o,s,i,n){return Cf(e,o,s,i,n)-wf(e,t,o,s,i,n)}const hf={description:Ho("Payment on the principal of an investment."),args:[Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("period (number)",Ho("The amortization period, in terms of number of periods.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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:cf(fi(e,this.locale),fi(t,this.locale),fi(o,this.locale),fi(s,this.locale),fi(i,this.locale),Ei(n)?1:0),format:"#,##0.00"}},isExported:!0},df={description:Ho("Internal rate of return given periodic cashflows."),args:[Qh("cashflow_amounts (number, range<number>)",Ho("An array or range containing the income or payments associated with the investment.")),Qh("rate_guess (number, default=0.1)",Ho("An estimate for what the internal rate of return will be."))],compute:function(e,t={value:.1}){const o=fi(t,this.locale);if(o<=-1)return new si(Rm(o));let s=!1,i=!1;const n=[];if(_i([e],(({value:e})=>{e>0&&(s=!0),e<0&&(i=!0),n.push(e)}),this.locale),!s||!i)return new si(im);const r=n.shift();return{value:Hm((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},uf={description:Ho("Returns the interest paid at a particular period of an investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("period (number)",Ho("The period for which you want to view the interest payment.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity."))],compute:function(e,t,o,s){const i=fi(e,this.locale),n=fi(t,this.locale),r=fi(o,this.locale),a=fi(s,this.locale);if(0===r)return new si(Ho("The number_of_periods (%s) must be different from zero.",r));return-1*(a-a*(n/r))*i},isExported:!0},gf={description:Ho("Modified Macaulay duration."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("An indicator of what day count method to use."))],compute:function(e,t,o,s,i,n={value:0}){const r=of.compute.bind(this)(e,t,o,s,i,n),a=fi(s,this.locale),l=Math.trunc(fi(i,this.locale));return fi(r,this.locale)/(1+a/l)},isExported:!0},pf={description:Ho("Modified internal rate of return."),args:[Qh("cashflow_amounts (range<number>)",Ho("A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.")),Qh("financing_rate (number)",Ho("The interest rate paid on funds invested.")),Qh("reinvestment_return_rate (number)",Ho("The return (as a percentage) earned on reinvestment of income received from the investment."))],compute:function(e,t,o){const s=fi(t,this.locale),i=fi(o,this.locale),n=Vi(e).flat().filter((e=>null!==e.value)).map((e=>fi(e,this.locale))),r=n.length;let a=0,l=0;for(const e of je(0,r)){const t=n[e];t>=0?a+=t*(i+1)**(r-e-1):l+=t/(s+1)**e}if(0===l||0===a)return new si(im);return(-a/l)**(1/(r-1))-1},isExported:!0},mf={description:Ho("Annual nominal interest rate."),args:[Qh("effective_rate (number)",Ho("The effective interest rate per year.")),Qh("periods_per_year (number)",Ho("The number of compounding periods per year."))],compute:function(e,t){const o=fi(e,this.locale),s=Math.trunc(fi(t,this.locale));return o<=0?new si(Ho("The effective_rate (%s) must be strictly positive.",o)):s<=0?new si(ym(s)):(Math.pow(o+1,1/s)-1)*s},isExported:!0},ff={description:Ho("Number of payment periods for an investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("payment_amount (number)",Ho("The amount of each payment made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=Ei(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 vf(e,t,o,s){let i=0;return Pi(o,((t,o)=>(i++,t+o/(1+e)**i)),t,s)}const bf={description:Ho("The net present value of an investment based on a series of periodic cash flows and a discount rate."),args:[Qh("discount (number)",Ho("The discount rate of the investment over one period.")),Qh("cashflow1 (number, range<number>)",Ho("The first future cash flow.")),Qh("cashflow2 (number, range<number>, repeating)",Ho("Additional future cash flows."))],compute:function(e,...t){const o=fi(e,this.locale);return-1===o?new si((e=>Ho("The discount (%s) must be different from -1.",e))(o)):{value:vf(o,0,t,this.locale),format:"#,##0.00"}},isExported:!0},Sf={description:Ho("Computes the number of periods needed for an investment to reach a value."),args:[Qh("rate (number)",Ho("The rate at which the investment grows each period.")),Qh("present_value (number)",Ho("The investment's current value.")),Qh("future_value (number)",Ho("The investment's desired future value."))],compute:function(e,t,o){const s=fi(e,this.locale),i=fi(t,this.locale),n=fi(o,this.locale);return s<=0?new si(Am(s)):i<=0?new si(xm(i)):n<=0?new si(Ho("The future_value (%s) must be strictly positive.",n)):(Math.log(n)-Math.log(i))/Math.log(1+s)},isExported:!0};function Cf(e,t,o,s,i){if(t<=0)throw new si(Sm(t));if(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 yf={description:Ho("Periodic payment for an annuity investment."),args:[Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(t,this.locale),r=fi(e,this.locale),a=Ei(i)?1:0,l=fi(s,this.locale);return{value:Cf(r,n,fi(o,this.locale),l,a),format:"#,##0.00"}},isExported:!0};function wf(e,t,o,s,i,n){if(o<=0)throw new si(Sm(o));if(t<=0||t>o)throw new si(Cm(o));const r=Cf(e,o,s,i,n);if(1===n&&1===t)return r;return r+-nf(e,0===n?t-1:t-2,r,s+r*n,0)*e}const If={description:Ho("Payment on the principal of an investment."),args:[Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("period (number)",Ho("The amortization period, in terms of number of periods.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(o,this.locale),a=fi(e,this.locale),l=fi(t,this.locale),c=Ei(n)?1:0,h=fi(i,this.locale);return{value:wf(a,l,r,fi(s,this.locale),h,c),format:"#,##0.00"}},isExported:!0},xf={description:Ho("Present value of an annuity investment."),args:[Qh("rate (number)",Ho("The interest rate.")),Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("payment_amount (number)",Ho("The amount per period to be paid.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("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=fi(e,this.locale),r=fi(t,this.locale),a=fi(o,this.locale),l=fi(s,this.locale),c=Ei(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},Ef={description:Ho("Price of a security paying periodic interest."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),l=Math.trunc(fi(t,this.locale)),c=fi(o,this.locale),h=fi(s,this.locale),d=fi(i,this.locale),u=Math.trunc(fi(n,this.locale)),g=Math.trunc(fi(r,this.locale));if(a>=l)return new si(bm(a,l));if(km(u))return new si(rm(u));if(Nm(g))return new si(am(g));if(c<0)return new si(Tm(c));if(h<0)return new si(Pm(h));if(d<=0)return new si(Dm(d));const p=Ss(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},Rf={description:Ho("Price of a discount security."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("discount (number)",Ho("The discount rate of the security at time of purchase.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(cm(a));if(l<=0)return new si(Dm(l));return l-a*l*Ss(n,r,c)},isExported:!0},Tf={description:Ho("Calculates the price of a security paying interest at maturity, based on expected yield."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("issue (date)",Ho("The date the security was initially issued.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("yield (number)",Ho("The expected annual yield of the security.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),a=Math.trunc(fi(t,this.locale)),l=Math.trunc(fi(o,this.locale)),c=fi(s,this.locale),h=fi(i,this.locale),d=Math.trunc(fi(n,this.locale));if(r<=l)return new si(((e,t)=>Ho("The settlement date (%(settlement)s) must be strictly greater than the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(r>=a)return new si(bm(r,a));if(Nm(d))return new si(am(d));if(c<0)return new si(Tm(c));if(h<0)return new si(Pm(h));const u=Ss(r,a,d),g=Ss(r,l,d);return(100+Ss(l,a,d)*c*100)/(1+u*h)-g*c*100},isExported:!0},Af=.1,Df={description:Ho("Interest rate of an annuity investment."),args:[Qh("number_of_periods (number)",Ho("The number of payments to be made.")),Qh("payment_per_period (number)",Ho("The amount per period to be paid.")),Qh("present_value (number)",Ho("The current value of the annuity.")),Qh("future_value (number, default=0)",Ho("The future value remaining after the final payment has been made.")),Qh("end_or_beginning (number, default=0)",Ho("Whether payments are due at the end (0) or beginning (1) of each period.")),Qh("rate_guess (number, default=0.1)",Ho("An estimate for what the interest rate will be."))],compute:function(e,t,o,s={value:0},i={value:0},n={value:Af}){const r=fi(e,this.locale),a=fi(t,this.locale),l=Ei(i)?1:0,c=fi(n,this.locale)||Af;let h=fi(s,this.locale),d=fi(o,this.locale);if(r<=0)return new si(Sm(r));if(!Mm([a,d,h]))return new si(Ho("There must be both positive and negative values in [payment_amount, present_value, future_value]."));if(c<=-1)return new si(Rm(c));h-=a*l,d+=a*l;return{value:Hm((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},_f={description:Ho("Amount received at maturity for a security."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("investment (number)",Ho("The amount invested (irrespective of face value of each security).")),Qh("discount (number)",Ho("The discount rate of the security invested in.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(pm(a));if(l<=0)return new si(cm(l));return a/(1-l*Ss(n,r,c))},isExported:!0},Of={description:Ho("Computes the rate needed for an investment to reach a specific value within a specific number of periods."),args:[Qh("number_of_periods (number)",Ho("The number of periods.")),Qh("present_value (number)",Ho("The present value of the investment.")),Qh("future_value (number)",Ho("The future value of the investment."))],compute:function(e,t,o){const s=fi(e,this.locale),i=fi(t,this.locale),n=fi(o,this.locale);return s<=0?new si(Sm(s)):(n/i)**(1/s)-1},isExported:!0},Ff={description:Ho("Depreciation of an asset using the straight-line method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated."))],compute:function(e,t,o){return{value:(fi(e,this.locale)-fi(t,this.locale))/fi(o,this.locale),format:"#,##0.00"}},isExported:!0},Pf={description:Ho("Depreciation via sum of years digit method."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("period (number)",Ho("The single period within life for which to calculate depreciation."))],compute:function(e,t,o,s){const i=fi(e,this.locale),n=fi(t,this.locale),r=fi(o,this.locale),a=fi(s,this.locale);if(a<=0)return new si(Im(a));if(r<=0)return new si(vm(r));if(a>r)return new si(wm(a,r));return{value:(r-a+1)/(r*(r+1)/2)*(i-n),format:"#,##0.00"}},isExported:!0};function Mf(e,t,o){return 100*(1-o*Ss(e,t,2))}const Nf={description:Ho("Price of a US Treasury bill."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("discount (number)",Ho("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=fi(o,this.locale);return s>=i?new si(bm(s,i)):Vm(s,i,this.locale)?n<=0?new si(cm(n)):n>=1?new si(hm(n)):Mf(s,i,n):new si(Om(s,i))},isExported:!0},kf={description:Ho("Equivalent rate of return for a US Treasury bill."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("discount (number)",Ho("The discount rate of the bill at time of purchase."))],compute:function(e,t,o){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=fi(o,this.locale);if(s>=i)return new si(bm(s,i));if(!Vm(s,i,this.locale))return new si(Om(s,i));if(n<=0)return new si(cm(n));if(n>=1)return new si(hm(n));const r=mp.compute.bind(this)({value:i},{value:s});if(r<=182)return 365*n/(360-n*r);const a=Mf(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},Vf={description:Ho("The yield of a US Treasury bill based on price."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value."))],compute:function(e,t,o){const s=Math.trunc(fi(e,this.locale)),i=Math.trunc(fi(t,this.locale)),n=fi(o,this.locale);if(s>=i)return new si(bm(s,i));if(!Vm(s,i,this.locale))return new si(Om(s,i));if(n<=0)return new si(Em(n));return(100-n)/n*(1/Ss(s,i,2))},isExported:!0},Lf={description:Ho("Variable declining balance. WARNING : does not handle decimal periods."),args:[Qh("cost (number)",Ho("The initial cost of the asset.")),Qh("salvage (number)",Ho("The value of the asset at the end of depreciation.")),Qh("life (number)",Ho("The number of periods over which the asset is depreciated.")),Qh("start (number)",Ho("Starting period to calculate depreciation.")),Qh("end (number)",Ho("Ending period to calculate depreciation.")),Qh("factor (number, default=2)",Ho("The number of months in the first year of depreciation.")),Qh("no_switch (number, default=false)",Ho("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=fi(e,this.locale),l=fi(t,this.locale),c=fi(o,this.locale),h=Math.trunc(fi(s,this.locale)),d=Math.trunc(fi(i,this.locale)),u=fi(n,this.locale),g=Ei(r);if(a<0)return new si(nm(a));if(l<0)return new si(_m(l));if(c<=0)return new si(vm(c));if(h<0)return new si((e=>Ho("The start_period (%s) must be positive or null.",e))(h));if(d<0)return new si((e=>Ho("The end_period (%s) must be positive or null.",e))(d));if(h>d)return new si(Ho("The start_period (%(start)s) must be smaller or equal to the end_period (%(end)s).",{start:h,end:d}));if(d>c)return new si(((e,t)=>Ho("The end_period (%(end)s) must be smaller or equal to the life (%(life)s).",{end:e,life:t}))(d,c));if(u<=0)return new si(lm(u));if(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},Hf={description:Ho("Internal rate of return given non-periodic cash flows."),args:[Qh("cashflow_amounts (range<number>)",Ho("An range containing the income or payments associated with the investment.")),Qh("cashflow_dates (range<number>)",Ho("An range with dates corresponding to the cash flows in cashflow_amounts.")),Qh("rate_guess (number, default=0.1)",Ho("An estimate for what the internal rate of return will be."))],compute:function(e,t,o={value:Af}){const s=fi(o,this.locale);if(!Zl(e,t))return new si(sm);const i=e.flat().map((e=>fi(e,this.locale))),n=t.flat().map((e=>fi(e,this.locale)));if(!Mm(i))return new si(im);if(n.some((e=>e<n[0])))return new si(dm(n[0]));if(s<=-1)return new si(Rm(s));const r=new Map;for(const e of je(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)));return Hm((e=>{let t=l[0];for(const o of je(1,l.length)){const s=(a[0]-a[o])/365;t+=l[o]*(1+e)**s}return t}),(e=>{let t=0;for(const o of je(1,l.length)){const s=(a[0]-a[o])/365;t+=s*l[o]*(1+e)**(s-1)}return t}),s,40,1e-5,(e=>e?e/10-.9:-.9))},isExported:!0},Uf={description:Ho("Net present value given to non-periodic cash flows.."),args:[Qh("discount (number)",Ho("The discount rate of the investment over one period.")),Qh("cashflow_amounts (number, range<number>)",Ho("An range containing the income or payments associated with the investment.")),Qh("cashflow_dates (number, range<number>)",Ho("An range with dates corresponding to the cash flows in cashflow_amounts."))],compute:function(e,t,o){const s=fi(e,this.locale);if(!Zl(t,o))return new si(sm);const i=ji(t).flat().map((e=>Si(e,this.locale))),n=ji(o).flat().map((e=>Si(e,this.locale)));if(n.some((e=>e<n[0])))return new si(dm(n[0]));if(s<=0)return new si(Am(s));if(1===i.length)return i[0];const r=new Map;for(const e of je(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 je(1,l.length)){const t=(a[0]-a[e])/365;c+=l[e]*(1+s)**t}return c},isExported:!0},Bf={description:Ho("Annual yield of a security paying periodic interest."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("frequency (number)",Ho("The number of interest or coupon payments per year (1, 2, or 4).")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),l=Math.trunc(fi(t,this.locale)),c=fi(o,this.locale),h=fi(s,this.locale),d=fi(i,this.locale),u=Math.trunc(fi(n,this.locale)),g=Math.trunc(fi(r,this.locale));if(a>=l)return new si(bm(a,l));if(km(u))return new si(rm(u));if(Nm(g))return new si(am(g));if(c<0)return new si(Tm(c));if(h<=0)return new si(Em(h));if(d<=0)return new si(Dm(d));const p=Ss(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=Hm((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},zf={description:Ho("Annual yield of a discount security."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("price (number)",Ho("The price at which the security is bought per 100 face value.")),Qh("redemption (number)",Ho("The redemption amount per 100 face value, or par.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),r=Math.trunc(fi(t,this.locale)),a=fi(o,this.locale),l=fi(s,this.locale),c=Math.trunc(fi(i,this.locale));if(n>=r)return new si(bm(n,r));if(Nm(c))return new si(am(c));if(a<=0)return new si(Em(a));if(l<=0)return new si(Dm(l));return(l/a-1)/Ss(n,r,c)},isExported:!0},$f={description:Ho("Annual yield of a security paying interest at maturity."),args:[Qh("settlement (date)",Ho("The settlement date of the security, the date after issuance when the security is delivered to the buyer.")),Qh("maturity (date)",Ho("The maturity or end date of the security, when it can be redeemed at face, or par value.")),Qh("issue (date)",Ho("The date the security was initially issued.")),Qh("rate (number)",Ho("The annualized rate of interest.")),Qh("price (number)",Ho("The price at which the security is bought.")),Qh("day_count_convention (number, default=0 )",Ho("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(fi(e,this.locale)),a=Math.trunc(fi(t,this.locale)),l=Math.trunc(fi(o,this.locale)),c=fi(s,this.locale),h=fi(i,this.locale),d=Math.trunc(fi(n,this.locale));if(r>=a)return new si(bm(r,a));if(Nm(d))return new si(am(d));if(r<l)return new si(((e,t)=>Ho("The settlement date (%(settlement)s) must be greater or equal to the issue date (%(issue)s).",{settlement:e,issue:t}))(r,l));if(c<0)return new si(Tm(c));if(h<=0)return new si(Em(h));return(100*(1+c*Ss(l,a,d))/(h+100*c*Ss(l,r,d))-1)/Ss(r,a,d)},isExported:!0};var Gf,Wf=Object.freeze({__proto__:null,ACCRINTM:Um,AMORLINC:Bm,COUPDAYBS:$m,COUPDAYS:zm,COUPDAYSNC:Gm,COUPNCD:Wm,COUPNUM:qm,COUPPCD:Zm,CUMIPMT:jm,CUMPRINC:Ym,DB:Xm,DDB:Jm,DISC:Qm,DOLLARDE:ef,DOLLARFR:tf,DURATION:of,EFFECT:sf,FV:rf,FVSCHEDULE:af,INTRATE:lf,IPMT:hf,IRR:df,ISPMT:uf,MDURATION:gf,MIRR:pf,NOMINAL:mf,NPER:ff,NPV:bf,PDURATION:Sf,PMT:yf,PPMT:If,PRICE:Ef,PRICEDISC:Rf,PRICEMAT:Tf,PV:xf,RATE:Df,RECEIVED:_f,RRI:Of,SLN:Ff,SYD:Pf,TBILLEQ:kf,TBILLPRICE:Nf,TBILLYIELD:Vf,VDB:Lf,XIRR:Hf,XNPV:Uf,YIELD:Bf,YIELDDISC:zf,YIELDMAT:$f});!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"}(Gf||(Gf={}));const qf=(e,t=(()=>!0))=>[{goTo:e,guard:t}],Zf=(e,t=(()=>!0))=>({goTo:e,guard:t}),jf={[Gf.LeftRef]:{REFERENCE:qf(Gf.Separator),NUMBER:qf(Gf.FullRowSeparator),SYMBOL:[Zf(Gf.FullColumnSeparator,(e=>{return t=e.value,Qr.test(t);var t})),Zf(Gf.FullRowSeparator,(e=>oa(e.value)))]},[Gf.FullColumnSeparator]:{SPACE:qf(Gf.FullColumnSeparator),OPERATOR:qf(Gf.RightColumnRef,(e=>":"===e.value))},[Gf.FullRowSeparator]:{SPACE:qf(Gf.FullRowSeparator),OPERATOR:qf(Gf.RightRowRef,(e=>":"===e.value))},[Gf.Separator]:{SPACE:qf(Gf.Separator),OPERATOR:qf(Gf.RightRef,(e=>":"===e.value))},[Gf.RightRef]:{SPACE:qf(Gf.RightRef),NUMBER:qf(Gf.Found),REFERENCE:qf(Gf.Found,(e=>na(e.value))),SYMBOL:qf(Gf.Found,(e=>sa(e.value)||ia(e.value)))},[Gf.RightColumnRef]:{SPACE:qf(Gf.RightColumnRef),SYMBOL:qf(Gf.Found,(e=>sa(e.value))),REFERENCE:qf(Gf.Found,(e=>na(e.value)))},[Gf.RightRowRef]:{SPACE:qf(Gf.RightRowRef),NUMBER:qf(Gf.Found),REFERENCE:qf(Gf.Found,(e=>na(e.value))),SYMBOL:qf(Gf.Found,(e=>ia(e.value)))},[Gf.Found]:{}};function Yf(e){let t=0,o=jf[Gf.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 Gf.Found:return s+=i.value,e.splice(0,t),{type:"REFERENCE",value:s};default:o=jf[r],s+=i.value}}return null}function Xf(e,t=qs){const o=cl(e,t),s=[];for(;o.length;)s.push(Yf(o)||o.shift());return s}const Kf=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Jf=["-","+"],Qf=["%"],ev=["*","+","&"];class tv{tokens;currentIndex=0;current;length;constructor(e){this.tokens=e,this.current=e[0],this.length=e.length}shift(){const e=this.tokens[this.currentIndex];return this.current=this.tokens[++this.currentIndex],e}get next(){return this.tokens[this.currentIndex+1]}}const ov={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function sv(e){const t=e.shift();if(!t)throw new ii;switch(t.type){case"DEBUGGER":const o=rv(e,1e3);return o.debug=!0,o;case"NUMBER":return{type:"NUMBER",value:As(t.value,qs),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"STRING":return{type:"STRING",value:Ue(t.value),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"INVALID_REFERENCE":return{type:"REFERENCE",value:ti.InvalidReference,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"REFERENCE":if(":"===e.current?.value&&"REFERENCE"===e.next?.type){e.shift();const o=e.shift();return{type:"REFERENCE",value:`${t.value}:${o?.value}`,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenIndex}}return{type:"REFERENCE",value:t.value,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"SYMBOL":const s=t.value,i=e.current;if("LEFT_PAREN"===i?.type&&Kf.test(t.value)&&s===Ge(s,"'")){const{args:o,rightParen:i}=function(e){nv(e,"LEFT_PAREN",Ho("Missing opening parenthesis"));const t=e.current;if("RIGHT_PAREN"===t?.type){return{args:[],rightParen:nv(e,"RIGHT_PAREN")}}const o=[];o.push(iv(e));for(;"RIGHT_PAREN"!==e.current?.type;)nv(e,"ARG_SEPARATOR",Ho("Wrong function call")),o.push(iv(e));const s=nv(e,"RIGHT_PAREN");return{args:o,rightParen:s}}(e);return{type:"FUNCALL",value:s,args:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:i.tokenIndex}}const n=s.toUpperCase();return"TRUE"===n||"FALSE"===n?{type:"BOOLEAN",value:"TRUE"===n,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:{type:"SYMBOL",value:Ge(t.value,"'"),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case"LEFT_PAREN":const r=rv(e),a=nv(e,"RIGHT_PAREN",Ho("Missing closing parenthesis"));return{...r,tokenStartIndex:t.tokenIndex,tokenEndIndex:a.tokenIndex};case"OPERATOR":const l=t.value;if(Jf.includes(l)){const o=rv(e,ov[l]);return{type:"UNARY_OPERATION",value:l,operand:o,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenEndIndex}}throw new ii(Ho("Unexpected token: %s",t.value));default:throw new ii(Ho("Unexpected token: %s",t.value))}}function iv(e){const t=e.current;return"ARG_SEPARATOR"===t?.type||"RIGHT_PAREN"===t?.type?{type:"EMPTY",value:"",tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:rv(e)}function nv(e,t,o){const s=e.shift();if(!s||s.type!==t)throw new ii(o);return s}function rv(e,t=0){if(0===e.length)throw new ii;let o=sv(e);for(;"OPERATOR"===e.current?.type&&ov[e.current.value]>t;){const t=e.shift(),s=t.value;if(Qf.includes(s))o={type:"UNARY_OPERATION",value:s,operand:o,postfix:!0,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenIndex};else{const t=rv(e,ov[s]);o={type:"BIN_OPERATION",value:s,left:o,right:t,tokenStartIndex:o.tokenStartIndex,tokenEndIndex:t.tokenEndIndex}}}return o}function av(e){return lv(Xf(e))}function lv(e){const t=e.map(((e,t)=>({type:e.type,value:e.value,tokenIndex:t}))).filter((e=>"SPACE"!==e.type)),o=new tv(t);"="===o.current?.value&&o.shift();const s=rv(o);if(o.current)throw new ii;return s}function cv(e,t,o){return uv(e,(e=>e.type===t?o(e):e))}function hv(e){return Array.from(dv(e))}function*dv(e){switch(yield e,e.type){case"FUNCALL":for(const t of e.args)yield*dv(t);break;case"UNARY_OPERATION":yield*dv(e.operand);break;case"BIN_OPERATION":yield*dv(e.left),yield*dv(e.right)}}function uv(e,t){switch((e=t(e)).type){case"FUNCALL":return{...e,args:e.args.map((e=>uv(e,t)))};case"UNARY_OPERATION":return{...e,operand:uv(e.operand,t)};case"BIN_OPERATION":return{...e,right:uv(e.right,t),left:uv(e.left,t)};default:return e}}function gv(e){switch(e.type){case"FUNCALL":const t=e.args.map((e=>gv(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?pv(e)+e.value:e.value+mv(e);case"BIN_OPERATION":return pv(e)+e.value+mv(e)}}function pv(e){const t=e.value,o="left"in e?e.left:e.operand,s=o.value;return"BIN_OPERATION"===o.type&&ov[s]<ov[t]?`(${gv(o)})`:gv(o)}function mv(e){const t=e.value,o="right"in e?e.right:e.operand,s=ov[o.value],i=ov[t];let n=!1;return"BIN_OPERATION"!==o.type?n=!1:s<i?n=!0:s!==i||ev.includes(t)||(n=!0),n?`(${gv(o)})`:gv(o)}function fv(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(0)?.type&&(e=e.slice(1));try{o.push(lv(e))}catch(e){o.push(void 0)}}}return e}(function(e){const t=[];let 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":t.length&&t[t.length-1].argPosition++,s(e);break;default:s(e)}if(t.length){const o=t[t.length-1];o.parent&&(e.functionContext=Object.assign({},o))}return e}))}(function(e){const t=[];let 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}))}(Xf(e,t)))))}function vv(e){if("REFERENCE"!==e.type)return e;const{xc:t,sheetName:o}=ra(e.value),[s,i]=t.split(":"),n=bv(s),r=i?`:${bv(i)}`:"";return{...e,value:aa(o,n+r)}}function bv(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=Sv(e,"colrow");break;case"colrow":e=Sv(e,"row");break;case"row":e=Sv(e,"col");break;case"col":e=Sv(e,"none")}return e}function Sv(e,t){let o;({sheetName:o,xc:e}=ra(e)),o=o?o+"!":"";const s=(e=e.replace(/\$/g,"")).indexOf(":");return s>=0?`${o}${Cv(e.slice(0,s),t)}:${Cv(e.slice(s+1),t)}`:o+Cv(e,t)}function Cv(e,t){const o=e.search(/[0-9]/),s=0!==o,i=o>=0;switch(t){case"col":return s?"$"+e:e;case"row":return i?e.slice(0,o)+"$"+e.slice(o):e;case"colrow":return i&&s?"$"+e.slice(0,o)+"$"+e.slice(o):"$"+e;case"none":return e}}function yv(e,t,o){const s=(t.startsWith("=")?fv(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(vv).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 wv=["address","col","contents","format","row","type"],Iv={description:Ho("Gets information about a cell."),args:[Qh("info_type (string)",Ho("The type of information requested. Can be one of %s",wv.join(", "))),Qh("reference (meta)",Ho("The reference to the cell."))],compute:function(e,t){const o=wi(e).toLowerCase();if(!wv.includes(o))return new si(Ho("The info_type should be one of %s.",wv.join(", ")));const s=this.__originSheetId,i=wi(t),n=i.includes(":")?i.split(":")[0]:i;let{sheetName:r,xc:a}=ra(n);r=r===this.getters.getSheetName(s)?void 0:r;const l=aa(r,Sv(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===_s.empty?"b":t===_s.text?"l":"v"}}return""},isExported:!0},xv={description:Ho("Whether a value is an error other than #N/A."),args:[Qh("value (any)",Ho("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return gi(t)&&t!==ti.NotAvailable},isExported:!0},Ev={description:Ho("Whether a value is an error."),args:[Qh("value (any)",Ho("The value to be verified as an error type."))],compute:function(e){const t=e?.value;return gi(t)},isExported:!0},Rv={description:Ho("Whether a value is `true` or `false`."),args:[Qh("value (any)",Ho("The value to be verified as a logical TRUE or FALSE."))],compute:function(e){return"boolean"==typeof e?.value},isExported:!0},Tv={description:Ho("Whether a value is the error #N/A."),args:[Qh("value (any)",Ho("The value to be verified as an error type."))],compute:function(e){return e?.value===ti.NotAvailable},isExported:!0},Av={description:Ho("Whether a value is non-textual."),args:[Qh("value (any)",Ho("The value to be checked."))],compute:function(e){return!_v.compute.bind(this)(e)},isExported:!0},Dv={description:Ho("Whether a value is a number."),args:[Qh("value (any)",Ho("The value to be verified as a number."))],compute:function(e){return"number"==typeof e?.value},isExported:!0},_v={description:Ho("Whether a value is text."),args:[Qh("value (any)",Ho("The value to be verified as text."))],compute:function(e){return"string"==typeof e?.value&&!1===gi(e?.value)},isExported:!0},Ov={description:Ho("Whether the referenced cell is empty"),args:[Qh("value (any)",Ho("Reference to the cell that will be checked for emptiness."))],compute:function(e){return null===e?.value},isExported:!0},Fv={description:Ho("Returns the error value #N/A."),args:[],compute:function(){return{value:ti.NotAvailable}},isExported:!0};var Pv=Object.freeze({__proto__:null,CELL:Iv,ISBLANK:Ov,ISERR:xv,ISERROR:Ev,ISLOGICAL:Rv,ISNA:Tv,ISNONTEXT:Av,ISNUMBER:Dv,ISTEXT:_v,NA:Fv});const Mv={description:Ho("Logical `and` operator."),args:[Qh("logical_expression1 (boolean, range<boolean>)",Ho("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.")),Qh("logical_expression2 (boolean, range<boolean>, repeating)",Ho("More expressions that represent logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Ul(e);return o?t:new si(Ki)},isExported:!0},Nv={description:Ho("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},kv={description:Ho("Returns value depending on logical expression."),args:[Qh("logical_expression (boolean, range<boolean>)",Ho("An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.")),Qh("value_if_true (any, range)",Ho("The value the function returns if logical_expression is TRUE.")),Qh("value_if_false (any, range, default=FALSE)",Ho("The value the function returns if logical_expression is FALSE."))],compute:function(e,t,o){if(oc(e))return Li(kv.compute,[e,t,o]);return(Ei(ec(e))?t:o)??{value:0}},isExported:!0},Vv={description:Ho("Value if it is not an error, otherwise 2nd argument."),args:[Qh("value (any, range)",Ho("The value to return if value itself is not an error.")),Qh('value_if_error (any, range, default="empty")',Ho("The value the function returns if value is an error."))],compute:function(e,t){if(oc(e))return Li(Vv.compute,[e,t]);return(gi(ec(e)?.value)?t:e)??{value:0}},isExported:!0},Lv={description:Ho("Value if it is not an #N/A error, otherwise 2nd argument."),args:[Qh("value (any, range)",Ho("The value to return if value itself is not #N/A an error.")),Qh('value_if_error (any, range, default="empty")',Ho("The value the function returns if value is an #N/A error."))],compute:function(e,t){if(oc(e))return Li(Lv.compute,[e,t]);return(ec(e)?.value===ti.NotAvailable?t:e)??{value:0}},isExported:!0},Hv={description:Ho("Returns a value depending on multiple logical expressions."),args:[Qh("condition1 (boolean, range<boolean>)",Ho("The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.")),Qh("value1 (any, range)",Ho("The returned value if condition1 is TRUE.")),Qh("condition2 (boolean, any, range, repeating)",Ho("Additional conditions to be evaluated if the previous ones are FALSE.")),Qh("value2 (any, range, repeating)",Ho("Additional values to be returned if their corresponding conditions are TRUE."))],compute:function(...e){if(e.length%2!=0)return new si(Ho("Wrong number of arguments. Expected an even number of arguments."));for(;e.length>0;){if(oc(e[0]))return Li(Hv.compute,e);const t=Ei(ec(e.shift())),o=e.shift();if(t)return o??{value:0}}return new si(Ho("No match."))},isExported:!0},Uv={description:Ho("Returns opposite of provided logical value."),args:[Qh("logical_expression (boolean)",Ho("An expression or reference to a cell holding an expression that represents some logical value."))],compute:function(e){return!Ei(e)},isExported:!0},Bv={description:Ho("Logical `or` operator."),args:[Qh("logical_expression1 (boolean, range<boolean>)",Ho("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.")),Qh("logical_expression2 (boolean, range<boolean>, repeating)",Ho("More expressions that evaluate to logical values."))],compute:function(...e){const{result:t,foundBoolean:o}=Bl(e);return o?t:new si(Ki)},isExported:!0},zv={description:Ho("Returns a value by comparing cases to an expression."),args:[Qh("expression (number, boolean, string)",Ho("The value to be checked.")),Qh("case1 (number, boolean, string)",Ho("The first case to be checked against expression.")),Qh("value1 (any)",Ho("The corresponding value to be returned if case1 matches expression.")),Qh("case2 (any, repeating)",Ho("Additional cases to try if the previous ones don't match expression.")),Qh("value2 (any, repeating)",Ho("Additional values to be returned if their corresponding cases match expression.")),Qh('default (any, default="empty")',Ho("An optional default value to be returned if none of the cases match expression."))],compute:function(e,...t){const o=t.length%2==0?pi(e):t.pop();for(let o=0;o<t.length;o+=2){const s=t[o];if(s&&gi(s.value))return s;if(e?.value===s?.value)return t[o+1]||{value:0}}return o||{value:0}},isExported:!0},$v={description:Ho("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},Gv={description:Ho("Logical `xor` operator."),args:[Qh("logical_expression1 (boolean, range<boolean>)",Ho("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.")),Qh("logical_expression2 (boolean, range<boolean>, repeating)",Ho("More expressions that evaluate to logical values."))],compute:function(...e){let t=!1,o=!1;return Hi(e,(e=>(t=!0,o=o?!e:e,!0))),t?o:new si(Ki)},isExported:!0};var Wv=Object.freeze({__proto__:null,AND:Mv,FALSE:Nv,IF:kv,IFERROR:Vv,IFNA:Lv,IFS:Hv,NOT:Uv,OR:Bv,SWITCH:zv,TRUE:$v,XOR:Gv});function qv(e,t){const o=t.getPivotId(e);if(!o)throw new si(Ho('There is no pivot with id "%s"',e));return o}function Zv(e){if(e.length%2!=0)throw new si(Ho("Function PIVOT takes an even number of arguments."))}function jv(e,t,o){const s=[];if("SPREADSHEET"===t.type&&t.dataSet){const{sheetId:o,zone:i}=t.dataSet,n=fr(i),r=e.getters.getRangeFromSheetXC(o,n);if(void 0===r||r.invalidXc||r.invalidSheetName)throw new ri;if(e.__originCellPosition&&r.sheetId===e.__originSheetId&&Rr(Mr(e.__originCellPosition),i))throw new ni;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 Yv=!0,Xv={description:Ho("Returns a cell reference as a string. "),args:[Qh("row (number)",Ho("The row number of the cell reference. ")),Qh("column (number)",Ho("The column number (not name) of the cell reference. A is column number 1. ")),Qh("absolute_relative_mode (number, default=1)",Ho("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).")),Qh("use_a1_notation (boolean, default=TRUE)",Ho("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).")),Qh("sheet (string, optional)",Ho("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=yi(e,this.locale),r=yi(t,this.locale);if(n<1)return new si(Yl(n));if(r<1)return new si(Yl(r));const a=yi(o,this.locale);if(![1,2,3,4].includes(a))return new si((l=4,c=a,Ho("The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.",1..toString(),l.toString(),c.toString())));var l,c;let h;if(Ei(s)){h=Po(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?aa(wi(i),h):h},isExported:!0},Kv={description:Ho("Column number of a specified cell."),args:[Qh("cell_reference (meta, default='this cell')",Ho("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(gi(e?.value))return e;if(void 0===e)return void 0===this.__originCellPosition?.col?new si(Ho("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.col+1;const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.left===t.right?t.left+1:Ni(t.right-t.left+1,1,((e,o)=>({value:t.left+e+1})))},isExported:!0},Jv={description:Ho("Number of columns in a specified array or range."),args:[Qh("range (meta)",Ho("The range whose column count will be returned."))],compute:function(e){if(gi(e?.value))return e;const t=ur(e.value);return t.right-t.left+1},isExported:!0},Qv={description:Ho("Horizontal lookup"),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("range (any, range)",Ho("The range to consider for the search. The first row in the range is searched for the key specified in search_key.")),Qh("index (number)",Ho("The row index of the value to be returned, where the first row in range is numbered 1.")),Qh("is_sorted (boolean, default=true)",Ho("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:Yv}){const i=Math.trunc(fi(o?.value,this.locale)),n=ji(t);if(1>i||i>n[0].length)return new si(Ho("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[t][0].value,a=n[Ei(s.value)?Gi(n,e,"nextSmaller","asc",n.length,r):Wi(n,e,"wildcard",n.length,r,this.lookupCaches)];return void 0===a?pi(e):a[i-1]},isExported:!0},eb={description:Ho("Returns the content of a cell, specified by row and column offset."),args:[Qh("reference (any, range)",Ho("The range of cells from which the values are returned.")),Qh("row (number, default=0)",Ho("The index of the row to be returned from within the reference range of cells.")),Qh("column (number, default=0)",Ho("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=ji(e),i=fi(t.value,this.locale),n=fi(o.value,this.locale);return n<0||n-1>=s.length||i<0||i-1>=s[0].length?new si(Ho("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},tb={description:Ho("Returns the content of a cell, specified by a string."),args:[Qh("reference (string)",Ho("The range of cells from which the values are returned.")),Qh("use_a1_notation (boolean, default=TRUE)",Ho("A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE)."))],compute:function(e,t={value:!0}){const o=e?.value?.toString();if(!o)return new ri(Ho("Reference should be defined."));if(!Ei(t))return new si(Ho("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 ri;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},ob={description:Ho("Look up a value."),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("search_array (any, range)",Ho("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.")),Qh("result_range (any, range, optional)",Ho("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=ji(t),i=ji(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=Gi(s,e,"nextSmaller","asc",a?r:n,l);return-1===c||a&&void 0===s[0][c]||!a&&void 0===s[c][r-1]?pi(e):0===i[0].length?a?s[n-1][c]:s[c][r-1]:(n=i.length,r=i[0].length,1!==n&&1!==r?new si(Ho("The result_range must be a single row or a single column.")):n>1?c>n-1?new si(Ho("[[FUNCTION_NAME]] evaluates to an out of range row value %s.",c+1)):i[c][0]:c>r-1?new si(Ho("[[FUNCTION_NAME]] evaluates to an out of range column value %s.",c+1)):i[0][c])},isExported:!0},sb={description:Ho("Position of item in range that matches value."),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("range (any, range)",Ho("The one-dimensional array to be searched.")),Qh("search_type (number, default=1)",Ho("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=fi(o,this.locale);const i=ji(t),n=i.length,r=i[0].length;if(1!==n&&1!==r)return new si(Ho("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=Gi(i,e,"nextSmaller","asc",c,l);break;case 0:a=Wi(i,e,"wildcard",c,l,this.lookupCaches);break;case-1:a=Gi(i,e,"nextGreater","desc",c,l)}return 1===n&&void 0===i[0][a]||1!==n&&void 0===i[a]?pi(e):a+1},isExported:!0},ib={description:Ho("Row number of a specified cell."),args:[Qh("cell_reference (meta, default='this cell')",Ho("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(gi(e?.value))return e;if(void 0===e)return void 0===this.__originCellPosition?.row?new si(Ho("In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.")):this.__originCellPosition.row+1;const t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.top===t.bottom?t.top+1:Ni(1,t.bottom-t.top+1,((e,o)=>({value:t.top+o+1})))},isExported:!0},nb={description:Ho("Number of rows in a specified array or range."),args:[Qh("range (meta)",Ho("The range whose row count will be returned."))],compute:function(e){if(gi(e?.value))return e;const t=ur(e.value);return t.bottom-t.top+1},isExported:!0},rb={description:Ho("Vertical lookup."),args:[Qh("search_key (string, number, boolean)",Ho("The value to search for. For example, 42, 'Cats', or I24.")),Qh("range (any, range)",Ho("The range to consider for the search. The first column in the range is searched for the key specified in search_key.")),Qh("index (number)",Ho("The column index of the value to be returned, where the first column in range is numbered 1.")),Qh("is_sorted (boolean, default=true)",Ho("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:Yv}){const i=Math.trunc(fi(o?.value,this.locale)),n=ji(t);if(1>i||i>n.length)return new si(Ho("[[FUNCTION_NAME]] evaluates to an out of bounds range."));const r=(e,t)=>e[0][t].value,a=Ei(s.value)?Gi(n,e,"nextSmaller","asc",n[0].length,r):Wi(n,e,"wildcard",n[0].length,r,this.lookupCaches),l=n[i-1][a];return void 0===l?pi(e):l},isExported:!0},ab={0:"strict",1:"nextGreater","-1":"nextSmaller",2:"wildcard"},lb={description:Ho("Search a range for a match and return the corresponding item from a second range."),args:[Qh("search_key (string,number,boolean)",Ho("The value to search for.")),Qh("lookup_range (any, range)",Ho("The range to consider for the search. Should be a single column or a single row.")),Qh("return_range (any, range)",Ho("The range containing the return value. Should have the same dimensions as lookup_range.")),Qh("if_not_found (any, optional)",Ho("If a valid match is not found, return this value.")),Qh("match_mode (any, default=0)",Ho("(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.")),Qh("search_mode (any, default=1)",Ho("(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(fi(i.value,this.locale)),a=Math.trunc(fi(n.value,this.locale)),l=ji(t),c=ji(o);if(1!==l.length&&1!==l[0].length)return new si(Ho("lookup_range should be either a single row or single column."));if(![1,-1,2,-2].includes(a))return new si(Ho("search_mode should be a value in [-1, 1, -2, 2]."));if(![-1,0,1,2].includes(r))return new si(Ho("match_mode should be a value in [-1, 0, 1, 2]."));const h=1===l.length?"col":"row";if(2===r&&[-2,2].includes(a))return new si(Ho("The search and match mode combination is not supported for XLOOKUP evaluation."));if("col"===h?c[0].length!==l[0].length:c.length!==l.length)return new si(Ho("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=ab[r],p=-1===a,m=2===a||-2===a?Gi(l,e,g,2===a?"asc":"desc",u,d):Wi(l,e,g,u,d,this.lookupCaches,p);return-1!==m?"col"===h?c.map((e=>[e[m]])):[c[m]]:void 0===s?pi(e):[[s]]},isExported:!0},cb={description:Ho("Get the value from a pivot."),args:[Qh("pivot_id (number,string)",Ho("ID of the pivot.")),Qh("measure_name (string)",Ho("Name of the measure.")),Qh("domain_field_name (string,repeating)",Ho("Field name.")),Qh("domain_value (number,string,boolean,repeating)",Ho("Value."))],compute:function(e,t,...o){const s=wi(e),i=wi(t),n=qv(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 si(Ho("The argument %s is not a valid measure. Here are the measures: %s",t,e))}}(n,i,this.getters),Zv(o);const r=this.getters.getPivot(n),a=this.getters.getPivotCoreDefinition(n);jv(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=Ho("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${s})`);return{value:ti.GenericError,message:Ho("Dimensions don't match the pivot definition")+". "+e}}const c=r.parseArgsToPivotDomain(o);return this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(n)?.trackValue(i,c),r.getPivotCellValueAndFormat(i,c)}},hb={description:Ho("Get the header of a pivot."),args:[Qh("pivot_id (number,string)",Ho("ID of the pivot.")),Qh("domain_field_name (string,repeating)",Ho("Field name.")),Qh("domain_value (number,string,value,repeating)",Ho("Value."))],compute:function(e,...t){const o=wi(e),s=qv(o,this.getters);Zv(t);const i=this.getters.getPivot(s);jv(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=Ho("Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.",`=PIVOT(${o})`);return{value:ti.GenericError,message:Ho("Dimensions don't match the pivot definition")+". "+e}}const r=i.parseArgsToPivotDomain(t);this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(s)?.trackHeader(r);const a=r.at(-1);if("measure"===a?.field)return i.getPivotMeasureValue(wi(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}}},db={description:Ho("Get a pivot table."),args:[Qh("pivot_id (string)",Ho("ID of the pivot.")),Qh("row_count (number, optional)",Ho("number of rows")),Qh("include_total (boolean, default=TRUE)",Ho("Whether to include total/sub-totals or not.")),Qh("include_column_titles (boolean, default=TRUE)",Ho("Whether to include the column titles or not.")),Qh("column_count (number, optional)",Ho("number of columns")),Qh("include_measure_titles (boolean, default=TRUE)",Ho("Whether to include the measure titles row or not."))],compute:function(e,t={value:1e4},o={value:!0},s={value:!0},i={value:Number.MAX_VALUE},n={value:!0}){const r=wi(e),a=fi(t,this.locale);if(a<0)return new si(Ho("The number of rows must be positive."));const l=fi(i,this.locale);if(l<0)return new si(Ho("The number of columns must be positive."));const c={displayColumnHeaders:Ei(s),displayTotals:Ei(o),displayMeasuresRow:Ei(n)},h=qv(r,this.getters),d=this.getters.getPivot(h),u=this.getters.getPivotCoreDefinition(h);jv(this,u,u.measures),d.init({reload:d.needsReevaluation});const g=d.assertIsValid({throwOnError:!1});if(g)return g;const p=d.getCollapsedTableStructure(),m=p.getPivotCells(c);let f=0;c.displayColumnHeaders&&(f=p.columns.length-1),c.displayMeasuresRow&&f++;const v=this.getters.getPivotName(h),b=Math.min(f+a,m[0].length);if(0===b)return[[{value:v}]];const S=Math.min(1+l,m.length),C=[];for(const e of je(0,S)){C[e]=[];for(const t of je(0,b)){const o=m[e][t];switch(o.type){case"EMPTY":C[e].push({value:""});break;case"HEADER":const t=d.getPivotHeaderValueAndFormat(o.domain);C[e].push((y=o.domain,w=t,0===y.length?w:{...w,format:(w.format||"@")+"* "}));break;case"MEASURE_HEADER":C[e].push(d.getPivotMeasureValue(o.measure,o.domain));break;case"VALUE":C[e].push(d.getPivotCellValueAndFormat(o.measure,o.domain))}}}var y,w;return(c.displayColumnHeaders||c.displayMeasuresRow)&&(C[0][0]={value:v}),C}},ub={description:Ho("Returns a range reference shifted by a specified number of rows and columns from a starting cell reference."),args:[Qh("cell_reference (meta)",Ho("The starting point from which to count the offset rows and columns.")),Qh("offset_rows (number)",Ho("The number of rows to offset by.")),Qh("offset_columns (number)",Ho("The number of columns to offset by.")),Qh("height (number, default='height of cell_reference')",Ho("The number of rows of the range to return starting at the offset target.")),Qh("width (number, default='width of cell_reference')",Ho("The number of columns of the range to return starting at the offset target."))],compute:function(e,t,o,s,i){if(gi(e?.value))return e;const n=e?.value;if(!n)return new si("In this context, the function OFFSET needs to have a cell or range in parameter.");const r=ur(n);let a=r.bottom-r.top+1,l=r.right-r.left+1;if(s){const e=fi(s,this.locale);if(e<1)return new si(Ho("Height value is %(_height)s. It should be greater than or equal to 1.",{_height:e}));a=e}if(i){const e=fi(i,this.locale);if(e<1)return new si(Ho("Width value is %(_width)s. It should be greater than or equal to 1.",{_width:e}));l=e}const{sheetName:c}=ra(n),h=c&&this.getters.getSheetIdByName(c)||this.getters.getActiveSheetId(),d=fi(t,this.locale),u=fi(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 ri(Ho("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(h,f);return v.invalidXc||v.invalidSheetName?new ri:(g&&this.addDependencies?.(g,[v]),Ni(l,a,((e,t)=>this.getters.getEvaluatedCell({sheetId:h,col:p+e,row:m+t}))))}};var gb=Object.freeze({__proto__:null,ADDRESS:Xv,COLUMN:Kv,COLUMNS:Jv,HLOOKUP:Qv,INDEX:eb,INDIRECT:tb,LOOKUP:ob,MATCH:sb,OFFSET:ub,PIVOT:db,PIVOT_HEADER:hb,PIVOT_VALUE:cb,ROW:ib,ROWS:nb,VLOOKUP:rb,XLOOKUP:lb});const pb={description:Ho("Sum of two numbers."),args:[Qh("value1 (number)",Ho("The first addend.")),Qh("value2 (number)",Ho("The second addend."))],compute:function(e,t){return{value:fi(e,this.locale)+fi(t,this.locale),format:e?.format||t?.format}}},mb={description:Ho("Concatenation of two values."),args:[Qh("value1 (string)",Ho("The value to which value2 will be appended.")),Qh("value2 (string)",Ho("The value to append to value1."))],compute:function(e,t){return wi(e)+wi(t)},isExported:!0},fb={description:Ho("One number divided by another."),args:[Qh("dividend (number)",Ho("The number to be divided.")),Qh("divisor (number)",Ho("The number to divide by."))],compute:function(e,t){const o=fi(t,this.locale);return 0===o?new hi(Ho("The divisor must be different from zero.")):{value:fi(e,this.locale)/o,format:e?.format||t?.format}}};function vb(e){return void 0===e||null===e.value}const bb={number:0,string:"",boolean:!1};function Sb(e,t,o=2e-16){return Math.abs(e-t)<o}const Cb={description:Ho("Equal."),args:[Qh("value1 (string, number, boolean)",Ho("The first value.")),Qh("value2 (string, number, boolean)",Ho("The value to test against value1 for equality."))],compute:function(e,t){if(gi(e?.value))return e;if(gi(t?.value))return t;let o=vb(e)?bb[typeof t?.value]:e?.value,s=vb(t)?bb[typeof e?.value]:t?.value;return"string"==typeof o&&(o=o.toUpperCase()),"string"==typeof s&&(s=s.toUpperCase()),"number"==typeof o&&"number"==typeof s?{value:Sb(o,s)}:{value:o===s}}};function yb(e,t,o){if(gi(e?.value))return e;if(gi(t?.value))return t;let s=vb(e)?bb[typeof t?.value]:e?.value,i=vb(t)?bb[typeof e?.value]:t?.value;"number"!=typeof s&&(s=wi(s).toUpperCase()),"number"!=typeof i&&(i=wi(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 wb={description:Ho("Strictly greater than."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being greater than value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){return yb(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?!Sb(e,t)&&e>t:e>t))}},Ib={description:Ho("Greater than or equal to."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being greater than or equal to value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){return yb(e,t,((e,t)=>"number"==typeof e&&"number"==typeof t?Sb(e,t)||e>t:e>=t))}},xb={description:Ho("Less than."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being less than value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){const o=Ib.compute.bind(this)(e,t);return gi(o.value)?o:{value:!o.value}}},Eb={description:Ho("Less than or equal to."),args:[Qh("value1 (number, string, boolean)",Ho("The value to test as being less than or equal to value2.")),Qh("value2 (number, string, boolean)",Ho("The second value."))],compute:function(e,t){const o=wb.compute.bind(this)(e,t);return gi(o.value)?o:{value:!o.value}}},Rb={description:Ho("Difference of two numbers."),args:[Qh("value1 (number)",Ho("The minuend, or number to be subtracted from.")),Qh("value2 (number)",Ho("The subtrahend, or number to subtract from value1."))],compute:function(e,t){return{value:fi(e,this.locale)-fi(t,this.locale),format:e?.format||t?.format}}},Tb={description:Ho("Product of two numbers"),args:[Qh("factor1 (number)",Ho("The first multiplicand.")),Qh("factor2 (number)",Ho("The second multiplicand."))],compute:function(e,t){return{value:fi(e,this.locale)*fi(t,this.locale),format:e?.format||t?.format}}},Ab={description:Ho("Not equal."),args:[Qh("value1 (string, number, boolean)",Ho("The first value.")),Qh("value2 (string, number, boolean)",Ho("The value to test against value1 for inequality."))],compute:function(e,t){const o=Cb.compute.bind(this)(e,t);return gi(o.value)?o:{value:!o.value}}},Db={description:Ho("A number raised to a power."),args:[Qh("base (number)",Ho("The number to raise to the exponent power.")),Qh("exponent (number)",Ho("The exponent to raise base to."))],compute:function(e,t){return bu.compute.bind(this)(e,t)}},_b={description:Ho("A number with the sign reversed."),args:[Qh("value (number)",Ho("The number to have its sign reversed. Equivalently, the number to multiply by -1."))],compute:function(e){return{value:-fi(e,this.locale),format:e?.format}}},Ob={description:Ho("Value interpreted as a percentage."),args:[Qh("percentage (number)",Ho("The value to interpret as a percentage."))],compute:function(e){return fi(e,this.locale)/100}},Fb={description:Ho("A specified number, unchanged."),args:[Qh("value (any)",Ho("The number to return."))],compute:function(e={value:null}){return e}};var Pb=Object.freeze({__proto__:null,ADD:pb,CONCAT:mb,DIVIDE:fb,EQ:Cb,GT:wb,GTE:Ib,LT:xb,LTE:Eb,MINUS:Rb,MULTIPLY:Tb,NE:Ab,POW:Db,UMINUS:_b,UNARY_PERCENT:Ob,UPLUS:Fb});const Mb=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),Nb={transform:e=>e,inverseTransform:e=>e},kb=1e-10,Vb=.0254,Lb=Vb/72,Hb=.3048,Ub=.9144,Bb=1609.34,zb=1852,$b=946073047258e4,Gb={g:{...Nb,category:"weight"},u:{...Mb(166053e-29),category:"weight"},grain:{...Mb(.0647989),category:"weight"},ozm:{...Mb(28.3495),category:"weight"},lbm:{...Mb(453.592),category:"weight"},stone:{...Mb(6350.29),category:"weight"},sg:{...Mb(14593.90294),category:"weight"},cwt:{...Mb(45359.237),category:"weight"},uk_cwt:{...Mb(50802.3),category:"weight"},ton:{...Mb(907184.74),category:"weight"},uk_ton:{...Mb(1016046.9),category:"weight"},m:{...Nb,category:"distance"},km:{...Mb(1e3),category:"distance"},ang:{...Mb(kb),category:"distance"},Picapt:{...Mb(Lb),category:"distance"},pica:{...Mb(Vb/6),category:"distance"},in:{...Mb(Vb),category:"distance"},ft:{...Mb(Hb),category:"distance"},yd:{...Mb(Ub),category:"distance"},ell:{...Mb(1.143),category:"distance"},mi:{...Mb(Bb),category:"distance"},survey_mi:{...Mb(1609.34),category:"distance"},Nmi:{...Mb(zb),category:"distance"},ly:{...Mb($b),category:"distance"},parsec:{...Mb(0x6da012f95c9fd0),category:"distance"},sec:{...Nb,category:"time"},min:{...Mb(60),category:"time"},hr:{...Mb(3600),category:"time"},day:{...Mb(86400),category:"time"},yr:{...Mb(31556952),category:"time"},Pa:{...Nb,category:"pressure"},bar:{...Mb(1e5),category:"pressure"},mmHg:{...Mb(133.322),category:"pressure"},Torr:{...Mb(133.322),category:"pressure"},psi:{...Mb(6894.76),category:"pressure"},atm:{...Mb(101325),category:"pressure"},N:{...Nb,category:"force"},dyn:{...Mb(1e-5),category:"force"},pond:{...Mb(.00980665),category:"force"},lbf:{...Mb(4.44822),category:"force"},J:{...Nb,category:"energy"},eV:{...Mb(160218e-24),category:"energy"},e:{...Mb(1e-7),category:"energy"},flb:{...Mb(1.3558179483),category:"energy"},c:{...Mb(4.184),category:"energy"},cal:{...Mb(4.1868),category:"energy"},BTU:{...Mb(1055.06),category:"energy"},Wh:{...Mb(3600),category:"energy"},HPh:{...Mb(2684520),category:"energy"},W:{...Nb,category:"power"},PS:{...Mb(735.499),category:"power"},HP:{...Mb(745.7),category:"power"},T:{...Nb,category:"magnetism"},ga:{...Mb(1e-4),category:"magnetism"},K:{...Nb,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:{...Mb(5/9),category:"temperature"},Reau:{transform:e=>1.25*e+273.15,inverseTransform:e=>(e-273.15)/1.25,category:"temperature"},"m^3":{...Nb,category:"volume",order:3},"ang^3":{...Mb(Math.pow(kb,3)),category:"volume",order:3},"Picapt^3":{...Mb(Math.pow(Lb,3)),category:"volume",order:3},tsp:{...Mb(492892e-11),category:"volume"},tspm:{...Mb(5e-6),category:"volume"},tbs:{...Mb(14786764825785619e-21),category:"volume"},"in^3":{...Mb(Math.pow(Vb,3)),category:"volume",order:3},oz:{...Mb(295735295625e-16),category:"volume"},cup:{...Mb(237e-6),category:"volume"},pt:{...Mb(.0004731765),category:"volume"},uk_pt:{...Mb(568261e-9),category:"volume"},qt:{...Mb(.0009463529),category:"volume"},l:{...Mb(.001),category:"volume"},uk_qt:{...Mb(.0011365225),category:"volume"},gal:{...Mb(.0037854118),category:"volume"},uk_gal:{...Mb(.00454609),category:"volume"},"ft^3":{...Mb(Math.pow(Hb,3)),category:"volume",order:3},bushel:{...Mb(.0352390704),category:"volume"},barrel:{...Mb(.158987295),category:"volume"},"yd^3":{...Mb(Math.pow(Ub,3)),category:"volume",order:3},MTON:{...Mb(1.13267386368),category:"volume"},GRT:{...Mb(2.83168),category:"volume"},"mi^3":{...Mb(Math.pow(Bb,3)),category:"volume",order:3},"Nmi^3":{...Mb(Math.pow(zb,3)),category:"volume",order:3},"ly^3":{...Mb(Math.pow($b,3)),category:"volume",order:3},"m^2":{...Nb,category:"area",order:2},"ang^2":{...Mb(Math.pow(kb,2)),category:"area",order:2},"Picapt^2":{...Mb(Math.pow(Lb,2)),category:"area",order:2},"in^2":{...Mb(Math.pow(Vb,2)),category:"area",order:2},"ft^2":{...Mb(Math.pow(Hb,2)),category:"area",order:2},"yd^2":{...Mb(Math.pow(Ub,2)),category:"area",order:2},ar:{...Mb(100),category:"area"},Morgen:{...Mb(2500),category:"area"},uk_acre:{...Mb(4046.8564224),category:"area"},us_acre:{...Mb(4046.8726098743),category:"area"},ha:{...Mb(1e4),category:"area"},"mi^2":{...Mb(Math.pow(Bb,2)),category:"area",order:2},"Nmi^2":{...Mb(Math.pow(zb,2)),category:"area",order:2},"ly^2":{...Mb(Math.pow($b,2)),category:"area",order:2},bit:{...Nb,category:"information"},byte:{...Mb(8),category:"information"},"m/s":{...Nb,category:"speed"},"m/hr":{...Mb(1/3600),category:"speed"},"km/hr":{...Mb(1/3.6),category:"speed"},mph:{...Mb(.44704),category:"speed"},kn:{...Mb(.5144444444),category:"speed"},admkn:{...Mb(.5147733333),category:"speed"}},Wb={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"},qb={"":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)},Zb={weight:Ho("Weight"),distance:Ho("Distance"),time:Ho("Time"),pressure:Ho("Pressure"),force:Ho("Force"),energy:Ho("Energy"),power:Ho("Power"),magnetism:Ho("Magnetism"),temperature:Ho("Temperature"),volume:Ho("Volume"),area:Ho("Area"),information:Ho("Information"),speed:Ho("Speed")};function jb(e){return Zb[e]??""}function Yb(e){for(const[t,o]of Object.entries(qb)){if(t&&!e.startsWith(t))continue;const s=e.slice(t.length);let i=Gb[s];if(!i&&Wb[s]&&(i=Gb[Wb[s]]),i)return{...i,factor:i.order?Math.pow(o,i.order):o}}}const Xb={description:Ho("Converts a numeric value to a different unit of measure."),args:[Qh("value (number)",Ho("the numeric value in start_unit to convert to end_unit")),Qh("start_unit (string)",Ho("The starting unit, the unit currently assigned to value")),Qh("end_unit (string)",Ho("The unit of measure into which to convert value"))],compute:function(e,t,o){const s=fi(e,this.locale),i=wi(t),n=wi(o),r=Yb(i),a=Yb(n);return r?a?r.category!==a.category?{value:ti.GenericError,message:Ho("Incompatible units of measure ('%s' vs '%s')",jb(r.category),jb(a.category))}:{value:a.inverseTransform(r.factor*r.transform(s))/a.factor,format:e?.format}:{value:ti.GenericError,message:Ho("Invalid units of measure ('%s')",n)}:{value:ti.GenericError,message:Ho("Invalid units of measure ('%s')",i)}},isExported:!0};var Kb=Object.freeze({__proto__:null,CONVERT:Xb});const Jb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,Qb={description:Ho("Gets character associated with number."),args:[Qh("table_number (number)",Ho("The number of the character to look up from the current Unicode table in decimal format."))],compute:function(e){const t=Math.trunc(fi(e,this.locale));return t<1?new si(Ho("The table_number (%s) is out of range.",t)):String.fromCharCode(t)},isExported:!0},eS={description:Ho("Remove non-printable characters from a piece of text."),args:[Qh("text (string)",Ho("The text whose non-printable characters are to be removed."))],compute:function(e){const t=wi(e);let o="";for(const e of t)e&&e.charCodeAt(0)>31&&(o+=e);return o},isExported:!0},tS={description:Ho("Appends strings to one another."),args:[Qh("string1 (string, range<string>)",Ho("The initial string.")),Qh("string2 (string, range<string>, repeating)",Ho("More strings to append in sequence."))],compute:function(...e){return Fi(e,((e,t)=>e+wi(t)),"")},isExported:!0},oS={description:Ho("Tests whether two strings are identical."),args:[Qh("string1 (string)",Ho("The first string to compare.")),Qh("string2 (string)",Ho("The second string to compare."))],compute:function(e,t){return wi(e)===wi(t)},isExported:!0},sS={description:Ho("First position of string found in text, case-sensitive."),args:[Qh("search_for (string)",Ho("The string to look for within text_to_search.")),Qh("text_to_search (string)",Ho("The text to search for the first occurrence of search_for.")),Qh("starting_at (number, default=1)",Ho("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=wi(e),i=wi(t),n=fi(o,this.locale);if(""===i)return new si(Ho("The text_to_search must be non-empty."));if(n<1)return new si(Ho("The starting_at (%s) must be greater than or equal to 1.",n));const r=i.indexOf(s,n-1);return-1===r?new si(Ho("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)):r+1},isExported:!0},iS={description:Ho("Concatenates elements of arrays with delimiter."),args:[Qh("delimiter (string)",Ho("The character or string to place between each concatenated value.")),Qh("value_or_array1 (string, range<string>)",Ho("The value or values to be appended using delimiter.")),Qh("value_or_array2 (string, range<string>, repeating)",Ho("More values to be appended using delimiter."))],compute:function(e,...t){const o=wi(e);return Fi(t,((e,t)=>(e?e+o:"")+wi(t)),"")}},nS={description:Ho("Substring from beginning of specified string."),args:[Qh("text (string)",Ho("The string from which the left portion will be returned.")),Qh("number_of_characters (number, optional)",Ho("The number of characters to return from the left side of string."))],compute:function(e,...t){const o=t.length?fi(t[0],this.locale):1;return o<0?new si(Ho("The number_of_characters (%s) must be positive or null.",o)):wi(e).substring(0,o)},isExported:!0},rS={description:Ho("Length of a string."),args:[Qh("text (string)",Ho("The string whose length will be returned."))],compute:function(e){return wi(e).length},isExported:!0},aS={description:Ho("Converts a specified string to lowercase."),args:[Qh("text (string)",Ho("The string to convert to lowercase."))],compute:function(e){return wi(e).toLowerCase()},isExported:!0},lS={description:Ho("A segment of a string."),args:[Qh("text (string)",Ho("The string to extract a segment from.")),Qh("starting_at (number)",Ho("The index from the left of string from which to begin extracting. The first character in string has the index 1.")),Qh("extract_length (number)",Ho("The length of the segment to extract."))],compute:function(e,t,o){const s=wi(e),i=fi(t,this.locale),n=fi(o,this.locale);return i<1?new si(Ho("The starting_at argument (%s) must be positive greater than one.",i.toString())):n<0?new si(Ho("The extract_length argument (%s) must be positive or null.",n)):s.slice(i-1,i+n-1)},isExported:!0},cS={description:Ho("Capitalizes each word in a specified string."),args:[Qh("text_to_capitalize (string)",Ho("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 wi(e).replace(Jb,(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()))},isExported:!0},hS={description:Ho("Replaces part of a text string with different text."),args:[Qh("text (string)",Ho("The text, a part of which will be replaced.")),Qh("position (number)",Ho("The position where the replacement will begin (starting from 1).")),Qh("length (number)",Ho("The number of characters in the text to be replaced.")),Qh("new_text (string)",Ho("The text which will be inserted into the original text."))],compute:function(e,t,o,s){const i=fi(t,this.locale);if(i<1)return new si(Ho("The position (%s) must be greater than or equal to 1.",i));const n=wi(e),r=fi(o,this.locale),a=wi(s);return n.substring(0,i-1)+a+n.substring(i-1+r)},isExported:!0},dS={description:Ho("A substring from the end of a specified string."),args:[Qh("text (string)",Ho("The string from which the right portion will be returned.")),Qh("number_of_characters (number, optional)",Ho("The number of characters to return from the right side of string."))],compute:function(e,...t){const o=t.length?fi(t[0],this.locale):1;if(o<0)return new si(Ho("The number_of_characters (%s) must be positive or null.",o));const s=wi(e),i=s.length;return s.substring(i-o,i)},isExported:!0},uS={description:Ho("First position of string found in text, ignoring case."),args:[Qh("search_for (string)",Ho("The string to look for within text_to_search.")),Qh("text_to_search (string)",Ho("The text to search for the first occurrence of search_for.")),Qh("starting_at (number, default=1)",Ho("The character within text_to_search at which to start the search."))],compute:function(e,t,o={value:1}){const s=wi(e).toLowerCase(),i=wi(t).toLowerCase(),n=fi(o,this.locale);if(""===i)return{value:ti.GenericError,message:Ho("The text_to_search must be non-empty.")};if(n<1)return{value:ti.GenericError,message:Ho("The starting_at (%s) must be greater than or equal to 1.",n)};const r=i.indexOf(s,n-1);return-1===r?{value:ti.GenericError,message:Ho("In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.",s,i)}:{value:r+1}},isExported:!0},gS={description:Ho("Split text by specific character delimiter(s)."),args:[Qh("text (string)",Ho("The text to divide.")),Qh("delimiter (string)",Ho("The character or characters to use to split text.")),Qh("split_by_each (boolean, default=true})",Ho("Whether or not to divide text around each character contained in delimiter.")),Qh("remove_empty_text (boolean, default=true)",Ho("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=wi(e),n=Be(wi(t)),r=Ei(o),a=Ei(s);if(n.length<=0)return new si(Ho("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))),Vi([c])},isExported:!1},pS={description:Ho("Replaces existing text with new text in a string."),args:[Qh("text_to_search (string)",Ho("The text within which to search and replace.")),Qh("search_for (string)",Ho("The string to search for within text_to_search.")),Qh("replace_with (string)",Ho("The string that will replace search_for.")),Qh("occurrence_number (number, optional)",Ho("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=fi(s,this.locale);if(i<0)return new si(Ho("The occurrenceNumber (%s) must be positive or null.",i));const n=wi(e),r=wi(t);if(""===r)return n;const a=wi(o),l=new RegExp(Be(r),"g");if(0===i)return n.replace(l,a);let c=0;return n.replace(l,(e=>++c===i?a:e))},isExported:!0},mS={description:Ho("Combines text from multiple strings and/or arrays."),args:[Qh("delimiter (string)",Ho(" A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.")),Qh("ignore_empty (boolean)",Ho("A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.")),Qh("text1 (string, range<string>)",Ho("Any text item. This could be a string, or an array of strings in a range.")),Qh("text2 (string, range<string>, repeating)",Ho("Additional text item(s)."))],compute:function(e,t,...o){const s=wi(e),i=Ei(t);let n=0;return Fi(o,((e,t)=>i&&""===wi(t)?e:(n++?e+s:"")+wi(t)),"")},isExported:!0},fS={description:Ho("Splits text into rows or columns using specified column and row delimiters."),args:[Qh("text (string)",Ho("The text to split.")),Qh("col_delimiter (string, range<string>)",Ho("Character or string to split columns by.")),Qh("row_delimiter (string, range<string>, optional)",Ho("Character or string to split rows by.")),Qh("ignore_empty (boolean, default=false)",Ho("Whether to ignore empty cells.")),Qh("match_mode (number, default=0)",Ho("Searches the text for a delimiter match. 0 = case-sensitive, 1 = case-insensitive.")),Qh(`pad_with (string, default="${ti.NotAvailable}")`,Ho("The value to use for padding empty cells."))],compute:function(e,t,o,s={value:false},i={value:0},n=new ai){const r=wi(e);if(r.length<=0)return new si(Ho("No text to split."));if(void 0===t&&void 0===o)return new si(Ho("At least one delimiter must be provided."));const a=ji(t).flat().map((e=>Be(wi(e)))),l=ji(o).flat().map((e=>Be(wi(e))));if(a.some((e=>""===e))||l.some((e=>""===e)))return new si(Ho("The delimiters cannot be empty values."));const c=Ei(s),h=fi(i,this.locale);if(![0,1].includes(h))return new si(Ho("match_mode should be a value of 0 or 1."));const d=[],u=1===h?"gi":"g",g=l.filter((e=>!a.includes(e)));let p=g.length?r.split(new RegExp(g.join("|"),u)):[r];c&&(p=p.filter((e=>""!==e)));const m=new RegExp(a.join("|"),u);for(const e of p){let t=a.length?e.split(m):[e];c&&(t=t.filter((e=>""!==e))),d.push(t.map((e=>({value:e}))))}const f=Math.max(...d.map((e=>e.length)));for(const e of d)for(;e.length<f;)e.push(n);return Vi(d)},isExported:!0},vS={description:Ho("Removes space characters."),args:[Qh("text (string)",Ho("The text or reference to a cell containing text to be trimmed."))],compute:function(e){return Dt(wi(e))},isExported:!0},bS={description:Ho("Converts a specified string to uppercase."),args:[Qh("text (string)",Ho("The string to convert to uppercase."))],compute:function(e){return wi(e).toUpperCase()},isExported:!0},SS={description:Ho("Converts a number to text according to a specified format."),args:[Qh("number (number)",Ho("The number, date or time to format.")),Qh("format (string)",Ho('The case-sensitive format of the result, enclosed in quotation marks. Examples: "0.00" rounded to 2 decimal places, "hh:mm:ss" for hour:minutes:seconds.'))],compute:function(e,t){return In(fi(e,this.locale),{format:wi(t),locale:this.locale})},isExported:!0},CS={description:Ho("Converts a string to a numeric value."),args:[Qh("value (number)",Ho("the string to be converted"))],compute:function(e){return fi(e,this.locale)},isExported:!0};var yS=Object.freeze({__proto__:null,CHAR:Qb,CLEAN:eS,CONCATENATE:tS,EXACT:oS,FIND:sS,JOIN:iS,LEFT:nS,LEN:rS,LOWER:aS,MID:lS,PROPER:cS,REPLACE:hS,RIGHT:dS,SEARCH:uS,SPLIT:gS,SUBSTITUTE:pS,TEXT:SS,TEXTJOIN:mS,TEXTSPLIT:fS,TRIM:vS,UPPER:bS,VALUE:CS});const wS={description:Ho("Creates a hyperlink in a cell."),args:[Qh("url (string)",Ho("The full URL of the link enclosed in quotation marks.")),Qh("link_label (string, optional)",Ho("The text to display in the cell, enclosed in quotation marks."))],compute:function(e,t){const o=wi(e).trim(),s=wi(t)||o;return""===o?s:ot(s,o)},isExported:!0};var IS=Object.freeze({__proto__:null,HYPERLINK:wS});const xS=[{name:Ho("Array"),functions:Rd},{name:Ho("Database"),functions:cp},{name:Ho("Date"),functions:Gp},{name:Ho("Filter"),functions:om},{name:Ho("Financial"),functions:Wf},{name:Ho("Info"),functions:Pv},{name:Ho("Lookup"),functions:gb},{name:Ho("Logical"),functions:Wv},{name:Ho("Math"),functions:Uu},{name:Ho("Misc"),functions:Ad},{name:Ho("Operator"),functions:Pb},{name:Ho("Statistical"),functions:jg},{name:Ho("Text"),functions:yS},{name:Ho("Engineering"),functions:qp},{name:Ho("Web"),functions:IS},{name:Ho("Parser"),functions:Kb}],ES=/^[A-Z0-9\_\.]+$/;const RS=new class extends n{mapping={};add(e,t){if((e=e.toUpperCase())in this.content)throw new Error(`${e} is already present in this registry!`);return this.replace(e,t)}replace(e,t){if(e=e.toUpperCase(),!ES.test(e))throw new Error(Ho("Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)",e));const o=function(e,t){let o=0,s=0,i=0,n=0;for(const e of t.args)o++,e.optional||e.repeating||e.default||s++,e.repeating&&i++,(e.optional||e.default)&&n++;const r=t;return r.minArgRequired=s,r.maxArgPossible=i?1/0:o,r.nbrArgRepeating=i,r.nbrArgOptional=n,r.hidden=t.hidden||!1,r.name=e,r}(e,t);return function(e){if(e.nbrArgRepeating&&e.nbrArgOptional>=e.nbrArgRepeating)throw new Error(`Function ${e.name} has more optional arguments than repeatable ones.`);let t=!1,o=!1;for(const s of e.args){if(s.type.includes("META")&&s.type.length>1)throw new Error(`Function ${e.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(s.repeating){if(!o&&t)throw new Error(`Function ${e.name} has non-consecutive repeating arguments. All repeating arguments must be declared consecutively.`);t=!0,o=!0}else o=!1}}(o),this.mapping[e]=function(e){function t(...t){const s=[],i=td(e,t.length);for(let o=0;o<t.length;o++){const n=i(o)??-1,r=e.args[n];if(!js(t[o])&&r.acceptMatrixOnly)throw new ii(Ho("Function %s expects the parameter '%s' to be reference to a cell or range.",e.name,(o+1).toString()));s.push(!r.acceptMatrix)}return Li(o.bind(this),t,s)}function o(...t){for(let o=0;o<t.length;o++){const s=t[o],i=td(e,t.length);if(!e.args[i(o)||o].acceptErrors&&!js(s)&&gi(s?.value))return s}try{return s.apply(this,t)}catch(t){return TS(t,e.name)}}function s(...t){this.debug;const o=e.compute.apply(this,t);return js(o)?"object"==typeof o[0][0]&&null!==o[0][0]&&"value"in o[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])}(o,(t=>AS(t,e.name))),o):ki(o,(e=>({value:e}))):"object"==typeof o&&null!==o&&"value"in o?(AS(o,e.name),o):{value:o}}return t}(o),super.replace(e,o),this}};for(const e of xS){const t=e.functions;for(let o in t){const s=t[o];s.category=s.category||e.name,o=o.replace(/_/g,"."),RS.add(o,{isExported:!1,...s})}}function TS(e,t){return o=e,void 0!==o?.value&&"string"==typeof o.value&&gi(e.value)?(_S(e)&&AS(e,t),e):(console.error(e),new si(DS+(_S(e)?" "+e.message:"")));var o}function AS(e,t){e.message?.includes("[[FUNCTION_NAME]]")&&(e.message=e.message.replace("[[FUNCTION_NAME]]",t))}const DS=Ho("An unexpected error occurred. Submit a support ticket at odoo.com/help.");function _S(e){return void 0!==e?.message&&"string"==typeof e.message}class OS{scope;code="";constructor(e=new PS){this.scope=e}append(...e){this.code+=e.map((e=>e.toString())).join("\n")+"\n"}return(e){return new FS(this.scope,this.code,e)}toString(){return MS(this.code)}}class FS{scope;returnExpression;code;constructor(e,t,o){this.scope=e,this.returnExpression=o,this.code=MS(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 PS{nextId=1;declaredVariables=new Set;nextVariableName(){const e="_"+this.nextId++;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}}function MS(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 NS=RS.content,kS={"=":"EQ","+":"ADD","-":"MINUS","*":"MULTIPLY","/":"DIVIDE",">=":"GTE","<>":"NE",">":"GT","<=":"LTE","<":"LT","^":"POWER","&":"CONCATENATE"},VS={"-":"UMINUS","+":"UPLUS","%":"UNARY.PERCENT"},LS={};function HS(e){return US(Xf(e))}function US(e){try{return function(e){const{dependencies:t,literalValues: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=Ue(i.value);t.strings.push({value:e});break;case"NUMBER":{const e=As(i.value,qs);t.numbers.push({value:e});break}case"SYMBOL":s.push(Ge(i.value,"'"))}return{dependencies:o,literalValues:t,symbols:s}}(e),i=function(e){let t="";for(const o of e)switch(o.type){case"STRING":t+="|S|";break;case"NUMBER":t+="|N|";break;case"REFERENCE":case"INVALID_REFERENCE":o.value.includes(":")?t+="|R|":t+="|C|";break;case"SPACE":break;default:t+=o.value}return t}(e);if(!LS[i]){const r=lv([...e]),a=new PS;let l=0,c=0,h=0;if("BIN_OPERATION"===r.type&&":"===r.value)throw new ii(Ho("Invalid formula"));if("EMPTY"===r.type)throw new ii(Ho("Invalid formula"));const d=m(r),u=new OS;u.append(`// ${i}`),u.append(d),u.append(`return ${d.returnExpression};`);const g=new Function("deps","ref","range","getSymbolValue","ctx",u.toString());function p(e){const{args:t}=e,o=e.value.toUpperCase(),s=NS[o];if(!s)throw new li(Ho('Unknown function: "%s"',e.value));!function(e){const t=e.args.length,o=e.value.toUpperCase(),s=NS[o],{nbrArgRepeating:i,minArgRequired:n}=s;if(t<n)throw new ii(Ho("Invalid number of arguments for the %(functionName)s function. Expected %(minArgRequired)s minimum, but got %(nbrArgSupplied)s instead.",{functionName:o,minArgRequired:n,nbrArgSupplied:t}));if(t>s.maxArgPossible)throw new ii(Ho("Invalid number of arguments for the %(functionName)s function. Expected %(maxArgPossible)s maximum, but got %(nbrArgSupplied)s instead.",{functionName:o,maxArgPossible:s.maxArgPossible,nbrArgSupplied:t}));if(i>1){const e=t-n-i*Math.floor((t-n)/i)-s.nbrArgOptional;if(e>0)throw new ii(Ho("Invalid number of arguments for the %(functionName)s function. Repeatable arguments should be supplied in groups of %(nbrArgRepeating)s, with up to %(nbrArgOptional)s optional. Got %(nbrValueRemaining)s too many.",{functionName:o,nbrArgRepeating:i,nbrArgOptional:s.nbrArgOptional,nbrValueRemaining:e}))}}(e);const i=[],n=td(s,t.length);for(let e=0;e<t.length;e++){const o=s.args[n(e)??-1],r=t[e],a=o.type||[],l=a.includes("META"),c=a.some((e=>BS(e)));i.push(m(r,l,c))}return i}function m(e,t=!1,o=!1){const i=new OS(a);if("REFERENCE"!==e.type&&("BIN_OPERATION"!==e.type||":"!==e.value)&&t)throw new ii(Ho("Argument must be a reference to a cell or range."));switch(e.debug&&(i.append("debugger;"),i.append('ctx["debug"] = true;')),e.type){case"BOOLEAN":return i.return(`{ value: ${e.value} }`);case"NUMBER":return i.return(`this.literalValues.numbers[${c++}]`);case"STRING":return i.return(`this.literalValues.strings[${l++}]`);case"REFERENCE":return!t&&e.value.includes(":")||o?i.return(`range(deps[${h++}])`):i.return(`ref(deps[${h++}], ${t?"true":"false"})`);case"FUNCALL":const n=p(e).map((e=>e.assignResultToVariable()));i.append(...n);const r=e.value.toUpperCase();return i.return(`ctx['${r}'](${n.map((e=>e.returnExpression))})`);case"UNARY_OPERATION":{const t=VS[e.value],o=m(e.operand,!1,!1).assignResultToVariable();return i.append(o),i.return(`ctx['${t}'](${o.returnExpression})`)}case"BIN_OPERATION":{const t=kS[e.value],o=m(e.left,!1,!1).assignResultToVariable(),s=m(e.right,!1,!1).assignResultToVariable();return i.append(o),i.append(s),i.return(`ctx['${t}'](${o.returnExpression}, ${s.returnExpression})`)}case"SYMBOL":const a=s.indexOf(e.value);return i.return(`getSymbolValue(this.symbols[${a}])`);case"EMPTY":return i.return("undefined")}}LS[i]=g}const n={execute:LS[i],dependencies:t,literalValues: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 BS(e){return e.startsWith("RANGE")}const zS=RS.content;function $S(e){try{return 0===hv(lv(e)).filter((e=>"FUNCALL"===e.type&&!zS[e.value.toUpperCase()]?.isExported)).length}catch(e){return!1}}function GS(e,t){if(!e.some((e=>"SYMBOL"===e.type&&t.includes(e.value.toUpperCase()))))return[];let o;try{o=lv(e)}catch{return[]}return function(e,t){return hv(e).filter((e=>"FUNCALL"===e.type&&t.includes(e.value.toUpperCase()))).map((e=>({functionName:e.value.toUpperCase(),args:e.args})))}(o,t)}function WS(e,t,o){if(!t.startsWith("="))return t;const s=Xf(t);for(let t=1;t<s.length;t++){if("REFERENCE"!==s[t].type)continue;const i=s[t].value,n=qS(e,i,o);i!==n&&(s[t]={value:n,type:"REFERENCE"})}return dt(s.map((e=>e.value)))}function qS(e,t,o){const s=ra(t).sheetName;if(s?!ga(s,o.sheetName.old):e!==o.sheetId)return t;const i=function(e,t){if(!ta.test(e))return fa(e);return ma({xc:e,sheetId:t},ZS)}(t,s?o.sheetId:e);if(i.invalidXc)return t;const n=o.applyChange(i);return"NONE"===n.changeType||"REMOVE"===n.changeType?t:Sa(n.range,e,function(e){return t=>t===e.sheetId?e.sheetName.current:""}(o))}function ZS(e){return{numberOfRows:Number.MAX_SAFE_INTEGER,numberOfCols:Number.MAX_SAFE_INTEGER}}const jS="x1",YS="xMovingAverage",XS={exponential:"exp",logarithmic:"log",polynomial:"poly",trailingMovingAverage:"movingAvg"};function KS(e,t,o,s){let i=!1;const n=[];for(const s in o){let r=o[s];if(r.labelCell){const e=eC(r.labelCell,t);r.labelCell!==e&&(i=!0,r={...r,labelCell:e})}const a=eC(r.dataRange,t);void 0===a||e.getRangeString(a,a.sheetId)===ti.InvalidReference?(i=!0,r=void 0):a!==r.dataRange&&(i=!0,r={...r,dataRange:a}),n[s]=r}let r=s;const a=eC(r,t);a!==r&&(i=!0,r=a);return{isStale:i,dataSets:n.filter(lt),labelRange:r}}function JS(e,t,o){return o.map((o=>({dataRange:Ca(e,t,o.dataRange),labelCell:o.labelCell?Ca(e,t,o.labelCell):void 0})))}function QS(e,t,o){return o?Ca(e,t,o):void 0}function eC(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}function tC(e,t,o,s){const i=[];for(const n of t){const t=e.getRangeFromSheetXC(o,n.dataRange),{unboundedZone:r,sheetId:a,invalidSheetName:l,invalidXc:c}=t;if(!l&&!c)if(r.left!==r.right&&r.top!==r.bottom){if(void 0===r.right)continue;for(let t=r.left;t<=r.right;t++){const o={...r,left:t,right:t};i.push({...oC(e,a,o,s?{top:o.top,bottom:o.top,left:o.left,right:o.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}}else i.push({...oC(e,a,r,s?{top:r.top,bottom:r.top,left:r.left,right:r.left}:void 0),backgroundColor:n.backgroundColor,rightYAxis:"y1"===n.yAxisId,customLabel:n.label,trend:n.trend})}return i}function oC(e,t,o,s){if(o.left!==o.right&&o.top!==o.bottom)throw new Error(`Zone should be a single column or row: ${fr(o)}`);if(s){const i=fr(o),n=fr(s);return{labelCell:e.getRangeFromSheetXC(t,n),dataRange:e.getRangeFromSheetXC(t,i)}}return{labelCell:void 0,dataRange:e.getRangeFromSheetXC(t,fr(o))}}function sC(e,t){const o=t.labelCell?.zone;let s=t.dataRange.zone;if(o){const{numberOfRows:e,numberOfCols:t}=Tr(s);1===e?s={...s,left:s.left+1}:1===t&&(s={...s,top:s.top+1})}const i=pa({...t.dataRange,zone:s},e.getSheetSize);let n,r={};return t.customLabel?r={text:t.customLabel}:t.labelCell&&(r={reference:e.getRangeString(t.labelCell,"forceSheetReference",{useBoundedReference:!0})}),t.trend?.type&&(n={type:"polynomial"===t.trend.type&&1===t.trend.order?"linear":XS[t.trend.type],color:t.trend.color,order:t.trend.order?Math.min(t.trend.order,6):void 0,window:t.trend.window||Ae}),{label:r,range:e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0}),backgroundColor:t.backgroundColor,rightYAxis:t.rightYAxis,trend:n}}function iC(e,t,o){if(!t)return;const s={...t.zone};o&&t.zone.bottom>t.zone.top&&(s.top=s.top+1);const i=pa({...t,zone:s},e.getSheetSize);return e.getRangeString(i,"forceSheetReference",{useBoundedReference:!0})}function nC(e,t,o){let s;if(t.labelRange){const i=qS(e,t.labelRange,o);i!==ti.InvalidReference&&(s=i)}const i=[];for(const s of t.dataSets){const t={...s},n=qS(e,s.dataRange,o);n!==ti.InvalidReference&&(t.dataRange=n,i.push(t))}return{...t,dataSets:i,labelRange:s}}function rC(e){return e&&jt(e)<.3?"#FFFFFF":"#000000"}function aC(e){return e&&jt(e)<.3?"#C8C8C8":"#666666"}function lC(e){if(e.dataSets){const t=void 0!==e.dataSets.find((e=>!ta.test(e.dataRange)));if(t)return"InvalidDataSet";if(e.dataSets.map((e=>dr(e.dataRange))).some((e=>e.top!==e.bottom&&kr(e))))return"InvalidDataSet"}return"Success"}function cC(e){if(e.labelRange){if(!ta.test(e.labelRange||""))return"InvalidLabelRange"}return"Success"}function hC(e,t,o){if(!o)return!1;if(!e)return!1;if(!t)return!0;const s=Lr(t.dataRange.zone);return!(Lr(e.zone)<s)}function dC(e){let t=!1,o=!1;if("horizontal"in e&&e.horizontal)return{useLeftAxis:!0,useRightAxis:!1};for(const s of e.dataSets||[])"y1"===s.yAxisId?o=!0:t=!0;return t||=!o,{useLeftAxis:t,useRightAxis:o}}function uC(e,t){return(o,s)=>{const i=e?.[s];return gC({format:i,locale:t})(o)}}function gC(e){return t=>{if(t=Number(t),isNaN(t))return t;const{locale:o,format:s}=e;return fC(In(t,{locale:o,format:!s&&Math.abs(t)>=1e3?"#,##":s}))}}const pC=[{value:"left",label:Ho("Left")},{value:"right",label:Ho("Right")}];function mC(e,t){const o=[],s=Ft(t.map((e=>e.data.length)));for(let t=0;t<=s;t++)o.push(e.next());return o}function fC(e){return e?e.length>ye?e.substring(0,ye)+"…":e:""}function vC(e){return e===jS||e===YS}const bC={id:"chartShowValuesPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;switch(i.save(),i.textAlign="center",i.textBaseline="middle",i.miterLimit=1,e.config.type){case"pie":case"doughnut":!function(e,t,o){for(const s of e._metasets)for(let e=0;e<s._parsed.length;e++){const i=Number(s._parsed[e]);if(isNaN(i)||0===i)continue;const n=s.data[e],{startAngle:r,endAngle:a,innerRadius:l,outerRadius:c}=n,h=(r+a)/2,d=(l+c)/2,u=n.x+d*Math.cos(h),g=n.y+d*Math.sin(h),p=t.callback(i,s,e),m=12,f=Va(o,p,{fontSize:m},"px"),v=c-l;if(f>=v||v<m)continue;const b=a-r,S=2*d*Math.tan(b/2);b<Math.PI/2&&(f>=S||S<m)||(o.fillStyle=rC(t.background),o.strokeStyle=t.background||"#ffffff",SC(p,u,g,o))}}(e,o,i);break;case"bar":case"line":case"radar":o.horizontal?CC(e,o,i):function(e,t,o){const s=e.chartArea.bottom,i=e.chartArea.top,n={};for(const r of e._metasets){if(vC(r.xAxisID)||r.hidden)continue;const a=e.scales[r.yAxisID];for(let l=0;l<r._parsed.length;l++){const c=r._parsed[l],h=Number("radar"===e.config.type?c.r:c.y);if(isNaN(h))continue;const d=r.data[l],u=d.x;let g=0;if("line"===e.config.type||"radar"===e.config.type)g=h<0?d.y+10:d.y-10;else{const e=a.getPixelForValue(0),t=12;g=Math.abs(e-d.y)<t?h<0?e+t/2:e-t/2:h<0?d.y-d.height/2:d.y+d.height/2}g=Math.min(g,s),g=Math.max(g,i),n[u]||(n[u]=[]);for(const e of n[u]||[])Math.abs(e-g)<13&&(g=h<0?e+13:e-13);n[u].push(g),o.fillStyle=d.options.backgroundColor,o.strokeStyle=t.background||"#ffffff";SC(t.callback(Number(h),r,l),u,g,o)}}}(e,o,i);break;case"funnel":CC(e,o,i)}i.restore()}};function SC(e,t,o,s){s.lineWidth=3,s.strokeText(e,t,o),s.lineWidth=1,s.fillText(e,t,o)}function CC(e,t,o){const s=e.chartArea.right,i=e.chartArea.left,n={};for(const r of e._metasets){if(vC(r.xAxisID))return;const a=e.scales[r.xAxisID].getPixelForValue(0);for(let e=0;e<r._parsed.length;e++){const l=Number(r._parsed[e].x);if(isNaN(l))continue;const c=t.callback(l,r,e),h=r.data[e],d=h.y,u=Va(o,c,{fontSize:12},"px"),g=3;let p;Math.abs(h.x-a)<u?p=l<0?a-u/2-g:a+u/2+g:(p=l<0?h.x+h.width/2:h.x-h.width/2,p=Math.min(p,s),p=Math.max(p,i)),n[d]||(n[d]=[]);for(const e of n[d])Math.abs(e-p)<u&&(p=l<0?e-u-g:e+u+g);n[d].push(p),o.fillStyle=h.options.backgroundColor,o.strokeStyle=t.background||"#ffffff",SC(c,p,d,o)}}}const yC={showHeaders:!0,headerDesign:{align:"center",fillColor:"#808080",bold:!0,fontSize:15},showValues:!0,showLabels:!0,valuesDesign:{align:"left",verticalAlign:"bottom",fontSize:12},coloringOptions:{type:"categoryColor",colors:[],useValueBasedGradient:!0}},wC="nullValue";function IC(e,t){const{dataSetsValues:o}=t,s=[],i=BC(e,o.length),n=[];for(const r in o){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=i.next(),d={label:a,data:l,hidden:c,borderColor:e.background||m,borderWidth:e.stacked?1:0,backgroundColor:h,yAxisID:e.horizontal?"y":e.dataSets?.[r].yAxisId||"y",xAxisID:"x"};s.push(d);const u=e.dataSets?.[r].trend,g=t.trendDataSetsValues?.[r];u?.display&&!e.horizontal&&g&&n.push(HC(d,u,g))}return s.push(...n),s}function xC(e,t){const{dataSetsValues:o,labels:s}=t,i=e.negativeValuesColor||A,n=e.positiveValuesColor||T,r=e.subTotalValuesColor||D,a=[],l=[],c={label:"",data:l,backgroundColor:a},h=[];let d=0;for(const t of o)if(!t.hidden){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(Ho("Subtotal")),l.push([0,d]),a.push(r))}return{datasets:[c],labels:h}}function EC(e,t){const{dataSetsValues:o,axisType:s,labels:i}=t,n=[],r=!!e.fillArea,a=!!e.stacked,l=[],c=BC(e,o.length);for(let h=0;h<o.length;h++){let{label:d,data:u,hidden:g}=o[h];d=e.dataSets?.[h].label||d;const p=c.next();s&&["linear","time"].includes(s)&&(u=u.map(((e,t)=>({x:i[t]||void 0,y:e}))));const m={label:d,data:u,hidden:g,tension:0,borderColor:p,backgroundColor:r?oo(p,Re):p,pointBackgroundColor:p,fill:!!r&&UC(h,a),pointRadius:e.hideDataMarkers?0:Te,yAxisID:e.dataSets?.[h].yAxisId||"y"};n.push(m);const f=e.dataSets?.[h].trend,v=t.trendDataSetsValues?.[h];f?.display&&v&&l.push(HC(m,f,v))}return n.push(...l),n}function RC(e,t){const o=EC(e,t);for(const e of o)vC(e.xAxisID)||(e.showLine=!1);return o}function TC(e,t){const{dataSetsValues:o}=t,s=[],i=Math.max(0,...o.map((e=>e?.data?.length??0))),n=mC(new fo(i),o);for(const{label:t,data:i,hidden:r}of o){if(r)continue;const o={label:t,data:i,borderColor:e.background||"#FFFFFF",backgroundColor:n,hoverOffset:10};s.push(o)}return s}function AC(e,t){const{dataSetsValues:o}=t,s=[],i=BC(e,o.length),n=[];for(let r=0;r<o.length;r++){let{label:a,data:l,hidden:c}=o[r];a=e.dataSets?.[r].label||a;const h=e.dataSets?.[r],d=i.next(),u=h?.type??"line",g={label:a,data:l,hidden:c,borderColor:d,backgroundColor:d,yAxisID:e.dataSets?.[r].yAxisId||"y",xAxisID:"x",type:u,order:"bar"===u?o.length+r:r,pointRadius:e.hideDataMarkers?0:Te};s.push(g);const p=e.dataSets?.[r].trend,m=t.trendDataSetsValues?.[r];p?.display&&m&&n.push(HC(g,p,m))}return s.push(...n),s}function DC(e,t){const{dataSetsValues:o}=t,s=[],i=e.fillArea??!1,n=BC(e,o.length);for(let t=0;t<o.length;t++){let{label:r,data:a,hidden:l}=o[t];e.dataSets?.[t]?.label&&(r=e.dataSets[t].label);const c=n.next(),h={label:r,data:a,hidden:l,borderColor:c,backgroundColor:c,pointRadius:e.hideDataMarkers?0:Te};i&&(h.backgroundColor=oo(c,Re),h.fill="start"),s.push(h)}return s}function _C(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 OC(e,t){const o=t.dataSetsValues[0],s=t.labels;if(!o)return[];let{label:i,data:n}=o;i=e.dataSets?.[0].label||i;return[{label:i,data:n.map((e=>e<=0?[0,0]:[-e,e])),backgroundColor:FC(s,e.funnelColors),yAxisID:"y",xAxisID:"x",barPercentage:1,categoryPercentage:1,borderColor:e.background||m,borderWidth:3}]}function FC(e,t){const o=new fo(e.length,t);return e.map((()=>o.next()))}function PC(e,t){const{dataSetsValues:o,labels:s}=t,i=kC(MC(o,s)),n=i[0]||[],r=new fo(n.length,e.groupColors||[]),a=n.map((e=>({label:e.label,color:r.next()}))),l=[];for(let t=i.length-1;t>=0;t--){const o={groupColors:a,parsing:{key:"value"},data:i[t],borderColor:t=>{const o="data"===t.type?t.raw:void 0;return o&&o.label!==wC?e.background||m:R},backgroundColor:e=>{const t="data"===e.type?e.raw:void 0;if(!t||t.label===wC)return R;const o=t.groups[0];return a.find((e=>e.label===o))?.color},hoverOffset:10};l.push(o)}return l}function MC(e,t){const o=function(e,t){const o=[],s=Math.max(...e.map((e=>e.data.length)));for(let i=0;i<s;i++){o[i]={};for(let t=0;t<e.length;t++){const s=null===e[t].data[i]?wC:String(e[t].data[i]);o[i][t]=s}o[i].value=Number(t[i])}return o}(e,t);return NC(o,0,e.length,[])}function NC(e,t,o,s){if(t>=o)return[];const i=Object.groupBy(e,(e=>e[t]));return Object.keys(i).map((e=>{const n=i[e]?.reduce(((e,t)=>e+Number(t.value)),0)||0,r=[...s,e];return{label:e,value:n,children:NC(i[e]||[],t+1,o,[...s,e]),groups:r,depth:t}})).sort(((e,t)=>t.value-e.value))}function kC(e){const t=[],o=[...e];for(;o.length>0;){const e=o.shift();e&&(t[e.depth]||(t[e.depth]=[]),t[e.depth].push(e),e.children&&o.push(...e.children))}return t}function VC(e,t){const{dataSetsValues:o,labels:s,locale:i,axisFormats:n}=t,r={locale:i,format:n?.y};if(0===o.length)return[];const a=MC(o,s).sort(((e,t)=>t.value-e.value)),l=function(e,t){const o="categoryColor"===e.coloringOptions?.type?e.coloringOptions.colors:[],s=new fo(t.length,o);return t.map((e=>({label:e.label,color:s.next()})))}(e,a),c=[],h=Math.max(...o.map((e=>e.data.length)));for(let e=0;e<h;e++){c[e]={};for(let t=0;t<o.length;t++)c[e][t]=o[t].data[e]?String(o[t].data[e]):void 0;c[e].value=Number(s[e])}const d=e.showLabels??yC.showLabels,u=e.showValues??yC.showValues,g=e.coloringOptions||yC.coloringOptions;let p;"colorScale"===g?.type&&(p=function(e,t){const o=kC(e),s=o[o.length-1],i=Math.min(...s.map((e=>e.value))),n=Math.max(...s.map((e=>e.value)));if(Number.isFinite(i)&&Number.isFinite(n)){const e=[{value:i,color:t.minColor}];if(t.midColor){const o=(i+n)/2;e.push({value:o,color:t.midColor})}return e.push({value:n,color:t.maxColor}),So(e)}return}(a,g));const m=[{data:[],tree:c,labels:{display:d||u,overflow:"hidden",...LC(e.valuesDesign,yC.valuesDesign),formatter:e=>[d?e.raw.g:void 0,u?In(e.raw.v,r):void 0].filter(lt)},captions:{display:e.showHeaders??yC.showHeaders,padding:6,...LC(e.headerDesign,yC.headerDesign)},key:"value",groups:je(0,o.length).map((e=>String(e))),borderWidth:0,spacing:1,displayMode:"headerBoxes",groupColors:l,backgroundColor:t=>{if("data"!==t.type)return"transparent";if(!t.raw.isLeaf)return e.headerDesign?.fillColor||yC.headerDesign?.fillColor;if("colorScale"===g.type)return p?.(t.raw.v)||"#FF0000";if("categoryColor"===g.type)return function(e,t,o,s){const i=e.raw._data.children[0][0],n=s.find((e=>e.label===i))?.color;if(!n||!o.useValueBasedGradient)return n||"#FF0000";const r=t.find((e=>e.label===i));if(!r||!r.children.length)return n;const a=kC(r.children),l=a[a.length-1],c=Math.max(...l.map((e=>e.value))),h=Math.min(...l.map((e=>e.value)));if(h===c||!isFinite(h)||!isFinite(c))return n;const d=Number(e.raw.v)||0,u=(d-c)/(h-c)*.5;return so(n,u)}(t,a,g,l);throw new Error("Unsupported coloring option type}")}}];return m}function LC(e,t){const o=e=>jt(e.element.options.backgroundColor)>.7?"#666666":"#FFFFFF";return{align:e?.align??t?.align,position:e?.verticalAlign??t?.verticalAlign,color:e?.color||o,hoverColor:e?.color||o,font:{weight:e?.bold??t?.bold?"bold":"normal",style:e?.italic??t?.italic?"italic":"normal",size:e?.fontSize??t?.fontSize}}}function HC(e,t,o){const s=Xt(e.backgroundColor);s.a=1;const i=t.color||so(Yt(s),.5);return{type:"line",xAxisID:"trailingMovingAverage"===t.type?YS:jS,yAxisID:e.yAxisID,label:e.label?Ho("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 UC(e,t){return t?0===e?"origin":"-1":"origin"}function BC(e,t){return new fo(t,e.dataSets?.map((e=>e.backgroundColor))||[])}const zC={id:"sunburstHoverPlugin",afterEvent(e,t,o){if(!o.enabled)return;const s=e.getActiveElements();let i=s.map((e=>({datasetIndex:e.datasetIndex,index:e.index})));for(const t of s){const o=e.data.datasets[t.datasetIndex].data[t.index];for(let t=0;t<e.data.datasets.length;t++){const s=e.data.datasets[t];for(let e=0;e<s.data.length;e++){const n=s.data[e];$C(o.groups,n.groups)&&i.push({datasetIndex:t,index:e})}}}i=i.filter((t=>{const{datasetIndex:o,index:s}=t;return e.data.datasets[o].data[s].label!==wC})),e.setActiveElements(i);for(const t of e.getSortedVisibleDatasetMetas())for(const e of t.data){const t=e.$context,{datasetIndex:o,index:s,dataset:n,raw:r}=t;if(r.label===wC)continue;const a="function"==typeof n.backgroundColor?n.backgroundColor(t):n.backgroundColor;i.length&&!i.some((e=>e.datasetIndex===o&&e.index===s))?e.options.backgroundColor=so(a,.5):e.options.backgroundColor=a}}};function $C(e,t){return t.length>e.length&&e.every(((e,o)=>e===t[o]))}const GC={id:"sunburstLabelsPlugin",afterDatasetsDraw(e,t,o){if(!o.showValues&&!o.showLabels||"doughnut"!==e.config.type)return;!function(e,t,o){const s=t.style,i=s.fontSize||13,n=i+3;for(const r of e._metasets)for(let a=0;a<r._dataset.data.length;a++){const l=r._dataset.data[a];if(l.label===wC)continue;const c=[t.showLabels?l.label:void 0,t.showValues?t.callback(l.value,"y"):void 0].filter(lt),h=r.data[a];let{startAngle:d,endAngle:u,innerRadius:g,outerRadius:p,circumference:m}=h;const f=h.options.offset/4,v=f*(1-Math.sin(Math.min(Math.PI,m||0)));g+=v,p+=v;const b=(d+u)/2,S=(g+p)/2,C=.9*(p-g),y=u-d;if((y>=Math.PI?p:Math.sin(y/2)*g*2)<c.length*n)continue;o.save();const w={x:Math.cos(b)*f,y:Math.sin(b)*f},I=e.chartArea.left+e.chartArea.width/2+w.x,x=e.chartArea.top+e.chartArea.height/2+w.y;let E;o.translate(I,x),b>Math.PI/2?(o.rotate(b-Math.PI),E=-S):(E=S,o.rotate(b));const R=jt(h.options.backgroundColor)>.7?"#666666":"#FFFFFF";o.fillStyle=s.textColor||R,o.textAlign="center",o.textBaseline="middle",o.font=Na(i,s.bold,s.italic);const T=-(c.length-1)*n/2;for(let e=0;e<c.length;e++){const t=Xa(o,C,c[e],s,"px");o.fillText(t,E,T+e*n)}o.restore()}}(e,o,e.ctx)}};const WC={id:"waterfallLinesPlugin",beforeDraw(e,t,o){if(!o.showConnectorLines)return;const s=e._metasets?.[0]?.data;if(!s)return;const i=e.ctx;i.save(),i.setLineDash([3,2]);for(let e=0;e<s.length;e++){const t=s[e];if(0===t.height)continue;const o=ZC(s,e);if(!o)break;const n=qC(t),r=qC(o),a=t.$context.raw,l=a[1]-a[0],c=Math.round(l<0?n.bottom-1:n.top),h=Math.round(n.right),d=Math.round(r.left);i.strokeStyle="#999",i.beginPath(),i.moveTo(h+1,c+.5),i.lineTo(d,c+.5),i.stroke()}i.restore()}};function qC(e){const t=e.base<e.y;return{left:e.x-e.width/2,right:e.x+e.width/2,bottom:t?e.base+e.height:e.y+e.height,top:t?e.base:e.y}}function ZC(e,t){return e.find(((e,o)=>o>t&&0!==e.height))}yh`
|
|
2
2
|
.o-spreadsheet {
|
|
3
3
|
.o-chart-custom-tooltip {
|
|
4
4
|
font-size: 12px;
|
|
@@ -1682,7 +1682,7 @@
|
|
|
1682
1682
|
}
|
|
1683
1683
|
}
|
|
1684
1684
|
}
|
|
1685
|
-
`;class DN extends t.Component{static template="o-spreadsheet-PivotDimension";static props={dimension:Object,onRemoved:{type:Function,optional:!0},onNameUpdated:{type:Function,optional:!0},slots:{type:Object,optional:!0}};static components={CogWheelMenu:AN,TextInput:TN};updateName(e){this.props.onNameUpdated?.(this.props.dimension,""===e||e.startsWith("=")?void 0:e)}}class _N extends t.Component{static template="o-spreadsheet-PivotDimensionGranularity";static props={dimension:Object,onUpdated:Function,availableGranularities:Set,allGranularities:Array};periods=Vc}class ON extends t.Component{static template="o-spreadsheet-PivotDimensionOrder";static props={dimension:Object,onUpdated:Function}}class FN extends t.Component{static template="o-spreadsheet-PivotMeasureEditor";static components={PivotDimension:DN,StandaloneComposer:OE};static props={definition:Object,measure:Object,onMeasureUpdated:Function,onRemoved:Function,generateMeasureId:Function,aggregators:Object,pivotId:String};getMeasureAutocomplete(){return e=this.props.definition,t=this.props.measure,{sequence:0,autoSelectFirstProposal:!0,getProposals(o){const s=e.measures.filter((e=>e!==t)).map((e=>{const t=We(e.id);return{text:t,description:e.displayName,htmlContent:[{value:t,color:Q}],fuzzySearchKey:e.displayName+t+e.fieldName}})),i=e.rows.concat(e.columns).map((e=>{const t=We(e.nameWithGranularity);return{text:t,description:e.displayName,htmlContent:[{value:t,color:Q}],fuzzySearchKey:e.displayName+t+e.fieldName}}));return s.concat(i)},selectProposal(e,t){let o=e.end;"SYMBOL"===e.type&&(o=e.start);const s=e.end;this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}};var e,t}updateMeasureFormula(e){this.props.onMeasureUpdated({...this.props.measure,computedBy:{sheetId:this.env.model.getters.getActiveSheetId(),formula:"="===e[0]?e:"="+e}})}updateAggregator(e){this.props.onMeasureUpdated({...this.props.measure,aggregator:e,id:this.props.generateMeasureId(this.props.measure.fieldName,e)})}updateName(e,t){this.props.measure.computedBy&&t?this.props.onMeasureUpdated({...this.props.measure,userDefinedName:t,id:this.props.generateMeasureId(t,this.props.measure.aggregator),fieldName:t}):this.props.onMeasureUpdated({...this.props.measure,userDefinedName:t})}toggleMeasureVisibility(){this.props.onMeasureUpdated({...this.props.measure,isHidden:!this.props.measure.isHidden})}openShowValuesAs(){this.env.replaceSidePanel("PivotMeasureDisplayPanel",`pivot_key_${this.props.pivotId}`,{pivotId:this.props.pivotId,measure:this.props.measure})}getColoredSymbolToken(e){if("SYMBOL"!==e.type)return;const t=Ge(e.value,"'");return this.props.definition.columns.some((e=>e.nameWithGranularity===t))||this.props.definition.rows.some((e=>e.nameWithGranularity===t))||this.props.definition.measures.some((e=>e.id===t&&e.id!==this.props.measure.id))?Q:void 0}get isCalculatedMeasureInvalid(){return
|
|
1685
|
+
`;class DN extends t.Component{static template="o-spreadsheet-PivotDimension";static props={dimension:Object,onRemoved:{type:Function,optional:!0},onNameUpdated:{type:Function,optional:!0},slots:{type:Object,optional:!0}};static components={CogWheelMenu:AN,TextInput:TN};updateName(e){this.props.onNameUpdated?.(this.props.dimension,""===e||e.startsWith("=")?void 0:e)}}class _N extends t.Component{static template="o-spreadsheet-PivotDimensionGranularity";static props={dimension:Object,onUpdated:Function,availableGranularities:Set,allGranularities:Array};periods=Vc}class ON extends t.Component{static template="o-spreadsheet-PivotDimensionOrder";static props={dimension:Object,onUpdated:Function}}class FN extends t.Component{static template="o-spreadsheet-PivotMeasureEditor";static components={PivotDimension:DN,StandaloneComposer:OE};static props={definition:Object,measure:Object,onMeasureUpdated:Function,onRemoved:Function,generateMeasureId:Function,aggregators:Object,pivotId:String};getMeasureAutocomplete(){return e=this.props.definition,t=this.props.measure,{sequence:0,autoSelectFirstProposal:!0,getProposals(o){const s=e.measures.filter((e=>e!==t)).map((e=>{const t=We(e.id);return{text:t,description:e.displayName,htmlContent:[{value:t,color:Q}],fuzzySearchKey:e.displayName+t+e.fieldName}})),i=e.rows.concat(e.columns).map((e=>{const t=We(e.nameWithGranularity);return{text:t,description:e.displayName,htmlContent:[{value:t,color:Q}],fuzzySearchKey:e.displayName+t+e.fieldName}}));return s.concat(i)},selectProposal(e,t){let o=e.end;"SYMBOL"===e.type&&(o=e.start);const s=e.end;this.composer.changeComposerCursorSelection(o,s),this.composer.replaceComposerCursorSelection(t)}};var e,t}updateMeasureFormula(e){this.props.onMeasureUpdated({...this.props.measure,computedBy:{sheetId:this.env.model.getters.getActiveSheetId(),formula:"="===e[0]?e:"="+e}})}updateAggregator(e){this.props.onMeasureUpdated({...this.props.measure,aggregator:e,id:this.props.generateMeasureId(this.props.measure.fieldName,e)})}updateName(e,t){this.props.measure.computedBy&&t?this.props.onMeasureUpdated({...this.props.measure,userDefinedName:t,id:this.props.generateMeasureId(t,this.props.measure.aggregator),fieldName:t}):this.props.onMeasureUpdated({...this.props.measure,userDefinedName:t})}toggleMeasureVisibility(){this.props.onMeasureUpdated({...this.props.measure,isHidden:!this.props.measure.isHidden})}openShowValuesAs(){this.env.replaceSidePanel("PivotMeasureDisplayPanel",`pivot_key_${this.props.pivotId}`,{pivotId:this.props.pivotId,measure:this.props.measure})}getColoredSymbolToken(e){if("SYMBOL"!==e.type)return;const t=Ge(e.value,"'");return this.props.definition.columns.some((e=>e.nameWithGranularity===t))||this.props.definition.rows.some((e=>e.nameWithGranularity===t))||this.props.definition.measures.some((e=>e.id===t&&e.id!==this.props.measure.id))?Q:void 0}get isCalculatedMeasureInvalid(){return HS(this.props.measure.computedBy?.formula??"").isBadExpression}}yh`
|
|
1686
1686
|
.o-pivot-sort {
|
|
1687
1687
|
.o-sort-card {
|
|
1688
1688
|
width: fit-content;
|
|
@@ -1871,7 +1871,7 @@
|
|
|
1871
1871
|
background: #e7f2f6;
|
|
1872
1872
|
}
|
|
1873
1873
|
}
|
|
1874
|
-
`;class Pk extends t.Component{static template="o_spreadsheet.PivotHTMLRenderer";static components={Checkbox:oR};static props={pivotId:String,onCellClicked:Function};pivot=this.env.model.getters.getPivot(this.props.pivotId);data={columns:[],rows:[],values:[]};state=t.useState({showMissingValuesOnly:!1});setup(){const e=this.pivot.getExpandedTableStructure(),t=this.env.model.getters.getPivotFormulaId(this.props.pivotId);this.data={columns:this._buildColHeaders(t,e),rows:this._buildRowHeaders(t,e),values:this._buildValues(t,e)}}get tracker(){return this.env.model.getters.getPivotPresenceTracker(this.props.pivotId)}getTableData(){if(!this.state.showMissingValuesOnly)return this.data;const e=this.getColumnsIndexes(),t=this.getRowsIndexes();return{columns:this.buildColumnsMissing(e),rows:this.buildRowsMissing(t),values:this.buildValuesMissing(e,t)}}addRecursiveRow(e){const t=this.pivot.getExpandedTableStructure().rows,o=[...t[e].values];if(o.length<=1)return[e];o.pop();const s=t.findIndex((e=>JSON.stringify(e.values)===JSON.stringify(o)));return[e].concat(this.addRecursiveRow(s))}buildColumnsMissing(e){const t=[];for(const e of this.data.columns){const o=[];for(const t in e)for(let s=0;s<e[t].span;s++)o.push(parseInt(t,10));t.push(o)}for(let o=t[t.length-1].length;o>=0;o--)if(!e.includes(o))for(const e of t)e.splice(o,1);const o=[];for(const e in t){const s=[];let i,n=1;for(let o=0;o<t[e].length;o++)i!==t[e][o]?(void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),i=t[e][o],n=1):n++;void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),o.push(s)}return o}buildRowsMissing(e){return e.map((e=>this.data.rows[e]))}buildValuesMissing(e,t){const o=e.map((()=>[]));for(const s of t)for(const t in e)o[t].push(this.data.values[e[t]][s]);return o}getColumnsIndexes(){const e=new Set;for(let t=0;t<this.data.columns.length;t++){const o=[];for(let e=0;e<this.data.columns[t].length;e++)for(let s=0;s<this.data.columns[t][e].span;s++)o.push(this.data.columns[t][e]);for(let t=0;t<o.length;t++)o[t].isMissing&&e.add(t)}for(let t=0;t<this.data.columns[this.data.columns.length-1].length;t++){this.data.values[t].find((e=>e.isMissing))&&e.add(t)}return Array.from(e).sort(((e,t)=>e-t))}getRowsIndexes(){const e=new Set;for(let t=0;t<this.data.rows.length;t++){this.data.rows[t].isMissing&&e.add(t);for(const o of this.data.values)o[t].isMissing&&this.addRecursiveRow(t).forEach((t=>e.add(t)))}return Array.from(e).sort(((e,t)=>e-t))}_buildColHeaders(e,t){const o=[];for(const s of t.columns){const t=[];for(const o of s){const s=[];for(let e=0;e<o.fields.length;e++)s.push({value:o.fields[e]},{value:o.values[e]});const i=this.pivot.parseArgsToPivotDomain(s),n=this.env.model.getters.getLocale();if("measure"===i.at(-1)?.field){const{value:s,format:r}=this.pivot.getPivotMeasureValue(wi(i.at(-1).value),i);t.push({formula:`=PIVOT.HEADER(${Bc(e,i).join(",")})`,value:In(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}else{const{value:s,format:r}=this.pivot.getPivotHeaderValueAndFormat(i);t.push({formula:`=PIVOT.HEADER(${Bc(e,i).join(",")})`,value:In(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}}o.push(t)}const s=o[o.length-1];return o[o.length-1]=s.map((e=>(e.isMissing||(e.style="color: #756f6f;"),e))),o}_buildRowHeaders(e,t){const o=[];for(const s of t.rows){const t=[];for(let e=0;e<s.fields.length;e++)t.push({value:s.fields[e]},{value:s.values[e]});const i=this.pivot.parseArgsToPivotDomain(t),{value:n,format:r}=this.pivot.getPivotHeaderValueAndFormat(i),a=this.env.model.getters.getLocale(),l={formula:`=PIVOT.HEADER(${Bc(e,i).join(",")})`,value:In(n,{format:r,locale:a}),isMissing:!this.tracker?.isHeaderPresent(i)};s.indent>1&&(l.style=`padding-left: ${s.indent-10}px`),o.push(l)}return o}_buildValues(e,t){const o=[];for(const s of t.columns.at(-1)||[]){const i=[],n=wi(s.values[s.values.length-1]);for(const o of t.rows){const t=[];for(let e=0;e<o.fields.length;e++)t.push({value:o.fields[e]},{value:o.values[e]});for(let e=0;e<s.fields.length-1;e++)t.push({value:s.fields[e]},{value:s.values[e]});const r=this.pivot.parseArgsToPivotDomain(t),{value:a,format:l}=this.pivot.getPivotCellValueAndFormat(n,r),c=this.env.model.getters.getLocale();i.push({formula:`=PIVOT.VALUE(${Bc(e,r,n).join(",")})`,value:In(a,{format:l,locale:c}),isMissing:!this.tracker?.isValuePresent(n,r)})}o.push(i)}return o}}class Mk{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 Nk extends Mk{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,o){}garbageCollectExternalResources(){}}class kk{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 Vk(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 Vk{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 Lk(e){return""===e?NaN:Number(e)}function Hk(e){return Object.entries(e).map((([e,t])=>t?Uk(parseInt(e,10),t):void 0)).filter(lt).map((e=>Po(e.left,e.top)+":"+Po(e.right,e.bottom)))}function Uk(e,t){return{...t.zone,id:e}}class Bk{getters;providers=[];constructor(e){this.getters=e}static getters=["adaptFormulaStringDependencies","copyFormulaStringForSheet","extendRange","getRangeString","getRangeFromSheetXC","createAdaptedRanges","getRangeData","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){const t=Ia(e);t?.applyChange&&this.executeOnAllRanges(t.applyChange,t.sheetId,t.sheetName)}finalize(){}verifyRangeRemoved(e){return t=>{const o=e(t);return"NONE"===o.changeType||pr(o.range.zone)?o:{range:o.range,changeType:"REMOVE"}}}executeOnAllRanges(e,t,o){const s=this.verifyRangeRemoved(e);for(const e of this.providers)e(s,t,o)}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,o,s){return e.map((e=>{if(!pr(e.zone))return e;const i=e.prefixSheet?e.sheetId:s,n=ba(e),r=va(e),a={...e.unboundedZone,left:n&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:n?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:r&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:o),bottom:r?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:o)};return function(e){if(mr(e.zone))return e;const t={...e.unboundedZone},o={...e.zone};let s=e.parts;if(void 0!==t.right&&t.right<t.left){const e=t.right;t.right=t.left,t.left=e,o.right=o.left,o.left=e,s=[{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1},{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1}]}if(void 0!==t.bottom&&t.bottom<t.top){const e=t.bottom;t.bottom=t.top,t.top=e,o.bottom=o.top,o.top=e,s=[{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1},{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1}]}return{unboundedZone:t,zone:o,parts:s,invalidXc:e.invalidXc,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}(pa({...e,sheetId:i,zone:a},this.getters.getSheetSize))}))}removeRangesSheetPrefix(e,t){return t.map((t=>t.prefixSheet&&t.sheetId===e?{...t,prefixSheet:!1}:t))}extendRange(e,t,o){const s="COL"===t?e.zone.right+o:e.zone.right,i="ROW"===t?e.zone.bottom+o:e.zone.bottom,n={left:e.zone.left,top:e.zone.top,right:ba(e)?void 0:s,bottom:va(e)?void 0:i};return pa({...e,zone:n},this.getters.getSheetSize)}getRangeFromSheetXC(e,t){if(!ta.test(t)||!this.getters.tryGetSheet(e))return fa(t);const{sheetName:o}=ra(t);return ma({xc:t,sheetId:this.getters.getSheetIdByName(o)||e,invalidSheetName:o&&!this.getters.getSheetIdByName(o)?o:void 0},this.getters.getSheetSize)}getRangeString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){return e?e.invalidXc?e.invalidXc:this.getters.tryGetSheet(e.sheetId)?Sa(e,t,this.getters.getSheetName,o):ti.InvalidReference:ti.InvalidReference}getRangeDataFromXc(e,t){const o=this.getters.getRangeFromSheetXC(e,t);return this.getRangeDataFromZone(o.sheetId,o.unboundedZone)}getRangeDataFromZone(e,t){return{_sheetId:e,_zone:t=this.getters.getUnboundedZone(e,t)}}getRangeData(e){return this.getRangeDataFromZone(e.sheetId,e.unboundedZone)}getRangeFromZone(e,t){return pa({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=>e.unboundedZone)),s=t.map((e=>e.unboundedZone));return nr(o,s).map((t=>this.getRangeFromZone(e[0].sheetId,t)))}getRangeFromRangeData(e){if(!this.getters.tryGetSheet(e._sheetId))return fa(ti.InvalidReference);return pa({prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]},this.getters.getSheetSize)}isRangeValid(e){if(!e)return!1;const{xc:t,sheetName:o}=ra(e);return null!==t.match(ta)&&(!o||void 0!==this.getters.getSheetIdByName(o))}getRangesUnion(e){const t=e.map((e=>e.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)}adaptFormulaStringDependencies(e,t,o){if(!t.startsWith("="))return t;const s=HS(t),i=s.dependencies.map((t=>{const s=this.getters.getRangeFromSheetXC(e,t),i=o(s);return"NONE"===i.changeType?s:i.range}));return this.getters.getFormulaString(e,s.tokens,i)}copyFormulaStringForSheet(e,t,o,s){if(!o.startsWith("="))return o;const i=HS(o),n=i.dependencies.map((o=>{const i=this.getters.getRangeFromSheetXC(e,o);return"keepSameReference"===s?i:Ca(e,t,i)}));return this.getters.getFormulaString(t,i.tokens,n)}}function zk(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}class $k extends Mk{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}}const Gk=new n;Gk.add("pivots",(e=>{for(const t of e.getPivotIds()){const o=e.getPivot(t);o.markAsDirtyForEvaluation?.()}}));const Wk=RS.mapping;function qk(e,t,o){return new Zk(e,t,o).getParameters()}class Zk{getters;computeCell;evalContext;rangeCache={};constructor(e,t,o){this.getters=t,this.computeCell=o,this.evalContext=Object.assign(Object.create(Wk),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:aa(this.getters.getSheetName(e.sheetId),fr(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=wr(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 pr(e.zone)?e.invalidSheetName?new si(Ho("Invalid sheet name: %s",e.invalidSheetName)):void 0:new ri}}function jk(e,t,o,s,i){Yk(e,t,o||0,s||e.length-1,i||Kk)}function Yk(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);Yk(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(Xk(e,o,t),i(e[s],h)>0&&Xk(e,o,s);d<u;){for(Xk(e,d,u),d++,u--;i(e[d],h)<0;)d++;for(;i(e[u],h)>0;)u--}0===i(e[o],h)?Xk(e,o,u):Xk(e,++u,s),u<=t&&(o=u+1),t<=u&&(s=u-1)}}function Xk(e,t,o){var s=e[t];e[t]=e[o],e[o]=s}function Kk(e,t){return e<t?-1:e>t?1:0}class Jk{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(!cV(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;cV(e,a)&&(t.leaf?o.push(r):lV(e,a)?this._all(r,o):i.push(r))}t=i.pop()}return o}collides(e){let t=this.data;if(!cV(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(cV(e,n)){if(t.leaf||lV(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=hV([]),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=Qk(e,o.children,t);if(-1!==s)return o.children.splice(s,1),i.push(o),this._condense(i),this}l||o.leaf||!lV(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=hV(e.slice(t,o+1)),eV(n,this.toBBox),n;s||(s=Math.ceil(Math.log(i)/Math.log(r)),r=Math.ceil(i/Math.pow(r,s-1))),n=hV([]),n.leaf=!1,n.height=s;const a=Math.ceil(i/r),l=a*Math.ceil(Math.sqrt(r));dV(e,t,o,l,this.compareMinX);for(let i=t;i<=o;i+=l){const t=Math.min(i+l-1,o);dV(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 eV(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=nV(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),oV(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=hV(o.children.splice(n,o.children.length-n));r.height=o.height,r.leaf=o.leaf,eV(o,this.toBBox),eV(r,this.toBBox),t?e[t-1].children.push(r):this._splitRoot(o,r)}_splitRoot(e,t){this.data=hV([e,t]),this.data.height=e.height+1,this.data.leaf=!1,eV(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=tV(e,0,r,this.toBBox),a=tV(e,r,o,this.toBBox),l=aV(t,a),c=nV(t)+nV(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:sV,i=e.leaf?this.compareMinY:iV;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=tV(e,0,t,i),r=tV(e,o-t,o,i);let a=rV(n)+rV(r);for(let s=t;s<o-t;s++){const t=e.children[s];oV(n,e.leaf?i(t):t),a+=rV(n)}for(let s=o-t-1;s>=t;s--){const t=e.children[s];oV(r,e.leaf?i(t):t),a+=rV(r)}return a}_adjustParentBBoxes(e,t,o){for(let s=o;s>=0;s--)oV(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():eV(e[o],this.toBBox)}}function Qk(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 eV(e,t){tV(e,0,e.children.length,t,e)}function tV(e,t,o,s,i){i||(i=hV(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];oV(i,e.leaf?s(t):t)}return i}function oV(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 sV(e,t){return e.minX-t.minX}function iV(e,t){return e.minY-t.minY}function nV(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function rV(e){return e.maxX-e.minX+(e.maxY-e.minY)}function aV(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 lV(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function cV(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function hV(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function dV(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;jk(e,r,t,o,i),n.push(t,r,r,o)}}class uV{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 gV,this.rTrees[e].load(t[e])}insert(e){const t=e.boundingBox.sheetId;this.rTrees[t]||(this.rTrees[t]=new gV),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 gV extends Jk{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 pV{createEmptyPositionSet;dependencies=new $D;rTree;constructor(e,t=[]){this.createEmptyPositionSet=e,this.rTree=new uV(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(Mr(e)));for(const e in r){const t=nr(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 mV 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 fV{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]=mV.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 vV{resultsToArrayFormulas=new uV;arrayFormulasToResults=new $D;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map((e=>e.data))||bV}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:Mr(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 bV=[],SV=Object.freeze(Jn(new ni)),CV=Object.freeze(Jn({value:null}));class yV{context;getters;compilationParams;evaluatedCells=new $D;formulaDependencies=ut(new pV(this.createEmptyPositionSet.bind(this)));blockedArrayFormulas=new fV({});spreadingRelations=new vV;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=qk(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||CV}getSpreadZone(e,t={ignoreSpillError:!1}){const o=this.spreadingRelations.getArrayResultZone(e);if(!o)return;const s=this.evaluatedCells.get(e);return s?.type!==_s.error||t.ignoreSpillError&&s?.value===ti.SpilledBlocked?yr(Mr(e),o):Mr(e)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(this.getEvaluatedCell(e).type===_s.empty)return;const t=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,Mr(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=qk(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.updateDependencies=this.updateDependencies.bind(this),this.compilationParams.evalContext.addDependencies=this.addDependencies.bind(this),this.compilationParams.evalContext.lookupCaches={forwardSearch:new Map,reverseSearch:new Map}}createEmptyPositionSet(){const e={};for(const t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new fV(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=Dr(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 vV,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 pV(this.createEmptyPositionSet.bind(this),e)}))}evaluateAllCells(){const e=performance.now();this.evaluatedCells=new $D,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=xV(t,this.compilationParams,e,this.buildSafeGetSymbolValue(o),this.compilationParams.evalContext.__originCellPosition);return js(s)?ki(s,IV):IV(s)}catch(e){return TS(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 fV({});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!==CV&&this.evaluatedCells.set(o,s)}Gk.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 CV;const s=o.id,i={format:o.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(s)?SV:(this.cellsBeingComputed.add(s),o.isFormula?this.computeFormulaCell(e,o):Xn(o,i))}catch(e){return e.value=e?.value||ti.GenericError,e.message=e?.message||DS,Jn(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=xV(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!js(o)){const s=Jn(IV(o),this.getters.getLocale(),t);return s.type===_s.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),wV(s,i,this.checkCollision(e)),wV(s,i,this.spreadValues(e,o)),this.invalidatePositionsDependingOnSpread(e.sheetId,n),Jn(IV(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===Lr(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 ci(Ho("Result couldn't be automatically expanded. Please insert more rows."));if(a)throw new ci(Ho("Result couldn't be automatically expanded. Please insert more columns."));throw new ci(Ho("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 ci(Ho("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!==_s.empty)throw this.blockedArrayFormulas.add(e),new ci(Ho("Array result was not expanded because it would overwrite data in %s.",Po(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=Jn(IV(s[i][n]),this.getters.getLocale(),a);l.type===_s.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 SV;this.symbolsBeingComputed.add(t);try{const o=e?.(t);return o||new ii(Ho("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=Dr(e);for(const e in o)t.push(...o[e].map((t=>({sheetId:e,zone:t}))));return this.formulaDependencies().getCellsDependingOn(t)}}function wV(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 IV(e){return null===e.value||void 0===e.value?{...e,value:0}:e}function xV(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 EV=/"(#[0-9a-fA-F]{6})"/g;const RV={isValid:!0};const TV=new n;function AV(e,t){const o=t.model.getters.getPivotCellFromPosition(e),s=t.model.getters.getPivotIdFromPosition(e);if(!s||"HEADER"!==o.type)return;const i=t.model.getters.getPivotCoreDefinition(s),n=i.collapsedDomains?.[o.dimension]?[...i.collapsedDomains[o.dimension]]:[],r=n.findIndex((e=>mt(e,o.domain)));-1!==r?n.splice(r,1):n.push(o.domain);const a=i.collapsedDomains?{...i.collapsedDomains}:{COL:[],ROW:[]};a[o.dimension]=n,t.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...i,collapsedDomains:a}})}TV.add("data_validation_checkbox",((e,t)=>{if(e.isCellValidCheckbox(t)){const o=!!e.getEvaluatedCell(t).value;return{svg:o?jR:qR,hoverSvg:o?jR:ZR,priority:2,horizontalAlign:"center",size:17,margin:2,position:t,type:"data_validation_checkbox",onClick:(e,t)=>{const s=t.model.getters.getCell(e);if(t.model.getters.isReadonly()||!!s?.isFormula)return;const i=o?"FALSE":"TRUE";t.model.dispatch("UPDATE_CELL",{...e,content:i})}}}})),TV.add("data_validation_chip_icon",((e,t)=>{const o=e.getDataValidationChipStyle(t);if(o){const s=e.getCellComputedStyle(t);return{svg:GR(o),hoverSvg:WR(o),priority:10,horizontalAlign:"right",size:$a(s),margin:4,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_chip_icon"}}})),TV.add("data_validation_list_icon",((e,t)=>{if(!e.isReadonly()&&e.cellHasListDataValidationIcon(t)){const s=e.getCellComputedStyle(t);return{svg:(o=s,{name:"CARET_DOWN",width:512,height:512,paths:[{fillColor:o.textColor||N,path:"M120 195 h270 l-135 130"}]}),hoverSvg:zR(s),priority:2,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_list_icon"}}var o})),TV.add("filter_icon",((e,t)=>{if(e.isFilterHeader(t)){const o=e.isFilterActive(t),s=jt(e.getCellComputedStyle(t).fillColor||"#fff")<.45;return{type:"filter_icon",svg:XR(o,s,!1),hoverSvg:XR(o,s,!0),priority:3,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const o=t.getStore(jx),s=o.persistentCellPopover;s.isOpen&&s.col===e.col&&s.row===e.row&&"FilterMenu"===s.type?o.close():o.open(e,"FilterMenu")}}}})),TV.add("conditional_formatting",((e,t)=>{const o=e.getConditionalIcon(t);if(o){const s=e.getCellStyle(t);return{type:"conditional_formatting",svg:KR[o].svg,priority:1,horizontalAlign:"left",size:$a(s),margin:4,position:t}}})),TV.add("pivot_collapse",((e,t)=>{if(!e.isSpillPivotFormula(t))return;const o=e.getPivotCellFromPosition(t),s=e.getPivotIdFromPosition(t);if("HEADER"===o.type&&s&&o.domain.length){const i=e.getPivotCoreDefinition(s),n=e.isDashboard(),r="COL"===o.dimension?i.columns:i.rows,a=!n&&o.domain.length!==r.length,l=(i.collapsedDomains?.[o.dimension]??[]).some((e=>mt(e,o.domain))),c="ROW"===o.dimension?15*(o.domain.length-1):0;return{type:"pivot_collapse",priority:4,horizontalAlign:"left",size:a||!n&&"ROW"===o.dimension&&i.rows.length>1?12:0,margin:a?4+c:c,svg:a?YR(l,!1):void 0,hoverSvg:a?YR(l,!0):void 0,position:t,onClick:AV}}}));const DV="0.00%";function _V(e){return class extends e{getters;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t){super(e,t),this.getters=t.getters}markAsDirtyForEvaluation(){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.markAsDirtyForEvaluation?.()}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(e.aggregator&&o.length+s.length!==t.length){const o=this.getValuesToAggregate(e,t),s=Nc[e.aggregator];if(!s)return{value:0};try{return s([o],this.getters.getLocale())}catch(t){return TS(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}=NO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new ai:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}if(s.find((t=>t.nameWithGranularity===e))){const{rowDomain:o}=NO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new ai:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}return this.getPivotCellValueAndFormat(e,t)}));return js(n)?n[0][0]:n}getValuesToAggregate(e,t){const{rowDomain:o,colDomain:s}=NO(this,t),i=super.getExpandedTableStructure(),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}if(o.length===this.definition.rows.length&&s.length&&s.length<this.definition.columns.length){const t=this.getSubTreeMatchingDomain(i.getColTree(),s),r=this.treeToLeafDomains(t,s);for(const t of r)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=Gc(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[]}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:ti.NotAvailable,message:Ho('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 TS(e,"COMPUTE_MEASURE_DISPLAY_VALUE")}}asPercentOfGrandTotal(e,t){const o=this.getGrandTotal(t.id);return 0===o?{value:ti.DivisionByZero}:{value:this.measureValueToNumber(e)/o,format:DV}}asPercentOfRowTotal(e,t,o){const s=this.getRowTotal(t.id,o);return 0===s?{value:ti.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:DV}}asPercentOfColumnTotal(e,t,o){const s=this.getColumnTotal(t.id,o);return 0===s?{value:ti.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:DV}}asPercentOfParentRowTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=NO(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:DV}}asPercentOfParentColumnTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=NO(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:DV}}asPercentOfParentTotal(e,t,o,s){const{fieldNameWithGranularity:i}=s;if(!i)return e;if(!UO(i,o))return{value:""};const n=function(e,t,o){let{rowDomain:s,colDomain:i}=NO(e,o);if("row"===BO(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:DV}}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:ti.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}=NO(this,o),h=zO(c),d=zO(l),u=a[h]?.[d];return{value:u??"",format:"running_total"===i?e.format:DV}}asPercentOf(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!UO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r||"sameValue"===r&&0===a?{value:ti.DivisionByZero}:!r||"sameValue"===r&&!a?{value:""}:"sameValue"===r?{value:1,format:DV}:void 0===a?{value:ti.NullError}:{value:a/r,format:DV}}asDifferenceFrom(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!UO(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(!UO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r?{value:ti.DivisionByZero}:r&&"sameValue"!==r?void 0===a?{value:ti.NullError}:{value:(a-r)/r,format:DV}:{value:""}}asRank(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;if(!UO(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}=NO(this,o),h=zO(c),d=zO(l),u=a[h]?.[d];return{value:u??""}}computeRank(e,t,o){const s={},i=BO(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Vi(r));for(const a of r){const r=zO(kO(this,n,a[0].domain)),l=a.map((t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:kO(this,i,t.domain)}))).filter((e=>UO(t,e.rowDomain))),c=Object.groupBy(l,(e=>GO(e.rowDomain,t)));for(const e in c)c[e]=Nt(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=zO(kO(this,i,e.domain)),n=c[GO(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:kt(s)}computeRunningTotal(e,t,o){const s={},i=BO(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Vi(r));for(const a of r){const r=zO(kO(this,n,a[0].domain));s[r]={};const l={},c=a.map((t=>({...t,rowDomain:kO(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))}))).filter((e=>UO(t,e.rowDomain)));for(const e of c){const o=zO(e.rowDomain),i=WO(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=zO(o),n=WO(o,t),a=s[r][i]||0,c=l[n];s[r][i]=c?a/c:void 0}}return"row"===i?s:kt(s)}getGrandTotal(e){const t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){const o=NO(this,t).rowDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}getColumnTotal(e,t){const o=NO(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===PO||s===MO?function(e,t,o,s){const i=BO(e,o),n="row"===i?e.getExpandedTableStructure().getRowTree():e.getExpandedTableStructure().getColTree(),r=LO(kO(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 HO(t,o,a[Ze(c+(s===PO?-1:1),0,a.length-1)])}(this,t,o,s):HO(t,o,s);if(mt(i,t))return"sameValue";if(!i||!function(e,t){for(const o of t)if(void 0===e.definition.rows.find((e=>e.nameWithGranularity===o.field))&&void 0===e.definition.columns.find((e=>e.nameWithGranularity===o.field)))return!1;const{rowDomain:o,colDomain:s}=NO(e,t);return VO(o,e.getExpandedTableStructure().getRowTree())&&VO(s,e.getExpandedTableStructure().getColTree())}(this,i))throw new ai;const n=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(n)}getPivotValueCells(e){return this.getCollapsedTableStructure().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`)}getCollapsedTableStructure(){const e=super.getCollapsedTableStructure();return this.sortTableStructure(e),e}getExpandedTableStructure(){const e=super.getExpandedTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;const t=this.definition.sortedColumn.measure;Kc(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,((e,t)=>this._getPivotCellValueAndFormat(e,t)))}}}const OV=["ADD_PIVOT","UPDATE_PIVOT","REMOVE_PIVOT"];function FV(e){return OV.includes(e.type)}const PV=new n;PV.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=In(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=Ri(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=ps(s);e.current=i;const n=o.getLocale(),r=In(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?Xn(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 MV=new n,NV=/(\d+)$/,kV=/^(.*\D+)/,VV=/^(.*\D+)(\d+)$/;function LV(e,t,o){let s=[],i=!1;for(const n of t){n===e&&(i=!0);const t=void 0===n||n.isFormula?void 0:Xn(n,{locale:qs,format:n.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function HV(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 UV(e){if(e.length<2)return 1;const t=e.map((e=>Ri(e,qs))),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=Yo.fromTimestamp(e[o-1].getTime()),i=ws(s,t),n=Cs(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+n);return{years:i,months:n,days:ys(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}}MV.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&On(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&Xn(e,{locale:qs}).type===_s.text&&VV.test(e.content),generateRule:(e,t,o)=>{const s=parseInt(e.content.match(NV)[0]),i=e.content.match(kV)[0],n=e.content.length-i.length,r=LV(e,t,(e=>e.type===_s.text&&VV.test(e.value))).filter((e=>i===(e.value??"").toString().match(kV)[0])).map((e=>parseInt((e.value??"").toString().match(NV)[0])));let a=HV(r);return["up","left"].includes(o)&&1===r.length&&(a=-a),{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:i,current:s,increment:a,numberPostfixLength:n}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&Xn(e,{locale:qs}).type===_s.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&&Xn(e,{locale:qs}).type===_s.number&&!!e.format&&On(e.format),generateRule:(e,t)=>{const o=UV(LV(e,t,(e=>e.type===_s.number&&!!e.format&&On(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=Xn(e,{locale:qs});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===_s.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===_s.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&Xn(e,{locale:qs}).type===_s.number,generateRule:(e,t,o)=>{const s=LV(e,t,(e=>e.type===_s.number&&!On(e.format||""))).map((e=>Number(e.value)));let i=HV(s);["up","left"].includes(o)&&1===s.length&&(i=-i);const n=Xn(e,{locale:qs});return{type:"INCREMENT_MODIFIER",increment:i,current:n.type===_s.number?n.value:0}},sequence:40});class BV extends Mk{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 zV{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}=PV.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}}}}const $V=new class extends n{addTransformation(e,t,o){this.content[e]||(this.content[e]=new Map);for(const s of t)this.content[e].set(s,o);return this}getTransformation(e,t){return this.content[t]&&this.content[t].get(e)}};const GV=new class extends n{add(e,t){return super.add(e,t),this}replace(e,t){return super.replace(e,t),this}get(e){return this.content[e]}};function WV(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId!==t.sheetId)return e;const o=th(e.pivot.dataSet.zone,t),s=o?{...e.pivot.dataSet,zone:o}:void 0;return{...e,pivot:{...e.pivot,dataSet:s}}}function qV(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(const 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 ZV(e,t){if(e.sheetId!==t.sheetId)return e;const o=th(e.zone,t);if(!o)return;const s=e.newTableRange?oh(e.newTableRange,t):void 0;return{...e,newTableRange:s,zone:o}}function jV(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let o;if("REMOVE_COLUMNS_ROWS"===t.type)o=ha(t.elements,[e.base])[0];else if("ADD_COLUMNS_ROWS"===t.type){o=ca(pt(t.position,t.base),t.quantity,[e.base])[0]}return void 0!==o?{...e,base:o}:void 0}function YV(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;const o=je(e.start,e.end+1);let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=ha(t.elements,o);else if("ADD_COLUMNS_ROWS"===t.type){s=ca(pt(t.position,t.base),t.quantity,o)}return 0!==s.length?{...e,start:Math.min(...s),end:Math.max(...s)}:void 0}function XV(e,t){return(e=ze(e)).pivot.measures.map((e=>{e.computedBy&&(e.computedBy.formula=WS(e.computedBy.sheetId,e.computedBy.formula,t))})),e}function KV(e,t){return{...e,definition:hx(e.sheetId,e.definition,t)}}$V.addTransformation("ADD_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],jV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],jV),$V.addTransformation("DELETE_SHEET",["MOVE_RANGES"],(function(e,t){const o=t.sheetId;if(e.targetSheetId===o||e.sheetId===o)return;return e})),$V.addTransformation("DELETE_FIGURE",["UPDATE_FIGURE","UPDATE_CHART"],(function(e,t){if(e.figureId===t.figureId)return;return e})),$V.addTransformation("CREATE_SHEET",["CREATE_SHEET"],(function(e,t){e.sheetId===t.sheetId&&(e={...e,sheetId:`${e.sheetId}~`});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})),$V.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)t.target.every((e=>!xr(s,e)))&&o.push(s);if(o.length)return{...e,target:o};return})),$V.addTransformation("ADD_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],qV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],qV),$V.addTransformation("ADD_COLUMNS_ROWS",["UPDATE_TABLE"],ZV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["UPDATE_TABLE"],ZV),$V.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:wR.styleId}}})),$V.addTransformation("ADD_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],YV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],YV),$V.addTransformation("REMOVE_PIVOT",["RENAME_PIVOT","DUPLICATE_PIVOT","INSERT_PIVOT","UPDATE_PIVOT"],(function(e,t){if(e.pivotId===t.pivotId)return;return e})),$V.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})),$V.addTransformation("ADD_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],WV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],WV),GV.add("UPDATE_CELL",(function(e,t){const o=e.content&&WS(e.sheetId,e.content,t);return{...e,content:o}})),GV.add("ADD_CONDITIONAL_FORMAT",(function(e,t){const o=e.cf.rule;if(e={...e,cf:{...e.cf}},"CellIsRule"===o.type)e.cf.rule={...o,values:o.values.map((o=>WS(e.sheetId,o,t)))};else if("ColorScaleRule"===o.type){const{minimum:s,maximum:i,midpoint:n}=o;e.cf.rule={...o,minimum:{...s,value:s.value&&WS(e.sheetId,s.value,t)},maximum:{...i,value:i.value&&WS(e.sheetId,i.value,t)},midpoint:n?{...n,value:WS(e.sheetId,n.value,t)}:void 0}}else if("IconSetRule"===o.type){const{upperInflectionPoint:s,lowerInflectionPoint:i}=o;e.cf.rule={...o,upperInflectionPoint:{...s,value:WS(e.sheetId,s.value,t)},lowerInflectionPoint:{...i,value:WS(e.sheetId,i.value,t)}}}else"DataBarRule"===o.type&&(e.cf.rule={...o,rangeValues:o.rangeValues?qS(e.sheetId,o.rangeValues,t):void 0});return e})),GV.add("ADD_DATA_VALIDATION_RULE",(function(e,t){return(e={...e,rule:{...e.rule,criterion:{...e.rule.criterion}}}).rule.criterion.values=e.rule.criterion.values.map((o=>WS(e.sheetId,o,t))),e})),GV.add("ADD_PIVOT",XV),GV.add("UPDATE_PIVOT",XV),GV.add("CREATE_CHART",KV),GV.add("UPDATE_CHART",KV);const JV=[{match:function(e){return"sheetId"in e},fn:tL},{match:function(e){return"target"in e&&"sheetId"in e},fn:function(e,t){const o=tL(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=[];for(const o of e.target){const e=th(o,t);e&&s.push(e)}if(!s.length)return"IGNORE_COMMAND";return{...e,target:s}}},{match:function(e){return"sheetId"in e&&"zone"in e},fn:function(e,t){const o=tL(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=th(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=tL(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(const 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)&&Er(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=tL(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=ha(t.elements,e.elements);else if("ADD_COLUMNS_ROWS"===t.type){s=ca(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=>oh(e,t))).filter(lt);if(!o.length)return"IGNORE_COMMAND";return{...e,ranges:o}}}];function QV(e,t){const o=$V.getTransformation(e.type,t.type),s=o?o(e,t):function(e,t){for(const{match:o,fn:s}of JV)if(o(e)){const o=s(e,t);if("SKIP_TRANSFORMATION"===o)continue;if("IGNORE_COMMAND"===o)return;e=o}return e}(e,t);return s?function(e,t){const o=GV.get(e.type);if(!o)return e;const s=Ia(t);if(s)return o(e,s);return e}(s,t):s}function eL(e,t){let o=[...e];const s=new Set($V.getKeys());for(const e of t)(s.has(e.type)||xa.contains(e.type))&&(o=o.reduce(((t,o)=>{const s=QV(o,e);return s&&t.push(s),t}),[]));return o}function tL(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 oL{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 sL extends Error{}class iL extends sh{revisions;transportService;serverRevisionId;clients={};clientId="local";debouncedMove;pendingMessages=[];awaitingClientPosition;waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new Ka;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 oL(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)),this.awaitingClientPosition&&(this._move(this.awaitingClientPosition),this.awaitingClientPosition=void 0)}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})}getCurrentClient(){return this.getClient(this.clientId)}getClient(e){const t=this.clients[e];if(!t)throw new sL("The client left the session");return t}getConnectedClients(){return new Set(Object.values(this.clients).filter(lt))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return 0===this.pendingMessages.length}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return void(this.awaitingClientPosition=e);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.getCurrentClient();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 oL(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:eL(o,t)})}break;case"SNAPSHOT_CREATED":{const t=new oL(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){let t=this.revisions.get(e.nextRevisionId);0===t.commands.length&&(this.revisions.rebase(t.id),t=this.revisions.get(e.nextRevisionId)),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"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();break;case"REVISION_UNDONE":{this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId));const t=this.pendingMessages.findIndex((e=>"REMOTE_REVISION"===e.type));-1!==t&&this.revisions.rebase(this.pendingMessages[t].nextRevisionId),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.sendPendingMessage();break}}}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 nL=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 rL(e){return nL.has(e.type)}const aL=[lL,function(e,t){return"target"in t&&Array.isArray(t.target)?{...ze(t),target:e.getSelectedZones()}:t},hL,function(e,t){return"ranges"in t?{...ze(t),ranges:e.getSelectedZones().map((t=>e.getRangeDataFromZone(e.getActiveSheetId(),t)))}:t}];function lL(e,t){return"sheetId"in t?{...ze(t),sheetId:e.getActiveSheetId()}:t}function cL(e,t){return"zone"in t?{...ze(t),zone:e.getSelectedZone()}:t}function hL(e,t){if(!("row"in t)||!("col"in t))return t;const{col:o,row:s}=e.getActivePosition();return{...ze(t),col:o,row:s}}const dL=new Ka;function uL(e,t){const o=e.getSelectedZone();return{...lL(e,t),elements:"COL"===t.dimension?je(o.left,o.right+1):je(o.top,o.bottom+1)}}function gL(e,t){const o=e.getSelectedZone();return{...ze(t),zone:o}}function pL(e,t){const o=ze(t),s=e.getSelectedZone(),{top:i,bottom:n,left:r,right:a}=s;return"cols"in o?o.cols=je(r,a+1):"rows"in o&&(o.rows=je(i,n+1)),o}function mL(e,t){const o=e.getSelectedZone();return{...lL(e,t),start:"COL"===t.dimension?o.left:o.top,end:"COL"===t.dimension?o.right:o.bottom}}const fL=new n;fL.add("UPDATE_CELL",bL),fL.add("CLEAR_CELL",bL),fL.add("CLEAR_CELLS",bL),fL.add("DELETE_CONTENT",bL),fL.add("ADD_MERGE",bL),fL.add("REMOVE_MERGE",bL),fL.add("SET_FORMATTING",bL),fL.add("CLEAR_FORMATTING",bL),fL.add("SET_BORDER",bL),fL.add("CREATE_TABLE",bL),fL.add("REMOVE_TABLE",bL),fL.add("HIDE_SHEET",bL),fL.add("ADD_COLUMNS_ROWS",(function(e,t){const o=e.getActivePosition();return{...lL(e,t),base:"COL"===t.dimension?o.col:o.row}})),fL.add("REMOVE_COLUMNS_ROWS",uL),fL.add("HIDE_COLUMNS_ROWS",uL),fL.add("RESIZE_COLUMNS_ROWS",uL),fL.add("CREATE_SHEET",(function(e,t){const o=ze(t);o.sheetId=dL.smallUuid();const s=t.name||e.getSheet(e.getActiveSheetId()).name,i=s.match(/(.+?)\d*$/)?.[1]||s;return o.name=e.getNextSheetName(i),o})),fL.add("CREATE_FIGURE",(function(e,t){const o=hL(e,lL(e,t));return o.figureId=dL.smallUuid(),o})),fL.add("CREATE_CHART",(function(e,t){return{...lL(e,t),figureId:dL.smallUuid()}})),fL.add("CREATE_IMAGE",(function(e,t){return{...lL(e,t),figureId:dL.smallUuid()}})),fL.add("GROUP_HEADERS",mL),fL.add("UNGROUP_HEADERS",mL),fL.add("UNFOLD_HEADER_GROUPS_IN_ZONE",cL),fL.add("FOLD_HEADER_GROUPS_IN_ZONE",cL);const vL=new n;function bL(e,t){let o=ze(t);for(const t of aL)o=t(e,o);return o}function SL(e,t){if(e.rootCommand&&"object"==typeof e.rootCommand)return Hs(e.rootCommand)?function(e,t){if(!t)return;if(!fL.contains(t.type))return;return fL.get(t.type)(e,t)}(t,e.rootCommand):function(e,t,o){if(!vL.contains(t.type))return;return vL.get(t.type)(e,t,o)}(t,e.rootCommand,e.commands)}vL.add("PASTE",(function(e,t){return{type:"REPEAT_PASTE",pasteOption:ze(t.pasteOption),target:e.getSelectedZones()}})),vL.add("INSERT_CELL",gL),vL.add("DELETE_CELL",gL),vL.add("AUTORESIZE_COLUMNS",pL),vL.add("AUTORESIZE_ROWS",pL),vL.add("SORT_CELLS",(function(e,t){const o=e.getSelectedZone();return{...lL(e,t),col:o.left,row:o.top,zone:o}})),vL.add("SUM_SELECTION",bL),vL.add("SET_DECIMAL",bL),vL.add("DELETE_UNFILTERED_CONTENT",bL);class CL{trackedValues=new Set;domainToArray(e){return e.flatMap((e=>[e.field,wi(e.value)]))}isValuePresent(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});return this.trackedValues.has(o)}isHeaderPresent(e){const t=JSON.stringify({domain:this.domainToArray(e)});return this.trackedValues.has(t)}trackValue(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});this.trackedValues.add(o)}trackHeader(e){const t=JSON.stringify({domain:this.domainToArray(e)});this.trackedValues.add(t)}}const yL=5242880;const wL={filterType:"criterion",type:"none",values:[]};class IL{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}=this.getters.getColDimensions(this.sheetId,e),{end:s}=this.getters.getRowDimensions(this.sheetId,t);let i=o-this.offsetCorrectionX;this.canScrollHorizontally&&(i=Math.max(i,this.viewportWidth));let n=s-this.offsetCorrectionY;return this.canScrollVertically&&(n=Math.max(n,this.viewportHeight),s+he>n&&!this.getters.isReadonly()&&(n+=he)),{width:i,height:n}}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);Er(s,this.boundaries.top,this.boundaries)&&this.adjustPositionX(s),Er(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=wr(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=wr(e,this.boundaries),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 xL=(new n).add("settings",class extends Nk{static getters=["getLocale"];locale=qs;allowDispatch(e){return"UPDATE_LOCALE"===e.type?El(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===Hl(e)&&(o=Hl(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??qs}export(e){e.settings={locale:this.locale}}}).add("sheet",class extends Nk{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","getDuplicateSheetName"];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"DUPLICATE_SHEET":return this.sheets[e.sheetIdTo]?"DuplicatedSheetId":this.orderedSheetIds.map(this.getSheetName.bind(this)).includes(e.sheetNameTo)?"DuplicatedSheetName":"Success";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||Wt(e.color)?"Success":"InvalidColor";case"DELETE_SHEET":return this.getVisibleSheetIds().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=Pt(e.elements),o=Ft(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.newName);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,e.sheetNameTo);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(const t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(const 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:la(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(lt).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=$e(e);for(const e in this.sheetIdsMapName)if(ga(e,t))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(lt)}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 da(this.orderedSheetIds.map(this.getSheetName.bind(this)),e)}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,je(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&&void 0!==e.col&&"row"in e&&void 0!==e.row&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(pr))return"InvalidRange";if(t.length){const o=this.getSheetZone(e);return t.every((e=>Rr(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:la(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),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("There is not enough visible sheets")}checkSheetName(e){const t=this.getters.tryGetSheetName(e.sheetId),o="RENAME_SHEET"===e.type?e.newName:e.name;if(void 0!==t&&o===t)return"UnchangedSheetName";const{orderedSheetIds:s,sheets:i}=this,n=o&&o.trim().toLowerCase();return s.find((t=>ga(i[t]?.name,n)&&t!==e.sheetId))?"DuplicatedSheetName":_e.test(n)?"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(const 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(const o of t)if(o.left<e.quantity&&e.quantity<=o.right)return"MergeOverlap";return"Success"}isRenameAllowed(e){return e.newName&&e.newName.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,o){const s=ze(this.getSheet(e));s.id=t,s.name=o;for(let e=0;e<=s.numberOfCols;e++)for(let t=0;t<=s.rows.length;t++)s.rows[t]&&(s.rows[t].cells[e]=void 0);const i=this.orderedSheetIds.slice(),n=i.indexOf(e);i.splice(n+1,0,s.id),this.history.update("orderedSheetIds",i),this.history.update("sheets",Object.assign({},this.sheets,{[s.id]:s}));for(const t of Object.values(this.getters.getCells(e))){const{col:e,row:o}=this.getCellPosition(t.id);this.dispatch("UPDATE_CELL",{sheetId:s.id,col:e,row:o,content:t.content,format:t.format,style:t.style})}const r=Object.assign({},this.sheetIdsMapName);r[s.name]=s.id,this.history.update("sheetIdsMapName",r)}getDuplicateSheetName(e){return ua(e,this.orderedSheetIds.map(this.getSheetName.bind(this)))}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(const 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(const o of Ye(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(const 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(const 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(const 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(const 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(const 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(Fo);let o=e.rowNumber,s=e.colNumber;for(const{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?"ranges"in e&&e.ranges.some((e=>""!==e._sheetId&&!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkZonesExistInSheet(e.sheetId,this.getCommandZones(e)):"Success"}}).add("header grouping",class extends Nk{static getters=["getHeaderGroups","getGroupsLayers","getVisibleGroupLayers","getHeaderGroup","getHeaderGroupsInZone","isGroupFolded","isRowFolded","isColFolded"];groups={};allowDispatch(e){switch(e.type){case"GROUP_HEADERS":{const{start:t,end:o,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";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,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";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":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return"UnknownHeaderGroup";if(je(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=ze(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;je(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]=ca(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=ha(o,je(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=MT(t,e,i);n.outlineLevel=s+1,o.isFolded&&(n.isHidden=!0)}if(o.isFolded){MT(t,e,o.end+1).collapsed=!0}}}}}}).add("header visibility",class extends Nk{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":Pt(e.elements)<0||Ft(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,ze(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(const 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(const t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!0);break;case"UNHIDE_COLUMNS_ROWS":for(const 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=je(0,this.getters.getNumberHeaders(e,t)),s=[];return this.getters.getHeaderGroups(e,t).forEach((e=>{e.isFolded&&s.push(...je(e.start,e.end+1))})),o.filter((o=>!this.hiddenHeaders[e][t][o]&&!s.includes(o)))}import(e){for(const 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(const 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 Nk{static getters=["getCoreTable","getCoreTables","getCoreTableMatchingTopLeft"];tables={};nextTableId=1;adaptRanges(e,t){for(const o of this.getCoreTables(t))this.applyRangeChangeOnTable(t,o,e)}allowDispatch(e){switch(e.type){case"CREATE_TABLE":if(e.ranges.some((t=>!this.getters.tryGetSheet(t._sheetId)||t._sheetId!==e.sheetId)))return"InvalidSheetId";const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone));return Ur(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(xr(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);s.length&&this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:s});const i=this.consumeNextId(),n=e.config||wR,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=>!wr(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=>Rr(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(lt):[]}getCoreTable({sheetId:e,col:t,row:o}){return this.getCoreTables(e).find((e=>Er(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter((e=>t.some((t=>xr(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(let e=a.top;e<=a.bottom;e++)for(let o=a.left;o<=a.right;o++){const s={sheetId:t,col:o,row:e},i=this.getters.getCell(s)?.content;if(i||this.getters.isInMerge(s)||this.getTablesOverlappingZones(t,[Mr(s)]).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 je(n.left,n.right+1)){const t={...n,left:e,right:e},r=this.consumeNextId();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=Nr(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 je(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||this.consumeNextId();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,Nr(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 C_(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 C_(o.id,s,t.config,this.getters.getRangeFromZone)}));return{id:t.id,range:o,filters:s,config:ze(t.config),type:t.type}}copyDynamicTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:o,config:ze(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=C_(e.id,o,t.config,this.getters.getRangeFromZone);n.push(i)}}const r=i.zone;if(n.length<Tr(r).numberOfCols){for(let o=r.left;o<=r.right;o++)if(!n.find((e=>e.col===o))){const s=this.consumeNextId(),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)}consumeNextId(){const e=`${this.nextTableId}`;return this.history.update("nextTableId",this.nextTableId+1),e}import(e){for(const t of e.sheets)for(const e of t.tables||[]){const o=this.consumeNextId(),s=e.config||wR,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:fr(e.range.zone),type:e.type};mt(e.config,wR)||(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=fr(e.range.zone);t.tables.push({range:o,filters:[],config:e.config})}}}).add("dataValidation",class extends Nk{static getters=["cellHasListDataValidationIcon","getDataValidationRule","getDataValidationRules","getValidationRuleForCell"];rules={};adaptRanges(e,t){this.adaptDVRanges(t,e),this.adaptDVFormulas(e)}adaptDVFormulas(e){for(const t in this.rules){for(let o=this.rules[t].length-1;o>=0;o--){const s=this.rules[t][o];for(let i=0;i<s.criterion.values.length;i++){const n=this.getters.adaptFormulaStringDependencies(t,s.criterion.values[i],e);this.history.update("rules",t,o,"criterion","values",i,n)}}}}adaptDVRanges(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.getters.tryGetSheet(e.sheetId)?e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkValidations(e,this.chainValidations(this.checkEmptyRange,this.checkValidRange,this.checkCriterionTypeIsValid,this.checkCriterionHasValidNumberOfValues,this.checkCriterionValuesAreValid)):"InvalidSheetId";case"REMOVE_DATA_VALIDATION_RULE":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";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=ze(this.rules[e.sheetId]).map((t=>({...t,ranges:t.ranges.map((t=>Ca(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=nr(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,Po(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(Er(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&&"chip"!==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,t.id),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,s){o=ze(o);for(const e of o)e.id!==s&&(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 wa(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={...ze(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 eE.contains(e.rule.criterion.type)?"Success":"UnknownDataValidationCriterionType"}checkCriterionHasValidNumberOfValues(e){const t=e.rule.criterion,o=eE.get(t.type).numberOfValues(t);return void 0!==o&&t.values.length!==o?"InvalidNumberOfCriterionValues":"Success"}checkCriterionValuesAreValid(e){const t=e.rule.criterion,o=eE.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 Nk{static getters=["zoneToXC","getCells","getTranslatedCellFormula","getCellStyle","getCellById","getFormulaString","getFormulaMovedInSheet"];nextId=1;cells={};adaptRanges(e,t,o){for(const s of Object.keys(this.cells))for(const i of Object.values(this.cells[s]||{}))if(i.isFormula)for(const n of i.compiledFormula.dependencies)if(n.sheetId===t||n.invalidSheetName===o.old){const t=e(n);"NONE"!==t.changeType&&this.history.update("cells",s,i.id,"compiledFormula","dependencies",i.compiledFormula.dependencies.indexOf(n),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);case"UPDATE_CELL_POSITION":return!e.cellId||this.cells[e.sheetId]?.[e.cellId]?"Success":"InvalidCellId";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);break;case"DELETE_SHEET":this.history.update("cells",e.sheetId,void 0)}}clearZones(e,t){for(const o of nr(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(const s of nr(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(const o of nr(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=je(e.base,e.base+e.quantity),s=e.base+e.quantity):(o=je(e.base+1,e.base+e.quantity+1),s=e.base),t(e.sheetId,s,o)}import(e){for(const t of e.sheets){const o=t.id,s=new $D;for(const e in t.cells)if(t.cells[e]){const{col:o,row:i}=Fo(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 qr(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(const 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=Po(s.col,s.row),l=this.removeDefaultStyleValues(r.style);if(Object.keys(l).length){const o=Gr(l,t);e[o]??=[],e[o].push(s)}if(r.format){const e=Gr(r.format,o);i[e]??=[],i[e].push(s)}r.content&&(n[a]=r.content)}s.styles=Wr(e),s.formats=Wr(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||[])jn(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(US(s).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),t,o,e);return this.getFormulaString(e,s,i)}getFormulaMovedInSheet(e,t,o){const s=US(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=Po((t=this.getters.expandZone(e,t)).left,t.top,o[0]),i=Po(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(const s of nr(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(const 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(const 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?It(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=Kn(t,i);return Yn(o=o||("number"==typeof n?Nn(t,i)||kn(t):void 0))||gi(t)||(t=wi(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 kk(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 Er(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 Nk{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(lt))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){this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map((t=>this.getMergeById(e,parseInt(t,10)))).filter(lt)}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(lt)}getSelectionRangeString(e,t){const o=this.getters.expandZone(e.sheetId,e.zone),s=pa({...e,zone:{...o,bottom:va(e)?void 0:o.bottom,right:ba(e)?void 0:o.right}},this.getters.getSheetSize),i=this.getters.getRangeString(s,t);if(this.isSingleCellOrMerge(e.sheetId,e.zone)){const{sheetName:e,xc:t}=ra(i);return aa(e,t.split(":")[0])}return i}doesIntersectMerge(e,t){for(const o of this.getMerges(e))if(xr(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){const{left:o,right:s,top:i,bottom:n}=t;let r={left:o,right:s,top:i,bottom:n};for(const t in this.merges[e]){const o=this.getMergeById(e,parseInt(t));o&&xr(o,r)&&(r=yr(o,r))}return Ir(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)&&Ir(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(const e of o)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(const 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 Ir(t,o);const{numberOfCols:s,numberOfRows:i}=Tr(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=Ze(s,0,this.getters.getNumberCols(e)-1),n=Ze(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?Uk(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&&xr(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);return Hr(t,o,s)?"FrozenPaneOverlap":"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||!Ir(e,i))return"InvalidTarget"}return"Success"}addMerge(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=Ze(s,0,this.getters.getNumberCols(e)-1),n=Ze(n,0,this.getters.getNumberRows(e)-1);if(Po(o,i)===Po(s,n))return;const r=this.getters.getCell({sheetId:e,col:o,row:i}),a=this.nextId++;this.history.update("merges",e,a,this.getters.getRangeFromSheetXC(e,fr({left:o,top:i,right:s,bottom:n})));const 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(const 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&&Ir(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}=Tr(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 _r(t))this.history.update("mergeCellMap",e,o,s,t.id)}import(e){const t=e.sheets||[];for(const 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(const o of t)this.addMerge(e,ur(o))}export(e){for(const t of e.sheets){const e=this.merges[t.id];e&&t.merges.push(...Hk(e))}}exportForExcel(e){this.export(e)}}).add("headerSize",class extends Nk{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,ze(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=Rt(this.sizes[e.sheetId][e.dimension],e.elements);this.history.update("sizes",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=[...this.sizes[e.sheetId][e.dimension]],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]||se)}getUserRowSize(e,t){const o=this.sizes[e]?.ROW[t];return o?Math.round(o):void 0}import(e){for(const t of e.sheets){const e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(const[o,s]of Object.entries(t.rows))s.size&&(e.ROW[o]=s.size);for(const[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(const o of e.sheets){void 0===o.rows&&(o.rows={});for(const e of je(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)??ie});void 0===o.cols&&(o.cols={});for(const e of je(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 Nk{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=>ze(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_BORDERS_ON_TARGET":for(const t of e.target)for(let o=t.top;o<=t.bottom;o++)for(let s=t.left;s<=t.right;s++)this.setBorder(e.sheetId,s,o,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 Ye(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?ze(s):null}getBordersColors(e){const t=[],o=this.borders[e];if(o)for(const e of o.filter(lt))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=je(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(const o of s)this.addBorder(e,o,i,t)}}}ensureRowBorderContinuity(e,t,o){const s=je(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(const o of s)this.addBorder(e,i,o,t)}}}getCommonSides(e,t){const o={};for(const 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(lt);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]?je(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.borders[e]?.[t-1]?.[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.borders[e]?.[t]?.[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.borders[e]?.[t+1]?.[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.borders[e]?.[t]?.[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(const n of nr(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(const 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(const i of nr(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 qr(t.id,t.borders)){const{sheetId:t,col:i,row:n}=o,r=e.borders[s];this.setBorder(t,i,n,r,!1)}for(const t of e.sheets)if(t.merges)for(const e of t.merges)this.addBordersToMerge(t.id,ur(e))}export(e){const t={};for(const 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=Gr(n,t),a={sheetId:o.id,col:s,row:i};e[r]??=[],e[r].push(a)}}o.borders=Wr(e)}e.borders=t}exportForExcel(e){this.export(e)}}).add("conditional formatting",class extends Nk{static getters=["getConditionalFormats","getRulesSelection","getRulesByCell","getAdaptedCfRanges"];cfRules={};adaptCFFormulas(e){for(const t in this.cfRules)for(const o of this.cfRules[t])if("DataBarRule"===o.rule.type&&o.rule.rangeValues){const s=e(o.rule.rangeValues);switch(s.changeType){case"REMOVE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",void 0);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",s.range)}}else if("CellIsRule"===o.rule.type)for(let s=0;s<o.rule.values.length;s++)this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","values",s,this.getters.adaptFormulaStringDependencies(t,o.rule.values[s],e));else if("IconSetRule"===o.rule.type)for(const s of["lowerInflectionPoint","upperInflectionPoint"])"formula"===o.rule[s].type&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,o.rule[s].value,e));else if("ColorScaleRule"===o.rule.type)for(const s of["minimum","maximum","midpoint"]){const i=o.rule[s];"formula"===i?.type&&i?.value&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,i.value,e))}}adaptCFRanges(e,t){for(const o of this.cfRules[e])for(const s of o.ranges){const i=t(s);switch(i.changeType){case"REMOVE":const 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){const o=t?[t]:Object.keys(this.cfRules);for(const t of o)this.adaptCFRanges(t,e);this.adaptCFFormulas(e)}allowDispatch(e){switch(e.type){case"ADD_CONDITIONAL_FORMAT":return e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":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(const t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map((e=>this.mapToConditionalFormatInternal(t.id,e)))}export(e){if(e.sheets)for(const 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(const 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(const i of this.cfRules[e])for(const e of i.ranges)Er(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(dr));const a=nr(r,s);return nr([...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,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){const t=eE.get(e.operator).numberOfValues({type:e.operator,values:e.values});if(void 0===t||t>2)throw new Error("Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.");const o=[],s=e=>void 0===e||""===e;return t>=1&&s(e.values[0])&&o.push("FirstArgMissing"),t>=2&&s(e.values[1])&&o.push("SecondArgMissing"),o.length?o:"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&&Lk(t)>=Lk(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&&Lk(t)>=Lk(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&&Lk(t)>=Lk(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 Nk{static getters=["getFigures","getFigure","getFigureSheetId"];figures={};insertionOrders=[];adaptRanges(e,t){for(const o of this.getFigures(t)){const s=e(this.getters.getRangeFromZone(t,{left:o.col,right:o.col,top:o.row,bottom:o.row}));if("MOVE"===s.changeType)this.history.update("figures",t,o.id,"col",s.range.zone.right),this.history.update("figures",t,o.id,"row",s.range.zone.bottom);else if("REMOVE"===s.changeType){const s=e(this.getters.getRangeFromZone(t,{left:0,right:o.col-1,top:0,bottom:o.row-1}));let{offset:i,col:n,row:r}=o;"NONE"!==s.changeType&&(n=s.range.zone.right+1,r=s.range.zone.bottom+1),({offset:i,col:n,row:r}=this.getPositionInSheet(t,{...o,col:n,row:r})),this.history.update("figures",t,o.id,"offset",i),this.history.update("figures",t,o.id,"col",n),this.history.update("figures",t,o.id,"row",r)}}}allowDispatch(e){switch(e.type){case"CREATE_FIGURE":return this.checkValidations(e,this.checkFigureDuplicate,this.checkFigureAnchorOffset);case"UPDATE_FIGURE":return this.checkValidations(e,this.checkFigureExists,this.checkFigureAnchorOffset);case"DELETE_FIGURE":return this.checkFigureExists(e);default:return"Success"}}beforeHandle(e){if("DELETE_SHEET"===e.type)this.getters.getFigures(e.sheetId).forEach((t=>{this.dispatch("DELETE_FIGURE",{figureId: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":const t={id:e.figureId,col:e.col,row:e.row,offset:e.offset,width:e.size.width,height:e.size.height,tag:e.tag};this.addFigure(t,e.sheetId);break;case"UPDATE_FIGURE":this.updateFigure(e);break;case"DELETE_FIGURE":this.removeFigure(e.figureId,e.sheetId);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.onColRemove(e.sheetId):this.onRowRemove(e.sheetId)}}onColRemove(e){const t=this.getters.getNumberCols(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+this.getters.getColSize(e,s);for(const t of this.getFigures(e))if(t.offset.x+t.width>o[t.col]){let s=t.offset.x,i=t.col;for(s=Math.min(s,o[i]-t.width);s<0&&i>0;)i--,s=o[i]-t.width;s!==t.offset.x&&this.history.update("figures",e,t.id,"offset",{x:Math.max(s,0),y:t.offset.y}),i!==t.col&&this.history.update("figures",e,t.id,"col",i)}}onRowRemove(e){const t=this.getters.getNumberRows(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+(this.getters.getUserRowSize(e,s)??ie);for(const t of this.getFigures(e))if(t.offset.y+t.height>o[t.row]){let s=t.offset.y,i=t.row;for(let t=this.getters.getUserRowSize(e,i)??ie;t<s;t=this.getters.getUserRowSize(e,i)??ie)i+=1,s-=t;for(s=Math.min(s,o[i]-t.height);s<0&&i>0;)i--,s=o[i]-t.height;s!==t.offset.y&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(0,s)}),i!==t.row&&this.history.update("figures",e,t.id,"row",i)}else t.offset.y+t.height>o[0]&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(o[0]-t.height,0)})}getPositionInSheet(e,t){const{numberOfRows:o,numberOfCols:s}=this.getters.getSheetSize(e);let i,n,r=0,a=0,{col:l,row:c}=t;const h={...t.offset};for(i=o;r<t.height&&i>0;i--)r+=this.getters.getUserRowSize(e,i-1)??ie;for(c>i?(c=i,h.y=Math.max(r-t.height,0)):c===i&&(h.y=Ze(h.y,0,Math.max(r-t.height,0))),n=s;a<t.width&&n>0;n--)a+=this.getters.getColSize(e,n-1);return l>n?(l=n,h.x=Math.max(a-t.width,0)):n===l&&(h.x=Ze(h.x,0,Math.max(a-t.width,0))),{col:l,row:c,offset:h}}updateFigure(e){if(!("figureId"in e)||!("sheetId"in e))return;const{figureId:t,sheetId:o,...s}=e,i={...this.getFigure(o,t),...s};for(const[e,t]of Object.entries(s))switch(e){case"offset":this.history.update("figures",o,i.id,e,t);break;case"col":case"row":case"width":case"height":void 0!==t&&this.history.update("figures",o,i.id,e,t)}}addFigure(e,t){this.history.update("figures",t,e.id,e),this.history.update("insertionOrders",this.insertionOrders.length,e.id)}deleteSheet(e){this.history.update("insertionOrders",this.insertionOrders.filter((t=>!this.figures[e]?.[t]))),this.history.update("figures",e,void 0)}removeFigure(e,t){this.history.update("insertionOrders",this.insertionOrders.filter((t=>t!==e))),this.history.update("figures",t,e,void 0)}checkFigureExists(e){return void 0===this.figures[e.sheetId]?.[e.figureId]?"FigureDoesNotExist":"Success"}checkFigureDuplicate(e){return Object.values(this.figures).find((t=>t?.[e.figureId]))?"DuplicatedFigureId":"Success"}checkFigureAnchorOffset(e){return e.col<0||e.row<0||e.offset&&(e.offset.x<0||e.offset.y<0)?"WrongSheetPosition":"Success"}getFigures(e){const t=[];for(const o of this.insertionOrders){const s=this.figures[e]?.[o];s&&t.push(s)}return t}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(const t of e.sheets)for(const e of t.figures)this.addFigure(e,t.id)}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){return this.export(e)}}).add("chart",class extends Nk{static getters=["isChartDefined","getChartDefinition","getChartType","getChartIds","getChart","getContextCreationChart"];charts={};createChart=ax(this.getters);validateChartDefinition=e=>cx(this,e.definition);adaptRanges(e,t,o){for(const[s,i]of Object.entries(this.charts))this.history.update("charts",s,i?.updateRanges(e,t,o))}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,this.checkChartChanged));default:return"Success"}}handle(e){switch(e.type){case"CREATE_CHART":this.addFigure(e.figureId,e.sheetId,e.col,e.row,e.offset,e.size),this.addChart(e.figureId,e.definition);break;case"UPDATE_CHART":this.addChart(e.figureId,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",{figureId:s,col:o.col,row:o.row,offset:o.offset,size:{width:o.width,height:o.height},definition:i.getDefinition(),sheetId:e.sheetIdTo})}break}case"DELETE_FIGURE":this.history.update("charts",e.figureId,void 0);break;case"DELETE_SHEET":for(const 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(const t of e.sheets)if(t.figures)for(const 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(const t of e.sheets){const e=this.getters.getFigures(t.id),o=[];for(const 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,s,i,n={width:536,height:335}){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"chart"})}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.figureId)?"DuplicatedChartId":"Success"}checkChartExists(e){return this.isChartDefined(e.figureId)?"Success":"ChartDoesNotExist"}checkChartChanged(e){return mt(this.getChartDefinition(e.figureId),e.definition)?"NoChanges":"Success"}}).add("image",class extends Nk{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.addFigure(e.figureId,e.sheetId,e.col,e.row,e.offset,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,offset:o.offset,col:o.col,row:o.row,size:t,definition:ze(i)})}}break}case"DELETE_FIGURE":this.history.update("images",e.sheetId,e.figureId,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}addFigure(e,t,o,s,i,n){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"image"})}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:ze(e)})}t.images=[...t.images,...o]}}getAllImages(){const e=[];for(const t in this.images)e.push(...Object.values(this.images[t]||{}).filter(lt));return e}}).add("pivot_core",class extends Nk{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.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures);case"UPDATE_PIVOT":return e.pivotId in this.pivots?mt(e.pivot,this.pivots[e.pivotId]?.definition)?"NoChanges":""===e.pivot.name?"EmptyName":this.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures):"PivotIdNotFound";case"RENAME_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound";if(""===e.name)return"EmptyName";break;case"REMOVE_PIVOT":case"DUPLICATE_PIVOT":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 qN(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=ze(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",ze(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:ze(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:$c(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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(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})}}}checkSortedColumnInMeasures(e){const t=e.measures.map((e=>e.id));return e.sortedColumn&&!t.includes(e.sortedColumn.measure)?"InvalidDefinition":"Success"}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||kc(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 Nk{allowDispatch(e){switch(e.type){case"ADD_PIVOT":case"UPDATE_PIVOT":const t=e.pivot;return this.checkDataSetValidity(t)}return"Success"}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=zk(this.getters.getRangeFromZone(s,i),e),r=n&&{sheetId:n.sheetId,zone:n.zone};this.dispatch("UPDATE_PIVOT",{pivotId:t,pivot:{...o,dataSet:r}})}}}checkDataSetValidity(e){if("SPREADSHEET"===e.type&&e.dataSet){const{zone:t,sheetId:o}=e.dataSet;return o&&this.getters.tryGetSheet(o)&&t&&pr(t)?this.getters.checkZonesExistInSheet(o,[t]):"InvalidDataSet"}return"Success"}}).add("tableStyle",class extends Nk{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(!HR[e.templateName])return"InvalidTableStyle";try{Gt(e.primaryColor)}catch(e){return"InvalidTableStyle"}}return"Success"}handle(e){switch(e.type){case"CREATE_TABLE_STYLE":const t=UR(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:wR.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 Vt(Ho("Custom Table Style"),Object.values(this.styles).map((e=>e.displayName)),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!LR[e]}import(e){for(const e in LR)this.styles[e]=LR[e];for(const t in e.customTableStyles){const o=e.customTableStyles[t];this.styles[t]=UR(o.displayName,o.templateName,o.primaryColor)}}export(e){const t={};for(const e in this.styles)LR[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}}),EL=(new n).add("ui_sheet",class extends BV{static getters=["getCellWidth","getTextWidth","getCellText","getCellMultiLineText","getContiguousZone","computeTextYCoordinate"];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(const 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.autoResizeRows(e.sheetId,e.rows);break;case"DELETE_UNFILTERED_CONTENT":const t=[];for(const o of e.target){const s=Ye(je(o.top,o.bottom+1).filter((t=>!this.getters.isRowFiltered(e.sheetId,t))));for(const e of s)t.push({...o,top:e[0],bottom:e[e.length-1]})}this.dispatch("DELETE_CONTENT",{sheetId:e.sheetId,target:t})}}getCellWidth(e){const t=this.getters.getCellComputedStyle(e);let o=0;const s=this.getters.getEvaluatedCell(e).formattedValue;if(s){const e=Wa(this.ctx,s,t,void 0);o+=Math.max(...e.map((e=>Va(this.ctx,e,t))))}for(const t of this.getters.getCellIcons(e))o+=t.margin+t.size;if(this.getters.getDataValidationChipStyle(e)&&(o+=10),0===o)return 0;if(o+=2*le,"wrap"===t.wrapping){const t=this.getters.getColSize(this.getters.getActiveSheetId(),e.col);return Math.min(t,o)}return o}getTextWidth(e,t){return Va(this.ctx,e,t)}getCellText(e,t){const o=this.getters.getCell(e),s=this.getters.getLocale();if(t?.showFormula&&o?.isFormula)return Ol(o.content,s);if(t?.showFormula&&!o?.content)return"";{const i=this.getters.getEvaluatedCell(e),n=t?.availableWidth?{availableWidth:t.availableWidth,measureText:e=>Va(this.ctx,e,o?.style||{})}:void 0;return In(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 Wa(this.ctx,s,o,t.wrapText?t.maxWidth:void 0)}computeTextYCoordinate(e,t,o=ue,s=1){const i=e.y+1,n=Pa(t,s);if(e.height>n+2*re){if("middle"===o)return Math.ceil(i+(e.height-n)/2);if("bottom"===o)return i+e.height-n-re}return i+re}getContiguousZone(e,t){const o=t=>{for(const o of je(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 je(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);Ir(i,e)||(s=!0,i=e)}while(s);return i}isCellEmpty(e){const t=this.getters.getMainCellPosition(e);return this.getters.getEvaluatedCell(t).type===_s.empty}getColMaxWidth(e,t){const o=_r(this.getters.getColsZone(e,t,t)).map((t=>this.getCellWidth({sheetId:e,...t})));return Math.max(0,Ft(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();if("ranges"in e&&e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId))))return"InvalidSheetId";const o=this.getters.getCommandZones(e);return!t&&o.length>0?"NoActiveSheet":t&&o.length>0?this.getters.checkZonesExistInSheet(t,o):"Success"}autoResizeRows(e,t){const o=[];for(const s of t){let t=0;for(const o of this.getters.getRowCells(e,s)){const s=this.getters.getCellById(o);if(!s)continue;const i=this.getters.getCellPosition(s.id),n=this.getters.getColSize(e,i.col);if(s.isFormula||this.getters.getArrayFormulaSpreadingOn(i)){const e=this.getters.getEvaluatedCell(i).formattedValue,o=Ma(this.ctx,e,s?.style,n);o>t&&o>ie&&(t=o)}else{const e=s.content,o=Ma(this.ctx,e,s?.style,n);o>=t&&o>ie&&(t=0)}}o.push(t||null)}const s=new Map(o.map((e=>[e,[]])));for(let e=0;e<o.length;e++)s.get(o[e])?.push(t[e]);for(const[t,o]of s)this.dispatch("RESIZE_COLUMNS_ROWS",{elements:o,dimension:"ROW",size:t,sheetId:e})}}).add("ui_options",class extends BV{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 BV{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:Ze(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=-1===e.row?this.lastCellSelected.row:Ze(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()}}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,s=[];switch(this.direction){case"down":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.top;o<=t.bottom;o++)i.push(Po(e,o));const n=this.createGenerator(i);for(let t=o.top;t<=o.bottom;t++)s.push(this.computeNewCell(n,e,t))}break;case"up":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.bottom;o>=t.top;o--)i.push(Po(e,o));const n=this.createGenerator(i);for(let t=o.bottom;t>=o.top;t--)s.push(this.computeNewCell(n,e,t))}break;case"left":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.right;o>=t.left;o--)i.push(Po(o,e));const n=this.createGenerator(i);for(let t=o.right;t>=o.left;t--)s.push(this.computeNewCell(n,t,e))}break;case"right":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.left;o<=t.right;o++)i.push(Po(o,e));const n=this.createGenerator(i);for(let t=o.left;t<=o.right;t++)s.push(this.computeNewCell(n,t,e))}}if(e){const e={},t={},o={},i=this.getters.getActiveSheetId();for(const n of s)this.collectBordersData(n,e),this.autofillMerge(i,n),this.autofillCell(i,n),this.collectConditionalFormatsData(i,n,t),this.collectDataValidationsData(i,n,o);this.autofillBorders(i,e),this.autofillConditionalFormats(i,t),this.autofillDataValidations(i,o),this.autofillZone=void 0,this.selection.resizeAnchorZone(this.direction,this.steps),this.lastCellSelected={},this.direction=void 0,this.steps=0,this.tooltip=void 0}}collectBordersData(e,t){const o=JSON.stringify(e.border);o in t||(t[o]=[]),t[o].push(Mr({col:e.col,row:e.row}))}collectConditionalFormatsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a=this.getters.getRulesByCell(e,s,i),l=Po(n,r);for(const e of a)e.id in o||(o[e.id]=[]),o[e.id].push(l)}collectDataValidationsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a={sheetId:e,col:s,row:i},l=this.getters.getValidationRuleForCell(a);l&&(l.id in o||(o[l.id]=[]),o[l.id].push(Mr({col:n,row:r})))}autofillCell(e,t){this.dispatch("UPDATE_CELL",{sheetId:e,col:t.col,row:t.row,content:t.content||"",style:t.style||null,format:t.format||""}),this.dispatch("AUTOFILL_CELL",t)}autofillBorders(e,t){for(const o in t){const s="undefined"===o?void 0:JSON.parse(o);this.dispatch("SET_BORDERS_ON_TARGET",{sheetId:e,border:s,target:nr(t[o])})}}autofillConditionalFormats(e,t){for(const o in t){const s=t[o],i=this.getters.getConditionalFormats(e).find((e=>e.id===o));if(!i)continue;const n=this.getters.getAdaptedCfRanges(e,i,s.map(ur),[]);n&&this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:i.id,rule:i.rule,stopIfTrue:i.stopIfTrue},ranges:n,sheetId:e})}}autofillDataValidations(e,t){for(const o in t){const s=t[o],i=this.getters.getDataValidationRule(e,o);if(!i)continue;const n=i.ranges.map((e=>e.zone)),r=nr(n.concat(s),[]);this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:i,ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e})}}select(e,t){const o=this.getters.getSelectedZone();if(Er(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!==_s.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!==_s.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!==_s.empty;)s+=1,e={sheetId:t,col:o+1,row:s}}return s-1}computeNewCell(e,t,o){const{cellData:s,tooltip:i,origin:n}=e.next(),{content:r,style:a,border:l,format:c}=s;return this.tooltip=i,{originCol:n.col,originRow:n.row,col:t,row:o,content:r,style:a,border:l,format:c}}getRule(e,t){const o=MV.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((o=>o.condition(e,t)));return o&&this.direction&&o.generateRule(e,t,this.direction)}createGenerator(e){const t=[],o=[],s=this.getters.getActiveSheetId();for(const t of e){const{col:e,row:i}=Fo(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(const 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 zV(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){const{originCol:o,originRow:s,col:i,row:n}=t,r={sheetId:e,col:i,row:n},a={sheetId:e,col:o,row:s};if(this.getters.isInMerge(r)&&!this.getters.isInMerge(a)){const t=this.getters.getMerge(r);t&&this.dispatch("REMOVE_MERGE",{sheetId:e,target:[t]})}const l=this.getters.getMerge(a);l?.left===o&&l?.top===s&&this.dispatch("ADD_MERGE",{sheetId:e,target:[{top:n,bottom:n+l.bottom-l.top,left:i,right:i+l.right-l.left}]})}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 BV{allowDispatch(e){return"SORT_CELLS"===e.type?Er(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 _r(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=>xr(e,t))),s=Tr(o[0]),[i,n]=[s.numberOfCols,s.numberOfRows];return o.every((e=>{const[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 _r(t).some((({col:t,row:o})=>{const s=this.getters.getArrayFormulaSpreadingOn({sheetId:e,col:t,row:o});return s&&!mt(s,{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]===_s.empty&&(o=o.slice(1)),!o.some((e=>e[0]===_s.empty))&&!!o.some((e=>e[1]!==_s.empty&&e[0]!==e[1]))}sortZone(e,t,o,s,i){const[n,r]=this.mainCellsSteps(e,o),a=this.getters.getMainCellPosition({sheetId:e,col:t.col,row:t.row}).col,l=Object.assign({},o);let 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===_s.empty?{...e,type:_s.number,value:0}:e)):s).sort(jp(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++){const{col:o,row:s,sheetId:i}=c[e][d[t]],a=this.getters.getCell({sheetId:i,col:o,row:s}),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=je(t.left,t.right+1,o),r=je(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 BV{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}=Er(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)||Ar(yr(n,t))?[{position:{col:s,row:i},zone:n}]:this.sumDimensions(e,yr(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=je(o,-1,-1),n=Ft(i.filter((e=>s[e]&&!s[e].isAutoSummable))),r=Ye(i.filter((e=>this.isNumber(s[e]))))[0]||[];return Ft(r)<n?1/0:Pt(r)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===_s.number&&!(e.format&&On(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 Ar(t)?(o.add(1===Tr(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)},_r(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)},_r(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 BV{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 nr(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=nr(s.map(Mr));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:nr(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 nr(t))for(const t of _r(i)){const i=this.getCellNumberFormat({sheetId:e,...t});if(void 0!==i){const e=qn(i,o);s[e]=s[e]||[],s[e].push(t)}}for(const t in s){const o=nr(s[t].map((e=>Mr(e))));this.setContextualFormat(e,o,t)}}getCellNumberFormat(e){for(const t of[e]){const e=this.getters.getEvaluatedCell(t);if(!(e.type!==_s.number||e.format&&On(e.format)))return e.format||Mn(e.value)}}}).add("insert_pivot",class extends BV{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===Lr(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:Ho("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:Ho("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.getCollapsedTableStructure().export(),"dynamic")}duplicatePivotInNewSheet(e,t,o){this.dispatch("DUPLICATE_PIVOT",{pivotId:e,newPivotId:t,duplicatedPivotName:Ho("%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(Ho("%(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.getCollapsedTableStructure().export(),"dynamic")}}getPivotDuplicateSheetName(e){const t=this.getters.getSheetIds().map((e=>this.getters.getSheetName(e)));return Vt(qe(e),t)}insertPivotWithTable(e,t,o,s,i,n){const{cols:r,rows:a,measures:l,fieldsType:c}=i,h=new qN(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:{...Ve,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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(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:$c(n,t)});const a=this.getters.getCoreTable({sheetId:e,col:t,row:o});if("dynamic"===a?.type){const s=Mr({col:t,row:o}),n=this.getters.getRangeDataFromZone(e,i);this.dispatch("UPDATE_TABLE",{sheetId:e,zone:s,newTableRange:n,tableType:"static"})}}}).add("pivot_presence",class extends BV{static getters=["getPivotPresenceTracker"];trackPresencePivotId;tracker;handle(e){switch(e.type){case"PIVOT_START_PRESENCE_TRACKING":this.tracker=new CL,this.trackPresencePivotId=e.pivotId;break;case"PIVOT_STOP_PRESENCE_TRACKING":this.trackPresencePivotId=void 0}}getPivotPresenceTracker(e){if(this.trackPresencePivotId===e){if(!this.tracker)throw new Error("Tracker not initialized");return this.tracker}}}).add("split_to_columns",class extends BV{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===_s.text){const e=this.getAutoSeparatorForString(t.value);if(e)return e}return" "}getAutoSeparatorForString(e){const t=[Ne,";",","," ","."];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:Rl(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 je(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 je(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 je(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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(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 BV{static getters=["getClientsToDisplay","getClient","getCurrentClient","getConnectedClients","isFullySynchronized"];static layers=["Selection"];colors=new bo(12);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(e){return this.session.getClient(e)}getCurrentClient(){return this.session.getCurrentClient()}getConnectedClients(){return[...this.session.getConnectedClients()].map((e=>({...e,color:this.colors.get(e.id)})))}isFullySynchronized(){return this.session.isFullySynchronized()}getClientsToDisplay(){try{this.getters.getCurrentClient()}catch(e){if(e instanceof sL)return[];throw e}const e=this.getters.getActiveSheetId(),t=[];for(const o of this.getters.getConnectedClients())o.id!==this.getters.getCurrentClient().id&&o.position&&o.position.sheetId===e&&this.isPositionValid(o.position)&&t.push({...o,position:o.position});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 BV{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("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=SL(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)&&(Hs(t.rootCommand)?fL.contains(t.rootCommand.type):vL.contains(t.rootCommand.type));var t}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 BV{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===Tr(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 Jc(this.getters,this.dispatch),l=a.copy(Qa(o,r),!1);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 je(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:Ho("%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=nr(this.getters.getSelectedZones()),t=this.getters.getActiveSheetId();let o=0;for(const{col:s,row:i}of e.map(_r).flat()){const e=this.getters.getCell({col:s,row:i,sheetId:t});if(!e)continue;const n=Dt(e.content);n!==e.content&&(o+=1,this.dispatch("UPDATE_CELL",{sheetId:t,col:s,row:i,content:n}))}const s=o?Ho("Trimmed whitespace from %s cells.",o):Ho("No selected cells had whitespace trimmed.");this.ui.notifyUI({type:"info",text:s,sticky:!1})}}).add("table_autofill",class extends BV{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&&Er(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!==_s.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 BV{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 BV{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 wa(t)){const t=this.getters.getCell(e),o=this.getters.getEvaluatedCell(e);if(t?.content)if(t?.content&&o.type===_s.empty){let o;if(t.content.startsWith("=")){const s=this.getters.evaluateFormula(e.sheetId,t.content);o=(js(s)?s[0][0]:s)?.toString()}else o=t.content;o&&Ke(o)||this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}else o.type!==_s.boolean&&this.dispatch("UPDATE_CELL",{...e,content:"FALSE"});else this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}}}}).add("checkbox_toggle",class extends BV{static getters=["hasBooleanValidationInZones"];handle(e){if("TOGGLE_CHECKBOX"===e.type)this.toggleCheckbox(e.sheetId,e.target)}hasBooleanValidationInZones(e){const t=this.getters.getActiveSheetId();for(const o of e)for(let e=o.left;e<=o.right;e++)for(let s=o.top;s<=o.bottom;s++)if(this.getters.isCellValidCheckbox({col:e,row:s,sheetId:t}))return!0;return!1}toggleCheckbox(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++){const o={col:t,row:s,sheetId:e};if(this.getters.isCellValidCheckbox(o)){const e=this.getters.getEvaluatedCell(o).value?"FALSE":"TRUE";this.dispatch("UPDATE_CELL",{...o,content:e})}}}}).add("geo_features",class extends BV{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")}}),RL=(new n).add("selection",class extends BV{static layers=["Selection"];static getters=["getActiveSheet","getActiveSheetId","getActiveSheetName","getActiveCell","getActiveCols","getActiveRows","getCurrentStyle","getSelectedZones","getSelectedZone","getSelectedCells","getSelectedFigureId","getSelection","getActivePosition","getSheetPosition","isSingleColSelected","getElementsFromSelection","tryGetActiveSheetId","isGridSelectionActive","getSelectecUnboundedZone"];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;isUnbounded;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient,this.isUnbounded=!1}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(this.isUnbounded=e.options?.unbounded||!1,e.mode){case"overrideSelection":o=[t.zone];break;case"updateAnchor":o=[...this.gridSelection.zones];const s=o.findIndex((t=>Ir(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,ze(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.figureId&&(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.figureId;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:ze(t)}}this.fallbackToVisibleSheet();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.fallbackToVisibleSheet(),this.selection.resetDefaultAnchor(this,ze(this.gridSelection.anchor))}isGridSelectionActive(){return this.selection.isListening(this)}getActiveSheet(){return this.activeSheet}getActiveSheetId(){return this.activeSheet.id}getActiveSheetName(){return this.activeSheet.name}tryGetActiveSheetId(){return this.activeSheet?.id}getActiveCell(){return this.getters.getEvaluatedCell(this.getActivePosition())}getActiveCols(){const e=new Set;for(const 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(const 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 ze(this.gridSelection.zones)}getSelectedZone(){return ze(this.gridSelection.anchor.zone)}getSelectecUnboundedZone(){return ze(this.isUnbounded?this.getters.getUnboundedZone(this.activeSheet.id,this.gridSelection.anchor.zone):this.gridSelection.anchor.zone)}getSelection(){return ze(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:ze(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,ze(this.gridSelection.anchor));else{const{col:e,row:o}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,o)}const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.activeSheet.id,col:o,row:s})}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=Sr(o,"left",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Sr(i,"left",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Sr(t,"left",[...e.elements])));this.setSelectionMixin(n,r)}onRowsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=Sr(o,"top",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Sr(i,"top",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Sr(t,"top",[...e.elements])));this.setSelectionMixin(n,r)}onAddElements(e){const t="COL"===e.dimension?"left":"top",o=br(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),s=this.gridSelection.zones.map((o=>br(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,o=this.getFiguresUpdates(e);this.dispatch("ADD_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,base:e.base,quantity:t,position:e.position});const s="COL"===e.dimension,i=e.elements[0],n=e.elements[t-1],r=e.base<i,a=r&&s?t:0,l=r&&!s?t:0,c=r?e.elements.map((e=>e+t)):e.elements,h={};for(const t of c)h[t]=this.getters.getHeaderSize(e.sheetId,e.dimension,t);const d=[{left:s?i+a:0,right:s?n+a:this.getters.getNumberCols(e.sheetId)-1,top:s?0:i+l,bottom:s?this.getters.getNumberRows(e.sheetId)-1:n+l}],u=this.getActiveSheetId(),g=r?e.base:e.base+1,p=[{left:s?g:0,right:s?g+t-1:this.getters.getNumberCols(e.sheetId)-1,top:s?0:g,bottom:s?this.getters.getNumberRows(e.sheetId)-1:g+t-1}];for(const e of eh.cellHandlers.getAll()){const t=new e(this.getters,this.dispatch),o=t.copy(Qa(u,d),!1,"shiftCells");o&&t.paste({zones:p,sheetId:u},o,{isCutOperation:!0})}const m=p[0],f=m.left,v=m.top;this.setSelectionMixin({zone:m,cell:{col:f,row:v}},[m]);let b=r?e.base:e.base+1;const S={};for(const t of c){const o=h[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,sheetName:e.sheetName,elements:c}),this.applyFigureUpdates(o)}getFiguresUpdates(e){const t=[],o={},s=e.elements[0]<e.base?e.base-e.elements.length+1:e.base;for(let t=0;t<e.elements.length;t++)o[e.elements[t]]=s+t;for(const s of this.getters.getFigures(e.sheetId))"COL"===e.dimension&&s.col in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,col:o[s.col],row:s.row}),"ROW"===e.dimension&&s.row in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,row:o[s.row],col:s.col});return t}applyFigureUpdates(e){for(const t of e)this.dispatch(t.type,{...t})}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":t||this.isTableRowMoveAllowed(i,e.elements)?"Success":"CannotMoveTableHeader"}isTableRowMoveAllowed(e,t){const o=this.getters.getCoreTables(e);if(0===o.length)return!0;const s=new Set(t);return o.every((({range:{zone:e},config:o})=>{const{top:i,bottom:n}=e;if(0===o.numberOfHeaders)return!0;const r=i+o.numberOfHeaders-1;if(!t.some((e=>e>=i&&e<=r)))return!0;return je(i,n+1).every((e=>s.has(e)))}))}fallbackToVisibleSheet(){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})}}clipSelection(e,t){const o=this.getters.getNumberCols(e)-1,s=this.getters.getNumberRows(e)-1;return{zones:t.zones.map((e=>({left:Ze(e.left,0,o),right:Ze(e.right,0,o),top:Ze(e.top,0,s),bottom:Ze(e.bottom,0,s)}))),anchor:{cell:{col:Ze(t.anchor.cell.col,0,o),row:Ze(t.anchor.cell.row,0,s)},zone:{left:Ze(t.anchor.zone.left,0,o),right:Ze(t.anchor.zone.right,0,o),top:Ze(t.anchor.zone.top,0,s),bottom:Ze(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):Mr(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 BV{static getters=["getFilterValue","getFilterHiddenValues","getFilterCriterionValue","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]=ze(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)}getFilterValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;return t?this.filterValues[o]?.[t]:void 0}getFilterHiddenValues(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return[];const s=this.filterValues[o][t]||[];return"values"===s.filterType?s.hiddenValues:[]}getFilterCriterionValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return wL;const s=this.filterValues[o][t];return s&&"criterion"===s.filterType?s:wL}isFilterActive(e){const t=this.getters.getFilterId(e);if(!t)return!1;const o=e.sheetId,s=this.filterValues[o]?.[t];return!!s&&("values"===s.filterType?s.hiddenValues.length>0:"none"!==s.type)}getFirstTableInSelection(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,value: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(const s of t){const t=this.filterValues[e]?.[s.id],i=s.filteredRange?.zone;if(t&&i&&!o.has(s.rangeWithHeaders.zone.top)&&!this.getters.isRowHiddenByUser(e,s.rangeWithHeaders.zone.top))if("values"===t.filterType){const n=t.hiddenValues?.map(qa);if(!n)continue;const r=new Set(n);for(let t=i.top;t<=i.bottom;t++){const i=this.getCellValueAsString(e,s.col,t);r.has(i)&&o.add(t)}}else{if("none"===t.type)continue;const n=eE.get(t.type),r=t.values.map((t=>t.startsWith("=")?this.getters.evaluateFormula(e,t)??"":Kn(t,qs)));if(r.some(oc))continue;const a={type:t.type,values:r.map(ec),dateValue:t.dateValue};for(let t=i.top;t<=i.bottom;t++){const i={sheetId:e,col:s.col,row:t},r=this.getters.getEvaluatedCell(i).value??"";n.isValueValid(r,a,this.getters,e)||o.add(t)}}}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=ur(o.range),i=[],n=[];for(const o of je(0,Tr(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?_r(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=Po(r.col,r.row);t.cells[u]=d,t.cellValues[u]=d}o.filters=i}}}getUniqueColNameForExcel(e,t,o){return t||(t=`Column${e}`),Vt(t,o,{compute:(e,o)=>t+String(o),start:2})}}).add("header_visibility_ui",class extends BV{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 je(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 BV{static getters=["getCellComputedBorder","getCellComputedStyle"];styles={};borders={};handle(e){if(Fs.has(e.type)||"UPDATE_CELL"===e.type||"SET_FORMATTING"===e.type||"ADD_DATA_VALIDATION_RULE"===e.type||"REMOVE_DATA_VALIDATION_RULE"===e.type||"EVALUATE_CELLS"===e.type)return this.styles={},void(this.borders={});rL(e)?"sheetId"in e?(delete this.styles[e.sheetId],delete this.borders[e.sheetId]):(this.styles={},this.borders={}):Ns.has(e.type)?this.styles={}:ks.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=this.getters.getCellTableStyle(e),i=this.getters.getDataValidationCellStyle(e),n={...bt(s),...bt(i),...bt(t?.style),...bt(o)};return this.getters.getEvaluatedCell(e).link&&!n.textColor&&(n.textColor=b),n}}).add("table_computed_style",class extends BV{static getters=["getCellTableStyle","getCellTableBorder"];tableStyles={};handle(e){Fs.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e)||"EVALUATE_CELLS"===e.type?this.tableStyles={}:rL(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=w_(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 BV{static getters=["getColDimensions","getRowDimensions","getColRowOffset"];headerPositions={};isDirty=!0;handle(e){switch(Fs.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.getters.tryGetSheet(e.sheetId)&&(this.headerPositions[e.sheetId]=this.computeHeaderPositionsOfSheet(e.sheetId));break;case"DUPLICATE_SHEET":this.headerPositions[e.sheetIdTo]=ze(this.headerPositions[e.sheetId])}}finalize(){for(const e of this.getters.getSheetIds())!this.isDirty&&this.headerPositions[e]||(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 BV{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","getFigureUI","getPositionAnchorOffset","getGridOffset"];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}=Pr(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(Fs.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":case"UNFREEZE_ROWS":case"UNFREEZE_COLUMNS":case"FREEZE_COLUMNS":case"FREEZE_ROWS":case"UNFREEZE_COLUMNS_ROWS":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":this.sheetsWithDirtyViewports.add(e.sheetId);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"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}}getGridOffset(){return{x:this.gridOffsetX,y:this.gridOffsetY}}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=>je(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=>je(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),{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),maxOffsetY:Math.max(0,o-s.viewportHeight)}}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));let r=i.findIndex((e=>o<=e));r=-1===r?i.length:r;const 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=jr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=jr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=jr(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=jr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=jr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=jr(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}}getRectWithoutHeaders(e){const t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,(t=>t.getFullRect(e)))}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{top:o}=this.getMainInternalViewport(e),s={left:t,right:t,top:o,bottom:o},{x:i,width:n}=this.getVisibleRect(s),r=i-this.gridOffsetX;return{start:r,size:n,end:r+n}}getRowDimensionsInViewport(e,t){const{left:o}=this.getMainInternalViewport(e),s={left:0,right:o,top:t,bottom:t},{y:i,height:n}=this.getVisibleRect(s),r=i-this.gridOffsetY;return{start:r,size:n,end:r+n}}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(lt)}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(Ze(e,0,s),Ze(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(Ze(e,0,s),Ze(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 IL(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 IL(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 IL(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 IL(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)}}getColIndexLeftOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().left,s=-this.getActiveSheetScrollInfo().scrollX-this.getters.getColRowOffset("COL",o,0);for(;e<s;o--)s-=this.getters.getColSize(t,o-1);return Math.max(o,0)}getRowIndexTopOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().top,s=-this.getActiveSheetScrollInfo().scrollY-this.getters.getColRowOffset("ROW",o,0);for(;e<s;o--)s-=this.getters.getRowSize(t,o-1);return Math.max(o,0)}getVisibleFigures(){const e=this.getters.getActiveSheetId(),t=[],o=this.getters.getFigures(e),{scrollX:s,scrollY:i}=this.getters.getActiveSheetScrollInfo(),{x:n,y:r}=this.getMainViewportCoordinates(),{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders();for(const c of o){const o=this.getFigureUI(e,c),{x:h,y:d}=o;h>=n&&(h+c.width<s+n||h>a+s+n)||(d>=r&&(d+c.height<i+r||d>l+i+r)||t.push(o))}return t}getFigureUI(e,t){const o=t.offset.x+this.getters.getColDimensions(e,t.col).start,s=t.offset.y+this.getters.getRowDimensions(e,t.row).start;return{...t,x:o,y:s}}getPositionAnchorOffset(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),s=e.x-t,i=e.y-o,n=s>=0?this.getColIndex(s):this.getColIndexLeftOfMainViewport(s),r=i>=0?this.getRowIndex(i):this.getRowIndexTopOfMainViewport(i),{x:a,y:l}=this.getRect(Mr({col:n,row:r}));return{col:n,row:r,offset:{x:Math.max(s-a+this.gridOffsetX,0),y:Math.max(i-l+this.gridOffsetY,0)}}}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 BV{static layers=["Clipboard"];static getters=["getClipboardTextAndImageContent","getClipboardId","getClipboardTextContent","isCutOperation"];status="invisible";originSheetId;copiedData;_isCutOperation=!1;clipboardId=(new Ka).uuidv4();fileStore;uuidGenerator;constructor(e){super(e),this.fileStore=e.external.fileStore,this.uuidGenerator=new Ka}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,"shiftCells");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,"shiftCells");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._isCutOperation="CUT"===e.type,this.copiedData=this.copy(t);break;case"PASTE_FROM_OS_CLIPBOARD":{this._isCutOperation=!1;const t=e.clipboardContent.data;if(e.clipboardContent.imageData){const t=this.getters.getActiveSheetId(),o=this.uuidGenerator.uuidv4(),s=e.clipboardContent.imageData,i=px(this.getters,s.size);this.dispatch("CREATE_IMAGE",{definition:s,size:i,col:e.target[0].left,row:e.target[0].top,offset:{x:0,y:0},sheetId:t,figureId:o})}this.copiedData=t||this.convertTextToClipboardData(e.clipboardContent.text??"");const o=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:o,selectTarget:!0,isCutOperation:!1}),this.status="invisible",this.copiedData=void 0;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(!pr(t[0])){this.dispatch("CLEAR_CELLS",{target:[e.zone],sheetId:this.getters.getActiveSheetId()});break}const s=this.copy(t,"shiftCells");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,"shiftCells");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(const 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:Hs(e)&&(this.status="invisible")}}convertTextToClipboardData(e){const t=this.selectClipboardHandlers({figureId:!0}).concat(this.selectClipboardHandlers({})),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?eh.figureHandlers:eh.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(const s of o){if("COL"===t&&e<=s.right)return!0;if("ROW"===t&&e<=s.bottom)return!0}return!1}copy(e,t="copyPaste"){const o={},s=this.getClipboardData(e);for(const{handlerName:e,handler:i}of this.selectClipboardHandlers(s)){const n=i.copy(s,this._isCutOperation,t);o[e]=n;const r=["sheetId","cells","zones","figureId"];for(const e of r)n&&e in n&&(o[e]=n[e])}return o}paste(e,t,o){if(!t)return;const s=this.getters.getActiveSheetId(),i=this.selectClipboardHandlers(t),{target:n,zone:r,selectedZones:a}=sl(s,e,t,i,o);void 0!==r&&this.addMissingDimensions(s,r.right-r.left+1,r.bottom-r.top+1,r.left,r.top),ol(i,t,n,o),o?.selectTarget&&il(this.selection,e,a)}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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(e),quantity:r,position:"after"})}getClipboardTextContent(){return this.getPlainTextContent()}getClipboardId(){return this.clipboardId}async getClipboardTextAndImageContent(){const e=await this.getImageContent(),t=e?.type,o={[Os.PlainText]:this.getPlainTextContent(),[Os.Html]:await this.getHTMLContent()};return t&&e&&(o[t]=e),o}getSheetData(){const e={version:hD(),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"}async 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="${xh(Ih(this.getters.getCellComputedStyle(t.position)))}">`+bx(this.getters.getCellText(t.position))+"</td>"}o+="</tr>"}o+="</table>",e=o}}else if(this.copiedData?.figureId){const t=this.copiedData.figureId,o=this.getters.getFigureSheetId(t);e="image"===this.getters.getFigure(o,t).tag?await this.craftImageHTML(t):"\t"}else e="\t";return`<div data-osheet-clipboard='${bx(JSON.stringify(this.getSheetData()))}'>${e}</div>`}readFileAsDataURL(e){return new Promise((t=>{const o=new FileReader;o.onload=()=>t(o.result),o.readAsDataURL(e)}))}async craftImageHTML(e){if(!this.fileStore)return"\t";const t=this.getters.getImage(e).path,o=await(this.fileStore?.getFile(t))||null;if(o){return`<img src="${bx(await this.readFileAsDataURL(o))}" />`}return"\t"}async getImageContent(){const e=this.copiedData?.figureId;if(!e)return;const t=this.getters.getFigureSheetId(e);let o;if("image"===this.getters.getFigure(t,e).tag){if(!this.fileStore)return;const t=this.getters.getImage(e).path;if(o=await(this.fileStore?.getFile(t)),"image/png"!==o.type){if(o.size>yL)return void this.ui.notifyUI({text:Ho("The file you are trying to copy is too large (>%sMB).\nIt will not be added to your OS clipboard.\nYou can download it directly instead.",Math.round(5)),sticky:!1,type:"warning"});o=await async function(e){return new Promise(((t,o)=>{const s=new Image;s.addEventListener("load",(()=>{const e=document.createElement("canvas");e.width=s.width,e.height=s.height;const o=e.getContext("2d");o?.drawImage(s,0,0),e.toBlob(t,"image/png")})),s.addEventListener("error",o),s.src=e}))}(t)}}return o?o instanceof File?o:new File([o],"image.png",{type:"image/png"}):void 0}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();if(o)return{figureId:o,sheetId:t};const s=Qa(t,e);return this._isCutOperation||(s.rowsIndexes=s.rowsIndexes.filter((e=>!this.getters.isRowFiltered(t,e)))),s}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)}}}),TL=(new n).add("evaluation",class extends $k{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 yV(e.custom,this.getters)}beforeHandle(e){(Fs.has(e.type)||Ms.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 js(o)?ki(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 _r(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 _r(t).map((({col:t,row:o})=>this.getEvaluatedCell({sheetId:e,col:t,row:o}))).every((e=>e.type===_s.empty))}mapVisiblePositions(e,t){const{sheetId:o,zone:s}=e;return _r(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={},t.formulaSpillRanges={};for(const t of this.evaluator.getEvaluatedPositions()){const o=this.evaluator.getEvaluatedCell(t),s=Po(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){const h=this.getters.getCell(t);if(a=$S(c.compiledFormula.tokens),r=a&&h?.content===c.content,!a&&""!==i){n=(i??"").toString();const t=o.format;if(t){const o=Gr(t,e.formats);l.formats[s]=o}}}const h=l.cells[s];let d;d=a&&r&&c instanceof kk?c.contentWithFixedReferences:a?h:n,l.cells[s]=d,l.cellValues[s]="error"!==o.type?i:void 0;const u=this.getSpreadZone(t);u&&(l.formulaSpillRanges[s]=this.getters.getRangeString(this.getters.getRangeFromZone(t.sheetId,u),t.sheetId))}}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 $k{static getters=["getChartRuntime","getStyleOfSingleCellChart"];charts={};createRuntimeChart=lx(this.getters);handle(e){if(Fs.has(e.type)||Ns.has(e.type)||Ps.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.figureId]=void 0;break;case"DELETE_SHEET":for(const 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:rC(e)};if(!t)return{background:m,fontColor:rC(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||rC(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=Wy(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 $k{static getters=["getConditionalIcon","getCellConditionalFormatStyle","getConditionalDataBar"];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(Fs.has(e.type)||Ns.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(const o of this.getters.getConditionalFormats(e).reverse())switch(o.rule.type){case"ColorScaleRule":for(const 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(const 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={sheetId:e,col:r,row:i},l=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}));this.getRuleResultForTarget(a,{...o.rule,values:l})&&(t[r]||(t[r]=[]),t[r][i]=Object.assign(t[r]?.[i]||{},o.rule.style))}}}return t}getComputedIcons(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("IconSetRule"===o.rule.type)for(const s of o.ranges)this.applyIcon(e,s,o.rule,t);return t}getComputedDataBars(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("DataBarRule"===o.rule.type)for(const 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===_s.number)).map((e=>e.value));switch(o.type){case"value":return"max"===s?Ft(i):Pt(i);case"number":return Number(o.value);case"percentage":const t=Pt(i);return t+(Ft(i)-t)*Number(o.value)/100;case"percentile":return Ds(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!==_s.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=Ft(this.getters.getEvaluatedCellsInZone(e,i.zone).filter((e=>e.type===_s.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});!Er(i,c,l)||h.type!==_s.number||h.value<=0||(s[o]||(s[o]=[]),s[o][t]={color:zt(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=So(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===_s.number){const e=Ze(n.value,i,r);s[o]||(s[o]=[]),s[o][t]=s[o]?.[t]||{},s[o][t].fillColor=c(e)}}}getRuleResultForTarget(e,t){const o=this.getters.getEvaluatedCell(e);if(o.type===_s.error)return!1;const{sheetId:s}=e,i=eE.get(t.operator),n=t.values.map((e=>e.startsWith("=")?this.getters.evaluateFormula(s,e)??"":Kn(e,qs)));if(n.some(oc))return!1;const r={type:t.operator,values:n.map(ec)};return i.isValueValid(o.value??"",r,this.getters,s)}}).add("row_size",class extends $k{static getters=["getRowSize","getHeaderSize","getMaxAnchorOffset"];tallestCellInRow={};ctx=document.createElement("canvas").getContext("2d");beforeHandle(e){if("ADD_COLUMNS_ROWS"===e.type){if("COL"===e.dimension)return;const t=pt(e.position,e.base),o=Array(e.quantity).fill(void 0),s=Tt(this.tallestCellInRow[e.sheetId],o,t);this.history.update("tallestCellInRow",e.sheetId,s)}}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=ze(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=Rt(this.tallestCellInRow[e.sheetId],e.elements);this.history.update("tallestCellInRow",e.sheetId,t);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 je(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 _r(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??ie)}getMaxAnchorOffset(e,t,o){let{numberOfRows:s,numberOfCols:i}=this.getters.getSheetSize(e),n=0;for(;n<t&&s>0;s--)n+=this.getRowSize(e,s-1);let r=0;for(;r<o&&i>0;i--)r+=this.getters.getColSize(e,i-1);return{col:i,row:s,offset:{x:r-o,y:n-t}}}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<=ie)&&(!s&&i>ie||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 ie;const t=this.getters.getCell(e),o=this.getters.getColSize(e.sheetId,e.col);return function(e,t,o){return t&&(t.isFormula||t.content)?Ma(e,t.isFormula?"":t.content,t.style,o):ie}(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>ie&&(i=r,s={cell:n,size:r})}return s&&s.size>ie?s:void 0}}).add("data_validation_ui",class extends $k{static getters=["getDataValidationInvalidCriterionValueMessage","getInvalidDataValidationMessage","getValidationResultForCellValue","getDataValidationRangeValues","isCellValidCheckbox","getDataValidationCellStyle","getDataValidationChipStyle","isDataValidationInvalid"];validationResults={};handle(e){if(Fs.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}getDataValidationCellStyle(e){if(!this.hasChip(e))return this.getDataValidationStyle(e)}getDataValidationChipStyle(e){if(this.hasChip(e))return this.getDataValidationStyle(e)??{fillColor:F}}getInvalidDataValidationMessage(e){const t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){const o=eE.get(e);return t.startsWith("=")?"onlyLiterals"===o.allowedValues?Ho("The value must not be a formula"):this.isValidFormula(t)?void 0:tw.CriterionError.validFormula:"onlyFormulas"===o.allowedValues?Ho("The value must be a formula"):o.isCriterionValueValid(t)?void 0:o.criterionValueErrorString}getDataValidationRangeValues(e,t){const o=this.getters.getRangeFromSheetXC(e,String(t.values[0])),s=[],i=new Set;for(const e of _r(o.zone)){const t=this.getters.getEvaluatedCell({...e,sheetId:o.sheetId});t.formattedValue&&!i.has(t.formattedValue)&&(i.add(t.formattedValue),s.push({label:t.formattedValue,value:t.value?.toString()||""}))}return s}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 RV;const s=this.getRuleErrorForCellValue(e,t,o);return s?{error:s,rule:o,isValid:!1}:RV}hasChip(e){const t=this.getters.getValidationRuleForCell(e);return("isValueInList"===t?.criterion.type||"isValueInRange"===t?.criterion.type)&&"chip"===t.criterion.displayStyle}getDataValidationStyle(e){const t=this.getters.getValidationRuleForCell(e);if(!t||this.isDataValidationInvalid(e))return;const o=this.getters.getEvaluatedCell(e),s=this.getValueColor(t,o.value);if(!s)return;return{fillColor:s,textColor:no(s)}}getValueColor(e,t){if("isValueInList"===e.criterion.type||"isValueInRange"===e.criterion.type)for(const o in e.criterion.colors)if(o.toLowerCase()===String(t).toLowerCase())return e.criterion.colors[o]}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]?.()||RV}computeSheetValidationResults(e){const t={},o=this.getters.getDataValidationRules(e).map((e=>e.ranges));for(const e of wa(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===_s.empty?RV:this.getValidationResultForCellValue(t.value,e)}))}return t}getRuleErrorForCellValue(e,t,o){const{sheetId:s}=t,i=o.criterion,n=eE.get(i.type),r=this.getCellOffsetInRule(t,o),a=this.getEvaluatedCriterionValues(s,r,i);if(a.some(oc))return;const l={...i,values:a.map(ec)};return n.isValueValid(e,l,this.getters,s)?void 0:n.getErrorString(l,this.getters,s)}getCellOffsetInRule(e,t){const o=t.ranges.find((t=>Er(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 Kn(o,qs);const s=HS(o),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,s.tokens);return this.getters.evaluateFormula(e,i)}))}}).add("dynamic_tables",class extends $k{static getters=["canCreateDynamicTableOnZones","doesZonesContainFilter","getFilter","getFilters","getTable","getTables","getTablesOverlappingZones","getFilterId","getFilterHeaders","isFilterHeader"];tables={};handle(e){if(Fs.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"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)xr(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=>Er(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getTables(e).filter((e=>t.some((t=>xr(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(!Ur(t))return!1;const o=yr(...t),s={col:o.left,row:o.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(s);if(!i)return!1;if(mt(i,s)&&1===Lr(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=C_(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=ur(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=fr(n.range.zone))}}}).add("custom_colors",class extends $k{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.figureId));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:Zt(255,0,0),colors:[]},{leadColor:Zt(255,128,0),colors:[]},{leadColor:Zt(128,128,0),colors:[]},{leadColor:Zt(128,255,0),colors:[]},{leadColor:Zt(0,255,0),colors:[]},{leadColor:Zt(0,255,128),colors:[]},{leadColor:Zt(0,255,255),colors:[]},{leadColor:Zt(0,127,255),colors:[]},{leadColor:Zt(0,0,255),colors:[]},{leadColor:Zt(127,0,255),colors:[]},{leadColor:Zt(128,0,128),colors:[]},{leadColor:Zt(255,0,128),colors:[]}];for(const o of e.map(Xt)){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)=>Jt(e).s-Jt(t).s)))).flat().map(Yt)}(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(zt(t.minimum.color)),o.push(t.midpoint?zt(t.midpoint.color):void 0),o.push(zt(t.maximum.color)))}return o.filter(lt)}getChartColors(e){const t=this.getters.getChart(e);if(void 0===t)return[];return[...JSON.stringify(t.getDefinition()).matchAll(EV)].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(lt):[]}tryToAddColors(e){for(const t of e){if(!Wt(t))continue;const e=Gt(t);t&&!ee.includes(e)&&this.history.update("customColors",e,!0)}}}).add("pivot_ui",class extends $k{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(Fs.has(e.type))for(const e of this.getters.getPivotIds())ik.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(FV);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 ok)ok[e].set.clear(),ok[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=BN(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=gv(t);return this.getters.evaluateFormula(e,o)}))}}getPivotCellFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||0===zN(t.compiledFormula.tokens))return ZN;const o=this.getters.getCellPosition(t.id),s=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!s)return ZN;let{functionName:i,args:n}=s;const r=n[0];if(!r)return ZN;const a=this.getters.getPivotId(r.toString());if(!a)return ZN;const l=this.getPivot(a);if(!l.isValid())return ZN;if("PIVOT"===i&&!t.content.replaceAll(" ","").toUpperCase().startsWith("=PIVOT"))return ZN;if("PIVOT"===i){const t=ec(n[2]),s=void 0===t||Ei(t),i=ec(n[3]),r=ec(n[5]),a=void 0===r||Ei(r),c={displayColumnHeaders:void 0===i||Ei(i),displayTotals:s,displayMeasuresRow:a},h=l.getCollapsedTableStructure().getPivotCells(c),d=e.col-o.col,u=e.row-o.row;return h[d][u]}try{const t=e.row-o.row,s=e.col-o.col;if(n=n.map((e=>js(e)?e[s][t]:e)),"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){const e=l.parseArgsToPivotDomain(n.slice(1).map((e=>({value:e}))));return{type:"HEADER",domain:e,dimension:NO(l,e).colDomain.length?"COL":"ROW"}}const[r,...a]=n.slice(1);return{type:"VALUE",domain:l.parseArgsToPivotDomain(a.map((e=>({value:e})))),measure:r?.toString()||""}}catch(e){return ZN}}generateNewCalculatedMeasureName(e){const t=e.map((e=>e.fieldName));return Vt(Ho("Calculated measure 1"),t,{compute:(e,t)=>Ho("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=_V(ik.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}}).add("cell_icon",class extends $k{static getters=["doesCellHaveGridIcon","getCellIcons","getCellIconRect"];cellIconsCache={};handle(e){"SET_VIEWPORT_OFFSET"!==e.type&&(this.cellIconsCache={})}getCellIcons(e){return this.cellIconsCache[e.sheetId]||(this.cellIconsCache[e.sheetId]={}),this.cellIconsCache[e.sheetId][e.col]||(this.cellIconsCache[e.sheetId][e.col]={}),this.cellIconsCache[e.sheetId][e.col][e.row]||(this.cellIconsCache[e.sheetId][e.col][e.row]=this.computeCellIcons(e)),this.cellIconsCache[e.sheetId][e.col][e.row]}getCellIconRect(e,t){const o=e.position,s=this.getters.getCell(o);return{x:this.getIconHorizontalPosition(t,e.horizontalAlign,e),y:this.getters.computeTextYCoordinate(t,e.size,s?.style?.verticalAlign),width:e.size,height:e.size}}getIconHorizontalPosition(e,t,o){const s=e.x,i=e.x+e.width;switch(t){case"right":return i-o.margin-o.size;case"left":return s+o.margin;default:const e=Math.floor((i-s-o.size)/2);return i-o.size-e}}computeCellIcons(e){const t={left:void 0,right:void 0,center:void 0},o=TV.getAll();for(const s of o){const o=s(this.getters,e);o&&(!t[o.horizontalAlign]||o.priority>t[o.horizontalAlign].priority)&&(t[o.horizontalAlign]=o)}if(t.center&&(t.left||t.right)){const e=Math.max(t.left?.priority||0,t.right?.priority||0);t.center.priority<e?t.center=void 0:(t.left=void 0,t.right=void 0)}return Object.values(t).filter(lt)}doesCellHaveGridIcon(e){return Boolean(this.getCellIcons(e).length)}});mE.add("dataValidation",{displayAllOnInitialContent:!0,canBeToggled:!1,getProposals(e,t){if(Lt(t))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[];const i=this.composer.currentEditedCell.sheetId,n="isValueInRange"===s.criterion.type?this.getters.getDataValidationRangeValues(i,s.criterion):s.criterion.values.map((e=>({label:e,value:e})));if(!("chip"===s.criterion.displayStyle))return n.map((e=>({text:e.value,fuzzySearchKey:e.label,htmlContent:[{value:e.label}]})));const r=s.criterion.colors;return n.map((e=>{const t=r?.[e.value];return{text:e.value,htmlContent:[{value:e.label,color:t?no(t):void 0,backgroundColor:t||F,classes:["badge rounded-pill fs-6 fw-normal w-100 mt-1 text-start"]}],fuzzySearchKey:e.label}}))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}}),mE.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!Lt(this.composer.currentContent))return[];const o=Object.entries(RS.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:EN(t,e,E,"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)}}),mE.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:wE.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(lt)},selectProposal:HN}),mE.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=UN(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:Ho("Count"),htmlContent:[{value:e,color:wE.STRING}],fuzzySearchKey:Ho("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:wE.STRING}],fuzzySearchKey:o}}(e)})).filter(lt):[]},selectProposal:LN}),mE.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=UN(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(lt),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=Ok.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(lt);return m.map((e=>{const[t,o]=e.split(":"),s=n[t];return s?VN(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:Ho("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:wE.STRING}],fuzzySearchKey:o.string+s}}))).filter(lt)},selectProposal:LN}),mE.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=UN(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(yn).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:wE.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:Ho("Quarter %s",e),htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"day_of_month"===a.granularity?je(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"iso_week_number"===a.granularity?je(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"day_of_week"===a.granularity?je(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"hour_number"===a.granularity?je(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"minute_number"===a.granularity?je(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"second_number"===a.granularity?je(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.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?wE.STRING:wE.NUMBER}],fuzzySearchKey:s+i}}))},selectProposal:LN}),mE.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 AL=new n;AL.add("link",{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t,o)=>Zo(t.model.getters.getEvaluatedCell(e).link,t,o),title:(e,t)=>{const o=t.getEvaluatedCell(e).link;return o?o.isExternal?Ho("Go to url: %(url)s",{url:o.url}):Ho("Go to %(label)s",{label:o.label}):""},sequence:5});const DL=(new n).add("ADD_COLUMNS_ROWS",(function(e){const t=[];let o=e.base;"after"===e.position&&o++;for(let s=0;s<e.quantity;s++)t.push(s+o);return[{type:"REMOVE_COLUMNS_ROWS",dimension:e.dimension,elements:t,sheetId:e.sheetId,sheetName:e.sheetName}]})).add("REMOVE_COLUMNS_ROWS",(function(e){const t=[],o=[...e.elements].sort(((e,t)=>e-t));for(const s of Ye(o)){const o=0===s[0]?0:s[0]-1,i=0===s[0]?"before":"after";t.push({type:"ADD_COLUMNS_ROWS",dimension:e.dimension,quantity:s.length,base:o,sheetId:e.sheetId,sheetName:e.sheetName,position:i})}return t})).add("ADD_MERGE",(function(e){return[{type:"REMOVE_MERGE",sheetId:e.sheetId,target:e.target}]})).add("REMOVE_MERGE",(function(e){return[{type:"ADD_MERGE",sheetId:e.sheetId,target:e.target}]})).add("CREATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetId,sheetName:e.name}]})).add("DELETE_SHEET",(function(e){return[{type:"CREATE_SHEET",sheetId:e.sheetId,position:1,name:e.sheetName}]})).add("DUPLICATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetIdTo,sheetName:""}]})).add("CREATE_FIGURE",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("CREATE_CHART",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("HIDE_COLUMNS_ROWS",(function(e){return[{type:"UNHIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("UNHIDE_COLUMNS_ROWS",(function(e){return[{type:"HIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("CREATE_TABLE_STYLE",(function(e){return[{type:"REMOVE_TABLE_STYLE",tableStyleId:e.tableStyleId}]})).add("ADD_PIVOT",(function(e){return[{type:"REMOVE_PIVOT",pivotId:e.pivotId}]})).add("RENAME_SHEET",(function(e){return[{type:"RENAME_SHEET",sheetId:e.sheetId,oldName:e.newName,newName:e.oldName}]}));for(const e of Ls.values())DL.contains(e)||DL.add(e,_L);function _L(e){return[e]}const OL=new n;OL.add("format_number_automatic",{...pF,id:"format_number_automatic",sequence:10}).add("format_number_plain_text",{...mF,id:"format_number_plain_text",sequence:15,separator:!0}).add("format_number_number",{...fF,id:"format_number_number",sequence:20}).add("format_number_percent",{...bF,id:"format_number_percent",sequence:30,separator:!0}).add("format_number_currency",{...SF,id:"format_number_currency",sequence:40}).add("format_number_accounting",{...yF,id:"format_number_accounting",sequence:45}).add("format_number_currency_rounded",{...CF,id:"format_number_currency_rounded",sequence:50}).add("format_custom_currency",{...IF,id:"format_custom_currency",sequence:60,separator:!0}).add("format_number_date",{...xF,id:"format_number_date",sequence:70}).add("format_number_time",{...EF,id:"format_number_time",sequence:80}).add("format_number_date_time",{...RF,id:"format_number_date_time",sequence:90}).add("format_number_duration",{...TF,id:"format_number_duration",sequence:100,separator:!0}).add("more_formats",{..._F,id:"more_formats",sequence:120});const FL=Et((e=>On(e)?"date":e.includes("[$")?"currency":"number")),PL={name:Ho("More formats"),icon:"o-spreadsheet-Icon.NUMBER_FORMATS",children:[e=>{const t=function(e){const t=new Set(OL.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=FL(s.format);"date"!==e&&"currency"!==e||o.set(s.format,gF({descriptionValue:"currency"===e?1e3:wF,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([...OL.getAll(),...t])}]};const ML=new vR;ML.add("file",{name:Ho("File"),sequence:10}).addChild("settings",["file"],{name:Ho("Settings"),sequence:200,execute:e=>e.openSidePanel("Settings"),isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.COG"}).add("edit",{name:Ho("Edit"),sequence:20}).addChild("undo",["edit"],{...__,sequence:10}).addChild("redo",["edit"],{...O_,sequence:20,separator:!0}).addChild("copy",["edit"],{...F_,sequence:30}).addChild("cut",["edit"],{...P_,sequence:40}).addChild("paste",["edit"],{...M_,sequence:50}).addChild("paste_special",["edit"],{...N_,sequence:60,separator:!0}).addChild("paste_special_value",["edit","paste_special"],{...k_,sequence:10}).addChild("paste_special_format",["edit","paste_special"],{...V_,sequence:20}).addChild("edit_table",["edit"],{...X_,isVisible:VD,sequence:60}).addChild("find_and_replace",["edit"],{...L_,sequence:65,separator:!0}).addChild("delete",["edit"],{name:Ho("Delete"),icon:"o-spreadsheet-Icon.TRASH",sequence:70}).addChild("edit_delete_cell_values",["edit","delete"],{...H_,sequence:10}).addChild("edit_delete_row",["edit","delete"],{...U_,sequence:20}).addChild("edit_delete_column",["edit","delete"],{...$_,sequence:30}).addChild("edit_delete_cell_shift_up",["edit","delete"],{...Z_,sequence:40}).addChild("edit_delete_cell_shift_left",["edit","delete"],{...j_,sequence:50}).addChild("edit_unhide_columns",["edit"],{...jD,sequence:80}).addChild("edit_unhide_rows",["edit"],{...KD,sequence:80}).add("view",{name:Ho("View"),sequence:30}).addChild("unfreeze_panes",["view"],{...JD,sequence:4}).addChild("freeze_panes",["view"],{...QD,sequence:5}).addChild("unfreeze_rows",["view","freeze_panes"],{...e_,sequence:5}).addChild("freeze_first_row",["view","freeze_panes"],{...t_,sequence:10}).addChild("freeze_second_row",["view","freeze_panes"],{...o_,sequence:15}).addChild("freeze_current_row",["view","freeze_panes"],{...s_,sequence:20,separator:!0}).addChild("unfreeze_columns",["view","freeze_panes"],{...i_,sequence:25}).addChild("freeze_first_col",["view","freeze_panes"],{...n_,sequence:30}).addChild("freeze_second_col",["view","freeze_panes"],{...r_,sequence:35}).addChild("freeze_current_col",["view","freeze_panes"],{...a_,sequence:40}).addChild("group_headers",["view"],{name:Ho("Group"),sequence:15,separator:!0,icon:"o-spreadsheet-Icon.PLUS_IN_BOX",isVisible:HD}).addChild("group_columns",["view","group_headers"],{...d_,sequence:5}).addChild("ungroup_columns",["view","group_headers"],{...g_,isVisible:e=>v_(e,"COL"),sequence:10}).addChild("group_rows",["view","group_headers"],{...u_,sequence:15}).addChild("ungroup_rows",["view","group_headers"],{...p_,isVisible:e=>v_(e,"ROW"),sequence:20}).addChild("show",["view"],{name:Ho("Show"),sequence:1,icon:"o-spreadsheet-Icon.SHOW"}).addChild("view_gridlines",["view","show"],{...l_,sequence:5}).addChild("view_formulas",["view","show"],{...h_,sequence:10}).addChild("view_irregularity_map",["view"],{...c_,sequence:40,separator:!0}).add("insert",{name:Ho("Insert"),sequence:40}).addChild("insert_row",["insert"],{...eO,sequence:10}).addChild("insert_row_before",["insert","insert_row"],{...oO,sequence:10}).addChild("insert_row_after",["insert","insert_row"],{...nO,sequence:20}).addChild("insert_column",["insert"],{...rO,sequence:20}).addChild("insert_column_before",["insert","insert_column"],{...lO,sequence:10}).addChild("insert_column_after",["insert","insert_column"],{...dO,sequence:20}).addChild("insert_cell",["insert"],{...uO,sequence:30}).addChild("insert_cell_down",["insert","insert_cell"],{...gO,name:Ho("Shift down"),sequence:10}).addChild("insert_cell_right",["insert","insert_cell"],{...pO,name:Ho("Shift right"),sequence:20}).addChild("insert_sheet",["insert"],{...DO,sequence:40,separator:!0}).addChild("insert_chart",["insert"],{...mO,sequence:50}).addChild("insert_pivot",["insert"],{...fO,sequence:52}).addChild("insert_image",["insert"],{...vO,sequence:55}).addChild("insert_table",["insert"],{...bO,sequence:57}).addChild("insert_function",["insert"],{...SO,sequence:60}).addChild("insert_function_sum",["insert","insert_function"],{...CO,sequence:0}).addChild("insert_function_average",["insert","insert_function"],{...yO,sequence:10}).addChild("insert_function_count",["insert","insert_function"],{...wO,sequence:20}).addChild("insert_function_max",["insert","insert_function"],{...IO,sequence:30}).addChild("insert_function_min",["insert","insert_function"],{...xO,sequence:40,separator:!0}).addChild("categorie_function_all",["insert","insert_function"],{...EO,sequence:50}).addChild("categories_function_list",["insert","insert_function"],(()=>{const e=RS.content;return[...new Set(RS.getAll().filter((e=>!e.hidden)).map((e=>e.category)))].filter(lt).sort().map(((t,o)=>{const s=Object.keys(e).filter((o=>e[o].category===t&&!e[o].hidden));return{name:t,children:_O(s)}}))})).addChild("insert_link",["insert"],{...RO,separator:!0,sequence:70}).addChild("insert_checkbox",["insert"],{...TO,sequence:80}).addChild("insert_dropdown",["insert"],{...AO,separator:!0,sequence:90}).add("format",{name:Ho("Format"),sequence:50}).addChild("format_number",["format"],{...PL,name:Ho("Number"),sequence:10,separator:!0}).addChild("format_bold",["format"],{...zF,sequence:20}).addChild("format_italic",["format"],{...$F,sequence:30}).addChild("format_underline",["format"],{...GF,sequence:40}).addChild("format_strikethrough",["format"],{...WF,sequence:50,separator:!0}).addChild("format_font_size",["format"],{...qF,sequence:60,separator:!0}).addChild("format_alignment",["format"],{...ZF,sequence:70}).addChild("format_alignment_left",["format","format_alignment"],{...YF,sequence:10}).addChild("format_alignment_center",["format","format_alignment"],{...XF,sequence:20}).addChild("format_alignment_right",["format","format_alignment"],{...KF,sequence:30,separator:!0}).addChild("format_alignment_top",["format","format_alignment"],{...QF,sequence:40}).addChild("format_alignment_middle",["format","format_alignment"],{...eP,sequence:50}).addChild("format_alignment_bottom",["format","format_alignment"],{...tP,sequence:60,separator:!0}).addChild("format_wrapping",["format"],{...oP,sequence:80,separator:!0}).addChild("format_wrapping_overflow",["format","format_wrapping"],{...iP,sequence:10}).addChild("format_wrapping_wrap",["format","format_wrapping"],{...nP,sequence:20}).addChild("format_wrapping_clip",["format","format_wrapping"],{...rP,sequence:30}).addChild("format_cf",["format"],{...aP,sequence:90,separator:!0}).addChild("format_clearFormat",["format"],{...lP,sequence:100,separator:!0}).add("data",{name:Ho("Data"),sequence:60}).addChild("sort_range",["data"],{...oF,sequence:10,separator:!0}).addChild("sort_ascending",["data","sort_range"],{...sF,sequence:10}).addChild("sort_descending",["data","sort_range"],{...aF,sequence:20}).addChild("data_cleanup",["data"],{...iF,sequence:15}).addChild("remove_duplicates",["data","data_cleanup"],{...nF,sequence:10}).addChild("trim_whitespace",["data","data_cleanup"],{...rF,sequence:20}).addChild("split_to_columns",["data"],{...hF,sequence:20}).addChild("data_validation",["data"],{name:Ho("Data Validation"),execute:e=>{e.openSidePanel("DataValidation")},isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.DATA_VALIDATION",sequence:30,separator:!0}).addChild("add_remove_data_filter",["data"],{...lF,sequence:40,separator:!0}).addChild("pivot_data_sources",["data"],(e=>{const t=e.model.getters.getPivotIds().length;return e.model.getters.getPivotIds().map(((o,s)=>{const i={get highlights(){return wN(e.model.getters,o)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(o)}`,name:e.model.getters.getPivotDisplayName(o),sequence:50+s/t,isReadonlyAllowed:!0,execute:e=>e.openSidePanel("PivotSidePanel",{pivotId:o}),isEnabled:e=>!e.isSmall,onStartHover:e=>e.getStore(vE).register(i),onStopHover:e=>e.getStore(vE).unRegister(i),icon:"o-spreadsheet-Icon.PIVOT",separator:s===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(o)?"o-spreadsheet-Icon.UNUSED_PIVOT_WARNING":void 0}}))})).addChild("reinsert_dynamic_pivot",["data"],dF).addChild("reinsert_static_pivot",["data"],uF);const NL=new class extends n{mapping={};uuidGenerator=new Ka;replace(e,t){const o={...t,id:this.uuidGenerator.uuidv4()};return super.replace(e,o)}getAllOrdered(){return this.getAll().sort(((e,t)=>e.sequence-t.sequence))}};class kL{listeners=[];async sendMessage(e){for(const{callback:t}of this.listeners)t(e)}onNewMessage(e,t){this.listeners.push({id:e,callback:t})}leave(e){this.listeners=this.listeners.filter((t=>t.id!==e))}}class VL{fileStore;constructor(e){this.fileStore=e}async requestImage(){const e=await this.userImageUpload(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}async uploadFile(e){const t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}userImageUpload(){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.addEventListener("load",(()=>{const e={width:s.width,height:s.height};t(e)})),s.addEventListener("error",o),s.src=e}))}}const LL=[{transform:"scale(0)"},{transform:"scale(0.8)",offset:.33},{opacity:"0",transform:"scale(1)",offset:1}];yh`
|
|
1874
|
+
`;class Pk extends t.Component{static template="o_spreadsheet.PivotHTMLRenderer";static components={Checkbox:oR};static props={pivotId:String,onCellClicked:Function};pivot=this.env.model.getters.getPivot(this.props.pivotId);data={columns:[],rows:[],values:[]};state=t.useState({showMissingValuesOnly:!1});setup(){const e=this.pivot.getExpandedTableStructure(),t=this.env.model.getters.getPivotFormulaId(this.props.pivotId);this.data={columns:this._buildColHeaders(t,e),rows:this._buildRowHeaders(t,e),values:this._buildValues(t,e)}}get tracker(){return this.env.model.getters.getPivotPresenceTracker(this.props.pivotId)}getTableData(){if(!this.state.showMissingValuesOnly)return this.data;const e=this.getColumnsIndexes(),t=this.getRowsIndexes();return{columns:this.buildColumnsMissing(e),rows:this.buildRowsMissing(t),values:this.buildValuesMissing(e,t)}}addRecursiveRow(e){const t=this.pivot.getExpandedTableStructure().rows,o=[...t[e].values];if(o.length<=1)return[e];o.pop();const s=t.findIndex((e=>JSON.stringify(e.values)===JSON.stringify(o)));return[e].concat(this.addRecursiveRow(s))}buildColumnsMissing(e){const t=[];for(const e of this.data.columns){const o=[];for(const t in e)for(let s=0;s<e[t].span;s++)o.push(parseInt(t,10));t.push(o)}for(let o=t[t.length-1].length;o>=0;o--)if(!e.includes(o))for(const e of t)e.splice(o,1);const o=[];for(const e in t){const s=[];let i,n=1;for(let o=0;o<t[e].length;o++)i!==t[e][o]?(void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),i=t[e][o],n=1):n++;void 0!==i&&s.push(Object.assign({},this.data.columns[e][i],{span:n})),o.push(s)}return o}buildRowsMissing(e){return e.map((e=>this.data.rows[e]))}buildValuesMissing(e,t){const o=e.map((()=>[]));for(const s of t)for(const t in e)o[t].push(this.data.values[e[t]][s]);return o}getColumnsIndexes(){const e=new Set;for(let t=0;t<this.data.columns.length;t++){const o=[];for(let e=0;e<this.data.columns[t].length;e++)for(let s=0;s<this.data.columns[t][e].span;s++)o.push(this.data.columns[t][e]);for(let t=0;t<o.length;t++)o[t].isMissing&&e.add(t)}for(let t=0;t<this.data.columns[this.data.columns.length-1].length;t++){this.data.values[t].find((e=>e.isMissing))&&e.add(t)}return Array.from(e).sort(((e,t)=>e-t))}getRowsIndexes(){const e=new Set;for(let t=0;t<this.data.rows.length;t++){this.data.rows[t].isMissing&&e.add(t);for(const o of this.data.values)o[t].isMissing&&this.addRecursiveRow(t).forEach((t=>e.add(t)))}return Array.from(e).sort(((e,t)=>e-t))}_buildColHeaders(e,t){const o=[];for(const s of t.columns){const t=[];for(const o of s){const s=[];for(let e=0;e<o.fields.length;e++)s.push({value:o.fields[e]},{value:o.values[e]});const i=this.pivot.parseArgsToPivotDomain(s),n=this.env.model.getters.getLocale();if("measure"===i.at(-1)?.field){const{value:s,format:r}=this.pivot.getPivotMeasureValue(wi(i.at(-1).value),i);t.push({formula:`=PIVOT.HEADER(${Bc(e,i).join(",")})`,value:In(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}else{const{value:s,format:r}=this.pivot.getPivotHeaderValueAndFormat(i);t.push({formula:`=PIVOT.HEADER(${Bc(e,i).join(",")})`,value:In(s,{format:r,locale:n}),span:o.width,isMissing:!this.tracker?.isHeaderPresent(i)})}}o.push(t)}const s=o[o.length-1];return o[o.length-1]=s.map((e=>(e.isMissing||(e.style="color: #756f6f;"),e))),o}_buildRowHeaders(e,t){const o=[];for(const s of t.rows){const t=[];for(let e=0;e<s.fields.length;e++)t.push({value:s.fields[e]},{value:s.values[e]});const i=this.pivot.parseArgsToPivotDomain(t),{value:n,format:r}=this.pivot.getPivotHeaderValueAndFormat(i),a=this.env.model.getters.getLocale(),l={formula:`=PIVOT.HEADER(${Bc(e,i).join(",")})`,value:In(n,{format:r,locale:a}),isMissing:!this.tracker?.isHeaderPresent(i)};s.indent>1&&(l.style=`padding-left: ${s.indent-10}px`),o.push(l)}return o}_buildValues(e,t){const o=[];for(const s of t.columns.at(-1)||[]){const i=[],n=wi(s.values[s.values.length-1]);for(const o of t.rows){const t=[];for(let e=0;e<o.fields.length;e++)t.push({value:o.fields[e]},{value:o.values[e]});for(let e=0;e<s.fields.length-1;e++)t.push({value:s.fields[e]},{value:s.values[e]});const r=this.pivot.parseArgsToPivotDomain(t),{value:a,format:l}=this.pivot.getPivotCellValueAndFormat(n,r),c=this.env.model.getters.getLocale();i.push({formula:`=PIVOT.VALUE(${Bc(e,r,n).join(",")})`,value:In(a,{format:l,locale:c}),isMissing:!this.tracker?.isValuePresent(n,r)})}o.push(i)}return o}}class Mk{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 Nk extends Mk{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,o){}garbageCollectExternalResources(){}}class kk{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 Vk(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 Vk{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 Lk(e){return""===e?NaN:Number(e)}function Hk(e){return Object.entries(e).map((([e,t])=>t?Uk(parseInt(e,10),t):void 0)).filter(lt).map((e=>Po(e.left,e.top)+":"+Po(e.right,e.bottom)))}function Uk(e,t){return{...t.zone,id:e}}class Bk{getters;providers=[];constructor(e){this.getters=e}static getters=["adaptFormulaStringDependencies","copyFormulaStringForSheet","extendRange","getRangeString","getRangeFromSheetXC","createAdaptedRanges","getRangeData","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){const t=Ia(e);t?.applyChange&&this.executeOnAllRanges(t.applyChange,t.sheetId,t.sheetName)}finalize(){}verifyRangeRemoved(e){return t=>{const o=e(t);return"NONE"===o.changeType||pr(o.range.zone)?o:{range:o.range,changeType:"REMOVE"}}}executeOnAllRanges(e,t,o){const s=this.verifyRangeRemoved(e);for(const e of this.providers)e(s,t,o)}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,o,s){return e.map((e=>{if(!pr(e.zone))return e;const i=e.prefixSheet?e.sheetId:s,n=ba(e),r=va(e),a={...e.unboundedZone,left:n&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:n?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:r&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:o),bottom:r?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:o)};return function(e){if(mr(e.zone))return e;const t={...e.unboundedZone},o={...e.zone};let s=e.parts;if(void 0!==t.right&&t.right<t.left){const e=t.right;t.right=t.left,t.left=e,o.right=o.left,o.left=e,s=[{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1},{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1}]}if(void 0!==t.bottom&&t.bottom<t.top){const e=t.bottom;t.bottom=t.top,t.top=e,o.bottom=o.top,o.top=e,s=[{colFixed:s[0]?.colFixed||!1,rowFixed:s[1]?.rowFixed||!1},{colFixed:s[1]?.colFixed||!1,rowFixed:s[0]?.rowFixed||!1}]}return{unboundedZone:t,zone:o,parts:s,invalidXc:e.invalidXc,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}(pa({...e,sheetId:i,zone:a},this.getters.getSheetSize))}))}removeRangesSheetPrefix(e,t){return t.map((t=>t.prefixSheet&&t.sheetId===e?{...t,prefixSheet:!1}:t))}extendRange(e,t,o){const s="COL"===t?e.zone.right+o:e.zone.right,i="ROW"===t?e.zone.bottom+o:e.zone.bottom,n={left:e.zone.left,top:e.zone.top,right:ba(e)?void 0:s,bottom:va(e)?void 0:i};return pa({...e,zone:n},this.getters.getSheetSize)}getRangeFromSheetXC(e,t){if(!ta.test(t)||!this.getters.tryGetSheet(e))return fa(t);const{sheetName:o}=ra(t);return ma({xc:t,sheetId:this.getters.getSheetIdByName(o)||e,invalidSheetName:o&&!this.getters.getSheetIdByName(o)?o:void 0},this.getters.getSheetSize)}getRangeString(e,t,o={useBoundedReference:!1,useFixedReference:!1}){return e?e.invalidXc?e.invalidXc:this.getters.tryGetSheet(e.sheetId)?Sa(e,t,this.getters.getSheetName,o):ti.InvalidReference:ti.InvalidReference}getRangeDataFromXc(e,t){const o=this.getters.getRangeFromSheetXC(e,t);return this.getRangeDataFromZone(o.sheetId,o.unboundedZone)}getRangeDataFromZone(e,t){return{_sheetId:e,_zone:t=this.getters.getUnboundedZone(e,t)}}getRangeData(e){return this.getRangeDataFromZone(e.sheetId,e.unboundedZone)}getRangeFromZone(e,t){return pa({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=>e.unboundedZone)),s=t.map((e=>e.unboundedZone));return nr(o,s).map((t=>this.getRangeFromZone(e[0].sheetId,t)))}getRangeFromRangeData(e){if(!this.getters.tryGetSheet(e._sheetId))return fa(ti.InvalidReference);return pa({prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]},this.getters.getSheetSize)}isRangeValid(e){if(!e)return!1;const{xc:t,sheetName:o}=ra(e);return null!==t.match(ta)&&(!o||void 0!==this.getters.getSheetIdByName(o))}getRangesUnion(e){const t=e.map((e=>e.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)}adaptFormulaStringDependencies(e,t,o){if(!t.startsWith("="))return t;const s=HS(t),i=s.dependencies.map((t=>{const s=this.getters.getRangeFromSheetXC(e,t),i=o(s);return"NONE"===i.changeType?s:i.range}));return this.getters.getFormulaString(e,s.tokens,i)}copyFormulaStringForSheet(e,t,o,s){if(!o.startsWith("="))return o;const i=HS(o),n=i.dependencies.map((o=>{const i=this.getters.getRangeFromSheetXC(e,o);return"keepSameReference"===s?i:Ca(e,t,i)}));return this.getters.getFormulaString(t,i.tokens,n)}}function zk(e,t){if(!e)return;const o=t(e);switch(o.changeType){case"NONE":return e;case"REMOVE":return;default:return o.range}}class $k extends Mk{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}}const Gk=new n;Gk.add("pivots",(e=>{for(const t of e.getPivotIds()){const o=e.getPivot(t);o.markAsDirtyForEvaluation?.()}}));const Wk=RS.mapping;function qk(e,t,o){return new Zk(e,t,o).getParameters()}class Zk{getters;computeCell;evalContext;rangeCache={};constructor(e,t,o){this.getters=t,this.computeCell=o,this.evalContext=Object.assign(Object.create(Wk),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:aa(this.getters.getSheetName(e.sheetId),fr(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=wr(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 pr(e.zone)?e.invalidSheetName?new si(Ho("Invalid sheet name: %s",e.invalidSheetName)):void 0:new ri}}function jk(e,t,o,s,i){Yk(e,t,o||0,s||e.length-1,i||Kk)}function Yk(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);Yk(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(Xk(e,o,t),i(e[s],h)>0&&Xk(e,o,s);d<u;){for(Xk(e,d,u),d++,u--;i(e[d],h)<0;)d++;for(;i(e[u],h)>0;)u--}0===i(e[o],h)?Xk(e,o,u):Xk(e,++u,s),u<=t&&(o=u+1),t<=u&&(s=u-1)}}function Xk(e,t,o){var s=e[t];e[t]=e[o],e[o]=s}function Kk(e,t){return e<t?-1:e>t?1:0}class Jk{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(!cV(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;cV(e,a)&&(t.leaf?o.push(r):lV(e,a)?this._all(r,o):i.push(r))}t=i.pop()}return o}collides(e){let t=this.data;if(!cV(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(cV(e,n)){if(t.leaf||lV(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=hV([]),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=Qk(e,o.children,t);if(-1!==s)return o.children.splice(s,1),i.push(o),this._condense(i),this}l||o.leaf||!lV(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=hV(e.slice(t,o+1)),eV(n,this.toBBox),n;s||(s=Math.ceil(Math.log(i)/Math.log(r)),r=Math.ceil(i/Math.pow(r,s-1))),n=hV([]),n.leaf=!1,n.height=s;const a=Math.ceil(i/r),l=a*Math.ceil(Math.sqrt(r));dV(e,t,o,l,this.compareMinX);for(let i=t;i<=o;i+=l){const t=Math.min(i+l-1,o);dV(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 eV(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=nV(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),oV(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=hV(o.children.splice(n,o.children.length-n));r.height=o.height,r.leaf=o.leaf,eV(o,this.toBBox),eV(r,this.toBBox),t?e[t-1].children.push(r):this._splitRoot(o,r)}_splitRoot(e,t){this.data=hV([e,t]),this.data.height=e.height+1,this.data.leaf=!1,eV(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=tV(e,0,r,this.toBBox),a=tV(e,r,o,this.toBBox),l=aV(t,a),c=nV(t)+nV(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:sV,i=e.leaf?this.compareMinY:iV;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=tV(e,0,t,i),r=tV(e,o-t,o,i);let a=rV(n)+rV(r);for(let s=t;s<o-t;s++){const t=e.children[s];oV(n,e.leaf?i(t):t),a+=rV(n)}for(let s=o-t-1;s>=t;s--){const t=e.children[s];oV(r,e.leaf?i(t):t),a+=rV(r)}return a}_adjustParentBBoxes(e,t,o){for(let s=o;s>=0;s--)oV(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():eV(e[o],this.toBBox)}}function Qk(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 eV(e,t){tV(e,0,e.children.length,t,e)}function tV(e,t,o,s,i){i||(i=hV(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];oV(i,e.leaf?s(t):t)}return i}function oV(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 sV(e,t){return e.minX-t.minX}function iV(e,t){return e.minY-t.minY}function nV(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function rV(e){return e.maxX-e.minX+(e.maxY-e.minY)}function aV(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 lV(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function cV(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function hV(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function dV(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;jk(e,r,t,o,i),n.push(t,r,r,o)}}class uV{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 gV,this.rTrees[e].load(t[e])}insert(e){const t=e.boundingBox.sheetId;this.rTrees[t]||(this.rTrees[t]=new gV),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.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&&mt(e.data,t.data)}}class gV extends Jk{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 pV{createEmptyPositionSet;dependencies=new $D;rTree;constructor(e,t=[]){this.createEmptyPositionSet=e,this.rTree=new uV(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(Mr(e)));for(const e in r){const t=nr(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 mV 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 fV{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]=mV.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 vV{resultsToArrayFormulas=new uV;arrayFormulasToResults=new $D;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map((e=>e.data))||bV}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:Mr(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 bV=[],SV=Object.freeze(Jn(new ni)),CV=Object.freeze(Jn({value:null}));class yV{context;getters;compilationParams;evaluatedCells=new $D;formulaDependencies=ut(new pV(this.createEmptyPositionSet.bind(this)));blockedArrayFormulas=new fV({});spreadingRelations=new vV;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=qk(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||CV}getSpreadZone(e,t={ignoreSpillError:!1}){const o=this.spreadingRelations.getArrayResultZone(e);if(!o)return;const s=this.evaluatedCells.get(e);return s?.type!==_s.error||t.ignoreSpillError&&s?.value===ti.SpilledBlocked?yr(Mr(e),o):Mr(e)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(this.getEvaluatedCell(e).type===_s.empty)return;const t=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,Mr(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=qk(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.updateDependencies=this.updateDependencies.bind(this),this.compilationParams.evalContext.addDependencies=this.addDependencies.bind(this),this.compilationParams.evalContext.lookupCaches={forwardSearch:new Map,reverseSearch:new Map}}createEmptyPositionSet(){const e={};for(const t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new fV(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=Dr(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 vV,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 pV(this.createEmptyPositionSet.bind(this),e)}))}evaluateAllCells(){const e=performance.now();this.evaluatedCells=new $D,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=xV(t,this.compilationParams,e,this.buildSafeGetSymbolValue(o),this.compilationParams.evalContext.__originCellPosition);return js(s)?ki(s,IV):IV(s)}catch(e){return TS(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 fV({});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!==CV&&this.evaluatedCells.set(o,s)}Gk.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 CV;const s=o.id,i={format:o.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(s)?SV:(this.cellsBeingComputed.add(s),o.isFormula?this.computeFormulaCell(e,o):Xn(o,i))}catch(e){return e.value=e?.value||ti.GenericError,e.message=e?.message||DS,Jn(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=xV(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!js(o)){const s=Jn(IV(o),this.getters.getLocale(),t);return s.type===_s.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),wV(s,i,this.checkCollision(e)),wV(s,i,this.spreadValues(e,o)),this.invalidatePositionsDependingOnSpread(e.sheetId,n),Jn(IV(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===Lr(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 ci(Ho("Result couldn't be automatically expanded. Please insert more rows."));if(a)throw new ci(Ho("Result couldn't be automatically expanded. Please insert more columns."));throw new ci(Ho("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 ci(Ho("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!==_s.empty)throw this.blockedArrayFormulas.add(e),new ci(Ho("Array result was not expanded because it would overwrite data in %s.",Po(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=Jn(IV(s[i][n]),this.getters.getLocale(),a);l.type===_s.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 SV;this.symbolsBeingComputed.add(t);try{const o=e?.(t);return o||new ii(Ho("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=Dr(e);for(const e in o)t.push(...o[e].map((t=>({sheetId:e,zone:t}))));return this.formulaDependencies().getCellsDependingOn(t)}}function wV(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 IV(e){return null===e.value||void 0===e.value?{...e,value:0}:e}function xV(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 EV=/"(#[0-9a-fA-F]{6})"/g;const RV={isValid:!0};const TV=new n;function AV(e,t){const o=t.model.getters.getPivotCellFromPosition(e),s=t.model.getters.getPivotIdFromPosition(e);if(!s||"HEADER"!==o.type)return;const i=t.model.getters.getPivotCoreDefinition(s),n=i.collapsedDomains?.[o.dimension]?[...i.collapsedDomains[o.dimension]]:[],r=n.findIndex((e=>mt(e,o.domain)));-1!==r?n.splice(r,1):n.push(o.domain);const a=i.collapsedDomains?{...i.collapsedDomains}:{COL:[],ROW:[]};a[o.dimension]=n,t.model.dispatch("UPDATE_PIVOT",{pivotId:s,pivot:{...i,collapsedDomains:a}})}TV.add("data_validation_checkbox",((e,t)=>{if(e.isCellValidCheckbox(t)){const o=!!e.getEvaluatedCell(t).value;return{svg:o?jR:qR,hoverSvg:o?jR:ZR,priority:2,horizontalAlign:"center",size:17,margin:2,position:t,type:"data_validation_checkbox",onClick:(e,t)=>{const s=t.model.getters.getCell(e);if(t.model.getters.isReadonly()||!!s?.isFormula)return;const i=o?"FALSE":"TRUE";t.model.dispatch("UPDATE_CELL",{...e,content:i})}}}})),TV.add("data_validation_chip_icon",((e,t)=>{const o=e.getDataValidationChipStyle(t);if(o){const s=e.getCellComputedStyle(t);return{svg:GR(o),hoverSvg:WR(o),priority:10,horizontalAlign:"right",size:$a(s),margin:4,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_chip_icon"}}})),TV.add("data_validation_list_icon",((e,t)=>{if(!e.isReadonly()&&e.cellHasListDataValidationIcon(t)){const s=e.getCellComputedStyle(t);return{svg:(o=s,{name:"CARET_DOWN",width:512,height:512,paths:[{fillColor:o.textColor||N,path:"M120 195 h270 l-135 130"}]}),hoverSvg:zR(s),priority:2,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const{col:o,row:s}=e;t.model.selection.selectCell(o,s),t.startCellEdition()},type:"data_validation_list_icon"}}var o})),TV.add("filter_icon",((e,t)=>{if(e.isFilterHeader(t)){const o=e.isFilterActive(t),s=jt(e.getCellComputedStyle(t).fillColor||"#fff")<.45;return{type:"filter_icon",svg:XR(o,s,!1),hoverSvg:XR(o,s,!0),priority:3,horizontalAlign:"right",size:17,margin:2,position:t,onClick:(e,t)=>{const o=t.getStore(jx),s=o.persistentCellPopover;s.isOpen&&s.col===e.col&&s.row===e.row&&"FilterMenu"===s.type?o.close():o.open(e,"FilterMenu")}}}})),TV.add("conditional_formatting",((e,t)=>{const o=e.getConditionalIcon(t);if(o){const s=e.getCellStyle(t);return{type:"conditional_formatting",svg:KR[o].svg,priority:1,horizontalAlign:"left",size:$a(s),margin:4,position:t}}})),TV.add("pivot_collapse",((e,t)=>{if(!e.isSpillPivotFormula(t))return;const o=e.getPivotCellFromPosition(t),s=e.getPivotIdFromPosition(t);if("HEADER"===o.type&&s&&o.domain.length){const i=e.getPivotCoreDefinition(s),n=e.isDashboard(),r="COL"===o.dimension?i.columns:i.rows,a=!n&&o.domain.length!==r.length,l=(i.collapsedDomains?.[o.dimension]??[]).some((e=>mt(e,o.domain))),c="ROW"===o.dimension?15*(o.domain.length-1):0;return{type:"pivot_collapse",priority:4,horizontalAlign:"left",size:a||!n&&"ROW"===o.dimension&&i.rows.length>1?12:0,margin:a?4+c:c,svg:a?YR(l,!1):void 0,hoverSvg:a?YR(l,!0):void 0,position:t,onClick:AV}}}));const DV="0.00%";function _V(e){return class extends e{getters;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t){super(e,t),this.getters=t.getters}markAsDirtyForEvaluation(){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.markAsDirtyForEvaluation?.()}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(e.aggregator&&o.length+s.length!==t.length){const o=this.getValuesToAggregate(e,t),s=Nc[e.aggregator];if(!s)return{value:0};try{return s([o],this.getters.getLocale())}catch(t){return TS(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}=NO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new ai:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}if(s.find((t=>t.nameWithGranularity===e))){const{rowDomain:o}=NO(this,t),s=o.findIndex((t=>t.field===e));return-1===s?new ai:this.getPivotHeaderValueAndFormat(o.slice(0,s+1))}return this.getPivotCellValueAndFormat(e,t)}));return js(n)?n[0][0]:n}getValuesToAggregate(e,t){const{rowDomain:o,colDomain:s}=NO(this,t),i=super.getExpandedTableStructure(),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}if(o.length===this.definition.rows.length&&s.length&&s.length<this.definition.columns.length){const t=this.getSubTreeMatchingDomain(i.getColTree(),s),r=this.treeToLeafDomains(t,s);for(const t of r)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=Gc(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[]}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:ti.NotAvailable,message:Ho('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 TS(e,"COMPUTE_MEASURE_DISPLAY_VALUE")}}asPercentOfGrandTotal(e,t){const o=this.getGrandTotal(t.id);return 0===o?{value:ti.DivisionByZero}:{value:this.measureValueToNumber(e)/o,format:DV}}asPercentOfRowTotal(e,t,o){const s=this.getRowTotal(t.id,o);return 0===s?{value:ti.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:DV}}asPercentOfColumnTotal(e,t,o){const s=this.getColumnTotal(t.id,o);return 0===s?{value:ti.DivisionByZero}:{value:this.measureValueToNumber(e)/s,format:DV}}asPercentOfParentRowTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=NO(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:DV}}asPercentOfParentColumnTotal(e,t,o){const s=function(e,t){const{colDomain:o,rowDomain:s}=NO(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:DV}}asPercentOfParentTotal(e,t,o,s){const{fieldNameWithGranularity:i}=s;if(!i)return e;if(!UO(i,o))return{value:""};const n=function(e,t,o){let{rowDomain:s,colDomain:i}=NO(e,o);if("row"===BO(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:DV}}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:ti.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}=NO(this,o),h=zO(c),d=zO(l),u=a[h]?.[d];return{value:u??"",format:"running_total"===i?e.format:DV}}asPercentOf(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!UO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r||"sameValue"===r&&0===a?{value:ti.DivisionByZero}:!r||"sameValue"===r&&!a?{value:""}:"sameValue"===r?{value:1,format:DV}:void 0===a?{value:ti.NullError}:{value:a/r,format:DV}}asDifferenceFrom(e,t,o,s){const{fieldNameWithGranularity:i,value:n}=s;if(void 0===n||!i)return e;if(!UO(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(!UO(i,o))return{value:""};const r=this.getComparisonValue(t,o,i,n),a=this.strictMeasureValueToNumber(e);return 0===r?{value:ti.DivisionByZero}:r&&"sameValue"!==r?void 0===a?{value:ti.NullError}:{value:(a-r)/r,format:DV}:{value:""}}asRank(e,t,o,s,i){const{fieldNameWithGranularity:n}=s;if(!n)return e;if(!UO(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}=NO(this,o),h=zO(c),d=zO(l),u=a[h]?.[d];return{value:u??""}}computeRank(e,t,o){const s={},i=BO(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Vi(r));for(const a of r){const r=zO(kO(this,n,a[0].domain)),l=a.map((t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:kO(this,i,t.domain)}))).filter((e=>UO(t,e.rowDomain))),c=Object.groupBy(l,(e=>GO(e.rowDomain,t)));for(const e in c)c[e]=Nt(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=zO(kO(this,i,e.domain)),n=c[GO(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:kt(s)}computeRunningTotal(e,t,o){const s={},i=BO(this,t),n="row"===i?"column":"row";let r=this.getPivotValueCells(e.id);"column"===i&&(r=Vi(r));for(const a of r){const r=zO(kO(this,n,a[0].domain));s[r]={};const l={},c=a.map((t=>({...t,rowDomain:kO(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))}))).filter((e=>UO(t,e.rowDomain)));for(const e of c){const o=zO(e.rowDomain),i=WO(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=zO(o),n=WO(o,t),a=s[r][i]||0,c=l[n];s[r][i]=c?a/c:void 0}}return"row"===i?s:kt(s)}getGrandTotal(e){const t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){const o=NO(this,t).rowDomain,s=this._getPivotCellValueAndFormat(e,o);return this.measureValueToNumber(s)}getColumnTotal(e,t){const o=NO(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===PO||s===MO?function(e,t,o,s){const i=BO(e,o),n="row"===i?e.getExpandedTableStructure().getRowTree():e.getExpandedTableStructure().getColTree(),r=LO(kO(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 HO(t,o,a[Ze(c+(s===PO?-1:1),0,a.length-1)])}(this,t,o,s):HO(t,o,s);if(mt(i,t))return"sameValue";if(!i||!function(e,t){for(const o of t)if(void 0===e.definition.rows.find((e=>e.nameWithGranularity===o.field))&&void 0===e.definition.columns.find((e=>e.nameWithGranularity===o.field)))return!1;const{rowDomain:o,colDomain:s}=NO(e,t);return VO(o,e.getExpandedTableStructure().getRowTree())&&VO(s,e.getExpandedTableStructure().getColTree())}(this,i))throw new ai;const n=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(n)}getPivotValueCells(e){return this.getCollapsedTableStructure().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`)}getCollapsedTableStructure(){const e=super.getCollapsedTableStructure();return this.sortTableStructure(e),e}getExpandedTableStructure(){const e=super.getExpandedTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;const t=this.definition.sortedColumn.measure;Kc(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,((e,t)=>this._getPivotCellValueAndFormat(e,t)))}}}const OV=["ADD_PIVOT","UPDATE_PIVOT","REMOVE_PIVOT"];function FV(e){return OV.includes(e.type)}const PV=new n;PV.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=In(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=Ri(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=ps(s);e.current=i;const n=o.getLocale(),r=In(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?Xn(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 MV=new n,NV=/(\d+)$/,kV=/^(.*\D+)/,VV=/^(.*\D+)(\d+)$/;function LV(e,t,o){let s=[],i=!1;for(const n of t){n===e&&(i=!0);const t=void 0===n||n.isFormula?void 0:Xn(n,{locale:qs,format:n.format});if(t&&o(t))s.push(t);else{if(i)return s;s=[]}}return s}function HV(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 UV(e){if(e.length<2)return 1;const t=e.map((e=>Ri(e,qs))),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=Yo.fromTimestamp(e[o-1].getTime()),i=ws(s,t),n=Cs(s,t)%12;s.setFullYear(s.getFullYear()+i),s.setMonth(s.getMonth()+n);return{years:i,months:n,days:ys(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}}MV.add("simple_value_copy",{condition:(e,t)=>!(1!==t.length||e.isFormula||e.format&&On(e.format)),generateRule:()=>({type:"COPY_MODIFIER"}),sequence:10}).add("increment_alphanumeric_value",{condition:e=>!e.isFormula&&Xn(e,{locale:qs}).type===_s.text&&VV.test(e.content),generateRule:(e,t,o)=>{const s=parseInt(e.content.match(NV)[0]),i=e.content.match(kV)[0],n=e.content.length-i.length,r=LV(e,t,(e=>e.type===_s.text&&VV.test(e.value))).filter((e=>i===(e.value??"").toString().match(kV)[0])).map((e=>parseInt((e.value??"").toString().match(NV)[0])));let a=HV(r);return["up","left"].includes(o)&&1===r.length&&(a=-a),{type:"ALPHANUMERIC_INCREMENT_MODIFIER",prefix:i,current:s,increment:a,numberPostfixLength:n}},sequence:15}).add("copy_text",{condition:e=>!e.isFormula&&Xn(e,{locale:qs}).type===_s.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&&Xn(e,{locale:qs}).type===_s.number&&!!e.format&&On(e.format),generateRule:(e,t)=>{const o=UV(LV(e,t,(e=>e.type===_s.number&&!!e.format&&On(e.format))).map((e=>Number(e.value))));if(void 0===o)return{type:"COPY_MODIFIER"};const s=Xn(e,{locale:qs});return"object"==typeof o?{type:"DATE_INCREMENT_MODIFIER",increment:o,current:s.type===_s.number?s.value:0}:{type:"INCREMENT_MODIFIER",increment:o,current:s.type===_s.number?s.value:0}},sequence:25}).add("increment_number",{condition:e=>!e.isFormula&&Xn(e,{locale:qs}).type===_s.number,generateRule:(e,t,o)=>{const s=LV(e,t,(e=>e.type===_s.number&&!On(e.format||""))).map((e=>Number(e.value)));let i=HV(s);["up","left"].includes(o)&&1===s.length&&(i=-i);const n=Xn(e,{locale:qs});return{type:"INCREMENT_MODIFIER",increment:i,current:n.type===_s.number?n.value:0}},sequence:40});class BV extends Mk{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 zV{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}=PV.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}}}}const $V=new class extends n{addTransformation(e,t,o){this.content[e]||(this.content[e]=new Map);for(const s of t)this.content[e].set(s,o);return this}getTransformation(e,t){return this.content[t]&&this.content[t].get(e)}};const GV=new class extends n{add(e,t){return super.add(e,t),this}replace(e,t){return super.replace(e,t),this}get(e){return this.content[e]}};function WV(e,t){if("SPREADSHEET"!==e.pivot.type)return e;if(e.pivot.dataSet?.sheetId!==t.sheetId)return e;const o=th(e.pivot.dataSet.zone,t),s=o?{...e.pivot.dataSet,zone:o}:void 0;return{...e,pivot:{...e.pivot,dataSet:s}}}function qV(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(const 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 ZV(e,t){if(e.sheetId!==t.sheetId)return e;const o=th(e.zone,t);if(!o)return;const s=e.newTableRange?oh(e.newTableRange,t):void 0;return{...e,newTableRange:s,zone:o}}function jV(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let o;if("REMOVE_COLUMNS_ROWS"===t.type)o=ha(t.elements,[e.base])[0];else if("ADD_COLUMNS_ROWS"===t.type){o=ca(pt(t.position,t.base),t.quantity,[e.base])[0]}return void 0!==o?{...e,base:o}:void 0}function YV(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;const o=je(e.start,e.end+1);let s=[];if("REMOVE_COLUMNS_ROWS"===t.type)s=ha(t.elements,o);else if("ADD_COLUMNS_ROWS"===t.type){s=ca(pt(t.position,t.base),t.quantity,o)}return 0!==s.length?{...e,start:Math.min(...s),end:Math.max(...s)}:void 0}function XV(e,t){return(e=ze(e)).pivot.measures.map((e=>{e.computedBy&&(e.computedBy.formula=WS(e.computedBy.sheetId,e.computedBy.formula,t))})),e}function KV(e,t){return{...e,definition:hx(e.sheetId,e.definition,t)}}$V.addTransformation("ADD_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],jV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_COLUMNS_ROWS"],jV),$V.addTransformation("DELETE_SHEET",["MOVE_RANGES"],(function(e,t){const o=t.sheetId;if(e.targetSheetId===o||e.sheetId===o)return;return e})),$V.addTransformation("DELETE_FIGURE",["UPDATE_FIGURE","UPDATE_CHART"],(function(e,t){if(e.figureId===t.figureId)return;return e})),$V.addTransformation("CREATE_SHEET",["CREATE_SHEET"],(function(e,t){e.sheetId===t.sheetId&&(e={...e,sheetId:`${e.sheetId}~`});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})),$V.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)t.target.every((e=>!xr(s,e)))&&o.push(s);if(o.length)return{...e,target:o};return})),$V.addTransformation("ADD_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],qV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["FREEZE_COLUMNS","FREEZE_ROWS"],qV),$V.addTransformation("ADD_COLUMNS_ROWS",["UPDATE_TABLE"],ZV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["UPDATE_TABLE"],ZV),$V.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:wR.styleId}}})),$V.addTransformation("ADD_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],YV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["GROUP_HEADERS","UNGROUP_HEADERS","FOLD_HEADER_GROUP","UNFOLD_HEADER_GROUP"],YV),$V.addTransformation("REMOVE_PIVOT",["RENAME_PIVOT","DUPLICATE_PIVOT","INSERT_PIVOT","UPDATE_PIVOT"],(function(e,t){if(e.pivotId===t.pivotId)return;return e})),$V.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})),$V.addTransformation("ADD_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],WV),$V.addTransformation("REMOVE_COLUMNS_ROWS",["ADD_PIVOT","UPDATE_PIVOT"],WV),GV.add("UPDATE_CELL",(function(e,t){const o=e.content&&WS(e.sheetId,e.content,t);return{...e,content:o}})),GV.add("ADD_CONDITIONAL_FORMAT",(function(e,t){const o=e.cf.rule;if(e={...e,cf:{...e.cf}},"CellIsRule"===o.type)e.cf.rule={...o,values:o.values.map((o=>WS(e.sheetId,o,t)))};else if("ColorScaleRule"===o.type){const{minimum:s,maximum:i,midpoint:n}=o;e.cf.rule={...o,minimum:{...s,value:s.value&&WS(e.sheetId,s.value,t)},maximum:{...i,value:i.value&&WS(e.sheetId,i.value,t)},midpoint:n?{...n,value:WS(e.sheetId,n.value,t)}:void 0}}else if("IconSetRule"===o.type){const{upperInflectionPoint:s,lowerInflectionPoint:i}=o;e.cf.rule={...o,upperInflectionPoint:{...s,value:WS(e.sheetId,s.value,t)},lowerInflectionPoint:{...i,value:WS(e.sheetId,i.value,t)}}}else"DataBarRule"===o.type&&(e.cf.rule={...o,rangeValues:o.rangeValues?qS(e.sheetId,o.rangeValues,t):void 0});return e})),GV.add("ADD_DATA_VALIDATION_RULE",(function(e,t){return(e={...e,rule:{...e.rule,criterion:{...e.rule.criterion}}}).rule.criterion.values=e.rule.criterion.values.map((o=>WS(e.sheetId,o,t))),e})),GV.add("ADD_PIVOT",XV),GV.add("UPDATE_PIVOT",XV),GV.add("CREATE_CHART",KV),GV.add("UPDATE_CHART",KV);const JV=[{match:function(e){return"sheetId"in e},fn:tL},{match:function(e){return"target"in e&&"sheetId"in e},fn:function(e,t){const o=tL(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=[];for(const o of e.target){const e=th(o,t);e&&s.push(e)}if(!s.length)return"IGNORE_COMMAND";return{...e,target:s}}},{match:function(e){return"sheetId"in e&&"zone"in e},fn:function(e,t){const o=tL(e,t);if("SKIP_TRANSFORMATION"!==o)return"IGNORE_COMMAND"===o?"IGNORE_COMMAND":e;const s=th(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=tL(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(const 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)&&Er(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=tL(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=ha(t.elements,e.elements);else if("ADD_COLUMNS_ROWS"===t.type){s=ca(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=>oh(e,t))).filter(lt);if(!o.length)return"IGNORE_COMMAND";return{...e,ranges:o}}}];function QV(e,t){const o=$V.getTransformation(e.type,t.type),s=o?o(e,t):function(e,t){for(const{match:o,fn:s}of JV)if(o(e)){const o=s(e,t);if("SKIP_TRANSFORMATION"===o)continue;if("IGNORE_COMMAND"===o)return;e=o}return e}(e,t);return s?function(e,t){const o=GV.get(e.type);if(!o)return e;const s=Ia(t);if(s)return o(e,s);return e}(s,t):s}function eL(e,t){let o=[...e];const s=new Set($V.getKeys());for(const e of t)(s.has(e.type)||xa.contains(e.type))&&(o=o.reduce(((t,o)=>{const s=QV(o,e);return s&&t.push(s),t}),[]));return o}function tL(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 oL{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 sL extends Error{}class iL extends sh{revisions;transportService;serverRevisionId;clients={};clientId="local";debouncedMove;pendingMessages=[];awaitingClientPosition;waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new Ka;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 oL(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)),this.awaitingClientPosition&&(this._move(this.awaitingClientPosition),this.awaitingClientPosition=void 0)}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})}getCurrentClient(){return this.getClient(this.clientId)}getClient(e){const t=this.clients[e];if(!t)throw new sL("The client left the session");return t}getConnectedClients(){return new Set(Object.values(this.clients).filter(lt))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return 0===this.pendingMessages.length}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return void(this.awaitingClientPosition=e);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.getCurrentClient();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 oL(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:eL(o,t)})}break;case"SNAPSHOT_CREATED":{const t=new oL(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){let t=this.revisions.get(e.nextRevisionId);0===t.commands.length&&(this.revisions.rebase(t.id),t=this.revisions.get(e.nextRevisionId)),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"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();break;case"REVISION_UNDONE":{this.waitingAck=!1,this.pendingMessages=this.pendingMessages.filter((t=>t.nextRevisionId!==e.nextRevisionId));const t=this.pendingMessages.findIndex((e=>"REMOTE_REVISION"===e.type));-1!==t&&this.revisions.rebase(this.pendingMessages[t].nextRevisionId),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.sendPendingMessage();break}}}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 nL=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 rL(e){return nL.has(e.type)}const aL=[lL,function(e,t){return"target"in t&&Array.isArray(t.target)?{...ze(t),target:e.getSelectedZones()}:t},hL,function(e,t){return"ranges"in t?{...ze(t),ranges:e.getSelectedZones().map((t=>e.getRangeDataFromZone(e.getActiveSheetId(),t)))}:t}];function lL(e,t){return"sheetId"in t?{...ze(t),sheetId:e.getActiveSheetId()}:t}function cL(e,t){return"zone"in t?{...ze(t),zone:e.getSelectedZone()}:t}function hL(e,t){if(!("row"in t)||!("col"in t))return t;const{col:o,row:s}=e.getActivePosition();return{...ze(t),col:o,row:s}}const dL=new Ka;function uL(e,t){const o=e.getSelectedZone();return{...lL(e,t),elements:"COL"===t.dimension?je(o.left,o.right+1):je(o.top,o.bottom+1)}}function gL(e,t){const o=e.getSelectedZone();return{...ze(t),zone:o}}function pL(e,t){const o=ze(t),s=e.getSelectedZone(),{top:i,bottom:n,left:r,right:a}=s;return"cols"in o?o.cols=je(r,a+1):"rows"in o&&(o.rows=je(i,n+1)),o}function mL(e,t){const o=e.getSelectedZone();return{...lL(e,t),start:"COL"===t.dimension?o.left:o.top,end:"COL"===t.dimension?o.right:o.bottom}}const fL=new n;fL.add("UPDATE_CELL",bL),fL.add("CLEAR_CELL",bL),fL.add("CLEAR_CELLS",bL),fL.add("DELETE_CONTENT",bL),fL.add("ADD_MERGE",bL),fL.add("REMOVE_MERGE",bL),fL.add("SET_FORMATTING",bL),fL.add("CLEAR_FORMATTING",bL),fL.add("SET_BORDER",bL),fL.add("CREATE_TABLE",bL),fL.add("REMOVE_TABLE",bL),fL.add("HIDE_SHEET",bL),fL.add("ADD_COLUMNS_ROWS",(function(e,t){const o=e.getActivePosition();return{...lL(e,t),base:"COL"===t.dimension?o.col:o.row}})),fL.add("REMOVE_COLUMNS_ROWS",uL),fL.add("HIDE_COLUMNS_ROWS",uL),fL.add("RESIZE_COLUMNS_ROWS",uL),fL.add("CREATE_SHEET",(function(e,t){const o=ze(t);o.sheetId=dL.smallUuid();const s=t.name||e.getSheet(e.getActiveSheetId()).name,i=s.match(/(.+?)\d*$/)?.[1]||s;return o.name=e.getNextSheetName(i),o})),fL.add("CREATE_FIGURE",(function(e,t){const o=hL(e,lL(e,t));return o.figureId=dL.smallUuid(),o})),fL.add("CREATE_CHART",(function(e,t){return{...lL(e,t),figureId:dL.smallUuid()}})),fL.add("CREATE_IMAGE",(function(e,t){return{...lL(e,t),figureId:dL.smallUuid()}})),fL.add("GROUP_HEADERS",mL),fL.add("UNGROUP_HEADERS",mL),fL.add("UNFOLD_HEADER_GROUPS_IN_ZONE",cL),fL.add("FOLD_HEADER_GROUPS_IN_ZONE",cL);const vL=new n;function bL(e,t){let o=ze(t);for(const t of aL)o=t(e,o);return o}function SL(e,t){if(e.rootCommand&&"object"==typeof e.rootCommand)return Hs(e.rootCommand)?function(e,t){if(!t)return;if(!fL.contains(t.type))return;return fL.get(t.type)(e,t)}(t,e.rootCommand):function(e,t,o){if(!vL.contains(t.type))return;return vL.get(t.type)(e,t,o)}(t,e.rootCommand,e.commands)}vL.add("PASTE",(function(e,t){return{type:"REPEAT_PASTE",pasteOption:ze(t.pasteOption),target:e.getSelectedZones()}})),vL.add("INSERT_CELL",gL),vL.add("DELETE_CELL",gL),vL.add("AUTORESIZE_COLUMNS",pL),vL.add("AUTORESIZE_ROWS",pL),vL.add("SORT_CELLS",(function(e,t){const o=e.getSelectedZone();return{...lL(e,t),col:o.left,row:o.top,zone:o}})),vL.add("SUM_SELECTION",bL),vL.add("SET_DECIMAL",bL),vL.add("DELETE_UNFILTERED_CONTENT",bL);class CL{trackedValues=new Set;domainToArray(e){return e.flatMap((e=>[e.field,wi(e.value)]))}isValuePresent(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});return this.trackedValues.has(o)}isHeaderPresent(e){const t=JSON.stringify({domain:this.domainToArray(e)});return this.trackedValues.has(t)}trackValue(e,t){const o=JSON.stringify({measure:e,domain:this.domainToArray(t)});this.trackedValues.add(o)}trackHeader(e){const t=JSON.stringify({domain:this.domainToArray(e)});this.trackedValues.add(t)}}const yL=5242880;const wL={filterType:"criterion",type:"none",values:[]};class IL{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}=this.getters.getColDimensions(this.sheetId,e),{end:s}=this.getters.getRowDimensions(this.sheetId,t);let i=o-this.offsetCorrectionX;this.canScrollHorizontally&&(i=Math.max(i,this.viewportWidth));let n=s-this.offsetCorrectionY;return this.canScrollVertically&&(n=Math.max(n,this.viewportHeight),s+he>n&&!this.getters.isReadonly()&&(n+=he)),{width:i,height:n}}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);Er(s,this.boundaries.top,this.boundaries)&&this.adjustPositionX(s),Er(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=wr(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=wr(e,this.boundaries),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 xL=(new n).add("settings",class extends Nk{static getters=["getLocale"];locale=qs;allowDispatch(e){return"UPDATE_LOCALE"===e.type?El(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===Hl(e)&&(o=Hl(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??qs}export(e){e.settings={locale:this.locale}}}).add("sheet",class extends Nk{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","getDuplicateSheetName"];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"DUPLICATE_SHEET":return this.sheets[e.sheetIdTo]?"DuplicatedSheetId":this.orderedSheetIds.map(this.getSheetName.bind(this)).includes(e.sheetNameTo)?"DuplicatedSheetName":"Success";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||Wt(e.color)?"Success":"InvalidColor";case"DELETE_SHEET":return this.getVisibleSheetIds().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=Pt(e.elements),o=Ft(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.newName);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,e.sheetNameTo);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(const t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(const 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:la(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(lt).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=$e(e);for(const e in this.sheetIdsMapName)if(ga(e,t))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(lt)}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 da(this.orderedSheetIds.map(this.getSheetName.bind(this)),e)}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,je(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&&void 0!==e.col&&"row"in e&&void 0!==e.row&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(pr))return"InvalidRange";if(t.length){const o=this.getSheetZone(e);return t.every((e=>Rr(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:la(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),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("There is not enough visible sheets")}checkSheetName(e){const t=this.getters.tryGetSheetName(e.sheetId),o="RENAME_SHEET"===e.type?e.newName:e.name;if(void 0!==t&&o===t)return"UnchangedSheetName";const{orderedSheetIds:s,sheets:i}=this,n=o&&o.trim().toLowerCase();return s.find((t=>ga(i[t]?.name,n)&&t!==e.sheetId))?"DuplicatedSheetName":_e.test(n)?"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(const 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(const o of t)if(o.left<e.quantity&&e.quantity<=o.right)return"MergeOverlap";return"Success"}isRenameAllowed(e){return e.newName&&e.newName.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,o){const s=ze(this.getSheet(e));s.id=t,s.name=o;for(let e=0;e<=s.numberOfCols;e++)for(let t=0;t<=s.rows.length;t++)s.rows[t]&&(s.rows[t].cells[e]=void 0);const i=this.orderedSheetIds.slice(),n=i.indexOf(e);i.splice(n+1,0,s.id),this.history.update("orderedSheetIds",i),this.history.update("sheets",Object.assign({},this.sheets,{[s.id]:s}));for(const t of Object.values(this.getters.getCells(e))){const{col:e,row:o}=this.getCellPosition(t.id);this.dispatch("UPDATE_CELL",{sheetId:s.id,col:e,row:o,content:t.content,format:t.format,style:t.style})}const r=Object.assign({},this.sheetIdsMapName);r[s.name]=s.id,this.history.update("sheetIdsMapName",r)}getDuplicateSheetName(e){return ua(e,this.orderedSheetIds.map(this.getSheetName.bind(this)))}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(const 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(const o of Ye(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(const 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(const 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(const 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(const 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(const 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(Fo);let o=e.rowNumber,s=e.colNumber;for(const{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?"ranges"in e&&e.ranges.some((e=>""!==e._sheetId&&!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkZonesExistInSheet(e.sheetId,this.getCommandZones(e)):"Success"}}).add("header grouping",class extends Nk{static getters=["getHeaderGroups","getGroupsLayers","getVisibleGroupLayers","getHeaderGroup","getHeaderGroupsInZone","isGroupFolded","isRowFolded","isColFolded"];groups={};allowDispatch(e){switch(e.type){case"GROUP_HEADERS":{const{start:t,end:o,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";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,sheetId:s}=e;if(!this.getters.tryGetSheet(s))return"InvalidSheetId";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":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";const t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return"UnknownHeaderGroup";if(je(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=ze(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;je(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]=ca(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=ha(o,je(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=MT(t,e,i);n.outlineLevel=s+1,o.isFolded&&(n.isHidden=!0)}if(o.isFolded){MT(t,e,o.end+1).collapsed=!0}}}}}}).add("header visibility",class extends Nk{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":Pt(e.elements)<0||Ft(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,ze(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(const 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=pt(e.position,e.base),o=Tt([...this.hiddenHeaders[e.sheetId][e.dimension]],Array(e.quantity).fill(!1),t);this.history.update("hiddenHeaders",e.sheetId,e.dimension,o);break}case"HIDE_COLUMNS_ROWS":for(const t of e.elements)this.history.update("hiddenHeaders",e.sheetId,e.dimension,t,!0);break;case"UNHIDE_COLUMNS_ROWS":for(const 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=je(0,this.getters.getNumberHeaders(e,t)),s=[];return this.getters.getHeaderGroups(e,t).forEach((e=>{e.isFolded&&s.push(...je(e.start,e.end+1))})),o.filter((o=>!this.hiddenHeaders[e][t][o]&&!s.includes(o)))}import(e){for(const 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(const 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 Nk{static getters=["getCoreTable","getCoreTables","getCoreTableMatchingTopLeft"];tables={};nextTableId=1;adaptRanges(e,t){for(const o of this.getCoreTables(t))this.applyRangeChangeOnTable(t,o,e)}allowDispatch(e){switch(e.type){case"CREATE_TABLE":if(e.ranges.some((t=>!this.getters.tryGetSheet(t._sheetId)||t._sheetId!==e.sheetId)))return"InvalidSheetId";const t=e.ranges.map((e=>this.getters.getRangeFromRangeData(e).zone));return Ur(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(xr(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);s.length&&this.dispatch("REMOVE_MERGE",{sheetId:e.sheetId,target:s});const i=this.consumeNextId(),n=e.config||wR,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=>!wr(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=>Rr(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(lt):[]}getCoreTable({sheetId:e,col:t,row:o}){return this.getCoreTables(e).find((e=>Er(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter((e=>t.some((t=>xr(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(let e=a.top;e<=a.bottom;e++)for(let o=a.left;o<=a.right;o++){const s={sheetId:t,col:o,row:e},i=this.getters.getCell(s)?.content;if(i||this.getters.isInMerge(s)||this.getTablesOverlappingZones(t,[Mr(s)]).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 je(n.left,n.right+1)){const t={...n,left:e,right:e},r=this.consumeNextId();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=Nr(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 je(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||this.consumeNextId();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,Nr(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 C_(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 C_(o.id,s,t.config,this.getters.getRangeFromZone)}));return{id:t.id,range:o,filters:s,config:ze(t.config),type:t.type}}copyDynamicTableForSheet(e,t){const o=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:o,config:ze(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=C_(e.id,o,t.config,this.getters.getRangeFromZone);n.push(i)}}const r=i.zone;if(n.length<Tr(r).numberOfCols){for(let o=r.left;o<=r.right;o++)if(!n.find((e=>e.col===o))){const s=this.consumeNextId(),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)}consumeNextId(){const e=`${this.nextTableId}`;return this.history.update("nextTableId",this.nextTableId+1),e}import(e){for(const t of e.sheets)for(const e of t.tables||[]){const o=this.consumeNextId(),s=e.config||wR,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:fr(e.range.zone),type:e.type};mt(e.config,wR)||(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=fr(e.range.zone);t.tables.push({range:o,filters:[],config:e.config})}}}).add("dataValidation",class extends Nk{static getters=["cellHasListDataValidationIcon","getDataValidationRule","getDataValidationRules","getValidationRuleForCell"];rules={};adaptRanges(e,t){this.adaptDVRanges(t,e),this.adaptDVFormulas(e)}adaptDVFormulas(e){for(const t in this.rules){for(let o=this.rules[t].length-1;o>=0;o--){const s=this.rules[t][o];for(let i=0;i<s.criterion.values.length;i++){const n=this.getters.adaptFormulaStringDependencies(t,s.criterion.values[i],e);this.history.update("rules",t,o,"criterion","values",i,n)}}}}adaptDVRanges(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.getters.tryGetSheet(e.sheetId)?e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":this.checkValidations(e,this.chainValidations(this.checkEmptyRange,this.checkValidRange,this.checkCriterionTypeIsValid,this.checkCriterionHasValidNumberOfValues,this.checkCriterionValuesAreValid)):"InvalidSheetId";case"REMOVE_DATA_VALIDATION_RULE":if(!this.getters.tryGetSheet(e.sheetId))return"InvalidSheetId";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=ze(this.rules[e.sheetId]).map((t=>({...t,ranges:t.ranges.map((t=>Ca(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=nr(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,Po(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(Er(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&&"chip"!==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,t.id),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,s){o=ze(o);for(const e of o)e.id!==s&&(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 wa(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={...ze(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 eE.contains(e.rule.criterion.type)?"Success":"UnknownDataValidationCriterionType"}checkCriterionHasValidNumberOfValues(e){const t=e.rule.criterion,o=eE.get(t.type).numberOfValues(t);return void 0!==o&&t.values.length!==o?"InvalidNumberOfCriterionValues":"Success"}checkCriterionValuesAreValid(e){const t=e.rule.criterion,o=eE.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 Nk{static getters=["zoneToXC","getCells","getTranslatedCellFormula","getCellStyle","getCellById","getFormulaString","getFormulaMovedInSheet"];nextId=1;cells={};adaptRanges(e,t,o){for(const s of Object.keys(this.cells))for(const i of Object.values(this.cells[s]||{}))if(i.isFormula)for(const n of i.compiledFormula.dependencies)if(n.sheetId===t||n.invalidSheetName===o.old){const t=e(n);"NONE"!==t.changeType&&this.history.update("cells",s,i.id,"compiledFormula","dependencies",i.compiledFormula.dependencies.indexOf(n),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);case"UPDATE_CELL_POSITION":return!e.cellId||this.cells[e.sheetId]?.[e.cellId]?"Success":"InvalidCellId";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);break;case"DELETE_SHEET":this.history.update("cells",e.sheetId,void 0)}}clearZones(e,t){for(const o of nr(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(const s of nr(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(const o of nr(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=je(e.base,e.base+e.quantity),s=e.base+e.quantity):(o=je(e.base+1,e.base+e.quantity+1),s=e.base),t(e.sheetId,s,o)}import(e){for(const t of e.sheets){const o=t.id,s=new $D;for(const e in t.cells)if(t.cells[e]){const{col:o,row:i}=Fo(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 qr(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(const 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=Po(s.col,s.row),l=this.removeDefaultStyleValues(r.style);if(Object.keys(l).length){const o=Gr(l,t);e[o]??=[],e[o].push(s)}if(r.format){const e=Gr(r.format,o);i[e]??=[],i[e].push(s)}r.content&&(n[a]=r.content)}s.styles=Wr(e),s.formats=Wr(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||[])jn(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(US(s).dependencies.map((t=>this.getters.getRangeFromSheetXC(e,t))),t,o,e);return this.getFormulaString(e,s,i)}getFormulaMovedInSheet(e,t,o){const s=US(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=Po((t=this.getters.expandZone(e,t)).left,t.top,o[0]),i=Po(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(const s of nr(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(const 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(const 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?It(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=Kn(t,i);return Yn(o=o||("number"==typeof n?Nn(t,i)||kn(t):void 0))||gi(t)||(t=wi(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 kk(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 Er(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 Nk{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(lt))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){this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map((t=>this.getMergeById(e,parseInt(t,10)))).filter(lt)}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(lt)}getSelectionRangeString(e,t){const o=this.getters.expandZone(e.sheetId,e.zone),s=pa({...e,zone:{...o,bottom:va(e)?void 0:o.bottom,right:ba(e)?void 0:o.right}},this.getters.getSheetSize),i=this.getters.getRangeString(s,t);if(this.isSingleCellOrMerge(e.sheetId,e.zone)){const{sheetName:e,xc:t}=ra(i);return aa(e,t.split(":")[0])}return i}doesIntersectMerge(e,t){for(const o of this.getMerges(e))if(xr(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){const{left:o,right:s,top:i,bottom:n}=t;let r={left:o,right:s,top:i,bottom:n};for(const t in this.merges[e]){const o=this.getMergeById(e,parseInt(t));o&&xr(o,r)&&(r=yr(o,r))}return Ir(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)&&Ir(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(const e of o)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(const 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 Ir(t,o);const{numberOfCols:s,numberOfRows:i}=Tr(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=Ze(s,0,this.getters.getNumberCols(e)-1),n=Ze(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?Uk(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&&xr(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);return Hr(t,o,s)?"FrozenPaneOverlap":"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||!Ir(e,i))return"InvalidTarget"}return"Success"}addMerge(e,t){let{left:o,right:s,top:i,bottom:n}=t;s=Ze(s,0,this.getters.getNumberCols(e)-1),n=Ze(n,0,this.getters.getNumberRows(e)-1);if(Po(o,i)===Po(s,n))return;const r=this.getters.getCell({sheetId:e,col:o,row:i}),a=this.nextId++;this.history.update("merges",e,a,this.getters.getRangeFromSheetXC(e,fr({left:o,top:i,right:s,bottom:n})));const 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(const 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&&Ir(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}=Tr(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 _r(t))this.history.update("mergeCellMap",e,o,s,t.id)}import(e){const t=e.sheets||[];for(const 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(const o of t)this.addMerge(e,ur(o))}export(e){for(const t of e.sheets){const e=this.merges[t.id];e&&t.merges.push(...Hk(e))}}exportForExcel(e){this.export(e)}}).add("headerSize",class extends Nk{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,ze(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=Rt(this.sizes[e.sheetId][e.dimension],e.elements);this.history.update("sizes",e.sheetId,e.dimension,t);break}case"ADD_COLUMNS_ROWS":{const t=this.sizes[e.sheetId][e.dimension],o=pt(e.position,e.base),s=t[e.base],i=Tt(t,Array(e.quantity).fill(s),o);this.history.update("sizes",e.sheetId,e.dimension,i);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]||se)}getUserRowSize(e,t){const o=this.sizes[e]?.ROW[t];return o?Math.round(o):void 0}import(e){for(const t of e.sheets){const e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(const[o,s]of Object.entries(t.rows))s.size&&(e.ROW[o]=s.size);for(const[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(const o of e.sheets){void 0===o.rows&&(o.rows={});for(const e of je(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)??ie});void 0===o.cols&&(o.cols={});for(const e of je(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 Nk{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=>ze(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_BORDERS_ON_TARGET":for(const t of e.target)for(let o=t.top;o<=t.bottom;o++)for(let s=t.left;s<=t.right;s++)this.setBorder(e.sheetId,s,o,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 Ye(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?ze(s):null}getBordersColors(e){const t=[],o=this.borders[e];if(o)for(const e of o.filter(lt))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=je(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(const o of s)this.addBorder(e,o,i,t)}}}ensureRowBorderContinuity(e,t,o){const s=je(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(const o of s)this.addBorder(e,i,o,t)}}}getCommonSides(e,t){const o={};for(const 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(lt);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]?je(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.borders[e]?.[t-1]?.[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.borders[e]?.[t]?.[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.borders[e]?.[t+1]?.[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.borders[e]?.[t]?.[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(const n of nr(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(const 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(const i of nr(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 qr(t.id,t.borders)){const{sheetId:t,col:i,row:n}=o,r=e.borders[s];this.setBorder(t,i,n,r,!1)}for(const t of e.sheets)if(t.merges)for(const e of t.merges)this.addBordersToMerge(t.id,ur(e))}export(e){const t={};for(const 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=Gr(n,t),a={sheetId:o.id,col:s,row:i};e[r]??=[],e[r].push(a)}}o.borders=Wr(e)}e.borders=t}exportForExcel(e){this.export(e)}}).add("conditional formatting",class extends Nk{static getters=["getConditionalFormats","getRulesSelection","getRulesByCell","getAdaptedCfRanges"];cfRules={};adaptCFFormulas(e){for(const t in this.cfRules)for(const o of this.cfRules[t])if("DataBarRule"===o.rule.type&&o.rule.rangeValues){const s=e(o.rule.rangeValues);switch(s.changeType){case"REMOVE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",void 0);break;case"RESIZE":case"MOVE":case"CHANGE":this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","rangeValues",s.range)}}else if("CellIsRule"===o.rule.type)for(let s=0;s<o.rule.values.length;s++)this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule","values",s,this.getters.adaptFormulaStringDependencies(t,o.rule.values[s],e));else if("IconSetRule"===o.rule.type)for(const s of["lowerInflectionPoint","upperInflectionPoint"])"formula"===o.rule[s].type&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,o.rule[s].value,e));else if("ColorScaleRule"===o.rule.type)for(const s of["minimum","maximum","midpoint"]){const i=o.rule[s];"formula"===i?.type&&i?.value&&this.history.update("cfRules",t,this.cfRules[t].indexOf(o),"rule",s,"value",this.getters.adaptFormulaStringDependencies(t,i.value,e))}}adaptCFRanges(e,t){for(const o of this.cfRules[e])for(const s of o.ranges){const i=t(s);switch(i.changeType){case"REMOVE":const 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){const o=t?[t]:Object.keys(this.cfRules);for(const t of o)this.adaptCFRanges(t,e);this.adaptCFFormulas(e)}allowDispatch(e){switch(e.type){case"ADD_CONDITIONAL_FORMAT":return e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId)))?"InvalidSheetId":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(const t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map((e=>this.mapToConditionalFormatInternal(t.id,e)))}export(e){if(e.sheets)for(const 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(const 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(const i of this.cfRules[e])for(const e of i.ranges)Er(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(dr));const a=nr(r,s);return nr([...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,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){const t=eE.get(e.operator).numberOfValues({type:e.operator,values:e.values});if(void 0===t||t>2)throw new Error("Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.");const o=[],s=e=>void 0===e||""===e;return t>=1&&s(e.values[0])&&o.push("FirstArgMissing"),t>=2&&s(e.values[1])&&o.push("SecondArgMissing"),o.length?o:"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&&Lk(t)>=Lk(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&&Lk(t)>=Lk(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&&Lk(t)>=Lk(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 Nk{static getters=["getFigures","getFigure","getFigureSheetId"];figures={};insertionOrders=[];adaptRanges(e,t){for(const o of this.getFigures(t)){const s=e(this.getters.getRangeFromZone(t,{left:o.col,right:o.col,top:o.row,bottom:o.row}));if("MOVE"===s.changeType)this.history.update("figures",t,o.id,"col",s.range.zone.right),this.history.update("figures",t,o.id,"row",s.range.zone.bottom);else if("REMOVE"===s.changeType){const s=e(this.getters.getRangeFromZone(t,{left:0,right:o.col-1,top:0,bottom:o.row-1}));let{offset:i,col:n,row:r}=o;"NONE"!==s.changeType&&(n=s.range.zone.right+1,r=s.range.zone.bottom+1),({offset:i,col:n,row:r}=this.getPositionInSheet(t,{...o,col:n,row:r})),this.history.update("figures",t,o.id,"offset",i),this.history.update("figures",t,o.id,"col",n),this.history.update("figures",t,o.id,"row",r)}}}allowDispatch(e){switch(e.type){case"CREATE_FIGURE":return this.checkValidations(e,this.checkFigureDuplicate,this.checkFigureAnchorOffset);case"UPDATE_FIGURE":return this.checkValidations(e,this.checkFigureExists,this.checkFigureAnchorOffset);case"DELETE_FIGURE":return this.checkFigureExists(e);default:return"Success"}}beforeHandle(e){if("DELETE_SHEET"===e.type)this.getters.getFigures(e.sheetId).forEach((t=>{this.dispatch("DELETE_FIGURE",{figureId: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":const t={id:e.figureId,col:e.col,row:e.row,offset:e.offset,width:e.size.width,height:e.size.height,tag:e.tag};this.addFigure(t,e.sheetId);break;case"UPDATE_FIGURE":this.updateFigure(e);break;case"DELETE_FIGURE":this.removeFigure(e.figureId,e.sheetId);break;case"REMOVE_COLUMNS_ROWS":"COL"===e.dimension?this.onColRemove(e.sheetId):this.onRowRemove(e.sheetId)}}onColRemove(e){const t=this.getters.getNumberCols(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+this.getters.getColSize(e,s);for(const t of this.getFigures(e))if(t.offset.x+t.width>o[t.col]){let s=t.offset.x,i=t.col;for(s=Math.min(s,o[i]-t.width);s<0&&i>0;)i--,s=o[i]-t.width;s!==t.offset.x&&this.history.update("figures",e,t.id,"offset",{x:Math.max(s,0),y:t.offset.y}),i!==t.col&&this.history.update("figures",e,t.id,"col",i)}}onRowRemove(e){const t=this.getters.getNumberRows(e),o=new Array(t+1);o[t]=0;for(let s=t-1;s>=0;s--)o[s]=o[s+1]+(this.getters.getUserRowSize(e,s)??ie);for(const t of this.getFigures(e))if(t.offset.y+t.height>o[t.row]){let s=t.offset.y,i=t.row;for(let t=this.getters.getUserRowSize(e,i)??ie;t<s;t=this.getters.getUserRowSize(e,i)??ie)i+=1,s-=t;for(s=Math.min(s,o[i]-t.height);s<0&&i>0;)i--,s=o[i]-t.height;s!==t.offset.y&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(0,s)}),i!==t.row&&this.history.update("figures",e,t.id,"row",i)}else t.offset.y+t.height>o[0]&&this.history.update("figures",e,t.id,"offset",{x:t.offset.x,y:Math.max(o[0]-t.height,0)})}getPositionInSheet(e,t){const{numberOfRows:o,numberOfCols:s}=this.getters.getSheetSize(e);let i,n,r=0,a=0,{col:l,row:c}=t;const h={...t.offset};for(i=o;r<t.height&&i>0;i--)r+=this.getters.getUserRowSize(e,i-1)??ie;for(c>i?(c=i,h.y=Math.max(r-t.height,0)):c===i&&(h.y=Ze(h.y,0,Math.max(r-t.height,0))),n=s;a<t.width&&n>0;n--)a+=this.getters.getColSize(e,n-1);return l>n?(l=n,h.x=Math.max(a-t.width,0)):n===l&&(h.x=Ze(h.x,0,Math.max(a-t.width,0))),{col:l,row:c,offset:h}}updateFigure(e){if(!("figureId"in e)||!("sheetId"in e))return;const{figureId:t,sheetId:o,...s}=e,i={...this.getFigure(o,t),...s};for(const[e,t]of Object.entries(s))switch(e){case"offset":this.history.update("figures",o,i.id,e,t);break;case"col":case"row":case"width":case"height":void 0!==t&&this.history.update("figures",o,i.id,e,t)}}addFigure(e,t){this.history.update("figures",t,e.id,e),this.history.update("insertionOrders",this.insertionOrders.length,e.id)}deleteSheet(e){this.history.update("insertionOrders",this.insertionOrders.filter((t=>!this.figures[e]?.[t]))),this.history.update("figures",e,void 0)}removeFigure(e,t){this.history.update("insertionOrders",this.insertionOrders.filter((t=>t!==e))),this.history.update("figures",t,e,void 0)}checkFigureExists(e){return void 0===this.figures[e.sheetId]?.[e.figureId]?"FigureDoesNotExist":"Success"}checkFigureDuplicate(e){return Object.values(this.figures).find((t=>t?.[e.figureId]))?"DuplicatedFigureId":"Success"}checkFigureAnchorOffset(e){return e.col<0||e.row<0||e.offset&&(e.offset.x<0||e.offset.y<0)?"WrongSheetPosition":"Success"}getFigures(e){const t=[];for(const o of this.insertionOrders){const s=this.figures[e]?.[o];s&&t.push(s)}return t}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(const t of e.sheets)for(const e of t.figures)this.addFigure(e,t.id)}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){return this.export(e)}}).add("chart",class extends Nk{static getters=["isChartDefined","getChartDefinition","getChartType","getChartIds","getChart","getContextCreationChart"];charts={};createChart=ax(this.getters);validateChartDefinition=e=>cx(this,e.definition);adaptRanges(e,t,o){for(const[s,i]of Object.entries(this.charts))this.history.update("charts",s,i?.updateRanges(e,t,o))}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,this.checkChartChanged));default:return"Success"}}handle(e){switch(e.type){case"CREATE_CHART":this.addFigure(e.figureId,e.sheetId,e.col,e.row,e.offset,e.size),this.addChart(e.figureId,e.definition);break;case"UPDATE_CHART":this.addChart(e.figureId,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",{figureId:s,col:o.col,row:o.row,offset:o.offset,size:{width:o.width,height:o.height},definition:i.getDefinition(),sheetId:e.sheetIdTo})}break}case"DELETE_FIGURE":this.history.update("charts",e.figureId,void 0);break;case"DELETE_SHEET":for(const 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(const t of e.sheets)if(t.figures)for(const 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(const t of e.sheets){const e=this.getters.getFigures(t.id),o=[];for(const 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,s,i,n={width:536,height:335}){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"chart"})}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.figureId)?"DuplicatedChartId":"Success"}checkChartExists(e){return this.isChartDefined(e.figureId)?"Success":"ChartDoesNotExist"}checkChartChanged(e){return mt(this.getChartDefinition(e.figureId),e.definition)?"NoChanges":"Success"}}).add("image",class extends Nk{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.addFigure(e.figureId,e.sheetId,e.col,e.row,e.offset,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,offset:o.offset,col:o.col,row:o.row,size:t,definition:ze(i)})}}break}case"DELETE_FIGURE":this.history.update("images",e.sheetId,e.figureId,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}addFigure(e,t,o,s,i,n){this.dispatch("CREATE_FIGURE",{sheetId:t,figureId:e,col:o,row:s,offset:i,size:n,tag:"image"})}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:ze(e)})}t.images=[...t.images,...o]}}getAllImages(){const e=[];for(const t in this.images)e.push(...Object.values(this.images[t]||{}).filter(lt));return e}}).add("pivot_core",class extends Nk{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.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures);case"UPDATE_PIVOT":return e.pivotId in this.pivots?mt(e.pivot,this.pivots[e.pivotId]?.definition)?"NoChanges":""===e.pivot.name?"EmptyName":this.checkValidations(e.pivot,this.checkDuplicatedMeasureIds,this.checkSortedColumnInMeasures):"PivotIdNotFound";case"RENAME_PIVOT":if(!(e.pivotId in this.pivots))return"PivotIdNotFound";if(""===e.name)return"EmptyName";break;case"REMOVE_PIVOT":case"DUPLICATE_PIVOT":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 qN(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=ze(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",ze(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:ze(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:$c(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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(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})}}}checkSortedColumnInMeasures(e){const t=e.measures.map((e=>e.id));return e.sortedColumn&&!t.includes(e.sortedColumn.measure)?"InvalidDefinition":"Success"}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||kc(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 Nk{allowDispatch(e){switch(e.type){case"ADD_PIVOT":case"UPDATE_PIVOT":const t=e.pivot;return this.checkDataSetValidity(t)}return"Success"}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=zk(this.getters.getRangeFromZone(s,i),e),r=n&&{sheetId:n.sheetId,zone:n.zone};this.dispatch("UPDATE_PIVOT",{pivotId:t,pivot:{...o,dataSet:r}})}}}checkDataSetValidity(e){if("SPREADSHEET"===e.type&&e.dataSet){const{zone:t,sheetId:o}=e.dataSet;return o&&this.getters.tryGetSheet(o)&&t&&pr(t)?this.getters.checkZonesExistInSheet(o,[t]):"InvalidDataSet"}return"Success"}}).add("tableStyle",class extends Nk{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(!HR[e.templateName])return"InvalidTableStyle";try{Gt(e.primaryColor)}catch(e){return"InvalidTableStyle"}}return"Success"}handle(e){switch(e.type){case"CREATE_TABLE_STYLE":const t=UR(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:wR.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 Vt(Ho("Custom Table Style"),Object.values(this.styles).map((e=>e.displayName)),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!LR[e]}import(e){for(const e in LR)this.styles[e]=LR[e];for(const t in e.customTableStyles){const o=e.customTableStyles[t];this.styles[t]=UR(o.displayName,o.templateName,o.primaryColor)}}export(e){const t={};for(const e in this.styles)LR[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}}),EL=(new n).add("ui_sheet",class extends BV{static getters=["getCellWidth","getTextWidth","getCellText","getCellMultiLineText","getContiguousZone","computeTextYCoordinate"];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(const 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.autoResizeRows(e.sheetId,e.rows);break;case"DELETE_UNFILTERED_CONTENT":const t=[];for(const o of e.target){const s=Ye(je(o.top,o.bottom+1).filter((t=>!this.getters.isRowFiltered(e.sheetId,t))));for(const e of s)t.push({...o,top:e[0],bottom:e[e.length-1]})}this.dispatch("DELETE_CONTENT",{sheetId:e.sheetId,target:t})}}getCellWidth(e){const t=this.getters.getCellComputedStyle(e);let o=0;const s=this.getters.getEvaluatedCell(e).formattedValue;if(s){const e=Wa(this.ctx,s,t,void 0);o+=Math.max(...e.map((e=>Va(this.ctx,e,t))))}for(const t of this.getters.getCellIcons(e))o+=t.margin+t.size;if(this.getters.getDataValidationChipStyle(e)&&(o+=10),0===o)return 0;if(o+=2*le,"wrap"===t.wrapping){const t=this.getters.getColSize(this.getters.getActiveSheetId(),e.col);return Math.min(t,o)}return o}getTextWidth(e,t){return Va(this.ctx,e,t)}getCellText(e,t){const o=this.getters.getCell(e),s=this.getters.getLocale();if(t?.showFormula&&o?.isFormula)return Ol(o.content,s);if(t?.showFormula&&!o?.content)return"";{const i=this.getters.getEvaluatedCell(e),n=t?.availableWidth?{availableWidth:t.availableWidth,measureText:e=>Va(this.ctx,e,o?.style||{})}:void 0;return In(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 Wa(this.ctx,s,o,t.wrapText?t.maxWidth:void 0)}computeTextYCoordinate(e,t,o=ue,s=1){const i=e.y+1,n=Pa(t,s);if(e.height>n+2*re){if("middle"===o)return Math.ceil(i+(e.height-n)/2);if("bottom"===o)return i+e.height-n-re}return i+re}getContiguousZone(e,t){const o=t=>{for(const o of je(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 je(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);Ir(i,e)||(s=!0,i=e)}while(s);return i}isCellEmpty(e){const t=this.getters.getMainCellPosition(e);return this.getters.getEvaluatedCell(t).type===_s.empty}getColMaxWidth(e,t){const o=_r(this.getters.getColsZone(e,t,t)).map((t=>this.getCellWidth({sheetId:e,...t})));return Math.max(0,Ft(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();if("ranges"in e&&e.ranges.some((e=>!this.getters.tryGetSheet(e._sheetId))))return"InvalidSheetId";const o=this.getters.getCommandZones(e);return!t&&o.length>0?"NoActiveSheet":t&&o.length>0?this.getters.checkZonesExistInSheet(t,o):"Success"}autoResizeRows(e,t){const o=[];for(const s of t){let t=0;for(const o of this.getters.getRowCells(e,s)){const s=this.getters.getCellById(o);if(!s)continue;const i=this.getters.getCellPosition(s.id),n=this.getters.getColSize(e,i.col);if(s.isFormula||this.getters.getArrayFormulaSpreadingOn(i)){const e=this.getters.getEvaluatedCell(i).formattedValue,o=Ma(this.ctx,e,s?.style,n);o>t&&o>ie&&(t=o)}else{const e=s.content,o=Ma(this.ctx,e,s?.style,n);o>=t&&o>ie&&(t=0)}}o.push(t||null)}const s=new Map(o.map((e=>[e,[]])));for(let e=0;e<o.length;e++)s.get(o[e])?.push(t[e]);for(const[t,o]of s)this.dispatch("RESIZE_COLUMNS_ROWS",{elements:o,dimension:"ROW",size:t,sheetId:e})}}).add("ui_options",class extends BV{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 BV{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:Ze(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=-1===e.row?this.lastCellSelected.row:Ze(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()}}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,s=[];switch(this.direction){case"down":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.top;o<=t.bottom;o++)i.push(Po(e,o));const n=this.createGenerator(i);for(let t=o.top;t<=o.bottom;t++)s.push(this.computeNewCell(n,e,t))}break;case"up":for(let e=t.left;e<=t.right;e++){const i=[];for(let o=t.bottom;o>=t.top;o--)i.push(Po(e,o));const n=this.createGenerator(i);for(let t=o.bottom;t>=o.top;t--)s.push(this.computeNewCell(n,e,t))}break;case"left":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.right;o>=t.left;o--)i.push(Po(o,e));const n=this.createGenerator(i);for(let t=o.right;t>=o.left;t--)s.push(this.computeNewCell(n,t,e))}break;case"right":for(let e=t.top;e<=t.bottom;e++){const i=[];for(let o=t.left;o<=t.right;o++)i.push(Po(o,e));const n=this.createGenerator(i);for(let t=o.left;t<=o.right;t++)s.push(this.computeNewCell(n,t,e))}}if(e){const e={},t={},o={},i=this.getters.getActiveSheetId();for(const n of s)this.collectBordersData(n,e),this.autofillMerge(i,n),this.autofillCell(i,n),this.collectConditionalFormatsData(i,n,t),this.collectDataValidationsData(i,n,o);this.autofillBorders(i,e),this.autofillConditionalFormats(i,t),this.autofillDataValidations(i,o),this.autofillZone=void 0,this.selection.resizeAnchorZone(this.direction,this.steps),this.lastCellSelected={},this.direction=void 0,this.steps=0,this.tooltip=void 0}}collectBordersData(e,t){const o=JSON.stringify(e.border);o in t||(t[o]=[]),t[o].push(Mr({col:e.col,row:e.row}))}collectConditionalFormatsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a=this.getters.getRulesByCell(e,s,i),l=Po(n,r);for(const e of a)e.id in o||(o[e.id]=[]),o[e.id].push(l)}collectDataValidationsData(e,t,o){const{originCol:s,originRow:i,col:n,row:r}=t,a={sheetId:e,col:s,row:i},l=this.getters.getValidationRuleForCell(a);l&&(l.id in o||(o[l.id]=[]),o[l.id].push(Mr({col:n,row:r})))}autofillCell(e,t){this.dispatch("UPDATE_CELL",{sheetId:e,col:t.col,row:t.row,content:t.content||"",style:t.style||null,format:t.format||""}),this.dispatch("AUTOFILL_CELL",t)}autofillBorders(e,t){for(const o in t){const s="undefined"===o?void 0:JSON.parse(o);this.dispatch("SET_BORDERS_ON_TARGET",{sheetId:e,border:s,target:nr(t[o])})}}autofillConditionalFormats(e,t){for(const o in t){const s=t[o],i=this.getters.getConditionalFormats(e).find((e=>e.id===o));if(!i)continue;const n=this.getters.getAdaptedCfRanges(e,i,s.map(ur),[]);n&&this.dispatch("ADD_CONDITIONAL_FORMAT",{cf:{id:i.id,rule:i.rule,stopIfTrue:i.stopIfTrue},ranges:n,sheetId:e})}}autofillDataValidations(e,t){for(const o in t){const s=t[o],i=this.getters.getDataValidationRule(e,o);if(!i)continue;const n=i.ranges.map((e=>e.zone)),r=nr(n.concat(s),[]);this.dispatch("ADD_DATA_VALIDATION_RULE",{rule:i,ranges:r.map((t=>this.getters.getRangeDataFromZone(e,t))),sheetId:e})}}select(e,t){const o=this.getters.getSelectedZone();if(Er(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!==_s.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!==_s.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!==_s.empty;)s+=1,e={sheetId:t,col:o+1,row:s}}return s-1}computeNewCell(e,t,o){const{cellData:s,tooltip:i,origin:n}=e.next(),{content:r,style:a,border:l,format:c}=s;return this.tooltip=i,{originCol:n.col,originRow:n.row,col:t,row:o,content:r,style:a,border:l,format:c}}getRule(e,t){const o=MV.getAll().sort(((e,t)=>e.sequence-t.sequence)).find((o=>o.condition(e,t)));return o&&this.direction&&o.generateRule(e,t,this.direction)}createGenerator(e){const t=[],o=[],s=this.getters.getActiveSheetId();for(const t of e){const{col:e,row:i}=Fo(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(const 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 zV(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){const{originCol:o,originRow:s,col:i,row:n}=t,r={sheetId:e,col:i,row:n},a={sheetId:e,col:o,row:s};if(this.getters.isInMerge(r)&&!this.getters.isInMerge(a)){const t=this.getters.getMerge(r);t&&this.dispatch("REMOVE_MERGE",{sheetId:e,target:[t]})}const l=this.getters.getMerge(a);l?.left===o&&l?.top===s&&this.dispatch("ADD_MERGE",{sheetId:e,target:[{top:n,bottom:n+l.bottom-l.top,left:i,right:i+l.right-l.left}]})}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 BV{allowDispatch(e){return"SORT_CELLS"===e.type?Er(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 _r(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=>xr(e,t))),s=Tr(o[0]),[i,n]=[s.numberOfCols,s.numberOfRows];return o.every((e=>{const[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 _r(t).some((({col:t,row:o})=>{const s=this.getters.getArrayFormulaSpreadingOn({sheetId:e,col:t,row:o});return s&&!mt(s,{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]===_s.empty&&(o=o.slice(1)),!o.some((e=>e[0]===_s.empty))&&!!o.some((e=>e[1]!==_s.empty&&e[0]!==e[1]))}sortZone(e,t,o,s,i){const[n,r]=this.mainCellsSteps(e,o),a=this.getters.getMainCellPosition({sheetId:e,col:t.col,row:t.row}).col,l=Object.assign({},o);let 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===_s.empty?{...e,type:_s.number,value:0}:e)):s).sort(jp(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++){const{col:o,row:s,sheetId:i}=c[e][d[t]],a=this.getters.getCell({sheetId:i,col:o,row:s}),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=je(t.left,t.right+1,o),r=je(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 BV{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}=Er(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)||Ar(yr(n,t))?[{position:{col:s,row:i},zone:n}]:this.sumDimensions(e,yr(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=je(o,-1,-1),n=Ft(i.filter((e=>s[e]&&!s[e].isAutoSummable))),r=Ye(i.filter((e=>this.isNumber(s[e]))))[0]||[];return Ft(r)<n?1/0:Pt(r)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===_s.number&&!(e.format&&On(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 Ar(t)?(o.add(1===Tr(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)},_r(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)},_r(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 BV{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 nr(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=nr(s.map(Mr));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:nr(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 nr(t))for(const t of _r(i)){const i=this.getCellNumberFormat({sheetId:e,...t});if(void 0!==i){const e=qn(i,o);s[e]=s[e]||[],s[e].push(t)}}for(const t in s){const o=nr(s[t].map((e=>Mr(e))));this.setContextualFormat(e,o,t)}}getCellNumberFormat(e){for(const t of[e]){const e=this.getters.getEvaluatedCell(t);if(!(e.type!==_s.number||e.format&&On(e.format)))return e.format||Mn(e.value)}}}).add("insert_pivot",class extends BV{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===Lr(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:Ho("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:Ho("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.getCollapsedTableStructure().export(),"dynamic")}duplicatePivotInNewSheet(e,t,o){this.dispatch("DUPLICATE_PIVOT",{pivotId:e,newPivotId:t,duplicatedPivotName:Ho("%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(Ho("%(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.getCollapsedTableStructure().export(),"dynamic")}}getPivotDuplicateSheetName(e){const t=this.getters.getSheetIds().map((e=>this.getters.getSheetName(e)));return Vt(qe(e),t)}insertPivotWithTable(e,t,o,s,i,n){const{cols:r,rows:a,measures:l,fieldsType:c}=i,h=new qN(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:{...Ve,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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(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:$c(n,t)});const a=this.getters.getCoreTable({sheetId:e,col:t,row:o});if("dynamic"===a?.type){const s=Mr({col:t,row:o}),n=this.getters.getRangeDataFromZone(e,i);this.dispatch("UPDATE_TABLE",{sheetId:e,zone:s,newTableRange:n,tableType:"static"})}}}).add("pivot_presence",class extends BV{static getters=["getPivotPresenceTracker"];trackPresencePivotId;tracker;handle(e){switch(e.type){case"PIVOT_START_PRESENCE_TRACKING":this.tracker=new CL,this.trackPresencePivotId=e.pivotId;break;case"PIVOT_STOP_PRESENCE_TRACKING":this.trackPresencePivotId=void 0}}getPivotPresenceTracker(e){if(this.trackPresencePivotId===e){if(!this.tracker)throw new Error("Tracker not initialized");return this.tracker}}}).add("split_to_columns",class extends BV{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===_s.text){const e=this.getAutoSeparatorForString(t.value);if(e)return e}return" "}getAutoSeparatorForString(e){const t=[Ne,";",","," ","."];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:Rl(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 je(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 je(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 je(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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(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 BV{static getters=["getClientsToDisplay","getClient","getCurrentClient","getConnectedClients","isFullySynchronized"];static layers=["Selection"];colors=new bo(12);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(e){return this.session.getClient(e)}getCurrentClient(){return this.session.getCurrentClient()}getConnectedClients(){return[...this.session.getConnectedClients()].map((e=>({...e,color:this.colors.get(e.id)})))}isFullySynchronized(){return this.session.isFullySynchronized()}getClientsToDisplay(){try{this.getters.getCurrentClient()}catch(e){if(e instanceof sL)return[];throw e}const e=this.getters.getActiveSheetId(),t=[];for(const o of this.getters.getConnectedClients())o.id!==this.getters.getCurrentClient().id&&o.position&&o.position.sheetId===e&&this.isPositionValid(o.position)&&t.push({...o,position:o.position});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 BV{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("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=SL(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)&&(Hs(t.rootCommand)?fL.contains(t.rootCommand.type):vL.contains(t.rootCommand.type));var t}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 BV{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===Tr(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 Jc(this.getters,this.dispatch),l=a.copy(Qa(o,r),!1);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 je(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:Ho("%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=nr(this.getters.getSelectedZones()),t=this.getters.getActiveSheetId();let o=0;for(const{col:s,row:i}of e.map(_r).flat()){const e=this.getters.getCell({col:s,row:i,sheetId:t});if(!e)continue;const n=Dt(e.content);n!==e.content&&(o+=1,this.dispatch("UPDATE_CELL",{sheetId:t,col:s,row:i,content:n}))}const s=o?Ho("Trimmed whitespace from %s cells.",o):Ho("No selected cells had whitespace trimmed.");this.ui.notifyUI({type:"info",text:s,sticky:!1})}}).add("table_autofill",class extends BV{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&&Er(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!==_s.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 BV{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 BV{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 wa(t)){const t=this.getters.getCell(e),o=this.getters.getEvaluatedCell(e);if(t?.content)if(t?.content&&o.type===_s.empty){let o;if(t.content.startsWith("=")){const s=this.getters.evaluateFormula(e.sheetId,t.content);o=(js(s)?s[0][0]:s)?.toString()}else o=t.content;o&&Ke(o)||this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}else o.type!==_s.boolean&&this.dispatch("UPDATE_CELL",{...e,content:"FALSE"});else this.dispatch("UPDATE_CELL",{...e,content:"FALSE"})}}}}).add("checkbox_toggle",class extends BV{static getters=["hasBooleanValidationInZones"];handle(e){if("TOGGLE_CHECKBOX"===e.type)this.toggleCheckbox(e.sheetId,e.target)}hasBooleanValidationInZones(e){const t=this.getters.getActiveSheetId();for(const o of e)for(let e=o.left;e<=o.right;e++)for(let s=o.top;s<=o.bottom;s++)if(this.getters.isCellValidCheckbox({col:e,row:s,sheetId:t}))return!0;return!1}toggleCheckbox(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++){const o={col:t,row:s,sheetId:e};if(this.getters.isCellValidCheckbox(o)){const e=this.getters.getEvaluatedCell(o).value?"FALSE":"TRUE";this.dispatch("UPDATE_CELL",{...o,content:e})}}}}).add("geo_features",class extends BV{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")}}),RL=(new n).add("selection",class extends BV{static layers=["Selection"];static getters=["getActiveSheet","getActiveSheetId","getActiveSheetName","getActiveCell","getActiveCols","getActiveRows","getCurrentStyle","getSelectedZones","getSelectedZone","getSelectedCells","getSelectedFigureId","getSelection","getActivePosition","getSheetPosition","isSingleColSelected","getElementsFromSelection","tryGetActiveSheetId","isGridSelectionActive","getSelectecUnboundedZone"];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;isUnbounded;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient,this.isUnbounded=!1}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(this.isUnbounded=e.options?.unbounded||!1,e.mode){case"overrideSelection":o=[t.zone];break;case"updateAnchor":o=[...this.gridSelection.zones];const s=o.findIndex((t=>Ir(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,ze(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.figureId&&(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.figureId;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:ze(t)}}this.fallbackToVisibleSheet();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.fallbackToVisibleSheet(),this.selection.resetDefaultAnchor(this,ze(this.gridSelection.anchor))}isGridSelectionActive(){return this.selection.isListening(this)}getActiveSheet(){return this.activeSheet}getActiveSheetId(){return this.activeSheet.id}getActiveSheetName(){return this.activeSheet.name}tryGetActiveSheetId(){return this.activeSheet?.id}getActiveCell(){return this.getters.getEvaluatedCell(this.getActivePosition())}getActiveCols(){const e=new Set;for(const 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(const 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 ze(this.gridSelection.zones)}getSelectedZone(){return ze(this.gridSelection.anchor.zone)}getSelectecUnboundedZone(){return ze(this.isUnbounded?this.getters.getUnboundedZone(this.activeSheet.id,this.gridSelection.anchor.zone):this.gridSelection.anchor.zone)}getSelection(){return ze(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:ze(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,ze(this.gridSelection.anchor));else{const{col:e,row:o}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,o)}const{col:o,row:s}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.activeSheet.id,col:o,row:s})}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=Sr(o,"left",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Sr(i,"left",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Sr(t,"left",[...e.elements])));this.setSelectionMixin(n,r)}onRowsRemoved(e){const{cell:t,zone:o}=this.gridSelection.anchor,s=Sr(o,"top",[...e.elements]);let i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=Sr(i,"top",[...e.elements]);const n={cell:{col:i.left,row:i.top},zone:s},r=this.gridSelection.zones.map((t=>Sr(t,"top",[...e.elements])));this.setSelectionMixin(n,r)}onAddElements(e){const t="COL"===e.dimension?"left":"top",o=br(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),s=this.gridSelection.zones.map((o=>br(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,o=this.getFiguresUpdates(e);this.dispatch("ADD_COLUMNS_ROWS",{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,base:e.base,quantity:t,position:e.position});const s="COL"===e.dimension,i=e.elements[0],n=e.elements[t-1],r=e.base<i,a=r&&s?t:0,l=r&&!s?t:0,c=r?e.elements.map((e=>e+t)):e.elements,h={};for(const t of c)h[t]=this.getters.getHeaderSize(e.sheetId,e.dimension,t);const d=[{left:s?i+a:0,right:s?n+a:this.getters.getNumberCols(e.sheetId)-1,top:s?0:i+l,bottom:s?this.getters.getNumberRows(e.sheetId)-1:n+l}],u=this.getActiveSheetId(),g=r?e.base:e.base+1,p=[{left:s?g:0,right:s?g+t-1:this.getters.getNumberCols(e.sheetId)-1,top:s?0:g,bottom:s?this.getters.getNumberRows(e.sheetId)-1:g+t-1}];for(const e of eh.cellHandlers.getAll()){const t=new e(this.getters,this.dispatch),o=t.copy(Qa(u,d),!1,"shiftCells");o&&t.paste({zones:p,sheetId:u},o,{isCutOperation:!0})}const m=p[0],f=m.left,v=m.top;this.setSelectionMixin({zone:m,cell:{col:f,row:v}},[m]);let b=r?e.base:e.base+1;const S={};for(const t of c){const o=h[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,sheetName:e.sheetName,elements:c}),this.applyFigureUpdates(o)}getFiguresUpdates(e){const t=[],o={},s=e.elements[0]<e.base?e.base-e.elements.length+1:e.base;for(let t=0;t<e.elements.length;t++)o[e.elements[t]]=s+t;for(const s of this.getters.getFigures(e.sheetId))"COL"===e.dimension&&s.col in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,col:o[s.col],row:s.row}),"ROW"===e.dimension&&s.row in o&&t.push({type:"UPDATE_FIGURE",sheetId:e.sheetId,figureId:s.id,row:o[s.row],col:s.col});return t}applyFigureUpdates(e){for(const t of e)this.dispatch(t.type,{...t})}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":t||this.isTableRowMoveAllowed(i,e.elements)?"Success":"CannotMoveTableHeader"}isTableRowMoveAllowed(e,t){const o=this.getters.getCoreTables(e);if(0===o.length)return!0;const s=new Set(t);return o.every((({range:{zone:e},config:o})=>{const{top:i,bottom:n}=e;if(0===o.numberOfHeaders)return!0;const r=i+o.numberOfHeaders-1;if(!t.some((e=>e>=i&&e<=r)))return!0;return je(i,n+1).every((e=>s.has(e)))}))}fallbackToVisibleSheet(){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})}}clipSelection(e,t){const o=this.getters.getNumberCols(e)-1,s=this.getters.getNumberRows(e)-1;return{zones:t.zones.map((e=>({left:Ze(e.left,0,o),right:Ze(e.right,0,o),top:Ze(e.top,0,s),bottom:Ze(e.bottom,0,s)}))),anchor:{cell:{col:Ze(t.anchor.cell.col,0,o),row:Ze(t.anchor.cell.row,0,s)},zone:{left:Ze(t.anchor.zone.left,0,o),right:Ze(t.anchor.zone.right,0,o),top:Ze(t.anchor.zone.top,0,s),bottom:Ze(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):Mr(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 BV{static getters=["getFilterValue","getFilterHiddenValues","getFilterCriterionValue","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]=ze(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)}getFilterValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;return t?this.filterValues[o]?.[t]:void 0}getFilterHiddenValues(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return[];const s=this.filterValues[o][t]||[];return"values"===s.filterType?s.hiddenValues:[]}getFilterCriterionValue(e){const t=this.getters.getFilterId(e),o=e.sheetId;if(!t||!this.filterValues[o])return wL;const s=this.filterValues[o][t];return s&&"criterion"===s.filterType?s:wL}isFilterActive(e){const t=this.getters.getFilterId(e);if(!t)return!1;const o=e.sheetId,s=this.filterValues[o]?.[t];return!!s&&("values"===s.filterType?s.hiddenValues.length>0:"none"!==s.type)}getFirstTableInSelection(){const e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,value: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(const s of t){const t=this.filterValues[e]?.[s.id],i=s.filteredRange?.zone;if(t&&i&&!o.has(s.rangeWithHeaders.zone.top)&&!this.getters.isRowHiddenByUser(e,s.rangeWithHeaders.zone.top))if("values"===t.filterType){const n=t.hiddenValues?.map(qa);if(!n)continue;const r=new Set(n);for(let t=i.top;t<=i.bottom;t++){const i=this.getCellValueAsString(e,s.col,t);r.has(i)&&o.add(t)}}else{if("none"===t.type)continue;const n=eE.get(t.type),r=t.values.map((t=>t.startsWith("=")?this.getters.evaluateFormula(e,t)??"":Kn(t,qs)));if(r.some(oc))continue;const a={type:t.type,values:r.map(ec),dateValue:t.dateValue};for(let t=i.top;t<=i.bottom;t++){const i={sheetId:e,col:s.col,row:t},r=this.getters.getEvaluatedCell(i).value??"";n.isValueValid(r,a,this.getters,e)||o.add(t)}}}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=ur(o.range),i=[],n=[];for(const o of je(0,Tr(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?_r(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=Po(r.col,r.row);t.cells[u]=d,t.cellValues[u]=d}o.filters=i}}}getUniqueColNameForExcel(e,t,o){return t||(t=`Column${e}`),Vt(t,o,{compute:(e,o)=>t+String(o),start:2})}}).add("header_visibility_ui",class extends BV{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 je(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 BV{static getters=["getCellComputedBorder","getCellComputedStyle"];styles={};borders={};handle(e){if(Fs.has(e.type)||"UPDATE_CELL"===e.type||"SET_FORMATTING"===e.type||"ADD_DATA_VALIDATION_RULE"===e.type||"REMOVE_DATA_VALIDATION_RULE"===e.type||"EVALUATE_CELLS"===e.type)return this.styles={},void(this.borders={});rL(e)?"sheetId"in e?(delete this.styles[e.sheetId],delete this.borders[e.sheetId]):(this.styles={},this.borders={}):Ns.has(e.type)?this.styles={}:ks.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=this.getters.getCellTableStyle(e),i=this.getters.getDataValidationCellStyle(e),n={...bt(s),...bt(i),...bt(t?.style),...bt(o)};return this.getters.getEvaluatedCell(e).link&&!n.textColor&&(n.textColor=b),n}}).add("table_computed_style",class extends BV{static getters=["getCellTableStyle","getCellTableBorder"];tableStyles={};handle(e){Fs.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"in e)||"EVALUATE_CELLS"===e.type?this.tableStyles={}:rL(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=w_(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 BV{static getters=["getColDimensions","getRowDimensions","getColRowOffset"];headerPositions={};isDirty=!0;handle(e){switch(Fs.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.getters.tryGetSheet(e.sheetId)&&(this.headerPositions[e.sheetId]=this.computeHeaderPositionsOfSheet(e.sheetId));break;case"DUPLICATE_SHEET":this.headerPositions[e.sheetIdTo]=ze(this.headerPositions[e.sheetId])}}finalize(){for(const e of this.getters.getSheetIds())!this.isDirty&&this.headerPositions[e]||(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 BV{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","getFigureUI","getPositionAnchorOffset","getGridOffset"];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}=Pr(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(Fs.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":case"UNFREEZE_ROWS":case"UNFREEZE_COLUMNS":case"FREEZE_COLUMNS":case"FREEZE_ROWS":case"UNFREEZE_COLUMNS_ROWS":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":this.sheetsWithDirtyViewports.add(e.sheetId);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"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}}getGridOffset(){return{x:this.gridOffsetX,y:this.gridOffsetY}}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=>je(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=>je(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),{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),maxOffsetY:Math.max(0,o-s.viewportHeight)}}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));let r=i.findIndex((e=>o<=e));r=-1===r?i.length:r;const 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=jr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=jr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=jr(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=jr(e-a),i=1):e<l&&o>=l&&c>0?(s=!0,n=jr(l-e),i=-1):r&&t<l&&e>l&&(s=!0,n=jr(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}}getRectWithoutHeaders(e){const t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,(t=>t.getFullRect(e)))}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{top:o}=this.getMainInternalViewport(e),s={left:t,right:t,top:o,bottom:o},{x:i,width:n}=this.getVisibleRect(s),r=i-this.gridOffsetX;return{start:r,size:n,end:r+n}}getRowDimensionsInViewport(e,t){const{left:o}=this.getMainInternalViewport(e),s={left:0,right:o,top:t,bottom:t},{y:i,height:n}=this.getVisibleRect(s),r=i-this.gridOffsetY;return{start:r,size:n,end:r+n}}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(lt)}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(Ze(e,0,s),Ze(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(Ze(e,0,s),Ze(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 IL(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 IL(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 IL(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 IL(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)}}getColIndexLeftOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().left,s=-this.getActiveSheetScrollInfo().scrollX-this.getters.getColRowOffset("COL",o,0);for(;e<s;o--)s-=this.getters.getColSize(t,o-1);return Math.max(o,0)}getRowIndexTopOfMainViewport(e){if(e>=0)return-1;const t=this.getters.getActiveSheetId();let o=this.getActiveMainViewport().top,s=-this.getActiveSheetScrollInfo().scrollY-this.getters.getColRowOffset("ROW",o,0);for(;e<s;o--)s-=this.getters.getRowSize(t,o-1);return Math.max(o,0)}getVisibleFigures(){const e=this.getters.getActiveSheetId(),t=[],o=this.getters.getFigures(e),{scrollX:s,scrollY:i}=this.getters.getActiveSheetScrollInfo(),{x:n,y:r}=this.getMainViewportCoordinates(),{width:a,height:l}=this.getters.getSheetViewDimensionWithHeaders();for(const c of o){const o=this.getFigureUI(e,c),{x:h,y:d}=o;h>=n&&(h+c.width<s+n||h>a+s+n)||(d>=r&&(d+c.height<i+r||d>l+i+r)||t.push(o))}return t}getFigureUI(e,t){const o=t.offset.x+this.getters.getColDimensions(e,t.col).start,s=t.offset.y+this.getters.getRowDimensions(e,t.row).start;return{...t,x:o,y:s}}getPositionAnchorOffset(e){const{scrollX:t,scrollY:o}=this.getters.getActiveSheetScrollInfo(),s=e.x-t,i=e.y-o,n=s>=0?this.getColIndex(s):this.getColIndexLeftOfMainViewport(s),r=i>=0?this.getRowIndex(i):this.getRowIndexTopOfMainViewport(i),{x:a,y:l}=this.getRect(Mr({col:n,row:r}));return{col:n,row:r,offset:{x:Math.max(s-a+this.gridOffsetX,0),y:Math.max(i-l+this.gridOffsetY,0)}}}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 BV{static layers=["Clipboard"];static getters=["getClipboardTextAndImageContent","getClipboardId","getClipboardTextContent","isCutOperation"];status="invisible";originSheetId;copiedData;_isCutOperation=!1;clipboardId=(new Ka).uuidv4();fileStore;uuidGenerator;constructor(e){super(e),this.fileStore=e.external.fileStore,this.uuidGenerator=new Ka}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,"shiftCells");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,"shiftCells");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._isCutOperation="CUT"===e.type,this.copiedData=this.copy(t);break;case"PASTE_FROM_OS_CLIPBOARD":{this._isCutOperation=!1;const t=e.clipboardContent.data;if(e.clipboardContent.imageData){const t=this.getters.getActiveSheetId(),o=this.uuidGenerator.uuidv4(),s=e.clipboardContent.imageData,i=px(this.getters,s.size);this.dispatch("CREATE_IMAGE",{definition:s,size:i,col:e.target[0].left,row:e.target[0].top,offset:{x:0,y:0},sheetId:t,figureId:o})}this.copiedData=t||this.convertTextToClipboardData(e.clipboardContent.text??"");const o=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:o,selectTarget:!0,isCutOperation:!1}),this.status="invisible",this.copiedData=void 0;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(!pr(t[0])){this.dispatch("CLEAR_CELLS",{target:[e.zone],sheetId:this.getters.getActiveSheetId()});break}const s=this.copy(t,"shiftCells");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,"shiftCells");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(const 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:Hs(e)&&(this.status="invisible")}}convertTextToClipboardData(e){const t=this.selectClipboardHandlers({figureId:!0}).concat(this.selectClipboardHandlers({})),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?eh.figureHandlers:eh.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(const s of o){if("COL"===t&&e<=s.right)return!0;if("ROW"===t&&e<=s.bottom)return!0}return!1}copy(e,t="copyPaste"){const o={},s=this.getClipboardData(e);for(const{handlerName:e,handler:i}of this.selectClipboardHandlers(s)){const n=i.copy(s,this._isCutOperation,t);o[e]=n;const r=["sheetId","cells","zones","figureId"];for(const e of r)n&&e in n&&(o[e]=n[e])}return o}paste(e,t,o){if(!t)return;const s=this.getters.getActiveSheetId(),i=this.selectClipboardHandlers(t),{target:n,zone:r,selectedZones:a}=sl(s,e,t,i,o);void 0!==r&&this.addMissingDimensions(s,r.right-r.left+1,r.bottom-r.top+1,r.left,r.top),ol(i,t,n,o),o?.selectTarget&&il(this.selection,e,a)}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,sheetName:this.getters.getSheetName(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,sheetName:this.getters.getSheetName(e),quantity:r,position:"after"})}getClipboardTextContent(){return this.getPlainTextContent()}getClipboardId(){return this.clipboardId}async getClipboardTextAndImageContent(){const e=await this.getImageContent(),t=e?.type,o={[Os.PlainText]:this.getPlainTextContent(),[Os.Html]:await this.getHTMLContent()};return t&&e&&(o[t]=e),o}getSheetData(){const e={version:hD(),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"}async 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="${xh(Ih(this.getters.getCellComputedStyle(t.position)))}">`+bx(this.getters.getCellText(t.position))+"</td>"}o+="</tr>"}o+="</table>",e=o}}else if(this.copiedData?.figureId){const t=this.copiedData.figureId,o=this.getters.getFigureSheetId(t);e="image"===this.getters.getFigure(o,t).tag?await this.craftImageHTML(t):"\t"}else e="\t";return`<div data-osheet-clipboard='${bx(JSON.stringify(this.getSheetData()))}'>${e}</div>`}readFileAsDataURL(e){return new Promise((t=>{const o=new FileReader;o.onload=()=>t(o.result),o.readAsDataURL(e)}))}async craftImageHTML(e){if(!this.fileStore)return"\t";const t=this.getters.getImage(e).path,o=await(this.fileStore?.getFile(t))||null;if(o){return`<img src="${bx(await this.readFileAsDataURL(o))}" />`}return"\t"}async getImageContent(){const e=this.copiedData?.figureId;if(!e)return;const t=this.getters.getFigureSheetId(e);let o;if("image"===this.getters.getFigure(t,e).tag){if(!this.fileStore)return;const t=this.getters.getImage(e).path;if(o=await(this.fileStore?.getFile(t)),"image/png"!==o.type){if(o.size>yL)return void this.ui.notifyUI({text:Ho("The file you are trying to copy is too large (>%sMB).\nIt will not be added to your OS clipboard.\nYou can download it directly instead.",Math.round(5)),sticky:!1,type:"warning"});o=await async function(e){return new Promise(((t,o)=>{const s=new Image;s.addEventListener("load",(()=>{const e=document.createElement("canvas");e.width=s.width,e.height=s.height;const o=e.getContext("2d");o?.drawImage(s,0,0),e.toBlob(t,"image/png")})),s.addEventListener("error",o),s.src=e}))}(t)}}return o?o instanceof File?o:new File([o],"image.png",{type:"image/png"}):void 0}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();if(o)return{figureId:o,sheetId:t};const s=Qa(t,e);return this._isCutOperation||(s.rowsIndexes=s.rowsIndexes.filter((e=>!this.getters.isRowFiltered(t,e)))),s}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)}}}),TL=(new n).add("evaluation",class extends $k{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 yV(e.custom,this.getters)}beforeHandle(e){(Fs.has(e.type)||Ms.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 js(o)?ki(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 _r(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 _r(t).map((({col:t,row:o})=>this.getEvaluatedCell({sheetId:e,col:t,row:o}))).every((e=>e.type===_s.empty))}mapVisiblePositions(e,t){const{sheetId:o,zone:s}=e;return _r(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={},t.formulaSpillRanges={};for(const t of this.evaluator.getEvaluatedPositions()){const o=this.evaluator.getEvaluatedCell(t),s=Po(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){const h=this.getters.getCell(t);if(a=$S(c.compiledFormula.tokens),r=a&&h?.content===c.content,!a&&""!==i){n=(i??"").toString();const t=o.format;if(t){const o=Gr(t,e.formats);l.formats[s]=o}}}const h=l.cells[s];let d;d=a&&r&&c instanceof kk?c.contentWithFixedReferences:a?h:n,l.cells[s]=d,l.cellValues[s]="error"!==o.type?i:void 0;const u=this.getSpreadZone(t);u&&(l.formulaSpillRanges[s]=this.getters.getRangeString(this.getters.getRangeFromZone(t.sheetId,u),t.sheetId))}}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 $k{static getters=["getChartRuntime","getStyleOfSingleCellChart"];charts={};createRuntimeChart=lx(this.getters);handle(e){if(Fs.has(e.type)||Ns.has(e.type)||Ps.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.figureId]=void 0;break;case"DELETE_SHEET":for(const 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:rC(e)};if(!t)return{background:m,fontColor:rC(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||rC(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=Wy(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 $k{static getters=["getConditionalIcon","getCellConditionalFormatStyle","getConditionalDataBar"];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(Fs.has(e.type)||Ns.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(const o of this.getters.getConditionalFormats(e).reverse())switch(o.rule.type){case"ColorScaleRule":for(const 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(const 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={sheetId:e,col:r,row:i},l=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}));this.getRuleResultForTarget(a,{...o.rule,values:l})&&(t[r]||(t[r]=[]),t[r][i]=Object.assign(t[r]?.[i]||{},o.rule.style))}}}return t}getComputedIcons(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("IconSetRule"===o.rule.type)for(const s of o.ranges)this.applyIcon(e,s,o.rule,t);return t}getComputedDataBars(e){const t={};for(const o of this.getters.getConditionalFormats(e).reverse())if("DataBarRule"===o.rule.type)for(const 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===_s.number)).map((e=>e.value));switch(o.type){case"value":return"max"===s?Ft(i):Pt(i);case"number":return Number(o.value);case"percentage":const t=Pt(i);return t+(Ft(i)-t)*Number(o.value)/100;case"percentile":return Ds(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!==_s.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=Ft(this.getters.getEvaluatedCellsInZone(e,i.zone).filter((e=>e.type===_s.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});!Er(i,c,l)||h.type!==_s.number||h.value<=0||(s[o]||(s[o]=[]),s[o][t]={color:zt(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=So(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===_s.number){const e=Ze(n.value,i,r);s[o]||(s[o]=[]),s[o][t]=s[o]?.[t]||{},s[o][t].fillColor=c(e)}}}getRuleResultForTarget(e,t){const o=this.getters.getEvaluatedCell(e);if(o.type===_s.error)return!1;const{sheetId:s}=e,i=eE.get(t.operator),n=t.values.map((e=>e.startsWith("=")?this.getters.evaluateFormula(s,e)??"":Kn(e,qs)));if(n.some(oc))return!1;const r={type:t.operator,values:n.map(ec)};return i.isValueValid(o.value??"",r,this.getters,s)}}).add("row_size",class extends $k{static getters=["getRowSize","getHeaderSize","getMaxAnchorOffset"];tallestCellInRow={};ctx=document.createElement("canvas").getContext("2d");beforeHandle(e){if("ADD_COLUMNS_ROWS"===e.type){if("COL"===e.dimension)return;const t=pt(e.position,e.base),o=Array(e.quantity).fill(void 0),s=Tt(this.tallestCellInRow[e.sheetId],o,t);this.history.update("tallestCellInRow",e.sheetId,s)}}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=ze(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=Rt(this.tallestCellInRow[e.sheetId],e.elements);this.history.update("tallestCellInRow",e.sheetId,t);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 je(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 _r(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??ie)}getMaxAnchorOffset(e,t,o){let{numberOfRows:s,numberOfCols:i}=this.getters.getSheetSize(e),n=0;for(;n<t&&s>0;s--)n+=this.getRowSize(e,s-1);let r=0;for(;r<o&&i>0;i--)r+=this.getters.getColSize(e,i-1);return{col:i,row:s,offset:{x:r-o,y:n-t}}}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<=ie)&&(!s&&i>ie||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 ie;const t=this.getters.getCell(e),o=this.getters.getColSize(e.sheetId,e.col);return function(e,t,o){return t&&(t.isFormula||t.content)?Ma(e,t.isFormula?"":t.content,t.style,o):ie}(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>ie&&(i=r,s={cell:n,size:r})}return s&&s.size>ie?s:void 0}}).add("data_validation_ui",class extends $k{static getters=["getDataValidationInvalidCriterionValueMessage","getInvalidDataValidationMessage","getValidationResultForCellValue","getDataValidationRangeValues","isCellValidCheckbox","getDataValidationCellStyle","getDataValidationChipStyle","isDataValidationInvalid"];validationResults={};handle(e){if(Fs.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}getDataValidationCellStyle(e){if(!this.hasChip(e))return this.getDataValidationStyle(e)}getDataValidationChipStyle(e){if(this.hasChip(e))return this.getDataValidationStyle(e)??{fillColor:F}}getInvalidDataValidationMessage(e){const t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){const o=eE.get(e);return t.startsWith("=")?"onlyLiterals"===o.allowedValues?Ho("The value must not be a formula"):this.isValidFormula(t)?void 0:tw.CriterionError.validFormula:"onlyFormulas"===o.allowedValues?Ho("The value must be a formula"):o.isCriterionValueValid(t)?void 0:o.criterionValueErrorString}getDataValidationRangeValues(e,t){const o=this.getters.getRangeFromSheetXC(e,String(t.values[0])),s=[],i=new Set;for(const e of _r(o.zone)){const t=this.getters.getEvaluatedCell({...e,sheetId:o.sheetId});t.formattedValue&&!i.has(t.formattedValue)&&(i.add(t.formattedValue),s.push({label:t.formattedValue,value:t.value?.toString()||""}))}return s}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 RV;const s=this.getRuleErrorForCellValue(e,t,o);return s?{error:s,rule:o,isValid:!1}:RV}hasChip(e){const t=this.getters.getValidationRuleForCell(e);return("isValueInList"===t?.criterion.type||"isValueInRange"===t?.criterion.type)&&"chip"===t.criterion.displayStyle}getDataValidationStyle(e){const t=this.getters.getValidationRuleForCell(e);if(!t||this.isDataValidationInvalid(e))return;const o=this.getters.getEvaluatedCell(e),s=this.getValueColor(t,o.value);if(!s)return;return{fillColor:s,textColor:no(s)}}getValueColor(e,t){if("isValueInList"===e.criterion.type||"isValueInRange"===e.criterion.type)for(const o in e.criterion.colors)if(o.toLowerCase()===String(t).toLowerCase())return e.criterion.colors[o]}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]?.()||RV}computeSheetValidationResults(e){const t={},o=this.getters.getDataValidationRules(e).map((e=>e.ranges));for(const e of wa(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===_s.empty?RV:this.getValidationResultForCellValue(t.value,e)}))}return t}getRuleErrorForCellValue(e,t,o){const{sheetId:s}=t,i=o.criterion,n=eE.get(i.type),r=this.getCellOffsetInRule(t,o),a=this.getEvaluatedCriterionValues(s,r,i);if(a.some(oc))return;const l={...i,values:a.map(ec)};return n.isValueValid(e,l,this.getters,s)?void 0:n.getErrorString(l,this.getters,s)}getCellOffsetInRule(e,t){const o=t.ranges.find((t=>Er(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 Kn(o,qs);const s=HS(o),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,s.tokens);return this.getters.evaluateFormula(e,i)}))}}).add("dynamic_tables",class extends $k{static getters=["canCreateDynamicTableOnZones","doesZonesContainFilter","getFilter","getFilters","getTable","getTables","getTablesOverlappingZones","getFilterId","getFilterHeaders","isFilterHeader"];tables={};handle(e){if(Fs.has(e.type)||"UPDATE_CELL"===e.type&&("content"in e||"format"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)xr(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=>Er(t,o,e.range.zone)))}getTablesOverlappingZones(e,t){return this.getTables(e).filter((e=>t.some((t=>xr(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(!Ur(t))return!1;const o=yr(...t),s={col:o.left,row:o.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(s);if(!i)return!1;if(mt(i,s)&&1===Lr(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=C_(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=ur(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=fr(n.range.zone))}}}).add("custom_colors",class extends $k{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.figureId));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:Zt(255,0,0),colors:[]},{leadColor:Zt(255,128,0),colors:[]},{leadColor:Zt(128,128,0),colors:[]},{leadColor:Zt(128,255,0),colors:[]},{leadColor:Zt(0,255,0),colors:[]},{leadColor:Zt(0,255,128),colors:[]},{leadColor:Zt(0,255,255),colors:[]},{leadColor:Zt(0,127,255),colors:[]},{leadColor:Zt(0,0,255),colors:[]},{leadColor:Zt(127,0,255),colors:[]},{leadColor:Zt(128,0,128),colors:[]},{leadColor:Zt(255,0,128),colors:[]}];for(const o of e.map(Xt)){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)=>Jt(e).s-Jt(t).s)))).flat().map(Yt)}(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(zt(t.minimum.color)),o.push(t.midpoint?zt(t.midpoint.color):void 0),o.push(zt(t.maximum.color)))}return o.filter(lt)}getChartColors(e){const t=this.getters.getChart(e);if(void 0===t)return[];return[...JSON.stringify(t.getDefinition()).matchAll(EV)].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(lt):[]}tryToAddColors(e){for(const t of e){if(!Wt(t))continue;const e=Gt(t);t&&!ee.includes(e)&&this.history.update("customColors",e,!0)}}}).add("pivot_ui",class extends $k{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(Fs.has(e.type))for(const e of this.getters.getPivotIds())ik.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(FV);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 ok)ok[e].set.clear(),ok[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=BN(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=gv(t);return this.getters.evaluateFormula(e,o)}))}}getPivotCellFromPosition(e){const t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||0===zN(t.compiledFormula.tokens))return ZN;const o=this.getters.getCellPosition(t.id),s=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!s)return ZN;let{functionName:i,args:n}=s;const r=n[0];if(!r)return ZN;const a=this.getters.getPivotId(r.toString());if(!a)return ZN;const l=this.getPivot(a);if(!l.isValid())return ZN;if("PIVOT"===i&&!t.content.replaceAll(" ","").toUpperCase().startsWith("=PIVOT"))return ZN;if("PIVOT"===i){const t=ec(n[2]),s=void 0===t||Ei(t),i=ec(n[3]),r=ec(n[5]),a=void 0===r||Ei(r),c={displayColumnHeaders:void 0===i||Ei(i),displayTotals:s,displayMeasuresRow:a},h=l.getCollapsedTableStructure().getPivotCells(c),d=e.col-o.col,u=e.row-o.row;return h[d][u]}try{const t=e.row-o.row,s=e.col-o.col;if(n=n.map((e=>js(e)?e[s][t]:e)),"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){const e=l.parseArgsToPivotDomain(n.slice(1).map((e=>({value:e}))));return{type:"HEADER",domain:e,dimension:NO(l,e).colDomain.length?"COL":"ROW"}}const[r,...a]=n.slice(1);return{type:"VALUE",domain:l.parseArgsToPivotDomain(a.map((e=>({value:e})))),measure:r?.toString()||""}}catch(e){return ZN}}generateNewCalculatedMeasureName(e){const t=e.map((e=>e.fieldName));return Vt(Ho("Calculated measure 1"),t,{compute:(e,t)=>Ho("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=_V(ik.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}}).add("cell_icon",class extends $k{static getters=["doesCellHaveGridIcon","getCellIcons","getCellIconRect"];cellIconsCache={};handle(e){"SET_VIEWPORT_OFFSET"!==e.type&&(this.cellIconsCache={})}getCellIcons(e){return this.cellIconsCache[e.sheetId]||(this.cellIconsCache[e.sheetId]={}),this.cellIconsCache[e.sheetId][e.col]||(this.cellIconsCache[e.sheetId][e.col]={}),this.cellIconsCache[e.sheetId][e.col][e.row]||(this.cellIconsCache[e.sheetId][e.col][e.row]=this.computeCellIcons(e)),this.cellIconsCache[e.sheetId][e.col][e.row]}getCellIconRect(e,t){const o=e.position,s=this.getters.getCell(o);return{x:this.getIconHorizontalPosition(t,e.horizontalAlign,e),y:this.getters.computeTextYCoordinate(t,e.size,s?.style?.verticalAlign),width:e.size,height:e.size}}getIconHorizontalPosition(e,t,o){const s=e.x,i=e.x+e.width;switch(t){case"right":return i-o.margin-o.size;case"left":return s+o.margin;default:const e=Math.floor((i-s-o.size)/2);return i-o.size-e}}computeCellIcons(e){const t={left:void 0,right:void 0,center:void 0},o=TV.getAll();for(const s of o){const o=s(this.getters,e);o&&(!t[o.horizontalAlign]||o.priority>t[o.horizontalAlign].priority)&&(t[o.horizontalAlign]=o)}if(t.center&&(t.left||t.right)){const e=Math.max(t.left?.priority||0,t.right?.priority||0);t.center.priority<e?t.center=void 0:(t.left=void 0,t.right=void 0)}return Object.values(t).filter(lt)}doesCellHaveGridIcon(e){return Boolean(this.getCellIcons(e).length)}});mE.add("dataValidation",{displayAllOnInitialContent:!0,canBeToggled:!1,getProposals(e,t){if(Lt(t))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[];const i=this.composer.currentEditedCell.sheetId,n="isValueInRange"===s.criterion.type?this.getters.getDataValidationRangeValues(i,s.criterion):s.criterion.values.map((e=>({label:e,value:e})));if(!("chip"===s.criterion.displayStyle))return n.map((e=>({text:e.value,fuzzySearchKey:e.label,htmlContent:[{value:e.label}]})));const r=s.criterion.colors;return n.map((e=>{const t=r?.[e.value];return{text:e.value,htmlContent:[{value:e.label,color:t?no(t):void 0,backgroundColor:t||F,classes:["badge rounded-pill fs-6 fw-normal w-100 mt-1 text-start"]}],fuzzySearchKey:e.label}}))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}}),mE.add("functions",{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if("SYMBOL"!==e.type)return[];const t=e.value;if(!Lt(this.composer.currentContent))return[];const o=Object.entries(RS.content).filter((([e,{hidden:t}])=>!t)).map((([e,{description:o}])=>({text:e,description:o,htmlContent:EN(t,e,E,"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)}}),mE.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:wE.NUMBER}],fuzzySearchKey:o+t.name,alwaysExpanded:!0}})).filter(lt)},selectProposal:HN}),mE.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=UN(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:Ho("Count"),htmlContent:[{value:e,color:wE.STRING}],fuzzySearchKey:Ho("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:wE.STRING}],fuzzySearchKey:o}}(e)})).filter(lt):[]},selectProposal:LN}),mE.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=UN(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(lt),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=Ok.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(lt);return m.map((e=>{const[t,o]=e.split(":"),s=n[t];return s?VN(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:Ho("%s (positional)",o.string)+(o.help?` (${o.help})`:""),htmlContent:[{value:s,color:wE.STRING}],fuzzySearchKey:o.string+s}}))).filter(lt)},selectProposal:LN}),mE.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=UN(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(yn).map(((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:wE.NUMBER}]}))):"quarter_number"===a.granularity?[1,2,3,4].map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:Ho("Quarter %s",e),htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"day_of_month"===a.granularity?je(1,32).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"iso_week_number"===a.granularity?je(0,54).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"day_of_week"===a.granularity?je(1,8).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"hour_number"===a.granularity?je(0,24).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"minute_number"===a.granularity?je(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.NUMBER}]}))):"second_number"===a.granularity?je(0,60).map((e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:"",htmlContent:[{value:`${e}`,color:wE.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?wE.STRING:wE.NUMBER}],fuzzySearchKey:s+i}}))},selectProposal:LN}),mE.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 AL=new n;AL.add("link",{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t,o)=>Zo(t.model.getters.getEvaluatedCell(e).link,t,o),title:(e,t)=>{const o=t.getEvaluatedCell(e).link;return o?o.isExternal?Ho("Go to url: %(url)s",{url:o.url}):Ho("Go to %(label)s",{label:o.label}):""},sequence:5});const DL=(new n).add("ADD_COLUMNS_ROWS",(function(e){const t=[];let o=e.base;"after"===e.position&&o++;for(let s=0;s<e.quantity;s++)t.push(s+o);return[{type:"REMOVE_COLUMNS_ROWS",dimension:e.dimension,elements:t,sheetId:e.sheetId,sheetName:e.sheetName}]})).add("REMOVE_COLUMNS_ROWS",(function(e){const t=[],o=[...e.elements].sort(((e,t)=>e-t));for(const s of Ye(o)){const o=0===s[0]?0:s[0]-1,i=0===s[0]?"before":"after";t.push({type:"ADD_COLUMNS_ROWS",dimension:e.dimension,quantity:s.length,base:o,sheetId:e.sheetId,sheetName:e.sheetName,position:i})}return t})).add("ADD_MERGE",(function(e){return[{type:"REMOVE_MERGE",sheetId:e.sheetId,target:e.target}]})).add("REMOVE_MERGE",(function(e){return[{type:"ADD_MERGE",sheetId:e.sheetId,target:e.target}]})).add("CREATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetId,sheetName:e.name}]})).add("DELETE_SHEET",(function(e){return[{type:"CREATE_SHEET",sheetId:e.sheetId,position:1,name:e.sheetName}]})).add("DUPLICATE_SHEET",(function(e){return[{type:"DELETE_SHEET",sheetId:e.sheetIdTo,sheetName:""}]})).add("CREATE_FIGURE",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("CREATE_CHART",(function(e){return[{type:"DELETE_FIGURE",figureId:e.figureId,sheetId:e.sheetId}]})).add("HIDE_COLUMNS_ROWS",(function(e){return[{type:"UNHIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("UNHIDE_COLUMNS_ROWS",(function(e){return[{type:"HIDE_COLUMNS_ROWS",sheetId:e.sheetId,dimension:e.dimension,elements:e.elements}]})).add("CREATE_TABLE_STYLE",(function(e){return[{type:"REMOVE_TABLE_STYLE",tableStyleId:e.tableStyleId}]})).add("ADD_PIVOT",(function(e){return[{type:"REMOVE_PIVOT",pivotId:e.pivotId}]})).add("RENAME_SHEET",(function(e){return[{type:"RENAME_SHEET",sheetId:e.sheetId,oldName:e.newName,newName:e.oldName}]}));for(const e of Ls.values())DL.contains(e)||DL.add(e,_L);function _L(e){return[e]}const OL=new n;OL.add("format_number_automatic",{...pF,id:"format_number_automatic",sequence:10}).add("format_number_plain_text",{...mF,id:"format_number_plain_text",sequence:15,separator:!0}).add("format_number_number",{...fF,id:"format_number_number",sequence:20}).add("format_number_percent",{...bF,id:"format_number_percent",sequence:30,separator:!0}).add("format_number_currency",{...SF,id:"format_number_currency",sequence:40}).add("format_number_accounting",{...yF,id:"format_number_accounting",sequence:45}).add("format_number_currency_rounded",{...CF,id:"format_number_currency_rounded",sequence:50}).add("format_custom_currency",{...IF,id:"format_custom_currency",sequence:60,separator:!0}).add("format_number_date",{...xF,id:"format_number_date",sequence:70}).add("format_number_time",{...EF,id:"format_number_time",sequence:80}).add("format_number_date_time",{...RF,id:"format_number_date_time",sequence:90}).add("format_number_duration",{...TF,id:"format_number_duration",sequence:100,separator:!0}).add("more_formats",{..._F,id:"more_formats",sequence:120});const FL=Et((e=>On(e)?"date":e.includes("[$")?"currency":"number")),PL={name:Ho("More formats"),icon:"o-spreadsheet-Icon.NUMBER_FORMATS",children:[e=>{const t=function(e){const t=new Set(OL.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=FL(s.format);"date"!==e&&"currency"!==e||o.set(s.format,gF({descriptionValue:"currency"===e?1e3:wF,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([...OL.getAll(),...t])}]};const ML=new vR;ML.add("file",{name:Ho("File"),sequence:10}).addChild("settings",["file"],{name:Ho("Settings"),sequence:200,execute:e=>e.openSidePanel("Settings"),isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.COG"}).add("edit",{name:Ho("Edit"),sequence:20}).addChild("undo",["edit"],{...__,sequence:10}).addChild("redo",["edit"],{...O_,sequence:20,separator:!0}).addChild("copy",["edit"],{...F_,sequence:30}).addChild("cut",["edit"],{...P_,sequence:40}).addChild("paste",["edit"],{...M_,sequence:50}).addChild("paste_special",["edit"],{...N_,sequence:60,separator:!0}).addChild("paste_special_value",["edit","paste_special"],{...k_,sequence:10}).addChild("paste_special_format",["edit","paste_special"],{...V_,sequence:20}).addChild("edit_table",["edit"],{...X_,isVisible:VD,sequence:60}).addChild("find_and_replace",["edit"],{...L_,sequence:65,separator:!0}).addChild("delete",["edit"],{name:Ho("Delete"),icon:"o-spreadsheet-Icon.TRASH",sequence:70}).addChild("edit_delete_cell_values",["edit","delete"],{...H_,sequence:10}).addChild("edit_delete_row",["edit","delete"],{...U_,sequence:20}).addChild("edit_delete_column",["edit","delete"],{...$_,sequence:30}).addChild("edit_delete_cell_shift_up",["edit","delete"],{...Z_,sequence:40}).addChild("edit_delete_cell_shift_left",["edit","delete"],{...j_,sequence:50}).addChild("edit_unhide_columns",["edit"],{...jD,sequence:80}).addChild("edit_unhide_rows",["edit"],{...KD,sequence:80}).add("view",{name:Ho("View"),sequence:30}).addChild("unfreeze_panes",["view"],{...JD,sequence:4}).addChild("freeze_panes",["view"],{...QD,sequence:5}).addChild("unfreeze_rows",["view","freeze_panes"],{...e_,sequence:5}).addChild("freeze_first_row",["view","freeze_panes"],{...t_,sequence:10}).addChild("freeze_second_row",["view","freeze_panes"],{...o_,sequence:15}).addChild("freeze_current_row",["view","freeze_panes"],{...s_,sequence:20,separator:!0}).addChild("unfreeze_columns",["view","freeze_panes"],{...i_,sequence:25}).addChild("freeze_first_col",["view","freeze_panes"],{...n_,sequence:30}).addChild("freeze_second_col",["view","freeze_panes"],{...r_,sequence:35}).addChild("freeze_current_col",["view","freeze_panes"],{...a_,sequence:40}).addChild("group_headers",["view"],{name:Ho("Group"),sequence:15,separator:!0,icon:"o-spreadsheet-Icon.PLUS_IN_BOX",isVisible:HD}).addChild("group_columns",["view","group_headers"],{...d_,sequence:5}).addChild("ungroup_columns",["view","group_headers"],{...g_,isVisible:e=>v_(e,"COL"),sequence:10}).addChild("group_rows",["view","group_headers"],{...u_,sequence:15}).addChild("ungroup_rows",["view","group_headers"],{...p_,isVisible:e=>v_(e,"ROW"),sequence:20}).addChild("show",["view"],{name:Ho("Show"),sequence:1,icon:"o-spreadsheet-Icon.SHOW"}).addChild("view_gridlines",["view","show"],{...l_,sequence:5}).addChild("view_formulas",["view","show"],{...h_,sequence:10}).addChild("view_irregularity_map",["view"],{...c_,sequence:40,separator:!0}).add("insert",{name:Ho("Insert"),sequence:40}).addChild("insert_row",["insert"],{...eO,sequence:10}).addChild("insert_row_before",["insert","insert_row"],{...oO,sequence:10}).addChild("insert_row_after",["insert","insert_row"],{...nO,sequence:20}).addChild("insert_column",["insert"],{...rO,sequence:20}).addChild("insert_column_before",["insert","insert_column"],{...lO,sequence:10}).addChild("insert_column_after",["insert","insert_column"],{...dO,sequence:20}).addChild("insert_cell",["insert"],{...uO,sequence:30}).addChild("insert_cell_down",["insert","insert_cell"],{...gO,name:Ho("Shift down"),sequence:10}).addChild("insert_cell_right",["insert","insert_cell"],{...pO,name:Ho("Shift right"),sequence:20}).addChild("insert_sheet",["insert"],{...DO,sequence:40,separator:!0}).addChild("insert_chart",["insert"],{...mO,sequence:50}).addChild("insert_pivot",["insert"],{...fO,sequence:52}).addChild("insert_image",["insert"],{...vO,sequence:55}).addChild("insert_table",["insert"],{...bO,sequence:57}).addChild("insert_function",["insert"],{...SO,sequence:60}).addChild("insert_function_sum",["insert","insert_function"],{...CO,sequence:0}).addChild("insert_function_average",["insert","insert_function"],{...yO,sequence:10}).addChild("insert_function_count",["insert","insert_function"],{...wO,sequence:20}).addChild("insert_function_max",["insert","insert_function"],{...IO,sequence:30}).addChild("insert_function_min",["insert","insert_function"],{...xO,sequence:40,separator:!0}).addChild("categorie_function_all",["insert","insert_function"],{...EO,sequence:50}).addChild("categories_function_list",["insert","insert_function"],(()=>{const e=RS.content;return[...new Set(RS.getAll().filter((e=>!e.hidden)).map((e=>e.category)))].filter(lt).sort().map(((t,o)=>{const s=Object.keys(e).filter((o=>e[o].category===t&&!e[o].hidden));return{name:t,children:_O(s)}}))})).addChild("insert_link",["insert"],{...RO,separator:!0,sequence:70}).addChild("insert_checkbox",["insert"],{...TO,sequence:80}).addChild("insert_dropdown",["insert"],{...AO,separator:!0,sequence:90}).add("format",{name:Ho("Format"),sequence:50}).addChild("format_number",["format"],{...PL,name:Ho("Number"),sequence:10,separator:!0}).addChild("format_bold",["format"],{...zF,sequence:20}).addChild("format_italic",["format"],{...$F,sequence:30}).addChild("format_underline",["format"],{...GF,sequence:40}).addChild("format_strikethrough",["format"],{...WF,sequence:50,separator:!0}).addChild("format_font_size",["format"],{...qF,sequence:60,separator:!0}).addChild("format_alignment",["format"],{...ZF,sequence:70}).addChild("format_alignment_left",["format","format_alignment"],{...YF,sequence:10}).addChild("format_alignment_center",["format","format_alignment"],{...XF,sequence:20}).addChild("format_alignment_right",["format","format_alignment"],{...KF,sequence:30,separator:!0}).addChild("format_alignment_top",["format","format_alignment"],{...QF,sequence:40}).addChild("format_alignment_middle",["format","format_alignment"],{...eP,sequence:50}).addChild("format_alignment_bottom",["format","format_alignment"],{...tP,sequence:60,separator:!0}).addChild("format_wrapping",["format"],{...oP,sequence:80,separator:!0}).addChild("format_wrapping_overflow",["format","format_wrapping"],{...iP,sequence:10}).addChild("format_wrapping_wrap",["format","format_wrapping"],{...nP,sequence:20}).addChild("format_wrapping_clip",["format","format_wrapping"],{...rP,sequence:30}).addChild("format_cf",["format"],{...aP,sequence:90,separator:!0}).addChild("format_clearFormat",["format"],{...lP,sequence:100,separator:!0}).add("data",{name:Ho("Data"),sequence:60}).addChild("sort_range",["data"],{...oF,sequence:10,separator:!0}).addChild("sort_ascending",["data","sort_range"],{...sF,sequence:10}).addChild("sort_descending",["data","sort_range"],{...aF,sequence:20}).addChild("data_cleanup",["data"],{...iF,sequence:15}).addChild("remove_duplicates",["data","data_cleanup"],{...nF,sequence:10}).addChild("trim_whitespace",["data","data_cleanup"],{...rF,sequence:20}).addChild("split_to_columns",["data"],{...hF,sequence:20}).addChild("data_validation",["data"],{name:Ho("Data Validation"),execute:e=>{e.openSidePanel("DataValidation")},isEnabled:e=>!e.isSmall,icon:"o-spreadsheet-Icon.DATA_VALIDATION",sequence:30,separator:!0}).addChild("add_remove_data_filter",["data"],{...lF,sequence:40,separator:!0}).addChild("pivot_data_sources",["data"],(e=>{const t=e.model.getters.getPivotIds().length;return e.model.getters.getPivotIds().map(((o,s)=>{const i={get highlights(){return wN(e.model.getters,o)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(o)}`,name:e.model.getters.getPivotDisplayName(o),sequence:50+s/t,isReadonlyAllowed:!0,execute:e=>e.openSidePanel("PivotSidePanel",{pivotId:o}),isEnabled:e=>!e.isSmall,onStartHover:e=>e.getStore(vE).register(i),onStopHover:e=>e.getStore(vE).unRegister(i),icon:"o-spreadsheet-Icon.PIVOT",separator:s===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(o)?"o-spreadsheet-Icon.UNUSED_PIVOT_WARNING":void 0}}))})).addChild("reinsert_dynamic_pivot",["data"],dF).addChild("reinsert_static_pivot",["data"],uF);const NL=new class extends n{mapping={};uuidGenerator=new Ka;replace(e,t){const o={...t,id:this.uuidGenerator.uuidv4()};return super.replace(e,o)}getAllOrdered(){return this.getAll().sort(((e,t)=>e.sequence-t.sequence))}};class kL{listeners=[];async sendMessage(e){for(const{callback:t}of this.listeners)t(e)}onNewMessage(e,t){this.listeners.push({id:e,callback:t})}leave(e){this.listeners=this.listeners.filter((t=>t.id!==e))}}class VL{fileStore;constructor(e){this.fileStore=e}async requestImage(){const e=await this.userImageUpload(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}async uploadFile(e){const t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}userImageUpload(){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.addEventListener("load",(()=>{const e={width:s.width,height:s.height};t(e)})),s.addEventListener("error",o),s.src=e}))}}const LL=[{transform:"scale(0)"},{transform:"scale(0.8)",offset:.33},{opacity:"0",transform:"scale(1)",offset:1}];yh`
|
|
1875
1875
|
.o-ripple {
|
|
1876
1876
|
z-index: 1;
|
|
1877
1877
|
}
|
|
@@ -2170,7 +2170,7 @@
|
|
|
2170
2170
|
.o-small-composer {
|
|
2171
2171
|
z-index: ${Fe.TopBarComposer};
|
|
2172
2172
|
}
|
|
2173
|
-
`;class tH extends t.Component{static components={Composer:DE,BottomBar:WL,Ripple:UL,RibbonMenu:eH};static template="o-spreadsheet-SmallBottomBar";static props={onClick:Function};composerFocusStore;composerStore;composerInterface;composerRef=t.useRef("bottombarComposer");menuState=t.useState({isOpen:!1});setup(){this.composerFocusStore=lh(bh);const e=lh(AP);this.composerStore=e,this.composerInterface={id:"bottombarComposer",get editionMode(){return e.editionMode},startEdition:this.composerStore.startEdition,setCurrentContent:this.composerStore.setCurrentContent,stopEdition:this.composerStore.stopEdition},t.useEffect((()=>{this.env.isMobile()&&!this.menuState.isOpen&&"inactive"!==this.composerStore.editionMode&&this.composerFocusStore.activeComposer!==this.composerInterface&&this.composerFocusStore.focusComposer(this.composerInterface,{focusMode:"contentFocus"})}))}get focus(){return this.composerFocusStore.activeComposer===this.composerInterface?this.composerFocusStore.focusMode:"inactive"}get rect(){return this.composerRef.el?my(this.composerRef.el):{x:0,y:0,width:0,height:0}}get composerProps(){const{width:e,height:t}=this.env.model.getters.getSheetViewDimensionWithHeaders();return{rect:{...this.rect},delimitation:{width:e,height:t},focus:this.focus,composerStore:this.composerStore,onComposerContentFocused:()=>this.composerFocusStore.focusComposer(this.composerInterface,{focusMode:"contentFocus"}),isDefaultFocus:!1,inputStyle:xh({height:"inactive"===this.focus?"26px":"fit-content","max-height":"130px"}),showAssistant:!Ry()}}get symbols(){return["=","(",")",":","-","/","*",",","+","$","."]}insertSymbol(e){this.composerStore.replaceComposerCursorSelection(e),this.composerFocusStore.focusComposer(this.composerInterface,{focusMode:"contentFocus"})}toggleRibbon(){this.composerStore.cancelEdition(),this.menuState.isOpen=!this.menuState.isOpen}}yh`
|
|
2173
|
+
`;class tH extends t.Component{static components={Composer:DE,BottomBar:WL,Ripple:UL,RibbonMenu:eH};static template="o-spreadsheet-SmallBottomBar";static props={onClick:Function};composerFocusStore;composerStore;composerInterface;composerRef=t.useRef("bottombarComposer");menuState=t.useState({isOpen:!1});setup(){this.composerFocusStore=lh(bh);const e=lh(AP);this.composerStore=e,this.composerInterface={id:"bottombarComposer",get editionMode(){return e.editionMode},startEdition:this.composerStore.startEdition,setCurrentContent:this.composerStore.setCurrentContent,stopEdition:this.composerStore.stopEdition},t.useEffect((()=>{this.env.isMobile()&&!this.menuState.isOpen&&"inactive"!==this.composerStore.editionMode&&this.composerFocusStore.activeComposer!==this.composerInterface&&this.composerFocusStore.focusComposer(this.composerInterface,{focusMode:"contentFocus"})}))}get focus(){return this.composerFocusStore.activeComposer===this.composerInterface?this.composerFocusStore.focusMode:"inactive"}get showFxIcon(){return"inactive"===this.focus&&!this.composerStore.currentContent}get rect(){return this.composerRef.el?my(this.composerRef.el):{x:0,y:0,width:0,height:0}}get composerProps(){const{width:e,height:t}=this.env.model.getters.getSheetViewDimensionWithHeaders();return{rect:{...this.rect},delimitation:{width:e,height:t},focus:this.focus,composerStore:this.composerStore,onComposerContentFocused:()=>this.composerFocusStore.focusComposer(this.composerInterface,{focusMode:"contentFocus"}),isDefaultFocus:!1,inputStyle:xh({height:"inactive"===this.focus?"26px":"fit-content","max-height":"130px"}),showAssistant:!Ry()}}get symbols(){return["=","(",")",":","-","/","*",",","+","$","."]}insertSymbol(e){this.composerStore.replaceComposerCursorSelection(e),this.composerFocusStore.focusComposer(this.composerInterface,{focusMode:"contentFocus"})}toggleRibbon(){this.composerStore.cancelEdition(),this.menuState.isOpen=!this.menuState.isOpen}}yh`
|
|
2174
2174
|
.o-topbar-composer-container {
|
|
2175
2175
|
height: ${34}px;
|
|
2176
2176
|
}
|
|
@@ -2181,20 +2181,12 @@
|
|
|
2181
2181
|
margin-bottom: -1px;
|
|
2182
2182
|
border: 1px solid;
|
|
2183
2183
|
font-family: ${fe};
|
|
2184
|
-
|
|
2185
|
-
/* In readonly we always show the fx icon if the composer is empty, not matter the focus */
|
|
2186
|
-
.o-composer:empty:not(:focus):not(.active)::before,
|
|
2187
|
-
&.o-topbar-composer-readonly .o-composer:empty::before {
|
|
2188
|
-
content: url("data:image/svg+xml,${encodeURIComponent("\n<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 121.8 122.9' width='16' height='16' focusable='false'>\n <path d='m28 34-4 5v2h10l-6 40c-4 22-6 28-7 30-2 2-3 3-5 3-3 0-7-2-9-4H4c-2 2-4 4-4 7s4 6 8 6 9-2 15-8c8-7 13-17 18-39l7-35 13-1 3-6H49c4-23 7-27 11-27 2 0 5 2 8 6h4c1-1 4-4 4-7 0-2-3-6-9-6-5 0-13 4-20 10-6 7-9 14-11 24h-8zm41 16c4-5 7-7 8-7s2 1 5 9l3 12c-7 11-12 17-16 17l-3-1-2-1c-3 0-6 3-6 7s3 7 7 7c6 0 12-6 22-23l3 10c3 9 6 13 10 13 5 0 11-4 18-15l-3-4c-4 6-7 8-8 8-2 0-4-3-6-10l-5-15 8-10 6-4 3 1 3 2c2 0 6-3 6-7s-2-7-6-7c-6 0-11 5-21 20l-2-6c-3-9-5-14-9-14-5 0-12 6-18 15l3 3z' fill='#BDBDBD'/>\n</svg>\n")}");
|
|
2189
|
-
position: relative;
|
|
2190
|
-
top: 20%;
|
|
2191
|
-
}
|
|
2192
2184
|
}
|
|
2193
2185
|
|
|
2194
2186
|
.user-select-text {
|
|
2195
2187
|
user-select: text;
|
|
2196
2188
|
}
|
|
2197
|
-
`;class oH extends t.Component{static template="o-spreadsheet-TopBarComposer";static props={};static components={Composer:DE};composerFocusStore;composerStore;composerInterface;setup(){this.composerFocusStore=lh(bh);const e=lh(AP);this.composerStore=e,this.composerInterface={id:"topbarComposer",get editionMode(){return e.editionMode},startEdition:this.composerStore.startEdition,setCurrentContent:this.composerStore.setCurrentContent,stopEdition:this.composerStore.stopEdition}}get focus(){return this.composerFocusStore.activeComposer===this.composerInterface?this.composerFocusStore.focusMode:"inactive"}get composerStyle(){const e={padding:"5px 0px 5px 8px","max-height":"100px","line-height":"24px"};return e.height="inactive"===this.focus?"34px":"fit-content",xh(e)}get containerStyle(){return"inactive"===this.focus?xh({"border-color":C,"border-right":"none"}):xh({"border-color":p,"z-index":String(Fe.TopBarComposer)})}onFocus(e){this.composerFocusStore.focusComposer(this.composerInterface,{selection:e})}}class sH{mutators=["closeDropdowns","openDropdown"];_currentDropdown=null;closeDropdowns(){this._currentDropdown=null}openDropdown(e){this._currentDropdown=e}get currentDropdown(){return this._currentDropdown}}function iH(){const e=t.useComponent(),o=lh(sH);return t.onWillUnmount((()=>{e===o.currentDropdown&&o.closeDropdowns()})),{closeDropdowns:()=>o.closeDropdowns(),openDropdown:()=>{o.openDropdown(e)},get isActive(){return o.currentDropdown===e}}}const nH=[[["all","o-spreadsheet-Icon.BORDERS"],["hv","o-spreadsheet-Icon.BORDER_HV"],["h","o-spreadsheet-Icon.BORDER_H"],["v","o-spreadsheet-Icon.BORDER_V"],["external","o-spreadsheet-Icon.BORDER_EXTERNAL"]],[["left","o-spreadsheet-Icon.BORDER_LEFT"],["top","o-spreadsheet-Icon.BORDER_TOP"],["right","o-spreadsheet-Icon.BORDER_RIGHT"],["bottom","o-spreadsheet-Icon.BORDER_BOTTOM"],["clear","o-spreadsheet-Icon.BORDER_CLEAR"]]];yh`
|
|
2189
|
+
`;class oH extends t.Component{static template="o-spreadsheet-TopBarComposer";static props={};static components={Composer:DE};composerFocusStore;composerStore;composerInterface;setup(){this.composerFocusStore=lh(bh);const e=lh(AP);this.composerStore=e,this.composerInterface={id:"topbarComposer",get editionMode(){return e.editionMode},startEdition:this.composerStore.startEdition,setCurrentContent:this.composerStore.setCurrentContent,stopEdition:this.composerStore.stopEdition}}get focus(){return this.composerFocusStore.activeComposer===this.composerInterface?this.composerFocusStore.focusMode:"inactive"}get showFxIcon(){return"inactive"===this.focus&&!this.composerStore.currentContent}get composerStyle(){const e={padding:"5px 0px 5px 8px","max-height":"100px","line-height":"24px"};return e.height="inactive"===this.focus?"34px":"fit-content",xh(e)}get containerStyle(){return"inactive"===this.focus?xh({"border-color":C,"border-right":"none"}):xh({"border-color":p,"z-index":String(Fe.TopBarComposer)})}onFocus(e){this.composerFocusStore.focusComposer(this.composerInterface,{selection:e})}}class sH{mutators=["closeDropdowns","openDropdown"];_currentDropdown=null;closeDropdowns(){this._currentDropdown=null}openDropdown(e){this._currentDropdown=e}get currentDropdown(){return this._currentDropdown}}function iH(){const e=t.useComponent(),o=lh(sH);return t.onWillUnmount((()=>{e===o.currentDropdown&&o.closeDropdowns()})),{closeDropdowns:()=>o.closeDropdowns(),openDropdown:()=>{o.openDropdown(e)},get isActive(){return o.currentDropdown===e}}}const nH=[[["all","o-spreadsheet-Icon.BORDERS"],["hv","o-spreadsheet-Icon.BORDER_HV"],["h","o-spreadsheet-Icon.BORDER_H"],["v","o-spreadsheet-Icon.BORDER_V"],["external","o-spreadsheet-Icon.BORDER_EXTERNAL"]],[["left","o-spreadsheet-Icon.BORDER_LEFT"],["top","o-spreadsheet-Icon.BORDER_TOP"],["right","o-spreadsheet-Icon.BORDER_RIGHT"],["bottom","o-spreadsheet-Icon.BORDER_BOTTOM"],["clear","o-spreadsheet-Icon.BORDER_CLEAR"]]];yh`
|
|
2198
2190
|
.o-border-selector {
|
|
2199
2191
|
padding: 4px;
|
|
2200
2192
|
background-color: white;
|
|
@@ -3340,4 +3332,4 @@
|
|
|
3340
3332
|
<tableParts count="${e.tables.length}">
|
|
3341
3333
|
${Ix(a)}
|
|
3342
3334
|
</tableParts>
|
|
3343
|
-
`}var FU;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(FU||(FU={}));function PU(e,t={}){const o=ze(t);return o.type=e,o}const MU={},NU={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:te,HEADER_WIDTH:oe,DESKTOP_BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:se,DEFAULT_CELL_HEIGHT:ie,SCROLLBAR_WIDTH:ne},kU={autoCompleteProviders:mE,autofillModifiersRegistry:PV,autofillRulesRegistry:MV,cellMenuRegistry:tF,colMenuRegistry:gP,errorTypes:oi,linkMenuRegistry:bR,functionRegistry:RS,featurePluginRegistry:EL,iconsOnCellRegistry:TV,statefulUIPluginRegistry:RL,coreViewsPluginRegistry:TL,corePluginRegistry:xL,rowMenuRegistry:SP,sidePanelRegistry:wk,figureRegistry:Gx,chartSidePanelComponentRegistry:JM,chartComponentRegistry:ix,chartRegistry:sx,chartSubtypeRegistry:rx,topbarMenuRegistry:ML,topbarComponentRegistry:NL,clickableCellRegistry:AL,otRegistry:$V,inverseCommandRegistry:DL,urlRegistry:zo,cellPopoverRegistry:Zx,numberFormatMenuRegistry:OL,repeatLocalCommandTransformRegistry:vL,repeatCommandTransformRegistry:fL,clipboardHandlersRegistries:eh,pivotRegistry:ik,pivotTimeAdapterRegistry:vc,pivotSidePanelRegistry:lk,pivotNormalizationValueRegistry:jc,supportedPivotPositionalFormulaRegistry:Ok,pivotToFunctionValueRegistry:Yc,migrationStepRegistry:lD,chartJsExtensionRegistry:Eh},VU={arg:Qh,isEvaluationError:gi,toBoolean:Ei,toJsDate:Ri,toNumber:fi,toString:wi,toNormalizedPivotValue:Gc,toFunctionPivotValue:qc,toXC:Po,toZone:ur,toUnboundedZone:dr,toCartesian:Fo,numberToLetters:wo,lettersToNumber:Io,UuidGenerator:Ka,formatValue:In,createCurrencyFormat:Vn,ColorGenerator:fo,computeTextWidth:Va,createEmptyWorkbookData:SD,createEmptySheet:bD,createEmptyExcelSheet:CD,rgbaToHex:Yt,colorToRGBA:Xt,positionToZone:Mr,isDefined:lt,isMatrix:js,lazy:ut,genericRepeat:bL,createAction:i,createActions:o,transformRangeData:oh,deepEquals:mt,overlap:xr,union:yr,isInside:Er,deepCopy:ze,expandZoneOnInsertion:vr,reduceZoneOnDeletion:Cr,unquote:Ge,getMaxObjectId:kc,getFunctionsFromTokens:GS,getFirstPivotFunction:BN,getNumberOfPivotFunctions:zN,parseDimension:Hc,isDateOrDatetimeField:Uc,makeFieldProposal:VN,insertTokenAfterArgSeparator:LN,insertTokenAfterLeftParenthesis:HN,mergeContiguousZones:Br,getPivotHighlights:wN,pivotTimeAdapter:bc,UNDO_REDO_PIVOT_COMMANDS:OV,createPivotFormula:$c,areDomainArgsFieldsValid:zc,splitReference:ra,sanitizeSheetName:qe,getUniqueText:Vt,isNumber:Rs,isDateTime:cs},LU={isMarkdownLink:et,parseMarkdownLink:st,markdownLink:ot,openLink:Zo,urlRepresentation:qo},HU={Checkbox:oR,Section:BE,RoundColorPicker:zE,ChartDataSeries:cM,ChartErrorSection:hM,ChartLabelRange:dM,ChartTitle:SM,ChartPanel:tN,ChartFigure:zx,ChartJsComponent:jC,Grid:_k,GridOverlay:GP,ScorecardChart:cy,LineConfigPanel:LM,BarConfigPanel:gM,PieChartDesignPanel:BM,GenericChartConfigPanel:uM,ChartWithAxisDesignPanel:TM,LineChartDesignPanel:HM,GaugeChartConfigPanel:OM,GaugeChartDesignPanel:FM,ScorecardChartConfigPanel:$M,ScorecardChartDesignPanel:GM,GeoChartDesignPanel:kM,RadarChartDesignPanel:zM,WaterfallChartDesignPanel:KM,ComboChartDesignPanel:DM,FunnelChartDesignPanel:_M,ChartTypePicker:QM,FigureComponent:Wx,MenuPopover:Ux,Popover:kx,SelectionInput:XE,ValidationMessages:kP,AddDimensionButton:RN,PivotDimensionGranularity:_N,PivotDimensionOrder:ON,PivotDimension:DN,PivotLayoutConfigurator:MN,PivotHTMLRenderer:Pk,PivotDeferUpdate:IN,PivotTitleSection:NN,CogWheelMenu:AN,TextInput:TN,SidePanelCollapsible:Jx,RadioSelection:yM,GeoChartRegionSelectSection:PM,ChartDashboardMenu:Bx,FullScreenChart:Fk},UU={useDragAndDropListItems:$E,useHighlights:iN,useHighlightsOnHover:sN},BU={useStoreProvider:ah,DependencyContainer:ih,CellPopoverStore:jx,ComposerFocusStore:bh,CellComposerStore:AP,FindAndReplaceStore:fN,HighlightStore:vE,DelayedHoveredCellStore:qx,HoveredTableStore:BP,ModelStore:gh,NotificationStore:bE,RendererStore:mh,SelectionInputStore:YE,SpreadsheetStore:fh,useStore:lh,useLocalStore:ch,SidePanelStore:Rk,PivotSidePanelStore:rk,PivotMeasureDisplayPanelStore:CN,ClientFocusStore:yP,GridRenderer:JP};const zU={DEFAULT_LOCALE:qs,HIGHLIGHT_COLOR:a,PIVOT_TABLE_CONFIG:Ve,ChartTerms:Yy},$U={...ux,...xI};e.AbstractCellClipboardHandler=rl,e.AbstractChart=YC,e.AbstractFigureClipboardHandler=Qc,e.CellErrorType=ti,e.ClientDisconnectedError=sL,e.CorePlugin=Nk,e.CoreViewPlugin=$k,e.DispatchResult=Us,e.EvaluationError=si,e.LocalTransportService=kL,e.Model=class extends sh{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 Ka,n=!1){const r=performance.now();console.debug("##### Model creation #####"),super(),ko===Mo&&Vo===No&&(Vo=()=>!0),s=fD(e,s);const a=gD(e,n);this.state=new _H,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new Bk(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.getRangeData=this.range.getRangeData.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.coreGetters.adaptFormulaStringDependencies=this.range.adaptFormulaStringDependencies.bind(this.range),this.coreGetters.copyFormulaStringForSheet=this.range.copyFormulaStringForSheet.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new AH(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(const e of xL.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(const e of TL.getAll()){const t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(const e of RL.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(const e of EL.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(const 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(const 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(const 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(const t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new iL(EH({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.dispatchToHandlers(this.coreHandlers,{type:"UNDO",commands:[e]})}}),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.smallUuid(),name:Ho("Anonymous").toString()},o=e.transportService||new kL;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(Ws));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=Hs(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new Us(t.flat()):Us.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(PU(e,t));dispatch=(e,t)=>{const o=PU(e,t),s=this.status;if(this.getters.isReadonly()&&(i=o,!Vs.has(i.type)))return new Us("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new Us("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();Hs(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(Hs(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(Hs(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return Us.Success};dispatchFromCorePlugin=(e,t)=>{const o=PU(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,Us.Success};dispatchToHandlers(e,t){const o=Hs(t);for(const s of e)!o&&s instanceof Nk||s.beforeHandle(t);for(const s of e)!o&&s instanceof Nk||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=SD();for(const t of this.handlers)t instanceof Nk&&t.export(e);return e.revisionId=this.session.getRevisionId()||Se,e=ze(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...SD(),sheets:[CD(uD,"Sheet1")]};for(const t of this.handlers)t instanceof Mk&&t.exportForExcel(e);return e=ze(e),_U(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=$N,e.Registry=n,e.Revision=oL,e.SPREADSHEET_DIMENSIONS=NU,e.Spreadsheet=vH,e.SpreadsheetPivotTable=qN,e.UIPlugin=BV,e.__info__=MU,e.addFunction=function e(t,o){return RS.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(Xs[e])throw new Error(`Layer ${e} already exists`);Xs[e]=t},e.astToFormula=gv,e.chartHelpers=$U,e.compile=HS,e.compileTokens=US,e.components=HU,e.constants=zU,e.convertAstNodes=cv,e.coreTypes=Ls,e.findCellInNewZone=Pr,e.functionCache=LS,e.helpers=VU,e.hooks=UU,e.invalidateCFEvaluationCommands=Ns,e.invalidateChartEvaluationCommands=Ps,e.invalidateDependenciesCommands=Ms,e.invalidateEvaluationCommands=Fs,e.iterateAstNodes=hv,e.links=LU,e.load=gD,e.parse=av,e.parseTokens=lv,e.readonlyAllowedCommands=Vs,e.registries=kU,e.setDefaultSheetViewSize=function(e){Pe=e},e.setTranslationMethod=function(e,t=(()=>!0)){ko=e,Vo=t},e.stores=BU,e.tokenColors=wE,e.tokenize=cl,MU.version="18.4.12",MU.date="2025-09-23T12:37:43.708Z",MU.hash="0c91305"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|
|
3335
|
+
`}var FU;!function(e){e[e.Ready=0]="Ready",e[e.Running=1]="Running",e[e.RunningCore=2]="RunningCore",e[e.Finalizing=3]="Finalizing"}(FU||(FU={}));function PU(e,t={}){const o=ze(t);return o.type=e,o}const MU={},NU={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:te,HEADER_WIDTH:oe,DESKTOP_BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:se,DEFAULT_CELL_HEIGHT:ie,SCROLLBAR_WIDTH:ne},kU={autoCompleteProviders:mE,autofillModifiersRegistry:PV,autofillRulesRegistry:MV,cellMenuRegistry:tF,colMenuRegistry:gP,errorTypes:oi,linkMenuRegistry:bR,functionRegistry:RS,featurePluginRegistry:EL,iconsOnCellRegistry:TV,statefulUIPluginRegistry:RL,coreViewsPluginRegistry:TL,corePluginRegistry:xL,rowMenuRegistry:SP,sidePanelRegistry:wk,figureRegistry:Gx,chartSidePanelComponentRegistry:JM,chartComponentRegistry:ix,chartRegistry:sx,chartSubtypeRegistry:rx,topbarMenuRegistry:ML,topbarComponentRegistry:NL,clickableCellRegistry:AL,otRegistry:$V,inverseCommandRegistry:DL,urlRegistry:zo,cellPopoverRegistry:Zx,numberFormatMenuRegistry:OL,repeatLocalCommandTransformRegistry:vL,repeatCommandTransformRegistry:fL,clipboardHandlersRegistries:eh,pivotRegistry:ik,pivotTimeAdapterRegistry:vc,pivotSidePanelRegistry:lk,pivotNormalizationValueRegistry:jc,supportedPivotPositionalFormulaRegistry:Ok,pivotToFunctionValueRegistry:Yc,migrationStepRegistry:lD,chartJsExtensionRegistry:Eh},VU={arg:Qh,isEvaluationError:gi,toBoolean:Ei,toJsDate:Ri,toNumber:fi,toString:wi,toNormalizedPivotValue:Gc,toFunctionPivotValue:qc,toXC:Po,toZone:ur,toUnboundedZone:dr,toCartesian:Fo,numberToLetters:wo,lettersToNumber:Io,UuidGenerator:Ka,formatValue:In,createCurrencyFormat:Vn,ColorGenerator:fo,computeTextWidth:Va,createEmptyWorkbookData:SD,createEmptySheet:bD,createEmptyExcelSheet:CD,rgbaToHex:Yt,colorToRGBA:Xt,positionToZone:Mr,isDefined:lt,isMatrix:js,lazy:ut,genericRepeat:bL,createAction:i,createActions:o,transformRangeData:oh,deepEquals:mt,overlap:xr,union:yr,isInside:Er,deepCopy:ze,expandZoneOnInsertion:vr,reduceZoneOnDeletion:Cr,unquote:Ge,getMaxObjectId:kc,getFunctionsFromTokens:GS,getFirstPivotFunction:BN,getNumberOfPivotFunctions:zN,parseDimension:Hc,isDateOrDatetimeField:Uc,makeFieldProposal:VN,insertTokenAfterArgSeparator:LN,insertTokenAfterLeftParenthesis:HN,mergeContiguousZones:Br,getPivotHighlights:wN,pivotTimeAdapter:bc,UNDO_REDO_PIVOT_COMMANDS:OV,createPivotFormula:$c,areDomainArgsFieldsValid:zc,splitReference:ra,sanitizeSheetName:qe,getUniqueText:Vt,isNumber:Rs,isDateTime:cs},LU={isMarkdownLink:et,parseMarkdownLink:st,markdownLink:ot,openLink:Zo,urlRepresentation:qo},HU={Checkbox:oR,Section:BE,RoundColorPicker:zE,ChartDataSeries:cM,ChartErrorSection:hM,ChartLabelRange:dM,ChartTitle:SM,ChartPanel:tN,ChartFigure:zx,ChartJsComponent:jC,Grid:_k,GridOverlay:GP,ScorecardChart:cy,LineConfigPanel:LM,BarConfigPanel:gM,PieChartDesignPanel:BM,GenericChartConfigPanel:uM,ChartWithAxisDesignPanel:TM,LineChartDesignPanel:HM,GaugeChartConfigPanel:OM,GaugeChartDesignPanel:FM,ScorecardChartConfigPanel:$M,ScorecardChartDesignPanel:GM,GeoChartDesignPanel:kM,RadarChartDesignPanel:zM,WaterfallChartDesignPanel:KM,ComboChartDesignPanel:DM,FunnelChartDesignPanel:_M,ChartTypePicker:QM,FigureComponent:Wx,MenuPopover:Ux,Popover:kx,SelectionInput:XE,ValidationMessages:kP,AddDimensionButton:RN,PivotDimensionGranularity:_N,PivotDimensionOrder:ON,PivotDimension:DN,PivotLayoutConfigurator:MN,PivotHTMLRenderer:Pk,PivotDeferUpdate:IN,PivotTitleSection:NN,CogWheelMenu:AN,TextInput:TN,SidePanelCollapsible:Jx,RadioSelection:yM,GeoChartRegionSelectSection:PM,ChartDashboardMenu:Bx,FullScreenChart:Fk},UU={useDragAndDropListItems:$E,useHighlights:iN,useHighlightsOnHover:sN},BU={useStoreProvider:ah,DependencyContainer:ih,CellPopoverStore:jx,ComposerFocusStore:bh,CellComposerStore:AP,FindAndReplaceStore:fN,HighlightStore:vE,DelayedHoveredCellStore:qx,HoveredTableStore:BP,ModelStore:gh,NotificationStore:bE,RendererStore:mh,SelectionInputStore:YE,SpreadsheetStore:fh,useStore:lh,useLocalStore:ch,SidePanelStore:Rk,PivotSidePanelStore:rk,PivotMeasureDisplayPanelStore:CN,ClientFocusStore:yP,GridRenderer:JP};const zU={DEFAULT_LOCALE:qs,HIGHLIGHT_COLOR:a,PIVOT_TABLE_CONFIG:Ve,ChartTerms:Yy},$U={...ux,...xI};e.AbstractCellClipboardHandler=rl,e.AbstractChart=YC,e.AbstractFigureClipboardHandler=Qc,e.CellErrorType=ti,e.ClientDisconnectedError=sL,e.CorePlugin=Nk,e.CoreViewPlugin=$k,e.DispatchResult=Us,e.EvaluationError=si,e.LocalTransportService=kL,e.Model=class extends sh{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 Ka,n=!1){const r=performance.now();console.debug("##### Model creation #####"),super(),ko===Mo&&Vo===No&&(Vo=()=>!0),s=fD(e,s);const a=gD(e,n);this.state=new _H,this.uuidGenerator=i,this.config=this.setupConfig(o),this.session=this.setupSession(a.revisionId),this.coreGetters={},this.range=new Bk(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.getRangeData=this.range.getRangeData.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.coreGetters.adaptFormulaStringDependencies=this.range.adaptFormulaStringDependencies.bind(this.range),this.coreGetters.copyFormulaStringForSheet=this.range.copyFormulaStringForSheet.bind(this.range),this.getters={isReadonly:()=>"readonly"===this.config.mode||"dashboard"===this.config.mode,isDashboard:()=>"dashboard"===this.config.mode},this.selection=new AH(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(const e of xL.getAll())this.setupCorePlugin(e,a);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(s);for(const e of TL.getAll()){const t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(const e of RL.getAll()){const t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(const e of EL.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(const 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(const 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(const 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(const t of e){const e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new iL(EH({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.dispatchToHandlers(this.coreHandlers,{type:"UNDO",commands:[e]})}}),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.smallUuid(),name:Ho("Anonymous").toString()},o=e.transportService||new kL;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(Ws));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=Hs(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some((e=>"Success"!==e))?new Us(t.flat()):Us.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(PU(e,t));dispatch=(e,t)=>{const o=PU(e,t),s=this.status;if(this.getters.isReadonly()&&(i=o,!Vs.has(i.type)))return new Us("Readonly");var i;if(!this.session.canApplyOptimisticUpdate())return new Us("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();Hs(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(Hs(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(Hs(o))throw new Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,o)}return Us.Success};dispatchFromCorePlugin=(e,t)=>{const o=PU(e,t),s=this.status;this.status=2;const i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,o),this.status=s,Us.Success};dispatchToHandlers(e,t){const o=Hs(t);for(const s of e)!o&&s instanceof Nk||s.beforeHandle(t);for(const s of e)!o&&s instanceof Nk||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=SD();for(const t of this.handlers)t instanceof Nk&&t.export(e);return e.revisionId=this.session.getRevisionId()||Se,e=ze(e),e}updateMode(e){this.config.mode=e,this.trigger("update")}exportXLSX(){this.dispatch("EVALUATE_CELLS");let e={...SD(),sheets:[CD(uD,"Sheet1")]};for(const t of this.handlers)t instanceof Mk&&t.exportForExcel(e);return e=ze(e),_U(e)}garbageCollectExternalResources(){for(const e of this.corePlugins)e.garbageCollectExternalResources()}},e.PivotRuntimeDefinition=$N,e.Registry=n,e.Revision=oL,e.SPREADSHEET_DIMENSIONS=NU,e.Spreadsheet=vH,e.SpreadsheetPivotTable=qN,e.UIPlugin=BV,e.__info__=MU,e.addFunction=function e(t,o){return RS.add(t,o),{addFunction:(t,o)=>e(t,o)}},e.addRenderingLayer=function(e,t){if(Xs[e])throw new Error(`Layer ${e} already exists`);Xs[e]=t},e.astToFormula=gv,e.chartHelpers=$U,e.compile=HS,e.compileTokens=US,e.components=HU,e.constants=zU,e.convertAstNodes=cv,e.coreTypes=Ls,e.findCellInNewZone=Pr,e.functionCache=LS,e.helpers=VU,e.hooks=UU,e.invalidateCFEvaluationCommands=Ns,e.invalidateChartEvaluationCommands=Ps,e.invalidateDependenciesCommands=Ms,e.invalidateEvaluationCommands=Fs,e.iterateAstNodes=hv,e.links=LU,e.load=gD,e.parse=av,e.parseTokens=lv,e.readonlyAllowedCommands=Vs,e.registries=kU,e.setDefaultSheetViewSize=function(e){Pe=e},e.setTranslationMethod=function(e,t=(()=>!0)){ko=e,Vo=t},e.stores=BU,e.tokenColors=wE,e.tokenize=cl,MU.version="18.4.13",MU.date="2025-10-07T10:00:55.413Z",MU.hash="d4df70e"}(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|