@odoo/o-spreadsheet 18.3.47 → 18.3.48
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 +100 -6
- package/dist/o_spreadsheet.css +3 -3
- package/dist/o_spreadsheet.esm.js +100 -6
- package/dist/o_spreadsheet.iife.js +100 -6
- package/dist/o_spreadsheet.iife.min.js +18 -18
- package/dist/o_spreadsheet.xml +4 -4
- package/package.json +17 -17
|
@@ -1,20 +1,20 @@
|
|
|
1
1
|
(function(e,t){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var n=Object.create,r=Object.defineProperty,i=Object.getOwnPropertyDescriptor,a=Object.getOwnPropertyNames,o=Object.getPrototypeOf,s=Object.prototype.hasOwnProperty,c=(e,t)=>()=>(t||(e((t={exports:{}}).exports,t),e=null),t.exports),l=(e,t)=>{let n={};for(var i in e)r(n,i,{get:e[i],enumerable:!0});return t||r(n,Symbol.toStringTag,{value:`Module`}),n},u=(e,t,n,o)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var c=a(t),l=0,u=c.length,d;l<u;l++)d=c[l],!s.call(e,d)&&d!==n&&r(e,d,{get:(e=>t[e]).bind(null,d),enumerable:!(o=i(t,d))||o.enumerable});return e},d=(e,t,i)=>(i=e==null?{}:n(o(e)),u(t||!e||!e.__esModule?r(i,`default`,{value:e,enumerable:!0}):i,e));function f(e){return e.map(m).sort((e,t)=>e.sequence-t.sequence)}let p=1;function m(e){let t=e.name,n=e.children,r=e.description,i=e.icon,a=e.secondaryIcon;return{id:(e.id||p++).toString(),name:typeof t==`function`?t:()=>t,isVisible:e.isVisible?e.isVisible:()=>!0,isEnabled:e.isEnabled?e.isEnabled:()=>!0,isActive:e.isActive,execute:e.execute,children:n?e=>n.map(t=>typeof t==`function`?t(e):t).flat().map(m).sort((e,t)=>e.sequence-t.sequence):()=>[],isReadonlyAllowed:e.isReadonlyAllowed||!1,separator:e.separator||!1,icon:typeof i==`function`?i:()=>i||``,iconColor:e.iconColor,secondaryIcon:typeof a==`function`?a:()=>a||``,description:typeof r==`function`?r:()=>r||``,textColor:e.textColor,sequence:e.sequence||0,onStartHover:e.onStartHover,onStopHover:e.onStopHover}}var h=class{content={};add(e,t){return this.content[e]=t,this}get(e){let t=this.content[e];if(!t&&!(e in this.content))throw 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]}};let g=.5,_=`#37A850`,v=`#f5f5f5`,y=`#F8F9FA`,ee=`#E8EAED`,te=`#595959`,ne=`#666666`,re=`#c9ccd2`,ie=`#3266ca`,ae=`#FFFFFF`,oe=`#CACACA`,se=11982760,ce=`#017E84`,le=`#188038`,ue=`#E0E2E4`,de=`#4A4F59`,fe=`#999`,pe=`#E2E3E3`,me=`#BCBCBC`,he=`#9B359B`,ge=`#00000000`,_e=`#111827`,ve=`#D8DADD`,ye=`#E7E9ED`,be=`#F9FAFB`,xe=`#374151`,Se=xe+`C2`,Ce=`#111827`,we=`#714B67`,Te=ve,Ee=`#111827`,De=`#e6f2f3`,Oe=`#111827`,ke=`#017E84`,Ae=`#D44C591A`,je=`#C34A41`,Me=`#98DBE2`,Ne=`#E6F2F3`,Pe=`#F28C28`,Fe=`#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`.split(`.`),Ie={align:`left`,verticalAlign:`bottom`,wrapping:`overflow`,bold:!1,italic:!1,strikethrough:!1,underline:!1,fontSize:10,fillColor:``,textColor:``},Le={...Ie,align:`right`},Re=Ie.verticalAlign,ze=Ie.wrapping,Be=Ie.fontSize,Ve=`'Roboto', arial`,He={style:`thin`,color:`#000000`},Ue=`START_REVISION`,We=`difference`,Ge=`#43C5B1`,Ke=`#EA6175`,qe=.4,Je=[`'`,`*`,`?`,`/`,`\\`,`[`,`]`],Ye=/'|\*|\?|\/|\\|\[|\]/,Xe=0;function Ze(){return Xe}function Qe(e){Xe=e}let $e=[6,7,8,9,10,11,12,14,18,24,36],et={hasFilters:!1,totalRow:!1,firstColumn:!0,lastColumn:!1,numberOfHeaders:1,bandedRows:!0,bandedColumns:!1,styleId:`TableStyleMedium5`,automaticAutofill:!1},tt={symbol:`$`,position:`before`,decimalPlaces:2,code:``,name:`Dollar`},nt=new RegExp(Ye,`g`);function rt(e){return e[0]===`"`&&(e=e.slice(1)),e[e.length-1]===`"`&&e[e.length-2]!==`\\`?e.slice(0,e.length-1):e}function it(e){return`clone`in e&&e.clone instanceof Function}function at(e){return e.replace(/[.*+?^${}()|[\]\\]/g,`\\$&`)}function b(e){switch(typeof e){case`object`:{if(e===null)return e;if(it(e))return e.clone();if(!(ot(e)||e instanceof Array))throw Error(`Unsupported type: only objects and arrays are supported`);let t=Array.isArray(e)?Array(e.length):{};if(Array.isArray(e))for(let n=0,r=e.length;n<r;n++)n in e&&(t[n]=b(e[n]));else for(let n in e)t[n]=b(e[n]);return t}case`number`:case`string`:case`boolean`:case`function`:case`undefined`:return e;default:throw Error(`Unsupported type: ${typeof e}`)}}function ot(e){return typeof e==`object`&&!!e&&(e?.constructor===Object||e?.constructor===void 0)}function st(e){return ct(e,`'`)}function ct(e,t=`"`){return e.startsWith(t)&&(e=e.slice(1)),e.endsWith(t)&&(e=e.slice(0,-1)),e}function lt(e){return e.match(/\w/g)?.length!==e.length&&(e=`'${e}'`),e}function ut(e,t=` `){return e.replace(nt,t)}function x(e,t,n){return e<t?t:e>n?n:e}function S(e,t,n=1){if(t<=e&&n>0)return[];if(n===0)throw Error(`range() step must not be zero`);let r=Math.ceil(Math.abs((t-e)/n)),i=Array(r);for(let t=0;t<r;t++)i[t]=e+t*n;return i}function dt(e){return e.reduce((e,t,n,r)=>(Math.abs(t-r[n-1])===1?e[e.length-1].push(t):e.push([t]),e),[])}function*ft(e,t){t.next();for(let n of e){let e=t.next();yield{...n,next:e.done?void 0:e.value}}}function pt(e){let t=e.toUpperCase();return t===`TRUE`||t===`FALSE`}let mt=/^\[(.+)\]\((.+)\)$/,ht=/^https?:\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{2,256}\.[a-z]{2,4}\b([-a-zA-Z0-9@:%_\+.~#?&//=]*)$/;function gt(e){return mt.test(e)}function _t(e){return ht.test(e)}function vt(e,t){return`[${e}](${t})`}function yt(e){let t=e.match(mt)||[],n=t[1],r=t[2];if(!n||!r)throw Error(`Could not parse markdown link ${e}.`);return{label:n,url:r}}let bt=`o-spreadsheet://`;function xt(e){return e.startsWith(bt)}function St(e){return`${bt}${e}`}function Ct(e){if(e.startsWith(bt))return e.slice(16);throw Error(`${e} is not a valid sheet link`)}function C(e){return e!==void 0}function wt(e){return e!==null}function Tt(e){return e===void 0?!0:Object.values(e).every(e=>typeof e==`object`?Tt(e):!e)}function Et(e,t,n){let r,i=function(){let i=this,a=Array.from(arguments);function o(){r=void 0,n||e.apply(i,a)}let s=n&&!r;clearTimeout(r),r=setTimeout(o,t),s&&e.apply(i,a)};return i.isDebouncePending=()=>r!==void 0,i.stopDebounce=()=>{clearTimeout(r)},i}function Dt(e){let t=!1;return async(...n)=>{t||(t=!0,await Promise.resolve(),t=!1,e(...n))}}function Ot(e){let t=``;for(let n=0,r=e.length;n<r;n++)t+=e[n];return t}function kt(e){let t=!1,n,r=()=>(t||=(n=e instanceof Function?e():e,!0),n);return r.map=e=>kt(()=>e(r())),r}function At(e,t){let n=e.slice(t).find(e=>e);return n||=e.slice(0,t).reverse().find(e=>e),n||``}function jt(e,t){return e===`after`?t+1:t}function w(e,t){if(e===t)return!0;if(e&&!t||t&&!e||typeof e!=typeof t||typeof e!=`object`)return!1;for(let n in t)if(!(n in e)&&t[n]!==void 0)return!1;for(let n in e){if(typeof e[n]!=typeof t[n])return!1;if(typeof e[n]==`object`){if(!w(e[n],t[n]))return!1}else if(e[n]!==t[n])return!1}return!0}function Mt(e,t){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++)if(!w(e[n],t[n]))return!1;return!0}function Nt(e,t){if(e.length<t.length)return!1;let n=new Set(e);return t.every(e=>n.has(e))}function Pt(e){if(!e)return e;let t={...e};return Object.keys(t).forEach(e=>!t[e]&&delete t[e]),t}let Ft=[` `,`\f`,`\v`,`\xA0`,` `,` `,` `,`\u2028`,`\u2029`,` `,` `,` `,``],It=new RegExp(Ft.join(`|`),`g`),Lt=/(\r\n|\r)/g,Rt=Ft.concat([` `]);function zt(e){return e?e.replace(Lt,`
|
|
2
2
|
`):``}function Bt(e){let 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 Vt(e){let t=new Map,n=e.name?e.name+` (memoized)`:`memoized`;return{[n](...n){return t.has(n[0])||t.set(n[0],e(...n)),t.get(n[0])}}[n]}function Ht(e,t){let n=new Set(t),r=[];for(let t=0;t<e.length;t++)n.has(t)||r.push(e[t]);return r}function Ut(e,t,n){return e.slice(0,n).concat(t).concat(e.slice(n))}function Wt(e,t,n){let r=[...e];return r[n]=t,r}function Gt(e){return e.split(`
|
|
3
3
|
`).map(e=>e.replace(/\s+/g,` `).trim()).join(`
|
|
4
|
-
`)}function Kt(e,t,n){return t>n?Kt(e,n,t):e>=t&&e<=n}function qt(e,t){let n=at(e),r=t.matchCase?``:`i`;return t.exactMatch&&(n=`^${n}$`),RegExp(n,r)}function Jt(e){let t=e.length;if(t<1e5)return Math.max(...e);let n=-1/0;for(;t--;)n=e[t]>n?e[t]:n;return n}function Yt(e){let t=e.length;if(t<1e5)return Math.min(...e);let n=1/0;for(;t--;)n=e[t]<n?e[t]:n;return n}var Xt=class{text;currentIndex=0;current;constructor(e){this.text=e,this.current=e[0]}shift(){let 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 Zt(e,t=e=>e){let n=new Set;return e.filter(e=>{let r=t(e);return n.has(r)?!1:(n.add(r),!0)})}function Qt(e){let t={};for(let n in e)for(let r in e[n])t[r]||(t[r]={}),t[r][n]=e[n][r];return t}function $t(e,t,n={}){let r=n.compute??((e,t)=>`${e} (${t})`),i=n.computeFirstOne??!1,a=n.start??1,o=i?r(e,a):e;for(;t.includes(o);)o=r(e,a++);return o}function en(e){return e.startsWith(`=`)||e.startsWith(`+`)}let tn=/rgba?\(|\s+|\)/gi,nn=/^#([A-F\d]{2}){3,4}$/,rn=[`#eb6d00`,`#0074d9`,`#ad8e00`,`#169ed4`,`#b10dc9`,`#00a82d`,`#00a3a3`,`#f012be`,`#3d9970`,`#111111`,`#62A300`,`#ff4136`,`#949494`,`#85144b`,`#001f3f`];function an(e){return sn(e.toString(16).padStart(6,`0`))}function on(e){return typeof e==`number`?e:Number.parseInt(sn(e).slice(1),16)}function sn(e){let t=e;if(e.startsWith(`rgb`)?t=pn(e):(t=e.replace(`#`,``).toUpperCase(),(t.length===3||t.length===4)&&(t=t.split(``).reduce((e,t)=>e+t+t,``)),t=`#${t}`),!nn.test(t))throw Error(`invalid color input: ${e}`);return t}function cn(e){try{return sn(e),!0}catch{return!1}}function ln(e){try{return vn(e),!0}catch{return!1}}let un=e=>e>=0&&e<=255;function dn(e,t,n,r=1){if(!un(e)||!un(t)||!un(n)||r<0||r>1)throw Error(`Invalid RGBA values ${[e,t,n,r]}`);return{a:r,b:n,g:t,r:e}}function fn(e){let{r:t,g:n,b:r}=hn(e);t/=255,n/=255,r/=255;let i=e=>e<=.03928?e/12.92:((e+.055)/1.055)**2.4,a=i(t),o=i(n),s=i(r);return .2126*a+.7152*o+.0722*s}function pn(e){let t=e.replace(tn,``).split(`,`),n=255;if(t.length!==3&&t.length!==4)throw Error(`invalid color`);if(t.length===4){let e=parseFloat(t.pop()||`1`);if(isNaN(e))throw Error(`invalid alpha value`);n=Math.round(e*255)}let r=t.map(e=>parseInt(e,10));return n!==255&&r.push(n),`#`+Ot(r.map(e=>e.toString(16).padStart(2,`0`))).toUpperCase()}function mn(e){let t=e.r.toString(16),n=e.g.toString(16),r=e.b.toString(16),i=Math.round(e.a*255).toString(16);return t.length===1&&(t=`0`+t),n.length===1&&(n=`0`+n),r.length===1&&(r=`0`+r),i.length===1&&(i=`0`+i),i===`ff`&&(i=``),(`#`+t+n+r+i).toUpperCase()}function hn(e){e=sn(e);let t,n,r,i;if(e.length===7)t=parseInt(e[1]+e[2],16),n=parseInt(e[3]+e[4],16),r=parseInt(e[5]+e[6],16),i=255;else if(e.length===9)t=parseInt(e[1]+e[2],16),n=parseInt(e[3]+e[4],16),r=parseInt(e[5]+e[6],16),i=parseInt(e[7]+e[8],16);else throw Error(`Invalid color`);return i=+(i/255).toFixed(3),{a:i,r:t,g:n,b:r}}function gn(e){e={...e},e.s/=100,e.l/=100;let t=(1-Math.abs(2*e.l-1))*e.s,n=t*(1-Math.abs(e.h/60%2-1)),r=e.l-t/2,i=0,a=0,o=0;return 0<=e.h&&e.h<60?(i=t,a=n,o=0):60<=e.h&&e.h<120?(i=n,a=t,o=0):120<=e.h&&e.h<180?(i=0,a=t,o=n):180<=e.h&&e.h<240?(i=0,a=n,o=t):240<=e.h&&e.h<300?(i=n,a=0,o=t):300<=e.h&&e.h<360&&(i=t,a=0,o=n),i=Math.round((i+r)*255),a=Math.round((a+r)*255),o=Math.round((o+r)*255),{a:e.a,r:i,g:a,b:o}}function _n(e){let t=e.r/255,n=e.g/255,r=e.b/255,i=Math.min(t,n,r),a=Math.max(t,n,r),o=a-i,s=0,c=0,l=0;return s=o===0?0:a===t?(n-r)/o%6:a===n?(r-t)/o+2:(t-n)/o+4,s=Math.round(s*60),s<0&&(s+=360),l=(a+i)/2,c=o===0?0:o/(1-Math.abs(2*l-1)),c=+(c*100).toFixed(1),l=+(l*100).toFixed(1),{a:e.a,h:s,s:c,l}}function vn(e){return mn(gn(e))}function yn(e){return _n(hn(e))}function bn(e,t,n=0){if(!(cn(e)&&cn(t)))return!1;let r=hn(e),i=hn(t);return r.a===i.a?Math.sqrt(((r.r-i.r)/255)**2+((r.g-i.g)/255)**2+((r.b-i.b)/255)**2)<=n:!1}function xn(e,t){return t===1?sn(e).slice(0,7):mn({...hn(e),a:t})}function Sn(e,t){let n=yn(e);return t===1?`#fff`:(n.l=t*(100-n.l)+n.l,vn(n))}function Cn(e,t){let n=yn(e);return t===1?`#000`:(n.l-=t*n.l,vn(n))}let wn=[`#4EA7F2`,`#EA6175`,`#43C5B1`,`#F4A261`,`#8481DD`,`#FFD86D`],Tn=[`#4EA7F2`,`#3188E6`,`#43C5B1`,`#00A78D`,`#EA6175`,`#CE4257`,`#F4A261`,`#F48935`,`#8481DD`,`#5752D1`,`#FFD86D`,`#FFBC2C`],En=[`#4EA7F2`,`#3188E6`,`#056BD9`,`#A76DBC`,`#7F4295`,`#6D2387`,`#EA6175`,`#CE4257`,`#982738`,`#43C5B1`,`#00A78D`,`#0E8270`,`#F4A261`,`#F48935`,`#BE5D10`,`#8481DD`,`#5752D1`,`#3A3580`,`#A4A8B6`,`#7E8290`,`#545B70`,`#FFD86D`,`#FFBC2C`,`#C08A16`],Dn=`#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`.split(`.`),On=[`#4EA7F2`,`#43C5B1`,`#EA6175`,`#F4A261`,`#8481DD`,`#FFD86D`,`#3188E6`,`#00A78D`,`#CE4257`,`#F48935`,`#5752D1`,`#FFBC2C`],kn=[`#4EA7F2`,`#A76DBC`,`#EA6175`,`#43C5B1`,`#F4A261`,`#8481DD`,`#A4A8B6`,`#FFD86D`,`#3188E6`,`#7F4295`,`#CE4257`,`#00A78D`,`#F48935`,`#5752D1`,`#7E8290`,`#FFBC2C`,`#056BD9`,`#6D2387`,`#982738`,`#0E8270`,`#BE5D10`,`#3A3580`,`#545B70`,`#C08A16`],An=`#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`.split(`.`);function jn(e,t){return t[e%t.length]}function Mn(e){return e<=6?wn:e<=12?Tn:e<=24?En:Dn}function Nn(e){return e<=6?wn:e<=12?On:e<=24?kn:An}var Pn=class{currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=Mn(e).filter(e=>!t.includes(e))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:jn(this.currentColorIndex++,this.palette)}},Fn=class extends Pn{constructor(e,t=[]){super(e,t),this.palette=Nn(e).filter(e=>!t.includes(e))}};function In(e){if(e.length<2)throw Error(`Color scale must have at least 2 points`);let t=[...e.sort((e,t)=>e.value-t.value)],n=[];for(let e=1;e<t.length;e++){let r=on(t[e-1].color),i=on(t[e].color);n.push({min:t[e-1].value,max:t[e].value,minColor:r,maxColor:i,colorDiff:Ln(t[e-1].value,t[e].value,r,i)})}return e=>{if(e<n[0].min)return an(n[0].minColor);for(let t of n)if(e>=t.min&&e<=t.max)return an(Rn(e,t.min,t.minColor,t.colorDiff));return an(n[n.length-1].maxColor)}}function Ln(e,t,n,r){let i=t-e,a=(n>>16)%256-(r>>16)%256,o=(n>>8)%256-(r>>8)%256,s=n%256-r%256;return[a/i,o/i,s/i]}function Rn(e,t,n,r){let[i,a,o]=r,s=Math.round((n>>16)%256-i*(e-t)),c=Math.round((n>>8)%256-a*(e-t)),l=Math.round(n%256-o*(e-t));return s<<16|c<<8|l}function zn(e){if(e<0)throw Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):zn(Math.floor(e/26)-1)+zn(e%26)}function Bn(e){let t=0,n=e.length;for(let r=0;r<n;r++){let n=Vn(e[r]);t=t*26+n}return t-1}function Vn(e){let t=e.charCodeAt(0);return t>=65&&t<=90?t-64:t-96}function Hn(e){return e>=`A`&&e<=`Z`||e>=`a`&&e<=`z`}function Un(e){return e>=`0`&&e<=`9`}let Wn=Bn(`ZZZ`);function Gn(e){for(;e.current===` `;)e.advanceBy(1)}function Kn(e){if(e.current===`$`&&e.advanceBy(1),!e.current||!Hn(e.current))return-1;let t=0;for(;e.current&&Hn(e.current);)t=t*26+Vn(e.shift());return t}function qn(e){if(e.current===`$`&&e.advanceBy(1),!e.current||!Un(e.current))return-1;let t=0;for(;e.current&&Un(e.current);)t=t*10+Number(e.shift());return t}function Jn(e){let t=new Xt(e);Gn(t);let n=Kn(t);if(n===-1||!t.current)throw Error(`Invalid cell description: ${e}`);let r=qn(t);Gn(t);let i=n-1,a=r-1;if(!t.isOver()||i>Wn||a>9999998)throw Error(`Invalid cell description: ${e}`);return{col:i,row:a}}function T(e,t,n={colFixed:!1,rowFixed:!1}){return(n.colFixed?`$`:``)+zn(e)+(n.rowFixed?`$`:``)+String(t+1)}function Yn(e,t=[]){if(e.length<=1&&t.length===0)return e;let n=[0],r=new Map([[0,[]]]);return Xn(n,r,e,!1),Xn(n,r,t,!0),er(n,r)}function Xn(e,t,n,r=!1){for(let i of n){let n=i.left,a=i.right===void 0?void 0:i.right+1,o=Zn(e,t,n,!0,0),s=Zn(e,t,a,!1,o);for(let n=o;n<=s;n++)Qn(t.get(e[n]),i,r);$n(e,t,o,s)}}function Zn(e,t,n,r,i){if(n===void 0)return e.length-1;let a=tr(e,n,i);return n===e[a]?r?a:a-1:(e.splice(a+1,0,n),t.set(n,[...t.get(e[a])]),r?a+1:a)}function Qn(e,t,n=!1){let r=t.top,i=t.bottom===void 0?void 0:t.bottom+1,a=[],o=tr(e,r,0,!1);if((o%2!=0&&!n||o%2==0&&n)&&a.push(r),i===void 0){e.splice(o+1),e.push(...a);return}let s=nr(e,i,0,!1);(s%2==0&&!n||s%2!=0&&n)&&a.push(i),e.splice(o+1,s-o-1,...a)}function $n(e,t,n,r){let i=n-1==-1?0:n-1,a=r===e.length-1?r:r+1;for(let n=a;n>i;n--)Mt(t.get(e[n]),t.get(e[n-1]))&&(t.delete(e[n]),e.splice(n,1))}function er(e,t){let n=[],r=[];for(let i=0;i<e.length;i++){let a=e[i],o=t.get(a);if(!o||o.length===0){n.push(...r),r=[];continue}let s=e[i+1];s!==void 0&&s--;let c=[];for(let e=0;e<o.length;e+=2){let t=o[e],n=o[e+1];n!==void 0&&n--;let i={top:t,left:a,bottom:n,right:s,hasHeader:n===void 0&&t!==0||s===void 0&&a!==0},l=!1;for(let e=r.length-1;e>=0;e--){let t=r[e];if(t.top===i.top&&t.bottom===i.bottom){t.right=i.right,r.splice(e,1),c.push(t),l=!0;break}}l||c.push(i)}n.push(...r),r=c}return n.push(...r),n}function tr(e,t,n=0,r=!0){let i=e.length-1,a=-1;for(;n<=i;){let o=Math.floor((n+i)/2);if(e[o]===t&&r)return o;e[o]<t?(a=o,n=o+1):i=o-1}return a}function nr(e,t,n=0,r=!0){let i=e.length-1,a=e.length;for(;n<=i;){let o=Math.floor((n+i)/2);if(e[o]===t&&r)return o;e[o]>t?(a=o,i=o-1):n=o+1}return a}function rr(e){let t=new Xt(e);Gn(t);let n=e.indexOf(`!`);n!==-1&&t.advanceBy(n+1);let r=Kn(t),i=qn(t),a,o,s,c,l=!1,u=!1,d=!1;if(i===-1?(s=c=r-1,a=o=0,l=!0):r===-1?(a=o=i-1,s=c=0,u=!0):(s=c=r-1,a=o=i-1,d=!0),Gn(t),t.current===`:`){t.advanceBy(1),Gn(t);let e=Kn(t),n=qn(t);n===-1?(c=e-1,l=!0):e===-1?(o=n-1,u=!0):(c=e-1,o=n-1,a=l?o:a,s=u?c:s,d=!0)}let f={top:a,left:s,bottom:l?void 0:o,right:u?void 0:c};return d&&=u||l,d&&(f.hasHeader=d),f}function ir(e){let t=Tr(rr(e)),n=t.bottom,r=t.right;if(n!==void 0&&n>9999998||r!==void 0&&r>Wn)throw Error(`Range string out of bounds: ${e}`);if(n===void 0&&r===void 0)throw Error(`Wrong zone xc. The zone cannot be at the same time a full column and a full row`);return t}function ar(e){let t=ir(e);if(t.bottom===void 0||t.right===void 0)throw Error(`This does not support unbounded ranges`);return t}function or(e){let{bottom:t,top:n,left:r,right:i}=e;return t!==void 0&&isNaN(t)||isNaN(n)||isNaN(r)||i!==void 0&&isNaN(i)?!1:sr(e)&&e.top>=0&&e.left>=0}function sr(e){return(e.bottom===void 0||e.bottom>=e.top&&e.bottom>=0)&&(e.right===void 0||e.right>=e.left&&e.right>=0)}function cr(e){let{top:t,bottom:n,left:r,right:i}=e,a=`hasHeader`in e?e.hasHeader:!1,o=t===n&&r===i;if(n===void 0&&i!==void 0)return t===0&&!a?`${zn(r)}:${zn(i)}`:`${T(r,t)}:${zn(i)}`;if(i===void 0&&n!==void 0)return r===0&&!a?`${t+1}:${n+1}`:`${T(r,t)}:${n+1}`;if(n!==void 0&&i!==void 0)return o?T(r,t):`${T(r,t)}:${T(i,n)}`;throw Error(`Bad zone format`)}function lr(e,t,n,r,i){let a=t===`left`?`columns`:`rows`,o=r===`before`?n-1:n,s=e[t===`left`?`right`:`bottom`];return e[t]<=o&&s&&s>o?Er(e,a,`RESIZE`,i):o<e[t]?Er(e,a,`MOVE`,i):{...e}}function ur(e,t,n,r,i){let a=t===`left`?`columns`:`rows`,o=r===`before`?n-1:n,s=t===`left`?`right`:`bottom`;return e[t]<=o&&e[s]>o?Er(e,a,`RESIZE`,i):o<e[t]?Er(e,a,`MOVE`,i):{...e}}function dr(e,t,n){let r=t===`left`?`right`:`bottom`,i=e[t],a=e[r];for(let o of n.sort((e,t)=>t-e))e[t]>o&&(i--,a--),e[t]<o&&e[r]>=o&&a--;return{...e,[t]:i,[r]:a}}function fr(e,t,n){let r=t===`left`?`right`:`bottom`,i=e[t],a=e[r],o=e[r];for(let r of n.sort((e,t)=>t-e))e[t]>r&&(i--,a!==void 0&&a--),o!==void 0&&a!==void 0&&e[t]<=r&&o>=r&&a--;if(!(a!==void 0&&i>a))return{...e,[t]:i,[r]:a}}function pr(...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 mr(...e){return{top:Math.min(...e.map(e=>e.top)),left:Math.min(...e.map(e=>e.left)),bottom:e.some(e=>e.bottom===void 0)?void 0:Math.max(...e.map(e=>e.bottom)),right:e.some(e=>e.right===void 0)?void 0:Math.max(...e.map(e=>e.right))}}function hr(e,t){if(_r(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 gr(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom}function _r(e,t){return!(e.bottom<t.top||t.bottom<e.top||e.right<t.left||t.right<e.left)}function vr(e,t,n){let{left:r,right:i,top:a,bottom:o}=n;return e>=r&&e<=i&&t>=a&&t<=o}function yr(e,t){return gr(pr(t,e),t)}function br(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function xr(e){let{numberOfCols:t,numberOfRows:n}=br(e);return t===1||n===1}function Sr(e){let{top:t,left:n,bottom:r,right:i}=e;if(Nr(e)===1)return[];let a={top:t+1,bottom:r,left:n,right:n};if(i===n)return[a];let o={top:t,bottom:r,left:n+1,right:i};return t===r?[o]:[a,o]}function Cr(e){let t={};for(let n of e)t[n.sheetId]??=[],t[n.sheetId].push(E(n));for(let e in t)t[e]=Yn(t[e]);return t}function wr(e){let t=[],{left:n,right:r,top:i,bottom:a}=Tr(e);for(let e of S(n,r+1))for(let n of S(i,a+1))t.push({col:e,row:n});return t}function Tr(e){return e.right!==void 0&&e.left>e.right&&(e={...e,left:e.right,right:e.left}),e.bottom!==void 0&&e.top>e.bottom&&(e={...e,top:e.bottom,bottom:e.top}),e}function Er(e,t,n,r){let i=t===`both`?r[0]:t===`columns`?r:0,a=t===`both`?r[1]:t===`rows`?r:0,o=`hasHeader`in e?e.hasHeader:!1,s;s=Mr(e)&&!o?t!==`rows`:jr(e)&&!o?t!==`columns`:!0;let c={...e};return s&&n===`MOVE`&&(c.left+=i,c.top+=a),c.right!==void 0&&(c.right+=i),c.bottom!==void 0&&(c.bottom+=a),c}function Dr(e){return e.reverse().filter((e,t,n)=>t===n.findIndex(t=>t.top===e.top&&t.bottom===e.bottom&&t.left===e.left&&t.right===e.right)).reverse()}function Or(e){return e.reduce((e,t)=>{let n=e.length;for(let r=0;r<n;r++)if(_r(e[r],t))return e[r]=pr(e[r],t),e;return e[n]=t,e},[])}function kr(e,t){let n,r,{left:i,right:a,top:o,bottom:s}=e,{left:c,right:l,top:u,bottom:d}=t;return n=c===i?l===a?c:l:c,r=u===o?d===s?u:d:u,{col:n,row:r}}function E(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function Ar(e){return{...e,right:e.left,bottom:e.top}}function jr(e){return e.right===void 0}function Mr(e){return e.bottom===void 0}function Nr(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function Pr(e,t){let{left:n,top:r,bottom:i,right:a}=e;if(a!==void 0&&i!==void 0)return e;if(i===void 0&&a!==void 0)return{right:a,top:r,left:n,bottom:t.numberOfRows-1};if(a===void 0&&i!==void 0)return{bottom:i,left:n,top:r,right:t.numberOfCols-1};throw Error(`Bad zone format`)}function Fr(e){return e.length<2?!0:Yn(e).length===1}function Ir(e){let t=new Set;for(let n of Yn(e))for(let e of S(n.left,n.right+1))t.add(e);return t}function Lr(e){let t=new Set;for(let n of Yn(e))for(let e of S(n.top,n.bottom+1))t.add(e);return t}function Rr(e,t){return e.right+1===t.left||e.left===t.right+1?e.top<=t.bottom&&e.top>=t.top||t.top<=e.bottom&&t.top>=e.top:e.bottom+1===t.top||e.top===t.bottom+1?e.left<=t.right&&e.left>=t.left||t.left<=e.right&&t.left>=e.left:!1}function zr(e){let t=[...e],n=!0;for(;n;){n=!1;for(let e=0;e<t.length;e++){let r=t[e],i=t.findIndex((t,n)=>e!==n&&(Rr(t,r)||_r(t,r)));if(i!==-1){t[e]=pr(t[i],r),t.splice(i,1),n=!0;break}}}return t}let Br=new WeakMap,Vr=new WeakMap;function Hr(e,t){Br.has(t)||(Br.set(t,new Map),Vr.set(t,0));let n=Br.get(t),r=Gr(e);if(n.has(r)){let i=n.get(r);return t[i]=e,i}let i=Vr.get(t)+1;return n.set(r,i),Vr.set(t,i),t[i]=e,i}function Ur(e){let t={};for(let n in e){let r=Yn(e[n].map(E));for(let e of r)t[cr(e)]=Number(n)}return t}function*Wr(e,t){for(let n in t){let r=ar(n),i=t[n];for(let t=r.top;t<=r.bottom;t++)for(let n=r.left;n<=r.right;n++)yield[{sheetId:e,col:n,row:t},i]}}function Gr(e){if(e===null)return`null`;if(e===void 0)return`undefined`;if(typeof e!=`object`)return String(e);if(Array.isArray(e)){let t=e.length,n=`[`;for(let r=0;r<t;r++)r>0&&(n+=`,`),n+=Gr(e[r]);return n+`]`}let t=Object.keys(e).sort(),n=`{`;for(let r of t)e[r]!==void 0&&(n+=`"${r}":${Gr(e[r])},`);return n+=`}`,n}var D=class e{jsDate;constructor(e,t,n,r=0,i=0,a=0){this.jsDate=new Date(Date.UTC(e,t,n,r,i,a,0))}static fromTimestamp(t){let n=new Date(t);return new e(n.getUTCFullYear(),n.getUTCMonth(),n.getUTCDate(),n.getUTCHours(),n.getUTCMinutes(),n.getUTCSeconds())}static now(){let t=new Date;return new e(t.getFullYear(),t.getMonth(),t.getDate(),t.getHours(),t.getMinutes(),t.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(){let e=new Date(this.jsDate.getTime()),t=e.getUTCDay()||7;e.setUTCDate(e.getUTCDate()+4-t);let n=new Date(Date.UTC(e.getUTCFullYear(),0,1));return Math.ceil(((e.getTime()-n.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)}};let Kr=new D(1899,11,30),qr=1440*60*1e3,Jr=2e3,Yr=D.now().getFullYear(),Xr=D.now().getMonth(),Zr=D.fromTimestamp(0).getTime()-Kr.getTime(),Qr=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,$r=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,ei=Rt.join(``),ti=RegExp(`\/|-|${Rt.join(`|`)}`),ni=RegExp(`^(\\d{1,4})[\/${ei}\-](\\d{1,4})([\/${ei}\-](\\d{1,4}))?$`),ri=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function ii(e,t){switch(typeof e){case`number`:return e;case`string`:return ai(e,t)?si(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function ai(e,t){return si(e,t)!==null}let oi=new Map;function si(e,t){return oi.has(t)||oi.set(t,new Map),oi.get(t).has(e)||oi.get(t).set(e,ci(e,t)),oi.get(t).get(e)}function ci(e,t){e=e.trim();let n=null,r=e.match(ri);if(r){if(n=gi(r[0]),n===null)return null;e=e.replace(r[0],``).trim()}let i=null,a=li(e,t);if(a){let t=a.dateString.match(ti)[0];if(i=di(a,t),i===null)return null;e=e.replace(a.dateString,``).trim()}return e!==``||!(i||n)?null:i&&i.jsDate&&n&&n.jsDate?{value:i.value+n.value,format:i.format+` `+(n.format===`hhhh:mm:ss`?`hh:mm:ss`:n.format),jsDate:new D(i.jsDate.getFullYear()+n.jsDate.getFullYear()-1899,i.jsDate.getMonth()+n.jsDate.getMonth()-11,i.jsDate.getDate()+n.jsDate.getDate()-30,i.jsDate.getHours()+n.jsDate.getHours(),i.jsDate.getMinutes()+n.jsDate.getMinutes(),i.jsDate.getSeconds()+n.jsDate.getSeconds())}:i||n}function li(e,t){let n=e.match(ni);if(!n)return null;let[,r,i,,a]=n;if(r.length>2&&a&&a.length>2)return null;if(r.length>2)return{year:r,month:i,day:a,dateString:e,type:`ymd`};let o=ui(t);return a?a.length>2?o===`mdy`?{month:r,day:i,year:a,dateString:e,type:`mdy`}:{day:r,month:i,year:a,dateString:e,type:`dmy`}:o===`mdy`?{month:r,day:i,year:a,dateString:e,type:`mdy`}:o===`ymd`?{year:r,month:i,day:a,dateString:e,type:`ymd`}:o===`dmy`?{day:r,month:i,year:a,dateString:e,type:`dmy`}:null:i.length>2?{month:r,year:i,day:void 0,dateString:e,type:o}:o===`dmy`?{day:r,month:i,year:a,dateString:e,type:`dmy`}:{month:r,day:i,year:a,dateString:e,type:`mdy`}}function ui(e){switch(e.dateFormat[0]){case`d`:return`dmy`;case`m`:return`mdy`;case`y`:return`ymd`}throw Error(`Invalid date format in locale`)}function di(e,t){let{year:n,month:r,day:i}=e,a=mi(r),o=hi(i),s=pi(n);if(s===null||a===null||o===null)return null;let c=r?.length===2&&a+1<10||i?.length===2&&o<10,l=n?.length!==2,u=new D(s,a,o);if(u.getMonth()!==a||u.getDate()!==o)return null;let d=u.getTime()-Kr.getTime(),f=fi(e,t,c,l);return{value:Math.round(d/qr),format:f,jsDate:u}}function fi(e,t,n,r){let i=e.year?r?`yyyy`:`yy`:void 0,a=e.month?n?`mm`:`m`:void 0,o=e.day?n?`dd`:`d`:void 0;switch(e.type){case`mdy`:return[a,o,i].filter(C).join(t);case`ymd`:return[i,a,o].filter(C).join(t);case`dmy`:return[o,a,i].filter(C).join(t)}}function pi(e){if(!e)return Yr;let t=Number(e);switch(e.length){case 1:return Jr+t;case 2:return Jr+(Jr+t>Yr+10?-100:0)+t;case 3:case 4:return t}return null}function mi(e){if(!e)return Xr;let t=Number(e);return t>=1&&t<=12?t-1:null}function hi(e){if(!e)return 1;let t=Number(e);return t>=0&&t<=31?t:null}function gi(e){if(e=e.trim(),ri.test(e)){let t=/AM/i.test(e),n=/PM/i.test(e),r=(t||n?e.substring(0,e.length-2).trim():e).split(/:/),i=r.length>=2,a=r.length===3,o=Number(r[0]),s=i?Number(r[1]):0,c=a?Number(r[2]):0,l=a?`hh:mm:ss`:`hh:mm`;if(t||n)l+=` a`;else if(!i)return null;o>=12&&t?o-=12:o<12&&n&&(o+=12),s+=Math.floor(c/60),c%=60,o+=Math.floor(s/60),s%=60,o>=24&&(l=`hhhh:mm:ss`);let u=new D(1899,11,30,o,s,c);return{value:o/24+s/1440+c/86400,format:l,jsDate:u}}return null}function _i(e){let t=Math.trunc(e),n=D.fromTimestamp(t*qr-Zr),r=e-t;r=r<0?1+r:r;let i=Math.round(r*24),a=Math.round((r-i/24)*24*60),o=Math.round((r-i/24-a/24/60)*24*60*60);return n.setHours(i),n.setMinutes(a),n.setSeconds(o),n}function vi(e){return Math.round(yi(e))}function yi(e){return(e.getTime()-Kr.getTime())/qr}function bi(e){return new D(e.getFullYear(),e.getMonth()+1,0).getDate()}function xi(e){return bi(e)===e.getDate()}function Si(e,t,n){let r=e.getFullYear(),i=e.getMonth(),a=e.getDate(),o=new D(r,i+t,1);return n&&a===bi(e)||a>bi(o)?o.setDate(bi(o)):o.setDate(a),o}function Ci(e){let t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function wi(e,t,n){if(e===t)return 0;if(e>t){let n=t;t=e,e=n}let r=_i(e),i=_i(t),a=r.getDate(),o=i.getDate(),s=r.getMonth(),c=i.getMonth(),l=r.getFullYear(),u=i.getFullYear(),d=0,f=0;switch(n){case 0:a===31&&(a=30),a===30&&o===31&&(o=30),s===1&&a===(Ci(l)?29:28)&&(a=30,c===1&&o===(Ci(u)?29:28)&&(o=30)),d=l+(s*30+a)/360,f=u+(c*30+o)/360;break;case 1:let n=365,r=l===u,i=l+1===u;if(!r&&!i||!r&&s<c||!r&&s===c&&a<o){let e=0,t=0;for(let n=l;n<=u;n++)e++,t+=Ci(n)?366:365;n=t/e}else r?Ci(l)&&(n=366):(Ci(l)&&s<2&&(n=366),Ci(u)&&(c>1||c===1&&o===29)&&(n=366));d=e/n,f=t/n;break;case 2:d=e/360,f=t/360;break;case 3:d=e/365,f=t/365;break;case 4:a===31&&(a=30),o===31&&(o=30),d=l+(s*30+a)/360,f=u+(c*30+o)/360;break}return f-d}function Ti(e,t){let n=(t.getFullYear()-e.getFullYear())*12+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?n-1:n}function Ei(e,t){let n=e.getTime(),r=t.getTime();return Math.floor((r-n)/qr)}function Di(e,t){let n=t.getFullYear()-e.getFullYear(),r=e.getMonth(),i=t.getMonth(),a=e.getDate(),o=t.getDate();return i>r||i===r&&o>=a?n:n-1}function Oi(e,t){return wi(e,t,1)<1}function ki(e,t){return Math.trunc(e)===Math.trunc(t)}function Ai(e,t,n){return t>n?Ai(e,n,t):(e=Math.trunc(e),t=Math.trunc(t),n=Math.trunc(n),e>=t&&e<=n)}function ji(e,t){return Math.trunc(e)<Math.trunc(t)}function Mi(e,t){return Math.trunc(e)<=Math.trunc(t)}function Ni(e,t){return Math.trunc(e)>Math.trunc(t)}function Pi(e,t){return Math.trunc(e)>=Math.trunc(t)}let Fi=Vt(function(e){return e=at(e),RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e(\\+|-)?\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)}),Ii=Vt(function(e){let t=at(e.decimalSeparator),n=`(?:\\d+(?:${at(e.thousandsSeparator||``)}\\d{3,})*(?:${t}\\d*)?)`,r=`(?:${t}\\d+)`,i=`(?:\\s*`+n+`|`+r+`)(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?`,a=`(?:\\s*-)?`,o=`(?:\\s*[\\$€])?`,s=`^(?:(?:`+[a+o+i,a+i+o,o+a+i].join(`)|(?:`)+`))$`;return new RegExp(s,`i`)});function Li(e,t){return e?Ii(t).test(e.trim()):!1}let Ri=Vt(function(e){return RegExp(`[\$€${at(e.thousandsSeparator||``)}]`,`g`)});function zi(e,t){e=e.replace(Ri(t),``),t.decimalSeparator!==`.`&&(e=e.replace(t.decimalSeparator,`.`));let n=Number(e);return isNaN(n)&&e.includes(`%`)&&(n=Number(e.split(`%`)[0]),!isNaN(n))?n/100:n}function Bi(e,t,n){let r=[...e].sort((e,t)=>e-t),i=(r.length+(n?-1:1))*t;if(n||i--,Number.isInteger(i))return r[i];let a=Math.ceil(i),o=Math.floor(i);return r[a]*(i-o)+r[o]*(a-i)}let Vi=e=>e,Hi=()=>!1,Ui=Vi,Wi=Hi;function Gi(e,...t){if(t.length===1&&typeof t[0]==`object`&&!(t[0]instanceof String)){let n=t[0];e=e.replace(/\%\(([^\)]+)\)s/g,(e,t)=>n[t])}else t.length>0&&(e=e.replace(/\%s/g,()=>t.shift()));return e}function Ki(e,t=()=>!0){Ui=e,Wi=t}function qi(){Ui===Vi&&Wi===Hi&&(Wi=()=>!0)}let O=function(e,...t){return Wi()?Gi(Ui(e),...t):new Ji(e,t)};var Ji=class extends String{constructor(e,t){super(e),this.values=t}valueOf(){let e=super.valueOf();return Wi()?Gi(Ui(e),...this.values):Gi(e,...this.values)}toString(){return this.valueOf()}};function Yi(e){return`sheetId`in e}function Xi(e){return`dimension`in e&&`sheetId`in e&&`elements`in e}function Zi(e){return`target`in e&&`sheetId`in e}function Qi(e){return`ranges`in e}function $i(e){return`col`in e&&`row`in e&&`sheetId`in e}function ea(e){return`sheetId`in e&&`zone`in e}let ta=new Set([`RENAME_SHEET`,`DELETE_SHEET`,`CREATE_SHEET`,`DUPLICATE_SHEET`,`ADD_COLUMNS_ROWS`,`REMOVE_COLUMNS_ROWS`,`UNDO`,`REDO`,`ADD_MERGE`,`REMOVE_MERGE`,`UPDATE_LOCALE`,`ADD_PIVOT`,`UPDATE_PIVOT`,`INSERT_PIVOT`,`RENAME_PIVOT`,`REMOVE_PIVOT`,`DUPLICATE_PIVOT`]),na=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`]),ra=new Set([`MOVE_RANGES`]),ia=new Set([`EVALUATE_CELLS`,`ADD_CONDITIONAL_FORMAT`,`REMOVE_CONDITIONAL_FORMAT`,`CHANGE_CONDITIONAL_FORMAT_PRIORITY`]),aa=new Set([`AUTOFILL_CELL`,`SET_BORDER`,`SET_ZONE_BORDERS`,`SET_BORDERS_ON_TARGET`]),oa=new Set([`START`,`ACTIVATE_SHEET`,`COPY`,`RESIZE_SHEETVIEW`,`SET_VIEWPORT_OFFSET`,`EVALUATE_CELLS`,`EVALUATE_CHARTS`,`SET_FORMULA_VISIBILITY`,`UPDATE_FILTER`]),sa=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`.split(`.`));function ca(e){return sa.has(e.type)}function la(e){return oa.has(e.type)}var ua=class{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter(e=>e!==`Success`)}static get Success(){return da}get isSuccessful(){return this.reasons.length===0}isCancelledBecause(e){return this.reasons.includes(e)}};let da=new ua,fa=function(e){return e.Success=`Success`,e.CancelledForUnknownReason=`CancelledForUnknownReason`,e.WillRemoveExistingMerge=`WillRemoveExistingMerge`,e.CannotMoveTableHeader=`CannotMoveTableHeader`,e.MergeIsDestructive=`MergeIsDestructive`,e.CellIsMerged=`CellIsMerged`,e.InvalidTarget=`InvalidTarget`,e.EmptyUndoStack=`EmptyUndoStack`,e.EmptyRedoStack=`EmptyRedoStack`,e.NotEnoughElements=`NotEnoughElements`,e.NotEnoughSheets=`NotEnoughSheets`,e.MissingSheetName=`MissingSheetName`,e.UnchangedSheetName=`UnchangedSheetName`,e.DuplicatedSheetName=`DuplicatedSheetName`,e.DuplicatedSheetId=`DuplicatedSheetId`,e.ForbiddenCharactersInSheetName=`ForbiddenCharactersInSheetName`,e.WrongSheetMove=`WrongSheetMove`,e.WrongSheetPosition=`WrongSheetPosition`,e.InvalidAnchorZone=`InvalidAnchorZone`,e.SelectionOutOfBound=`SelectionOutOfBound`,e.TargetOutOfSheet=`TargetOutOfSheet`,e.WrongCutSelection=`WrongCutSelection`,e.WrongPasteSelection=`WrongPasteSelection`,e.WrongPasteOption=`WrongPasteOption`,e.WrongFigurePasteOption=`WrongFigurePasteOption`,e.EmptyClipboard=`EmptyClipboard`,e.EmptyRange=`EmptyRange`,e.InvalidRange=`InvalidRange`,e.InvalidZones=`InvalidZones`,e.InvalidSheetId=`InvalidSheetId`,e.InvalidCellId=`InvalidCellId`,e.InvalidFigureId=`InvalidFigureId`,e.InputAlreadyFocused=`InputAlreadyFocused`,e.MaximumRangesReached=`MaximumRangesReached`,e.MinimumRangesReached=`MinimumRangesReached`,e.InvalidChartDefinition=`InvalidChartDefinition`,e.InvalidDataSet=`InvalidDataSet`,e.InvalidLabelRange=`InvalidLabelRange`,e.InvalidScorecardKeyValue=`InvalidScorecardKeyValue`,e.InvalidScorecardBaseline=`InvalidScorecardBaseline`,e.InvalidGaugeDataRange=`InvalidGaugeDataRange`,e.EmptyGaugeRangeMin=`EmptyGaugeRangeMin`,e.GaugeRangeMinNaN=`GaugeRangeMinNaN`,e.EmptyGaugeRangeMax=`EmptyGaugeRangeMax`,e.GaugeRangeMaxNaN=`GaugeRangeMaxNaN`,e.GaugeLowerInflectionPointNaN=`GaugeLowerInflectionPointNaN`,e.GaugeUpperInflectionPointNaN=`GaugeUpperInflectionPointNaN`,e.InvalidAutofillSelection=`InvalidAutofillSelection`,e.MinBiggerThanMax=`MinBiggerThanMax`,e.LowerBiggerThanUpper=`LowerBiggerThanUpper`,e.MidBiggerThanMax=`MidBiggerThanMax`,e.MinBiggerThanMid=`MinBiggerThanMid`,e.FirstArgMissing=`FirstArgMissing`,e.SecondArgMissing=`SecondArgMissing`,e.MinNaN=`MinNaN`,e.MidNaN=`MidNaN`,e.MaxNaN=`MaxNaN`,e.ValueUpperInflectionNaN=`ValueUpperInflectionNaN`,e.ValueLowerInflectionNaN=`ValueLowerInflectionNaN`,e.MinInvalidFormula=`MinInvalidFormula`,e.MidInvalidFormula=`MidInvalidFormula`,e.MaxInvalidFormula=`MaxInvalidFormula`,e.ValueUpperInvalidFormula=`ValueUpperInvalidFormula`,e.ValueLowerInvalidFormula=`ValueLowerInvalidFormula`,e.InvalidSortAnchor=`InvalidSortAnchor`,e.InvalidSortZone=`InvalidSortZone`,e.SortZoneWithArrayFormulas=`SortZoneWithArrayFormulas`,e.WaitingSessionConfirmation=`WaitingSessionConfirmation`,e.MergeOverlap=`MergeOverlap`,e.TooManyHiddenElements=`TooManyHiddenElements`,e.Readonly=`Readonly`,e.InvalidViewportSize=`InvalidViewportSize`,e.InvalidScrollingDirection=`InvalidScrollingDirection`,e.ViewportScrollLimitsReached=`ViewportScrollLimitsReached`,e.FigureDoesNotExist=`FigureDoesNotExist`,e.InvalidConditionalFormatId=`InvalidConditionalFormatId`,e.InvalidConditionalFormatType=`InvalidConditionalFormatType`,e.InvalidCellPopover=`InvalidCellPopover`,e.EmptyTarget=`EmptyTarget`,e.InvalidFreezeQuantity=`InvalidFreezeQuantity`,e.FrozenPaneOverlap=`FrozenPaneOverlap`,e.ValuesNotChanged=`ValuesNotChanged`,e.InvalidFilterZone=`InvalidFilterZone`,e.TableNotFound=`TableNotFound`,e.TableOverlap=`TableOverlap`,e.InvalidTableConfig=`InvalidTableConfig`,e.InvalidTableStyle=`InvalidTableStyle`,e.FilterNotFound=`FilterNotFound`,e.MergeInTable=`MergeInTable`,e.NonContinuousTargets=`NonContinuousTargets`,e.DuplicatedFigureId=`DuplicatedFigureId`,e.InvalidSelectionStep=`InvalidSelectionStep`,e.DuplicatedChartId=`DuplicatedChartId`,e.ChartDoesNotExist=`ChartDoesNotExist`,e.InvalidHeaderIndex=`InvalidHeaderIndex`,e.InvalidQuantity=`InvalidQuantity`,e.MoreThanOneColumnSelected=`MoreThanOneColumnSelected`,e.EmptySplitSeparator=`EmptySplitSeparator`,e.SplitWillOverwriteContent=`SplitWillOverwriteContent`,e.NoSplitSeparatorInSelection=`NoSplitSeparatorInSelection`,e.NoActiveSheet=`NoActiveSheet`,e.InvalidLocale=`InvalidLocale`,e.MoreThanOneRangeSelected=`MoreThanOneRangeSelected`,e.NoColumnsProvided=`NoColumnsProvided`,e.ColumnsNotIncludedInZone=`ColumnsNotIncludedInZone`,e.DuplicatesColumnsSelected=`DuplicatesColumnsSelected`,e.InvalidHeaderGroupStartEnd=`InvalidHeaderGroupStartEnd`,e.HeaderGroupAlreadyExists=`HeaderGroupAlreadyExists`,e.UnknownHeaderGroup=`UnknownHeaderGroup`,e.UnknownDataValidationRule=`UnknownDataValidationRule`,e.UnknownDataValidationCriterionType=`UnknownDataValidationCriterionType`,e.InvalidDataValidationCriterionValue=`InvalidDataValidationCriterionValue`,e.InvalidNumberOfCriterionValues=`InvalidNumberOfCriterionValues`,e.InvalidCopyPasteSelection=`InvalidCopyPasteSelection`,e.NoChanges=`NoChanges`,e.InvalidInputId=`InvalidInputId`,e.SheetIsHidden=`SheetIsHidden`,e.InvalidTableResize=`InvalidTableResize`,e.PivotIdNotFound=`PivotIdNotFound`,e.PivotInError=`PivotInError`,e.EmptyName=`EmptyName`,e.ValueCellIsInvalidFormula=`ValueCellIsInvalidFormula`,e.InvalidDefinition=`InvalidDefinition`,e.InvalidColor=`InvalidColor`,e.InvalidPivotDataSet=`InvalidPivotDataSet`,e}({}),pa=[{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:`;`}],k=pa[0],ma=[`thin`,`medium`,`thick`,`dashed`,`dotted`];function A(e){return Array.isArray(e)&&Array.isArray(e[0])}let ha={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},ga=Vt(()=>Object.keys(ha).sort((e,t)=>ha[e]-ha[t]));function _a(e,t){if(ha[e])throw Error(`Layer ${e} already exists`);ha[e]=t}let j={NotAvailable:`#N/A`,InvalidReference:`#REF`,BadExpression:`#BAD_EXPR`,CircularDependency:`#CYCLE`,UnknownFunction:`#NAME?`,DivisionByZero:`#DIV/0!`,SpilledBlocked:`#SPILL!`,GenericError:`#ERROR`,NullError:`#NULL!`},va=new Set(Object.values(j));var M=class{constructor(e=O(`Error`),t=j.GenericError){this.message=e,this.value=t,this.message=e.toString()}},ya=class extends M{constructor(e=O(`Invalid expression`)){super(e,j.BadExpression)}},ba=class extends M{constructor(e=O(`Circular reference`)){super(e,j.CircularDependency)}},xa=class extends M{constructor(e=O(`Invalid reference`)){super(e,j.InvalidReference)}},Sa=class extends M{constructor(e=O(`Data not available`)){super(e,j.NotAvailable)}},Ca=class extends M{constructor(e=O(`Unknown function`)){super(e,j.UnknownFunction)}},wa=class extends M{constructor(e=O(`Spill range is not empty`),t){super(e,j.SpilledBlocked),this.errorOriginPosition=t}};let Ta=[`number`,`string`,`boolean`,`undefined`];function N(e,t,n){if(!e())throw new M(t,n)}function Ea(e){if(e!==void 0)return A(e)?e[0][0]?.format:e.format}function P(e){return typeof e==`string`&&va.has(e)}function Da(e){return{value:j.NotAvailable,message:O(`Did not find value '%s' in [[FUNCTION_NAME]] evaluation.`,I(e))}}let Oa=e=>O(`The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.`,e),ka=(e,t,n)=>O(`The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.`,e.toString(),t.toString(),n.toString()),Aa=(e,t)=>O(`The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.`,t,e.map(e=>`'${e}'`).join(`, `));function F(e,t){let n=Va(e);switch(typeof n){case`number`:return n;case`boolean`:return+!!n;case`string`:if(Li(n,t)||n===``)return zi(n,t);let e=si(n,t);if(e)return e.value;throw new M(Oa(n));default:return 0}}function ja(e,t){try{return F(e,t)}catch{return}}function Ma(e,t){return z(e).map(e=>e.map(e=>{if(typeof e.value!=`number`){let n=``;throw typeof e==`object`?n=O(`Function [[FUNCTION_NAME]] expects number values for %s, but got an empty value.`,t):typeof e==`string`?n=O(`Function [[FUNCTION_NAME]] expects number values for %s, but got a string.`,t):typeof e==`boolean`&&(n=O(`Function [[FUNCTION_NAME]] expects number values for %s, but got a boolean.`,t)),new M(n)}return e.value}))}function Na(e,t){let n=Va(e);if(n===``)throw new M(Oa(n));return F(n,t)}function Pa(e,t){return Math.trunc(F(e,t))}function Fa(e,t){return Math.trunc(Na(e,t))}function Ia(e){N(()=>e>=1,O(`The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.`,e.toString()))}function La(e){N(()=>e!==0,O(`Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero)}function I(e){let t=Va(e);switch(typeof t){case`string`:return t;case`number`:return t.toString();case`boolean`:return t?`TRUE`:`FALSE`;default:return``}}let Ra=Vt(function(e){return e.toLowerCase().normalize(`NFD`).replace(/[\u0300-\u036f]/g,``)}),za=e=>O(`The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.`,e);function L(e){let t=Va(e);switch(typeof t){case`boolean`:return t;case`string`:if(t){let e=t.toUpperCase();if(e===`TRUE`)return!0;if(e===`FALSE`)return!1;throw new M(za(t))}else return!1;case`number`:return!!t;default:return!1}}function Ba(e){let t=Va(e);if(t===``)throw new M(za(t));return L(t)}function R(e,t){return _i(F(Va(e),t))}function Va(e){if(typeof e==`object`&&e&&`value`in e){if(P(e.value))throw e;return e.value}if(P(e))throw new M(``,e);return e}function Ha(e,t,n){for(let r of e)if(A(r)){let e=r.length,n=r[0].length;for(let i=0;i<n;i++)for(let n=0;n<e;n++)t(r[n][i])}else n(r)}function Ua(e,t){Ha(e,e=>{if(P(e.value))throw e;t(e)},e=>{if(P(e?.value))throw e;t(e)})}function Wa(e,t,n){Ha(e,e=>{if(typeof e?.value==`number`&&t(e),P(e?.value))throw e},e=>{t({value:Na(e,n),format:e?.format})})}function Ga(e,t,n,r,i=`rowFirst`){let a=r;for(let r of e)if(A(r)){let e=r.length,n=r[0].length;if(i===`rowFirst`)for(let i=0;i<n;i++)for(let n=0;n<e;n++)a=t(a,r[n][i]);else for(let i=0;i<e;i++)for(let e=0;e<n;e++)a=t(a,r[i][e])}else a=n(a,r);return a}function Ka(e,t,n,r=`rowFirst`){return Ga(e,t,t,n,r)}function qa(e,t,n,r){return Ga(e,(e,n)=>{let r=n?.value;if(typeof r==`number`)return t(e,r);if(P(r))throw n;return e},(e,n)=>t(e,Na(n,r)),n)}function Ja(e,t,n,r){return Ga(e,(e,n)=>{let i=n?.value;if(i!=null){if(typeof i==`number`)return t(e,i);if(typeof i==`boolean`)return t(e,F(i,r));if(P(i))throw n;return t(e,0)}return e},(e,n)=>t(e,F(n,r)),n)}function Ya(e,t,n){let r=Array(e);for(let i=0;i<e;i++){r[i]=Array(t);for(let e=0;e<t;e++)r[i][e]=n(i,e)}return r}function Xa(e,t){return e.length===0?[]:Ya(e.length,e[0].length,(n,r)=>t(e[n][r]))}function Za(e,t){let n=e.length,r=e[0]?.length??0;for(let i=0;i<n;i++)for(let n=0;n<r;n++)t(e[i][n])}function Qa(e){return e.length?Ya(e[0].length,e.length,(t,n)=>e[n][t]):[]}function $a(e,t,n=void 0){let r=1,i=1,a=1/0,o=1/0,s;for(let e=0;e<t.length;e++){let c=t[e];if(A(c)&&(n===void 0||n[e])){let n=c.length,l=c[0].length;n!==1||l!==1?(s??=Array(t.length),n!==1&&l!==1?(s[e]=`matrix`,r=Math.max(r,n),i=Math.max(i,l),a=Math.min(a,n),o=Math.min(o,l)):n===1?l!==1&&(s[e]=`vertical`,i=Math.max(i,l),o=Math.min(o,l)):(s[e]=`horizontal`,r=Math.max(r,n),a=Math.min(a,n))):t[e]=c[0][0]}}if(r===1&&i===1)return e(...t);let c=(e,n)=>t.map((t,r)=>{switch(s?.[r]){case`matrix`:return t[e][n];case`horizontal`:return t[e][0];case`vertical`:return t[0][n];case void 0:return t}});return Ya(r,i,(t,n)=>{if(t>a-1||n>o-1)return new Sa(O(`Array arguments to [[FUNCTION_NAME]] are of different size.`));let r=e(...c(t,n));return A(r)?r[0][0]:r})}function eo(e,t,n){for(let r of e)if(A(r)){let e=r.length,n=r[0].length;for(let i=0;i<n;i++)for(let n=0;n<e;n++)if(!t(r[n][i]??void 0))return}else if(!n(r))return}function to(e,t){return eo(e,e=>{let n=e?.value;if(typeof n==`boolean`)return t(n);if(typeof n==`number`)return t(!!n);if(P(n))throw e;return!0},e=>e!==void 0&&e.value!==null?t(Ba(e)):!0)}function no(e,t){let n,r,i=e.substring(0,2);return i===`<=`||i===`>=`||i===`<>`?(n=i,r=e.substring(2)):(i=e.substring(0,1),i===`<`||i===`>`||i===`=`?(n=i,r=e.substring(1)):(n=`=`,r=e)),Li(r,t)||ai(r,t)?r=F(r,t):(r===`TRUE`||r===`FALSE`)&&(r=L(r)),{operator:n,operand:r}}let ro=Vt(function(e){if(e===`*`)return/.+/;let t=``,n=``;for(let r of e)r===`?`&&n!==`~`?t+=`.`:r===`*`&&n!==`~`?t+=`.*`:((r===`*`||r===`?`)&&(t=t.slice(0,-1)),[`^`,`.`,`[`,`]`,`$`,`(`,`)`,`*`,`+`,`?`,`|`,`{`,`}`,`\\`].includes(r)&&(t+=`\\`),t+=r),n=r;return RegExp(`^`+t+`$`,`i`)});function io(e=``,t,n){let{operator:r,operand:i}=t;if(i===void 0||e===null||i===null)return!1;if(typeof i==`number`&&r===`=`)return typeof e==`string`&&(Li(e,n)||ai(e,n))?F(e,n)===i:e===i;if(r===`<>`||r===`=`){let t;return t=typeof e==typeof i?typeof e==`string`&&typeof i==`string`?ro(i).test(e):e===i:!1,r===`=`?t:!t}if(typeof e==typeof i)switch(r){case`<`:return e<i;case`>`:return e>i;case`<=`:return e<=i;case`>=`:return e>=i}return!1}function ao(e,t,n,r=!1){let i=e.length;if(i%2==1)throw new M(O(`Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs.`));let a=z(e[0]),o=a.length,s=a[0].length,c=[];for(let t=0;t<i-1;t+=2){let i=z(e[t]);if(i.length!==o||i[0].length!==s)throw new M(O(`Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension`));let a=no(I(e[t+1]),n);r&&typeof a.operand==`string`&&(a.operand+=`*`),c.push(a)}for(let r=0;r<o;r++)for(let a=0;a<s;a++){let o=!0;for(let t=0;t<i-1;t+=2){let i=z(e[t])[r][a].value,s=c[t/2];if(o=io(i??void 0,s,n),!o)break}o&&t(r,a)}}function oo(e,t,n,r,i,a){if(t===void 0||t.value===null)return-1;if(P(t.value))throw t;let o=lo(t.value),s=typeof o,c,l,u=0,d=i-1,f,p,m,h,g=r===`desc`?t=>lo(a(e,i-t-1)):t=>lo(a(e,t));for(;d-u>=0;){for(f=Math.floor((u+d)/2),p=f,m=g(p),h=typeof m;u<p&&s!==h;)p--,m=g(p),h=typeof m;if(h!==s||m==null){u=f+1;continue}n===`strict`&&m===o?(c=m,l=p):n===`nextSmaller`&&m<=o?(c==null||c<m||c===m&&l<p)&&(c=m,l=p):n===`nextGreater`&&m>=o&&(c===void 0||c>m||c===m&&l<p)&&(c=m,l=p),m>o||n===`strict`&&m===o?d=p-1:u=f+1}return l===void 0?-1:r===`desc`?i-l-1:l}function so(e,t,n,r,i,a,o=!1){if(t===void 0||t.value===null)return-1;if(P(t.value))throw t;let s=lo(t.value),c=o?(e,t)=>lo(i(e,r-t-1)):(e,t)=>lo(i(e,t)),l=n!==`wildcard`||typeof s!=`string`||!(s.includes(`*`)||s.includes(`?`));if(a&&l){let t=o?`reverseSearch`:`forwardSearch`,i=a[t].get(e);if(i===void 0){i=new Map;for(let t=0;t<r;t++){let n=c(e,t)??null;i.has(n)||i.set(n,t)}a[t].set(e,i)}if(i.has(s)){let e=i.get(s);return o?r-e-1:e}if(n===`strict`)return-1}let u=co(e,s,n,r,c);return o&&u!==-1?r-u-1:u}function co(e,t,n,r,i){let a=n=>i(e,n)===t;if(n===`wildcard`&&typeof t==`string`&&(t.includes(`*`)||t.includes(`?`))){let n=ro(t);a=t=>{let r=i(e,t);return typeof r==`string`?n.test(r):!1}}let o,s=-1;n===`nextSmaller`&&(a=n=>{let r=i(e,n);return(!o&&uo(t,r)>=0||uo(t,r)>=0&&uo(r,o)>0)&&(o=r,s=n),r===t}),n===`nextGreater`&&(a=n=>{let r=i(e,n);return(!o&&uo(t,r)<=0||uo(t,r)<=0&&uo(r,o)<0)&&(o=r,s=n),r===t});for(let e=0;e<r;e++)if(a(e))return e;return s}function lo(e){return typeof e==`string`?Ra(e):e}function uo(e,t){let n=Ta.indexOf(typeof e)-Ta.indexOf(typeof t);return n===0&&(typeof e==`string`&&typeof t==`string`?n=e.localeCompare(t):typeof e==`number`&&typeof t==`number`?n=e-t:typeof e==`boolean`&&typeof t==`boolean`&&(n=Number(e)-Number(t))),n}function z(e){return e===void 0?[[]]:A(e)?e:[[e]]}function fo(e,t){return Ka(e,(e,n)=>(e.push(t(n)),e),[],`rowFirst`)}function po(e){if(e===void 0)return!1;let{value:t}=e;return!(t===null||t===``)}function mo(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}let ho=new h;function go(e,t){return e=mo(e),{url:e,label:t||e,isExternal:!0,isUrlEditable:!0}}ho.add(`sheet_URL`,{match:e=>xt(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){let n=Ct(e);return t.tryGetSheetName(n)||O(`Invalid sheet`)},open(e,t){let n=Ct(e);t.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:n}).isCancelledBecause(`SheetIsHidden`)&&t.notifyUser({type:`warning`,sticky:!1,text:O(`Cannot open the link because the linked sheet is hidden.`)})},sequence:0});let _o={createLink:go,match:e=>_t(e),open:e=>window.open(e,`_blank`),urlRepresentation:e=>e,sequence:0};function vo(e){return ho.getAll().sort((e,t)=>e.sequence-t.sequence).find(t=>t.match(e))||_o}function yo(e,t){return vo(e.url).urlRepresentation(e.url,t)}function bo(e,t,n){vo(e.url).open(e.url,t,n)}function xo(e){if(typeof e==`string`){if(gt(e)){let{label:t,url:n}=yt(e);return vo(n).createLink(n,t)}else if(_t(e))return go(e)}}function So(e){let t=new Xt(e),n=[],r=[];for(n.push(r);!t.isOver();){if(t.current===`;`){r=[],n.push(r),t.shift();continue}let e=Ao(t)||Co(t)||To(t)||Eo(t)||Oo(t)||ko(t)||Mo(t)||Do(t)||No(t);if(!e)throw Error(`Unknown token at `+t.remaining());r.push(e)}return n}function Co(e){let t;if(e.current===`"`?(e.shift(),t=`"`):e.currentStartsWith(`[$`)&&(e.advanceBy(2),t=`]`),!t)return null;let n=``;for(;e.current&&e.current!==t;)n+=e.shift();if(e.current===t)e.shift();else throw Error(`Unterminated string in format`);return{type:`STRING`,value:n}}let wo=new Set(`$+-/():!^&~{}<>= `);function To(e){if(e.current===`\\`){e.shift();let t=e.shift();if(!t)throw Error(`Unexpected end of format string`);return{type:`CHAR`,value:t}}return wo.has(e.current)?{type:`CHAR`,value:e.shift()}:null}function Eo(e){return e.current===`,`?(e.shift(),{type:`THOUSANDS_SEPARATOR`,value:`,`}):null}function Do(e){return e.current===`@`?(e.shift(),{type:`TEXT_PLACEHOLDER`,value:`@`}):null}function Oo(e){return e.current===`.`?(e.shift(),{type:`DECIMAL_POINT`,value:`.`}):null}function ko(e){return e.current===`%`?(e.shift(),{type:`PERCENT`,value:`%`}):null}function Ao(e){if(e.current===`0`||e.current===`#`){let t=e.current;return e.shift(),{type:`DIGIT`,value:t}}return null}let jo=new Set(`dmqyhsa`);function Mo(e){if(!jo.has(e.current))return null;let t=e.current,n=``;for(;e.current===t;)n+=e.shift();return{type:`DATE_PART`,value:n}}function No(e){if(e.current!==`*`)return null;e.shift();let t=e.shift();if(!t)throw Error(`Unexpected end of format string`);return{type:`REPEATED_CHAR`,value:t}}let Po={};function Fo(e){let t=Po[e];return t===void 0&&(t=Io(e),Po[e]=t),t}function Io(e){let t=So(e);for(let e of t){let t=e.filter(e=>e.type===`REPEATED_CHAR`);for(let e of t.slice(1))e.type=`CHAR`}let n=Vo(t[0])||Bo(t[0])||Ho(t[0]);if(!n)throw Error(`Invalid first format part of: `+e);if(t.length>1&&n.type===`text`)throw Error(`The first format in a multi-part format must be a number format: `+e);let r=Vo(t[1])||Bo(t[1]);if(t[1]?.length&&!r)throw Error(`Invalid second format part of: `+e);let i=Vo(t[2])||Bo(t[2]);if(t[2]?.length&&!i)throw Error(`Invalid third format part of: `+e);let a=Ho(t[3]);if(t[3]?.length&&!a)throw Error(`Invalid fourth format part of: `+e);return{positive:n,negative:r,zero:i,text:a}}function Lo(e){return e.every(e=>e.type===`DATE_PART`||e.type===`DECIMAL_POINT`||e.type===`THOUSANDS_SEPARATOR`||e.type===`STRING`||e.type===`CHAR`||e.type===`REPEATED_CHAR`)}function Ro(e){return e.every(e=>e.type===`DIGIT`||e.type===`DECIMAL_POINT`||e.type===`THOUSANDS_SEPARATOR`||e.type===`PERCENT`||e.type===`STRING`||e.type===`CHAR`||e.type===`REPEATED_CHAR`)}function zo(e){return e.every(e=>e.type===`STRING`||e.type===`TEXT_PLACEHOLDER`||e.type===`CHAR`||e.type===`REPEATED_CHAR`)}function Bo(e){if(!e||!Ro(e))return;let t=[],n,r=t,i=0,a=0,o=e.findLastIndex(e=>e.type===`DIGIT`),s=!1,c=0;for(let l=0;l<e.length;l++){let u=e[l];switch(u.type){case`DIGIT`:r===t?r.push(u):c<20&&(r.push(u),c++);break;case`DECIMAL_POINT`:if(r===t)n=[],r=n;else throw Error(`Multiple decimal points in a number format`);break;case`REPEATED_CHAR`:case`CHAR`:case`STRING`:r.push(u);break;case`PERCENT`:i++,r.push(u);break;case`THOUSANDS_SEPARATOR`:l-1===o?(a+=1,o++,r.push(u)):e[l+1]?.type===`DIGIT`&&e[l-1]?.type===`DIGIT`?(r===t&&(s=!0),r.push(u)):r.push({type:`CHAR`,value:`,`});break}}return{type:`number`,integerPart:t,decimalPart:n,percentSymbols:i,thousandsSeparator:s,magnitude:a}}function Vo(e){let t=e&&Lo(e)?{type:`date`,tokens:e}:void 0;if(t){if(t.tokens.length&&t.tokens.every(e=>e.type===`DATE_PART`&&e.value===`a`))throw Error(`Invalid date format`);return{type:`date`,tokens:Uo(t.tokens.map(e=>e.type===`THOUSANDS_SEPARATOR`||e.type===`DECIMAL_POINT`?{type:`CHAR`,value:e.value}:e))}}}function Ho(e){return e&&zo(e)?{type:`text`,tokens:e}:void 0}function Uo(e){let t=e.filter(e=>e.type===`DATE_PART`);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}function Wo(e){return[Go(e.positive),Go(e.negative),Go(e.zero),Go(e.text)].filter(C).join(`;`)}function Go(e){if(!e)return;let t=``,n=e.type===`number`?Ko(e):e.tokens;for(let e of n)switch(e.type){case`STRING`:t+=`[$${e.value}]`;break;case`CHAR`:t+=qo(e.value)?`\\${e.value}`:e.value;break;case`REPEATED_CHAR`:t+=`*`+e.value;break;case`DATE_PART`:t+=e.value===`MM`?`mm`:e.value;break;default:t+=e.value}return t}function Ko(e){let t=[...e.integerPart];return e.decimalPart&&(t.push({type:`DECIMAL_POINT`,value:`.`}),t.push(...e.decimalPart)),t}function qo(e){return!wo.has(e)}let Jo=`REPEATED_CHAR_PLACEHOLDER_`,Yo={0:O(`January`),1:O(`February`),2:O(`March`),3:O(`April`),4:O(`May`),5:O(`June`),6:O(`July`),7:O(`August`),8:O(`September`),9:O(`October`),10:O(`November`),11:O(`December`)},Xo={0:O(`Sunday`),1:O(`Monday`),2:O(`Tuesday`),3:O(`Wednesday`),4:O(`Thursday`),5:O(`Friday`),6:O(`Saturday`)};function B(e,{format:t,locale:n,formatWidth:r}){switch(typeof e==`boolean`&&(e=e?`TRUE`:`FALSE`),typeof e){case`string`:{if(e.includes(`\\"`)&&(e=e.replaceAll(/\\"/g,`"`)),!t)return e;let n=Fo(t),i=n.text||n.positive;return!i||i.type!==`text`?e:Zo(e,i,r)}case`number`:t||=ps(e);let i=Fo(t);if(i.positive.type===`text`)return Zo(e.toString(),i.positive,r);let a=i.positive;if(e<0&&i.negative?(a=i.negative,e=-e):e===0&&i.zero&&(a=i.zero),a.type===`date`)return Qo(us(e,a),r);let o=e<0,s=Qo($o(Math.abs(e),a,n),r);return o?`-`+s:s;case`object`:return``}}function Zo(e,t,n){let r=``;for(let n of t.tokens)switch(n.type){case`TEXT_PLACEHOLDER`:r+=e;break;case`CHAR`:case`STRING`:r+=n.value;break;case`REPEATED_CHAR`:r+=Jo+n.value;break}return Qo(r,n)}function Qo(e,t){let n=e.indexOf(Jo);if(n===-1)return e;let r=e.slice(0,n),i=e.slice(n+26+1),a=e[n+26];function o(){if(!t)return{timesToRepeat:0,padding:``};let e=t.measureText(r+i),n=t.measureText(a),o=t.availableWidth-e;if(o<=0)return{timesToRepeat:0,padding:``};let s=Math.floor(o/n),c=o-s*n,l=t.measureText(` `);return{timesToRepeat:s,padding:` `.repeat(Math.floor(c/l))}}let{timesToRepeat:s,padding:c}=o();return r+a.repeat(s)+c+i}function $o(e,t,n){if(e===1/0)return`∞`+(t.percentSymbols?`%`:``);let r=t.percentSymbols*2-t.magnitude*3;e*=10**r;let i=0;t.decimalPart!==void 0&&(i=t.decimalPart.filter(e=>e.type===`DIGIT`).length);let{integerDigits:a,decimalDigits:o}=rs(Math.abs(e),i),s=es(a,t,t.thousandsSeparator?n.thousandsSeparator:void 0);return t.decimalPart!==void 0&&(s+=n.decimalSeparator+ts(o||``,t)),s}function es(e,t,n){let r=t.integerPart;r.some(e=>e.type===`DIGIT`)||(r=[...r,{type:`DIGIT`,value:`#`}]),e===`0`&&(e=``);let i=``,a=r.findIndex(e=>e.type===`DIGIT`),o=e.length-1;function s(t,r){if(r===`0`&&(t||=`0`),!t)return;let a=e.length-1-o;i=n&&a>0&&a%3==0?t+n+i:t+i}for(let t=r.length-1;t>=0;t--){let n=r[t];switch(n.type){case`DIGIT`:let r=e[o];if(s(r,n.value),o--,a===t)for(;o>=0;)s(e[o],`0`),o--;break;case`THOUSANDS_SEPARATOR`:break;case`REPEATED_CHAR`:i=Jo+n.value+i;break;default:i=n.value+i;break}}return i}function ts(e,t){if(!t.decimalPart)return``;let n=``,r=0;for(let i of t.decimalPart)switch(i.type){case`DIGIT`:let t=i.value===`#`?e[r]||``:e[r]||`0`;n+=t,r++;break;case`THOUSANDS_SEPARATOR`:break;case`REPEATED_CHAR`:n+=Jo+i.value;break;default:n+=i.value;break}return n}let ns=[];function rs(e,t=20){let n=e.toString();if(n.includes(`e`))return ss(e,t);if(Number.isInteger(e))return{integerDigits:n,decimalDigits:void 0};let r=n.indexOf(`.`),i=n.substring(0,r),a=n.substring(r+1);if(t===0)return Number(a[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(a.length>t){let{integerDigits:e,decimalDigits:n}=os(a,t);a=n,e!==`0`&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:is(a||``)}}function is(e){let t=e.length-1;for(;t>=0&&e[t]===`0`;)t--;return e.slice(0,t+1)||void 0}let as=/^0+/;function os(e,t){let n=`0`,r=e,i=e.slice(0,t);if(Number(e[t])<5)return{integerDigits:n,decimalDigits:i};let a=i.match(as)?.[0]||``,o=(Number(i)+1).toString(),s=i.slice(a.length),c=o.length>s.length;return c&&!a?(n=`1`,r=void 0):r=c?a.slice(0,-1)+o:a+o,{integerDigits:n,decimalDigits:r}}function ss(e,t=20){let n=ns[t];n||(n=new Intl.NumberFormat(`en-US`,{maximumFractionDigits:t,useGrouping:!1}),ns[t]=n);let[r,i]=n.format(e).split(`.`);return{integerDigits:r,decimalDigits:i}}function cs(e,t){let{integerDigits:n,decimalDigits:r}=rs(e,20);return r?n+t+r:n}let ls=Vt(function(e){if(!e)return!1;try{return Fo(e).positive.type===`date`}catch{return!1}});function us(e,t){let n=_i(e);if(isNaN(n.getTime()))return e.toString();let r=t.tokens.some(e=>e.type===`DATE_PART`&&e.value===`a`),i=``;for(let e of t.tokens)switch(e.type){case`DATE_PART`:i+=ds(n,e.value,r);break;case`REPEATED_CHAR`:i+=Jo+e.value;break;default:i+=e.value;break}return i}function ds(e,t,n){switch(t){case`d`:return e.getDate();case`dd`:return e.getDate().toString().padStart(2,`0`);case`ddd`:return Xo[e.getDay()].slice(0,3);case`dddd`:return Xo[e.getDay()].toString();case`m`:return e.getMonth()+1;case`mm`:return String(e.getMonth()+1).padStart(2,`0`);case`mmm`:return Yo[e.getMonth()].slice(0,3);case`mmmm`:return Yo[e.getMonth()].toString();case`mmmmm`:return Yo[e.getMonth()].slice(0,1);case`qq`:return O(`Q%(quarter)s`,{quarter:e.getQuarter()}).toString();case`qqqq`:return O(`Quarter %(quarter)s`,{quarter:e.getQuarter()}).toString();case`yy`:let r=String(e.getFullYear()).replace(`-`,``).padStart(2,`0`);return r.slice(r.length-2);case`yyyy`:return String(e.getFullYear()).replace(`-`,``).padStart(4,`0`);case`hhhh`:return Math.floor((e.getTime()-Kr.getTime())/(3600*1e3)).toString();case`hh`:let i=e.getHours();return n&&(i=i===0?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 Error(`invalid date format token: ${t}`)}}let fs=Vt(function(e){return RegExp(`[0-9]+${at(e.decimalSeparator)}[0-9]`)});function ps(e){let{integerDigits:t,decimalDigits:n}=rs(e);if(!n)return`0`;let r=t.replace(`-`,``).length;if(r+2>11)return`0`;let i=11-r-1;return{decimalDigits:n}=rs(e,Math.min(i,n.length)),n?`0.`+`0`.repeat(n.length):`0`}function ms(e,t){if(ai(e,t))return si(e,t).format}function hs(e){let t=e.includes(`.`)?`0.00`:`0`,n=e.match(/[\$€]/);if(n){let r=e.match(/[\d]/),i=`[$`+n.values().next().value+`]`;return r.index<n.index?`#,##`+t+i:i+`#,##`+t}if(e.includes(`%`))return t+`%`}function gs(e){let t=e.decimalPlaces??2,n=e.position??`before`,r=e.code??``,i=e.symbol??``,a=`#,##0`+(t?`.`+`0`.repeat(t):``),o=`${r} ${i}`.trim();return n===`after`&&r&&(o=` `+o),ys(o,n,a)}function _s(e){let t=e.decimalPlaces??2,n=e.position??`before`,r=e.code??``,i=e.symbol??``,a=`#,##0`+(t?`.`+`0`.repeat(t):``),o=`${r} ${i}`.trim();return n===`after`&&r&&(o=` `+o),[vs(o,n,` ${a} `),vs(o,n,`(${a})`),vs(o,n,` - `)].join(`;`)}function vs(e,t,n){let r=`[$${e}]`;return t===`before`?r+`* `+n:n+`* `+r}function ys(e,t,n){let r=`[$${e}]`;return t===`before`?r+n:n+r}function bs(e){let t=Fo(e);return Wo({positive:xs(t.positive),negative:t.negative?xs(t.negative):void 0,zero:t.zero?xs(t.zero):void 0,text:t.text})}function xs(e){if(e.type!==`number`||!e.decimalPart)return e;let t=e.decimalPart.filter(e=>e.type!==`DIGIT`);return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...t]}}function Ss({value:e,format:t},n){return B(e,{format:Cs({value:e,format:t},void 0,n),locale:n})}function Cs(e,t,n){let r=0;try{r=Math.abs(F(e?.value,n))}catch{return``}let i=e?.format;if(t!==void 0)switch(t?.value){case`k`:return ws(i,1,`k`,n);case`m`:return ws(i,2,`m`,n);case`b`:return ws(i,3,`b`,n);default:throw new M(O(`The formatting unit should be 'k', 'm' or 'b'.`))}return r<1e5?ws(i,0,``,n):r<1e8?ws(i,1,`k`,n):r<1e11?ws(i,2,`m`,n):ws(i,3,`b`,n)}function ws(e,t,n,r){let i=Fo(e||`#,##0`);return Wo({positive:Ts(i.positive,t,n),negative:i.negative?Ts(i.negative,t,n):void 0,zero:i.zero?Ts(i.zero,t,n):void 0,text:i.text})}function Ts(e,t,n){if(e.type!==`number`)return e;let r=xs(e),i={type:`STRING`,value:n},a=[...r.integerPart],o=a.findLastIndex(e=>e.type===`DIGIT`);if(o===-1)throw Error(`Cannot create a large number format from a format with no digit.`);for(;a[o+1]?.type===`THOUSANDS_SEPARATOR`;)a=Ht(a,[o+1]);let s=a[o+1];a=s?.type===`STRING`&&[`m`,`k`,`b`].includes(s.value)?Wt(a,i,o+1):Ut(a,[i],o+1),t>0&&(a=Ut(a,Array(t).fill({type:`THOUSANDS_SEPARATOR`,value:`,`}),o+1));let c=r.percentSymbols-a.filter(e=>e.type===`PERCENT`).length;return a.push(...Array(c).fill({type:`PERCENT`,value:`%`})),{...r,integerPart:a,magnitude:t}}function Es(e,t){let n=Fo(e);return Wo(Fo(Wo({positive:Ds(n.positive,t),negative:n.negative?Ds(n.negative,t):void 0,zero:n.zero?Ds(n.zero,t):void 0,text:n.text})))}function Ds(e,t){return e.type===`number`?t>0?ks(e,t):Os(e,Math.abs(t)):e}function Os(e,t){let n=e.decimalPart;if(!n)return e;let r=[],i=0;for(let e=n.length-1;e>=0&&!(i>=Math.abs(t));e--)n[e].type===`DIGIT`&&(i++,r.push(e));return n=Ht(n,r),n.some(e=>e.type===`DIGIT`)?{...e,decimalPart:n}:{...e,decimalPart:void 0,integerPart:[...e.integerPart,...n]}}function ks(e,t){let n=e.integerPart,r=e.decimalPart;if(!r){let e=n.findLastIndex(e=>e.type===`DIGIT`);r=n.slice(e+1),n=n.slice(0,e+1)}let i=S(0,t).map(()=>({type:`DIGIT`,value:`0`})),a=r.findLastIndex(e=>e.type===`DIGIT`);return r=a===-1?[...i,...r]:Ut(r,i,a+1),{...e,decimalPart:r,integerPart:n}}function As(e){let t=Fo(e);for(let e of[t.positive,t.negative,t.zero])if(e&&e.type===`date`&&e.tokens.some(e=>e.type===`DATE_PART`&&e.value.includes(`q`)))return!1;return!0}function js(e){if(!e)return!1;try{return Fo(e).positive.type===`text`}catch{return!1}}function Ms(e,t){return Ps({value:js(t.format)&&e.parsedValue!==null?e.content:e.parsedValue,format:t.format},t.locale)}function Ns(e,t){if(e.startsWith(`=`))throw Error(`Cannot parse "${e}" because it's not a literal value. It's a formula`);if(e===``)return null;if(Li(e,k))return zi(e,k);let n=si(e,t);return n?n.value:pt(e)?e.toUpperCase()===`TRUE`:e}function Ps(e,t=k,n){let r=xo(e.value);if(!r)return Fs(e,t,n);let i=Ns(r.label,t);return{...Fs({value:i,format:e.format||(typeof i==`number`?ms(r.label,t)||hs(r.label):void 0)},t,n),link:r}}function Fs(e,t,n){let{value:r,format:i,message:a,errorOriginPosition:o}=e;i=n?.format||i;let s=B(r,{format:i,locale:t});return P(r)?Vs(r,a,o):r===null?Rs(i):js(i)?Is(I(r),i,s):typeof r==`number`?ls(i||``)?zs(r,i,s):Ls(r,i,s):typeof r==`boolean`?Bs(r,i,s):Is(r,i,s)}function Is(e,t,n){return{value:e,format:t,formattedValue:n,type:`text`,isAutoSummable:!0,defaultAlign:`left`}}function Ls(e,t,n){return{value:e||0,format:t,formattedValue:n,type:`number`,isAutoSummable:!0,defaultAlign:`right`}}let Rs=Vt(function(e){return{value:null,format:e,formattedValue:``,type:`empty`,isAutoSummable:!0,defaultAlign:`left`}});function zs(e,t,n){return{value:e,format:t,formattedValue:n,type:`number`,isAutoSummable:!1,defaultAlign:`right`}}function Bs(e,t,n){return{value:e,format:t,formattedValue:n,type:`boolean`,isAutoSummable:!1,defaultAlign:`center`}}function Vs(e,t,n){return{value:e,formattedValue:e,message:t,type:`error`,isAutoSummable:!1,defaultAlign:`center`,errorOriginPosition:n}}function Hs(e){let t=D.now();switch(e){case`today`:return Math.floor(yi(t));case`yesterday`:return t.setDate(t.getDate()-1),Math.floor(yi(t));case`tomorrow`:return t.setDate(t.getDate()+1),Math.floor(yi(t));case`lastWeek`:return t.setDate(t.getDate()-6),Math.floor(yi(t));case`lastMonth`:{let e=t.getMonth()===0?11:t.getMonth()-1,n=new D(t.getFullYear(),e,1);return t.getDate()>bi(n)?t.setDate(1):(t.setDate(t.getDate()+1),t.setMonth(t.getMonth()-1)),Math.floor(yi(t))}case`lastYear`:return t.getMonth()===1&&t.getDate()===29?(t.setDate(28),t.setFullYear(t.getFullYear()-1)):(t.setDate(t.getDate()+1),t.setFullYear(t.getFullYear()-1)),Math.floor(yi(t))}}function Us(e,t){return`dateValue`in e&&e.dateValue!==`exactDate`?[Hs(e.dateValue)]:e.values.map(e=>ii(e,t))}function Ws(e,t){return e.values.map(e=>ja(e,t))}function Gs(e,t){return e.map(e=>{if(e.startsWith(`=`))return e;let n=Ns(e,t);return typeof n==`number`?B(n,{format:t.dateFormat,locale:t}):``})}function Ks(e){return 20+120*Math.exp(-.035*(e-1))}let qs=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,`i`),Js=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,`i`),Ys=new RegExp(/^\$?([A-Z]{1,3})+$/,`i`),Xs=new RegExp(/^\$?([0-9]{1,7})+$/,`i`),Zs=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,`i`),Qs=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,`i`),$s=RegExp(`^\\s*('.+'!|[^']+!)?(`+[qs.source,`(\\$?[A-Z]{1,3})?\\$?[0-9]{1,7}\\s*:\\s*(\\$?[A-Z]{1,3})?\\$?[0-9]{1,7}\\s*`,`\\$?[A-Z]{1,3}(\\$?[0-9]{1,7})?\\s*:\\s*\\$?[A-Z]{1,3}(\\$?[0-9]{1,7})?\\s*`].join(`|`)+`)$`,`i`);function ec(e){return Zs.test(e)}function tc(e){return Qs.test(e)}function nc(e){return Ys.test(e)}function rc(e){return Xs.test(e)}function ic(e){return Js.test(e)}function ac(e){if(!e.includes(`!`))return{xc:e};let t=e.split(`!`),n=t.pop();return{sheetName:st(t.join(`!`))||void 0,xc:n}}function oc(e,t){return e===void 0?t:`${lt(e)}!${t}`}function sc(e,t){let n=e.zone,r=Pr(n,t(e.sheetId)),i=e.parts;return e.parts.length===1&&Nr(r)>1?i=[e.parts[0],e.parts[0]]:e.parts.length===2&&Nr(r)===1&&(i=[e.parts[0]]),{unboundedZone:n,zone:r,parts:i,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function cc(e,t){let n=e.xc,{xc:r,sheetName:i}=ac(n),a=ir(r);return sc({zone:a,parts:_c(r,a),sheetId:e.sheetId,prefixSheet:!!i,invalidSheetName:e.invalidSheetName},t)}function lc(e){let t={left:-1,top:-1,right:-1,bottom:-1};return{sheetId:``,zone:t,unboundedZone:t,parts:[],invalidXc:e,prefixSheet:!1}}function uc(e){return Mr(e.unboundedZone)}function dc(e){return jr(e.unboundedZone)}function fc(e,t,n,r={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||e.zone.left<0||e.zone.top<0)return j.InvalidReference;let i=e.sheetId!==t||e.invalidSheetName||e.prefixSheet,a=``;if(i&&(a=e.invalidSheetName?lt(e.invalidSheetName):lt(n(e.sheetId))),i&&!a)return j.InvalidReference;let o=Dc(e,0,r);return e.parts&&e.parts.length===2&&(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)&&(o+=`:`,o+=Dc(e,1,r)),`${i?a+`!`:``}${o}`}function pc(e,t,n){let r=n.sheetId===e?t:n.sheetId;return{...n,sheetId:r}}function mc(e,t,n){if(!n)return;let r=e.getRangeFromSheetXC(t,n);return r.invalidSheetName||r.invalidXc?void 0:r}function hc(e,t){let n=[];for(let r of t){let t=r.dataRange;if(!e.isRangeValid(t)){n.push(r);continue}let{sheetName:i}=ac(t),a=i?`${i}!`:``,o=ir(t);if(o.bottom!==o.top&&o.left!==o.right)if(o.right)for(let e=o.left;e<=o.right;++e){let t=e===o.left?r:{yAxisId:r.yAxisId};n.push({...t,dataRange:`${a}${cr({left:e,right:e,top:o.top,bottom:o.bottom})}`})}else for(let e=o.top;e<=o.bottom;++e){let t=e===o.top?r:{yAxisId:r.yAxisId};n.push({...t,dataRange:`${a}${cr({left:o.left,right:o.right,top:e,bottom:e})}`})}else n.push(r)}return n}function gc(e){let t=[];for(let n of e)for(let e of wr(n.zone))t.push({...e,sheetId:n.sheetId});return t}function _c(e,t){let n=e.split(`:`).map(e=>{let t=tc(e);return{colFixed:t?!1:e.startsWith(`$`),rowFixed:t?e.startsWith(`$`):e.includes(`$`,1)}}),r=t.bottom===void 0,i=t.right===void 0;return r&&(n[0].rowFixed=n[0].rowFixed||n[1].rowFixed,n[1].rowFixed=n[0].rowFixed||n[1].rowFixed),i&&(n[0].colFixed=n[0].colFixed||n[1].colFixed,n[1].colFixed=n[0].colFixed||n[1].colFixed),n}function vc(e){if(sr(e.zone))return e;let t={...e.unboundedZone},n={...e.zone},r=e.parts;if(t.right!==void 0&&t.right<t.left){let e=t.right;t.right=t.left,t.left=e,n.right=n.left,n.left=e,r=[{colFixed:r[1]?.colFixed||!1,rowFixed:r[0]?.rowFixed||!1},{colFixed:r[0]?.colFixed||!1,rowFixed:r[1]?.rowFixed||!1}]}if(t.bottom!==void 0&&t.bottom<t.top){let e=t.bottom;t.bottom=t.top,t.top=e,n.bottom=n.top,n.top=e,r=[{colFixed:r[0]?.colFixed||!1,rowFixed:r[1]?.rowFixed||!1},{colFixed:r[1]?.colFixed||!1,rowFixed:r[0]?.rowFixed||!1}]}return{unboundedZone:t,zone:n,parts:r,invalidXc:e.invalidXc,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function yc(e){return bc.get(e.type)?.(e)}let bc=new class extends h{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};bc.add(`REMOVE_COLUMNS_ROWS`,e=>({applyChange:xc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})).add(`ADD_COLUMNS_ROWS`,e=>({applyChange:Sc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})).add(`DELETE_SHEET`,e=>({applyChange:Cc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})).add(`RENAME_SHEET`,e=>({applyChange:wc(e),sheetId:e.sheetId,sheetName:{old:e.oldName,current:e.newName}})).add(`MOVE_RANGES`,e=>({applyChange:Tc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}));function xc(e){let t=e.dimension===`COL`?`left`:`top`,n=e.dimension===`COL`?`right`:`bottom`,r=e.dimension===`COL`?`columns`:`rows`,i=[...e.elements];i.sort((e,t)=>t-e);let a=dt(i);return i=>{if(i.sheetId!==e.sheetId)return{changeType:`NONE`,range:i};let o=i,s=`NONE`;for(let e of a){let a=Yt(e),c=Jt(e);if(i.zone[t]<=a&&a<=i.zone[n]){let e=Math.min(i.zone[n],c)-a+1;s=`RESIZE`,o=Ec(o,r,s,-e)}else if(i.zone[t]>=a&&i.zone[n]<=c)s=`REMOVE`,o=lc(j.InvalidReference);else if(i.zone[t]<=c&&i.zone[n]>=c){let e=c-i.zone[t]+1;s=`RESIZE`,o=Ec(o,r,s,-e),o=Ec(o,r,`MOVE`,-(i.zone[t]-a))}else a<i.zone[t]&&(s=`MOVE`,o=Ec(o,r,s,-(c-a+1)))}return{changeType:s,range:o}}}function Sc(e){let t=e.dimension===`COL`?`left`:`top`,n=e.dimension===`COL`?`right`:`bottom`,r=e.dimension===`COL`?`columns`:`rows`;return i=>{if(i.sheetId!==e.sheetId)return{changeType:`NONE`,range:i};if(e.position===`after`){if(i.zone[t]<=e.base&&e.base<i.zone[n])return{changeType:`RESIZE`,range:Ec(i,r,`RESIZE`,e.quantity)};if(e.base<i.zone[t])return{changeType:`MOVE`,range:Ec(i,r,`MOVE`,e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[n])return{changeType:`RESIZE`,range:Ec(i,r,`RESIZE`,e.quantity)};if(e.base<=i.zone[t])return{changeType:`MOVE`,range:Ec(i,r,`MOVE`,e.quantity)}}return{changeType:`NONE`,range:i}}}function Cc(e){return t=>{if(t.sheetId!==e.sheetId&&t.invalidSheetName!==e.sheetName)return{changeType:`NONE`,range:t};let n=e.sheetName;return t={...lc(j.InvalidReference),invalidSheetName:n},{changeType:`REMOVE`,range:t}}}function wc(e){return t=>{if(t.sheetId===e.sheetId)return{changeType:`CHANGE`,range:t};if(e.newName&&t.invalidSheetName===e.newName){let n=e.sheetId;return{changeType:`CHANGE`,range:{...t,sheetId:n,invalidSheetName:void 0}}}if(e.oldName&&t.invalidSheetName===e.oldName){let n=e.sheetId;return{changeType:`CHANGE`,range:{...t,sheetId:n,invalidSheetName:void 0}}}return{changeType:`NONE`,range:t}}}function Tc(e){let t=e.target[0];return n=>{if(n.sheetId!==e.sheetId||!yr(n.zone,t))return{changeType:`NONE`,range:n};let r=e.targetSheetId,i=Ec(n,`both`,`MOVE`,[e.col-t.left,e.row-t.top]),a=e.sheetId===r?i.prefixSheet:!0;return{changeType:`MOVE`,range:{...i,sheetId:r,prefixSheet:a}}}}function Ec(e,t,n,r){return{...e,unboundedZone:Er(e.unboundedZone,t,n,r),zone:Er(e.zone,t,n,r)}}function Dc(e,t,n={useBoundedReference:!1,useFixedReference:!1}){let r=e.parts[t]?.colFixed||n.useFixedReference?`$`:``,i=zn(t===0?e.zone.left:e.zone.right),a=e.parts[t]?.rowFixed||n.useFixedReference?`$`:``,o=String(t===0?e.zone.top+1:e.zone.bottom+1),s=``;return s=Mr(e.unboundedZone)&&!n.useBoundedReference?t===0&&e.unboundedZone.hasHeader?r+i+a+o:r+i:jr(e.unboundedZone)&&!n.useBoundedReference?t===0&&e.unboundedZone.hasHeader?r+i+a+o:a+o:r+i+a+o,s}function Oc(e,t){e=e.toLocaleLowerCase(),t=t.toLocaleLowerCase();let n=0,r=0,i=t.length,a=0;for(let o=0;o<i;o++)t[o]===e[a]?(a++,r+=100+r-o/200):r=0,n+=r;return a===e.length?n:0}function kc(e,t,n){let r=[];return t.forEach(t=>{let i=Oc(e,n(t));i>0&&r.push({score:i,elem:t})}),r.sort((e,t)=>t.score-e.score),r.map(e=>e.elem)}function Ac(e){let t=[];for(let n=0;n<e;n++)t.push({cells:{}});return t}function jc(e,t,n){return n.map(n=>n>=e?n+t:n)}function Mc(e,t){return e=[...e].sort((e,t)=>t-e),t.map(t=>{for(let n of e)if(t>n)t--;else if(t===n)return;return t}).filter(C)}function Nc(e,t=`Sheet`){let n=1,r=`${t}${n}`;for(;e.includes(r);)r=`${t}${n}`,n++;return r}function Pc(e,t){let n=1,r=O(`Copy of %s`,e),i=r.toString();for(;t.includes(i);)i=`${r} (${n})`,n++;return i}function Fc(e,t){return e===void 0||t===void 0?!1:st(e.trim().toUpperCase())===st(t.trim().toUpperCase())}function Ic(e,t=1){return t*(e+4)-4}function Lc(e,t,n,r){if(!t||!t.isFormula&&!t.content)return 23;let i=``;try{if(!t.isFormula){let e={format:t.format,locale:n};i=B(Ns(t.content,n),e)}}catch{i=j.GenericError}return Rc(e,i,t.style,r)}function Rc(e,t,n,r){let i=Xc(e,t,n,n?.wrapping===`wrap`?r-8:void 0).length;return Ic(Jc(n),i)+6}function zc(e,t=!1,n=!1){return`${n?`italic`:``} ${t?`bold`:``} ${e}px ${Ve}`}let Bc={};function Vc(e,t,n,r=`pt`){let i=qc(n,r);e.save(),e.font=i;let a=Hc(e,t);return e.restore(),a}function Hc(e,t){let n=e.font;return Bc[n]||(Bc[n]={}),Bc[n][t]===void 0&&(Bc[n][t]=e.measureText(t).width),Bc[n][t]}let Uc={};function Wc(e,t,n,r=`pt`){let i=qc(n,r);e.save(),e.font=i;let a=Gc(e,t);return e.restore(),a}function Gc(e,t){let n=e.font;if(Uc[n]||(Uc[n]={}),Uc[n][t]===void 0){let r=e.measureText(t),i=r.width,a=r.fontBoundingBoxAscent+r.fontBoundingBoxDescent;Uc[n][t]={width:i,height:a}}return Uc[n][t]}function Kc(e){return Math.round(e*96/72)}function qc(e,t=`pt`){return`${e.italic?`italic `:``}${e.bold?`bold`:`400`} ${(t===`pt`?Jc(e):e.fontSize)??Be}px ${Ve}`}function Jc(e){return Kc(e?.fontSize||Be)}function Yc(e,t,n,r){if(Vc(e,t,r)<=n)return[t];let i=[],a=``;for(let o of t)Vc(e,a+o,r)>n?(i.push(a),a=o):a+=o;return i.push(a),i}function Xc(e,t,n,r){n||={},gt(t)&&(t=yt(t).label);let i=[],a=t.includes(`
|
|
4
|
+
`)}function Kt(e,t,n){return t>n?Kt(e,n,t):e>=t&&e<=n}function qt(e,t){let n=at(e),r=t.matchCase?``:`i`;return t.exactMatch&&(n=`^${n}$`),RegExp(n,r)}function Jt(e){let t=e.length;if(t<1e5)return Math.max(...e);let n=-1/0;for(;t--;)n=e[t]>n?e[t]:n;return n}function Yt(e){let t=e.length;if(t<1e5)return Math.min(...e);let n=1/0;for(;t--;)n=e[t]<n?e[t]:n;return n}var Xt=class{text;currentIndex=0;current;constructor(e){this.text=e,this.current=e[0]}shift(){let 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 Zt(e,t=e=>e){let n=new Set;return e.filter(e=>{let r=t(e);return n.has(r)?!1:(n.add(r),!0)})}function Qt(e){let t={};for(let n in e)for(let r in e[n])t[r]||(t[r]={}),t[r][n]=e[n][r];return t}function $t(e,t,n={}){let r=n.compute??((e,t)=>`${e} (${t})`),i=n.computeFirstOne??!1,a=n.start??1,o=i?r(e,a):e;for(;t.includes(o);)o=r(e,a++);return o}function en(e){return e.startsWith(`=`)||e.startsWith(`+`)}let tn=/rgba?\(|\s+|\)/gi,nn=/^#([A-F\d]{2}){3,4}$/,rn=[`#eb6d00`,`#0074d9`,`#ad8e00`,`#169ed4`,`#b10dc9`,`#00a82d`,`#00a3a3`,`#f012be`,`#3d9970`,`#111111`,`#62A300`,`#ff4136`,`#949494`,`#85144b`,`#001f3f`];function an(e){return sn(e.toString(16).padStart(6,`0`))}function on(e){return typeof e==`number`?e:Number.parseInt(sn(e).slice(1),16)}function sn(e){let t=e;if(e.startsWith(`rgb`)?t=pn(e):(t=e.replace(`#`,``).toUpperCase(),(t.length===3||t.length===4)&&(t=t.split(``).reduce((e,t)=>e+t+t,``)),t=`#${t}`),!nn.test(t))throw Error(`invalid color input: ${e}`);return t}function cn(e){try{return sn(e),!0}catch{return!1}}function ln(e){try{return vn(e),!0}catch{return!1}}let un=e=>e>=0&&e<=255;function dn(e,t,n,r=1){if(!un(e)||!un(t)||!un(n)||r<0||r>1)throw Error(`Invalid RGBA values ${[e,t,n,r]}`);return{a:r,b:n,g:t,r:e}}function fn(e){let{r:t,g:n,b:r}=hn(e);t/=255,n/=255,r/=255;let i=e=>e<=.03928?e/12.92:((e+.055)/1.055)**2.4,a=i(t),o=i(n),s=i(r);return .2126*a+.7152*o+.0722*s}function pn(e){let t=e.replace(tn,``).split(`,`),n=255;if(t.length!==3&&t.length!==4)throw Error(`invalid color`);if(t.length===4){let e=parseFloat(t.pop()||`1`);if(isNaN(e))throw Error(`invalid alpha value`);n=Math.round(e*255)}let r=t.map(e=>parseInt(e,10));return n!==255&&r.push(n),`#`+Ot(r.map(e=>e.toString(16).padStart(2,`0`))).toUpperCase()}function mn(e){let t=e.r.toString(16),n=e.g.toString(16),r=e.b.toString(16),i=Math.round(e.a*255).toString(16);return t.length===1&&(t=`0`+t),n.length===1&&(n=`0`+n),r.length===1&&(r=`0`+r),i.length===1&&(i=`0`+i),i===`ff`&&(i=``),(`#`+t+n+r+i).toUpperCase()}function hn(e){e=sn(e);let t,n,r,i;if(e.length===7)t=parseInt(e[1]+e[2],16),n=parseInt(e[3]+e[4],16),r=parseInt(e[5]+e[6],16),i=255;else if(e.length===9)t=parseInt(e[1]+e[2],16),n=parseInt(e[3]+e[4],16),r=parseInt(e[5]+e[6],16),i=parseInt(e[7]+e[8],16);else throw Error(`Invalid color`);return i=+(i/255).toFixed(3),{a:i,r:t,g:n,b:r}}function gn(e){e={...e},e.s/=100,e.l/=100;let t=(1-Math.abs(2*e.l-1))*e.s,n=t*(1-Math.abs(e.h/60%2-1)),r=e.l-t/2,i=0,a=0,o=0;return 0<=e.h&&e.h<60?(i=t,a=n,o=0):60<=e.h&&e.h<120?(i=n,a=t,o=0):120<=e.h&&e.h<180?(i=0,a=t,o=n):180<=e.h&&e.h<240?(i=0,a=n,o=t):240<=e.h&&e.h<300?(i=n,a=0,o=t):300<=e.h&&e.h<360&&(i=t,a=0,o=n),i=Math.round((i+r)*255),a=Math.round((a+r)*255),o=Math.round((o+r)*255),{a:e.a,r:i,g:a,b:o}}function _n(e){let t=e.r/255,n=e.g/255,r=e.b/255,i=Math.min(t,n,r),a=Math.max(t,n,r),o=a-i,s=0,c=0,l=0;return s=o===0?0:a===t?(n-r)/o%6:a===n?(r-t)/o+2:(t-n)/o+4,s=Math.round(s*60),s<0&&(s+=360),l=(a+i)/2,c=o===0?0:o/(1-Math.abs(2*l-1)),c=+(c*100).toFixed(1),l=+(l*100).toFixed(1),{a:e.a,h:s,s:c,l}}function vn(e){return mn(gn(e))}function yn(e){return _n(hn(e))}function bn(e,t,n=0){if(!(cn(e)&&cn(t)))return!1;let r=hn(e),i=hn(t);return r.a===i.a?Math.sqrt(((r.r-i.r)/255)**2+((r.g-i.g)/255)**2+((r.b-i.b)/255)**2)<=n:!1}function xn(e,t){return t===1?sn(e).slice(0,7):mn({...hn(e),a:t})}function Sn(e,t){let n=yn(e);return t===1?`#fff`:(n.l=t*(100-n.l)+n.l,vn(n))}function Cn(e,t){let n=yn(e);return t===1?`#000`:(n.l-=t*n.l,vn(n))}let wn=[`#4EA7F2`,`#EA6175`,`#43C5B1`,`#F4A261`,`#8481DD`,`#FFD86D`],Tn=[`#4EA7F2`,`#3188E6`,`#43C5B1`,`#00A78D`,`#EA6175`,`#CE4257`,`#F4A261`,`#F48935`,`#8481DD`,`#5752D1`,`#FFD86D`,`#FFBC2C`],En=[`#4EA7F2`,`#3188E6`,`#056BD9`,`#A76DBC`,`#7F4295`,`#6D2387`,`#EA6175`,`#CE4257`,`#982738`,`#43C5B1`,`#00A78D`,`#0E8270`,`#F4A261`,`#F48935`,`#BE5D10`,`#8481DD`,`#5752D1`,`#3A3580`,`#A4A8B6`,`#7E8290`,`#545B70`,`#FFD86D`,`#FFBC2C`,`#C08A16`],Dn=`#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`.split(`.`),On=[`#4EA7F2`,`#43C5B1`,`#EA6175`,`#F4A261`,`#8481DD`,`#FFD86D`,`#3188E6`,`#00A78D`,`#CE4257`,`#F48935`,`#5752D1`,`#FFBC2C`],kn=[`#4EA7F2`,`#A76DBC`,`#EA6175`,`#43C5B1`,`#F4A261`,`#8481DD`,`#A4A8B6`,`#FFD86D`,`#3188E6`,`#7F4295`,`#CE4257`,`#00A78D`,`#F48935`,`#5752D1`,`#7E8290`,`#FFBC2C`,`#056BD9`,`#6D2387`,`#982738`,`#0E8270`,`#BE5D10`,`#3A3580`,`#545B70`,`#C08A16`],An=`#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`.split(`.`);function jn(e,t){return t[e%t.length]}function Mn(e){return e<=6?wn:e<=12?Tn:e<=24?En:Dn}function Nn(e){return e<=6?wn:e<=12?On:e<=24?kn:An}var Pn=class{preferredColors;currentColorIndex=0;palette;constructor(e,t=[]){this.preferredColors=t,this.palette=Mn(e).filter(e=>!t.includes(e))}next(){return this.preferredColors?.[this.currentColorIndex]?this.preferredColors[this.currentColorIndex++]:jn(this.currentColorIndex++,this.palette)}},Fn=class extends Pn{constructor(e,t=[]){super(e,t),this.palette=Nn(e).filter(e=>!t.includes(e))}};function In(e){if(e.length<2)throw Error(`Color scale must have at least 2 points`);let t=[...e.sort((e,t)=>e.value-t.value)],n=[];for(let e=1;e<t.length;e++){let r=on(t[e-1].color),i=on(t[e].color);n.push({min:t[e-1].value,max:t[e].value,minColor:r,maxColor:i,colorDiff:Ln(t[e-1].value,t[e].value,r,i)})}return e=>{if(e<n[0].min)return an(n[0].minColor);for(let t of n)if(e>=t.min&&e<=t.max)return an(Rn(e,t.min,t.minColor,t.colorDiff));return an(n[n.length-1].maxColor)}}function Ln(e,t,n,r){let i=t-e,a=(n>>16)%256-(r>>16)%256,o=(n>>8)%256-(r>>8)%256,s=n%256-r%256;return[a/i,o/i,s/i]}function Rn(e,t,n,r){let[i,a,o]=r,s=Math.round((n>>16)%256-i*(e-t)),c=Math.round((n>>8)%256-a*(e-t)),l=Math.round(n%256-o*(e-t));return s<<16|c<<8|l}function zn(e){if(e<0)throw Error(`number must be positive. Got ${e}`);return e<26?String.fromCharCode(65+e):zn(Math.floor(e/26)-1)+zn(e%26)}function Bn(e){let t=0,n=e.length;for(let r=0;r<n;r++){let n=Vn(e[r]);t=t*26+n}return t-1}function Vn(e){let t=e.charCodeAt(0);return t>=65&&t<=90?t-64:t-96}function Hn(e){return e>=`A`&&e<=`Z`||e>=`a`&&e<=`z`}function Un(e){return e>=`0`&&e<=`9`}let Wn=Bn(`ZZZ`);function Gn(e){for(;e.current===` `;)e.advanceBy(1)}function Kn(e){if(e.current===`$`&&e.advanceBy(1),!e.current||!Hn(e.current))return-1;let t=0;for(;e.current&&Hn(e.current);)t=t*26+Vn(e.shift());return t}function qn(e){if(e.current===`$`&&e.advanceBy(1),!e.current||!Un(e.current))return-1;let t=0;for(;e.current&&Un(e.current);)t=t*10+Number(e.shift());return t}function Jn(e){let t=new Xt(e);Gn(t);let n=Kn(t);if(n===-1||!t.current)throw Error(`Invalid cell description: ${e}`);let r=qn(t);Gn(t);let i=n-1,a=r-1;if(!t.isOver()||i>Wn||a>9999998)throw Error(`Invalid cell description: ${e}`);return{col:i,row:a}}function T(e,t,n={colFixed:!1,rowFixed:!1}){return(n.colFixed?`$`:``)+zn(e)+(n.rowFixed?`$`:``)+String(t+1)}function Yn(e,t=[]){if(e.length<=1&&t.length===0)return e;let n=[0],r=new Map([[0,[]]]);return Xn(n,r,e,!1),Xn(n,r,t,!0),er(n,r)}function Xn(e,t,n,r=!1){for(let i of n){let n=i.left,a=i.right===void 0?void 0:i.right+1,o=Zn(e,t,n,!0,0),s=Zn(e,t,a,!1,o);for(let n=o;n<=s;n++)Qn(t.get(e[n]),i,r);$n(e,t,o,s)}}function Zn(e,t,n,r,i){if(n===void 0)return e.length-1;let a=tr(e,n,i);return n===e[a]?r?a:a-1:(e.splice(a+1,0,n),t.set(n,[...t.get(e[a])]),r?a+1:a)}function Qn(e,t,n=!1){let r=t.top,i=t.bottom===void 0?void 0:t.bottom+1,a=[],o=tr(e,r,0,!1);if((o%2!=0&&!n||o%2==0&&n)&&a.push(r),i===void 0){e.splice(o+1),e.push(...a);return}let s=nr(e,i,0,!1);(s%2==0&&!n||s%2!=0&&n)&&a.push(i),e.splice(o+1,s-o-1,...a)}function $n(e,t,n,r){let i=n-1==-1?0:n-1,a=r===e.length-1?r:r+1;for(let n=a;n>i;n--)Mt(t.get(e[n]),t.get(e[n-1]))&&(t.delete(e[n]),e.splice(n,1))}function er(e,t){let n=[],r=[];for(let i=0;i<e.length;i++){let a=e[i],o=t.get(a);if(!o||o.length===0){n.push(...r),r=[];continue}let s=e[i+1];s!==void 0&&s--;let c=[];for(let e=0;e<o.length;e+=2){let t=o[e],n=o[e+1];n!==void 0&&n--;let i={top:t,left:a,bottom:n,right:s,hasHeader:n===void 0&&t!==0||s===void 0&&a!==0},l=!1;for(let e=r.length-1;e>=0;e--){let t=r[e];if(t.top===i.top&&t.bottom===i.bottom){t.right=i.right,r.splice(e,1),c.push(t),l=!0;break}}l||c.push(i)}n.push(...r),r=c}return n.push(...r),n}function tr(e,t,n=0,r=!0){let i=e.length-1,a=-1;for(;n<=i;){let o=Math.floor((n+i)/2);if(e[o]===t&&r)return o;e[o]<t?(a=o,n=o+1):i=o-1}return a}function nr(e,t,n=0,r=!0){let i=e.length-1,a=e.length;for(;n<=i;){let o=Math.floor((n+i)/2);if(e[o]===t&&r)return o;e[o]>t?(a=o,i=o-1):n=o+1}return a}function rr(e){let t=new Xt(e);Gn(t);let n=e.indexOf(`!`);n!==-1&&t.advanceBy(n+1);let r=Kn(t),i=qn(t),a,o,s,c,l=!1,u=!1,d=!1;if(i===-1?(s=c=r-1,a=o=0,l=!0):r===-1?(a=o=i-1,s=c=0,u=!0):(s=c=r-1,a=o=i-1,d=!0),Gn(t),t.current===`:`){t.advanceBy(1),Gn(t);let e=Kn(t),n=qn(t);n===-1?(c=e-1,l=!0):e===-1?(o=n-1,u=!0):(c=e-1,o=n-1,a=l?o:a,s=u?c:s,d=!0)}let f={top:a,left:s,bottom:l?void 0:o,right:u?void 0:c};return d&&=u||l,d&&(f.hasHeader=d),f}function ir(e){let t=Tr(rr(e)),n=t.bottom,r=t.right;if(n!==void 0&&n>9999998||r!==void 0&&r>Wn)throw Error(`Range string out of bounds: ${e}`);if(n===void 0&&r===void 0)throw Error(`Wrong zone xc. The zone cannot be at the same time a full column and a full row`);return t}function ar(e){let t=ir(e);if(t.bottom===void 0||t.right===void 0)throw Error(`This does not support unbounded ranges`);return t}function or(e){let{bottom:t,top:n,left:r,right:i}=e;return t!==void 0&&isNaN(t)||isNaN(n)||isNaN(r)||i!==void 0&&isNaN(i)?!1:sr(e)&&e.top>=0&&e.left>=0}function sr(e){return(e.bottom===void 0||e.bottom>=e.top&&e.bottom>=0)&&(e.right===void 0||e.right>=e.left&&e.right>=0)}function cr(e){let{top:t,bottom:n,left:r,right:i}=e,a=`hasHeader`in e?e.hasHeader:!1,o=t===n&&r===i;if(n===void 0&&i!==void 0)return t===0&&!a?`${zn(r)}:${zn(i)}`:`${T(r,t)}:${zn(i)}`;if(i===void 0&&n!==void 0)return r===0&&!a?`${t+1}:${n+1}`:`${T(r,t)}:${n+1}`;if(n!==void 0&&i!==void 0)return o?T(r,t):`${T(r,t)}:${T(i,n)}`;throw Error(`Bad zone format`)}function lr(e,t,n,r,i){let a=t===`left`?`columns`:`rows`,o=r===`before`?n-1:n,s=e[t===`left`?`right`:`bottom`];return e[t]<=o&&s&&s>o?Er(e,a,`RESIZE`,i):o<e[t]?Er(e,a,`MOVE`,i):{...e}}function ur(e,t,n,r,i){let a=t===`left`?`columns`:`rows`,o=r===`before`?n-1:n,s=t===`left`?`right`:`bottom`;return e[t]<=o&&e[s]>o?Er(e,a,`RESIZE`,i):o<e[t]?Er(e,a,`MOVE`,i):{...e}}function dr(e,t,n){let r=t===`left`?`right`:`bottom`,i=e[t],a=e[r];for(let o of n.sort((e,t)=>t-e))e[t]>o&&(i--,a--),e[t]<o&&e[r]>=o&&a--;return{...e,[t]:i,[r]:a}}function fr(e,t,n){let r=t===`left`?`right`:`bottom`,i=e[t],a=e[r],o=e[r];for(let r of n.sort((e,t)=>t-e))e[t]>r&&(i--,a!==void 0&&a--),o!==void 0&&a!==void 0&&e[t]<=r&&o>=r&&a--;if(!(a!==void 0&&i>a))return{...e,[t]:i,[r]:a}}function pr(...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 mr(...e){return{top:Math.min(...e.map(e=>e.top)),left:Math.min(...e.map(e=>e.left)),bottom:e.some(e=>e.bottom===void 0)?void 0:Math.max(...e.map(e=>e.bottom)),right:e.some(e=>e.right===void 0)?void 0:Math.max(...e.map(e=>e.right))}}function hr(e,t){if(_r(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 gr(e,t){return e.left===t.left&&e.right===t.right&&e.top===t.top&&e.bottom===t.bottom}function _r(e,t){return!(e.bottom<t.top||t.bottom<e.top||e.right<t.left||t.right<e.left)}function vr(e,t,n){let{left:r,right:i,top:a,bottom:o}=n;return e>=r&&e<=i&&t>=a&&t<=o}function yr(e,t){return gr(pr(t,e),t)}function br(e){return{numberOfRows:e.bottom-e.top+1,numberOfCols:e.right-e.left+1}}function xr(e){let{numberOfCols:t,numberOfRows:n}=br(e);return t===1||n===1}function Sr(e){let{top:t,left:n,bottom:r,right:i}=e;if(Nr(e)===1)return[];let a={top:t+1,bottom:r,left:n,right:n};if(i===n)return[a];let o={top:t,bottom:r,left:n+1,right:i};return t===r?[o]:[a,o]}function Cr(e){let t={};for(let n of e)t[n.sheetId]??=[],t[n.sheetId].push(E(n));for(let e in t)t[e]=Yn(t[e]);return t}function wr(e){let t=[],{left:n,right:r,top:i,bottom:a}=Tr(e);for(let e of S(n,r+1))for(let n of S(i,a+1))t.push({col:e,row:n});return t}function Tr(e){return e.right!==void 0&&e.left>e.right&&(e={...e,left:e.right,right:e.left}),e.bottom!==void 0&&e.top>e.bottom&&(e={...e,top:e.bottom,bottom:e.top}),e}function Er(e,t,n,r){let i=t===`both`?r[0]:t===`columns`?r:0,a=t===`both`?r[1]:t===`rows`?r:0,o=`hasHeader`in e?e.hasHeader:!1,s;s=Mr(e)&&!o?t!==`rows`:jr(e)&&!o?t!==`columns`:!0;let c={...e};return s&&n===`MOVE`&&(c.left+=i,c.top+=a),c.right!==void 0&&(c.right+=i),c.bottom!==void 0&&(c.bottom+=a),c}function Dr(e){return e.reverse().filter((e,t,n)=>t===n.findIndex(t=>t.top===e.top&&t.bottom===e.bottom&&t.left===e.left&&t.right===e.right)).reverse()}function Or(e){return e.reduce((e,t)=>{let n=e.length;for(let r=0;r<n;r++)if(_r(e[r],t))return e[r]=pr(e[r],t),e;return e[n]=t,e},[])}function kr(e,t){let n,r,{left:i,right:a,top:o,bottom:s}=e,{left:c,right:l,top:u,bottom:d}=t;return n=c===i?l===a?c:l:c,r=u===o?d===s?u:d:u,{col:n,row:r}}function E(e){return{left:e.col,right:e.col,top:e.row,bottom:e.row}}function Ar(e){return{...e,right:e.left,bottom:e.top}}function jr(e){return e.right===void 0}function Mr(e){return e.bottom===void 0}function Nr(e){return(e.bottom-e.top+1)*(e.right-e.left+1)}function Pr(e,t){let{left:n,top:r,bottom:i,right:a}=e;if(a!==void 0&&i!==void 0)return e;if(i===void 0&&a!==void 0)return{right:a,top:r,left:n,bottom:t.numberOfRows-1};if(a===void 0&&i!==void 0)return{bottom:i,left:n,top:r,right:t.numberOfCols-1};throw Error(`Bad zone format`)}function Fr(e){return e.length<2?!0:Yn(e).length===1}function Ir(e){let t=new Set;for(let n of Yn(e))for(let e of S(n.left,n.right+1))t.add(e);return t}function Lr(e){let t=new Set;for(let n of Yn(e))for(let e of S(n.top,n.bottom+1))t.add(e);return t}function Rr(e,t){return e.right+1===t.left||e.left===t.right+1?e.top<=t.bottom&&e.top>=t.top||t.top<=e.bottom&&t.top>=e.top:e.bottom+1===t.top||e.top===t.bottom+1?e.left<=t.right&&e.left>=t.left||t.left<=e.right&&t.left>=e.left:!1}function zr(e){let t=[...e],n=!0;for(;n;){n=!1;for(let e=0;e<t.length;e++){let r=t[e],i=t.findIndex((t,n)=>e!==n&&(Rr(t,r)||_r(t,r)));if(i!==-1){t[e]=pr(t[i],r),t.splice(i,1),n=!0;break}}}return t}let Br=new WeakMap,Vr=new WeakMap;function Hr(e,t){Br.has(t)||(Br.set(t,new Map),Vr.set(t,0));let n=Br.get(t),r=Gr(e);if(n.has(r)){let i=n.get(r);return t[i]=e,i}let i=Vr.get(t)+1;return n.set(r,i),Vr.set(t,i),t[i]=e,i}function Ur(e){let t={};for(let n in e){let r=Yn(e[n].map(E));for(let e of r)t[cr(e)]=Number(n)}return t}function*Wr(e,t){for(let n in t){let r=ar(n),i=t[n];for(let t=r.top;t<=r.bottom;t++)for(let n=r.left;n<=r.right;n++)yield[{sheetId:e,col:n,row:t},i]}}function Gr(e){if(e===null)return`null`;if(e===void 0)return`undefined`;if(typeof e!=`object`)return String(e);if(Array.isArray(e)){let t=e.length,n=`[`;for(let r=0;r<t;r++)r>0&&(n+=`,`),n+=Gr(e[r]);return n+`]`}let t=Object.keys(e).sort(),n=`{`;for(let r of t)e[r]!==void 0&&(n+=`"${r}":${Gr(e[r])},`);return n+=`}`,n}var D=class e{jsDate;constructor(e,t,n,r=0,i=0,a=0){this.jsDate=new Date(Date.UTC(e,t,n,r,i,a,0))}static fromTimestamp(t){let n=new Date(t);return new e(n.getUTCFullYear(),n.getUTCMonth(),n.getUTCDate(),n.getUTCHours(),n.getUTCMinutes(),n.getUTCSeconds())}static now(){let t=new Date;return new e(t.getFullYear(),t.getMonth(),t.getDate(),t.getHours(),t.getMinutes(),t.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(){let e=new Date(this.jsDate.getTime()),t=e.getUTCDay()||7;e.setUTCDate(e.getUTCDate()+4-t);let n=new Date(Date.UTC(e.getUTCFullYear(),0,1));return Math.ceil(((e.getTime()-n.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)}};let Kr=new D(1899,11,30),qr=1440*60*1e3,Jr=2e3,Yr=D.now().getFullYear(),Xr=D.now().getMonth(),Zr=D.fromTimestamp(0).getTime()-Kr.getTime(),Qr=/^\d{1,2}(\/|-|\s)\d{1,2}((\/|-|\s)\d{1,4})?$/,$r=/^\d{3,4}(\/|-|\s)\d{1,2}(\/|-|\s)\d{1,2}$/,ei=Rt.join(``),ti=RegExp(`\/|-|${Rt.join(`|`)}`),ni=RegExp(`^(\\d{1,4})[\/${ei}\-](\\d{1,4})([\/${ei}\-](\\d{1,4}))?$`),ri=/((\d+(:\d+)?(:\d+)?\s*(AM|PM))|(\d+:\d+(:\d+)?))$/;function ii(e,t){switch(typeof e){case`number`:return e;case`string`:return ai(e,t)?si(e,t)?.value:!e||isNaN(Number(e))?void 0:Number(e);default:return}}function ai(e,t){return si(e,t)!==null}let oi=new Map;function si(e,t){return oi.has(t)||oi.set(t,new Map),oi.get(t).has(e)||oi.get(t).set(e,ci(e,t)),oi.get(t).get(e)}function ci(e,t){e=e.trim();let n=null,r=e.match(ri);if(r){if(n=gi(r[0]),n===null)return null;e=e.replace(r[0],``).trim()}let i=null,a=li(e,t);if(a){let t=a.dateString.match(ti)[0];if(i=di(a,t),i===null)return null;e=e.replace(a.dateString,``).trim()}return e!==``||!(i||n)?null:i&&i.jsDate&&n&&n.jsDate?{value:i.value+n.value,format:i.format+` `+(n.format===`hhhh:mm:ss`?`hh:mm:ss`:n.format),jsDate:new D(i.jsDate.getFullYear()+n.jsDate.getFullYear()-1899,i.jsDate.getMonth()+n.jsDate.getMonth()-11,i.jsDate.getDate()+n.jsDate.getDate()-30,i.jsDate.getHours()+n.jsDate.getHours(),i.jsDate.getMinutes()+n.jsDate.getMinutes(),i.jsDate.getSeconds()+n.jsDate.getSeconds())}:i||n}function li(e,t){let n=e.match(ni);if(!n)return null;let[,r,i,,a]=n;if(r.length>2&&a&&a.length>2)return null;if(r.length>2)return{year:r,month:i,day:a,dateString:e,type:`ymd`};let o=ui(t);return a?a.length>2?o===`mdy`?{month:r,day:i,year:a,dateString:e,type:`mdy`}:{day:r,month:i,year:a,dateString:e,type:`dmy`}:o===`mdy`?{month:r,day:i,year:a,dateString:e,type:`mdy`}:o===`ymd`?{year:r,month:i,day:a,dateString:e,type:`ymd`}:o===`dmy`?{day:r,month:i,year:a,dateString:e,type:`dmy`}:null:i.length>2?{month:r,year:i,day:void 0,dateString:e,type:o}:o===`dmy`?{day:r,month:i,year:a,dateString:e,type:`dmy`}:{month:r,day:i,year:a,dateString:e,type:`mdy`}}function ui(e){switch(e.dateFormat[0]){case`d`:return`dmy`;case`m`:return`mdy`;case`y`:return`ymd`}throw Error(`Invalid date format in locale`)}function di(e,t){let{year:n,month:r,day:i}=e,a=mi(r),o=hi(i),s=pi(n);if(s===null||a===null||o===null)return null;let c=r?.length===2&&a+1<10||i?.length===2&&o<10,l=n?.length!==2,u=new D(s,a,o);if(u.getMonth()!==a||u.getDate()!==o)return null;let d=u.getTime()-Kr.getTime(),f=fi(e,t,c,l);return{value:Math.round(d/qr),format:f,jsDate:u}}function fi(e,t,n,r){let i=e.year?r?`yyyy`:`yy`:void 0,a=e.month?n?`mm`:`m`:void 0,o=e.day?n?`dd`:`d`:void 0;switch(e.type){case`mdy`:return[a,o,i].filter(C).join(t);case`ymd`:return[i,a,o].filter(C).join(t);case`dmy`:return[o,a,i].filter(C).join(t)}}function pi(e){if(!e)return Yr;let t=Number(e);switch(e.length){case 1:return Jr+t;case 2:return Jr+(Jr+t>Yr+10?-100:0)+t;case 3:case 4:return t}return null}function mi(e){if(!e)return Xr;let t=Number(e);return t>=1&&t<=12?t-1:null}function hi(e){if(!e)return 1;let t=Number(e);return t>=0&&t<=31?t:null}function gi(e){if(e=e.trim(),ri.test(e)){let t=/AM/i.test(e),n=/PM/i.test(e),r=(t||n?e.substring(0,e.length-2).trim():e).split(/:/),i=r.length>=2,a=r.length===3,o=Number(r[0]),s=i?Number(r[1]):0,c=a?Number(r[2]):0,l=a?`hh:mm:ss`:`hh:mm`;if(t||n)l+=` a`;else if(!i)return null;o>=12&&t?o-=12:o<12&&n&&(o+=12),s+=Math.floor(c/60),c%=60,o+=Math.floor(s/60),s%=60,o>=24&&(l=`hhhh:mm:ss`);let u=new D(1899,11,30,o,s,c);return{value:o/24+s/1440+c/86400,format:l,jsDate:u}}return null}function _i(e){let t=Math.trunc(e),n=D.fromTimestamp(t*qr-Zr),r=e-t;r=r<0?1+r:r;let i=Math.round(r*24),a=Math.round((r-i/24)*24*60),o=Math.round((r-i/24-a/24/60)*24*60*60);return n.setHours(i),n.setMinutes(a),n.setSeconds(o),n}function vi(e){return Math.round(yi(e))}function yi(e){return(e.getTime()-Kr.getTime())/qr}function bi(e){return new D(e.getFullYear(),e.getMonth()+1,0).getDate()}function xi(e){return bi(e)===e.getDate()}function Si(e,t,n){let r=e.getFullYear(),i=e.getMonth(),a=e.getDate(),o=new D(r,i+t,1);return n&&a===bi(e)||a>bi(o)?o.setDate(bi(o)):o.setDate(a),o}function Ci(e){let t=Math.trunc(e);return t%4==0&&t%100!=0||t%400==0}function wi(e,t,n){if(e===t)return 0;if(e>t){let n=t;t=e,e=n}let r=_i(e),i=_i(t),a=r.getDate(),o=i.getDate(),s=r.getMonth(),c=i.getMonth(),l=r.getFullYear(),u=i.getFullYear(),d=0,f=0;switch(n){case 0:a===31&&(a=30),a===30&&o===31&&(o=30),s===1&&a===(Ci(l)?29:28)&&(a=30,c===1&&o===(Ci(u)?29:28)&&(o=30)),d=l+(s*30+a)/360,f=u+(c*30+o)/360;break;case 1:let n=365,r=l===u,i=l+1===u;if(!r&&!i||!r&&s<c||!r&&s===c&&a<o){let e=0,t=0;for(let n=l;n<=u;n++)e++,t+=Ci(n)?366:365;n=t/e}else r?Ci(l)&&(n=366):(Ci(l)&&s<2&&(n=366),Ci(u)&&(c>1||c===1&&o===29)&&(n=366));d=e/n,f=t/n;break;case 2:d=e/360,f=t/360;break;case 3:d=e/365,f=t/365;break;case 4:a===31&&(a=30),o===31&&(o=30),d=l+(s*30+a)/360,f=u+(c*30+o)/360;break}return f-d}function Ti(e,t){let n=(t.getFullYear()-e.getFullYear())*12+t.getMonth()-e.getMonth();return e.getDate()>t.getDate()?n-1:n}function Ei(e,t){let n=e.getTime(),r=t.getTime();return Math.floor((r-n)/qr)}function Di(e,t){let n=t.getFullYear()-e.getFullYear(),r=e.getMonth(),i=t.getMonth(),a=e.getDate(),o=t.getDate();return i>r||i===r&&o>=a?n:n-1}function Oi(e,t){return wi(e,t,1)<1}function ki(e,t){return Math.trunc(e)===Math.trunc(t)}function Ai(e,t,n){return t>n?Ai(e,n,t):(e=Math.trunc(e),t=Math.trunc(t),n=Math.trunc(n),e>=t&&e<=n)}function ji(e,t){return Math.trunc(e)<Math.trunc(t)}function Mi(e,t){return Math.trunc(e)<=Math.trunc(t)}function Ni(e,t){return Math.trunc(e)>Math.trunc(t)}function Pi(e,t){return Math.trunc(e)>=Math.trunc(t)}let Fi=Vt(function(e){return e=at(e),RegExp(`(?:^-?\\d+(?:${e}?\\d*(?:e(\\+|-)?\\d+)?)?|^-?${e}\\d+)(?!\\w|!)`)}),Ii=Vt(function(e){let t=at(e.decimalSeparator),n=`(?:\\d+(?:${at(e.thousandsSeparator||``)}\\d{3,})*(?:${t}\\d*)?)`,r=`(?:${t}\\d+)`,i=`(?:\\s*`+n+`|`+r+`)(?:e(?:\\+|-)?\\d+)?(?:\\s*%)?`,a=`(?:\\s*-)?`,o=`(?:\\s*[\\$€])?`,s=`^(?:(?:`+[a+o+i,a+i+o,o+a+i].join(`)|(?:`)+`))$`;return new RegExp(s,`i`)});function Li(e,t){return e?Ii(t).test(e.trim()):!1}let Ri=Vt(function(e){return RegExp(`[\$€${at(e.thousandsSeparator||``)}]`,`g`)});function zi(e,t){e=e.replace(Ri(t),``),t.decimalSeparator!==`.`&&(e=e.replace(t.decimalSeparator,`.`));let n=Number(e);return isNaN(n)&&e.includes(`%`)&&(n=Number(e.split(`%`)[0]),!isNaN(n))?n/100:n}function Bi(e,t,n){let r=[...e].sort((e,t)=>e-t),i=(r.length+(n?-1:1))*t;if(n||i--,Number.isInteger(i))return r[i];let a=Math.ceil(i),o=Math.floor(i);return r[a]*(i-o)+r[o]*(a-i)}let Vi=e=>e,Hi=()=>!1,Ui=Vi,Wi=Hi;function Gi(e,...t){if(t.length===1&&typeof t[0]==`object`&&!(t[0]instanceof String)){let n=t[0];e=e.replace(/\%\(([^\)]+)\)s/g,(e,t)=>n[t])}else t.length>0&&(e=e.replace(/\%s/g,()=>t.shift()));return e}function Ki(e,t=()=>!0){Ui=e,Wi=t}function qi(){Ui===Vi&&Wi===Hi&&(Wi=()=>!0)}let O=function(e,...t){return Wi()?Gi(Ui(e),...t):new Ji(e,t)};var Ji=class extends String{values;constructor(e,t){super(e),this.values=t}valueOf(){let e=super.valueOf();return Wi()?Gi(Ui(e),...this.values):Gi(e,...this.values)}toString(){return this.valueOf()}};function Yi(e){return`sheetId`in e}function Xi(e){return`dimension`in e&&`sheetId`in e&&`elements`in e}function Zi(e){return`target`in e&&`sheetId`in e}function Qi(e){return`ranges`in e}function $i(e){return`col`in e&&`row`in e&&`sheetId`in e}function ea(e){return`sheetId`in e&&`zone`in e}let ta=new Set([`RENAME_SHEET`,`DELETE_SHEET`,`CREATE_SHEET`,`DUPLICATE_SHEET`,`ADD_COLUMNS_ROWS`,`REMOVE_COLUMNS_ROWS`,`UNDO`,`REDO`,`ADD_MERGE`,`REMOVE_MERGE`,`UPDATE_LOCALE`,`ADD_PIVOT`,`UPDATE_PIVOT`,`INSERT_PIVOT`,`RENAME_PIVOT`,`REMOVE_PIVOT`,`DUPLICATE_PIVOT`]),na=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`]),ra=new Set([`MOVE_RANGES`]),ia=new Set([`EVALUATE_CELLS`,`ADD_CONDITIONAL_FORMAT`,`REMOVE_CONDITIONAL_FORMAT`,`CHANGE_CONDITIONAL_FORMAT_PRIORITY`]),aa=new Set([`AUTOFILL_CELL`,`SET_BORDER`,`SET_ZONE_BORDERS`,`SET_BORDERS_ON_TARGET`]),oa=new Set([`START`,`ACTIVATE_SHEET`,`COPY`,`RESIZE_SHEETVIEW`,`SET_VIEWPORT_OFFSET`,`EVALUATE_CELLS`,`EVALUATE_CHARTS`,`SET_FORMULA_VISIBILITY`,`UPDATE_FILTER`]),sa=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`.split(`.`));function ca(e){return sa.has(e.type)}function la(e){return oa.has(e.type)}var ua=class{reasons;constructor(e=[]){Array.isArray(e)||(e=[e]),e=[...new Set(e)],this.reasons=e.filter(e=>e!==`Success`)}static get Success(){return da}get isSuccessful(){return this.reasons.length===0}isCancelledBecause(e){return this.reasons.includes(e)}};let da=new ua,fa=function(e){return e.Success=`Success`,e.CancelledForUnknownReason=`CancelledForUnknownReason`,e.WillRemoveExistingMerge=`WillRemoveExistingMerge`,e.CannotMoveTableHeader=`CannotMoveTableHeader`,e.MergeIsDestructive=`MergeIsDestructive`,e.CellIsMerged=`CellIsMerged`,e.InvalidTarget=`InvalidTarget`,e.EmptyUndoStack=`EmptyUndoStack`,e.EmptyRedoStack=`EmptyRedoStack`,e.NotEnoughElements=`NotEnoughElements`,e.NotEnoughSheets=`NotEnoughSheets`,e.MissingSheetName=`MissingSheetName`,e.UnchangedSheetName=`UnchangedSheetName`,e.DuplicatedSheetName=`DuplicatedSheetName`,e.DuplicatedSheetId=`DuplicatedSheetId`,e.ForbiddenCharactersInSheetName=`ForbiddenCharactersInSheetName`,e.WrongSheetMove=`WrongSheetMove`,e.WrongSheetPosition=`WrongSheetPosition`,e.InvalidAnchorZone=`InvalidAnchorZone`,e.SelectionOutOfBound=`SelectionOutOfBound`,e.TargetOutOfSheet=`TargetOutOfSheet`,e.WrongCutSelection=`WrongCutSelection`,e.WrongPasteSelection=`WrongPasteSelection`,e.WrongPasteOption=`WrongPasteOption`,e.WrongFigurePasteOption=`WrongFigurePasteOption`,e.EmptyClipboard=`EmptyClipboard`,e.EmptyRange=`EmptyRange`,e.InvalidRange=`InvalidRange`,e.InvalidZones=`InvalidZones`,e.InvalidSheetId=`InvalidSheetId`,e.InvalidCellId=`InvalidCellId`,e.InvalidFigureId=`InvalidFigureId`,e.InputAlreadyFocused=`InputAlreadyFocused`,e.MaximumRangesReached=`MaximumRangesReached`,e.MinimumRangesReached=`MinimumRangesReached`,e.InvalidChartDefinition=`InvalidChartDefinition`,e.InvalidDataSet=`InvalidDataSet`,e.InvalidLabelRange=`InvalidLabelRange`,e.InvalidScorecardKeyValue=`InvalidScorecardKeyValue`,e.InvalidScorecardBaseline=`InvalidScorecardBaseline`,e.InvalidGaugeDataRange=`InvalidGaugeDataRange`,e.EmptyGaugeRangeMin=`EmptyGaugeRangeMin`,e.GaugeRangeMinNaN=`GaugeRangeMinNaN`,e.EmptyGaugeRangeMax=`EmptyGaugeRangeMax`,e.GaugeRangeMaxNaN=`GaugeRangeMaxNaN`,e.GaugeLowerInflectionPointNaN=`GaugeLowerInflectionPointNaN`,e.GaugeUpperInflectionPointNaN=`GaugeUpperInflectionPointNaN`,e.InvalidAutofillSelection=`InvalidAutofillSelection`,e.MinBiggerThanMax=`MinBiggerThanMax`,e.LowerBiggerThanUpper=`LowerBiggerThanUpper`,e.MidBiggerThanMax=`MidBiggerThanMax`,e.MinBiggerThanMid=`MinBiggerThanMid`,e.FirstArgMissing=`FirstArgMissing`,e.SecondArgMissing=`SecondArgMissing`,e.MinNaN=`MinNaN`,e.MidNaN=`MidNaN`,e.MaxNaN=`MaxNaN`,e.ValueUpperInflectionNaN=`ValueUpperInflectionNaN`,e.ValueLowerInflectionNaN=`ValueLowerInflectionNaN`,e.MinInvalidFormula=`MinInvalidFormula`,e.MidInvalidFormula=`MidInvalidFormula`,e.MaxInvalidFormula=`MaxInvalidFormula`,e.ValueUpperInvalidFormula=`ValueUpperInvalidFormula`,e.ValueLowerInvalidFormula=`ValueLowerInvalidFormula`,e.InvalidSortAnchor=`InvalidSortAnchor`,e.InvalidSortZone=`InvalidSortZone`,e.SortZoneWithArrayFormulas=`SortZoneWithArrayFormulas`,e.WaitingSessionConfirmation=`WaitingSessionConfirmation`,e.MergeOverlap=`MergeOverlap`,e.TooManyHiddenElements=`TooManyHiddenElements`,e.Readonly=`Readonly`,e.InvalidViewportSize=`InvalidViewportSize`,e.InvalidScrollingDirection=`InvalidScrollingDirection`,e.ViewportScrollLimitsReached=`ViewportScrollLimitsReached`,e.FigureDoesNotExist=`FigureDoesNotExist`,e.InvalidConditionalFormatId=`InvalidConditionalFormatId`,e.InvalidConditionalFormatType=`InvalidConditionalFormatType`,e.InvalidCellPopover=`InvalidCellPopover`,e.EmptyTarget=`EmptyTarget`,e.InvalidFreezeQuantity=`InvalidFreezeQuantity`,e.FrozenPaneOverlap=`FrozenPaneOverlap`,e.ValuesNotChanged=`ValuesNotChanged`,e.InvalidFilterZone=`InvalidFilterZone`,e.TableNotFound=`TableNotFound`,e.TableOverlap=`TableOverlap`,e.InvalidTableConfig=`InvalidTableConfig`,e.InvalidTableStyle=`InvalidTableStyle`,e.FilterNotFound=`FilterNotFound`,e.MergeInTable=`MergeInTable`,e.NonContinuousTargets=`NonContinuousTargets`,e.DuplicatedFigureId=`DuplicatedFigureId`,e.InvalidSelectionStep=`InvalidSelectionStep`,e.DuplicatedChartId=`DuplicatedChartId`,e.ChartDoesNotExist=`ChartDoesNotExist`,e.InvalidHeaderIndex=`InvalidHeaderIndex`,e.InvalidQuantity=`InvalidQuantity`,e.MoreThanOneColumnSelected=`MoreThanOneColumnSelected`,e.EmptySplitSeparator=`EmptySplitSeparator`,e.SplitWillOverwriteContent=`SplitWillOverwriteContent`,e.NoSplitSeparatorInSelection=`NoSplitSeparatorInSelection`,e.NoActiveSheet=`NoActiveSheet`,e.InvalidLocale=`InvalidLocale`,e.MoreThanOneRangeSelected=`MoreThanOneRangeSelected`,e.NoColumnsProvided=`NoColumnsProvided`,e.ColumnsNotIncludedInZone=`ColumnsNotIncludedInZone`,e.DuplicatesColumnsSelected=`DuplicatesColumnsSelected`,e.InvalidHeaderGroupStartEnd=`InvalidHeaderGroupStartEnd`,e.HeaderGroupAlreadyExists=`HeaderGroupAlreadyExists`,e.UnknownHeaderGroup=`UnknownHeaderGroup`,e.UnknownDataValidationRule=`UnknownDataValidationRule`,e.UnknownDataValidationCriterionType=`UnknownDataValidationCriterionType`,e.InvalidDataValidationCriterionValue=`InvalidDataValidationCriterionValue`,e.InvalidNumberOfCriterionValues=`InvalidNumberOfCriterionValues`,e.InvalidCopyPasteSelection=`InvalidCopyPasteSelection`,e.NoChanges=`NoChanges`,e.InvalidInputId=`InvalidInputId`,e.SheetIsHidden=`SheetIsHidden`,e.InvalidTableResize=`InvalidTableResize`,e.PivotIdNotFound=`PivotIdNotFound`,e.PivotInError=`PivotInError`,e.EmptyName=`EmptyName`,e.ValueCellIsInvalidFormula=`ValueCellIsInvalidFormula`,e.InvalidDefinition=`InvalidDefinition`,e.InvalidColor=`InvalidColor`,e.InvalidPivotDataSet=`InvalidPivotDataSet`,e}({}),pa=[{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:`;`}],k=pa[0],ma=[`thin`,`medium`,`thick`,`dashed`,`dotted`];function A(e){return Array.isArray(e)&&Array.isArray(e[0])}let ha={Background:0,Highlights:1,Clipboard:2,Chart:4,Autofill:5,Selection:6,Headers:100},ga=Vt(()=>Object.keys(ha).sort((e,t)=>ha[e]-ha[t]));function _a(e,t){if(ha[e])throw Error(`Layer ${e} already exists`);ha[e]=t}let j={NotAvailable:`#N/A`,InvalidReference:`#REF`,BadExpression:`#BAD_EXPR`,CircularDependency:`#CYCLE`,UnknownFunction:`#NAME?`,DivisionByZero:`#DIV/0!`,SpilledBlocked:`#SPILL!`,GenericError:`#ERROR`,NullError:`#NULL!`},va=new Set(Object.values(j));var M=class{message;value;constructor(e=O(`Error`),t=j.GenericError){this.message=e,this.value=t,this.message=e.toString()}},ya=class extends M{constructor(e=O(`Invalid expression`)){super(e,j.BadExpression)}},ba=class extends M{constructor(e=O(`Circular reference`)){super(e,j.CircularDependency)}},xa=class extends M{constructor(e=O(`Invalid reference`)){super(e,j.InvalidReference)}},Sa=class extends M{constructor(e=O(`Data not available`)){super(e,j.NotAvailable)}},Ca=class extends M{constructor(e=O(`Unknown function`)){super(e,j.UnknownFunction)}},wa=class extends M{errorOriginPosition;constructor(e=O(`Spill range is not empty`),t){super(e,j.SpilledBlocked),this.errorOriginPosition=t}};let Ta=[`number`,`string`,`boolean`,`undefined`];function N(e,t,n){if(!e())throw new M(t,n)}function Ea(e){if(e!==void 0)return A(e)?e[0][0]?.format:e.format}function P(e){return typeof e==`string`&&va.has(e)}function Da(e){return{value:j.NotAvailable,message:O(`Did not find value '%s' in [[FUNCTION_NAME]] evaluation.`,I(e))}}let Oa=e=>O(`The function [[FUNCTION_NAME]] expects a number value, but '%s' is a string, and cannot be coerced to a number.`,e),ka=(e,t,n)=>O(`The function [[FUNCTION_NAME]] expects a number value between %s and %s inclusive, but receives %s.`,e.toString(),t.toString(),n.toString()),Aa=(e,t)=>O(`The function [[FUNCTION_NAME]] has an argument with value '%s'. It should be one of: %s.`,t,e.map(e=>`'${e}'`).join(`, `));function F(e,t){let n=Va(e);switch(typeof n){case`number`:return n;case`boolean`:return+!!n;case`string`:if(Li(n,t)||n===``)return zi(n,t);let e=si(n,t);if(e)return e.value;throw new M(Oa(n));default:return 0}}function ja(e,t){try{return F(e,t)}catch{return}}function Ma(e,t){return z(e).map(e=>e.map(e=>{if(typeof e.value!=`number`){let n=``;throw typeof e==`object`?n=O(`Function [[FUNCTION_NAME]] expects number values for %s, but got an empty value.`,t):typeof e==`string`?n=O(`Function [[FUNCTION_NAME]] expects number values for %s, but got a string.`,t):typeof e==`boolean`&&(n=O(`Function [[FUNCTION_NAME]] expects number values for %s, but got a boolean.`,t)),new M(n)}return e.value}))}function Na(e,t){let n=Va(e);if(n===``)throw new M(Oa(n));return F(n,t)}function Pa(e,t){return Math.trunc(F(e,t))}function Fa(e,t){return Math.trunc(Na(e,t))}function Ia(e){N(()=>e>=1,O(`The function [[FUNCTION_NAME]] expects a number value to be greater than or equal to 1, but receives %s.`,e.toString()))}function La(e){N(()=>e!==0,O(`Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero)}function I(e){let t=Va(e);switch(typeof t){case`string`:return t;case`number`:return t.toString();case`boolean`:return t?`TRUE`:`FALSE`;default:return``}}let Ra=Vt(function(e){return e.toLowerCase().normalize(`NFD`).replace(/[\u0300-\u036f]/g,``)}),za=e=>O(`The function [[FUNCTION_NAME]] expects a boolean value, but '%s' is a text, and cannot be coerced to a boolean.`,e);function L(e){let t=Va(e);switch(typeof t){case`boolean`:return t;case`string`:if(t){let e=t.toUpperCase();if(e===`TRUE`)return!0;if(e===`FALSE`)return!1;throw new M(za(t))}else return!1;case`number`:return!!t;default:return!1}}function Ba(e){let t=Va(e);if(t===``)throw new M(za(t));return L(t)}function R(e,t){return _i(F(Va(e),t))}function Va(e){if(typeof e==`object`&&e&&`value`in e){if(P(e.value))throw e;return e.value}if(P(e))throw new M(``,e);return e}function Ha(e,t,n){for(let r of e)if(A(r)){let e=r.length,n=r[0].length;for(let i=0;i<n;i++)for(let n=0;n<e;n++)t(r[n][i])}else n(r)}function Ua(e,t){Ha(e,e=>{if(P(e.value))throw e;t(e)},e=>{if(P(e?.value))throw e;t(e)})}function Wa(e,t,n){Ha(e,e=>{if(typeof e?.value==`number`&&t(e),P(e?.value))throw e},e=>{t({value:Na(e,n),format:e?.format})})}function Ga(e,t,n,r,i=`rowFirst`){let a=r;for(let r of e)if(A(r)){let e=r.length,n=r[0].length;if(i===`rowFirst`)for(let i=0;i<n;i++)for(let n=0;n<e;n++)a=t(a,r[n][i]);else for(let i=0;i<e;i++)for(let e=0;e<n;e++)a=t(a,r[i][e])}else a=n(a,r);return a}function Ka(e,t,n,r=`rowFirst`){return Ga(e,t,t,n,r)}function qa(e,t,n,r){return Ga(e,(e,n)=>{let r=n?.value;if(typeof r==`number`)return t(e,r);if(P(r))throw n;return e},(e,n)=>t(e,Na(n,r)),n)}function Ja(e,t,n,r){return Ga(e,(e,n)=>{let i=n?.value;if(i!=null){if(typeof i==`number`)return t(e,i);if(typeof i==`boolean`)return t(e,F(i,r));if(P(i))throw n;return t(e,0)}return e},(e,n)=>t(e,F(n,r)),n)}function Ya(e,t,n){let r=Array(e);for(let i=0;i<e;i++){r[i]=Array(t);for(let e=0;e<t;e++)r[i][e]=n(i,e)}return r}function Xa(e,t){return e.length===0?[]:Ya(e.length,e[0].length,(n,r)=>t(e[n][r]))}function Za(e,t){let n=e.length,r=e[0]?.length??0;for(let i=0;i<n;i++)for(let n=0;n<r;n++)t(e[i][n])}function Qa(e){return e.length?Ya(e[0].length,e.length,(t,n)=>e[n][t]):[]}function $a(e,t,n=void 0){let r=1,i=1,a=1/0,o=1/0,s;for(let e=0;e<t.length;e++){let c=t[e];if(A(c)&&(n===void 0||n[e])){let n=c.length,l=c[0].length;n!==1||l!==1?(s??=Array(t.length),n!==1&&l!==1?(s[e]=`matrix`,r=Math.max(r,n),i=Math.max(i,l),a=Math.min(a,n),o=Math.min(o,l)):n===1?l!==1&&(s[e]=`vertical`,i=Math.max(i,l),o=Math.min(o,l)):(s[e]=`horizontal`,r=Math.max(r,n),a=Math.min(a,n))):t[e]=c[0][0]}}if(r===1&&i===1)return e(...t);let c=(e,n)=>t.map((t,r)=>{switch(s?.[r]){case`matrix`:return t[e][n];case`horizontal`:return t[e][0];case`vertical`:return t[0][n];case void 0:return t}});return Ya(r,i,(t,n)=>{if(t>a-1||n>o-1)return new Sa(O(`Array arguments to [[FUNCTION_NAME]] are of different size.`));let r=e(...c(t,n));return A(r)?r[0][0]:r})}function eo(e,t,n){for(let r of e)if(A(r)){let e=r.length,n=r[0].length;for(let i=0;i<n;i++)for(let n=0;n<e;n++)if(!t(r[n][i]??void 0))return}else if(!n(r))return}function to(e,t){return eo(e,e=>{let n=e?.value;if(typeof n==`boolean`)return t(n);if(typeof n==`number`)return t(!!n);if(P(n))throw e;return!0},e=>e!==void 0&&e.value!==null?t(Ba(e)):!0)}function no(e,t){let n,r,i=e.substring(0,2);return i===`<=`||i===`>=`||i===`<>`?(n=i,r=e.substring(2)):(i=e.substring(0,1),i===`<`||i===`>`||i===`=`?(n=i,r=e.substring(1)):(n=`=`,r=e)),Li(r,t)||ai(r,t)?r=F(r,t):(r===`TRUE`||r===`FALSE`)&&(r=L(r)),{operator:n,operand:r}}let ro=Vt(function(e){if(e===`*`)return/.+/;let t=``,n=``;for(let r of e)r===`?`&&n!==`~`?t+=`.`:r===`*`&&n!==`~`?t+=`.*`:((r===`*`||r===`?`)&&(t=t.slice(0,-1)),[`^`,`.`,`[`,`]`,`$`,`(`,`)`,`*`,`+`,`?`,`|`,`{`,`}`,`\\`].includes(r)&&(t+=`\\`),t+=r),n=r;return RegExp(`^`+t+`$`,`i`)});function io(e=``,t,n){let{operator:r,operand:i}=t;if(i===void 0||e===null||i===null)return!1;if(typeof i==`number`&&r===`=`)return typeof e==`string`&&(Li(e,n)||ai(e,n))?F(e,n)===i:e===i;if(r===`<>`||r===`=`){let t;return t=typeof e==typeof i?typeof e==`string`&&typeof i==`string`?ro(i).test(e):e===i:!1,r===`=`?t:!t}if(typeof e==typeof i)switch(r){case`<`:return e<i;case`>`:return e>i;case`<=`:return e<=i;case`>=`:return e>=i}return!1}function ao(e,t,n,r=!1){let i=e.length;if(i%2==1)throw new M(O(`Function [[FUNCTION_NAME]] expects criteria_range and criterion to be in pairs.`));let a=z(e[0]),o=a.length,s=a[0].length,c=[];for(let t=0;t<i-1;t+=2){let i=z(e[t]);if(i.length!==o||i[0].length!==s)throw new M(O(`Function [[FUNCTION_NAME]] expects criteria_range to have the same dimension`));let a=no(I(e[t+1]),n);r&&typeof a.operand==`string`&&(a.operand+=`*`),c.push(a)}for(let r=0;r<o;r++)for(let a=0;a<s;a++){let o=!0;for(let t=0;t<i-1;t+=2){let i=z(e[t])[r][a].value,s=c[t/2];if(o=io(i??void 0,s,n),!o)break}o&&t(r,a)}}function oo(e,t,n,r,i,a){if(t===void 0||t.value===null)return-1;if(P(t.value))throw t;let o=lo(t.value),s=typeof o,c,l,u=0,d=i-1,f,p,m,h,g=r===`desc`?t=>lo(a(e,i-t-1)):t=>lo(a(e,t));for(;d-u>=0;){for(f=Math.floor((u+d)/2),p=f,m=g(p),h=typeof m;u<p&&s!==h;)p--,m=g(p),h=typeof m;if(h!==s||m==null){u=f+1;continue}n===`strict`&&m===o?(c=m,l=p):n===`nextSmaller`&&m<=o?(c==null||c<m||c===m&&l<p)&&(c=m,l=p):n===`nextGreater`&&m>=o&&(c===void 0||c>m||c===m&&l<p)&&(c=m,l=p),m>o||n===`strict`&&m===o?d=p-1:u=f+1}return l===void 0?-1:r===`desc`?i-l-1:l}function so(e,t,n,r,i,a,o=!1){if(t===void 0||t.value===null)return-1;if(P(t.value))throw t;let s=lo(t.value),c=o?(e,t)=>lo(i(e,r-t-1)):(e,t)=>lo(i(e,t)),l=n!==`wildcard`||typeof s!=`string`||!(s.includes(`*`)||s.includes(`?`));if(a&&l){let t=o?`reverseSearch`:`forwardSearch`,i=a[t].get(e);if(i===void 0){i=new Map;for(let t=0;t<r;t++){let n=c(e,t)??null;i.has(n)||i.set(n,t)}a[t].set(e,i)}if(i.has(s)){let e=i.get(s);return o?r-e-1:e}if(n===`strict`)return-1}let u=co(e,s,n,r,c);return o&&u!==-1?r-u-1:u}function co(e,t,n,r,i){let a=n=>i(e,n)===t;if(n===`wildcard`&&typeof t==`string`&&(t.includes(`*`)||t.includes(`?`))){let n=ro(t);a=t=>{let r=i(e,t);return typeof r==`string`?n.test(r):!1}}let o,s=-1;n===`nextSmaller`&&(a=n=>{let r=i(e,n);return(!o&&uo(t,r)>=0||uo(t,r)>=0&&uo(r,o)>0)&&(o=r,s=n),r===t}),n===`nextGreater`&&(a=n=>{let r=i(e,n);return(!o&&uo(t,r)<=0||uo(t,r)<=0&&uo(r,o)<0)&&(o=r,s=n),r===t});for(let e=0;e<r;e++)if(a(e))return e;return s}function lo(e){return typeof e==`string`?Ra(e):e}function uo(e,t){let n=Ta.indexOf(typeof e)-Ta.indexOf(typeof t);return n===0&&(typeof e==`string`&&typeof t==`string`?n=e.localeCompare(t):typeof e==`number`&&typeof t==`number`?n=e-t:typeof e==`boolean`&&typeof t==`boolean`&&(n=Number(e)-Number(t))),n}function z(e){return e===void 0?[[]]:A(e)?e:[[e]]}function fo(e,t){return Ka(e,(e,n)=>(e.push(t(n)),e),[],`rowFirst`)}function po(e){if(e===void 0)return!1;let{value:t}=e;return!(t===null||t===``)}function mo(e){return/^https?:\/\//i.test(e)?e:`https://${e}`}let ho=new h;function go(e,t){return e=mo(e),{url:e,label:t||e,isExternal:!0,isUrlEditable:!0}}ho.add(`sheet_URL`,{match:e=>xt(e),createLink:(e,t)=>({label:t,url:e,isExternal:!1,isUrlEditable:!1}),urlRepresentation(e,t){let n=Ct(e);return t.tryGetSheetName(n)||O(`Invalid sheet`)},open(e,t){let n=Ct(e);t.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:t.model.getters.getActiveSheetId(),sheetIdTo:n}).isCancelledBecause(`SheetIsHidden`)&&t.notifyUser({type:`warning`,sticky:!1,text:O(`Cannot open the link because the linked sheet is hidden.`)})},sequence:0});let _o={createLink:go,match:e=>_t(e),open:e=>window.open(e,`_blank`),urlRepresentation:e=>e,sequence:0};function vo(e){return ho.getAll().sort((e,t)=>e.sequence-t.sequence).find(t=>t.match(e))||_o}function yo(e,t){return vo(e.url).urlRepresentation(e.url,t)}function bo(e,t,n){vo(e.url).open(e.url,t,n)}function xo(e){if(typeof e==`string`){if(gt(e)){let{label:t,url:n}=yt(e);return vo(n).createLink(n,t)}else if(_t(e))return go(e)}}function So(e){let t=new Xt(e),n=[],r=[];for(n.push(r);!t.isOver();){if(t.current===`;`){r=[],n.push(r),t.shift();continue}let e=Ao(t)||Co(t)||To(t)||Eo(t)||Oo(t)||ko(t)||Mo(t)||Do(t)||No(t);if(!e)throw Error(`Unknown token at `+t.remaining());r.push(e)}return n}function Co(e){let t;if(e.current===`"`?(e.shift(),t=`"`):e.currentStartsWith(`[$`)&&(e.advanceBy(2),t=`]`),!t)return null;let n=``;for(;e.current&&e.current!==t;)n+=e.shift();if(e.current===t)e.shift();else throw Error(`Unterminated string in format`);return{type:`STRING`,value:n}}let wo=new Set(`$+-/():!^&~{}<>= `);function To(e){if(e.current===`\\`){e.shift();let t=e.shift();if(!t)throw Error(`Unexpected end of format string`);return{type:`CHAR`,value:t}}return wo.has(e.current)?{type:`CHAR`,value:e.shift()}:null}function Eo(e){return e.current===`,`?(e.shift(),{type:`THOUSANDS_SEPARATOR`,value:`,`}):null}function Do(e){return e.current===`@`?(e.shift(),{type:`TEXT_PLACEHOLDER`,value:`@`}):null}function Oo(e){return e.current===`.`?(e.shift(),{type:`DECIMAL_POINT`,value:`.`}):null}function ko(e){return e.current===`%`?(e.shift(),{type:`PERCENT`,value:`%`}):null}function Ao(e){if(e.current===`0`||e.current===`#`){let t=e.current;return e.shift(),{type:`DIGIT`,value:t}}return null}let jo=new Set(`dmqyhsa`);function Mo(e){if(!jo.has(e.current))return null;let t=e.current,n=``;for(;e.current===t;)n+=e.shift();return{type:`DATE_PART`,value:n}}function No(e){if(e.current!==`*`)return null;e.shift();let t=e.shift();if(!t)throw Error(`Unexpected end of format string`);return{type:`REPEATED_CHAR`,value:t}}let Po={};function Fo(e){let t=Po[e];return t===void 0&&(t=Io(e),Po[e]=t),t}function Io(e){let t=So(e);for(let e of t){let t=e.filter(e=>e.type===`REPEATED_CHAR`);for(let e of t.slice(1))e.type=`CHAR`}let n=Vo(t[0])||Bo(t[0])||Ho(t[0]);if(!n)throw Error(`Invalid first format part of: `+e);if(t.length>1&&n.type===`text`)throw Error(`The first format in a multi-part format must be a number format: `+e);let r=Vo(t[1])||Bo(t[1]);if(t[1]?.length&&!r)throw Error(`Invalid second format part of: `+e);let i=Vo(t[2])||Bo(t[2]);if(t[2]?.length&&!i)throw Error(`Invalid third format part of: `+e);let a=Ho(t[3]);if(t[3]?.length&&!a)throw Error(`Invalid fourth format part of: `+e);return{positive:n,negative:r,zero:i,text:a}}function Lo(e){return e.every(e=>e.type===`DATE_PART`||e.type===`DECIMAL_POINT`||e.type===`THOUSANDS_SEPARATOR`||e.type===`STRING`||e.type===`CHAR`||e.type===`REPEATED_CHAR`)}function Ro(e){return e.every(e=>e.type===`DIGIT`||e.type===`DECIMAL_POINT`||e.type===`THOUSANDS_SEPARATOR`||e.type===`PERCENT`||e.type===`STRING`||e.type===`CHAR`||e.type===`REPEATED_CHAR`)}function zo(e){return e.every(e=>e.type===`STRING`||e.type===`TEXT_PLACEHOLDER`||e.type===`CHAR`||e.type===`REPEATED_CHAR`)}function Bo(e){if(!e||!Ro(e))return;let t=[],n,r=t,i=0,a=0,o=e.findLastIndex(e=>e.type===`DIGIT`),s=!1,c=0;for(let l=0;l<e.length;l++){let u=e[l];switch(u.type){case`DIGIT`:r===t?r.push(u):c<20&&(r.push(u),c++);break;case`DECIMAL_POINT`:if(r===t)n=[],r=n;else throw Error(`Multiple decimal points in a number format`);break;case`REPEATED_CHAR`:case`CHAR`:case`STRING`:r.push(u);break;case`PERCENT`:i++,r.push(u);break;case`THOUSANDS_SEPARATOR`:l-1===o?(a+=1,o++,r.push(u)):e[l+1]?.type===`DIGIT`&&e[l-1]?.type===`DIGIT`?(r===t&&(s=!0),r.push(u)):r.push({type:`CHAR`,value:`,`});break}}return{type:`number`,integerPart:t,decimalPart:n,percentSymbols:i,thousandsSeparator:s,magnitude:a}}function Vo(e){let t=e&&Lo(e)?{type:`date`,tokens:e}:void 0;if(t){if(t.tokens.length&&t.tokens.every(e=>e.type===`DATE_PART`&&e.value===`a`))throw Error(`Invalid date format`);return{type:`date`,tokens:Uo(t.tokens.map(e=>e.type===`THOUSANDS_SEPARATOR`||e.type===`DECIMAL_POINT`?{type:`CHAR`,value:e.value}:e))}}}function Ho(e){return e&&zo(e)?{type:`text`,tokens:e}:void 0}function Uo(e){let t=e.filter(e=>e.type===`DATE_PART`);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}function Wo(e){return[Go(e.positive),Go(e.negative),Go(e.zero),Go(e.text)].filter(C).join(`;`)}function Go(e){if(!e)return;let t=``,n=e.type===`number`?Ko(e):e.tokens;for(let e of n)switch(e.type){case`STRING`:t+=`[$${e.value}]`;break;case`CHAR`:t+=qo(e.value)?`\\${e.value}`:e.value;break;case`REPEATED_CHAR`:t+=`*`+e.value;break;case`DATE_PART`:t+=e.value===`MM`?`mm`:e.value;break;default:t+=e.value}return t}function Ko(e){let t=[...e.integerPart];return e.decimalPart&&(t.push({type:`DECIMAL_POINT`,value:`.`}),t.push(...e.decimalPart)),t}function qo(e){return!wo.has(e)}let Jo=`REPEATED_CHAR_PLACEHOLDER_`,Yo={0:O(`January`),1:O(`February`),2:O(`March`),3:O(`April`),4:O(`May`),5:O(`June`),6:O(`July`),7:O(`August`),8:O(`September`),9:O(`October`),10:O(`November`),11:O(`December`)},Xo={0:O(`Sunday`),1:O(`Monday`),2:O(`Tuesday`),3:O(`Wednesday`),4:O(`Thursday`),5:O(`Friday`),6:O(`Saturday`)};function B(e,{format:t,locale:n,formatWidth:r}){switch(typeof e==`boolean`&&(e=e?`TRUE`:`FALSE`),typeof e){case`string`:{if(e.includes(`\\"`)&&(e=e.replaceAll(/\\"/g,`"`)),!t)return e;let n=Fo(t),i=n.text||n.positive;return!i||i.type!==`text`?e:Zo(e,i,r)}case`number`:t||=ps(e);let i=Fo(t);if(i.positive.type===`text`)return Zo(e.toString(),i.positive,r);let a=i.positive;if(e<0&&i.negative?(a=i.negative,e=-e):e===0&&i.zero&&(a=i.zero),a.type===`date`)return Qo(us(e,a),r);let o=e<0,s=Qo($o(Math.abs(e),a,n),r);return o?`-`+s:s;case`object`:return``}}function Zo(e,t,n){let r=``;for(let n of t.tokens)switch(n.type){case`TEXT_PLACEHOLDER`:r+=e;break;case`CHAR`:case`STRING`:r+=n.value;break;case`REPEATED_CHAR`:r+=Jo+n.value;break}return Qo(r,n)}function Qo(e,t){let n=e.indexOf(Jo);if(n===-1)return e;let r=e.slice(0,n),i=e.slice(n+26+1),a=e[n+26];function o(){if(!t)return{timesToRepeat:0,padding:``};let e=t.measureText(r+i),n=t.measureText(a),o=t.availableWidth-e;if(o<=0)return{timesToRepeat:0,padding:``};let s=Math.floor(o/n),c=o-s*n,l=t.measureText(` `);return{timesToRepeat:s,padding:` `.repeat(Math.floor(c/l))}}let{timesToRepeat:s,padding:c}=o();return r+a.repeat(s)+c+i}function $o(e,t,n){if(e===1/0)return`∞`+(t.percentSymbols?`%`:``);let r=t.percentSymbols*2-t.magnitude*3;e*=10**r;let i=0;t.decimalPart!==void 0&&(i=t.decimalPart.filter(e=>e.type===`DIGIT`).length);let{integerDigits:a,decimalDigits:o}=rs(Math.abs(e),i),s=es(a,t,t.thousandsSeparator?n.thousandsSeparator:void 0);return t.decimalPart!==void 0&&(s+=n.decimalSeparator+ts(o||``,t)),s}function es(e,t,n){let r=t.integerPart;r.some(e=>e.type===`DIGIT`)||(r=[...r,{type:`DIGIT`,value:`#`}]),e===`0`&&(e=``);let i=``,a=r.findIndex(e=>e.type===`DIGIT`),o=e.length-1;function s(t,r){if(r===`0`&&(t||=`0`),!t)return;let a=e.length-1-o;i=n&&a>0&&a%3==0?t+n+i:t+i}for(let t=r.length-1;t>=0;t--){let n=r[t];switch(n.type){case`DIGIT`:let r=e[o];if(s(r,n.value),o--,a===t)for(;o>=0;)s(e[o],`0`),o--;break;case`THOUSANDS_SEPARATOR`:break;case`REPEATED_CHAR`:i=Jo+n.value+i;break;default:i=n.value+i;break}}return i}function ts(e,t){if(!t.decimalPart)return``;let n=``,r=0;for(let i of t.decimalPart)switch(i.type){case`DIGIT`:let t=i.value===`#`?e[r]||``:e[r]||`0`;n+=t,r++;break;case`THOUSANDS_SEPARATOR`:break;case`REPEATED_CHAR`:n+=Jo+i.value;break;default:n+=i.value;break}return n}let ns=[];function rs(e,t=20){let n=e.toString();if(n.includes(`e`))return ss(e,t);if(Number.isInteger(e))return{integerDigits:n,decimalDigits:void 0};let r=n.indexOf(`.`),i=n.substring(0,r),a=n.substring(r+1);if(t===0)return Number(a[0])>=5&&(i=(Number(i)+1).toString()),{integerDigits:i,decimalDigits:void 0};if(a.length>t){let{integerDigits:e,decimalDigits:n}=os(a,t);a=n,e!==`0`&&(i=(Number(i)+Number(e)).toString())}return{integerDigits:i,decimalDigits:is(a||``)}}function is(e){let t=e.length-1;for(;t>=0&&e[t]===`0`;)t--;return e.slice(0,t+1)||void 0}let as=/^0+/;function os(e,t){let n=`0`,r=e,i=e.slice(0,t);if(Number(e[t])<5)return{integerDigits:n,decimalDigits:i};let a=i.match(as)?.[0]||``,o=(Number(i)+1).toString(),s=i.slice(a.length),c=o.length>s.length;return c&&!a?(n=`1`,r=void 0):r=c?a.slice(0,-1)+o:a+o,{integerDigits:n,decimalDigits:r}}function ss(e,t=20){let n=ns[t];n||(n=new Intl.NumberFormat(`en-US`,{maximumFractionDigits:t,useGrouping:!1}),ns[t]=n);let[r,i]=n.format(e).split(`.`);return{integerDigits:r,decimalDigits:i}}function cs(e,t){let{integerDigits:n,decimalDigits:r}=rs(e,20);return r?n+t+r:n}let ls=Vt(function(e){if(!e)return!1;try{return Fo(e).positive.type===`date`}catch{return!1}});function us(e,t){let n=_i(e);if(isNaN(n.getTime()))return e.toString();let r=t.tokens.some(e=>e.type===`DATE_PART`&&e.value===`a`),i=``;for(let e of t.tokens)switch(e.type){case`DATE_PART`:i+=ds(n,e.value,r);break;case`REPEATED_CHAR`:i+=Jo+e.value;break;default:i+=e.value;break}return i}function ds(e,t,n){switch(t){case`d`:return e.getDate();case`dd`:return e.getDate().toString().padStart(2,`0`);case`ddd`:return Xo[e.getDay()].slice(0,3);case`dddd`:return Xo[e.getDay()].toString();case`m`:return e.getMonth()+1;case`mm`:return String(e.getMonth()+1).padStart(2,`0`);case`mmm`:return Yo[e.getMonth()].slice(0,3);case`mmmm`:return Yo[e.getMonth()].toString();case`mmmmm`:return Yo[e.getMonth()].slice(0,1);case`qq`:return O(`Q%(quarter)s`,{quarter:e.getQuarter()}).toString();case`qqqq`:return O(`Quarter %(quarter)s`,{quarter:e.getQuarter()}).toString();case`yy`:let r=String(e.getFullYear()).replace(`-`,``).padStart(2,`0`);return r.slice(r.length-2);case`yyyy`:return String(e.getFullYear()).replace(`-`,``).padStart(4,`0`);case`hhhh`:return Math.floor((e.getTime()-Kr.getTime())/(3600*1e3)).toString();case`hh`:let i=e.getHours();return n&&(i=i===0?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 Error(`invalid date format token: ${t}`)}}let fs=Vt(function(e){return RegExp(`[0-9]+${at(e.decimalSeparator)}[0-9]`)});function ps(e){let{integerDigits:t,decimalDigits:n}=rs(e);if(!n)return`0`;let r=t.replace(`-`,``).length;if(r+2>11)return`0`;let i=11-r-1;return{decimalDigits:n}=rs(e,Math.min(i,n.length)),n?`0.`+`0`.repeat(n.length):`0`}function ms(e,t){if(ai(e,t))return si(e,t).format}function hs(e){let t=e.includes(`.`)?`0.00`:`0`,n=e.match(/[\$€]/);if(n){let r=e.match(/[\d]/),i=`[$`+n.values().next().value+`]`;return r.index<n.index?`#,##`+t+i:i+`#,##`+t}if(e.includes(`%`))return t+`%`}function gs(e){let t=e.decimalPlaces??2,n=e.position??`before`,r=e.code??``,i=e.symbol??``,a=`#,##0`+(t?`.`+`0`.repeat(t):``),o=`${r} ${i}`.trim();return n===`after`&&r&&(o=` `+o),ys(o,n,a)}function _s(e){let t=e.decimalPlaces??2,n=e.position??`before`,r=e.code??``,i=e.symbol??``,a=`#,##0`+(t?`.`+`0`.repeat(t):``),o=`${r} ${i}`.trim();return n===`after`&&r&&(o=` `+o),[vs(o,n,` ${a} `),vs(o,n,`(${a})`),vs(o,n,` - `)].join(`;`)}function vs(e,t,n){let r=`[$${e}]`;return t===`before`?r+`* `+n:n+`* `+r}function ys(e,t,n){let r=`[$${e}]`;return t===`before`?r+n:n+r}function bs(e){let t=Fo(e);return Wo({positive:xs(t.positive),negative:t.negative?xs(t.negative):void 0,zero:t.zero?xs(t.zero):void 0,text:t.text})}function xs(e){if(e.type!==`number`||!e.decimalPart)return e;let t=e.decimalPart.filter(e=>e.type!==`DIGIT`);return{...e,decimalPart:void 0,integerPart:[...e.integerPart,...t]}}function Ss({value:e,format:t},n){return B(e,{format:Cs({value:e,format:t},void 0,n),locale:n})}function Cs(e,t,n){let r=0;try{r=Math.abs(F(e?.value,n))}catch{return``}let i=e?.format;if(t!==void 0)switch(t?.value){case`k`:return ws(i,1,`k`,n);case`m`:return ws(i,2,`m`,n);case`b`:return ws(i,3,`b`,n);default:throw new M(O(`The formatting unit should be 'k', 'm' or 'b'.`))}return r<1e5?ws(i,0,``,n):r<1e8?ws(i,1,`k`,n):r<1e11?ws(i,2,`m`,n):ws(i,3,`b`,n)}function ws(e,t,n,r){let i=Fo(e||`#,##0`);return Wo({positive:Ts(i.positive,t,n),negative:i.negative?Ts(i.negative,t,n):void 0,zero:i.zero?Ts(i.zero,t,n):void 0,text:i.text})}function Ts(e,t,n){if(e.type!==`number`)return e;let r=xs(e),i={type:`STRING`,value:n},a=[...r.integerPart],o=a.findLastIndex(e=>e.type===`DIGIT`);if(o===-1)throw Error(`Cannot create a large number format from a format with no digit.`);for(;a[o+1]?.type===`THOUSANDS_SEPARATOR`;)a=Ht(a,[o+1]);let s=a[o+1];a=s?.type===`STRING`&&[`m`,`k`,`b`].includes(s.value)?Wt(a,i,o+1):Ut(a,[i],o+1),t>0&&(a=Ut(a,Array(t).fill({type:`THOUSANDS_SEPARATOR`,value:`,`}),o+1));let c=r.percentSymbols-a.filter(e=>e.type===`PERCENT`).length;return a.push(...Array(c).fill({type:`PERCENT`,value:`%`})),{...r,integerPart:a,magnitude:t}}function Es(e,t){let n=Fo(e);return Wo(Fo(Wo({positive:Ds(n.positive,t),negative:n.negative?Ds(n.negative,t):void 0,zero:n.zero?Ds(n.zero,t):void 0,text:n.text})))}function Ds(e,t){return e.type===`number`?t>0?ks(e,t):Os(e,Math.abs(t)):e}function Os(e,t){let n=e.decimalPart;if(!n)return e;let r=[],i=0;for(let e=n.length-1;e>=0&&!(i>=Math.abs(t));e--)n[e].type===`DIGIT`&&(i++,r.push(e));return n=Ht(n,r),n.some(e=>e.type===`DIGIT`)?{...e,decimalPart:n}:{...e,decimalPart:void 0,integerPart:[...e.integerPart,...n]}}function ks(e,t){let n=e.integerPart,r=e.decimalPart;if(!r){let e=n.findLastIndex(e=>e.type===`DIGIT`);r=n.slice(e+1),n=n.slice(0,e+1)}let i=S(0,t).map(()=>({type:`DIGIT`,value:`0`})),a=r.findLastIndex(e=>e.type===`DIGIT`);return r=a===-1?[...i,...r]:Ut(r,i,a+1),{...e,decimalPart:r,integerPart:n}}function As(e){let t=Fo(e);for(let e of[t.positive,t.negative,t.zero])if(e&&e.type===`date`&&e.tokens.some(e=>e.type===`DATE_PART`&&e.value.includes(`q`)))return!1;return!0}function js(e){if(!e)return!1;try{return Fo(e).positive.type===`text`}catch{return!1}}function Ms(e,t){return Ps({value:js(t.format)&&e.parsedValue!==null?e.content:e.parsedValue,format:t.format},t.locale)}function Ns(e,t){if(e.startsWith(`=`))throw Error(`Cannot parse "${e}" because it's not a literal value. It's a formula`);if(e===``)return null;if(Li(e,k))return zi(e,k);let n=si(e,t);return n?n.value:pt(e)?e.toUpperCase()===`TRUE`:e}function Ps(e,t=k,n){let r=xo(e.value);if(!r)return Fs(e,t,n);let i=Ns(r.label,t);return{...Fs({value:i,format:e.format||(typeof i==`number`?ms(r.label,t)||hs(r.label):void 0)},t,n),link:r}}function Fs(e,t,n){let{value:r,format:i,message:a,errorOriginPosition:o}=e;i=n?.format||i;let s=B(r,{format:i,locale:t});return P(r)?Vs(r,a,o):r===null?Rs(i):js(i)?Is(I(r),i,s):typeof r==`number`?ls(i||``)?zs(r,i,s):Ls(r,i,s):typeof r==`boolean`?Bs(r,i,s):Is(r,i,s)}function Is(e,t,n){return{value:e,format:t,formattedValue:n,type:`text`,isAutoSummable:!0,defaultAlign:`left`}}function Ls(e,t,n){return{value:e||0,format:t,formattedValue:n,type:`number`,isAutoSummable:!0,defaultAlign:`right`}}let Rs=Vt(function(e){return{value:null,format:e,formattedValue:``,type:`empty`,isAutoSummable:!0,defaultAlign:`left`}});function zs(e,t,n){return{value:e,format:t,formattedValue:n,type:`number`,isAutoSummable:!1,defaultAlign:`right`}}function Bs(e,t,n){return{value:e,format:t,formattedValue:n,type:`boolean`,isAutoSummable:!1,defaultAlign:`center`}}function Vs(e,t,n){return{value:e,formattedValue:e,message:t,type:`error`,isAutoSummable:!1,defaultAlign:`center`,errorOriginPosition:n}}function Hs(e){let t=D.now();switch(e){case`today`:return Math.floor(yi(t));case`yesterday`:return t.setDate(t.getDate()-1),Math.floor(yi(t));case`tomorrow`:return t.setDate(t.getDate()+1),Math.floor(yi(t));case`lastWeek`:return t.setDate(t.getDate()-6),Math.floor(yi(t));case`lastMonth`:{let e=t.getMonth()===0?11:t.getMonth()-1,n=new D(t.getFullYear(),e,1);return t.getDate()>bi(n)?t.setDate(1):(t.setDate(t.getDate()+1),t.setMonth(t.getMonth()-1)),Math.floor(yi(t))}case`lastYear`:return t.getMonth()===1&&t.getDate()===29?(t.setDate(28),t.setFullYear(t.getFullYear()-1)):(t.setDate(t.getDate()+1),t.setFullYear(t.getFullYear()-1)),Math.floor(yi(t))}}function Us(e,t){return`dateValue`in e&&e.dateValue!==`exactDate`?[Hs(e.dateValue)]:e.values.map(e=>ii(e,t))}function Ws(e,t){return e.values.map(e=>ja(e,t))}function Gs(e,t){return e.map(e=>{if(e.startsWith(`=`))return e;let n=Ns(e,t);return typeof n==`number`?B(n,{format:t.dateFormat,locale:t}):``})}function Ks(e){return 20+120*Math.exp(-.035*(e-1))}let qs=new RegExp(/\$?([A-Z]{1,3})\$?([0-9]{1,7})/,`i`),Js=new RegExp(/^\$?([A-Z]{1,3})\$?([0-9]{1,7})$/,`i`),Ys=new RegExp(/^\$?([A-Z]{1,3})+$/,`i`),Xs=new RegExp(/^\$?([0-9]{1,7})+$/,`i`),Zs=new RegExp(/^\s*('.+'!|[^']+!)?\$?([A-Z]{1,3})$/,`i`),Qs=new RegExp(/^\s*('.+'!|[^']+!)?\$?([0-9]{1,7})$/,`i`),$s=RegExp(`^\\s*('.+'!|[^']+!)?(`+[qs.source,`(\\$?[A-Z]{1,3})?\\$?[0-9]{1,7}\\s*:\\s*(\\$?[A-Z]{1,3})?\\$?[0-9]{1,7}\\s*`,`\\$?[A-Z]{1,3}(\\$?[0-9]{1,7})?\\s*:\\s*\\$?[A-Z]{1,3}(\\$?[0-9]{1,7})?\\s*`].join(`|`)+`)$`,`i`);function ec(e){return Zs.test(e)}function tc(e){return Qs.test(e)}function nc(e){return Ys.test(e)}function rc(e){return Xs.test(e)}function ic(e){return Js.test(e)}function ac(e){if(!e.includes(`!`))return{xc:e};let t=e.split(`!`),n=t.pop();return{sheetName:st(t.join(`!`))||void 0,xc:n}}function oc(e,t){return e===void 0?t:`${lt(e)}!${t}`}function sc(e,t){let n=e.zone,r=Pr(n,t(e.sheetId)),i=e.parts;return e.parts.length===1&&Nr(r)>1?i=[e.parts[0],e.parts[0]]:e.parts.length===2&&Nr(r)===1&&(i=[e.parts[0]]),{unboundedZone:n,zone:r,parts:i,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function cc(e,t){let n=e.xc,{xc:r,sheetName:i}=ac(n),a=ir(r);return sc({zone:a,parts:_c(r,a),sheetId:e.sheetId,prefixSheet:!!i,invalidSheetName:e.invalidSheetName},t)}function lc(e){let t={left:-1,top:-1,right:-1,bottom:-1};return{sheetId:``,zone:t,unboundedZone:t,parts:[],invalidXc:e,prefixSheet:!1}}function uc(e){return Mr(e.unboundedZone)}function dc(e){return jr(e.unboundedZone)}function fc(e,t,n,r={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||e.zone.left<0||e.zone.top<0)return j.InvalidReference;let i=e.sheetId!==t||e.invalidSheetName||e.prefixSheet,a=``;if(i&&(a=e.invalidSheetName?lt(e.invalidSheetName):lt(n(e.sheetId))),i&&!a)return j.InvalidReference;let o=Dc(e,0,r);return e.parts&&e.parts.length===2&&(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)&&(o+=`:`,o+=Dc(e,1,r)),`${i?a+`!`:``}${o}`}function pc(e,t,n){let r=n.sheetId===e?t:n.sheetId;return{...n,sheetId:r}}function mc(e,t,n){if(!n)return;let r=e.getRangeFromSheetXC(t,n);return r.invalidSheetName||r.invalidXc?void 0:r}function hc(e,t){let n=[];for(let r of t){let t=r.dataRange;if(!e.isRangeValid(t)){n.push(r);continue}let{sheetName:i}=ac(t),a=i?`${i}!`:``,o=ir(t);if(o.bottom!==o.top&&o.left!==o.right)if(o.right)for(let e=o.left;e<=o.right;++e){let t=e===o.left?r:{yAxisId:r.yAxisId};n.push({...t,dataRange:`${a}${cr({left:e,right:e,top:o.top,bottom:o.bottom})}`})}else for(let e=o.top;e<=o.bottom;++e){let t=e===o.top?r:{yAxisId:r.yAxisId};n.push({...t,dataRange:`${a}${cr({left:o.left,right:o.right,top:e,bottom:e})}`})}else n.push(r)}return n}function gc(e){let t=[];for(let n of e)for(let e of wr(n.zone))t.push({...e,sheetId:n.sheetId});return t}function _c(e,t){let n=e.split(`:`).map(e=>{let t=tc(e);return{colFixed:t?!1:e.startsWith(`$`),rowFixed:t?e.startsWith(`$`):e.includes(`$`,1)}}),r=t.bottom===void 0,i=t.right===void 0;return r&&(n[0].rowFixed=n[0].rowFixed||n[1].rowFixed,n[1].rowFixed=n[0].rowFixed||n[1].rowFixed),i&&(n[0].colFixed=n[0].colFixed||n[1].colFixed,n[1].colFixed=n[0].colFixed||n[1].colFixed),n}function vc(e){if(sr(e.zone))return e;let t={...e.unboundedZone},n={...e.zone},r=e.parts;if(t.right!==void 0&&t.right<t.left){let e=t.right;t.right=t.left,t.left=e,n.right=n.left,n.left=e,r=[{colFixed:r[1]?.colFixed||!1,rowFixed:r[0]?.rowFixed||!1},{colFixed:r[0]?.colFixed||!1,rowFixed:r[1]?.rowFixed||!1}]}if(t.bottom!==void 0&&t.bottom<t.top){let e=t.bottom;t.bottom=t.top,t.top=e,n.bottom=n.top,n.top=e,r=[{colFixed:r[0]?.colFixed||!1,rowFixed:r[1]?.rowFixed||!1},{colFixed:r[1]?.colFixed||!1,rowFixed:r[0]?.rowFixed||!1}]}return{unboundedZone:t,zone:n,parts:r,invalidXc:e.invalidXc,prefixSheet:e.prefixSheet,invalidSheetName:e.invalidSheetName,sheetId:e.sheetId}}function yc(e){return bc.get(e.type)?.(e)}let bc=new class extends h{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};bc.add(`REMOVE_COLUMNS_ROWS`,e=>({applyChange:xc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})).add(`ADD_COLUMNS_ROWS`,e=>({applyChange:Sc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})).add(`DELETE_SHEET`,e=>({applyChange:Cc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}})).add(`RENAME_SHEET`,e=>({applyChange:wc(e),sheetId:e.sheetId,sheetName:{old:e.oldName,current:e.newName}})).add(`MOVE_RANGES`,e=>({applyChange:Tc(e),sheetId:e.sheetId,sheetName:{old:e.sheetName,current:e.sheetName}}));function xc(e){let t=e.dimension===`COL`?`left`:`top`,n=e.dimension===`COL`?`right`:`bottom`,r=e.dimension===`COL`?`columns`:`rows`,i=[...e.elements];i.sort((e,t)=>t-e);let a=dt(i);return i=>{if(i.sheetId!==e.sheetId)return{changeType:`NONE`,range:i};let o=i,s=`NONE`;for(let e of a){let a=Yt(e),c=Jt(e);if(i.zone[t]<=a&&a<=i.zone[n]){let e=Math.min(i.zone[n],c)-a+1;s=`RESIZE`,o=Ec(o,r,s,-e)}else if(i.zone[t]>=a&&i.zone[n]<=c)s=`REMOVE`,o=lc(j.InvalidReference);else if(i.zone[t]<=c&&i.zone[n]>=c){let e=c-i.zone[t]+1;s=`RESIZE`,o=Ec(o,r,s,-e),o=Ec(o,r,`MOVE`,-(i.zone[t]-a))}else a<i.zone[t]&&(s=`MOVE`,o=Ec(o,r,s,-(c-a+1)))}return{changeType:s,range:o}}}function Sc(e){let t=e.dimension===`COL`?`left`:`top`,n=e.dimension===`COL`?`right`:`bottom`,r=e.dimension===`COL`?`columns`:`rows`;return i=>{if(i.sheetId!==e.sheetId)return{changeType:`NONE`,range:i};if(e.position===`after`){if(i.zone[t]<=e.base&&e.base<i.zone[n])return{changeType:`RESIZE`,range:Ec(i,r,`RESIZE`,e.quantity)};if(e.base<i.zone[t])return{changeType:`MOVE`,range:Ec(i,r,`MOVE`,e.quantity)}}else{if(i.zone[t]<e.base&&e.base<=i.zone[n])return{changeType:`RESIZE`,range:Ec(i,r,`RESIZE`,e.quantity)};if(e.base<=i.zone[t])return{changeType:`MOVE`,range:Ec(i,r,`MOVE`,e.quantity)}}return{changeType:`NONE`,range:i}}}function Cc(e){return t=>{if(t.sheetId!==e.sheetId&&t.invalidSheetName!==e.sheetName)return{changeType:`NONE`,range:t};let n=e.sheetName;return t={...lc(j.InvalidReference),invalidSheetName:n},{changeType:`REMOVE`,range:t}}}function wc(e){return t=>{if(t.sheetId===e.sheetId)return{changeType:`CHANGE`,range:t};if(e.newName&&t.invalidSheetName===e.newName){let n=e.sheetId;return{changeType:`CHANGE`,range:{...t,sheetId:n,invalidSheetName:void 0}}}if(e.oldName&&t.invalidSheetName===e.oldName){let n=e.sheetId;return{changeType:`CHANGE`,range:{...t,sheetId:n,invalidSheetName:void 0}}}return{changeType:`NONE`,range:t}}}function Tc(e){let t=e.target[0];return n=>{if(n.sheetId!==e.sheetId||!yr(n.zone,t))return{changeType:`NONE`,range:n};let r=e.targetSheetId,i=Ec(n,`both`,`MOVE`,[e.col-t.left,e.row-t.top]),a=e.sheetId===r?i.prefixSheet:!0;return{changeType:`MOVE`,range:{...i,sheetId:r,prefixSheet:a}}}}function Ec(e,t,n,r){return{...e,unboundedZone:Er(e.unboundedZone,t,n,r),zone:Er(e.zone,t,n,r)}}function Dc(e,t,n={useBoundedReference:!1,useFixedReference:!1}){let r=e.parts[t]?.colFixed||n.useFixedReference?`$`:``,i=zn(t===0?e.zone.left:e.zone.right),a=e.parts[t]?.rowFixed||n.useFixedReference?`$`:``,o=String(t===0?e.zone.top+1:e.zone.bottom+1),s=``;return s=Mr(e.unboundedZone)&&!n.useBoundedReference?t===0&&e.unboundedZone.hasHeader?r+i+a+o:r+i:jr(e.unboundedZone)&&!n.useBoundedReference?t===0&&e.unboundedZone.hasHeader?r+i+a+o:a+o:r+i+a+o,s}function Oc(e,t){e=e.toLocaleLowerCase(),t=t.toLocaleLowerCase();let n=0,r=0,i=t.length,a=0;for(let o=0;o<i;o++)t[o]===e[a]?(a++,r+=100+r-o/200):r=0,n+=r;return a===e.length?n:0}function kc(e,t,n){let r=[];return t.forEach(t=>{let i=Oc(e,n(t));i>0&&r.push({score:i,elem:t})}),r.sort((e,t)=>t.score-e.score),r.map(e=>e.elem)}function Ac(e){let t=[];for(let n=0;n<e;n++)t.push({cells:{}});return t}function jc(e,t,n){return n.map(n=>n>=e?n+t:n)}function Mc(e,t){return e=[...e].sort((e,t)=>t-e),t.map(t=>{for(let n of e)if(t>n)t--;else if(t===n)return;return t}).filter(C)}function Nc(e,t=`Sheet`){let n=1,r=`${t}${n}`;for(;e.includes(r);)r=`${t}${n}`,n++;return r}function Pc(e,t){let n=1,r=O(`Copy of %s`,e),i=r.toString();for(;t.includes(i);)i=`${r} (${n})`,n++;return i}function Fc(e,t){return e===void 0||t===void 0?!1:st(e.trim().toUpperCase())===st(t.trim().toUpperCase())}function Ic(e,t=1){return t*(e+4)-4}function Lc(e,t,n,r){if(!t||!t.isFormula&&!t.content)return 23;let i=``;try{if(!t.isFormula){let e={format:t.format,locale:n};i=B(Ns(t.content,n),e)}}catch{i=j.GenericError}return Rc(e,i,t.style,r)}function Rc(e,t,n,r){let i=Xc(e,t,n,n?.wrapping===`wrap`?r-8:void 0).length;return Ic(Jc(n),i)+6}function zc(e,t=!1,n=!1){return`${n?`italic`:``} ${t?`bold`:``} ${e}px ${Ve}`}let Bc={};function Vc(e,t,n,r=`pt`){let i=qc(n,r);e.save(),e.font=i;let a=Hc(e,t);return e.restore(),a}function Hc(e,t){let n=e.font;return Bc[n]||(Bc[n]={}),Bc[n][t]===void 0&&(Bc[n][t]=e.measureText(t).width),Bc[n][t]}let Uc={};function Wc(e,t,n,r=`pt`){let i=qc(n,r);e.save(),e.font=i;let a=Gc(e,t);return e.restore(),a}function Gc(e,t){let n=e.font;if(Uc[n]||(Uc[n]={}),Uc[n][t]===void 0){let r=e.measureText(t),i=r.width,a=r.fontBoundingBoxAscent+r.fontBoundingBoxDescent;Uc[n][t]={width:i,height:a}}return Uc[n][t]}function Kc(e){return Math.round(e*96/72)}function qc(e,t=`pt`){return`${e.italic?`italic `:``}${e.bold?`bold`:`400`} ${(t===`pt`?Jc(e):e.fontSize)??Be}px ${Ve}`}function Jc(e){return Kc(e?.fontSize||Be)}function Yc(e,t,n,r){if(Vc(e,t,r)<=n)return[t];let i=[],a=``;for(let o of t)Vc(e,a+o,r)>n?(i.push(a),a=o):a+=o;return i.push(a),i}function Xc(e,t,n,r){n||={},gt(t)&&(t=yt(t).label);let i=[],a=t.includes(`
|
|
5
5
|
`)?t.split(`
|
|
6
|
-
`):[t];for(let t of a){let a=t.includes(` `)?t.split(` `):[t];if(!r){i.push(t);continue}let o=``,s=r;for(let t of a){let a=Yc(e,t,r,n),c=a.pop(),l=Vc(e,c,n);if(a.length)o!==``&&(i.push(o),o=``,s=r),a.forEach(e=>{i.push(e)}),o=c,s=r-l;else{let t=o===``?c:` `+c,a=Vc(e,t,n);a<=s?(o+=t,s-=a):(i.push(o),o=c,s=r-l)}}o!==``&&i.push(o)}return i}function Zc(e,t,n,r=.25){let i=1;if(n(i)>e)return i;if(n(t)<e)return t;let a=(i+t)/2,o=n(a),s=0;for(;Math.abs(o-e)>r&&s<20;)o>=e?t=(i+t)/2:i=(i+t)/2,a=(i+t)/2,o=n(a),s++;return a}function Qc(e){return Jc(e)+8}function $c(e){return e?e.toLowerCase():``}let el=/([0-9\.]*)px/;function tl(e){return Number(e.match(el)?.[1])}function nl(e,t,n){let r=Hc(e,t);if(r<=n)return t;let i=Hc(e,`…`);if(r<=i)return t;let a=t.length;for(;r>=n-i&&a-- >0;)t=t.substring(0,a),r=Hc(e,t);return t+`…`}function rl(e,t,n,r=!1,i=!1,a=tl(e.font)/10){if(e.fillText(t,n.x,n.y),!r&&!i)return;let o=e.measureText(t),s=o.width,c=o.actualBoundingBoxAscent+o.actualBoundingBoxDescent,l=o.fontBoundingBoxAscent+o.fontBoundingBoxDescent,{x:u,y:d}=n,f=d,p=d;switch(e.textAlign){case`center`:u-=s/2;break;case`right`:u-=s;break}switch(e.textBaseline){case`top`:p+=l-2*a,f+=l/2-a;break;case`middle`:p+=l/2-a;break;case`alphabetic`:p+=2*a,f-=3*a;break;case`bottom`:p=d,f-=c/2-a/2;break}r&&(e.lineWidth=a,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(u,p),e.lineTo(u+s,p),e.stroke()),i&&(e.lineWidth=a,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(u,f),e.lineTo(u+s,f),e.stroke())}function il(e,t,n,r,i=`pt`){if(Vc(e,n,r,i)<=t)return n;let a=Vc(e,`...`,r,i);if(a>=t)return``;let o=1,s=n.length,c;for(;o<=s;){let l=Math.floor((o+s)/2);c=Vc(e,n.slice(0,l),r,i),c+a>t?s=l-1:o=l+1}let l=n.slice(0,Math.max(0,o-1));return l?l+`...`:``}var al=class{smallUuid(){return window.crypto?`10000000-1000`.replace(/[01]/g,e=>{let t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)}):`xxxxxxxx-xxxx`.replace(/[xy]/g,function(e){let t=Math.random()*16|0;return(e===`x`?t:t&3|8).toString(16)})}uuidv4(){return window.crypto?`10000000-1000-4000-8000-100000000000`.replace(/[018]/g,e=>{let 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){let t=Math.random()*16|0;return(e===`x`?t:t&3|8).toString(16)})}};let ol=[`image/avif`,`image/bmp`,`image/gif`,`image/vnd.microsoft.icon`,`image/jpeg`,`image/png`,`image/tiff`,`image/webp`];function sl(e,t){let n=new Set(t.map(e=>e.left)),r=new Set(t.map(e=>e.right)),i=new Set(t.map(e=>e.top)),a=new Set(t.map(e=>e.bottom)),o=i.size===1&&a.size===1||n.size===1&&r.size===1?Or(t):[t[t.length-1]],s=o.map(e=>wr(e)).flat();return{sheetId:e,zones:t,clippedZones:o,columnsIndexes:[...new Set(s.map(e=>e.col))].sort((e,t)=>e-t),rowsIndexes:[...new Set(s.map(e=>e.row))].sort((e,t)=>e-t)}}function cl(e,t,n){let r=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-n+1,e.top),a=[];for(let o=e.left;o<=r;o+=t)for(let r=e.top;r<=i;r+=n)a.push({left:o,top:r,bottom:r+n-1,right:o+t-1});return a}function ll(e,t){if(!t.length||!t[0].length)return e;let n=t[0].length,r=t.length;return e.map(e=>cl(e,n,r)).flat()}function ul(e){let t;e[`text/html`]&&(t=dl(new DOMParser().parseFromString(e[`text/html`],`text/html`)));let n=e[`text/plain`]||``,r;if(!n.trim()){for(let t of ol)if(e[t]){r=e[t];break}}return{text:n,data:t,imageBlob:r}}function dl(e){if([...e.documentElement.attributes].some(e=>e.value.includes(`microsoft`)))return;let t=e.querySelector(`div`)?.getAttribute(`data-osheet-clipboard`);return t&&JSON.parse(t)}let fl=(e,t,n,r)=>{e.forEach(({handlerName:e,handler:i})=>{let a=t[e];a&&i.paste(n,a,r)})};function pl(e,t,n,r,i){let a,o=[],s={sheetId:e,zones:t};for(let{handlerName:c,handler:l}of r){let r=n[c];if(!r)continue;let u=l.getPasteTarget(e,t,r,i);u.figureId&&(s.figureId=u.figureId);for(let e of u.zones){if(o.push(e),a===void 0){a=e;continue}a=pr(a,e)}}return{target:s,zone:a,selectedZones:o}}let ml=(e,t,n)=>{let r={col:t[0].left,row:t[0].top};e.getBackToDefault(),e.selectZone({cell:r,zone:pr(...n)},{scrollIntoView:!1})};var hl=class{constructor(e,t){this.getters=e,this.dispatch=t}copy(e,t,n=`copyPaste`){}paste(e,t,n){}isPasteAllowed(e,t,n,r){return`Success`}isCutAllowed(e){return`Success`}getPasteTarget(e,t,n,r){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}},gl=class extends hl{copy(e,t,n=`copyPaste`){}pasteFromCopy(e,t,n,r){if(t.length===1)for(let i of ll(t,n))this.pasteZone(e,i.left,i.top,n,r);else for(let i of Yn(t))for(let t=i.left;t<=i.right;t++)for(let a=i.top;a<=i.bottom;a++)this.pasteZone(e,t,a,n,r)}pasteZone(e,t,n,r,i){}},_l=class extends gl{queuedBordersToAdd={};copy(e){let t=e.sheetId;if(e.zones.length===0)return;let{rowsIndexes:n,columnsIndexes:r}=e,i=[];for(let e of n){let n=[];for(let i of r){let r={col:i,row:e,sheetId:t};n.push(this.getters.getCellBorder(r))}i.push(n)}return{borders:i}}paste(e,t,n){let r=e.sheetId;if(n.pasteOption===`asValue`)return;let i=e.zones;if(!n.isCutOperation)this.pasteFromCopy(r,i,t.borders);else{let{left:e,top:n}=i[0];this.pasteZone(r,e,n,t.borders)}this.executeQueuedChanges(r)}pasteZone(e,t,n,r){for(let[i,a]of r.entries())for(let[r,o]of a.entries()){let a={col:t+r,row:n+i,sheetId:e};this.pasteBorder(o,a)}}pasteBorder(e,t){let n={...this.getters.getCellBorder(t),...e},r=JSON.stringify(n);this.queuedBordersToAdd[r]||(this.queuedBordersToAdd[r]=[]),this.queuedBordersToAdd[r].push(E(t))}executeQueuedChanges(e){for(let t in this.queuedBordersToAdd){let n=this.queuedBordersToAdd[t],r=JSON.parse(t),i=Yn(n,[]);this.dispatch(`SET_BORDERS_ON_TARGET`,{sheetId:e,target:i,border:r})}this.queuedBordersToAdd={}}};let vl=[`%`],yl=`+,-,*,/,:,=,<>,>=,>,<=,<,^,&`.split(`,`).concat(vl);function bl(e,t=k){e=zt(e);let n=new Xt(e),r=[],i=It.test(e)?Ml:Nl;for(;!n.isOver();){let e=Pl(n)||i(n)||wl(n,t)||Cl(n)||Tl(n)||Ol(n)||xl(n)||Fl(n)||Dl(n,t)||jl(n);e||={type:`UNKNOWN`,value:n.shift()},r.push(e)}return r}function xl(e){return e.current===`?`?(e.shift(),{type:`DEBUGGER`,value:`?`}):null}let Sl={"(":{type:`LEFT_PAREN`,value:`(`},")":{type:`RIGHT_PAREN`,value:`)`}};function Cl(e){return e.current===`(`||e.current===`)`?Sl[e.shift()]:null}function wl(e,t){return e.current===t.formulaArgSeparator?{type:`ARG_SEPARATOR`,value:e.shift()}:null}function Tl(e){for(let t of yl)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:`OPERATOR`,value:t};return null}let El=new Set(`0123456789`);function Dl(e,t){if(!El.has(e.current)&&e.current!==t.decimalSeparator)return null;let n=e.remaining().match(Fi(t.decimalSeparator));return n?(e.advanceBy(n[0].length),{type:`NUMBER`,value:n[0]}):null}function Ol(e){if(e.current===`"`){let t=e.shift(),n=t;for(;e.current&&(e.current!==t||n[n.length-1]===`\\`);)n+=e.shift();return e.current===`"`&&(n+=e.shift()),{type:`STRING`,value:n}}return null}let kl=/\p{L}|\p{N}|_|\.|!|\$/u,Al=new Set(`ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$`);function jl(e){let t=``;if(e.current===`'`){let n=e.shift();for(t+=n;e.current;)if(n=e.shift(),t+=n,n===`'`)if(e.current&&e.current===`'`)n=e.shift(),t+=n;else break;if(n!==`'`)return{type:`UNKNOWN`,value:t}}for(;e.current&&(Al.has(e.current)||e.current.match(kl));)t+=e.shift();if(t.length){let e=t;return $s.test(e)?{type:`REFERENCE`,value:e}:{type:`SYMBOL`,value:e}}return null}function Ml(e){let t=``;for(;e.current===` `||e.current&&e.current.match(It);)t+=e.shift();return t?{type:`SPACE`,value:t}:null}function Nl(e){let t=``;for(;e.current===` `;)t+=e.shift();return t?{type:`SPACE`,value:t}:null}function Pl(e){let t=0;for(;e.current===`
|
|
6
|
+
`):[t];for(let t of a){let a=t.includes(` `)?t.split(` `):[t];if(!r){i.push(t);continue}let o=``,s=r;for(let t of a){let a=Yc(e,t,r,n),c=a.pop(),l=Vc(e,c,n);if(a.length)o!==``&&(i.push(o),o=``,s=r),a.forEach(e=>{i.push(e)}),o=c,s=r-l;else{let t=o===``?c:` `+c,a=Vc(e,t,n);a<=s?(o+=t,s-=a):(i.push(o),o=c,s=r-l)}}o!==``&&i.push(o)}return i}function Zc(e,t,n,r=.25){let i=1;if(n(i)>e)return i;if(n(t)<e)return t;let a=(i+t)/2,o=n(a),s=0;for(;Math.abs(o-e)>r&&s<20;)o>=e?t=(i+t)/2:i=(i+t)/2,a=(i+t)/2,o=n(a),s++;return a}function Qc(e){return Jc(e)+8}function $c(e){return e?e.toLowerCase():``}let el=/([0-9\.]*)px/;function tl(e){return Number(e.match(el)?.[1])}function nl(e,t,n){let r=Hc(e,t);if(r<=n)return t;let i=Hc(e,`…`);if(r<=i)return t;let a=t.length;for(;r>=n-i&&a-- >0;)t=t.substring(0,a),r=Hc(e,t);return t+`…`}function rl(e,t,n,r=!1,i=!1,a=tl(e.font)/10){if(e.fillText(t,n.x,n.y),!r&&!i)return;let o=e.measureText(t),s=o.width,c=o.actualBoundingBoxAscent+o.actualBoundingBoxDescent,l=o.fontBoundingBoxAscent+o.fontBoundingBoxDescent,{x:u,y:d}=n,f=d,p=d;switch(e.textAlign){case`center`:u-=s/2;break;case`right`:u-=s;break}switch(e.textBaseline){case`top`:p+=l-2*a,f+=l/2-a;break;case`middle`:p+=l/2-a;break;case`alphabetic`:p+=2*a,f-=3*a;break;case`bottom`:p=d,f-=c/2-a/2;break}r&&(e.lineWidth=a,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(u,p),e.lineTo(u+s,p),e.stroke()),i&&(e.lineWidth=a,e.strokeStyle=e.fillStyle,e.beginPath(),e.moveTo(u,f),e.lineTo(u+s,f),e.stroke())}function il(e,t,n,r,i=`pt`){if(Vc(e,n,r,i)<=t)return n;let a=Vc(e,`...`,r,i);if(a>=t)return``;let o=1,s=n.length,c;for(;o<=s;){let l=Math.floor((o+s)/2);c=Vc(e,n.slice(0,l),r,i),c+a>t?s=l-1:o=l+1}let l=n.slice(0,Math.max(0,o-1));return l?l+`...`:``}var al=class{smallUuid(){return window.crypto?`10000000-1000`.replace(/[01]/g,e=>{let t=Number(e);return(t^crypto.getRandomValues(new Uint8Array(1))[0]&15>>t/4).toString(16)}):`xxxxxxxx-xxxx`.replace(/[xy]/g,function(e){let t=Math.random()*16|0;return(e===`x`?t:t&3|8).toString(16)})}uuidv4(){return window.crypto?`10000000-1000-4000-8000-100000000000`.replace(/[018]/g,e=>{let 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){let t=Math.random()*16|0;return(e===`x`?t:t&3|8).toString(16)})}};let ol=[`image/avif`,`image/bmp`,`image/gif`,`image/vnd.microsoft.icon`,`image/jpeg`,`image/png`,`image/tiff`,`image/webp`];function sl(e,t){let n=new Set(t.map(e=>e.left)),r=new Set(t.map(e=>e.right)),i=new Set(t.map(e=>e.top)),a=new Set(t.map(e=>e.bottom)),o=i.size===1&&a.size===1||n.size===1&&r.size===1?Or(t):[t[t.length-1]],s=o.map(e=>wr(e)).flat();return{sheetId:e,zones:t,clippedZones:o,columnsIndexes:[...new Set(s.map(e=>e.col))].sort((e,t)=>e-t),rowsIndexes:[...new Set(s.map(e=>e.row))].sort((e,t)=>e-t)}}function cl(e,t,n){let r=Math.max(e.right-t+1,e.left),i=Math.max(e.bottom-n+1,e.top),a=[];for(let o=e.left;o<=r;o+=t)for(let r=e.top;r<=i;r+=n)a.push({left:o,top:r,bottom:r+n-1,right:o+t-1});return a}function ll(e,t){if(!t.length||!t[0].length)return e;let n=t[0].length,r=t.length;return e.map(e=>cl(e,n,r)).flat()}function ul(e){let t;e[`text/html`]&&(t=dl(new DOMParser().parseFromString(e[`text/html`],`text/html`)));let n=e[`text/plain`]||``,r;if(!n.trim()){for(let t of ol)if(e[t]){r=e[t];break}}return{text:n,data:t,imageBlob:r}}function dl(e){if([...e.documentElement.attributes].some(e=>e.value.includes(`microsoft`)))return;let t=e.querySelector(`div`)?.getAttribute(`data-osheet-clipboard`);return t&&JSON.parse(t)}let fl=(e,t,n,r)=>{e.forEach(({handlerName:e,handler:i})=>{let a=t[e];a&&i.paste(n,a,r)})};function pl(e,t,n,r,i){let a,o=[],s={sheetId:e,zones:t};for(let{handlerName:c,handler:l}of r){let r=n[c];if(!r)continue;let u=l.getPasteTarget(e,t,r,i);u.figureId&&(s.figureId=u.figureId);for(let e of u.zones){if(o.push(e),a===void 0){a=e;continue}a=pr(a,e)}}return{target:s,zone:a,selectedZones:o}}let ml=(e,t,n)=>{let r={col:t[0].left,row:t[0].top};e.getBackToDefault(),e.selectZone({cell:r,zone:pr(...n)},{scrollIntoView:!1})};var hl=class{getters;dispatch;constructor(e,t){this.getters=e,this.dispatch=t}copy(e,t,n=`copyPaste`){}paste(e,t,n){}isPasteAllowed(e,t,n,r){return`Success`}isCutAllowed(e){return`Success`}getPasteTarget(e,t,n,r){return{zones:[],sheetId:e}}convertTextToClipboardData(e){}},gl=class extends hl{copy(e,t,n=`copyPaste`){}pasteFromCopy(e,t,n,r){if(t.length===1)for(let i of ll(t,n))this.pasteZone(e,i.left,i.top,n,r);else for(let i of Yn(t))for(let t=i.left;t<=i.right;t++)for(let a=i.top;a<=i.bottom;a++)this.pasteZone(e,t,a,n,r)}pasteZone(e,t,n,r,i){}},_l=class extends gl{queuedBordersToAdd={};copy(e){let t=e.sheetId;if(e.zones.length===0)return;let{rowsIndexes:n,columnsIndexes:r}=e,i=[];for(let e of n){let n=[];for(let i of r){let r={col:i,row:e,sheetId:t};n.push(this.getters.getCellBorder(r))}i.push(n)}return{borders:i}}paste(e,t,n){let r=e.sheetId;if(n.pasteOption===`asValue`)return;let i=e.zones;if(!n.isCutOperation)this.pasteFromCopy(r,i,t.borders);else{let{left:e,top:n}=i[0];this.pasteZone(r,e,n,t.borders)}this.executeQueuedChanges(r)}pasteZone(e,t,n,r){for(let[i,a]of r.entries())for(let[r,o]of a.entries()){let a={col:t+r,row:n+i,sheetId:e};this.pasteBorder(o,a)}}pasteBorder(e,t){let n={...this.getters.getCellBorder(t),...e},r=JSON.stringify(n);this.queuedBordersToAdd[r]||(this.queuedBordersToAdd[r]=[]),this.queuedBordersToAdd[r].push(E(t))}executeQueuedChanges(e){for(let t in this.queuedBordersToAdd){let n=this.queuedBordersToAdd[t],r=JSON.parse(t),i=Yn(n,[]);this.dispatch(`SET_BORDERS_ON_TARGET`,{sheetId:e,target:i,border:r})}this.queuedBordersToAdd={}}};let vl=[`%`],yl=`+,-,*,/,:,=,<>,>=,>,<=,<,^,&`.split(`,`).concat(vl);function bl(e,t=k){e=zt(e);let n=new Xt(e),r=[],i=It.test(e)?Ml:Nl;for(;!n.isOver();){let e=Pl(n)||i(n)||wl(n,t)||Cl(n)||Tl(n)||Ol(n)||xl(n)||Fl(n)||Dl(n,t)||jl(n);e||={type:`UNKNOWN`,value:n.shift()},r.push(e)}return r}function xl(e){return e.current===`?`?(e.shift(),{type:`DEBUGGER`,value:`?`}):null}let Sl={"(":{type:`LEFT_PAREN`,value:`(`},")":{type:`RIGHT_PAREN`,value:`)`}};function Cl(e){return e.current===`(`||e.current===`)`?Sl[e.shift()]:null}function wl(e,t){return e.current===t.formulaArgSeparator?{type:`ARG_SEPARATOR`,value:e.shift()}:null}function Tl(e){for(let t of yl)if(e.currentStartsWith(t))return e.advanceBy(t.length),{type:`OPERATOR`,value:t};return null}let El=new Set(`0123456789`);function Dl(e,t){if(!El.has(e.current)&&e.current!==t.decimalSeparator)return null;let n=e.remaining().match(Fi(t.decimalSeparator));return n?(e.advanceBy(n[0].length),{type:`NUMBER`,value:n[0]}):null}function Ol(e){if(e.current===`"`){let t=e.shift(),n=t;for(;e.current&&(e.current!==t||n[n.length-1]===`\\`);)n+=e.shift();return e.current===`"`&&(n+=e.shift()),{type:`STRING`,value:n}}return null}let kl=/\p{L}|\p{N}|_|\.|!|\$/u,Al=new Set(`ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789_.!$`);function jl(e){let t=``;if(e.current===`'`){let n=e.shift();for(t+=n;e.current;)if(n=e.shift(),t+=n,n===`'`)if(e.current&&e.current===`'`)n=e.shift(),t+=n;else break;if(n!==`'`)return{type:`UNKNOWN`,value:t}}for(;e.current&&(Al.has(e.current)||e.current.match(kl));)t+=e.shift();if(t.length){let e=t;return $s.test(e)?{type:`REFERENCE`,value:e}:{type:`SYMBOL`,value:e}}return null}function Ml(e){let t=``;for(;e.current===` `||e.current&&e.current.match(It);)t+=e.shift();return t?{type:`SPACE`,value:t}:null}function Nl(e){let t=``;for(;e.current===` `;)t+=e.shift();return t?{type:`SPACE`,value:t}:null}function Pl(e){let t=0;for(;e.current===`
|
|
7
7
|
`;)t++,e.shift();return t?{type:`SPACE`,value:`
|
|
8
8
|
`.repeat(t)}:null}function Fl(e){return e.currentStartsWith(j.InvalidReference)?(e.advanceBy(j.InvalidReference.length),{type:`INVALID_REFERENCE`,value:j.InvalidReference}):null}function Il(e){if(!e||typeof e!=`object`||!(!e.thousandsSeparator||typeof e.thousandsSeparator==`string`))return!1;for(let t of[`code`,`name`,`decimalSeparator`,`dateFormat`,`timeFormat`,`formulaArgSeparator`])if(!e[t]||typeof e[t]!=`string`)return!1;if(e.formulaArgSeparator===e.decimalSeparator||e.thousandsSeparator===e.decimalSeparator)return!1;try{B(1,{locale:e,format:`#,##0.00`}),B(1,{locale:e,format:e.dateFormat}),B(1,{locale:e,format:e.timeFormat})}catch{return!1}return!0}function Ll(e,t){return en(e)?Vl(e,t):Wl(e,t)}function Rl(e,t){return en(e)?Vl(e,t):Gl(e,t)}function zl(e,t){return e.startsWith(`=`)?Hl(e,t):ql(e,t)}function Bl(e,t){return en(e)?Vl(e,t):Wl(e,t)}function Vl(e,t){return Ul(e.startsWith(`+`)?`=`+e.slice(1):e,t,k)}function Hl(e,t){return Ul(e,k,t)}function Ul(e,t,n){if(t.formulaArgSeparator===n.formulaArgSeparator&&t.decimalSeparator===n.decimalSeparator)return e;let r=bl(e,t),i=``;for(let e of r)e.type===`NUMBER`?i+=e.value.replace(t.decimalSeparator,n.decimalSeparator):e.type===`ARG_SEPARATOR`?i+=n.formulaArgSeparator:i+=e.value;return i}function Wl(e,t){return t.decimalSeparator===`.`||!Li(e,t)?e:(t.thousandsSeparator&&(e=e.replaceAll(t.thousandsSeparator,``)),e.replace(t.decimalSeparator,`.`))}function Gl(e,t){if(ai(e,t)){let n=F(e,t),r=k.dateFormat;return Number.isInteger(n)||(r+=` `+k.timeFormat),B(n,{locale:k,format:r})}return Wl(e,t)}function Kl(e,t){if(t.decimalSeparator===`.`||!Li(e,k))return e;let n=fs(k);return e.replace(n,e=>e.replace(`.`,t.decimalSeparator))}function ql(e,t){if(ai(e,k)){let n=F(e,k),r=t.dateFormat;return Number.isInteger(n)||(r+=` `+t.timeFormat),B(n,{locale:t,format:r})}return Kl(e,t)}function Jl(e,t){return Zl(e,e=>Rl(e,t))}function Yl(e,t){return Zl(e,e=>zl(e,t))}function Xl(e,t){let n=b(e);return n.criterion.values=n.criterion.values.map(e=>zl(e,t)),n}function Zl(e,t){switch(e=b(e),e.type){case`CellIsRule`:switch(e.operator){case`Between`:case`NotBetween`:case`Equal`:case`NotEqual`:case`GreaterThan`:case`GreaterThanOrEqual`:case`LessThan`:case`LessThanOrEqual`:return e.values=e.values.map(e=>t(e)),e;case`BeginsWith`:case`ContainsText`:case`EndsWith`:case`NotContains`:case`IsEmpty`:case`IsNotEmpty`:return e}case`DataBarRule`:return e;case`ColorScaleRule`:return e.minimum=Ql(e.minimum,t),e.maximum=Ql(e.maximum,t),e.midpoint&&=Ql(e.midpoint,t),e;case`IconSetRule`:return e.lowerInflectionPoint.value=t(e.lowerInflectionPoint.value),e.upperInflectionPoint.value=t(e.upperInflectionPoint.value),e}}function Ql(e,t){if(!e?.value)return e;let n=t(e.type===`formula`?`=`+e.value:e.value),r=e.type===`formula`?n.slice(1):n;return{...e,value:r}}function $l(e){return e.dateFormat+` `+e.timeFormat}function eu(e){let t=!1,n=!0;return to(e,e=>(t=!0,n&&=e,n)),{foundBoolean:t,result:n}}function tu(e){let t=!1,n=!1;return to(e,e=>(t=!0,n||=e,!n)),{foundBoolean:t,result:n}}function nu(e,t){return qa(e,(e,t)=>e+t,0,t)}function ru(e){return Ka(e,(e,t)=>po(t)?e.add(t?.value):e,new Set).size}function iu(e){let t=Array(e);for(let n=0;n<e;n++)t[n]=Array(e).fill(0),t[n][n]=1;return t}function au(e){if(e.length<1||e[0].length<1)throw Error(`invertMatrix: an empty matrix cannot be inverted.`);if(e.length!==e[0].length)throw Error(`invertMatrix: only square matrices are invertible`);let t=1,n=e.length,r=iu(n),i=e.map(e=>e.slice());for(let e=0;e<n;e++){let a=i[e][e];if(a===0){for(let a=e+1;a<n;a++)if(i[e][a]!==0){ou(i,e,a),ou(r,e,a),t*=-1;break}if(a=i[e][e],a===0)return{determinant:0}}for(let t=0;t<n;t++)i[t][e]=i[t][e]/a,r[t][e]=r[t][e]/a;t*=a;for(let t=0;t<n;t++){if(t===e)continue;let a=i[e][t];for(let o=0;o<n;o++)i[o][t]-=a*i[o][e],r[o][t]-=a*r[o][e]}}return{inverted:r,determinant:t}}function ou(e,t,n){for(let r=0;r<e.length;r++){let i=e[r][t];e[r][t]=e[r][n],e[r][n]=i}}function su(e,t){if(e.length<1||t.length<1)throw Error(`multiplyMatrices: empty matrices cannot be multiplied.`);if(e.length!==t[0].length)throw Error(`multiplyMatrices: incompatible matrices size.`);let n=e[0].length,r=t.length,i=e.length,a=Array(r);for(let o=0;o<r;o++){a[o]=Array(n);for(let r=0;r<n;r++){let n=0;for(let a=0;a<i;a++)n+=e[a][r]*t[o][a];a[o][r]=n}}return a}function cu(e){if(!A(e))return e;if(!lu(e))throw Error(`The value should be a scalar or a 1x1 matrix`);return e[0][0]}function lu(e){return e.length===1&&e[0].length===1}function uu(e){return A(e)&&!lu(e)}function du(...e){let t=e[0].length;e.forEach((e,n)=>N(()=>e.length===t,O(`[[FUNCTION_NAME]] has mismatched dimensions for argument %s (%s vs %s).`,n.toString(),t.toString(),e.length.toString())))}function fu(e,t){let n=0,r=qa(e,(e,t)=>(n+=1,e+t),0,t);return La(n),r/n}function pu(e,t){let n=0;for(let r of e)if(A(r))for(let e of r)for(let t of e)typeof t.value==`number`&&(n+=1);else{let e=r?.value;!P(e)&&(typeof e!=`string`||Li(e,t)||si(e,t))&&(n+=1)}return n}function mu(e){return Ka(e,(e,t)=>t!==void 0&&t.value!==null?e+1:e,0)}function hu(e,t){let n={value:-1/0};return Wa(e,e=>{e.value>=n.value&&(n=e)},t),n.value===-1/0?{value:0}:n}function gu(e,t){let n={value:1/0};return Wa(e,e=>{e.value<=n.value&&(n=e)},t),n.value===1/0?{value:0}:n}function _u(e,t,n){let r=e[0].length?e:[S(1,t.flat().length+1)],i=r.length,a=n[0].length?n:r;return a=a.length===i?Qa(a):a,{_X:r,_newX:a}}function vu(e,t,n=!0,r=!1){let i=t.flat(),a=i.length,{_X:o}=_u(e,t,[[]]);o=o.length===a?Qa(o):o.slice(),du(o[0],i);let s=o.length,c=a-s-+!!n,l=[i],u=Qa(o.reverse()),d=[];for(let e=0;e<s;e++)if(d.push(0),n){for(let t of o[e])d[e]+=t;d[e]/=a}let f=0;if(n){for(let e of i)f+=e;f/=a}let p=u.map(e=>e.map((e,t)=>e-d[t]));n&&u.forEach(e=>e.push(1));let m=bu(u,l);if(n||m.push([0]),!r)return m;let{inverted:h}=au(su(p,Qa(p)));if(h===void 0)throw new M(O(`Matrix is not invertible`));let g=0,_=0;for(let e=0;e<a;e++){let t=i[e]-f,n=0;for(let t=0;t<s;t++){let r=p[e][t];n+=r*m[t][0]}let r=t-n;g+=r*r,_+=n*n}let v=Math.sqrt(g/c),y=_/(_+g),ee=_/s/(g/c),te=[];for(let e=0;e<s;e++)te.push(v*Math.sqrt(h[e][e]));if(n){let e=su(h,[d]),t=su(Qa([d]),e);te.push(v*Math.sqrt(t[0][0]+1/i.length))}let ne=[[m[0][0],te[0],y,ee,_],[m[1][0],te[1],v,c,g]];for(let e=2;e<s;e++)ne.push([m[e][0],te[e],``,``,``]);return n?ne.push([m[s][0],te[s],``,``,``]):ne.push([0,``,``,``,``]),ne}function yu(e,t,n,r){du(t,e),N(()=>n>=1,O(`Function [[FUNCTION_NAME]] A regression of order less than 1 cannot be possible.`));let i=[e],a=t.map(e=>S(0,n).map(t=>e**+(n-t)));r&&a.forEach(e=>e.push(1));let o=bu(a,i);return r||o.push([0]),o}function bu(e,t){let{inverted:n}=au(su(e,Qa(e)));if(n===void 0)throw new M(O(`Matrix is not invertible`));return Qa(su(n,su(e,t)))}function xu(e,t,n){return e.reduce((e,r,i)=>e+r*t**+(n-i),0)}function Su(e){return e.map(e=>e.map(e=>Math.exp(e)))}function Cu(e){return e.map(e=>e.map(e=>Math.log(e)))}function wu(e,t,n,r){let{_X:i,_newX:a}=_u(t,e,n),o=vu(i,e,r,!1),s=o.length-1,c=a.map(e=>{let t=0;for(let n=0;n<s;n++)t+=o[n][0]*e[s-n-1];return t+=o[s][0],[t]});return c.length===n.length?c:Qa(c)}function Tu(e,t,n=2){let r=[];for(let e=0;e<n-1;e++)r.push({x:t[e],y:NaN});for(let i=0;i<=e.length-n;i++){let a=0;for(let t=i;t<i+n;t++)a+=e[t];r.push({x:t[i+n-1],y:a/n})}return r}function Eu(e,t){N(()=>e.length>0&&e[0].length>0,O(`[[FUNCTION_NAME]] expects the provided values of %(argName)s to be a non-empty matrix.`,{argName:t}))}function Du(...e){if(e.length===0||e.some(e=>e.length===0))throw new Sa(O(`[[FUNCTION_NAME]] has no valid input data.`))}let Ou=`(previous)`;function ku(e,t){let{colDomain:n,rowDomain:r}=ju(e,t);return[...n,...r.slice(0,r.length-1)]}function Au(e,t){let{colDomain:n,rowDomain:r}=ju(e,t);return[...n.slice(0,n.length-1),...r]}function ju(e,t){let n=e.definition.rows.map(e=>e.nameWithGranularity),r=t.filter(e=>n.includes(e.field)),i=e.definition.columns.map(e=>e.nameWithGranularity);return{colDomain:t.filter(e=>i.includes(e.field)),rowDomain:r}}function Mu(e,t,n){return t===`column`?ju(e,n).colDomain:ju(e,n).rowDomain}function Nu(e,t){return t.find(t=>t.field===e)?.value}function Pu(e,t){let{rowDomain:n,colDomain:r}=ju(e,t);return Fu(n,e.getTableStructure().getRowTree())&&Fu(r,e.getTableStructure().getColTree())}function Fu(e,t){return Iu(e,t)!==void 0}function Iu(e,t,n){let r=t;for(let t of e){let e=r.find(e=>e.value===t.value);if(!e)return;if(e.field===n)return r;r=e.children}return r}function Lu(e,t,n){let{rowDomain:r,colDomain:i}=ju(e,n);if(Bu(e,t)===`row`){let e=r.findIndex(e=>e.field===t);if(e===-1)return n;r=r.slice(0,e+1)}else{let e=i.findIndex(e=>e.field===t);if(e===-1)return n;i=i.slice(0,e+1)}return[...r,...i]}function Ru(e,t,n){e=b(e);let r=e.find(e=>e.field===t);return r&&(r.value=n),e}function zu(e,t){return t.some(t=>t.field===e)}function Bu(e,t){if(e.definition.rows.map(e=>e.nameWithGranularity).includes(t))return`row`;if(e.definition.columns.map(e=>e.nameWithGranularity).includes(t))return`column`;throw Error(`Field ${t} not found in pivot`)}function Vu(e,t,n,r){let i=Bu(e,n),a=i===`row`?e.getTableStructure().getRowTree():e.getTableStructure().getColTree(),o=Iu(Mu(e,i,t),a,n)?.map(e=>e.value)??[],s=Nu(n,t);if(s===void 0)return;let c=o.indexOf(s);if(!(s===void 0||c===-1))return Ru(t,n,o[x(c+(r===`(previous)`?-1:1),0,o.length-1)])}function Hu(e){return e?e.map(Uu).join(`, `):``}function Uu(e){return e?`${e.field}=${e.value}`:``}function Wu(e,t){let n=e.findIndex(e=>e.field===t);if(n===-1)return``;let r=e.slice(0,n),i=e.at(-1);return Hu(i.field===t?r:[...r,i])}function Gu(e,t){let n=e.findIndex(e=>e.field===t);return n===-1?``:Hu([...e.slice(0,n),...e.slice(n+1)])}function Ku(e,t,n){let r=[...e],i=[...t];r.sort((e,t)=>n([...i,e],[...i,t]));for(let t of e)t.children=Ku(t.children,[...i,t],n);return r}let qu=new h;function Ju(e){return qu.get(e)}let Yu={normalizeFunctionValue(e){return F(e,k)},toValueAndFormat(e,t){return{value:F(e,k),format:`dd mmm yyyy`}},toFunctionValue(e){let t=R(e,k);return`DATE(${t.getFullYear()},${t.getMonth()+1},${t.getDate()})`}},Xu={normalizeFunctionValue(e){let t=F(e,k);if(t<1||t>31)throw new M(O(`%s is not a valid day of month (it should be a number between 1 and 31)`,t));return t},toValueAndFormat(e){return{value:F(e,k),format:`0`}},toFunctionValue(e){return`${e}`}},Zu={normalizeFunctionValue(e){let t=F(e,k);if(t<1||t>7)throw new M(O(`%s is not a valid day of week (it should be a number between 1 and 7)`,t));return t},toValueAndFormat(e,t){return{value:Xo[(e-1+(t||k).weekStart)%7].toString(),format:`@`}},toFunctionValue(e){return`${e}`}},Qu={normalizeFunctionValue(e){let t=F(e,k);if(t<0||t>53)throw new M(O(`%s is not a valid week (it should be a number between 0 and 53)`,t));return t},toValueAndFormat(e){return{value:F(e,k),format:`0`}},toFunctionValue(e){return`${e}`}},$u={normalizeFunctionValue(e){let t=F(e,k);if(t<1||t>12)throw new M(O(`%s is not a valid month (it should be a number between 1 and 12)`,t));return t},toValueAndFormat(e){return{value:Yo[F(e,k)-1].toString(),format:`@`}},toFunctionValue(e){return`${e}`}},ed={normalizeFunctionValue(e){return B(F(e,k),{locale:k,format:`mm/yyyy`})},toValueAndFormat(e){return{value:F(e,k),format:`mmmm yyyy`}},toFunctionValue(e){let t=R(e,k);return`DATE(${t.getFullYear()},${t.getMonth()+1},1)`}},td={normalizeFunctionValue(e){let t=F(e,k);if(t<1||t>4)throw new M(O(`%s is not a valid quarter (it should be a number between 1 and 4)`,t));return t},toValueAndFormat(e){return{value:O(`Q%(quarter_number)s`,{quarter_number:e}),format:`@`}},toFunctionValue(e){return`${e}`}},nd={normalizeFunctionValue(e){let t=F(e,k);return t>3e3?R(t,k).getFullYear():t},toValueAndFormat(e){return{value:F(e,k),format:`0`}},toFunctionValue(e){return`${e}`}},rd={normalizeFunctionValue(e){let t=F(e,k);if(t<0||t>23)throw new M(O(`%s is not a valid hour (it should be a number between 0 and 23)`,t));return t},toValueAndFormat(e){return{value:O(`%(hour_number)sh`,{hour_number:e}),format:`@`}},toFunctionValue(e){return`${e}`}},id={normalizeFunctionValue(e){let t=F(e,k);if(t<0||t>59)throw new M(O(`%s is not a valid minute (it should be a number between 0 and 59)`,t));return t},toValueAndFormat(e){return{value:O(`%(minute_number)s'`,{minute_number:e}),format:`@`}},toFunctionValue(e){return`${e}`}},ad={normalizeFunctionValue(e){let t=F(e,k);if(t<0||t>59)throw new M(O(`%s is not a valid second (it should be a number between 0 and 59)`,t));return t},toValueAndFormat(e){return{value:O(`%(second_number)s''`,{second_number:e}),format:`@`}},toFunctionValue(e){return`${e}`}};function od(e){return{normalizeFunctionValue(t){return t===null?null:e.normalizeFunctionValue(t)},toValueAndFormat(t,n){return t===null?{value:O(`(Undefined)`)}:e.toValueAndFormat(t,n)},toFunctionValue(t){return t===null?`false`:e.toFunctionValue(t)}}}qu.add(`day`,od(Yu)).add(`year`,od(nd)).add(`day_of_month`,od(Xu)).add(`iso_week_number`,od(Qu)).add(`month_number`,od($u)).add(`month`,od(ed)).add(`quarter_number`,od(td)).add(`day_of_week`,od(Zu)).add(`hour_number`,od(rd)).add(`minute_number`,od(id)).add(`second_number`,od(ad));let sd={count:O(`Count`),count_distinct:O(`Count Distinct`),bool_and:O(`Boolean And`),bool_or:O(`Boolean Or`),max:O(`Maximum`),min:O(`Minimum`),avg:O(`Average`),sum:O(`Sum`)},cd=[`max`,`min`,`avg`,`sum`,`count_distinct`,`count`],ld={integer:cd,char:cd,datetime:cd,boolean:[`count_distinct`,`count`,`bool_and`,`bool_or`]},ud={};for(let e in ld){ud[e]={};for(let t of ld[e])ud[e][t]=sd[t]}let dd={count:e=>({value:mu([e]),format:`0`}),count_distinct:e=>({value:ru([e]),format:`0`}),bool_and:e=>({value:eu([e]).result}),bool_or:e=>({value:tu([e]).result}),max:(e,t)=>hu([e],t),min:(e,t)=>gu([e],t),avg:(e,t)=>({value:fu([e],t),format:Ea(e)}),sum:(e,t)=>({value:nu([e],t),format:Ea(e)})};function fd(e){let t=Object.keys(e);if(!t.length)return 0;let n=t.map(e=>parseInt(e,10));return Math.max(...n)}let pd={year:O(`Year`),quarter:O(`Quarter & Year`),month:O(`Month & Year`),week:O(`Week & Year`),day:O(`Day`),quarter_number:O(`Quarter`),month_number:O(`Month`),iso_week_number:O(`Week`),day_of_month:O(`Day of Month`),day_of_week:O(`Day of Week`),hour_number:O(`Hour`),minute_number:O(`Minute`),second_number:O(`Second`)},md=[`date`,`datetime`];function hd(e){let[t,n]=e.split(`:`);return n?{fieldName:t,granularity:n}:{fieldName:t}}function gd(e){return md.includes(e.type)}function _d(e,t,n){let r=[e];n&&r.push(`"${n}"`);for(let{field:e,value:n,type:i}of t){if(e===`measure`){r.push(`"measure"`,`"${n}"`);continue}let{granularity:t}=hd(e),a=Sd(n,{type:i,granularity:t});r.push(`"${e}"`,a)}return r}function vd(e,t){let n=0,r=0,i=t.columns.map(e=>e.nameWithGranularity),a=t.rows.map(e=>e.nameWithGranularity);for(;e[n]!==void 0&&e[n]===a[r];)n++,r++;for(r=0;e[n]!==void 0&&e[n]===i[r];)n++,r++;return e.length===n}function yd(e,t){switch(t.type){case`HEADER`:return`=PIVOT.HEADER(${_d(e,t.domain).join(`,`)})`;case`VALUE`:return`=PIVOT.VALUE(${_d(e,t.domain,t.measure).join(`,`)})`;case`MEASURE_HEADER`:return`=PIVOT.HEADER(${_d(e,[...t.domain,{field:`measure`,value:t.measure,type:`char`}]).join(`,`)})`}return``}function bd(e,t){if(t===null||t===`null`)return null;let n=typeof t==`object`?t.value:t;if(P(n))return n;let r=typeof t==`boolean`?I(t).toLocaleLowerCase():I(t);if(r===`null`)return null;if(!wd.contains(e.type))throw new M(O(`Field %(field)s is not supported because of its type (%(type)s)`,{field:e.displayName,type:e.type}));return r.toLowerCase()===`false`?!1:wd.get(e.type)(r,e.granularity)}function xd(e,t){return Ju(t??`month`).normalizeFunctionValue(e)}function Sd(e,t){return e===null?`"null"`:Td.contains(t.type)?Td.get(t.type)(e,t.granularity):`"${e}"`}function Cd(e,t){return Ju(t??`month`).toFunctionValue(e)}let wd=new h;wd.add(`date`,xd).add(`datetime`,xd).add(`integer`,e=>F(e,k)).add(`boolean`,e=>L(e)).add(`char`,e=>I(e));let Td=new h;Td.add(`date`,Cd).add(`datetime`,Cd).add(`integer`,e=>`${F(e,k)}`).add(`boolean`,e=>L(e)?`TRUE`:`FALSE`).add(`char`,e=>`"${I(e).replace(/"/g,`\\"`)}"`);function Ed(e){return e.displayName+(e.granularity?` (${pd[e.granularity]})`:``)}function Dd(e,t,n){let{rowDomain:r,colDomain:i}=ju(e,t);if(r.length===0&&i.length===0)return n;if(r.length===0&&i.length>0)return{...n,format:(n.format||`@`)+`* `};let a=r.length-1,o=n.format||`@`;return{...n,format:`${` `.repeat(a)}${o}* `}}function Od(e,t){try{if(!t.getMeasure(e.measure))return!1;let n=t.definition.columns;for(let r=0;r<e.domain.length;r++){if(n[r].nameWithGranularity!==e.domain[r].field)return!1;let i=t.getPossibleFieldValues(n[r]).map(e=>e.value);if(!i.includes(e.domain[r].value)&&!(e.domain[r].value===null&&i.includes(``)))return!1}return!0}catch{return!1}}var kd=class extends gl{isCutAllowed(e){return e.zones.length===1?`Success`:`WrongCutSelection`}copy(e,t,n=`copyPaste`){let r=e.sheetId,{clippedZones:i,rowsIndexes:a,columnsIndexes:o}=e,s=[],c=a.length===1&&o.length===1;for(let t of a){let i=[];for(let s of o){let l={col:s,row:t,sheetId:r},u=this.getters.getCell(l),d=this.getters.getEvaluatedCell(l),f=this.getters.getPivotIdFromPosition(l),p=this.getters.getArrayFormulaSpreadingOn(l);if(n!==`shiftCells`&&f&&p){let t=this.getters.getSpreadZone(p);if((!w(p,l)||!c)&&t&&!e.zones.some(e=>yr(t,e))){let e=this.getters.getPivotCellFromPosition(l),t=yd(this.getters.getPivotFormulaId(f),e);u={id:u?.id||``,style:u?.style,format:u?.format,content:t,isFormula:!1,parsedValue:d.value}}}else if(n!==`shiftCells`&&p&&!w(p,l)){let e=a.includes(p.row)&&o.includes(p.col)?``:B(d.value,{locale:this.getters.getLocale()});u={id:u?.id||``,style:u?.style,format:d.format,content:e,isFormula:!1,parsedValue:d.value}}i.push({content:u?.content??``,style:u?.style,format:u?.format,tokens:u?.isFormula?u.compiledFormula.tokens.map(({value:e,type:t})=>({value:e,type:t})):[],border:this.getters.getCellBorder(l)||void 0,evaluatedCell:d,position:l})}s.push(i)}return{cells:s,zones:i,sheetId:e.sheetId}}isPasteAllowed(e,t,n,r){if(!n.cells)return`Success`;if(r?.isCutOperation&&r?.pasteOption!==void 0)return`WrongPasteOption`;if(t.length>1&&(n.cells.length>1||n.cells[0].length>1))return`WrongPasteSelection`;let i=n.cells.length,a=n.cells[0].length;for(let r of ll(t,n.cells))if(this.getters.doesIntersectMerge(e,r)&&(t.length>1||!this.getters.isSingleCellOrMerge(e,t[0])||i*a!==1))return`WillRemoveExistingMerge`;return`Success`}paste(e,t,n){let r=e.zones,i=e.sheetId;n.isCutOperation?this.pasteFromCut(i,r,t,n):this.pasteFromCopy(i,r,t.cells,n)}getPasteTarget(e,t,n,r){let i=n.cells[0].length,a=n.cells.length;return r?.isCutOperation?{sheetId:e,zones:[{left:t[0].left,top:t[0].top,right:t[0].left+i-1,bottom:t[0].top+a-1}]}:i===1&&a===1?{zones:[],sheetId:e}:{sheetId:e,zones:ll(t,n.cells)}}pasteFromCut(e,t,n,r){this.clearClippedZones(n);let i=t[0];this.pasteZone(e,i.left,i.top,n.cells,r)}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,n,r,i){for(let[a,o]of r.entries())for(let[r,s]of o.entries()){if(!s)continue;let o={col:t+r,row:n+a,sheetId:e};this.pasteCell(s,o,i)}}pasteCell(e,t,n){let{sheetId:r,col:i,row:a}=t,o=this.getters.getEvaluatedCell(t),s=e?.format||e.evaluatedCell.format;if(n?.pasteOption===`asValue`){this.dispatch(`UPDATE_CELL`,{...t,content:e.evaluatedCell.value?.toString()||``});return}if(n?.pasteOption===`onlyFormat`){this.dispatch(`UPDATE_CELL`,{...t,style:e?.style??null,format:s??o.format});return}let c=e?.content;e?.tokens&&e.tokens.length>0&&!n?.isCutOperation?c=this.getters.getTranslatedCellFormula(r,i-e.position.col,a-e.position.row,e.tokens):e?.tokens&&e.tokens.length>0&&(c=this.getters.getFormulaMovedInSheet(e.position.sheetId,r,e.tokens)),c!==``||e?.format||e?.style?this.dispatch(`UPDATE_CELL`,{...t,content:c,style:e?.style||null,format:e?.format}):o&&this.dispatch(`CLEAR_CELL`,t)}convertTextToClipboardData(e){let t=this.getters.getLocale(),n={cells:[]},r=[],i=0;for(let[t,n]of e.replace(/\r/g,``).split(`
|
|
9
|
-
`).entries())r.push(n.split(` `)),r[t].length>i&&(i=r[t].length);for(let e of r){let r=[];for(let n=0;n<i;n++){let i=Bl(e[n]||``,t);r.push({content:i,evaluatedCell:{formattedValue:i}})}n.cells.push(r)}return n}},Ad=class extends hl{copy(e){}},jd=class extends Ad{copy(e){let t=e.sheetId,n=this.getters.getFigure(t,e.figureId);if(!n)throw Error(`No figure for the given id: ${e.figureId}`);if(n.tag!==`chart`)return;let r={...n},i=this.getters.getChart(e.figureId);if(!i)throw Error(`No chart for the given id: ${e.figureId}`);let a=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:r,copiedChart:a}}getPasteTarget(e,t,n,r){return{zones:[],figureId:new al().smallUuid(),sheetId:e}}paste(e,t,n){if(!e.figureId)return;let{zones:r,figureId:i}=e,a=e.sheetId,{width:o,height:s}=t.copiedFigure,c=t.copiedChart.copyInSheetId(a),l=this.getters.getMaxAnchorOffset(a,s,o),{left:u,top:d}=r[0],f={x:0,y:0};u>l.col&&(u=l.col,f.x=l.offset.x),d>l.row&&(d=l.row,f.y=l.offset.y),this.dispatch(`CREATE_CHART`,{figureId:i,sheetId:a,definition:c.getDefinition(),col:u,row:d,offset:f,size:{height:s,width:o}}),n.isCutOperation&&this.dispatch(`DELETE_FIGURE`,{sheetId:t.copiedChart.sheetId,figureId:t.copiedFigure.id}),this.dispatch(`SELECT_FIGURE`,{figureId:i})}isPasteAllowed(e,t,n,r){return t.length===0?`EmptyTarget`:r?.pasteOption===void 0?`Success`:`WrongFigurePasteOption`}},Md=class extends gl{uuidGenerator=new al;queuedChanges={};copy(e){if(!e.zones.length)return;let{rowsIndexes:t,columnsIndexes:n}=e,r=e.sheetId,i=[];for(let e of t){let t=[];for(let i of n){let n=Array.from(this.getters.getRulesByCell(r,i,e));t.push({position:{col:i,row:e,sheetId:r},rules:n})}i.push(t)}return{cfRules:i}}paste(e,t,n){if(this.queuedChanges={},n.pasteOption===`asValue`)return;let r=e.zones,i=e.sheetId;n.isCutOperation?this.pasteFromCut(i,r,t):this.pasteFromCopy(i,r,t.cfRules,n),this.executeQueuedChanges()}pasteFromCut(e,t,n){let r=t[0];this.pasteZone(e,r.left,r.top,n.cfRules,{isCutOperation:!0})}pasteZone(e,t,n,r,i){for(let[a,o]of r.entries())for(let[r,s]of o.entries()){let o={col:t+r,row:n+a,sheetId:e};this.pasteCf(s,o,i?.isCutOperation)}}pasteCf(e,t,n){if(e?.rules&&e.rules.length>0){let r=E(e.position),i=E(t);for(let a of e.rules){let o=[];if(n&&o.push(r),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,a,[i],o);else{this.adaptCFRules(e.position.sheetId,a,[],o);let n=this.getCFToCopyTo(t.sheetId,a);this.adaptCFRules(t.sheetId,n,[i],[])}}}}adaptCFRules(e,t,n,r){this.queuedChanges[e]||(this.queuedChanges[e]=[]);let i=this.queuedChanges[e].find(e=>e.cf.id===t.id);i?(i.toAdd.push(...n),i.toRemove.push(...r)):this.queuedChanges[e].push({toAdd:n,toRemove:r,cf:t})}executeQueuedChanges(){for(let e in this.queuedChanges)for(let{toAdd:t,toRemove:n,cf:r}of this.queuedChanges[e]){let i=this.getters.getAdaptedCfRanges(e,r,t,n);if(i){if(i.length===0){this.dispatch(`REMOVE_CONDITIONAL_FORMAT`,{id:r.id,sheetId:e});continue}this.dispatch(`ADD_CONDITIONAL_FORMAT`,{cf:{id:r.id,rule:r.rule,stopIfTrue:r.stopIfTrue},ranges:i,sheetId:e})}}}getCFToCopyTo(e,t){let n=this.getters.getConditionalFormats(e).find(e=>e.stopIfTrue===t.stopIfTrue&&w(e.rule,t.rule)),r=this.queuedChanges[e];return!n&&r&&(n=r.find(e=>e.cf.stopIfTrue===t.stopIfTrue&&w(e.cf.rule,t.rule))?.cf),n||{...t,id:this.uuidGenerator.smallUuid(),ranges:[]}}},Nd=class extends gl{uuidGenerator=new al;queuedChanges={};copy(e){let{rowsIndexes:t,columnsIndexes:n}=e,r=e.sheetId,i=[];for(let e of t){let t=[];for(let i of n){let n={sheetId:r,col:i,row:e},a=this.getters.getValidationRuleForCell(n);t.push({position:n,rule:a})}i.push(t)}return{dvRules:i}}paste(e,t,n){if(this.queuedChanges={},n.pasteOption)return;let r=e.zones,i=e.sheetId;n.isCutOperation?this.pasteFromCut(i,r,t):this.pasteFromCopy(i,r,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,n){let r=t[0];this.pasteZone(e,r.left,r.top,n.dvRules,{isCutOperation:!0})}pasteZone(e,t,n,r,i){for(let[a,o]of r.entries())for(let[r,s]of o.entries()){let o={col:t+r,row:n+a,sheetId:e};this.pasteDataValidation(s,o,i?.isCutOperation)}}pasteDataValidation(e,t,n){if(e){let r=E(t),i=E(e.position),a=e.rule;if(!a){let e=this.getters.getValidationRuleForCell(t);e&&this.adaptDataValidationRule(t.sheetId,e,[],[r]);return}let o=[];if(n&&o.push(i),e.position.sheetId===t.sheetId){let n=this.getDataValidationRuleToCopyTo(t.sheetId,a,!1);this.adaptDataValidationRule(e.position.sheetId,n,[r],o)}else{let n=this.getters.getValidationRuleForCell(e.position);n&&this.adaptDataValidationRule(e.position.sheetId,n,[],o);let i=this.getDataValidationRuleToCopyTo(t.sheetId,a);this.adaptDataValidationRule(t.sheetId,i,[r],[])}}}getDataValidationRuleToCopyTo(e,t,n=!0){let r=this.getters.getDataValidationRules(e).find(e=>w(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking),i=this.queuedChanges[e];return!r&&i&&(r=i.find(e=>w(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking)?.rule),r||{...t,id:n?this.uuidGenerator.smallUuid():t.id,ranges:[]}}adaptDataValidationRule(e,t,n,r){this.queuedChanges[e]||(this.queuedChanges[e]=[]);let i=this.queuedChanges[e].find(e=>e.rule.id===t.id);i?(i.toAdd.push(...n),i.toRemove.push(...r)):this.queuedChanges[e].push({toAdd:n,toRemove:r,rule:t})}executeQueuedChanges(){for(let e in this.queuedChanges)for(let{toAdd:t,toRemove:n,rule:r}of this.queuedChanges[e]){let i=Yn([...Yn(r.ranges.map(e=>e.zone),n),...t],[]);if(i.length===0){this.dispatch(`REMOVE_DATA_VALIDATION_RULE`,{sheetId:e,id:r.id});continue}this.dispatch(`ADD_DATA_VALIDATION_RULE`,{rule:{id:r.id,criterion:r.criterion,isBlocking:r.isBlocking},ranges:i.map(t=>this.getters.getRangeDataFromZone(e,t)),sheetId:e})}}},Pd=class extends Ad{copy(e){let t=e.sheetId,n=this.getters.getFigure(t,e.figureId);if(!n)throw Error(`No figure for the given id: ${e.figureId}`);let r={...n};if(n.tag!==`image`)return;let i=b(this.getters.getImage(e.figureId));return{figureId:e.figureId,copiedFigure:r,copiedImage:i,sheetId:t}}getPasteTarget(e,t,n,r){return{sheetId:e,zones:[],figureId:new al().smallUuid()}}paste(e,t,n){if(!e.figureId)return;let{zones:r,figureId:i}=e,a=this.getters.getActiveSheetId(),{width:o,height:s}=t.copiedFigure,c=b(t.copiedImage),l=this.getters.getMaxAnchorOffset(a,s,o),{left:u,top:d}=r[0],f={x:0,y:0};u>l.col&&(u=l.col,f.x=l.offset.x),d>l.row&&(d=l.row,f.y=l.offset.y),this.dispatch(`CREATE_IMAGE`,{figureId:i,sheetId:a,col:u,row:d,offset:f,size:{height:s,width:o},definition:c}),n.isCutOperation&&this.dispatch(`DELETE_FIGURE`,{sheetId:t.sheetId,figureId:t.copiedFigure.id}),this.dispatch(`SELECT_FIGURE`,{figureId:i})}isPasteAllowed(e,t,n,r){return t.length===0?`EmptyTarget`:r?.pasteOption===void 0?`Success`:`WrongFigurePasteOption`}},Fd=class extends gl{copy(e){let t=this.getters.getActiveSheetId(),{rowsIndexes:n,columnsIndexes:r}=e,i=[];for(let e of n){let n=[];for(let i of r){let r={col:i,row:e,sheetId:t};n.push(this.getters.getMerge(r))}i.push(n)}return{merges:i,sheetId:t}}paste(e,t,n){if(n.isCutOperation){let e=t.merges.flat().filter(C);this.dispatch(`REMOVE_MERGE`,{sheetId:t.sheetId,target:e})}this.pasteFromCopy(e.sheetId,e.zones,t.merges,n)}pasteZone(e,t,n,r){for(let[i,a]of r.entries())for(let[r,o]of a.entries()){let a={col:t+r,row:n+i,sheetId:e};this.pasteMerge(o,a)}}pasteMerge(e,t){if(!e||this.getters.isInMerge(t))return;let{sheetId:n,col:r,row:i}=t;this.dispatch(`ADD_MERGE`,{sheetId:n,force:!0,target:[{left:r,top:i,right:r+e.right-e.left,bottom:i+e.bottom-e.top}]})}},Id=class extends gl{copy(e){return{zones:e.clippedZones,sheetId:e.sheetId}}paste(e,t,n){if(n.isCutOperation){let n=e.zones[0];this.dispatch(`MOVE_RANGES`,{target:t.zones,sheetId:t.sheetId,sheetName:this.getters.getSheetName(t.sheetId),targetSheetId:e.sheetId,col:n.left,row:n.top})}}},Ld=class extends gl{isPasteAllowed(e,t,n,r){if(!(`cells`in n))return`Success`;let{xSplit:i,ySplit:a}=this.getters.getPaneDivisions(e);for(let e of ll(t,n.cells))if(e.left<i&&e.right>=i||e.top<a&&e.bottom>=a)return`FrozenPaneOverlap`;return`Success`}},Rd=class extends gl{copy(e,t,n=`copyPaste`){let r=e.sheetId,{rowsIndexes:i,columnsIndexes:a,zones:o}=e,s=new Set,c=[];for(let e of i){let l=[];c.push(l);for(let c of a){let a={col:c,row:e,sheetId:r},u=this.getters.getTable(a);if(!u){l.push({});continue}let d=this.getters.getCoreTable(a),f=d?.range.zone,p;if(!s.has(u.id)&&d&&f&&o.some(e=>yr(f,e))){s.add(u.id);let{numberOfRows:e}=br(f);for(let n=f.top;n<=f.bottom;n++)!t&&!i.includes(n)&&e--;let n=d.range,r=this.getters.extendRange(d.range,`ROW`,n.zone.top+e-1-n.zone.bottom);p={range:this.getters.getRangeData(r),config:d.config,type:d.type}}n!==`shiftCells`&&l.push({table:p,style:this.getTableStyleToCopy(a),isWholeTableCopied:s.has(u.id)})}}return{tableCells:c,sheetId:e.sheetId}}getTableStyleToCopy(e){let t=this.getters.getCellTableStyle(e),n=this.getters.getCellStyle(e),r=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...Pt(n)},border:{...r,...Pt(i)}}}paste(e,t,n){let r=e.zones,i=e.sheetId;n.isCutOperation?this.pasteFromCut(i,r,t,n):this.pasteFromCopy(i,r,t.tableCells,n)}pasteFromCut(e,t,n,r){for(let e of n.tableCells)for(let t of e)t.table&&this.dispatch(`REMOVE_TABLE`,{sheetId:n.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});let i=t[0];this.pasteZone(e,i.left,i.top,n.tableCells,r)}pasteZone(e,t,n,r,i){for(let a=0;a<r.length;a++){let o=r[a];for(let r=0;r<o.length;r++){let s=o[r];if(!s)continue;let c={col:t+r,row:n+a,sheetId:e};this.pasteTableCell(e,s,c,i)}}if(r.length===1)for(let i=0;i<r[0].length;i++)this.dispatch(`AUTOFILL_TABLE_COLUMN`,{col:t+i,row:n,sheetId:e})}pasteTableCell(e,t,n,r){if(t.table&&!r?.pasteOption){let{range:r}=t.table,i=br(this.getters.getRangeFromRangeData(r).zone),a={left:n.col,top:n.row,right:n.col+i.numberOfCols-1,bottom:n.row+i.numberOfRows-1};this.dispatch(`CREATE_TABLE`,{sheetId:n.sheetId,ranges:[this.getters.getRangeDataFromZone(e,a)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(n)||r?.pasteOption===`asValue`||(!r?.pasteOption&&!t.isWholeTableCopied||r?.pasteOption===`onlyFormat`)&&(t.style?.style&&this.dispatch(`UPDATE_CELL`,{...n,style:t.style.style}),t.style?.border&&this.dispatch(`SET_BORDER`,{...n,border:t.style.border}))}};let zd={figureHandlers:new h,cellHandlers:new h};zd.figureHandlers.add(`chart`,jd).add(`image`,Pd),zd.cellHandlers.add(`dataValidation`,Nd).add(`cell`,kd).add(`sheet`,Ld).add(`merge`,Fd).add(`border`,_l).add(`table`,Rd).add(`conditionalFormat`,Md).add(`references`,Id);function Bd(e,t){return t.type===`REMOVE_COLUMNS_ROWS`?fr(e,t.dimension===`COL`?`left`:`top`,t.elements):t.type===`ADD_COLUMNS_ROWS`?lr(e,t.dimension===`COL`?`left`:`top`,t.base,t.position,t.quantity):e}function Vd(e,t){let n=t.type===`DELETE_SHEET`&&t.sheetId;if(`sheetId`in t&&e._sheetId!==t.sheetId)return e;{let r=Bd(e._zone,t);if(r&&n!==e._sheetId)return{...e,_zone:r}}}var Hd=class{subscriptions={};on(e,t,n){if(!n)throw Error(`Missing callback`);this.subscriptions[e]||(this.subscriptions[e]=[]),this.subscriptions[e].push({owner:t,callback:n})}trigger(e,t){let n=this.subscriptions[e]||[];for(let e=0,r=n.length;e<r;e++){let r=n[e];r.callback.call(r.owner,t)}}off(e,t){let n=this.subscriptions[e];n&&(this.subscriptions[e]=n.filter(e=>e.owner!==t))}clear(){this.subscriptions={}}},Ud=class extends Hd{dependencies=new Map;factory=new Wd(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw 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()}},Wd=class{pendingBuilds=new Set;constructor(e){this.get=e}build(e,...t){if(this.pendingBuilds.has(e))throw Error(`Circular dependency detected: ${[...this.pendingBuilds,e].map(e=>e.name).join(` -> `)}`);this.pendingBuilds.add(e);let n=new e(this.get,...t);return this.pendingBuilds.delete(e),n}};function Gd(e){class t{constructor(t){throw Error(`This is a abstract store for ${e}, it cannot be instantiated.
|
|
9
|
+
`).entries())r.push(n.split(` `)),r[t].length>i&&(i=r[t].length);for(let e of r){let r=[];for(let n=0;n<i;n++){let i=Bl(e[n]||``,t);r.push({content:i,evaluatedCell:{formattedValue:i}})}n.cells.push(r)}return n}},Ad=class extends hl{copy(e){}},jd=class extends Ad{copy(e){let t=e.sheetId,n=this.getters.getFigure(t,e.figureId);if(!n)throw Error(`No figure for the given id: ${e.figureId}`);if(n.tag!==`chart`)return;let r={...n},i=this.getters.getChart(e.figureId);if(!i)throw Error(`No chart for the given id: ${e.figureId}`);let a=i.copyInSheetId(t);return{figureId:e.figureId,copiedFigure:r,copiedChart:a}}getPasteTarget(e,t,n,r){return{zones:[],figureId:new al().smallUuid(),sheetId:e}}paste(e,t,n){if(!e.figureId)return;let{zones:r,figureId:i}=e,a=e.sheetId,{width:o,height:s}=t.copiedFigure,c=t.copiedChart.copyInSheetId(a),l=this.getters.getMaxAnchorOffset(a,s,o),{left:u,top:d}=r[0],f={x:0,y:0};u>l.col&&(u=l.col,f.x=l.offset.x),d>l.row&&(d=l.row,f.y=l.offset.y),this.dispatch(`CREATE_CHART`,{figureId:i,sheetId:a,definition:c.getDefinition(),col:u,row:d,offset:f,size:{height:s,width:o}}),n.isCutOperation&&this.dispatch(`DELETE_FIGURE`,{sheetId:t.copiedChart.sheetId,figureId:t.copiedFigure.id}),this.dispatch(`SELECT_FIGURE`,{figureId:i})}isPasteAllowed(e,t,n,r){return t.length===0?`EmptyTarget`:r?.pasteOption===void 0?`Success`:`WrongFigurePasteOption`}},Md=class extends gl{uuidGenerator=new al;queuedChanges={};copy(e){if(!e.zones.length)return;let{rowsIndexes:t,columnsIndexes:n}=e,r=e.sheetId,i=[];for(let e of t){let t=[];for(let i of n){let n=Array.from(this.getters.getRulesByCell(r,i,e));t.push({position:{col:i,row:e,sheetId:r},rules:n})}i.push(t)}return{cfRules:i}}paste(e,t,n){if(this.queuedChanges={},n.pasteOption===`asValue`)return;let r=e.zones,i=e.sheetId;n.isCutOperation?this.pasteFromCut(i,r,t):this.pasteFromCopy(i,r,t.cfRules,n),this.executeQueuedChanges()}pasteFromCut(e,t,n){let r=t[0];this.pasteZone(e,r.left,r.top,n.cfRules,{isCutOperation:!0})}pasteZone(e,t,n,r,i){for(let[a,o]of r.entries())for(let[r,s]of o.entries()){let o={col:t+r,row:n+a,sheetId:e};this.pasteCf(s,o,i?.isCutOperation)}}pasteCf(e,t,n){if(e?.rules&&e.rules.length>0){let r=E(e.position),i=E(t);for(let a of e.rules){let o=[];if(n&&o.push(r),e.position.sheetId===t.sheetId)this.adaptCFRules(e.position.sheetId,a,[i],o);else{this.adaptCFRules(e.position.sheetId,a,[],o);let n=this.getCFToCopyTo(t.sheetId,a);this.adaptCFRules(t.sheetId,n,[i],[])}}}}adaptCFRules(e,t,n,r){this.queuedChanges[e]||(this.queuedChanges[e]=[]);let i=this.queuedChanges[e].find(e=>e.cf.id===t.id);i?(i.toAdd.push(...n),i.toRemove.push(...r)):this.queuedChanges[e].push({toAdd:n,toRemove:r,cf:t})}executeQueuedChanges(){for(let e in this.queuedChanges)for(let{toAdd:t,toRemove:n,cf:r}of this.queuedChanges[e]){let i=this.getters.getAdaptedCfRanges(e,r,t,n);if(i){if(i.length===0){this.dispatch(`REMOVE_CONDITIONAL_FORMAT`,{id:r.id,sheetId:e});continue}this.dispatch(`ADD_CONDITIONAL_FORMAT`,{cf:{id:r.id,rule:r.rule,stopIfTrue:r.stopIfTrue},ranges:i,sheetId:e})}}}getCFToCopyTo(e,t){let n=this.getters.getConditionalFormats(e).find(e=>e.stopIfTrue===t.stopIfTrue&&w(e.rule,t.rule)),r=this.queuedChanges[e];return!n&&r&&(n=r.find(e=>e.cf.stopIfTrue===t.stopIfTrue&&w(e.cf.rule,t.rule))?.cf),n||{...t,id:this.uuidGenerator.smallUuid(),ranges:[]}}},Nd=class extends gl{uuidGenerator=new al;queuedChanges={};copy(e){let{rowsIndexes:t,columnsIndexes:n}=e,r=e.sheetId,i=[];for(let e of t){let t=[];for(let i of n){let n={sheetId:r,col:i,row:e},a=this.getters.getValidationRuleForCell(n);t.push({position:n,rule:a})}i.push(t)}return{dvRules:i}}paste(e,t,n){if(this.queuedChanges={},n.pasteOption)return;let r=e.zones,i=e.sheetId;n.isCutOperation?this.pasteFromCut(i,r,t):this.pasteFromCopy(i,r,t.dvRules),this.executeQueuedChanges()}pasteFromCut(e,t,n){let r=t[0];this.pasteZone(e,r.left,r.top,n.dvRules,{isCutOperation:!0})}pasteZone(e,t,n,r,i){for(let[a,o]of r.entries())for(let[r,s]of o.entries()){let o={col:t+r,row:n+a,sheetId:e};this.pasteDataValidation(s,o,i?.isCutOperation)}}pasteDataValidation(e,t,n){if(e){let r=E(t),i=E(e.position),a=e.rule;if(!a){let e=this.getters.getValidationRuleForCell(t);e&&this.adaptDataValidationRule(t.sheetId,e,[],[r]);return}let o=[];if(n&&o.push(i),e.position.sheetId===t.sheetId){let n=this.getDataValidationRuleToCopyTo(t.sheetId,a,!1);this.adaptDataValidationRule(e.position.sheetId,n,[r],o)}else{let n=this.getters.getValidationRuleForCell(e.position);n&&this.adaptDataValidationRule(e.position.sheetId,n,[],o);let i=this.getDataValidationRuleToCopyTo(t.sheetId,a);this.adaptDataValidationRule(t.sheetId,i,[r],[])}}}getDataValidationRuleToCopyTo(e,t,n=!0){let r=this.getters.getDataValidationRules(e).find(e=>w(t.criterion,e.criterion)&&t.isBlocking===e.isBlocking),i=this.queuedChanges[e];return!r&&i&&(r=i.find(e=>w(t.criterion,e.rule.criterion)&&t.isBlocking===e.rule.isBlocking)?.rule),r||{...t,id:n?this.uuidGenerator.smallUuid():t.id,ranges:[]}}adaptDataValidationRule(e,t,n,r){this.queuedChanges[e]||(this.queuedChanges[e]=[]);let i=this.queuedChanges[e].find(e=>e.rule.id===t.id);i?(i.toAdd.push(...n),i.toRemove.push(...r)):this.queuedChanges[e].push({toAdd:n,toRemove:r,rule:t})}executeQueuedChanges(){for(let e in this.queuedChanges)for(let{toAdd:t,toRemove:n,rule:r}of this.queuedChanges[e]){let i=Yn([...Yn(r.ranges.map(e=>e.zone),n),...t],[]);if(i.length===0){this.dispatch(`REMOVE_DATA_VALIDATION_RULE`,{sheetId:e,id:r.id});continue}this.dispatch(`ADD_DATA_VALIDATION_RULE`,{rule:{id:r.id,criterion:r.criterion,isBlocking:r.isBlocking},ranges:i.map(t=>this.getters.getRangeDataFromZone(e,t)),sheetId:e})}}},Pd=class extends Ad{copy(e){let t=e.sheetId,n=this.getters.getFigure(t,e.figureId);if(!n)throw Error(`No figure for the given id: ${e.figureId}`);let r={...n};if(n.tag!==`image`)return;let i=b(this.getters.getImage(e.figureId));return{figureId:e.figureId,copiedFigure:r,copiedImage:i,sheetId:t}}getPasteTarget(e,t,n,r){return{sheetId:e,zones:[],figureId:new al().smallUuid()}}paste(e,t,n){if(!e.figureId)return;let{zones:r,figureId:i}=e,a=this.getters.getActiveSheetId(),{width:o,height:s}=t.copiedFigure,c=b(t.copiedImage),l=this.getters.getMaxAnchorOffset(a,s,o),{left:u,top:d}=r[0],f={x:0,y:0};u>l.col&&(u=l.col,f.x=l.offset.x),d>l.row&&(d=l.row,f.y=l.offset.y),this.dispatch(`CREATE_IMAGE`,{figureId:i,sheetId:a,col:u,row:d,offset:f,size:{height:s,width:o},definition:c}),n.isCutOperation&&this.dispatch(`DELETE_FIGURE`,{sheetId:t.sheetId,figureId:t.copiedFigure.id}),this.dispatch(`SELECT_FIGURE`,{figureId:i})}isPasteAllowed(e,t,n,r){return t.length===0?`EmptyTarget`:r?.pasteOption===void 0?`Success`:`WrongFigurePasteOption`}},Fd=class extends gl{copy(e){let t=this.getters.getActiveSheetId(),{rowsIndexes:n,columnsIndexes:r}=e,i=[];for(let e of n){let n=[];for(let i of r){let r={col:i,row:e,sheetId:t};n.push(this.getters.getMerge(r))}i.push(n)}return{merges:i,sheetId:t}}paste(e,t,n){if(n.isCutOperation){let e=t.merges.flat().filter(C);this.dispatch(`REMOVE_MERGE`,{sheetId:t.sheetId,target:e})}this.pasteFromCopy(e.sheetId,e.zones,t.merges,n)}pasteZone(e,t,n,r){for(let[i,a]of r.entries())for(let[r,o]of a.entries()){let a={col:t+r,row:n+i,sheetId:e};this.pasteMerge(o,a)}}pasteMerge(e,t){if(!e||this.getters.isInMerge(t))return;let{sheetId:n,col:r,row:i}=t;this.dispatch(`ADD_MERGE`,{sheetId:n,force:!0,target:[{left:r,top:i,right:r+e.right-e.left,bottom:i+e.bottom-e.top}]})}},Id=class extends gl{copy(e){return{zones:e.clippedZones,sheetId:e.sheetId}}paste(e,t,n){if(n.isCutOperation){let n=e.zones[0];this.dispatch(`MOVE_RANGES`,{target:t.zones,sheetId:t.sheetId,sheetName:this.getters.getSheetName(t.sheetId),targetSheetId:e.sheetId,col:n.left,row:n.top})}}},Ld=class extends gl{isPasteAllowed(e,t,n,r){if(!(`cells`in n))return`Success`;let{xSplit:i,ySplit:a}=this.getters.getPaneDivisions(e);for(let e of ll(t,n.cells))if(e.left<i&&e.right>=i||e.top<a&&e.bottom>=a)return`FrozenPaneOverlap`;return`Success`}},Rd=class extends gl{copy(e,t,n=`copyPaste`){let r=e.sheetId,{rowsIndexes:i,columnsIndexes:a,zones:o}=e,s=new Set,c=[];for(let e of i){let l=[];c.push(l);for(let c of a){let a={col:c,row:e,sheetId:r},u=this.getters.getTable(a);if(!u){l.push({});continue}let d=this.getters.getCoreTable(a),f=d?.range.zone,p;if(!s.has(u.id)&&d&&f&&o.some(e=>yr(f,e))){s.add(u.id);let{numberOfRows:e}=br(f);for(let n=f.top;n<=f.bottom;n++)!t&&!i.includes(n)&&e--;let n=d.range,r=this.getters.extendRange(d.range,`ROW`,n.zone.top+e-1-n.zone.bottom);p={range:this.getters.getRangeData(r),config:d.config,type:d.type}}n!==`shiftCells`&&l.push({table:p,style:this.getTableStyleToCopy(a),isWholeTableCopied:s.has(u.id)})}}return{tableCells:c,sheetId:e.sheetId}}getTableStyleToCopy(e){let t=this.getters.getCellTableStyle(e),n=this.getters.getCellStyle(e),r=this.getters.getCellTableBorder(e),i=this.getters.getCellBorder(e);return{style:{...t,...Pt(n)},border:{...r,...Pt(i)}}}paste(e,t,n){let r=e.zones,i=e.sheetId;n.isCutOperation?this.pasteFromCut(i,r,t,n):this.pasteFromCopy(i,r,t.tableCells,n)}pasteFromCut(e,t,n,r){for(let e of n.tableCells)for(let t of e)t.table&&this.dispatch(`REMOVE_TABLE`,{sheetId:n.sheetId,target:[this.getters.getRangeFromRangeData(t.table.range).zone]});let i=t[0];this.pasteZone(e,i.left,i.top,n.tableCells,r)}pasteZone(e,t,n,r,i){for(let a=0;a<r.length;a++){let o=r[a];for(let r=0;r<o.length;r++){let s=o[r];if(!s)continue;let c={col:t+r,row:n+a,sheetId:e};this.pasteTableCell(e,s,c,i)}}if(r.length===1)for(let i=0;i<r[0].length;i++)this.dispatch(`AUTOFILL_TABLE_COLUMN`,{col:t+i,row:n,sheetId:e})}pasteTableCell(e,t,n,r){if(t.table&&!r?.pasteOption){let{range:r}=t.table,i=br(this.getters.getRangeFromRangeData(r).zone),a={left:n.col,top:n.row,right:n.col+i.numberOfCols-1,bottom:n.row+i.numberOfRows-1};this.dispatch(`CREATE_TABLE`,{sheetId:n.sheetId,ranges:[this.getters.getRangeDataFromZone(e,a)],config:t.table.config,tableType:t.table.type})}this.getters.getCoreTable(n)||r?.pasteOption===`asValue`||(!r?.pasteOption&&!t.isWholeTableCopied||r?.pasteOption===`onlyFormat`)&&(t.style?.style&&this.dispatch(`UPDATE_CELL`,{...n,style:t.style.style}),t.style?.border&&this.dispatch(`SET_BORDER`,{...n,border:t.style.border}))}};let zd={figureHandlers:new h,cellHandlers:new h};zd.figureHandlers.add(`chart`,jd).add(`image`,Pd),zd.cellHandlers.add(`dataValidation`,Nd).add(`cell`,kd).add(`sheet`,Ld).add(`merge`,Fd).add(`border`,_l).add(`table`,Rd).add(`conditionalFormat`,Md).add(`references`,Id);function Bd(e,t){return t.type===`REMOVE_COLUMNS_ROWS`?fr(e,t.dimension===`COL`?`left`:`top`,t.elements):t.type===`ADD_COLUMNS_ROWS`?lr(e,t.dimension===`COL`?`left`:`top`,t.base,t.position,t.quantity):e}function Vd(e,t){let n=t.type===`DELETE_SHEET`&&t.sheetId;if(`sheetId`in t&&e._sheetId!==t.sheetId)return e;{let r=Bd(e._zone,t);if(r&&n!==e._sheetId)return{...e,_zone:r}}}var Hd=class{subscriptions={};on(e,t,n){if(!n)throw Error(`Missing callback`);this.subscriptions[e]||(this.subscriptions[e]=[]),this.subscriptions[e].push({owner:t,callback:n})}trigger(e,t){let n=this.subscriptions[e]||[];for(let e=0,r=n.length;e<r;e++){let r=n[e];r.callback.call(r.owner,t)}}off(e,t){let n=this.subscriptions[e];n&&(this.subscriptions[e]=n.filter(e=>e.owner!==t))}clear(){this.subscriptions={}}},Ud=class extends Hd{dependencies=new Map;factory=new Wd(this.get.bind(this));inject(e,t){if(this.dependencies.has(e)&&this.dependencies.get(e)!==t)throw 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()}},Wd=class{get;pendingBuilds=new Set;constructor(e){this.get=e}build(e,...t){if(this.pendingBuilds.has(e))throw Error(`Circular dependency detected: ${[...this.pendingBuilds,e].map(e=>e.name).join(` -> `)}`);this.pendingBuilds.add(e);let n=new e(this.get,...t);return this.pendingBuilds.delete(e),n}};function Gd(e){class t{constructor(t){throw Error(`This is a abstract store for ${e}, it cannot be instantiated.
|
|
10
10
|
Did you forget to inject your store instance?
|
|
11
11
|
|
|
12
12
|
const stores = useStoreProvider();
|
|
13
13
|
stores.inject(MyMetaStore, storeInstance);
|
|
14
|
-
`)}}return t}var Kd=class{disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach(e=>e())}};function qd(){let e=(0,t.useEnv)();if(e.__spreadsheet_stores__ instanceof Ud)return e.__spreadsheet_stores__;let n=new Ud;return(0,t.useSubEnv)({__spreadsheet_stores__:n,getStore:e=>Xd(n.get(e),()=>n.trigger(`store-updated`))}),n}function V(e){let n=Zd((0,t.useEnv)());return Yd(n,n.get(e))}function Jd(e,...n){let r=Zd((0,t.useEnv)()),i=r.instantiate(e,...n);return(0,t.onWillUnmount)(()=>i.dispose()),Yd(r,i)}function Yd(e,n){let r=(0,t.useComponent)();return Xd(n,()=>{(0,t.status)(r)===`mounted`&&e.trigger(`store-updated`)})}function Xd(e,t){return new Proxy(e,{get(n,r,i){let a=n,o=Reflect.get(n,r,a);return e.mutators?.includes(r)?new Proxy(o,{apply(e,n,r){Reflect.apply(e,a,r)!==`noStateChange`&&t()}}):o}})}function Zd(e){let t=e.__spreadsheet_stores__;if(!(t instanceof Ud))throw Error(`No store provider found. Did you forget to call useStoreProvider()?`);return t}let Qd=Gd(`Model`);var $d=class{mutators=[`register`,`unRegister`,`drawLayer`];renderers={};register(e){if(e.renderingLayers.length)for(let t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(let t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter(t=>t!==e)}drawLayer(e,t){let n=this.renderers[t];if(n)for(let r of n)e.ctx.save(),r.drawLayer(e,t),e.ctx.restore();return`noStateChange`}},ef=class extends Kd{model=this.get(Qd);getters=this.model.getters;renderer=this.get($d);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){}};let tf={id:`void-composer`,get editionMode(){return`inactive`},startEdition:()=>{throw Error(`No composer is registered`)},stopEdition:()=>{throw Error(`No composer is registered`)},setCurrentContent:()=>{throw Error(`No composer is registered`)}};var nf=class extends ef{mutators=[`focusComposer`,`focusActiveComposer`];activeComposer=tf;_focusMode=`inactive`;get focusMode(){return this.activeComposer.editionMode===`inactive`?`inactive`:this._focusMode}focusComposer(e,t){if(this.activeComposer=e,this.getters.isReadonly())return`noStateChange`;this._focusMode=t.focusMode||`contentFocus`,this._focusMode!==`inactive`&&this.setComposerContent(t)}focusActiveComposer(e){if(this.getters.isReadonly())return`noStateChange`;if(!this.activeComposer)throw Error(`No composer is registered`);this._focusMode=e.focusMode||`contentFocus`,this._focusMode!==`inactive`&&this.setComposerContent(e)}setComposerContent({content:e,selection:t}){this.activeComposer.editionMode===`inactive`?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}};let rf={},af=0;function H(e,...t){let n=`__sheet__${af++}`;return sf(n,String.raw(e,...t)),cf(n),n}function of(e){let t=e.split(/(\{|\}|;)/).map(e=>e.trim()),n=[],r=[],i=[];function a(e,t){let r=[];for(let i of n[e]){let o=t&&t+` `+i||i;o.includes(`&`)&&(o=i.replace(/&/g,t||``)),e<n.length-1&&(o=a(e+1,o)),r.push(o)}return r.join(`, `)}function o(){i.length&&(r.push(a(0)+` {`),r.push(...i),r.push(`}`),i=[])}for(;t.length;){let e=t.shift();e===`}`?(o(),n.pop()):(t[0]===`{`&&(o(),n.push(e.split(/\s*,\s*/)),t.shift()),t[0]===`;`&&i.push(` `+e+`;`))}return r.join(`
|
|
15
|
-
`)}function sf(e,t){let n=document.createElement(`style`);n.textContent=of(t),rf[e]=n}function cf(e){let t=rf[e];t.setAttribute(`component`,e),document.head.appendChild(t)}function lf({strikethrough:e,underline:t}){return!e&&!t?`none`:`${e?`line-through`:``} ${t?`underline`:``}`}function uf(e){let t=df(e);return e&&e.fillColor&&(t.background=e.fillColor),t}function df(e){let t={};if(!e)return t;if(e.bold&&(t[`font-weight`]=`bold`),e.italic&&(t[`font-style`]=`italic`),e.strikethrough||e.underline){let n=e.strikethrough?`line-through`:``;n=e.underline?n+` underline`:n,t[`text-decoration`]=n}return e.textColor&&(t.color=e.textColor),t}function U(e){let t=``;for(let n in e)e[n]&&(t+=`${n}:${e[n]}; `);return t}function ff(e){let t=window.getComputedStyle(e);return{top:parseInt(t.marginTop,10)||0,bottom:parseInt(t.marginBottom,10)||0,left:parseInt(t.marginLeft,10)||0,right:parseInt(t.marginRight,10)||0}}let pf=new h;function mf(){return!!window.Chart.registry.plugins.get(`chartShowValuesPlugin`)}function hf(){if(!(!window.Chart||mf()))for(let e of pf.getAll())e.register(window.Chart)}function gf(){if(window.Chart)for(let e of pf.getAll())e.unregister(window.Chart)}function _f(){return class extends window.Chart.BarController{static id=`funnel`;static defaults={...window.Chart?.BarController.defaults,dataElementType:`funnel`,animation:{duration:e=>e.type===`data`?1e3*(e.raw[1]/Math.max(...e.dataset.data.map(e=>e[1]))):1e3}};updateElements(e,t,n,r){super.updateElements(e,t,n,r);for(let i=t;i<t+n;i++){let t=e[i];this.updateElement(t,i,{nextElement:e[i+1]},r)}}}}function vf(){return class extends window.Chart.BarElement{static id=`funnel`;draw(e){e.save();let{x:t,y:n,height:r,nextElement:i,base:a,options:o}=this.getProps([`x`,`y`,`width`,`height`,`nextElement`,`base`,`options`]),s=yf(this),c=(s-(i?yf(i):0))/2,l=Math.min(t,a),u=n-r/2;e.fillStyle=o.backgroundColor,e.beginPath(),e.moveTo(l,u),e.lineTo(l+s,u),e.lineTo(l+s-c,u+r),e.lineTo(l+c,u+r),e.closePath(),e.fill(),o.borderWidth&&(e.strokeStyle=o.borderColor,e.lineWidth=o.borderWidth,e.stroke()),e.restore()}inRange(e,t){let{x:n,y:r,height:i,nextElement:a,base:o}=this.getProps([`x`,`y`,`width`,`height`,`nextElement`,`base`,`options`]),s=yf(this),c=a?yf(a):0,l=Math.min(n,o),u=r-i/2;if(t<u||t>u+i)return!1;let d=(s-c)/2,f=l+d*(t-u)/i,p=l+s-d*(t-u)/i;return!(e<f||e>p)}}}function yf(e){let{x:t,base:n}=e.getProps([`x`,`base`]);return Math.max(t,n)-Math.min(t,n)}let bf=function(e){if(!e.length)return{x:0,y:0};let{x:t,y:n,base:r,width:i,height:a}=e[0].element.getProps([`x`,`y`,`width`,`height`,`base`]),o=Math.min(t,r),s=n-a/2;return{x:o+i*2/3,y:s+a/2}},xf=/(.*?)\((.*?)\)(.*)/,Sf=[`ANY`,`BOOLEAN`,`DATE`,`NUMBER`,`STRING`,`RANGE`,`RANGE<BOOLEAN>`,`RANGE<DATE>`,`RANGE<NUMBER>`,`RANGE<STRING>`,`META`];function W(e,t=``){return Cf(e,t)}function Cf(e,t){let n=e.match(xf),r=n[1].trim();if(!r)throw Error(`Function argument definition is missing a name: '${e}'.`);let i=[],a=!1,o=!1,s;for(let e of n[2].split(`,`)){let t=e.trim().toUpperCase(),n=Sf.find(e=>t===e);n?i.push(n):t===`RANGE<ANY>`?i.push(`RANGE`):t===`OPTIONAL`?a=!0:t===`REPEATING`?o=!0:t.startsWith(`DEFAULT=`)&&(s=e.trim().slice(8))}let c={name:r,description:t,type:i};return(i.includes(`ANY`)||i.includes(`RANGE`))&&(c.acceptErrors=!0),a&&(c.optional=!0),o&&(c.repeating=!0),s!==void 0&&(c.default=!0,c.defaultValue=s),i.some(e=>e.startsWith(`RANGE`))&&(c.acceptMatrix=!0),i.every(e=>e.startsWith(`RANGE`))&&(c.acceptMatrixOnly=!0),c}function wf(e,t){let n=0,r=0,i=0,a=0;for(let e of t.args)n++,!e.optional&&!e.repeating&&!e.default&&r++,e.repeating&&i++,(e.optional||e.default)&&a++;let o=t;return o.minArgRequired=r,o.maxArgPossible=i?1/0:n,o.nbrArgRepeating=i,o.nbrArgOptional=a,o.hidden=t.hidden||!1,o.name=e,o}let Tf={};function Ef(e,t){let n=e.name;return Tf[n]?.[t]||(Tf[n]||(Tf[n]={}),Tf[n][t]||(Tf[n][t]=Df(e,t)),Tf[n][t])}function Df(e,t){let n={},r=e.nbrArgRepeating?Math.floor((t-e.minArgRequired)/e.nbrArgRepeating):0,i=e.nbrArgRepeating*r,a=t-e.minArgRequired-i,o=0,s=0;for(let t=0;t<e.args.length;t++){let i=e.args[t];if(i.optional||i.default){s<a&&(n[o]=t,o++),s++;continue}if(i.repeating){for(let i=0;i<r;i++)for(let r=0;r<e.nbrArgRepeating;r++)n[o]=t+r,o++;t+=e.nbrArgRepeating-1;continue}n[o]=t,o++}return e=>n[e]}function Of(e){if(e.nbrArgRepeating&&e.nbrArgOptional>=e.nbrArgRepeating)throw Error(`Function ${e.name} has more optional arguments than repeatable ones.`);let t=!1,n=!1;for(let r of e.args){if(r.type.includes(`META`)&&r.type.length>1)throw 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(r.repeating){if(!n&&t)throw Error(`Function ${e.name} has non-consecutive repeating arguments. All repeating arguments must be declared consecutively.`);t=!0,n=!0}else n=!1}}function kf(e,t){N(()=>t.length===1||t[0].length===1,e)}function Af(e,...t){if(t.every(A)){let n=t[0].length,r=t[0][0].length;for(let i of t)N(()=>i.length===n&&i[0].length===r,e);return}if(t.some(e=>Array.isArray(e)&&(e.length!==1||e[0].length!==1)))throw new M(e)}function jf(e,t){N(()=>t>0,e)}function Mf(e,t){N(()=>t.length===t[0].length,e)}var Nf=l({ARRAY_CONSTRAIN:()=>Pf,CHOOSECOLS:()=>Ff,CHOOSEROWS:()=>If,EXPAND:()=>Lf,FLATTEN:()=>Rf,FREQUENCY:()=>zf,HSTACK:()=>Bf,MDETERM:()=>Vf,MINVERSE:()=>Hf,MMULT:()=>Uf,SUMPRODUCT:()=>Wf,SUMX2MY2:()=>Kf,SUMX2PY2:()=>qf,SUMXMY2:()=>Jf,TOCOL:()=>Zf,TOROW:()=>Qf,TRANSPOSE:()=>$f,VSTACK:()=>ep,WRAPCOLS:()=>tp,WRAPROWS:()=>np});let Pf={description:O(`Returns a result array constrained to a specific width and height.`),args:[W(`input_range (any, range<any>)`,O(`The range to constrain.`)),W(`rows (number)`,O(`The number of rows in the constrained array.`)),W(`columns (number)`,O(`The number of columns in the constrained array.`))],compute:function(e,t,n){let r=z(e),i=Pa(t?.value,this.locale),a=Pa(n?.value,this.locale);jf(O(`The rows argument (%s) must be strictly positive.`,i.toString()),i),jf(O(`The columns argument (%s) must be strictly positive.`,i.toString()),a);let o=Math.min(i,r[0].length);return Ya(Math.min(a,r.length),o,(e,t)=>r[e][t])},isExported:!1},Ff={description:O(`Creates a new array from the selected columns in the existing range.`),args:[W(`array (any, range<any>)`,O(`The array that contains the columns to be returned.`)),W(`col_num (number, range<number>)`,O(`The first column index of the columns to be returned.`)),W(`col_num2 (number, range<number>, repeating)`,O(`The columns indexes of the columns to be returned.`))],compute:function(e,...t){let n=z(e),r=fo(t,e=>Pa(e?.value,this.locale)),i=r.filter(e=>e===0||n.length<Math.abs(e));N(()=>i.length===0,O(`The columns arguments must be between -%s and %s (got %s), excluding 0.`,n.length.toString(),n.length.toString(),i.join(`,`)));let a=Array(r.length);for(let e=0;e<r.length;e++)r[e]>0?a[e]=n[r[e]-1]:a[e]=n[n.length+r[e]];return a},isExported:!0},If={description:O(`Creates a new array from the selected rows in the existing range.`),args:[W(`array (any, range<any>)`,O(`The array that contains the rows to be returned.`)),W(`row_num (number, range<number>)`,O(`The first row index of the rows to be returned.`)),W(`row_num2 (number, range<number>, repeating)`,O(`The rows indexes of the rows to be returned.`))],compute:function(e,...t){let n=z(e),r=fo(t,e=>Pa(e?.value,this.locale)),i=n.length,a=r.filter(e=>e===0||n[0].length<Math.abs(e));return N(()=>a.length===0,O(`The rows arguments must be between -%s and %s (got %s), excluding 0.`,n[0].length.toString(),n[0].length.toString(),a.join(`,`))),Ya(i,r.length,(e,t)=>r[t]>0?n[e][r[t]-1]:n[e][n[e].length+r[t]])},isExported:!0},Lf={description:O(`Expands or pads an array to specified row and column dimensions.`),args:[W(`array (any, range<any>)`,O(`The array to expand.`)),W(`rows (number)`,O(`The number of rows in the expanded array. If missing, rows will not be expanded.`)),W(`columns (number, optional)`,O(`The number of columns in the expanded array. If missing, columns will not be expanded.`)),W(`pad_with (any, default=0)`,O(`The value with which to pad.`))],compute:function(e,t,n,r={value:0}){let i=z(e),a=Pa(t?.value,this.locale),o=n===void 0?i.length:Pa(n.value,this.locale);return N(()=>a>=i[0].length,O(`The rows arguments (%s) must be greater or equal than the number of rows of the array.`,a.toString())),N(()=>o>=i.length,O(`The columns arguments (%s) must be greater or equal than the number of columns of the array.`,o.toString())),Ya(o,a,(e,t)=>e>=i.length||t>=i[e].length?r:i[e][t])},isExported:!0},Rf={description:O(`Flattens all the values from one or more ranges into a single column.`),args:[W(`range (any, range<any>)`,O(`The first range to flatten.`)),W(`range2 (any, range<any>, repeating)`,O(`Additional ranges to flatten.`))],compute:function(...e){return[fo(e,e=>e===void 0?{value:``}:e)]},isExported:!1},zf={description:O(`Calculates the frequency distribution of a range.`),args:[W(`data (range<number>)`,O(`The array of ranges containing the values to be counted.`)),W(`classes (number, range<number>)`,O(`The range containing the set of classes.`))],compute:function(e,t){let n=fo([e],e=>e.value).filter(e=>typeof e==`number`),r=fo([t],e=>e.value).filter(e=>typeof e==`number`).map((e,t)=>({initialIndex:t,value:e,count:0})).sort((e,t)=>e.value-t.value);r.push({initialIndex:r.length,value:1/0,count:0});let i=n.sort((e,t)=>e-t),a=0;for(let e of i){for(;e>r[a].value&&a<r.length-1;)a++;r[a].count++}return[r.sort((e,t)=>e.initialIndex-t.initialIndex).map(e=>e.count)]},isExported:!0},Bf={description:O(`Appends ranges horizontally and in sequence to return a larger array.`),args:[W(`range1 (any, range<any>)`,O(`The first range to be appended.`)),W(`range2 (any, range<any>, repeating)`,O(`Additional ranges to add to range1.`))],compute:function(...e){let t=Math.max(...e.map(e=>e?.[0]?.length??0)),n=[];for(let r of e){let e=z(r);for(let r=0;r<e.length;r++){let i=Array(t).fill({value:null});for(let t=0;t<e[r].length;t++)i[t]=e[r][t];n.push(i)}}return n},isExported:!0},Vf={description:O(`Returns the matrix determinant of a square matrix.`),args:[W(`square_matrix (number, range<number>)`,O(`An range with an equal number of rows and columns representing a matrix whose determinant will be calculated.`))],compute:function(e){let t=Ma(e,`square_matrix`);return Mf(O(`The argument square_matrix must have the same number of columns and rows.`),t),au(t).determinant},isExported:!0},Hf={description:O(`Returns the multiplicative inverse of a square matrix.`),args:[W(`square_matrix (number, range<number>)`,O(`An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated.`))],compute:function(e){let t=Ma(e,`square_matrix`);Mf(O(`The argument square_matrix must have the same number of columns and rows.`),t);let{inverted:n}=au(t);return n||new M(O(`The matrix is not invertible.`))},isExported:!0},Uf={description:O(`Calculates the matrix product of two matrices.`),args:[W(`matrix1 (number, range<number>)`,O(`The first matrix in the matrix multiplication operation.`)),W(`matrix2 (number, range<number>)`,O(`The second matrix in the matrix multiplication operation.`))],compute:function(e,t){let n=Ma(e,`matrix1`),r=Ma(t,`matrix2`);return N(()=>n.length>0&&r.length>0,O(`The first and second arguments of [[FUNCTION_NAME]] must be non-empty matrices.`)),N(()=>n.length===r[0].length,O(`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).`,n.length.toString(),r[0].length.toString())),su(n,r)},isExported:!0},Wf={description:O(`Calculates the sum of the products of corresponding entries in equal-sized ranges.`),args:[W(`range1 (number, range<number>)`,O(`The first range whose entries will be multiplied with corresponding entries in the other ranges.`)),W(`range2 (number, range<number>, repeating)`,O(`The other range whose entries will be multiplied with corresponding entries in the other ranges.`))],compute:function(...e){Af(O(`All the ranges must have the same dimensions.`),...e);let t=e.map(z),n=0;for(let e=0;e<t[0].length;e++)for(let r=0;r<t[0][e].length;r++){if(!t.every(t=>typeof t[e][r].value==`number`))continue;let i=1;for(let n of t)i*=F(n[e][r],this.locale);n+=i}return n},isExported:!0};function Gf(e,t,n){Af(`The arguments array_x and array_y must have the same dimensions.`,e,t);let r=z(e),i=z(t),a=!1,o=0;for(let e in r)for(let t in r[e]){let s=r[e][t].value,c=i[e][t].value;typeof s!=`number`||typeof c!=`number`||(a=!0,o+=n(s,c))}return a?o:new M(O(`The arguments array_x and array_y must contain at least one pair of numbers.`))}let Kf={description:O(`Calculates the sum of the difference of the squares of the values in two array.`),args:[W(`array_x (number, range<number>)`,O(`The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.`)),W(`array_y (number, range<number>)`,O(`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 Gf(e,t,(e,t)=>e**2-t**2)},isExported:!0},qf={description:O(`Calculates the sum of the sum of the squares of the values in two array.`),args:[W(`array_x (number, range<number>)`,O(`The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.`)),W(`array_y (number, range<number>)`,O(`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 Gf(e,t,(e,t)=>e**2+t**2)},isExported:!0},Jf={description:O(`Calculates the sum of squares of the differences of values in two array.`),args:[W(`array_x (number, range<number>)`,O(`The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.`)),W(`array_y (number, range<number>)`,O(`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 Gf(e,t,(e,t)=>(e-t)**2)},isExported:!0},Yf=[W(`array (any, range<any>)`,O(`The array which will be transformed.`)),W(`ignore (number, default=0)`,O(`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.`)),W(`scan_by_column (number, default=false)`,O(`Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row.`))];function Xf(e){let t=Math.trunc(e);if(t===0)return()=>!0;if(t===1)return e=>e.value!==null;if(t===2)return e=>!P(e.value);if(t===3)return e=>e.value!==null&&!P(e.value);throw new M(O(`Argument ignore must be between 0 and 3`))}let Zf={description:O(`Transforms a range of cells into a single column.`),args:Yf,compute:function(e,t={value:0},n={value:!1}){let r=z(e),i=F(t.value,this.locale),a=(L(n.value)?r:Qa(r)).flat().filter(Xf(i));return a.length===0?new Sa(O(`No results for the given arguments of TOCOL.`)):[a]},isExported:!0},Qf={description:O(`Transforms a range of cells into a single row.`),args:Yf,compute:function(e,t={value:0},n={value:!1}){let r=z(e),i=F(t.value,this.locale),a=(L(n.value)?r:Qa(r)).flat().filter(Xf(i)).map(e=>[e]);return a.length===0||a[0].length===0?new Sa(O(`No results for the given arguments of TOROW.`)):a},isExported:!0},$f={description:O(`Transposes the rows and columns of a range.`),args:[W(`range (any, range<any>)`,O(`The range to be transposed.`))],compute:function(e){let t=z(e),n=t[0].length,r=t.length;return Ya(n,r,(e,n)=>t[n][e])},isExported:!0},ep={description:O(`Appends ranges vertically and in sequence to return a larger array.`),args:[W(`range1 (any, range<any>)`,O(`The first range to be appended.`)),W(`range2 (any, range<any>, repeating)`,O(`Additional ranges to add to range1.`))],compute:function(...e){let t=Math.max(...e.map(e=>z(e).length)),n=e.reduce((e,t)=>e+z(t)[0].length,0),r=Array(t).fill([]).map(()=>Array(n).fill({value:0})),i=0;for(let t of e){let e=z(t);for(let t=0;t<e.length;t++)for(let n=0;n<e[t].length;n++)r[t][i+n]=e[t][n];i+=e[0].length}return r},isExported:!0},tp={description:O(`Wraps the provided row or column of cells by columns after a specified number of elements to form a new array.`),args:[W(`range (any, range<any>)`,O(`The range to wrap.`)),W(`wrap_count (number)`,O(`The maximum number of cells for each column, rounded down to the nearest whole number.`)),W(`pad_with (any, default=0)`,O(`The value with which to fill the extra cells in the range.`))],compute:function(e,t,n={value:0}){let r=z(e),i=Pa(t?.value,this.locale);kf(O(`Argument range must be a single row or column.`),r);let a=r.flat();return Ya(Math.ceil(a.length/i),i,(e,t)=>{let r=e*i+t;return r<a.length?a[r]:n})},isExported:!0},np={description:O(`Wraps the provided row or column of cells by rows after a specified number of elements to form a new array.`),args:[W(`range (any, range<any>)`,O(`The range to wrap.`)),W(`wrap_count (number)`,O(`The maximum number of cells for each row, rounded down to the nearest whole number.`)),W(`pad_with (any, default=0)`,O(`The value with which to fill the extra cells in the range.`))],compute:function(e,t,n={value:0}){let r=z(e),i=Pa(t?.value,this.locale);kf(O(`Argument range must be a single row or column.`),r);let a=r.flat();return Ya(i,Math.ceil(a.length/i),(e,t)=>{let r=t*i+e;return r<a.length?a[r]:n})},isExported:!0};var rp=l({FORMAT_LARGE_NUMBER:()=>ip});let ip={description:O(`Apply a large number format`),args:[W(`value (number)`,O(`The number.`)),W(`unit (string, optional)`,O(`The formatting unit. Use 'k', 'm', or 'b' to force the unit`))],compute:function(e,t){return{value:F(e,this.locale),format:Cs(e,t,this.locale)}}};var ap=l({ABS:()=>sp,ACOS:()=>cp,ACOSH:()=>lp,ACOT:()=>up,ACOTH:()=>dp,ASIN:()=>fp,ASINH:()=>pp,ATAN:()=>mp,ATAN2:()=>hp,ATANH:()=>gp,CEILING:()=>_p,CEILING_MATH:()=>yp,CEILING_PRECISE:()=>bp,COS:()=>xp,COSH:()=>Sp,COT:()=>Cp,COTH:()=>wp,COUNTBLANK:()=>Tp,COUNTIF:()=>Ep,COUNTIFS:()=>Dp,COUNTUNIQUE:()=>Op,COUNTUNIQUEIFS:()=>kp,CSC:()=>Ap,CSCH:()=>jp,DECIMAL:()=>Mp,DEGREES:()=>Np,EXP:()=>Pp,FLOOR:()=>Fp,FLOOR_MATH:()=>Lp,FLOOR_PRECISE:()=>Rp,INT:()=>gm,ISEVEN:()=>zp,ISODD:()=>Vp,ISO_CEILING:()=>Bp,LN:()=>Hp,LOG:()=>Up,MOD:()=>Gp,MUNIT:()=>Kp,ODD:()=>qp,PI:()=>Jp,POWER:()=>Yp,PRODUCT:()=>Xp,RAND:()=>Zp,RANDARRAY:()=>Qp,RANDBETWEEN:()=>$p,ROUND:()=>em,ROUNDDOWN:()=>tm,ROUNDUP:()=>nm,SEC:()=>rm,SECH:()=>im,SEQUENCE:()=>am,SIN:()=>om,SINH:()=>sm,SQRT:()=>cm,SUM:()=>lm,SUMIF:()=>um,SUMIFS:()=>dm,TAN:()=>fm,TANH:()=>pm,TRUNC:()=>hm});let op=/^-?[a-z0-9]+$/i,sp={description:O(`Absolute value of a number.`),args:[W(`value (number)`,O(`The number of which to return the absolute value.`))],compute:function(e){return Math.abs(F(e,this.locale))},isExported:!0},cp={description:O(`Inverse cosine of a value, in radians.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)<=1,O(`The value (%s) must be between -1 and 1 inclusive.`,t.toString())),Math.acos(t)},isExported:!0},lp={description:O(`Inverse hyperbolic cosine of a number.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1.`))],compute:function(e){let t=F(e,this.locale);return N(()=>t>=1,O(`The value (%s) must be greater than or equal to 1.`,t.toString())),Math.acosh(t)},isExported:!0},up={description:O(`Inverse cotangent of a value.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse cotangent.`))],compute:function(e){let t=F(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},dp={description:O(`Inverse hyperbolic cotangent of a value.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)>1,O(`The value (%s) cannot be between -1 and 1 inclusive.`,t.toString())),Math.log((t+1)/(t-1))/2},isExported:!0},fp={description:O(`Inverse sine of a value, in radians.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)<=1,O(`The value (%s) must be between -1 and 1 inclusive.`,t.toString())),Math.asin(t)},isExported:!0},pp={description:O(`Inverse hyperbolic sine of a number.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic sine.`))],compute:function(e){return Math.asinh(F(e,this.locale))},isExported:!0},mp={description:O(`Inverse tangent of a value, in radians.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse tangent.`))],compute:function(e){return Math.atan(F(e,this.locale))},isExported:!0},hp={description:O(`Angle from the X axis to a point (x,y), in radians.`),args:[W(`x (number)`,O(`The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.`)),W(`y (number)`,O(`The y coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.`))],compute:function(e,t){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>n!==0||r!==0,O(`Function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero),Math.atan2(r,n)},isExported:!0},gp={description:O(`Inverse hyperbolic tangent of a number.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)<1,O(`The value (%s) must be between -1 and 1 exclusive.`,t.toString())),Math.atanh(t)},isExported:!0},_p={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`value (number)`,O(`The value to round up to the nearest integer multiple of factor.`)),W(`factor (number, default=1)`,O(`The number to whose multiples value will be rounded.`))],compute:function(e,t={value:1}){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>r>=0||n<=0,O(`The factor (%s) must be positive when the value (%s) is positive.`,r.toString(),n.toString())),{value:r?Math.ceil(n/r)*r:0,format:e?.format}},isExported:!0};function vp(e,t,n=0){return t===0?0:(t=Math.abs(t),e>=0?Math.ceil(e/t)*t:n===0?-Math.floor(Math.abs(e)/t)*t:-Math.ceil(Math.abs(e)/t)*t)}let yp={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round up to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded. The sign of significance will be ignored.`)),W(`mode (number, default=0)`,O(`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},n={value:0}){let r=F(t,this.locale);return{value:vp(F(e,this.locale),r,F(n,this.locale)),format:e?.format}},isExported:!0},bp={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round up to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded.`))],compute:function(e,t={value:1}){let n=F(t,this.locale);return{value:vp(F(e,this.locale),n),format:e?.format}},isExported:!0},xp={description:O(`Cosine of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the cosine of, in radians.`))],compute:function(e){return Math.cos(F(e,this.locale))},isExported:!0},Sp={description:O(`Hyperbolic cosine of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic cosine of.`))],compute:function(e){return Math.cosh(F(e,this.locale))},isExported:!0},Cp={description:O(`Cotangent of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the cotangent of, in radians.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.tan(t)},isExported:!0},wp={description:O(`Hyperbolic cotangent of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic cotangent of.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.tanh(t)},isExported:!0},Tp={description:O(`Number of empty values.`),args:[W(`value1 (any, range)`,O(`The first value or range in which to count the number of blanks.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges in which to count the number of blanks.`))],compute:function(...e){return Ka(e,(e,t)=>t===void 0||t.value===null||t.value===``?e+1:e,0)},isExported:!0},Ep={description:O(`A conditional count across a range.`),args:[W(`range (range)`,O(`The range that is tested against criterion.`)),W(`criterion (string)`,O(`The pattern or test to apply to range.`))],compute:function(...e){let t=0;return ao(e,(e,n)=>{t+=1},this.locale),t},isExported:!0},Dp={description:O(`Count values depending on multiple criteria.`),args:[W(`criteria_range1 (range)`,O(`The range to check against criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`Additional criteria to check.`))],compute:function(...e){let t=0;return ao(e,(e,n)=>{t+=1},this.locale),t},isExported:!0},Op={description:O(`Counts number of unique values in a range.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider for uniqueness.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider for uniqueness.`))],compute:function(...e){return ru(e)}},kp={description:O(`Counts number of unique values in a range, filtered by a set of criteria.`),args:[W(`range (range)`,O(`The range of cells from which the number of unique values will be counted.`)),W(`criteria_range1 (range)`,O(`The range of cells over which to evaluate criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=new Set;return ao(t,(t,r)=>{let i=e[t]?.[r];po(i)&&n.add(i.value)},this.locale),n.size}},Ap={description:O(`Cosecant of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the cosecant of, in radians.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.sin(t)},isExported:!0},jp={description:O(`Hyperbolic cosecant of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic cosecant of.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.sinh(t)},isExported:!0},Mp={description:O(`Converts from another base to decimal.`),args:[W(`value (string)`,O(`The number to convert.`)),W(`base (number)`,O(`The base to convert the value from.`))],compute:function(e,t){let n=F(t,this.locale);n=Math.floor(n),N(()=>2<=n&&n<=36,O(`The base (%s) must be between 2 and 36 inclusive.`,n.toString()));let r=I(e);if(r===``)return 0;N(()=>op.test(r),O(`The value (%s) must be a valid base %s representation.`,r,n.toString()));let i=parseInt(r,n);return N(()=>!isNaN(i),O(`The value (%s) must be a valid base %s representation.`,r,n.toString())),i},isExported:!0},Np={description:O(`Converts an angle value in radians to degrees.`),args:[W(`angle (number)`,O(`The angle to convert from radians to degrees.`))],compute:function(e){return F(e,this.locale)*180/Math.PI},isExported:!0},Pp={description:O(`Euler's number, e (~2.718) raised to a power.`),args:[W(`value (number)`,O(`The exponent to raise e.`))],compute:function(e){return Math.exp(F(e,this.locale))},isExported:!0},Fp={description:O(`Rounds number down to nearest multiple of factor.`),args:[W(`value (number)`,O(`The value to round down to the nearest integer multiple of factor.`)),W(`factor (number, default=1)`,O(`The number to whose multiples value will be rounded.`))],compute:function(e,t={value:1}){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>r>=0||n<=0,O(`The factor (%s) must be positive when the value (%s) is positive.`,r.toString(),n.toString())),{value:r?Math.floor(n/r)*r:0,format:e?.format}},isExported:!0};function Ip(e,t,n=0){return t===0?0:(t=Math.abs(t),e>=0?Math.floor(e/t)*t:n===0?-Math.ceil(Math.abs(e)/t)*t:-Math.floor(Math.abs(e)/t)*t)}let Lp={description:O(`Rounds number down to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round down to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded. The sign of significance will be ignored.`)),W(`mode (number, default=0)`,O(`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},n={value:0}){let r=F(t,this.locale);return{value:Ip(F(e,this.locale),r,F(n,this.locale)),format:e?.format}},isExported:!0},Rp={description:O(`Rounds number down to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round down to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded.`))],compute:function(e,t={value:1}){let n=F(t,this.locale);return{value:Ip(F(e,this.locale),n),format:e?.format}},isExported:!0},zp={description:O(`Whether the provided value is even.`),args:[W(`value (number)`,O(`The value to be verified as even.`))],compute:function(e){let t=Na(e,this.locale);return!(Math.floor(Math.abs(t))&1)},isExported:!0},Bp={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round up to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded.`))],compute:function(e,t={value:1}){return{value:vp(F(e,this.locale),F(t,this.locale)),format:e?.format}},isExported:!0},Vp={description:O(`Whether the provided value is even.`),args:[W(`value (number)`,O(`The value to be verified as even.`))],compute:function(e){let t=Na(e,this.locale);return!!(Math.floor(Math.abs(t))&1)},isExported:!0},Hp={description:O(`The logarithm of a number, base e (euler's number).`),args:[W(`value (number)`,O(`The value for which to calculate the logarithm, base e.`))],compute:function(e){let t=F(e,this.locale);return N(()=>t>0,O(`The value (%s) must be strictly positive.`,t.toString())),Math.log(t)},isExported:!0},Up={description:O(`The logarithm of a number, for a given base.`),args:[W(`value (number)`,O(`The value for which to calculate the logarithm.`)),W(`base (number, default=10)`,O(`The base of the logarithm.`))],compute:function(e,t={value:10}){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>n>0,O(`The value (%s) must be strictly positive.`,n.toString())),N(()=>r>0,O(`The base (%s) must be strictly positive.`,r.toString())),N(()=>r!==1,O(`The base must be different from 1.`)),Math.log10(n)/Math.log10(r)},isExported:!0};function Wp(e,t){N(()=>t!==0,O(`The divisor must be different from 0.`),j.DivisionByZero);let n=e%t;return n>0&&t<0||n<0&&t>0?n+t:n}let Gp={description:O(`Modulo (remainder) operator.`),args:[W(`dividend (number)`,O(`The number to be divided to find the remainder.`)),W(`divisor (number)`,O(`The number to divide by.`))],compute:function(e,t){let n=F(t,this.locale);return{value:Wp(F(e,this.locale),n),format:e?.format}},isExported:!0},Kp={description:O(`Returns a n x n unit matrix, where n is the input dimension.`),args:[W(`dimension (number)`,O(`An integer specifying the dimension size of the unit matrix. It must be positive.`))],compute:function(e){let t=Pa(e,this.locale);return jf(O(`The argument dimension must be positive`),t),iu(t)},isExported:!0},qp={description:O(`Rounds a number up to the nearest odd integer.`),args:[W(`value (number)`,O(`The value to round to the next greatest odd number.`))],compute:function(e){let t=F(e,this.locale),n=Math.ceil(Math.abs(t));return n=n&1?n:n+1,{value:t<0?-n:n,format:e?.format}},isExported:!0},Jp={description:O(`The number pi.`),args:[],compute:function(){return Math.PI},isExported:!0},Yp={description:O(`A number raised to a power.`),args:[W(`base (number)`,O(`The number to raise to the exponent power.`)),W(`exponent (number)`,O(`The exponent to raise base to.`))],compute:function(e,t){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>n>=0||Number.isInteger(r),O(`The exponent (%s) must be an integer when the base is negative.`,r.toString())),{value:n**+r,format:e?.format}},isExported:!0},Xp={description:O(`Result of multiplying a series of numbers together.`),args:[W(`factor1 (number, range<number>)`,O(`The first number or range to calculate for the product.`)),W(`factor2 (number, range<number>, repeating)`,O(`More numbers or ranges to calculate for the product.`))],compute:function(...e){let t=0,n=1;for(let r of e)if(A(r))for(let e of r)for(let r of e){let e=r.value;if(typeof e==`number`&&(n*=e,t+=1),P(e))return r}else r!==void 0&&r.value!==null&&(n*=Na(r,this.locale),t+=1);return{value:t===0?0:n,format:Ea(e[0])}},isExported:!0},Zp={description:O(`A random number between 0 inclusive and 1 exclusive.`),args:[],compute:function(){return Math.random()},isExported:!0},Qp={description:O(`Returns a grid of random numbers between 0 inclusive and 1 exclusive.`),args:[W(`rows (number, default=1)`,O(`The number of rows to be returned.`)),W(`columns (number, default=1)`,O(`The number of columns to be returned.`)),W(`min (number, default=0)`,O(`The minimum number you would like returned.`)),W(`max (number, default=1)`,O(`The maximum number you would like returned.`)),W(`whole_number (number, default=FALSE)`,O(`Return a whole number or a decimal value.`))],compute:function(e={value:1},t={value:1},n={value:0},r={value:1},i={value:!1}){let a=Pa(t,this.locale),o=Pa(e,this.locale),s=F(n,this.locale),c=F(r,this.locale),l=L(i);jf(O(`The number of columns (%s) must be positive.`,a.toString()),a),jf(O(`The number of rows (%s) must be positive.`,o.toString()),o),N(()=>s<=c,O(`The maximum (%s) must be greater than or equal to the minimum (%s).`,c.toString(),s.toString())),l&&N(()=>Number.isInteger(s)&&Number.isInteger(c),O(`The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.`,c.toString(),s.toString()));let u=Array(a);for(let e=0;e<a;e++){u[e]=Array(o);for(let t=0;t<o;t++)l?u[e][t]=Math.floor(Math.random()*(c-s+1)+s):u[e][t]=s+Math.random()*(c-s)}return u},isExported:!0},$p={description:O(`Random integer between two values, inclusive.`),args:[W(`low (number)`,O(`The low end of the random range.`)),W(`high (number)`,O(`The high end of the random range.`))],compute:function(e,t){let n=F(e,this.locale);Number.isInteger(n)||(n=Math.ceil(n));let r=F(t,this.locale);return Number.isInteger(r)||(r=Math.floor(r)),N(()=>n<=r,O(`The high (%s) must be greater than or equal to the low (%s).`,r.toString(),n.toString())),{value:n+Math.ceil((r-n+1)*Math.random())-1,format:e?.format}},isExported:!0},em={description:O(`Rounds a number according to standard rules.`),args:[W(`value (number)`,O(`The value to round to places number of places.`)),W(`places (number, default=0)`,O(`The number of decimal places to which to round.`))],compute:function(e,t={value:0}){let n=F(e,this.locale),r=F(t,this.locale),i=Math.abs(n),a;return r===0?a=Math.round(i):(Number.isInteger(r)||(r=Math.trunc(r)),a=Math.round(i*10**r)/10**r),{value:n>=0?a:-a,format:e?.format}},isExported:!0},tm={description:O(`Rounds down a number.`),args:[W(`value (number)`,O(`The value to round to places number of places, always rounding down.`)),W(`places (number, default=0)`,O(`The number of decimal places to which to round.`))],compute:function(e,t={value:0}){let n=F(e,this.locale),r=F(t,this.locale),i=Math.abs(n),a;return r===0?a=Math.floor(i):(Number.isInteger(r)||(r=Math.trunc(r)),a=Math.floor(i*10**r)/10**r),{value:n>=0?a:-a,format:e?.format}},isExported:!0},nm={description:O(`Rounds up a number.`),args:[W(`value (number)`,O(`The value to round to places number of places, always rounding up.`)),W(`places (number, default=0)`,O(`The number of decimal places to which to round.`))],compute:function(e,t={value:0}){let n=F(e,this.locale),r=F(t,this.locale),i=Math.abs(n),a;return r===0?a=Math.ceil(i):(Number.isInteger(r)||(r=Math.trunc(r)),a=Math.ceil(i*10**r)/10**r),{value:n>=0?a:-a,format:e?.format}},isExported:!0},rm={description:O(`Secant of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the secant of, in radians.`))],compute:function(e){return 1/Math.cos(F(e,this.locale))},isExported:!0},im={description:O(`Hyperbolic secant of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic secant of.`))],compute:function(e){return 1/Math.cosh(F(e,this.locale))},isExported:!0},am={description:O(`Returns a sequence of numbers.`),args:[W(`rows (number)`,O(`The number of rows to return`)),W(`columns (number, optional, default=1)`,O(`The number of columns to return`)),W(`start (number, optional, default=1)`,O(`The first number in the sequence`)),W(`step (number, optional, default=1)`,O(`The amount to increment each value in the sequence`))],compute:function(e,t={value:1},n={value:1},r={value:1}){let i=F(n,this.locale),a=F(r,this.locale),o=Pa(e,this.locale),s=Pa(t,this.locale);return jf(O(`The number of columns (%s) must be positive.`,s),s),jf(O(`The number of rows (%s) must be positive.`,o),o),Ya(s,o,(e,t)=>({value:i+t*s*a+e*a}))},isExported:!0},om={description:O(`Sine of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the sine of, in radians.`))],compute:function(e){return Math.sin(F(e,this.locale))},isExported:!0},sm={description:O(`Hyperbolic sine of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic sine of.`))],compute:function(e){return Math.sinh(F(e,this.locale))},isExported:!0},cm={description:O(`Positive square root of a positive number.`),args:[W(`value (number)`,O(`The number for which to calculate the positive square root.`))],compute:function(e){let t=F(e,this.locale);return N(()=>t>=0,O(`The value (%s) must be positive or null.`,t.toString())),{value:Math.sqrt(t),format:e?.format}},isExported:!0},lm={description:O(`Sum of a series of numbers and/or cells.`),args:[W(`value1 (number, range<number>)`,O(`The first number or range to add together.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional numbers or ranges to add to value1.`))],compute:function(...e){let t=e[0];return{value:nu(e,this.locale),format:Ea(t)}},isExported:!0},um={description:O(`A conditional sum across a range.`),args:[W(`criteria_range (range)`,O(`The range which is tested against criterion.`)),W(`criterion (string)`,O(`The pattern or test to apply to range.`)),W(`sum_range (range, default=criteria_range)`,O(`The range to be summed, if different from range.`))],compute:function(e,t,n){n===void 0&&(n=e);let r=0;return ao([e,t],(e,t)=>{let i=n[e]?.[t]?.value;typeof i==`number`&&(r+=i)},this.locale),r},isExported:!0},dm={description:O(`Sums a range depending on multiple criteria.`),args:[W(`sum_range (range)`,O(`The range to sum.`)),W(`criteria_range1 (range)`,O(`The range to check against criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1.`)),W(`criteria_range2 (any, range, repeating)`,O(`Additional ranges to check.`)),W(`criterion2 (string, repeating)`,O(`Additional criteria to check.`))],compute:function(e,...t){let n=0;return ao(t,(t,r)=>{let i=e[t]?.[r]?.value;typeof i==`number`&&(n+=i)},this.locale),n},isExported:!0},fm={description:O(`Tangent of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the tangent of, in radians.`))],compute:function(e){return Math.tan(F(e,this.locale))},isExported:!0},pm={description:O(`Hyperbolic tangent of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic tangent of.`))],compute:function(e){return Math.tanh(F(e,this.locale))},isExported:!0};function mm(e,t){return t===0?Math.trunc(e):(Number.isInteger(t)||(t=Math.trunc(t)),Math.trunc(e*10**t)/10**t)}let hm={description:O(`Truncates a number.`),args:[W(`value (number)`,O(`The value to be truncated.`)),W(`places (number, default=0)`,O(`The number of significant digits to the right of the decimal point to retain.`))],compute:function(e,t={value:0}){return{value:mm(F(e,this.locale),F(t,this.locale)),format:e?.format}},isExported:!0},gm={description:O(`Rounds a number down to the nearest integer that is less than or equal to it.`),args:[W(`value (number)`,O(`The number to round down to the nearest integer.`))],compute:function(e){return Math.floor(F(e,this.locale))},isExported:!0};var _m=l({AVEDEV:()=>Sm,AVERAGE:()=>Cm,AVERAGEA:()=>Dm,AVERAGEIF:()=>Om,AVERAGEIFS:()=>km,AVERAGE_WEIGHTED:()=>Em,CORREL:()=>Zm,COUNT:()=>Am,COUNTA:()=>jm,COVAR:()=>Mm,COVARIANCE_P:()=>Nm,COVARIANCE_S:()=>Pm,FORECAST:()=>Fm,GROWTH:()=>Im,INTERCEPT:()=>Lm,LARGE:()=>Rm,LINEST:()=>zm,LOGEST:()=>Bm,MATTHEWS:()=>Vm,MAX:()=>Hm,MAXA:()=>Um,MAXIFS:()=>Wm,MEDIAN:()=>Gm,MIN:()=>Km,MINA:()=>qm,MINIFS:()=>Jm,PEARSON:()=>Xm,PERCENTILE:()=>Qm,PERCENTILE_EXC:()=>$m,PERCENTILE_INC:()=>eh,POLYFIT_COEFFS:()=>th,POLYFIT_FORECAST:()=>nh,QUARTILE:()=>rh,QUARTILE_EXC:()=>ih,QUARTILE_INC:()=>ah,RANK:()=>oh,RSQ:()=>sh,SLOPE:()=>ch,SMALL:()=>lh,SPEARMAN:()=>uh,STDEV:()=>dh,STDEVA:()=>mh,STDEVP:()=>hh,STDEVPA:()=>gh,STDEV_P:()=>fh,STDEV_S:()=>ph,STEYX:()=>_h,TREND:()=>vh,VAR:()=>yh,VARA:()=>Sh,VARP:()=>Ch,VARPA:()=>wh,VAR_P:()=>bh,VAR_S:()=>xh});function vm(e,t){let n=[],r=[],i=0,a=0;Ua([e],e=>{n.push(e),i+=1}),Ua([t],e=>{r.push(e),a+=1}),N(()=>i===a,O(`[[FUNCTION_NAME]] has mismatched argument count %s vs %s.`,i,a));let o=[],s=[];for(let e=0;e<i;e++){let t=n[e]?.value,i=r[e]?.value;typeof t==`number`&&typeof i==`number`&&(s.push(t),o.push(i))}return{flatDataX:o,flatDataY:s}}function ym(e,t,n){let{flatDataX:r,flatDataY:i}=vm(e,t),a=i.length;N(()=>a!==0&&(!n||a!==1),O(`Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero);let o=0,s=0;for(let e=0;e<a;e++)o+=i[e],s+=r[e];let c=o/a,l=s/a,u=0;for(let e=0;e<a;e++)u+=(i[e]-c)*(r[e]-l);return u/(a-+!!n)}function bm(e,t,n,r){let i=0,a=n?Ja:qa,o=a(e,(e,t)=>(i+=1,e+t),0,r);N(()=>i!==0&&(!t||i!==1),O(`Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero);let s=o/i;return a(e,(e,t)=>e+(t-s)**2,0,r)/(i-+!!t)}function xm(e,t,n,r){let i=F(t,r);N(()=>n?0<=i&&i<=1:0<i&&i<1,O(`Function [[FUNCTION_NAME]] parameter 2 value is out of range.`));let a=[],o,s=0;return Ua(e,e=>{let t=e?.value;typeof t==`number`&&(o=oo(a,e,`nextSmaller`,`asc`,a.length,(e,t)=>e[t]),a.splice(o+1,0,t),s++)}),N(()=>s!==0,O(`[[FUNCTION_NAME]] has no valid input data.`)),n||N(()=>1/(s+1)<=i&&i<=s/(s+1),O(`Function [[FUNCTION_NAME]] parameter 2 value is out of range.`)),Bi(a,i,n)}let Sm={description:O(`Average magnitude of deviations from mean.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){let t=0,n=qa(e,(e,n)=>(t+=1,e+n),0,this.locale);La(t);let r=n/t;return qa(e,(e,t)=>e+Math.abs(r-t),0,this.locale)/t},isExported:!0},Cm={description:O(`Numerical average value in a dataset, ignoring text.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the average value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the average value.`))],compute:function(...e){return{value:fu(e,this.locale),format:Ea(e[0])}},isExported:!0},wm=O(`[[FUNCTION_NAME]] has mismatched range sizes.`),Tm=O(`[[FUNCTION_NAME]] expects the weight to be positive or equal to 0.`),Em={description:O(`Weighted average.`),args:[W(`values (number, range<number>)`,O(`Values to average.`)),W(`weights (number, range<number>)`,O(`Weights for each corresponding value.`)),W(`additional_values (number, range<number>, repeating)`,O(`Additional values to average.`)),W(`additional_weights (number, range<number>, repeating)`,O(`Additional weights.`))],compute:function(...e){let t=0,n=0;for(let r=0;r<e.length-1;r+=2){let i=e[r],a=e[r+1];if(Af(wm,i,a),A(i))for(let e=0;e<i.length;e++)for(let r=0;r<i[0].length;r++){let o=i[e][r].value,s=A(a)?a?.[e][r].value:F(a,this.locale),c=typeof o==`number`,l=typeof s==`number`;if(c&&l){N(()=>s>=0,Tm),t+=o*s,n+=s;continue}N(()=>c===l,O(`[[FUNCTION_NAME]] expects number values.`))}else{let e=F(i,this.locale),r=A(a)?a?.[0][0].value:F(a,this.locale);typeof r==`number`&&(N(()=>r>=0,Tm),t+=e*r,n+=r)}}return La(n),{value:t/n,format:Ea(e[0])}}},Dm={description:O(`Numerical average value in a dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the average value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the average value.`))],compute:function(...e){let t=0,n=Ja(e,(e,n)=>(t+=1,e+n),0,this.locale);return La(t),{value:n/t,format:Ea(e[0])}},isExported:!0},Om={description:O(`Average of values depending on criteria.`),args:[W(`criteria_range (number, range<number>)`,O(`The range to check against criterion.`)),W(`criterion (string)`,O(`The pattern or test to apply to criteria_range.`)),W(`average_range (number, range<number>, default=criteria_range)`,O(`The range to average. If not included, criteria_range is used for the average instead.`))],compute:function(e,t,n){let r=z(n===void 0?e:n),i=0,a=0;return ao([e,t],(e,t)=>{let n=r[e]?.[t]?.value;typeof n==`number`&&(i+=1,a+=n)},this.locale),La(i),a/i},isExported:!0},km={description:O(`Average of values depending on multiple criteria.`),args:[W(`average_range (range)`,O(`The range to average.`)),W(`criteria_range1 (range)`,O(`The range to check against criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1.`)),W(`criteria_range2 (any, range, repeating)`,O(`Additional criteria_range and criterion to check.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=z(e),r=0,i=0;return ao(t,(e,t)=>{let a=n[e]?.[t]?.value;typeof a==`number`&&(r+=1,i+=a)},this.locale),La(r),i/r},isExported:!0},Am={description:O(`The number of numeric values in dataset.`),args:[W(`value1 (number, any, range<number>)`,O(`The first value or range to consider when counting.`)),W(`value2 (number, any, range<number>, repeating)`,O(`Additional values or ranges to consider when counting.`))],compute:function(...e){return pu(e,this.locale)},isExported:!0},jm={description:O(`The number of values in a dataset.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider when counting.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider when counting.`))],compute:function(...e){return mu(e)},isExported:!0},Mm={description:O(`The covariance of a dataset.`),args:[W(`data_y (any, range)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (any, range)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return ym(e,t,!1)},isExported:!0},Nm={description:O(`The covariance of a dataset.`),args:[W(`data_y (any, range)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (any, range)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return ym(e,t,!1)},isExported:!0},Pm={description:O(`The sample covariance of a dataset.`),args:[W(`data_y (any, range)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (any, range)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return ym(e,t,!0)},isExported:!0},Fm={description:O(`Calculates the expected y-value for a specified x based on a linear regression of a dataset.`),args:[W(`x (number, range<number>)`,O(`The value(s) on the x-axis to forecast.`)),W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t,n){let{flatDataX:r,flatDataY:i}=vm(t,n);return Du(r,i),wu([i],[r],Xa(z(e),e=>F(e,this.locale)),!0)},isExported:!0},Im={description:O(`Fits points to exponential growth trend.`),args:[W(`known_data_y (range<number>)`,O(`The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.`)),W(`known_data_x (range<number>, default={1;2;3;...})`,O(`The values of the independent variable(s) corresponding with known_data_y.`)),W(`new_data_x (any, range, default=known_data_x)`,O(`The data points to return the y values for on the ideal curve fit.`)),W(`b (boolean, default=TRUE)`,O(`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=[[]],n=[[]],r={value:!0}){return Eu(e,`known_data_y`),Su(wu(Cu(Ma(e,`known_data_y`)),Ma(t,`known_data_x`),Ma(n,`new_data_y`),L(r)))}},Lm={description:O(`Compute the intercept of the linear regression.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);Du(n,r);let[[],[i]]=vu([n],[r]);return i},isExported:!0},Rm={description:O(`Nth largest element from a data set.`),args:[W(`data (any, range)`,O(`Array or range containing the dataset to consider.`)),W(`n (number)`,O(`The rank from largest to smallest of the element to return.`))],compute:function(e,t){let n=Math.trunc(F(t?.value,this.locale)),r=[],i,a=0;Ua([e],e=>{typeof e?.value==`number`&&(i=oo(r,e,`nextSmaller`,`asc`,r.length,(e,t)=>e[t].value),r.splice(i+1,0,e),a++,a>n&&(r.shift(),a--))});let o=r.shift();return N(()=>o!==void 0,O(`[[FUNCTION_NAME]] has no valid input data.`)),N(()=>a>=n,O(`Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.`,n)),o},isExported:!0},zm={description:O(`Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>, default={1;2;3;...})`,O(`The range representing the array or matrix of independent data.`)),W(`calculate_b (boolean, default=TRUE)`,O(`A flag specifying wheter to compute the slope or not`)),W(`verbose (boolean, default=FALSE)`,O(`A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept`))],compute:function(e,t=[[]],n={value:!0},r={value:!1}){return Eu(e,`data_y`),vu(Ma(t,`data_x`),Ma(e,`data_y`),L(n),L(r))},isExported:!0},Bm={description:O(`Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>, optional, default={1;2;3;...})`,O(`The range representing the array or matrix of independent data.`)),W(`calculate_b (boolean, default=TRUE)`,O(`A flag specifying wheter to compute the slope or not`)),W(`verbose (boolean, default=FALSE)`,O(`A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept`))],compute:function(e,t=[[]],n={value:!0},r={value:!1}){Eu(e,`data_y`);let i=vu(Ma(t,`data_x`),Cu(Ma(e,`data_y`)),L(n),L(r));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},Vm={description:O(`Compute the Matthews correlation coefficient of a dataset.`),args:[W(`data_x (range)`,O(`The range representing the array or matrix of observed data.`)),W(`data_y (range)`,O(`The range representing the array or matrix of predicted data.`))],compute:function(e,t){let n=e.flat(),r=t.flat();du(n,r),Du(n,r);let i=n.length,a=0,o=0,s=0,c=0;for(let e=0;e<i;++e){let t=L(n[e]);t===L(r[e])?t?o++:a++:t?c++:s++}return(o*a-s*c)/Math.sqrt((o+s)*(o+c)*(a+s)*(a+c))},isExported:!1},Hm={description:O(`Maximum value in a numeric dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the maximum value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the maximum value.`))],compute:function(...e){return hu(e,this.locale)},isExported:!0},Um={description:O(`Maximum numeric value in a dataset.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider when calculating the maximum value.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider when calculating the maximum value.`))],compute:function(...e){let t=Ja(e,(e,t)=>Math.max(t,e),-1/0,this.locale);return{value:t===-1/0?0:t,format:Ea(e[0])}},isExported:!0},Wm={description:O(`Returns the maximum value in a range of cells, filtered by a set of criteria.`),args:[W(`range (range)`,O(`The range of cells from which the maximum will be determined.`)),W(`criteria_range1 (range)`,O(`The range of cells over which to evaluate criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=-1/0;return ao(t,(t,r)=>{let i=e[t]?.[r]?.value;typeof i==`number`&&(n=n<i?i:n)},this.locale),n===-1/0?0:n},isExported:!0},Gm={description:O(`Median value in a numeric dataset.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider when calculating the median value.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider when calculating the median value.`))],compute:function(...e){let t=[];return Wa(e,e=>{t.push(e)},this.locale),{value:xm(t,{value:.5},!0,this.locale),format:Ea(t[0])}},isExported:!0},Km={description:O(`Minimum value in a numeric dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the minimum value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the minimum value.`))],compute:function(...e){return gu(e,this.locale)},isExported:!0},qm={description:O(`Minimum numeric value in a dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the minimum value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the minimum value.`))],compute:function(...e){let t=Ja(e,(e,t)=>Math.min(t,e),1/0,this.locale);return{value:t===1/0?0:t,format:Ea(e[0])}},isExported:!0},Jm={description:O(`Returns the minimum value in a range of cells, filtered by a set of criteria.`),args:[W(`range (range)`,O(`The range of cells from which the minimum will be determined.`)),W(`criteria_range1 (range)`,O(`The range of cells over which to evaluate criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=1/0;return ao(t,(t,r)=>{let i=e[t]?.[r]?.value;typeof i==`number`&&(n=n>i?i:n)},this.locale),n===1/0?0:n},isExported:!0};function Ym(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);Du(n,r);let i=n.length,a=0,o=0,s=0,c=0,l=0;for(let e=0;e<i;e++){let t=n[e],i=r[e];a+=t,o+=i,s+=t*i,c+=t*t,l+=i*i}return(i*s-a*o)/Math.sqrt((i*c-a*a)*(i*l-o*o))}let Xm={description:O(`Compute the Pearson product-moment correlation coefficient of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return Ym(e,t)},isExported:!0},Zm=Xm,Qm={description:O(`Value at a given percentile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`percentile (number)`,O(`The percentile whose value within data will be calculated and returned.`))],compute:function(e,t){return eh.compute.bind(this)(e,t)},isExported:!0},$m={description:O(`Value at a given percentile of a dataset exclusive of 0 and 1.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`percentile (number)`,O(`The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned.`))],compute:function(e,t){return{value:xm([e],t,!1,this.locale),format:Ea(e)}},isExported:!0},eh={description:O(`Value at a given percentile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`percentile (number)`,O(`The percentile whose value within data will be calculated and returned.`))],compute:function(e,t){return{value:xm([e],t,!0,this.locale),format:Ea(e)}},isExported:!0},th={description:O(`Compute the coefficients of polynomial regression of the dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`)),W(`order (number)`,O(`The order of the polynomial to fit the data, between 1 and 6.`)),W(`intercept (boolean, default=TRUE)`,O(`A flag specifying whether to compute the intercept or not.`))],compute:function(e,t,n,r={value:!0}){let{flatDataX:i,flatDataY:a}=vm(e,t);return Du(i,a),yu(a,i,F(n,this.locale),L(r))},isExported:!1},nh={description:O(`Predict value by computing a polynomial regression of the dataset.`),args:[W(`x (number, range<number>)`,O(`The value(s) on the x-axis to forecast.`)),W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`)),W(`order (number)`,O(`The order of the polynomial to fit the data, between 1 and 6.`)),W(`intercept (boolean, default=TRUE)`,O(`A flag specifying whether to compute the intercept or not.`))],compute:function(e,t,n,r,i={value:!0}){let a=F(r,this.locale),{flatDataX:o,flatDataY:s}=vm(t,n);Du(o,s);let c=yu(s,o,a,L(i)).flat();return Xa(z(e),e=>xu(c,F(e,this.locale),a))},isExported:!1},rh={description:O(`Value nearest to a specific quartile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`quartile_number (number)`,O(`Which quartile value to return.`))],compute:function(e,t){return ah.compute.bind(this)(e,t)},isExported:!0},ih={description:O(`Value nearest to a specific quartile of a dataset exclusive of 0 and 4.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`quartile_number (number)`,O(`Which quartile value, exclusive of 0 and 4, to return.`))],compute:function(e,t){let n={value:.25*Math.trunc(F(t,this.locale))};return{value:xm([e],n,!1,this.locale),format:Ea(e)}},isExported:!0},ah={description:O(`Value nearest to a specific quartile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`quartile_number (number)`,O(`Which quartile value to return.`))],compute:function(e,t){let n={value:.25*Math.trunc(F(t,this.locale))};return{value:xm([e],n,!0,this.locale),format:Ea(e)}},isExported:!0},oh={description:O(`Returns the rank of a specified value in a dataset.`),args:[W(`value (number)`,O(`The value whose rank will be determined.`)),W(`data (range)`,O(`The range containing the dataset to consider.`)),W(`is_ascending (boolean, default=FALSE)`,O(`Whether to consider the values in data in descending or ascending order.`))],compute:function(e,t,n={value:!1}){let r=L(n),i=F(e,this.locale),a=1,o=!1;for(let e of t)for(let t of e){if(typeof t.value!=`number`)continue;let e=F(t,this.locale);e===i?o=!0:e>i!==r&&a++}return o?a:new Sa(O(`Value not found in the given data.`))},isExported:!0},sh={description:O(`Compute the square of r, the Pearson product-moment correlation coefficient of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return Ym(t,e)**2},isExported:!0},ch={description:O(`Compute the slope of the linear regression.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);Du(n,r);let[[i]]=vu([n],[r]);return i},isExported:!0},lh={description:O(`Nth smallest element in a data set.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`n (number)`,O(`The rank from smallest to largest of the element to return.`))],compute:function(e,t){let n=Math.trunc(F(t?.value,this.locale)),r=[],i,a=0;Ua([e],e=>{typeof e?.value==`number`&&(i=oo(r,e,`nextSmaller`,`asc`,r.length,(e,t)=>e[t].value),r.splice(i+1,0,e),a++,a>n&&(r.pop(),a--))});let o=r.pop();return N(()=>o!==void 0,O(`[[FUNCTION_NAME]] has no valid input data.`)),N(()=>a>=n,O(`Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.`,n)),o},isExported:!0},uh={description:O(`Compute the Spearman rank correlation coefficient of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(t,e);Du(n,r);let i=n.length,a=n.map((e,t)=>[e,r[t]]);a.sort((e,t)=>e[0]-t[0]);for(let e=0;e<i;++e)a[e][0]=e;a.sort((e,t)=>e[1]-t[1]);let o=0;for(let e=0;e<i;++e)o+=(a[e][0]-e)**2;return 1-6*o/(i**3-i)},isExported:!1},dh={description:O(`Standard deviation.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return Math.sqrt(yh.compute.bind(this)(...e))},isExported:!0},fh={description:O(`Standard deviation of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return Math.sqrt(bh.compute.bind(this)(...e))},isExported:!0},ph={description:O(`Standard deviation.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return Math.sqrt(xh.compute.bind(this)(...e))},isExported:!0},mh={description:O(`Standard deviation of sample (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return Math.sqrt(Sh.compute.bind(this)(...e))},isExported:!0},hh={description:O(`Standard deviation of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return Math.sqrt(Ch.compute.bind(this)(...e))},isExported:!0},gh={description:O(`Standard deviation of entire population (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return Math.sqrt(wh.compute.bind(this)(...e))},isExported:!0},_h={description:O(`Calculates the standard error of the predicted y-value for each x in the regression of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);return Du(n,r),vu([n],[r],!0,!0)[1][2]},isExported:!0},vh={description:O(`Fits points to linear trend derived via least-squares.`),args:[W(`known_data_y (number, range<number>)`,O(`The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.`)),W(`known_data_x (number, range<number>, optional, default={1;2;3;...})`,O(`The values of the independent variable(s) corresponding with known_data_y.`)),W(`new_data_x (number, range<number>, optional, default=known_data_x)`,O(`The data points to return the y values for on the ideal curve fit.`)),W(`b (boolean, optional, default=TRUE)`,O(`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=[[]],n=[[]],r={value:!0}){return Eu(e,`known_data_y`),wu(Ma(e,`known_data_y`),Ma(t,`known_data_x`),Ma(n,`new_data_y`),L(r))}},yh={description:O(`Variance.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return bm(e,!0,!1,this.locale)},isExported:!0},bh={description:O(`Variance of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return bm(e,!1,!1,this.locale)},isExported:!0},xh={description:O(`Variance.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return bm(e,!0,!1,this.locale)},isExported:!0},Sh={description:O(`Variance of sample (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return bm(e,!0,!0,this.locale)},isExported:!0},Ch={description:O(`Variance of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return bm(e,!1,!1,this.locale)},isExported:!0},wh={description:O(`Variance of entire population (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return bm(e,!1,!0,this.locale)},isExported:!0};var Th=l({DAVERAGE:()=>Oh,DCOUNT:()=>kh,DCOUNTA:()=>Ah,DGET:()=>jh,DMAX:()=>Mh,DMIN:()=>Nh,DPRODUCT:()=>Ph,DSTDEV:()=>Fh,DSTDEVP:()=>Ih,DSUM:()=>Lh,DVAR:()=>Rh,DVARP:()=>zh});function Eh(e,t,n,r){let i=new Map,a=e.length;for(let t=a-1;t>=0;t--)i.set(I(e[t][0]).toUpperCase(),t);let o=t?.value;if(typeof o!=`number`&&typeof o!=`string`)throw new M(O(`The field must be a number or a string`));let s;if(typeof o==`number`){if(s=Math.trunc(o)-1,s<0||a-1<s)throw new M(O(`The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.`,{fieldValue:o.toString(),dimRowDB:a.toString()}))}else{let e=I(t).toUpperCase();if(s=i.get(e)??-1,s===-1)throw new M(O(`The field (%s) must be one of %s.`,I(t),[...i.keys()].toString()))}let c=n[0].length;if(c<2)throw new M(O(`The criteria range contains %s row, it must be at least 2 rows.`,c.toString()));let l=new Set,u=e[0].length;for(let t=1;t<c;t++){let a=[],o=!0;for(let r=0;r<n.length;r++){let s=I(n[r][0]).toUpperCase(),c=i.get(s),l=n[r][t];if(l.value!==null)if(c!==void 0)a.push([e[c].slice(1,u)]),a.push(l);else{o=!1;break}}if(o)if(a.length>0)ao(a,(e,t)=>{l.add(t)},r,!0);else{l=new Set(Array(u-1).keys());break}}let d=e[s];return[...l].map(e=>d[e+1])}let Dh=[W(`database (range)`,O(`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.`)),W(`field (number, string)`,O(`Indicates which column in database contains the values to be extracted and operated on.`)),W(`criteria (range)`,O(`An array or range containing zero or more criteria to filter the database values by before operating.`))],Oh={description:O(`Average of a set of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Cm.compute.bind(this)([r])},isExported:!0},kh={description:O(`Counts values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Am.compute.bind(this)([r])},isExported:!0},Ah={description:O(`Counts values and text from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return jm.compute.bind(this)([r])},isExported:!0},jh={description:O(`Single value from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return N(()=>r.length===1,O(`More than one match found in DGET evaluation.`)),r[0]},isExported:!0},Mh={description:O(`Maximum of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Hm.compute.bind(this)([r])},isExported:!0},Nh={description:O(`Minimum of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Km.compute.bind(this)([r])},isExported:!0},Ph={description:O(`Product of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Xp.compute.bind(this)([r])},isExported:!0},Fh={description:O(`Standard deviation of population sample from table.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return dh.compute.bind(this)([r])},isExported:!0},Ih={description:O(`Standard deviation of entire population from table.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return hh.compute.bind(this)([r])},isExported:!0},Lh={description:O(`Sum of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return lm.compute.bind(this)([r])},isExported:!0},Rh={description:O(`Variance of population sample from table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return yh.compute.bind(this)([r])},isExported:!0},zh={description:O(`Variance of a population from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Ch.compute.bind(this)([r])},isExported:!0};var Bh=l({DATE:()=>Hh,DATEDIF:()=>Uh,DATEVALUE:()=>Wh,DAY:()=>Gh,DAYS:()=>Kh,DAYS360:()=>qh,EDATE:()=>Jh,EOMONTH:()=>Yh,HOUR:()=>Xh,ISOWEEKNUM:()=>Zh,MINUTE:()=>Qh,MONTH:()=>$h,MONTH_END:()=>hg,MONTH_START:()=>mg,NETWORKDAYS:()=>eg,NETWORKDAYS_INTL:()=>ng,NOW:()=>rg,QUARTER:()=>gg,QUARTER_END:()=>vg,QUARTER_START:()=>_g,SECOND:()=>ig,TIME:()=>ag,TIMEVALUE:()=>og,TODAY:()=>sg,WEEKDAY:()=>cg,WEEKNUM:()=>lg,WORKDAY:()=>ug,WORKDAY_INTL:()=>dg,YEAR:()=>fg,YEARFRAC:()=>pg,YEAR_END:()=>bg,YEAR_START:()=>yg}),Vh=function(e){return 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`,e}(Vh||{});let Hh={description:O(`Converts year/month/day into a date.`),args:[W(`year (number)`,O(`The year component of the date.`)),W(`month (number)`,O(`The month component of the date.`)),W(`day (number)`,O(`The day component of the date.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=Math.trunc(F(n,this.locale));N(()=>0<=r&&r<=9999,O(`The year (%s) must be between 0 and 9999 inclusive.`,r.toString())),r<1900&&(r+=1900);let o=vi(new D(r,i-1,a));return N(()=>o>=0,O(`The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.`)),{value:o,format:this.locale.dateFormat}},isExported:!0},Uh={description:O(`Calculates the number of days, months, or years between two dates.`),args:[W(`start_date (date)`,O(`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.`)),W(`end_date (date)`,O(`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.`)),W(`unit (string)`,O(`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,n){let r=I(n).toUpperCase();N(()=>Object.values(Vh).includes(r),Aa(Object.values(Vh),I(n)));let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=_i(i),s=_i(a);switch(N(()=>a>=i,O(`start_date (%s) should be on or before end_date (%s).`,o.toLocaleDateString(),s.toLocaleDateString())),r){case`Y`:return Di(o,s);case`M`:return Ti(o,s);case`D`:return Ei(o,s);case`YM`:return Ti(o,s)-Di(o,s)*12;case`MD`:let e=s.getDate()-o.getDate();return e<0&&(e=bi(new D(s.getFullYear(),s.getMonth()-1,1))-Math.abs(e)),e;case`YD`:{if(Oi(i,a))return Ei(o,s);let e=new D(o.getFullYear(),s.getMonth(),s.getDate()),t=Ei(o,e);return t<0&&(e.setFullYear(o.getFullYear()+1),t=Ei(o,e)),t}}},isExported:!0},Wh={description:O(`Converts a date string to a date value.`),args:[W(`date_string (string)`,O(`The string representing the date.`))],compute:function(e){let t=I(e),n=si(t,this.locale);return N(()=>n!==null,O(`The date_string (%s) cannot be parsed to date/time.`,t.toString())),Math.trunc(n.value)},isExported:!0},Gh={description:O(`Day of the month that a specific date falls on.`),args:[W(`date (string)`,O(`The date from which to extract the day.`))],compute:function(e){return R(e,this.locale).getDate()},isExported:!0},Kh={description:O(`Number of days between two dates.`),args:[W(`end_date (date)`,O(`The end of the date range.`)),W(`start_date (date)`,O(`The start of the date range.`))],compute:function(e,t){let n=R(e,this.locale),r=R(t,this.locale),i=n.getTime()-r.getTime();return Math.round(i/qr)},isExported:!0},qh={description:O(`Number of days between two dates on a 360-day year (months of 30 days).`),args:[W(`start_date (date)`,O(`The start date to consider in the calculation.`)),W(`end_date (date)`,O(`The end date to consider in the calculation.`)),W(`method (number, default=0)`,O(`An indicator of what day count method to use. (0) US NASD method (1) European method`))],compute:function(e,t,n={value:0}){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=wi(r,i,L(n)?4:0);return Math.sign(i-r)*Math.round(a*360)},isExported:!0},Jh={description:O(`Date a number of months before/after another date.`),args:[W(`start_date (date)`,O(`The date from which to calculate the result.`)),W(`months (number)`,O(`The number of months before (negative) or after (positive) 'start_date' to calculate.`))],compute:function(e,t){return{value:vi(Si(R(e,this.locale),Math.trunc(F(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},Yh={description:O(`Last day of a month before or after a date.`),args:[W(`start_date (date)`,O(`The date from which to calculate the result.`)),W(`months (number)`,O(`The number of months before (negative) or after (positive) 'start_date' to consider.`))],compute:function(e,t){let n=R(e,this.locale),r=Math.trunc(F(t,this.locale));return{value:vi(new D(n.getFullYear(),n.getMonth()+r+1,0)),format:this.locale.dateFormat}},isExported:!0},Xh={description:O(`Hour component of a specific time.`),args:[W(`time (date)`,O(`The time from which to calculate the hour component.`))],compute:function(e){return R(e,this.locale).getHours()},isExported:!0},Zh={description:O(`ISO week number of the year.`),args:[W(`date (date)`,O(`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){let t=R(e,this.locale),n=t.getFullYear(),r=1;for(;new D(n,0,r).getDay()!==4;)r+=1;let i=new D(n,0,r-3),a=31;for(;new D(n,11,a).getDay()!==4;)--a;let o=new D(n,11,a+3),s;s=i.getTime()<=t.getTime()?t.getTime()<=o.getTime()?0:1:-1;let c;switch(s){case 0:c=i;break;case 1:c=new D(n,11,a+3+1);break;case-1:let e=1;for(;new D(n-1,0,e).getDay()!==4;)e+=1;c=new D(n-1,0,e-3);break}let l=(t.getTime()-c.getTime())/qr;return Math.floor(l/7)+1},isExported:!0},Qh={description:O(`Minute component of a specific time.`),args:[W(`time (date)`,O(`The time from which to calculate the minute component.`))],compute:function(e){return R(e,this.locale).getMinutes()},isExported:!0},$h={description:O(`Month of the year a specific date falls in`),args:[W(`date (date)`,O(`The date from which to extract the month.`))],compute:function(e){return R(e,this.locale).getMonth()+1},isExported:!0},eg={description:O(`Net working days between two provided days.`),args:[W(`start_date (date)`,O(`The start date of the period from which to calculate the number of net working days.`)),W(`end_date (date)`,O(`The end date of the period from which to calculate the number of net working days.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the date serial numbers to consider holidays.`))],compute:function(e,t,n){return ng.compute.bind(this)(e,t,{value:1},n)},isExported:!0};function tg(e){let t=e?.value;if(typeof t==`string`){N(()=>{if(t.length!==7)return!1;for(let e of t)if(e!==`0`&&e!==`1`)return!1;return!0},O(`When weekend is a string (%s) it must be composed of "0" or "1".`,t));let e=[];for(let n=0;n<7;n++)t[n]===`1`&&e.push((n+1)%7);return e}if(typeof t==`number`)return N(()=>1<=t&&t<=7||11<=t&&t<=17,O(`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 M(O(`The weekend must be a number or a string.`))}let ng={description:O(`Net working days between two dates (specifying weekends).`),args:[W(`start_date (date)`,O(`The start date of the period from which to calculate the number of net working days.`)),W(`end_date (date)`,O(`The end date of the period from which to calculate the number of net working days.`)),W(`weekend (any, default=1)`,O(`A number or string representing which days of the week are considered weekends.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the dates to consider as holidays.`))],compute:function(e,t,n={value:1},r){let i=R(e,this.locale),a=R(t,this.locale),o=tg(n),s=new Set;r!==void 0&&Ua([r],e=>{let t=R(e,this.locale);s.add(t.getTime())});let c=i.getTime()>a.getTime(),l=D.fromTimestamp((c?i:a).getTime()),u=D.fromTimestamp((c?a:i).getTime()),d=l.getTime(),f=u.getTime(),p=0;for(;f<=d;)!o.includes(u.getDay())&&!s.has(f)&&(p+=1),u.setDate(u.getDate()+1),f=u.getTime();return c?-p:p},isExported:!0},rg={description:O(`Current date and time as a date value.`),args:[],compute:function(){let e=D.now(),t=e.getTime()-Kr.getTime(),n=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/qr)+n,format:$l(this.locale)}},isExported:!0},ig={description:O(`Minute component of a specific time.`),args:[W(`time (date)`,O(`The time from which to calculate the second component.`))],compute:function(e){return R(e,this.locale).getSeconds()},isExported:!0},ag={description:O(`Converts hour/minute/second into a time.`),args:[W(`hour (number)`,O(`The hour component of the time.`)),W(`minute (number)`,O(`The minute component of the time.`)),W(`second (number)`,O(`The second component of the time.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=Math.trunc(F(n,this.locale));return i+=Math.floor(a/60),a=a%60+(a<0?60:0),r+=Math.floor(i/60),i=i%60+(i<0?60:0),r%=24,N(()=>r>=0,O(`The function [[FUNCTION_NAME]] result cannot be negative`)),{value:r/24+i/1440+a/(1440*60),format:this.locale.timeFormat}},isExported:!0},og={description:O(`Converts a time string into its serial number representation.`),args:[W(`time_string (string)`,O(`The string that holds the time representation.`))],compute:function(e){let t=I(e),n=si(t,this.locale);N(()=>n!==null,O(`The time_string (%s) cannot be parsed to date/time.`,t));let r=n.value-Math.trunc(n.value);return r<0?1+r:r},isExported:!0},sg={description:O(`Current date as a date value.`),args:[],compute:function(){let e=D.now();return{value:vi(new D(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},cg={description:O(`Day of the week of the date provided (as number).`),args:[W(`date (date)`,O(`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.`)),W(`type (number, default=1)`,O(`A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1.`))],compute:function(e,t={value:1}){let n=R(e,this.locale),r=Math.round(F(t,this.locale)),i=n.getDay();return N(()=>[1,2,3].includes(r),O(`The type (%s) must be 1, 2 or 3.`,r.toString())),r===1?i+1:r===2?i===0?7:i:i===0?6:i-1},isExported:!0},lg={description:O(`Week number of the year.`),args:[W(`date (date)`,O(`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.`)),W(`type (number, default=1)`,O(`A number representing the day that a week starts on. Sunday = 1.`))],compute:function(e,t={value:1}){let n=R(e,this.locale),r=Math.round(F(t,this.locale));if(N(()=>r===1||r===2||11<=r&&r<=17||r===21,O(`The type (%s) is out of range.`,r.toString())),r===21)return Zh.compute.bind(this)(e);let i;i=r===1||r===2?r-1:r-10==7?0:r-10;let a=n.getFullYear(),o=1,s=new D(a,0,o);for(;s.getDay()!==i;)o+=1,s=new D(a,0,o);let c=(n.getTime()-s.getTime())/qr;return c<0?1:Math.floor(c/7)+(o===1?1:2)},isExported:!0},ug={description:O(`Date after a number of workdays.`),args:[W(`start_date (date)`,O(`The date from which to begin counting.`)),W(`num_days (number)`,O(`The number of working days to advance from start_date. If negative, counts backwards.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the dates to consider holidays.`))],compute:function(e,t,n={value:null}){return dg.compute.bind(this)(e,t,{value:1},n)},isExported:!0},dg={description:O(`Date after a number of workdays (specifying weekends).`),args:[W(`start_date (date)`,O(`The date from which to begin counting.`)),W(`num_days (number)`,O(`The number of working days to advance from start_date. If negative, counts backwards.`)),W(`weekend (any, default=1)`,O(`A number or string representing which days of the week are considered weekends.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the dates to consider holidays.`))],compute:function(e,t,n={value:1},r){let i=R(e,this.locale),a=Math.trunc(F(t,this.locale));typeof n.value==`string`&&N(()=>n.value!==`1111111`,O(`The weekend must be different from '1111111'.`));let o=tg(n),s=new Set;r!==void 0&&Ua([r],e=>{let t=R(e,this.locale);s.add(t.getTime())});let c=D.fromTimestamp(i.getTime()),l=c.getTime(),u=Math.sign(a),d=Math.abs(a);for(;d>0;)c.setDate(c.getDate()+u),l=c.getTime(),!o.includes(c.getDay())&&!s.has(l)&&--d;let f=l-Kr.getTime();return{value:Math.round(f/qr),format:this.locale.dateFormat}},isExported:!0},fg={description:O(`Year specified by a given date.`),args:[W(`date (date)`,O(`The date from which to extract the year.`))],compute:function(e){return R(e,this.locale).getFullYear()},isExported:!0},pg={description:O(`Exact number of years between two dates.`),args:[W(`start_date (date)`,O(`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.`)),W(`end_date (date)`,O(`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.`)),W(`day_count_convention (number, default=0)`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n={value:0}){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=Math.trunc(F(n,this.locale));return N(()=>r>=0,O(`The start_date (%s) must be positive or null.`,r.toString())),N(()=>i>=0,O(`The end_date (%s) must be positive or null.`,i.toString())),N(()=>0<=a&&a<=4,O(`The day_count_convention (%s) must be between 0 and 4 inclusive.`,a.toString())),wi(r,i,a)}},mg={description:O(`First day of the month preceding a date.`),args:[W(`date (date)`,O(`The date from which to calculate the result.`))],compute:function(e){let t=R(e,this.locale);return{value:vi(new D(t.getFullYear(),t.getMonth(),1)),format:this.locale.dateFormat}}},hg={description:O(`Last day of the month following a date.`),args:[W(`date (date)`,O(`The date from which to calculate the result.`))],compute:function(e){return Yh.compute.bind(this)(e,{value:0})}},gg={description:O(`Quarter of the year a specific date falls in`),args:[W(`date (date)`,O(`The date from which to extract the quarter.`))],compute:function(e){return Math.ceil((R(e,this.locale).getMonth()+1)/3)}},_g={description:O(`First day of the quarter of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the start of quarter.`))],compute:function(e){let t=gg.compute.bind(this)(e);return{value:vi(new D(fg.compute.bind(this)(e),(t-1)*3,1)),format:this.locale.dateFormat}}},vg={description:O(`Last day of the quarter of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the end of quarter.`))],compute:function(e){let t=gg.compute.bind(this)(e);return{value:vi(new D(fg.compute.bind(this)(e),t*3,0)),format:this.locale.dateFormat}}},yg={description:O(`First day of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the start of the year.`))],compute:function(e){return{value:vi(new D(fg.compute.bind(this)(e),0,1)),format:this.locale.dateFormat}}},bg={description:O(`Last day of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the end of the year.`))],compute:function(e){return{value:vi(new D(fg.compute.bind(this)(e)+1,0,0)),format:this.locale.dateFormat}}};var xg=l({DELTA:()=>Sg});let Sg={description:O(`Compare two numeric values, returning 1 if they're equal.`),args:[W(`number1 (number)`,O(`The first number to compare.`)),W(`number2 (number, default=0)`,O(`The second number to compare.`))],compute:function(e,t={value:0}){return+(F(e,this.locale)===F(t,this.locale))},isExported:!0},Cg=[`number`,`error`,`text`,`boolean`];function wg(e){let t=e===`asc`?1:-1;return(e,n)=>{if(e.type===`empty`)return n.type===`empty`?0:1;if(n.type===`empty`)return-1;let r=Cg.indexOf(e.type)-Cg.indexOf(n.type);return r===0&&(r=e.type===`text`||e.type===`error`?e.value.localeCompare(n.value):e.value-n.value),t*r}}function Tg(e,t,n){let r=e.map((e,t)=>({index:t,type:e.type,value:e.value}));return(n?r.map(e=>e.type===`empty`?{...e,type:`number`,value:0}:e):r).sort(wg(t))}function Eg(e,t,n,r,i){let a=r.right>r.left;if(e.model.getters.doesIntersectMerge(t,r)){a=!1;let n;for(let i=r.top;i<=r.bottom;i++){n=[];for(let a=r.left;a<=r.right;a++){let r=e.model.getters.getMerge({sheetId:t,col:a,row:i});r&&!n.includes(r.id.toString())&&n.push(r.id.toString())}if(n.length>=2){a=!0;break}}}if(a){Dg(e,t,n,r,i);return}let o=e.model.getters.getContiguousZone(t,r);gr(o,r)?Dg(e,t,n,r,i):e.askConfirmation(O(`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?`),()=>Dg(e,t,n,o,i),()=>Dg(e,t,n,r,i))}function Dg(e,t,n,r,i,a){let o=e.model.dispatch(`SORT_CELLS`,{sheetId:t,col:n.col,row:n.row,zone:r,sortDirection:i,sortOptions:a});if(o.isCancelledBecause(`InvalidSortZone`)){let{col:t,row:i}=n;e.model.selection.selectZone({cell:{col:t,row:i},zone:r}),e.raiseError(O(`Cannot sort. To sort, select only cells or only merges that have the same size.`))}if(o.isCancelledBecause(`SortZoneWithArrayFormulas`)){let{col:t,row:i}=n;e.model.selection.selectZone({cell:{col:t,row:i},zone:r}),e.raiseError(O(`Cannot sort a zone with array formulas.`))}}var Og=l({FILTER:()=>Ag,SORT:()=>jg,SORTN:()=>Mg,UNIQUE:()=>Ng});function kg(e,t,...n){for(let e=0;e<n.length;e++)N(()=>n[e]!==void 0,O(`Value for parameter %s is missing in [[FUNCTION_NAME]].`,e%2==0?`sort_column`:`is_ascending`));let r=[],i=[],a=e.length;for(let o=0;o<n.length;o+=2){r.push(L(cu(n[o+1])?.value)?`asc`:`desc`);let s=n[o];if(A(s)&&(s.length>1||s[0].length>1))N(()=>s.length===1&&s[0].length===a,O(`Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.`,`sort_column${o+1}`,a,s.length,s[0].length)),i.push(s.flat().map(e=>e.value));else{let n=F(cu(s)?.value,t);if(n<1||n>e[0].length)return e;i.push(e.map(e=>e[n-1].value))}}if(i.length===0)for(let t=0;t<e[0].length;t++)i.push(e.map(e=>e[t].value)),r.push(`asc`);let o={desc:wg(`desc`),asc:wg(`asc`)},s=S(0,e.length);return s.sort((e,t)=>{for(let[n,a]of i.entries()){let i=a[e],s=a[t],c={value:i,type:i===null?`empty`:typeof i==`string`?`text`:typeof i},l={value:s,type:s===null?`empty`:typeof s==`string`?`text`:typeof s},u=o[r[n]](c,l);if(u!==0)return u}return 0}),s.map(t=>e[t])}let Ag={description:O(`Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions.`),args:[W(`range (any, range<any>)`,O(`The data to be filtered.`)),W(`condition1 (boolean, range<boolean>)`,O(`A column or row containing true or false values corresponding to the first column or row of range.`)),W(`condition2 (boolean, range<boolean>, repeating)`,O(`Additional column or row containing true or false values.`))],compute:function(e,...t){let n=z(e),r=t.map(e=>Xa(z(e),e=>e.value));r.map(e=>kf(O(`The arguments condition must be a single column or row.`),e)),Af(O(`The arguments conditions must have the same dimensions.`),...t);let i=r.map(e=>e.flat()),a=r[0].length===1?`row`:`col`;n=a===`row`?Qa(n):n,N(()=>i.every(e=>e.length===n.length),O(`FILTER has mismatched sizes on the range and conditions.`));let o=[];for(let e=0;e<n.length;e++){let t=n[e];i.every(t=>(typeof t[e]==`boolean`||typeof t[e]==`number`)&&t[e])&&o.push(t)}return o.length?a===`row`?Qa(o):o:new Sa(O(`No match found in FILTER evaluation`))},isExported:!1},jg={description:O(`Sorts the rows of a given array or range by the values in one or more columns.`),args:[W(`range (range)`,O(`The data to be sorted.`)),W(`sort_column (any, range<number>, repeating)`,O(`The index of the column in range or a range outside of range containing the values by which to sort.`)),W(`is_ascending (boolean, repeating)`,O(`TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order.`))],compute:function(e,...t){return Qa(kg(Qa(e),this.locale,...t))},isExported:!0},Mg={description:O(`Returns the first n items in a data set after performing a sort.`),args:[W(`range (range)`,O(`The data to be sorted.`)),W(`n (number)`,O(`The number of items to return.`)),W(`display_ties_mode (number, default=0)`,O(`A number representing the way to display ties.`)),W(`sort_column (number, range<number>, repeating)`,O(`The index of the column in range or a range outside of range containing the values by which to sort.`)),W(`is_ascending (boolean, repeating)`,O(`TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order.`))],compute:function(e,t,...n){let r=F(t?.value??1,this.locale),i=n.length%2==0?0:F(n[0]?.value,this.locale),a=n.length%2==0?n:n.slice(1);N(()=>r>=0,O(`Wrong value of 'n'. Expected a positive number. Got %s.`,r)),N(()=>i>=0&&i<=3,O(`Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.`,i));let o=kg(Qa(e),this.locale,...a),s=(e,t)=>JSON.stringify(o[e].map(e=>e.value))===JSON.stringify(o[t].map(e=>e.value));switch(i){case 0:return Qa(o.slice(0,r));case 1:for(let e=r;e<o.length;e++)if(!s(e,r-1))return Qa(o.slice(0,e));return Qa(o);case 2:{let e=[o[0]];for(let t=1;t<o.length;t++)for(let n=0;n<t&&!s(t,n);n++)n===t-1&&e.push(o[t]);return Qa(e.slice(0,r))}case 3:{let e=[o[0]],t=1;for(let n=1;n<o.length&&(s(n,n-1)||t++,!(t>r));n++)e.push(o[n]);return Qa(e)}}},isExported:!1},Ng={description:O(`Unique rows in the provided source range.`),args:[W(`range (any, range<any>)`,O(`The data to filter by unique entries.`)),W(`by_column (boolean, default=FALSE)`,O(`Whether to filter the data by columns or by rows.`)),W(`exactly_once (boolean, default=FALSE)`,O(`Whether to return only entries with no duplicates.`))],compute:function(e={value:``},t,n){if(!A(e))return[[e]];let r=L(t?.value)||!1,i=L(n?.value)||!1;r||(e=Qa(e));let a=new Map;for(let t of e){let e=JSON.stringify(t.map(e=>e.value)),n=a.get(e);n?n.count++:a.set(e,{data:t,count:1})}let o=[];for(let e of a.values())i&&e.count>1||o.push(e.data);return o.length?r?o:Qa(o):new M(O(`No unique values found`))},isExported:!0};function Pg(e,t){N(()=>e<t,O(`The maturity (%s) must be strictly greater than the settlement (%s).`,t.toString(),e.toString()))}function Fg(e,t){N(()=>t<e,O(`The settlement date (%s) must be strictly greater than the issue date (%s).`,e.toString(),t.toString()))}function Ig(e){N(()=>[1,2,4].includes(e),O(`The frequency (%s) must be one of %s`,e.toString(),[1,2,4].toString()))}function Lg(e){N(()=>0<=e&&e<=4,O(`The day_count_convention (%s) must be between 0 and 4 inclusive.`,e.toString()))}function Rg(e){N(()=>e>0,O(`The redemption (%s) must be strictly positive.`,e.toString()))}function zg(e){N(()=>e>0,O(`The price (%s) must be strictly positive.`,e.toString()))}function Bg(e){N(()=>e>0,O(`The number_of_periods (%s) must be greater than 0.`,e.toString()))}function Vg(e){N(()=>e>0,O(`The rate (%s) must be strictly positive.`,e.toString()))}function Hg(e){N(()=>e>0,O(`The life (%s) must be strictly positive.`,e.toString()))}function Ug(e){N(()=>e>0,O(`The cost (%s) must be strictly positive.`,e.toString()))}function Wg(e){N(()=>e>=0,O(`The purchase_date (%s) must be positive or null.`,e.toString()))}function Gg(e){N(()=>e>=0,O(`The issue (%s) must be positive or null.`,e.toString()))}function Kg(e){N(()=>e>=0,O(`The cost (%s) must be positive or null.`,e.toString()))}function qg(e){N(()=>e>0,O(`The period (%s) must be strictly positive.`,e.toString()))}function Jg(e){N(()=>e>=0,O(`The period (%s) must be positive or null.`,e.toString()))}function Yg(e){N(()=>e>=0,O(`The salvage (%s) must be positive or null.`,e.toString()))}function Xg(e,t){N(()=>e<=t,O(`The salvage (%s) must be smaller or equal than the cost (%s).`,e.toString(),t.toString()))}function Zg(e){N(()=>e>0,O(`The present value (%s) must be strictly positive.`,e.toString()))}function Qg(e,t){N(()=>e<=t,O(`The period (%s) must be less than or equal life (%s).`,e.toString(),t.toString()))}function $g(e){N(()=>e>0,O(`The investment (%s) must be strictly positive.`,e.toString()))}function e_(e){N(()=>e>0,O(`The discount (%s) must be strictly positive.`,e.toString()))}function t_(e){N(()=>e<1,O(`The discount (%s) must be smaller than 1.`,e.toString()))}function n_(e){N(()=>e>0,O(`The depreciation factor (%s) must be strictly positive.`,e.toString()))}function r_(e,t,n){let r=R(e,n),i=R(t,n),a=R(e,n);a.setFullYear(r.getFullYear()+1),N(()=>i.getTime()<=a.getTime(),O(`The settlement date (%s) must at most one year after the maturity date (%s).`,e.toString(),t.toString()))}function i_(e,t,n){Bg(n),N(()=>e>0,O(`The first_period (%s) must be strictly positive.`,e.toString())),N(()=>t>0,O(`The last_period (%s) must be strictly positive.`,t.toString())),N(()=>e<=t,O(`The first_period (%s) must be smaller or equal to the last_period (%s).`,e.toString(),t.toString())),N(()=>t<=n,O(`The last_period (%s) must be smaller or equal to the number_of_periods (%s).`,e.toString(),n.toString()))}function a_(e,t,n){Hg(n),N(()=>e>=0,O(`The start_period (%s) must be greater or equal than 0.`,e.toString())),N(()=>t>=0,O(`The end_period (%s) must be greater or equal than 0.`,t.toString())),N(()=>e<=t,O(`The start_period (%s) must be smaller or equal to the end_period (%s).`,e.toString(),t.toString())),N(()=>t<=n,O(`The end_period (%s) must be smaller or equal to the life (%s).`,e.toString(),n.toString()))}function o_(e){N(()=>e>-1,O(`The rate_guess (%s) must be strictly greater than -1.`,e.toString()))}function s_(e,t){N(()=>e.length===t.length&&e[0].length===t[0].length,O(`The cashflow_amounts and cashflow_dates ranges must have the same dimensions.`))}function c_(e){N(()=>e.some(e=>e>0)&&e.some(e=>e<0),O(`There must be both positive and negative values in cashflow_amounts.`))}function l_(e){N(()=>e.every(t=>t>=e[0]),O(`All the dates should be greater or equal to the first date in cashflow_dates (%s).`,e[0].toString()))}var u_=l({ACCRINTM:()=>p_,AMORLINC:()=>m_,COUPDAYBS:()=>g_,COUPDAYS:()=>h_,COUPDAYSNC:()=>__,COUPNCD:()=>v_,COUPNUM:()=>y_,COUPPCD:()=>b_,CUMIPMT:()=>x_,CUMPRINC:()=>S_,DB:()=>C_,DDB:()=>T_,DISC:()=>E_,DOLLARDE:()=>D_,DOLLARFR:()=>O_,DURATION:()=>k_,EFFECT:()=>A_,FV:()=>M_,FVSCHEDULE:()=>N_,INTRATE:()=>P_,IPMT:()=>I_,IRR:()=>R_,ISPMT:()=>z_,MDURATION:()=>B_,MIRR:()=>V_,NOMINAL:()=>H_,NPER:()=>U_,NPV:()=>G_,PDURATION:()=>K_,PMT:()=>J_,PPMT:()=>X_,PRICE:()=>Q_,PRICEDISC:()=>$_,PRICEMAT:()=>ev,PV:()=>Z_,RATE:()=>nv,RECEIVED:()=>rv,RRI:()=>iv,SLN:()=>av,SYD:()=>ov,TBILLEQ:()=>lv,TBILLPRICE:()=>cv,TBILLYIELD:()=>uv,VDB:()=>dv,XIRR:()=>fv,XNPV:()=>pv,YIELD:()=>mv,YIELDDISC:()=>hv,YIELDMAT:()=>gv});let d_=[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))];function f_(e,t,n,r,i=1e-10,a){let o=n,s,c,l,u=!1,d=0,f;do{if(l=e(o),isNaN(l)){N(()=>d<r&&a!==void 0,O(`Function [[FUNCTION_NAME]] didn't find any result.`)),d++,o=a(f),f=o;continue}s=o-l/t(o),c=Math.abs(s-o),o=s,u=c<i||Math.abs(l)<i,N(()=>d<r,O(`Function [[FUNCTION_NAME]] didn't find any result.`)),d++}while(!u);return o}let p_={description:O(`Accrued interest of security paying at maturity.`),args:[W(`issue (date)`,O(`The date the security was initially issued.`)),W(`maturity (date)`,O(`The maturity date of the security.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(r,this.locale),c=F(n,this.locale),l=Math.trunc(F(i,this.locale));Gg(a),Fg(o,a),Lg(l),Rg(s),Vg(c);let u=wi(a,o,l);return s*c*u},isExported:!0},m_={description:O(`Depreciation for an accounting period.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`purchase_date (date)`,O(`The date the asset was purchased.`)),W(`first_period_end (date)`,O(`The date the first period ended.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`)),W(`rate (number)`,O(`The deprecation rate.`)),W(`day_count_convention (number, optional)`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a,o={value:0}){o||=0;let s=F(e,this.locale),c=Math.trunc(F(t,this.locale)),l=Math.trunc(F(n,this.locale)),u=F(r,this.locale),d=F(i,this.locale),f=F(a,this.locale),p=Math.trunc(F(o,this.locale));Ug(s),Wg(c),Yg(u),Xg(u,s),Jg(d),Vg(f),Lg(p),N(()=>c<=l,O(`The purchase_date (%s) must be before the first_period_end (%s).`,c.toString(),l.toString()));let m=d<1&&d>0?1:Math.trunc(d),h=s*f,g=wi(c,l,p),_=c===l?h:h*g,v=s-_-h*m;return v>=u?m===0?_:h:u-v<h?h-(u-v):0},isExported:!0},h_={description:O(`Days in coupon period containing settlement date.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));if(Pg(i,a),Ig(o),Lg(s),s===1){let i=b_.compute.bind(this)(e,t,n,r).value;return v_.compute.bind(this)(e,t,n,r).value-i}return(s===3?365:360)/o},isExported:!0},g_={description:O(`Days from settlement until next coupon.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=b_.compute.bind(this)(e,t,n,r).value;if([1,2,3].includes(s))return i-c;if(s===4){let e=wi(c,i,s);return Math.round(e*360)}let l=R(i,this.locale),u=R(c,this.locale),d=u.getFullYear(),f=l.getFullYear(),p=u.getMonth()+1,m=l.getMonth()+1,h=u.getDate(),g=l.getDate();return p===2&&m===2&&xi(u)&&xi(l)&&(g=30),g===31&&(h===30||h===31)&&(g=30),p===2&&xi(u)&&(h=30),h===31&&(h=30),(f-d)*360+(m-p)*30+(g-h)},isExported:!0},__={description:O(`Days from settlement until next coupon.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=v_.compute.bind(this)(e,t,n,r).value;if([1,2,3].includes(s))return c-i;if(s===4){let e=wi(i,c,s);return Math.round(e*360)}let l=g_.compute.bind(this)(e,t,n,r);return h_.compute.bind(this)(e,t,n,r)-l},isExported:!0},v_={description:O(`Next coupon date after the settlement date.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=12/o,l=y_.compute.bind(this)(e,t,n,r);return{value:vi(Si(R(a,this.locale),-(l-1)*c,!0)),format:this.locale.dateFormat}},isExported:!0},y_={description:O(`Number of coupons between settlement and maturity.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=1,l=a,u=12/o;for(;l>i;)l=vi(Si(R(l,this.locale),-u,!1)),c++;return c-1},isExported:!0},b_={description:O(`Last coupon date prior to or on the settlement date.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=12/o,l=y_.compute.bind(this)(e,t,n,r);return{value:vi(Si(R(a,this.locale),-l*c,!0)),format:this.locale.dateFormat}},isExported:!0},x_={description:O(`Cumulative interest paid over a set of periods.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`first_period (number)`,O(`The number of the payment period to begin the cumulative calculation.`)),W(`last_period (number)`,O(`The number of the payment period to end the cumulative calculation.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i,a={value:0}){let o=F(r,this.locale),s=F(i,this.locale),c=F(e,this.locale),l=F(n,this.locale),u=F(t,this.locale),d=+!!L(a);i_(o,s,u),Vg(c),Zg(l);let f=0;for(let e=o;e<=s;e++)f+=F_(c,e,u,l,0,d);return f},isExported:!0},S_={description:O(`Cumulative principal paid over a set of periods.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`first_period (number)`,O(`The number of the payment period to begin the cumulative calculation.`)),W(`last_period (number)`,O(`The number of the payment period to end the cumulative calculation.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i,a={value:0}){let o=F(r,this.locale),s=F(i,this.locale),c=F(e,this.locale),l=F(n,this.locale),u=F(t,this.locale),d=+!!L(a);i_(o,s,u),Vg(c),Zg(l);let f=0;for(let e=o;e<=s;e++)f+=Y_(c,e,u,l,0,d);return f},isExported:!0},C_={description:O(`Depreciation via declining balance method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`)),W(`month (number, optional)`,O(`The number of months in the first year of depreciation.`))],compute:function(e,t,n,r,...i){let a=F(e,this.locale),o=F(t,this.locale),s=F(n,this.locale),c=Math.trunc(F(r,this.locale)),l=i.length?Math.trunc(F(i[0],this.locale)):12,u=s+(l===12?0:1);Kg(a),Yg(o),qg(c),Hg(s),N(()=>1<=l&&l<=12,O(`The month (%s) must be between 1 and 12 inclusive.`,l.toString())),N(()=>c<=u,O(`The period (%s) must be less than or equal to %s.`,c.toString(),u.toString()));let d=l/12,f=1-(o/a)**(1/s);f=Math.round(f*1e3)/1e3;let p=a,m=a*(1-f*d);for(let e=1;e<c;e++)p=m,m=p*(1-f),e===s&&(m=p*(1-f*(1-d)));return{value:p-m,format:`#,##0.00`}},isExported:!0};function w_(e,t,n,r,i){if(Kg(e),Yg(t),qg(r),Hg(n),Qg(r,n),n_(i),e===0||t>=e)return 0;let a=i/n;if(a>1)return r===1?e-t:0;if(r<=1)return e*a;let o=e*(1-a)**(r-1),s=e*(1-a)**r,c=s<t?o-t:o-s;return Math.max(c,0)}let T_={description:O(`Depreciation via double-declining balance method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`)),W(`factor (number, default=2)`,O(`The factor by which depreciation decreases.`))],compute:function(e,t,n,r,i={value:2}){return{value:w_(F(e,this.locale),F(t,this.locale),F(n,this.locale),F(r,this.locale),F(i,this.locale)),format:`#,##0.00`}},isExported:!0},E_={description:O(`Discount rate of a security based on price.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),Lg(l),zg(s),Rg(c);let u=wi(a,o,l);return(c-s)/c/u},isExported:!0},D_={description:O(`Convert a decimal fraction to decimal value.`),args:[W(`fractional_price (number)`,O(`The price quotation given using fractional decimal conventions.`)),W(`unit (number)`,O(`The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));N(()=>r>0,O(`The unit (%s) must be strictly positive.`,r.toString()));let i=Math.trunc(n);return i+(n-i)*(10**Math.ceil(Math.log10(r))/r)},isExported:!0},O_={description:O(`Convert a decimal value to decimal fraction.`),args:[W(`decimal_price (number)`,O(`The price quotation given as a decimal value.`)),W(`unit (number)`,O(`The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));N(()=>r>0,O(`The unit (%s) must be strictly positive.`,r.toString()));let i=Math.trunc(n);return i+(n-i)*(r/10**Math.ceil(Math.log10(r)))},isExported:!0},k_={description:O(`Number of periods for an investment to reach a value.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){let o=Math.trunc(F(e,this.locale)),s=Math.trunc(F(t,this.locale)),c=F(n,this.locale),l=F(r,this.locale),u=Math.trunc(F(i,this.locale)),d=Math.trunc(F(a,this.locale));Pg(o,s),Ig(u),Lg(d),N(()=>c>=0,O(`The rate (%s) must be positive or null.`,c.toString())),N(()=>l>=0,O(`The yield (%s) must be positive or null.`,l.toString()));let f=wi(o,s,d),p=f-Math.trunc(f)||1/u,m=Math.ceil(f*u),h=c/u,g=l/u,_=0,v=0;for(let e=1;e<=m;e++){let t=(h+ +(e===m))/(1+g)**e;v+=(p+(e-1)/u)*t,_+=t}return _===0?0:v/_},isExported:!0},A_={description:O(`Annual effective interest rate.`),args:[W(`nominal_rate (number)`,O(`The nominal interest rate per year.`)),W(`periods_per_year (number)`,O(`The number of compounding periods per year.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));return N(()=>n>0,O(`The nominal rate (%s) must be strictly greater than 0.`,n.toString())),N(()=>r>0,O(`The number of periods by year (%s) must strictly greater than 0.`,r.toString())),(1+n/r)**+r-1},isExported:!0};function j_(e,t,n,r,i){return e===0?-(r+n*t):-r*(1+e)**t-n*(1+e*i)*((1+e)**t-1)/e}let M_={description:O(`Future value of an annuity investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`payment_amount (number)`,O(`The amount per period to be paid.`)),W(`present_value (number, default=0)`,O(`The current value of the annuity.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){return r||=0,i||=0,{value:j_(F(e,this.locale),F(t,this.locale),F(n,this.locale),F(r,this.locale),+!!L(i)),format:`#,##0.00`}},isExported:!0},N_={description:O(`Future value of principal from series of rates.`),args:[W(`principal (number)`,O(`The amount of initial capital or value to compound against.`)),W(`rate_schedule (number, range<number>)`,O(`A series of interest rates to compound against the principal.`))],compute:function(e,t){let n=F(e,this.locale);return Ka([t],(e,t)=>e*(1+F(t,this.locale)),n)},isExported:!0},P_={description:O(`Calculates effective interest rate.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`investment (number)`,O(`The amount invested in the security.`)),W(`redemption (number)`,O(`The amount to be received at maturity.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(r,this.locale),c=F(n,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),$g(c),Rg(s),Lg(l);let u=wi(a,o,l);return(s-c)/c/u},isExported:!0};function F_(e,t,n,r,i,a){return q_(e,n,r,i,a)-Y_(e,t,n,r,i,a)}let I_={description:O(`Payment on the principal of an investment.`),args:[W(`rate (number)`,O(`The annualized rate of interest.`)),W(`period (number)`,O(`The amortization period, in terms of number of periods.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i={value:0},a={value:0}){return{value:F_(F(e,this.locale),F(t,this.locale),F(n,this.locale),F(r,this.locale),F(i,this.locale),+!!L(a)),format:`#,##0.00`}},isExported:!0},L_=.1,R_={description:O(`Internal rate of return given periodic cashflows.`),args:[W(`cashflow_amounts (number, range<number>)`,O(`An array or range containing the income or payments associated with the investment.`)),W(`rate_guess (number, default=${L_})`,O(`An estimate for what the internal rate of return will be.`))],compute:function(e,t={value:L_}){let n=F(t,this.locale);o_(n);let r=!1,i=!1,a=[];Wa([e],({value:e})=>{e>0&&(r=!0),e<0&&(i=!0),a.push(e)},this.locale),N(()=>r&&i,O(`The cashflow_amounts must include negative and positive values.`));let o=a.shift();function s(e,t,n){let r=n.length,i=0;return n.reduce((t,n)=>(i++,t+n*e**(r-i)),t*e**r)}function c(e,t,n){let r=n.length,i=0;return n.reduce((t,n)=>(i++,t+n*(r-i)*e**(r-i-1)),t*r*e**(r-1))}function l(e){return s(e,o,a)}function u(e){return c(e,o,a)}return{value:f_(l,u,n+1,20,1e-5)-1,format:`0%`}},isExported:!0},z_={description:O(`Returns the interest paid at a particular period of an investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`period (number)`,O(`The period for which you want to view the interest payment.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`))],compute:function(e,t,n,r){let i=F(e,this.locale),a=F(t,this.locale),o=F(n,this.locale),s=F(r,this.locale);return N(()=>o!==0,O(`The number of periods must be different than 0.`,o.toString())),-1*(s-a/o*s)*i},isExported:!0},B_={description:O(`Modified Macaulay duration.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){return k_.compute.bind(this)(e,t,n,r,i,a)/(1+F(r,this.locale)/Math.trunc(F(i,this.locale)))},isExported:!0},V_={description:O(`Modified internal rate of return.`),args:[W(`cashflow_amounts (range<number>)`,O(`A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.`)),W(`financing_rate (number)`,O(`The interest rate paid on funds invested.`)),W(`reinvestment_return_rate (number)`,O(`The return (as a percentage) earned on reinvestment of income received from the investment.`))],compute:function(e,t,n){let r=F(t,this.locale),i=F(n,this.locale),a=Qa(e).flat().filter(e=>e.value!==null).map(e=>F(e,this.locale)),o=a.length,s=0,c=0;for(let e of S(0,o)){let t=a[e];t>=0?s+=t*(i+1)**(o-e-1):c+=t/(r+1)**e}N(()=>c!==0&&s!==0,O(`There must be both positive and negative values in cashflow_amounts.`));let l=1/(o-1);return(-s/c)**l-1},isExported:!0},H_={description:O(`Annual nominal interest rate.`),args:[W(`effective_rate (number)`,O(`The effective interest rate per year.`)),W(`periods_per_year (number)`,O(`The number of compounding periods per year.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));return N(()=>n>0,O(`The effective rate (%s) must must strictly greater than 0.`,n.toString())),N(()=>r>0,O(`The number of periods by year (%s) must strictly greater than 0.`,r.toString())),((n+1)**(1/r)-1)*r},isExported:!0},U_={description:O(`Number of payment periods for an investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`payment_amount (number)`,O(`The amount of each payment made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){r||=0,i||=0;let a=F(e,this.locale),o=F(t,this.locale),s=F(n,this.locale),c=F(r,this.locale),l=+!!L(i);if(a===0)return-(c+s)/o;let u=o*(1+a*l)/a;return Math.log((u-c)/(s+u))/Math.log(1+a)},isExported:!0};function W_(e,t,n,r){let i=0;return qa(n,(t,n)=>(i++,t+n/(1+e)**i),t,r)}let G_={description:O(`The net present value of an investment based on a series of periodic cash flows and a discount rate.`),args:[W(`discount (number)`,O(`The discount rate of the investment over one period.`)),W(`cashflow1 (number, range<number>)`,O(`The first future cash flow.`)),W(`cashflow2 (number, range<number>, repeating)`,O(`Additional future cash flows.`))],compute:function(e,...t){let n=F(e,this.locale);return N(()=>n!==-1,O(`The discount (%s) must be different from -1.`,n.toString())),{value:W_(n,0,t,this.locale),format:`#,##0.00`}},isExported:!0},K_={description:O(`Computes the number of periods needed for an investment to reach a value.`),args:[W(`rate (number)`,O(`The rate at which the investment grows each period.`)),W(`present_value (number)`,O(`The investment's current value.`)),W(`future_value (number)`,O(`The investment's desired future value.`))],compute:function(e,t,n){let r=F(e,this.locale),i=F(t,this.locale),a=F(n,this.locale);return Vg(r),N(()=>i>0,O(`The present_value (%s) must be strictly positive.`,i.toString())),N(()=>a>0,O(`The future_value (%s) must be strictly positive.`,a.toString())),(Math.log(a)-Math.log(i))/Math.log(1+r)},isExported:!0};function q_(e,t,n,r,i){if(Bg(t),e===0)return-(r+n)/t;let a=-(n*(1+e)**t+r);return a=a*e/((1+e*i)*((1+e)**t-1)),a}let J_={description:O(`Periodic payment for an annuity investment.`),args:[W(`rate (number)`,O(`The annualized rate of interest.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){let a=F(t,this.locale),o=F(e,this.locale),s=+!!L(i),c=F(r,this.locale);return{value:q_(o,a,F(n,this.locale),c,s),format:`#,##0.00`}},isExported:!0};function Y_(e,t,n,r,i,a){Bg(n),N(()=>t>0&&t<=n,O(`The period must be between 1 and number_of_periods (%s)`,n));let o=q_(e,n,r,i,a);return a===1&&t===1?o:o+-j_(e,a===0?t-1:t-2,o,r+o*a,0)*e}let X_={description:O(`Payment on the principal of an investment.`),args:[W(`rate (number)`,O(`The annualized rate of interest.`)),W(`period (number)`,O(`The amortization period, in terms of number of periods.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i={value:0},a={value:0}){let o=F(n,this.locale),s=F(e,this.locale),c=F(t,this.locale),l=+!!L(a),u=F(i,this.locale);return{value:Y_(s,c,o,F(r,this.locale),u,l),format:`#,##0.00`}},isExported:!0},Z_={description:O(`Present value of an annuity investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`payment_amount (number)`,O(`The amount per period to be paid.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){r||=0,i||=0;let a=F(e,this.locale),o=F(t,this.locale),s=F(n,this.locale),c=F(r,this.locale),l=+!!L(i);return{value:a?-(s*(1+a*l)*((1+a)**o-1)/a+c)/(1+a)**o:-(c+s*o),format:`#,##0.00`}},isExported:!0},Q_={description:O(`Price of a security paying periodic interest.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a,o={value:0}){o||=0;let s=Math.trunc(F(e,this.locale)),c=Math.trunc(F(t,this.locale)),l=F(n,this.locale),u=F(r,this.locale),d=F(i,this.locale),f=Math.trunc(F(a,this.locale)),p=Math.trunc(F(o,this.locale));Pg(s,c),Ig(f),Lg(p),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),N(()=>u>=0,O(`The yield (%s) must be positive or null.`,u.toString())),Rg(d);let m=wi(s,c,p)*f,h=Math.ceil(m),g=m-Math.floor(m)||1,_=1+u/f,v=100*l/f;if(h===1)return(v+d)/(g*u/f+1)-v*(1-g);let y=0;for(let e=1;e<=h;e++)y+=v/_**(e-1+g);return d/_**(h-1+g)+y-v*(1-g)},isExported:!0},$_={description:O(`Price of a discount security.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`discount (number)`,O(`The discount rate of the security at time of purchase.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),Lg(l),e_(s),Rg(c);let u=wi(a,o,l);return c-s*c*u},isExported:!0},ev={description:O(`Calculates the price of a security paying interest at maturity, based on expected yield.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`issue (date)`,O(`The date the security was initially issued.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){a||=0;let o=Math.trunc(F(e,this.locale)),s=Math.trunc(F(t,this.locale)),c=Math.trunc(F(n,this.locale)),l=F(r,this.locale),u=F(i,this.locale),d=Math.trunc(F(a,this.locale));Fg(o,c),Pg(o,s),Lg(d),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),N(()=>u>=0,O(`The yield (%s) must be positive or null.`,u.toString()));let f=wi(o,s,d),p=wi(o,c,d),m=100+wi(c,s,d)*l*100,h=1+f*u,g=p*l*100;return m/h-g},isExported:!0},tv=.1,nv={description:O(`Interest rate of an annuity investment.`),args:[W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`payment_per_period (number)`,O(`The amount per period to be paid.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`)),W(`rate_guess (number, default=${tv})`,O(`An estimate for what the interest rate will be.`))],compute:function(e,t,n,r={value:0},i={value:0},a={value:tv}){let o=F(e,this.locale),s=F(t,this.locale),c=+!!L(i),l=F(a,this.locale)||tv,u=F(r,this.locale),d=F(n,this.locale);return Bg(o),N(()=>[s,d,u].some(e=>e>0)&&[s,d,u].some(e=>e<0),O(`There must be both positive and negative values in [payment_amount, present_value, future_value].`,o.toString())),o_(l),u-=s*c,d+=s*c,{value:f_(e=>{let t=(1+e)**+o,n=(t-1)/e;return u+d*t+s*n},e=>{let t=(1+e)**(o-1),n=((1+e)**+o-1)/e,r=o*t/e-n/e;return d*o*t+s*r},l,40,1e-5),format:`0%`}},isExported:!0},rv={description:O(`Amount received at maturity for a security.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`investment (number)`,O(`The amount invested (irrespective of face value of each security).`)),W(`discount (number)`,O(`The discount rate of the security invested in.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));return Pg(a,o),Lg(l),$g(s),e_(c),s/(1-c*wi(a,o,l))},isExported:!0},iv={description:O(`Computes the rate needed for an investment to reach a specific value within a specific number of periods.`),args:[W(`number_of_periods (number)`,O(`The number of periods.`)),W(`present_value (number)`,O(`The present value of the investment.`)),W(`future_value (number)`,O(`The future value of the investment.`))],compute:function(e,t,n){let r=F(e,this.locale),i=F(t,this.locale),a=F(n,this.locale);return Bg(r),(a/i)**(1/r)-1},isExported:!0},av={description:O(`Depreciation of an asset using the straight-line method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`))],compute:function(e,t,n){let r=F(e,this.locale),i=F(t,this.locale),a=F(n,this.locale);return{value:(r-i)/a,format:`#,##0.00`}},isExported:!0},ov={description:O(`Depreciation via sum of years digit method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`))],compute:function(e,t,n,r){let i=F(e,this.locale),a=F(t,this.locale),o=F(n,this.locale),s=F(r,this.locale);qg(s),Hg(o),Qg(s,o);let c=o*(o+1)/2,l=o-s+1;return{value:(i-a)*(l/c),format:`#,##0.00`}},isExported:!0};function sv(e,t,n){return 100*(1-n*wi(e,t,2))}let cv={description:O(`Price of a US Treasury bill.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`discount (number)`,O(`The discount rate of the bill at time of purchase.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=F(n,this.locale);return Pg(r,i),r_(r,i,this.locale),e_(a),t_(a),sv(r,i,a)},isExported:!0},lv={description:O(`Equivalent rate of return for a US Treasury bill.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`discount (number)`,O(`The discount rate of the bill at time of purchase.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=F(n,this.locale);Pg(r,i),r_(r,i,this.locale),e_(a),t_(a);let o=Kh.compute.bind(this)({value:i},{value:r});if(o<=182)return 365*a/(360-a*o);let s=sv(r,i,a)/100,c=o/(o===366?366:365);return(-2*c+2*Math.sqrt(c**2-(2*c-1)*(1-1/s)))/(2*c-1)},isExported:!0},uv={description:O(`The yield of a US Treasury bill based on price.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=F(n,this.locale);Pg(r,i),r_(r,i,this.locale),zg(a);let o=wi(r,i,2);return(100-a)/a*(1/o)},isExported:!0},dv={description:O(`Variable declining balance. WARNING : does not handle decimal periods.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`start (number)`,O(`Starting period to calculate depreciation.`)),W(`end (number)`,O(`Ending period to calculate depreciation.`)),W(`factor (number, default=2)`,O(`The number of months in the first year of depreciation.`)),W(`no_switch (number, default=false)`,O(`Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation.`))],compute:function(e,t,n,r,i,a={value:2},o={value:!1}){a||=0;let s=F(e,this.locale),c=F(t,this.locale),l=F(n,this.locale),u=Math.trunc(F(r,this.locale)),d=Math.trunc(F(i,this.locale)),f=F(a,this.locale),p=L(o);if(Kg(s),Yg(c),a_(u,d,l),n_(f),s===0)return 0;if(c>=s)return u<1?s-c:0;let m=f/l;if(m>=1)return u<1?s-c:0;let h=s,g=0,_=0,v=!1;for(let e=0;e<d;e++){if(!v||p){let t=h*m,n=l-e,r=(h-c)/n;!p&&r>t?(v=!0,g=r):g=t}let t=Math.max(h-g,c);e>=u&&(_+=h-t),h=t}return _},isExported:!0},fv={description:O(`Internal rate of return given non-periodic cash flows.`),args:[W(`cashflow_amounts (range<number>)`,O(`An range containing the income or payments associated with the investment.`)),W(`cashflow_dates (range<number>)`,O(`An range with dates corresponding to the cash flows in cashflow_amounts.`)),W(`rate_guess (number, default=${tv})`,O(`An estimate for what the internal rate of return will be.`))],compute:function(e,t,n={value:tv}){let r=F(n,this.locale),i=e.flat().map(e=>F(e,this.locale)),a=t.flat().map(e=>F(e,this.locale));s_(e,t),c_(i),l_(a),o_(r);let o=new Map;for(let e of S(0,a.length)){let t=a[e];o.has(t)?o.set(t,o.get(t)+i[e]):o.set(t,i[e])}let s=Array.from(o.keys()),c=s.map(e=>o.get(e));return f_(e=>{let t=c[0];for(let n of S(1,c.length)){let r=(s[0]-s[n])/365;t+=c[n]*(1+e)**r}return t},e=>{let t=0;for(let n of S(1,c.length)){let r=(s[0]-s[n])/365;t+=r*c[n]*(1+e)**(r-1)}return t},r,40,1e-5,e=>e?e/10-.9:-.9)},isExported:!0},pv={description:O(`Net present value given to non-periodic cash flows..`),args:[W(`discount (number)`,O(`The discount rate of the investment over one period.`)),W(`cashflow_amounts (number, range<number>)`,O(`An range containing the income or payments associated with the investment.`)),W(`cashflow_dates (number, range<number>)`,O(`An range with dates corresponding to the cash flows in cashflow_amounts.`))],compute:function(e,t,n){let r=F(e,this.locale),i=A(t)?t.flat().map(e=>Na(e,this.locale)):[Na(t,this.locale)],a=A(n)?n.flat().map(e=>Na(e,this.locale)):[Na(n,this.locale)];if(A(n)&&A(t)?s_(t,n):N(()=>i.length===a.length,O(`There must be the same number of values in cashflow_amounts and cashflow_dates.`)),l_(a),Vg(r),i.length===1)return i[0];let o=new Map;for(let e of S(0,a.length)){let t=a[e];o.has(t)?o.set(t,o.get(t)+i[e]):o.set(t,i[e])}let s=Array.from(o.keys()),c=s.map(e=>o.get(e)),l=c[0];for(let e of S(1,c.length)){let t=(s[0]-s[e])/365;l+=c[e]*(1+r)**t}return l},isExported:!0},mv={description:O(`Annual yield of a security paying periodic interest.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a,o={value:0}){o||=0;let s=Math.trunc(F(e,this.locale)),c=Math.trunc(F(t,this.locale)),l=F(n,this.locale),u=F(r,this.locale),d=F(i,this.locale),f=Math.trunc(F(a,this.locale)),p=Math.trunc(F(o,this.locale));Pg(s,c),Ig(f),Lg(p),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),zg(u),Rg(d);let m=wi(s,c,p)*f,h=Math.ceil(m),g=m-Math.floor(m)||1,_=100*l/f;if(h===1){let e=u+_*(1-g);return(d+_-e)*f*(1/g)/e}function v(e,t,n,r,i,a){let o=a-(e+i*(1-t))*r**(n-1+t);for(let e=1;e<=n;e++)o+=i*r**(e-1);return o}function y(e,t,n,r,i){let a=-(e+i*(1-t))*(n-1+t)*r**(n-2+t);for(let e=1;e<=n;e++)a+=i*(e-1)*r**(e-2);return a}function ee(e){return v(u,g,h,e,_,d)}function te(e){return y(u,g,h,e,_)}return(f_(ee,te,1+(l+1)/f,100,1e-5)-1)*f},isExported:!0},hv={description:O(`Annual yield of a discount security.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),Lg(l),zg(s),Rg(c);let u=wi(a,o,l);return(c/s-1)/u},isExported:!0},gv={description:O(`Annual yield of a security paying interest at maturity.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`issue (date)`,O(`The date the security was initially issued.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`price (number)`,O(`The price at which the security is bought.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){a||=0;let o=Math.trunc(F(e,this.locale)),s=Math.trunc(F(t,this.locale)),c=Math.trunc(F(n,this.locale)),l=F(r,this.locale),u=F(i,this.locale),d=Math.trunc(F(a,this.locale));Pg(o,s),Lg(d),N(()=>o>=c,O(`The settlement (%s) must be greater than or equal to the issue (%s).`,o.toString(),c.toString())),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),zg(u);let f=wi(c,s,d),p=wi(c,o,d),m=wi(o,s,d);return(100*(1+l*f)/(u+100*l*p)-1)/m},isExported:!0},_v=(e,t=()=>!0)=>[{goTo:e,guard:t}],vv=(e,t=()=>!0)=>({goTo:e,guard:t}),yv={0:{REFERENCE:_v(2),NUMBER:_v(4),SYMBOL:[vv(3,e=>ec(e.value)),vv(4,e=>tc(e.value))]},3:{SPACE:_v(3),OPERATOR:_v(5,e=>e.value===`:`)},4:{SPACE:_v(4),OPERATOR:_v(6,e=>e.value===`:`)},2:{SPACE:_v(2),OPERATOR:_v(1,e=>e.value===`:`)},1:{SPACE:_v(1),NUMBER:_v(7),REFERENCE:_v(7,e=>ic(e.value)),SYMBOL:_v(7,e=>nc(e.value)||rc(e.value))},5:{SPACE:_v(5),SYMBOL:_v(7,e=>nc(e.value)),REFERENCE:_v(7,e=>ic(e.value))},6:{SPACE:_v(6),NUMBER:_v(7),REFERENCE:_v(7,e=>ic(e.value)),SYMBOL:_v(7,e=>rc(e.value))},7:{}};function bv(e){let t=0,n=yv[0],r=``;for(;n!==void 0;){let i=e[t++];if(!i)return null;let a=n[i.type]?.find(e=>e.guard(i)),o=a?a.goTo:void 0;switch(o){case void 0:return null;case 7:return r+=i.value,e.splice(0,t),{type:`REFERENCE`,value:r};default:n=yv[o],r+=i.value;break}}return null}function xv(e,t=k){let n=bl(e,t),r=[];for(;n.length;)r.push(bv(n)||n.shift());return r}let Sv=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Cv=[`-`,`+`],wv=[`%`],Tv=[`*`,`+`,`&`];var Ev=class{tokens;currentIndex=0;current;length;constructor(e){this.tokens=e,this.current=e[0],this.length=e.length}shift(){let e=this.tokens[this.currentIndex];return this.current=this.tokens[++this.currentIndex],e}get next(){return this.tokens[this.currentIndex+1]}};let Dv={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function Ov(e){let t=e.shift();if(!t)throw new ya;switch(t.type){case`DEBUGGER`:let n=Mv(e,1e3);return n.debug=!0,n;case`NUMBER`:return{type:`NUMBER`,value:zi(t.value,k),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`STRING`:return{type:`STRING`,value:rt(t.value),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`INVALID_REFERENCE`:return{type:`REFERENCE`,value:j.InvalidReference,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`REFERENCE`:if(e.current?.value===`:`&&e.next?.type===`REFERENCE`){e.shift();let n=e.shift();return{type:`REFERENCE`,value:`${t.value}:${n?.value}`,tokenStartIndex:t.tokenIndex,tokenEndIndex:n.tokenIndex}}return{type:`REFERENCE`,value:t.value,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`SYMBOL`:let r=t.value;if(e.current?.type===`LEFT_PAREN`&&Sv.test(t.value)&&r===ct(r,`'`)){let{args:n,rightParen:i}=kv(e);return{type:`FUNCALL`,value:r,args:n,tokenStartIndex:t.tokenIndex,tokenEndIndex:i.tokenIndex}}let i=r.toUpperCase();return i===`TRUE`||i===`FALSE`?{type:`BOOLEAN`,value:i===`TRUE`,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:{type:`SYMBOL`,value:ct(t.value,`'`),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`LEFT_PAREN`:let a=Mv(e),o=jv(e,`RIGHT_PAREN`,O(`Missing closing parenthesis`));return{...a,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenIndex};case`OPERATOR`:let s=t.value;if(Cv.includes(s)){let n=Mv(e,Dv[s]);return{type:`UNARY_OPERATION`,value:s,operand:n,tokenStartIndex:t.tokenIndex,tokenEndIndex:n.tokenEndIndex}}throw new ya(O(`Unexpected token: %s`,t.value));default:throw new ya(O(`Unexpected token: %s`,t.value))}}function kv(e){if(jv(e,`LEFT_PAREN`,O(`Missing opening parenthesis`)),e.current?.type===`RIGHT_PAREN`)return{args:[],rightParen:jv(e,`RIGHT_PAREN`)};let t=[];for(t.push(Av(e));e.current?.type!==`RIGHT_PAREN`;)jv(e,`ARG_SEPARATOR`,O(`Wrong function call`)),t.push(Av(e));return{args:t,rightParen:jv(e,`RIGHT_PAREN`)}}function Av(e){let t=e.current;return t?.type===`ARG_SEPARATOR`||t?.type===`RIGHT_PAREN`?{type:`EMPTY`,value:``,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:Mv(e)}function jv(e,t,n){let r=e.shift();if(!r||r.type!==t)throw new ya(n);return r}function Mv(e,t=0){if(e.length===0)throw new ya;let n=Ov(e);for(;e.current?.type===`OPERATOR`&&Dv[e.current.value]>t;){let t=e.shift(),r=t.value;if(wv.includes(r))n={type:`UNARY_OPERATION`,value:r,operand:n,postfix:!0,tokenStartIndex:n.tokenStartIndex,tokenEndIndex:t.tokenIndex};else{let t=Mv(e,Dv[r]);n={type:`BIN_OPERATION`,value:r,left:n,right:t,tokenStartIndex:n.tokenStartIndex,tokenEndIndex:t.tokenEndIndex}}}return n}function Nv(e){return Pv(xv(e))}function Pv(e){let t=new Ev(e.map((e,t)=>({type:e.type,value:e.value,tokenIndex:t})).filter(e=>e.type!==`SPACE`));t.current?.value===`=`&&t.shift();let n=Mv(t);if(t.current)throw new ya;return n}function Fv(e,t,n){return Rv(e,e=>e.type===t?n(e):e)}function Iv(e){return Array.from(Lv(e))}function*Lv(e){switch(yield e,e.type){case`FUNCALL`:for(let t of e.args)yield*Lv(t);break;case`UNARY_OPERATION`:yield*Lv(e.operand);break;case`BIN_OPERATION`:yield*Lv(e.left),yield*Lv(e.right);break}}function Rv(e,t){switch(e=t(e),e.type){case`FUNCALL`:return{...e,args:e.args.map(e=>Rv(e,t))};case`UNARY_OPERATION`:return{...e,operand:Rv(e.operand,t)};case`BIN_OPERATION`:return{...e,right:Rv(e.right,t),left:Rv(e.left,t)};default:return e}}function zv(e){switch(e.type){case`FUNCALL`:let t=e.args.map(e=>zv(e));return`${e.value}(${t.join(`,`)})`;case`NUMBER`:return e.value.toString();case`REFERENCE`:return e.value;case`STRING`:return`"${e.value}"`;case`BOOLEAN`:return e.value?`TRUE`:`FALSE`;case`UNARY_OPERATION`:return e.postfix?Bv(e)+e.value:e.value+Vv(e);case`BIN_OPERATION`:return Bv(e)+e.value+Vv(e);default:return e.value}}function Bv(e){let t=e.value,n=`left`in e?e.left:e.operand,r=n.value;return n.type===`BIN_OPERATION`&&Dv[r]<Dv[t]?`(${zv(n)})`:zv(n)}function Vv(e){let t=e.value,n=`right`in e?e.right:e.operand,r=Dv[n.value],i=Dv[t],a=!1;return n.type===`BIN_OPERATION`?(r<i||r===i&&!Tv.includes(t))&&(a=!0):a=!1,a?`(${zv(n)})`:zv(n)}function Hv(e){let t=0;return e.map(e=>{let n=e.value.toString().length,r=Object.assign({},e,{start:t,end:t+n,length:n});return t=r.end,r})}function Uv(e){let t=[],n=0;return e.map((r,i)=>{if(r.type===`LEFT_PAREN`){t.push(n+1),n=0;for(let n=i-1;n>=0;n--){if(e[n].type===`SPACE`){e[n].parenthesesCode=t.join(`:`);continue}e[n].type===`SYMBOL`&&(e[n].parenthesesCode=t.join(`:`));break}}return r.parenthesesCode=t.join(`:`),r.type===`RIGHT_PAREN`&&t.length&&(n=t.pop()),r})}function Wv(e){let t=[],n=``;function r(e){if(t.length===0)return;let n=t.at(-1);if(n&&n.argsTokens){let{argsTokens:t,argPosition:r}=n;t[r]||(t[r]=[]),t[r].push({value:e.value,type:e.type})}}return e.map((e,i)=>{switch([`SPACE`,`LEFT_PAREN`].includes(e.type)||(n=``),e.type){case`SYMBOL`:r(e),n=e.value;break;case`LEFT_PAREN`:t.push({parent:n,argPosition:0,argsTokens:[],args:[]}),r(e),n=``;break;case`RIGHT_PAREN`:t.pop()?.argsTokens?.flat().forEach(r),r(e);break;case`ARG_SEPARATOR`:t.length&&t[t.length-1].argPosition++,r(e);break;default:r(e);break}if(t.length){let n=t[t.length-1];n.parent&&(e.functionContext=Object.assign({},n))}return e})}function Gv(e){for(let t of e)if(t.functionContext){let{argsTokens:e,args:n}=t.functionContext;if(delete t.functionContext.argsTokens,n.length||!e)continue;e[0]?.[0]?.type===`LEFT_PAREN`&&(e[0]=e[0].slice(1));for(let t of e){let e=t;e.at(0)?.type===`ARG_SEPARATOR`&&(e=e.slice(1));try{n.push(Pv(e))}catch{n.push(void 0)}}}return e}function Kv(e,t){return Gv(Wv(Uv(Hv(xv(e,t)))))}function qv(e){if(e.type!==`REFERENCE`)return e;let{xc:t,sheetName:n}=ac(e.value),[r,i]=t.split(`:`),a=Jv(r),o=i?`:${Jv(i)}`:``;return{...e,value:oc(n,a+o)}}function Jv(e){switch(Zv(e)){case`none`:e=Yv(e,`colrow`);break;case`colrow`:e=Yv(e,`row`);break;case`row`:e=Yv(e,`col`);break;case`col`:e=Yv(e,`none`);break}return e}function Yv(e,t){let n;({sheetName:n,xc:e}=ac(e)),n=n?n+`!`:``,e=e.replace(/\$/g,``);let r=e.indexOf(`:`);return r>=0?`${n}${Xv(e.slice(0,r),t)}:${Xv(e.slice(r+1),t)}`:n+Xv(e,t)}function Xv(e,t){let n=e.search(/[0-9]/),r=n!==0,i=n>=0;switch(t){case`col`:return r?`$`+e:e;case`row`:return i?e.slice(0,n)+`$`+e.slice(n):e;case`colrow`:return!i||!r?`$`+e:`$`+e.slice(0,n)+`$`+e.slice(n);case`none`:return e}}function Zv(e){return ey(e)?`colrow`:Qv(e)?`col`:$v(e)?`row`:`none`}function Qv(e){return e.startsWith(`$`)}function $v(e){return e.includes(`$`,1)}function ey(e){return e.startsWith(`$`)&&e.length>1&&e.slice(1).includes(`$`)}function ty(e,t,n){let r=(t.startsWith(`=`)?Kv(t,n):[]).filter(t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end),i=r.filter(e=>e.type===`REFERENCE`);if(i.length===0)return;let a=r.map(qv).map(e=>e.value).join(``),o=r[0].start,s=r[r.length-1].end,c=t.slice(0,o)+a+t.slice(s),l=c.length-t.length,u={start:i[0].start,end:i[i.length-1].end+l};return i.length===1&&e.start===e.end&&(u.start=u.end),{content:c,selection:u}}var ny=l({CELL:()=>iy,ISBLANK:()=>fy,ISERR:()=>ay,ISERROR:()=>oy,ISLOGICAL:()=>sy,ISNA:()=>cy,ISNONTEXT:()=>ly,ISNUMBER:()=>uy,ISTEXT:()=>dy,NA:()=>py});let ry=[`address`,`col`,`contents`,`format`,`row`,`type`],iy={description:O(`Gets information about a cell.`),args:[W(`info_type (string)`,O(`The type of information requested. Can be one of %s`,ry.join(`, `))),W(`reference (meta)`,O(`The reference to the cell.`))],compute:function(e,t){let n=I(e).toLowerCase();N(()=>ry.includes(n),O(`The info_type should be one of %s.`,ry.join(`, `)));let r=this.__originSheetId,i=I(t),{sheetName:a,xc:o}=ac(i.includes(`:`)?i.split(`:`)[0]:i);a=a===this.getters.getSheetName(r)?void 0:a;let s=oc(a,Yv(o,`colrow`)),c=this.getters.getRangeFromSheetXC(r,s);switch(n){case`address`:return this.getters.getRangeString(c,r);case`col`:return c.zone.left+1;case`contents`:{let e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).value}case`format`:{let 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`:{let e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top},t=this.getters.getEvaluatedCell(e).type;return t===`empty`?`b`:t===`text`?`l`:`v`}}return``},isExported:!0},ay={description:O(`Whether a value is an error other than #N/A.`),args:[W(`value (any)`,O(`The value to be verified as an error type.`))],compute:function(e){let t=e?.value;return P(t)&&t!==j.NotAvailable},isExported:!0},oy={description:O(`Whether a value is an error.`),args:[W(`value (any)`,O(`The value to be verified as an error type.`))],compute:function(e){let t=e?.value;return P(t)},isExported:!0},sy={description:O("Whether a value is `true` or `false`."),args:[W(`value (any)`,O(`The value to be verified as a logical TRUE or FALSE.`))],compute:function(e){return typeof e?.value==`boolean`},isExported:!0},cy={description:O(`Whether a value is the error #N/A.`),args:[W(`value (any)`,O(`The value to be verified as an error type.`))],compute:function(e){return e?.value===j.NotAvailable},isExported:!0},ly={description:O(`Whether a value is non-textual.`),args:[W(`value (any)`,O(`The value to be checked.`))],compute:function(e){return!dy.compute.bind(this)(e)},isExported:!0},uy={description:O(`Whether a value is a number.`),args:[W(`value (any)`,O(`The value to be verified as a number.`))],compute:function(e){return typeof e?.value==`number`},isExported:!0},dy={description:O(`Whether a value is text.`),args:[W(`value (any)`,O(`The value to be verified as text.`))],compute:function(e){return typeof e?.value==`string`&&P(e?.value)===!1},isExported:!0},fy={description:O(`Whether the referenced cell is empty`),args:[W(`value (any)`,O(`Reference to the cell that will be checked for emptiness.`))],compute:function(e){return e?.value===null},isExported:!0},py={description:O(`Returns the error value #N/A.`),args:[],compute:function(){return{value:j.NotAvailable}},isExported:!0};var my=l({AND:()=>hy,FALSE:()=>gy,IF:()=>_y,IFERROR:()=>vy,IFNA:()=>yy,IFS:()=>by,NOT:()=>xy,OR:()=>Sy,SWITCH:()=>Cy,TRUE:()=>wy,XOR:()=>Ty});let hy={description:O("Logical `and` operator."),args:[W(`logical_expression1 (boolean, range<boolean>)`,O(`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.`)),W(`logical_expression2 (boolean, range<boolean>, repeating)`,O(`More expressions that represent logical values.`))],compute:function(...e){let{result:t,foundBoolean:n}=eu(e);return N(()=>n,O(`[[FUNCTION_NAME]] has no valid input data.`)),t},isExported:!0},gy={description:O("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},_y={description:O(`Returns value depending on logical expression.`),args:[W(`logical_expression (boolean, range<boolean>)`,O(`An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.`)),W(`value_if_true (any, range)`,O(`The value the function returns if logical_expression is TRUE.`)),W(`value_if_false (any, range, default=FALSE)`,O(`The value the function returns if logical_expression is FALSE.`))],compute:function(e,t,n){if(uu(e))return $a(_y.compute,[e,t,n]);let r=L(cu(e))?t:n;return uu(r)||(r=cu(r)),r===void 0?{value:``}:!A(r)&&r.value===null?{...r,value:``}:r},isExported:!0},vy={description:O(`Value if it is not an error, otherwise 2nd argument.`),args:[W(`value (any, range)`,O(`The value to return if value itself is not an error.`)),W(`value_if_error (any, range, default="empty")`,O(`The value the function returns if value is an error.`))],compute:function(e,t){if(uu(e))return $a(vy.compute,[e,t]);let n=P(cu(e)?.value)?t:e;return uu(n)||(n=cu(n)),n===void 0?{value:``}:!A(n)&&n.value===null?{...n,value:``}:n},isExported:!0},yy={description:O(`Value if it is not an #N/A error, otherwise 2nd argument.`),args:[W(`value (any, range)`,O(`The value to return if value itself is not #N/A an error.`)),W(`value_if_error (any, range, default="empty")`,O(`The value the function returns if value is an #N/A error.`))],compute:function(e,t){if(uu(e))return $a(yy.compute,[e,t]);let n=cu(e)?.value===j.NotAvailable?t:e;return uu(n)||(n=cu(n)),n===void 0?{value:``}:!A(n)&&n.value===null?{...n,value:``}:n},isExported:!0},by={description:O(`Returns a value depending on multiple logical expressions.`),args:[W(`condition1 (boolean, range<boolean>)`,O(`The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.`)),W(`value1 (any, range)`,O(`The returned value if condition1 is TRUE.`)),W(`condition2 (boolean, any, range, repeating)`,O(`Additional conditions to be evaluated if the previous ones are FALSE.`)),W(`value2 (any, range, repeating)`,O(`Additional values to be returned if their corresponding conditions are TRUE.`))],compute:function(...e){for(N(()=>e.length%2==0,O(`Wrong number of arguments. Expected an even number of arguments.`));e.length>0;){if(uu(e[0]))return $a(by.compute,e);let t=L(cu(e.shift())),n=e.shift();if(t)return uu(n)||(n=cu(n)),n===void 0?{value:``}:!A(n)&&n.value===null?{...n,value:``}:n}return new M(O(`No match.`))},isExported:!0},xy={description:O(`Returns opposite of provided logical value.`),args:[W(`logical_expression (boolean)`,O(`An expression or reference to a cell holding an expression that represents some logical value.`))],compute:function(e){return!L(e)},isExported:!0},Sy={description:O("Logical `or` operator."),args:[W(`logical_expression1 (boolean, range<boolean>)`,O(`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.`)),W(`logical_expression2 (boolean, range<boolean>, repeating)`,O(`More expressions that evaluate to logical values.`))],compute:function(...e){let{result:t,foundBoolean:n}=tu(e);return N(()=>n,O(`[[FUNCTION_NAME]] has no valid input data.`)),t},isExported:!0},Cy={description:O(`Returns a value by comparing cases to an expression.`),args:[W(`expression (number, boolean, string)`,O(`The value to be checked.`)),W(`case1 (number, boolean, string)`,O(`The first case to be checked against expression.`)),W(`value1 (any)`,O(`The corresponding value to be returned if case1 matches expression.`)),W(`case2 (any, repeating)`,O(`Additional cases to try if the previous ones don't match expression.`)),W(`value2 (any, repeating)`,O(`Additional values to be returned if their corresponding cases match expression.`)),W(`default (any, default="empty")`,O(`An optional default value to be returned if none of the cases match expression.`))],compute:function(e,...t){let n=t.length%2==0?Da(e):t.pop();for(let n=0;n<t.length;n+=2){let r=t[n];if(r&&P(r.value))return r;if(e?.value===r?.value)return t[n+1]||{value:0}}return n||{value:0}},isExported:!0},wy={description:O("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},Ty={description:O("Logical `xor` operator."),args:[W(`logical_expression1 (boolean, range<boolean>)`,O(`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.`)),W(`logical_expression2 (boolean, range<boolean>, repeating)`,O(`More expressions that evaluate to logical values.`))],compute:function(...e){let t=!1,n=!1;return to(e,e=>(t=!0,n=n?!e:e,!0)),N(()=>t,O(`[[FUNCTION_NAME]] has no valid input data.`)),n},isExported:!0};function Ey(e,t){let n=t.getPivotId(e);if(!n)throw new M(O(`There is no pivot with id "%s"`,e));return n}function Dy(e,t,n){let{measures:r}=n.getPivotCoreDefinition(e);if(!r.find(e=>e.id===t))throw new M(O(`The argument %s is not a valid measure. Here are the measures: %s`,t,`(${r.map(e=>e.id).join(`, `)})`))}function Oy(e){if(e.length%2!=0)throw new M(O(`Function PIVOT takes an even number of arguments.`))}function ky(e,t,n){let r=[],i=e.getters.getPivotCoreDefinition(t);if(i.type===`SPREADSHEET`&&i.dataSet){let{sheetId:t,zone:n}=i.dataSet,a=cr(n),o=e.getters.getRangeFromSheetXC(t,a);if(o===void 0||o.invalidXc||o.invalidSheetName)throw new xa;if(e.__originCellPosition&&o.sheetId===e.__originSheetId&&yr(E(e.__originCellPosition),n))throw new ba;r.push(o)}for(let i of n)i.computedBy&&r.push(...e.getters.getMeasureFullDependencies(t,i));let a=e.__originCellPosition;a&&r.length&&(e.updateDependencies?.(a),e.addDependencies?.(a,r))}var Ay=l({ADDRESS:()=>jy,COLUMN:()=>My,COLUMNS:()=>Ny,HLOOKUP:()=>Py,INDEX:()=>Fy,INDIRECT:()=>Iy,LOOKUP:()=>Ly,MATCH:()=>Ry,OFFSET:()=>qy,PIVOT:()=>Ky,PIVOT_HEADER:()=>Gy,PIVOT_VALUE:()=>Wy,ROW:()=>zy,ROWS:()=>By,VLOOKUP:()=>Vy,XLOOKUP:()=>Uy});let jy={description:O(`Returns a cell reference as a string. `),args:[W(`row (number)`,O(`The row number of the cell reference. `)),W(`column (number)`,O(`The column number (not name) of the cell reference. A is column number 1. `)),W(`absolute_relative_mode (number, default=1)`,O(`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).`)),W(`use_a1_notation (boolean, default=TRUE)`,O(`A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).`)),W(`sheet (string, optional)`,O(`A string indicating the name of the sheet into which the address points.`))],compute:function(e,t,n={value:1},r={value:!0},i){let a=Fa(e,this.locale),o=Fa(t,this.locale);Ia(a),Ia(o);let s=Fa(n,this.locale);N(()=>[1,2,3,4].includes(s),ka(1,4,s));let c=L(r),l;if(c){let e={rowFixed:[1,2].includes(s),colFixed:[1,3].includes(s)};l=T(o-1,a-1,e)}else l=([1,2].includes(s)?`R${a}`:`R[${a}]`)+([1,3].includes(s)?`C${o}`:`C[${o}]`);return i===void 0?l:oc(I(i),l)},isExported:!0},My={description:O(`Column number of a specified cell.`),args:[W(`cell_reference (meta, default='this cell')`,O(`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(P(e?.value))return e;if(e===void 0)return N(()=>this.__originCellPosition?.col!==void 0,`In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.`),this.__originCellPosition.col+1;let t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.left===t.right?t.left+1:Ya(t.right-t.left+1,1,(e,n)=>({value:t.left+e+1}))},isExported:!0},Ny={description:O(`Number of columns in a specified array or range.`),args:[W(`range (meta)`,O(`The range whose column count will be returned.`))],compute:function(e){if(P(e?.value))return e;let t=ar(e.value);return t.right-t.left+1},isExported:!0},Py={description:O(`Horizontal lookup`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`range (any, range)`,O(`The range to consider for the search. The first row in the range is searched for the key specified in search_key.`)),W(`index (number)`,O(`The row index of the value to be returned, where the first row in range is numbered 1.`)),W(`is_sorted (boolean, default=true)`,O(`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,n,r={value:!0}){let i=Math.trunc(F(n?.value,this.locale)),a=z(t);N(()=>1<=i&&i<=a[0].length,O(`[[FUNCTION_NAME]] evaluates to an out of bounds range.`));let o=(e,t)=>e[t][0].value,s=a[L(r.value)?oo(a,e,`nextSmaller`,`asc`,a.length,o):so(a,e,`wildcard`,a.length,o,this.lookupCaches)];return s===void 0?Da(e):s[i-1]},isExported:!0},Fy={description:O(`Returns the content of a cell, specified by row and column offset.`),args:[W(`reference (any, range)`,O(`The range of cells from which the values are returned.`)),W(`row (number, default=0)`,O(`The index of the row to be returned from within the reference range of cells.`)),W(`column (number, default=0)`,O(`The index of the column to be returned from within the reference range of cells.`))],compute:function(e,t={value:0},n={value:0}){let r=z(e),i=F(t.value,this.locale),a=F(n.value,this.locale);return N(()=>a>=0&&a-1<r.length&&i>=0&&i-1<r[0].length,O(`Index out of range.`)),i===0&&a===0?r:i===0?[r[a-1]]:a===0?r.map(e=>[e[i-1]]):r[a-1][i-1]},isExported:!0},Iy={description:O(`Returns the content of a cell, specified by a string.`),args:[W(`reference (string)`,O(`The range of cells from which the values are returned.`)),W(`use_a1_notation (boolean, default=TRUE)`,O(`A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).`))],compute:function(e,t={value:!0}){let n=e?.value?.toString();if(!n)return new xa(O(`Reference should be defined.`));if(!L(t))return new M(O(`R1C1 notation is not supported.`));let r=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);let a=this.getters.getRangeFromSheetXC(r,n);if(a===void 0||a.invalidXc||a.invalidSheetName)return new xa;i&&this.addDependencies?.(i,[a]);let o=[];for(let e=a.zone.left;e<=a.zone.right;e++){let t=[];for(let n=a.zone.top;n<=a.zone.bottom;n++){let r={sheetId:a.sheetId,col:e,row:n};t.push(this.getters.getEvaluatedCell(r))}o.push(t)}return o.length===1&&o[0].length===1?o[0][0]:o},isExported:!0},Ly={description:O(`Look up a value.`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`search_array (any, range)`,O(`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.`)),W(`result_range (any, range, optional)`,O(`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,n){let r=z(t),i=z(n),a=r.length,o=r[0].length,s=o>=a,c=oo(r,e,`nextSmaller`,`asc`,s?o:a,s?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value);return c===-1||s&&r[0][c]===void 0||!s&&r[c][o-1]===void 0?Da(e):i[0].length===0?s?r[a-1][c]:r[c][o-1]:(a=i.length,o=i[0].length,N(()=>a===1||o===1,O(`The result_range must be a single row or a single column.`)),a>1?(N(()=>c<=a-1,O(`[[FUNCTION_NAME]] evaluates to an out of range row value %s.`,(c+1).toString())),i[c][0]):(N(()=>c<=o-1,O(`[[FUNCTION_NAME]] evaluates to an out of range column value %s.`,(c+1).toString())),i[0][c]))},isExported:!0},Ry={description:O(`Position of item in range that matches value.`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`range (any, range)`,O(`The one-dimensional array to be searched.`)),W(`search_type (number, default=1)`,O(`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,n={value:1}){let r=F(n,this.locale),i=z(t),a=i.length,o=i[0].length;N(()=>a===1||o===1,O(`The range must be a single row or a single column.`));let s=-1,c=a===1?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,l=a===1?i[0].length:i.length;switch(r=Math.sign(r),r){case 1:s=oo(i,e,`nextSmaller`,`asc`,l,c);break;case 0:s=so(i,e,`wildcard`,l,c,this.lookupCaches);break;case-1:s=oo(i,e,`nextGreater`,`desc`,l,c);break}return a===1&&i[0][s]===void 0||a!==1&&i[s]===void 0?Da(e):s+1},isExported:!0},zy={description:O(`Row number of a specified cell.`),args:[W(`cell_reference (meta, default='this cell')`,O(`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(P(e?.value))return e;if(e===void 0)return N(()=>this.__originCellPosition?.row!==void 0,`In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.`),this.__originCellPosition.row+1;let t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.top===t.bottom?t.top+1:Ya(1,t.bottom-t.top+1,(e,n)=>({value:t.top+n+1}))},isExported:!0},By={description:O(`Number of rows in a specified array or range.`),args:[W(`range (meta)`,O(`The range whose row count will be returned.`))],compute:function(e){if(P(e?.value))return e;let t=ar(e.value);return t.bottom-t.top+1},isExported:!0},Vy={description:O(`Vertical lookup.`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`range (any, range)`,O(`The range to consider for the search. The first column in the range is searched for the key specified in search_key.`)),W(`index (number)`,O(`The column index of the value to be returned, where the first column in range is numbered 1.`)),W(`is_sorted (boolean, default=true)`,O(`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,n,r={value:!0}){let i=Math.trunc(F(n?.value,this.locale)),a=z(t);N(()=>1<=i&&i<=a.length,O(`[[FUNCTION_NAME]] evaluates to an out of bounds range.`));let o=(e,t)=>e[0][t].value,s=L(r.value)?oo(a,e,`nextSmaller`,`asc`,a[0].length,o):so(a,e,`wildcard`,a[0].length,o,this.lookupCaches),c=a[i-1][s];return c===void 0?Da(e):c},isExported:!0},Hy={0:`strict`,1:`nextGreater`,"-1":`nextSmaller`,2:`wildcard`},Uy={description:O(`Search a range for a match and return the corresponding item from a second range.`),args:[W(`search_key (string,number,boolean)`,O(`The value to search for.`)),W(`lookup_range (any, range)`,O(`The range to consider for the search. Should be a single column or a single row.`)),W(`return_range (any, range)`,O(`The range containing the return value. Should have the same dimensions as lookup_range.`)),W(`if_not_found (any, optional)`,O(`If a valid match is not found, return this value.`)),W(`match_mode (any, default=0)`,O(`(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.`)),W(`search_mode (any, default=1)`,O(`(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,n,r,i={value:0},a={value:1}){let o=Math.trunc(F(i.value,this.locale)),s=Math.trunc(F(a.value,this.locale)),c=z(t),l=z(n);N(()=>c.length===1||c[0].length===1,O(`lookup_range should be either a single row or single column.`)),N(()=>[-1,1,-2,2].includes(s),O(`search_mode should be a value in [-1, 1, -2, 2].`)),N(()=>[-1,0,1,2].includes(o),O(`match_mode should be a value in [-1, 0, 1, 2].`));let u=c.length===1?`col`:`row`;N(()=>!(o===2&&[-2,2].includes(s)),O(`the search and match mode combination is not supported for XLOOKUP evaluation.`)),N(()=>u===`col`?l[0].length===c[0].length:l.length===c.length,O(`return_range should have the same dimensions as lookup_range.`));let d=u===`col`?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,f=u===`col`?c[0].length:c.length,p=Hy[o],m=s===-1,h=s===2||s===-2?oo(c,e,p,s===2?`asc`:`desc`,f,d):so(c,e,p,f,d,this.lookupCaches,m);return h===-1?r===void 0?Da(e):[[r]]:u===`col`?l.map(e=>[e[h]]):[l[h]]},isExported:!0},Wy={description:O(`Get the value from a pivot.`),args:[W(`pivot_id (number,string)`,O(`ID of the pivot.`)),W(`measure_name (string)`,O(`Name of the measure.`)),W(`domain_field_name (string,repeating)`,O(`Field name.`)),W(`domain_value (number,string,boolean,repeating)`,O(`Value.`))],compute:function(e,t,...n){let r=I(e),i=I(t),a=Ey(r,this.getters);Dy(a,i,this.getters),Oy(n);let o=this.getters.getPivot(a),s=this.getters.getPivotCoreDefinition(a);ky(this,a,s.measures.filter(e=>e.id===i)),o.init({reload:o.needsReevaluation});let c=o.assertIsValid({throwOnError:!1});if(c)return c;if(!o.areDomainArgsFieldsValid(n)){let e=O(`Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.`,`=PIVOT(${r})`);return{value:j.GenericError,message:O(`Dimensions don't match the pivot definition`)+`. `+e}}let l=o.parseArgsToPivotDomain(n);return this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(a)?.trackValue(i,l),o.getPivotCellValueAndFormat(i,l)}},Gy={description:O(`Get the header of a pivot.`),args:[W(`pivot_id (number,string)`,O(`ID of the pivot.`)),W(`domain_field_name (string,repeating)`,O(`Field name.`)),W(`domain_value (number,string,value,repeating)`,O(`Value.`))],compute:function(e,...t){let n=I(e),r=Ey(n,this.getters);Oy(t);let i=this.getters.getPivot(r);ky(this,r,[]),i.init({reload:i.needsReevaluation});let a=i.assertIsValid({throwOnError:!1});if(a)return a;if(!i.areDomainArgsFieldsValid(t)){let e=O(`Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.`,`=PIVOT(${n})`);return{value:j.GenericError,message:O(`Dimensions don't match the pivot definition`)+`. `+e}}let o=i.parseArgsToPivotDomain(t);this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(r)?.trackHeader(o);let s=o.at(-1);if(s?.field===`measure`)return i.getPivotMeasureValue(I(s.value),o);let{value:c,format:l}=i.getPivotHeaderValueAndFormat(o);return{value:c,format:!s||s.field===`measure`||s.value===`false`?void 0:l}}},Ky={description:O(`Get a pivot table.`),args:[W(`pivot_id (string)`,O(`ID of the pivot.`)),W(`row_count (number, optional)`,O(`number of rows`)),W(`include_total (boolean, default=TRUE)`,O(`Whether to include total/sub-totals or not.`)),W(`include_column_titles (boolean, default=TRUE)`,O(`Whether to include the column titles or not.`)),W(`column_count (number, optional)`,O(`number of columns`))],compute:function(e,t={value:1e4},n={value:!0},r={value:!0},i={value:Number.MAX_VALUE}){let a=I(e),o=F(t,this.locale);if(o<0)return new M(O(`The number of rows must be positive.`));let s=F(i,this.locale);if(s<0)return new M(O(`The number of columns must be positive.`));let c=L(r),l=L(n),u=Ey(a,this.getters),d=this.getters.getPivot(u),f=this.getters.getPivotCoreDefinition(u);ky(this,u,f.measures),d.init({reload:d.needsReevaluation});let p=d.assertIsValid({throwOnError:!1});if(p)return p;let m=d.getTableStructure(),h=m.getPivotCells(l,c),g=c?m.columns.length:0,_=this.getters.getPivotDisplayName(u),v=Math.min(g+o,h[0].length);if(v===0)return[[{value:_}]];let y=Math.min(1+s,h.length),ee=[];for(let e of S(0,y)){ee[e]=[];for(let t of S(0,v)){let n=h[e][t];switch(n.type){case`EMPTY`:ee[e].push({value:``});break;case`HEADER`:let t=d.getPivotHeaderValueAndFormat(n.domain);ee[e].push(Dd(d,n.domain,t));break;case`MEASURE_HEADER`:ee[e].push(d.getPivotMeasureValue(n.measure,n.domain));break;case`VALUE`:ee[e].push(d.getPivotCellValueAndFormat(n.measure,n.domain));break}}}return c&&(ee[0][0]={value:_}),ee}},qy={description:O(`Returns a range reference shifted by a specified number of rows and columns from a starting cell reference.`),args:[W(`cell_reference (meta)`,O(`The starting point from which to count the offset rows and columns.`)),W(`offset_rows (number)`,O(`The number of rows to offset by.`)),W(`offset_columns (number)`,O(`The number of columns to offset by.`)),W(`height (number, default='height of cell_reference')`,O(`The number of rows of the range to return starting at the offset target.`)),W(`width (number, default='width of cell_reference')`,O(`The number of columns of the range to return starting at the offset target.`))],compute:function(e,t,n,r,i){if(P(e?.value))return e;let a=e?.value;if(!a)return new M(`In this context, the function OFFSET needs to have a cell or range in parameter.`);let o=ar(a),s=o.bottom-o.top+1,c=o.right-o.left+1;if(r){let e=F(r,this.locale);jf(O(`Height value is %(_height)s. It should be greater than or equal to 1.`,{_height:e}),e),s=e}if(i){let e=F(i,this.locale);jf(O(`Width value is %(_width)s. It should be greater than or equal to 1.`,{_width:e}),e),c=e}let{sheetName:l}=ac(a),u=l&&this.getters.getSheetIdByName(l)||this.getters.getActiveSheetId(),d=F(t,this.locale),f=F(n,this.locale),p=this.__originCellPosition;p&&this.updateDependencies?.(p);let m=o.left+f,h=o.top+d;if(m<0||h<0)return new xa(O(`OFFSET evaluates to an out of bounds range.`));let g={left:m,top:h,right:m+c-1,bottom:h+s-1},_=this.getters.getRangeFromZone(u,g);return _.invalidXc||_.invalidSheetName?new xa:(p&&this.addDependencies?.(p,[_]),Ya(c,s,(e,t)=>this.getters.getEvaluatedCell({sheetId:u,col:m+e,row:h+t})))}};var Jy=l({ADD:()=>Yy,CONCAT:()=>Xy,DIVIDE:()=>Zy,EQ:()=>tb,GT:()=>rb,GTE:()=>ib,LT:()=>ab,LTE:()=>ob,MINUS:()=>sb,MULTIPLY:()=>cb,NE:()=>lb,POW:()=>ub,UMINUS:()=>db,UNARY_PERCENT:()=>fb,UPLUS:()=>pb});let Yy={description:O(`Sum of two numbers.`),args:[W(`value1 (number)`,O(`The first addend.`)),W(`value2 (number)`,O(`The second addend.`))],compute:function(e,t){return{value:F(e,this.locale)+F(t,this.locale),format:e?.format||t?.format}}},Xy={description:O(`Concatenation of two values.`),args:[W(`value1 (string)`,O(`The value to which value2 will be appended.`)),W(`value2 (string)`,O(`The value to append to value1.`))],compute:function(e,t){return I(e)+I(t)},isExported:!0},Zy={description:O(`One number divided by another.`),args:[W(`dividend (number)`,O(`The number to be divided.`)),W(`divisor (number)`,O(`The number to divide by.`))],compute:function(e,t){let n=F(t,this.locale);return N(()=>n!==0,O(`The divisor must be different from zero.`),j.DivisionByZero),{value:F(e,this.locale)/n,format:e?.format||t?.format}}};function Qy(e){return e===void 0||e.value===null}let $y={number:0,string:``,boolean:!1};function eb(e,t,n=2e-16){return Math.abs(e-t)<n}let tb={description:O(`Equal.`),args:[W(`value1 (string, number, boolean)`,O(`The first value.`)),W(`value2 (string, number, boolean)`,O(`The value to test against value1 for equality.`))],compute:function(e,t){if(P(e?.value))return e;if(P(t?.value))return t;let n=Qy(e)?$y[typeof t?.value]:e?.value,r=Qy(t)?$y[typeof e?.value]:t?.value;return typeof n==`string`&&(n=n.toUpperCase()),typeof r==`string`&&(r=r.toUpperCase()),typeof n==`number`&&typeof r==`number`?{value:eb(n,r)}:{value:n===r}}};function nb(e,t,n){if(P(e?.value))return e;if(P(t?.value))return t;let r=Qy(e)?$y[typeof t?.value]:e?.value,i=Qy(t)?$y[typeof e?.value]:t?.value;typeof r!=`number`&&(r=I(r).toUpperCase()),typeof i!=`number`&&(i=I(i).toUpperCase());let a=typeof r,o=typeof i;return a===`string`&&o===`number`?{value:!0}:o===`string`&&a===`number`?{value:!1}:{value:n(r,i)}}let rb={description:O(`Strictly greater than.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being greater than value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){return nb(e,t,(e,t)=>typeof e==`number`&&typeof t==`number`?!eb(e,t)&&e>t:e>t)}},ib={description:O(`Greater than or equal to.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being greater than or equal to value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){return nb(e,t,(e,t)=>typeof e==`number`&&typeof t==`number`?eb(e,t)||e>t:e>=t)}},ab={description:O(`Less than.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being less than value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){let n=ib.compute.bind(this)(e,t);return P(n.value)?n:{value:!n.value}}},ob={description:O(`Less than or equal to.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being less than or equal to value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){let n=rb.compute.bind(this)(e,t);return P(n.value)?n:{value:!n.value}}},sb={description:O(`Difference of two numbers.`),args:[W(`value1 (number)`,O(`The minuend, or number to be subtracted from.`)),W(`value2 (number)`,O(`The subtrahend, or number to subtract from value1.`))],compute:function(e,t){return{value:F(e,this.locale)-F(t,this.locale),format:e?.format||t?.format}}},cb={description:O(`Product of two numbers`),args:[W(`factor1 (number)`,O(`The first multiplicand.`)),W(`factor2 (number)`,O(`The second multiplicand.`))],compute:function(e,t){return{value:F(e,this.locale)*F(t,this.locale),format:e?.format||t?.format}}},lb={description:O(`Not equal.`),args:[W(`value1 (string, number, boolean)`,O(`The first value.`)),W(`value2 (string, number, boolean)`,O(`The value to test against value1 for inequality.`))],compute:function(e,t){let n=tb.compute.bind(this)(e,t);return P(n.value)?n:{value:!n.value}}},ub={description:O(`A number raised to a power.`),args:[W(`base (number)`,O(`The number to raise to the exponent power.`)),W(`exponent (number)`,O(`The exponent to raise base to.`))],compute:function(e,t){return Yp.compute.bind(this)(e,t)}},db={description:O(`A number with the sign reversed.`),args:[W(`value (number)`,O(`The number to have its sign reversed. Equivalently, the number to multiply by -1.`))],compute:function(e){return{value:-F(e,this.locale),format:e?.format}}},fb={description:O(`Value interpreted as a percentage.`),args:[W(`percentage (number)`,O(`The value to interpret as a percentage.`))],compute:function(e){return F(e,this.locale)/100}},pb={description:O(`A specified number, unchanged.`),args:[W(`value (any)`,O(`The number to return.`))],compute:function(e={value:null}){return e}},G=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),mb={transform:e=>e,inverseTransform:e=>e},hb=1e-10,gb=.0254,_b=gb/72,vb=.3048,yb=.9144,bb=1609.34,xb=1852,Sb=946073047258e4,Cb={g:{...mb,category:`weight`},u:{...G(166053e-29),category:`weight`},grain:{...G(.0647989),category:`weight`},ozm:{...G(28.3495),category:`weight`},lbm:{...G(453.592),category:`weight`},stone:{...G(6350.29),category:`weight`},sg:{...G(14593.90294),category:`weight`},cwt:{...G(45359.237),category:`weight`},uk_cwt:{...G(50802.3),category:`weight`},ton:{...G(907184.74),category:`weight`},uk_ton:{...G(1016046.9),category:`weight`},m:{...mb,category:`distance`},km:{...G(1e3),category:`distance`},ang:{...G(hb),category:`distance`},Picapt:{...G(_b),category:`distance`},pica:{...G(gb/6),category:`distance`},in:{...G(gb),category:`distance`},ft:{...G(vb),category:`distance`},yd:{...G(yb),category:`distance`},ell:{...G(1.143),category:`distance`},mi:{...G(bb),category:`distance`},survey_mi:{...G(1609.34),category:`distance`},Nmi:{...G(xb),category:`distance`},ly:{...G(Sb),category:`distance`},parsec:{...G(0x6da012f95c9fd0),category:`distance`},sec:{...mb,category:`time`},min:{...G(60),category:`time`},hr:{...G(3600),category:`time`},day:{...G(86400),category:`time`},yr:{...G(31556952),category:`time`},Pa:{...mb,category:`pressure`},bar:{...G(1e5),category:`pressure`},mmHg:{...G(133.322),category:`pressure`},Torr:{...G(133.322),category:`pressure`},psi:{...G(6894.76),category:`pressure`},atm:{...G(101325),category:`pressure`},N:{...mb,category:`force`},dyn:{...G(1e-5),category:`force`},pond:{...G(.00980665),category:`force`},lbf:{...G(4.44822),category:`force`},J:{...mb,category:`energy`},eV:{...G(160218e-24),category:`energy`},e:{...G(1e-7),category:`energy`},flb:{...G(1.3558179483),category:`energy`},c:{...G(4.184),category:`energy`},cal:{...G(4.1868),category:`energy`},BTU:{...G(1055.06),category:`energy`},Wh:{...G(3600),category:`energy`},HPh:{...G(2684520),category:`energy`},W:{...mb,category:`power`},PS:{...G(735.499),category:`power`},HP:{...G(745.7),category:`power`},T:{...mb,category:`magnetism`},ga:{...G(1e-4),category:`magnetism`},K:{...mb,category:`temperature`},C:{transform:e=>e+273.15,inverseTransform:e=>e-273.15,category:`temperature`},F:{transform:e=>(e-32)*5/9+273.15,inverseTransform:e=>(e-273.15)*9/5+32,category:`temperature`},Rank:{...G(5/9),category:`temperature`},Reau:{transform:e=>e*1.25+273.15,inverseTransform:e=>(e-273.15)/1.25,category:`temperature`},"m^3":{...mb,category:`volume`,order:3},"ang^3":{...G(hb**3),category:`volume`,order:3},"Picapt^3":{...G(_b**3),category:`volume`,order:3},tsp:{...G(492892e-11),category:`volume`},tspm:{...G(5e-6),category:`volume`},tbs:{...G(14786764825785619e-21),category:`volume`},"in^3":{...G(gb**3),category:`volume`,order:3},oz:{...G(295735295625e-16),category:`volume`},cup:{...G(237e-6),category:`volume`},pt:{...G(.0004731765),category:`volume`},uk_pt:{...G(568261e-9),category:`volume`},qt:{...G(.0009463529),category:`volume`},l:{...G(.001),category:`volume`},uk_qt:{...G(.0011365225),category:`volume`},gal:{...G(.0037854118),category:`volume`},uk_gal:{...G(.00454609),category:`volume`},"ft^3":{...G(vb**3),category:`volume`,order:3},bushel:{...G(.0352390704),category:`volume`},barrel:{...G(.158987295),category:`volume`},"yd^3":{...G(yb**3),category:`volume`,order:3},MTON:{...G(1.13267386368),category:`volume`},GRT:{...G(2.83168),category:`volume`},"mi^3":{...G(bb**3),category:`volume`,order:3},"Nmi^3":{...G(xb**3),category:`volume`,order:3},"ly^3":{...G(Sb**3),category:`volume`,order:3},"m^2":{...mb,category:`area`,order:2},"ang^2":{...G(hb**2),category:`area`,order:2},"Picapt^2":{...G(_b**2),category:`area`,order:2},"in^2":{...G(gb**2),category:`area`,order:2},"ft^2":{...G(vb**2),category:`area`,order:2},"yd^2":{...G(yb**2),category:`area`,order:2},ar:{...G(100),category:`area`},Morgen:{...G(2500),category:`area`},uk_acre:{...G(4046.8564224),category:`area`},us_acre:{...G(4046.8726098743),category:`area`},ha:{...G(1e4),category:`area`},"mi^2":{...G(bb**2),category:`area`,order:2},"Nmi^2":{...G(xb**2),category:`area`,order:2},"ly^2":{...G(Sb**2),category:`area`,order:2},bit:{...mb,category:`information`},byte:{...G(8),category:`information`},"m/s":{...mb,category:`speed`},"m/hr":{...G(1/3600),category:`speed`},"km/hr":{...G(1/3.6),category:`speed`},mph:{...G(.44704),category:`speed`},kn:{...G(.5144444444),category:`speed`},admkn:{...G(.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`},Tb={"":1,Y:1e24,Z:1e21,E:0xde0b6b3a7640000,P:0x38d7ea4c68000,T:0xe8d4a51000,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:2**80,Zi:2**70,Ei:2**60,Pi:2**50,Ti:2**40,Gi:2**30,Mi:2**20,ki:2**10},Eb={weight:O(`Weight`),distance:O(`Distance`),time:O(`Time`),pressure:O(`Pressure`),force:O(`Force`),energy:O(`Energy`),power:O(`Power`),magnetism:O(`Magnetism`),temperature:O(`Temperature`),volume:O(`Volume`),area:O(`Area`),information:O(`Information`),speed:O(`Speed`)};function Db(e){return Eb[e]??``}function Ob(e){for(let[t,n]of Object.entries(Tb)){if(t&&!e.startsWith(t))continue;let r=e.slice(t.length),i=Cb[r];if(!i&&wb[r]&&(i=Cb[wb[r]]),i)return{...i,factor:i.order?n**+i.order:n}}}var kb=l({CONVERT:()=>Ab});let Ab={description:O(`Converts a numeric value to a different unit of measure.`),args:[W(`value (number)`,O(`the numeric value in start_unit to convert to end_unit`)),W(`start_unit (string)`,O(`The starting unit, the unit currently assigned to value`)),W(`end_unit (string)`,O(`The unit of measure into which to convert value`))],compute:function(e,t,n){let r=F(e,this.locale),i=I(t),a=I(n),o=Ob(i),s=Ob(a);return o?s?o.category===s.category?{value:s.inverseTransform(o.factor*o.transform(r))/s.factor,format:e?.format}:{value:j.GenericError,message:O(`Incompatible units of measure ('%s' vs '%s')`,Db(o.category),Db(s.category))}:{value:j.GenericError,message:O(`Invalid units of measure ('%s')`,a)}:{value:j.GenericError,message:O(`Invalid units of measure ('%s')`,i)}},isExported:!0};var jb=l({CHAR:()=>Nb,CLEAN:()=>Pb,CONCATENATE:()=>Fb,EXACT:()=>Ib,FIND:()=>Lb,JOIN:()=>Rb,LEFT:()=>zb,LEN:()=>Bb,LOWER:()=>Vb,MID:()=>Hb,PROPER:()=>Ub,REPLACE:()=>Wb,RIGHT:()=>Gb,SEARCH:()=>Kb,SPLIT:()=>qb,SUBSTITUTE:()=>Jb,TEXT:()=>Qb,TEXTJOIN:()=>Yb,TRIM:()=>Xb,UPPER:()=>Zb,VALUE:()=>$b});let Mb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,Nb={description:O(`Gets character associated with number.`),args:[W(`table_number (number)`,O(`The number of the character to look up from the current Unicode table in decimal format.`))],compute:function(e){let t=Math.trunc(F(e,this.locale));return N(()=>t>=1,O(`The table_number (%s) is out of range.`,t.toString())),String.fromCharCode(t)},isExported:!0},Pb={description:O(`Remove non-printable characters from a piece of text.`),args:[W(`text (string)`,O(`The text whose non-printable characters are to be removed.`))],compute:function(e){let t=I(e),n=``;for(let e of t)e&&e.charCodeAt(0)>31&&(n+=e);return n},isExported:!0},Fb={description:O(`Appends strings to one another.`),args:[W(`string1 (string, range<string>)`,O(`The initial string.`)),W(`string2 (string, range<string>, repeating)`,O(`More strings to append in sequence.`))],compute:function(...e){return Ka(e,(e,t)=>e+I(t),``)},isExported:!0},Ib={description:O(`Tests whether two strings are identical.`),args:[W(`string1 (string)`,O(`The first string to compare.`)),W(`string2 (string)`,O(`The second string to compare.`))],compute:function(e,t){return I(e)===I(t)},isExported:!0},Lb={description:O(`First position of string found in text, case-sensitive.`),args:[W(`search_for (string)`,O(`The string to look for within text_to_search.`)),W(`text_to_search (string)`,O(`The text to search for the first occurrence of search_for.`)),W(`starting_at (number, default=1)`,O(`The character within text_to_search at which to start the search.`))],compute:function(e,t,n={value:1}){let r=I(e),i=I(t),a=F(n,this.locale);N(()=>i!==``,O(`The text_to_search must be non-empty.`)),N(()=>a>=1,O(`The starting_at (%s) must be greater than or equal to 1.`,a.toString()));let o=i.indexOf(r,a-1);return N(()=>o>=0,O(`In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.`,r.toString(),i)),o+1},isExported:!0},Rb={description:O(`Concatenates elements of arrays with delimiter.`),args:[W(`delimiter (string)`,O(`The character or string to place between each concatenated value.`)),W(`value_or_array1 (string, range<string>)`,O(`The value or values to be appended using delimiter.`)),W(`value_or_array2 (string, range<string>, repeating)`,O(`More values to be appended using delimiter.`))],compute:function(e,...t){let n=I(e);return Ka(t,(e,t)=>(e?e+n:``)+I(t),``)}},zb={description:O(`Substring from beginning of specified string.`),args:[W(`text (string)`,O(`The string from which the left portion will be returned.`)),W(`number_of_characters (number, optional)`,O(`The number of characters to return from the left side of string.`))],compute:function(e,...t){let n=t.length?F(t[0],this.locale):1;return N(()=>n>=0,O(`The number_of_characters (%s) must be positive or null.`,n.toString())),I(e).substring(0,n)},isExported:!0},Bb={description:O(`Length of a string.`),args:[W(`text (string)`,O(`The string whose length will be returned.`))],compute:function(e){return I(e).length},isExported:!0},Vb={description:O(`Converts a specified string to lowercase.`),args:[W(`text (string)`,O(`The string to convert to lowercase.`))],compute:function(e){return I(e).toLowerCase()},isExported:!0},Hb={description:O(`A segment of a string.`),args:[W(`text (string)`,O(`The string to extract a segment from.`)),W(`starting_at (number)`,O(`The index from the left of string from which to begin extracting. The first character in string has the index 1.`)),W(`extract_length (number)`,O(`The length of the segment to extract.`))],compute:function(e,t,n){let r=I(e),i=F(t,this.locale),a=F(n,this.locale);return N(()=>i>=1,O(`The starting_at argument (%s) must be positive greater than one.`,i.toString())),N(()=>a>=0,O(`The extract_length argument (%s) must be positive or null.`,a.toString())),r.slice(i-1,i+a-1)},isExported:!0},Ub={description:O(`Capitalizes each word in a specified string.`),args:[W(`text_to_capitalize (string)`,O(`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 I(e).replace(Mb,e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase())},isExported:!0},Wb={description:O(`Replaces part of a text string with different text.`),args:[W(`text (string)`,O(`The text, a part of which will be replaced.`)),W(`position (number)`,O(`The position where the replacement will begin (starting from 1).`)),W(`length (number)`,O(`The number of characters in the text to be replaced.`)),W(`new_text (string)`,O(`The text which will be inserted into the original text.`))],compute:function(e,t,n,r){let i=F(t,this.locale);N(()=>i>=1,O(`The position (%s) must be greater than or equal to 1.`,i.toString()));let a=I(e),o=F(n,this.locale),s=I(r);return a.substring(0,i-1)+s+a.substring(i-1+o)},isExported:!0},Gb={description:O(`A substring from the end of a specified string.`),args:[W(`text (string)`,O(`The string from which the right portion will be returned.`)),W(`number_of_characters (number, optional)`,O(`The number of characters to return from the right side of string.`))],compute:function(e,...t){let n=t.length?F(t[0],this.locale):1;N(()=>n>=0,O(`The number_of_characters (%s) must be positive or null.`,n.toString()));let r=I(e),i=r.length;return r.substring(i-n,i)},isExported:!0},Kb={description:O(`First position of string found in text, ignoring case.`),args:[W(`search_for (string)`,O(`The string to look for within text_to_search.`)),W(`text_to_search (string)`,O(`The text to search for the first occurrence of search_for.`)),W(`starting_at (number, default=1)`,O(`The character within text_to_search at which to start the search.`))],compute:function(e,t,n={value:1}){let r=I(e).toLowerCase(),i=I(t).toLowerCase(),a=F(n,this.locale);if(i===``)return{value:j.GenericError,message:O(`The text_to_search must be non-empty.`)};if(a<1)return{value:j.GenericError,message:O(`The starting_at (%s) must be greater than or equal to 1.`,a)};let o=i.indexOf(r,a-1);return o===-1?{value:j.GenericError,message:O(`In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.`,r,i)}:{value:o+1}},isExported:!0},qb={description:O(`Split text by specific character delimiter(s).`),args:[W(`text (string)`,O(`The text to divide.`)),W(`delimiter (string)`,O(`The character or characters to use to split text.`)),W(`split_by_each (boolean, default=true})`,O(`Whether or not to divide text around each character contained in delimiter.`)),W(`remove_empty_text (boolean, default=true)`,O(`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,n={value:!0},r={value:!0}){let i=I(e),a=at(I(t)),o=L(n),s=L(r);N(()=>a.length>0,O(`The _delimiter (%s) must be not be empty.`,a));let c=o?RegExp(`[${a}]`,`g`):new RegExp(a,`g`),l=i.split(c);return s&&(l=l.filter(e=>e!==``)),Qa([l])},isExported:!1},Jb={description:O(`Replaces existing text with new text in a string.`),args:[W(`text_to_search (string)`,O(`The text within which to search and replace.`)),W(`search_for (string)`,O(`The string to search for within text_to_search.`)),W(`replace_with (string)`,O(`The string that will replace search_for.`)),W(`occurrence_number (number, optional)`,O(`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,n,r){let i=F(r,this.locale);N(()=>i>=0,O(`The occurrenceNumber (%s) must be positive or null.`,i.toString()));let a=I(e),o=I(t);if(o===``)return a;let s=I(n),c=new RegExp(at(o),`g`);if(i===0)return a.replace(c,s);let l=0;return a.replace(c,e=>++l===i?s:e)},isExported:!0},Yb={description:O(`Combines text from multiple strings and/or arrays.`),args:[W(`delimiter (string)`,O(` A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.`)),W(`ignore_empty (boolean)`,O(`A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.`)),W(`text1 (string, range<string>)`,O(`Any text item. This could be a string, or an array of strings in a range.`)),W(`text2 (string, range<string>, repeating)`,O(`Additional text item(s).`))],compute:function(e,t,...n){let r=I(e),i=L(t),a=0;return Ka(n,(e,t)=>i&&I(t)===``?e:(a++?e+r:``)+I(t),``)},isExported:!0},Xb={description:O(`Removes space characters.`),args:[W(`text (string)`,O(`The text or reference to a cell containing text to be trimmed.`))],compute:function(e){return Gt(I(e))},isExported:!0},Zb={description:O(`Converts a specified string to uppercase.`),args:[W(`text (string)`,O(`The string to convert to uppercase.`))],compute:function(e){return I(e).toUpperCase()},isExported:!0},Qb={description:O(`Converts a number to text according to a specified format.`),args:[W(`number (number)`,O(`The number, date or time to format.`)),W(`format (string)`,O(`The pattern by which to format the number, enclosed in quotation marks.`))],compute:function(e,t){return B(F(e,this.locale),{format:I(t),locale:this.locale})},isExported:!0},$b={description:O(`Converts a string to a numeric value.`),args:[W(`value (number)`,O(`the string to be converted`))],compute:function(e){return F(e,this.locale)},isExported:!0};var ex=l({HYPERLINK:()=>tx});let tx={description:O(`Creates a hyperlink in a cell.`),args:[W(`url (string)`,O(`The full URL of the link enclosed in quotation marks.`)),W(`link_label (string, optional)`,O(`The text to display in the cell, enclosed in quotation marks.`))],compute:function(e,t){let n=I(e).trim(),r=I(t)||n;return n===``?r:vt(r,n)},isExported:!0},nx=[{name:O(`Array`),functions:Nf},{name:O(`Database`),functions:Th},{name:O(`Date`),functions:Bh},{name:O(`Filter`),functions:Og},{name:O(`Financial`),functions:u_},{name:O(`Info`),functions:ny},{name:O(`Lookup`),functions:Ay},{name:O(`Logical`),functions:my},{name:O(`Math`),functions:ap},{name:O(`Misc`),functions:rp},{name:O(`Operator`),functions:Jy},{name:O(`Statistical`),functions:_m},{name:O(`Text`),functions:jb},{name:O(`Engineering`),functions:xg},{name:O(`Web`),functions:ex},{name:O(`Parser`),functions:kb}],rx=/^[A-Z0-9\_\.]+$/,ix=new class extends h{mapping={};add(e,t){if(e=e.toUpperCase(),!rx.test(e))throw Error(O(`Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)`,e));let n=wf(e,t);return Of(n),this.mapping[e]=ax(n),super.add(e,n),this}};for(let e of nx){let t=e.functions;for(let n in t){let r=t[n];r.category=r.category||e.name,n=n.replace(/_/g,`.`),ix.add(n,{isExported:!1,...r})}}function ax(e){function t(...t){let i=[],a=Ef(e,t.length);for(let n=0;n<t.length;n++){let r=a(n)??-1,o=e.args[r],s=t[n];if(!A(s)&&o.acceptMatrixOnly)throw new ya(O(`Function %s expects the parameter '%s' to be reference to a cell or range.`,e.name,(n+1).toString()));i.push(!o.acceptMatrix)}return n($a(r.bind(this),t,i))}function n(t){return A(t)?Za(t,t=>cx(t,e.name)):cx(t,e.name),t}function r(...t){for(let n=0;n<t.length;n++){let r=t[n],i=Ef(e,t.length);if(!e.args[i(n)||n].acceptErrors&&!A(r)&&P(r?.value))return r}try{return i.apply(this,t)}catch(t){return ox(t,e.name)}}function i(...t){this.debug&&=!1;let n=e.compute.apply(this,t);return A(n)?typeof n[0][0]==`object`&&n[0][0]!==null&&`value`in n[0][0]?n:Xa(n,e=>({value:e})):typeof n==`object`&&n&&`value`in n?n:(e.name,{value:n})}return t}function ox(e,t){return sx(e)&&P(e.value)?(ux(e)&&cx(e,t),e):(console.error(e),new M(lx+(ux(e)?` `+e.message:``)))}function sx(e){return e?.value!==void 0&&typeof e.value==`string`}function cx(e,t){e.message?.includes(`[[FUNCTION_NAME]]`)&&(e.message=e.message.replace(`[[FUNCTION_NAME]]`,t))}let lx=O(`An unexpected error occurred. Submit a support ticket at odoo.com/help.`);function ux(e){return e?.message!==void 0&&typeof e.message==`string`}var dx=class{code=``;constructor(e=new px){this.scope=e}append(...e){this.code+=e.map(e=>e.toString()).join(`
|
|
14
|
+
`)}}return t}var Kd=class{get;disposeCallbacks=[];constructor(e){this.get=e}onDispose(e){this.disposeCallbacks.push(e)}dispose(){this.disposeCallbacks.forEach(e=>e())}};function qd(){let e=(0,t.useEnv)();if(e.__spreadsheet_stores__ instanceof Ud)return e.__spreadsheet_stores__;let n=new Ud;return(0,t.useSubEnv)({__spreadsheet_stores__:n,getStore:e=>Xd(n.get(e),()=>n.trigger(`store-updated`))}),n}function V(e){let n=Zd((0,t.useEnv)());return Yd(n,n.get(e))}function Jd(e,...n){let r=Zd((0,t.useEnv)()),i=r.instantiate(e,...n);return(0,t.onWillUnmount)(()=>i.dispose()),Yd(r,i)}function Yd(e,n){let r=(0,t.useComponent)();return Xd(n,()=>{(0,t.status)(r)===`mounted`&&e.trigger(`store-updated`)})}function Xd(e,t){return new Proxy(e,{get(n,r,i){let a=n,o=Reflect.get(n,r,a);return e.mutators?.includes(r)?new Proxy(o,{apply(e,n,r){Reflect.apply(e,a,r)!==`noStateChange`&&t()}}):o}})}function Zd(e){let t=e.__spreadsheet_stores__;if(!(t instanceof Ud))throw Error(`No store provider found. Did you forget to call useStoreProvider()?`);return t}let Qd=Gd(`Model`);var $d=class{mutators=[`register`,`unRegister`,`drawLayer`];renderers={};register(e){if(e.renderingLayers.length)for(let t of e.renderingLayers)this.renderers[t]||(this.renderers[t]=[]),this.renderers[t].push(e)}unRegister(e){for(let t of Object.keys(this.renderers))this.renderers[t]=this.renderers[t].filter(t=>t!==e)}drawLayer(e,t){let n=this.renderers[t];if(n)for(let r of n)e.ctx.save(),r.drawLayer(e,t),e.ctx.restore();return`noStateChange`}},ef=class extends Kd{model=this.get(Qd);getters=this.model.getters;renderer=this.get($d);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){}};let tf={id:`void-composer`,get editionMode(){return`inactive`},startEdition:()=>{throw Error(`No composer is registered`)},stopEdition:()=>{throw Error(`No composer is registered`)},setCurrentContent:()=>{throw Error(`No composer is registered`)}};var nf=class extends ef{mutators=[`focusComposer`,`focusActiveComposer`];activeComposer=tf;_focusMode=`inactive`;get focusMode(){return this.activeComposer.editionMode===`inactive`?`inactive`:this._focusMode}focusComposer(e,t){if(this.activeComposer=e,this.getters.isReadonly())return`noStateChange`;this._focusMode=t.focusMode||`contentFocus`,this._focusMode!==`inactive`&&this.setComposerContent(t)}focusActiveComposer(e){if(this.getters.isReadonly())return`noStateChange`;if(!this.activeComposer)throw Error(`No composer is registered`);this._focusMode=e.focusMode||`contentFocus`,this._focusMode!==`inactive`&&this.setComposerContent(e)}setComposerContent({content:e,selection:t}){this.activeComposer.editionMode===`inactive`?this.activeComposer.startEdition(e,t):e&&this.activeComposer.setCurrentContent(e,t)}};let rf={},af=0;function H(e,...t){let n=`__sheet__${af++}`;return sf(n,String.raw(e,...t)),cf(n),n}function of(e){let t=e.split(/(\{|\}|;)/).map(e=>e.trim()),n=[],r=[],i=[];function a(e,t){let r=[];for(let i of n[e]){let o=t&&t+` `+i||i;o.includes(`&`)&&(o=i.replace(/&/g,t||``)),e<n.length-1&&(o=a(e+1,o)),r.push(o)}return r.join(`, `)}function o(){i.length&&(r.push(a(0)+` {`),r.push(...i),r.push(`}`),i=[])}for(;t.length;){let e=t.shift();e===`}`?(o(),n.pop()):(t[0]===`{`&&(o(),n.push(e.split(/\s*,\s*/)),t.shift()),t[0]===`;`&&i.push(` `+e+`;`))}return r.join(`
|
|
15
|
+
`)}function sf(e,t){let n=document.createElement(`style`);n.textContent=of(t),rf[e]=n}function cf(e){let t=rf[e];t.setAttribute(`component`,e),document.head.appendChild(t)}function lf({strikethrough:e,underline:t}){return!e&&!t?`none`:`${e?`line-through`:``} ${t?`underline`:``}`}function uf(e){let t=df(e);return e&&e.fillColor&&(t.background=e.fillColor),t}function df(e){let t={};if(!e)return t;if(e.bold&&(t[`font-weight`]=`bold`),e.italic&&(t[`font-style`]=`italic`),e.strikethrough||e.underline){let n=e.strikethrough?`line-through`:``;n=e.underline?n+` underline`:n,t[`text-decoration`]=n}return e.textColor&&(t.color=e.textColor),t}function U(e){let t=``;for(let n in e)e[n]&&(t+=`${n}:${e[n]}; `);return t}function ff(e){let t=window.getComputedStyle(e);return{top:parseInt(t.marginTop,10)||0,bottom:parseInt(t.marginBottom,10)||0,left:parseInt(t.marginLeft,10)||0,right:parseInt(t.marginRight,10)||0}}let pf=new h;function mf(){return!!window.Chart.registry.plugins.get(`chartShowValuesPlugin`)}function hf(){if(!(!window.Chart||mf()))for(let e of pf.getAll())e.register(window.Chart)}function gf(){if(window.Chart)for(let e of pf.getAll())e.unregister(window.Chart)}function _f(){return class extends window.Chart.BarController{static id=`funnel`;static defaults={...window.Chart?.BarController.defaults,dataElementType:`funnel`,animation:{duration:e=>e.type===`data`?1e3*(e.raw[1]/Math.max(...e.dataset.data.map(e=>e[1]))):1e3}};updateElements(e,t,n,r){super.updateElements(e,t,n,r);for(let i=t;i<t+n;i++){let t=e[i];this.updateElement(t,i,{nextElement:e[i+1]},r)}}}}function vf(){return class extends window.Chart.BarElement{static id=`funnel`;draw(e){e.save();let{x:t,y:n,height:r,nextElement:i,base:a,options:o}=this.getProps([`x`,`y`,`width`,`height`,`nextElement`,`base`,`options`]),s=yf(this),c=(s-(i?yf(i):0))/2,l=Math.min(t,a),u=n-r/2;e.fillStyle=o.backgroundColor,e.beginPath(),e.moveTo(l,u),e.lineTo(l+s,u),e.lineTo(l+s-c,u+r),e.lineTo(l+c,u+r),e.closePath(),e.fill(),o.borderWidth&&(e.strokeStyle=o.borderColor,e.lineWidth=o.borderWidth,e.stroke()),e.restore()}inRange(e,t){let{x:n,y:r,height:i,nextElement:a,base:o}=this.getProps([`x`,`y`,`width`,`height`,`nextElement`,`base`,`options`]),s=yf(this),c=a?yf(a):0,l=Math.min(n,o),u=r-i/2;if(t<u||t>u+i)return!1;let d=(s-c)/2,f=l+d*(t-u)/i,p=l+s-d*(t-u)/i;return!(e<f||e>p)}}}function yf(e){let{x:t,base:n}=e.getProps([`x`,`base`]);return Math.max(t,n)-Math.min(t,n)}let bf=function(e){if(!e.length)return{x:0,y:0};let{x:t,y:n,base:r,width:i,height:a}=e[0].element.getProps([`x`,`y`,`width`,`height`,`base`]),o=Math.min(t,r),s=n-a/2;return{x:o+i*2/3,y:s+a/2}},xf=/(.*?)\((.*?)\)(.*)/,Sf=[`ANY`,`BOOLEAN`,`DATE`,`NUMBER`,`STRING`,`RANGE`,`RANGE<BOOLEAN>`,`RANGE<DATE>`,`RANGE<NUMBER>`,`RANGE<STRING>`,`META`];function W(e,t=``){return Cf(e,t)}function Cf(e,t){let n=e.match(xf),r=n[1].trim();if(!r)throw Error(`Function argument definition is missing a name: '${e}'.`);let i=[],a=!1,o=!1,s;for(let e of n[2].split(`,`)){let t=e.trim().toUpperCase(),n=Sf.find(e=>t===e);n?i.push(n):t===`RANGE<ANY>`?i.push(`RANGE`):t===`OPTIONAL`?a=!0:t===`REPEATING`?o=!0:t.startsWith(`DEFAULT=`)&&(s=e.trim().slice(8))}let c={name:r,description:t,type:i};return(i.includes(`ANY`)||i.includes(`RANGE`))&&(c.acceptErrors=!0),a&&(c.optional=!0),o&&(c.repeating=!0),s!==void 0&&(c.default=!0,c.defaultValue=s),i.some(e=>e.startsWith(`RANGE`))&&(c.acceptMatrix=!0),i.every(e=>e.startsWith(`RANGE`))&&(c.acceptMatrixOnly=!0),c}function wf(e,t){let n=0,r=0,i=0,a=0;for(let e of t.args)n++,!e.optional&&!e.repeating&&!e.default&&r++,e.repeating&&i++,(e.optional||e.default)&&a++;let o=t;return o.minArgRequired=r,o.maxArgPossible=i?1/0:n,o.nbrArgRepeating=i,o.nbrArgOptional=a,o.hidden=t.hidden||!1,o.name=e,o}let Tf={};function Ef(e,t){let n=e.name;return Tf[n]?.[t]||(Tf[n]||(Tf[n]={}),Tf[n][t]||(Tf[n][t]=Df(e,t)),Tf[n][t])}function Df(e,t){let n={},r=e.nbrArgRepeating?Math.floor((t-e.minArgRequired)/e.nbrArgRepeating):0,i=e.nbrArgRepeating*r,a=t-e.minArgRequired-i,o=0,s=0;for(let t=0;t<e.args.length;t++){let i=e.args[t];if(i.optional||i.default){s<a&&(n[o]=t,o++),s++;continue}if(i.repeating){for(let i=0;i<r;i++)for(let r=0;r<e.nbrArgRepeating;r++)n[o]=t+r,o++;t+=e.nbrArgRepeating-1;continue}n[o]=t,o++}return e=>n[e]}function Of(e){if(e.nbrArgRepeating&&e.nbrArgOptional>=e.nbrArgRepeating)throw Error(`Function ${e.name} has more optional arguments than repeatable ones.`);let t=!1,n=!1;for(let r of e.args){if(r.type.includes(`META`)&&r.type.length>1)throw 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(r.repeating){if(!n&&t)throw Error(`Function ${e.name} has non-consecutive repeating arguments. All repeating arguments must be declared consecutively.`);t=!0,n=!0}else n=!1}}function kf(e,t){N(()=>t.length===1||t[0].length===1,e)}function Af(e,...t){if(t.every(A)){let n=t[0].length,r=t[0][0].length;for(let i of t)N(()=>i.length===n&&i[0].length===r,e);return}if(t.some(e=>Array.isArray(e)&&(e.length!==1||e[0].length!==1)))throw new M(e)}function jf(e,t){N(()=>t>0,e)}function Mf(e,t){N(()=>t.length===t[0].length,e)}var Nf=l({ARRAY_CONSTRAIN:()=>Pf,CHOOSECOLS:()=>Ff,CHOOSEROWS:()=>If,EXPAND:()=>Lf,FLATTEN:()=>Rf,FREQUENCY:()=>zf,HSTACK:()=>Bf,MDETERM:()=>Vf,MINVERSE:()=>Hf,MMULT:()=>Uf,SUMPRODUCT:()=>Wf,SUMX2MY2:()=>Kf,SUMX2PY2:()=>qf,SUMXMY2:()=>Jf,TOCOL:()=>Zf,TOROW:()=>Qf,TRANSPOSE:()=>$f,VSTACK:()=>ep,WRAPCOLS:()=>tp,WRAPROWS:()=>np});let Pf={description:O(`Returns a result array constrained to a specific width and height.`),args:[W(`input_range (any, range<any>)`,O(`The range to constrain.`)),W(`rows (number)`,O(`The number of rows in the constrained array.`)),W(`columns (number)`,O(`The number of columns in the constrained array.`))],compute:function(e,t,n){let r=z(e),i=Pa(t?.value,this.locale),a=Pa(n?.value,this.locale);jf(O(`The rows argument (%s) must be strictly positive.`,i.toString()),i),jf(O(`The columns argument (%s) must be strictly positive.`,i.toString()),a);let o=Math.min(i,r[0].length);return Ya(Math.min(a,r.length),o,(e,t)=>r[e][t])},isExported:!1},Ff={description:O(`Creates a new array from the selected columns in the existing range.`),args:[W(`array (any, range<any>)`,O(`The array that contains the columns to be returned.`)),W(`col_num (number, range<number>)`,O(`The first column index of the columns to be returned.`)),W(`col_num2 (number, range<number>, repeating)`,O(`The columns indexes of the columns to be returned.`))],compute:function(e,...t){let n=z(e),r=fo(t,e=>Pa(e?.value,this.locale)),i=r.filter(e=>e===0||n.length<Math.abs(e));N(()=>i.length===0,O(`The columns arguments must be between -%s and %s (got %s), excluding 0.`,n.length.toString(),n.length.toString(),i.join(`,`)));let a=Array(r.length);for(let e=0;e<r.length;e++)r[e]>0?a[e]=n[r[e]-1]:a[e]=n[n.length+r[e]];return a},isExported:!0},If={description:O(`Creates a new array from the selected rows in the existing range.`),args:[W(`array (any, range<any>)`,O(`The array that contains the rows to be returned.`)),W(`row_num (number, range<number>)`,O(`The first row index of the rows to be returned.`)),W(`row_num2 (number, range<number>, repeating)`,O(`The rows indexes of the rows to be returned.`))],compute:function(e,...t){let n=z(e),r=fo(t,e=>Pa(e?.value,this.locale)),i=n.length,a=r.filter(e=>e===0||n[0].length<Math.abs(e));return N(()=>a.length===0,O(`The rows arguments must be between -%s and %s (got %s), excluding 0.`,n[0].length.toString(),n[0].length.toString(),a.join(`,`))),Ya(i,r.length,(e,t)=>r[t]>0?n[e][r[t]-1]:n[e][n[e].length+r[t]])},isExported:!0},Lf={description:O(`Expands or pads an array to specified row and column dimensions.`),args:[W(`array (any, range<any>)`,O(`The array to expand.`)),W(`rows (number)`,O(`The number of rows in the expanded array. If missing, rows will not be expanded.`)),W(`columns (number, optional)`,O(`The number of columns in the expanded array. If missing, columns will not be expanded.`)),W(`pad_with (any, default=0)`,O(`The value with which to pad.`))],compute:function(e,t,n,r={value:0}){let i=z(e),a=Pa(t?.value,this.locale),o=n===void 0?i.length:Pa(n.value,this.locale);return N(()=>a>=i[0].length,O(`The rows arguments (%s) must be greater or equal than the number of rows of the array.`,a.toString())),N(()=>o>=i.length,O(`The columns arguments (%s) must be greater or equal than the number of columns of the array.`,o.toString())),Ya(o,a,(e,t)=>e>=i.length||t>=i[e].length?r:i[e][t])},isExported:!0},Rf={description:O(`Flattens all the values from one or more ranges into a single column.`),args:[W(`range (any, range<any>)`,O(`The first range to flatten.`)),W(`range2 (any, range<any>, repeating)`,O(`Additional ranges to flatten.`))],compute:function(...e){return[fo(e,e=>e===void 0?{value:``}:e)]},isExported:!1},zf={description:O(`Calculates the frequency distribution of a range.`),args:[W(`data (range<number>)`,O(`The array of ranges containing the values to be counted.`)),W(`classes (number, range<number>)`,O(`The range containing the set of classes.`))],compute:function(e,t){let n=fo([e],e=>e.value).filter(e=>typeof e==`number`),r=fo([t],e=>e.value).filter(e=>typeof e==`number`).map((e,t)=>({initialIndex:t,value:e,count:0})).sort((e,t)=>e.value-t.value);r.push({initialIndex:r.length,value:1/0,count:0});let i=n.sort((e,t)=>e-t),a=0;for(let e of i){for(;e>r[a].value&&a<r.length-1;)a++;r[a].count++}return[r.sort((e,t)=>e.initialIndex-t.initialIndex).map(e=>e.count)]},isExported:!0},Bf={description:O(`Appends ranges horizontally and in sequence to return a larger array.`),args:[W(`range1 (any, range<any>)`,O(`The first range to be appended.`)),W(`range2 (any, range<any>, repeating)`,O(`Additional ranges to add to range1.`))],compute:function(...e){let t=Math.max(...e.map(e=>e?.[0]?.length??0)),n=[];for(let r of e){let e=z(r);for(let r=0;r<e.length;r++){let i=Array(t).fill({value:null});for(let t=0;t<e[r].length;t++)i[t]=e[r][t];n.push(i)}}return n},isExported:!0},Vf={description:O(`Returns the matrix determinant of a square matrix.`),args:[W(`square_matrix (number, range<number>)`,O(`An range with an equal number of rows and columns representing a matrix whose determinant will be calculated.`))],compute:function(e){let t=Ma(e,`square_matrix`);return Mf(O(`The argument square_matrix must have the same number of columns and rows.`),t),au(t).determinant},isExported:!0},Hf={description:O(`Returns the multiplicative inverse of a square matrix.`),args:[W(`square_matrix (number, range<number>)`,O(`An range with an equal number of rows and columns representing a matrix whose multiplicative inverse will be calculated.`))],compute:function(e){let t=Ma(e,`square_matrix`);Mf(O(`The argument square_matrix must have the same number of columns and rows.`),t);let{inverted:n}=au(t);return n||new M(O(`The matrix is not invertible.`))},isExported:!0},Uf={description:O(`Calculates the matrix product of two matrices.`),args:[W(`matrix1 (number, range<number>)`,O(`The first matrix in the matrix multiplication operation.`)),W(`matrix2 (number, range<number>)`,O(`The second matrix in the matrix multiplication operation.`))],compute:function(e,t){let n=Ma(e,`matrix1`),r=Ma(t,`matrix2`);return N(()=>n.length>0&&r.length>0,O(`The first and second arguments of [[FUNCTION_NAME]] must be non-empty matrices.`)),N(()=>n.length===r[0].length,O(`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).`,n.length.toString(),r[0].length.toString())),su(n,r)},isExported:!0},Wf={description:O(`Calculates the sum of the products of corresponding entries in equal-sized ranges.`),args:[W(`range1 (number, range<number>)`,O(`The first range whose entries will be multiplied with corresponding entries in the other ranges.`)),W(`range2 (number, range<number>, repeating)`,O(`The other range whose entries will be multiplied with corresponding entries in the other ranges.`))],compute:function(...e){Af(O(`All the ranges must have the same dimensions.`),...e);let t=e.map(z),n=0;for(let e=0;e<t[0].length;e++)for(let r=0;r<t[0][e].length;r++){if(!t.every(t=>typeof t[e][r].value==`number`))continue;let i=1;for(let n of t)i*=F(n[e][r],this.locale);n+=i}return n},isExported:!0};function Gf(e,t,n){Af(`The arguments array_x and array_y must have the same dimensions.`,e,t);let r=z(e),i=z(t),a=!1,o=0;for(let e in r)for(let t in r[e]){let s=r[e][t].value,c=i[e][t].value;typeof s!=`number`||typeof c!=`number`||(a=!0,o+=n(s,c))}return a?o:new M(O(`The arguments array_x and array_y must contain at least one pair of numbers.`))}let Kf={description:O(`Calculates the sum of the difference of the squares of the values in two array.`),args:[W(`array_x (number, range<number>)`,O(`The array or range of values whose squares will be reduced by the squares of corresponding entries in array_y and added together.`)),W(`array_y (number, range<number>)`,O(`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 Gf(e,t,(e,t)=>e**2-t**2)},isExported:!0},qf={description:O(`Calculates the sum of the sum of the squares of the values in two array.`),args:[W(`array_x (number, range<number>)`,O(`The array or range of values whose squares will be added to the squares of corresponding entries in array_y and added together.`)),W(`array_y (number, range<number>)`,O(`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 Gf(e,t,(e,t)=>e**2+t**2)},isExported:!0},Jf={description:O(`Calculates the sum of squares of the differences of values in two array.`),args:[W(`array_x (number, range<number>)`,O(`The array or range of values that will be reduced by corresponding entries in array_y, squared, and added together.`)),W(`array_y (number, range<number>)`,O(`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 Gf(e,t,(e,t)=>(e-t)**2)},isExported:!0},Yf=[W(`array (any, range<any>)`,O(`The array which will be transformed.`)),W(`ignore (number, default=0)`,O(`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.`)),W(`scan_by_column (number, default=false)`,O(`Whether the array should be scanned by column. True scans the array by column and false (default) scans the array by row.`))];function Xf(e){let t=Math.trunc(e);if(t===0)return()=>!0;if(t===1)return e=>e.value!==null;if(t===2)return e=>!P(e.value);if(t===3)return e=>e.value!==null&&!P(e.value);throw new M(O(`Argument ignore must be between 0 and 3`))}let Zf={description:O(`Transforms a range of cells into a single column.`),args:Yf,compute:function(e,t={value:0},n={value:!1}){let r=z(e),i=F(t.value,this.locale),a=(L(n.value)?r:Qa(r)).flat().filter(Xf(i));return a.length===0?new Sa(O(`No results for the given arguments of TOCOL.`)):[a]},isExported:!0},Qf={description:O(`Transforms a range of cells into a single row.`),args:Yf,compute:function(e,t={value:0},n={value:!1}){let r=z(e),i=F(t.value,this.locale),a=(L(n.value)?r:Qa(r)).flat().filter(Xf(i)).map(e=>[e]);return a.length===0||a[0].length===0?new Sa(O(`No results for the given arguments of TOROW.`)):a},isExported:!0},$f={description:O(`Transposes the rows and columns of a range.`),args:[W(`range (any, range<any>)`,O(`The range to be transposed.`))],compute:function(e){let t=z(e),n=t[0].length,r=t.length;return Ya(n,r,(e,n)=>t[n][e])},isExported:!0},ep={description:O(`Appends ranges vertically and in sequence to return a larger array.`),args:[W(`range1 (any, range<any>)`,O(`The first range to be appended.`)),W(`range2 (any, range<any>, repeating)`,O(`Additional ranges to add to range1.`))],compute:function(...e){let t=Math.max(...e.map(e=>z(e).length)),n=e.reduce((e,t)=>e+z(t)[0].length,0),r=Array(t).fill([]).map(()=>Array(n).fill({value:0})),i=0;for(let t of e){let e=z(t);for(let t=0;t<e.length;t++)for(let n=0;n<e[t].length;n++)r[t][i+n]=e[t][n];i+=e[0].length}return r},isExported:!0},tp={description:O(`Wraps the provided row or column of cells by columns after a specified number of elements to form a new array.`),args:[W(`range (any, range<any>)`,O(`The range to wrap.`)),W(`wrap_count (number)`,O(`The maximum number of cells for each column, rounded down to the nearest whole number.`)),W(`pad_with (any, default=0)`,O(`The value with which to fill the extra cells in the range.`))],compute:function(e,t,n={value:0}){let r=z(e),i=Pa(t?.value,this.locale);kf(O(`Argument range must be a single row or column.`),r);let a=r.flat();return Ya(Math.ceil(a.length/i),i,(e,t)=>{let r=e*i+t;return r<a.length?a[r]:n})},isExported:!0},np={description:O(`Wraps the provided row or column of cells by rows after a specified number of elements to form a new array.`),args:[W(`range (any, range<any>)`,O(`The range to wrap.`)),W(`wrap_count (number)`,O(`The maximum number of cells for each row, rounded down to the nearest whole number.`)),W(`pad_with (any, default=0)`,O(`The value with which to fill the extra cells in the range.`))],compute:function(e,t,n={value:0}){let r=z(e),i=Pa(t?.value,this.locale);kf(O(`Argument range must be a single row or column.`),r);let a=r.flat();return Ya(i,Math.ceil(a.length/i),(e,t)=>{let r=t*i+e;return r<a.length?a[r]:n})},isExported:!0};var rp=l({FORMAT_LARGE_NUMBER:()=>ip});let ip={description:O(`Apply a large number format`),args:[W(`value (number)`,O(`The number.`)),W(`unit (string, optional)`,O(`The formatting unit. Use 'k', 'm', or 'b' to force the unit`))],compute:function(e,t){return{value:F(e,this.locale),format:Cs(e,t,this.locale)}}};var ap=l({ABS:()=>sp,ACOS:()=>cp,ACOSH:()=>lp,ACOT:()=>up,ACOTH:()=>dp,ASIN:()=>fp,ASINH:()=>pp,ATAN:()=>mp,ATAN2:()=>hp,ATANH:()=>gp,CEILING:()=>_p,CEILING_MATH:()=>yp,CEILING_PRECISE:()=>bp,COS:()=>xp,COSH:()=>Sp,COT:()=>Cp,COTH:()=>wp,COUNTBLANK:()=>Tp,COUNTIF:()=>Ep,COUNTIFS:()=>Dp,COUNTUNIQUE:()=>Op,COUNTUNIQUEIFS:()=>kp,CSC:()=>Ap,CSCH:()=>jp,DECIMAL:()=>Mp,DEGREES:()=>Np,EXP:()=>Pp,FLOOR:()=>Fp,FLOOR_MATH:()=>Lp,FLOOR_PRECISE:()=>Rp,INT:()=>gm,ISEVEN:()=>zp,ISODD:()=>Vp,ISO_CEILING:()=>Bp,LN:()=>Hp,LOG:()=>Up,MOD:()=>Gp,MUNIT:()=>Kp,ODD:()=>qp,PI:()=>Jp,POWER:()=>Yp,PRODUCT:()=>Xp,RAND:()=>Zp,RANDARRAY:()=>Qp,RANDBETWEEN:()=>$p,ROUND:()=>em,ROUNDDOWN:()=>tm,ROUNDUP:()=>nm,SEC:()=>rm,SECH:()=>im,SEQUENCE:()=>am,SIN:()=>om,SINH:()=>sm,SQRT:()=>cm,SUM:()=>lm,SUMIF:()=>um,SUMIFS:()=>dm,TAN:()=>fm,TANH:()=>pm,TRUNC:()=>hm});let op=/^-?[a-z0-9]+$/i,sp={description:O(`Absolute value of a number.`),args:[W(`value (number)`,O(`The number of which to return the absolute value.`))],compute:function(e){return Math.abs(F(e,this.locale))},isExported:!0},cp={description:O(`Inverse cosine of a value, in radians.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse cosine. Must be between -1 and 1, inclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)<=1,O(`The value (%s) must be between -1 and 1 inclusive.`,t.toString())),Math.acos(t)},isExported:!0},lp={description:O(`Inverse hyperbolic cosine of a number.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic cosine. Must be greater than or equal to 1.`))],compute:function(e){let t=F(e,this.locale);return N(()=>t>=1,O(`The value (%s) must be greater than or equal to 1.`,t.toString())),Math.acosh(t)},isExported:!0},up={description:O(`Inverse cotangent of a value.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse cotangent.`))],compute:function(e){let t=F(e,this.locale);return(Math.sign(t)||1)*Math.PI/2-Math.atan(t)},isExported:!0},dp={description:O(`Inverse hyperbolic cotangent of a value.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic cotangent. Must not be between -1 and 1, inclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)>1,O(`The value (%s) cannot be between -1 and 1 inclusive.`,t.toString())),Math.log((t+1)/(t-1))/2},isExported:!0},fp={description:O(`Inverse sine of a value, in radians.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse sine. Must be between -1 and 1, inclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)<=1,O(`The value (%s) must be between -1 and 1 inclusive.`,t.toString())),Math.asin(t)},isExported:!0},pp={description:O(`Inverse hyperbolic sine of a number.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic sine.`))],compute:function(e){return Math.asinh(F(e,this.locale))},isExported:!0},mp={description:O(`Inverse tangent of a value, in radians.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse tangent.`))],compute:function(e){return Math.atan(F(e,this.locale))},isExported:!0},hp={description:O(`Angle from the X axis to a point (x,y), in radians.`),args:[W(`x (number)`,O(`The x coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.`)),W(`y (number)`,O(`The y coordinate of the endpoint of the line segment for which to calculate the angle from the x-axis.`))],compute:function(e,t){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>n!==0||r!==0,O(`Function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero),Math.atan2(r,n)},isExported:!0},gp={description:O(`Inverse hyperbolic tangent of a number.`),args:[W(`value (number)`,O(`The value for which to calculate the inverse hyperbolic tangent. Must be between -1 and 1, exclusive.`))],compute:function(e){let t=F(e,this.locale);return N(()=>Math.abs(t)<1,O(`The value (%s) must be between -1 and 1 exclusive.`,t.toString())),Math.atanh(t)},isExported:!0},_p={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`value (number)`,O(`The value to round up to the nearest integer multiple of factor.`)),W(`factor (number, default=1)`,O(`The number to whose multiples value will be rounded.`))],compute:function(e,t={value:1}){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>r>=0||n<=0,O(`The factor (%s) must be positive when the value (%s) is positive.`,r.toString(),n.toString())),{value:r?Math.ceil(n/r)*r:0,format:e?.format}},isExported:!0};function vp(e,t,n=0){return t===0?0:(t=Math.abs(t),e>=0?Math.ceil(e/t)*t:n===0?-Math.floor(Math.abs(e)/t)*t:-Math.ceil(Math.abs(e)/t)*t)}let yp={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round up to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded. The sign of significance will be ignored.`)),W(`mode (number, default=0)`,O(`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},n={value:0}){let r=F(t,this.locale);return{value:vp(F(e,this.locale),r,F(n,this.locale)),format:e?.format}},isExported:!0},bp={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round up to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded.`))],compute:function(e,t={value:1}){let n=F(t,this.locale);return{value:vp(F(e,this.locale),n),format:e?.format}},isExported:!0},xp={description:O(`Cosine of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the cosine of, in radians.`))],compute:function(e){return Math.cos(F(e,this.locale))},isExported:!0},Sp={description:O(`Hyperbolic cosine of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic cosine of.`))],compute:function(e){return Math.cosh(F(e,this.locale))},isExported:!0},Cp={description:O(`Cotangent of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the cotangent of, in radians.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.tan(t)},isExported:!0},wp={description:O(`Hyperbolic cotangent of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic cotangent of.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.tanh(t)},isExported:!0},Tp={description:O(`Number of empty values.`),args:[W(`value1 (any, range)`,O(`The first value or range in which to count the number of blanks.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges in which to count the number of blanks.`))],compute:function(...e){return Ka(e,(e,t)=>t===void 0||t.value===null||t.value===``?e+1:e,0)},isExported:!0},Ep={description:O(`A conditional count across a range.`),args:[W(`range (range)`,O(`The range that is tested against criterion.`)),W(`criterion (string)`,O(`The pattern or test to apply to range.`))],compute:function(...e){let t=0;return ao(e,(e,n)=>{t+=1},this.locale),t},isExported:!0},Dp={description:O(`Count values depending on multiple criteria.`),args:[W(`criteria_range1 (range)`,O(`The range to check against criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`Additional criteria to check.`))],compute:function(...e){let t=0;return ao(e,(e,n)=>{t+=1},this.locale),t},isExported:!0},Op={description:O(`Counts number of unique values in a range.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider for uniqueness.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider for uniqueness.`))],compute:function(...e){return ru(e)}},kp={description:O(`Counts number of unique values in a range, filtered by a set of criteria.`),args:[W(`range (range)`,O(`The range of cells from which the number of unique values will be counted.`)),W(`criteria_range1 (range)`,O(`The range of cells over which to evaluate criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=new Set;return ao(t,(t,r)=>{let i=e[t]?.[r];po(i)&&n.add(i.value)},this.locale),n.size}},Ap={description:O(`Cosecant of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the cosecant of, in radians.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.sin(t)},isExported:!0},jp={description:O(`Hyperbolic cosecant of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic cosecant of.`))],compute:function(e){let t=F(e,this.locale);return La(t),1/Math.sinh(t)},isExported:!0},Mp={description:O(`Converts from another base to decimal.`),args:[W(`value (string)`,O(`The number to convert.`)),W(`base (number)`,O(`The base to convert the value from.`))],compute:function(e,t){let n=F(t,this.locale);n=Math.floor(n),N(()=>2<=n&&n<=36,O(`The base (%s) must be between 2 and 36 inclusive.`,n.toString()));let r=I(e);if(r===``)return 0;N(()=>op.test(r),O(`The value (%s) must be a valid base %s representation.`,r,n.toString()));let i=parseInt(r,n);return N(()=>!isNaN(i),O(`The value (%s) must be a valid base %s representation.`,r,n.toString())),i},isExported:!0},Np={description:O(`Converts an angle value in radians to degrees.`),args:[W(`angle (number)`,O(`The angle to convert from radians to degrees.`))],compute:function(e){return F(e,this.locale)*180/Math.PI},isExported:!0},Pp={description:O(`Euler's number, e (~2.718) raised to a power.`),args:[W(`value (number)`,O(`The exponent to raise e.`))],compute:function(e){return Math.exp(F(e,this.locale))},isExported:!0},Fp={description:O(`Rounds number down to nearest multiple of factor.`),args:[W(`value (number)`,O(`The value to round down to the nearest integer multiple of factor.`)),W(`factor (number, default=1)`,O(`The number to whose multiples value will be rounded.`))],compute:function(e,t={value:1}){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>r>=0||n<=0,O(`The factor (%s) must be positive when the value (%s) is positive.`,r.toString(),n.toString())),{value:r?Math.floor(n/r)*r:0,format:e?.format}},isExported:!0};function Ip(e,t,n=0){return t===0?0:(t=Math.abs(t),e>=0?Math.floor(e/t)*t:n===0?-Math.ceil(Math.abs(e)/t)*t:-Math.floor(Math.abs(e)/t)*t)}let Lp={description:O(`Rounds number down to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round down to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded. The sign of significance will be ignored.`)),W(`mode (number, default=0)`,O(`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},n={value:0}){let r=F(t,this.locale);return{value:Ip(F(e,this.locale),r,F(n,this.locale)),format:e?.format}},isExported:!0},Rp={description:O(`Rounds number down to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round down to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded.`))],compute:function(e,t={value:1}){let n=F(t,this.locale);return{value:Ip(F(e,this.locale),n),format:e?.format}},isExported:!0},zp={description:O(`Whether the provided value is even.`),args:[W(`value (number)`,O(`The value to be verified as even.`))],compute:function(e){let t=Na(e,this.locale);return!(Math.floor(Math.abs(t))&1)},isExported:!0},Bp={description:O(`Rounds number up to nearest multiple of factor.`),args:[W(`number (number)`,O(`The value to round up to the nearest integer multiple of significance.`)),W(`significance (number, default=1)`,O(`The number to whose multiples number will be rounded.`))],compute:function(e,t={value:1}){return{value:vp(F(e,this.locale),F(t,this.locale)),format:e?.format}},isExported:!0},Vp={description:O(`Whether the provided value is even.`),args:[W(`value (number)`,O(`The value to be verified as even.`))],compute:function(e){let t=Na(e,this.locale);return!!(Math.floor(Math.abs(t))&1)},isExported:!0},Hp={description:O(`The logarithm of a number, base e (euler's number).`),args:[W(`value (number)`,O(`The value for which to calculate the logarithm, base e.`))],compute:function(e){let t=F(e,this.locale);return N(()=>t>0,O(`The value (%s) must be strictly positive.`,t.toString())),Math.log(t)},isExported:!0},Up={description:O(`The logarithm of a number, for a given base.`),args:[W(`value (number)`,O(`The value for which to calculate the logarithm.`)),W(`base (number, default=10)`,O(`The base of the logarithm.`))],compute:function(e,t={value:10}){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>n>0,O(`The value (%s) must be strictly positive.`,n.toString())),N(()=>r>0,O(`The base (%s) must be strictly positive.`,r.toString())),N(()=>r!==1,O(`The base must be different from 1.`)),Math.log10(n)/Math.log10(r)},isExported:!0};function Wp(e,t){N(()=>t!==0,O(`The divisor must be different from 0.`),j.DivisionByZero);let n=e%t;return n>0&&t<0||n<0&&t>0?n+t:n}let Gp={description:O(`Modulo (remainder) operator.`),args:[W(`dividend (number)`,O(`The number to be divided to find the remainder.`)),W(`divisor (number)`,O(`The number to divide by.`))],compute:function(e,t){let n=F(t,this.locale);return{value:Wp(F(e,this.locale),n),format:e?.format}},isExported:!0},Kp={description:O(`Returns a n x n unit matrix, where n is the input dimension.`),args:[W(`dimension (number)`,O(`An integer specifying the dimension size of the unit matrix. It must be positive.`))],compute:function(e){let t=Pa(e,this.locale);return jf(O(`The argument dimension must be positive`),t),iu(t)},isExported:!0},qp={description:O(`Rounds a number up to the nearest odd integer.`),args:[W(`value (number)`,O(`The value to round to the next greatest odd number.`))],compute:function(e){let t=F(e,this.locale),n=Math.ceil(Math.abs(t));return n=n&1?n:n+1,{value:t<0?-n:n,format:e?.format}},isExported:!0},Jp={description:O(`The number pi.`),args:[],compute:function(){return Math.PI},isExported:!0},Yp={description:O(`A number raised to a power.`),args:[W(`base (number)`,O(`The number to raise to the exponent power.`)),W(`exponent (number)`,O(`The exponent to raise base to.`))],compute:function(e,t){let n=F(e,this.locale),r=F(t,this.locale);return N(()=>n>=0||Number.isInteger(r),O(`The exponent (%s) must be an integer when the base is negative.`,r.toString())),{value:n**+r,format:e?.format}},isExported:!0},Xp={description:O(`Result of multiplying a series of numbers together.`),args:[W(`factor1 (number, range<number>)`,O(`The first number or range to calculate for the product.`)),W(`factor2 (number, range<number>, repeating)`,O(`More numbers or ranges to calculate for the product.`))],compute:function(...e){let t=0,n=1;for(let r of e)if(A(r))for(let e of r)for(let r of e){let e=r.value;if(typeof e==`number`&&(n*=e,t+=1),P(e))return r}else r!==void 0&&r.value!==null&&(n*=Na(r,this.locale),t+=1);return{value:t===0?0:n,format:Ea(e[0])}},isExported:!0},Zp={description:O(`A random number between 0 inclusive and 1 exclusive.`),args:[],compute:function(){return Math.random()},isExported:!0},Qp={description:O(`Returns a grid of random numbers between 0 inclusive and 1 exclusive.`),args:[W(`rows (number, default=1)`,O(`The number of rows to be returned.`)),W(`columns (number, default=1)`,O(`The number of columns to be returned.`)),W(`min (number, default=0)`,O(`The minimum number you would like returned.`)),W(`max (number, default=1)`,O(`The maximum number you would like returned.`)),W(`whole_number (number, default=FALSE)`,O(`Return a whole number or a decimal value.`))],compute:function(e={value:1},t={value:1},n={value:0},r={value:1},i={value:!1}){let a=Pa(t,this.locale),o=Pa(e,this.locale),s=F(n,this.locale),c=F(r,this.locale),l=L(i);jf(O(`The number of columns (%s) must be positive.`,a.toString()),a),jf(O(`The number of rows (%s) must be positive.`,o.toString()),o),N(()=>s<=c,O(`The maximum (%s) must be greater than or equal to the minimum (%s).`,c.toString(),s.toString())),l&&N(()=>Number.isInteger(s)&&Number.isInteger(c),O(`The maximum (%s) and minimum (%s) must be integers when whole_number is TRUE.`,c.toString(),s.toString()));let u=Array(a);for(let e=0;e<a;e++){u[e]=Array(o);for(let t=0;t<o;t++)l?u[e][t]=Math.floor(Math.random()*(c-s+1)+s):u[e][t]=s+Math.random()*(c-s)}return u},isExported:!0},$p={description:O(`Random integer between two values, inclusive.`),args:[W(`low (number)`,O(`The low end of the random range.`)),W(`high (number)`,O(`The high end of the random range.`))],compute:function(e,t){let n=F(e,this.locale);Number.isInteger(n)||(n=Math.ceil(n));let r=F(t,this.locale);return Number.isInteger(r)||(r=Math.floor(r)),N(()=>n<=r,O(`The high (%s) must be greater than or equal to the low (%s).`,r.toString(),n.toString())),{value:n+Math.ceil((r-n+1)*Math.random())-1,format:e?.format}},isExported:!0},em={description:O(`Rounds a number according to standard rules.`),args:[W(`value (number)`,O(`The value to round to places number of places.`)),W(`places (number, default=0)`,O(`The number of decimal places to which to round.`))],compute:function(e,t={value:0}){let n=F(e,this.locale),r=F(t,this.locale),i=Math.abs(n),a;return r===0?a=Math.round(i):(Number.isInteger(r)||(r=Math.trunc(r)),a=Math.round(i*10**r)/10**r),{value:n>=0?a:-a,format:e?.format}},isExported:!0},tm={description:O(`Rounds down a number.`),args:[W(`value (number)`,O(`The value to round to places number of places, always rounding down.`)),W(`places (number, default=0)`,O(`The number of decimal places to which to round.`))],compute:function(e,t={value:0}){let n=F(e,this.locale),r=F(t,this.locale),i=Math.abs(n),a;return r===0?a=Math.floor(i):(Number.isInteger(r)||(r=Math.trunc(r)),a=Math.floor(i*10**r)/10**r),{value:n>=0?a:-a,format:e?.format}},isExported:!0},nm={description:O(`Rounds up a number.`),args:[W(`value (number)`,O(`The value to round to places number of places, always rounding up.`)),W(`places (number, default=0)`,O(`The number of decimal places to which to round.`))],compute:function(e,t={value:0}){let n=F(e,this.locale),r=F(t,this.locale),i=Math.abs(n),a;return r===0?a=Math.ceil(i):(Number.isInteger(r)||(r=Math.trunc(r)),a=Math.ceil(i*10**r)/10**r),{value:n>=0?a:-a,format:e?.format}},isExported:!0},rm={description:O(`Secant of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the secant of, in radians.`))],compute:function(e){return 1/Math.cos(F(e,this.locale))},isExported:!0},im={description:O(`Hyperbolic secant of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic secant of.`))],compute:function(e){return 1/Math.cosh(F(e,this.locale))},isExported:!0},am={description:O(`Returns a sequence of numbers.`),args:[W(`rows (number)`,O(`The number of rows to return`)),W(`columns (number, optional, default=1)`,O(`The number of columns to return`)),W(`start (number, optional, default=1)`,O(`The first number in the sequence`)),W(`step (number, optional, default=1)`,O(`The amount to increment each value in the sequence`))],compute:function(e,t={value:1},n={value:1},r={value:1}){let i=F(n,this.locale),a=F(r,this.locale),o=Pa(e,this.locale),s=Pa(t,this.locale);return jf(O(`The number of columns (%s) must be positive.`,s),s),jf(O(`The number of rows (%s) must be positive.`,o),o),Ya(s,o,(e,t)=>({value:i+t*s*a+e*a}))},isExported:!0},om={description:O(`Sine of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the sine of, in radians.`))],compute:function(e){return Math.sin(F(e,this.locale))},isExported:!0},sm={description:O(`Hyperbolic sine of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic sine of.`))],compute:function(e){return Math.sinh(F(e,this.locale))},isExported:!0},cm={description:O(`Positive square root of a positive number.`),args:[W(`value (number)`,O(`The number for which to calculate the positive square root.`))],compute:function(e){let t=F(e,this.locale);return N(()=>t>=0,O(`The value (%s) must be positive or null.`,t.toString())),{value:Math.sqrt(t),format:e?.format}},isExported:!0},lm={description:O(`Sum of a series of numbers and/or cells.`),args:[W(`value1 (number, range<number>)`,O(`The first number or range to add together.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional numbers or ranges to add to value1.`))],compute:function(...e){let t=e[0];return{value:nu(e,this.locale),format:Ea(t)}},isExported:!0},um={description:O(`A conditional sum across a range.`),args:[W(`criteria_range (range)`,O(`The range which is tested against criterion.`)),W(`criterion (string)`,O(`The pattern or test to apply to range.`)),W(`sum_range (range, default=criteria_range)`,O(`The range to be summed, if different from range.`))],compute:function(e,t,n){n===void 0&&(n=e);let r=0;return ao([e,t],(e,t)=>{let i=n[e]?.[t]?.value;typeof i==`number`&&(r+=i)},this.locale),r},isExported:!0},dm={description:O(`Sums a range depending on multiple criteria.`),args:[W(`sum_range (range)`,O(`The range to sum.`)),W(`criteria_range1 (range)`,O(`The range to check against criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1.`)),W(`criteria_range2 (any, range, repeating)`,O(`Additional ranges to check.`)),W(`criterion2 (string, repeating)`,O(`Additional criteria to check.`))],compute:function(e,...t){let n=0;return ao(t,(t,r)=>{let i=e[t]?.[r]?.value;typeof i==`number`&&(n+=i)},this.locale),n},isExported:!0},fm={description:O(`Tangent of an angle provided in radians.`),args:[W(`angle (number)`,O(`The angle to find the tangent of, in radians.`))],compute:function(e){return Math.tan(F(e,this.locale))},isExported:!0},pm={description:O(`Hyperbolic tangent of any real number.`),args:[W(`value (number)`,O(`Any real value to calculate the hyperbolic tangent of.`))],compute:function(e){return Math.tanh(F(e,this.locale))},isExported:!0};function mm(e,t){return t===0?Math.trunc(e):(Number.isInteger(t)||(t=Math.trunc(t)),Math.trunc(e*10**t)/10**t)}let hm={description:O(`Truncates a number.`),args:[W(`value (number)`,O(`The value to be truncated.`)),W(`places (number, default=0)`,O(`The number of significant digits to the right of the decimal point to retain.`))],compute:function(e,t={value:0}){return{value:mm(F(e,this.locale),F(t,this.locale)),format:e?.format}},isExported:!0},gm={description:O(`Rounds a number down to the nearest integer that is less than or equal to it.`),args:[W(`value (number)`,O(`The number to round down to the nearest integer.`))],compute:function(e){return Math.floor(F(e,this.locale))},isExported:!0};var _m=l({AVEDEV:()=>Sm,AVERAGE:()=>Cm,AVERAGEA:()=>Dm,AVERAGEIF:()=>Om,AVERAGEIFS:()=>km,AVERAGE_WEIGHTED:()=>Em,CORREL:()=>Zm,COUNT:()=>Am,COUNTA:()=>jm,COVAR:()=>Mm,COVARIANCE_P:()=>Nm,COVARIANCE_S:()=>Pm,FORECAST:()=>Fm,GROWTH:()=>Im,INTERCEPT:()=>Lm,LARGE:()=>Rm,LINEST:()=>zm,LOGEST:()=>Bm,MATTHEWS:()=>Vm,MAX:()=>Hm,MAXA:()=>Um,MAXIFS:()=>Wm,MEDIAN:()=>Gm,MIN:()=>Km,MINA:()=>qm,MINIFS:()=>Jm,PEARSON:()=>Xm,PERCENTILE:()=>Qm,PERCENTILE_EXC:()=>$m,PERCENTILE_INC:()=>eh,POLYFIT_COEFFS:()=>th,POLYFIT_FORECAST:()=>nh,QUARTILE:()=>rh,QUARTILE_EXC:()=>ih,QUARTILE_INC:()=>ah,RANK:()=>oh,RSQ:()=>sh,SLOPE:()=>ch,SMALL:()=>lh,SPEARMAN:()=>uh,STDEV:()=>dh,STDEVA:()=>mh,STDEVP:()=>hh,STDEVPA:()=>gh,STDEV_P:()=>fh,STDEV_S:()=>ph,STEYX:()=>_h,TREND:()=>vh,VAR:()=>yh,VARA:()=>Sh,VARP:()=>Ch,VARPA:()=>wh,VAR_P:()=>bh,VAR_S:()=>xh});function vm(e,t){let n=[],r=[],i=0,a=0;Ua([e],e=>{n.push(e),i+=1}),Ua([t],e=>{r.push(e),a+=1}),N(()=>i===a,O(`[[FUNCTION_NAME]] has mismatched argument count %s vs %s.`,i,a));let o=[],s=[];for(let e=0;e<i;e++){let t=n[e]?.value,i=r[e]?.value;typeof t==`number`&&typeof i==`number`&&(s.push(t),o.push(i))}return{flatDataX:o,flatDataY:s}}function ym(e,t,n){let{flatDataX:r,flatDataY:i}=vm(e,t),a=i.length;N(()=>a!==0&&(!n||a!==1),O(`Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero);let o=0,s=0;for(let e=0;e<a;e++)o+=i[e],s+=r[e];let c=o/a,l=s/a,u=0;for(let e=0;e<a;e++)u+=(i[e]-c)*(r[e]-l);return u/(a-+!!n)}function bm(e,t,n,r){let i=0,a=n?Ja:qa,o=a(e,(e,t)=>(i+=1,e+t),0,r);N(()=>i!==0&&(!t||i!==1),O(`Evaluation of function [[FUNCTION_NAME]] caused a divide by zero error.`),j.DivisionByZero);let s=o/i;return a(e,(e,t)=>e+(t-s)**2,0,r)/(i-+!!t)}function xm(e,t,n,r){let i=F(t,r);N(()=>n?0<=i&&i<=1:0<i&&i<1,O(`Function [[FUNCTION_NAME]] parameter 2 value is out of range.`));let a=[],o,s=0;return Ua(e,e=>{let t=e?.value;typeof t==`number`&&(o=oo(a,e,`nextSmaller`,`asc`,a.length,(e,t)=>e[t]),a.splice(o+1,0,t),s++)}),N(()=>s!==0,O(`[[FUNCTION_NAME]] has no valid input data.`)),n||N(()=>1/(s+1)<=i&&i<=s/(s+1),O(`Function [[FUNCTION_NAME]] parameter 2 value is out of range.`)),Bi(a,i,n)}let Sm={description:O(`Average magnitude of deviations from mean.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){let t=0,n=qa(e,(e,n)=>(t+=1,e+n),0,this.locale);La(t);let r=n/t;return qa(e,(e,t)=>e+Math.abs(r-t),0,this.locale)/t},isExported:!0},Cm={description:O(`Numerical average value in a dataset, ignoring text.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the average value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the average value.`))],compute:function(...e){return{value:fu(e,this.locale),format:Ea(e[0])}},isExported:!0},wm=O(`[[FUNCTION_NAME]] has mismatched range sizes.`),Tm=O(`[[FUNCTION_NAME]] expects the weight to be positive or equal to 0.`),Em={description:O(`Weighted average.`),args:[W(`values (number, range<number>)`,O(`Values to average.`)),W(`weights (number, range<number>)`,O(`Weights for each corresponding value.`)),W(`additional_values (number, range<number>, repeating)`,O(`Additional values to average.`)),W(`additional_weights (number, range<number>, repeating)`,O(`Additional weights.`))],compute:function(...e){let t=0,n=0;for(let r=0;r<e.length-1;r+=2){let i=e[r],a=e[r+1];if(Af(wm,i,a),A(i))for(let e=0;e<i.length;e++)for(let r=0;r<i[0].length;r++){let o=i[e][r].value,s=A(a)?a?.[e][r].value:F(a,this.locale),c=typeof o==`number`,l=typeof s==`number`;if(c&&l){N(()=>s>=0,Tm),t+=o*s,n+=s;continue}N(()=>c===l,O(`[[FUNCTION_NAME]] expects number values.`))}else{let e=F(i,this.locale),r=A(a)?a?.[0][0].value:F(a,this.locale);typeof r==`number`&&(N(()=>r>=0,Tm),t+=e*r,n+=r)}}return La(n),{value:t/n,format:Ea(e[0])}}},Dm={description:O(`Numerical average value in a dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the average value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the average value.`))],compute:function(...e){let t=0,n=Ja(e,(e,n)=>(t+=1,e+n),0,this.locale);return La(t),{value:n/t,format:Ea(e[0])}},isExported:!0},Om={description:O(`Average of values depending on criteria.`),args:[W(`criteria_range (number, range<number>)`,O(`The range to check against criterion.`)),W(`criterion (string)`,O(`The pattern or test to apply to criteria_range.`)),W(`average_range (number, range<number>, default=criteria_range)`,O(`The range to average. If not included, criteria_range is used for the average instead.`))],compute:function(e,t,n){let r=z(n===void 0?e:n),i=0,a=0;return ao([e,t],(e,t)=>{let n=r[e]?.[t]?.value;typeof n==`number`&&(i+=1,a+=n)},this.locale),La(i),a/i},isExported:!0},km={description:O(`Average of values depending on multiple criteria.`),args:[W(`average_range (range)`,O(`The range to average.`)),W(`criteria_range1 (range)`,O(`The range to check against criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1.`)),W(`criteria_range2 (any, range, repeating)`,O(`Additional criteria_range and criterion to check.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=z(e),r=0,i=0;return ao(t,(e,t)=>{let a=n[e]?.[t]?.value;typeof a==`number`&&(r+=1,i+=a)},this.locale),La(r),i/r},isExported:!0},Am={description:O(`The number of numeric values in dataset.`),args:[W(`value1 (number, any, range<number>)`,O(`The first value or range to consider when counting.`)),W(`value2 (number, any, range<number>, repeating)`,O(`Additional values or ranges to consider when counting.`))],compute:function(...e){return pu(e,this.locale)},isExported:!0},jm={description:O(`The number of values in a dataset.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider when counting.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider when counting.`))],compute:function(...e){return mu(e)},isExported:!0},Mm={description:O(`The covariance of a dataset.`),args:[W(`data_y (any, range)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (any, range)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return ym(e,t,!1)},isExported:!0},Nm={description:O(`The covariance of a dataset.`),args:[W(`data_y (any, range)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (any, range)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return ym(e,t,!1)},isExported:!0},Pm={description:O(`The sample covariance of a dataset.`),args:[W(`data_y (any, range)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (any, range)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return ym(e,t,!0)},isExported:!0},Fm={description:O(`Calculates the expected y-value for a specified x based on a linear regression of a dataset.`),args:[W(`x (number, range<number>)`,O(`The value(s) on the x-axis to forecast.`)),W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t,n){let{flatDataX:r,flatDataY:i}=vm(t,n);return Du(r,i),wu([i],[r],Xa(z(e),e=>F(e,this.locale)),!0)},isExported:!0},Im={description:O(`Fits points to exponential growth trend.`),args:[W(`known_data_y (range<number>)`,O(`The array or range containing dependent (y) values that are already known, used to curve fit an ideal exponential growth curve.`)),W(`known_data_x (range<number>, default={1;2;3;...})`,O(`The values of the independent variable(s) corresponding with known_data_y.`)),W(`new_data_x (any, range, default=known_data_x)`,O(`The data points to return the y values for on the ideal curve fit.`)),W(`b (boolean, default=TRUE)`,O(`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=[[]],n=[[]],r={value:!0}){return Eu(e,`known_data_y`),Su(wu(Cu(Ma(e,`known_data_y`)),Ma(t,`known_data_x`),Ma(n,`new_data_y`),L(r)))}},Lm={description:O(`Compute the intercept of the linear regression.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);Du(n,r);let[[],[i]]=vu([n],[r]);return i},isExported:!0},Rm={description:O(`Nth largest element from a data set.`),args:[W(`data (any, range)`,O(`Array or range containing the dataset to consider.`)),W(`n (number)`,O(`The rank from largest to smallest of the element to return.`))],compute:function(e,t){let n=Math.trunc(F(t?.value,this.locale)),r=[],i,a=0;Ua([e],e=>{typeof e?.value==`number`&&(i=oo(r,e,`nextSmaller`,`asc`,r.length,(e,t)=>e[t].value),r.splice(i+1,0,e),a++,a>n&&(r.shift(),a--))});let o=r.shift();return N(()=>o!==void 0,O(`[[FUNCTION_NAME]] has no valid input data.`)),N(()=>a>=n,O(`Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.`,n)),o},isExported:!0},zm={description:O(`Given partial data about a linear trend, calculates various parameters about the ideal linear trend using the least-squares method.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>, default={1;2;3;...})`,O(`The range representing the array or matrix of independent data.`)),W(`calculate_b (boolean, default=TRUE)`,O(`A flag specifying wheter to compute the slope or not`)),W(`verbose (boolean, default=FALSE)`,O(`A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept`))],compute:function(e,t=[[]],n={value:!0},r={value:!1}){return Eu(e,`data_y`),vu(Ma(t,`data_x`),Ma(e,`data_y`),L(n),L(r))},isExported:!0},Bm={description:O(`Given partial data about an exponential growth curve, calculates various parameters about the best fit ideal exponential growth curve.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>, optional, default={1;2;3;...})`,O(`The range representing the array or matrix of independent data.`)),W(`calculate_b (boolean, default=TRUE)`,O(`A flag specifying wheter to compute the slope or not`)),W(`verbose (boolean, default=FALSE)`,O(`A flag specifying whether to return additional regression statistics or only the linear coefficients and the y-intercept`))],compute:function(e,t=[[]],n={value:!0},r={value:!1}){Eu(e,`data_y`);let i=vu(Ma(t,`data_x`),Cu(Ma(e,`data_y`)),L(n),L(r));for(let e=0;e<i.length;e++)i[e][0]=Math.exp(i[e][0]);return i},isExported:!0},Vm={description:O(`Compute the Matthews correlation coefficient of a dataset.`),args:[W(`data_x (range)`,O(`The range representing the array or matrix of observed data.`)),W(`data_y (range)`,O(`The range representing the array or matrix of predicted data.`))],compute:function(e,t){let n=e.flat(),r=t.flat();du(n,r),Du(n,r);let i=n.length,a=0,o=0,s=0,c=0;for(let e=0;e<i;++e){let t=L(n[e]);t===L(r[e])?t?o++:a++:t?c++:s++}return(o*a-s*c)/Math.sqrt((o+s)*(o+c)*(a+s)*(a+c))},isExported:!1},Hm={description:O(`Maximum value in a numeric dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the maximum value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the maximum value.`))],compute:function(...e){return hu(e,this.locale)},isExported:!0},Um={description:O(`Maximum numeric value in a dataset.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider when calculating the maximum value.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider when calculating the maximum value.`))],compute:function(...e){let t=Ja(e,(e,t)=>Math.max(t,e),-1/0,this.locale);return{value:t===-1/0?0:t,format:Ea(e[0])}},isExported:!0},Wm={description:O(`Returns the maximum value in a range of cells, filtered by a set of criteria.`),args:[W(`range (range)`,O(`The range of cells from which the maximum will be determined.`)),W(`criteria_range1 (range)`,O(`The range of cells over which to evaluate criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=-1/0;return ao(t,(t,r)=>{let i=e[t]?.[r]?.value;typeof i==`number`&&(n=n<i?i:n)},this.locale),n===-1/0?0:n},isExported:!0},Gm={description:O(`Median value in a numeric dataset.`),args:[W(`value1 (any, range)`,O(`The first value or range to consider when calculating the median value.`)),W(`value2 (any, range, repeating)`,O(`Additional values or ranges to consider when calculating the median value.`))],compute:function(...e){let t=[];return Wa(e,e=>{t.push(e)},this.locale),{value:xm(t,{value:.5},!0,this.locale),format:Ea(t[0])}},isExported:!0},Km={description:O(`Minimum value in a numeric dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the minimum value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the minimum value.`))],compute:function(...e){return gu(e,this.locale)},isExported:!0},qm={description:O(`Minimum numeric value in a dataset.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range to consider when calculating the minimum value.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to consider when calculating the minimum value.`))],compute:function(...e){let t=Ja(e,(e,t)=>Math.min(t,e),1/0,this.locale);return{value:t===1/0?0:t,format:Ea(e[0])}},isExported:!0},Jm={description:O(`Returns the minimum value in a range of cells, filtered by a set of criteria.`),args:[W(`range (range)`,O(`The range of cells from which the minimum will be determined.`)),W(`criteria_range1 (range)`,O(`The range of cells over which to evaluate criterion1.`)),W(`criterion1 (string)`,O(`The pattern or test to apply to criteria_range1, such that each cell that evaluates to TRUE will be included in the filtered set.`)),W(`criteria_range2 (any, range, repeating)`,O(`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.`)),W(`criterion2 (string, repeating)`,O(`The pattern or test to apply to criteria_range2.`))],compute:function(e,...t){let n=1/0;return ao(t,(t,r)=>{let i=e[t]?.[r]?.value;typeof i==`number`&&(n=n>i?i:n)},this.locale),n===1/0?0:n},isExported:!0};function Ym(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);Du(n,r);let i=n.length,a=0,o=0,s=0,c=0,l=0;for(let e=0;e<i;e++){let t=n[e],i=r[e];a+=t,o+=i,s+=t*i,c+=t*t,l+=i*i}return(i*s-a*o)/Math.sqrt((i*c-a*a)*(i*l-o*o))}let Xm={description:O(`Compute the Pearson product-moment correlation coefficient of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return Ym(e,t)},isExported:!0},Zm=Xm,Qm={description:O(`Value at a given percentile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`percentile (number)`,O(`The percentile whose value within data will be calculated and returned.`))],compute:function(e,t){return eh.compute.bind(this)(e,t)},isExported:!0},$m={description:O(`Value at a given percentile of a dataset exclusive of 0 and 1.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`percentile (number)`,O(`The percentile, exclusive of 0 and 1, whose value within 'data' will be calculated and returned.`))],compute:function(e,t){return{value:xm([e],t,!1,this.locale),format:Ea(e)}},isExported:!0},eh={description:O(`Value at a given percentile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`percentile (number)`,O(`The percentile whose value within data will be calculated and returned.`))],compute:function(e,t){return{value:xm([e],t,!0,this.locale),format:Ea(e)}},isExported:!0},th={description:O(`Compute the coefficients of polynomial regression of the dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`)),W(`order (number)`,O(`The order of the polynomial to fit the data, between 1 and 6.`)),W(`intercept (boolean, default=TRUE)`,O(`A flag specifying whether to compute the intercept or not.`))],compute:function(e,t,n,r={value:!0}){let{flatDataX:i,flatDataY:a}=vm(e,t);return Du(i,a),yu(a,i,F(n,this.locale),L(r))},isExported:!1},nh={description:O(`Predict value by computing a polynomial regression of the dataset.`),args:[W(`x (number, range<number>)`,O(`The value(s) on the x-axis to forecast.`)),W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`)),W(`order (number)`,O(`The order of the polynomial to fit the data, between 1 and 6.`)),W(`intercept (boolean, default=TRUE)`,O(`A flag specifying whether to compute the intercept or not.`))],compute:function(e,t,n,r,i={value:!0}){let a=F(r,this.locale),{flatDataX:o,flatDataY:s}=vm(t,n);Du(o,s);let c=yu(s,o,a,L(i)).flat();return Xa(z(e),e=>xu(c,F(e,this.locale),a))},isExported:!1},rh={description:O(`Value nearest to a specific quartile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`quartile_number (number)`,O(`Which quartile value to return.`))],compute:function(e,t){return ah.compute.bind(this)(e,t)},isExported:!0},ih={description:O(`Value nearest to a specific quartile of a dataset exclusive of 0 and 4.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`quartile_number (number)`,O(`Which quartile value, exclusive of 0 and 4, to return.`))],compute:function(e,t){let n={value:.25*Math.trunc(F(t,this.locale))};return{value:xm([e],n,!1,this.locale),format:Ea(e)}},isExported:!0},ah={description:O(`Value nearest to a specific quartile of a dataset.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`quartile_number (number)`,O(`Which quartile value to return.`))],compute:function(e,t){let n={value:.25*Math.trunc(F(t,this.locale))};return{value:xm([e],n,!0,this.locale),format:Ea(e)}},isExported:!0},oh={description:O(`Returns the rank of a specified value in a dataset.`),args:[W(`value (number)`,O(`The value whose rank will be determined.`)),W(`data (range)`,O(`The range containing the dataset to consider.`)),W(`is_ascending (boolean, default=FALSE)`,O(`Whether to consider the values in data in descending or ascending order.`))],compute:function(e,t,n={value:!1}){let r=L(n),i=F(e,this.locale),a=1,o=!1;for(let e of t)for(let t of e){if(typeof t.value!=`number`)continue;let e=F(t,this.locale);e===i?o=!0:e>i!==r&&a++}return o?a:new Sa(O(`Value not found in the given data.`))},isExported:!0},sh={description:O(`Compute the square of r, the Pearson product-moment correlation coefficient of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){return Ym(t,e)**2},isExported:!0},ch={description:O(`Compute the slope of the linear regression.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);Du(n,r);let[[i]]=vu([n],[r]);return i},isExported:!0},lh={description:O(`Nth smallest element in a data set.`),args:[W(`data (any, range)`,O(`The array or range containing the dataset to consider.`)),W(`n (number)`,O(`The rank from smallest to largest of the element to return.`))],compute:function(e,t){let n=Math.trunc(F(t?.value,this.locale)),r=[],i,a=0;Ua([e],e=>{typeof e?.value==`number`&&(i=oo(r,e,`nextSmaller`,`asc`,r.length,(e,t)=>e[t].value),r.splice(i+1,0,e),a++,a>n&&(r.pop(),a--))});let o=r.pop();return N(()=>o!==void 0,O(`[[FUNCTION_NAME]] has no valid input data.`)),N(()=>a>=n,O(`Function [[FUNCTION_NAME]] parameter 2 value (%s) is out of range.`,n)),o},isExported:!0},uh={description:O(`Compute the Spearman rank correlation coefficient of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(t,e);Du(n,r);let i=n.length,a=n.map((e,t)=>[e,r[t]]);a.sort((e,t)=>e[0]-t[0]);for(let e=0;e<i;++e)a[e][0]=e;a.sort((e,t)=>e[1]-t[1]);let o=0;for(let e=0;e<i;++e)o+=(a[e][0]-e)**2;return 1-6*o/(i**3-i)},isExported:!1},dh={description:O(`Standard deviation.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return Math.sqrt(yh.compute.bind(this)(...e))},isExported:!0},fh={description:O(`Standard deviation of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return Math.sqrt(bh.compute.bind(this)(...e))},isExported:!0},ph={description:O(`Standard deviation.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return Math.sqrt(xh.compute.bind(this)(...e))},isExported:!0},mh={description:O(`Standard deviation of sample (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return Math.sqrt(Sh.compute.bind(this)(...e))},isExported:!0},hh={description:O(`Standard deviation of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return Math.sqrt(Ch.compute.bind(this)(...e))},isExported:!0},gh={description:O(`Standard deviation of entire population (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return Math.sqrt(wh.compute.bind(this)(...e))},isExported:!0},_h={description:O(`Calculates the standard error of the predicted y-value for each x in the regression of a dataset.`),args:[W(`data_y (range<number>)`,O(`The range representing the array or matrix of dependent data.`)),W(`data_x (range<number>)`,O(`The range representing the array or matrix of independent data.`))],compute:function(e,t){let{flatDataX:n,flatDataY:r}=vm(e,t);return Du(n,r),vu([n],[r],!0,!0)[1][2]},isExported:!0},vh={description:O(`Fits points to linear trend derived via least-squares.`),args:[W(`known_data_y (number, range<number>)`,O(`The array or range containing dependent (y) values that are already known, used to curve fit an ideal linear trend.`)),W(`known_data_x (number, range<number>, optional, default={1;2;3;...})`,O(`The values of the independent variable(s) corresponding with known_data_y.`)),W(`new_data_x (number, range<number>, optional, default=known_data_x)`,O(`The data points to return the y values for on the ideal curve fit.`)),W(`b (boolean, optional, default=TRUE)`,O(`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=[[]],n=[[]],r={value:!0}){return Eu(e,`known_data_y`),wu(Ma(e,`known_data_y`),Ma(t,`known_data_x`),Ma(n,`new_data_y`),L(r))}},yh={description:O(`Variance.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return bm(e,!0,!1,this.locale)},isExported:!0},bh={description:O(`Variance of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return bm(e,!1,!1,this.locale)},isExported:!0},xh={description:O(`Variance.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return bm(e,!0,!1,this.locale)},isExported:!0},Sh={description:O(`Variance of sample (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the sample.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the sample.`))],compute:function(...e){return bm(e,!0,!0,this.locale)},isExported:!0},Ch={description:O(`Variance of entire population.`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return bm(e,!1,!1,this.locale)},isExported:!0},wh={description:O(`Variance of entire population (text as 0).`),args:[W(`value1 (number, range<number>)`,O(`The first value or range of the population.`)),W(`value2 (number, range<number>, repeating)`,O(`Additional values or ranges to include in the population.`))],compute:function(...e){return bm(e,!1,!0,this.locale)},isExported:!0};var Th=l({DAVERAGE:()=>Oh,DCOUNT:()=>kh,DCOUNTA:()=>Ah,DGET:()=>jh,DMAX:()=>Mh,DMIN:()=>Nh,DPRODUCT:()=>Ph,DSTDEV:()=>Fh,DSTDEVP:()=>Ih,DSUM:()=>Lh,DVAR:()=>Rh,DVARP:()=>zh});function Eh(e,t,n,r){let i=new Map,a=e.length;for(let t=a-1;t>=0;t--)i.set(I(e[t][0]).toUpperCase(),t);let o=t?.value;if(typeof o!=`number`&&typeof o!=`string`)throw new M(O(`The field must be a number or a string`));let s;if(typeof o==`number`){if(s=Math.trunc(o)-1,s<0||a-1<s)throw new M(O(`The field (%(fieldValue)s) must be one of %(dimRowDB)s or must be a number between 1 and %s inclusive.`,{fieldValue:o.toString(),dimRowDB:a.toString()}))}else{let e=I(t).toUpperCase();if(s=i.get(e)??-1,s===-1)throw new M(O(`The field (%s) must be one of %s.`,I(t),[...i.keys()].toString()))}let c=n[0].length;if(c<2)throw new M(O(`The criteria range contains %s row, it must be at least 2 rows.`,c.toString()));let l=new Set,u=e[0].length;for(let t=1;t<c;t++){let a=[],o=!0;for(let r=0;r<n.length;r++){let s=I(n[r][0]).toUpperCase(),c=i.get(s),l=n[r][t];if(l.value!==null)if(c!==void 0)a.push([e[c].slice(1,u)]),a.push(l);else{o=!1;break}}if(o)if(a.length>0)ao(a,(e,t)=>{l.add(t)},r,!0);else{l=new Set(Array(u-1).keys());break}}let d=e[s];return[...l].map(e=>d[e+1])}let Dh=[W(`database (range)`,O(`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.`)),W(`field (number, string)`,O(`Indicates which column in database contains the values to be extracted and operated on.`)),W(`criteria (range)`,O(`An array or range containing zero or more criteria to filter the database values by before operating.`))],Oh={description:O(`Average of a set of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Cm.compute.bind(this)([r])},isExported:!0},kh={description:O(`Counts values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Am.compute.bind(this)([r])},isExported:!0},Ah={description:O(`Counts values and text from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return jm.compute.bind(this)([r])},isExported:!0},jh={description:O(`Single value from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return N(()=>r.length===1,O(`More than one match found in DGET evaluation.`)),r[0]},isExported:!0},Mh={description:O(`Maximum of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Hm.compute.bind(this)([r])},isExported:!0},Nh={description:O(`Minimum of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Km.compute.bind(this)([r])},isExported:!0},Ph={description:O(`Product of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Xp.compute.bind(this)([r])},isExported:!0},Fh={description:O(`Standard deviation of population sample from table.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return dh.compute.bind(this)([r])},isExported:!0},Ih={description:O(`Standard deviation of entire population from table.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return hh.compute.bind(this)([r])},isExported:!0},Lh={description:O(`Sum of values from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return lm.compute.bind(this)([r])},isExported:!0},Rh={description:O(`Variance of population sample from table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return yh.compute.bind(this)([r])},isExported:!0},zh={description:O(`Variance of a population from a table-like range.`),args:Dh,compute:function(e,t,n){let r=Eh(e,t,n,this.locale);return Ch.compute.bind(this)([r])},isExported:!0};var Bh=l({DATE:()=>Hh,DATEDIF:()=>Uh,DATEVALUE:()=>Wh,DAY:()=>Gh,DAYS:()=>Kh,DAYS360:()=>qh,EDATE:()=>Jh,EOMONTH:()=>Yh,HOUR:()=>Xh,ISOWEEKNUM:()=>Zh,MINUTE:()=>Qh,MONTH:()=>$h,MONTH_END:()=>hg,MONTH_START:()=>mg,NETWORKDAYS:()=>eg,NETWORKDAYS_INTL:()=>ng,NOW:()=>rg,QUARTER:()=>gg,QUARTER_END:()=>vg,QUARTER_START:()=>_g,SECOND:()=>ig,TIME:()=>ag,TIMEVALUE:()=>og,TODAY:()=>sg,WEEKDAY:()=>cg,WEEKNUM:()=>lg,WORKDAY:()=>ug,WORKDAY_INTL:()=>dg,YEAR:()=>fg,YEARFRAC:()=>pg,YEAR_END:()=>bg,YEAR_START:()=>yg}),Vh=function(e){return 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`,e}(Vh||{});let Hh={description:O(`Converts year/month/day into a date.`),args:[W(`year (number)`,O(`The year component of the date.`)),W(`month (number)`,O(`The month component of the date.`)),W(`day (number)`,O(`The day component of the date.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=Math.trunc(F(n,this.locale));N(()=>0<=r&&r<=9999,O(`The year (%s) must be between 0 and 9999 inclusive.`,r.toString())),r<1900&&(r+=1900);let o=vi(new D(r,i-1,a));return N(()=>o>=0,O(`The function [[FUNCTION_NAME]] result must be greater than or equal 01/01/1900.`)),{value:o,format:this.locale.dateFormat}},isExported:!0},Uh={description:O(`Calculates the number of days, months, or years between two dates.`),args:[W(`start_date (date)`,O(`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.`)),W(`end_date (date)`,O(`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.`)),W(`unit (string)`,O(`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,n){let r=I(n).toUpperCase();N(()=>Object.values(Vh).includes(r),Aa(Object.values(Vh),I(n)));let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=_i(i),s=_i(a);switch(N(()=>a>=i,O(`start_date (%s) should be on or before end_date (%s).`,o.toLocaleDateString(),s.toLocaleDateString())),r){case`Y`:return Di(o,s);case`M`:return Ti(o,s);case`D`:return Ei(o,s);case`YM`:return Ti(o,s)-Di(o,s)*12;case`MD`:let e=s.getDate()-o.getDate();return e<0&&(e=bi(new D(s.getFullYear(),s.getMonth()-1,1))-Math.abs(e)),e;case`YD`:{if(Oi(i,a))return Ei(o,s);let e=new D(o.getFullYear(),s.getMonth(),s.getDate()),t=Ei(o,e);return t<0&&(e.setFullYear(o.getFullYear()+1),t=Ei(o,e)),t}}},isExported:!0},Wh={description:O(`Converts a date string to a date value.`),args:[W(`date_string (string)`,O(`The string representing the date.`))],compute:function(e){let t=I(e),n=si(t,this.locale);return N(()=>n!==null,O(`The date_string (%s) cannot be parsed to date/time.`,t.toString())),Math.trunc(n.value)},isExported:!0},Gh={description:O(`Day of the month that a specific date falls on.`),args:[W(`date (string)`,O(`The date from which to extract the day.`))],compute:function(e){return R(e,this.locale).getDate()},isExported:!0},Kh={description:O(`Number of days between two dates.`),args:[W(`end_date (date)`,O(`The end of the date range.`)),W(`start_date (date)`,O(`The start of the date range.`))],compute:function(e,t){let n=R(e,this.locale),r=R(t,this.locale),i=n.getTime()-r.getTime();return Math.round(i/qr)},isExported:!0},qh={description:O(`Number of days between two dates on a 360-day year (months of 30 days).`),args:[W(`start_date (date)`,O(`The start date to consider in the calculation.`)),W(`end_date (date)`,O(`The end date to consider in the calculation.`)),W(`method (number, default=0)`,O(`An indicator of what day count method to use. (0) US NASD method (1) European method`))],compute:function(e,t,n={value:0}){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=wi(r,i,L(n)?4:0);return Math.sign(i-r)*Math.round(a*360)},isExported:!0},Jh={description:O(`Date a number of months before/after another date.`),args:[W(`start_date (date)`,O(`The date from which to calculate the result.`)),W(`months (number)`,O(`The number of months before (negative) or after (positive) 'start_date' to calculate.`))],compute:function(e,t){return{value:vi(Si(R(e,this.locale),Math.trunc(F(t,this.locale)),!1)),format:this.locale.dateFormat}},isExported:!0},Yh={description:O(`Last day of a month before or after a date.`),args:[W(`start_date (date)`,O(`The date from which to calculate the result.`)),W(`months (number)`,O(`The number of months before (negative) or after (positive) 'start_date' to consider.`))],compute:function(e,t){let n=R(e,this.locale),r=Math.trunc(F(t,this.locale));return{value:vi(new D(n.getFullYear(),n.getMonth()+r+1,0)),format:this.locale.dateFormat}},isExported:!0},Xh={description:O(`Hour component of a specific time.`),args:[W(`time (date)`,O(`The time from which to calculate the hour component.`))],compute:function(e){return R(e,this.locale).getHours()},isExported:!0},Zh={description:O(`ISO week number of the year.`),args:[W(`date (date)`,O(`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){let t=R(e,this.locale),n=t.getFullYear(),r=1;for(;new D(n,0,r).getDay()!==4;)r+=1;let i=new D(n,0,r-3),a=31;for(;new D(n,11,a).getDay()!==4;)--a;let o=new D(n,11,a+3),s;s=i.getTime()<=t.getTime()?t.getTime()<=o.getTime()?0:1:-1;let c;switch(s){case 0:c=i;break;case 1:c=new D(n,11,a+3+1);break;case-1:let e=1;for(;new D(n-1,0,e).getDay()!==4;)e+=1;c=new D(n-1,0,e-3);break}let l=(t.getTime()-c.getTime())/qr;return Math.floor(l/7)+1},isExported:!0},Qh={description:O(`Minute component of a specific time.`),args:[W(`time (date)`,O(`The time from which to calculate the minute component.`))],compute:function(e){return R(e,this.locale).getMinutes()},isExported:!0},$h={description:O(`Month of the year a specific date falls in`),args:[W(`date (date)`,O(`The date from which to extract the month.`))],compute:function(e){return R(e,this.locale).getMonth()+1},isExported:!0},eg={description:O(`Net working days between two provided days.`),args:[W(`start_date (date)`,O(`The start date of the period from which to calculate the number of net working days.`)),W(`end_date (date)`,O(`The end date of the period from which to calculate the number of net working days.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the date serial numbers to consider holidays.`))],compute:function(e,t,n){return ng.compute.bind(this)(e,t,{value:1},n)},isExported:!0};function tg(e){let t=e?.value;if(typeof t==`string`){N(()=>{if(t.length!==7)return!1;for(let e of t)if(e!==`0`&&e!==`1`)return!1;return!0},O(`When weekend is a string (%s) it must be composed of "0" or "1".`,t));let e=[];for(let n=0;n<7;n++)t[n]===`1`&&e.push((n+1)%7);return e}if(typeof t==`number`)return N(()=>1<=t&&t<=7||11<=t&&t<=17,O(`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 M(O(`The weekend must be a number or a string.`))}let ng={description:O(`Net working days between two dates (specifying weekends).`),args:[W(`start_date (date)`,O(`The start date of the period from which to calculate the number of net working days.`)),W(`end_date (date)`,O(`The end date of the period from which to calculate the number of net working days.`)),W(`weekend (any, default=1)`,O(`A number or string representing which days of the week are considered weekends.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the dates to consider as holidays.`))],compute:function(e,t,n={value:1},r){let i=R(e,this.locale),a=R(t,this.locale),o=tg(n),s=new Set;r!==void 0&&Ua([r],e=>{let t=R(e,this.locale);s.add(t.getTime())});let c=i.getTime()>a.getTime(),l=D.fromTimestamp((c?i:a).getTime()),u=D.fromTimestamp((c?a:i).getTime()),d=l.getTime(),f=u.getTime(),p=0;for(;f<=d;)!o.includes(u.getDay())&&!s.has(f)&&(p+=1),u.setDate(u.getDate()+1),f=u.getTime();return c?-p:p},isExported:!0},rg={description:O(`Current date and time as a date value.`),args:[],compute:function(){let e=D.now(),t=e.getTime()-Kr.getTime(),n=e.getHours()/24+e.getMinutes()/1440+e.getSeconds()/86400;return{value:Math.floor(t/qr)+n,format:$l(this.locale)}},isExported:!0},ig={description:O(`Minute component of a specific time.`),args:[W(`time (date)`,O(`The time from which to calculate the second component.`))],compute:function(e){return R(e,this.locale).getSeconds()},isExported:!0},ag={description:O(`Converts hour/minute/second into a time.`),args:[W(`hour (number)`,O(`The hour component of the time.`)),W(`minute (number)`,O(`The minute component of the time.`)),W(`second (number)`,O(`The second component of the time.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=Math.trunc(F(n,this.locale));return i+=Math.floor(a/60),a=a%60+(a<0?60:0),r+=Math.floor(i/60),i=i%60+(i<0?60:0),r%=24,N(()=>r>=0,O(`The function [[FUNCTION_NAME]] result cannot be negative`)),{value:r/24+i/1440+a/(1440*60),format:this.locale.timeFormat}},isExported:!0},og={description:O(`Converts a time string into its serial number representation.`),args:[W(`time_string (string)`,O(`The string that holds the time representation.`))],compute:function(e){let t=I(e),n=si(t,this.locale);N(()=>n!==null,O(`The time_string (%s) cannot be parsed to date/time.`,t));let r=n.value-Math.trunc(n.value);return r<0?1+r:r},isExported:!0},sg={description:O(`Current date as a date value.`),args:[],compute:function(){let e=D.now();return{value:vi(new D(e.getFullYear(),e.getMonth(),e.getDate())),format:this.locale.dateFormat}},isExported:!0},cg={description:O(`Day of the week of the date provided (as number).`),args:[W(`date (date)`,O(`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.`)),W(`type (number, default=1)`,O(`A number indicating which numbering system to use to represent weekdays. By default, counts starting with Sunday = 1.`))],compute:function(e,t={value:1}){let n=R(e,this.locale),r=Math.round(F(t,this.locale)),i=n.getDay();return N(()=>[1,2,3].includes(r),O(`The type (%s) must be 1, 2 or 3.`,r.toString())),r===1?i+1:r===2?i===0?7:i:i===0?6:i-1},isExported:!0},lg={description:O(`Week number of the year.`),args:[W(`date (date)`,O(`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.`)),W(`type (number, default=1)`,O(`A number representing the day that a week starts on. Sunday = 1.`))],compute:function(e,t={value:1}){let n=R(e,this.locale),r=Math.round(F(t,this.locale));if(N(()=>r===1||r===2||11<=r&&r<=17||r===21,O(`The type (%s) is out of range.`,r.toString())),r===21)return Zh.compute.bind(this)(e);let i;i=r===1||r===2?r-1:r-10==7?0:r-10;let a=n.getFullYear(),o=1,s=new D(a,0,o);for(;s.getDay()!==i;)o+=1,s=new D(a,0,o);let c=(n.getTime()-s.getTime())/qr;return c<0?1:Math.floor(c/7)+(o===1?1:2)},isExported:!0},ug={description:O(`Date after a number of workdays.`),args:[W(`start_date (date)`,O(`The date from which to begin counting.`)),W(`num_days (number)`,O(`The number of working days to advance from start_date. If negative, counts backwards.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the dates to consider holidays.`))],compute:function(e,t,n={value:null}){return dg.compute.bind(this)(e,t,{value:1},n)},isExported:!0},dg={description:O(`Date after a number of workdays (specifying weekends).`),args:[W(`start_date (date)`,O(`The date from which to begin counting.`)),W(`num_days (number)`,O(`The number of working days to advance from start_date. If negative, counts backwards.`)),W(`weekend (any, default=1)`,O(`A number or string representing which days of the week are considered weekends.`)),W(`holidays (date, range<date>, optional)`,O(`A range or array constant containing the dates to consider holidays.`))],compute:function(e,t,n={value:1},r){let i=R(e,this.locale),a=Math.trunc(F(t,this.locale));typeof n.value==`string`&&N(()=>n.value!==`1111111`,O(`The weekend must be different from '1111111'.`));let o=tg(n),s=new Set;r!==void 0&&Ua([r],e=>{let t=R(e,this.locale);s.add(t.getTime())});let c=D.fromTimestamp(i.getTime()),l=c.getTime(),u=Math.sign(a),d=Math.abs(a);for(;d>0;)c.setDate(c.getDate()+u),l=c.getTime(),!o.includes(c.getDay())&&!s.has(l)&&--d;let f=l-Kr.getTime();return{value:Math.round(f/qr),format:this.locale.dateFormat}},isExported:!0},fg={description:O(`Year specified by a given date.`),args:[W(`date (date)`,O(`The date from which to extract the year.`))],compute:function(e){return R(e,this.locale).getFullYear()},isExported:!0},pg={description:O(`Exact number of years between two dates.`),args:[W(`start_date (date)`,O(`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.`)),W(`end_date (date)`,O(`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.`)),W(`day_count_convention (number, default=0)`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n={value:0}){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=Math.trunc(F(n,this.locale));return N(()=>r>=0,O(`The start_date (%s) must be positive or null.`,r.toString())),N(()=>i>=0,O(`The end_date (%s) must be positive or null.`,i.toString())),N(()=>0<=a&&a<=4,O(`The day_count_convention (%s) must be between 0 and 4 inclusive.`,a.toString())),wi(r,i,a)}},mg={description:O(`First day of the month preceding a date.`),args:[W(`date (date)`,O(`The date from which to calculate the result.`))],compute:function(e){let t=R(e,this.locale);return{value:vi(new D(t.getFullYear(),t.getMonth(),1)),format:this.locale.dateFormat}}},hg={description:O(`Last day of the month following a date.`),args:[W(`date (date)`,O(`The date from which to calculate the result.`))],compute:function(e){return Yh.compute.bind(this)(e,{value:0})}},gg={description:O(`Quarter of the year a specific date falls in`),args:[W(`date (date)`,O(`The date from which to extract the quarter.`))],compute:function(e){return Math.ceil((R(e,this.locale).getMonth()+1)/3)}},_g={description:O(`First day of the quarter of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the start of quarter.`))],compute:function(e){let t=gg.compute.bind(this)(e);return{value:vi(new D(fg.compute.bind(this)(e),(t-1)*3,1)),format:this.locale.dateFormat}}},vg={description:O(`Last day of the quarter of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the end of quarter.`))],compute:function(e){let t=gg.compute.bind(this)(e);return{value:vi(new D(fg.compute.bind(this)(e),t*3,0)),format:this.locale.dateFormat}}},yg={description:O(`First day of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the start of the year.`))],compute:function(e){return{value:vi(new D(fg.compute.bind(this)(e),0,1)),format:this.locale.dateFormat}}},bg={description:O(`Last day of the year a specific date falls in.`),args:[W(`date (date)`,O(`The date from which to calculate the end of the year.`))],compute:function(e){return{value:vi(new D(fg.compute.bind(this)(e)+1,0,0)),format:this.locale.dateFormat}}};var xg=l({DELTA:()=>Sg});let Sg={description:O(`Compare two numeric values, returning 1 if they're equal.`),args:[W(`number1 (number)`,O(`The first number to compare.`)),W(`number2 (number, default=0)`,O(`The second number to compare.`))],compute:function(e,t={value:0}){return+(F(e,this.locale)===F(t,this.locale))},isExported:!0},Cg=[`number`,`error`,`text`,`boolean`];function wg(e){let t=e===`asc`?1:-1;return(e,n)=>{if(e.type===`empty`)return n.type===`empty`?0:1;if(n.type===`empty`)return-1;let r=Cg.indexOf(e.type)-Cg.indexOf(n.type);return r===0&&(r=e.type===`text`||e.type===`error`?e.value.localeCompare(n.value):e.value-n.value),t*r}}function Tg(e,t,n){let r=e.map((e,t)=>({index:t,type:e.type,value:e.value}));return(n?r.map(e=>e.type===`empty`?{...e,type:`number`,value:0}:e):r).sort(wg(t))}function Eg(e,t,n,r,i){let a=r.right>r.left;if(e.model.getters.doesIntersectMerge(t,r)){a=!1;let n;for(let i=r.top;i<=r.bottom;i++){n=[];for(let a=r.left;a<=r.right;a++){let r=e.model.getters.getMerge({sheetId:t,col:a,row:i});r&&!n.includes(r.id.toString())&&n.push(r.id.toString())}if(n.length>=2){a=!0;break}}}if(a){Dg(e,t,n,r,i);return}let o=e.model.getters.getContiguousZone(t,r);gr(o,r)?Dg(e,t,n,r,i):e.askConfirmation(O(`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?`),()=>Dg(e,t,n,o,i),()=>Dg(e,t,n,r,i))}function Dg(e,t,n,r,i,a){let o=e.model.dispatch(`SORT_CELLS`,{sheetId:t,col:n.col,row:n.row,zone:r,sortDirection:i,sortOptions:a});if(o.isCancelledBecause(`InvalidSortZone`)){let{col:t,row:i}=n;e.model.selection.selectZone({cell:{col:t,row:i},zone:r}),e.raiseError(O(`Cannot sort. To sort, select only cells or only merges that have the same size.`))}if(o.isCancelledBecause(`SortZoneWithArrayFormulas`)){let{col:t,row:i}=n;e.model.selection.selectZone({cell:{col:t,row:i},zone:r}),e.raiseError(O(`Cannot sort a zone with array formulas.`))}}var Og=l({FILTER:()=>Ag,SORT:()=>jg,SORTN:()=>Mg,UNIQUE:()=>Ng});function kg(e,t,...n){for(let e=0;e<n.length;e++)N(()=>n[e]!==void 0,O(`Value for parameter %s is missing in [[FUNCTION_NAME]].`,e%2==0?`sort_column`:`is_ascending`));let r=[],i=[],a=e.length;for(let o=0;o<n.length;o+=2){r.push(L(cu(n[o+1])?.value)?`asc`:`desc`);let s=n[o];if(A(s)&&(s.length>1||s[0].length>1))N(()=>s.length===1&&s[0].length===a,O(`Wrong size for %s. Expected a range of size 1x%s. Got %sx%s.`,`sort_column${o+1}`,a,s.length,s[0].length)),i.push(s.flat().map(e=>e.value));else{let n=F(cu(s)?.value,t);if(n<1||n>e[0].length)return e;i.push(e.map(e=>e[n-1].value))}}if(i.length===0)for(let t=0;t<e[0].length;t++)i.push(e.map(e=>e[t].value)),r.push(`asc`);let o={desc:wg(`desc`),asc:wg(`asc`)},s=S(0,e.length);return s.sort((e,t)=>{for(let[n,a]of i.entries()){let i=a[e],s=a[t],c={value:i,type:i===null?`empty`:typeof i==`string`?`text`:typeof i},l={value:s,type:s===null?`empty`:typeof s==`string`?`text`:typeof s},u=o[r[n]](c,l);if(u!==0)return u}return 0}),s.map(t=>e[t])}let Ag={description:O(`Returns a filtered version of the source range, returning only rows or columns that meet the specified conditions.`),args:[W(`range (any, range<any>)`,O(`The data to be filtered.`)),W(`condition1 (boolean, range<boolean>)`,O(`A column or row containing true or false values corresponding to the first column or row of range.`)),W(`condition2 (boolean, range<boolean>, repeating)`,O(`Additional column or row containing true or false values.`))],compute:function(e,...t){let n=z(e),r=t.map(e=>Xa(z(e),e=>e.value));r.map(e=>kf(O(`The arguments condition must be a single column or row.`),e)),Af(O(`The arguments conditions must have the same dimensions.`),...t);let i=r.map(e=>e.flat()),a=r[0].length===1?`row`:`col`;n=a===`row`?Qa(n):n,N(()=>i.every(e=>e.length===n.length),O(`FILTER has mismatched sizes on the range and conditions.`));let o=[];for(let e=0;e<n.length;e++){let t=n[e];i.every(t=>(typeof t[e]==`boolean`||typeof t[e]==`number`)&&t[e])&&o.push(t)}return o.length?a===`row`?Qa(o):o:new Sa(O(`No match found in FILTER evaluation`))},isExported:!1},jg={description:O(`Sorts the rows of a given array or range by the values in one or more columns.`),args:[W(`range (range)`,O(`The data to be sorted.`)),W(`sort_column (any, range<number>, repeating)`,O(`The index of the column in range or a range outside of range containing the values by which to sort.`)),W(`is_ascending (boolean, repeating)`,O(`TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order.`))],compute:function(e,...t){return Qa(kg(Qa(e),this.locale,...t))},isExported:!0},Mg={description:O(`Returns the first n items in a data set after performing a sort.`),args:[W(`range (range)`,O(`The data to be sorted.`)),W(`n (number)`,O(`The number of items to return.`)),W(`display_ties_mode (number, default=0)`,O(`A number representing the way to display ties.`)),W(`sort_column (number, range<number>, repeating)`,O(`The index of the column in range or a range outside of range containing the values by which to sort.`)),W(`is_ascending (boolean, repeating)`,O(`TRUE or FALSE indicating whether to sort sort_column in ascending order. FALSE sorts in descending order.`))],compute:function(e,t,...n){let r=F(t?.value??1,this.locale),i=n.length%2==0?0:F(n[0]?.value,this.locale),a=n.length%2==0?n:n.slice(1);N(()=>r>=0,O(`Wrong value of 'n'. Expected a positive number. Got %s.`,r)),N(()=>i>=0&&i<=3,O(`Wrong value of 'display_ties_mode'. Expected a positive number between 0 and 3. Got %s.`,i));let o=kg(Qa(e),this.locale,...a),s=(e,t)=>JSON.stringify(o[e].map(e=>e.value))===JSON.stringify(o[t].map(e=>e.value));switch(i){case 0:return Qa(o.slice(0,r));case 1:for(let e=r;e<o.length;e++)if(!s(e,r-1))return Qa(o.slice(0,e));return Qa(o);case 2:{let e=[o[0]];for(let t=1;t<o.length;t++)for(let n=0;n<t&&!s(t,n);n++)n===t-1&&e.push(o[t]);return Qa(e.slice(0,r))}case 3:{let e=[o[0]],t=1;for(let n=1;n<o.length&&(s(n,n-1)||t++,!(t>r));n++)e.push(o[n]);return Qa(e)}}},isExported:!1},Ng={description:O(`Unique rows in the provided source range.`),args:[W(`range (any, range<any>)`,O(`The data to filter by unique entries.`)),W(`by_column (boolean, default=FALSE)`,O(`Whether to filter the data by columns or by rows.`)),W(`exactly_once (boolean, default=FALSE)`,O(`Whether to return only entries with no duplicates.`))],compute:function(e={value:``},t,n){if(!A(e))return[[e]];let r=L(t?.value)||!1,i=L(n?.value)||!1;r||(e=Qa(e));let a=new Map;for(let t of e){let e=JSON.stringify(t.map(e=>e.value)),n=a.get(e);n?n.count++:a.set(e,{data:t,count:1})}let o=[];for(let e of a.values())i&&e.count>1||o.push(e.data);return o.length?r?o:Qa(o):new M(O(`No unique values found`))},isExported:!0};function Pg(e,t){N(()=>e<t,O(`The maturity (%s) must be strictly greater than the settlement (%s).`,t.toString(),e.toString()))}function Fg(e,t){N(()=>t<e,O(`The settlement date (%s) must be strictly greater than the issue date (%s).`,e.toString(),t.toString()))}function Ig(e){N(()=>[1,2,4].includes(e),O(`The frequency (%s) must be one of %s`,e.toString(),[1,2,4].toString()))}function Lg(e){N(()=>0<=e&&e<=4,O(`The day_count_convention (%s) must be between 0 and 4 inclusive.`,e.toString()))}function Rg(e){N(()=>e>0,O(`The redemption (%s) must be strictly positive.`,e.toString()))}function zg(e){N(()=>e>0,O(`The price (%s) must be strictly positive.`,e.toString()))}function Bg(e){N(()=>e>0,O(`The number_of_periods (%s) must be greater than 0.`,e.toString()))}function Vg(e){N(()=>e>0,O(`The rate (%s) must be strictly positive.`,e.toString()))}function Hg(e){N(()=>e>0,O(`The life (%s) must be strictly positive.`,e.toString()))}function Ug(e){N(()=>e>0,O(`The cost (%s) must be strictly positive.`,e.toString()))}function Wg(e){N(()=>e>=0,O(`The purchase_date (%s) must be positive or null.`,e.toString()))}function Gg(e){N(()=>e>=0,O(`The issue (%s) must be positive or null.`,e.toString()))}function Kg(e){N(()=>e>=0,O(`The cost (%s) must be positive or null.`,e.toString()))}function qg(e){N(()=>e>0,O(`The period (%s) must be strictly positive.`,e.toString()))}function Jg(e){N(()=>e>=0,O(`The period (%s) must be positive or null.`,e.toString()))}function Yg(e){N(()=>e>=0,O(`The salvage (%s) must be positive or null.`,e.toString()))}function Xg(e,t){N(()=>e<=t,O(`The salvage (%s) must be smaller or equal than the cost (%s).`,e.toString(),t.toString()))}function Zg(e){N(()=>e>0,O(`The present value (%s) must be strictly positive.`,e.toString()))}function Qg(e,t){N(()=>e<=t,O(`The period (%s) must be less than or equal life (%s).`,e.toString(),t.toString()))}function $g(e){N(()=>e>0,O(`The investment (%s) must be strictly positive.`,e.toString()))}function e_(e){N(()=>e>0,O(`The discount (%s) must be strictly positive.`,e.toString()))}function t_(e){N(()=>e<1,O(`The discount (%s) must be smaller than 1.`,e.toString()))}function n_(e){N(()=>e>0,O(`The depreciation factor (%s) must be strictly positive.`,e.toString()))}function r_(e,t,n){let r=R(e,n),i=R(t,n),a=R(e,n);a.setFullYear(r.getFullYear()+1),N(()=>i.getTime()<=a.getTime(),O(`The settlement date (%s) must at most one year after the maturity date (%s).`,e.toString(),t.toString()))}function i_(e,t,n){Bg(n),N(()=>e>0,O(`The first_period (%s) must be strictly positive.`,e.toString())),N(()=>t>0,O(`The last_period (%s) must be strictly positive.`,t.toString())),N(()=>e<=t,O(`The first_period (%s) must be smaller or equal to the last_period (%s).`,e.toString(),t.toString())),N(()=>t<=n,O(`The last_period (%s) must be smaller or equal to the number_of_periods (%s).`,e.toString(),n.toString()))}function a_(e,t,n){Hg(n),N(()=>e>=0,O(`The start_period (%s) must be greater or equal than 0.`,e.toString())),N(()=>t>=0,O(`The end_period (%s) must be greater or equal than 0.`,t.toString())),N(()=>e<=t,O(`The start_period (%s) must be smaller or equal to the end_period (%s).`,e.toString(),t.toString())),N(()=>t<=n,O(`The end_period (%s) must be smaller or equal to the life (%s).`,e.toString(),n.toString()))}function o_(e){N(()=>e>-1,O(`The rate_guess (%s) must be strictly greater than -1.`,e.toString()))}function s_(e,t){N(()=>e.length===t.length&&e[0].length===t[0].length,O(`The cashflow_amounts and cashflow_dates ranges must have the same dimensions.`))}function c_(e){N(()=>e.some(e=>e>0)&&e.some(e=>e<0),O(`There must be both positive and negative values in cashflow_amounts.`))}function l_(e){N(()=>e.every(t=>t>=e[0]),O(`All the dates should be greater or equal to the first date in cashflow_dates (%s).`,e[0].toString()))}var u_=l({ACCRINTM:()=>p_,AMORLINC:()=>m_,COUPDAYBS:()=>g_,COUPDAYS:()=>h_,COUPDAYSNC:()=>__,COUPNCD:()=>v_,COUPNUM:()=>y_,COUPPCD:()=>b_,CUMIPMT:()=>x_,CUMPRINC:()=>S_,DB:()=>C_,DDB:()=>T_,DISC:()=>E_,DOLLARDE:()=>D_,DOLLARFR:()=>O_,DURATION:()=>k_,EFFECT:()=>A_,FV:()=>M_,FVSCHEDULE:()=>N_,INTRATE:()=>P_,IPMT:()=>I_,IRR:()=>R_,ISPMT:()=>z_,MDURATION:()=>B_,MIRR:()=>V_,NOMINAL:()=>H_,NPER:()=>U_,NPV:()=>G_,PDURATION:()=>K_,PMT:()=>J_,PPMT:()=>X_,PRICE:()=>Q_,PRICEDISC:()=>$_,PRICEMAT:()=>ev,PV:()=>Z_,RATE:()=>nv,RECEIVED:()=>rv,RRI:()=>iv,SLN:()=>av,SYD:()=>ov,TBILLEQ:()=>lv,TBILLPRICE:()=>cv,TBILLYIELD:()=>uv,VDB:()=>dv,XIRR:()=>fv,XNPV:()=>pv,YIELD:()=>mv,YIELDDISC:()=>hv,YIELDMAT:()=>gv});let d_=[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))];function f_(e,t,n,r,i=1e-10,a){let o=n,s,c,l,u=!1,d=0,f;do{if(l=e(o),isNaN(l)){N(()=>d<r&&a!==void 0,O(`Function [[FUNCTION_NAME]] didn't find any result.`)),d++,o=a(f),f=o;continue}s=o-l/t(o),c=Math.abs(s-o),o=s,u=c<i||Math.abs(l)<i,N(()=>d<r,O(`Function [[FUNCTION_NAME]] didn't find any result.`)),d++}while(!u);return o}let p_={description:O(`Accrued interest of security paying at maturity.`),args:[W(`issue (date)`,O(`The date the security was initially issued.`)),W(`maturity (date)`,O(`The maturity date of the security.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(r,this.locale),c=F(n,this.locale),l=Math.trunc(F(i,this.locale));Gg(a),Fg(o,a),Lg(l),Rg(s),Vg(c);let u=wi(a,o,l);return s*c*u},isExported:!0},m_={description:O(`Depreciation for an accounting period.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`purchase_date (date)`,O(`The date the asset was purchased.`)),W(`first_period_end (date)`,O(`The date the first period ended.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`)),W(`rate (number)`,O(`The deprecation rate.`)),W(`day_count_convention (number, optional)`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a,o={value:0}){o||=0;let s=F(e,this.locale),c=Math.trunc(F(t,this.locale)),l=Math.trunc(F(n,this.locale)),u=F(r,this.locale),d=F(i,this.locale),f=F(a,this.locale),p=Math.trunc(F(o,this.locale));Ug(s),Wg(c),Yg(u),Xg(u,s),Jg(d),Vg(f),Lg(p),N(()=>c<=l,O(`The purchase_date (%s) must be before the first_period_end (%s).`,c.toString(),l.toString()));let m=d<1&&d>0?1:Math.trunc(d),h=s*f,g=wi(c,l,p),_=c===l?h:h*g,v=s-_-h*m;return v>=u?m===0?_:h:u-v<h?h-(u-v):0},isExported:!0},h_={description:O(`Days in coupon period containing settlement date.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));if(Pg(i,a),Ig(o),Lg(s),s===1){let i=b_.compute.bind(this)(e,t,n,r).value;return v_.compute.bind(this)(e,t,n,r).value-i}return(s===3?365:360)/o},isExported:!0},g_={description:O(`Days from settlement until next coupon.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=b_.compute.bind(this)(e,t,n,r).value;if([1,2,3].includes(s))return i-c;if(s===4){let e=wi(c,i,s);return Math.round(e*360)}let l=R(i,this.locale),u=R(c,this.locale),d=u.getFullYear(),f=l.getFullYear(),p=u.getMonth()+1,m=l.getMonth()+1,h=u.getDate(),g=l.getDate();return p===2&&m===2&&xi(u)&&xi(l)&&(g=30),g===31&&(h===30||h===31)&&(g=30),p===2&&xi(u)&&(h=30),h===31&&(h=30),(f-d)*360+(m-p)*30+(g-h)},isExported:!0},__={description:O(`Days from settlement until next coupon.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=v_.compute.bind(this)(e,t,n,r).value;if([1,2,3].includes(s))return c-i;if(s===4){let e=wi(i,c,s);return Math.round(e*360)}let l=g_.compute.bind(this)(e,t,n,r);return h_.compute.bind(this)(e,t,n,r)-l},isExported:!0},v_={description:O(`Next coupon date after the settlement date.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=12/o,l=y_.compute.bind(this)(e,t,n,r);return{value:vi(Si(R(a,this.locale),-(l-1)*c,!0)),format:this.locale.dateFormat}},isExported:!0},y_={description:O(`Number of coupons between settlement and maturity.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=1,l=a,u=12/o;for(;l>i;)l=vi(Si(R(l,this.locale),-u,!1)),c++;return c-1},isExported:!0},b_={description:O(`Last coupon date prior to or on the settlement date.`),args:d_,compute:function(e,t,n,r={value:0}){r||=0;let i=Math.trunc(F(e,this.locale)),a=Math.trunc(F(t,this.locale)),o=Math.trunc(F(n,this.locale)),s=Math.trunc(F(r,this.locale));Pg(i,a),Ig(o),Lg(s);let c=12/o,l=y_.compute.bind(this)(e,t,n,r);return{value:vi(Si(R(a,this.locale),-l*c,!0)),format:this.locale.dateFormat}},isExported:!0},x_={description:O(`Cumulative interest paid over a set of periods.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`first_period (number)`,O(`The number of the payment period to begin the cumulative calculation.`)),W(`last_period (number)`,O(`The number of the payment period to end the cumulative calculation.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i,a={value:0}){let o=F(r,this.locale),s=F(i,this.locale),c=F(e,this.locale),l=F(n,this.locale),u=F(t,this.locale),d=+!!L(a);i_(o,s,u),Vg(c),Zg(l);let f=0;for(let e=o;e<=s;e++)f+=F_(c,e,u,l,0,d);return f},isExported:!0},S_={description:O(`Cumulative principal paid over a set of periods.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`first_period (number)`,O(`The number of the payment period to begin the cumulative calculation.`)),W(`last_period (number)`,O(`The number of the payment period to end the cumulative calculation.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i,a={value:0}){let o=F(r,this.locale),s=F(i,this.locale),c=F(e,this.locale),l=F(n,this.locale),u=F(t,this.locale),d=+!!L(a);i_(o,s,u),Vg(c),Zg(l);let f=0;for(let e=o;e<=s;e++)f+=Y_(c,e,u,l,0,d);return f},isExported:!0},C_={description:O(`Depreciation via declining balance method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`)),W(`month (number, optional)`,O(`The number of months in the first year of depreciation.`))],compute:function(e,t,n,r,...i){let a=F(e,this.locale),o=F(t,this.locale),s=F(n,this.locale),c=Math.trunc(F(r,this.locale)),l=i.length?Math.trunc(F(i[0],this.locale)):12,u=s+(l===12?0:1);Kg(a),Yg(o),qg(c),Hg(s),N(()=>1<=l&&l<=12,O(`The month (%s) must be between 1 and 12 inclusive.`,l.toString())),N(()=>c<=u,O(`The period (%s) must be less than or equal to %s.`,c.toString(),u.toString()));let d=l/12,f=1-(o/a)**(1/s);f=Math.round(f*1e3)/1e3;let p=a,m=a*(1-f*d);for(let e=1;e<c;e++)p=m,m=p*(1-f),e===s&&(m=p*(1-f*(1-d)));return{value:p-m,format:`#,##0.00`}},isExported:!0};function w_(e,t,n,r,i){if(Kg(e),Yg(t),qg(r),Hg(n),Qg(r,n),n_(i),e===0||t>=e)return 0;let a=i/n;if(a>1)return r===1?e-t:0;if(r<=1)return e*a;let o=e*(1-a)**(r-1),s=e*(1-a)**r,c=s<t?o-t:o-s;return Math.max(c,0)}let T_={description:O(`Depreciation via double-declining balance method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`)),W(`factor (number, default=2)`,O(`The factor by which depreciation decreases.`))],compute:function(e,t,n,r,i={value:2}){return{value:w_(F(e,this.locale),F(t,this.locale),F(n,this.locale),F(r,this.locale),F(i,this.locale)),format:`#,##0.00`}},isExported:!0},E_={description:O(`Discount rate of a security based on price.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),Lg(l),zg(s),Rg(c);let u=wi(a,o,l);return(c-s)/c/u},isExported:!0},D_={description:O(`Convert a decimal fraction to decimal value.`),args:[W(`fractional_price (number)`,O(`The price quotation given using fractional decimal conventions.`)),W(`unit (number)`,O(`The units of the fraction, e.g. 8 for 1/8ths or 32 for 1/32nds.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));N(()=>r>0,O(`The unit (%s) must be strictly positive.`,r.toString()));let i=Math.trunc(n);return i+(n-i)*(10**Math.ceil(Math.log10(r))/r)},isExported:!0},O_={description:O(`Convert a decimal value to decimal fraction.`),args:[W(`decimal_price (number)`,O(`The price quotation given as a decimal value.`)),W(`unit (number)`,O(`The units of the desired fraction, e.g. 8 for 1/8ths or 32 for 1/32nds.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));N(()=>r>0,O(`The unit (%s) must be strictly positive.`,r.toString()));let i=Math.trunc(n);return i+(n-i)*(r/10**Math.ceil(Math.log10(r)))},isExported:!0},k_={description:O(`Number of periods for an investment to reach a value.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){let o=Math.trunc(F(e,this.locale)),s=Math.trunc(F(t,this.locale)),c=F(n,this.locale),l=F(r,this.locale),u=Math.trunc(F(i,this.locale)),d=Math.trunc(F(a,this.locale));Pg(o,s),Ig(u),Lg(d),N(()=>c>=0,O(`The rate (%s) must be positive or null.`,c.toString())),N(()=>l>=0,O(`The yield (%s) must be positive or null.`,l.toString()));let f=wi(o,s,d),p=f-Math.trunc(f)||1/u,m=Math.ceil(f*u),h=c/u,g=l/u,_=0,v=0;for(let e=1;e<=m;e++){let t=(h+ +(e===m))/(1+g)**e;v+=(p+(e-1)/u)*t,_+=t}return _===0?0:v/_},isExported:!0},A_={description:O(`Annual effective interest rate.`),args:[W(`nominal_rate (number)`,O(`The nominal interest rate per year.`)),W(`periods_per_year (number)`,O(`The number of compounding periods per year.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));return N(()=>n>0,O(`The nominal rate (%s) must be strictly greater than 0.`,n.toString())),N(()=>r>0,O(`The number of periods by year (%s) must strictly greater than 0.`,r.toString())),(1+n/r)**+r-1},isExported:!0};function j_(e,t,n,r,i){return e===0?-(r+n*t):-r*(1+e)**t-n*(1+e*i)*((1+e)**t-1)/e}let M_={description:O(`Future value of an annuity investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`payment_amount (number)`,O(`The amount per period to be paid.`)),W(`present_value (number, default=0)`,O(`The current value of the annuity.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){return r||=0,i||=0,{value:j_(F(e,this.locale),F(t,this.locale),F(n,this.locale),F(r,this.locale),+!!L(i)),format:`#,##0.00`}},isExported:!0},N_={description:O(`Future value of principal from series of rates.`),args:[W(`principal (number)`,O(`The amount of initial capital or value to compound against.`)),W(`rate_schedule (number, range<number>)`,O(`A series of interest rates to compound against the principal.`))],compute:function(e,t){let n=F(e,this.locale);return Ka([t],(e,t)=>e*(1+F(t,this.locale)),n)},isExported:!0},P_={description:O(`Calculates effective interest rate.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`investment (number)`,O(`The amount invested in the security.`)),W(`redemption (number)`,O(`The amount to be received at maturity.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(r,this.locale),c=F(n,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),$g(c),Rg(s),Lg(l);let u=wi(a,o,l);return(s-c)/c/u},isExported:!0};function F_(e,t,n,r,i,a){return q_(e,n,r,i,a)-Y_(e,t,n,r,i,a)}let I_={description:O(`Payment on the principal of an investment.`),args:[W(`rate (number)`,O(`The annualized rate of interest.`)),W(`period (number)`,O(`The amortization period, in terms of number of periods.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i={value:0},a={value:0}){return{value:F_(F(e,this.locale),F(t,this.locale),F(n,this.locale),F(r,this.locale),F(i,this.locale),+!!L(a)),format:`#,##0.00`}},isExported:!0},L_=.1,R_={description:O(`Internal rate of return given periodic cashflows.`),args:[W(`cashflow_amounts (number, range<number>)`,O(`An array or range containing the income or payments associated with the investment.`)),W(`rate_guess (number, default=${L_})`,O(`An estimate for what the internal rate of return will be.`))],compute:function(e,t={value:L_}){let n=F(t,this.locale);o_(n);let r=!1,i=!1,a=[];Wa([e],({value:e})=>{e>0&&(r=!0),e<0&&(i=!0),a.push(e)},this.locale),N(()=>r&&i,O(`The cashflow_amounts must include negative and positive values.`));let o=a.shift();function s(e,t,n){let r=n.length,i=0;return n.reduce((t,n)=>(i++,t+n*e**(r-i)),t*e**r)}function c(e,t,n){let r=n.length,i=0;return n.reduce((t,n)=>(i++,t+n*(r-i)*e**(r-i-1)),t*r*e**(r-1))}function l(e){return s(e,o,a)}function u(e){return c(e,o,a)}return{value:f_(l,u,n+1,20,1e-5)-1,format:`0%`}},isExported:!0},z_={description:O(`Returns the interest paid at a particular period of an investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`period (number)`,O(`The period for which you want to view the interest payment.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`))],compute:function(e,t,n,r){let i=F(e,this.locale),a=F(t,this.locale),o=F(n,this.locale),s=F(r,this.locale);return N(()=>o!==0,O(`The number of periods must be different than 0.`,o.toString())),-1*(s-a/o*s)*i},isExported:!0},B_={description:O(`Modified Macaulay duration.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){return k_.compute.bind(this)(e,t,n,r,i,a)/(1+F(r,this.locale)/Math.trunc(F(i,this.locale)))},isExported:!0},V_={description:O(`Modified internal rate of return.`),args:[W(`cashflow_amounts (range<number>)`,O(`A range containing the income or payments associated with the investment. The array should contain bot payments and incomes.`)),W(`financing_rate (number)`,O(`The interest rate paid on funds invested.`)),W(`reinvestment_return_rate (number)`,O(`The return (as a percentage) earned on reinvestment of income received from the investment.`))],compute:function(e,t,n){let r=F(t,this.locale),i=F(n,this.locale),a=Qa(e).flat().filter(e=>e.value!==null).map(e=>F(e,this.locale)),o=a.length,s=0,c=0;for(let e of S(0,o)){let t=a[e];t>=0?s+=t*(i+1)**(o-e-1):c+=t/(r+1)**e}N(()=>c!==0&&s!==0,O(`There must be both positive and negative values in cashflow_amounts.`));let l=1/(o-1);return(-s/c)**l-1},isExported:!0},H_={description:O(`Annual nominal interest rate.`),args:[W(`effective_rate (number)`,O(`The effective interest rate per year.`)),W(`periods_per_year (number)`,O(`The number of compounding periods per year.`))],compute:function(e,t){let n=F(e,this.locale),r=Math.trunc(F(t,this.locale));return N(()=>n>0,O(`The effective rate (%s) must must strictly greater than 0.`,n.toString())),N(()=>r>0,O(`The number of periods by year (%s) must strictly greater than 0.`,r.toString())),((n+1)**(1/r)-1)*r},isExported:!0},U_={description:O(`Number of payment periods for an investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`payment_amount (number)`,O(`The amount of each payment made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){r||=0,i||=0;let a=F(e,this.locale),o=F(t,this.locale),s=F(n,this.locale),c=F(r,this.locale),l=+!!L(i);if(a===0)return-(c+s)/o;let u=o*(1+a*l)/a;return Math.log((u-c)/(s+u))/Math.log(1+a)},isExported:!0};function W_(e,t,n,r){let i=0;return qa(n,(t,n)=>(i++,t+n/(1+e)**i),t,r)}let G_={description:O(`The net present value of an investment based on a series of periodic cash flows and a discount rate.`),args:[W(`discount (number)`,O(`The discount rate of the investment over one period.`)),W(`cashflow1 (number, range<number>)`,O(`The first future cash flow.`)),W(`cashflow2 (number, range<number>, repeating)`,O(`Additional future cash flows.`))],compute:function(e,...t){let n=F(e,this.locale);return N(()=>n!==-1,O(`The discount (%s) must be different from -1.`,n.toString())),{value:W_(n,0,t,this.locale),format:`#,##0.00`}},isExported:!0},K_={description:O(`Computes the number of periods needed for an investment to reach a value.`),args:[W(`rate (number)`,O(`The rate at which the investment grows each period.`)),W(`present_value (number)`,O(`The investment's current value.`)),W(`future_value (number)`,O(`The investment's desired future value.`))],compute:function(e,t,n){let r=F(e,this.locale),i=F(t,this.locale),a=F(n,this.locale);return Vg(r),N(()=>i>0,O(`The present_value (%s) must be strictly positive.`,i.toString())),N(()=>a>0,O(`The future_value (%s) must be strictly positive.`,a.toString())),(Math.log(a)-Math.log(i))/Math.log(1+r)},isExported:!0};function q_(e,t,n,r,i){if(Bg(t),e===0)return-(r+n)/t;let a=-(n*(1+e)**t+r);return a=a*e/((1+e*i)*((1+e)**t-1)),a}let J_={description:O(`Periodic payment for an annuity investment.`),args:[W(`rate (number)`,O(`The annualized rate of interest.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){let a=F(t,this.locale),o=F(e,this.locale),s=+!!L(i),c=F(r,this.locale);return{value:q_(o,a,F(n,this.locale),c,s),format:`#,##0.00`}},isExported:!0};function Y_(e,t,n,r,i,a){Bg(n),N(()=>t>0&&t<=n,O(`The period must be between 1 and number_of_periods (%s)`,n));let o=q_(e,n,r,i,a);return a===1&&t===1?o:o+-j_(e,a===0?t-1:t-2,o,r+o*a,0)*e}let X_={description:O(`Payment on the principal of an investment.`),args:[W(`rate (number)`,O(`The annualized rate of interest.`)),W(`period (number)`,O(`The amortization period, in terms of number of periods.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r,i={value:0},a={value:0}){let o=F(n,this.locale),s=F(e,this.locale),c=F(t,this.locale),l=+!!L(a),u=F(i,this.locale);return{value:Y_(s,c,o,F(r,this.locale),u,l),format:`#,##0.00`}},isExported:!0},Z_={description:O(`Present value of an annuity investment.`),args:[W(`rate (number)`,O(`The interest rate.`)),W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`payment_amount (number)`,O(`The amount per period to be paid.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`))],compute:function(e,t,n,r={value:0},i={value:0}){r||=0,i||=0;let a=F(e,this.locale),o=F(t,this.locale),s=F(n,this.locale),c=F(r,this.locale),l=+!!L(i);return{value:a?-(s*(1+a*l)*((1+a)**o-1)/a+c)/(1+a)**o:-(c+s*o),format:`#,##0.00`}},isExported:!0},Q_={description:O(`Price of a security paying periodic interest.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a,o={value:0}){o||=0;let s=Math.trunc(F(e,this.locale)),c=Math.trunc(F(t,this.locale)),l=F(n,this.locale),u=F(r,this.locale),d=F(i,this.locale),f=Math.trunc(F(a,this.locale)),p=Math.trunc(F(o,this.locale));Pg(s,c),Ig(f),Lg(p),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),N(()=>u>=0,O(`The yield (%s) must be positive or null.`,u.toString())),Rg(d);let m=wi(s,c,p)*f,h=Math.ceil(m),g=m-Math.floor(m)||1,_=1+u/f,v=100*l/f;if(h===1)return(v+d)/(g*u/f+1)-v*(1-g);let y=0;for(let e=1;e<=h;e++)y+=v/_**(e-1+g);return d/_**(h-1+g)+y-v*(1-g)},isExported:!0},$_={description:O(`Price of a discount security.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`discount (number)`,O(`The discount rate of the security at time of purchase.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),Lg(l),e_(s),Rg(c);let u=wi(a,o,l);return c-s*c*u},isExported:!0},ev={description:O(`Calculates the price of a security paying interest at maturity, based on expected yield.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`issue (date)`,O(`The date the security was initially issued.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`yield (number)`,O(`The expected annual yield of the security.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){a||=0;let o=Math.trunc(F(e,this.locale)),s=Math.trunc(F(t,this.locale)),c=Math.trunc(F(n,this.locale)),l=F(r,this.locale),u=F(i,this.locale),d=Math.trunc(F(a,this.locale));Fg(o,c),Pg(o,s),Lg(d),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),N(()=>u>=0,O(`The yield (%s) must be positive or null.`,u.toString()));let f=wi(o,s,d),p=wi(o,c,d),m=100+wi(c,s,d)*l*100,h=1+f*u,g=p*l*100;return m/h-g},isExported:!0},tv=.1,nv={description:O(`Interest rate of an annuity investment.`),args:[W(`number_of_periods (number)`,O(`The number of payments to be made.`)),W(`payment_per_period (number)`,O(`The amount per period to be paid.`)),W(`present_value (number)`,O(`The current value of the annuity.`)),W(`future_value (number, default=0)`,O(`The future value remaining after the final payment has been made.`)),W(`end_or_beginning (number, default=0)`,O(`Whether payments are due at the end (0) or beginning (1) of each period.`)),W(`rate_guess (number, default=${tv})`,O(`An estimate for what the interest rate will be.`))],compute:function(e,t,n,r={value:0},i={value:0},a={value:tv}){let o=F(e,this.locale),s=F(t,this.locale),c=+!!L(i),l=F(a,this.locale)||tv,u=F(r,this.locale),d=F(n,this.locale);return Bg(o),N(()=>[s,d,u].some(e=>e>0)&&[s,d,u].some(e=>e<0),O(`There must be both positive and negative values in [payment_amount, present_value, future_value].`,o.toString())),o_(l),u-=s*c,d+=s*c,{value:f_(e=>{let t=(1+e)**+o,n=(t-1)/e;return u+d*t+s*n},e=>{let t=(1+e)**(o-1),n=((1+e)**+o-1)/e,r=o*t/e-n/e;return d*o*t+s*r},l,40,1e-5),format:`0%`}},isExported:!0},rv={description:O(`Amount received at maturity for a security.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`investment (number)`,O(`The amount invested (irrespective of face value of each security).`)),W(`discount (number)`,O(`The discount rate of the security invested in.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));return Pg(a,o),Lg(l),$g(s),e_(c),s/(1-c*wi(a,o,l))},isExported:!0},iv={description:O(`Computes the rate needed for an investment to reach a specific value within a specific number of periods.`),args:[W(`number_of_periods (number)`,O(`The number of periods.`)),W(`present_value (number)`,O(`The present value of the investment.`)),W(`future_value (number)`,O(`The future value of the investment.`))],compute:function(e,t,n){let r=F(e,this.locale),i=F(t,this.locale),a=F(n,this.locale);return Bg(r),(a/i)**(1/r)-1},isExported:!0},av={description:O(`Depreciation of an asset using the straight-line method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`))],compute:function(e,t,n){let r=F(e,this.locale),i=F(t,this.locale),a=F(n,this.locale);return{value:(r-i)/a,format:`#,##0.00`}},isExported:!0},ov={description:O(`Depreciation via sum of years digit method.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`period (number)`,O(`The single period within life for which to calculate depreciation.`))],compute:function(e,t,n,r){let i=F(e,this.locale),a=F(t,this.locale),o=F(n,this.locale),s=F(r,this.locale);qg(s),Hg(o),Qg(s,o);let c=o*(o+1)/2,l=o-s+1;return{value:(i-a)*(l/c),format:`#,##0.00`}},isExported:!0};function sv(e,t,n){return 100*(1-n*wi(e,t,2))}let cv={description:O(`Price of a US Treasury bill.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`discount (number)`,O(`The discount rate of the bill at time of purchase.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=F(n,this.locale);return Pg(r,i),r_(r,i,this.locale),e_(a),t_(a),sv(r,i,a)},isExported:!0},lv={description:O(`Equivalent rate of return for a US Treasury bill.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`discount (number)`,O(`The discount rate of the bill at time of purchase.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=F(n,this.locale);Pg(r,i),r_(r,i,this.locale),e_(a),t_(a);let o=Kh.compute.bind(this)({value:i},{value:r});if(o<=182)return 365*a/(360-a*o);let s=sv(r,i,a)/100,c=o/(o===366?366:365);return(-2*c+2*Math.sqrt(c**2-(2*c-1)*(1-1/s)))/(2*c-1)},isExported:!0},uv={description:O(`The yield of a US Treasury bill based on price.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`))],compute:function(e,t,n){let r=Math.trunc(F(e,this.locale)),i=Math.trunc(F(t,this.locale)),a=F(n,this.locale);Pg(r,i),r_(r,i,this.locale),zg(a);let o=wi(r,i,2);return(100-a)/a*(1/o)},isExported:!0},dv={description:O(`Variable declining balance. WARNING : does not handle decimal periods.`),args:[W(`cost (number)`,O(`The initial cost of the asset.`)),W(`salvage (number)`,O(`The value of the asset at the end of depreciation.`)),W(`life (number)`,O(`The number of periods over which the asset is depreciated.`)),W(`start (number)`,O(`Starting period to calculate depreciation.`)),W(`end (number)`,O(`Ending period to calculate depreciation.`)),W(`factor (number, default=2)`,O(`The number of months in the first year of depreciation.`)),W(`no_switch (number, default=false)`,O(`Whether to switch to straight-line depreciation when the depreciation is greater than the declining balance calculation.`))],compute:function(e,t,n,r,i,a={value:2},o={value:!1}){a||=0;let s=F(e,this.locale),c=F(t,this.locale),l=F(n,this.locale),u=Math.trunc(F(r,this.locale)),d=Math.trunc(F(i,this.locale)),f=F(a,this.locale),p=L(o);if(Kg(s),Yg(c),a_(u,d,l),n_(f),s===0)return 0;if(c>=s)return u<1?s-c:0;let m=f/l;if(m>=1)return u<1?s-c:0;let h=s,g=0,_=0,v=!1;for(let e=0;e<d;e++){if(!v||p){let t=h*m,n=l-e,r=(h-c)/n;!p&&r>t?(v=!0,g=r):g=t}let t=Math.max(h-g,c);e>=u&&(_+=h-t),h=t}return _},isExported:!0},fv={description:O(`Internal rate of return given non-periodic cash flows.`),args:[W(`cashflow_amounts (range<number>)`,O(`An range containing the income or payments associated with the investment.`)),W(`cashflow_dates (range<number>)`,O(`An range with dates corresponding to the cash flows in cashflow_amounts.`)),W(`rate_guess (number, default=${tv})`,O(`An estimate for what the internal rate of return will be.`))],compute:function(e,t,n={value:tv}){let r=F(n,this.locale),i=e.flat().map(e=>F(e,this.locale)),a=t.flat().map(e=>F(e,this.locale));s_(e,t),c_(i),l_(a),o_(r);let o=new Map;for(let e of S(0,a.length)){let t=a[e];o.has(t)?o.set(t,o.get(t)+i[e]):o.set(t,i[e])}let s=Array.from(o.keys()),c=s.map(e=>o.get(e));return f_(e=>{let t=c[0];for(let n of S(1,c.length)){let r=(s[0]-s[n])/365;t+=c[n]*(1+e)**r}return t},e=>{let t=0;for(let n of S(1,c.length)){let r=(s[0]-s[n])/365;t+=r*c[n]*(1+e)**(r-1)}return t},r,40,1e-5,e=>e?e/10-.9:-.9)},isExported:!0},pv={description:O(`Net present value given to non-periodic cash flows..`),args:[W(`discount (number)`,O(`The discount rate of the investment over one period.`)),W(`cashflow_amounts (number, range<number>)`,O(`An range containing the income or payments associated with the investment.`)),W(`cashflow_dates (number, range<number>)`,O(`An range with dates corresponding to the cash flows in cashflow_amounts.`))],compute:function(e,t,n){let r=F(e,this.locale),i=A(t)?t.flat().map(e=>Na(e,this.locale)):[Na(t,this.locale)],a=A(n)?n.flat().map(e=>Na(e,this.locale)):[Na(n,this.locale)];if(A(n)&&A(t)?s_(t,n):N(()=>i.length===a.length,O(`There must be the same number of values in cashflow_amounts and cashflow_dates.`)),l_(a),Vg(r),i.length===1)return i[0];let o=new Map;for(let e of S(0,a.length)){let t=a[e];o.has(t)?o.set(t,o.get(t)+i[e]):o.set(t,i[e])}let s=Array.from(o.keys()),c=s.map(e=>o.get(e)),l=c[0];for(let e of S(1,c.length)){let t=(s[0]-s[e])/365;l+=c[e]*(1+r)**t}return l},isExported:!0},mv={description:O(`Annual yield of a security paying periodic interest.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`frequency (number)`,O(`The number of interest or coupon payments per year (1, 2, or 4).`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a,o={value:0}){o||=0;let s=Math.trunc(F(e,this.locale)),c=Math.trunc(F(t,this.locale)),l=F(n,this.locale),u=F(r,this.locale),d=F(i,this.locale),f=Math.trunc(F(a,this.locale)),p=Math.trunc(F(o,this.locale));Pg(s,c),Ig(f),Lg(p),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),zg(u),Rg(d);let m=wi(s,c,p)*f,h=Math.ceil(m),g=m-Math.floor(m)||1,_=100*l/f;if(h===1){let e=u+_*(1-g);return(d+_-e)*f*(1/g)/e}function v(e,t,n,r,i,a){let o=a-(e+i*(1-t))*r**(n-1+t);for(let e=1;e<=n;e++)o+=i*r**(e-1);return o}function y(e,t,n,r,i){let a=-(e+i*(1-t))*(n-1+t)*r**(n-2+t);for(let e=1;e<=n;e++)a+=i*(e-1)*r**(e-2);return a}function ee(e){return v(u,g,h,e,_,d)}function te(e){return y(u,g,h,e,_)}return(f_(ee,te,1+(l+1)/f,100,1e-5)-1)*f},isExported:!0},hv={description:O(`Annual yield of a discount security.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`price (number)`,O(`The price at which the security is bought per 100 face value.`)),W(`redemption (number)`,O(`The redemption amount per 100 face value, or par.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i={value:0}){i||=0;let a=Math.trunc(F(e,this.locale)),o=Math.trunc(F(t,this.locale)),s=F(n,this.locale),c=F(r,this.locale),l=Math.trunc(F(i,this.locale));Pg(a,o),Lg(l),zg(s),Rg(c);let u=wi(a,o,l);return(c/s-1)/u},isExported:!0},gv={description:O(`Annual yield of a security paying interest at maturity.`),args:[W(`settlement (date)`,O(`The settlement date of the security, the date after issuance when the security is delivered to the buyer.`)),W(`maturity (date)`,O(`The maturity or end date of the security, when it can be redeemed at face, or par value.`)),W(`issue (date)`,O(`The date the security was initially issued.`)),W(`rate (number)`,O(`The annualized rate of interest.`)),W(`price (number)`,O(`The price at which the security is bought.`)),W(`day_count_convention (number, default=0 )`,O(`An indicator of what day count method to use.`))],compute:function(e,t,n,r,i,a={value:0}){a||=0;let o=Math.trunc(F(e,this.locale)),s=Math.trunc(F(t,this.locale)),c=Math.trunc(F(n,this.locale)),l=F(r,this.locale),u=F(i,this.locale),d=Math.trunc(F(a,this.locale));Pg(o,s),Lg(d),N(()=>o>=c,O(`The settlement (%s) must be greater than or equal to the issue (%s).`,o.toString(),c.toString())),N(()=>l>=0,O(`The rate (%s) must be positive or null.`,l.toString())),zg(u);let f=wi(c,s,d),p=wi(c,o,d),m=wi(o,s,d);return(100*(1+l*f)/(u+100*l*p)-1)/m},isExported:!0},_v=(e,t=()=>!0)=>[{goTo:e,guard:t}],vv=(e,t=()=>!0)=>({goTo:e,guard:t}),yv={0:{REFERENCE:_v(2),NUMBER:_v(4),SYMBOL:[vv(3,e=>ec(e.value)),vv(4,e=>tc(e.value))]},3:{SPACE:_v(3),OPERATOR:_v(5,e=>e.value===`:`)},4:{SPACE:_v(4),OPERATOR:_v(6,e=>e.value===`:`)},2:{SPACE:_v(2),OPERATOR:_v(1,e=>e.value===`:`)},1:{SPACE:_v(1),NUMBER:_v(7),REFERENCE:_v(7,e=>ic(e.value)),SYMBOL:_v(7,e=>nc(e.value)||rc(e.value))},5:{SPACE:_v(5),SYMBOL:_v(7,e=>nc(e.value)),REFERENCE:_v(7,e=>ic(e.value))},6:{SPACE:_v(6),NUMBER:_v(7),REFERENCE:_v(7,e=>ic(e.value)),SYMBOL:_v(7,e=>rc(e.value))},7:{}};function bv(e){let t=0,n=yv[0],r=``;for(;n!==void 0;){let i=e[t++];if(!i)return null;let a=n[i.type]?.find(e=>e.guard(i)),o=a?a.goTo:void 0;switch(o){case void 0:return null;case 7:return r+=i.value,e.splice(0,t),{type:`REFERENCE`,value:r};default:n=yv[o],r+=i.value;break}}return null}function xv(e,t=k){let n=bl(e,t),r=[];for(;n.length;)r.push(bv(n)||n.shift());return r}let Sv=/[a-zA-Z0-9\_]+(\.[a-zA-Z0-9\_]+)*/,Cv=[`-`,`+`],wv=[`%`],Tv=[`*`,`+`,`&`];var Ev=class{tokens;currentIndex=0;current;length;constructor(e){this.tokens=e,this.current=e[0],this.length=e.length}shift(){let e=this.tokens[this.currentIndex];return this.current=this.tokens[++this.currentIndex],e}get next(){return this.tokens[this.currentIndex+1]}};let Dv={"^":30,"%":30,"*":20,"/":20,"+":15,"-":15,"&":13,">":10,"<>":10,">=":10,"<":10,"<=":10,"=":10};function Ov(e){let t=e.shift();if(!t)throw new ya;switch(t.type){case`DEBUGGER`:let n=Mv(e,1e3);return n.debug=!0,n;case`NUMBER`:return{type:`NUMBER`,value:zi(t.value,k),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`STRING`:return{type:`STRING`,value:rt(t.value),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`INVALID_REFERENCE`:return{type:`REFERENCE`,value:j.InvalidReference,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`REFERENCE`:if(e.current?.value===`:`&&e.next?.type===`REFERENCE`){e.shift();let n=e.shift();return{type:`REFERENCE`,value:`${t.value}:${n?.value}`,tokenStartIndex:t.tokenIndex,tokenEndIndex:n.tokenIndex}}return{type:`REFERENCE`,value:t.value,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`SYMBOL`:let r=t.value;if(e.current?.type===`LEFT_PAREN`&&Sv.test(t.value)&&r===ct(r,`'`)){let{args:n,rightParen:i}=kv(e);return{type:`FUNCALL`,value:r,args:n,tokenStartIndex:t.tokenIndex,tokenEndIndex:i.tokenIndex}}let i=r.toUpperCase();return i===`TRUE`||i===`FALSE`?{type:`BOOLEAN`,value:i===`TRUE`,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:{type:`SYMBOL`,value:ct(t.value,`'`),tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex};case`LEFT_PAREN`:let a=Mv(e),o=jv(e,`RIGHT_PAREN`,O(`Missing closing parenthesis`));return{...a,tokenStartIndex:t.tokenIndex,tokenEndIndex:o.tokenIndex};case`OPERATOR`:let s=t.value;if(Cv.includes(s)){let n=Mv(e,Dv[s]);return{type:`UNARY_OPERATION`,value:s,operand:n,tokenStartIndex:t.tokenIndex,tokenEndIndex:n.tokenEndIndex}}throw new ya(O(`Unexpected token: %s`,t.value));default:throw new ya(O(`Unexpected token: %s`,t.value))}}function kv(e){if(jv(e,`LEFT_PAREN`,O(`Missing opening parenthesis`)),e.current?.type===`RIGHT_PAREN`)return{args:[],rightParen:jv(e,`RIGHT_PAREN`)};let t=[];for(t.push(Av(e));e.current?.type!==`RIGHT_PAREN`;)jv(e,`ARG_SEPARATOR`,O(`Wrong function call`)),t.push(Av(e));return{args:t,rightParen:jv(e,`RIGHT_PAREN`)}}function Av(e){let t=e.current;return t?.type===`ARG_SEPARATOR`||t?.type===`RIGHT_PAREN`?{type:`EMPTY`,value:``,tokenStartIndex:t.tokenIndex,tokenEndIndex:t.tokenIndex}:Mv(e)}function jv(e,t,n){let r=e.shift();if(!r||r.type!==t)throw new ya(n);return r}function Mv(e,t=0){if(e.length===0)throw new ya;let n=Ov(e);for(;e.current?.type===`OPERATOR`&&Dv[e.current.value]>t;){let t=e.shift(),r=t.value;if(wv.includes(r))n={type:`UNARY_OPERATION`,value:r,operand:n,postfix:!0,tokenStartIndex:n.tokenStartIndex,tokenEndIndex:t.tokenIndex};else{let t=Mv(e,Dv[r]);n={type:`BIN_OPERATION`,value:r,left:n,right:t,tokenStartIndex:n.tokenStartIndex,tokenEndIndex:t.tokenEndIndex}}}return n}function Nv(e){return Pv(xv(e))}function Pv(e){let t=new Ev(e.map((e,t)=>({type:e.type,value:e.value,tokenIndex:t})).filter(e=>e.type!==`SPACE`));t.current?.value===`=`&&t.shift();let n=Mv(t);if(t.current)throw new ya;return n}function Fv(e,t,n){return Rv(e,e=>e.type===t?n(e):e)}function Iv(e){return Array.from(Lv(e))}function*Lv(e){switch(yield e,e.type){case`FUNCALL`:for(let t of e.args)yield*Lv(t);break;case`UNARY_OPERATION`:yield*Lv(e.operand);break;case`BIN_OPERATION`:yield*Lv(e.left),yield*Lv(e.right);break}}function Rv(e,t){switch(e=t(e),e.type){case`FUNCALL`:return{...e,args:e.args.map(e=>Rv(e,t))};case`UNARY_OPERATION`:return{...e,operand:Rv(e.operand,t)};case`BIN_OPERATION`:return{...e,right:Rv(e.right,t),left:Rv(e.left,t)};default:return e}}function zv(e){switch(e.type){case`FUNCALL`:let t=e.args.map(e=>zv(e));return`${e.value}(${t.join(`,`)})`;case`NUMBER`:return e.value.toString();case`REFERENCE`:return e.value;case`STRING`:return`"${e.value}"`;case`BOOLEAN`:return e.value?`TRUE`:`FALSE`;case`UNARY_OPERATION`:return e.postfix?Bv(e)+e.value:e.value+Vv(e);case`BIN_OPERATION`:return Bv(e)+e.value+Vv(e);default:return e.value}}function Bv(e){let t=e.value,n=`left`in e?e.left:e.operand,r=n.value;return n.type===`BIN_OPERATION`&&Dv[r]<Dv[t]?`(${zv(n)})`:zv(n)}function Vv(e){let t=e.value,n=`right`in e?e.right:e.operand,r=Dv[n.value],i=Dv[t],a=!1;return n.type===`BIN_OPERATION`?(r<i||r===i&&!Tv.includes(t))&&(a=!0):a=!1,a?`(${zv(n)})`:zv(n)}function Hv(e){let t=0;return e.map(e=>{let n=e.value.toString().length,r=Object.assign({},e,{start:t,end:t+n,length:n});return t=r.end,r})}function Uv(e){let t=[],n=0;return e.map((r,i)=>{if(r.type===`LEFT_PAREN`){t.push(n+1),n=0;for(let n=i-1;n>=0;n--){if(e[n].type===`SPACE`){e[n].parenthesesCode=t.join(`:`);continue}e[n].type===`SYMBOL`&&(e[n].parenthesesCode=t.join(`:`));break}}return r.parenthesesCode=t.join(`:`),r.type===`RIGHT_PAREN`&&t.length&&(n=t.pop()),r})}function Wv(e){let t=[],n=``;function r(e){if(t.length===0)return;let n=t.at(-1);if(n&&n.argsTokens){let{argsTokens:t,argPosition:r}=n;t[r]||(t[r]=[]),t[r].push({value:e.value,type:e.type})}}return e.map((e,i)=>{switch([`SPACE`,`LEFT_PAREN`].includes(e.type)||(n=``),e.type){case`SYMBOL`:r(e),n=e.value;break;case`LEFT_PAREN`:t.push({parent:n,argPosition:0,argsTokens:[],args:[]}),r(e),n=``;break;case`RIGHT_PAREN`:t.pop()?.argsTokens?.flat().forEach(r),r(e);break;case`ARG_SEPARATOR`:t.length&&t[t.length-1].argPosition++,r(e);break;default:r(e);break}if(t.length){let n=t[t.length-1];n.parent&&(e.functionContext=Object.assign({},n))}return e})}function Gv(e){for(let t of e)if(t.functionContext){let{argsTokens:e,args:n}=t.functionContext;if(delete t.functionContext.argsTokens,n.length||!e)continue;e[0]?.[0]?.type===`LEFT_PAREN`&&(e[0]=e[0].slice(1));for(let t of e){let e=t;e.at(0)?.type===`ARG_SEPARATOR`&&(e=e.slice(1));try{n.push(Pv(e))}catch{n.push(void 0)}}}return e}function Kv(e,t){return Gv(Wv(Uv(Hv(xv(e,t)))))}function qv(e){if(e.type!==`REFERENCE`)return e;let{xc:t,sheetName:n}=ac(e.value),[r,i]=t.split(`:`),a=Jv(r),o=i?`:${Jv(i)}`:``;return{...e,value:oc(n,a+o)}}function Jv(e){switch(Zv(e)){case`none`:e=Yv(e,`colrow`);break;case`colrow`:e=Yv(e,`row`);break;case`row`:e=Yv(e,`col`);break;case`col`:e=Yv(e,`none`);break}return e}function Yv(e,t){let n;({sheetName:n,xc:e}=ac(e)),n=n?n+`!`:``,e=e.replace(/\$/g,``);let r=e.indexOf(`:`);return r>=0?`${n}${Xv(e.slice(0,r),t)}:${Xv(e.slice(r+1),t)}`:n+Xv(e,t)}function Xv(e,t){let n=e.search(/[0-9]/),r=n!==0,i=n>=0;switch(t){case`col`:return r?`$`+e:e;case`row`:return i?e.slice(0,n)+`$`+e.slice(n):e;case`colrow`:return!i||!r?`$`+e:`$`+e.slice(0,n)+`$`+e.slice(n);case`none`:return e}}function Zv(e){return ey(e)?`colrow`:Qv(e)?`col`:$v(e)?`row`:`none`}function Qv(e){return e.startsWith(`$`)}function $v(e){return e.includes(`$`,1)}function ey(e){return e.startsWith(`$`)&&e.length>1&&e.slice(1).includes(`$`)}function ty(e,t,n){let r=(t.startsWith(`=`)?Kv(t,n):[]).filter(t=>t.start<=e.start&&t.end>=e.start||t.start>=e.start&&t.start<e.end),i=r.filter(e=>e.type===`REFERENCE`);if(i.length===0)return;let a=r.map(qv).map(e=>e.value).join(``),o=r[0].start,s=r[r.length-1].end,c=t.slice(0,o)+a+t.slice(s),l=c.length-t.length,u={start:i[0].start,end:i[i.length-1].end+l};return i.length===1&&e.start===e.end&&(u.start=u.end),{content:c,selection:u}}var ny=l({CELL:()=>iy,ISBLANK:()=>fy,ISERR:()=>ay,ISERROR:()=>oy,ISLOGICAL:()=>sy,ISNA:()=>cy,ISNONTEXT:()=>ly,ISNUMBER:()=>uy,ISTEXT:()=>dy,NA:()=>py});let ry=[`address`,`col`,`contents`,`format`,`row`,`type`],iy={description:O(`Gets information about a cell.`),args:[W(`info_type (string)`,O(`The type of information requested. Can be one of %s`,ry.join(`, `))),W(`reference (meta)`,O(`The reference to the cell.`))],compute:function(e,t){let n=I(e).toLowerCase();N(()=>ry.includes(n),O(`The info_type should be one of %s.`,ry.join(`, `)));let r=this.__originSheetId,i=I(t),{sheetName:a,xc:o}=ac(i.includes(`:`)?i.split(`:`)[0]:i);a=a===this.getters.getSheetName(r)?void 0:a;let s=oc(a,Yv(o,`colrow`)),c=this.getters.getRangeFromSheetXC(r,s);switch(n){case`address`:return this.getters.getRangeString(c,r);case`col`:return c.zone.left+1;case`contents`:{let e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top};return this.getters.getEvaluatedCell(e).value}case`format`:{let 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`:{let e={sheetId:c.sheetId,col:c.zone.left,row:c.zone.top},t=this.getters.getEvaluatedCell(e).type;return t===`empty`?`b`:t===`text`?`l`:`v`}}return``},isExported:!0},ay={description:O(`Whether a value is an error other than #N/A.`),args:[W(`value (any)`,O(`The value to be verified as an error type.`))],compute:function(e){let t=e?.value;return P(t)&&t!==j.NotAvailable},isExported:!0},oy={description:O(`Whether a value is an error.`),args:[W(`value (any)`,O(`The value to be verified as an error type.`))],compute:function(e){let t=e?.value;return P(t)},isExported:!0},sy={description:O("Whether a value is `true` or `false`."),args:[W(`value (any)`,O(`The value to be verified as a logical TRUE or FALSE.`))],compute:function(e){return typeof e?.value==`boolean`},isExported:!0},cy={description:O(`Whether a value is the error #N/A.`),args:[W(`value (any)`,O(`The value to be verified as an error type.`))],compute:function(e){return e?.value===j.NotAvailable},isExported:!0},ly={description:O(`Whether a value is non-textual.`),args:[W(`value (any)`,O(`The value to be checked.`))],compute:function(e){return!dy.compute.bind(this)(e)},isExported:!0},uy={description:O(`Whether a value is a number.`),args:[W(`value (any)`,O(`The value to be verified as a number.`))],compute:function(e){return typeof e?.value==`number`},isExported:!0},dy={description:O(`Whether a value is text.`),args:[W(`value (any)`,O(`The value to be verified as text.`))],compute:function(e){return typeof e?.value==`string`&&P(e?.value)===!1},isExported:!0},fy={description:O(`Whether the referenced cell is empty`),args:[W(`value (any)`,O(`Reference to the cell that will be checked for emptiness.`))],compute:function(e){return e?.value===null},isExported:!0},py={description:O(`Returns the error value #N/A.`),args:[],compute:function(){return{value:j.NotAvailable}},isExported:!0};var my=l({AND:()=>hy,FALSE:()=>gy,IF:()=>_y,IFERROR:()=>vy,IFNA:()=>yy,IFS:()=>by,NOT:()=>xy,OR:()=>Sy,SWITCH:()=>Cy,TRUE:()=>wy,XOR:()=>Ty});let hy={description:O("Logical `and` operator."),args:[W(`logical_expression1 (boolean, range<boolean>)`,O(`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.`)),W(`logical_expression2 (boolean, range<boolean>, repeating)`,O(`More expressions that represent logical values.`))],compute:function(...e){let{result:t,foundBoolean:n}=eu(e);return N(()=>n,O(`[[FUNCTION_NAME]] has no valid input data.`)),t},isExported:!0},gy={description:O("Logical value `false`."),args:[],compute:function(){return!1},isExported:!0},_y={description:O(`Returns value depending on logical expression.`),args:[W(`logical_expression (boolean, range<boolean>)`,O(`An expression or reference to a cell containing an expression that represents some logical value, i.e. TRUE or FALSE.`)),W(`value_if_true (any, range)`,O(`The value the function returns if logical_expression is TRUE.`)),W(`value_if_false (any, range, default=FALSE)`,O(`The value the function returns if logical_expression is FALSE.`))],compute:function(e,t,n){if(uu(e))return $a(_y.compute,[e,t,n]);let r=L(cu(e))?t:n;return uu(r)||(r=cu(r)),r===void 0?{value:``}:!A(r)&&r.value===null?{...r,value:``}:r},isExported:!0},vy={description:O(`Value if it is not an error, otherwise 2nd argument.`),args:[W(`value (any, range)`,O(`The value to return if value itself is not an error.`)),W(`value_if_error (any, range, default="empty")`,O(`The value the function returns if value is an error.`))],compute:function(e,t){if(uu(e))return $a(vy.compute,[e,t]);let n=P(cu(e)?.value)?t:e;return uu(n)||(n=cu(n)),n===void 0?{value:``}:!A(n)&&n.value===null?{...n,value:``}:n},isExported:!0},yy={description:O(`Value if it is not an #N/A error, otherwise 2nd argument.`),args:[W(`value (any, range)`,O(`The value to return if value itself is not #N/A an error.`)),W(`value_if_error (any, range, default="empty")`,O(`The value the function returns if value is an #N/A error.`))],compute:function(e,t){if(uu(e))return $a(yy.compute,[e,t]);let n=cu(e)?.value===j.NotAvailable?t:e;return uu(n)||(n=cu(n)),n===void 0?{value:``}:!A(n)&&n.value===null?{...n,value:``}:n},isExported:!0},by={description:O(`Returns a value depending on multiple logical expressions.`),args:[W(`condition1 (boolean, range<boolean>)`,O(`The first condition to be evaluated. This can be a boolean, a number, an array, or a reference to any of those.`)),W(`value1 (any, range)`,O(`The returned value if condition1 is TRUE.`)),W(`condition2 (boolean, any, range, repeating)`,O(`Additional conditions to be evaluated if the previous ones are FALSE.`)),W(`value2 (any, range, repeating)`,O(`Additional values to be returned if their corresponding conditions are TRUE.`))],compute:function(...e){for(N(()=>e.length%2==0,O(`Wrong number of arguments. Expected an even number of arguments.`));e.length>0;){if(uu(e[0]))return $a(by.compute,e);let t=L(cu(e.shift())),n=e.shift();if(t)return uu(n)||(n=cu(n)),n===void 0?{value:``}:!A(n)&&n.value===null?{...n,value:``}:n}return new M(O(`No match.`))},isExported:!0},xy={description:O(`Returns opposite of provided logical value.`),args:[W(`logical_expression (boolean)`,O(`An expression or reference to a cell holding an expression that represents some logical value.`))],compute:function(e){return!L(e)},isExported:!0},Sy={description:O("Logical `or` operator."),args:[W(`logical_expression1 (boolean, range<boolean>)`,O(`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.`)),W(`logical_expression2 (boolean, range<boolean>, repeating)`,O(`More expressions that evaluate to logical values.`))],compute:function(...e){let{result:t,foundBoolean:n}=tu(e);return N(()=>n,O(`[[FUNCTION_NAME]] has no valid input data.`)),t},isExported:!0},Cy={description:O(`Returns a value by comparing cases to an expression.`),args:[W(`expression (number, boolean, string)`,O(`The value to be checked.`)),W(`case1 (number, boolean, string)`,O(`The first case to be checked against expression.`)),W(`value1 (any)`,O(`The corresponding value to be returned if case1 matches expression.`)),W(`case2 (any, repeating)`,O(`Additional cases to try if the previous ones don't match expression.`)),W(`value2 (any, repeating)`,O(`Additional values to be returned if their corresponding cases match expression.`)),W(`default (any, default="empty")`,O(`An optional default value to be returned if none of the cases match expression.`))],compute:function(e,...t){let n=t.length%2==0?Da(e):t.pop();for(let n=0;n<t.length;n+=2){let r=t[n];if(r&&P(r.value))return r;if(e?.value===r?.value)return t[n+1]||{value:0}}return n||{value:0}},isExported:!0},wy={description:O("Logical value `true`."),args:[],compute:function(){return!0},isExported:!0},Ty={description:O("Logical `xor` operator."),args:[W(`logical_expression1 (boolean, range<boolean>)`,O(`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.`)),W(`logical_expression2 (boolean, range<boolean>, repeating)`,O(`More expressions that evaluate to logical values.`))],compute:function(...e){let t=!1,n=!1;return to(e,e=>(t=!0,n=n?!e:e,!0)),N(()=>t,O(`[[FUNCTION_NAME]] has no valid input data.`)),n},isExported:!0};function Ey(e,t){let n=t.getPivotId(e);if(!n)throw new M(O(`There is no pivot with id "%s"`,e));return n}function Dy(e,t,n){let{measures:r}=n.getPivotCoreDefinition(e);if(!r.find(e=>e.id===t))throw new M(O(`The argument %s is not a valid measure. Here are the measures: %s`,t,`(${r.map(e=>e.id).join(`, `)})`))}function Oy(e){if(e.length%2!=0)throw new M(O(`Function PIVOT takes an even number of arguments.`))}function ky(e,t,n){let r=[],i=e.getters.getPivotCoreDefinition(t);if(i.type===`SPREADSHEET`&&i.dataSet){let{sheetId:t,zone:n}=i.dataSet,a=cr(n),o=e.getters.getRangeFromSheetXC(t,a);if(o===void 0||o.invalidXc||o.invalidSheetName)throw new xa;if(e.__originCellPosition&&o.sheetId===e.__originSheetId&&yr(E(e.__originCellPosition),n))throw new ba;r.push(o)}for(let i of n)i.computedBy&&r.push(...e.getters.getMeasureFullDependencies(t,i));let a=e.__originCellPosition;a&&r.length&&(e.updateDependencies?.(a),e.addDependencies?.(a,r))}var Ay=l({ADDRESS:()=>jy,COLUMN:()=>My,COLUMNS:()=>Ny,HLOOKUP:()=>Py,INDEX:()=>Fy,INDIRECT:()=>Iy,LOOKUP:()=>Ly,MATCH:()=>Ry,OFFSET:()=>qy,PIVOT:()=>Ky,PIVOT_HEADER:()=>Gy,PIVOT_VALUE:()=>Wy,ROW:()=>zy,ROWS:()=>By,VLOOKUP:()=>Vy,XLOOKUP:()=>Uy});let jy={description:O(`Returns a cell reference as a string. `),args:[W(`row (number)`,O(`The row number of the cell reference. `)),W(`column (number)`,O(`The column number (not name) of the cell reference. A is column number 1. `)),W(`absolute_relative_mode (number, default=1)`,O(`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).`)),W(`use_a1_notation (boolean, default=TRUE)`,O(`A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).`)),W(`sheet (string, optional)`,O(`A string indicating the name of the sheet into which the address points.`))],compute:function(e,t,n={value:1},r={value:!0},i){let a=Fa(e,this.locale),o=Fa(t,this.locale);Ia(a),Ia(o);let s=Fa(n,this.locale);N(()=>[1,2,3,4].includes(s),ka(1,4,s));let c=L(r),l;if(c){let e={rowFixed:[1,2].includes(s),colFixed:[1,3].includes(s)};l=T(o-1,a-1,e)}else l=([1,2].includes(s)?`R${a}`:`R[${a}]`)+([1,3].includes(s)?`C${o}`:`C[${o}]`);return i===void 0?l:oc(I(i),l)},isExported:!0},My={description:O(`Column number of a specified cell.`),args:[W(`cell_reference (meta, default='this cell')`,O(`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(P(e?.value))return e;if(e===void 0)return N(()=>this.__originCellPosition?.col!==void 0,`In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.`),this.__originCellPosition.col+1;let t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.left===t.right?t.left+1:Ya(t.right-t.left+1,1,(e,n)=>({value:t.left+e+1}))},isExported:!0},Ny={description:O(`Number of columns in a specified array or range.`),args:[W(`range (meta)`,O(`The range whose column count will be returned.`))],compute:function(e){if(P(e?.value))return e;let t=ar(e.value);return t.right-t.left+1},isExported:!0},Py={description:O(`Horizontal lookup`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`range (any, range)`,O(`The range to consider for the search. The first row in the range is searched for the key specified in search_key.`)),W(`index (number)`,O(`The row index of the value to be returned, where the first row in range is numbered 1.`)),W(`is_sorted (boolean, default=true)`,O(`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,n,r={value:!0}){let i=Math.trunc(F(n?.value,this.locale)),a=z(t);N(()=>1<=i&&i<=a[0].length,O(`[[FUNCTION_NAME]] evaluates to an out of bounds range.`));let o=(e,t)=>e[t][0].value,s=a[L(r.value)?oo(a,e,`nextSmaller`,`asc`,a.length,o):so(a,e,`wildcard`,a.length,o,this.lookupCaches)];return s===void 0?Da(e):s[i-1]},isExported:!0},Fy={description:O(`Returns the content of a cell, specified by row and column offset.`),args:[W(`reference (any, range)`,O(`The range of cells from which the values are returned.`)),W(`row (number, default=0)`,O(`The index of the row to be returned from within the reference range of cells.`)),W(`column (number, default=0)`,O(`The index of the column to be returned from within the reference range of cells.`))],compute:function(e,t={value:0},n={value:0}){let r=z(e),i=F(t.value,this.locale),a=F(n.value,this.locale);return N(()=>a>=0&&a-1<r.length&&i>=0&&i-1<r[0].length,O(`Index out of range.`)),i===0&&a===0?r:i===0?[r[a-1]]:a===0?r.map(e=>[e[i-1]]):r[a-1][i-1]},isExported:!0},Iy={description:O(`Returns the content of a cell, specified by a string.`),args:[W(`reference (string)`,O(`The range of cells from which the values are returned.`)),W(`use_a1_notation (boolean, default=TRUE)`,O(`A boolean indicating whether to use A1 style notation (TRUE) or R1C1 style notation (FALSE).`))],compute:function(e,t={value:!0}){let n=e?.value?.toString();if(!n)return new xa(O(`Reference should be defined.`));if(!L(t))return new M(O(`R1C1 notation is not supported.`));let r=this.__originSheetId,i=this.__originCellPosition;i&&this.updateDependencies?.(i);let a=this.getters.getRangeFromSheetXC(r,n);if(a===void 0||a.invalidXc||a.invalidSheetName)return new xa;i&&this.addDependencies?.(i,[a]);let o=[];for(let e=a.zone.left;e<=a.zone.right;e++){let t=[];for(let n=a.zone.top;n<=a.zone.bottom;n++){let r={sheetId:a.sheetId,col:e,row:n};t.push(this.getters.getEvaluatedCell(r))}o.push(t)}return o.length===1&&o[0].length===1?o[0][0]:o},isExported:!0},Ly={description:O(`Look up a value.`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`search_array (any, range)`,O(`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.`)),W(`result_range (any, range, optional)`,O(`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,n){let r=z(t),i=z(n),a=r.length,o=r[0].length,s=o>=a,c=oo(r,e,`nextSmaller`,`asc`,s?o:a,s?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value);return c===-1||s&&r[0][c]===void 0||!s&&r[c][o-1]===void 0?Da(e):i[0].length===0?s?r[a-1][c]:r[c][o-1]:(a=i.length,o=i[0].length,N(()=>a===1||o===1,O(`The result_range must be a single row or a single column.`)),a>1?(N(()=>c<=a-1,O(`[[FUNCTION_NAME]] evaluates to an out of range row value %s.`,(c+1).toString())),i[c][0]):(N(()=>c<=o-1,O(`[[FUNCTION_NAME]] evaluates to an out of range column value %s.`,(c+1).toString())),i[0][c]))},isExported:!0},Ry={description:O(`Position of item in range that matches value.`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`range (any, range)`,O(`The one-dimensional array to be searched.`)),W(`search_type (number, default=1)`,O(`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,n={value:1}){let r=F(n,this.locale),i=z(t),a=i.length,o=i[0].length;N(()=>a===1||o===1,O(`The range must be a single row or a single column.`));let s=-1,c=a===1?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,l=a===1?i[0].length:i.length;switch(r=Math.sign(r),r){case 1:s=oo(i,e,`nextSmaller`,`asc`,l,c);break;case 0:s=so(i,e,`wildcard`,l,c,this.lookupCaches);break;case-1:s=oo(i,e,`nextGreater`,`desc`,l,c);break}return a===1&&i[0][s]===void 0||a!==1&&i[s]===void 0?Da(e):s+1},isExported:!0},zy={description:O(`Row number of a specified cell.`),args:[W(`cell_reference (meta, default='this cell')`,O(`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(P(e?.value))return e;if(e===void 0)return N(()=>this.__originCellPosition?.row!==void 0,`In this context, the function [[FUNCTION_NAME]] needs to have a cell or range in parameter.`),this.__originCellPosition.row+1;let t=this.getters.getRangeFromSheetXC(this.getters.getActiveSheetId(),e.value).zone;return t.top===t.bottom?t.top+1:Ya(1,t.bottom-t.top+1,(e,n)=>({value:t.top+n+1}))},isExported:!0},By={description:O(`Number of rows in a specified array or range.`),args:[W(`range (meta)`,O(`The range whose row count will be returned.`))],compute:function(e){if(P(e?.value))return e;let t=ar(e.value);return t.bottom-t.top+1},isExported:!0},Vy={description:O(`Vertical lookup.`),args:[W(`search_key (string, number, boolean)`,O(`The value to search for. For example, 42, 'Cats', or I24.`)),W(`range (any, range)`,O(`The range to consider for the search. The first column in the range is searched for the key specified in search_key.`)),W(`index (number)`,O(`The column index of the value to be returned, where the first column in range is numbered 1.`)),W(`is_sorted (boolean, default=true)`,O(`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,n,r={value:!0}){let i=Math.trunc(F(n?.value,this.locale)),a=z(t);N(()=>1<=i&&i<=a.length,O(`[[FUNCTION_NAME]] evaluates to an out of bounds range.`));let o=(e,t)=>e[0][t].value,s=L(r.value)?oo(a,e,`nextSmaller`,`asc`,a[0].length,o):so(a,e,`wildcard`,a[0].length,o,this.lookupCaches),c=a[i-1][s];return c===void 0?Da(e):c},isExported:!0},Hy={0:`strict`,1:`nextGreater`,"-1":`nextSmaller`,2:`wildcard`},Uy={description:O(`Search a range for a match and return the corresponding item from a second range.`),args:[W(`search_key (string,number,boolean)`,O(`The value to search for.`)),W(`lookup_range (any, range)`,O(`The range to consider for the search. Should be a single column or a single row.`)),W(`return_range (any, range)`,O(`The range containing the return value. Should have the same dimensions as lookup_range.`)),W(`if_not_found (any, optional)`,O(`If a valid match is not found, return this value.`)),W(`match_mode (any, default=0)`,O(`(0) Exact match. (-1) Return next smaller item if no match. (1) Return next greater item if no match. (2) Wildcard match.`)),W(`search_mode (any, default=1)`,O(`(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,n,r,i={value:0},a={value:1}){let o=Math.trunc(F(i.value,this.locale)),s=Math.trunc(F(a.value,this.locale)),c=z(t),l=z(n);N(()=>c.length===1||c[0].length===1,O(`lookup_range should be either a single row or single column.`)),N(()=>[-1,1,-2,2].includes(s),O(`search_mode should be a value in [-1, 1, -2, 2].`)),N(()=>[-1,0,1,2].includes(o),O(`match_mode should be a value in [-1, 0, 1, 2].`));let u=c.length===1?`col`:`row`;N(()=>!(o===2&&[-2,2].includes(s)),O(`the search and match mode combination is not supported for XLOOKUP evaluation.`)),N(()=>u===`col`?l[0].length===c[0].length:l.length===c.length,O(`return_range should have the same dimensions as lookup_range.`));let d=u===`col`?(e,t)=>e[0][t].value:(e,t)=>e[t][0].value,f=u===`col`?c[0].length:c.length,p=Hy[o],m=s===-1,h=s===2||s===-2?oo(c,e,p,s===2?`asc`:`desc`,f,d):so(c,e,p,f,d,this.lookupCaches,m);return h===-1?r===void 0?Da(e):[[r]]:u===`col`?l.map(e=>[e[h]]):[l[h]]},isExported:!0},Wy={description:O(`Get the value from a pivot.`),args:[W(`pivot_id (number,string)`,O(`ID of the pivot.`)),W(`measure_name (string)`,O(`Name of the measure.`)),W(`domain_field_name (string,repeating)`,O(`Field name.`)),W(`domain_value (number,string,boolean,repeating)`,O(`Value.`))],compute:function(e,t,...n){let r=I(e),i=I(t),a=Ey(r,this.getters);Dy(a,i,this.getters),Oy(n);let o=this.getters.getPivot(a),s=this.getters.getPivotCoreDefinition(a);ky(this,a,s.measures.filter(e=>e.id===i)),o.init({reload:o.needsReevaluation});let c=o.assertIsValid({throwOnError:!1});if(c)return c;if(!o.areDomainArgsFieldsValid(n)){let e=O(`Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.`,`=PIVOT(${r})`);return{value:j.GenericError,message:O(`Dimensions don't match the pivot definition`)+`. `+e}}let l=o.parseArgsToPivotDomain(n);return this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(a)?.trackValue(i,l),o.getPivotCellValueAndFormat(i,l)}},Gy={description:O(`Get the header of a pivot.`),args:[W(`pivot_id (number,string)`,O(`ID of the pivot.`)),W(`domain_field_name (string,repeating)`,O(`Field name.`)),W(`domain_value (number,string,value,repeating)`,O(`Value.`))],compute:function(e,...t){let n=I(e),r=Ey(n,this.getters);Oy(t);let i=this.getters.getPivot(r);ky(this,r,[]),i.init({reload:i.needsReevaluation});let a=i.assertIsValid({throwOnError:!1});if(a)return a;if(!i.areDomainArgsFieldsValid(t)){let e=O(`Consider using a dynamic pivot formula: %s. Or re-insert the static pivot from the Data menu.`,`=PIVOT(${n})`);return{value:j.GenericError,message:O(`Dimensions don't match the pivot definition`)+`. `+e}}let o=i.parseArgsToPivotDomain(t);this.getters.getActiveSheetId()===this.__originSheetId&&this.getters.getPivotPresenceTracker(r)?.trackHeader(o);let s=o.at(-1);if(s?.field===`measure`)return i.getPivotMeasureValue(I(s.value),o);let{value:c,format:l}=i.getPivotHeaderValueAndFormat(o);return{value:c,format:!s||s.field===`measure`||s.value===`false`?void 0:l}}},Ky={description:O(`Get a pivot table.`),args:[W(`pivot_id (string)`,O(`ID of the pivot.`)),W(`row_count (number, optional)`,O(`number of rows`)),W(`include_total (boolean, default=TRUE)`,O(`Whether to include total/sub-totals or not.`)),W(`include_column_titles (boolean, default=TRUE)`,O(`Whether to include the column titles or not.`)),W(`column_count (number, optional)`,O(`number of columns`))],compute:function(e,t={value:1e4},n={value:!0},r={value:!0},i={value:Number.MAX_VALUE}){let a=I(e),o=F(t,this.locale);if(o<0)return new M(O(`The number of rows must be positive.`));let s=F(i,this.locale);if(s<0)return new M(O(`The number of columns must be positive.`));let c=L(r),l=L(n),u=Ey(a,this.getters),d=this.getters.getPivot(u),f=this.getters.getPivotCoreDefinition(u);ky(this,u,f.measures),d.init({reload:d.needsReevaluation});let p=d.assertIsValid({throwOnError:!1});if(p)return p;let m=d.getTableStructure(),h=m.getPivotCells(l,c),g=c?m.columns.length:0,_=this.getters.getPivotDisplayName(u),v=Math.min(g+o,h[0].length);if(v===0)return[[{value:_}]];let y=Math.min(1+s,h.length),ee=[];for(let e of S(0,y)){ee[e]=[];for(let t of S(0,v)){let n=h[e][t];switch(n.type){case`EMPTY`:ee[e].push({value:``});break;case`HEADER`:let t=d.getPivotHeaderValueAndFormat(n.domain);ee[e].push(Dd(d,n.domain,t));break;case`MEASURE_HEADER`:ee[e].push(d.getPivotMeasureValue(n.measure,n.domain));break;case`VALUE`:ee[e].push(d.getPivotCellValueAndFormat(n.measure,n.domain));break}}}return c&&(ee[0][0]={value:_}),ee}},qy={description:O(`Returns a range reference shifted by a specified number of rows and columns from a starting cell reference.`),args:[W(`cell_reference (meta)`,O(`The starting point from which to count the offset rows and columns.`)),W(`offset_rows (number)`,O(`The number of rows to offset by.`)),W(`offset_columns (number)`,O(`The number of columns to offset by.`)),W(`height (number, default='height of cell_reference')`,O(`The number of rows of the range to return starting at the offset target.`)),W(`width (number, default='width of cell_reference')`,O(`The number of columns of the range to return starting at the offset target.`))],compute:function(e,t,n,r,i){if(P(e?.value))return e;let a=e?.value;if(!a)return new M(`In this context, the function OFFSET needs to have a cell or range in parameter.`);let o=ar(a),s=o.bottom-o.top+1,c=o.right-o.left+1;if(r){let e=F(r,this.locale);jf(O(`Height value is %(_height)s. It should be greater than or equal to 1.`,{_height:e}),e),s=e}if(i){let e=F(i,this.locale);jf(O(`Width value is %(_width)s. It should be greater than or equal to 1.`,{_width:e}),e),c=e}let{sheetName:l}=ac(a),u=l&&this.getters.getSheetIdByName(l)||this.getters.getActiveSheetId(),d=F(t,this.locale),f=F(n,this.locale),p=this.__originCellPosition;p&&this.updateDependencies?.(p);let m=o.left+f,h=o.top+d;if(m<0||h<0)return new xa(O(`OFFSET evaluates to an out of bounds range.`));let g={left:m,top:h,right:m+c-1,bottom:h+s-1},_=this.getters.getRangeFromZone(u,g);return _.invalidXc||_.invalidSheetName?new xa:(p&&this.addDependencies?.(p,[_]),Ya(c,s,(e,t)=>this.getters.getEvaluatedCell({sheetId:u,col:m+e,row:h+t})))}};var Jy=l({ADD:()=>Yy,CONCAT:()=>Xy,DIVIDE:()=>Zy,EQ:()=>tb,GT:()=>rb,GTE:()=>ib,LT:()=>ab,LTE:()=>ob,MINUS:()=>sb,MULTIPLY:()=>cb,NE:()=>lb,POW:()=>ub,UMINUS:()=>db,UNARY_PERCENT:()=>fb,UPLUS:()=>pb});let Yy={description:O(`Sum of two numbers.`),args:[W(`value1 (number)`,O(`The first addend.`)),W(`value2 (number)`,O(`The second addend.`))],compute:function(e,t){return{value:F(e,this.locale)+F(t,this.locale),format:e?.format||t?.format}}},Xy={description:O(`Concatenation of two values.`),args:[W(`value1 (string)`,O(`The value to which value2 will be appended.`)),W(`value2 (string)`,O(`The value to append to value1.`))],compute:function(e,t){return I(e)+I(t)},isExported:!0},Zy={description:O(`One number divided by another.`),args:[W(`dividend (number)`,O(`The number to be divided.`)),W(`divisor (number)`,O(`The number to divide by.`))],compute:function(e,t){let n=F(t,this.locale);return N(()=>n!==0,O(`The divisor must be different from zero.`),j.DivisionByZero),{value:F(e,this.locale)/n,format:e?.format||t?.format}}};function Qy(e){return e===void 0||e.value===null}let $y={number:0,string:``,boolean:!1};function eb(e,t,n=2e-16){return Math.abs(e-t)<n}let tb={description:O(`Equal.`),args:[W(`value1 (string, number, boolean)`,O(`The first value.`)),W(`value2 (string, number, boolean)`,O(`The value to test against value1 for equality.`))],compute:function(e,t){if(P(e?.value))return e;if(P(t?.value))return t;let n=Qy(e)?$y[typeof t?.value]:e?.value,r=Qy(t)?$y[typeof e?.value]:t?.value;return typeof n==`string`&&(n=n.toUpperCase()),typeof r==`string`&&(r=r.toUpperCase()),typeof n==`number`&&typeof r==`number`?{value:eb(n,r)}:{value:n===r}}};function nb(e,t,n){if(P(e?.value))return e;if(P(t?.value))return t;let r=Qy(e)?$y[typeof t?.value]:e?.value,i=Qy(t)?$y[typeof e?.value]:t?.value;typeof r!=`number`&&(r=I(r).toUpperCase()),typeof i!=`number`&&(i=I(i).toUpperCase());let a=typeof r,o=typeof i;return a===`string`&&o===`number`?{value:!0}:o===`string`&&a===`number`?{value:!1}:{value:n(r,i)}}let rb={description:O(`Strictly greater than.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being greater than value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){return nb(e,t,(e,t)=>typeof e==`number`&&typeof t==`number`?!eb(e,t)&&e>t:e>t)}},ib={description:O(`Greater than or equal to.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being greater than or equal to value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){return nb(e,t,(e,t)=>typeof e==`number`&&typeof t==`number`?eb(e,t)||e>t:e>=t)}},ab={description:O(`Less than.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being less than value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){let n=ib.compute.bind(this)(e,t);return P(n.value)?n:{value:!n.value}}},ob={description:O(`Less than or equal to.`),args:[W(`value1 (number, string, boolean)`,O(`The value to test as being less than or equal to value2.`)),W(`value2 (number, string, boolean)`,O(`The second value.`))],compute:function(e,t){let n=rb.compute.bind(this)(e,t);return P(n.value)?n:{value:!n.value}}},sb={description:O(`Difference of two numbers.`),args:[W(`value1 (number)`,O(`The minuend, or number to be subtracted from.`)),W(`value2 (number)`,O(`The subtrahend, or number to subtract from value1.`))],compute:function(e,t){return{value:F(e,this.locale)-F(t,this.locale),format:e?.format||t?.format}}},cb={description:O(`Product of two numbers`),args:[W(`factor1 (number)`,O(`The first multiplicand.`)),W(`factor2 (number)`,O(`The second multiplicand.`))],compute:function(e,t){return{value:F(e,this.locale)*F(t,this.locale),format:e?.format||t?.format}}},lb={description:O(`Not equal.`),args:[W(`value1 (string, number, boolean)`,O(`The first value.`)),W(`value2 (string, number, boolean)`,O(`The value to test against value1 for inequality.`))],compute:function(e,t){let n=tb.compute.bind(this)(e,t);return P(n.value)?n:{value:!n.value}}},ub={description:O(`A number raised to a power.`),args:[W(`base (number)`,O(`The number to raise to the exponent power.`)),W(`exponent (number)`,O(`The exponent to raise base to.`))],compute:function(e,t){return Yp.compute.bind(this)(e,t)}},db={description:O(`A number with the sign reversed.`),args:[W(`value (number)`,O(`The number to have its sign reversed. Equivalently, the number to multiply by -1.`))],compute:function(e){return{value:-F(e,this.locale),format:e?.format}}},fb={description:O(`Value interpreted as a percentage.`),args:[W(`percentage (number)`,O(`The value to interpret as a percentage.`))],compute:function(e){return F(e,this.locale)/100}},pb={description:O(`A specified number, unchanged.`),args:[W(`value (any)`,O(`The number to return.`))],compute:function(e={value:null}){return e}},G=e=>({transform:t=>t*e,inverseTransform:t=>t/e}),mb={transform:e=>e,inverseTransform:e=>e},hb=1e-10,gb=.0254,_b=gb/72,vb=.3048,yb=.9144,bb=1609.34,xb=1852,Sb=946073047258e4,Cb={g:{...mb,category:`weight`},u:{...G(166053e-29),category:`weight`},grain:{...G(.0647989),category:`weight`},ozm:{...G(28.3495),category:`weight`},lbm:{...G(453.592),category:`weight`},stone:{...G(6350.29),category:`weight`},sg:{...G(14593.90294),category:`weight`},cwt:{...G(45359.237),category:`weight`},uk_cwt:{...G(50802.3),category:`weight`},ton:{...G(907184.74),category:`weight`},uk_ton:{...G(1016046.9),category:`weight`},m:{...mb,category:`distance`},km:{...G(1e3),category:`distance`},ang:{...G(hb),category:`distance`},Picapt:{...G(_b),category:`distance`},pica:{...G(gb/6),category:`distance`},in:{...G(gb),category:`distance`},ft:{...G(vb),category:`distance`},yd:{...G(yb),category:`distance`},ell:{...G(1.143),category:`distance`},mi:{...G(bb),category:`distance`},survey_mi:{...G(1609.34),category:`distance`},Nmi:{...G(xb),category:`distance`},ly:{...G(Sb),category:`distance`},parsec:{...G(0x6da012f95c9fd0),category:`distance`},sec:{...mb,category:`time`},min:{...G(60),category:`time`},hr:{...G(3600),category:`time`},day:{...G(86400),category:`time`},yr:{...G(31556952),category:`time`},Pa:{...mb,category:`pressure`},bar:{...G(1e5),category:`pressure`},mmHg:{...G(133.322),category:`pressure`},Torr:{...G(133.322),category:`pressure`},psi:{...G(6894.76),category:`pressure`},atm:{...G(101325),category:`pressure`},N:{...mb,category:`force`},dyn:{...G(1e-5),category:`force`},pond:{...G(.00980665),category:`force`},lbf:{...G(4.44822),category:`force`},J:{...mb,category:`energy`},eV:{...G(160218e-24),category:`energy`},e:{...G(1e-7),category:`energy`},flb:{...G(1.3558179483),category:`energy`},c:{...G(4.184),category:`energy`},cal:{...G(4.1868),category:`energy`},BTU:{...G(1055.06),category:`energy`},Wh:{...G(3600),category:`energy`},HPh:{...G(2684520),category:`energy`},W:{...mb,category:`power`},PS:{...G(735.499),category:`power`},HP:{...G(745.7),category:`power`},T:{...mb,category:`magnetism`},ga:{...G(1e-4),category:`magnetism`},K:{...mb,category:`temperature`},C:{transform:e=>e+273.15,inverseTransform:e=>e-273.15,category:`temperature`},F:{transform:e=>(e-32)*5/9+273.15,inverseTransform:e=>(e-273.15)*9/5+32,category:`temperature`},Rank:{...G(5/9),category:`temperature`},Reau:{transform:e=>e*1.25+273.15,inverseTransform:e=>(e-273.15)/1.25,category:`temperature`},"m^3":{...mb,category:`volume`,order:3},"ang^3":{...G(hb**3),category:`volume`,order:3},"Picapt^3":{...G(_b**3),category:`volume`,order:3},tsp:{...G(492892e-11),category:`volume`},tspm:{...G(5e-6),category:`volume`},tbs:{...G(14786764825785619e-21),category:`volume`},"in^3":{...G(gb**3),category:`volume`,order:3},oz:{...G(295735295625e-16),category:`volume`},cup:{...G(237e-6),category:`volume`},pt:{...G(.0004731765),category:`volume`},uk_pt:{...G(568261e-9),category:`volume`},qt:{...G(.0009463529),category:`volume`},l:{...G(.001),category:`volume`},uk_qt:{...G(.0011365225),category:`volume`},gal:{...G(.0037854118),category:`volume`},uk_gal:{...G(.00454609),category:`volume`},"ft^3":{...G(vb**3),category:`volume`,order:3},bushel:{...G(.0352390704),category:`volume`},barrel:{...G(.158987295),category:`volume`},"yd^3":{...G(yb**3),category:`volume`,order:3},MTON:{...G(1.13267386368),category:`volume`},GRT:{...G(2.83168),category:`volume`},"mi^3":{...G(bb**3),category:`volume`,order:3},"Nmi^3":{...G(xb**3),category:`volume`,order:3},"ly^3":{...G(Sb**3),category:`volume`,order:3},"m^2":{...mb,category:`area`,order:2},"ang^2":{...G(hb**2),category:`area`,order:2},"Picapt^2":{...G(_b**2),category:`area`,order:2},"in^2":{...G(gb**2),category:`area`,order:2},"ft^2":{...G(vb**2),category:`area`,order:2},"yd^2":{...G(yb**2),category:`area`,order:2},ar:{...G(100),category:`area`},Morgen:{...G(2500),category:`area`},uk_acre:{...G(4046.8564224),category:`area`},us_acre:{...G(4046.8726098743),category:`area`},ha:{...G(1e4),category:`area`},"mi^2":{...G(bb**2),category:`area`,order:2},"Nmi^2":{...G(xb**2),category:`area`,order:2},"ly^2":{...G(Sb**2),category:`area`,order:2},bit:{...mb,category:`information`},byte:{...G(8),category:`information`},"m/s":{...mb,category:`speed`},"m/hr":{...G(1/3600),category:`speed`},"km/hr":{...G(1/3.6),category:`speed`},mph:{...G(.44704),category:`speed`},kn:{...G(.5144444444),category:`speed`},admkn:{...G(.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`},Tb={"":1,Y:1e24,Z:1e21,E:0xde0b6b3a7640000,P:0x38d7ea4c68000,T:0xe8d4a51000,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:2**80,Zi:2**70,Ei:2**60,Pi:2**50,Ti:2**40,Gi:2**30,Mi:2**20,ki:2**10},Eb={weight:O(`Weight`),distance:O(`Distance`),time:O(`Time`),pressure:O(`Pressure`),force:O(`Force`),energy:O(`Energy`),power:O(`Power`),magnetism:O(`Magnetism`),temperature:O(`Temperature`),volume:O(`Volume`),area:O(`Area`),information:O(`Information`),speed:O(`Speed`)};function Db(e){return Eb[e]??``}function Ob(e){for(let[t,n]of Object.entries(Tb)){if(t&&!e.startsWith(t))continue;let r=e.slice(t.length),i=Cb[r];if(!i&&wb[r]&&(i=Cb[wb[r]]),i)return{...i,factor:i.order?n**+i.order:n}}}var kb=l({CONVERT:()=>Ab});let Ab={description:O(`Converts a numeric value to a different unit of measure.`),args:[W(`value (number)`,O(`the numeric value in start_unit to convert to end_unit`)),W(`start_unit (string)`,O(`The starting unit, the unit currently assigned to value`)),W(`end_unit (string)`,O(`The unit of measure into which to convert value`))],compute:function(e,t,n){let r=F(e,this.locale),i=I(t),a=I(n),o=Ob(i),s=Ob(a);return o?s?o.category===s.category?{value:s.inverseTransform(o.factor*o.transform(r))/s.factor,format:e?.format}:{value:j.GenericError,message:O(`Incompatible units of measure ('%s' vs '%s')`,Db(o.category),Db(s.category))}:{value:j.GenericError,message:O(`Invalid units of measure ('%s')`,a)}:{value:j.GenericError,message:O(`Invalid units of measure ('%s')`,i)}},isExported:!0};var jb=l({CHAR:()=>Nb,CLEAN:()=>Pb,CONCATENATE:()=>Fb,EXACT:()=>Ib,FIND:()=>Lb,JOIN:()=>Rb,LEFT:()=>zb,LEN:()=>Bb,LOWER:()=>Vb,MID:()=>Hb,PROPER:()=>Ub,REPLACE:()=>Wb,RIGHT:()=>Gb,SEARCH:()=>Kb,SPLIT:()=>qb,SUBSTITUTE:()=>Jb,TEXT:()=>Qb,TEXTJOIN:()=>Yb,TRIM:()=>Xb,UPPER:()=>Zb,VALUE:()=>$b});let Mb=/[A-Za-zÀ-ÖØ-öø-ÿ]+/g,Nb={description:O(`Gets character associated with number.`),args:[W(`table_number (number)`,O(`The number of the character to look up from the current Unicode table in decimal format.`))],compute:function(e){let t=Math.trunc(F(e,this.locale));return N(()=>t>=1,O(`The table_number (%s) is out of range.`,t.toString())),String.fromCharCode(t)},isExported:!0},Pb={description:O(`Remove non-printable characters from a piece of text.`),args:[W(`text (string)`,O(`The text whose non-printable characters are to be removed.`))],compute:function(e){let t=I(e),n=``;for(let e of t)e&&e.charCodeAt(0)>31&&(n+=e);return n},isExported:!0},Fb={description:O(`Appends strings to one another.`),args:[W(`string1 (string, range<string>)`,O(`The initial string.`)),W(`string2 (string, range<string>, repeating)`,O(`More strings to append in sequence.`))],compute:function(...e){return Ka(e,(e,t)=>e+I(t),``)},isExported:!0},Ib={description:O(`Tests whether two strings are identical.`),args:[W(`string1 (string)`,O(`The first string to compare.`)),W(`string2 (string)`,O(`The second string to compare.`))],compute:function(e,t){return I(e)===I(t)},isExported:!0},Lb={description:O(`First position of string found in text, case-sensitive.`),args:[W(`search_for (string)`,O(`The string to look for within text_to_search.`)),W(`text_to_search (string)`,O(`The text to search for the first occurrence of search_for.`)),W(`starting_at (number, default=1)`,O(`The character within text_to_search at which to start the search.`))],compute:function(e,t,n={value:1}){let r=I(e),i=I(t),a=F(n,this.locale);N(()=>i!==``,O(`The text_to_search must be non-empty.`)),N(()=>a>=1,O(`The starting_at (%s) must be greater than or equal to 1.`,a.toString()));let o=i.indexOf(r,a-1);return N(()=>o>=0,O(`In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.`,r.toString(),i)),o+1},isExported:!0},Rb={description:O(`Concatenates elements of arrays with delimiter.`),args:[W(`delimiter (string)`,O(`The character or string to place between each concatenated value.`)),W(`value_or_array1 (string, range<string>)`,O(`The value or values to be appended using delimiter.`)),W(`value_or_array2 (string, range<string>, repeating)`,O(`More values to be appended using delimiter.`))],compute:function(e,...t){let n=I(e);return Ka(t,(e,t)=>(e?e+n:``)+I(t),``)}},zb={description:O(`Substring from beginning of specified string.`),args:[W(`text (string)`,O(`The string from which the left portion will be returned.`)),W(`number_of_characters (number, optional)`,O(`The number of characters to return from the left side of string.`))],compute:function(e,...t){let n=t.length?F(t[0],this.locale):1;return N(()=>n>=0,O(`The number_of_characters (%s) must be positive or null.`,n.toString())),I(e).substring(0,n)},isExported:!0},Bb={description:O(`Length of a string.`),args:[W(`text (string)`,O(`The string whose length will be returned.`))],compute:function(e){return I(e).length},isExported:!0},Vb={description:O(`Converts a specified string to lowercase.`),args:[W(`text (string)`,O(`The string to convert to lowercase.`))],compute:function(e){return I(e).toLowerCase()},isExported:!0},Hb={description:O(`A segment of a string.`),args:[W(`text (string)`,O(`The string to extract a segment from.`)),W(`starting_at (number)`,O(`The index from the left of string from which to begin extracting. The first character in string has the index 1.`)),W(`extract_length (number)`,O(`The length of the segment to extract.`))],compute:function(e,t,n){let r=I(e),i=F(t,this.locale),a=F(n,this.locale);return N(()=>i>=1,O(`The starting_at argument (%s) must be positive greater than one.`,i.toString())),N(()=>a>=0,O(`The extract_length argument (%s) must be positive or null.`,a.toString())),r.slice(i-1,i+a-1)},isExported:!0},Ub={description:O(`Capitalizes each word in a specified string.`),args:[W(`text_to_capitalize (string)`,O(`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 I(e).replace(Mb,e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase())},isExported:!0},Wb={description:O(`Replaces part of a text string with different text.`),args:[W(`text (string)`,O(`The text, a part of which will be replaced.`)),W(`position (number)`,O(`The position where the replacement will begin (starting from 1).`)),W(`length (number)`,O(`The number of characters in the text to be replaced.`)),W(`new_text (string)`,O(`The text which will be inserted into the original text.`))],compute:function(e,t,n,r){let i=F(t,this.locale);N(()=>i>=1,O(`The position (%s) must be greater than or equal to 1.`,i.toString()));let a=I(e),o=F(n,this.locale),s=I(r);return a.substring(0,i-1)+s+a.substring(i-1+o)},isExported:!0},Gb={description:O(`A substring from the end of a specified string.`),args:[W(`text (string)`,O(`The string from which the right portion will be returned.`)),W(`number_of_characters (number, optional)`,O(`The number of characters to return from the right side of string.`))],compute:function(e,...t){let n=t.length?F(t[0],this.locale):1;N(()=>n>=0,O(`The number_of_characters (%s) must be positive or null.`,n.toString()));let r=I(e),i=r.length;return r.substring(i-n,i)},isExported:!0},Kb={description:O(`First position of string found in text, ignoring case.`),args:[W(`search_for (string)`,O(`The string to look for within text_to_search.`)),W(`text_to_search (string)`,O(`The text to search for the first occurrence of search_for.`)),W(`starting_at (number, default=1)`,O(`The character within text_to_search at which to start the search.`))],compute:function(e,t,n={value:1}){let r=I(e).toLowerCase(),i=I(t).toLowerCase(),a=F(n,this.locale);if(i===``)return{value:j.GenericError,message:O(`The text_to_search must be non-empty.`)};if(a<1)return{value:j.GenericError,message:O(`The starting_at (%s) must be greater than or equal to 1.`,a)};let o=i.indexOf(r,a-1);return o===-1?{value:j.GenericError,message:O(`In [[FUNCTION_NAME]] evaluation, cannot find '%s' within '%s'.`,r,i)}:{value:o+1}},isExported:!0},qb={description:O(`Split text by specific character delimiter(s).`),args:[W(`text (string)`,O(`The text to divide.`)),W(`delimiter (string)`,O(`The character or characters to use to split text.`)),W(`split_by_each (boolean, default=true})`,O(`Whether or not to divide text around each character contained in delimiter.`)),W(`remove_empty_text (boolean, default=true)`,O(`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,n={value:!0},r={value:!0}){let i=I(e),a=at(I(t)),o=L(n),s=L(r);N(()=>a.length>0,O(`The _delimiter (%s) must be not be empty.`,a));let c=o?RegExp(`[${a}]`,`g`):new RegExp(a,`g`),l=i.split(c);return s&&(l=l.filter(e=>e!==``)),Qa([l])},isExported:!1},Jb={description:O(`Replaces existing text with new text in a string.`),args:[W(`text_to_search (string)`,O(`The text within which to search and replace.`)),W(`search_for (string)`,O(`The string to search for within text_to_search.`)),W(`replace_with (string)`,O(`The string that will replace search_for.`)),W(`occurrence_number (number, optional)`,O(`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,n,r){let i=F(r,this.locale);N(()=>i>=0,O(`The occurrenceNumber (%s) must be positive or null.`,i.toString()));let a=I(e),o=I(t);if(o===``)return a;let s=I(n),c=new RegExp(at(o),`g`);if(i===0)return a.replace(c,s);let l=0;return a.replace(c,e=>++l===i?s:e)},isExported:!0},Yb={description:O(`Combines text from multiple strings and/or arrays.`),args:[W(`delimiter (string)`,O(` A string, possible empty, or a reference to a valid string. If empty, the text will be simply concatenated.`)),W(`ignore_empty (boolean)`,O(`A boolean; if TRUE, empty cells selected in the text arguments won't be included in the result.`)),W(`text1 (string, range<string>)`,O(`Any text item. This could be a string, or an array of strings in a range.`)),W(`text2 (string, range<string>, repeating)`,O(`Additional text item(s).`))],compute:function(e,t,...n){let r=I(e),i=L(t),a=0;return Ka(n,(e,t)=>i&&I(t)===``?e:(a++?e+r:``)+I(t),``)},isExported:!0},Xb={description:O(`Removes space characters.`),args:[W(`text (string)`,O(`The text or reference to a cell containing text to be trimmed.`))],compute:function(e){return Gt(I(e))},isExported:!0},Zb={description:O(`Converts a specified string to uppercase.`),args:[W(`text (string)`,O(`The string to convert to uppercase.`))],compute:function(e){return I(e).toUpperCase()},isExported:!0},Qb={description:O(`Converts a number to text according to a specified format.`),args:[W(`number (number)`,O(`The number, date or time to format.`)),W(`format (string)`,O(`The pattern by which to format the number, enclosed in quotation marks.`))],compute:function(e,t){return B(F(e,this.locale),{format:I(t),locale:this.locale})},isExported:!0},$b={description:O(`Converts a string to a numeric value.`),args:[W(`value (number)`,O(`the string to be converted`))],compute:function(e){return F(e,this.locale)},isExported:!0};var ex=l({HYPERLINK:()=>tx});let tx={description:O(`Creates a hyperlink in a cell.`),args:[W(`url (string)`,O(`The full URL of the link enclosed in quotation marks.`)),W(`link_label (string, optional)`,O(`The text to display in the cell, enclosed in quotation marks.`))],compute:function(e,t){let n=I(e).trim(),r=I(t)||n;return n===``?r:vt(r,n)},isExported:!0},nx=[{name:O(`Array`),functions:Nf},{name:O(`Database`),functions:Th},{name:O(`Date`),functions:Bh},{name:O(`Filter`),functions:Og},{name:O(`Financial`),functions:u_},{name:O(`Info`),functions:ny},{name:O(`Lookup`),functions:Ay},{name:O(`Logical`),functions:my},{name:O(`Math`),functions:ap},{name:O(`Misc`),functions:rp},{name:O(`Operator`),functions:Jy},{name:O(`Statistical`),functions:_m},{name:O(`Text`),functions:jb},{name:O(`Engineering`),functions:xg},{name:O(`Web`),functions:ex},{name:O(`Parser`),functions:kb}],rx=/^[A-Z0-9\_\.]+$/,ix=new class extends h{mapping={};add(e,t){if(e=e.toUpperCase(),!rx.test(e))throw Error(O(`Invalid function name %s. Function names can exclusively contain alphanumerical values separated by dots (.) or underscore (_)`,e));let n=wf(e,t);return Of(n),this.mapping[e]=ax(n),super.add(e,n),this}};for(let e of nx){let t=e.functions;for(let n in t){let r=t[n];r.category=r.category||e.name,n=n.replace(/_/g,`.`),ix.add(n,{isExported:!1,...r})}}function ax(e){function t(...t){let i=[],a=Ef(e,t.length);for(let n=0;n<t.length;n++){let r=a(n)??-1,o=e.args[r],s=t[n];if(!A(s)&&o.acceptMatrixOnly)throw new ya(O(`Function %s expects the parameter '%s' to be reference to a cell or range.`,e.name,(n+1).toString()));i.push(!o.acceptMatrix)}return n($a(r.bind(this),t,i))}function n(t){return A(t)?Za(t,t=>cx(t,e.name)):cx(t,e.name),t}function r(...t){for(let n=0;n<t.length;n++){let r=t[n],i=Ef(e,t.length);if(!e.args[i(n)||n].acceptErrors&&!A(r)&&P(r?.value))return r}try{return i.apply(this,t)}catch(t){return ox(t,e.name)}}function i(...t){this.debug&&=!1;let n=e.compute.apply(this,t);return A(n)?typeof n[0][0]==`object`&&n[0][0]!==null&&`value`in n[0][0]?n:Xa(n,e=>({value:e})):typeof n==`object`&&n&&`value`in n?n:(e.name,{value:n})}return t}function ox(e,t){return sx(e)&&P(e.value)?(ux(e)&&cx(e,t),e):(console.error(e),new M(lx+(ux(e)?` `+e.message:``)))}function sx(e){return e?.value!==void 0&&typeof e.value==`string`}function cx(e,t){e.message?.includes(`[[FUNCTION_NAME]]`)&&(e.message=e.message.replace(`[[FUNCTION_NAME]]`,t))}let lx=O(`An unexpected error occurred. Submit a support ticket at odoo.com/help.`);function ux(e){return e?.message!==void 0&&typeof e.message==`string`}var dx=class{scope;code=``;constructor(e=new px){this.scope=e}append(...e){this.code+=e.map(e=>e.toString()).join(`
|
|
16
16
|
`)+`
|
|
17
|
-
`}return(e){return new fx(this.scope,this.code,e)}toString(){return hx(this.code)}},fx=class{code;constructor(e,t,n){this.scope=e,this.returnExpression=n,this.code=hx(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;let e=this.scope.nextVariableName(),t=new dx(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}},px=class{nextId=1;declaredVariables=new Set;nextVariableName(){let e=`_${this.nextId++}`;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}};function mx(e){return e.split(`
|
|
17
|
+
`}return(e){return new fx(this.scope,this.code,e)}toString(){return hx(this.code)}},fx=class{scope;returnExpression;code;constructor(e,t,n){this.scope=e,this.returnExpression=n,this.code=hx(t)}toString(){return this.code}assignResultToVariable(){if(this.scope.isAlreadyDeclared(this.returnExpression))return this;let e=this.scope.nextVariableName(),t=new dx(this.scope);return t.append(this.code),t.append(`const ${e} = ${this.returnExpression};`),t.return(e)}},px=class{nextId=1;declaredVariables=new Set;nextVariableName(){let e=`_${this.nextId++}`;return this.declaredVariables.add(e),e}isAlreadyDeclared(e){return this.declaredVariables.has(e)}};function mx(e){return e.split(`
|
|
18
18
|
`).map(e=>e.trim()).filter(e=>e!==``)}function hx(e){let t=``,n=0,r=mx(e);for(let e of r)e.startsWith(`}`)&&n--,t+=` `.repeat(n)+e+`
|
|
19
19
|
`,e.endsWith(`{`)&&n++;return t.trim()}let gx=ix.content,_x={"=":`EQ`,"+":`ADD`,"-":`MINUS`,"*":`MULTIPLY`,"/":`DIVIDE`,">=":`GTE`,"<>":`NE`,">":`GT`,"<=":`LTE`,"<":`LT`,"^":`POWER`,"&":`CONCATENATE`},vx={"-":`UMINUS`,"+":`UPLUS`,"%":`UNARY.PERCENT`},yx={};function bx(e){return xx(xv(e))}function xx(e){try{return Sx(e)}catch(t){return{tokens:e,dependencies:[],execute:function(){return t},isBadExpression:!0,normalizedFormula:e.map(e=>e.value).join(``)}}}function Sx(e){let{dependencies:t,literalValues:n,symbols:r}=wx(e),i=Cx(e);if(!yx[i]){let t=Pv([...e]),n=new px,s=0,c=0,l=0;if(t.type===`BIN_OPERATION`&&t.value===`:`||t.type===`EMPTY`)throw new ya(O(`Invalid formula`));let u=o(t),d=new dx;d.append(u),d.append(`return ${u.returnExpression};`),yx[i]=Function(`deps`,`ref`,`range`,`getSymbolValue`,`ctx`,d.toString());function a(e){let{args:t}=e,n=gx[e.value.toUpperCase()];if(!n)throw new Ca(O(`Unknown function: "%s"`,e.value));Tx(e);let r=[],i=Ef(n,t.length);for(let e=0;e<t.length;e++){let a=n.args[i(e)??-1],s=t[e],c=a.type||[],l=c.includes(`META`),u=c.some(e=>Ex(e));r.push(o(s,l,u))}return r}function o(e,t=!1,i=!1){let u=new dx(n);if(e.type!==`REFERENCE`&&!(e.type===`BIN_OPERATION`&&e.value===`:`)&&t)throw new ya(O(`Argument must be a reference to a cell or range.`));switch(e.debug&&(u.append(`debugger;`),u.append(`ctx["debug"] = true;`)),e.type){case`BOOLEAN`:return u.return(`{ value: ${e.value} }`);case`NUMBER`:return u.return(`this.literalValues.numbers[${c++}]`);case`STRING`:return u.return(`this.literalValues.strings[${s++}]`);case`REFERENCE`:return!t&&e.value.includes(`:`)||i?u.return(`range(deps[${l++}])`):u.return(`ref(deps[${l++}], ${t?`true`:`false`})`);case`FUNCALL`:let n=a(e).map(e=>e.assignResultToVariable());u.append(...n);let d=e.value.toUpperCase();return u.return(`ctx['${d}'](${n.map(e=>e.returnExpression)})`);case`UNARY_OPERATION`:{let t=vx[e.value],n=o(e.operand,!1,!1).assignResultToVariable();return u.append(n),u.return(`ctx['${t}'](${n.returnExpression})`)}case`BIN_OPERATION`:{let t=_x[e.value],n=o(e.left,!1,!1).assignResultToVariable(),r=o(e.right,!1,!1).assignResultToVariable();return u.append(n),u.append(r),u.return(`ctx['${t}'](${n.returnExpression}, ${r.returnExpression})`)}case`SYMBOL`:let f=r.indexOf(e.value);return u.return(`getSymbolValue(this.symbols[${f}])`);case`EMPTY`:return u.return(`undefined`)}}}return{execute:yx[i],dependencies:t,literalValues:n,symbols:r,tokens:e,isBadExpression:!1,normalizedFormula:i}}function Cx(e){let t=``;for(let n of e)switch(n.type){case`STRING`:t+=`|S|`;break;case`NUMBER`:t+=`|N|`;break;case`REFERENCE`:case`INVALID_REFERENCE`:n.value.includes(`:`)?t+=`|R|`:t+=`|C|`;break;case`SPACE`:break;default:t+=n.value;break}return t}function wx(e){let t={numbers:[],strings:[]},n=[],r=[];for(let i of e)switch(i.type){case`INVALID_REFERENCE`:case`REFERENCE`:n.push(i.value);break;case`STRING`:let e=rt(i.value);t.strings.push({value:e});break;case`NUMBER`:{let e=zi(i.value,k);t.numbers.push({value:e});break}case`SYMBOL`:r.push(ct(i.value,`'`))}return{dependencies:n,literalValues:t,symbols:r}}function Tx(e){let t=e.args.length,n=e.value.toUpperCase(),r=gx[n],{nbrArgRepeating:i,minArgRequired:a}=r;if(t<a)throw new ya(O(`Invalid number of arguments for the %(functionName)s function. Expected %(minArgRequired)s minimum, but got %(nbrArgSupplied)s instead.`,{functionName:n,minArgRequired:a,nbrArgSupplied:t}));if(t>r.maxArgPossible)throw new ya(O(`Invalid number of arguments for the %(functionName)s function. Expected %(maxArgPossible)s maximum, but got %(nbrArgSupplied)s instead.`,{functionName:n,maxArgPossible:r.maxArgPossible,nbrArgSupplied:t}));if(i>1){let e=i*Math.floor((t-a)/i),o=t-a-e-r.nbrArgOptional;if(o>0)throw new ya(O(`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:n,nbrArgRepeating:i,nbrArgOptional:r.nbrArgOptional,nbrValueRemaining:o}))}}function Ex(e){return e.startsWith(`RANGE`)}let Dx=ix.content;function Ox(e){try{return Iv(Pv(e)).filter(e=>e.type===`FUNCALL`&&!Dx[e.value.toUpperCase()]?.isExported).length===0}catch{return!1}}function kx(e,t){if(!e.some(e=>e.type===`SYMBOL`&&t.includes(e.value.toUpperCase())))return[];let n;try{n=Pv(e)}catch{return[]}return Ax(n,t)}function Ax(e,t){return Iv(e).filter(e=>e.type===`FUNCALL`&&t.includes(e.value.toUpperCase())).map(e=>({functionName:e.value.toUpperCase(),args:e.args}))}function jx(e,t,n){if(!t.startsWith(`=`))return t;let r=xv(t);for(let t=1;t<r.length;t++){if(r[t].type!==`REFERENCE`)continue;let i=r[t].value,a=Mx(e,i,n).range;i!==a&&(r[t]={value:a,type:`REFERENCE`})}return Ot(r.map(e=>e.value))}function Mx(e,t,n){let r=ac(t).sheetName;if(r?!Fc(r,n.sheetName.old):e!==n.sheetId)return{changeType:`NONE`,range:t};let i=Fx(t,r?n.sheetId:e);if(i.invalidXc)return{changeType:`NONE`,range:t};let a=n.applyChange(i);if(a.changeType===`NONE`||a.changeType===`REMOVE`)return{changeType:a.changeType,range:t};let o=fc(a.range,e,Nx(n));return o===j.InvalidReference?{changeType:`REMOVE`,range:o}:{changeType:a.changeType,range:o}}function Nx(e){return t=>t===e.sheetId?e.sheetName.current:``}function Px(e){return{numberOfRows:2**53-1,numberOfCols:2**53-1}}function Fx(e,t){return $s.test(e)?cc({xc:e,sheetId:t},Px):lc(e)}let Ix=`xMovingAverage`;function Lx(e,t,n,r){let i=!1,a=[];for(let r in n){let o=n[r];if(o.labelCell){let e=Bx(o.labelCell,t);o.labelCell!==e&&(i=!0,o={...o,labelCell:e})}let s=Bx(o.dataRange,t);s===void 0||e.getRangeString(s,s.sheetId)===j.InvalidReference?(i=!0,o=void 0):s!==o.dataRange&&(i=!0,o={...o,dataRange:s}),a[r]=o}let o=r,s=Bx(o,t);s!==o&&(i=!0,o=s);let c=a.filter(C);return{isStale:i,dataSets:c,labelRange:o}}function Rx(e,t,n){return n.map(n=>({dataRange:pc(e,t,n.dataRange),labelCell:n.labelCell?pc(e,t,n.labelCell):void 0}))}function zx(e,t,n){return n?pc(e,t,n):void 0}function Bx(e,t){if(!e)return;let n=t(e);switch(n.changeType){case`REMOVE`:return;default:return n.range}}function Vx(e,t,n,r){let i=[];for(let a of t){let{unboundedZone:t,sheetId:o,invalidSheetName:s,invalidXc:c}=e.getRangeFromSheetXC(n,a.dataRange);if(!(s||c))if(t.left!==t.right&&t.top!==t.bottom){if(t.right===void 0)continue;for(let n=t.left;n<=t.right;n++){let s={...t,left:n,right:n};i.push({...Hx(e,o,s,r?{top:s.top,bottom:s.top,left:s.left,right:s.left}:void 0),backgroundColor:a.backgroundColor,rightYAxis:a.yAxisId===`y1`,customLabel:a.label})}}else i.push({...Hx(e,o,t,r?{top:t.top,bottom:t.top,left:t.left,right:t.left}:void 0),backgroundColor:a.backgroundColor,rightYAxis:a.yAxisId===`y1`,customLabel:a.label})}return i}function Hx(e,t,n,r){if(n.left!==n.right&&n.top!==n.bottom)throw Error(`Zone should be a single column or row: ${cr(n)}`);if(r){let i=cr(n),a=cr(r);return{labelCell:e.getRangeFromSheetXC(t,a),dataRange:e.getRangeFromSheetXC(t,i)}}else return{labelCell:void 0,dataRange:e.getRangeFromSheetXC(t,cr(n))}}function Ux(e,t){let n=t.labelCell?.zone,r=t.dataRange.zone;if(n){let{numberOfRows:e,numberOfCols:t}=br(r);e===1?r={...r,left:r.left+1}:t===1&&(r={...r,top:r.top+1})}let i=sc({...t.dataRange,zone:r},e.getSheetSize),a={};return t.customLabel?a={text:t.customLabel}:t.labelCell&&(a={reference:e.getRangeString(t.labelCell,`forceSheetReference`,{useBoundedReference:!0})}),{label:a,range:e.getRangeString(i,`forceSheetReference`,{useBoundedReference:!0}),backgroundColor:t.backgroundColor,rightYAxis:t.rightYAxis}}function Wx(e,t,n){if(!t)return;let r={...t.zone};n&&t.zone.bottom>t.zone.top&&(r.top+=1);let i=sc({...t,zone:r},e.getSheetSize);return e.getRangeString(i,`forceSheetReference`,{useBoundedReference:!0})}function Gx(e,t,n){let r;if(t.labelRange){let{changeType:i,range:a}=Mx(e,t.labelRange,n);i!==`REMOVE`&&(r=a)}let i=[];for(let r of t.dataSets){let t={...r},{changeType:a,range:o}=Mx(e,r.dataRange,n);a!==`REMOVE`&&(t.dataRange=o,i.push(t))}return{...t,dataSets:i,labelRange:r}}function Kx(e){return e&&fn(e)<.3?`#FFFFFF`:`#000000`}function qx(e){return e&&fn(e)<.3?`#C8C8C8`:`#666666`}function Jx(e){return e.dataSets&&(e.dataSets.find(e=>!$s.test(e.dataRange))!==void 0||e.dataSets.map(e=>ir(e.dataRange)).some(e=>e.top!==e.bottom&&jr(e)))?`InvalidDataSet`:`Success`}function Yx(e){return e.labelRange&&!$s.test(e.labelRange||``)?`InvalidLabelRange`:`Success`}function Xx(e,t,n){if(!n||!e)return!1;if(!t)return!0;let r=Nr(t.dataRange.zone);return!(Nr(e.zone)<r)}function Zx(e,t){let{x:n,y:r}=e.getMainViewportCoordinates(),{scrollX:i,scrollY:a}=e.getActiveSheetScrollInfo(),{width:o,height:s}=e.getVisibleRect(e.getActiveMainViewport());return{x:n+i+Math.max(0,(o-t.width)/2),y:r+a+Math.max(0,(s-t.height)/2)}}function Qx(e){let t=!1,n=!1;if(`horizontal`in e&&e.horizontal)return{useLeftAxis:!0,useRightAxis:!1};for(let r of e.dataSets||[])r.yAxisId===`y1`?n=!0:t=!0;return t||=!n,{useLeftAxis:t,useRightAxis:n}}function $x(e,t){return(n,r)=>{let i=e?.[r];return eS({format:i,locale:t})(n)}}function eS(e){return t=>{if(t=Number(t),isNaN(t))return t;let{locale:n,format:r}=e;return rS(B(t,{locale:n,format:!r&&Math.abs(t)>=1e3?`#,##`:r}))}}let tS=[{value:`left`,label:O(`Left`)},{value:`right`,label:O(`Right`)}];function nS(e,t){let n=[],r=Jt(t.map(e=>e.data.length));for(let t=0;t<=r;t++)n.push(e.next());return n}function rS(e){return e?e.length>20?e.substring(0,20)+`…`:e:``}function iS(e){return e===`x1`||e===`xMovingAverage`}let aS={id:`chartShowValuesPlugin`,afterDatasetsDraw(e,t,n){if(!n.showValues||!e._metasets?.[0]?.data)return;let r=e.ctx;switch(r.save(),r.textAlign=`center`,r.textBaseline=`middle`,r.miterLimit=1,e.config.type){case`pie`:case`doughnut`:lS(e,n,r);break;case`bar`:case`line`:case`radar`:n.horizontal?cS(e,n,r):sS(e,n,r);break;case`funnel`:cS(e,n,r);break}r.restore()}};function oS(e,t,n,r){r.lineWidth=3,r.strokeText(e,t,n),r.lineWidth=1,r.fillText(e,t,n)}function sS(e,t,n){let r={};for(let i of e._metasets){if(iS(i.xAxisID)||i.hidden)continue;let a=e.scales[i.yAxisID];for(let o=0;o<i._parsed.length;o++){let s=i._parsed[o],c=Number(e.config.type===`radar`?s.r:s.y);if(isNaN(c))continue;let l=i.data[o],u=l.x,d=0;if(e.config.type===`line`||e.config.type===`radar`)d=c<0?l.y+10:l.y-10;else{let e=a.getPixelForValue(0);d=Math.abs(e-l.y)<12?c<0?e+12/2:e-12/2:c<0?l.y-l.height/2:l.y+l.height/2}r[u]||(r[u]=[]);for(let e of r[u]||[])Math.abs(e-d)<13&&(d=c<0?e+13:e-13);r[u].push(d),n.fillStyle=l.options.backgroundColor,n.strokeStyle=t.background||`#ffffff`,oS(t.callback(Number(c),i,o),u,d,n)}}}function cS(e,t,n){let r={};for(let i of e._metasets){if(iS(i.xAxisID))return;let a=e.scales[i.xAxisID].getPixelForValue(0);for(let e=0;e<i._parsed.length;e++){let o=Number(i._parsed[e].x);if(isNaN(o))continue;let s=t.callback(o,i,e),c=i.data[e],l=c.y,u=Vc(n,s,{fontSize:12},`px`),d=Math.abs(c.x-a),f;f=d<u?o<0?a-u/2-3:a+u/2+3:o<0?c.x+c.width/2:c.x-c.width/2,r[l]||(r[l]=[]);for(let e of r[l])Math.abs(e-f)<u&&(f=o<0?e-u-3:e+u+3);r[l].push(f),n.fillStyle=c.options.backgroundColor,n.strokeStyle=t.background||`#ffffff`,oS(s,f,l,n)}}}function lS(e,t,n){for(let r of e._metasets)for(let e=0;e<r._parsed.length;e++){let i=Number(r._parsed[e]);if(isNaN(i)||i===0)continue;let a=r.data[e],{startAngle:o,endAngle:s,innerRadius:c,outerRadius:l}=a,u=(o+s)/2,d=(c+l)/2,f=a.x+d*Math.cos(u),p=a.y+d*Math.sin(u),m=t.callback(i,r,e),h=Vc(n,m,{fontSize:12},`px`),g=l-c;if(h>=g||g<12)continue;let _=s-o,v=2*d*Math.tan(_/2);_<Math.PI/2&&(h>=v||v<12)||(n.fillStyle=Kx(t.background),n.strokeStyle=t.background||`#ffffff`,oS(m,f,p,n))}}let uS={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}},dS=`nullValue`;function fS(e,t){let{dataSetsValues:n}=t,r=[],i=jS(e,n.length),a=[];for(let o in n){let{label:s,data:c,hidden:l}=n[o];s=e.dataSets?.[o].label||s;let u=i.next(),d={label:s,data:c,hidden:l,borderColor:e.background||`#FFFFFF`,borderWidth:+!!e.stacked,backgroundColor:u,yAxisID:e.horizontal?`y`:e.dataSets?.[o].yAxisId||`y`,xAxisID:`x`};r.push(d);let f=e.dataSets?.[o].trend,p=t.trendDataSetsValues?.[o];!f?.display||e.horizontal||!p||a.push(kS(d,f,p))}return r.push(...a),r}function pS(e,t){let{dataSetsValues:n,labels:r}=t,i=e.negativeValuesColor||`#EA6175`,a=e.positiveValuesColor||`#4EA7F2`,o=e.subTotalValuesColor||`#AAAAAA`,s=[],c=[],l={label:``,data:c,backgroundColor:s},u=[],d=0;for(let t of n)if(!t.hidden){for(let l=0;l<t.data.length;l++){let f=t.data[l];if(u.push(r[l]),isNaN(Number(f))){c.push([d,d]),s.push(``);continue}c.push([d,f+d]);let p=f>=0?a:i;l===0&&t===n[0]&&e.firstValueAsSubtotal&&(p=o),s.push(p),d+=f}e.showSubTotals&&(u.push(O(`Subtotal`)),c.push([0,d]),s.push(o))}return{datasets:[l],labels:u}}function mS(e,t){let{dataSetsValues:n,axisType:r,labels:i}=t,a=[],o=!!e.fillArea,s=!!e.stacked,c=[],l=jS(e,n.length);for(let u=0;u<n.length;u++){let{label:d,data:f,hidden:p}=n[u];d=e.dataSets?.[u].label||d;let m=l.next();r&&[`linear`,`time`].includes(r)&&(f=f.map((e,t)=>({x:i[t]||void 0,y:e})));let h={label:d,data:f,hidden:p,tension:0,borderColor:m,backgroundColor:o?xn(m,qe):m,pointBackgroundColor:m,fill:o?AS(u,s):!1,yAxisID:e.dataSets?.[u].yAxisId||`y`};a.push(h);let g=e.dataSets?.[u].trend,_=t.trendDataSetsValues?.[u];!g?.display||!_||c.push(kS(h,g,_))}return a.push(...c),a}function hS(e,t){let n=mS(e,t);for(let e of n)iS(e.xAxisID)||(e.showLine=!1);return n}function gS(e,t){let{dataSetsValues:n}=t,r=[],i=nS(new Pn(Math.max(0,...n.map(e=>e?.data?.length??0))),n);for(let{label:t,data:a,hidden:o}of n){if(o)continue;let n={label:t,data:a,borderColor:e.background||`#FFFFFF`,backgroundColor:i,hoverOffset:10};r.push(n)}return r}function _S(e,t){let{dataSetsValues:n}=t,r=[],i=jS(e,n.length),a=[];for(let o=0;o<n.length;o++){let{label:s,data:c,hidden:l}=n[o];s=e.dataSets?.[o].label||s;let u=e.dataSets?.[o],d=i.next(),f=u?.type??`line`,p={label:s,data:c,hidden:l,borderColor:d,backgroundColor:d,yAxisID:e.dataSets?.[o].yAxisId||`y`,xAxisID:`x`,type:f,order:f===`bar`?n.length+o:o};r.push(p);let m=e.dataSets?.[o].trend,h=t.trendDataSetsValues?.[o];!m?.display||!h||a.push(kS(p,m,h))}return r.push(...a),r}function vS(e,t){let{dataSetsValues:n}=t,r=[],i=e.fillArea??!1,a=jS(e,n.length);for(let t=0;t<n.length;t++){let{label:o,data:s,hidden:c}=n[t];e.dataSets?.[t]?.label&&(o=e.dataSets[t].label);let l=a.next(),u={label:o,data:s,hidden:c,borderColor:l,backgroundColor:l};i&&(u.backgroundColor=xn(l,qe),u.fill=`start`),r.push(u)}return r}function yS(e,t){let{availableRegions:n,dataSetsValues:r,labels:i}=t,a=e.region||n[0]?.id,o=a?t.getGeoJsonFeatures(a):void 0,s={outline:o,showOutline:!!o,data:[]};if(o&&a){let e={};if(r[0])for(let n=0;n<r[0].data.length;n++){if(!i[n]||r[0].data[n]===void 0)continue;let o=t.geoFeatureNameToId(a,i[n]);o&&(e[o]={value:r[0].data[n],label:i[n]})}for(let t of o)t.id&&s.data.push({feature:{...t,properties:{name:e[t.id]?.label}},value:e[t.id]?.value})}return[s]}function bS(e,t){let n=t.dataSetsValues[0],r=t.labels;if(!n)return[];let{label:i,data:a}=n;return i=e.dataSets?.[0].label||i,[{label:i,data:a.map(e=>e<=0?[0,0]:[-e,e]),backgroundColor:xS(r,e.funnelColors),yAxisID:`y`,xAxisID:`x`,barPercentage:1,categoryPercentage:1,borderColor:e.background||`#FFFFFF`,borderWidth:3}]}function xS(e,t){let n=new Pn(e.length,t);return e.map(()=>n.next())}function SS(e,t){let{dataSetsValues:n,labels:r}=t,i=ES(wS(n,r)),a=i[0]||[],o=new Pn(a.length,e.groupColors||[]),s=a.map(e=>({label:e.label,color:o.next()})),c=[];for(let t=i.length-1;t>=0;t--){let n={groupColors:s,parsing:{key:`value`},data:i[t],borderColor:t=>{let n=t.type===`data`?t.raw:void 0;return!n||n.label===`nullValue`?ge:e.background||`#FFFFFF`},backgroundColor:e=>{let t=e.type===`data`?e.raw:void 0;if(!t||t.label===`nullValue`)return ge;let n=t.groups[0];return s.find(e=>e.label===n)?.color},hoverOffset:10};c.push(n)}return c}function CS(e,t){let n=[],r=Math.max(...e.map(e=>e.data.length));for(let i=0;i<r;i++){n[i]={};for(let t=0;t<e.length;t++){let r=e[t].data[i]===null?dS:String(e[t].data[i]);n[i][t]=r}n[i].value=Number(t[i])}return n}function wS(e,t){return TS(CS(e,t),0,e.length,[])}function TS(e,t,n,r){if(t>=n)return[];let i=Object.groupBy(e,e=>e[t]);return Object.keys(i).map(e=>{let a=i[e]?.reduce((e,t)=>e+Number(t.value),0)||0,o=[...r,e];return{label:e,value:a,children:TS(i[e]||[],t+1,n,[...r,e]),groups:o,depth:t}}).sort((e,t)=>t.value-e.value)}function ES(e){let t=[],n=[...e];for(;n.length>0;){let e=n.shift();e&&(t[e.depth]||(t[e.depth]=[]),t[e.depth].push(e),e.children&&n.push(...e.children))}return t}function DS(e,t){let{dataSetsValues:n,labels:r,locale:i,axisFormats:a}=t,o={locale:i,format:a?.y};if(n.length===0)return[];let s=wS(n,r).sort((e,t)=>t.value-e.value),c=MS(e,s),l=[],u=Math.max(...n.map(e=>e.data.length));for(let e=0;e<u;e++){l[e]={};for(let t=0;t<n.length;t++)l[e][t]=n[t].data[e]?String(n[t].data[e]):void 0;l[e].value=Number(r[e])}let d=e.showLabels??uS.showLabels,f=e.showValues??uS.showValues,p=e.coloringOptions||uS.coloringOptions,m;return p?.type===`colorScale`&&(m=NS(s,p)),[{data:[],tree:l,labels:{display:d||f,overflow:`hidden`,...OS(e.valuesDesign,uS.valuesDesign),formatter:e=>[d?e.raw.g:void 0,f?B(e.raw.v,o):void 0].filter(C)},captions:{display:e.showHeaders??uS.showHeaders,padding:6,...OS(e.headerDesign,uS.headerDesign)},key:`value`,groups:S(0,n.length).map(e=>String(e)),borderWidth:0,spacing:1,displayMode:`headerBoxes`,groupColors:c,backgroundColor:t=>{if(t.type!==`data`)return`transparent`;if(!t.raw.isLeaf)return e.headerDesign?.fillColor||uS.headerDesign?.fillColor;if(p.type===`colorScale`)return m?.(t.raw.v)||`#FF0000`;if(p.type===`categoryColor`)return PS(t,s,p,c);throw Error(`Unsupported coloring option type}`)}}]}function OS(e,t){let n=e=>{let t=e.element.options.backgroundColor;return fn(t)>.7?`#666666`:`#FFFFFF`};return{align:e?.align??t?.align,position:e?.verticalAlign??t?.verticalAlign,color:e?.color||n,hoverColor:e?.color||n,font:{weight:e?.bold??t?.bold?`bold`:`normal`,style:e?.italic??t?.italic?`italic`:`normal`,size:e?.fontSize??t?.fontSize}}}function kS(e,t,n){let r=hn(e.backgroundColor);r.a=1;let i=t.color||Sn(mn(r),.5);return{type:`line`,xAxisID:t.type===`trailingMovingAverage`?Ix:`x1`,yAxisID:e.yAxisID,label:e.label?O(`Trend line for %s`,e.label):``,data:n,order:-1,showLine:!0,pointRadius:0,backgroundColor:i,borderColor:i,borderDash:[5,5],borderWidth:void 0,fill:!1,pointBackgroundColor:i}}function AS(e,t){return t?e===0?`origin`:`-1`:`origin`}function jS(e,t){return new Pn(t,e.dataSets?.map(e=>e.backgroundColor)||[])}function MS(e,t){let n=e.coloringOptions?.type===`categoryColor`?e.coloringOptions.colors:[],r=new Pn(t.length,n);return t.map(e=>({label:e.label,color:r.next()}))}function NS(e,t){let n=ES(e),r=n[n.length-1],i=Math.min(...r.map(e=>e.value)),a=Math.max(...r.map(e=>e.value));if(Number.isFinite(i)&&Number.isFinite(a)){let e=[{value:i,color:t.minColor}];if(t.midColor){let n=(i+a)/2;e.push({value:n,color:t.midColor})}return e.push({value:a,color:t.maxColor}),In(e)}}function PS(e,t,n,r){let i=e.raw._data.children[0][0],a=r.find(e=>e.label===i)?.color;if(!a||!n.useValueBasedGradient)return a||`#FF0000`;let o=t.find(e=>e.label===i);if(!o||!o.children.length)return a;let s=ES(o.children),c=s[s.length-1],l=Math.max(...c.map(e=>e.value)),u=Math.min(...c.map(e=>e.value));return u===l||!isFinite(u)||!isFinite(l)?a:Sn(a,((Number(e.raw.v)||0)-l)/(u-l)*.5)}let FS={id:`sunburstHoverPlugin`,afterEvent(e,t,n){if(!n.enabled)return;let r=e.getActiveElements(),i=r.map(e=>({datasetIndex:e.datasetIndex,index:e.index}));for(let t of r){let n=e.data.datasets[t.datasetIndex].data[t.index];for(let t=0;t<e.data.datasets.length;t++){let r=e.data.datasets[t];for(let e=0;e<r.data.length;e++){let a=r.data[e];IS(n.groups,a.groups)&&i.push({datasetIndex:t,index:e})}}}i=i.filter(t=>{let{datasetIndex:n,index:r}=t;return e.data.datasets[n].data[r].label!==dS}),e.setActiveElements(i);for(let t of e.getSortedVisibleDatasetMetas())for(let e of t.data){let t=e.$context,{datasetIndex:n,index:r,dataset:a,raw:o}=t;if(o.label===`nullValue`)continue;let s=typeof a.backgroundColor==`function`?a.backgroundColor(t):a.backgroundColor;i.length&&!i.some(e=>e.datasetIndex===n&&e.index===r)?e.options.backgroundColor=Sn(s,.5):e.options.backgroundColor=s}}};function IS(e,t){return t.length>e.length&&e.every((e,n)=>e===t[n])}let LS={id:`sunburstLabelsPlugin`,afterDatasetsDraw(e,t,n){if(!n.showValues&&!n.showLabels||e.config.type!==`doughnut`)return;let r=e.ctx;RS(e,n,r)}};function RS(e,t,n){let r=t.style,i=r.fontSize||13,a=i+3;for(let o of e._metasets)for(let s=0;s<o._dataset.data.length;s++){let c=o._dataset.data[s];if(c.label===`nullValue`)continue;let l=[t.showLabels?c.label:void 0,t.showValues?t.callback(c.value,`y`):void 0].filter(C),u=o.data[s],{startAngle:d,endAngle:f,innerRadius:p,outerRadius:m,circumference:h}=u,g=u.options.offset/4,_=g*(1-Math.sin(Math.min(Math.PI,h||0)));p+=_,m+=_;let v=(d+f)/2,y=(p+m)/2,ee=(m-p)*.9,te=f-d;if((te>=Math.PI?m:Math.sin(te/2)*p*2)<l.length*a)continue;n.save();let ne={x:Math.cos(v)*g,y:Math.sin(v)*g},re=e.chartArea.left+e.chartArea.width/2+ne.x,ie=e.chartArea.top+e.chartArea.height/2+ne.y;n.translate(re,ie);let ae;v>Math.PI/2?(n.rotate(v-Math.PI),ae=-y):(ae=y,n.rotate(v));let oe=u.options.backgroundColor,se=fn(oe)>.7?`#666666`:`#FFFFFF`;n.fillStyle=r.textColor||se,n.textAlign=`center`,n.textBaseline=`middle`,n.font=zc(i,r.bold,r.italic);let ce=-((l.length-1)*a)/2;for(let e=0;e<l.length;e++){let t=il(n,ee,l[e],r,`px`);n.fillText(t,ae,ce+e*a)}n.restore()}}let zS={id:`waterfallLinesPlugin`,beforeDraw(e,t,n){if(!n.showConnectorLines)return;let r=e._metasets?.[0]?.data;if(!r)return;let i=e.ctx;i.save(),i.setLineDash([3,2]);for(let e=0;e<r.length;e++){let t=r[e];if(t.height===0)continue;let n=VS(r,e);if(!n)break;let a=BS(t),o=BS(n),s=t.$context.raw,c=s[1]-s[0],l=Math.round(c<0?a.bottom-1:a.top),u=Math.round(a.right),d=Math.round(o.left);i.strokeStyle=`#999`,i.beginPath(),i.moveTo(u+1,l+.5),i.lineTo(d,l+.5),i.stroke()}i.restore()}};function BS(e){let 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 VS(e,t){return e.find((e,n)=>n>t&&e.height!==0)}H`
|
|
20
20
|
.o-spreadsheet {
|
|
@@ -24,7 +24,7 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
24
24
|
z-index: ${1002};
|
|
25
25
|
}
|
|
26
26
|
}
|
|
27
|
-
`,pf.add(`chartShowValuesPlugin`,{register:e=>e.register(aS),unregister:e=>e.unregister(aS)}),pf.add(`waterfallLinesPlugin`,{register:e=>e.register(zS),unregister:e=>e.unregister(zS)}),pf.add(`funnelController`,{register:e=>e.register(_f()),unregister:e=>e.unregister(_f())}),pf.add(`funnelElement`,{register:e=>e.register(vf()),unregister:e=>e.unregister(vf())}),pf.add(`funnelTooltipPositioner`,{register:e=>e.Tooltip.positioners.funnelTooltipPositioner=bf,unregister:e=>e.Tooltip.positioners.funnelTooltipPositioner=void 0}),pf.add(`sunburstLabelsPlugin`,{register:e=>e.register(LS),unregister:e=>e.unregister(LS)}),pf.add(`sunburstHoverPlugin`,{register:e=>e.register(FS),unregister:e=>e.unregister(FS)});var HS=class extends t.Component{static template=`o-spreadsheet-ChartJsComponent`;static props={figureUI:Object};canvas=(0,t.useRef)(`graphContainer`);chart;currentRuntime;currentDevicePixelRatio=window.devicePixelRatio;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){let e=this.env.model.getters.getChartRuntime(this.props.figureUI.id);if(!(`chartJsConfig`in e))throw Error(`Unsupported chart runtime`);return e}setup(){(0,t.onMounted)(()=>{hf();let e=this.chartRuntime;this.currentRuntime=e,this.createChart(b(e.chartJsConfig))}),(0,t.onWillUnmount)(()=>this.chart?.destroy()),(0,t.useEffect)(()=>{let e=this.chartRuntime;e===this.currentRuntime?this.currentDevicePixelRatio!==window.devicePixelRatio&&(this.currentDevicePixelRatio=window.devicePixelRatio,this.updateChartJs(b(this.currentRuntime.chartJsConfig))):(e.chartJsConfig.type===this.currentRuntime.chartJsConfig.type?this.updateChartJs(b(e.chartJsConfig)):(this.chart?.destroy(),this.createChart(b(e.chartJsConfig))),this.currentRuntime=e)})}createChart(e){let t=this.canvas.el.getContext(`2d`);this.chart=new window.Chart(t,e)}updateChartJs(e){e.data&&e.data.datasets?(this.chart.data=e.data,e.options?.plugins?.title&&(this.chart.config.options.plugins.title=e.options.plugins.title)):this.chart.data.datasets=[],this.chart.config.options=e.options,this.chart.update()}},US=class{sheetId;title;getters;constructor(e,t,n){this.title=e.title,this.sheetId=t,this.getters=n}static validateChartDefinition(e,t){throw Error(`This method should be implemented by sub class`)}static transformDefinition(e,t,n){throw Error(`This method should be implemented by sub class`)}static getDefinitionFromContextCreation(e){throw Error(`This method should be implemented by sub class`)}};function WS(e,t,n,r,i){if(!e)return``;if(n===`text`||t?.type!==`number`||e.type!==`number`)return r?Ss(e,i):e.formattedValue;let{value:a,format:o}=e;return n===`progress`?(a=t.value/a,o=`0.0%`):(a=Math.abs(t.value-a),n===`percentage`&&a!==0&&(a/=e.value),n===`percentage`&&(o=`0.0%`),o||(a=Math.round(a*100)/100)),r?Ss({value:a,format:o},i):B(a,{format:o,locale:i})}function GS(e,t,n){return e?t?Ss(e,n):e.formattedValue??String(e.value??``):``}function KS(e,t,n,r,i){if(t===`text`||t===`progress`||e?.type!==`number`||n?.type!==`number`)return;let a=n.value-e.value;if(a>0)return r;if(a<0)return i}function qS(e,t,n){if(n===`text`||e?.type!==`number`||t?.type!==`number`)return`neutral`;let r=t.value-e.value;return r>0?`up`:r<0?`down`:`neutral`}function JS(e){return e.keyValue&&!$s.test(e.keyValue)?`InvalidScorecardKeyValue`:`Success`}function YS(e){return e.baseline&&!$s.test(e.baseline)?`InvalidScorecardBaseline`:`Success`}let XS=new window.Path2D(`M8.6 4.8a.5.5 0 0 1 0 .75l-3.9 3.9a.5 .5 0 0 1 -.75 0l-3.8 -3.9a.5 .5 0 0 1 0 -.75l.4-.4a.5.5 0 0 1 .75 0l2.3 2.4v-5.7c0-.25.25-.5.5-.5h.6c.25 0 .5.25.5.5v5.8l2.3 -2.4a.5.5 0 0 1 .75 0z`),ZS=new window.Path2D(`M8.7 5.5a.5.5 0 0 0 0-.75l-3.8-4a.5.5 0 0 0-.75 0l-3.8 4a.5.5 0 0 0 0 .75l.4.4a.5.5 0 0 0 .75 0l2.3-2.4v5.8c0 .25.25.5.5.5h.6c.25 0 .5-.25.5-.5v-5.8l2.2 2.4a.5.5 0 0 0 .75 0z`);var QS=class e extends US{keyValue;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type=`scorecard`;constructor(e,t,n){super(e,t,n),this.keyValue=mc(n,t,e.keyValue),this.baseline=mc(n,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??`#43C5B1`,this.baselineColorDown=e.baselineColorDown??`#EA6175`,this.humanize=e.humanize??!1}static validateChartDefinition(e,t){return e.checkValidations(t,JS,YS)}static getDefinitionFromContextCreation(e){return{background:e.background,type:`scorecard`,keyValue:e.range?.[0]?.dataRange,title:e.title||{text:``},baselineMode:We,baselineColorUp:Ge,baselineColorDown:Ke,baseline:e.auxiliaryRange||``}}static transformDefinition(e,t,n){let r,i;if(t.baseline){let{changeType:i,range:a}=Mx(e,t.baseline,n);i!==`REMOVE`&&(r=a)}if(t.keyValue){let{changeType:r,range:a}=Mx(e,t.keyValue,n);r!==`REMOVE`&&(i=a)}return{...t,baseline:r,keyValue:i}}duplicateInDuplicatedSheet(t){let n=zx(this.sheetId,t,this.baseline),r=zx(this.sheetId,t,this.keyValue);return new e(this.getDefinitionWithSpecificRanges(n,r,t),t,this.getters)}copyInSheetId(t){return new e(this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue,t),t,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue)}getContextCreation(){return{...this,range:this.keyValue?[{dataRange:this.getters.getRangeString(this.keyValue,this.sheetId)}]:void 0,auxiliaryRange:this.baseline?this.getters.getRangeString(this.baseline,this.sheetId):void 0}}getDefinitionWithSpecificRanges(e,t,n){return{baselineColorDown:this.baselineColorDown,baselineColorUp:this.baselineColorUp,baselineMode:this.baselineMode,title:this.title,type:`scorecard`,background:this.background,baseline:e?this.getters.getRangeString(e,n||this.sheetId):void 0,baselineDescr:this.baselineDescr,keyValue:t?this.getters.getRangeString(t,n||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges({applyChange:t}){let n=Bx(this.baseline,t),r=Bx(this.keyValue,t);return this.baseline===n&&this.keyValue===r?this:new e(this.getDefinitionWithSpecificRanges(n,r),this.sheetId,this.getters)}};function $S(e,t){let n=t.getContext(`2d`),r=window.devicePixelRatio||1;t.width=r*e.canvas.width,t.height=r*e.canvas.height,n.scale(r,r);let i=e.canvas.width-40;if(n.fillStyle=e.canvas.backgroundColor,n.fillRect(0,0,e.canvas.width,e.canvas.height),e.title){n.font=e.title.style.font,n.fillStyle=e.title.style.color;let t=n.textBaseline;n.textBaseline=`middle`,n.fillText(nl(n,e.title.text,i-e.title.position.x),e.title.position.x,e.title.position.y),n.textBaseline=t}if(e.baseline&&(n.font=e.baseline.style.font,n.fillStyle=e.baseline.style.color,rl(n,e.baseline.text,e.baseline.position,e.baseline.style.underline,e.baseline.style.strikethrough)),e.baselineArrow&&e.baselineArrow.style.size>0){n.save(),n.fillStyle=e.baselineArrow.style.color,n.translate(e.baselineArrow.position.x,e.baselineArrow.position.y);let t=e.baselineArrow.style.size/10;switch(n.scale(t,t),e.baselineArrow.direction){case`down`:n.fill(XS);break;case`up`:n.fill(ZS);break}n.restore()}if(e.baselineDescr){let t=e.baselineDescr[0];n.font=t.style.font,n.fillStyle=t.style.color;for(let t of e.baselineDescr)n.fillText(nl(n,t.text,i-t.position.x),t.position.x,t.position.y)}if(e.key&&(n.font=e.key.style.font,n.fillStyle=e.key.style.color,rl(n,nl(n,e.key.text,i-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.progressBar){if(n.fillStyle=e.progressBar.style.backgroundColor,n.beginPath(),n.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width,e.progressBar.dimension.height,e.progressBar.dimension.height/2),n.fill(),n.fillStyle=e.progressBar.style.color,n.beginPath(),e.progressBar.value>0)n.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width*Math.max(0,Math.min(1,e.progressBar.value)),e.progressBar.dimension.height,e.progressBar.dimension.height/2);else{let t=e.progressBar.dimension.width*Math.max(0,Math.min(1,-e.progressBar.value));n.roundRect(e.progressBar.position.x+e.progressBar.dimension.width-t,e.progressBar.position.y,t,e.progressBar.dimension.height,e.progressBar.dimension.height/2)}n.fill()}}function eC(e,t){let n=``,r,i=t.getLocale();if(e.keyValue){let a={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};r=t.getEvaluatedCell(a),n=GS(r,e.humanize??!1,i)}let a,o=e.baseline;if(o){let e={sheetId:o.sheetId,col:o.zone.left,row:o.zone.top};a=t.getEvaluatedCell(e)}let{background:s,fontColor:c}=t.getStyleOfSingleCellChart(e.background,e.keyValue),l=WS(a,r,e.baselineMode,e.humanize??!1,i),u=e.baselineMode===`progress`&&Li(l,i)?F(l,i):0;return{title:{...e.title,text:e.title.text?O(e.title.text):``},keyValue:n,baselineDisplay:l,baselineArrow:qS(a,r,e.baselineMode),baselineColor:KS(a,e.baselineMode,r,e.baselineColorUp,e.baselineColorDown),baselineDescr:e.baselineMode!==`progress`&&e.baselineDescr?O(e.baselineDescr):``,fontColor:c,background:s,baselineStyle:e.baselineMode!==`percentage`&&e.baselineMode!==`progress`&&o?t.getCellStyle({sheetId:o.sheetId,col:o.zone.left,row:o.zone.top}):void 0,keyValueStyle:e.keyValue?t.getCellStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,progressBar:e.baselineMode===`progress`?{value:u,color:u>0?e.baselineColorUp:e.baselineColorDown}:void 0}}let tC=.05;function nC(e,t){let n=e||``;return t&&n?` `+n:n}function rC({width:e,height:t},n){return new iC({width:e,height:t},n).computeDesign()}var iC=class{context;width;height;constructor({width:e,height:t},n){this.runtime=n;let r=document.createElement(`canvas`);this.width=r.width=e,this.height=r.height=t,this.context=r.getContext(`2d`)}computeDesign(){let e={canvas:{width:this.width,height:this.height,backgroundColor:this.backgroundColor}},t=this.getTextStyles(),n=0;if(this.title){let r,i;switch({height:n,width:i}=this.getFullTextDimensions(this.title,t.title.font),this.runtime.title.align){case`center`:r=(this.width-i)/2;break;case`right`:r=this.width-i-10;break;default:r=10}e.title={text:this.title,style:t.title,position:{x:r,y:10+n/2}}}let r=t.baselineArrow?.size??0,{height:i,width:a}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);let o=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;e.baseline={text:this.baseline,style:t.baselineValue,position:{x:(this.width-a-o+r)/2,y:this.keyValue?this.height*(1-tC*(this.runtime.progressBar?1:2)):this.height-(this.height-n-i)/2-10}};let s=r+20;if(e.baseline.position.x<s&&(e.baseline.position.x=s),t.baselineArrow&&!this.runtime.progressBar&&(e.baselineArrow={direction:this.baselineArrow,style:t.baselineArrow,position:{x:e.baseline.position.x-r,y:e.baseline.position.y-(i+r)/2}}),this.baselineDescr){let n={x:e.baseline.position.x+a,y:e.baseline.position.y};e.baselineDescr=[{text:this.baselineDescr,style:t.baselineDescr,position:n}]}let c=0;this.runtime.progressBar&&(c=this.height*.05,e.progressBar={position:{x:20,y:this.height*(1-2*tC)-i-c},dimension:{height:c,width:this.width-40},value:this.runtime.progressBar.value,style:{color:this.runtime.progressBar.color,backgroundColor:this.secondaryFontColor}});let{width:l,height:u}=this.getFullTextDimensions(this.keyValue,t.keyValue.font);return this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(10,(this.width-l)/2),y:this.height*(.5-tC*2)+10/2+(n+u/2)/2}}),e}get title(){return this.runtime.title.text??``}get keyValue(){return this.runtime.keyValue}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return nC(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return qx(this.backgroundColor)}getTextDimensions(e,t){this.context.font=t;let n=this.context.measureText(e);return{width:n.width,height:n.actualBoundingBoxAscent+n.actualBoundingBoxDescent}}getFullTextDimensions(e,t){this.context.font=t;let n=this.context.measureText(e);return{width:n.width,height:n.fontBoundingBoxAscent+n.fontBoundingBoxDescent}}getTextStyles(){let e=16,t=Math.floor(.9*e);return this.runtime.progressBar&&(e/=1.5),{title:{font:zc(this.runtime.title.fontSize??14,this.runtime.title.bold,this.runtime.title.italic),color:this.runtime.title.color??this.secondaryFontColor},keyValue:{color:this.runtime.keyValueStyle?.textColor||this.runtime.fontColor,font:zc(32,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},baselineValue:{font:zc(e,this.runtime.baselineStyle?.bold,this.runtime.baselineStyle?.italic),strikethrough:this.runtime.baselineStyle?.strikethrough,underline:this.runtime.baselineStyle?.underline,color:this.runtime.baselineStyle?.textColor||this.runtime.baselineColor||this.secondaryFontColor},baselineDescr:{font:zc(t),color:this.secondaryFontColor},baselineArrow:this.baselineArrow===`neutral`||this.runtime.progressBar?void 0:{size:this.keyValue?.8*e:0,color:this.runtime.baselineColor||this.secondaryFontColor}}}},aC=class extends t.Component{static template=`o-spreadsheet-ScorecardChart`;static props={figureUI:Object};canvas=(0,t.useRef)(`chartContainer`);get runtime(){return this.env.model.getters.getChartRuntime(this.props.figureUI.id)}get title(){return O(this.env.model.getters.getChartDefinition(this.props.figureUI.id).title.text??``)}setup(){(0,t.useEffect)(this.createChart.bind(this),()=>{let e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]})}createChart(){let e=this.canvas.el;$S(rC(e.getBoundingClientRect(),this.runtime),e)}};let oC=new h;oC.add(`dataValidation`,{displayAllOnInitialContent:!0,canBeToggled:!1,getProposals(e,t){return en(t)||!this.composer.currentEditedCell?[]:sC(this.getters,this.composer.currentEditedCell).map(e=>({text:e.value?.toString()||``,htmlContent:[{value:e.label}],fuzzySearchKey:e.label}))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}});function sC(e,t){let n=e.getValidationRuleForCell(t);if(!n||n.criterion.type!==`isValueInList`&&n.criterion.type!==`isValueInRange`)return[];let r=[];if(n.criterion.type===`isValueInList`)r=n.criterion.values.map(e=>({label:e,value:e}));else{let i=new Set,a=e.getRangeFromSheetXC(t.sheetId,n.criterion.values[0]);for(let t of wr(a.zone)){let n=e.getEvaluatedCell({...t,sheetId:a.sheetId});n.formattedValue&&!i.has(n.formattedValue)&&(i.add(n.formattedValue),r.push({label:n.formattedValue,value:n.value}))}}return r}function cC(e,t,n,r){let i=[];e=e.toLowerCase();for(let a of e){let e=t.toLocaleLowerCase().indexOf(a);e!==-1&&(i.push({value:t.slice(0,e),color:``},{value:t[e],color:n,classes:[r]}),t=t.slice(e+1))}return i.push({value:t}),i.filter(e=>e.value)}oC.add(`functions`,{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if(e.type!==`SYMBOL`)return[];let t=e.value;return en(this.composer.currentContent)?Object.entries(ix.content).filter(([e,{hidden:t}])=>!t).map(([e,{description:n}])=>({text:e,description:n,htmlContent:cC(t,e,he,`o-semi-bold`)})).sort((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)):[]},selectProposal(e,t){let n=e.end,r=e.end;[`SYMBOL`,`FUNCTION`].includes(e.type)&&(n=e.start);let i=this.composer.currentTokens;t+=`(`;let a=i.map(e=>e.start).indexOf(e.start);a+1<i.length&&i[a+1]?.type===`LEFT_PAREN`&&r++,this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t)}});function lC(e,t,n){let{x:r,y:i,width:a,height:o}=n;if(a<0||o<0)return;let s=t.color||`#37A850`,{ctx:c}=e;c.save(),t.noBorder||(t.dashed&&c.setLineDash([5,3]),c.strokeStyle=s,t.thinLine?(c.lineWidth=1,c.strokeRect(r,i,a,o)):(c.lineWidth=2,c.strokeRect(r+.5,i+.5,a,o))),t.noFill||(c.fillStyle=xn(sn(s),t.fillAlpha??.12),c.fillRect(r,i,a,o)),c.restore()}var uC=class extends ef{mutators=[`register`,`unRegister`];providers=[];constructor(e){super(e),this.onDispose(()=>{this.providers=[]})}get renderingLayers(){return[`Highlights`]}get highlights(){let e=this.getters.getActiveSheetId();return this.providers.flatMap(e=>e.highlights).filter(t=>t.sheetId===e).map(e=>{let{numberOfRows:t,numberOfCols:n}=br(e.zone),r=t*n===1?this.getters.expandZone(e.sheetId,e.zone):e.zone;return{...e,zone:r}})}register(e){this.providers.push(e)}unRegister(e){this.providers=this.providers.filter(t=>t!==e)}drawLayer(e,t){if(t===`Highlights`)for(let t of this.highlights)lC(e,t,this.getters.getVisibleRect(t.zone))}},dC=class{mutators=[`notifyUser`,`raiseError`,`askConfirmation`,`updateNotificationCallbacks`];notifyUser=e=>window.alert(e.text);askConfirmation=(e,t,n)=>{window.confirm(e)?t():n?.()};raiseError=(e,t)=>{window.alert(e),t?.()};updateNotificationCallbacks(e){this.notifyUser=e.notifyUser||this.notifyUser,this.raiseError=e.raiseError||this.raiseError,this.askConfirmation=e.askConfirmation||this.askConfirmation}};let fC=`#000000`,pC=`#3da4ab`,mC={OPERATOR:pC,NUMBER:`#02c39a`,STRING:`#00a82d`,FUNCTION:fC,DEBUGGER:pC,LEFT_PAREN:fC,RIGHT_PAREN:fC,ARG_SEPARATOR:fC,ORPHAN_RIGHT_PAREN:`#ff0000`};var hC=class extends ef{mutators=[`startEdition`,`setCurrentContent`,`stopEdition`,`stopComposerRangeSelection`,`cancelEdition`,`cycleReferences`,`toggleEditionMode`,`changeComposerCursorSelection`,`replaceComposerCursorSelection`,`hoverToken`];col=0;row=0;editionMode=`inactive`;sheetId=``;_currentContent=``;currentTokens=[];selectionStart=0;selectionEnd=0;initialContent=``;colorIndexByRange={};hoveredTokens=[];hoveredContentEvaluation=``;notificationStore=this.get(dC);highlightStore=this.get(uC);constructor(e){super(e),this.highlightStore.register(this),this.onDispose(()=>{this.highlightStore.unRegister(this),this._cancelEdition()})}handleEvent(e){let t=this.getters.getActiveSheetId(),n;switch(n=e.options.unbounded?this.getters.getUnboundedZone(t,e.anchor.zone):e.anchor.zone,e.mode){case`newAnchor`:this.editionMode===`selecting`&&this.insertSelectedRange(n);break;default:this.editionMode===`selecting`?this.replaceSelectedRange(n):this.updateComposerRange(e.previousAnchor.zone,n);break}}changeComposerCursorSelection(e,t){this.isSelectionValid(this._currentContent.length,e,t)&&(this.selectionStart=e,this.selectionEnd=t,this.stopComposerRangeSelection(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode=`editing`)}startEdition(e,t){if(t){let n=e||this.getComposerContent(this.getters.getActivePosition());if(!this.isSelectionValid(n.length,t.start,t.end))return}let{col:n,row:r}=this.getters.getActivePosition();this.model.dispatch(`SELECT_FIGURE`,{figureId:null}),this.model.dispatch(`SCROLL_TO_CELL`,{col:n,row:r}),this.editionMode!==`inactive`&&e?this.setContent(e,t):this._startEdition(e,t),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor()}cancelEdition(){this.resetContent(),this.cancelEditionAndActivateSheet()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case`SELECT_FIGURE`:e.figureId&&(this.resetContent(),this.cancelEditionAndActivateSheet());break;case`START_CHANGE_HIGHLIGHT`:let{left:t,top:n}=e.zone;this.isSelectingRange&&(this.editionMode=`editing`),this.model.selection.resetAnchor(this,{cell:{col:t,row:n},zone:e.zone});break}}get currentContent(){return this.editionMode===`inactive`?this.getComposerContent(this.getters.getActivePosition()):this._currentContent}get composerSelection(){return{start:this.selectionStart,end:this.selectionEnd}}get isSelectingRange(){return this.editionMode===`selecting`}get showSelectionIndicator(){return this.isSelectingRange&&this.canStartComposerRangeSelection()}get tokenAtCursor(){let e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd);if(!(e===t&&t===0))return this.currentTokens.find(n=>n.start<=e&&n.end>=t)}cycleReferences(){let e=this.getters.getLocale(),t=ty(this.composerSelection,this._currentContent,e);t!==void 0&&this.setCurrentContent(t.content,t.selection)}toggleEditionMode(){if(this.editionMode===`inactive`)return;let e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd),n=[...this.currentTokens].reverse().find(n=>n.end>=e&&t>=n.start&&n.type===`REFERENCE`);if(this.editionMode===`editing`&&n){let e=this.getters.getActiveSheetId(),{sheetName:t,xc:r}=ac(n.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=n.end;let a=this.getters.getRangeFromSheetXC(this.sheetId,r).zone;this.captureSelection(a),this.editionMode=`selecting`}else this.editionMode=`editing`}hoverToken(e){this.currentTokens.forEach(e=>e.isInHoverContext=void 0);let t=[...this.currentTokens];if(e===void 0||[`ARG_SEPARATOR`,`SPACE`].includes(t[e].type)){this.hoveredContentEvaluation=``,this.hoveredTokens=[];return}let n=this.getNumberOfMissingParenthesis(t);n>0&&t.push(...Array(n).fill({value:`)`,type:`RIGHT_PAREN`}));let r=t;if(e!==0){let n=this.getRelatedTokens(t,e),i=t.filter(e=>!n.includes(e)&&e.type!==`SPACE`);r=i.length===1&&i[0]===t[0]?t:n}r.forEach(e=>e.isInHoverContext=!0);let i=r.map(e=>e.value).join(``);en(i)||(i=`=${i}`);let a=Ll(i,this.getters.getLocale()),o=this.evaluateCanonicalFormula(a);this.hoveredTokens=r,this.hoveredContentEvaluation=this.evaluationResultToDisplayString(o)}evaluateCanonicalFormula(e){return this.getters.evaluateFormulaResult(this.sheetId,e)}getRelatedTokens(e,t){try{let n=Pv(e),r;for(let e of Iv(n))if(t>=e.tokenStartIndex&&t<=e.tokenEndIndex)r=e;else if(t<e.tokenStartIndex)break;return r?e.slice(r.tokenStartIndex,r.tokenEndIndex+1):e}catch(t){if(t instanceof M)return e;throw t}}evaluationResultToDisplayString(e){let t=this.getters.getLocale();if(A(e)){let n=t.decimalSeparator===`,`?`/`:`,`;return`{${Qa(e).map(e=>e.map(e=>this.cellValueToDisplayString(e)).join(n)).join(`;`)}}`}return this.cellValueToDisplayString(e)}cellValueToDisplayString(e){let t=e.value;switch(typeof t){case`number`:return B(t,{locale:this.getters.getLocale(),format:e.format});case`string`:return P(t)?t:`"${t}"`;case`boolean`:return t?`TRUE`:`FALSE`}return`0`}captureSelection(e,t,n){this.model.selection.capture(this,{cell:{col:t??e.left,row:n??e.top},zone:e},{handleEvent:this.handleEvent.bind(this),release:()=>{this._stopEdition()}})}isSelectionValid(e,t,n){return t>=0&&t<=e&&n>=0&&n<=e}startComposerRangeSelection(){if(this.sheetId===this.getters.getActiveSheetId()){let e=E({col:this.col,row:this.row});this.model.selection.resetAnchor(this,{cell:{col:this.col,row:this.row},zone:e})}this.editionMode=`selecting`}_startEdition(e,t){let n=this.getters.getActiveCell(),r=this.getters.getLocale();e&&n.format?.includes(`%`)&&Li(e,r)&&(t||={start:e.length,end:e.length},e=`${e}%`);let{col:i,row:a,sheetId:o}=this.getters.getActivePosition();this.col=i,this.sheetId=o,this.row=a,this.initialContent=this.getComposerContent({sheetId:o,col:i,row:a}),this.editionMode=`editing`,this.setContent(e||this.initialContent,t),this.colorIndexByRange={};let s=E({col:this.col,row:this.row});this.captureSelection(s,i,a)}_stopEdition(){if(this.editionMode!==`inactive`){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(this.initialContent===e)return;if(e&&en(e)){let t=this.getNumberOfMissingParenthesis(this.currentTokens);t>0&&(e+=Ot(Array(t).fill(`)`)))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return Ll(this._currentContent,this.getters.getLocale())}cancelEditionAndActivateSheet(){this.editionMode!==`inactive`&&(this._cancelEdition(),this.getters.getActiveSheetId()!==this.sheetId&&this.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:this.getters.getActiveSheetId(),sheetIdTo:this.sheetId}))}_cancelEdition(){this.editionMode!==`inactive`&&(this.editionMode=`inactive`,this.model.selection.release(this),this.colorIndexByRange={},this.hoveredTokens=[],this.hoveredContentEvaluation=``)}resetContent(){this.setContent(this.initialContent||``)}setContent(e,t,n){let r=this._currentContent!==e;if(this._currentContent=e,t?(this.selectionStart=t.start,this.selectionEnd=t.end):this.selectionStart=this.selectionEnd=e.length,r||this.editionMode!==`inactive`){let t=this.getters.getLocale();this.currentTokens=en(e)?Kv(e,t):[],this.currentTokens.length>100&&n&&this.notificationStore.raiseError(O(`This formula has over 100 parts. It can't be processed properly, consider splitting it into multiple cells`))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection()}getAutoCompleteProviders(){return oC.getAll()}insertSelectedRange(e){let t=Math.min(this.selectionStart,this.selectionEnd),n=this.getZoneReference(e);this.canStartComposerRangeSelection()?this.insertText(n,t):this.insertText(`,`+n,t)}replaceSelectedRange(e){let t=this.getZoneReference(e),n=this.tokenAtCursor,r=n?.type===`REFERENCE`?n.start:this.selectionStart;this.replaceText(t,r,this.selectionEnd)}updateComposerRange(e,t){let n=this.getters.getActiveSheetId(),r=this.tokenAtCursor,i=(r?[r,...this.currentTokens]:this.currentTokens).filter(e=>e.type===`REFERENCE`).find(t=>{let{xc:r,sheetName:i}=ac(t.value),a=i||this.getters.getSheetName(this.sheetId);if(!Fc(this.getters.getSheetName(n),a))return!1;let o=this.getters.getRangeFromSheetXC(n,r);return gr(this.getters.expandZone(n,o.zone),e)});if(!i)return;let a=this.getters.getRangeFromSheetXC(n,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;let o=this.getters.getRangeFromZone(n,t),s=this.getRangeReference(o,a.parts);this.replaceSelection(s)}getZoneReference(e){let t=this.sheetId,n=this.getters.getActiveSheetId(),r=this.getters.getRangeFromZone(n,e);return this.getters.getSelectionRangeString(r,t)}getRangeReference(e,t){let n=[...t],r={...e,parts:n};return this.getters.getSelectionRangeString(r,this.sheetId)}replaceSelection(e){let t=Math.min(this.selectionStart,this.selectionEnd),n=Math.max(this.selectionStart,this.selectionEnd);this.replaceText(e,t,n)}replaceText(e,t,n){this._currentContent=this._currentContent.slice(0,t)+this._currentContent.slice(n,this._currentContent.length),this.insertText(e,t)}insertText(e,t){let n=this._currentContent.slice(0,t)+e+this._currentContent.slice(t),r=t+e.length;this.setCurrentContent(n,{start:r,end:r})}updateTokenColor(){this.updateRangeColor();for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].color=this.getTokenColor(this.currentTokens[e])}getTokenColor(e){if(e.type===`REFERENCE`){let{xc:t,sheetName:n}=ac(e.value);return this.rangeColor(t,n)||`#000000`}if(e.type===`SYMBOL`){let t=e.value.toUpperCase();if(t===`TRUE`||t===`FALSE`)return mC.NUMBER;if(t in ix.content)return mC.FUNCTION}return[`LEFT_PAREN`,`RIGHT_PAREN`].includes(e.type)&&e.parenthesesCode===``?mC.ORPHAN_RIGHT_PAREN:mC[e.type]||`#000000`}rangeColor(e,t){let n=t?this.model.getters.getSheetIdByName(t):this.sheetId,r=this.highlights.find(t=>{if(t.sheetId!==n)return!1;let r=this.model.getters.getRangeFromSheetXC(n,e).zone;return r=Nr(r)===1?this.model.getters.expandZone(n,r):r,gr(r,t.zone)});return r&&r.color?r.color:void 0}computeFormulaCursorContext(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isBlurred=!1;if(this.selectionStart!==this.selectionEnd)return;let e=this.getParenthesesCodeAfterCursor(),t=[...this.currentTokens].reverse().find(t=>e.startsWith(t.parenthesesCode)&&t.type===`SYMBOL`);if(t)for(let e=0;e<this.currentTokens.length;e++)(this.currentTokens[e].parenthesesCode||``).startsWith(t.parenthesesCode||``)||(this.currentTokens[e].isBlurred=!0)}getParenthesesCodeAfterCursor(){let e=this.tokenAtCursor?.parenthesesCode||``;return this.tokenAtCursor?.type===`RIGHT_PAREN`?e.slice(0,-1)||``:e}computeParenthesisRelatedToCursor(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isParenthesisLinkedToCursor=!1;let e=this.tokenAtCursor;if(!(!e||e.parenthesesCode===``||![`LEFT_PAREN`,`RIGHT_PAREN`].includes(e.type)))for(let t=0;t<this.currentTokens.length;t++){let n=this.currentTokens[t];[`LEFT_PAREN`,`RIGHT_PAREN`].includes(n.type)&&n.parenthesesCode===e.parenthesesCode&&n!==e&&(this.currentTokens[t].isParenthesisLinkedToCursor=!0,this.tokenAtCursor.isParenthesisLinkedToCursor=!0)}}updateRangeColor(){if(!en(this._currentContent)||this.editionMode===`inactive`)return;let e=this.sheetId,t=this.getReferencedRanges().map(t=>this.getters.getRangeString(t,e)),n={};for(let e of t)this.colorIndexByRange[e]!==void 0&&(n[e]=this.colorIndexByRange[e]);let r=new Set(Object.values(n)),i=0,a=()=>{for(;r.has(i);)i++;return r.add(i),i};for(let e of t)n[e]=e in n?n[e]:a();this.colorIndexByRange=n}get highlights(){if(!en(this.currentContent)||this.editionMode===`inactive`)return[];let e=this.sheetId,t=e=>rn[this.colorIndexByRange[e]%rn.length];return this.getReferencedRanges().map(n=>{let r=this.getters.getRangeString(n,e),{numberOfRows:i,numberOfCols:a}=br(n.zone);return{zone:i*a===1?this.getters.expandZone(n.sheetId,n.zone):n.zone,color:t(r),sheetId:n.sheetId,interactive:!0}})}getReferencedRanges(){let e=this.sheetId;return this.currentTokens.filter(e=>e.type===`REFERENCE`).map(t=>this.getters.getRangeFromSheetXC(e,t.value)).filter(e=>!e.invalidSheetName&&!e.invalidXc)}get autocompleteProvider(){let e=this.currentContent,t=en(e)?this.tokenAtCursor:{type:`STRING`,value:e};if(this.editionMode===`inactive`||!t||[`TRUE`,`FALSE`].includes(t.value.toUpperCase())||!(this.canStartComposerRangeSelection()||[`SYMBOL`,`STRING`,`UNKNOWN`].includes(t.type)))return;let n={composer:this,getters:this.getters},r=this.getAutoCompleteProviders().sort((e,t)=>(e.sequence??1/0)-(t.sequence??1/0)).map(r=>({...r,getProposals:r.getProposals.bind(n,t,e),selectProposal:r.selectProposal.bind(n,t)}));for(let e of r){let n=e.getProposals(),r=n?.find(e=>e.text===t.value),i=t.value.replace(/[ ,\(\)]/g,``);if(this._currentContent===this.initialContent&&e.displayAllOnInitialContent&&n?.length)return{proposals:n,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled};if(r&&this._currentContent!==this.initialContent)return;if(i&&n&&![`ARG_SEPARATOR`,`LEFT_PAREN`,`OPERATOR`].includes(t.type)){let e=kc(i,n,e=>e.fuzzySearchKey||e.text);(!r||e.length)&&(n=e)}if(e.maxDisplayedProposals&&(n=n?.slice(0,e.maxDisplayedProposals)),n?.length)return{proposals:n,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled}}}canStartComposerRangeSelection(){if(en(this._currentContent)){let e=this.tokenAtCursor;if(!e)return!1;let t=this.currentTokens.map(e=>e.start).indexOf(e.start),n=t,r=e;for(;![`ARG_SEPARATOR`,`LEFT_PAREN`,`OPERATOR`].includes(r.type)||vl.includes(r.value);){if(r.type!==`SPACE`||n<1)return!1;n--,r=this.currentTokens[n]}for(n=t+1,r=this.currentTokens[n];r&&![`ARG_SEPARATOR`,`RIGHT_PAREN`,`OPERATOR`].includes(r.type);){if(r.type!==`SPACE`)return!1;n++,r=this.currentTokens[n]}return!0}return!1}getNumberOfMissingParenthesis(e){return e.filter(e=>e.type===`LEFT_PAREN`).length-e.filter(e=>e.type===`RIGHT_PAREN`).length}};let gC=[`PIVOT.VALUE`,`PIVOT.HEADER`,`PIVOT`];function _C(e,t){let n=`"${t?`${e.name}:${t}`:e.name}"`,r=e.string===e.name?n:e.string+n;return{text:n,description:e.string+(e.help?` (${e.help})`:``),htmlContent:[{value:n,color:mC.STRING}],fuzzySearchKey:r}}function vC(e){let t=`"${e.id}"`,n=e.displayName+e.fieldName+t;return{text:t,description:e.displayName,htmlContent:[{value:t,color:mC.STRING}],fuzzySearchKey:n}}function yC(e,t){let n=e.end,r=e.end;e.type!==`ARG_SEPARATOR`&&(n=e.start),this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t)}function bC(e,t){let n=e.end,r=e.end;e.type!==`LEFT_PAREN`&&(n=e.start),this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t)}function xC(e){let t=e.functionContext?.args[0];if(!(!t||![`STRING`,`NUMBER`].includes(t.type)))return t.value}function SC(e){return kx(e,gC)[0]}function CC(e){return kx(e,gC).length}let wC=new h;wC.add(`SPREADSHEET`,!1),oC.add(`pivot_ids`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(!t||![`PIVOT.VALUE`,`PIVOT.HEADER`,`PIVOT`].includes(t.parent.toUpperCase())||t.argPosition!==0)return;let n=this.getters.getPivotIds();if(!n.includes(e.value))return n.map(e=>{let t=this.getters.getPivotCoreDefinition(e),n=`${this.getters.getPivotFormulaId(e)}`;return{text:n,description:t.name,htmlContent:[{value:n,color:mC.NUMBER}],fuzzySearchKey:n+t.name,alwaysExpanded:!0}}).filter(C)},selectProposal:bC}),oC.add(`pivot_measures`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(t?.parent.toUpperCase()!==`PIVOT.VALUE`||t.argPosition!==1)return[];let n=xC(e),r=this.getters.getPivotId(n);if(!r||!this.getters.isExistingPivot(r))return[];let i=this.getters.getPivot(r);return i.init(),i.isValid()?i.definition.measures.map(e=>{if(e.fieldName===`__count`){let e=`"__count"`;return{text:e,description:O(`Count`),htmlContent:[{value:e,color:mC.STRING}],fuzzySearchKey:O(`Count`)+e}}return vC(e)}).filter(C):[]},selectProposal:yC}),oC.add(`pivot_group_fields`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(!t||!TC(e)&&!EC(e))return;let n=xC(e),r=this.getters.getPivotId(n);if(!r||!this.getters.isExistingPivot(r))return;let i=this.getters.getPivot(r);i.init();let a=i.getFields(),{columns:o,rows:s}=i.definition,c=t.args;t?.parent.toUpperCase()===`PIVOT.VALUE`?(c=c.filter((e,t)=>t%2==0),c=c.slice(1,t.argPosition)):c=c.filter((e,t)=>t%2==1);let l=c.map(e=>e?.value).filter(C),u=o.map(e=>e.nameWithGranularity),d=s.map(e=>e.nameWithGranularity),f=[],p=[`ARG_SEPARATOR`,`SPACE`].includes(e.type)?l.at(-1):l.at(-2),m=wC.get(i.type);if(m&&p?.startsWith(`#`)&&(p=p.slice(1)),p===void 0&&(f.push(u[0]),f.push(d[0])),d.includes(p)){let e=d[d.indexOf(p)+1];f.push(e),f.push(u[0])}if(u.includes(p)){let e=u[u.indexOf(p)+1];f.push(e)}let h=f.filter(C);return h.map(e=>{let[t,n]=e.split(`:`),r=a[t];return r?_C(r,n):void 0}).concat(h.map(e=>{if(!m)return;let t=a[e.split(`:`)[0]];if(!t)return;let n=`"#${e}"`;return{text:n,description:O(`%s (positional)`,t.string)+(t.help?` (${t.help})`:``),htmlContent:[{value:n,color:mC.STRING}],fuzzySearchKey:t.string+n}})).filter(C)},selectProposal:yC});function TC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.VALUE`&&t.argPosition>=2&&t.argPosition%2==0}function EC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.HEADER`&&t.argPosition>=1&&t.argPosition%2==1}oC.add(`pivot_group_values`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(!t||!e||!DC(e)&&!OC(e))return;let n=xC(e),r=this.getters.getPivotId(n);if(!r||!this.getters.isExistingPivot(r))return;let i=this.getters.getPivot(r);if(!i.isValid())return;let a=t.argPosition,o=e.functionContext?.args[a-1]?.value;if(!o)return;let s;try{s=i.definition.getDimension(o)}catch{return}return s.granularity===`month_number`?Object.values(Yo).map((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:mC.NUMBER}]})):s.granularity===`quarter_number`?[1,2,3,4].map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:O(`Quarter %s`,e),htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`day_of_month`?S(1,32).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`iso_week_number`?S(0,54).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`day_of_week`?S(1,8).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`hour_number`?S(0,24).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`minute_number`?S(0,60).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`second_number`?S(0,60).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):i.getPossibleFieldValues(s).map(({value:e,label:t})=>{let n=typeof e==`string`,r=n?`"${e}"`:e.toString(),i=n?mC.STRING:mC.NUMBER,a=t===e?``:t;return{text:r,description:a,htmlContent:[{value:r,color:i}],fuzzySearchKey:r+a}})},selectProposal:yC});function DC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.VALUE`&&t.argPosition>=2&&t.argPosition%2==1}function OC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.HEADER`&&t.argPosition>=1&&t.argPosition%2==0}oC.add(`sheet_names`,{sequence:150,autoSelectFirstProposal:!0,getProposals(e){return e.type===`SYMBOL`||e.type===`UNKNOWN`&&e.value.startsWith(`'`)?this.getters.getSheetIds().map(e=>{let t=lt(this.getters.getSheetName(e));return{text:t,fuzzySearchKey:t.startsWith(`'`)?t:`'`+t}}):[]},selectProposal(e,t){let n=e.start,r=e.end;this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t+`!`)}});let kC=new h;kC.add(`ALPHANUMERIC_INCREMENT_MODIFIER`,{apply:(e,t)=>{e.current+=e.increment;let n=`${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:n},tooltip:{props:{content:n}}}}}).add(`INCREMENT_MODIFIER`,{apply:(e,t,n)=>{e.current+=e.increment;let r=e.current.toString(),i=n.getLocale(),a=B(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:r},tooltip:r?{props:{content:a}}:void 0}}}).add(`DATE_INCREMENT_MODIFIER`,{apply:(e,t,n)=>{let r=R(e.current,n.getLocale());r.setFullYear(r.getFullYear()+e.increment.years||0),r.setMonth(r.getMonth()+e.increment.months||0),r.setDate(r.getDate()+e.increment.days||0);let i=yi(r);e.current=i;let a=n.getLocale(),o=B(i,{format:t.cell?.format,locale:a});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:o}}:void 0}}}).add(`COPY_MODIFIER`,{apply:(e,t,n)=>{let r=t.cell?.content||``,i={locale:n.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:r},tooltip:r?{props:{content:t.cell?Ms(t.cell,i).formattedValue:``}}:void 0}}}).add(`FORMULA_MODIFIER`,{apply:(e,t,n,r)=>{e.current+=e.increment;let i=0,a=0;switch(r){case`up`:i=0,a=-e.current;break;case`down`:i=0,a=e.current;break;case`left`:i=-e.current,a=0;break;case`right`:i=e.current,a=0;break}let o=t.cell;if(!o||!o.isFormula)return{cellData:{}};let s=t.sheetId,c=n.getTranslatedCellFormula(s,i,a,o.compiledFormula.tokens);return{cellData:{border:t.border,style:o.style,format:o.format,content:c},tooltip:c?{props:{content:c}}:void 0}}});let AC=new h,jC=/(\d+)$/,MC=/^(.*\D+)/,NC=/^(.*\D+)(\d+)$/;function PC(e,t,n){let r=[],i=!1;for(let a of t){a===e&&(i=!0);let t=a===void 0||a.isFormula?void 0:Ms(a,{locale:k,format:a.format});if(t&&n(t))r.push(t);else{if(i)return r;r=[]}}return r}function FC(e){let t=[],n=e[0];for(let r=1;r<e.length;r++){let i=e[r];t.push(i-n),n=i}return t.reduce((e,t)=>e+t,0)/t.length}function IC(e){let t=1;return e.length>=2&&(t=FC(e)*e.length),t}function LC(e){return e.length<2?e[0]||{years:0,months:0,days:0}:e.every(t=>t.years===e[0].years&&t.months===e[0].months&&t.days===e[0].days)?e[0]:void 0}function RC(e){if(e.length<2)return 1;let t=e.map(e=>R(e,k)),n=LC(zC(t));if(n===void 0)return;let r=Object.values(n).filter(e=>e!==0).length===1,i=Object.values(n).every(e=>e===0);if(!r||i){let n=t.map((e,n)=>{if(n===0)return 0;let r=t[n-1];return Math.floor(e.getTime())-Math.floor(r.getTime())}).slice(1);if(n.every(e=>e===n[0]))return e.length*(e[1]-e[0])}return{years:n.years*e.length,months:n.months*e.length,days:n.days*e.length}}AC.add(`simple_value_copy`,{condition:(e,t)=>t.length===1&&!e.isFormula&&!(e.format&&ls(e.format)),generateRule:()=>({type:`COPY_MODIFIER`}),sequence:10}).add(`increment_alphanumeric_value`,{condition:e=>!e.isFormula&&Ms(e,{locale:k}).type===`text`&&NC.test(e.content),generateRule:(e,t,n)=>{let r=parseInt(e.content.match(jC)[0]),i=e.content.match(MC)[0],a=e.content.length-i.length,o=PC(e,t,e=>e.type===`text`&&NC.test(e.value)).filter(e=>i===(e.value??``).toString().match(MC)[0]).map(e=>parseInt((e.value??``).toString().match(jC)[0])),s=IC(o);return[`up`,`left`].includes(n)&&o.length===1&&(s=-s),{type:`ALPHANUMERIC_INCREMENT_MODIFIER`,prefix:i,current:r,increment:s,numberPostfixLength:a}},sequence:15}).add(`copy_text`,{condition:e=>!e.isFormula&&Ms(e,{locale:k}).type===`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&&Ms(e,{locale:k}).type===`number`&&!!e.format&&ls(e.format),generateRule:(e,t)=>{let n=RC(PC(e,t,e=>e.type===`number`&&!!e.format&&ls(e.format)).map(e=>Number(e.value)));if(n===void 0)return{type:`COPY_MODIFIER`};let r=Ms(e,{locale:k});return typeof n==`object`?{type:`DATE_INCREMENT_MODIFIER`,increment:n,current:r.type===`number`?r.value:0}:{type:`INCREMENT_MODIFIER`,increment:n,current:r.type===`number`?r.value:0}},sequence:25}).add(`increment_number`,{condition:e=>!e.isFormula&&Ms(e,{locale:k}).type===`number`,generateRule:(e,t,n)=>{let r=PC(e,t,e=>e.type===`number`&&!ls(e.format||``)).map(e=>Number(e.value)),i=IC(r);[`up`,`left`].includes(n)&&r.length===1&&(i=-i);let a=Ms(e,{locale:k});return{type:`INCREMENT_MODIFIER`,increment:i,current:a.type===`number`?a.value:0}},sequence:40});function zC(e){return e.length<2?[{years:0,months:0,days:0}]:e.map((t,n)=>{if(n===0)return{years:0,months:0,days:0};let r=D.fromTimestamp(e[n-1].getTime()),i=Di(r,t),a=Ti(r,t)%12;return r.setFullYear(r.getFullYear()+i),r.setMonth(r.getMonth()+a),{years:i,months:a,days:Ei(r,t)}}).slice(1)}let BC=new h,VC=`#F3F2F1`;function HC(e,t){let n=e.getBoundingClientRect(),r=window.devicePixelRatio||1;e.width=r*n.width,e.height=r*n.height;let i=e.getContext(`2d`);i.scale(r,r);let a=JC(n,t,i);WC(i,a),UC(i,a),KC(i,a),GC(i,a),qC(i,a)}function UC(e,t){e.save();let n=t.gauge,r=n.rect.x+n.rect.width/2,i=n.rect.y+n.rect.height,a=n.rect.height-n.arcWidth/2;if(a<0)return;let o=n.percentage===1?0:Math.PI*(1+n.percentage);e.strokeStyle=VC,e.beginPath(),e.lineWidth=n.arcWidth,e.arc(r,i,a,o,0),e.stroke(),e.strokeStyle=n.color,e.beginPath(),e.arc(r,i,a,Math.PI,o),e.stroke(),e.restore()}function WC(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}function GC(e,t){for(let n of[t.minLabel,t.maxLabel,t.gaugeValue])e.save(),e.textAlign=`center`,e.fillStyle=n.color,e.font=`${n.fontSize}px ${Ve}`,e.fillText(n.label,n.textPosition.x,n.textPosition.y),e.restore()}function KC(e,t){let{x:n,y:r,width:i,height:a}=t.gauge.rect;for(let o of t.inflectionValues){e.save(),e.translate(n+i/2-.5,r+a-.5),e.rotate(Math.PI/2-o.rotation),e.lineWidth=2,e.strokeStyle=qx(t.backgroundColor)+`aa`,e.beginPath(),e.moveTo(0,-(a-t.gauge.arcWidth)),e.lineTo(0,-a-3),e.stroke(),e.textAlign=`center`,e.font=`${o.fontSize}px ${Ve}`,e.fillStyle=o.color;let s=-a-6-o.offset;e.fillText(o.label,0,s),e.restore()}}function qC(e,t){e.save();let n=t.title;e.font=zc(n.fontSize,n.bold,n.italic),e.textBaseline=`middle`,e.fillStyle=n.color,e.fillText(n.label,n.textPosition.x,n.textPosition.y),e.restore()}function JC(e,t,n){let r=t.maxValue,i=t.minValue,a=t.gaugeValue,o=YC(e,t.title.text),s=o.width/6,c=a?(a.value-i.value)/(r.value-i.value):0,l={x:e.width/2,y:o.y+o.height-o.height/12},u=80;o.height<300&&(u*=o.height/300);let d=o.width/2,f=a?.label||`-`;Vc(n,f,{fontSize:u},`px`)>d&&(u=Zc(d,u,e=>Vc(n,f,{fontSize:e},`px`)));let p={x:o.x+s/2,y:o.y+o.height+12},m={x:o.x+o.width-s/2,y:o.y+o.height+12},h=qx(t.background),g=XC(t,o,h,n),_=0,v=0,y=0;switch(t.title.text&&({width:v,height:y}=Wc(n,t.title.text,{fontSize:16,...t.title},`px`)),t.title.align){case`right`:_=e.width-v-20;break;case`center`:_=(e.width-v)/2;break;default:_=20;break}return{width:e.width,height:e.height,title:{label:t.title.text??``,fontSize:t.title.fontSize??16,textPosition:{x:_,y:15+y/2},color:t.title.color??h,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:o,arcWidth:s,percentage:x(c,0,1),color:ZC(t)},inflectionValues:g,gaugeValue:{label:f,textPosition:l,fontSize:u,color:h},minLabel:{label:t.minValue.label,textPosition:p,fontSize:12,color:h},maxLabel:{label:t.maxValue.label,textPosition:m,fontSize:12,color:h}}}function YC(e,t){let n=t?25:0,r=e.height-20-n-10,i=e.width-60,a,o;return i>2*r?(a=2*r,o=r):(a=i,o=i/2),{x:30+(i-a)/2,y:n+10+(r-o)/2,width:a,height:o}}function XC(e,t,n,r){let i=e.maxValue,a=e.minValue,o={x:t.x+t.width/2,y:t.y+t.height},s={fontSize:12},c=[],l=[];for(let u of e.inflectionValues){let e=(u.value-a.value)/(i.value-a.value),d=Vc(r,u.label,s,`px`),f=Math.PI-Math.PI*e,p=tw(f,t.height+6,o.x,o.y,d+2,12),m=l.some(e=>ew(e,p))?12:0;l.push(p),c.push({rotation:f,label:u.label,fontSize:12,color:n,offset:m})}return c}function ZC(e){let t=e.gaugeValue?.value;if(t===void 0)return VC;for(let n=0;n<e.inflectionValues.length;n++){let r=e.inflectionValues[n];if(r.operator===`<`&&t<r.value||r.operator===`<=`&&t<=r.value)return e.colors[n]}return e.colors.at(-1)}function QC(e){return[{start:e.topLeft,end:e.topRight},{start:e.topRight,end:e.bottomRight},{start:e.bottomRight,end:e.bottomLeft},{start:e.bottomLeft,end:e.topLeft}]}function $C(e,t){let n=e.start,r=e.end,i=t.start,a=t.end;function o(e,t,n){return(n.y-e.y)*(t.x-e.x)>(t.y-e.y)*(n.x-e.x)}return o(n,i,a)!==o(r,i,a)&&o(n,r,i)!==o(n,r,a)}function ew(e,t){let n=QC(e),r=QC(t);for(let e of n)for(let t of r)if($C(e,t))return!0;return!1}function tw(e,t,n,r,i,a){let o=Math.cos(e),s=Math.sin(e),c=o*t,l=s*t,u=i/2*s,d=i/2*o,f={x:c+u+n,y:r-(l-d)},p={x:c-u+n,y:r-(l+d)},m=o*(t+a),h=s*(t+a),g={x:m-u+n,y:r-(h+d)};return{bottomLeft:p,bottomRight:f,topRight:{x:m+u+n,y:r-(h-d)},topLeft:g}}var nw=class extends t.Component{static template=`o-spreadsheet-GaugeChartComponent`;canvas=(0,t.useRef)(`chartContainer`);get runtime(){return this.env.model.getters.getChartRuntime(this.props.figureUI.id)}setup(){(0,t.useEffect)(()=>HC(this.canvas.el,this.runtime),()=>{let e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]})}};nw.props={figureUI:Object};function rw(e){return e=sn(e).replace(`#`,``),e.length===8?e.slice(6)+e.slice(0,6):e}let iw={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1,events:[`mousemove`,`mouseout`,`click`,`touchstart`,`touchmove`,`mouseup`]};function aw(e,t,n){let r=document.createElement(`div`);r.style.width=`${t.width}px`,r.style.height=`${t.height}px`;let i=document.createElement(`canvas`);r.append(i),i.setAttribute(`width`,t.width.toString()),i.setAttribute(`height`,t.height.toString());let a;if(document.body.append(r),`chartJsConfig`in e){let t=mf();t||hf();let n=b(e.chartJsConfig);n.plugins=[sw];let r=new window.Chart(i,n);a=r.toBase64Image(),r.destroy(),t||gf()}else n===`scorecard`?($S(rC(t,e),i),a=i.toDataURL()):n===`gauge`&&(HC(i,e),a=i.toDataURL());return r.remove(),a}async function ow(e,t,n){let r=document.createElement(`div`);r.style.width=`${t.width}px`,r.style.height=`${t.height}px`,r.style.position=`fixed`,r.style.opacity=`0`;let i=document.createElement(`canvas`);r.append(i),i.setAttribute(`width`,t.width.toString()),i.setAttribute(`height`,t.height.toString()),document.body.append(r);let a=null;if(`chartJsConfig`in e){let t=mf();t||hf();let n=b(e.chartJsConfig);n.plugins=[sw];let r=new window.Chart(i,n);a=await new Promise(e=>i.toBlob(e,`image/png`)),r.destroy(),t||gf()}else n===`scorecard`?($S(rC(t,e),i),a=await new Promise(e=>i.toBlob(e,`image/png`))):n===`gauge`&&(HC(i,e),a=await new Promise(e=>i.toBlob(e,`image/png`)));return r.remove(),a?new File([a],`chart.png`,{type:`image/png`}):void 0}let sw={id:`customCanvasBackgroundColor`,beforeDraw:e=>{let{ctx:t}=e;t.save(),t.globalCompositeOperation=`destination-over`,t.fillStyle=`#ffffff`,t.fillRect(0,0,e.width,e.height),t.restore()}},cw={Errors:{InvalidRange:O(`The range is invalid`),FirstArgMissing:O(`The argument is missing. Please provide a value`),SecondArgMissing:O(`The second argument is missing. Please provide a value`),MinNaN:O(`The minpoint must be a number`),MidNaN:O(`The midpoint must be a number`),MaxNaN:O(`The maxpoint must be a number`),ValueUpperInflectionNaN:O(`The first value must be a number`),ValueLowerInflectionNaN:O(`The second value must be a number`),MinBiggerThanMax:O(`Minimum must be smaller then Maximum`),MinBiggerThanMid:O(`Minimum must be smaller then Midpoint`),MidBiggerThanMax:O(`Midpoint must be smaller then Maximum`),LowerBiggerThanUpper:O(`Lower inflection point must be smaller than upper inflection point`),MinInvalidFormula:O(`Invalid Minpoint formula`),MaxInvalidFormula:O(`Invalid Maxpoint formula`),MidInvalidFormula:O(`Invalid Midpoint formula`),ValueUpperInvalidFormula:O(`Invalid upper inflection point formula`),ValueLowerInvalidFormula:O(`Invalid lower inflection point formula`),EmptyRange:O(`A range needs to be defined`),ValueCellIsInvalidFormula:O(`At least one of the provided values is an invalid formula`),Unexpected:O(`The rule is invalid for an unknown reason`)},ColorScale:O(`Color scale`),IconSet:O(`Icon set`),DataBar:O(`Data bar`)},lw={IsEmpty:O(`Is empty`),IsNotEmpty:O(`Is not empty`),ContainsText:O(`Contains`),NotContains:O(`Does not contain`),BeginsWith:O(`Starts with`),EndsWith:O(`Ends with`),Equal:O(`Is equal to`),NotEqual:O(`Is not equal to`),GreaterThan:O(`Is greater than`),GreaterThanOrEqual:O(`Is greater than or equal to`),LessThan:O(`Is less than`),LessThanOrEqual:O(`Is less than or equal to`),Between:O(`Is between`),NotBetween:O(`Is not between`)},uw={Series:O(`Series`),BackgroundColor:O(`Background color`),StackedBarChart:O(`Stacked bar chart`),StackedLineChart:O(`Stacked line chart`),StackedAreaChart:O(`Stacked area chart`),StackedColumnChart:O(`Stacked column chart`),CumulativeData:O(`Cumulative data`),TreatLabelsAsText:O(`Treat labels as text`),AggregatedChart:O(`Aggregate`),Errors:{Unexpected:O(`The chart definition is invalid for an unknown reason`),InvalidDataSet:O(`The dataset is invalid`),InvalidLabelRange:O(`Labels are invalid`),InvalidScorecardKeyValue:O(`The key value is invalid`),InvalidScorecardBaseline:O(`The baseline value is invalid`),InvalidGaugeDataRange:O(`The data range is invalid`),EmptyGaugeRangeMin:O(`A minimum range limit value is needed`),GaugeRangeMinNaN:O(`The minimum range limit value must be a number`),EmptyGaugeRangeMax:O(`A maximum range limit value is needed`),GaugeRangeMaxNaN:O(`The maximum range limit value must be a number`),GaugeLowerInflectionPointNaN:O(`The lower inflection point value must be a number`),GaugeUpperInflectionPointNaN:O(`The upper inflection point value must be a number`)},GeoChart:{ColorScales:{blues:O(`Blues`),cividis:O(`Cividis`),greens:O(`Greens`),greys:O(`Greys`),oranges:O(`Oranges`),purples:O(`Purples`),rainbow:O(`Rainbow`),reds:O(`Reds`),viridis:O(`Viridis`)}}},dw={Custom:O(`Custom`)},fw=O(`Merged cells are preventing this operation. Unmerge those cells and try again.`),pw=O(`The header row of a table can't be moved.`),mw={Errors:{Unexpected:O(`Cannot split the selection for an unknown reason`),NoSplitSeparatorInSelection:O(`There is no match for the selected separator in the selection`),MoreThanOneColumnSelected:O(`Only a selection from a single column can be split`),SplitWillOverwriteContent:O(`Splitting will overwrite existing content`)}},hw={Errors:{Unexpected:O(`Cannot remove duplicates for an unknown reason`),MoreThanOneRangeSelected:O(`Please select only one range of cells`),EmptyTarget:O(`Please select a range of cells containing values.`),NoColumnsProvided:O(`Please select at latest one column to analyze.`),WillRemoveExistingMerge:O(`This operation is not possible due to a merge. Please remove the merges first than try again.`)}},K={DateIs:{today:O(`today`),yesterday:O(`yesterday`),tomorrow:O(`tomorrow`),lastWeek:O(`in the past week`),lastMonth:O(`in the past month`),lastYear:O(`in the past year`)},DateIsBefore:{today:O(`today`),yesterday:O(`yesterday`),tomorrow:O(`tomorrow`),lastWeek:O(`one week ago`),lastMonth:O(`one month ago`),lastYear:O(`one year ago`)},CriterionError:{notEmptyValue:O(`The value must not be empty`),numberValue:O(`The value must be a number`),dateValue:O(`The value must be a date`),validRange:O(`The value must be a valid range`),validFormula:O(`The formula must be valid`)},Errors:{InvalidRange:O(`The range is invalid.`),InvalidDataValidationCriterionValue:O(`One or more of the provided criteria values are invalid. Please review and correct them.`),InvalidNumberOfCriterionValues:O(`One or more of the provided criteria values are missing.`),Unexpected:O(`The rule is invalid for an unknown reason.`)}},gw={Errors:{Unexpected:O(`The table zone is invalid for an unknown reason`),TableOverlap:O(`You cannot create overlapping tables.`),NonContinuousTargets:O(`A table can only be created on a continuous selection.`),InvalidRange:O(`The range is invalid`),TargetOutOfSheet:O(`The range is out of the sheet`)},Checkboxes:{hasFilters:O(`Filter button`),headerRow:O(`Header row(s)`),bandedRows:O(`Banded rows`),firstColumn:O(`First column`),lastColumn:O(`Last column`),bandedColumns:O(`Banded columns`),automaticAutofill:O(`Automatically autofill formulas`),totalRow:O(`Total row`),isDynamic:O(`Auto-adjust to formula result`)},Tooltips:{filterWithoutHeader:O(`Cannot have filters without a header row`),isDynamic:O(`For tables based on array formulas only`)}},_w={labels:{no_calculations:O(`No calculations`),"%_of_grand_total":O(`% of grand total`),"%_of_col_total":O(`% of column total`),"%_of_row_total":O(`% of row total`),"%_of":O(`% of`),"%_of_parent_row_total":O(`% of parent row total`),"%_of_parent_col_total":O(`% of parent column total`),"%_of_parent_total":O(`% of parent total`),difference_from:O(`Difference from`),"%_difference_from":O(`% difference from`),running_total:O(`Running total`),"%_running_total":O(`% Running total`),rank_asc:O(`Rank smallest to largest`),rank_desc:O(`Rank largest to smallest`),index:O(`Index`)},descriptions:{"%_of_grand_total":()=>O(`Displayed as % of grand total`),"%_of_col_total":()=>O(`Displayed as % of column total`),"%_of_row_total":()=>O(`Displayed as % of row total`),"%_of":e=>O(`Displayed as % of "%s"`,e),"%_of_parent_row_total":e=>O(`Displayed as % of parent row total of "%s"`,e),"%_of_parent_col_total":()=>O(`Displayed as % of parent column total`),"%_of_parent_total":e=>O(`Displayed as % of parent "%s" total`,e),difference_from:e=>O(`Displayed as difference from "%s"`,e),"%_difference_from":e=>O(`Displayed as % difference from "%s"`,e),running_total:e=>O(`Displayed as running total based on "%s"`,e),"%_running_total":e=>O(`Displayed as % running total based on "%s"`,e),rank_asc:e=>O(`Displayed as rank from smallest to largest based on "%s"`,e),rank_desc:e=>O(`Displayed as rank largest to smallest based on "%s"`,e),index:()=>O(`Displayed as index`)},documentation:{no_calculations:O(`Displays the value that is entered in the field.`),"%_of_grand_total":O(`Displays values as a percentage of the grand total of all the values or data points in the report.`),"%_of_col_total":O(`Displays all the values in each column or series as a percentage of the total for the column or series.`),"%_of_row_total":O(`Displays the value in each row or category as a percentage of the total for the row or category.`),"%_of":O(`Displays values as a percentage of the value of the Base item in the Base field.`),"%_of_parent_row_total":O(`Calculates values as follows:
|
|
27
|
+
`,pf.add(`chartShowValuesPlugin`,{register:e=>e.register(aS),unregister:e=>e.unregister(aS)}),pf.add(`waterfallLinesPlugin`,{register:e=>e.register(zS),unregister:e=>e.unregister(zS)}),pf.add(`funnelController`,{register:e=>e.register(_f()),unregister:e=>e.unregister(_f())}),pf.add(`funnelElement`,{register:e=>e.register(vf()),unregister:e=>e.unregister(vf())}),pf.add(`funnelTooltipPositioner`,{register:e=>e.Tooltip.positioners.funnelTooltipPositioner=bf,unregister:e=>e.Tooltip.positioners.funnelTooltipPositioner=void 0}),pf.add(`sunburstLabelsPlugin`,{register:e=>e.register(LS),unregister:e=>e.unregister(LS)}),pf.add(`sunburstHoverPlugin`,{register:e=>e.register(FS),unregister:e=>e.unregister(FS)});var HS=class extends t.Component{static template=`o-spreadsheet-ChartJsComponent`;static props={figureUI:Object};canvas=(0,t.useRef)(`graphContainer`);chart;currentRuntime;currentDevicePixelRatio=window.devicePixelRatio;get background(){return this.chartRuntime.background}get canvasStyle(){return`background-color: ${this.background}`}get chartRuntime(){let e=this.env.model.getters.getChartRuntime(this.props.figureUI.id);if(!(`chartJsConfig`in e))throw Error(`Unsupported chart runtime`);return e}setup(){(0,t.onMounted)(()=>{hf();let e=this.chartRuntime;this.currentRuntime=e,this.createChart(b(e.chartJsConfig))}),(0,t.onWillUnmount)(()=>this.chart?.destroy()),(0,t.useEffect)(()=>{let e=this.chartRuntime;e===this.currentRuntime?this.currentDevicePixelRatio!==window.devicePixelRatio&&(this.currentDevicePixelRatio=window.devicePixelRatio,this.updateChartJs(b(this.currentRuntime.chartJsConfig))):(e.chartJsConfig.type===this.currentRuntime.chartJsConfig.type?this.updateChartJs(b(e.chartJsConfig)):(this.chart?.destroy(),this.createChart(b(e.chartJsConfig))),this.currentRuntime=e)})}createChart(e){let t=this.canvas.el.getContext(`2d`);this.chart=new window.Chart(t,e)}updateChartJs(e){e.data&&e.data.datasets?(this.chart.data=e.data,e.options?.plugins?.title&&(this.chart.config.options.plugins.title=e.options.plugins.title)):this.chart.data.datasets=[],this.chart.config.options=e.options,this.chart.update()}},US=class{sheetId;title;getters;constructor(e,t,n){this.title=e.title,this.sheetId=t,this.getters=n}static validateChartDefinition(e,t){throw Error(`This method should be implemented by sub class`)}static transformDefinition(e,t,n){throw Error(`This method should be implemented by sub class`)}static getDefinitionFromContextCreation(e){throw Error(`This method should be implemented by sub class`)}};function WS(e,t,n,r,i){if(!e)return``;if(n===`text`||t?.type!==`number`||e.type!==`number`)return r?Ss(e,i):e.formattedValue;let{value:a,format:o}=e;return n===`progress`?(a=t.value/a,o=`0.0%`):(a=Math.abs(t.value-a),n===`percentage`&&a!==0&&(a/=e.value),n===`percentage`&&(o=`0.0%`),o||(a=Math.round(a*100)/100)),r?Ss({value:a,format:o},i):B(a,{format:o,locale:i})}function GS(e,t,n){return e?t?Ss(e,n):e.formattedValue??String(e.value??``):``}function KS(e,t,n,r,i){if(t===`text`||t===`progress`||e?.type!==`number`||n?.type!==`number`)return;let a=n.value-e.value;if(a>0)return r;if(a<0)return i}function qS(e,t,n){if(n===`text`||e?.type!==`number`||t?.type!==`number`)return`neutral`;let r=t.value-e.value;return r>0?`up`:r<0?`down`:`neutral`}function JS(e){return e.keyValue&&!$s.test(e.keyValue)?`InvalidScorecardKeyValue`:`Success`}function YS(e){return e.baseline&&!$s.test(e.baseline)?`InvalidScorecardBaseline`:`Success`}let XS=new window.Path2D(`M8.6 4.8a.5.5 0 0 1 0 .75l-3.9 3.9a.5 .5 0 0 1 -.75 0l-3.8 -3.9a.5 .5 0 0 1 0 -.75l.4-.4a.5.5 0 0 1 .75 0l2.3 2.4v-5.7c0-.25.25-.5.5-.5h.6c.25 0 .5.25.5.5v5.8l2.3 -2.4a.5.5 0 0 1 .75 0z`),ZS=new window.Path2D(`M8.7 5.5a.5.5 0 0 0 0-.75l-3.8-4a.5.5 0 0 0-.75 0l-3.8 4a.5.5 0 0 0 0 .75l.4.4a.5.5 0 0 0 .75 0l2.3-2.4v5.8c0 .25.25.5.5.5h.6c.25 0 .5-.25.5-.5v-5.8l2.2 2.4a.5.5 0 0 0 .75 0z`);var QS=class e extends US{keyValue;baseline;baselineMode;baselineDescr;progressBar=!1;background;baselineColorUp;baselineColorDown;fontColor;humanize;type=`scorecard`;constructor(e,t,n){super(e,t,n),this.keyValue=mc(n,t,e.keyValue),this.baseline=mc(n,t,e.baseline),this.baselineMode=e.baselineMode,this.baselineDescr=e.baselineDescr,this.background=e.background,this.baselineColorUp=e.baselineColorUp??`#43C5B1`,this.baselineColorDown=e.baselineColorDown??`#EA6175`,this.humanize=e.humanize??!1}static validateChartDefinition(e,t){return e.checkValidations(t,JS,YS)}static getDefinitionFromContextCreation(e){return{background:e.background,type:`scorecard`,keyValue:e.range?.[0]?.dataRange,title:e.title||{text:``},baselineMode:We,baselineColorUp:Ge,baselineColorDown:Ke,baseline:e.auxiliaryRange||``}}static transformDefinition(e,t,n){let r,i;if(t.baseline){let{changeType:i,range:a}=Mx(e,t.baseline,n);i!==`REMOVE`&&(r=a)}if(t.keyValue){let{changeType:r,range:a}=Mx(e,t.keyValue,n);r!==`REMOVE`&&(i=a)}return{...t,baseline:r,keyValue:i}}duplicateInDuplicatedSheet(t){let n=zx(this.sheetId,t,this.baseline),r=zx(this.sheetId,t,this.keyValue);return new e(this.getDefinitionWithSpecificRanges(n,r,t),t,this.getters)}copyInSheetId(t){return new e(this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue,t),t,this.getters)}getDefinition(){return this.getDefinitionWithSpecificRanges(this.baseline,this.keyValue)}getContextCreation(){return{...this,range:this.keyValue?[{dataRange:this.getters.getRangeString(this.keyValue,this.sheetId)}]:void 0,auxiliaryRange:this.baseline?this.getters.getRangeString(this.baseline,this.sheetId):void 0}}getDefinitionWithSpecificRanges(e,t,n){return{baselineColorDown:this.baselineColorDown,baselineColorUp:this.baselineColorUp,baselineMode:this.baselineMode,title:this.title,type:`scorecard`,background:this.background,baseline:e?this.getters.getRangeString(e,n||this.sheetId):void 0,baselineDescr:this.baselineDescr,keyValue:t?this.getters.getRangeString(t,n||this.sheetId):void 0,humanize:this.humanize}}getDefinitionForExcel(){}updateRanges({applyChange:t}){let n=Bx(this.baseline,t),r=Bx(this.keyValue,t);return this.baseline===n&&this.keyValue===r?this:new e(this.getDefinitionWithSpecificRanges(n,r),this.sheetId,this.getters)}};function $S(e,t){let n=t.getContext(`2d`),r=window.devicePixelRatio||1;t.width=r*e.canvas.width,t.height=r*e.canvas.height,n.scale(r,r);let i=e.canvas.width-40;if(n.fillStyle=e.canvas.backgroundColor,n.fillRect(0,0,e.canvas.width,e.canvas.height),e.title){n.font=e.title.style.font,n.fillStyle=e.title.style.color;let t=n.textBaseline;n.textBaseline=`middle`,n.fillText(nl(n,e.title.text,i-e.title.position.x),e.title.position.x,e.title.position.y),n.textBaseline=t}if(e.baseline&&(n.font=e.baseline.style.font,n.fillStyle=e.baseline.style.color,rl(n,e.baseline.text,e.baseline.position,e.baseline.style.underline,e.baseline.style.strikethrough)),e.baselineArrow&&e.baselineArrow.style.size>0){n.save(),n.fillStyle=e.baselineArrow.style.color,n.translate(e.baselineArrow.position.x,e.baselineArrow.position.y);let t=e.baselineArrow.style.size/10;switch(n.scale(t,t),e.baselineArrow.direction){case`down`:n.fill(XS);break;case`up`:n.fill(ZS);break}n.restore()}if(e.baselineDescr){let t=e.baselineDescr[0];n.font=t.style.font,n.fillStyle=t.style.color;for(let t of e.baselineDescr)n.fillText(nl(n,t.text,i-t.position.x),t.position.x,t.position.y)}if(e.key&&(n.font=e.key.style.font,n.fillStyle=e.key.style.color,rl(n,nl(n,e.key.text,i-e.key.position.x),e.key.position,e.key.style.underline,e.key.style.strikethrough)),e.progressBar){if(n.fillStyle=e.progressBar.style.backgroundColor,n.beginPath(),n.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width,e.progressBar.dimension.height,e.progressBar.dimension.height/2),n.fill(),n.fillStyle=e.progressBar.style.color,n.beginPath(),e.progressBar.value>0)n.roundRect(e.progressBar.position.x,e.progressBar.position.y,e.progressBar.dimension.width*Math.max(0,Math.min(1,e.progressBar.value)),e.progressBar.dimension.height,e.progressBar.dimension.height/2);else{let t=e.progressBar.dimension.width*Math.max(0,Math.min(1,-e.progressBar.value));n.roundRect(e.progressBar.position.x+e.progressBar.dimension.width-t,e.progressBar.position.y,t,e.progressBar.dimension.height,e.progressBar.dimension.height/2)}n.fill()}}function eC(e,t){let n=``,r,i=t.getLocale();if(e.keyValue){let a={sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top};r=t.getEvaluatedCell(a),n=GS(r,e.humanize??!1,i)}let a,o=e.baseline;if(o){let e={sheetId:o.sheetId,col:o.zone.left,row:o.zone.top};a=t.getEvaluatedCell(e)}let{background:s,fontColor:c}=t.getStyleOfSingleCellChart(e.background,e.keyValue),l=WS(a,r,e.baselineMode,e.humanize??!1,i),u=e.baselineMode===`progress`&&Li(l,i)?F(l,i):0;return{title:{...e.title,text:e.title.text?O(e.title.text):``},keyValue:n,baselineDisplay:l,baselineArrow:qS(a,r,e.baselineMode),baselineColor:KS(a,e.baselineMode,r,e.baselineColorUp,e.baselineColorDown),baselineDescr:e.baselineMode!==`progress`&&e.baselineDescr?O(e.baselineDescr):``,fontColor:c,background:s,baselineStyle:e.baselineMode!==`percentage`&&e.baselineMode!==`progress`&&o?t.getCellStyle({sheetId:o.sheetId,col:o.zone.left,row:o.zone.top}):void 0,keyValueStyle:e.keyValue?t.getCellStyle({sheetId:e.keyValue.sheetId,col:e.keyValue.zone.left,row:e.keyValue.zone.top}):void 0,progressBar:e.baselineMode===`progress`?{value:u,color:u>0?e.baselineColorUp:e.baselineColorDown}:void 0}}let tC=.05;function nC(e,t){let n=e||``;return t&&n?` `+n:n}function rC({width:e,height:t},n){return new iC({width:e,height:t},n).computeDesign()}var iC=class{runtime;context;width;height;constructor({width:e,height:t},n){this.runtime=n;let r=document.createElement(`canvas`);this.width=r.width=e,this.height=r.height=t,this.context=r.getContext(`2d`)}computeDesign(){let e={canvas:{width:this.width,height:this.height,backgroundColor:this.backgroundColor}},t=this.getTextStyles(),n=0;if(this.title){let r,i;switch({height:n,width:i}=this.getFullTextDimensions(this.title,t.title.font),this.runtime.title.align){case`center`:r=(this.width-i)/2;break;case`right`:r=this.width-i-10;break;default:r=10}e.title={text:this.title,style:t.title,position:{x:r,y:10+n/2}}}let r=t.baselineArrow?.size??0,{height:i,width:a}=this.getTextDimensions(this.baseline,t.baselineValue.font);this.baseline||(i=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).height);let o=this.getTextDimensions(this.baselineDescr,t.baselineDescr.font).width;e.baseline={text:this.baseline,style:t.baselineValue,position:{x:(this.width-a-o+r)/2,y:this.keyValue?this.height*(1-tC*(this.runtime.progressBar?1:2)):this.height-(this.height-n-i)/2-10}};let s=r+20;if(e.baseline.position.x<s&&(e.baseline.position.x=s),t.baselineArrow&&!this.runtime.progressBar&&(e.baselineArrow={direction:this.baselineArrow,style:t.baselineArrow,position:{x:e.baseline.position.x-r,y:e.baseline.position.y-(i+r)/2}}),this.baselineDescr){let n={x:e.baseline.position.x+a,y:e.baseline.position.y};e.baselineDescr=[{text:this.baselineDescr,style:t.baselineDescr,position:n}]}let c=0;this.runtime.progressBar&&(c=this.height*.05,e.progressBar={position:{x:20,y:this.height*(1-2*tC)-i-c},dimension:{height:c,width:this.width-40},value:this.runtime.progressBar.value,style:{color:this.runtime.progressBar.color,backgroundColor:this.secondaryFontColor}});let{width:l,height:u}=this.getFullTextDimensions(this.keyValue,t.keyValue.font);return this.keyValue&&(e.key={text:this.keyValue,style:t.keyValue,position:{x:Math.max(10,(this.width-l)/2),y:this.height*(.5-tC*2)+10/2+(n+u/2)/2}}),e}get title(){return this.runtime.title.text??``}get keyValue(){return this.runtime.keyValue}get baseline(){return this.runtime.baselineDisplay}get baselineDescr(){return nC(this.runtime.baselineDescr,this.baseline)}get baselineArrow(){return this.runtime.baselineArrow}get backgroundColor(){return this.runtime.background}get secondaryFontColor(){return qx(this.backgroundColor)}getTextDimensions(e,t){this.context.font=t;let n=this.context.measureText(e);return{width:n.width,height:n.actualBoundingBoxAscent+n.actualBoundingBoxDescent}}getFullTextDimensions(e,t){this.context.font=t;let n=this.context.measureText(e);return{width:n.width,height:n.fontBoundingBoxAscent+n.fontBoundingBoxDescent}}getTextStyles(){let e=16,t=Math.floor(.9*e);return this.runtime.progressBar&&(e/=1.5),{title:{font:zc(this.runtime.title.fontSize??14,this.runtime.title.bold,this.runtime.title.italic),color:this.runtime.title.color??this.secondaryFontColor},keyValue:{color:this.runtime.keyValueStyle?.textColor||this.runtime.fontColor,font:zc(32,this.runtime.keyValueStyle?.bold,this.runtime.keyValueStyle?.italic),strikethrough:this.runtime.keyValueStyle?.strikethrough,underline:this.runtime.keyValueStyle?.underline},baselineValue:{font:zc(e,this.runtime.baselineStyle?.bold,this.runtime.baselineStyle?.italic),strikethrough:this.runtime.baselineStyle?.strikethrough,underline:this.runtime.baselineStyle?.underline,color:this.runtime.baselineStyle?.textColor||this.runtime.baselineColor||this.secondaryFontColor},baselineDescr:{font:zc(t),color:this.secondaryFontColor},baselineArrow:this.baselineArrow===`neutral`||this.runtime.progressBar?void 0:{size:this.keyValue?.8*e:0,color:this.runtime.baselineColor||this.secondaryFontColor}}}},aC=class extends t.Component{static template=`o-spreadsheet-ScorecardChart`;static props={figureUI:Object};canvas=(0,t.useRef)(`chartContainer`);get runtime(){return this.env.model.getters.getChartRuntime(this.props.figureUI.id)}get title(){return O(this.env.model.getters.getChartDefinition(this.props.figureUI.id).title.text??``)}setup(){(0,t.useEffect)(this.createChart.bind(this),()=>{let e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]})}createChart(){let e=this.canvas.el;$S(rC(e.getBoundingClientRect(),this.runtime),e)}};let oC=new h;oC.add(`dataValidation`,{displayAllOnInitialContent:!0,canBeToggled:!1,getProposals(e,t){return en(t)||!this.composer.currentEditedCell?[]:sC(this.getters,this.composer.currentEditedCell).map(e=>({text:e.value?.toString()||``,htmlContent:[{value:e.label}],fuzzySearchKey:e.label}))},selectProposal(e,t){this.composer.setCurrentContent(t),this.composer.stopEdition()}});function sC(e,t){let n=e.getValidationRuleForCell(t);if(!n||n.criterion.type!==`isValueInList`&&n.criterion.type!==`isValueInRange`)return[];let r=[];if(n.criterion.type===`isValueInList`)r=n.criterion.values.map(e=>({label:e,value:e}));else{let i=new Set,a=e.getRangeFromSheetXC(t.sheetId,n.criterion.values[0]);for(let t of wr(a.zone)){let n=e.getEvaluatedCell({...t,sheetId:a.sheetId});n.formattedValue&&!i.has(n.formattedValue)&&(i.add(n.formattedValue),r.push({label:n.formattedValue,value:n.value}))}}return r}function cC(e,t,n,r){let i=[];e=e.toLowerCase();for(let a of e){let e=t.toLocaleLowerCase().indexOf(a);e!==-1&&(i.push({value:t.slice(0,e),color:``},{value:t[e],color:n,classes:[r]}),t=t.slice(e+1))}return i.push({value:t}),i.filter(e=>e.value)}oC.add(`functions`,{sequence:100,autoSelectFirstProposal:!0,maxDisplayedProposals:10,getProposals(e){if(e.type!==`SYMBOL`)return[];let t=e.value;return en(this.composer.currentContent)?Object.entries(ix.content).filter(([e,{hidden:t}])=>!t).map(([e,{description:n}])=>({text:e,description:n,htmlContent:cC(t,e,he,`o-semi-bold`)})).sort((e,t)=>e.text.length-t.text.length||e.text.localeCompare(t.text)):[]},selectProposal(e,t){let n=e.end,r=e.end;[`SYMBOL`,`FUNCTION`].includes(e.type)&&(n=e.start);let i=this.composer.currentTokens;t+=`(`;let a=i.map(e=>e.start).indexOf(e.start);a+1<i.length&&i[a+1]?.type===`LEFT_PAREN`&&r++,this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t)}});function lC(e,t,n){let{x:r,y:i,width:a,height:o}=n;if(a<0||o<0)return;let s=t.color||`#37A850`,{ctx:c}=e;c.save(),t.noBorder||(t.dashed&&c.setLineDash([5,3]),c.strokeStyle=s,t.thinLine?(c.lineWidth=1,c.strokeRect(r,i,a,o)):(c.lineWidth=2,c.strokeRect(r+.5,i+.5,a,o))),t.noFill||(c.fillStyle=xn(sn(s),t.fillAlpha??.12),c.fillRect(r,i,a,o)),c.restore()}var uC=class extends ef{mutators=[`register`,`unRegister`];providers=[];constructor(e){super(e),this.onDispose(()=>{this.providers=[]})}get renderingLayers(){return[`Highlights`]}get highlights(){let e=this.getters.getActiveSheetId();return this.providers.flatMap(e=>e.highlights).filter(t=>t.sheetId===e).map(e=>{let{numberOfRows:t,numberOfCols:n}=br(e.zone),r=t*n===1?this.getters.expandZone(e.sheetId,e.zone):e.zone;return{...e,zone:r}})}register(e){this.providers.push(e)}unRegister(e){this.providers=this.providers.filter(t=>t!==e)}drawLayer(e,t){if(t===`Highlights`)for(let t of this.highlights)lC(e,t,this.getters.getVisibleRect(t.zone))}},dC=class{mutators=[`notifyUser`,`raiseError`,`askConfirmation`,`updateNotificationCallbacks`];notifyUser=e=>window.alert(e.text);askConfirmation=(e,t,n)=>{window.confirm(e)?t():n?.()};raiseError=(e,t)=>{window.alert(e),t?.()};updateNotificationCallbacks(e){this.notifyUser=e.notifyUser||this.notifyUser,this.raiseError=e.raiseError||this.raiseError,this.askConfirmation=e.askConfirmation||this.askConfirmation}};let fC=`#000000`,pC=`#3da4ab`,mC={OPERATOR:pC,NUMBER:`#02c39a`,STRING:`#00a82d`,FUNCTION:fC,DEBUGGER:pC,LEFT_PAREN:fC,RIGHT_PAREN:fC,ARG_SEPARATOR:fC,ORPHAN_RIGHT_PAREN:`#ff0000`};var hC=class extends ef{mutators=[`startEdition`,`setCurrentContent`,`stopEdition`,`stopComposerRangeSelection`,`cancelEdition`,`cycleReferences`,`toggleEditionMode`,`changeComposerCursorSelection`,`replaceComposerCursorSelection`,`hoverToken`];col=0;row=0;editionMode=`inactive`;sheetId=``;_currentContent=``;currentTokens=[];selectionStart=0;selectionEnd=0;initialContent=``;colorIndexByRange={};hoveredTokens=[];hoveredContentEvaluation=``;notificationStore=this.get(dC);highlightStore=this.get(uC);constructor(e){super(e),this.highlightStore.register(this),this.onDispose(()=>{this.highlightStore.unRegister(this),this._cancelEdition()})}handleEvent(e){let t=this.getters.getActiveSheetId(),n;switch(n=e.options.unbounded?this.getters.getUnboundedZone(t,e.anchor.zone):e.anchor.zone,e.mode){case`newAnchor`:this.editionMode===`selecting`&&this.insertSelectedRange(n);break;default:this.editionMode===`selecting`?this.replaceSelectedRange(n):this.updateComposerRange(e.previousAnchor.zone,n);break}}changeComposerCursorSelection(e,t){this.isSelectionValid(this._currentContent.length,e,t)&&(this.selectionStart=e,this.selectionEnd=t,this.stopComposerRangeSelection(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}stopComposerRangeSelection(){this.isSelectingRange&&(this.editionMode=`editing`)}startEdition(e,t){if(t){let n=e||this.getComposerContent(this.getters.getActivePosition());if(!this.isSelectionValid(n.length,t.start,t.end))return}let{col:n,row:r}=this.getters.getActivePosition();this.model.dispatch(`SELECT_FIGURE`,{figureId:null}),this.model.dispatch(`SCROLL_TO_CELL`,{col:n,row:r}),this.editionMode!==`inactive`&&e?this.setContent(e,t):this._startEdition(e,t),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor()}cancelEdition(){this.resetContent(),this.cancelEditionAndActivateSheet()}setCurrentContent(e,t){t&&!this.isSelectionValid(e.length,t.start,t.end)||(this.setContent(e,t,!0),this.updateTokenColor(),this.computeFormulaCursorContext(),this.computeParenthesisRelatedToCursor())}replaceComposerCursorSelection(e){this.replaceSelection(e)}handle(e){switch(e.type){case`SELECT_FIGURE`:e.figureId&&(this.resetContent(),this.cancelEditionAndActivateSheet());break;case`START_CHANGE_HIGHLIGHT`:let{left:t,top:n}=e.zone;this.isSelectingRange&&(this.editionMode=`editing`),this.model.selection.resetAnchor(this,{cell:{col:t,row:n},zone:e.zone});break}}get currentContent(){return this.editionMode===`inactive`?this.getComposerContent(this.getters.getActivePosition()):this._currentContent}get composerSelection(){return{start:this.selectionStart,end:this.selectionEnd}}get isSelectingRange(){return this.editionMode===`selecting`}get showSelectionIndicator(){return this.isSelectingRange&&this.canStartComposerRangeSelection()}get tokenAtCursor(){let e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd);if(!(e===t&&t===0))return this.currentTokens.find(n=>n.start<=e&&n.end>=t)}cycleReferences(){let e=this.getters.getLocale(),t=ty(this.composerSelection,this._currentContent,e);t!==void 0&&this.setCurrentContent(t.content,t.selection)}toggleEditionMode(){if(this.editionMode===`inactive`)return;let e=Math.min(this.selectionStart,this.selectionEnd),t=Math.max(this.selectionStart,this.selectionEnd),n=[...this.currentTokens].reverse().find(n=>n.end>=e&&t>=n.start&&n.type===`REFERENCE`);if(this.editionMode===`editing`&&n){let e=this.getters.getActiveSheetId(),{sheetName:t,xc:r}=ac(n.value),i=this.getters.getSheetIdByName(t);i&&i!==e&&this.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:e,sheetIdTo:i}),this.selectionStart=this.selectionEnd=n.end;let a=this.getters.getRangeFromSheetXC(this.sheetId,r).zone;this.captureSelection(a),this.editionMode=`selecting`}else this.editionMode=`editing`}hoverToken(e){this.currentTokens.forEach(e=>e.isInHoverContext=void 0);let t=[...this.currentTokens];if(e===void 0||[`ARG_SEPARATOR`,`SPACE`].includes(t[e].type)){this.hoveredContentEvaluation=``,this.hoveredTokens=[];return}let n=this.getNumberOfMissingParenthesis(t);n>0&&t.push(...Array(n).fill({value:`)`,type:`RIGHT_PAREN`}));let r=t;if(e!==0){let n=this.getRelatedTokens(t,e),i=t.filter(e=>!n.includes(e)&&e.type!==`SPACE`);r=i.length===1&&i[0]===t[0]?t:n}r.forEach(e=>e.isInHoverContext=!0);let i=r.map(e=>e.value).join(``);en(i)||(i=`=${i}`);let a=Ll(i,this.getters.getLocale()),o=this.evaluateCanonicalFormula(a);this.hoveredTokens=r,this.hoveredContentEvaluation=this.evaluationResultToDisplayString(o)}evaluateCanonicalFormula(e){return this.getters.evaluateFormulaResult(this.sheetId,e)}getRelatedTokens(e,t){try{let n=Pv(e),r;for(let e of Iv(n))if(t>=e.tokenStartIndex&&t<=e.tokenEndIndex)r=e;else if(t<e.tokenStartIndex)break;return r?e.slice(r.tokenStartIndex,r.tokenEndIndex+1):e}catch(t){if(t instanceof M)return e;throw t}}evaluationResultToDisplayString(e){let t=this.getters.getLocale();if(A(e)){let n=t.decimalSeparator===`,`?`/`:`,`;return`{${Qa(e).map(e=>e.map(e=>this.cellValueToDisplayString(e)).join(n)).join(`;`)}}`}return this.cellValueToDisplayString(e)}cellValueToDisplayString(e){let t=e.value;switch(typeof t){case`number`:return B(t,{locale:this.getters.getLocale(),format:e.format});case`string`:return P(t)?t:`"${t}"`;case`boolean`:return t?`TRUE`:`FALSE`}return`0`}captureSelection(e,t,n){this.model.selection.capture(this,{cell:{col:t??e.left,row:n??e.top},zone:e},{handleEvent:this.handleEvent.bind(this),release:()=>{this._stopEdition()}})}isSelectionValid(e,t,n){return t>=0&&t<=e&&n>=0&&n<=e}startComposerRangeSelection(){if(this.sheetId===this.getters.getActiveSheetId()){let e=E({col:this.col,row:this.row});this.model.selection.resetAnchor(this,{cell:{col:this.col,row:this.row},zone:e})}this.editionMode=`selecting`}_startEdition(e,t){let n=this.getters.getActiveCell(),r=this.getters.getLocale();e&&n.format?.includes(`%`)&&Li(e,r)&&(t||={start:e.length,end:e.length},e=`${e}%`);let{col:i,row:a,sheetId:o}=this.getters.getActivePosition();this.col=i,this.sheetId=o,this.row=a,this.initialContent=this.getComposerContent({sheetId:o,col:i,row:a}),this.editionMode=`editing`,this.setContent(e||this.initialContent,t),this.colorIndexByRange={};let s=E({col:this.col,row:this.row});this.captureSelection(s,i,a)}_stopEdition(){if(this.editionMode!==`inactive`){this.cancelEditionAndActivateSheet();let e=this.getCurrentCanonicalContent();if(this.initialContent===e)return;if(e&&en(e)){let t=this.getNumberOfMissingParenthesis(this.currentTokens);t>0&&(e+=Ot(Array(t).fill(`)`)))}this.confirmEdition(e)}}getCurrentCanonicalContent(){return Ll(this._currentContent,this.getters.getLocale())}cancelEditionAndActivateSheet(){this.editionMode!==`inactive`&&(this._cancelEdition(),this.getters.getActiveSheetId()!==this.sheetId&&this.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:this.getters.getActiveSheetId(),sheetIdTo:this.sheetId}))}_cancelEdition(){this.editionMode!==`inactive`&&(this.editionMode=`inactive`,this.model.selection.release(this),this.colorIndexByRange={},this.hoveredTokens=[],this.hoveredContentEvaluation=``)}resetContent(){this.setContent(this.initialContent||``)}setContent(e,t,n){let r=this._currentContent!==e;if(this._currentContent=e,t?(this.selectionStart=t.start,this.selectionEnd=t.end):this.selectionStart=this.selectionEnd=e.length,r||this.editionMode!==`inactive`){let t=this.getters.getLocale();this.currentTokens=en(e)?Kv(e,t):[],this.currentTokens.length>100&&n&&this.notificationStore.raiseError(O(`This formula has over 100 parts. It can't be processed properly, consider splitting it into multiple cells`))}this.canStartComposerRangeSelection()&&this.startComposerRangeSelection()}getAutoCompleteProviders(){return oC.getAll()}insertSelectedRange(e){let t=Math.min(this.selectionStart,this.selectionEnd),n=this.getZoneReference(e);this.canStartComposerRangeSelection()?this.insertText(n,t):this.insertText(`,`+n,t)}replaceSelectedRange(e){let t=this.getZoneReference(e),n=this.tokenAtCursor,r=n?.type===`REFERENCE`?n.start:this.selectionStart;this.replaceText(t,r,this.selectionEnd)}updateComposerRange(e,t){let n=this.getters.getActiveSheetId(),r=this.tokenAtCursor,i=(r?[r,...this.currentTokens]:this.currentTokens).filter(e=>e.type===`REFERENCE`).find(t=>{let{xc:r,sheetName:i}=ac(t.value),a=i||this.getters.getSheetName(this.sheetId);if(!Fc(this.getters.getSheetName(n),a))return!1;let o=this.getters.getRangeFromSheetXC(n,r);return gr(this.getters.expandZone(n,o.zone),e)});if(!i)return;let a=this.getters.getRangeFromSheetXC(n,i.value);this.selectionStart=i.start,this.selectionEnd=this.selectionStart+i.value.length;let o=this.getters.getRangeFromZone(n,t),s=this.getRangeReference(o,a.parts);this.replaceSelection(s)}getZoneReference(e){let t=this.sheetId,n=this.getters.getActiveSheetId(),r=this.getters.getRangeFromZone(n,e);return this.getters.getSelectionRangeString(r,t)}getRangeReference(e,t){let n=[...t],r={...e,parts:n};return this.getters.getSelectionRangeString(r,this.sheetId)}replaceSelection(e){let t=Math.min(this.selectionStart,this.selectionEnd),n=Math.max(this.selectionStart,this.selectionEnd);this.replaceText(e,t,n)}replaceText(e,t,n){this._currentContent=this._currentContent.slice(0,t)+this._currentContent.slice(n,this._currentContent.length),this.insertText(e,t)}insertText(e,t){let n=this._currentContent.slice(0,t)+e+this._currentContent.slice(t),r=t+e.length;this.setCurrentContent(n,{start:r,end:r})}updateTokenColor(){this.updateRangeColor();for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].color=this.getTokenColor(this.currentTokens[e])}getTokenColor(e){if(e.type===`REFERENCE`){let{xc:t,sheetName:n}=ac(e.value);return this.rangeColor(t,n)||`#000000`}if(e.type===`SYMBOL`){let t=e.value.toUpperCase();if(t===`TRUE`||t===`FALSE`)return mC.NUMBER;if(t in ix.content)return mC.FUNCTION}return[`LEFT_PAREN`,`RIGHT_PAREN`].includes(e.type)&&e.parenthesesCode===``?mC.ORPHAN_RIGHT_PAREN:mC[e.type]||`#000000`}rangeColor(e,t){let n=t?this.model.getters.getSheetIdByName(t):this.sheetId,r=this.highlights.find(t=>{if(t.sheetId!==n)return!1;let r=this.model.getters.getRangeFromSheetXC(n,e).zone;return r=Nr(r)===1?this.model.getters.expandZone(n,r):r,gr(r,t.zone)});return r&&r.color?r.color:void 0}computeFormulaCursorContext(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isBlurred=!1;if(this.selectionStart!==this.selectionEnd)return;let e=this.getParenthesesCodeAfterCursor(),t=[...this.currentTokens].reverse().find(t=>e.startsWith(t.parenthesesCode)&&t.type===`SYMBOL`);if(t)for(let e=0;e<this.currentTokens.length;e++)(this.currentTokens[e].parenthesesCode||``).startsWith(t.parenthesesCode||``)||(this.currentTokens[e].isBlurred=!0)}getParenthesesCodeAfterCursor(){let e=this.tokenAtCursor?.parenthesesCode||``;return this.tokenAtCursor?.type===`RIGHT_PAREN`?e.slice(0,-1)||``:e}computeParenthesisRelatedToCursor(){for(let e=0;e<this.currentTokens.length;e++)this.currentTokens[e].isParenthesisLinkedToCursor=!1;let e=this.tokenAtCursor;if(!(!e||e.parenthesesCode===``||![`LEFT_PAREN`,`RIGHT_PAREN`].includes(e.type)))for(let t=0;t<this.currentTokens.length;t++){let n=this.currentTokens[t];[`LEFT_PAREN`,`RIGHT_PAREN`].includes(n.type)&&n.parenthesesCode===e.parenthesesCode&&n!==e&&(this.currentTokens[t].isParenthesisLinkedToCursor=!0,this.tokenAtCursor.isParenthesisLinkedToCursor=!0)}}updateRangeColor(){if(!en(this._currentContent)||this.editionMode===`inactive`)return;let e=this.sheetId,t=this.getReferencedRanges().map(t=>this.getters.getRangeString(t,e)),n={};for(let e of t)this.colorIndexByRange[e]!==void 0&&(n[e]=this.colorIndexByRange[e]);let r=new Set(Object.values(n)),i=0,a=()=>{for(;r.has(i);)i++;return r.add(i),i};for(let e of t)n[e]=e in n?n[e]:a();this.colorIndexByRange=n}get highlights(){if(!en(this.currentContent)||this.editionMode===`inactive`)return[];let e=this.sheetId,t=e=>rn[this.colorIndexByRange[e]%rn.length];return this.getReferencedRanges().map(n=>{let r=this.getters.getRangeString(n,e),{numberOfRows:i,numberOfCols:a}=br(n.zone);return{zone:i*a===1?this.getters.expandZone(n.sheetId,n.zone):n.zone,color:t(r),sheetId:n.sheetId,interactive:!0}})}getReferencedRanges(){let e=this.sheetId;return this.currentTokens.filter(e=>e.type===`REFERENCE`).map(t=>this.getters.getRangeFromSheetXC(e,t.value)).filter(e=>!e.invalidSheetName&&!e.invalidXc)}get autocompleteProvider(){let e=this.currentContent,t=en(e)?this.tokenAtCursor:{type:`STRING`,value:e};if(this.editionMode===`inactive`||!t||[`TRUE`,`FALSE`].includes(t.value.toUpperCase())||!(this.canStartComposerRangeSelection()||[`SYMBOL`,`STRING`,`UNKNOWN`].includes(t.type)))return;let n={composer:this,getters:this.getters},r=this.getAutoCompleteProviders().sort((e,t)=>(e.sequence??1/0)-(t.sequence??1/0)).map(r=>({...r,getProposals:r.getProposals.bind(n,t,e),selectProposal:r.selectProposal.bind(n,t)}));for(let e of r){let n=e.getProposals(),r=n?.find(e=>e.text===t.value),i=t.value.replace(/[ ,\(\)]/g,``);if(this._currentContent===this.initialContent&&e.displayAllOnInitialContent&&n?.length)return{proposals:n,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled};if(r&&this._currentContent!==this.initialContent)return;if(i&&n&&![`ARG_SEPARATOR`,`LEFT_PAREN`,`OPERATOR`].includes(t.type)){let e=kc(i,n,e=>e.fuzzySearchKey||e.text);(!r||e.length)&&(n=e)}if(e.maxDisplayedProposals&&(n=n?.slice(0,e.maxDisplayedProposals)),n?.length)return{proposals:n,selectProposal:e.selectProposal,autoSelectFirstProposal:e.autoSelectFirstProposal??!1,canBeToggled:e.canBeToggled}}}canStartComposerRangeSelection(){if(en(this._currentContent)){let e=this.tokenAtCursor;if(!e)return!1;let t=this.currentTokens.map(e=>e.start).indexOf(e.start),n=t,r=e;for(;![`ARG_SEPARATOR`,`LEFT_PAREN`,`OPERATOR`].includes(r.type)||vl.includes(r.value);){if(r.type!==`SPACE`||n<1)return!1;n--,r=this.currentTokens[n]}for(n=t+1,r=this.currentTokens[n];r&&![`ARG_SEPARATOR`,`RIGHT_PAREN`,`OPERATOR`].includes(r.type);){if(r.type!==`SPACE`)return!1;n++,r=this.currentTokens[n]}return!0}return!1}getNumberOfMissingParenthesis(e){return e.filter(e=>e.type===`LEFT_PAREN`).length-e.filter(e=>e.type===`RIGHT_PAREN`).length}};let gC=[`PIVOT.VALUE`,`PIVOT.HEADER`,`PIVOT`];function _C(e,t){let n=`"${t?`${e.name}:${t}`:e.name}"`,r=e.string===e.name?n:e.string+n;return{text:n,description:e.string+(e.help?` (${e.help})`:``),htmlContent:[{value:n,color:mC.STRING}],fuzzySearchKey:r}}function vC(e){let t=`"${e.id}"`,n=e.displayName+e.fieldName+t;return{text:t,description:e.displayName,htmlContent:[{value:t,color:mC.STRING}],fuzzySearchKey:n}}function yC(e,t){let n=e.end,r=e.end;e.type!==`ARG_SEPARATOR`&&(n=e.start),this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t)}function bC(e,t){let n=e.end,r=e.end;e.type!==`LEFT_PAREN`&&(n=e.start),this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t)}function xC(e){let t=e.functionContext?.args[0];if(!(!t||![`STRING`,`NUMBER`].includes(t.type)))return t.value}function SC(e){return kx(e,gC)[0]}function CC(e){return kx(e,gC).length}let wC=new h;wC.add(`SPREADSHEET`,!1),oC.add(`pivot_ids`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(!t||![`PIVOT.VALUE`,`PIVOT.HEADER`,`PIVOT`].includes(t.parent.toUpperCase())||t.argPosition!==0)return;let n=this.getters.getPivotIds();if(!n.includes(e.value))return n.map(e=>{let t=this.getters.getPivotCoreDefinition(e),n=`${this.getters.getPivotFormulaId(e)}`;return{text:n,description:t.name,htmlContent:[{value:n,color:mC.NUMBER}],fuzzySearchKey:n+t.name,alwaysExpanded:!0}}).filter(C)},selectProposal:bC}),oC.add(`pivot_measures`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(t?.parent.toUpperCase()!==`PIVOT.VALUE`||t.argPosition!==1)return[];let n=xC(e),r=this.getters.getPivotId(n);if(!r||!this.getters.isExistingPivot(r))return[];let i=this.getters.getPivot(r);return i.init(),i.isValid()?i.definition.measures.map(e=>{if(e.fieldName===`__count`){let e=`"__count"`;return{text:e,description:O(`Count`),htmlContent:[{value:e,color:mC.STRING}],fuzzySearchKey:O(`Count`)+e}}return vC(e)}).filter(C):[]},selectProposal:yC}),oC.add(`pivot_group_fields`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(!t||!TC(e)&&!EC(e))return;let n=xC(e),r=this.getters.getPivotId(n);if(!r||!this.getters.isExistingPivot(r))return;let i=this.getters.getPivot(r);i.init();let a=i.getFields(),{columns:o,rows:s}=i.definition,c=t.args;t?.parent.toUpperCase()===`PIVOT.VALUE`?(c=c.filter((e,t)=>t%2==0),c=c.slice(1,t.argPosition)):c=c.filter((e,t)=>t%2==1);let l=c.map(e=>e?.value).filter(C),u=o.map(e=>e.nameWithGranularity),d=s.map(e=>e.nameWithGranularity),f=[],p=[`ARG_SEPARATOR`,`SPACE`].includes(e.type)?l.at(-1):l.at(-2),m=wC.get(i.type);if(m&&p?.startsWith(`#`)&&(p=p.slice(1)),p===void 0&&(f.push(u[0]),f.push(d[0])),d.includes(p)){let e=d[d.indexOf(p)+1];f.push(e),f.push(u[0])}if(u.includes(p)){let e=u[u.indexOf(p)+1];f.push(e)}let h=f.filter(C);return h.map(e=>{let[t,n]=e.split(`:`),r=a[t];return r?_C(r,n):void 0}).concat(h.map(e=>{if(!m)return;let t=a[e.split(`:`)[0]];if(!t)return;let n=`"#${e}"`;return{text:n,description:O(`%s (positional)`,t.string)+(t.help?` (${t.help})`:``),htmlContent:[{value:n,color:mC.STRING}],fuzzySearchKey:t.string+n}})).filter(C)},selectProposal:yC});function TC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.VALUE`&&t.argPosition>=2&&t.argPosition%2==0}function EC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.HEADER`&&t.argPosition>=1&&t.argPosition%2==1}oC.add(`pivot_group_values`,{sequence:50,autoSelectFirstProposal:!0,getProposals(e){let t=e.functionContext;if(!t||!e||!DC(e)&&!OC(e))return;let n=xC(e),r=this.getters.getPivotId(n);if(!r||!this.getters.isExistingPivot(r))return;let i=this.getters.getPivot(r);if(!i.isValid())return;let a=t.argPosition,o=e.functionContext?.args[a-1]?.value;if(!o)return;let s;try{s=i.definition.getDimension(o)}catch{return}return s.granularity===`month_number`?Object.values(Yo).map((e,t)=>({text:`${t+1}`,fuzzySearchKey:e.toString(),description:e.toString(),htmlContent:[{value:`${t+1}`,color:mC.NUMBER}]})):s.granularity===`quarter_number`?[1,2,3,4].map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:O(`Quarter %s`,e),htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`day_of_month`?S(1,32).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`iso_week_number`?S(0,54).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`day_of_week`?S(1,8).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`hour_number`?S(0,24).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`minute_number`?S(0,60).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):s.granularity===`second_number`?S(0,60).map(e=>({text:`${e}`,fuzzySearchKey:`${e}`,description:``,htmlContent:[{value:`${e}`,color:mC.NUMBER}]})):i.getPossibleFieldValues(s).map(({value:e,label:t})=>{let n=typeof e==`string`,r=n?`"${e}"`:e.toString(),i=n?mC.STRING:mC.NUMBER,a=t===e?``:t;return{text:r,description:a,htmlContent:[{value:r,color:i}],fuzzySearchKey:r+a}})},selectProposal:yC});function DC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.VALUE`&&t.argPosition>=2&&t.argPosition%2==1}function OC(e){let t=e.functionContext;return t?.parent.toUpperCase()===`PIVOT.HEADER`&&t.argPosition>=1&&t.argPosition%2==0}oC.add(`sheet_names`,{sequence:150,autoSelectFirstProposal:!0,getProposals(e){return e.type===`SYMBOL`||e.type===`UNKNOWN`&&e.value.startsWith(`'`)?this.getters.getSheetIds().map(e=>{let t=lt(this.getters.getSheetName(e));return{text:t,fuzzySearchKey:t.startsWith(`'`)?t:`'`+t}}):[]},selectProposal(e,t){let n=e.start,r=e.end;this.composer.changeComposerCursorSelection(n,r),this.composer.replaceComposerCursorSelection(t+`!`)}});let kC=new h;kC.add(`ALPHANUMERIC_INCREMENT_MODIFIER`,{apply:(e,t)=>{e.current+=e.increment;let n=`${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:n},tooltip:{props:{content:n}}}}}).add(`INCREMENT_MODIFIER`,{apply:(e,t,n)=>{e.current+=e.increment;let r=e.current.toString(),i=n.getLocale(),a=B(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:r},tooltip:r?{props:{content:a}}:void 0}}}).add(`DATE_INCREMENT_MODIFIER`,{apply:(e,t,n)=>{let r=R(e.current,n.getLocale());r.setFullYear(r.getFullYear()+e.increment.years||0),r.setMonth(r.getMonth()+e.increment.months||0),r.setDate(r.getDate()+e.increment.days||0);let i=yi(r);e.current=i;let a=n.getLocale(),o=B(i,{format:t.cell?.format,locale:a});return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:i.toString()},tooltip:i?{props:{content:o}}:void 0}}}).add(`COPY_MODIFIER`,{apply:(e,t,n)=>{let r=t.cell?.content||``,i={locale:n.getLocale(),format:t.cell?.format};return{cellData:{border:t.border,style:t.cell&&t.cell.style,format:t.cell&&t.cell.format,content:r},tooltip:r?{props:{content:t.cell?Ms(t.cell,i).formattedValue:``}}:void 0}}}).add(`FORMULA_MODIFIER`,{apply:(e,t,n,r)=>{e.current+=e.increment;let i=0,a=0;switch(r){case`up`:i=0,a=-e.current;break;case`down`:i=0,a=e.current;break;case`left`:i=-e.current,a=0;break;case`right`:i=e.current,a=0;break}let o=t.cell;if(!o||!o.isFormula)return{cellData:{}};let s=t.sheetId,c=n.getTranslatedCellFormula(s,i,a,o.compiledFormula.tokens);return{cellData:{border:t.border,style:o.style,format:o.format,content:c},tooltip:c?{props:{content:c}}:void 0}}});let AC=new h,jC=/(\d+)$/,MC=/^(.*\D+)/,NC=/^(.*\D+)(\d+)$/;function PC(e,t,n){let r=[],i=!1;for(let a of t){a===e&&(i=!0);let t=a===void 0||a.isFormula?void 0:Ms(a,{locale:k,format:a.format});if(t&&n(t))r.push(t);else{if(i)return r;r=[]}}return r}function FC(e){let t=[],n=e[0];for(let r=1;r<e.length;r++){let i=e[r];t.push(i-n),n=i}return t.reduce((e,t)=>e+t,0)/t.length}function IC(e){let t=1;return e.length>=2&&(t=FC(e)*e.length),t}function LC(e){return e.length<2?e[0]||{years:0,months:0,days:0}:e.every(t=>t.years===e[0].years&&t.months===e[0].months&&t.days===e[0].days)?e[0]:void 0}function RC(e){if(e.length<2)return 1;let t=e.map(e=>R(e,k)),n=LC(zC(t));if(n===void 0)return;let r=Object.values(n).filter(e=>e!==0).length===1,i=Object.values(n).every(e=>e===0);if(!r||i){let n=t.map((e,n)=>{if(n===0)return 0;let r=t[n-1];return Math.floor(e.getTime())-Math.floor(r.getTime())}).slice(1);if(n.every(e=>e===n[0]))return e.length*(e[1]-e[0])}return{years:n.years*e.length,months:n.months*e.length,days:n.days*e.length}}AC.add(`simple_value_copy`,{condition:(e,t)=>t.length===1&&!e.isFormula&&!(e.format&&ls(e.format)),generateRule:()=>({type:`COPY_MODIFIER`}),sequence:10}).add(`increment_alphanumeric_value`,{condition:e=>!e.isFormula&&Ms(e,{locale:k}).type===`text`&&NC.test(e.content),generateRule:(e,t,n)=>{let r=parseInt(e.content.match(jC)[0]),i=e.content.match(MC)[0],a=e.content.length-i.length,o=PC(e,t,e=>e.type===`text`&&NC.test(e.value)).filter(e=>i===(e.value??``).toString().match(MC)[0]).map(e=>parseInt((e.value??``).toString().match(jC)[0])),s=IC(o);return[`up`,`left`].includes(n)&&o.length===1&&(s=-s),{type:`ALPHANUMERIC_INCREMENT_MODIFIER`,prefix:i,current:r,increment:s,numberPostfixLength:a}},sequence:15}).add(`copy_text`,{condition:e=>!e.isFormula&&Ms(e,{locale:k}).type===`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&&Ms(e,{locale:k}).type===`number`&&!!e.format&&ls(e.format),generateRule:(e,t)=>{let n=RC(PC(e,t,e=>e.type===`number`&&!!e.format&&ls(e.format)).map(e=>Number(e.value)));if(n===void 0)return{type:`COPY_MODIFIER`};let r=Ms(e,{locale:k});return typeof n==`object`?{type:`DATE_INCREMENT_MODIFIER`,increment:n,current:r.type===`number`?r.value:0}:{type:`INCREMENT_MODIFIER`,increment:n,current:r.type===`number`?r.value:0}},sequence:25}).add(`increment_number`,{condition:e=>!e.isFormula&&Ms(e,{locale:k}).type===`number`,generateRule:(e,t,n)=>{let r=PC(e,t,e=>e.type===`number`&&!ls(e.format||``)).map(e=>Number(e.value)),i=IC(r);[`up`,`left`].includes(n)&&r.length===1&&(i=-i);let a=Ms(e,{locale:k});return{type:`INCREMENT_MODIFIER`,increment:i,current:a.type===`number`?a.value:0}},sequence:40});function zC(e){return e.length<2?[{years:0,months:0,days:0}]:e.map((t,n)=>{if(n===0)return{years:0,months:0,days:0};let r=D.fromTimestamp(e[n-1].getTime()),i=Di(r,t),a=Ti(r,t)%12;return r.setFullYear(r.getFullYear()+i),r.setMonth(r.getMonth()+a),{years:i,months:a,days:Ei(r,t)}}).slice(1)}let BC=new h,VC=`#F3F2F1`;function HC(e,t){let n=e.getBoundingClientRect(),r=window.devicePixelRatio||1;e.width=r*n.width,e.height=r*n.height;let i=e.getContext(`2d`);i.scale(r,r);let a=JC(n,t,i);WC(i,a),UC(i,a),KC(i,a),GC(i,a),qC(i,a)}function UC(e,t){e.save();let n=t.gauge,r=n.rect.x+n.rect.width/2,i=n.rect.y+n.rect.height,a=n.rect.height-n.arcWidth/2;if(a<0)return;let o=n.percentage===1?0:Math.PI*(1+n.percentage);e.strokeStyle=VC,e.beginPath(),e.lineWidth=n.arcWidth,e.arc(r,i,a,o,0),e.stroke(),e.strokeStyle=n.color,e.beginPath(),e.arc(r,i,a,Math.PI,o),e.stroke(),e.restore()}function WC(e,t){e.save(),e.fillStyle=t.backgroundColor,e.fillRect(0,0,t.width,t.height),e.restore()}function GC(e,t){for(let n of[t.minLabel,t.maxLabel,t.gaugeValue])e.save(),e.textAlign=`center`,e.fillStyle=n.color,e.font=`${n.fontSize}px ${Ve}`,e.fillText(n.label,n.textPosition.x,n.textPosition.y),e.restore()}function KC(e,t){let{x:n,y:r,width:i,height:a}=t.gauge.rect;for(let o of t.inflectionValues){e.save(),e.translate(n+i/2-.5,r+a-.5),e.rotate(Math.PI/2-o.rotation),e.lineWidth=2,e.strokeStyle=qx(t.backgroundColor)+`aa`,e.beginPath(),e.moveTo(0,-(a-t.gauge.arcWidth)),e.lineTo(0,-a-3),e.stroke(),e.textAlign=`center`,e.font=`${o.fontSize}px ${Ve}`,e.fillStyle=o.color;let s=-a-6-o.offset;e.fillText(o.label,0,s),e.restore()}}function qC(e,t){e.save();let n=t.title;e.font=zc(n.fontSize,n.bold,n.italic),e.textBaseline=`middle`,e.fillStyle=n.color,e.fillText(n.label,n.textPosition.x,n.textPosition.y),e.restore()}function JC(e,t,n){let r=t.maxValue,i=t.minValue,a=t.gaugeValue,o=YC(e,t.title.text),s=o.width/6,c=a?(a.value-i.value)/(r.value-i.value):0,l={x:e.width/2,y:o.y+o.height-o.height/12},u=80;o.height<300&&(u*=o.height/300);let d=o.width/2,f=a?.label||`-`;Vc(n,f,{fontSize:u},`px`)>d&&(u=Zc(d,u,e=>Vc(n,f,{fontSize:e},`px`)));let p={x:o.x+s/2,y:o.y+o.height+12},m={x:o.x+o.width-s/2,y:o.y+o.height+12},h=qx(t.background),g=XC(t,o,h,n),_=0,v=0,y=0;switch(t.title.text&&({width:v,height:y}=Wc(n,t.title.text,{fontSize:16,...t.title},`px`)),t.title.align){case`right`:_=e.width-v-20;break;case`center`:_=(e.width-v)/2;break;default:_=20;break}return{width:e.width,height:e.height,title:{label:t.title.text??``,fontSize:t.title.fontSize??16,textPosition:{x:_,y:15+y/2},color:t.title.color??h,bold:t.title.bold,italic:t.title.italic},backgroundColor:t.background,gauge:{rect:o,arcWidth:s,percentage:x(c,0,1),color:ZC(t)},inflectionValues:g,gaugeValue:{label:f,textPosition:l,fontSize:u,color:h},minLabel:{label:t.minValue.label,textPosition:p,fontSize:12,color:h},maxLabel:{label:t.maxValue.label,textPosition:m,fontSize:12,color:h}}}function YC(e,t){let n=t?25:0,r=e.height-20-n-10,i=e.width-60,a,o;return i>2*r?(a=2*r,o=r):(a=i,o=i/2),{x:30+(i-a)/2,y:n+10+(r-o)/2,width:a,height:o}}function XC(e,t,n,r){let i=e.maxValue,a=e.minValue,o={x:t.x+t.width/2,y:t.y+t.height},s={fontSize:12},c=[],l=[];for(let u of e.inflectionValues){let e=(u.value-a.value)/(i.value-a.value),d=Vc(r,u.label,s,`px`),f=Math.PI-Math.PI*e,p=tw(f,t.height+6,o.x,o.y,d+2,12),m=l.some(e=>ew(e,p))?12:0;l.push(p),c.push({rotation:f,label:u.label,fontSize:12,color:n,offset:m})}return c}function ZC(e){let t=e.gaugeValue?.value;if(t===void 0)return VC;for(let n=0;n<e.inflectionValues.length;n++){let r=e.inflectionValues[n];if(r.operator===`<`&&t<r.value||r.operator===`<=`&&t<=r.value)return e.colors[n]}return e.colors.at(-1)}function QC(e){return[{start:e.topLeft,end:e.topRight},{start:e.topRight,end:e.bottomRight},{start:e.bottomRight,end:e.bottomLeft},{start:e.bottomLeft,end:e.topLeft}]}function $C(e,t){let n=e.start,r=e.end,i=t.start,a=t.end;function o(e,t,n){return(n.y-e.y)*(t.x-e.x)>(t.y-e.y)*(n.x-e.x)}return o(n,i,a)!==o(r,i,a)&&o(n,r,i)!==o(n,r,a)}function ew(e,t){let n=QC(e),r=QC(t);for(let e of n)for(let t of r)if($C(e,t))return!0;return!1}function tw(e,t,n,r,i,a){let o=Math.cos(e),s=Math.sin(e),c=o*t,l=s*t,u=i/2*s,d=i/2*o,f={x:c+u+n,y:r-(l-d)},p={x:c-u+n,y:r-(l+d)},m=o*(t+a),h=s*(t+a),g={x:m-u+n,y:r-(h+d)};return{bottomLeft:p,bottomRight:f,topRight:{x:m+u+n,y:r-(h-d)},topLeft:g}}var nw=class extends t.Component{static template=`o-spreadsheet-GaugeChartComponent`;canvas=(0,t.useRef)(`chartContainer`);get runtime(){return this.env.model.getters.getChartRuntime(this.props.figureUI.id)}setup(){(0,t.useEffect)(()=>HC(this.canvas.el,this.runtime),()=>{let e=this.canvas.el.getBoundingClientRect();return[e.width,e.height,this.runtime,this.canvas.el,window.devicePixelRatio]})}};nw.props={figureUI:Object};function rw(e){return e=sn(e).replace(`#`,``),e.length===8?e.slice(6)+e.slice(0,6):e}let iw={responsive:!0,maintainAspectRatio:!1,elements:{line:{fill:!1},point:{hitRadius:15}},animation:!1,events:[`mousemove`,`mouseout`,`click`,`touchstart`,`touchmove`,`mouseup`]};function aw(e,t,n){let r=document.createElement(`div`);r.style.width=`${t.width}px`,r.style.height=`${t.height}px`;let i=document.createElement(`canvas`);r.append(i),i.setAttribute(`width`,t.width.toString()),i.setAttribute(`height`,t.height.toString());let a;if(document.body.append(r),`chartJsConfig`in e){let t=mf();t||hf();let n=b(e.chartJsConfig);n.plugins=[sw];let r=new window.Chart(i,n);a=r.toBase64Image(),r.destroy(),t||gf()}else n===`scorecard`?($S(rC(t,e),i),a=i.toDataURL()):n===`gauge`&&(HC(i,e),a=i.toDataURL());return r.remove(),a}async function ow(e,t,n){let r=document.createElement(`div`);r.style.width=`${t.width}px`,r.style.height=`${t.height}px`,r.style.position=`fixed`,r.style.opacity=`0`;let i=document.createElement(`canvas`);r.append(i),i.setAttribute(`width`,t.width.toString()),i.setAttribute(`height`,t.height.toString()),document.body.append(r);let a=null;if(`chartJsConfig`in e){let t=mf();t||hf();let n=b(e.chartJsConfig);n.plugins=[sw];let r=new window.Chart(i,n);a=await new Promise(e=>i.toBlob(e,`image/png`)),r.destroy(),t||gf()}else n===`scorecard`?($S(rC(t,e),i),a=await new Promise(e=>i.toBlob(e,`image/png`))):n===`gauge`&&(HC(i,e),a=await new Promise(e=>i.toBlob(e,`image/png`)));return r.remove(),a?new File([a],`chart.png`,{type:`image/png`}):void 0}let sw={id:`customCanvasBackgroundColor`,beforeDraw:e=>{let{ctx:t}=e;t.save(),t.globalCompositeOperation=`destination-over`,t.fillStyle=`#ffffff`,t.fillRect(0,0,e.width,e.height),t.restore()}},cw={Errors:{InvalidRange:O(`The range is invalid`),FirstArgMissing:O(`The argument is missing. Please provide a value`),SecondArgMissing:O(`The second argument is missing. Please provide a value`),MinNaN:O(`The minpoint must be a number`),MidNaN:O(`The midpoint must be a number`),MaxNaN:O(`The maxpoint must be a number`),ValueUpperInflectionNaN:O(`The first value must be a number`),ValueLowerInflectionNaN:O(`The second value must be a number`),MinBiggerThanMax:O(`Minimum must be smaller then Maximum`),MinBiggerThanMid:O(`Minimum must be smaller then Midpoint`),MidBiggerThanMax:O(`Midpoint must be smaller then Maximum`),LowerBiggerThanUpper:O(`Lower inflection point must be smaller than upper inflection point`),MinInvalidFormula:O(`Invalid Minpoint formula`),MaxInvalidFormula:O(`Invalid Maxpoint formula`),MidInvalidFormula:O(`Invalid Midpoint formula`),ValueUpperInvalidFormula:O(`Invalid upper inflection point formula`),ValueLowerInvalidFormula:O(`Invalid lower inflection point formula`),EmptyRange:O(`A range needs to be defined`),ValueCellIsInvalidFormula:O(`At least one of the provided values is an invalid formula`),Unexpected:O(`The rule is invalid for an unknown reason`)},ColorScale:O(`Color scale`),IconSet:O(`Icon set`),DataBar:O(`Data bar`)},lw={IsEmpty:O(`Is empty`),IsNotEmpty:O(`Is not empty`),ContainsText:O(`Contains`),NotContains:O(`Does not contain`),BeginsWith:O(`Starts with`),EndsWith:O(`Ends with`),Equal:O(`Is equal to`),NotEqual:O(`Is not equal to`),GreaterThan:O(`Is greater than`),GreaterThanOrEqual:O(`Is greater than or equal to`),LessThan:O(`Is less than`),LessThanOrEqual:O(`Is less than or equal to`),Between:O(`Is between`),NotBetween:O(`Is not between`)},uw={Series:O(`Series`),BackgroundColor:O(`Background color`),StackedBarChart:O(`Stacked bar chart`),StackedLineChart:O(`Stacked line chart`),StackedAreaChart:O(`Stacked area chart`),StackedColumnChart:O(`Stacked column chart`),CumulativeData:O(`Cumulative data`),TreatLabelsAsText:O(`Treat labels as text`),AggregatedChart:O(`Aggregate`),Errors:{Unexpected:O(`The chart definition is invalid for an unknown reason`),InvalidDataSet:O(`The dataset is invalid`),InvalidLabelRange:O(`Labels are invalid`),InvalidScorecardKeyValue:O(`The key value is invalid`),InvalidScorecardBaseline:O(`The baseline value is invalid`),InvalidGaugeDataRange:O(`The data range is invalid`),EmptyGaugeRangeMin:O(`A minimum range limit value is needed`),GaugeRangeMinNaN:O(`The minimum range limit value must be a number`),EmptyGaugeRangeMax:O(`A maximum range limit value is needed`),GaugeRangeMaxNaN:O(`The maximum range limit value must be a number`),GaugeLowerInflectionPointNaN:O(`The lower inflection point value must be a number`),GaugeUpperInflectionPointNaN:O(`The upper inflection point value must be a number`)},GeoChart:{ColorScales:{blues:O(`Blues`),cividis:O(`Cividis`),greens:O(`Greens`),greys:O(`Greys`),oranges:O(`Oranges`),purples:O(`Purples`),rainbow:O(`Rainbow`),reds:O(`Reds`),viridis:O(`Viridis`)}}},dw={Custom:O(`Custom`)},fw=O(`Merged cells are preventing this operation. Unmerge those cells and try again.`),pw=O(`The header row of a table can't be moved.`),mw={Errors:{Unexpected:O(`Cannot split the selection for an unknown reason`),NoSplitSeparatorInSelection:O(`There is no match for the selected separator in the selection`),MoreThanOneColumnSelected:O(`Only a selection from a single column can be split`),SplitWillOverwriteContent:O(`Splitting will overwrite existing content`)}},hw={Errors:{Unexpected:O(`Cannot remove duplicates for an unknown reason`),MoreThanOneRangeSelected:O(`Please select only one range of cells`),EmptyTarget:O(`Please select a range of cells containing values.`),NoColumnsProvided:O(`Please select at latest one column to analyze.`),WillRemoveExistingMerge:O(`This operation is not possible due to a merge. Please remove the merges first than try again.`)}},K={DateIs:{today:O(`today`),yesterday:O(`yesterday`),tomorrow:O(`tomorrow`),lastWeek:O(`in the past week`),lastMonth:O(`in the past month`),lastYear:O(`in the past year`)},DateIsBefore:{today:O(`today`),yesterday:O(`yesterday`),tomorrow:O(`tomorrow`),lastWeek:O(`one week ago`),lastMonth:O(`one month ago`),lastYear:O(`one year ago`)},CriterionError:{notEmptyValue:O(`The value must not be empty`),numberValue:O(`The value must be a number`),dateValue:O(`The value must be a date`),validRange:O(`The value must be a valid range`),validFormula:O(`The formula must be valid`)},Errors:{InvalidRange:O(`The range is invalid.`),InvalidDataValidationCriterionValue:O(`One or more of the provided criteria values are invalid. Please review and correct them.`),InvalidNumberOfCriterionValues:O(`One or more of the provided criteria values are missing.`),Unexpected:O(`The rule is invalid for an unknown reason.`)}},gw={Errors:{Unexpected:O(`The table zone is invalid for an unknown reason`),TableOverlap:O(`You cannot create overlapping tables.`),NonContinuousTargets:O(`A table can only be created on a continuous selection.`),InvalidRange:O(`The range is invalid`),TargetOutOfSheet:O(`The range is out of the sheet`)},Checkboxes:{hasFilters:O(`Filter button`),headerRow:O(`Header row(s)`),bandedRows:O(`Banded rows`),firstColumn:O(`First column`),lastColumn:O(`Last column`),bandedColumns:O(`Banded columns`),automaticAutofill:O(`Automatically autofill formulas`),totalRow:O(`Total row`),isDynamic:O(`Auto-adjust to formula result`)},Tooltips:{filterWithoutHeader:O(`Cannot have filters without a header row`),isDynamic:O(`For tables based on array formulas only`)}},_w={labels:{no_calculations:O(`No calculations`),"%_of_grand_total":O(`% of grand total`),"%_of_col_total":O(`% of column total`),"%_of_row_total":O(`% of row total`),"%_of":O(`% of`),"%_of_parent_row_total":O(`% of parent row total`),"%_of_parent_col_total":O(`% of parent column total`),"%_of_parent_total":O(`% of parent total`),difference_from:O(`Difference from`),"%_difference_from":O(`% difference from`),running_total:O(`Running total`),"%_running_total":O(`% Running total`),rank_asc:O(`Rank smallest to largest`),rank_desc:O(`Rank largest to smallest`),index:O(`Index`)},descriptions:{"%_of_grand_total":()=>O(`Displayed as % of grand total`),"%_of_col_total":()=>O(`Displayed as % of column total`),"%_of_row_total":()=>O(`Displayed as % of row total`),"%_of":e=>O(`Displayed as % of "%s"`,e),"%_of_parent_row_total":e=>O(`Displayed as % of parent row total of "%s"`,e),"%_of_parent_col_total":()=>O(`Displayed as % of parent column total`),"%_of_parent_total":e=>O(`Displayed as % of parent "%s" total`,e),difference_from:e=>O(`Displayed as difference from "%s"`,e),"%_difference_from":e=>O(`Displayed as % difference from "%s"`,e),running_total:e=>O(`Displayed as running total based on "%s"`,e),"%_running_total":e=>O(`Displayed as % running total based on "%s"`,e),rank_asc:e=>O(`Displayed as rank from smallest to largest based on "%s"`,e),rank_desc:e=>O(`Displayed as rank largest to smallest based on "%s"`,e),index:()=>O(`Displayed as index`)},documentation:{no_calculations:O(`Displays the value that is entered in the field.`),"%_of_grand_total":O(`Displays values as a percentage of the grand total of all the values or data points in the report.`),"%_of_col_total":O(`Displays all the values in each column or series as a percentage of the total for the column or series.`),"%_of_row_total":O(`Displays the value in each row or category as a percentage of the total for the row or category.`),"%_of":O(`Displays values as a percentage of the value of the Base item in the Base field.`),"%_of_parent_row_total":O(`Calculates values as follows:
|
|
28
28
|
(value for the item) / (value for the parent item on rows)`),"%_of_parent_col_total":O(`Calculates values as follows:
|
|
29
29
|
(value for the item) / (value for the parent item on columns)`),"%_of_parent_total":O(`Calculates values as follows:
|
|
30
30
|
(value for the item) / (value for the parent item of the selected Base field)`),difference_from:O(`Displays values as the difference from the value of the Base item in the Base field.`),"%_difference_from":O(`Displays values as the percentage difference from the value of the Base item in the Base field.`),running_total:O(`Displays the value for successive items in the Base field as a running total.`),"%_running_total":O(`Calculates the value as a percentage for successive items in the Base field that are displayed as a running total.`),rank_asc:O(`Displays the rank of selected values in a specific field, listing the smallest item in the field as 1, and each larger value with a higher rank value.`),rank_desc:O(`Displays the rank of selected values in a specific field, listing the largest item in the field as 1, and each smaller value with a higher rank value.`),index:O(`Calculates values as follows:
|
|
@@ -75,7 +75,7 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
75
75
|
height: 100%;
|
|
76
76
|
position: relative;
|
|
77
77
|
}
|
|
78
|
-
`;var HE=class extends t.Component{static template=`o-spreadsheet-ChartFigure`;static props={figureUI:Object};static components={};onDoubleClick(){this.env.model.dispatch(`SELECT_FIGURE`,{figureId:this.props.figureUI.id}),this.env.openSidePanel(`ChartPanel`)}get chartType(){return this.env.model.getters.getChartType(this.props.figureUI.id)}get chartComponent(){let e=this.chartType,t=RE.get(e);if(!t)throw Error(`Component is not defined for type ${e}`);return t}},UE=class extends t.Component{static template=`o-spreadsheet-ImageFigure`;static props={figureUI:Object};static components={};get figureId(){return this.props.figureUI.id}get getImagePath(){return this.env.model.getters.getImagePath(this.figureId)}};let WE=/Mac/i,GE=[`Shift`,`Control`,`Alt`,`Meta`];function KE(e,t){return e?!!t.target&&e.contains(t.target):!1}function qE(){let e=document.querySelector(`.o-grid-overlay`);if(e){let{top:t,left:n}=e.getBoundingClientRect();return{top:t,left:n}}throw Error(`Can't find spreadsheet position`)}function JE(e){let t=e.getBoundingClientRect();return{x:t.x,y:t.y,width:t.width,height:t.height}}function*YE(e){if(yield e,e.hasChildNodes())for(let t of e.childNodes)yield*YE(t)}function XE(){return Array.from(document.querySelectorAll(`.o-spreadsheet .o-menu`))}function ZE(e){let{startElement:t,endElement:n,startSelectionOffset:r,endSelectionOffset:i}=QE(e);return{start:$E(e,t,r),end:$E(e,n,i)}}function QE(e){let t=document.getSelection();return{startElement:t.anchorNode||e,startSelectionOffset:t.anchorOffset,endElement:t.focusNode||e,endSelectionOffset:t.focusOffset}}function $E(e,t,n){let r=0,i=YE(e),a=i.next(),o=!0;for(;!a.done&&a.value!==t;)a.value.hasChildNodes()||a.value.textContent&&(r+=a.value.textContent.length),(a.value.nodeName===`P`||a.value.nodeName===`DIV`&&a.value!==e)&&(o?o=!1:r++),a=i.next();if(a.value!==t)return 0;if(!a.value.hasChildNodes())r+=n;else{let e=[...a.value.childNodes].slice(0,n);r+=e.reduce((t,n,r)=>{if(n.textContent!==null){let i=n.textContent.length;return n.nodeName===`P`&&r!==e.length-1&&i++,t+i}else return t},0)}return t.nodeName===`P`&&!o&&t.textContent===``&&r++,r}let eD=/^[a-zA-Z]$/;function tD(e,t=`key`){let n=``;GE.includes(e.key)||(rD(e)&&(n+=`Ctrl+`),e.altKey&&(n+=`Alt+`),e.shiftKey&&(n+=`Shift+`));let r=t===`key`?e.key:e.code;return n+=eD.test(r)?r.toUpperCase():r,n}function nD(){return!!WE.test(navigator.userAgent)}function rD(e){return nD()?e.metaKey:e.ctrlKey}function iD(e){return e.button===1||rD(e)&&e.button===0}async function aD(e){return new Promise((t,n)=>{let r=new Image;r.addEventListener(`load`,()=>{let e=document.createElement(`canvas`);e.width=r.width,e.height=r.height,e.getContext(`2d`)?.drawImage(r,0,0),e.toBlob(t,`image/png`)}),r.addEventListener(`error`,n),r.src=e})}function oD(e,t){let n=document.createElement(`a`);n.href=e,n.download=t,document.body.appendChild(n),n.click(),document.body.removeChild(n)}function sD(){return/Firefox/i.test(navigator.userAgent)}function cD(e){let t=LE.getAll().sort((e,t)=>e.sequence-t.sequence);function n(n,r,i){let a=t.find(e=>e.match(r.type));if(!a)throw Error(`No builder for this chart: ${r.type}`);return a.createChart(r,i,e)}return n}function lD(e){let t=LE.getAll().sort((e,t)=>e.sequence-t.sequence);function n(n){let r=t.find(e=>e.match(n.type));if(!r)throw Error(`No runtime builder for this chart.`);return r.getChartRuntime(n,e)}return n}function uD(e,t){let n=LE.getAll().find(e=>e.match(t.type));if(!n)throw Error(`Unknown chart type.`);return n.validateChartDefinition(e,t)}function dD(e,t,n){let r=LE.getAll().find(e=>e.match(t.type));if(!r)throw Error(`Unknown chart type.`);return r.transformDefinition(e,t,n)}function fD(e,t){let n=pD(t,e);if(n)return n;let r=t.getActiveSheetId(),i=e,a=br(e).numberOfCols===1;a||(i={...e,left:e.left+1});let o=cr(t.getUnboundedZone(r,i)),s=[{dataRange:o,yAxisId:`y`}],c=t.getCell({sheetId:r,col:e.left,row:e.top});if(Nr(e)===1&&c?.content)return{type:`scorecard`,title:{},background:c.style?.fillColor||void 0,keyValue:cr(e),baselineMode:We,baselineColorUp:Ge,baselineColorDown:Ke};let l=!!t.getEvaluatedCellsInZone(r,{...i,bottom:i.top}).find(e=>e.type!==`empty`&&e.type!==`number`),u;a||(u=cr(t.getUnboundedZone(r,{...e,right:e.left})));let d=i.right===i.left?`none`:`top`,f={title:{},dataSets:s,labelsAsText:!1,stacked:!1,aggregated:!1,cumulative:!1,labelRange:u,type:`line`,dataSetsHaveTitle:l,legendPosition:d},p=new xE(f,r,t);if(Bw(f,p.dataSets,p.labelRange,t))return f;let m=Vx(t,s,r,l);return a&&Jw(t,m[0]).every(e=>typeof e==`string`&&!P(e))?{title:{},dataSets:[{dataRange:o}],aggregated:!0,labelRange:o,type:`pie`,legendPosition:`top`,dataSetsHaveTitle:!1}:{title:{},dataSets:s,labelRange:u,type:`bar`,stacked:!1,aggregated:!1,dataSetsHaveTitle:l,legendPosition:d}}function pD(e,t){let n=e.getActiveSheetId(),r=br(t).numberOfCols;if(t.top===t.bottom||r<=2)return;let i=e.getEvaluatedCell({sheetId:n,col:t.right,row:t.top}).type!==`number`,a=r=>{let a=e.getEvaluatedCellsInZone(n,{...t,left:r,right:r,top:t.top+ +!!i});if(a.every(e=>e.type!==`number`))return`string`;if(a.every(e=>e.type!==`text`))return`number`};for(let e=t.left;e<t.right;e++){let n=a(e);if(e!==t.right&&n!==`string`||e===t.right&&n!==`number`)return}let o={...t,right:t.right-1},s={...t,left:t.right};return{title:{},dataSets:[{dataRange:cr(o)}],type:`sunburst`,legendPosition:`none`,labelRange:cr(s),dataSetsHaveTitle:i}}var mD=l({AbstractChart:()=>US,BarChart:()=>nE,CHART_AXIS_CHOICES:()=>tS,CHART_COMMON_OPTIONS:()=>iw,GaugeChart:()=>pE,LineChart:()=>xE,MOVING_AVERAGE_TREND_LINE_XAXIS_ID:()=>Ix,PieChart:()=>CE,ScorecardChart:()=>QS,TREND_LINE_XAXIS_ID:()=>`x1`,WaterfallChart:()=>FE,adaptChartRange:()=>Bx,chartFactory:()=>cD,chartFontColor:()=>Kx,chartMutedFontColor:()=>qx,chartRuntimeFactory:()=>lD,chartToImageFile:()=>ow,chartToImageUrl:()=>aw,checkDataset:()=>Jx,checkLabelRange:()=>Yx,createBarChartRuntime:()=>rE,createDataSets:()=>Vx,createGaugeChartRuntime:()=>mE,createLineChartRuntime:()=>SE,createPieChartRuntime:()=>wE,createScorecardChartRuntime:()=>eC,createWaterfallChartRuntime:()=>IE,drawScoreChart:()=>$S,duplicateDataSetsInDuplicatedSheet:()=>Rx,duplicateLabelRangeInDuplicatedSheet:()=>zx,formatChartDatasetValue:()=>$x,formatTickValue:()=>eS,getChartPositionAtCenterOfViewport:()=>Zx,getDefinedAxis:()=>Qx,getPieColors:()=>nS,getSmartChartDefinition:()=>fD,isTrendLineAxis:()=>iS,shouldRemoveFirstLabel:()=>Xx,toExcelDataset:()=>Ux,toExcelLabelRange:()=>Wx,transformChartDefinitionWithDataSetsWithZone:()=>Gx,transformDefinition:()=>dD,truncateLabel:()=>rS,updateChartRangesWithDataSets:()=>Lx,validateChartDefinition:()=>uD});function hD(e,t){let{scrollX:n,scrollY:r}=e.getActiveSheetScrollInfo(),i=e.getSheetViewDimension(),a=n+Math.max(0,(i.width-t.width)/2),o=r+Math.max(0,(i.height-t.height)/2);return e.getPositionAnchorOffset({x:a,y:o})}function gD(e,t){let n=b(t),r=e.getSheetViewDimension(),i=r.width,a=r.height;if(n.width>i){let e=i/n.width;n.width=i,n.height*=e}if(n.height>a){let e=a/n.height;n.height=a,n.width*=e}return n}var _D=class{constructor(e){this.xmlString=e}toString(){return this.xmlString}};let vD=[`areaChart`,`area3DChart`,`lineChart`,`line3DChart`,`stockChart`,`radarChart`,`scatterChart`,`pieChart`,`pie3DChart`,`doughnutChart`,`barChart`,`bar3DChart`,`ofPieChart`,`surfaceChart`,`surface3DChart`,`bubbleChart`,`comboChart`,`radarChart`];function yD(e,t,n){return{content:new XMLSerializer().serializeToString(e),path:t,contentType:n}}function bD(e){return String(e).replace(/\&/g,`&`).replace(/\</g,`<`).replace(/\>/g,`>`).replace(/\"/g,`"`).replace(/\'/g,`'`).replace(/[\x00-\x08\x0B\x0C\x0E-\x1F]/g,``)}function q(e){return new _D(e.map(([e,t])=>`${e}="${bD(t)}"`).join(` `))}function xD(e,t=`text/xml`){let n=new DOMParser().parseFromString(e.toString(),t),r=n.querySelector(`parsererror`);if(r){let t=r.innerHTML,n=parseInt(t.split(`:`)[0],10),i=e.toString().trim().split(`
|
|
78
|
+
`;var HE=class extends t.Component{static template=`o-spreadsheet-ChartFigure`;static props={figureUI:Object};static components={};onDoubleClick(){this.env.model.dispatch(`SELECT_FIGURE`,{figureId:this.props.figureUI.id}),this.env.openSidePanel(`ChartPanel`)}get chartType(){return this.env.model.getters.getChartType(this.props.figureUI.id)}get chartComponent(){let e=this.chartType,t=RE.get(e);if(!t)throw Error(`Component is not defined for type ${e}`);return t}},UE=class extends t.Component{static template=`o-spreadsheet-ImageFigure`;static props={figureUI:Object};static components={};get figureId(){return this.props.figureUI.id}get getImagePath(){return this.env.model.getters.getImagePath(this.figureId)}};let WE=/Mac/i,GE=[`Shift`,`Control`,`Alt`,`Meta`];function KE(e,t){return e?!!t.target&&e.contains(t.target):!1}function qE(){let e=document.querySelector(`.o-grid-overlay`);if(e){let{top:t,left:n}=e.getBoundingClientRect();return{top:t,left:n}}throw Error(`Can't find spreadsheet position`)}function JE(e){let t=e.getBoundingClientRect();return{x:t.x,y:t.y,width:t.width,height:t.height}}function*YE(e){if(yield e,e.hasChildNodes())for(let t of e.childNodes)yield*YE(t)}function XE(){return Array.from(document.querySelectorAll(`.o-spreadsheet .o-menu`))}function ZE(e){let{startElement:t,endElement:n,startSelectionOffset:r,endSelectionOffset:i}=QE(e);return{start:$E(e,t,r),end:$E(e,n,i)}}function QE(e){let t=document.getSelection();return{startElement:t.anchorNode||e,startSelectionOffset:t.anchorOffset,endElement:t.focusNode||e,endSelectionOffset:t.focusOffset}}function $E(e,t,n){let r=0,i=YE(e),a=i.next(),o=!0;for(;!a.done&&a.value!==t;)a.value.hasChildNodes()||a.value.textContent&&(r+=a.value.textContent.length),(a.value.nodeName===`P`||a.value.nodeName===`DIV`&&a.value!==e)&&(o?o=!1:r++),a=i.next();if(a.value!==t)return 0;if(!a.value.hasChildNodes())r+=n;else{let e=[...a.value.childNodes].slice(0,n);r+=e.reduce((t,n,r)=>{if(n.textContent!==null){let i=n.textContent.length;return n.nodeName===`P`&&r!==e.length-1&&i++,t+i}else return t},0)}return t.nodeName===`P`&&!o&&t.textContent===``&&r++,r}let eD=/^[a-zA-Z]$/;function tD(e,t=`key`){let n=``;GE.includes(e.key)||(rD(e)&&(n+=`Ctrl+`),e.altKey&&(n+=`Alt+`),e.shiftKey&&(n+=`Shift+`));let r=t===`key`?e.key:e.code;return n+=eD.test(r)?r.toUpperCase():r,n}function nD(){return!!WE.test(navigator.userAgent)}function rD(e){return nD()?e.metaKey:e.ctrlKey}function iD(e){return e.button===1||rD(e)&&e.button===0}async function aD(e){return new Promise((t,n)=>{let r=new Image;r.addEventListener(`load`,()=>{let e=document.createElement(`canvas`);e.width=r.width,e.height=r.height,e.getContext(`2d`)?.drawImage(r,0,0),e.toBlob(t,`image/png`)}),r.addEventListener(`error`,n),r.src=e})}function oD(e,t){let n=document.createElement(`a`);n.href=e,n.download=t,document.body.appendChild(n),n.click(),document.body.removeChild(n)}function sD(){return/Firefox/i.test(navigator.userAgent)}function cD(e){let t=LE.getAll().sort((e,t)=>e.sequence-t.sequence);function n(n,r,i){let a=t.find(e=>e.match(r.type));if(!a)throw Error(`No builder for this chart: ${r.type}`);return a.createChart(r,i,e)}return n}function lD(e){let t=LE.getAll().sort((e,t)=>e.sequence-t.sequence);function n(n){let r=t.find(e=>e.match(n.type));if(!r)throw Error(`No runtime builder for this chart.`);return r.getChartRuntime(n,e)}return n}function uD(e,t){let n=LE.getAll().find(e=>e.match(t.type));if(!n)throw Error(`Unknown chart type.`);return n.validateChartDefinition(e,t)}function dD(e,t,n){let r=LE.getAll().find(e=>e.match(t.type));if(!r)throw Error(`Unknown chart type.`);return r.transformDefinition(e,t,n)}function fD(e,t){let n=pD(t,e);if(n)return n;let r=t.getActiveSheetId(),i=e,a=br(e).numberOfCols===1;a||(i={...e,left:e.left+1});let o=cr(t.getUnboundedZone(r,i)),s=[{dataRange:o,yAxisId:`y`}],c=t.getCell({sheetId:r,col:e.left,row:e.top});if(Nr(e)===1&&c?.content)return{type:`scorecard`,title:{},background:c.style?.fillColor||void 0,keyValue:cr(e),baselineMode:We,baselineColorUp:Ge,baselineColorDown:Ke};let l=!!t.getEvaluatedCellsInZone(r,{...i,bottom:i.top}).find(e=>e.type!==`empty`&&e.type!==`number`),u;a||(u=cr(t.getUnboundedZone(r,{...e,right:e.left})));let d=i.right===i.left?`none`:`top`,f={title:{},dataSets:s,labelsAsText:!1,stacked:!1,aggregated:!1,cumulative:!1,labelRange:u,type:`line`,dataSetsHaveTitle:l,legendPosition:d},p=new xE(f,r,t);if(Bw(f,p.dataSets,p.labelRange,t))return f;let m=Vx(t,s,r,l);return a&&Jw(t,m[0]).every(e=>typeof e==`string`&&!P(e))?{title:{},dataSets:[{dataRange:o}],aggregated:!0,labelRange:o,type:`pie`,legendPosition:`top`,dataSetsHaveTitle:!1}:{title:{},dataSets:s,labelRange:u,type:`bar`,stacked:!1,aggregated:!1,dataSetsHaveTitle:l,legendPosition:d}}function pD(e,t){let n=e.getActiveSheetId(),r=br(t).numberOfCols;if(t.top===t.bottom||r<=2)return;let i=e.getEvaluatedCell({sheetId:n,col:t.right,row:t.top}).type!==`number`,a=r=>{let a=e.getEvaluatedCellsInZone(n,{...t,left:r,right:r,top:t.top+ +!!i});if(a.every(e=>e.type!==`number`))return`string`;if(a.every(e=>e.type!==`text`))return`number`};for(let e=t.left;e<t.right;e++){let n=a(e);if(e!==t.right&&n!==`string`||e===t.right&&n!==`number`)return}let o={...t,right:t.right-1},s={...t,left:t.right};return{title:{},dataSets:[{dataRange:cr(o)}],type:`sunburst`,legendPosition:`none`,labelRange:cr(s),dataSetsHaveTitle:i}}var mD=l({AbstractChart:()=>US,BarChart:()=>nE,CHART_AXIS_CHOICES:()=>tS,CHART_COMMON_OPTIONS:()=>iw,GaugeChart:()=>pE,LineChart:()=>xE,MOVING_AVERAGE_TREND_LINE_XAXIS_ID:()=>Ix,PieChart:()=>CE,ScorecardChart:()=>QS,TREND_LINE_XAXIS_ID:()=>`x1`,WaterfallChart:()=>FE,adaptChartRange:()=>Bx,chartFactory:()=>cD,chartFontColor:()=>Kx,chartMutedFontColor:()=>qx,chartRuntimeFactory:()=>lD,chartToImageFile:()=>ow,chartToImageUrl:()=>aw,checkDataset:()=>Jx,checkLabelRange:()=>Yx,createBarChartRuntime:()=>rE,createDataSets:()=>Vx,createGaugeChartRuntime:()=>mE,createLineChartRuntime:()=>SE,createPieChartRuntime:()=>wE,createScorecardChartRuntime:()=>eC,createWaterfallChartRuntime:()=>IE,drawScoreChart:()=>$S,duplicateDataSetsInDuplicatedSheet:()=>Rx,duplicateLabelRangeInDuplicatedSheet:()=>zx,formatChartDatasetValue:()=>$x,formatTickValue:()=>eS,getChartPositionAtCenterOfViewport:()=>Zx,getDefinedAxis:()=>Qx,getPieColors:()=>nS,getSmartChartDefinition:()=>fD,isTrendLineAxis:()=>iS,shouldRemoveFirstLabel:()=>Xx,toExcelDataset:()=>Ux,toExcelLabelRange:()=>Wx,transformChartDefinitionWithDataSetsWithZone:()=>Gx,transformDefinition:()=>dD,truncateLabel:()=>rS,updateChartRangesWithDataSets:()=>Lx,validateChartDefinition:()=>uD});function hD(e,t){let{scrollX:n,scrollY:r}=e.getActiveSheetScrollInfo(),i=e.getSheetViewDimension(),a=n+Math.max(0,(i.width-t.width)/2),o=r+Math.max(0,(i.height-t.height)/2);return e.getPositionAnchorOffset({x:a,y:o})}function gD(e,t){let n=b(t),r=e.getSheetViewDimension(),i=r.width,a=r.height;if(n.width>i){let e=i/n.width;n.width=i,n.height*=e}if(n.height>a){let e=a/n.height;n.height=a,n.width*=e}return n}var _D=class{xmlString;constructor(e){this.xmlString=e}toString(){return this.xmlString}};let vD=[`areaChart`,`area3DChart`,`lineChart`,`line3DChart`,`stockChart`,`radarChart`,`scatterChart`,`pieChart`,`pie3DChart`,`doughnutChart`,`barChart`,`bar3DChart`,`ofPieChart`,`surfaceChart`,`surface3DChart`,`bubbleChart`,`comboChart`,`radarChart`];function yD(e,t,n){return{content:new XMLSerializer().serializeToString(e),path:t,contentType:n}}function bD(e){return String(e).replace(/\&/g,`&`).replace(/\</g,`<`).replace(/\>/g,`>`).replace(/\"/g,`"`).replace(/\'/g,`'`).replace(/[\x00-\x08\x0B\x0C\x0E-\x1F]/g,``)}function q(e){return new _D(e.map(([e,t])=>`${e}="${bD(t)}"`).join(` `))}function xD(e,t=`text/xml`){let n=new DOMParser().parseFromString(e.toString(),t),r=n.querySelector(`parsererror`);if(r){let t=r.innerHTML,n=parseInt(t.split(`:`)[0],10),i=e.toString().trim().split(`
|
|
79
79
|
`),a=i.slice(Math.max(n-3,0),Math.min(n+2,i.length)).join(`
|
|
80
80
|
`);throw Error(`XML string could not be parsed: ${t}\n${a}`)}return n}function SD(e){if(e)return{style:e.style,color:{rgb:e.color}}}function CD(e){let t=[{},...Object.values(e.borders).map(e=>({left:SD(e.left),right:SD(e.right),bottom:SD(e.bottom),top:SD(e.top)}))];return{relsFiles:[],sharedStrings:[],styles:[{fontId:0,fillId:0,numFmtId:0,borderId:0,alignment:{}}],fonts:[{size:Be,family:2,color:{rgb:`000000`},name:`Arial`}],fills:[{reservedAttribute:`none`},{reservedAttribute:`gray125`}],borders:t,numFmts:[],dxfs:[]}}function wD(e,t){return Y`
|
|
81
81
|
<Override ContentType="${t}" PartName="${e}" />
|
|
@@ -258,7 +258,7 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
258
258
|
width: fit-content;
|
|
259
259
|
height: fit-content;
|
|
260
260
|
}
|
|
261
|
-
`;var SM=class extends t.Component{static template=`o-spreadsheet-Popover`;static props={anchorRect:Object,containerRect:{type:Object,optional:!0},positioning:{type:String,optional:!0},maxWidth:{type:Number,optional:!0},maxHeight:{type:Number,optional:!0},verticalOffset:{type:Number,optional:!0},onMouseWheel:{type:Function,optional:!0},onPopoverHidden:{type:Function,optional:!0},onPopoverMoved:{type:Function,optional:!0},zIndex:{type:Number,optional:!0},class:{type:String,optional:!0},slots:Object};static defaultProps={positioning:`bottom-left`,verticalOffset:0,onMouseWheel:()=>{},onPopoverMoved:()=>{},onPopoverHidden:()=>{},zIndex:35};popoverRef=(0,t.useRef)(`popover`);currentPosition=void 0;currentDisplayValue=void 0;spreadsheetRect=pM();containerRect;setup(){this.containerRect=hM(),(0,t.useEffect)(()=>{if(!this.containerRect)throw Error(`Popover container is not defined`);let e=this.popoverRef.el,t=vM(this.props.anchorRect,this.containerRect),n=t?`block`:`none`;if(this.currentDisplayValue!==`none`&&n===`none`&&this.props.onPopoverHidden?.(),e.style.display=n,this.currentDisplayValue=n,!t)return;let r={width:this.props.maxWidth,height:this.props.maxHeight},i={width:e.getBoundingClientRect().width,height:e.getBoundingClientRect().height},a=this.spreadsheetRect,o=this.props.positioning===`bottom-left`?new wM(t,this.containerRect,r,a):new TM(t,this.containerRect,r,a);e.style[`max-height`]=o.getMaxHeight(i.height)+`px`,e.style[`max-width`]=o.getMaxWidth(i.width)+`px`,i={width:e.getBoundingClientRect().width,height:e.getBoundingClientRect().height};let s=o.getCss(i,this.props.verticalOffset);for(let t of Object.keys(s))e.style[t]=s[t];let c=o.getCurrentPosition(i);this.currentPosition&&c!==this.currentPosition&&this.props.onPopoverMoved?.(),this.currentPosition=c})}get popoverStyle(){return U({"z-index":`${this.props.zIndex}`})}},CM=class{constructor(e,t,n,r){this.anchorRect=e,this.containerRect=t,this.propsMaxSize=n,this.spreadsheetOffset=r}shouldRenderAtBottom(e){return e<=this.availableHeightDown||this.availableHeightDown>=this.availableHeightUp}shouldRenderAtRight(e){return e<=this.availableWidthRight||this.availableWidthRight>=this.availableWidthLeft}getMaxHeight(e){let t=this.shouldRenderAtBottom(e)?this.availableHeightDown:this.availableHeightUp;return this.propsMaxSize.height?Math.min(t,this.propsMaxSize.height):t}getMaxWidth(e){let t=this.shouldRenderAtRight(e)?this.availableWidthRight:this.availableWidthLeft;return this.propsMaxSize.width?Math.min(t,this.propsMaxSize.width):t}getCss(e,t){let n=this.getMaxHeight(e.height),r=this.getMaxWidth(e.width),i=Math.min(n,e.height),a=Math.min(r,e.width),o=this.shouldRenderAtBottom(e.height),s=this.shouldRenderAtRight(e.width);return t=o?t:-t,{top:this.getTopCoordinate(i,o)-this.spreadsheetOffset.y-t+`px`,left:this.getLeftCoordinate(a,s)-this.spreadsheetOffset.x+`px`}}getCurrentPosition(e){let t=this.shouldRenderAtBottom(e.height),n=this.shouldRenderAtRight(e.width);return t&&n?`bottom-right`:t&&!n?`bottom-left`:!t&&n?`top-right`:`top-left`}},wM=class extends CM{get availableHeightUp(){return this.anchorRect.y-this.containerRect.y}get availableHeightDown(){return this.containerRect.height-this.availableHeightUp-this.anchorRect.height}get availableWidthRight(){return this.containerRect.x+this.containerRect.width-this.anchorRect.x}get availableWidthLeft(){return this.anchorRect.x+this.anchorRect.width-this.containerRect.x}getTopCoordinate(e,t){return t?this.anchorRect.y+this.anchorRect.height:this.anchorRect.y-e}getLeftCoordinate(e,t){return t?this.anchorRect.x:this.anchorRect.x+this.anchorRect.width-e}},TM=class extends CM{get availableHeightUp(){return this.anchorRect.y+this.anchorRect.height-this.containerRect.y}get availableHeightDown(){return this.containerRect.y+this.containerRect.height-this.anchorRect.y}get availableWidthRight(){return this.containerRect.width-this.anchorRect.width-this.availableWidthLeft}get availableWidthLeft(){return this.anchorRect.x-this.containerRect.x}getTopCoordinate(e,t){return t?this.anchorRect.y:this.anchorRect.y+this.anchorRect.height-e}getLeftCoordinate(e,t){return t?this.anchorRect.x+this.anchorRect.width:this.anchorRect.x-e}};H`
|
|
261
|
+
`;var SM=class extends t.Component{static template=`o-spreadsheet-Popover`;static props={anchorRect:Object,containerRect:{type:Object,optional:!0},positioning:{type:String,optional:!0},maxWidth:{type:Number,optional:!0},maxHeight:{type:Number,optional:!0},verticalOffset:{type:Number,optional:!0},onMouseWheel:{type:Function,optional:!0},onPopoverHidden:{type:Function,optional:!0},onPopoverMoved:{type:Function,optional:!0},zIndex:{type:Number,optional:!0},class:{type:String,optional:!0},slots:Object};static defaultProps={positioning:`bottom-left`,verticalOffset:0,onMouseWheel:()=>{},onPopoverMoved:()=>{},onPopoverHidden:()=>{},zIndex:35};popoverRef=(0,t.useRef)(`popover`);currentPosition=void 0;currentDisplayValue=void 0;spreadsheetRect=pM();containerRect;setup(){this.containerRect=hM(),(0,t.useEffect)(()=>{if(!this.containerRect)throw Error(`Popover container is not defined`);let e=this.popoverRef.el,t=vM(this.props.anchorRect,this.containerRect),n=t?`block`:`none`;if(this.currentDisplayValue!==`none`&&n===`none`&&this.props.onPopoverHidden?.(),e.style.display=n,this.currentDisplayValue=n,!t)return;let r={width:this.props.maxWidth,height:this.props.maxHeight},i={width:e.getBoundingClientRect().width,height:e.getBoundingClientRect().height},a=this.spreadsheetRect,o=this.props.positioning===`bottom-left`?new wM(t,this.containerRect,r,a):new TM(t,this.containerRect,r,a);e.style[`max-height`]=o.getMaxHeight(i.height)+`px`,e.style[`max-width`]=o.getMaxWidth(i.width)+`px`,i={width:e.getBoundingClientRect().width,height:e.getBoundingClientRect().height};let s=o.getCss(i,this.props.verticalOffset);for(let t of Object.keys(s))e.style[t]=s[t];let c=o.getCurrentPosition(i);this.currentPosition&&c!==this.currentPosition&&this.props.onPopoverMoved?.(),this.currentPosition=c})}get popoverStyle(){return U({"z-index":`${this.props.zIndex}`})}},CM=class{anchorRect;containerRect;propsMaxSize;spreadsheetOffset;constructor(e,t,n,r){this.anchorRect=e,this.containerRect=t,this.propsMaxSize=n,this.spreadsheetOffset=r}shouldRenderAtBottom(e){return e<=this.availableHeightDown||this.availableHeightDown>=this.availableHeightUp}shouldRenderAtRight(e){return e<=this.availableWidthRight||this.availableWidthRight>=this.availableWidthLeft}getMaxHeight(e){let t=this.shouldRenderAtBottom(e)?this.availableHeightDown:this.availableHeightUp;return this.propsMaxSize.height?Math.min(t,this.propsMaxSize.height):t}getMaxWidth(e){let t=this.shouldRenderAtRight(e)?this.availableWidthRight:this.availableWidthLeft;return this.propsMaxSize.width?Math.min(t,this.propsMaxSize.width):t}getCss(e,t){let n=this.getMaxHeight(e.height),r=this.getMaxWidth(e.width),i=Math.min(n,e.height),a=Math.min(r,e.width),o=this.shouldRenderAtBottom(e.height),s=this.shouldRenderAtRight(e.width);return t=o?t:-t,{top:this.getTopCoordinate(i,o)-this.spreadsheetOffset.y-t+`px`,left:this.getLeftCoordinate(a,s)-this.spreadsheetOffset.x+`px`}}getCurrentPosition(e){let t=this.shouldRenderAtBottom(e.height),n=this.shouldRenderAtRight(e.width);return t&&n?`bottom-right`:t&&!n?`bottom-left`:!t&&n?`top-right`:`top-left`}},wM=class extends CM{get availableHeightUp(){return this.anchorRect.y-this.containerRect.y}get availableHeightDown(){return this.containerRect.height-this.availableHeightUp-this.anchorRect.height}get availableWidthRight(){return this.containerRect.x+this.containerRect.width-this.anchorRect.x}get availableWidthLeft(){return this.anchorRect.x+this.anchorRect.width-this.containerRect.x}getTopCoordinate(e,t){return t?this.anchorRect.y+this.anchorRect.height:this.anchorRect.y-e}getLeftCoordinate(e,t){return t?this.anchorRect.x:this.anchorRect.x+this.anchorRect.width-e}},TM=class extends CM{get availableHeightUp(){return this.anchorRect.y+this.anchorRect.height-this.containerRect.y}get availableHeightDown(){return this.containerRect.y+this.containerRect.height-this.anchorRect.y}get availableWidthRight(){return this.containerRect.width-this.anchorRect.width-this.availableWidthLeft}get availableWidthLeft(){return this.anchorRect.x-this.containerRect.x}getTopCoordinate(e,t){return t?this.anchorRect.y:this.anchorRect.y+this.anchorRect.height-e}getLeftCoordinate(e,t){return t?this.anchorRect.x+this.anchorRect.width:this.anchorRect.x-e}};H`
|
|
262
262
|
.o-menu {
|
|
263
263
|
background-color: white;
|
|
264
264
|
padding: ${6}px 0px;
|
|
@@ -348,7 +348,7 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
348
348
|
}
|
|
349
349
|
}
|
|
350
350
|
}
|
|
351
|
-
`;var DM=class extends t.Component{static template=`o-spreadsheet-LinkEditor`;static props={cellPosition:Object,onClosed:{type:Function,optional:!0}};static components={Menu:EM};menuItems=fM.getMenuItems();link=(0,t.useState)(this.defaultState);menu=(0,t.useState)({isOpen:!1});linkEditorMenuButtonRef=(0,t.useRef)(`linkEditorMenuButton`);menuButtonRect=mM(this.linkEditorMenuButtonRef);urlInput=(0,t.useRef)(`urlInput`);setup(){(0,t.onMounted)(()=>this.urlInput.el?.focus())}get defaultState(){let{col:e,row:t}=this.props.cellPosition,n=this.env.model.getters.getActiveSheetId(),r=this.env.model.getters.getEvaluatedCell({sheetId:n,col:e,row:t});return r.link?{url:r.link.url,label:r.formattedValue,isUrlEditable:r.link.isUrlEditable}:{label:r.formattedValue,url:``,isUrlEditable:!0}}onSpecialLink(e){let{detail:t}=e,n=xo(t);n&&(this.link.url=n.url,this.link.label=n.label,this.link.isUrlEditable=n.isUrlEditable)}getUrlRepresentation(e){return yo(e,this.env.model.getters)}openMenu(){this.menu.isOpen=!0}removeLink(){this.link.url=``,this.link.isUrlEditable=!0}save(){let{col:e,row:t}=this.props.cellPosition,n=this.env.model.getters.getLocale(),r=this.link.label?Ll(this.link.label,n):this.link.url;this.env.model.dispatch(`UPDATE_CELL`,{col:e,row:t,sheetId:this.env.model.getters.getActiveSheetId(),content:vt(r,this.link.url)}),this.props.onClosed?.()}cancel(){this.props.onClosed?.()}onKeyDown(e){switch(e.key){case`Enter`:this.link.url&&this.save(),e.stopPropagation(),e.preventDefault();break;case`Escape`:this.cancel(),e.stopPropagation();break}}};BC.add(`ErrorToolTip`,Jj).add(`LinkCell`,rM).add(`LinkEditor`,{onOpen:(e,t)=>({isOpen:!0,props:{cellPosition:e},Component:DM,cellCorner:`bottom-left`})}).add(`FilterMenu`,$j);function OM(e,t,n=OA){let r=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,r);r.length===1&&!i&&Nr(r[0])===1&&(e.model.selection.selectTableAroundSelection(),r=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,r));let a=r.map(n=>e.model.getters.getRangeDataFromZone(t,n)),o=e.model.dispatch(`CREATE_TABLE`,{ranges:a,sheetId:t,config:n,tableType:i?`dynamic`:`static`});return o.isCancelledBecause(`TableOverlap`)?e.raiseError(gw.Errors.TableOverlap):o.isCancelledBecause(`NonContinuousTargets`)&&e.raiseError(gw.Errors.NonContinuousTargets),o}function kM(e,t){e.model.dispatch(`SET_FORMATTING_WITH_PIVOT`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),format:t})}function AM(e,t){e.model.dispatch(`SET_FORMATTING`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),style:t})}let jM=async e=>NM(e),MM=async e=>NM(e,`asValue`);async function NM(e,t){let n=await e.clipboard.read();switch(n.status){case`ok`:let r=e.model.getters.getClipboardId(),i=ul(n.content),a=i.data?.clipboardId,o=e.model.getters.getSelectedZones();r===a?Gj(e,o,t):await Kj(e,o,i,t),e.model.getters.isCutOperation()&&t!==`asValue`&&await e.clipboard.write({"text/plain":``});break;case`notImplemented`:e.raiseError(O(`Pasting from the context menu is not supported in this browser. Use keyboard shortcuts ctrl+c / ctrl+v instead.`));break;case`permissionDenied`:e.raiseError(O(`Access to the clipboard denied by the browser. Please enable clipboard permission for this page in your browser settings.`));break}}let PM=e=>NM(e,`onlyFormat`),FM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Clear rows`);let t,n,r=e.model.getters.getActiveRows();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.top,n=r.bottom}return t===n?O(`Clear row %s`,(t+1).toString()):O(`Clear rows %s - %s`,(t+1).toString(),(n+1).toString())},IM=e=>{let t=e.model.getters.getActiveSheetId(),n=[...e.model.getters.getActiveRows()].map(n=>e.model.getters.getRowsZone(t,n,n));e.model.dispatch(`DELETE_CONTENT`,{target:n,sheetId:e.model.getters.getActiveSheetId()})},LM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Clear columns`);let t,n,r=e.model.getters.getActiveCols();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.left,n=r.right}return t===n?O(`Clear column %s`,zn(t)):O(`Clear columns %s - %s`,zn(t),zn(n))},RM=e=>{let t=e.model.getters.getActiveSheetId(),n=[...e.model.getters.getActiveCols()].map(n=>e.model.getters.getColsZone(t,n,n));e.model.dispatch(`DELETE_CONTENT`,{target:n,sheetId:e.model.getters.getActiveSheetId()})},zM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Delete rows`);let t,n,r=e.model.getters.getActiveRows();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.top,n=r.bottom}return t===n?O(`Delete row %s`,(t+1).toString()):O(`Delete rows %s - %s`,(t+1).toString(),(n+1).toString())},BM=e=>{let t=[...e.model.getters.getActiveRows()];if(!t.length){let n=e.model.getters.getSelectedZones()[0];for(let e=n.top;e<=n.bottom;e++)t.push(e)}e.model.dispatch(`REMOVE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),dimension:`ROW`,elements:t})},VM=(e,t)=>{if(e===`COL`&&t.model.getters.getActiveRows().size>0||e===`ROW`&&t.model.getters.getActiveCols().size>0)return!1;let n=t.model.getters.getActiveSheetId(),r=t.model.getters.getElementsFromSelection(e),i=t.model.getters.checkElementsIncludeAllVisibleHeaders(n,e,r),a=t.model.getters.checkElementsIncludeAllNonFrozenHeaders(n,e,r);return!i&&!a},HM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Delete columns`);let t,n,r=e.model.getters.getActiveCols();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.left,n=r.right}return t===n?O(`Delete column %s`,zn(t)):O(`Delete columns %s - %s`,zn(t),zn(n))},UM=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getElementsFromSelection(`ROW`);return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,`ROW`,n)},WM=e=>{let t=[...e.model.getters.getActiveCols()];if(!t.length){let n=e.model.getters.getSelectedZones()[0];for(let e=n.left;e<=n.right;e++)t.push(e)}e.model.dispatch(`REMOVE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),dimension:`COL`,elements:t})},GM=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getElementsFromSelection(`COL`);return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,`COL`,n)},KM=e=>{let t=e.model.getters.getActiveRows(),n,r;if(t.size)n=Yt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.top,r=t.bottom-t.top+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`before`,base:n,quantity:r,dimension:`ROW`})},qM=e=>{let t=e.model.getters.getActiveRows(),n,r;if(t.size)n=Jt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.bottom,r=t.bottom-t.top+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`after`,base:n,quantity:r,dimension:`ROW`})},JM=e=>{let t=e.model.getters.getActiveCols(),n,r;if(t.size)n=Yt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.left,r=t.right-t.left+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`before`,dimension:`COL`,base:n,quantity:r})},YM=e=>{let t=e.model.getters.getActiveCols(),n,r;if(t.size)n=Jt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.right,r=t.right-t.left+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`after`,dimension:`COL`,base:n,quantity:r})},XM=e=>{let t=e.model.getters.getElementsFromSelection(`COL`),n=t[0],r=t[t.length-1];return t.length===1?O(`Hide column %s`,zn(n).toString()):r-n+1===t.length?O(`Hide columns %s - %s`,zn(n).toString(),zn(r).toString()):O(`Hide columns`)},ZM=e=>{let t=e.model.getters.getElementsFromSelection(`ROW`),n=t[0],r=t[t.length-1];return t.length===1?O(`Hide row %s`,(n+1).toString()):r-n+1===t.length?O(`Hide rows %s - %s`,(n+1).toString(),(r+1).toString()):O(`Hide rows`)},QM=e=>{let t=e.model.getters,n=e.model.uuidGenerator.smallUuid(),r=t.getActiveSheetId();Nr(e.model.getters.getSelectedZone())===1&&e.model.selection.selectTableAroundSelection();let i={width:536,height:335},{col:a,row:o,offset:s}=hD(t,i);e.model.dispatch(`CREATE_CHART`,{sheetId:r,figureId:n,col:a,row:o,offset:s,size:i,definition:fD(e.model.getters.getSelectedZone(),e.model.getters)}).isSuccessful&&(e.model.dispatch(`SELECT_FIGURE`,{figureId:n}),e.openSidePanel(`ChartPanel`))},$M=e=>{let t=e.model.uuidGenerator.smallUuid(),n=e.model.uuidGenerator.smallUuid();e.model.dispatch(`INSERT_NEW_PIVOT`,{pivotId:t,newSheetId:n}).isSuccessful&&e.openSidePanel(`PivotSidePanel`,{pivotId:t})},eN=e=>e.model.getters.getPivotIds().map((t,n)=>({id:`reinsert_dynamic_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:n,execute:e=>{let n=e.model.getters.getSelectedZone(),r=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch(`INSERT_PIVOT_WITH_TABLE`,{pivotId:t,table:r,col:n.left,row:n.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:`dynamic`}),e.model.dispatch(`REFRESH_PIVOT`,{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()})),tN=e=>e.model.getters.getPivotIds().map((t,n)=>({id:`reinsert_static_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:n,execute:e=>{let n=e.model.getters.getSelectedZone(),r=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch(`INSERT_PIVOT_WITH_TABLE`,{pivotId:t,table:r,col:n.left,row:n.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:`static`}),e.model.dispatch(`REFRESH_PIVOT`,{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()}));async function nN(e){try{return await e.imageProvider.requestImage()}catch{e.raiseError(O(`An unexpected error occurred during the image transfer`));return}}let rN=async e=>{if(e.imageProvider){let t=e.model.getters.getActiveSheetId(),n=e.model.uuidGenerator.smallUuid(),r=await nN(e);if(!r)return;let i=gD(e.model.getters,r.size),{col:a,row:o,offset:s}=hD(e.model.getters,i);e.model.dispatch(`CREATE_IMAGE`,{sheetId:t,figureId:n,col:a,row:o,offset:s,size:i,definition:r})}},iN=e=>kM(e,`0.00%`),aN=e=>{e.openSidePanel(`ConditionalFormatting`,{selection:e.model.getters.getSelectedZones()})},oN=e=>{let{col:t,row:n}=e.model.getters.getActivePosition();e.getStore(tM).open({col:t,row:n},`LinkEditor`)},sN=e=>{let t=e.model.getters.getActiveSheetId(),{col:n,row:r}=e.model.getters.getActivePosition(),i=e.model.getters.getEvaluatedCell({sheetId:t,col:n,row:r});return i&&i.link?O(`Edit link`):O(`Insert link`)},cN=e=>e.model.getters.getFirstTableInSelection()?.config.hasFilters||!1,lN=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSelectedZones();return e.model.getters.getTablesOverlappingZones(t,n).length===1},uN=e=>Fr(e.model.getters.getSelectedZones()),dN=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getFirstTableInSelection();n?e.model.dispatch(`UPDATE_TABLE`,{sheetId:t,zone:n.range.zone,config:{hasFilters:!0}}):OM(e,t,{...OA,hasFilters:!0,bandedRows:!1,styleId:`TableStyleLight11`})},fN=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getFirstTableInSelection();n&&e.model.dispatch(`UPDATE_TABLE`,{sheetId:t,zone:n.range.zone,config:{hasFilters:!1}})},pN=e=>{OM(e,e.model.getters.getActiveSheetId()).isSuccessful&&e.openSidePanel(`TableSidePanel`,{})},mN=e=>{let t=e.model.getters.getActivePosition(),n=e.model.getters.getTable(t);n&&e.model.dispatch(`REMOVE_TABLE`,{sheetId:t.sheetId,target:[n.range.zone]})},hN=e=>e.model.getters.getSelectedZones().length===1,gN=(e,t)=>{if(!hN(e))return!1;let n=t===`COL`?e.model.getters.getActiveCols():e.model.getters.getActiveRows(),r=t===`COL`?e.model.getters.getActiveRows():e.model.getters.getActiveCols(),i=e.model.getters.getActiveSheetId(),a=gr(e.model.getters.getSelectedZone(),e.model.getters.getSheetZone(i));return Bt(n)&&(r.size===0||a)},_N={name:e=>cN(e)?O(`Remove selected filters`):O(`Add filters`),isEnabled:e=>uN(e),execute:e=>cN(e)?fN(e):dN(e),icon:`o-spreadsheet-Icon.FILTER_ICON_ACTIVE`},vN={name:O(`Undo`),description:`Ctrl+Z`,execute:e=>e.model.dispatch(`REQUEST_UNDO`),isEnabled:e=>e.model.getters.canUndo(),icon:`o-spreadsheet-Icon.UNDO`},yN={name:O(`Redo`),description:`Ctrl+Y`,execute:e=>e.model.dispatch(`REQUEST_REDO`),isEnabled:e=>e.model.getters.canRedo(),icon:`o-spreadsheet-Icon.REDO`},bN={name:O(`Copy`),description:`Ctrl+C`,isReadonlyAllowed:!0,execute:async e=>{e.model.dispatch(`COPY`),await e.clipboard.write(await e.model.getters.getClipboardTextAndImageContent())},icon:`o-spreadsheet-Icon.CLIPBOARD`},xN={name:O(`Cut`),description:`Ctrl+X`,execute:async e=>{QD(e),await e.clipboard.write(await e.model.getters.getClipboardTextAndImageContent())},icon:`o-spreadsheet-Icon.CUT`},SN={name:O(`Paste`),description:`Ctrl+V`,execute:jM,icon:`o-spreadsheet-Icon.PASTE`},CN={name:O(`Paste special`),isVisible:e=>!e.model.getters.isCutOperation(),icon:`o-spreadsheet-Icon.PASTE`},wN={name:O(`Paste as value`),description:`Ctrl+Shift+V`,execute:MM},TN={name:O(`Paste format only`),execute:PM},EN={name:O(`Find and replace`),description:`Ctrl+H`,isReadonlyAllowed:!0,execute:e=>{e.openSidePanel(`FindAndReplace`,{})},icon:`o-spreadsheet-Icon.SEARCH`},DN={name:O(`Delete values`),execute:e=>e.model.dispatch(`DELETE_UNFILTERED_CONTENT`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()})},ON={name:zM,execute:BM,isVisible:e=>VM(`ROW`,e)},kN={...ON,isVisible:hN},AN={name:FM,execute:IM},jN={name:HM,execute:WM,isVisible:e=>VM(`COL`,e)},MN={...jN,isVisible:hN},NN={name:LM,execute:RM},PN={name:O(`Delete cells`),isVisible:hN},FN={name:O(`Delete cell and shift up`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`DELETE_CELL`,{zone:t,shiftDimension:`ROW`}))}},IN={name:O(`Delete cell and shift left`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`DELETE_CELL`,{zone:t,shiftDimension:`COL`}))}},LN={name:O(`Merge cells`),isEnabled:e=>!BN(e),isActive:e=>VN(e),execute:e=>HN(e),icon:`o-spreadsheet-Icon.MERGE_CELL`},RN={name:()=>O(`Edit table`),execute:e=>e.openSidePanel(`TableSidePanel`,{}),icon:`o-spreadsheet-Icon.EDIT_TABLE`},zN={name:()=>O(`Delete table`),execute:mN,icon:`o-spreadsheet-Icon.DELETE_TABLE`};function BN(e){let t=e.model.getters.getSelectedZones(),{top:n,left:r,right:i,bottom:a}=e.model.getters.getSelectedZone(),{sheetId:o}=e.model.getters.getActivePosition(),{xSplit:s,ySplit:c}=e.model.getters.getPaneDivisions(o);return t.length>1||n===a&&r===i||r<s&&s<=i||n<c&&c<=a}function VN(e){if(!BN(e)){let t=e.model.getters.getSelectedZones(),{col:n,row:r,sheetId:i}=e.model.getters.getActivePosition(),a=e.model.getters.expandZone(i,E({col:n,row:r}));return gr(t[0],a)}return!1}function HN(e){if(BN(e))return;let t=e.model.getters.getSelectedZones(),n=[t[t.length-1]],r=e.model.getters.getActiveSheetId();VN(e)?e.model.dispatch(`REMOVE_MERGE`,{sheetId:r,target:n}):eO(e,r,n)}let UN={name:e=>{let t=SP(e);return t===1?O(`Insert row`):O(`Insert %s rows`,t.toString())},isVisible:e=>gN(e,`ROW`),icon:`o-spreadsheet-Icon.INSERT_ROW`},WN={name:e=>{let t=SP(e);return t===1?O(`Insert row above`):O(`Insert %s rows above`,t.toString())},execute:KM,isVisible:e=>gN(e,`ROW`),icon:`o-spreadsheet-Icon.INSERT_ROW_BEFORE`},GN={...WN,name:e=>{let t=SP(e);return t===1?O(`Row above`):O(`%s Rows above`,t.toString())}},KN={...WN,name:e=>{let t=SP(e);return t===1?O(`Insert row`):O(`Insert %s rows`,t.toString())},isVisible:hN,icon:`o-spreadsheet-Icon.INSERT_ROW_BEFORE`},qN={execute:qM,name:e=>{let t=SP(e);return t===1?O(`Insert row below`):O(`Insert %s rows below`,t.toString())},isVisible:e=>gN(e,`ROW`),icon:`o-spreadsheet-Icon.INSERT_ROW_AFTER`},JN={...qN,name:e=>{let t=SP(e);return t===1?O(`Row below`):O(`%s Rows below`,t.toString())}},YN={name:e=>{let t=CP(e);return t===1?O(`Insert column`):O(`Insert %s columns`,t.toString())},isVisible:e=>gN(e,`COL`),icon:`o-spreadsheet-Icon.INSERT_COL`},XN={name:e=>{let t=CP(e);return t===1?O(`Insert column left`):O(`Insert %s columns left`,t.toString())},execute:JM,isVisible:e=>gN(e,`COL`),icon:`o-spreadsheet-Icon.INSERT_COL_BEFORE`},ZN={...XN,name:e=>{let t=CP(e);return t===1?O(`Column left`):O(`%s Columns left`,t.toString())}},QN={...XN,name:e=>{let t=CP(e);return t===1?O(`Insert column`):O(`Insert %s columns`,t.toString())},isVisible:hN,icon:`o-spreadsheet-Icon.INSERT_COL_BEFORE`},$N={name:e=>{let t=CP(e);return t===1?O(`Insert column right`):O(`Insert %s columns right`,t.toString())},execute:YM,isVisible:e=>gN(e,`COL`),icon:`o-spreadsheet-Icon.INSERT_COL_AFTER`},eP={...$N,name:e=>{let t=CP(e);return t===1?O(`Column right`):O(`%s Columns right`,t.toString())},execute:YM},tP={name:O(`Insert cells`),isVisible:e=>hN(e)&&e.model.getters.getActiveCols().size===0&&e.model.getters.getActiveRows().size===0,icon:`o-spreadsheet-Icon.INSERT_CELL`},nP={name:O(`Insert cells and shift down`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`INSERT_CELL`,{zone:t,shiftDimension:`ROW`}))},isVisible:e=>e.model.getters.getActiveRows().size===0&&e.model.getters.getActiveCols().size===0,icon:`o-spreadsheet-Icon.INSERT_CELL_SHIFT_DOWN`},rP={name:O(`Insert cells and shift right`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`INSERT_CELL`,{zone:t,shiftDimension:`COL`}))},isVisible:e=>e.model.getters.getActiveRows().size===0&&e.model.getters.getActiveCols().size===0,icon:`o-spreadsheet-Icon.INSERT_CELL_SHIFT_RIGHT`},iP={name:O(`Chart`),execute:QM,icon:`o-spreadsheet-Icon.INSERT_CHART`},aP={name:O(`Pivot table`),execute:$M,icon:`o-spreadsheet-Icon.PIVOT`},oP={name:O(`Image`),description:`Ctrl+O`,execute:rN,isVisible:e=>e.imageProvider!==void 0,icon:`o-spreadsheet-Icon.INSERT_IMAGE`},sP={name:()=>O(`Table`),execute:pN,isVisible:e=>uN(e)&&!e.model.getters.getFirstTableInSelection(),icon:`o-spreadsheet-Icon.PAINT_TABLE`},cP={name:O(`Function`),icon:`o-spreadsheet-Icon.FORMULA`},lP={name:O(`SUM`),execute:e=>e.startCellEdition(`=SUM(`)},uP={name:O(`AVERAGE`),execute:e=>e.startCellEdition(`=AVERAGE(`)},dP={name:O(`COUNT`),execute:e=>e.startCellEdition(`=COUNT(`)},fP={name:O(`MAX`),execute:e=>e.startCellEdition(`=MAX(`)},pP={name:O(`MIN`),execute:e=>e.startCellEdition(`=MIN(`)},mP={name:O(`All`),children:[hP]};function hP(){return xP(ix.getKeys().filter(e=>!ix.get(e).hidden))}let gP=()=>{let e=ix.content;return[...new Set(ix.getAll().filter(e=>!e.hidden).map(e=>e.category))].filter(C).sort().map((t,n)=>({name:t,children:xP(Object.keys(e).filter(n=>e[n].category===t&&!e[n].hidden))}))},_P={name:O(`Link`),execute:oN,icon:`o-spreadsheet-Icon.INSERT_LINK`},vP={name:O(`Checkbox`),execute:e=>{let t=e.model.getters.getSelectedZones(),n=e.model.getters.getActiveSheetId(),r=t.map(t=>e.model.getters.getRangeDataFromZone(n,t));e.model.dispatch(`ADD_DATA_VALIDATION_RULE`,{ranges:r,sheetId:n,rule:{id:e.model.uuidGenerator.smallUuid(),criterion:{type:`isBoolean`,values:[]}}})},icon:`o-spreadsheet-Icon.INSERT_CHECKBOX`},yP={name:O(`Dropdown list`),execute:e=>{let t=e.model.getters.getSelectedZones(),n=e.model.getters.getActiveSheetId(),r=t.map(t=>e.model.getters.getRangeDataFromZone(n,t)),i=e.model.uuidGenerator.smallUuid();e.model.dispatch(`ADD_DATA_VALIDATION_RULE`,{ranges:r,sheetId:n,rule:{id:i,criterion:{type:`isValueInList`,values:[],displayStyle:`arrow`}}});let a=e.model.getters.getDataValidationRule(n,i);a&&e.openSidePanel(`DataValidationEditor`,{rule:Xl(a,e.model.getters.getLocale()),onExit:()=>{e.openSidePanel(`DataValidation`)}})},icon:`o-spreadsheet-Icon.INSERT_DROPDOWN`},bP={name:O(`Insert sheet`),execute:e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSheetIds().indexOf(t)+1,r=e.model.uuidGenerator.smallUuid();e.model.dispatch(`CREATE_SHEET`,{sheetId:r,position:n,name:e.model.getters.getNextSheetName()}),e.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:t,sheetIdTo:r})},icon:`o-spreadsheet-Icon.INSERT_SHEET`};function xP(e){return e.sort().map((e,t)=>({name:e,sequence:t*10,execute:t=>t.startCellEdition(`=${e}(`)}))}function SP(e){let t=e.model.getters.getActiveRows();if(t.size)return t.size;{let t=e.model.getters.getSelectedZones()[0];return t.bottom-t.top+1}}function CP(e){let t=e.model.getters.getActiveCols();if(t.size)return t.size;{let t=e.model.getters.getSelectedZones()[0];return t.right-t.left+1}}let wP={name:O(`See pivot properties`),execute(e){let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);e.openSidePanel(`PivotSidePanel`,{pivotId:n})},isVisible:e=>{let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);return n&&e.model.getters.isExistingPivot(n)||!1},isReadonlyAllowed:!0,icon:`o-spreadsheet-Icon.PIVOT`},TP={name:O(`Ascending`),execute:e=>AP(e,`asc`),isActive:e=>jP(e,`asc`)},EP={name:O(`Descending`),execute:e=>AP(e,`desc`),isActive:e=>jP(e,`desc`)},DP={name:O(`No sorting`),execute:e=>AP(e,`none`),isActive:e=>jP(e,`none`)},OP={name:O(`Convert to individual formulas`),execute(e){let t=e.model.getters.getActivePosition(),n=e.model.getters.getCorrespondingFormulaCell(t),r=e.model.getters.getPivotIdFromPosition(t);if(!n||!r)return;let{sheetId:i,col:a,row:o}=e.model.getters.getCellPosition(n.id),s=e.model.getters.getPivot(r);s.init(),s.isValid()&&e.model.dispatch(`SPLIT_PIVOT_FORMULA`,{sheetId:i,col:a,row:o,pivotId:r})},isVisible:e=>{let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);if(!n)return!1;let r=e.model.getters.getPivot(n),i=e.model.getters.getEvaluatedCell(t);return r.isValid()&&e.model.getters.isSpillPivotFormula(t)&&i.type!==`error`},icon:`o-spreadsheet-Icon.PIVOT`};function kP(e){let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);if(!n||!e.model.getters.isExistingPivot(n)||!e.model.getters.isSpillPivotFormula(t)||!e.model.getters.getPivot(n).isValid())return!1;let r=e.model.getters.getPivotCellFromPosition(t);return r.type===`VALUE`||r.type===`MEASURE_HEADER`}function AP(e,t){let n=e.model.getters.getActivePosition(),r=e.model.getters.getPivotIdFromPosition(n),i=e.model.getters.getPivotCellFromPosition(n);if(i.type===`EMPTY`||i.type===`HEADER`||!r)return;if(t===`none`){e.model.dispatch(`UPDATE_PIVOT`,{pivotId:r,pivot:{...e.model.getters.getPivotCoreDefinition(r),sortedColumn:void 0}});return}let a=ju(e.model.getters.getPivot(r),i.domain).colDomain;e.model.dispatch(`UPDATE_PIVOT`,{pivotId:r,pivot:{...e.model.getters.getPivotCoreDefinition(r),sortedColumn:{domain:a,order:t,measure:i.measure}}})}function jP(e,t){let n=e.model.getters.getActivePosition(),r=e.model.getters.getPivotIdFromPosition(n),i=e.model.getters.getPivotCellFromPosition(n);if(i.type===`EMPTY`||i.type===`HEADER`||!r)return!1;let a=e.model.getters.getPivot(r),o=ju(a,i.domain).colDomain,s=a.definition.sortedColumn;return t===`none`?!s:!s||s.order!==t?!1:s.measure===i.measure&&w(s.domain,o)}let MP=new ZD;MP.add(`cut`,{...xN,sequence:10}).add(`copy`,{...bN,sequence:20}).add(`paste`,{...SN,sequence:30}).add(`paste_special`,{...CN,sequence:40,separator:!0}).addChild(`paste_value_only`,[`paste_special`],{...wN,sequence:10}).addChild(`paste_format_only`,[`paste_special`],{...TN,sequence:20}).add(`add_row_before`,{...KN,sequence:70}).add(`add_column_before`,{...QN,sequence:90}).add(`insert_cell`,{...tP,sequence:100,separator:!0}).addChild(`insert_cell_down`,[`insert_cell`],{...nP,name:O(`Shift down`),sequence:10}).addChild(`insert_cell_right`,[`insert_cell`],{...rP,name:O(`Shift right`),sequence:20}).add(`delete_row`,{...kN,sequence:110,icon:`o-spreadsheet-Icon.TRASH`}).add(`delete_column`,{...MN,sequence:120,icon:`o-spreadsheet-Icon.TRASH`}).add(`delete_cell`,{...PN,sequence:130,separator:!0,icon:`o-spreadsheet-Icon.TRASH`}).addChild(`delete_cell_up`,[`delete_cell`],{...FN,name:O(`Shift up`),sequence:10,icon:`o-spreadsheet-Icon.DELETE_CELL_SHIFT_UP`}).addChild(`delete_cell_left`,[`delete_cell`],{...IN,name:O(`Shift left`),sequence:20,icon:`o-spreadsheet-Icon.DELETE_CELL_SHIFT_LEFT`}).add(`edit_table`,{...RN,isVisible:lN,sequence:140}).add(`delete_table`,{...zN,isVisible:lN,sequence:145,separator:!0}).add(`insert_link`,{..._P,name:sN,sequence:150,separator:!0}).add(`pivot_sorting`,{name:O(`Sort pivot`),sequence:155,icon:`o-spreadsheet-Icon.SORT_RANGE`,isVisible:kP}).add(`pivot_fix_formulas`,{...OP,sequence:160}).add(`pivot_properties`,{...wP,sequence:170,separator:!0}).addChild(`pivot_sorting_asc`,[`pivot_sorting`],{...TP,sequence:10}).addChild(`pivot_sorting_desc`,[`pivot_sorting`],{...EP,sequence:20}).addChild(`pivot_sorting_none`,[`pivot_sorting`],{...DP,sequence:30});let NP={name:O(`Sort range`),isVisible:hN,icon:`o-spreadsheet-Icon.SORT_RANGE`},PP={name:O(`Ascending (A ⟶ Z)`),execute:e=>{let{anchor:t,zones:n}=e.model.getters.getSelection();Eg(e,e.model.getters.getActiveSheetId(),t.cell,n[0],`asc`)},icon:`o-spreadsheet-Icon.SORT_ASCENDING`},FP={name:O(`Data cleanup`),icon:`o-spreadsheet-Icon.DATA_CLEANUP`},IP={name:O(`Remove duplicates`),execute:e=>{Nr(e.model.getters.getSelectedZone())===1&&e.model.selection.selectTableAroundSelection(),e.openSidePanel(`RemoveDuplicates`,{})}},LP={name:O(`Trim whitespace`),execute:e=>{e.model.dispatch(`TRIM_WHITESPACE`)}},RP={name:O(`Descending (Z ⟶ A)`),execute:e=>{let{anchor:t,zones:n}=e.model.getters.getSelection();Eg(e,e.model.getters.getActiveSheetId(),t.cell,n[0],`desc`)},icon:`o-spreadsheet-Icon.SORT_DESCENDING`},zP={..._N},BP={..._N,isActive:e=>cN(e)},VP={name:O(`Split text to columns`),sequence:1,execute:e=>e.openSidePanel(`SplitToColumns`,{}),isEnabled:e=>e.model.getters.isSingleColSelected(),icon:`o-spreadsheet-Icon.SPLIT_TEXT`},HP={id:`reinsert_dynamic_pivot`,name:O(`Re-insert dynamic pivot`),sequence:60,icon:`o-spreadsheet-Icon.INSERT_PIVOT`,children:[eN],isVisible:e=>e.model.getters.getPivotIds().some(t=>e.model.getters.getPivot(t).isValid())},UP={id:`reinsert_static_pivot`,name:O(`Re-insert static pivot`),sequence:70,icon:`o-spreadsheet-Icon.INSERT_PIVOT`,children:[tN],isVisible:e=>e.model.getters.getPivotIds().some(t=>e.model.getters.getPivot(t).isValid())};function WP({name:e,format:t,descriptionValue:n}){let r=typeof t==`function`?t:()=>t;return{name:e,description:e=>B(n,{format:r(e),locale:e.model.getters.getLocale()}),execute:e=>kM(e,r(e)),isActive:e=>BF(e,r(e)),format:t}}let GP={name:O(`Automatic`),execute:e=>kM(e,``),isActive:e=>zF(e)},KP={name:O(`Plain text`),execute:e=>kM(e,`@`),isActive:e=>BF(e,`@`)},qP=WP({name:O(`Number`),descriptionValue:1000.12,format:`#,##0.00`}),JP={name:O(`Format as percent`),execute:iN,icon:`o-spreadsheet-Icon.PERCENT`},YP=WP({name:O(`Percent`),descriptionValue:.1012,format:`0.00%`}),XP=WP({name:O(`Currency`),descriptionValue:1000.12,format:e=>gs(e.model.config.defaultCurrency||tt)}),ZP={...WP({name:O(`Currency rounded`),descriptionValue:1e3,format:e=>bs(gs(e.model.config.defaultCurrency||tt))}),isVisible:e=>{let t=gs(e.model.config.defaultCurrency||tt);return t!==bs(t)}},QP=WP({name:O(`Accounting`),descriptionValue:-1000.12,format:e=>_s(e.model.config.defaultCurrency||tt)}),$P=Ns(`2023/09/26 10:43:00 PM`,k),eF={name:O(`Custom currency`),isVisible:e=>e.loadCurrencies!==void 0,execute:e=>e.openSidePanel(`CustomCurrency`,{})},tF=WP({name:O(`Date`),descriptionValue:$P,format:e=>e.model.getters.getLocale().dateFormat}),nF=WP({name:O(`Time`),descriptionValue:$P,format:e=>e.model.getters.getLocale().timeFormat}),rF=WP({name:O(`Date time`),descriptionValue:$P,format:e=>$l(e.model.getters.getLocale())}),iF=WP({name:O(`Duration`),descriptionValue:`27:51:38`,format:`hhhh:mm:ss`}),aF=WP({name:O(`Quarter`),descriptionValue:$P,format:`qq yyyy`}),oF=WP({name:O(`Full quarter`),descriptionValue:$P,format:`qqqq yyyy`}),sF={name:O(`More date formats`),execute:e=>e.openSidePanel(`MoreFormats`,{})},cF=WP({name:O(`Full date time`),format:`dddd d mmmm yyyy hh:mm:ss a`,descriptionValue:$P}),lF=WP({name:O(`Full week day and month`),format:`dddd d mmmm yyyy`,descriptionValue:$P}),uF=WP({name:O(`Day and full month`),format:`d mmmm yyyy`,descriptionValue:$P}),dF=WP({name:O(`Short week day`),format:`ddd d mmm yyyy`,descriptionValue:$P}),fF=WP({name:O(`Day and short month`),format:`d mmm yyyy`,descriptionValue:$P}),pF=WP({name:O(`Full month`),format:`mmmm yyyy`,descriptionValue:$P}),mF=WP({name:O(`Short month`),format:`mmm yyyy`,descriptionValue:$P}),hF={name:O(`Increase decimal places`),icon:`o-spreadsheet-Icon.INCREASE_DECIMAL`,execute:e=>e.model.dispatch(`SET_DECIMAL`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:1})},gF={name:O(`Decrease decimal places`),icon:`o-spreadsheet-Icon.DECRASE_DECIMAL`,execute:e=>e.model.dispatch(`SET_DECIMAL`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:-1})},_F={name:O(`Bold`),description:`Ctrl+B`,execute:e=>AM(e,{bold:!e.model.getters.getCurrentStyle().bold}),icon:`o-spreadsheet-Icon.BOLD`,isActive:e=>!!e.model.getters.getCurrentStyle().bold},vF={name:O(`Italic`),description:`Ctrl+I`,execute:e=>AM(e,{italic:!e.model.getters.getCurrentStyle().italic}),icon:`o-spreadsheet-Icon.ITALIC`,isActive:e=>!!e.model.getters.getCurrentStyle().italic},yF={name:O(`Underline`),description:`Ctrl+U`,execute:e=>AM(e,{underline:!e.model.getters.getCurrentStyle().underline}),icon:`o-spreadsheet-Icon.UNDERLINE`,isActive:e=>!!e.model.getters.getCurrentStyle().underline},bF={name:O(`Strikethrough`),execute:e=>AM(e,{strikethrough:!e.model.getters.getCurrentStyle().strikethrough}),icon:`o-spreadsheet-Icon.STRIKE`,isActive:e=>!!e.model.getters.getCurrentStyle().strikethrough},xF={name:O(`Font size`),children:RF(),icon:`o-spreadsheet-Icon.FONT_SIZE`},SF={name:O(`Alignment`),icon:`o-spreadsheet-Icon.ALIGN_LEFT`},CF={name:O(`Horizontal align`),icon:e=>GF(e)},wF={name:O(`Left`),description:`Ctrl+Shift+L`,execute:e=>AM(e,{align:`left`}),isActive:e=>HF(e)===`left`,icon:`o-spreadsheet-Icon.ALIGN_LEFT`},TF={name:O(`Center`),description:`Ctrl+Shift+E`,execute:e=>AM(e,{align:`center`}),isActive:e=>HF(e)===`center`,icon:`o-spreadsheet-Icon.ALIGN_CENTER`},EF={name:O(`Right`),description:`Ctrl+Shift+R`,execute:e=>AM(e,{align:`right`}),isActive:e=>HF(e)===`right`,icon:`o-spreadsheet-Icon.ALIGN_RIGHT`},DF={name:O(`Vertical align`),icon:e=>KF(e)},OF={name:O(`Top`),execute:e=>AM(e,{verticalAlign:`top`}),isActive:e=>UF(e)===`top`,icon:`o-spreadsheet-Icon.ALIGN_TOP`},kF={name:O(`Middle`),execute:e=>AM(e,{verticalAlign:`middle`}),isActive:e=>UF(e)===`middle`,icon:`o-spreadsheet-Icon.ALIGN_MIDDLE`},AF={name:O(`Bottom`),execute:e=>AM(e,{verticalAlign:`bottom`}),isActive:e=>UF(e)===`bottom`,icon:`o-spreadsheet-Icon.ALIGN_BOTTOM`},jF={name:O(`Wrapping`),icon:`o-spreadsheet-Icon.WRAPPING_OVERFLOW`},MF={name:O(`Wrapping`),icon:e=>qF(e)},NF={name:O(`Overflow`),execute:e=>AM(e,{wrapping:`overflow`}),isActive:e=>WF(e)===`overflow`,icon:`o-spreadsheet-Icon.WRAPPING_OVERFLOW`},PF={name:O(`Wrap`),execute:e=>AM(e,{wrapping:`wrap`}),isActive:e=>WF(e)===`wrap`,icon:`o-spreadsheet-Icon.WRAPPING_WRAP`},FF={name:O(`Clip`),execute:e=>AM(e,{wrapping:`clip`}),isActive:e=>WF(e)===`clip`,icon:`o-spreadsheet-Icon.WRAPPING_CLIP`};O(`Text Color`),O(`Fill Color`);let IF={name:O(`Conditional formatting`),execute:aN,icon:`o-spreadsheet-Icon.CONDITIONAL_FORMAT`},LF={name:O(`Clear formatting`),description:`Ctrl+<`,execute:e=>e.model.dispatch(`CLEAR_FORMATTING`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()}),icon:`o-spreadsheet-Icon.CLEAR_FORMAT`};function RF(){return $e.map(e=>({name:e.toString(),sequence:e,id:`font_size_${e}`,execute:t=>AM(t,{fontSize:e}),isActive:t=>VF(t,e)}))}function zF(e){let t=e.model.getters.getActivePosition();return e.model.getters.getPivotCellFromPosition(t).type===`VALUE`?!e.model.getters.getEvaluatedCell(t).format:!e.model.getters.getCell(t)?.format}function BF(e,t){let n=e.model.getters.getActivePosition();return e.model.getters.getPivotCellFromPosition(n).type===`VALUE`?e.model.getters.getEvaluatedCell(n).format===t:e.model.getters.getCell(n)?.format===t}function VF(e,t){return(e.model.getters.getCurrentStyle().fontSize||Be)===t}function HF(e){let t=e.model.getters.getCurrentStyle();return t.align?t.align:e.model.getters.getActiveCell().defaultAlign}function UF(e){let t=e.model.getters.getCurrentStyle();return t.verticalAlign?t.verticalAlign:Re}function WF(e){let t=e.model.getters.getCurrentStyle();return t.wrapping?t.wrapping:ze}function GF(e){switch(HF(e)){case`right`:return`o-spreadsheet-Icon.ALIGN_RIGHT`;case`center`:return`o-spreadsheet-Icon.ALIGN_CENTER`;default:return`o-spreadsheet-Icon.ALIGN_LEFT`}}function KF(e){switch(UF(e)){case`top`:return`o-spreadsheet-Icon.ALIGN_TOP`;case`middle`:return`o-spreadsheet-Icon.ALIGN_MIDDLE`;default:return`o-spreadsheet-Icon.ALIGN_BOTTOM`}}function qF(e){switch(WF(e)){case`wrap`:return`o-spreadsheet-Icon.WRAPPING_WRAP`;case`clip`:return`o-spreadsheet-Icon.WRAPPING_CLIP`;default:return`o-spreadsheet-Icon.WRAPPING_OVERFLOW`}}function JF(e,t,n){let r=e.model.getters.getActiveSheetId(),i=t===`COL`?`FREEZE_COLUMNS`:`FREEZE_ROWS`;e.model.dispatch(i,{sheetId:r,quantity:n}).isCancelledBecause(`MergeOverlap`)&&e.raiseError(fw)}var YF=class{map={};constructor(e=[]){for(let[t,n]of e)this.set(t,n)}set({sheetId:e,col:t,row:n},r){let i=this.map;i[e]||(i[e]={}),i[e][t]||(i[e][t]={}),i[e][t][n]=r}get({sheetId:e,col:t,row:n}){return this.map[e]?.[t]?.[n]}getSheet(e){return this.map[e]}has({sheetId:e,col:t,row:n}){return this.map[e]?.[t]?.[n]!==void 0}delete({sheetId:e,col:t,row:n}){delete this.map[e]?.[t]?.[n]}keys(){let e=this.map,t=[];for(let n in e)for(let r in e[n])for(let i in e[n][r])t.push({sheetId:n,col:parseInt(r),row:parseInt(i)});return t}keysForSheet(e){let t=this.map[e];if(!t)return[];let n=[];for(let r in t)for(let i in t[r])n.push({sheetId:e,col:parseInt(r),row:parseInt(i)});return n}*entries(){let e=this.map;for(let t of this.keys()){let{sheetId:n,col:r,row:i}=t;yield[t,e[n][r][i]]}}},XF=class extends ef{mutators=[`enable`,`disable`];isInvalidated=!1;fingerprintColors={[QF]:`#D9D9D9`};isEnabled=!1;colors=new YF;handle(e){switch(ca(e)&&this.isEnabled&&(this.isInvalidated=!0),e.type){case`UNDO`:case`REDO`:case`ACTIVATE_SHEET`:this.isEnabled&&(this.isInvalidated=!0);break}}finalize(){this.isInvalidated&&(this.isInvalidated=!1,this.computeFingerprints())}enable(){this.isEnabled=!0,this.computeFingerprints()}disable(){this.isEnabled=!1,this.colors=new YF}computeFingerprints(){this.colors=new YF;let e=new YF,t=new Set,n=this.getters.getActiveSheetId(),r=this.getters.getCells(n);for(let n in r){let i=this.computeFingerprint(r[n]);if(!i)continue;t.add(i);let a=this.getters.getCellPosition(n);e.set(a,i)}this.assignColors(t);for(let[t,n]of e.entries()){let e=this.fingerprintColors[n];this.colors.set(t,e),this.colorSpreadZone(t,e)}}colorSpreadZone(e,t){let n=this.getters.getSpreadZone(e);if(!n)return;let r=e.sheetId;for(let e=n.top;e<=n.bottom;e++)for(let i=n.left;i<=n.right;i++){let n={sheetId:r,col:i,row:e};this.colors.set(n,t)}}assignColors(e){let t=new Fn(e.size);Object.keys(this.fingerprintColors).forEach(()=>t.next());for(let n of e)this.fingerprintColors[n]||(this.fingerprintColors[n]=xn(t.next(),.8))}computeFingerprint(e){let t=this.getters.getCellPosition(e.id);return e.isFormula?this.computeFormulaFingerprint(t,e):this.getLiteralFingerprint(t)}computeFormulaFingerprint(e,t){let n=t.compiledFormula.dependencies,r=e.col,i=e.row,a=this.getters.getSheetIds().indexOf(e.sheetId),o={dx:0,dy:0,dSheet:0};for(let e of n){let t=e.zone,[n,s]=e.parts;o.dSheet=this.getters.getSheetIds().indexOf(e.sheetId)-a;let c=dc(e)&&!e.unboundedZone.hasHeader,l=uc(e)&&!e.unboundedZone.hasHeader,u=c||n?.colFixed?0:r,d=l||n?.rowFixed?0:i,f=!s&&n?.colFixed||s?.colFixed,p=!s&&n.rowFixed||s?.rowFixed,m=e.unboundedZone.right===void 0,h=e.unboundedZone.bottom===void 0,g=m||f?0:r,_=h||p?0:i,v=Tr({top:t.top-d,left:t.left-u,right:t.right-g,bottom:t.bottom-_});for(let e=v.top;e<=v.bottom;e++)for(let t=v.left;t<=v.right;t++)o.dx+=t,o.dy+=e}let s=t.compiledFormula.normalizedFormula;return ZF(o)+s}getLiteralFingerprint(e){switch(this.getters.getEvaluatedCell(e).type){case`number`:case`boolean`:return QF;case`text`:case`empty`:case`error`:return}}};function ZF(e){return Object.entries(e).sort(([e],[t])=>e.localeCompare(t)).map(([e,t])=>t).join(`,`)}let QF=`DATA_FINGERPRINT`,$F={name:XM,execute:e=>{let t=e.model.getters.getElementsFromSelection(`COL`);e.model.dispatch(`HIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`COL`,elements:t})},isVisible:GM,icon:`o-spreadsheet-Icon.HIDE_COL`},eI={name:O(`Unhide columns`),execute:e=>{let t=e.model.getters.getElementsFromSelection(`COL`);e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`COL`,elements:t})},isVisible:e=>{let t=e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection(`COL`).some(e=>t.includes(e))},icon:`o-spreadsheet-Icon.UNHIDE_COL`},tI={name:O(`Unhide all columns`),execute:e=>{let t=e.model.getters.getActiveSheetId();e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:t,dimension:`COL`,elements:Array.from(Array(e.model.getters.getNumberCols(t)).keys())})},isVisible:e=>e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).length>0,icon:`o-spreadsheet-Icon.UNHIDE_COL`},nI={name:ZM,execute:e=>{let t=e.model.getters.getElementsFromSelection(`ROW`);e.model.dispatch(`HIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`ROW`,elements:t})},isVisible:UM,icon:`o-spreadsheet-Icon.HIDE_ROW`},rI={name:O(`Unhide rows`),execute:e=>{let t=e.model.getters.getElementsFromSelection(`ROW`);e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`ROW`,elements:t})},isVisible:e=>{let t=e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection(`ROW`).some(e=>t.includes(e))},icon:`o-spreadsheet-Icon.UNHIDE_ROW`},iI={name:O(`Unhide all rows`),execute:e=>{let t=e.model.getters.getActiveSheetId();e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:t,dimension:`ROW`,elements:Array.from(Array(e.model.getters.getNumberRows(t)).keys())})},isVisible:e=>e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).length>0,icon:`o-spreadsheet-Icon.UNHIDE_ROW`},aI={name:O(`Unfreeze`),isVisible:e=>{let{xSplit:t,ySplit:n}=e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId());return t+n>0},execute:e=>e.model.dispatch(`UNFREEZE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId()}),icon:`o-spreadsheet-Icon.UNFREEZE`},oI={name:O(`Freeze`),icon:`o-spreadsheet-Icon.FREEZE`},sI={name:O(`No rows`),execute:e=>e.model.dispatch(`UNFREEZE_ROWS`,{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).ySplit},cI={name:O(`1 row`),execute:e=>JF(e,`ROW`,1),isReadonlyAllowed:!0},lI={name:O(`2 rows`),execute:e=>JF(e,`ROW`,2),isReadonlyAllowed:!0},uI={name:O(`Up to current row`),execute:e=>{let{bottom:t}=e.model.getters.getSelectedZone();JF(e,`ROW`,t+1)},isReadonlyAllowed:!0},dI={name:O(`No columns`),execute:e=>e.model.dispatch(`UNFREEZE_COLUMNS`,{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).xSplit},fI={name:O(`1 column`),execute:e=>JF(e,`COL`,1),isReadonlyAllowed:!0},pI={name:O(`2 columns`),execute:e=>JF(e,`COL`,2),isReadonlyAllowed:!0},mI={name:O(`Up to current column`),execute:e=>{let{right:t}=e.model.getters.getSelectedZone();JF(e,`COL`,t+1)},isReadonlyAllowed:!0},hI={name:O(`Gridlines`),execute:e=>{let t=e.model.getters.getActiveSheetId();e.model.dispatch(`SET_GRID_LINES_VISIBILITY`,{sheetId:t,areGridLinesVisible:!e.model.getters.getGridLinesVisibility(t)})},isActive:e=>{let t=e.model.getters.getActiveSheetId();return e.model.getters.getGridLinesVisibility(t)}},gI={name:O(`Irregularity map`),execute:e=>{let t=e.getStore(XF);t.isEnabled?t.disable():t.enable()},isReadonlyAllowed:!0,icon:`o-spreadsheet-Icon.IRREGULARITY_MAP`},_I={name:O(`Formulas`),isActive:e=>e.model.getters.shouldShowFormulas(),execute:e=>e.model.dispatch(`SET_FORMULA_VISIBILITY`,{show:!e.model.getters.shouldShowFormulas()}),isReadonlyAllowed:!0},vI={name:e=>{let t=e.model.getters.getSelectedZone();return t.left===t.right?O(`Group column %s`,zn(t.left)):O(`Group columns %s - %s`,zn(t.left),zn(t.right))},execute:e=>SI(e,`COL`),isVisible:e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSelectedZone(),r=e.model.getters.getHeaderGroupsInZone(t,`COL`,n);return hN(e)&&!r.some(e=>e.start===n.left&&e.end===n.right)},icon:`o-spreadsheet-Icon.GROUP_COLUMNS`},yI={name:e=>{let t=e.model.getters.getSelectedZone();return t.top===t.bottom?O(`Group row %s`,String(t.top+1)):O(`Group rows %s - %s`,String(t.top+1),String(t.bottom+1))},execute:e=>SI(e,`ROW`),isVisible:e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSelectedZone(),r=e.model.getters.getHeaderGroupsInZone(t,`ROW`,n);return hN(e)&&!r.some(e=>e.start===n.top&&e.end===n.bottom)},icon:`o-spreadsheet-Icon.GROUP_ROWS`},bI={name:e=>{let t=e.model.getters.getSelectedZone();return t.left===t.right?O(`Ungroup column %s`,zn(t.left)):O(`Ungroup columns %s - %s`,zn(t.left),zn(t.right))},execute:e=>CI(e,`COL`),icon:`o-spreadsheet-Icon.UNGROUP_COLUMNS`},xI={name:e=>{let t=e.model.getters.getSelectedZone();return t.top===t.bottom?O(`Ungroup row %s`,String(t.top+1)):O(`Ungroup rows %s - %s`,String(t.top+1),String(t.bottom+1))},execute:e=>CI(e,`ROW`),icon:`o-spreadsheet-Icon.UNGROUP_ROWS`};function SI(e,t){let n=e.model.getters.getSelectedZone(),r=e.model.getters.getActiveSheetId();e.model.dispatch(`GROUP_HEADERS`,{sheetId:r,dimension:t,start:t===`COL`?n.left:n.top,end:t===`COL`?n.right:n.bottom})}function CI(e,t){let n=e.model.getters.getSelectedZone(),r=e.model.getters.getActiveSheetId();e.model.dispatch(`UNGROUP_HEADERS`,{sheetId:r,dimension:t,start:t===`COL`?n.left:n.top,end:t===`COL`?n.right:n.bottom})}function wI(e,t){let n=e.model.getters.getActiveSheetId(),r=e.model.getters.getSelectedZones();return r.length===1&&e.model.getters.getHeaderGroupsInZone(n,t,r[0]).length>0}let TI=new ZD;TI.add(`cut`,{...xN,sequence:10}).add(`copy`,{...bN,sequence:20}).add(`paste`,{...SN,sequence:30}).add(`paste_special`,{...CN,sequence:40,separator:!0}).addChild(`paste_value_only`,[`paste_special`],{...wN,sequence:10}).addChild(`paste_format_only`,[`paste_special`],{...TN,sequence:20}).add(`sort_columns`,{...NP,name:e=>e.model.getters.getActiveCols().size>1?O(`Sort columns`):O(`Sort column`),sequence:50,separator:!0}).addChild(`sort_ascending`,[`sort_columns`],{...PP,sequence:10}).addChild(`sort_descending`,[`sort_columns`],{...RP,sequence:20}).add(`add_column_before`,{...XN,sequence:70}).add(`add_column_after`,{...$N,sequence:80}).add(`delete_column`,{...jN,sequence:90,icon:`o-spreadsheet-Icon.TRASH`}).add(`clear_column`,{...NN,sequence:100,icon:`o-spreadsheet-Icon.CLEAR`}).add(`hide_columns`,{...$F,sequence:105,separator:!0}).add(`unhide_columns`,{...eI,sequence:106,separator:!0}).add(`conditional_formatting`,{...IF,sequence:110,separator:!0}).add(`edit_table`,{...RN,isVisible:lN,sequence:120}).add(`delete_table`,{...zN,isVisible:lN,sequence:125,separator:!0}).add(`group_columns`,{sequence:150,...vI}).add(`ungroup_columns`,{sequence:155,...bI,isVisible:e=>wI(e,`COL`)});let EI=new h;EI.add(`format_number_automatic`,{...GP,id:`format_number_automatic`,sequence:10}).add(`format_number_plain_text`,{...KP,id:`format_number_plain_text`,sequence:15,separator:!0}).add(`format_number_number`,{...qP,id:`format_number_number`,sequence:20}).add(`format_number_percent`,{...YP,id:`format_number_percent`,sequence:30,separator:!0}).add(`format_number_currency`,{...XP,id:`format_number_currency`,sequence:40}).add(`format_number_accounting`,{...QP,id:`format_number_accounting`,sequence:45}).add(`format_number_currency_rounded`,{...ZP,id:`format_number_currency_rounded`,sequence:50}).add(`format_custom_currency`,{...eF,id:`format_custom_currency`,sequence:60,separator:!0}).add(`format_number_date`,{...tF,id:`format_number_date`,sequence:70}).add(`format_number_time`,{...nF,id:`format_number_time`,sequence:80}).add(`format_number_date_time`,{...rF,id:`format_number_date_time`,sequence:90}).add(`format_number_duration`,{...iF,id:`format_number_duration`,sequence:100,separator:!0}).add(`more_formats`,{...sF,id:`more_formats`,sequence:120});function DI(e){let t=new Set(EI.getAll().map(t=>typeof t.format==`function`?t.format(e):t.format)),n=new Map;for(let r of e.model.getters.getSheetIds()){let i=e.model.getters.getEvaluatedCells(r);for(let e in i){let r=i[e];if(r.format&&!n.has(r.format)&&!t.has(r.format)){let e=OI(r.format);(e===`date`||e===`currency`)&&n.set(r.format,WP({descriptionValue:e===`currency`?1e3:$P,format:r.format,name:r.format}))}}}return[...n.values()]}let OI=Vt(e=>ls(e)?`date`:e.includes(`[$`)?`currency`:`number`),kI={name:O(`More formats`),icon:`o-spreadsheet-Icon.NUMBER_FORMATS`,children:[e=>{let t=DI(e).map(e=>({...e,sequence:110}));return t.length>0&&(t[t.length-1].separator=!0),f([...EI.getAll(),...t])}]},AI=new ZD;AI.add(`cut`,{...xN,sequence:10}).add(`copy`,{...bN,sequence:20}).add(`paste`,{...SN,sequence:30}).add(`paste_special`,{...CN,sequence:40,separator:!0}).addChild(`paste_value_only`,[`paste_special`],{...wN,sequence:10}).addChild(`paste_format_only`,[`paste_special`],{...TN,sequence:20}).add(`add_row_before`,{...WN,sequence:50}).add(`add_row_after`,{...qN,sequence:60}).add(`delete_row`,{...ON,sequence:70,icon:`o-spreadsheet-Icon.TRASH`}).add(`clear_row`,{...AN,sequence:80,icon:`o-spreadsheet-Icon.CLEAR`}).add(`hide_rows`,{...nI,sequence:85,separator:!0}).add(`unhide_rows`,{...rI,sequence:86,separator:!0}).add(`conditional_formatting`,{...IF,sequence:90,separator:!0}).add(`group_rows`,{sequence:100,...yI}).add(`ungroup_rows`,{sequence:110,...xI,isVisible:e=>wI(e,`ROW`)});function jI(e){let t=new ZD;return t.add(`delete`,{...aM,sequence:10}).add(`hide_sheet`,{...dM,sequence:20}).add(`duplicate`,{...oM,sequence:30,separator:!0}).add(`rename`,{...sM(e),sequence:40}).add(`change_color`,{...cM(e),sequence:50,separator:!0}).add(`move_right`,{...lM,sequence:60}).add(`move_left`,{...uM,sequence:70}),t}function MI(e,t){let n=e.getActiveSheetId();return zr(NI(e,t).map(E)).map(e=>({sheetId:n,zone:e,noFill:!0,color:_}))}function NI(e,t){let n=[],r=e.getActiveSheetId();for(let i of e.getSheetViewVisibleCols())for(let a of e.getSheetViewVisibleRows()){let o={sheetId:r,col:i,row:a};t===e.getPivotIdFromPosition(o)&&n.push(o)}return n}let PI=new ZD;PI.add(`file`,{name:O(`File`),sequence:10}).addChild(`settings`,[`file`],{name:O(`Settings`),sequence:100,execute:e=>e.openSidePanel(`Settings`),icon:`o-spreadsheet-Icon.COG`}).add(`edit`,{name:O(`Edit`),sequence:20}).addChild(`undo`,[`edit`],{...vN,sequence:10}).addChild(`redo`,[`edit`],{...yN,sequence:20,separator:!0}).addChild(`copy`,[`edit`],{...bN,sequence:30}).addChild(`cut`,[`edit`],{...xN,sequence:40}).addChild(`paste`,[`edit`],{...SN,sequence:50}).addChild(`paste_special`,[`edit`],{...CN,sequence:60,separator:!0}).addChild(`paste_special_value`,[`edit`,`paste_special`],{...wN,sequence:10}).addChild(`paste_special_format`,[`edit`,`paste_special`],{...TN,sequence:20}).addChild(`edit_table`,[`edit`],{...RN,isVisible:lN,sequence:60}).addChild(`find_and_replace`,[`edit`],{...EN,sequence:65,separator:!0}).addChild(`delete`,[`edit`],{name:O(`Delete`),icon:`o-spreadsheet-Icon.TRASH`,sequence:70}).addChild(`edit_delete_cell_values`,[`edit`,`delete`],{...DN,sequence:10}).addChild(`edit_delete_row`,[`edit`,`delete`],{...ON,sequence:20}).addChild(`edit_delete_column`,[`edit`,`delete`],{...jN,sequence:30}).addChild(`edit_delete_cell_shift_up`,[`edit`,`delete`],{...FN,sequence:40}).addChild(`edit_delete_cell_shift_left`,[`edit`,`delete`],{...IN,sequence:50}).addChild(`edit_unhide_columns`,[`edit`],{...tI,sequence:80}).addChild(`edit_unhide_rows`,[`edit`],{...iI,sequence:80}).add(`view`,{name:O(`View`),sequence:30}).addChild(`unfreeze_panes`,[`view`],{...aI,sequence:4}).addChild(`freeze_panes`,[`view`],{...oI,sequence:5}).addChild(`unfreeze_rows`,[`view`,`freeze_panes`],{...sI,sequence:5}).addChild(`freeze_first_row`,[`view`,`freeze_panes`],{...cI,sequence:10}).addChild(`freeze_second_row`,[`view`,`freeze_panes`],{...lI,sequence:15}).addChild(`freeze_current_row`,[`view`,`freeze_panes`],{...uI,sequence:20,separator:!0}).addChild(`unfreeze_columns`,[`view`,`freeze_panes`],{...dI,sequence:25}).addChild(`freeze_first_col`,[`view`,`freeze_panes`],{...fI,sequence:30}).addChild(`freeze_second_col`,[`view`,`freeze_panes`],{...pI,sequence:35}).addChild(`freeze_current_col`,[`view`,`freeze_panes`],{...mI,sequence:40}).addChild(`group_headers`,[`view`],{name:O(`Group`),sequence:15,separator:!0,icon:`o-spreadsheet-Icon.PLUS_IN_BOX`,isVisible:hN}).addChild(`group_columns`,[`view`,`group_headers`],{...vI,sequence:5}).addChild(`ungroup_columns`,[`view`,`group_headers`],{...bI,isVisible:e=>wI(e,`COL`),sequence:10}).addChild(`group_rows`,[`view`,`group_headers`],{...yI,sequence:15}).addChild(`ungroup_rows`,[`view`,`group_headers`],{...xI,isVisible:e=>wI(e,`ROW`),sequence:20}).addChild(`show`,[`view`],{name:O(`Show`),sequence:1,icon:`o-spreadsheet-Icon.SHOW`}).addChild(`view_gridlines`,[`view`,`show`],{...hI,sequence:5}).addChild(`view_formulas`,[`view`,`show`],{..._I,sequence:10}).addChild(`view_irregularity_map`,[`view`],{...gI,sequence:40,separator:!0}).add(`insert`,{name:O(`Insert`),sequence:40}).addChild(`insert_row`,[`insert`],{...UN,sequence:10}).addChild(`insert_row_before`,[`insert`,`insert_row`],{...GN,sequence:10}).addChild(`insert_row_after`,[`insert`,`insert_row`],{...JN,sequence:20}).addChild(`insert_column`,[`insert`],{...YN,sequence:20}).addChild(`insert_column_before`,[`insert`,`insert_column`],{...ZN,sequence:10}).addChild(`insert_column_after`,[`insert`,`insert_column`],{...eP,sequence:20}).addChild(`insert_cell`,[`insert`],{...tP,sequence:30}).addChild(`insert_cell_down`,[`insert`,`insert_cell`],{...nP,name:O(`Shift down`),sequence:10}).addChild(`insert_cell_right`,[`insert`,`insert_cell`],{...rP,name:O(`Shift right`),sequence:20}).addChild(`insert_sheet`,[`insert`],{...bP,sequence:40,separator:!0}).addChild(`insert_chart`,[`insert`],{...iP,sequence:50}).addChild(`insert_pivot`,[`insert`],{...aP,sequence:52}).addChild(`insert_image`,[`insert`],{...oP,sequence:55}).addChild(`insert_table`,[`insert`],{...sP,sequence:57}).addChild(`insert_function`,[`insert`],{...cP,sequence:60}).addChild(`insert_function_sum`,[`insert`,`insert_function`],{...lP,sequence:0}).addChild(`insert_function_average`,[`insert`,`insert_function`],{...uP,sequence:10}).addChild(`insert_function_count`,[`insert`,`insert_function`],{...dP,sequence:20}).addChild(`insert_function_max`,[`insert`,`insert_function`],{...fP,sequence:30}).addChild(`insert_function_min`,[`insert`,`insert_function`],{...pP,sequence:40,separator:!0}).addChild(`categorie_function_all`,[`insert`,`insert_function`],{...mP,sequence:50}).addChild(`categories_function_list`,[`insert`,`insert_function`],gP).addChild(`insert_link`,[`insert`],{..._P,separator:!0,sequence:70}).addChild(`insert_checkbox`,[`insert`],{...vP,sequence:80}).addChild(`insert_dropdown`,[`insert`],{...yP,separator:!0,sequence:90}).add(`format`,{name:O(`Format`),sequence:50}).addChild(`format_number`,[`format`],{...kI,name:O(`Number`),sequence:10,separator:!0}).addChild(`format_bold`,[`format`],{..._F,sequence:20}).addChild(`format_italic`,[`format`],{...vF,sequence:30}).addChild(`format_underline`,[`format`],{...yF,sequence:40}).addChild(`format_strikethrough`,[`format`],{...bF,sequence:50,separator:!0}).addChild(`format_font_size`,[`format`],{...xF,sequence:60,separator:!0}).addChild(`format_alignment`,[`format`],{...SF,sequence:70}).addChild(`format_alignment_left`,[`format`,`format_alignment`],{...wF,sequence:10}).addChild(`format_alignment_center`,[`format`,`format_alignment`],{...TF,sequence:20}).addChild(`format_alignment_right`,[`format`,`format_alignment`],{...EF,sequence:30,separator:!0}).addChild(`format_alignment_top`,[`format`,`format_alignment`],{...OF,sequence:40}).addChild(`format_alignment_middle`,[`format`,`format_alignment`],{...kF,sequence:50}).addChild(`format_alignment_bottom`,[`format`,`format_alignment`],{...AF,sequence:60,separator:!0}).addChild(`format_wrapping`,[`format`],{...jF,sequence:80,separator:!0}).addChild(`format_wrapping_overflow`,[`format`,`format_wrapping`],{...NF,sequence:10}).addChild(`format_wrapping_wrap`,[`format`,`format_wrapping`],{...PF,sequence:20}).addChild(`format_wrapping_clip`,[`format`,`format_wrapping`],{...FF,sequence:30}).addChild(`format_cf`,[`format`],{...IF,sequence:90,separator:!0}).addChild(`format_clearFormat`,[`format`],{...LF,sequence:100,separator:!0}).add(`data`,{name:O(`Data`),sequence:60}).addChild(`sort_range`,[`data`],{...NP,sequence:10,separator:!0}).addChild(`sort_ascending`,[`data`,`sort_range`],{...PP,sequence:10}).addChild(`sort_descending`,[`data`,`sort_range`],{...RP,sequence:20}).addChild(`data_cleanup`,[`data`],{...FP,sequence:15}).addChild(`remove_duplicates`,[`data`,`data_cleanup`],{...IP,sequence:10}).addChild(`trim_whitespace`,[`data`,`data_cleanup`],{...LP,sequence:20}).addChild(`split_to_columns`,[`data`],{...VP,sequence:20}).addChild(`data_validation`,[`data`],{name:O(`Data Validation`),execute:e=>{e.openSidePanel(`DataValidation`)},icon:`o-spreadsheet-Icon.DATA_VALIDATION`,sequence:30,separator:!0}).addChild(`add_remove_data_filter`,[`data`],{...zP,sequence:40,separator:!0}).addChild(`pivot_data_sources`,[`data`],e=>{let t=e.model.getters.getPivotIds().length;return e.model.getters.getPivotIds().map((n,r)=>{let i={get highlights(){return MI(e.model.getters,n)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(n)}`,name:e.model.getters.getPivotDisplayName(n),sequence:50+r/t,isReadonlyAllowed:!0,execute:e=>e.openSidePanel(`PivotSidePanel`,{pivotId:n}),onStartHover:e=>e.getStore(uC).register(i),onStopHover:e=>e.getStore(uC).unRegister(i),icon:`o-spreadsheet-Icon.PIVOT`,separator:r===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(n)?`o-spreadsheet-Icon.UNUSED_PIVOT_WARNING`:void 0}})}).addChild(`reinsert_dynamic_pivot`,[`data`],HP).addChild(`reinsert_static_pivot`,[`data`],UP);let FI=new class extends h{addTransformation(e,t,n){this.content[e]||(this.content[e]=new Map);for(let r of t)this.content[e].set(r,n);return this}getTransformation(e,t){return this.content[t]&&this.content[t].get(e)}},II=new class extends h{mapping={};uuidGenerator=new al;add(e,t){let n={...t,id:this.uuidGenerator.uuidv4()};return super.add(e,n)}getAllOrdered(){return this.getAll().sort((e,t)=>e.sequence-t.sequence)}};var Q=class extends t.Component{static template=`o_spreadsheet.Section`;static props={class:{type:String,optional:!0},title:{type:String,optional:!0},slots:Object}};function LI(e,t){let n=()=>{window.removeEventListener(`pointerup`,r),window.removeEventListener(`dragstart`,i),window.removeEventListener(`pointermove`,e),window.removeEventListener(`wheel`,e)},r=e=>{t(e),n()};function i(e){e.preventDefault()}return window.addEventListener(`pointerup`,r),window.addEventListener(`dragstart`,i),window.addEventListener(`pointermove`,e),window.addEventListener(`wheel`,e,{passive:!1}),n}function RI(){let e,n=document.body.style.cursor,r=[],i=()=>{e=void 0,document.body.style.cursor=n,r.forEach(e=>e()),r=[]},a=(t,a)=>{let s=()=>{document.body.style.cursor=`move`,e&&(Object.assign(o.itemsStyle,e.getItemStyles()),a.onChange?.())};o.cancel=()=>{o.draggedItemId=void 0,o.itemsStyle={},document.body.style.cursor=n,a.onCancel?.(),i()};let c=(e,t)=>{o.draggedItemId=void 0,o.itemsStyle={},document.body.style.cursor=n,a.onDragEnd?.(e,t),i()};document.body.style.cursor=`move`,o.draggedItemId=a.draggedItemId;let l=t===`horizontal`?new HI(a.scrollableContainerEl):new VI(a.scrollableContainerEl);e=new zI({...a,container:l,onChange:s,onDragEnd:c,onCancel:o.cancel});let u=LI(e.onMouseMove.bind(e),e.onMouseUp.bind(e));r.push(u);let d=e.onScroll.bind(e);a.scrollableContainerEl.addEventListener(`scroll`,d),r.push(()=>a.scrollableContainerEl.removeEventListener(`scroll`,d)),r.push(e.destroy.bind(e))};(0,t.onWillUnmount)(()=>{i()});let o=(0,t.useState)({itemsStyle:{},draggedItemId:void 0,start:a,cancel:()=>{}});return o}var zI=class{draggedItemId;items;container;initialMousePosition;currentMousePosition;initialScroll;minPosition;maxPosition;edgeScrollIntervalId;onChange;onCancel;onDragEnd;deadZone;constructor(e){this.items=e.items.map(e=>({...e,positionAtStart:e.position})),this.draggedItemId=e.draggedItemId,this.container=e.container,this.onChange=e.onChange,this.onCancel=e.onCancel,this.onDragEnd=e.onDragEnd,this.initialMousePosition=e.initialMousePosition,this.currentMousePosition=e.initialMousePosition,this.initialScroll=this.container.scroll,this.minPosition=this.items[0].position,this.maxPosition=this.items[this.items.length-1].position+this.items[this.items.length-1].size}getItemStyles(){let e={};for(let t of this.items)e[t.id]=this.getItemStyle(t.id);return e}getItemStyle(e){let t=this.container.cssPositionProperty,n={};return n.position=`relative`,n[t]=(this.getItemsPositions()[e]||0)+`px`,n.transition=`${t} 0.5s`,n[`pointer-events`]=`none`,this.draggedItemId===e&&(n.transition=`${t} 0s`,n[`z-index`]=`1000`),U(n)}onScroll(){this.moveDraggedItemToPosition(this.currentMousePosition+this.scrollOffset)}onMouseMove(e){if(e.button>1){this.onCancel();return}let t=this.container.getMousePosition(e);if(this.currentMousePosition=t,t<this.container.start||t>this.container.end){this.startEdgeScroll(t<this.container.start?-1:1);return}else this.stopEdgeScroll();this.moveDraggedItemToPosition(t+this.scrollOffset)}moveDraggedItemToPosition(e){let t=this.getHoveredItemIndex(e,this.items),n=this.items.findIndex(e=>e.id===this.draggedItemId),r=this.items[n];if(this.deadZone&&this.isInZone(e,this.deadZone)){this.onChange(this.getItemsPositions());return}else this.isInZone(e,{start:r.position,end:r.position+r.size})&&(this.deadZone=void 0);if(n===t){this.onChange(this.getItemsPositions());return}let i=Math.min(n,t),a=Math.max(n,t),o=Math.sign(t-n),s=0;for(let e=i;e<=a;e++)e!==n&&(this.items[e].position-=o*r.size,s+=this.items[e].size);r.position+=o*s,this.items.sort((e,t)=>e.position-t.position),this.deadZone=o>0?{start:e,end:r.position}:{start:r.position+r.size,end:e},this.onChange(this.getItemsPositions())}onMouseUp(e){e.button!==0&&this.onCancel(),e.stopPropagation(),e.preventDefault();let t=this.items.findIndex(e=>e.id===this.draggedItemId);return this.onDragEnd(this.draggedItemId,t),this.stopEdgeScroll(),!1}startEdgeScroll(e){this.edgeScrollIntervalId||=window.setInterval(()=>{let t=e*3;this.container.scroll+=t},5)}stopEdgeScroll(){window.clearInterval(this.edgeScrollIntervalId),this.edgeScrollIntervalId=void 0}getHoveredItemIndex(e,t){return e<=this.minPosition?0:e>=this.maxPosition?t.length-1:t.findIndex(t=>t.position+t.size>=e)}getItemsPositions(){let e={};for(let t of this.items){if(t.id!==this.draggedItemId){e[t.id]=t.position-t.positionAtStart;continue}let n=this.currentMousePosition-this.initialMousePosition+this.scrollOffset;n=Math.max(this.minPosition-t.positionAtStart,n),n=Math.min(this.maxPosition-t.positionAtStart-t.size,n),e[t.id]=n}return e}isInZone(e,t){return e>=t.start&&e<=t.end}get scrollOffset(){return this.container.scroll-this.initialScroll}destroy(){this.stopEdgeScroll()}},BI=class{constructor(e){this.el=e}get containerRect(){return this.el.getBoundingClientRect()}},VI=class extends BI{get start(){return this.containerRect.top}get end(){return this.containerRect.bottom}get cssPositionProperty(){return`top`}get scroll(){return this.el.scrollTop}set scroll(e){this.el.scrollTop=e}getMousePosition(e){return e.clientY}},HI=class extends BI{get start(){return this.containerRect.left}get end(){return this.containerRect.right}get cssPositionProperty(){return`left`}get scroll(){return this.el.scrollLeft}set scroll(e){this.el.scrollLeft=e}getMousePosition(e){return e.clientX}};let UI={ArrowDown:`down`,ArrowLeft:`left`,ArrowRight:`right`,ArrowUp:`up`};function WI(e,t){let n=UI[e.key];e.shiftKey?t.resizeAnchorZone(n,rD(e)?`end`:1):t.moveAnchorCell(n,rD(e)?`end`:1)}var GI=class{mutators=[`focus`,`unfocus`];focusedElement=null;focus(e){this.focusedElement=e}unfocus(e){this.focusedElement&&this.focusedElement===e&&(this.focusedElement=null)}},KI=class extends ef{mutators=[`resetWithRanges`,`focusById`,`unfocus`,`addEmptyRange`,`removeRange`,`changeRange`,`reset`,`confirm`,`updateColors`];ranges=[];focusedRangeIndex=null;inputSheetId;focusStore=this.get(GI);highlightStore=this.get(uC);constructor(e,t=[],n=!1,r=[]){if(super(e),this.initialRanges=t,this.inputHasSingleRange=n,this.colors=r,n&&t.length>1)throw Error(`Input with a single range cannot be instantiated with several range references.`);this.inputSheetId=this.getters.getActiveSheetId(),this.resetWithRanges(t),this.highlightStore.register(this),this.onDispose(()=>{this.unfocus(),this.highlightStore.unRegister(this)})}handleEvent(e){if(this.focusedRangeIndex===null)return;let t=this.inputSheetId,n=this.getters.getActiveSheetId(),r=e.options.unbounded?this.getters.getUnboundedZone(n,e.anchor.zone):e.anchor.zone,i=this.getters.getRangeFromZone(n,r);if(e.mode===`newAnchor`&&!this.inputHasSingleRange&&this.ranges[this.focusedRangeIndex].xc.trim()!==``){let e=this.getters.getSelectionRangeString(i,t);this.insertNewRange(this.ranges.length,[e]),this.focusLast()}else{let e=i.parts,n=this.ranges[this.focusedRangeIndex].xc.trim();n&&(e=this.getters.getRangeFromSheetXC(t,n).parts);let r={...i,parts:e},a=this.getters.getSelectionRangeString(r,t);this.setRange(this.focusedRangeIndex,[a])}}handle(e){switch(e.type){case`ACTIVATE_SHEET`:if(e.sheetIdFrom!==e.sheetIdTo){let{col:t,row:n}=this.getters.getNextVisibleCellPosition({sheetId:e.sheetIdTo,col:0,row:0}),r=this.getters.expandZone(e.sheetIdTo,E({col:t,row:n}));this.model.selection.resetAnchor(this,{cell:{col:t,row:n},zone:r})}break;case`START_CHANGE_HIGHLIGHT`:let t=this.getters.getActiveSheetId(),n=this.getters.expandZone(t,e.zone),r=this.ranges.findIndex(e=>{let{xc:r,sheetName:i}=ac(e.xc),a=i||this.getters.getSheetName(this.inputSheetId);if(this.getters.getSheetName(t)!==a)return!1;let o=this.getters.getRangeFromSheetXC(t,r);return gr(this.getters.expandZone(t,o.zone),n)});if(r!==-1){this.focus(r);let{left:e,top:t}=n;this.model.selection.resetAnchor(this,{cell:{col:e,row:t},zone:n})}break}}changeRange(e,t){if(this.inputHasSingleRange&&t.split(`,`).length>1)return;let n=this.getIndex(e);if(n!==null&&this.focusedRangeIndex!==n&&this.focus(n),n!==null){let e=t.replace(/^,+/,``).split(`,`).map(e=>e.trim());this.setRange(n,e),this.captureSelection()}}addEmptyRange(){this.inputHasSingleRange&&this.ranges.length===1||(this.insertNewRange(this.ranges.length,[``]),this.focusLast())}removeRange(e){if(this.ranges.length===1)return;let t=this.getIndex(e);t!==null&&this.removeRangeByIndex(t)}updateColors(e){this.colors=e;let t=new Pn(this.ranges.length,this.colors);this.ranges=this.ranges.map(e=>({...e,color:t.next()}))}confirm(){for(let e of this.selectionInputs)e.xc===``&&this.removeRange(e.id);let e=this.getters.getActiveSheetId();this.inputSheetId!==e&&this.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:e,sheetIdTo:this.inputSheetId}),this.selectionInputValues.join()!==this.initialRanges.join()&&this.resetWithRanges(this.selectionInputValues),this.initialRanges=this.selectionInputValues,this.unfocus()}reset(){this.resetWithRanges(this.initialRanges),this.confirm()}get selectionInputValues(){return this.cleanInputs(this.ranges.map(e=>e.xc?e.xc:``))}get selectionInputs(){return this.ranges.map((e,t)=>Object.assign({},e,{color:this.hasMainFocus&&this.focusedRangeIndex!==null&&this.getters.isRangeValid(e.xc)?e.color:null,isFocused:this.hasMainFocus&&this.focusedRangeIndex===t,isValidRange:e.xc===``||this.getters.isRangeValid(e.xc)}))}get isResettable(){return this.initialRanges.join()!==this.ranges.map(e=>e.xc).join()}get isConfirmable(){return this.selectionInputs.every(e=>e.isValidRange)}get hasFocus(){return this.selectionInputs.some(e=>e.isFocused)}get hasMainFocus(){let e=this.focusStore.focusedElement;return!!e&&e===this}get highlights(){return this.hasMainFocus?this.ranges.map(e=>this.inputToHighlights(e)).flat():[]}focusById(e){this.focus(this.getIndex(e))}focus(e){this.focusStore.focus(this),this.focusedRangeIndex=e,this.captureSelection()}focusLast(){this.focus(this.ranges.length-1)}unfocus(){this.focusedRangeIndex=null,this.focusStore.unfocus(this),this.model.selection.release(this)}captureSelection(){if(this.focusedRangeIndex===null)return;let e=this.ranges[this.focusedRangeIndex],t=this.getters.getActiveSheetId(),n=this.getters.getRangeFromSheetXC(t,e?.xc||`A1`).zone;this.model.selection.capture(this,{cell:{col:n.left,row:n.top},zone:n},{handleEvent:this.handleEvent.bind(this),release:this.unfocus.bind(this)})}resetWithRanges(e){this.ranges=[],this.insertNewRange(0,e),this.ranges.length===0&&(this.insertNewRange(this.ranges.length,[``]),this.focusLast())}setContent(e,t){this.ranges[e]={...this.ranges[e],xc:t}}insertNewRange(e,t){let n=Math.max(0,...this.ranges.map(e=>Number(e.id))),r=new Pn(this.ranges.length,this.colors);for(let t=0;t<e;t++)r.next();this.ranges.splice(e,0,...t.map((e,t)=>({xc:e,id:n+t+1,color:r.next()})))}setRange(e,t){let[,...n]=t;this.setContent(e,t[0]),this.insertNewRange(e+1,n),n.length&&this.focus(e+n.length)}removeRangeByIndex(e){this.ranges.splice(e,1),this.focusedRangeIndex!==null&&this.focusLast()}inputToHighlights({xc:e,color:t}){return this.cleanInputs([e]).filter(e=>this.getters.isRangeValid(e)).filter(e=>this.shouldBeHighlighted(this.inputSheetId,e)).map(e=>{let{sheetName:n}=ac(e);return{zone:this.getters.getRangeFromSheetXC(this.inputSheetId,e).zone,sheetId:n&&this.getters.getSheetIdByName(n)||this.inputSheetId,color:t,interactive:!0}})}cleanInputs(e){return e.map(e=>e.split(`,`)).flat().map(e=>e.trim()).filter(e=>e!==``)}shouldBeHighlighted(e,t){let{sheetName:n}=ac(t),r=this.getters.getSheetIdByName(n),i=this.getters.getActiveSheet().id;return this.getters.isRangeValid(t)&&(r===i||r===void 0&&i===e)}getIndex(e){let t=this.ranges.findIndex(t=>t.id===e);return t>=0?t:null}};H`
|
|
351
|
+
`;var DM=class extends t.Component{static template=`o-spreadsheet-LinkEditor`;static props={cellPosition:Object,onClosed:{type:Function,optional:!0}};static components={Menu:EM};menuItems=fM.getMenuItems();link=(0,t.useState)(this.defaultState);menu=(0,t.useState)({isOpen:!1});linkEditorMenuButtonRef=(0,t.useRef)(`linkEditorMenuButton`);menuButtonRect=mM(this.linkEditorMenuButtonRef);urlInput=(0,t.useRef)(`urlInput`);setup(){(0,t.onMounted)(()=>this.urlInput.el?.focus())}get defaultState(){let{col:e,row:t}=this.props.cellPosition,n=this.env.model.getters.getActiveSheetId(),r=this.env.model.getters.getEvaluatedCell({sheetId:n,col:e,row:t});return r.link?{url:r.link.url,label:r.formattedValue,isUrlEditable:r.link.isUrlEditable}:{label:r.formattedValue,url:``,isUrlEditable:!0}}onSpecialLink(e){let{detail:t}=e,n=xo(t);n&&(this.link.url=n.url,this.link.label=n.label,this.link.isUrlEditable=n.isUrlEditable)}getUrlRepresentation(e){return yo(e,this.env.model.getters)}openMenu(){this.menu.isOpen=!0}removeLink(){this.link.url=``,this.link.isUrlEditable=!0}save(){let{col:e,row:t}=this.props.cellPosition,n=this.env.model.getters.getLocale(),r=this.link.label?Ll(this.link.label,n):this.link.url;this.env.model.dispatch(`UPDATE_CELL`,{col:e,row:t,sheetId:this.env.model.getters.getActiveSheetId(),content:vt(r,this.link.url)}),this.props.onClosed?.()}cancel(){this.props.onClosed?.()}onKeyDown(e){switch(e.key){case`Enter`:this.link.url&&this.save(),e.stopPropagation(),e.preventDefault();break;case`Escape`:this.cancel(),e.stopPropagation();break}}};BC.add(`ErrorToolTip`,Jj).add(`LinkCell`,rM).add(`LinkEditor`,{onOpen:(e,t)=>({isOpen:!0,props:{cellPosition:e},Component:DM,cellCorner:`bottom-left`})}).add(`FilterMenu`,$j);function OM(e,t,n=OA){let r=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,r);r.length===1&&!i&&Nr(r[0])===1&&(e.model.selection.selectTableAroundSelection(),r=e.model.getters.getSelectedZones(),i=e.model.getters.canCreateDynamicTableOnZones(t,r));let a=r.map(n=>e.model.getters.getRangeDataFromZone(t,n)),o=e.model.dispatch(`CREATE_TABLE`,{ranges:a,sheetId:t,config:n,tableType:i?`dynamic`:`static`});return o.isCancelledBecause(`TableOverlap`)?e.raiseError(gw.Errors.TableOverlap):o.isCancelledBecause(`NonContinuousTargets`)&&e.raiseError(gw.Errors.NonContinuousTargets),o}function kM(e,t){e.model.dispatch(`SET_FORMATTING_WITH_PIVOT`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),format:t})}function AM(e,t){e.model.dispatch(`SET_FORMATTING`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),style:t})}let jM=async e=>NM(e),MM=async e=>NM(e,`asValue`);async function NM(e,t){let n=await e.clipboard.read();switch(n.status){case`ok`:let r=e.model.getters.getClipboardId(),i=ul(n.content),a=i.data?.clipboardId,o=e.model.getters.getSelectedZones();r===a?Gj(e,o,t):await Kj(e,o,i,t),e.model.getters.isCutOperation()&&t!==`asValue`&&await e.clipboard.write({"text/plain":``});break;case`notImplemented`:e.raiseError(O(`Pasting from the context menu is not supported in this browser. Use keyboard shortcuts ctrl+c / ctrl+v instead.`));break;case`permissionDenied`:e.raiseError(O(`Access to the clipboard denied by the browser. Please enable clipboard permission for this page in your browser settings.`));break}}let PM=e=>NM(e,`onlyFormat`),FM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Clear rows`);let t,n,r=e.model.getters.getActiveRows();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.top,n=r.bottom}return t===n?O(`Clear row %s`,(t+1).toString()):O(`Clear rows %s - %s`,(t+1).toString(),(n+1).toString())},IM=e=>{let t=e.model.getters.getActiveSheetId(),n=[...e.model.getters.getActiveRows()].map(n=>e.model.getters.getRowsZone(t,n,n));e.model.dispatch(`DELETE_CONTENT`,{target:n,sheetId:e.model.getters.getActiveSheetId()})},LM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Clear columns`);let t,n,r=e.model.getters.getActiveCols();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.left,n=r.right}return t===n?O(`Clear column %s`,zn(t)):O(`Clear columns %s - %s`,zn(t),zn(n))},RM=e=>{let t=e.model.getters.getActiveSheetId(),n=[...e.model.getters.getActiveCols()].map(n=>e.model.getters.getColsZone(t,n,n));e.model.dispatch(`DELETE_CONTENT`,{target:n,sheetId:e.model.getters.getActiveSheetId()})},zM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Delete rows`);let t,n,r=e.model.getters.getActiveRows();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.top,n=r.bottom}return t===n?O(`Delete row %s`,(t+1).toString()):O(`Delete rows %s - %s`,(t+1).toString(),(n+1).toString())},BM=e=>{let t=[...e.model.getters.getActiveRows()];if(!t.length){let n=e.model.getters.getSelectedZones()[0];for(let e=n.top;e<=n.bottom;e++)t.push(e)}e.model.dispatch(`REMOVE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),dimension:`ROW`,elements:t})},VM=(e,t)=>{if(e===`COL`&&t.model.getters.getActiveRows().size>0||e===`ROW`&&t.model.getters.getActiveCols().size>0)return!1;let n=t.model.getters.getActiveSheetId(),r=t.model.getters.getElementsFromSelection(e),i=t.model.getters.checkElementsIncludeAllVisibleHeaders(n,e,r),a=t.model.getters.checkElementsIncludeAllNonFrozenHeaders(n,e,r);return!i&&!a},HM=e=>{if(e.model.getters.getSelectedZones().length>1)return O(`Delete columns`);let t,n,r=e.model.getters.getActiveCols();if(r.size!==0)t=Yt([...r]),n=Jt([...r]);else{let r=e.model.getters.getSelectedZones()[0];t=r.left,n=r.right}return t===n?O(`Delete column %s`,zn(t)):O(`Delete columns %s - %s`,zn(t),zn(n))},UM=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getElementsFromSelection(`ROW`);return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,`ROW`,n)},WM=e=>{let t=[...e.model.getters.getActiveCols()];if(!t.length){let n=e.model.getters.getSelectedZones()[0];for(let e=n.left;e<=n.right;e++)t.push(e)}e.model.dispatch(`REMOVE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),dimension:`COL`,elements:t})},GM=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getElementsFromSelection(`COL`);return!e.model.getters.checkElementsIncludeAllVisibleHeaders(t,`COL`,n)},KM=e=>{let t=e.model.getters.getActiveRows(),n,r;if(t.size)n=Yt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.top,r=t.bottom-t.top+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`before`,base:n,quantity:r,dimension:`ROW`})},qM=e=>{let t=e.model.getters.getActiveRows(),n,r;if(t.size)n=Jt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.bottom,r=t.bottom-t.top+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`after`,base:n,quantity:r,dimension:`ROW`})},JM=e=>{let t=e.model.getters.getActiveCols(),n,r;if(t.size)n=Yt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.left,r=t.right-t.left+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`before`,dimension:`COL`,base:n,quantity:r})},YM=e=>{let t=e.model.getters.getActiveCols(),n,r;if(t.size)n=Jt([...t]),r=t.size;else{let t=e.model.getters.getSelectedZones()[0];n=t.right,r=t.right-t.left+1}e.model.dispatch(`ADD_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),sheetName:e.model.getters.getActiveSheetName(),position:`after`,dimension:`COL`,base:n,quantity:r})},XM=e=>{let t=e.model.getters.getElementsFromSelection(`COL`),n=t[0],r=t[t.length-1];return t.length===1?O(`Hide column %s`,zn(n).toString()):r-n+1===t.length?O(`Hide columns %s - %s`,zn(n).toString(),zn(r).toString()):O(`Hide columns`)},ZM=e=>{let t=e.model.getters.getElementsFromSelection(`ROW`),n=t[0],r=t[t.length-1];return t.length===1?O(`Hide row %s`,(n+1).toString()):r-n+1===t.length?O(`Hide rows %s - %s`,(n+1).toString(),(r+1).toString()):O(`Hide rows`)},QM=e=>{let t=e.model.getters,n=e.model.uuidGenerator.smallUuid(),r=t.getActiveSheetId();Nr(e.model.getters.getSelectedZone())===1&&e.model.selection.selectTableAroundSelection();let i={width:536,height:335},{col:a,row:o,offset:s}=hD(t,i);e.model.dispatch(`CREATE_CHART`,{sheetId:r,figureId:n,col:a,row:o,offset:s,size:i,definition:fD(e.model.getters.getSelectedZone(),e.model.getters)}).isSuccessful&&(e.model.dispatch(`SELECT_FIGURE`,{figureId:n}),e.openSidePanel(`ChartPanel`))},$M=e=>{let t=e.model.uuidGenerator.smallUuid(),n=e.model.uuidGenerator.smallUuid();e.model.dispatch(`INSERT_NEW_PIVOT`,{pivotId:t,newSheetId:n}).isSuccessful&&e.openSidePanel(`PivotSidePanel`,{pivotId:t})},eN=e=>e.model.getters.getPivotIds().map((t,n)=>({id:`reinsert_dynamic_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:n,execute:e=>{let n=e.model.getters.getSelectedZone(),r=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch(`INSERT_PIVOT_WITH_TABLE`,{pivotId:t,table:r,col:n.left,row:n.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:`dynamic`}),e.model.dispatch(`REFRESH_PIVOT`,{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()})),tN=e=>e.model.getters.getPivotIds().map((t,n)=>({id:`reinsert_static_pivot_${e.model.getters.getPivotFormulaId(t)}`,name:e.model.getters.getPivotDisplayName(t),sequence:n,execute:e=>{let n=e.model.getters.getSelectedZone(),r=e.model.getters.getPivot(t).getTableStructure().export();e.model.dispatch(`INSERT_PIVOT_WITH_TABLE`,{pivotId:t,table:r,col:n.left,row:n.top,sheetId:e.model.getters.getActiveSheetId(),pivotMode:`static`}),e.model.dispatch(`REFRESH_PIVOT`,{id:t})},isVisible:e=>e.model.getters.getPivot(t).isValid()}));async function nN(e){try{return await e.imageProvider.requestImage()}catch{e.raiseError(O(`An unexpected error occurred during the image transfer`));return}}let rN=async e=>{if(e.imageProvider){let t=e.model.getters.getActiveSheetId(),n=e.model.uuidGenerator.smallUuid(),r=await nN(e);if(!r)return;let i=gD(e.model.getters,r.size),{col:a,row:o,offset:s}=hD(e.model.getters,i);e.model.dispatch(`CREATE_IMAGE`,{sheetId:t,figureId:n,col:a,row:o,offset:s,size:i,definition:r})}},iN=e=>kM(e,`0.00%`),aN=e=>{e.openSidePanel(`ConditionalFormatting`,{selection:e.model.getters.getSelectedZones()})},oN=e=>{let{col:t,row:n}=e.model.getters.getActivePosition();e.getStore(tM).open({col:t,row:n},`LinkEditor`)},sN=e=>{let t=e.model.getters.getActiveSheetId(),{col:n,row:r}=e.model.getters.getActivePosition(),i=e.model.getters.getEvaluatedCell({sheetId:t,col:n,row:r});return i&&i.link?O(`Edit link`):O(`Insert link`)},cN=e=>e.model.getters.getFirstTableInSelection()?.config.hasFilters||!1,lN=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSelectedZones();return e.model.getters.getTablesOverlappingZones(t,n).length===1},uN=e=>Fr(e.model.getters.getSelectedZones()),dN=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getFirstTableInSelection();n?e.model.dispatch(`UPDATE_TABLE`,{sheetId:t,zone:n.range.zone,config:{hasFilters:!0}}):OM(e,t,{...OA,hasFilters:!0,bandedRows:!1,styleId:`TableStyleLight11`})},fN=e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getFirstTableInSelection();n&&e.model.dispatch(`UPDATE_TABLE`,{sheetId:t,zone:n.range.zone,config:{hasFilters:!1}})},pN=e=>{OM(e,e.model.getters.getActiveSheetId()).isSuccessful&&e.openSidePanel(`TableSidePanel`,{})},mN=e=>{let t=e.model.getters.getActivePosition(),n=e.model.getters.getTable(t);n&&e.model.dispatch(`REMOVE_TABLE`,{sheetId:t.sheetId,target:[n.range.zone]})},hN=e=>e.model.getters.getSelectedZones().length===1,gN=(e,t)=>{if(!hN(e))return!1;let n=t===`COL`?e.model.getters.getActiveCols():e.model.getters.getActiveRows(),r=t===`COL`?e.model.getters.getActiveRows():e.model.getters.getActiveCols(),i=e.model.getters.getActiveSheetId(),a=gr(e.model.getters.getSelectedZone(),e.model.getters.getSheetZone(i));return Bt(n)&&(r.size===0||a)},_N={name:e=>cN(e)?O(`Remove selected filters`):O(`Add filters`),isEnabled:e=>uN(e),execute:e=>cN(e)?fN(e):dN(e),icon:`o-spreadsheet-Icon.FILTER_ICON_ACTIVE`},vN={name:O(`Undo`),description:`Ctrl+Z`,execute:e=>e.model.dispatch(`REQUEST_UNDO`),isEnabled:e=>e.model.getters.canUndo(),icon:`o-spreadsheet-Icon.UNDO`},yN={name:O(`Redo`),description:`Ctrl+Y`,execute:e=>e.model.dispatch(`REQUEST_REDO`),isEnabled:e=>e.model.getters.canRedo(),icon:`o-spreadsheet-Icon.REDO`},bN={name:O(`Copy`),description:`Ctrl+C`,isReadonlyAllowed:!0,execute:async e=>{e.model.dispatch(`COPY`),await e.clipboard.write(await e.model.getters.getClipboardTextAndImageContent())},icon:`o-spreadsheet-Icon.CLIPBOARD`},xN={name:O(`Cut`),description:`Ctrl+X`,execute:async e=>{QD(e),await e.clipboard.write(await e.model.getters.getClipboardTextAndImageContent())},icon:`o-spreadsheet-Icon.CUT`},SN={name:O(`Paste`),description:`Ctrl+V`,execute:jM,icon:`o-spreadsheet-Icon.PASTE`},CN={name:O(`Paste special`),isVisible:e=>!e.model.getters.isCutOperation(),icon:`o-spreadsheet-Icon.PASTE`},wN={name:O(`Paste as value`),description:`Ctrl+Shift+V`,execute:MM},TN={name:O(`Paste format only`),execute:PM},EN={name:O(`Find and replace`),description:`Ctrl+H`,isReadonlyAllowed:!0,execute:e=>{e.openSidePanel(`FindAndReplace`,{})},icon:`o-spreadsheet-Icon.SEARCH`},DN={name:O(`Delete values`),execute:e=>e.model.dispatch(`DELETE_UNFILTERED_CONTENT`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()})},ON={name:zM,execute:BM,isVisible:e=>VM(`ROW`,e)},kN={...ON,isVisible:hN},AN={name:FM,execute:IM},jN={name:HM,execute:WM,isVisible:e=>VM(`COL`,e)},MN={...jN,isVisible:hN},NN={name:LM,execute:RM},PN={name:O(`Delete cells`),isVisible:hN},FN={name:O(`Delete cell and shift up`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`DELETE_CELL`,{zone:t,shiftDimension:`ROW`}))}},IN={name:O(`Delete cell and shift left`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`DELETE_CELL`,{zone:t,shiftDimension:`COL`}))}},LN={name:O(`Merge cells`),isEnabled:e=>!BN(e),isActive:e=>VN(e),execute:e=>HN(e),icon:`o-spreadsheet-Icon.MERGE_CELL`},RN={name:()=>O(`Edit table`),execute:e=>e.openSidePanel(`TableSidePanel`,{}),icon:`o-spreadsheet-Icon.EDIT_TABLE`},zN={name:()=>O(`Delete table`),execute:mN,icon:`o-spreadsheet-Icon.DELETE_TABLE`};function BN(e){let t=e.model.getters.getSelectedZones(),{top:n,left:r,right:i,bottom:a}=e.model.getters.getSelectedZone(),{sheetId:o}=e.model.getters.getActivePosition(),{xSplit:s,ySplit:c}=e.model.getters.getPaneDivisions(o);return t.length>1||n===a&&r===i||r<s&&s<=i||n<c&&c<=a}function VN(e){if(!BN(e)){let t=e.model.getters.getSelectedZones(),{col:n,row:r,sheetId:i}=e.model.getters.getActivePosition(),a=e.model.getters.expandZone(i,E({col:n,row:r}));return gr(t[0],a)}return!1}function HN(e){if(BN(e))return;let t=e.model.getters.getSelectedZones(),n=[t[t.length-1]],r=e.model.getters.getActiveSheetId();VN(e)?e.model.dispatch(`REMOVE_MERGE`,{sheetId:r,target:n}):eO(e,r,n)}let UN={name:e=>{let t=SP(e);return t===1?O(`Insert row`):O(`Insert %s rows`,t.toString())},isVisible:e=>gN(e,`ROW`),icon:`o-spreadsheet-Icon.INSERT_ROW`},WN={name:e=>{let t=SP(e);return t===1?O(`Insert row above`):O(`Insert %s rows above`,t.toString())},execute:KM,isVisible:e=>gN(e,`ROW`),icon:`o-spreadsheet-Icon.INSERT_ROW_BEFORE`},GN={...WN,name:e=>{let t=SP(e);return t===1?O(`Row above`):O(`%s Rows above`,t.toString())}},KN={...WN,name:e=>{let t=SP(e);return t===1?O(`Insert row`):O(`Insert %s rows`,t.toString())},isVisible:hN,icon:`o-spreadsheet-Icon.INSERT_ROW_BEFORE`},qN={execute:qM,name:e=>{let t=SP(e);return t===1?O(`Insert row below`):O(`Insert %s rows below`,t.toString())},isVisible:e=>gN(e,`ROW`),icon:`o-spreadsheet-Icon.INSERT_ROW_AFTER`},JN={...qN,name:e=>{let t=SP(e);return t===1?O(`Row below`):O(`%s Rows below`,t.toString())}},YN={name:e=>{let t=CP(e);return t===1?O(`Insert column`):O(`Insert %s columns`,t.toString())},isVisible:e=>gN(e,`COL`),icon:`o-spreadsheet-Icon.INSERT_COL`},XN={name:e=>{let t=CP(e);return t===1?O(`Insert column left`):O(`Insert %s columns left`,t.toString())},execute:JM,isVisible:e=>gN(e,`COL`),icon:`o-spreadsheet-Icon.INSERT_COL_BEFORE`},ZN={...XN,name:e=>{let t=CP(e);return t===1?O(`Column left`):O(`%s Columns left`,t.toString())}},QN={...XN,name:e=>{let t=CP(e);return t===1?O(`Insert column`):O(`Insert %s columns`,t.toString())},isVisible:hN,icon:`o-spreadsheet-Icon.INSERT_COL_BEFORE`},$N={name:e=>{let t=CP(e);return t===1?O(`Insert column right`):O(`Insert %s columns right`,t.toString())},execute:YM,isVisible:e=>gN(e,`COL`),icon:`o-spreadsheet-Icon.INSERT_COL_AFTER`},eP={...$N,name:e=>{let t=CP(e);return t===1?O(`Column right`):O(`%s Columns right`,t.toString())},execute:YM},tP={name:O(`Insert cells`),isVisible:e=>hN(e)&&e.model.getters.getActiveCols().size===0&&e.model.getters.getActiveRows().size===0,icon:`o-spreadsheet-Icon.INSERT_CELL`},nP={name:O(`Insert cells and shift down`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`INSERT_CELL`,{zone:t,shiftDimension:`ROW`}))},isVisible:e=>e.model.getters.getActiveRows().size===0&&e.model.getters.getActiveCols().size===0,icon:`o-spreadsheet-Icon.INSERT_CELL_SHIFT_DOWN`},rP={name:O(`Insert cells and shift right`),execute:e=>{let t=e.model.getters.getSelectedZone();Wj(e,e.model.dispatch(`INSERT_CELL`,{zone:t,shiftDimension:`COL`}))},isVisible:e=>e.model.getters.getActiveRows().size===0&&e.model.getters.getActiveCols().size===0,icon:`o-spreadsheet-Icon.INSERT_CELL_SHIFT_RIGHT`},iP={name:O(`Chart`),execute:QM,icon:`o-spreadsheet-Icon.INSERT_CHART`},aP={name:O(`Pivot table`),execute:$M,icon:`o-spreadsheet-Icon.PIVOT`},oP={name:O(`Image`),description:`Ctrl+O`,execute:rN,isVisible:e=>e.imageProvider!==void 0,icon:`o-spreadsheet-Icon.INSERT_IMAGE`},sP={name:()=>O(`Table`),execute:pN,isVisible:e=>uN(e)&&!e.model.getters.getFirstTableInSelection(),icon:`o-spreadsheet-Icon.PAINT_TABLE`},cP={name:O(`Function`),icon:`o-spreadsheet-Icon.FORMULA`},lP={name:O(`SUM`),execute:e=>e.startCellEdition(`=SUM(`)},uP={name:O(`AVERAGE`),execute:e=>e.startCellEdition(`=AVERAGE(`)},dP={name:O(`COUNT`),execute:e=>e.startCellEdition(`=COUNT(`)},fP={name:O(`MAX`),execute:e=>e.startCellEdition(`=MAX(`)},pP={name:O(`MIN`),execute:e=>e.startCellEdition(`=MIN(`)},mP={name:O(`All`),children:[hP]};function hP(){return xP(ix.getKeys().filter(e=>!ix.get(e).hidden))}let gP=()=>{let e=ix.content;return[...new Set(ix.getAll().filter(e=>!e.hidden).map(e=>e.category))].filter(C).sort().map((t,n)=>({name:t,children:xP(Object.keys(e).filter(n=>e[n].category===t&&!e[n].hidden))}))},_P={name:O(`Link`),execute:oN,icon:`o-spreadsheet-Icon.INSERT_LINK`},vP={name:O(`Checkbox`),execute:e=>{let t=e.model.getters.getSelectedZones(),n=e.model.getters.getActiveSheetId(),r=t.map(t=>e.model.getters.getRangeDataFromZone(n,t));e.model.dispatch(`ADD_DATA_VALIDATION_RULE`,{ranges:r,sheetId:n,rule:{id:e.model.uuidGenerator.smallUuid(),criterion:{type:`isBoolean`,values:[]}}})},icon:`o-spreadsheet-Icon.INSERT_CHECKBOX`},yP={name:O(`Dropdown list`),execute:e=>{let t=e.model.getters.getSelectedZones(),n=e.model.getters.getActiveSheetId(),r=t.map(t=>e.model.getters.getRangeDataFromZone(n,t)),i=e.model.uuidGenerator.smallUuid();e.model.dispatch(`ADD_DATA_VALIDATION_RULE`,{ranges:r,sheetId:n,rule:{id:i,criterion:{type:`isValueInList`,values:[],displayStyle:`arrow`}}});let a=e.model.getters.getDataValidationRule(n,i);a&&e.openSidePanel(`DataValidationEditor`,{rule:Xl(a,e.model.getters.getLocale()),onExit:()=>{e.openSidePanel(`DataValidation`)}})},icon:`o-spreadsheet-Icon.INSERT_DROPDOWN`},bP={name:O(`Insert sheet`),execute:e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSheetIds().indexOf(t)+1,r=e.model.uuidGenerator.smallUuid();e.model.dispatch(`CREATE_SHEET`,{sheetId:r,position:n,name:e.model.getters.getNextSheetName()}),e.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:t,sheetIdTo:r})},icon:`o-spreadsheet-Icon.INSERT_SHEET`};function xP(e){return e.sort().map((e,t)=>({name:e,sequence:t*10,execute:t=>t.startCellEdition(`=${e}(`)}))}function SP(e){let t=e.model.getters.getActiveRows();if(t.size)return t.size;{let t=e.model.getters.getSelectedZones()[0];return t.bottom-t.top+1}}function CP(e){let t=e.model.getters.getActiveCols();if(t.size)return t.size;{let t=e.model.getters.getSelectedZones()[0];return t.right-t.left+1}}let wP={name:O(`See pivot properties`),execute(e){let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);e.openSidePanel(`PivotSidePanel`,{pivotId:n})},isVisible:e=>{let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);return n&&e.model.getters.isExistingPivot(n)||!1},isReadonlyAllowed:!0,icon:`o-spreadsheet-Icon.PIVOT`},TP={name:O(`Ascending`),execute:e=>AP(e,`asc`),isActive:e=>jP(e,`asc`)},EP={name:O(`Descending`),execute:e=>AP(e,`desc`),isActive:e=>jP(e,`desc`)},DP={name:O(`No sorting`),execute:e=>AP(e,`none`),isActive:e=>jP(e,`none`)},OP={name:O(`Convert to individual formulas`),execute(e){let t=e.model.getters.getActivePosition(),n=e.model.getters.getCorrespondingFormulaCell(t),r=e.model.getters.getPivotIdFromPosition(t);if(!n||!r)return;let{sheetId:i,col:a,row:o}=e.model.getters.getCellPosition(n.id),s=e.model.getters.getPivot(r);s.init(),s.isValid()&&e.model.dispatch(`SPLIT_PIVOT_FORMULA`,{sheetId:i,col:a,row:o,pivotId:r})},isVisible:e=>{let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);if(!n)return!1;let r=e.model.getters.getPivot(n),i=e.model.getters.getEvaluatedCell(t);return r.isValid()&&e.model.getters.isSpillPivotFormula(t)&&i.type!==`error`},icon:`o-spreadsheet-Icon.PIVOT`};function kP(e){let t=e.model.getters.getActivePosition(),n=e.model.getters.getPivotIdFromPosition(t);if(!n||!e.model.getters.isExistingPivot(n)||!e.model.getters.isSpillPivotFormula(t)||!e.model.getters.getPivot(n).isValid())return!1;let r=e.model.getters.getPivotCellFromPosition(t);return r.type===`VALUE`||r.type===`MEASURE_HEADER`}function AP(e,t){let n=e.model.getters.getActivePosition(),r=e.model.getters.getPivotIdFromPosition(n),i=e.model.getters.getPivotCellFromPosition(n);if(i.type===`EMPTY`||i.type===`HEADER`||!r)return;if(t===`none`){e.model.dispatch(`UPDATE_PIVOT`,{pivotId:r,pivot:{...e.model.getters.getPivotCoreDefinition(r),sortedColumn:void 0}});return}let a=ju(e.model.getters.getPivot(r),i.domain).colDomain;e.model.dispatch(`UPDATE_PIVOT`,{pivotId:r,pivot:{...e.model.getters.getPivotCoreDefinition(r),sortedColumn:{domain:a,order:t,measure:i.measure}}})}function jP(e,t){let n=e.model.getters.getActivePosition(),r=e.model.getters.getPivotIdFromPosition(n),i=e.model.getters.getPivotCellFromPosition(n);if(i.type===`EMPTY`||i.type===`HEADER`||!r)return!1;let a=e.model.getters.getPivot(r),o=ju(a,i.domain).colDomain,s=a.definition.sortedColumn;return t===`none`?!s:!s||s.order!==t?!1:s.measure===i.measure&&w(s.domain,o)}let MP=new ZD;MP.add(`cut`,{...xN,sequence:10}).add(`copy`,{...bN,sequence:20}).add(`paste`,{...SN,sequence:30}).add(`paste_special`,{...CN,sequence:40,separator:!0}).addChild(`paste_value_only`,[`paste_special`],{...wN,sequence:10}).addChild(`paste_format_only`,[`paste_special`],{...TN,sequence:20}).add(`add_row_before`,{...KN,sequence:70}).add(`add_column_before`,{...QN,sequence:90}).add(`insert_cell`,{...tP,sequence:100,separator:!0}).addChild(`insert_cell_down`,[`insert_cell`],{...nP,name:O(`Shift down`),sequence:10}).addChild(`insert_cell_right`,[`insert_cell`],{...rP,name:O(`Shift right`),sequence:20}).add(`delete_row`,{...kN,sequence:110,icon:`o-spreadsheet-Icon.TRASH`}).add(`delete_column`,{...MN,sequence:120,icon:`o-spreadsheet-Icon.TRASH`}).add(`delete_cell`,{...PN,sequence:130,separator:!0,icon:`o-spreadsheet-Icon.TRASH`}).addChild(`delete_cell_up`,[`delete_cell`],{...FN,name:O(`Shift up`),sequence:10,icon:`o-spreadsheet-Icon.DELETE_CELL_SHIFT_UP`}).addChild(`delete_cell_left`,[`delete_cell`],{...IN,name:O(`Shift left`),sequence:20,icon:`o-spreadsheet-Icon.DELETE_CELL_SHIFT_LEFT`}).add(`edit_table`,{...RN,isVisible:lN,sequence:140}).add(`delete_table`,{...zN,isVisible:lN,sequence:145,separator:!0}).add(`insert_link`,{..._P,name:sN,sequence:150,separator:!0}).add(`pivot_sorting`,{name:O(`Sort pivot`),sequence:155,icon:`o-spreadsheet-Icon.SORT_RANGE`,isVisible:kP}).add(`pivot_fix_formulas`,{...OP,sequence:160}).add(`pivot_properties`,{...wP,sequence:170,separator:!0}).addChild(`pivot_sorting_asc`,[`pivot_sorting`],{...TP,sequence:10}).addChild(`pivot_sorting_desc`,[`pivot_sorting`],{...EP,sequence:20}).addChild(`pivot_sorting_none`,[`pivot_sorting`],{...DP,sequence:30});let NP={name:O(`Sort range`),isVisible:hN,icon:`o-spreadsheet-Icon.SORT_RANGE`},PP={name:O(`Ascending (A ⟶ Z)`),execute:e=>{let{anchor:t,zones:n}=e.model.getters.getSelection();Eg(e,e.model.getters.getActiveSheetId(),t.cell,n[0],`asc`)},icon:`o-spreadsheet-Icon.SORT_ASCENDING`},FP={name:O(`Data cleanup`),icon:`o-spreadsheet-Icon.DATA_CLEANUP`},IP={name:O(`Remove duplicates`),execute:e=>{Nr(e.model.getters.getSelectedZone())===1&&e.model.selection.selectTableAroundSelection(),e.openSidePanel(`RemoveDuplicates`,{})}},LP={name:O(`Trim whitespace`),execute:e=>{e.model.dispatch(`TRIM_WHITESPACE`)}},RP={name:O(`Descending (Z ⟶ A)`),execute:e=>{let{anchor:t,zones:n}=e.model.getters.getSelection();Eg(e,e.model.getters.getActiveSheetId(),t.cell,n[0],`desc`)},icon:`o-spreadsheet-Icon.SORT_DESCENDING`},zP={..._N},BP={..._N,isActive:e=>cN(e)},VP={name:O(`Split text to columns`),sequence:1,execute:e=>e.openSidePanel(`SplitToColumns`,{}),isEnabled:e=>e.model.getters.isSingleColSelected(),icon:`o-spreadsheet-Icon.SPLIT_TEXT`},HP={id:`reinsert_dynamic_pivot`,name:O(`Re-insert dynamic pivot`),sequence:60,icon:`o-spreadsheet-Icon.INSERT_PIVOT`,children:[eN],isVisible:e=>e.model.getters.getPivotIds().some(t=>e.model.getters.getPivot(t).isValid())},UP={id:`reinsert_static_pivot`,name:O(`Re-insert static pivot`),sequence:70,icon:`o-spreadsheet-Icon.INSERT_PIVOT`,children:[tN],isVisible:e=>e.model.getters.getPivotIds().some(t=>e.model.getters.getPivot(t).isValid())};function WP({name:e,format:t,descriptionValue:n}){let r=typeof t==`function`?t:()=>t;return{name:e,description:e=>B(n,{format:r(e),locale:e.model.getters.getLocale()}),execute:e=>kM(e,r(e)),isActive:e=>BF(e,r(e)),format:t}}let GP={name:O(`Automatic`),execute:e=>kM(e,``),isActive:e=>zF(e)},KP={name:O(`Plain text`),execute:e=>kM(e,`@`),isActive:e=>BF(e,`@`)},qP=WP({name:O(`Number`),descriptionValue:1000.12,format:`#,##0.00`}),JP={name:O(`Format as percent`),execute:iN,icon:`o-spreadsheet-Icon.PERCENT`},YP=WP({name:O(`Percent`),descriptionValue:.1012,format:`0.00%`}),XP=WP({name:O(`Currency`),descriptionValue:1000.12,format:e=>gs(e.model.config.defaultCurrency||tt)}),ZP={...WP({name:O(`Currency rounded`),descriptionValue:1e3,format:e=>bs(gs(e.model.config.defaultCurrency||tt))}),isVisible:e=>{let t=gs(e.model.config.defaultCurrency||tt);return t!==bs(t)}},QP=WP({name:O(`Accounting`),descriptionValue:-1000.12,format:e=>_s(e.model.config.defaultCurrency||tt)}),$P=Ns(`2023/09/26 10:43:00 PM`,k),eF={name:O(`Custom currency`),isVisible:e=>e.loadCurrencies!==void 0,execute:e=>e.openSidePanel(`CustomCurrency`,{})},tF=WP({name:O(`Date`),descriptionValue:$P,format:e=>e.model.getters.getLocale().dateFormat}),nF=WP({name:O(`Time`),descriptionValue:$P,format:e=>e.model.getters.getLocale().timeFormat}),rF=WP({name:O(`Date time`),descriptionValue:$P,format:e=>$l(e.model.getters.getLocale())}),iF=WP({name:O(`Duration`),descriptionValue:`27:51:38`,format:`hhhh:mm:ss`}),aF=WP({name:O(`Quarter`),descriptionValue:$P,format:`qq yyyy`}),oF=WP({name:O(`Full quarter`),descriptionValue:$P,format:`qqqq yyyy`}),sF={name:O(`More date formats`),execute:e=>e.openSidePanel(`MoreFormats`,{})},cF=WP({name:O(`Full date time`),format:`dddd d mmmm yyyy hh:mm:ss a`,descriptionValue:$P}),lF=WP({name:O(`Full week day and month`),format:`dddd d mmmm yyyy`,descriptionValue:$P}),uF=WP({name:O(`Day and full month`),format:`d mmmm yyyy`,descriptionValue:$P}),dF=WP({name:O(`Short week day`),format:`ddd d mmm yyyy`,descriptionValue:$P}),fF=WP({name:O(`Day and short month`),format:`d mmm yyyy`,descriptionValue:$P}),pF=WP({name:O(`Full month`),format:`mmmm yyyy`,descriptionValue:$P}),mF=WP({name:O(`Short month`),format:`mmm yyyy`,descriptionValue:$P}),hF={name:O(`Increase decimal places`),icon:`o-spreadsheet-Icon.INCREASE_DECIMAL`,execute:e=>e.model.dispatch(`SET_DECIMAL`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:1})},gF={name:O(`Decrease decimal places`),icon:`o-spreadsheet-Icon.DECRASE_DECIMAL`,execute:e=>e.model.dispatch(`SET_DECIMAL`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones(),step:-1})},_F={name:O(`Bold`),description:`Ctrl+B`,execute:e=>AM(e,{bold:!e.model.getters.getCurrentStyle().bold}),icon:`o-spreadsheet-Icon.BOLD`,isActive:e=>!!e.model.getters.getCurrentStyle().bold},vF={name:O(`Italic`),description:`Ctrl+I`,execute:e=>AM(e,{italic:!e.model.getters.getCurrentStyle().italic}),icon:`o-spreadsheet-Icon.ITALIC`,isActive:e=>!!e.model.getters.getCurrentStyle().italic},yF={name:O(`Underline`),description:`Ctrl+U`,execute:e=>AM(e,{underline:!e.model.getters.getCurrentStyle().underline}),icon:`o-spreadsheet-Icon.UNDERLINE`,isActive:e=>!!e.model.getters.getCurrentStyle().underline},bF={name:O(`Strikethrough`),execute:e=>AM(e,{strikethrough:!e.model.getters.getCurrentStyle().strikethrough}),icon:`o-spreadsheet-Icon.STRIKE`,isActive:e=>!!e.model.getters.getCurrentStyle().strikethrough},xF={name:O(`Font size`),children:RF(),icon:`o-spreadsheet-Icon.FONT_SIZE`},SF={name:O(`Alignment`),icon:`o-spreadsheet-Icon.ALIGN_LEFT`},CF={name:O(`Horizontal align`),icon:e=>GF(e)},wF={name:O(`Left`),description:`Ctrl+Shift+L`,execute:e=>AM(e,{align:`left`}),isActive:e=>HF(e)===`left`,icon:`o-spreadsheet-Icon.ALIGN_LEFT`},TF={name:O(`Center`),description:`Ctrl+Shift+E`,execute:e=>AM(e,{align:`center`}),isActive:e=>HF(e)===`center`,icon:`o-spreadsheet-Icon.ALIGN_CENTER`},EF={name:O(`Right`),description:`Ctrl+Shift+R`,execute:e=>AM(e,{align:`right`}),isActive:e=>HF(e)===`right`,icon:`o-spreadsheet-Icon.ALIGN_RIGHT`},DF={name:O(`Vertical align`),icon:e=>KF(e)},OF={name:O(`Top`),execute:e=>AM(e,{verticalAlign:`top`}),isActive:e=>UF(e)===`top`,icon:`o-spreadsheet-Icon.ALIGN_TOP`},kF={name:O(`Middle`),execute:e=>AM(e,{verticalAlign:`middle`}),isActive:e=>UF(e)===`middle`,icon:`o-spreadsheet-Icon.ALIGN_MIDDLE`},AF={name:O(`Bottom`),execute:e=>AM(e,{verticalAlign:`bottom`}),isActive:e=>UF(e)===`bottom`,icon:`o-spreadsheet-Icon.ALIGN_BOTTOM`},jF={name:O(`Wrapping`),icon:`o-spreadsheet-Icon.WRAPPING_OVERFLOW`},MF={name:O(`Wrapping`),icon:e=>qF(e)},NF={name:O(`Overflow`),execute:e=>AM(e,{wrapping:`overflow`}),isActive:e=>WF(e)===`overflow`,icon:`o-spreadsheet-Icon.WRAPPING_OVERFLOW`},PF={name:O(`Wrap`),execute:e=>AM(e,{wrapping:`wrap`}),isActive:e=>WF(e)===`wrap`,icon:`o-spreadsheet-Icon.WRAPPING_WRAP`},FF={name:O(`Clip`),execute:e=>AM(e,{wrapping:`clip`}),isActive:e=>WF(e)===`clip`,icon:`o-spreadsheet-Icon.WRAPPING_CLIP`};O(`Text Color`),O(`Fill Color`);let IF={name:O(`Conditional formatting`),execute:aN,icon:`o-spreadsheet-Icon.CONDITIONAL_FORMAT`},LF={name:O(`Clear formatting`),description:`Ctrl+<`,execute:e=>e.model.dispatch(`CLEAR_FORMATTING`,{sheetId:e.model.getters.getActiveSheetId(),target:e.model.getters.getSelectedZones()}),icon:`o-spreadsheet-Icon.CLEAR_FORMAT`};function RF(){return $e.map(e=>({name:e.toString(),sequence:e,id:`font_size_${e}`,execute:t=>AM(t,{fontSize:e}),isActive:t=>VF(t,e)}))}function zF(e){let t=e.model.getters.getActivePosition();return e.model.getters.getPivotCellFromPosition(t).type===`VALUE`?!e.model.getters.getEvaluatedCell(t).format:!e.model.getters.getCell(t)?.format}function BF(e,t){let n=e.model.getters.getActivePosition();return e.model.getters.getPivotCellFromPosition(n).type===`VALUE`?e.model.getters.getEvaluatedCell(n).format===t:e.model.getters.getCell(n)?.format===t}function VF(e,t){return(e.model.getters.getCurrentStyle().fontSize||Be)===t}function HF(e){let t=e.model.getters.getCurrentStyle();return t.align?t.align:e.model.getters.getActiveCell().defaultAlign}function UF(e){let t=e.model.getters.getCurrentStyle();return t.verticalAlign?t.verticalAlign:Re}function WF(e){let t=e.model.getters.getCurrentStyle();return t.wrapping?t.wrapping:ze}function GF(e){switch(HF(e)){case`right`:return`o-spreadsheet-Icon.ALIGN_RIGHT`;case`center`:return`o-spreadsheet-Icon.ALIGN_CENTER`;default:return`o-spreadsheet-Icon.ALIGN_LEFT`}}function KF(e){switch(UF(e)){case`top`:return`o-spreadsheet-Icon.ALIGN_TOP`;case`middle`:return`o-spreadsheet-Icon.ALIGN_MIDDLE`;default:return`o-spreadsheet-Icon.ALIGN_BOTTOM`}}function qF(e){switch(WF(e)){case`wrap`:return`o-spreadsheet-Icon.WRAPPING_WRAP`;case`clip`:return`o-spreadsheet-Icon.WRAPPING_CLIP`;default:return`o-spreadsheet-Icon.WRAPPING_OVERFLOW`}}function JF(e,t,n){let r=e.model.getters.getActiveSheetId(),i=t===`COL`?`FREEZE_COLUMNS`:`FREEZE_ROWS`;e.model.dispatch(i,{sheetId:r,quantity:n}).isCancelledBecause(`MergeOverlap`)&&e.raiseError(fw)}var YF=class{map={};constructor(e=[]){for(let[t,n]of e)this.set(t,n)}set({sheetId:e,col:t,row:n},r){let i=this.map;i[e]||(i[e]={}),i[e][t]||(i[e][t]={}),i[e][t][n]=r}get({sheetId:e,col:t,row:n}){return this.map[e]?.[t]?.[n]}getSheet(e){return this.map[e]}has({sheetId:e,col:t,row:n}){return this.map[e]?.[t]?.[n]!==void 0}delete({sheetId:e,col:t,row:n}){delete this.map[e]?.[t]?.[n]}keys(){let e=this.map,t=[];for(let n in e)for(let r in e[n])for(let i in e[n][r])t.push({sheetId:n,col:parseInt(r),row:parseInt(i)});return t}keysForSheet(e){let t=this.map[e];if(!t)return[];let n=[];for(let r in t)for(let i in t[r])n.push({sheetId:e,col:parseInt(r),row:parseInt(i)});return n}*entries(){let e=this.map;for(let t of this.keys()){let{sheetId:n,col:r,row:i}=t;yield[t,e[n][r][i]]}}},XF=class extends ef{mutators=[`enable`,`disable`];isInvalidated=!1;fingerprintColors={[QF]:`#D9D9D9`};isEnabled=!1;colors=new YF;handle(e){switch(ca(e)&&this.isEnabled&&(this.isInvalidated=!0),e.type){case`UNDO`:case`REDO`:case`ACTIVATE_SHEET`:this.isEnabled&&(this.isInvalidated=!0);break}}finalize(){this.isInvalidated&&(this.isInvalidated=!1,this.computeFingerprints())}enable(){this.isEnabled=!0,this.computeFingerprints()}disable(){this.isEnabled=!1,this.colors=new YF}computeFingerprints(){this.colors=new YF;let e=new YF,t=new Set,n=this.getters.getActiveSheetId(),r=this.getters.getCells(n);for(let n in r){let i=this.computeFingerprint(r[n]);if(!i)continue;t.add(i);let a=this.getters.getCellPosition(n);e.set(a,i)}this.assignColors(t);for(let[t,n]of e.entries()){let e=this.fingerprintColors[n];this.colors.set(t,e),this.colorSpreadZone(t,e)}}colorSpreadZone(e,t){let n=this.getters.getSpreadZone(e);if(!n)return;let r=e.sheetId;for(let e=n.top;e<=n.bottom;e++)for(let i=n.left;i<=n.right;i++){let n={sheetId:r,col:i,row:e};this.colors.set(n,t)}}assignColors(e){let t=new Fn(e.size);Object.keys(this.fingerprintColors).forEach(()=>t.next());for(let n of e)this.fingerprintColors[n]||(this.fingerprintColors[n]=xn(t.next(),.8))}computeFingerprint(e){let t=this.getters.getCellPosition(e.id);return e.isFormula?this.computeFormulaFingerprint(t,e):this.getLiteralFingerprint(t)}computeFormulaFingerprint(e,t){let n=t.compiledFormula.dependencies,r=e.col,i=e.row,a=this.getters.getSheetIds().indexOf(e.sheetId),o={dx:0,dy:0,dSheet:0};for(let e of n){let t=e.zone,[n,s]=e.parts;o.dSheet=this.getters.getSheetIds().indexOf(e.sheetId)-a;let c=dc(e)&&!e.unboundedZone.hasHeader,l=uc(e)&&!e.unboundedZone.hasHeader,u=c||n?.colFixed?0:r,d=l||n?.rowFixed?0:i,f=!s&&n?.colFixed||s?.colFixed,p=!s&&n.rowFixed||s?.rowFixed,m=e.unboundedZone.right===void 0,h=e.unboundedZone.bottom===void 0,g=m||f?0:r,_=h||p?0:i,v=Tr({top:t.top-d,left:t.left-u,right:t.right-g,bottom:t.bottom-_});for(let e=v.top;e<=v.bottom;e++)for(let t=v.left;t<=v.right;t++)o.dx+=t,o.dy+=e}let s=t.compiledFormula.normalizedFormula;return ZF(o)+s}getLiteralFingerprint(e){switch(this.getters.getEvaluatedCell(e).type){case`number`:case`boolean`:return QF;case`text`:case`empty`:case`error`:return}}};function ZF(e){return Object.entries(e).sort(([e],[t])=>e.localeCompare(t)).map(([e,t])=>t).join(`,`)}let QF=`DATA_FINGERPRINT`,$F={name:XM,execute:e=>{let t=e.model.getters.getElementsFromSelection(`COL`);e.model.dispatch(`HIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`COL`,elements:t})},isVisible:GM,icon:`o-spreadsheet-Icon.HIDE_COL`},eI={name:O(`Unhide columns`),execute:e=>{let t=e.model.getters.getElementsFromSelection(`COL`);e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`COL`,elements:t})},isVisible:e=>{let t=e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection(`COL`).some(e=>t.includes(e))},icon:`o-spreadsheet-Icon.UNHIDE_COL`},tI={name:O(`Unhide all columns`),execute:e=>{let t=e.model.getters.getActiveSheetId();e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:t,dimension:`COL`,elements:Array.from(Array(e.model.getters.getNumberCols(t)).keys())})},isVisible:e=>e.model.getters.getHiddenColsGroups(e.model.getters.getActiveSheetId()).length>0,icon:`o-spreadsheet-Icon.UNHIDE_COL`},nI={name:ZM,execute:e=>{let t=e.model.getters.getElementsFromSelection(`ROW`);e.model.dispatch(`HIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`ROW`,elements:t})},isVisible:UM,icon:`o-spreadsheet-Icon.HIDE_ROW`},rI={name:O(`Unhide rows`),execute:e=>{let t=e.model.getters.getElementsFromSelection(`ROW`);e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId(),dimension:`ROW`,elements:t})},isVisible:e=>{let t=e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).flat();return e.model.getters.getElementsFromSelection(`ROW`).some(e=>t.includes(e))},icon:`o-spreadsheet-Icon.UNHIDE_ROW`},iI={name:O(`Unhide all rows`),execute:e=>{let t=e.model.getters.getActiveSheetId();e.model.dispatch(`UNHIDE_COLUMNS_ROWS`,{sheetId:t,dimension:`ROW`,elements:Array.from(Array(e.model.getters.getNumberRows(t)).keys())})},isVisible:e=>e.model.getters.getHiddenRowsGroups(e.model.getters.getActiveSheetId()).length>0,icon:`o-spreadsheet-Icon.UNHIDE_ROW`},aI={name:O(`Unfreeze`),isVisible:e=>{let{xSplit:t,ySplit:n}=e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId());return t+n>0},execute:e=>e.model.dispatch(`UNFREEZE_COLUMNS_ROWS`,{sheetId:e.model.getters.getActiveSheetId()}),icon:`o-spreadsheet-Icon.UNFREEZE`},oI={name:O(`Freeze`),icon:`o-spreadsheet-Icon.FREEZE`},sI={name:O(`No rows`),execute:e=>e.model.dispatch(`UNFREEZE_ROWS`,{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).ySplit},cI={name:O(`1 row`),execute:e=>JF(e,`ROW`,1),isReadonlyAllowed:!0},lI={name:O(`2 rows`),execute:e=>JF(e,`ROW`,2),isReadonlyAllowed:!0},uI={name:O(`Up to current row`),execute:e=>{let{bottom:t}=e.model.getters.getSelectedZone();JF(e,`ROW`,t+1)},isReadonlyAllowed:!0},dI={name:O(`No columns`),execute:e=>e.model.dispatch(`UNFREEZE_COLUMNS`,{sheetId:e.model.getters.getActiveSheetId()}),isReadonlyAllowed:!0,isVisible:e=>!!e.model.getters.getPaneDivisions(e.model.getters.getActiveSheetId()).xSplit},fI={name:O(`1 column`),execute:e=>JF(e,`COL`,1),isReadonlyAllowed:!0},pI={name:O(`2 columns`),execute:e=>JF(e,`COL`,2),isReadonlyAllowed:!0},mI={name:O(`Up to current column`),execute:e=>{let{right:t}=e.model.getters.getSelectedZone();JF(e,`COL`,t+1)},isReadonlyAllowed:!0},hI={name:O(`Gridlines`),execute:e=>{let t=e.model.getters.getActiveSheetId();e.model.dispatch(`SET_GRID_LINES_VISIBILITY`,{sheetId:t,areGridLinesVisible:!e.model.getters.getGridLinesVisibility(t)})},isActive:e=>{let t=e.model.getters.getActiveSheetId();return e.model.getters.getGridLinesVisibility(t)}},gI={name:O(`Irregularity map`),execute:e=>{let t=e.getStore(XF);t.isEnabled?t.disable():t.enable()},isReadonlyAllowed:!0,icon:`o-spreadsheet-Icon.IRREGULARITY_MAP`},_I={name:O(`Formulas`),isActive:e=>e.model.getters.shouldShowFormulas(),execute:e=>e.model.dispatch(`SET_FORMULA_VISIBILITY`,{show:!e.model.getters.shouldShowFormulas()}),isReadonlyAllowed:!0},vI={name:e=>{let t=e.model.getters.getSelectedZone();return t.left===t.right?O(`Group column %s`,zn(t.left)):O(`Group columns %s - %s`,zn(t.left),zn(t.right))},execute:e=>SI(e,`COL`),isVisible:e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSelectedZone(),r=e.model.getters.getHeaderGroupsInZone(t,`COL`,n);return hN(e)&&!r.some(e=>e.start===n.left&&e.end===n.right)},icon:`o-spreadsheet-Icon.GROUP_COLUMNS`},yI={name:e=>{let t=e.model.getters.getSelectedZone();return t.top===t.bottom?O(`Group row %s`,String(t.top+1)):O(`Group rows %s - %s`,String(t.top+1),String(t.bottom+1))},execute:e=>SI(e,`ROW`),isVisible:e=>{let t=e.model.getters.getActiveSheetId(),n=e.model.getters.getSelectedZone(),r=e.model.getters.getHeaderGroupsInZone(t,`ROW`,n);return hN(e)&&!r.some(e=>e.start===n.top&&e.end===n.bottom)},icon:`o-spreadsheet-Icon.GROUP_ROWS`},bI={name:e=>{let t=e.model.getters.getSelectedZone();return t.left===t.right?O(`Ungroup column %s`,zn(t.left)):O(`Ungroup columns %s - %s`,zn(t.left),zn(t.right))},execute:e=>CI(e,`COL`),icon:`o-spreadsheet-Icon.UNGROUP_COLUMNS`},xI={name:e=>{let t=e.model.getters.getSelectedZone();return t.top===t.bottom?O(`Ungroup row %s`,String(t.top+1)):O(`Ungroup rows %s - %s`,String(t.top+1),String(t.bottom+1))},execute:e=>CI(e,`ROW`),icon:`o-spreadsheet-Icon.UNGROUP_ROWS`};function SI(e,t){let n=e.model.getters.getSelectedZone(),r=e.model.getters.getActiveSheetId();e.model.dispatch(`GROUP_HEADERS`,{sheetId:r,dimension:t,start:t===`COL`?n.left:n.top,end:t===`COL`?n.right:n.bottom})}function CI(e,t){let n=e.model.getters.getSelectedZone(),r=e.model.getters.getActiveSheetId();e.model.dispatch(`UNGROUP_HEADERS`,{sheetId:r,dimension:t,start:t===`COL`?n.left:n.top,end:t===`COL`?n.right:n.bottom})}function wI(e,t){let n=e.model.getters.getActiveSheetId(),r=e.model.getters.getSelectedZones();return r.length===1&&e.model.getters.getHeaderGroupsInZone(n,t,r[0]).length>0}let TI=new ZD;TI.add(`cut`,{...xN,sequence:10}).add(`copy`,{...bN,sequence:20}).add(`paste`,{...SN,sequence:30}).add(`paste_special`,{...CN,sequence:40,separator:!0}).addChild(`paste_value_only`,[`paste_special`],{...wN,sequence:10}).addChild(`paste_format_only`,[`paste_special`],{...TN,sequence:20}).add(`sort_columns`,{...NP,name:e=>e.model.getters.getActiveCols().size>1?O(`Sort columns`):O(`Sort column`),sequence:50,separator:!0}).addChild(`sort_ascending`,[`sort_columns`],{...PP,sequence:10}).addChild(`sort_descending`,[`sort_columns`],{...RP,sequence:20}).add(`add_column_before`,{...XN,sequence:70}).add(`add_column_after`,{...$N,sequence:80}).add(`delete_column`,{...jN,sequence:90,icon:`o-spreadsheet-Icon.TRASH`}).add(`clear_column`,{...NN,sequence:100,icon:`o-spreadsheet-Icon.CLEAR`}).add(`hide_columns`,{...$F,sequence:105,separator:!0}).add(`unhide_columns`,{...eI,sequence:106,separator:!0}).add(`conditional_formatting`,{...IF,sequence:110,separator:!0}).add(`edit_table`,{...RN,isVisible:lN,sequence:120}).add(`delete_table`,{...zN,isVisible:lN,sequence:125,separator:!0}).add(`group_columns`,{sequence:150,...vI}).add(`ungroup_columns`,{sequence:155,...bI,isVisible:e=>wI(e,`COL`)});let EI=new h;EI.add(`format_number_automatic`,{...GP,id:`format_number_automatic`,sequence:10}).add(`format_number_plain_text`,{...KP,id:`format_number_plain_text`,sequence:15,separator:!0}).add(`format_number_number`,{...qP,id:`format_number_number`,sequence:20}).add(`format_number_percent`,{...YP,id:`format_number_percent`,sequence:30,separator:!0}).add(`format_number_currency`,{...XP,id:`format_number_currency`,sequence:40}).add(`format_number_accounting`,{...QP,id:`format_number_accounting`,sequence:45}).add(`format_number_currency_rounded`,{...ZP,id:`format_number_currency_rounded`,sequence:50}).add(`format_custom_currency`,{...eF,id:`format_custom_currency`,sequence:60,separator:!0}).add(`format_number_date`,{...tF,id:`format_number_date`,sequence:70}).add(`format_number_time`,{...nF,id:`format_number_time`,sequence:80}).add(`format_number_date_time`,{...rF,id:`format_number_date_time`,sequence:90}).add(`format_number_duration`,{...iF,id:`format_number_duration`,sequence:100,separator:!0}).add(`more_formats`,{...sF,id:`more_formats`,sequence:120});function DI(e){let t=new Set(EI.getAll().map(t=>typeof t.format==`function`?t.format(e):t.format)),n=new Map;for(let r of e.model.getters.getSheetIds()){let i=e.model.getters.getEvaluatedCells(r);for(let e in i){let r=i[e];if(r.format&&!n.has(r.format)&&!t.has(r.format)){let e=OI(r.format);(e===`date`||e===`currency`)&&n.set(r.format,WP({descriptionValue:e===`currency`?1e3:$P,format:r.format,name:r.format}))}}}return[...n.values()]}let OI=Vt(e=>ls(e)?`date`:e.includes(`[$`)?`currency`:`number`),kI={name:O(`More formats`),icon:`o-spreadsheet-Icon.NUMBER_FORMATS`,children:[e=>{let t=DI(e).map(e=>({...e,sequence:110}));return t.length>0&&(t[t.length-1].separator=!0),f([...EI.getAll(),...t])}]},AI=new ZD;AI.add(`cut`,{...xN,sequence:10}).add(`copy`,{...bN,sequence:20}).add(`paste`,{...SN,sequence:30}).add(`paste_special`,{...CN,sequence:40,separator:!0}).addChild(`paste_value_only`,[`paste_special`],{...wN,sequence:10}).addChild(`paste_format_only`,[`paste_special`],{...TN,sequence:20}).add(`add_row_before`,{...WN,sequence:50}).add(`add_row_after`,{...qN,sequence:60}).add(`delete_row`,{...ON,sequence:70,icon:`o-spreadsheet-Icon.TRASH`}).add(`clear_row`,{...AN,sequence:80,icon:`o-spreadsheet-Icon.CLEAR`}).add(`hide_rows`,{...nI,sequence:85,separator:!0}).add(`unhide_rows`,{...rI,sequence:86,separator:!0}).add(`conditional_formatting`,{...IF,sequence:90,separator:!0}).add(`group_rows`,{sequence:100,...yI}).add(`ungroup_rows`,{sequence:110,...xI,isVisible:e=>wI(e,`ROW`)});function jI(e){let t=new ZD;return t.add(`delete`,{...aM,sequence:10}).add(`hide_sheet`,{...dM,sequence:20}).add(`duplicate`,{...oM,sequence:30,separator:!0}).add(`rename`,{...sM(e),sequence:40}).add(`change_color`,{...cM(e),sequence:50,separator:!0}).add(`move_right`,{...lM,sequence:60}).add(`move_left`,{...uM,sequence:70}),t}function MI(e,t){let n=e.getActiveSheetId();return zr(NI(e,t).map(E)).map(e=>({sheetId:n,zone:e,noFill:!0,color:_}))}function NI(e,t){let n=[],r=e.getActiveSheetId();for(let i of e.getSheetViewVisibleCols())for(let a of e.getSheetViewVisibleRows()){let o={sheetId:r,col:i,row:a};t===e.getPivotIdFromPosition(o)&&n.push(o)}return n}let PI=new ZD;PI.add(`file`,{name:O(`File`),sequence:10}).addChild(`settings`,[`file`],{name:O(`Settings`),sequence:100,execute:e=>e.openSidePanel(`Settings`),icon:`o-spreadsheet-Icon.COG`}).add(`edit`,{name:O(`Edit`),sequence:20}).addChild(`undo`,[`edit`],{...vN,sequence:10}).addChild(`redo`,[`edit`],{...yN,sequence:20,separator:!0}).addChild(`copy`,[`edit`],{...bN,sequence:30}).addChild(`cut`,[`edit`],{...xN,sequence:40}).addChild(`paste`,[`edit`],{...SN,sequence:50}).addChild(`paste_special`,[`edit`],{...CN,sequence:60,separator:!0}).addChild(`paste_special_value`,[`edit`,`paste_special`],{...wN,sequence:10}).addChild(`paste_special_format`,[`edit`,`paste_special`],{...TN,sequence:20}).addChild(`edit_table`,[`edit`],{...RN,isVisible:lN,sequence:60}).addChild(`find_and_replace`,[`edit`],{...EN,sequence:65,separator:!0}).addChild(`delete`,[`edit`],{name:O(`Delete`),icon:`o-spreadsheet-Icon.TRASH`,sequence:70}).addChild(`edit_delete_cell_values`,[`edit`,`delete`],{...DN,sequence:10}).addChild(`edit_delete_row`,[`edit`,`delete`],{...ON,sequence:20}).addChild(`edit_delete_column`,[`edit`,`delete`],{...jN,sequence:30}).addChild(`edit_delete_cell_shift_up`,[`edit`,`delete`],{...FN,sequence:40}).addChild(`edit_delete_cell_shift_left`,[`edit`,`delete`],{...IN,sequence:50}).addChild(`edit_unhide_columns`,[`edit`],{...tI,sequence:80}).addChild(`edit_unhide_rows`,[`edit`],{...iI,sequence:80}).add(`view`,{name:O(`View`),sequence:30}).addChild(`unfreeze_panes`,[`view`],{...aI,sequence:4}).addChild(`freeze_panes`,[`view`],{...oI,sequence:5}).addChild(`unfreeze_rows`,[`view`,`freeze_panes`],{...sI,sequence:5}).addChild(`freeze_first_row`,[`view`,`freeze_panes`],{...cI,sequence:10}).addChild(`freeze_second_row`,[`view`,`freeze_panes`],{...lI,sequence:15}).addChild(`freeze_current_row`,[`view`,`freeze_panes`],{...uI,sequence:20,separator:!0}).addChild(`unfreeze_columns`,[`view`,`freeze_panes`],{...dI,sequence:25}).addChild(`freeze_first_col`,[`view`,`freeze_panes`],{...fI,sequence:30}).addChild(`freeze_second_col`,[`view`,`freeze_panes`],{...pI,sequence:35}).addChild(`freeze_current_col`,[`view`,`freeze_panes`],{...mI,sequence:40}).addChild(`group_headers`,[`view`],{name:O(`Group`),sequence:15,separator:!0,icon:`o-spreadsheet-Icon.PLUS_IN_BOX`,isVisible:hN}).addChild(`group_columns`,[`view`,`group_headers`],{...vI,sequence:5}).addChild(`ungroup_columns`,[`view`,`group_headers`],{...bI,isVisible:e=>wI(e,`COL`),sequence:10}).addChild(`group_rows`,[`view`,`group_headers`],{...yI,sequence:15}).addChild(`ungroup_rows`,[`view`,`group_headers`],{...xI,isVisible:e=>wI(e,`ROW`),sequence:20}).addChild(`show`,[`view`],{name:O(`Show`),sequence:1,icon:`o-spreadsheet-Icon.SHOW`}).addChild(`view_gridlines`,[`view`,`show`],{...hI,sequence:5}).addChild(`view_formulas`,[`view`,`show`],{..._I,sequence:10}).addChild(`view_irregularity_map`,[`view`],{...gI,sequence:40,separator:!0}).add(`insert`,{name:O(`Insert`),sequence:40}).addChild(`insert_row`,[`insert`],{...UN,sequence:10}).addChild(`insert_row_before`,[`insert`,`insert_row`],{...GN,sequence:10}).addChild(`insert_row_after`,[`insert`,`insert_row`],{...JN,sequence:20}).addChild(`insert_column`,[`insert`],{...YN,sequence:20}).addChild(`insert_column_before`,[`insert`,`insert_column`],{...ZN,sequence:10}).addChild(`insert_column_after`,[`insert`,`insert_column`],{...eP,sequence:20}).addChild(`insert_cell`,[`insert`],{...tP,sequence:30}).addChild(`insert_cell_down`,[`insert`,`insert_cell`],{...nP,name:O(`Shift down`),sequence:10}).addChild(`insert_cell_right`,[`insert`,`insert_cell`],{...rP,name:O(`Shift right`),sequence:20}).addChild(`insert_sheet`,[`insert`],{...bP,sequence:40,separator:!0}).addChild(`insert_chart`,[`insert`],{...iP,sequence:50}).addChild(`insert_pivot`,[`insert`],{...aP,sequence:52}).addChild(`insert_image`,[`insert`],{...oP,sequence:55}).addChild(`insert_table`,[`insert`],{...sP,sequence:57}).addChild(`insert_function`,[`insert`],{...cP,sequence:60}).addChild(`insert_function_sum`,[`insert`,`insert_function`],{...lP,sequence:0}).addChild(`insert_function_average`,[`insert`,`insert_function`],{...uP,sequence:10}).addChild(`insert_function_count`,[`insert`,`insert_function`],{...dP,sequence:20}).addChild(`insert_function_max`,[`insert`,`insert_function`],{...fP,sequence:30}).addChild(`insert_function_min`,[`insert`,`insert_function`],{...pP,sequence:40,separator:!0}).addChild(`categorie_function_all`,[`insert`,`insert_function`],{...mP,sequence:50}).addChild(`categories_function_list`,[`insert`,`insert_function`],gP).addChild(`insert_link`,[`insert`],{..._P,separator:!0,sequence:70}).addChild(`insert_checkbox`,[`insert`],{...vP,sequence:80}).addChild(`insert_dropdown`,[`insert`],{...yP,separator:!0,sequence:90}).add(`format`,{name:O(`Format`),sequence:50}).addChild(`format_number`,[`format`],{...kI,name:O(`Number`),sequence:10,separator:!0}).addChild(`format_bold`,[`format`],{..._F,sequence:20}).addChild(`format_italic`,[`format`],{...vF,sequence:30}).addChild(`format_underline`,[`format`],{...yF,sequence:40}).addChild(`format_strikethrough`,[`format`],{...bF,sequence:50,separator:!0}).addChild(`format_font_size`,[`format`],{...xF,sequence:60,separator:!0}).addChild(`format_alignment`,[`format`],{...SF,sequence:70}).addChild(`format_alignment_left`,[`format`,`format_alignment`],{...wF,sequence:10}).addChild(`format_alignment_center`,[`format`,`format_alignment`],{...TF,sequence:20}).addChild(`format_alignment_right`,[`format`,`format_alignment`],{...EF,sequence:30,separator:!0}).addChild(`format_alignment_top`,[`format`,`format_alignment`],{...OF,sequence:40}).addChild(`format_alignment_middle`,[`format`,`format_alignment`],{...kF,sequence:50}).addChild(`format_alignment_bottom`,[`format`,`format_alignment`],{...AF,sequence:60,separator:!0}).addChild(`format_wrapping`,[`format`],{...jF,sequence:80,separator:!0}).addChild(`format_wrapping_overflow`,[`format`,`format_wrapping`],{...NF,sequence:10}).addChild(`format_wrapping_wrap`,[`format`,`format_wrapping`],{...PF,sequence:20}).addChild(`format_wrapping_clip`,[`format`,`format_wrapping`],{...FF,sequence:30}).addChild(`format_cf`,[`format`],{...IF,sequence:90,separator:!0}).addChild(`format_clearFormat`,[`format`],{...LF,sequence:100,separator:!0}).add(`data`,{name:O(`Data`),sequence:60}).addChild(`sort_range`,[`data`],{...NP,sequence:10,separator:!0}).addChild(`sort_ascending`,[`data`,`sort_range`],{...PP,sequence:10}).addChild(`sort_descending`,[`data`,`sort_range`],{...RP,sequence:20}).addChild(`data_cleanup`,[`data`],{...FP,sequence:15}).addChild(`remove_duplicates`,[`data`,`data_cleanup`],{...IP,sequence:10}).addChild(`trim_whitespace`,[`data`,`data_cleanup`],{...LP,sequence:20}).addChild(`split_to_columns`,[`data`],{...VP,sequence:20}).addChild(`data_validation`,[`data`],{name:O(`Data Validation`),execute:e=>{e.openSidePanel(`DataValidation`)},icon:`o-spreadsheet-Icon.DATA_VALIDATION`,sequence:30,separator:!0}).addChild(`add_remove_data_filter`,[`data`],{...zP,sequence:40,separator:!0}).addChild(`pivot_data_sources`,[`data`],e=>{let t=e.model.getters.getPivotIds().length;return e.model.getters.getPivotIds().map((n,r)=>{let i={get highlights(){return MI(e.model.getters,n)}};return{id:`item_pivot_${e.model.getters.getPivotFormulaId(n)}`,name:e.model.getters.getPivotDisplayName(n),sequence:50+r/t,isReadonlyAllowed:!0,execute:e=>e.openSidePanel(`PivotSidePanel`,{pivotId:n}),onStartHover:e=>e.getStore(uC).register(i),onStopHover:e=>e.getStore(uC).unRegister(i),icon:`o-spreadsheet-Icon.PIVOT`,separator:r===e.model.getters.getPivotIds().length-1,secondaryIcon:e=>e.model.getters.isPivotUnused(n)?`o-spreadsheet-Icon.UNUSED_PIVOT_WARNING`:void 0}})}).addChild(`reinsert_dynamic_pivot`,[`data`],HP).addChild(`reinsert_static_pivot`,[`data`],UP);let FI=new class extends h{addTransformation(e,t,n){this.content[e]||(this.content[e]=new Map);for(let r of t)this.content[e].set(r,n);return this}getTransformation(e,t){return this.content[t]&&this.content[t].get(e)}},II=new class extends h{mapping={};uuidGenerator=new al;add(e,t){let n={...t,id:this.uuidGenerator.uuidv4()};return super.add(e,n)}getAllOrdered(){return this.getAll().sort((e,t)=>e.sequence-t.sequence)}};var Q=class extends t.Component{static template=`o_spreadsheet.Section`;static props={class:{type:String,optional:!0},title:{type:String,optional:!0},slots:Object}};function LI(e,t){let n=()=>{window.removeEventListener(`pointerup`,r),window.removeEventListener(`dragstart`,i),window.removeEventListener(`pointermove`,e),window.removeEventListener(`wheel`,e)},r=e=>{t(e),n()};function i(e){e.preventDefault()}return window.addEventListener(`pointerup`,r),window.addEventListener(`dragstart`,i),window.addEventListener(`pointermove`,e),window.addEventListener(`wheel`,e,{passive:!1}),n}function RI(){let e,n=document.body.style.cursor,r=[],i=()=>{e=void 0,document.body.style.cursor=n,r.forEach(e=>e()),r=[]},a=(t,a)=>{let s=()=>{document.body.style.cursor=`move`,e&&(Object.assign(o.itemsStyle,e.getItemStyles()),a.onChange?.())};o.cancel=()=>{o.draggedItemId=void 0,o.itemsStyle={},document.body.style.cursor=n,a.onCancel?.(),i()};let c=(e,t)=>{o.draggedItemId=void 0,o.itemsStyle={},document.body.style.cursor=n,a.onDragEnd?.(e,t),i()};document.body.style.cursor=`move`,o.draggedItemId=a.draggedItemId;let l=t===`horizontal`?new HI(a.scrollableContainerEl):new VI(a.scrollableContainerEl);e=new zI({...a,container:l,onChange:s,onDragEnd:c,onCancel:o.cancel});let u=LI(e.onMouseMove.bind(e),e.onMouseUp.bind(e));r.push(u);let d=e.onScroll.bind(e);a.scrollableContainerEl.addEventListener(`scroll`,d),r.push(()=>a.scrollableContainerEl.removeEventListener(`scroll`,d)),r.push(e.destroy.bind(e))};(0,t.onWillUnmount)(()=>{i()});let o=(0,t.useState)({itemsStyle:{},draggedItemId:void 0,start:a,cancel:()=>{}});return o}var zI=class{draggedItemId;items;container;initialMousePosition;currentMousePosition;initialScroll;minPosition;maxPosition;edgeScrollIntervalId;onChange;onCancel;onDragEnd;deadZone;constructor(e){this.items=e.items.map(e=>({...e,positionAtStart:e.position})),this.draggedItemId=e.draggedItemId,this.container=e.container,this.onChange=e.onChange,this.onCancel=e.onCancel,this.onDragEnd=e.onDragEnd,this.initialMousePosition=e.initialMousePosition,this.currentMousePosition=e.initialMousePosition,this.initialScroll=this.container.scroll,this.minPosition=this.items[0].position,this.maxPosition=this.items[this.items.length-1].position+this.items[this.items.length-1].size}getItemStyles(){let e={};for(let t of this.items)e[t.id]=this.getItemStyle(t.id);return e}getItemStyle(e){let t=this.container.cssPositionProperty,n={};return n.position=`relative`,n[t]=(this.getItemsPositions()[e]||0)+`px`,n.transition=`${t} 0.5s`,n[`pointer-events`]=`none`,this.draggedItemId===e&&(n.transition=`${t} 0s`,n[`z-index`]=`1000`),U(n)}onScroll(){this.moveDraggedItemToPosition(this.currentMousePosition+this.scrollOffset)}onMouseMove(e){if(e.button>1){this.onCancel();return}let t=this.container.getMousePosition(e);if(this.currentMousePosition=t,t<this.container.start||t>this.container.end){this.startEdgeScroll(t<this.container.start?-1:1);return}else this.stopEdgeScroll();this.moveDraggedItemToPosition(t+this.scrollOffset)}moveDraggedItemToPosition(e){let t=this.getHoveredItemIndex(e,this.items),n=this.items.findIndex(e=>e.id===this.draggedItemId),r=this.items[n];if(this.deadZone&&this.isInZone(e,this.deadZone)){this.onChange(this.getItemsPositions());return}else this.isInZone(e,{start:r.position,end:r.position+r.size})&&(this.deadZone=void 0);if(n===t){this.onChange(this.getItemsPositions());return}let i=Math.min(n,t),a=Math.max(n,t),o=Math.sign(t-n),s=0;for(let e=i;e<=a;e++)e!==n&&(this.items[e].position-=o*r.size,s+=this.items[e].size);r.position+=o*s,this.items.sort((e,t)=>e.position-t.position),this.deadZone=o>0?{start:e,end:r.position}:{start:r.position+r.size,end:e},this.onChange(this.getItemsPositions())}onMouseUp(e){e.button!==0&&this.onCancel(),e.stopPropagation(),e.preventDefault();let t=this.items.findIndex(e=>e.id===this.draggedItemId);return this.onDragEnd(this.draggedItemId,t),this.stopEdgeScroll(),!1}startEdgeScroll(e){this.edgeScrollIntervalId||=window.setInterval(()=>{let t=e*3;this.container.scroll+=t},5)}stopEdgeScroll(){window.clearInterval(this.edgeScrollIntervalId),this.edgeScrollIntervalId=void 0}getHoveredItemIndex(e,t){return e<=this.minPosition?0:e>=this.maxPosition?t.length-1:t.findIndex(t=>t.position+t.size>=e)}getItemsPositions(){let e={};for(let t of this.items){if(t.id!==this.draggedItemId){e[t.id]=t.position-t.positionAtStart;continue}let n=this.currentMousePosition-this.initialMousePosition+this.scrollOffset;n=Math.max(this.minPosition-t.positionAtStart,n),n=Math.min(this.maxPosition-t.positionAtStart-t.size,n),e[t.id]=n}return e}isInZone(e,t){return e>=t.start&&e<=t.end}get scrollOffset(){return this.container.scroll-this.initialScroll}destroy(){this.stopEdgeScroll()}},BI=class{el;constructor(e){this.el=e}get containerRect(){return this.el.getBoundingClientRect()}},VI=class extends BI{get start(){return this.containerRect.top}get end(){return this.containerRect.bottom}get cssPositionProperty(){return`top`}get scroll(){return this.el.scrollTop}set scroll(e){this.el.scrollTop=e}getMousePosition(e){return e.clientY}},HI=class extends BI{get start(){return this.containerRect.left}get end(){return this.containerRect.right}get cssPositionProperty(){return`left`}get scroll(){return this.el.scrollLeft}set scroll(e){this.el.scrollLeft=e}getMousePosition(e){return e.clientX}};let UI={ArrowDown:`down`,ArrowLeft:`left`,ArrowRight:`right`,ArrowUp:`up`};function WI(e,t){let n=UI[e.key];e.shiftKey?t.resizeAnchorZone(n,rD(e)?`end`:1):t.moveAnchorCell(n,rD(e)?`end`:1)}var GI=class{mutators=[`focus`,`unfocus`];focusedElement=null;focus(e){this.focusedElement=e}unfocus(e){this.focusedElement&&this.focusedElement===e&&(this.focusedElement=null)}},KI=class extends ef{initialRanges;inputHasSingleRange;colors;mutators=[`resetWithRanges`,`focusById`,`unfocus`,`addEmptyRange`,`removeRange`,`changeRange`,`reset`,`confirm`,`updateColors`];ranges=[];focusedRangeIndex=null;inputSheetId;focusStore=this.get(GI);highlightStore=this.get(uC);constructor(e,t=[],n=!1,r=[]){if(super(e),this.initialRanges=t,this.inputHasSingleRange=n,this.colors=r,n&&t.length>1)throw Error(`Input with a single range cannot be instantiated with several range references.`);this.inputSheetId=this.getters.getActiveSheetId(),this.resetWithRanges(t),this.highlightStore.register(this),this.onDispose(()=>{this.unfocus(),this.highlightStore.unRegister(this)})}handleEvent(e){if(this.focusedRangeIndex===null)return;let t=this.inputSheetId,n=this.getters.getActiveSheetId(),r=e.options.unbounded?this.getters.getUnboundedZone(n,e.anchor.zone):e.anchor.zone,i=this.getters.getRangeFromZone(n,r);if(e.mode===`newAnchor`&&!this.inputHasSingleRange&&this.ranges[this.focusedRangeIndex].xc.trim()!==``){let e=this.getters.getSelectionRangeString(i,t);this.insertNewRange(this.ranges.length,[e]),this.focusLast()}else{let e=i.parts,n=this.ranges[this.focusedRangeIndex].xc.trim();n&&(e=this.getters.getRangeFromSheetXC(t,n).parts);let r={...i,parts:e},a=this.getters.getSelectionRangeString(r,t);this.setRange(this.focusedRangeIndex,[a])}}handle(e){switch(e.type){case`ACTIVATE_SHEET`:if(e.sheetIdFrom!==e.sheetIdTo){let{col:t,row:n}=this.getters.getNextVisibleCellPosition({sheetId:e.sheetIdTo,col:0,row:0}),r=this.getters.expandZone(e.sheetIdTo,E({col:t,row:n}));this.model.selection.resetAnchor(this,{cell:{col:t,row:n},zone:r})}break;case`START_CHANGE_HIGHLIGHT`:let t=this.getters.getActiveSheetId(),n=this.getters.expandZone(t,e.zone),r=this.ranges.findIndex(e=>{let{xc:r,sheetName:i}=ac(e.xc),a=i||this.getters.getSheetName(this.inputSheetId);if(this.getters.getSheetName(t)!==a)return!1;let o=this.getters.getRangeFromSheetXC(t,r);return gr(this.getters.expandZone(t,o.zone),n)});if(r!==-1){this.focus(r);let{left:e,top:t}=n;this.model.selection.resetAnchor(this,{cell:{col:e,row:t},zone:n})}break}}changeRange(e,t){if(this.inputHasSingleRange&&t.split(`,`).length>1)return;let n=this.getIndex(e);if(n!==null&&this.focusedRangeIndex!==n&&this.focus(n),n!==null){let e=t.replace(/^,+/,``).split(`,`).map(e=>e.trim());this.setRange(n,e),this.captureSelection()}}addEmptyRange(){this.inputHasSingleRange&&this.ranges.length===1||(this.insertNewRange(this.ranges.length,[``]),this.focusLast())}removeRange(e){if(this.ranges.length===1)return;let t=this.getIndex(e);t!==null&&this.removeRangeByIndex(t)}updateColors(e){this.colors=e;let t=new Pn(this.ranges.length,this.colors);this.ranges=this.ranges.map(e=>({...e,color:t.next()}))}confirm(){for(let e of this.selectionInputs)e.xc===``&&this.removeRange(e.id);let e=this.getters.getActiveSheetId();this.inputSheetId!==e&&this.model.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:e,sheetIdTo:this.inputSheetId}),this.selectionInputValues.join()!==this.initialRanges.join()&&this.resetWithRanges(this.selectionInputValues),this.initialRanges=this.selectionInputValues,this.unfocus()}reset(){this.resetWithRanges(this.initialRanges),this.confirm()}get selectionInputValues(){return this.cleanInputs(this.ranges.map(e=>e.xc?e.xc:``))}get selectionInputs(){return this.ranges.map((e,t)=>Object.assign({},e,{color:this.hasMainFocus&&this.focusedRangeIndex!==null&&this.getters.isRangeValid(e.xc)?e.color:null,isFocused:this.hasMainFocus&&this.focusedRangeIndex===t,isValidRange:e.xc===``||this.getters.isRangeValid(e.xc)}))}get isResettable(){return this.initialRanges.join()!==this.ranges.map(e=>e.xc).join()}get isConfirmable(){return this.selectionInputs.every(e=>e.isValidRange)}get hasFocus(){return this.selectionInputs.some(e=>e.isFocused)}get hasMainFocus(){let e=this.focusStore.focusedElement;return!!e&&e===this}get highlights(){return this.hasMainFocus?this.ranges.map(e=>this.inputToHighlights(e)).flat():[]}focusById(e){this.focus(this.getIndex(e))}focus(e){this.focusStore.focus(this),this.focusedRangeIndex=e,this.captureSelection()}focusLast(){this.focus(this.ranges.length-1)}unfocus(){this.focusedRangeIndex=null,this.focusStore.unfocus(this),this.model.selection.release(this)}captureSelection(){if(this.focusedRangeIndex===null)return;let e=this.ranges[this.focusedRangeIndex],t=this.getters.getActiveSheetId(),n=this.getters.getRangeFromSheetXC(t,e?.xc||`A1`).zone;this.model.selection.capture(this,{cell:{col:n.left,row:n.top},zone:n},{handleEvent:this.handleEvent.bind(this),release:this.unfocus.bind(this)})}resetWithRanges(e){this.ranges=[],this.insertNewRange(0,e),this.ranges.length===0&&(this.insertNewRange(this.ranges.length,[``]),this.focusLast())}setContent(e,t){this.ranges[e]={...this.ranges[e],xc:t}}insertNewRange(e,t){let n=Math.max(0,...this.ranges.map(e=>Number(e.id))),r=new Pn(this.ranges.length,this.colors);for(let t=0;t<e;t++)r.next();this.ranges.splice(e,0,...t.map((e,t)=>({xc:e,id:n+t+1,color:r.next()})))}setRange(e,t){let[,...n]=t;this.setContent(e,t[0]),this.insertNewRange(e+1,n),n.length&&this.focus(e+n.length)}removeRangeByIndex(e){this.ranges.splice(e,1),this.focusedRangeIndex!==null&&this.focusLast()}inputToHighlights({xc:e,color:t}){return this.cleanInputs([e]).filter(e=>this.getters.isRangeValid(e)).filter(e=>this.shouldBeHighlighted(this.inputSheetId,e)).map(e=>{let{sheetName:n}=ac(e);return{zone:this.getters.getRangeFromSheetXC(this.inputSheetId,e).zone,sheetId:n&&this.getters.getSheetIdByName(n)||this.inputSheetId,color:t,interactive:!0}})}cleanInputs(e){return e.map(e=>e.split(`,`)).flat().map(e=>e.trim()).filter(e=>e!==``)}shouldBeHighlighted(e,t){let{sheetName:n}=ac(t),r=this.getters.getSheetIdByName(n),i=this.getters.getActiveSheet().id;return this.getters.isRangeValid(t)&&(r===i||r===void 0&&i===e)}getIndex(e){let t=this.ranges.findIndex(t=>t.id===e);return t>=0?t:null}};H`
|
|
352
352
|
.o-selection {
|
|
353
353
|
.o-selection-input {
|
|
354
354
|
padding: 2px 0px;
|
|
@@ -904,7 +904,7 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
904
904
|
`;var ML=class extends t.Component{static template=`o-spreadsheet-Composer`;static props={focus:{validate:e=>[`inactive`,`cellFocus`,`contentFocus`].includes(e)},inputStyle:{type:String,optional:!0},rect:{type:Object,optional:!0},delimitation:{type:Object,optional:!0},onComposerCellFocused:{type:Function,optional:!0},onComposerContentFocused:Function,isDefaultFocus:{type:Boolean,optional:!0},onInputContextMenu:{type:Function,optional:!0},composerStore:Object,placeholder:{type:String,optional:!0}};static components={TextValueProvider:SL,FunctionDescriptionProvider:EL,SpeechBubble:DL};static defaultProps={inputStyle:``,isDefaultFocus:!1};DOMFocusableElementStore;composerRef=(0,t.useRef)(`o_composer`);contentHelper=new wL(this.composerRef.el);composerState=(0,t.useState)({positionStart:0,positionEnd:0,hoveredRect:void 0});autoCompleteState;functionDescriptionState=(0,t.useState)({showDescription:!1,functionDescription:{},argsToFocus:[]});assistant=(0,t.useState)({forcedClosed:!1});compositionActive=!1;spreadsheetRect=pM();lastHoveredTokenIndex=void 0;debouncedHover=Et((e,t)=>{let n=this.contentHelper.getCurrentSelection();if(n.start!==n.end)return;let r=this.props.composerStore.hoveredTokens;this.props.composerStore.hoverToken(e),w(r,this.props.composerStore.hoveredTokens)||(this.composerState.hoveredRect=t)},120);get assistantStyleProperties(){let e=this.composerRef.el.getBoundingClientRect(),t={};t[`min-width`]=`${Math.min(this.props.rect?.width||1/0,300)}px`;let n=(this.autoCompleteState.provider?.proposals)?.some(e=>e.description);if((this.functionDescriptionState.showDescription||n)&&(t.width=`300px`),this.props.delimitation&&this.props.rect){let{x:e,y:n,height:r}=this.props.rect,i=this.props.delimitation.height-(n+r);t[`max-height`]=`${i}px`,n>i&&(t[`max-height`]=`${n-9}px`,t.top=`-3px`,t.transform=`translate(0, -100%)`),e+300>this.props.delimitation.width&&(t.right=`0px`)}else t[`max-height`]=`${this.spreadsheetRect.height-e.bottom-1}px`,e.left+300+15+9>this.spreadsheetRect.width&&(t.right=`9px`);return t}get assistantStyle(){let e=this.assistantStyleProperties;return U({"max-height":e[`max-height`],width:e.width,"min-width":e[`min-width`]})}get assistantContainerStyle(){let e=this.assistantStyleProperties;return U({top:e.top,right:e.right,transform:e.transform})}shouldProcessInputEvents=!1;tokens=[];keyMapping={Enter:e=>this.processEnterKey(e,`down`),"Shift+Enter":e=>this.processEnterKey(e,`up`),"Alt+Enter":this.processNewLineEvent,"Ctrl+Enter":this.processNewLineEvent,Escape:this.processEscapeKey,F2:e=>this.toggleEditionMode(e),F4:e=>this.processF4Key(e),Tab:e=>this.processTabKey(e,`right`),"Shift+Tab":e=>this.processTabKey(e,`left`)};keyCodeMapping={NumpadDecimal:this.processNumpadDecimal};setup(){this.DOMFocusableElementStore=V(xL),this.autoCompleteState=Jd(CL),(0,t.onMounted)(()=>{let e=this.composerRef.el;this.props.isDefaultFocus&&this.DOMFocusableElementStore.setFocusableElement(e),this.contentHelper.updateEl(e)}),this.env.model.selection.observe(this,{handleEvent:()=>this.autoCompleteState.hide()}),(0,t.onWillUnmount)(()=>{this.env.model.selection.detachObserver(this),this.debouncedHover.stopDebounce()}),(0,t.useEffect)(()=>{this.processContent(),document.activeElement===this.contentHelper.el&&this.props.composerStore.editionMode===`inactive`&&!this.props.isDefaultFocus&&this.DOMFocusableElementStore.focus()}),(0,t.useEffect)(()=>{this.processTokenAtCursor()},()=>[this.props.composerStore.editionMode!==`inactive`]),(0,t.useEffect)(()=>{this.contentHelper.scrollSelectionIntoView()},()=>[this.props.composerStore.composerSelection.start,this.props.composerStore.composerSelection.end])}processArrowKeys(e){let t=this.props.composerStore.tokenAtCursor;if((this.props.composerStore.isSelectingRange||this.props.composerStore.editionMode===`inactive`)&&!([`ArrowUp`,`ArrowDown`].includes(e.key)&&this.autoCompleteState.provider&&t?.type!==`REFERENCE`)){this.functionDescriptionState.showDescription=!1,this.autoCompleteState.hide(),e.preventDefault(),e.stopPropagation(),WI(e,this.env.model.selection);return}let n=this.props.composerStore.currentContent;if(this.props.focus===`cellFocus`&&!this.autoCompleteState.provider&&!en(n)){this.props.composerStore.stopEdition();return}e.stopPropagation(),this.handleArrowKeysForAutocomplete(e)}handleArrowKeysForAutocomplete(e){[`ArrowUp`,`ArrowDown`].includes(e.key)&&this.autoCompleteState.provider&&(e.preventDefault(),this.autoCompleteState.moveSelection(e.key===`ArrowDown`?`next`:`previous`))}processTabKey(e,t){if(e.preventDefault(),e.stopPropagation(),this.props.composerStore.editionMode!==`inactive`){let e=this.autoCompleteState;if(e.provider&&e.selectedIndex!==void 0){let t=e.provider.proposals[e.selectedIndex]?.text;if(t){this.autoComplete(t);return}}this.props.composerStore.stopEdition(t)}}processEnterKey(e,t){e.preventDefault(),e.stopPropagation();let n=this.autoCompleteState;if(n.provider&&n.selectedIndex!==void 0){let e=n.provider.proposals[n.selectedIndex]?.text;if(e){this.autoComplete(e);return}}this.props.composerStore.stopEdition(t)}processNewLineEvent(e){e.preventDefault(),e.stopPropagation();let t=this.contentHelper.getText(),n=this.contentHelper.getCurrentSelection(),r=Math.min(n.start,n.end),i=Math.max(n.start,n.end);this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t.slice(0,r)+`
|
|
905
905
|
`+t.slice(i),{start:r+1,end:r+1}),this.processContent()}processEscapeKey(e){this.props.composerStore.cancelEdition(),e.stopPropagation(),e.preventDefault()}processF4Key(e){e.stopPropagation(),this.props.composerStore.cycleReferences(),this.processContent()}toggleEditionMode(e){e.stopPropagation(),this.props.composerStore.toggleEditionMode(),this.processContent()}processNumpadDecimal(e){e.stopPropagation(),e.preventDefault();let t=this.env.model.getters.getLocale(),n=this.contentHelper.getCurrentSelection(),r=this.props.composerStore.currentContent,i=r.slice(0,n.start)+t.decimalSeparator+r.slice(n.end);this.props.composerStore.setCurrentContent(i,{start:n.start+1,end:n.start+1}),this.processContent()}onCompositionStart(){this.compositionActive=!0}onCompositionEnd(){this.compositionActive=!1}onKeydown(e){if(this.props.composerStore.editionMode===`inactive`)return;if(e.key.startsWith(`Arrow`)){this.processArrowKeys(e);return}let t=this.keyMapping[tD(e)]||this.keyCodeMapping[tD(e,`code`)];t?t.call(this,e):e.stopPropagation()}onPaste(e){this.props.composerStore.editionMode===`inactive`?e.preventDefault():e.stopPropagation()}onInput(e){if(!this.shouldProcessInputEvents)return;e.stopPropagation();let t;if(t=this.props.composerStore.editionMode===`inactive`?e.data||``:this.contentHelper.getText(),this.props.focus===`inactive`)return this.props.onComposerCellFocused?.(t);let n=this.contentHelper.getCurrentSelection();this.props.composerStore.stopComposerRangeSelection(),this.props.composerStore.setCurrentContent(t,n),this.processTokenAtCursor()}onKeyup(e){if(this.contentHelper.el===document.activeElement){if(this.autoCompleteState.provider&&[`ArrowUp`,`ArrowDown`].includes(e.key)||this.props.composerStore.isSelectingRange&&e.key?.startsWith(`Arrow`))return;let{start:t,end:n}=this.props.composerStore.composerSelection,{start:r,end:i}=this.contentHelper.getCurrentSelection();(r!==t||i!==n)&&this.props.composerStore.changeComposerCursorSelection(r,i),this.processTokenAtCursor()}}onBlur(e){if(this.props.composerStore.editionMode===`inactive`)return;let t=e.relatedTarget;if(!t||!(t instanceof HTMLElement)){this.props.composerStore.stopEdition();return}if(t.attributes.getNamedItem(`composerFocusableElement`)){this.contentHelper.el.focus();return}t.classList.contains(`o-composer`)||this.props.composerStore.stopEdition()}updateAutoCompleteIndex(e){this.autoCompleteState.selectIndex(x(0,e,10))}onMousedown(e){e.button>0||(this.debouncedHover.stopDebounce(),this.contentHelper.removeSelection())}onMouseup(){if(this.env.model.getters.isReadonly())return;let e=this.contentHelper.getCurrentSelection();e.start!==e.end&&this.props.composerStore.hoverToken(void 0)}onClick(){if(this.env.model.getters.isReadonly())return;let e=this.contentHelper.getCurrentSelection();this.props.onComposerContentFocused(),this.props.composerStore.changeComposerCursorSelection(e.start,e.end),this.processTokenAtCursor()}onDblClick(){if(this.env.model.getters.isReadonly())return;let e=this.props.composerStore.currentContent;if(en(e)){let t=this.props.composerStore.currentTokens,n=this.contentHelper.getCurrentSelection();if(n.start===n.end)return;let r=e.substring(n.start,n.end),i=t.filter(e=>e.value.includes(r)&&e.start<=n.start&&e.end>=n.end)[0];if(!i)return;i.type===`REFERENCE`&&this.props.composerStore.changeComposerCursorSelection(i.start,i.end)}}onContextMenu(e){this.props.composerStore.editionMode===`inactive`&&this.props.onInputContextMenu?.(e)}closeAssistant(){this.canBeToggled&&(this.assistant.forcedClosed=!0)}openAssistant(){this.canBeToggled&&(this.assistant.forcedClosed=!1)}onWheel(e){this.composerRef.el&&this.composerRef.el.scrollHeight>this.composerRef.el.clientHeight&&e.stopPropagation()}get canBeToggled(){return this.autoCompleteState.provider?.canBeToggled??!0}processContent(){if(this.compositionActive)return;this.shouldProcessInputEvents=!1,this.props.focus!==`inactive`&&document.activeElement!==this.contentHelper.el&&this.contentHelper.el.focus();let e=this.getContentLines();if(this.contentHelper.setText(e),e.length!==0&&e.length[0]!==0&&this.props.focus!==`inactive`){let{start:e,end:t}=this.props.composerStore.composerSelection;this.contentHelper.selectRange(e,t)}this.shouldProcessInputEvents=!0}getContentLines(){let e=this.props.composerStore.currentContent,t=en(e);return e===``?[]:t&&this.props.focus!==`inactive`?this.splitHtmlContentIntoLines(this.getHtmlContentFromTokens()):this.splitHtmlContentIntoLines([{value:e,classes:[]}])}getHtmlContentFromTokens(){let e=this.props.composerStore.currentTokens,t=[],{end:n,start:r}=this.props.composerStore.composerSelection;for(let i=0;i<e.length;i++){let a=e[i],o=a.color||`#000000`;a.isBlurred&&(o=xn(o,.5));let s=[];a.type===`REFERENCE`&&this.props.composerStore.tokenAtCursor===a&&this.props.composerStore.editionMode===`selecting`&&s.push(`text-decoration-underline`),n===r&&a.isParenthesisLinkedToCursor&&s.push(AL),a.isInHoverContext&&s.push(jL),this.props.composerStore.showSelectionIndicator&&n===r&&n===a.end&&s.push(kL),t.push({value:a.value,color:o,classes:s,onHover:e=>this.onTokenHover(i,e),onStopHover:()=>this.onTokenHover(void 0)})}return t}onTokenHover(e,t){this.lastHoveredTokenIndex!==e&&(this.lastHoveredTokenIndex=e,this.debouncedHover(e,t))}splitHtmlContentIntoLines(e){let t=[],n=[];for(let r of e)if(r.value.includes(`
|
|
906
906
|
`)){let e=r.value.split(`
|
|
907
|
-
`),i=e.pop();for(let i of e)n.push({color:r.color,value:i}),t.push(n),n=[];n.push({...r,value:i})}else n.push(r);n.length&&t.push(n);let r=[];for(let e of t)e.every(this.isContentEmpty)?r.push([e[0]]):r.push(e.filter(e=>!this.isContentEmpty(e)));return r}isContentEmpty(e){return!(e.value||e.classes?.length)}processTokenAtCursor(){let e=this.props.composerStore;this.autoCompleteState.provider&&this.autoCompleteState.hide(),this.functionDescriptionState.showDescription=!1;let t=this.props.composerStore.autocompleteProvider;t&&this.autoCompleteState.useProvider(t);let n=this.props.composerStore.tokenAtCursor;if(en(e.currentContent)&&n&&n.type!==`SYMBOL`){let e=n.functionContext,t=e?.parent.toUpperCase();if(e&&t&&t in OL&&n.type!==`UNKNOWN`){let r=OL[t],i=e.argPosition,a=e.args.length;this.functionDescriptionState.functionDescription=r;let o=this.props.composerStore.currentTokens.some(e=>e.type===`RIGHT_PAREN`&&e.parenthesesCode===n.parenthesesCode);this.functionDescriptionState.argsToFocus=this.getArgsToFocus(o,r,a,i),this.functionDescriptionState.showDescription=!0}}}getArgsToFocus(e,t,n,r){let{nbrArgRepeating:i,minArgRequired:a,nbrArgOptional:o,maxArgPossible:s}=t;if(e){let e=Ef(t,Math.max(Math.min(s,n),a))(r);return e===void 0?[]:[e]}let c=Math.max(n,a),l=i?a+Math.ceil((c-a)/i)*i+o:s,u=[];for(let e=c;e<=l;e++){let n=Ef(t,e)(r);n!==void 0&&u.push(n)}return[...new Set(u)]}autoComplete(e){!e||this.assistant.forcedClosed&&this.canBeToggled||(this.autoCompleteState.provider?.selectProposal(e),this.processTokenAtCursor())}get displaySpeechBubble(){return!!(this.props.focus!==`inactive`&&this.composerState.hoveredRect&&this.props.composerStore.hoveredContentEvaluation)}},NL=class extends hC{constructor(e,t){super(e),this.args=t,this._currentContent=this.getComposerContent()}getAutoCompleteProviders(){let e=super.getAutoCompleteProviders(),t=this.args().contextualAutocomplete;return t&&e.push(t),e}getZoneReference(e){let t=super.getZoneReference(e);return this.args().defaultStatic?Yv(t,`colrow`):t}getComposerContent(){let e=this._currentContent;if(this.editionMode===`inactive`){let t=this.args().defaultRangeSheetId;e=xv(this.args().content).map(e=>{if(e.type===`REFERENCE`){let n=this.getters.getRangeFromSheetXC(t,e.value);return this.getters.getRangeString(n,this.getters.getActiveSheetId())}return e.value}).join(``)}return zl(e,this.getters.getLocale())}stopEdition(){this._stopEdition()}confirmEdition(e){this.args().onConfirm(e)}getTokenColor(e){if(e.type===`SYMBOL`){let t=this.args().getContextualColoredSymbolToken?.(e);if(t)return t}return super.getTokenColor(e)}hoverToken(){}};H`
|
|
907
|
+
`),i=e.pop();for(let i of e)n.push({color:r.color,value:i}),t.push(n),n=[];n.push({...r,value:i})}else n.push(r);n.length&&t.push(n);let r=[];for(let e of t)e.every(this.isContentEmpty)?r.push([e[0]]):r.push(e.filter(e=>!this.isContentEmpty(e)));return r}isContentEmpty(e){return!(e.value||e.classes?.length)}processTokenAtCursor(){let e=this.props.composerStore;this.autoCompleteState.provider&&this.autoCompleteState.hide(),this.functionDescriptionState.showDescription=!1;let t=this.props.composerStore.autocompleteProvider;t&&this.autoCompleteState.useProvider(t);let n=this.props.composerStore.tokenAtCursor;if(en(e.currentContent)&&n&&n.type!==`SYMBOL`){let e=n.functionContext,t=e?.parent.toUpperCase();if(e&&t&&t in OL&&n.type!==`UNKNOWN`){let r=OL[t],i=e.argPosition,a=e.args.length;this.functionDescriptionState.functionDescription=r;let o=this.props.composerStore.currentTokens.some(e=>e.type===`RIGHT_PAREN`&&e.parenthesesCode===n.parenthesesCode);this.functionDescriptionState.argsToFocus=this.getArgsToFocus(o,r,a,i),this.functionDescriptionState.showDescription=!0}}}getArgsToFocus(e,t,n,r){let{nbrArgRepeating:i,minArgRequired:a,nbrArgOptional:o,maxArgPossible:s}=t;if(e){let e=Ef(t,Math.max(Math.min(s,n),a))(r);return e===void 0?[]:[e]}let c=Math.max(n,a),l=i?a+Math.ceil((c-a)/i)*i+o:s,u=[];for(let e=c;e<=l;e++){let n=Ef(t,e)(r);n!==void 0&&u.push(n)}return[...new Set(u)]}autoComplete(e){!e||this.assistant.forcedClosed&&this.canBeToggled||(this.autoCompleteState.provider?.selectProposal(e),this.processTokenAtCursor())}get displaySpeechBubble(){return!!(this.props.focus!==`inactive`&&this.composerState.hoveredRect&&this.props.composerStore.hoveredContentEvaluation)}},NL=class extends hC{args;constructor(e,t){super(e),this.args=t,this._currentContent=this.getComposerContent()}getAutoCompleteProviders(){let e=super.getAutoCompleteProviders(),t=this.args().contextualAutocomplete;return t&&e.push(t),e}getZoneReference(e){let t=super.getZoneReference(e);return this.args().defaultStatic?Yv(t,`colrow`):t}getComposerContent(){let e=this._currentContent;if(this.editionMode===`inactive`){let t=this.args().defaultRangeSheetId;e=xv(this.args().content).map(e=>{if(e.type===`REFERENCE`){let n=this.getters.getRangeFromSheetXC(t,e.value);return this.getters.getRangeString(n,this.getters.getActiveSheetId())}return e.value}).join(``)}return zl(e,this.getters.getLocale())}stopEdition(){this._stopEdition()}confirmEdition(e){this.args().onConfirm(e)}getTokenColor(e){if(e.type===`SYMBOL`){let t=this.args().getContextualColoredSymbolToken?.(e);if(t)return t}return super.getTokenColor(e)}hoverToken(){}};H`
|
|
908
908
|
.o-spreadsheet {
|
|
909
909
|
.o-standalone-composer {
|
|
910
910
|
min-height: 24px;
|
|
@@ -1299,7 +1299,7 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
1299
1299
|
width: 24px;
|
|
1300
1300
|
}
|
|
1301
1301
|
}
|
|
1302
|
-
`;let LR=f([cF,lF,uF,dF,fF,pF,mF,tF,nF,rF,iF,aF,oF]);var RR=class extends t.Component{static template=`o-spreadsheet-MoreFormatsPanel`;static props={onCloseSidePanel:Function};get dateFormatsActions(){return LR}},zR=class extends ef{mutators=[`cancelMeasureDisplayEdition`,`updateMeasureDisplayType`,`updateMeasureDisplayField`,`updateMeasureDisplayValue`];measureDisplay;constructor(e,t,n){super(e),this.pivotId=t,this.initialMeasure=n,this.measureDisplay=n.display||{type:`no_calculations`}}updateMeasureDisplayType(e){this.updatePivotMeasureDisplay(this.getMeasureDisplay(e,this.measureDisplay.fieldNameWithGranularity,this.measureDisplay.value))}updateMeasureDisplayField(e){this.updatePivotMeasureDisplay(this.getMeasureDisplay(this.measureDisplay.type,e,this.measureDisplay.value))}updateMeasureDisplayValue(e){this.updatePivotMeasureDisplay(this.getMeasureDisplay(this.measureDisplay.type,this.measureDisplay.fieldNameWithGranularity,e))}updatePivotMeasureDisplay(e){let t=b(this.model.getters.getPivotCoreDefinition(this.pivotId)),n=this.getMeasureIndex(this.initialMeasure.id,t),r={...t.measures[n],display:e};t.measures[n]=r,this.model.dispatch(`UPDATE_PIVOT`,{pivot:t,pivotId:this.pivotId}).isSuccessful&&(this.measureDisplay=e)}getMeasureDisplay(e,t,n){switch(e){case`no_calculations`:case`%_of_grand_total`:case`%_of_col_total`:case`%_of_row_total`:case`%_of_parent_row_total`:case`%_of_parent_col_total`:case`index`:return{type:e};case`%_of_parent_total`:case`running_total`:case`%_running_total`:case`rank_asc`:case`rank_desc`:return t||=this.fields[0]?.nameWithGranularity,{type:e,fieldNameWithGranularity:t};case`%_of`:case`difference_from`:case`%_difference_from`:t||=this.fields[0]?.nameWithGranularity;let r=this.getPossibleValues(t);return(n===void 0||!r.find(e=>e.value===n))&&(n=Ou),{type:e,fieldNameWithGranularity:t,value:n??`(previous)`}}}getMeasureIndex(e,t){let n=t.measures.findIndex(t=>t.id===e);if(n===-1)throw Error(`Measure with id ${e} not found in pivot.`);return n}get doesDisplayNeedsField(){return[`%_of_parent_total`,`running_total`,`%_running_total`,`rank_asc`,`rank_desc`].includes(this.measureDisplay.type)||this.doesDisplayNeedsValue}get fields(){let e=this.getters.getPivot(this.pivotId).definition;return[...e.columns,...e.rows].map(e=>({...e,displayName:Ed(e)}))}get doesDisplayNeedsValue(){return this.isDisplayValueDependant(this.measureDisplay)}isDisplayValueDependant(e){return[`%_of`,`difference_from`,`%_difference_from`].includes(e.type)}get values(){let e=this.measureDisplay;return this.isDisplayValueDependant(e)?this.getPossibleValues(e.fieldNameWithGranularity):[]}getPossibleValues(e){let t=[{value:Ou,label:O(`(previous)`)},{value:`(next)`,label:O(`(next)`)}],n=this.fields.find(t=>t.nameWithGranularity===e);if(!n)return[];let r=this.getters.getPivot(this.pivotId).getPossibleFieldValues(n);return[...t,...r]}cancelMeasureDisplayEdition(){let e=b(this.model.getters.getPivotCoreDefinition(this.pivotId)),t=this.getMeasureIndex(this.initialMeasure.id,e);e.measures[t]={...e.measures[t],display:this.initialMeasure.display},this.model.dispatch(`UPDATE_PIVOT`,{pivot:e,pivotId:this.pivotId})}};H`
|
|
1302
|
+
`;let LR=f([cF,lF,uF,dF,fF,pF,mF,tF,nF,rF,iF,aF,oF]);var RR=class extends t.Component{static template=`o-spreadsheet-MoreFormatsPanel`;static props={onCloseSidePanel:Function};get dateFormatsActions(){return LR}},zR=class extends ef{pivotId;initialMeasure;mutators=[`cancelMeasureDisplayEdition`,`updateMeasureDisplayType`,`updateMeasureDisplayField`,`updateMeasureDisplayValue`];measureDisplay;constructor(e,t,n){super(e),this.pivotId=t,this.initialMeasure=n,this.measureDisplay=n.display||{type:`no_calculations`}}updateMeasureDisplayType(e){this.updatePivotMeasureDisplay(this.getMeasureDisplay(e,this.measureDisplay.fieldNameWithGranularity,this.measureDisplay.value))}updateMeasureDisplayField(e){this.updatePivotMeasureDisplay(this.getMeasureDisplay(this.measureDisplay.type,e,this.measureDisplay.value))}updateMeasureDisplayValue(e){this.updatePivotMeasureDisplay(this.getMeasureDisplay(this.measureDisplay.type,this.measureDisplay.fieldNameWithGranularity,e))}updatePivotMeasureDisplay(e){let t=b(this.model.getters.getPivotCoreDefinition(this.pivotId)),n=this.getMeasureIndex(this.initialMeasure.id,t),r={...t.measures[n],display:e};t.measures[n]=r,this.model.dispatch(`UPDATE_PIVOT`,{pivot:t,pivotId:this.pivotId}).isSuccessful&&(this.measureDisplay=e)}getMeasureDisplay(e,t,n){switch(e){case`no_calculations`:case`%_of_grand_total`:case`%_of_col_total`:case`%_of_row_total`:case`%_of_parent_row_total`:case`%_of_parent_col_total`:case`index`:return{type:e};case`%_of_parent_total`:case`running_total`:case`%_running_total`:case`rank_asc`:case`rank_desc`:return t||=this.fields[0]?.nameWithGranularity,{type:e,fieldNameWithGranularity:t};case`%_of`:case`difference_from`:case`%_difference_from`:t||=this.fields[0]?.nameWithGranularity;let r=this.getPossibleValues(t);return(n===void 0||!r.find(e=>e.value===n))&&(n=Ou),{type:e,fieldNameWithGranularity:t,value:n??`(previous)`}}}getMeasureIndex(e,t){let n=t.measures.findIndex(t=>t.id===e);if(n===-1)throw Error(`Measure with id ${e} not found in pivot.`);return n}get doesDisplayNeedsField(){return[`%_of_parent_total`,`running_total`,`%_running_total`,`rank_asc`,`rank_desc`].includes(this.measureDisplay.type)||this.doesDisplayNeedsValue}get fields(){let e=this.getters.getPivot(this.pivotId).definition;return[...e.columns,...e.rows].map(e=>({...e,displayName:Ed(e)}))}get doesDisplayNeedsValue(){return this.isDisplayValueDependant(this.measureDisplay)}isDisplayValueDependant(e){return[`%_of`,`difference_from`,`%_difference_from`].includes(e.type)}get values(){let e=this.measureDisplay;return this.isDisplayValueDependant(e)?this.getPossibleValues(e.fieldNameWithGranularity):[]}getPossibleValues(e){let t=[{value:Ou,label:O(`(previous)`)},{value:`(next)`,label:O(`(next)`)}],n=this.fields.find(t=>t.nameWithGranularity===e);if(!n)return[];let r=this.getters.getPivot(this.pivotId).getPossibleFieldValues(n);return[...t,...r]}cancelMeasureDisplayEdition(){let e=b(this.model.getters.getPivotCoreDefinition(this.pivotId)),t=this.getMeasureIndex(this.initialMeasure.id,e);e.measures[t]={...e.measures[t],display:this.initialMeasure.display},this.model.dispatch(`UPDATE_PIVOT`,{pivot:e,pivotId:this.pivotId})}};H`
|
|
1303
1303
|
.o-sidePanel {
|
|
1304
1304
|
.o-pivot-measure-display-field,
|
|
1305
1305
|
.o-pivot-measure-display-value {
|
|
@@ -1392,7 +1392,7 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
1392
1392
|
.add-calculated-measure {
|
|
1393
1393
|
cursor: pointer;
|
|
1394
1394
|
}
|
|
1395
|
-
`;var QR=class extends t.Component{static template=`o-spreadsheet-PivotLayoutConfigurator`;static components={AddDimensionButton:UR,PivotDimension:KR,PivotDimensionOrder:JR,PivotDimensionGranularity:qR,PivotMeasureEditor:XR,PivotSortSection:ZR};static props={definition:Object,onDimensionsUpdated:Function,unusedGroupableFields:Array,measureFields:Array,unusedGranularities:Object,dateGranularities:Array,datetimeGranularities:Array,getScrollableContainerEl:{type:Function,optional:!0},pivotId:String};dimensionsRef=(0,t.useRef)(`pivot-dimensions`);dragAndDrop=RI();AGGREGATORS=ud;composerFocus;isDateOrDatetimeField=gd;setup(){this.composerFocus=V(nf)}startDragAndDrop(e,t){if(t.button!==0||t.target.tagName===`SELECT`)return;let n=this.getDimensionElementsRects(),{columns:r,rows:i}=this.props.definition,a=[...r.map(e=>e.nameWithGranularity),`__rows_title__`,...i.map(e=>e.nameWithGranularity)],o=r.concat(i),s=a.map((e,t)=>({id:e,size:n[t+1].height,position:n[t+1].y}));this.dragAndDrop.start(`vertical`,{draggedItemId:e.nameWithGranularity,initialMousePosition:t.clientY,items:s,scrollableContainerEl:this.props.getScrollableContainerEl?.()||this.dimensionsRef.el,onDragEnd:(e,t)=>{let n=a.findIndex(t=>t===e);if(n===t)return;let r=[...a];r.splice(n,1),r.splice(t,0,e);let i=r.slice(0,r.indexOf(`__rows_title__`)),s=r.slice(r.indexOf(`__rows_title__`)+1);this.props.onDimensionsUpdated({columns:i.map(e=>o.find(t=>t.nameWithGranularity===e)).filter(C),rows:s.map(e=>o.find(t=>t.nameWithGranularity===e)).filter(C)})}})}getGranularitiesFor(e){return gd(e)?e.type===`date`?this.props.dateGranularities:this.props.datetimeGranularities:[]}startDragAndDropMeasures(e,t){if(t.button!==0||t.target.tagName===`SELECT`||t.target.tagName===`INPUT`||this.composerFocus.focusMode!==`inactive`)return;let n=this.getDimensionElementsRects(),{measures:r,columns:i,rows:a}=this.props.definition,o=r.map(e=>e.id),s=3+i.length+a.length,c=o.map((e,t)=>({id:e,size:n[t+s].height,position:n[t+s].y}));this.dragAndDrop.start(`vertical`,{draggedItemId:e.id,initialMousePosition:t.clientY,items:c,scrollableContainerEl:this.props.getScrollableContainerEl?.()||this.dimensionsRef.el,onDragEnd:(e,t)=>{let n=o.findIndex(t=>t===e);if(n===t)return;let i=[...o];i.splice(n,1),i.splice(t,0,e),this.props.onDimensionsUpdated({measures:i.map(e=>r.find(t=>t.id===e)).filter(C)})}})}getDimensionElementsRects(){return Array.from(this.dimensionsRef.el.children).map(e=>{let t=getComputedStyle(e),n=e.getBoundingClientRect();return{x:n.x,y:n.y,width:n.width+parseInt(t.marginLeft||`0`)+parseInt(t.marginRight||`0`),height:n.height+parseInt(t.marginTop||`0`)+parseInt(t.marginBottom||`0`)}})}removeDimension(e){let{columns:t,rows:n}=this.props.definition;this.props.onDimensionsUpdated({columns:t.filter(t=>t.nameWithGranularity!==e.nameWithGranularity),rows:n.filter(t=>t.nameWithGranularity!==e.nameWithGranularity)})}removeMeasureDimension(e){let{measures:t}=this.props.definition;this.props.onDimensionsUpdated({measures:t.filter(t=>t.id!==e.id)})}addColumnDimension(e){let{columns:t}=this.props.definition;this.props.onDimensionsUpdated({columns:t.concat([{fieldName:e,order:`asc`}])})}addRowDimension(e){let{rows:t}=this.props.definition;this.props.onDimensionsUpdated({rows:t.concat([{fieldName:e,order:`asc`}])})}addMeasureDimension(e){let{measures:t}=this.props.definition,n=this.getDefaultMeasureAggregator(e);this.props.onDimensionsUpdated({measures:t.concat([{id:this.getMeasureId(e,n),fieldName:e,aggregator:n}])})}updateMeasure(e,t){let{measures:n}=this.props.definition,r={measures:n.map(n=>n.id===e.id?t:n)};this.props.definition.sortedColumn?.measure===e.id&&(r.sortedColumn={...this.props.definition.sortedColumn,measure:t.id}),this.props.onDimensionsUpdated(r)}getMeasureId(e,t){let n=e.replaceAll(`'`,``)+(t?`:${t}`:``),r=n,i=2;for(;this.props.definition.measures.some(e=>e.id===r);)r=`${n}:${i}`,i++;return r}getDefaultMeasureAggregator(e){let t=this.props.measureFields.find(t=>t.name===e);return t?.aggregator?t.aggregator:`count`}addCalculatedMeasure(){let{measures:e}=this.props.definition,t=this.env.model.getters.generateNewCalculatedMeasureName(e);this.props.onDimensionsUpdated({measures:e.concat([{id:this.getMeasureId(t,`sum`),fieldName:t,aggregator:`sum`,computedBy:{sheetId:this.env.model.getters.getActiveSheetId(),formula:`=0`}}])})}updateOrder(e,t){let{rows:n,columns:r}=this.props.definition;this.props.onDimensionsUpdated({rows:n.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,order:t||void 0}:n),columns:r.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,order:t||void 0}:n)})}updateGranularity(e,t){let{rows:n,columns:r}=this.props.definition;this.props.onDimensionsUpdated({rows:n.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,granularity:t}:n),columns:r.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,granularity:t}:n)})}getMeasureDescription(e){let t=e.display;if(!t||t.type===`no_calculations`)return``;let n=this.env.model.getters.getPivot(this.props.pivotId),r=[...n.definition.columns,...n.definition.rows].find(e=>e.nameWithGranularity===t.fieldNameWithGranularity),i=r?Ed(r):``;return _w.descriptions[t.type](i)}},$R=class extends t.Component{static template=`o-spreadsheet-PivotTitleSection`;static components={CogWheelMenu:GR,Section:Q,TextInput:WR};static props={pivotId:String,flipAxis:Function};get cogWheelMenuItems(){return[{name:O(`Flip axes`),icon:`o-spreadsheet-Icon.EXCHANGE`,execute:this.props.flipAxis},{name:O(`Duplicate`),icon:`o-spreadsheet-Icon.COPY`,execute:()=>this.duplicatePivot()},{name:O(`Delete`),icon:`o-spreadsheet-Icon.TRASH`,execute:()=>this.delete()}]}get name(){return this.env.model.getters.getPivotName(this.props.pivotId)}get displayName(){return this.env.model.getters.getPivotDisplayName(this.props.pivotId)}duplicatePivot(){let e=this.env.model.uuidGenerator.smallUuid(),t=this.env.model.uuidGenerator.smallUuid(),n=this.env.model.dispatch(`DUPLICATE_PIVOT_IN_NEW_SHEET`,{pivotId:this.props.pivotId,newPivotId:e,newSheetId:t}),r;r=n.isSuccessful?O(`Pivot duplicated.`):n.isCancelledBecause(`PivotInError`)?O(`Cannot duplicate a pivot in error.`):O(`Pivot duplication failed.`);let i=n.isSuccessful?`success`:`danger`;this.env.notifyUser({text:r,sticky:!1,type:i}),n.isSuccessful&&this.env.openSidePanel(`PivotSidePanel`,{pivotId:e})}delete(){this.env.askConfirmation(O(`Are you sure you want to delete this pivot?`),()=>{this.env.model.dispatch(`REMOVE_PIVOT`,{pivotId:this.props.pivotId})})}onNameChanged(e){let t=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);this.env.model.dispatch(`UPDATE_PIVOT`,{pivotId:this.props.pivotId,pivot:{...t,name:e}})}},ez=class{measures;columns;rows;sortedColumn;constructor(e,t){this.measures=e.measures.map(e=>tz(t,e)),this.columns=e.columns.map(e=>nz(t,e)),this.rows=e.rows.map(e=>nz(t,e)),this.sortedColumn=e.sortedColumn}getDimension(e){let t=this.columns.find(t=>t.nameWithGranularity===e)||this.rows.find(t=>t.nameWithGranularity===e);if(!t)throw new M(O(`Dimension %s does not exist`,e));return t}getMeasure(e){let t=this.measures.find(t=>t.id===e);if(!t)throw new M(O(`Field %s is not a measure`,e));return t}};function tz(e,t){let n=t.fieldName,r=n===`__count`?{name:`__count`,string:O(`Count`),type:`integer`,aggregator:`sum`}:e[n],i=t.aggregator;return{id:t.id,get displayName(){return t.userDefinedName??r?.string??t.fieldName},userDefinedName:t.userDefinedName,fieldName:n,aggregator:i,type:n===`__count`?`integer`:r?.type??`integer`,isValid:!!(r||t.computedBy),isHidden:t.isHidden,format:t.format,computedBy:t.computedBy,display:t.display}}function nz(e,t){let n=e[t.fieldName],r=n?.type??`integer`,i=n&&gd(n)?t.granularity:void 0;return{displayName:n?.string??t.fieldName,nameWithGranularity:t.fieldName+(i?`:${i}`:``),fieldName:t.fieldName,granularity:i,type:r,order:t.order,isValid:!!n}}var rz=class extends ez{range;constructor(e,t,n){if(super(e,t),e.dataSet){let{sheetId:t,zone:r}=e.dataSet;this.range=n.getRangeFromZone(t,r)}}},iz=class{columns;rows;measures;fieldsType;maxIndent;pivotCells={};rowTree;colTree;isSorted=!1;constructor(e,t,n,r){this.columns=e.map(e=>{let t=1;return e.map(e=>(e={...e,offset:t},t+=e.width,e))}),this.rows=t,this.measures=n,this.fieldsType=r,this.maxIndent=Math.max(...this.rows.map(e=>e.indent)),this.rowTree=kt(()=>this.buildRowsTree()),this.colTree=kt(()=>this.buildColumnsTree())}getNumberOfDataColumns(){return this.columns.at(-1)?.length||0}getPivotCells(e=!0,t=!0){let n=JSON.stringify({includeTotal:e,includeColumnHeaders:t});if(!this.pivotCells[n]){let r=this.rows.length,i=this.getNumberOfDataColumns(),a=this.columns.length+r,o=1+i;!e&&r!==1&&--a,!e&&i!==this.measures.length&&(o-=this.measures.length);let s=[],c=t?0:this.columns.length;for(let t=0;t<o;t++){s.push([]);for(let n=c;n<a;n++)!e&&n===a||s[t].push(this.getPivotCell(t,n,e))}this.pivotCells[n]=s}return this.pivotCells[n]}getRowTree(){return this.rowTree()}getColTree(){return this.colTree()}isTotalRow(e){return this.rows[e].indent!==this.maxIndent}getPivotCell(e,t,n=!0){let r=this.columns.length;if(e>0&&t===r-1){let n=this.getColHeaderDomain(e,t);if(!n)return az;let r=n.at(-1)?.value?.toString()||``;return{type:`MEASURE_HEADER`,domain:n.slice(0,-1),measure:r}}else if(t<=r-1){let n=this.getColHeaderDomain(e,t);return n?{type:`HEADER`,domain:n}:az}else if(e===0){let e=t-r;return{type:`HEADER`,domain:this.getRowDomain(e)}}else{let i=t-r;return!n&&this.isTotalRow(i)?az:{type:`VALUE`,domain:[...this.getRowDomain(i),...this.getColDomain(e)],measure:this.getColMeasure(e)}}}getColHeaderDomain(e,t){if(e===0)return;let n=[],r=this.columns[t].find(t=>t.offset===e);if(r){for(let e=0;e<r.fields.length;e++){let t=r.fields[e];if(t===`measure`)n.push({type:`char`,field:t,value:bd({displayName:`measure`,type:`char`},r.values[e])});else{let{fieldName:i,granularity:a}=hd(t),o=this.fieldsType[i]||`char`;n.push({type:o,field:t,value:bd({displayName:i,type:o,granularity:a},r.values[e])})}}return n}}getColDomain(e){let t=this.getColHeaderDomain(e,this.columns.length-1);return t?t.slice(0,-1):[]}getColMeasure(e){let t=this.getColHeaderDomain(e,this.columns.length-1)?.at(-1)?.value;if(t==null)throw Error(`Measure is missing`);return t.toString()}getRowDomain(e){let t=[];for(let n=0;n<this.rows[e].fields.length;n++){let r=this.rows[e].fields[n],{fieldName:i,granularity:a}=hd(r),o=this.fieldsType[i]||`char`;t.push({type:o,field:r,value:bd({displayName:i,type:o,granularity:a},this.rows[e].values[n])})}return t}buildRowsTree(){let e=[],t=0,n={};n[0]=e;for(let r of this.rows){if(r.fields.length===0||r.values.length===0)return e;let i=r.fields.length-1,a=r.fields[i],{fieldName:o,granularity:s}=hd(a),c=bd({displayName:o,type:this.fieldsType[o]??`char`,granularity:s},r.values[i]);if(i>t){t=i,n[t]=[];let e=n[t-1].at(-1);e&&(e.children=n[t])}t=i;let l={value:c,field:r.fields[i],children:[],type:this.fieldsType[o]||`char`,width:0};n[t].push(l)}return e}buildColumnsTree(){let e=[],t=this.columns.at(-2)||[],n={};n[0]=e;for(let e of t)for(let t=0;t<e.fields.length;t++){let r=e.fields[t],{fieldName:i,granularity:a}=hd(r),o=bd({displayName:i,type:this.fieldsType[i]??`char`,granularity:a},e.values[t]),s={value:o,field:e.fields[t],children:[],width:e.width,type:this.fieldsType[i]||`char`};n[t]?.at(-1)?.value!==o&&(n[t+1]=[],s.children=n[t+1],n[t].push(s))}return e}export(){return{cols:this.columns,rows:this.rows,measures:this.measures,fieldsType:this.fieldsType}}sort(e,t,n){if(this.isSorted)return;let r=(e,t)=>{let r=n(e,t).value;return typeof r==`number`?r:-1/0},i=t.domain,a=Ku(this.rowTree(),[],(n,a)=>{let o=r(e,[...n,...i]),s=r(e,[...a,...i]);return t.order===`asc`?o-s:s-o});this.rowTree=kt(a),this.rows=[...this.rowTreeToRows(a),this.rows[this.rows.length-1]],this.isSorted=!0}rowTreeToRows(e,t){return e.flatMap(e=>{let n={indent:t?t.indent+1:1,fields:[...t?.fields||[],e.field],values:[...t?.values||[],e.value]};return[n,...this.rowTreeToRows(e.children,n)]})}};let az={type:`EMPTY`};function oz(e,t){let n=t.measures.filter(e=>!e.isHidden).map(e=>e.id),r=cz(e,t.columns,0);lz(r,n.length);let i=uz(r,t),a=sz(e,0,t.rows,[],[]);a.push({fields:[],values:[],indent:0});let o={};for(let e of t.columns)o[e.fieldName]=e.type;for(let e of t.rows)o[e.fieldName]=e.type;return new iz(i,a,n,o)}function sz(e,t,n,r,i){if(t>=n.length)return[];let a=n[t],o=a.nameWithGranularity,s=dz(e,a),c=pz(s,a),l=[],u=r.concat(o);for(let e of c){let r=i.concat(e);l.push({fields:u,values:r,indent:t+1});let a=s[e];a&&l.push(...sz(a,t+1,n,u,r))}return l}function cz(e,t,n){if(n>=t.length)return[];let r=t[n],i=t[n].nameWithGranularity,a=dz(e,r);return pz(a,t[n]).map(e=>({value:a[e]?.[0]?.[r.nameWithGranularity]?.value??null,field:i,children:cz(a[e]||[],t,n+1),type:r.type,width:0}))}function lz(e,t){for(let n in e){let r=e[n];r.children.length===0?r.width=t:(lz(r.children,t),r.width=r.children.reduce((e,t)=>e+t.width,0))}}function uz(e,t){let n=t.columns.map(e=>e.nameWithGranularity),r=n.length,i=t.measures.filter(e=>!e.isHidden),a=i.length,o=Array(r).fill(0).map(()=>[]);function s(e,t,i){let a=o[t];for(let o of e){let e=i.concat([o.value]),c={fields:n.slice(0,t+1),values:e,width:o.width,offset:0};a.push(c),t<=r-1&&s(o.children,t+1,e)}}s(e,0,[]);let c=n.length>0,l=[];return c&&o[o.length-1].forEach(e=>{i.forEach(t=>{let n={fields:[...e.fields,`measure`],values:[...e.values,t.id],width:1,offset:0};l.push(n)})}),i.forEach(e=>{let t={fields:[`measure`],values:[e.id],width:1,offset:0};l.push(t)}),o.push(l),o.length===1&&o.unshift([]),o[o.length-2].push({fields:[],values:[],width:a,offset:0}),o}function dz(e,t){return Object.groupBy(e,fz(t))}function fz(e){let t=e.nameWithGranularity;return e=>`${e[t]?.value??null}`}function pz(e,t){return t.order?Object.keys(e).sort((e,n)=>mz(t,e,n)):Object.keys(e)}function mz(e,t,n){return t===`null`?e.order===`asc`?1:-1:n===`null`?e.order===`asc`?-1:1:e.type===`integer`||e.type===`datetime`?e.order===`asc`?F(t,k)-F(n,k):F(n,k)-F(t,k):e.order===`asc`?t.localeCompare(n):n.localeCompare(t)}let hz=Symbol(`NULL`);function gz(e,t,n){let r=e.granularity||`month`;if(!(r in _z))throw Error(`Unknown date granularity: ${r}`);let i=typeof t==`number`||typeof t==`string`?t:hz;if(!_z[r].set.has(t)){_z[r].set.add(t);let a=null;if(typeof t==`number`||typeof t==`string`){let e=R(t,n);switch(r){case`year`:a=e.getFullYear();break;case`quarter_number`:a=Math.floor(e.getMonth()/3)+1;break;case`month_number`:a=e.getMonth()+1;break;case`month`:a=Math.floor(F(t,n));break;case`iso_week_number`:a=e.getIsoWeek();break;case`day_of_month`:a=e.getDate();break;case`day`:a=Math.floor(F(t,n));break;case`day_of_week`:a=(e.getDay()+7-n.weekStart)%7+1;break;case`hour_number`:a=e.getHours();break;case`minute_number`:a=e.getMinutes();break;case`second_number`:a=e.getSeconds();break}}_z[r].values[i]=bd(e,a)}return _z[r].values[i]}let _z={year:{set:new Set,values:{}},quarter_number:{set:new Set,values:{}},month_number:{set:new Set,values:{}},month:{set:new Set,values:{}},iso_week_number:{set:new Set,values:{}},day_of_month:{set:new Set,values:{}},day:{set:new Set,values:{}},day_of_week:{set:new Set,values:{}},hour_number:{set:new Set,values:{}},minute_number:{set:new Set,values:{}},second_number:{set:new Set,values:{}}};function vz(){for(let e in _z)_z[e].set.clear(),_z[e].values={}}var yz=class{type=`SPREADSHEET`;getters;_definition;coreDefinition;metaData={fields:{},fieldKeys:[]};dataEntries=[];table;invalidRangeError;needsReevaluation=!0;constructor(e,t){this.getters=t.getters,this.coreDefinition=t.definition}init(e={}){(!this._definition||e.reload)&&(this.reload(4),this.needsReevaluation=!1)}reload(e){e===4&&(this.metaData=this.loadMetaData()),e>=3&&(this._definition=this.loadRuntimeDefinition()),e>=2&&(this.dataEntries=this.loadData()),e>=1&&(this.table=void 0)}onDefinitionChange(e){let t=this.coreDefinition;if(this.coreDefinition=e,this._definition){let n=Math.max(this.computeShouldReload(t,e),0);this.reload(n)}}computeShouldReload(e,t){return w(e.dataSet,t.dataSet)?3:4}get isInvalidRange(){return!!this.invalidRangeError}get invalidRangeMessage(){return this.invalidRangeError?.message}get definition(){if(this._definition||this.init(),!this._definition)throw Error(`Pivot definition should be defined at this point.`);return this._definition}isValid(){if(this.invalidRangeError||!this.definition)return!1;for(let e of this.definition.measures)if(!e.isValid)return!1;for(let e of this.definition.columns)if(!e.isValid)return!1;for(let e of this.definition.rows)if(!e.isValid)return!1;return!0}assertIsValid({throwOnError:e}){if(!this.isValid()){if(e)throw this.invalidRangeError?this.invalidRangeError:new M(O(`At least one measure and/or dimension is not correct.`));return{value:j.GenericError,message:this.invalidRangeError?.message??O(`At least one measure and/or dimension is not correct.`)}}}areDomainArgsFieldsValid(e){let t=e.filter((e,t)=>t%2==0).map(I);return t.length&&t.at(-1)===`measure`&&(t=t.slice(0,-1)),vd(t,this.definition)}parseArgsToPivotDomain(e){let t=[];for(let n=0;n<e.length-1;n+=2){let r=I(e[n]),i=this.getTypeOfDimension(r),a=r===`measure`?I(e[n+1]):bd(this.getDimension(r),e[n+1]);t.push({field:r,value:a,type:i})}return t}markAsDirtyForEvaluation(){this.needsReevaluation=!0}getMeasure(e){return this.definition.getMeasure(e)}getPivotMeasureValue(e){return{value:this.getMeasure(e).displayName}}getPivotHeaderValueAndFormat(e){let t=e.at(-1);if(!t)return{value:O(`Total`)};let n=this.getDimension(t.field),r=this.filterDataEntriesFromDomain(this.dataEntries,e)[0]?.[n.nameWithGranularity];return n.type===`datetime`?Ju(n.granularity||`month`).toValueAndFormat(t.value,this.getters.getLocale()):r?r.value===null?{value:O(`(Undefined)`)}:r:{value:``}}getPivotCellValueAndFormat(e,t){let n=this.filterDataEntriesFromDomain(this.dataEntries,t);if(n.length===0)return{value:``};let r=this.getMeasure(e),i=n.map(e=>e[r.fieldName]).filter(C),a=i.filter(e=>e.type!==`empty`),o=r.aggregator,s=dd[o];if(!s)throw Error(`Aggregator ${o} does not exist`);try{let e=s([i],this.getters.getLocale());return a.length===0?{...e,value:``}:e}catch(e){return ox(e,o.toUpperCase())}}getPossibleFieldValues(e){let t=[],n=dz(this.dataEntries,e),r=pz(n,e);for(let i of r)t.push({value:n[i]?.[0]?.[e.nameWithGranularity]?.value??``,label:n[i]?.[0]?.[e.nameWithGranularity]?.formattedValue||``});return t}getTableStructure(){if(!this.isValid())throw Error(`Pivot is not valid !`);return this.table||=oz(this.dataEntries,this.definition),this.table}getFields(){return this.metaData.fields}get fields(){return this.getFields()}loadMetaData(){if(this.invalidRangeError=void 0,this.coreDefinition.dataSet){let{zone:e,sheetId:t}=this.coreDefinition.dataSet,n=this.getters.getRangeFromZone(t,e);try{return this.extractFieldsFromRange(n)}catch(e){return this.invalidRangeError=e,{fields:{},fieldKeys:[]}}}else return this.invalidRangeError=new M(O(`The pivot cannot be created because the dataset is missing.`)),{fields:{},fieldKeys:[]}}loadRuntimeDefinition(){return new rz(this.coreDefinition,this.fields,this.getters)}loadData(){let e=this._definition?.range;return this.isValid()&&e?this.extractDataEntriesFromRange(e):[]}getTypeOfDimension(e){if(e===`measure`)return`char`;let{fieldName:t}=hd(e),n=this.fields[t]?.type;if(!n)throw Error(`Field ${t} does not exist`);return n}filterDataEntriesFromDomain(e,t){return t.reduce((e,t)=>this.filterDataEntriesFromDomainNode(e,t),e)}filterDataEntriesFromDomainNode(e,t){let{field:n,value:r,type:i}=t,{nameWithGranularity:a}=this.getDimension(n);return e.filter(e=>{let t=e[a]?.value;return i===`char`?String(t)===String(r):t===r})}getDimension(e){return this.definition.getDimension(e)}getTypeFromZone(e,t){let n=this.getters.getEvaluatedCellsInZone(e,t).filter(e=>!(e.type===`empty`||e.value===``));return n.length===0?`integer`:n.every(e=>e.type===`number`&&e.format&&ls(e.format))?`datetime`:n.every(e=>e.type===`boolean`)?`boolean`:n.every(e=>e.type===`number`)?`integer`:`char`}assertCellIsValidField(e,t,n){if(n.type===`error`)throw new M(O(`The pivot cannot be created because cell %s contains an error`,T(e,t)));if(n.type===`empty`||n.value===``)throw new M(O(`The pivot cannot be created because cell %s is empty`,T(e,t)));if(n.value===`__count`)throw new M(O(`The pivot cannot be created because cell %s contains a reserved value`,T(e,t)))}extractFieldsFromRange(e){let t={},n=[],r=e.sheetId,i=e.zone.top;for(let a=e.zone.left;a<=e.zone.right;a++){let o=this.getters.getEvaluatedCell({sheetId:r,col:a,row:i});this.assertCellIsValidField(a,i,o);let s=o.value?.toString();if(s){let i=this.getTypeFromZone(r,{top:e.zone.top+1,left:a,bottom:e.zone.bottom,right:a}),o=this.findName(s,t);t[o]={name:o,type:i,string:o,aggregator:i===`integer`?`sum`:`count`},n.push(o)}}return{fields:t,fieldKeys:n}}findName(e,t){return $t(e,Object.keys(t),{compute:(e,t)=>`${e}${t}`,start:2})}extractDataEntriesFromRange(e){let t=[];for(let n=e.zone.top+1;n<=e.zone.bottom;n++){let r={top:n,bottom:n,left:e.zone.left,right:e.zone.right},i=this.getters.getEvaluatedCellsInZone(e.sheetId,r),a={};for(let e in i){let t=i[e],n=this.fields[this.metaData.fieldKeys[e]];if(!n)throw Error(`Field ${this.metaData.fieldKeys[e]} does not exist`);t.value===``?a[n.name]={value:null,type:`empty`,formattedValue:``}:a[n.name]=t}a.__count={value:1,type:`number`,formattedValue:`1`},t.push(a)}let n=this.definition.columns.concat(this.definition.rows).filter(e=>e.type===`datetime`);if(n.length){let e=this.getters.getLocale();for(let r of t)for(let t of n){let n=gz(t,r[t.fieldName]?.value||null,this.getters.getLocale()),{format:i,value:a}=Ju(t.granularity||`month`).toValueAndFormat(n,e);r[t.nameWithGranularity]={value:n,type:r[t.fieldName]?.type||`empty`,format:r[t.fieldName]?.format,formattedValue:B(a,{locale:e,format:i})}}}return t}};let bz=new h,xz=[`year`,`quarter_number`,`month_number`,`month`,`iso_week_number`,`day_of_month`,`day`,`day_of_week`],Sz=[...xz,`hour_number`,`minute_number`,`second_number`];bz.add(`SPREADSHEET`,{ui:yz,definition:rz,dateGranularities:[...xz],isMeasureCandidate:e=>e.type!==`boolean`,datetimeGranularities:[...Sz],isGroupable:()=>!0,adaptRanges:(e,t,n)=>{if(t.type!==`SPREADSHEET`||!t.dataSet)return t;let{sheetId:r,zone:i}=t.dataSet,a=e.getRangeFromZone(r,i),o=Cz(a,n);if(o===a)return t;let s=o&&{sheetId:o.sheetId,zone:o.zone};return{...t,dataSet:s}}});function Cz(e,t){if(!e)return;let n=t(e);switch(n.changeType){case`REMOVE`:return;default:return n.range}}var wz=class extends ef{mutators=[`reset`,`deferUpdates`,`applyUpdate`,`discardPendingUpdate`,`update`];updatesAreDeferred;draft=null;notification=this.get(dC);alreadyNotified=!1;constructor(e,t){super(e),this.pivotId=t,this.updatesAreDeferred=this.getters.getPivotCoreDefinition(this.pivotId).deferUpdates??!1}handle(e){switch(e.type){case`UPDATE_PIVOT`:e.pivotId===this.pivotId&&this.getters.getPivot(this.pivotId).init()}}get fields(){return this.pivot.getFields()}get pivot(){return this.getters.getPivot(this.pivotId)}get definition(){let e=bz.get(this.pivot.type).definition;return this.draft?new e(this.draft,this.fields,this.getters):this.pivot.definition}get isDirty(){return!!this.draft}get measureFields(){let e=[{name:`__count`,string:O(`Count`),type:`integer`,aggregator:`sum`}],t=this.fields;for(let n in t){let r=t[n];r&&bz.get(this.pivot.type).isMeasureCandidate(r)&&e.push(r)}return e.sort((e,t)=>e.string.localeCompare(t.string))}get unusedGroupableFields(){let e=[],t=this.fields;for(let n in t){let r=t[n];r&&bz.get(this.pivot.type).isGroupable(r)&&e.push(r)}let{columns:n,rows:r,measures:i}=this.definition,a=i.concat(r).concat(n).map(e=>e.fieldName),o=this.unusedGranularities;return e.filter(e=>gd(e)?!a.includes(e.name)||o[e.name].size>0:!a.includes(e.name)).sort((e,t)=>e.string.localeCompare(t.string))}get datetimeGranularities(){return bz.get(this.pivot.type).datetimeGranularities}get dateGranularities(){return bz.get(this.pivot.type).dateGranularities}get unusedGranularities(){return this.getUnusedGranularities(this.fields,this.draft??this.getters.getPivotCoreDefinition(this.pivotId))}reset(e){this.pivotId=e,this.updatesAreDeferred=!0,this.draft=null}deferUpdates(e){e===!1&&this.draft?(this.draft.deferUpdates=!1,this.applyUpdate()):this.update({deferUpdates:e}),this.updatesAreDeferred=e}applyUpdate(){if(this.draft&&(this.model.dispatch(`UPDATE_PIVOT`,{pivotId:this.pivotId,pivot:this.draft}),this.draft=null,!this.alreadyNotified&&this.isUpdatedPivotVisibleInViewportOnlyAsStaticPivot())){let e=`=PIVOT(${this.getters.getPivotFormulaId(this.pivotId)})`;this.alreadyNotified=!0,this.notification.notifyUser({type:`info`,text:O(`Pivot updates only work with dynamic pivot tables. Use the formula '%s' or re-insert the static pivot from the Data menu.`,e),sticky:!0})}}discardPendingUpdate(){this.draft=null}update(e){let t=this.getters.getPivotCoreDefinition(this.pivotId),n={...t,...this.draft,...e},r={...n,columns:n.columns.map(e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity})),rows:n.rows.map(e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity})),measures:n.measures.map(e=>({id:e.id,fieldName:e.fieldName,aggregator:e.aggregator,userDefinedName:e.userDefinedName,computedBy:e.computedBy,isHidden:e.isHidden,format:e.format,display:e.display})),sortedColumn:this.shouldKeepSortedColumn(n)?n.sortedColumn:void 0};if(!this.draft&&w(t,r))return;let i=this.addDefaultDateTimeGranularity(this.fields,r);this.draft=i,this.updatesAreDeferred||this.applyUpdate()}isUpdatedPivotVisibleInViewportOnlyAsStaticPivot(){let e=0,t=this.getters.getPivotFormulaId(this.pivotId);for(let n of this.getters.getVisibleCellPositions()){let r=this.getters.getCell(n);if(r?.isFormula){let n=SC(r.compiledFormula.tokens),i=n?.args[0]?.value;if(n&&t===i.toString()){if(n.functionName===`PIVOT`)return!1;e++}}}return e>0}addDefaultDateTimeGranularity(e,t){let{columns:n,rows:r}=t,i=b(n),a=b(r),o=this.getUnusedGranularities(e,t);for(let t of i.concat(a)){let n=e[t.fieldName]?.type;if((n===`date`||n===`datetime`)&&!t.granularity){let e=o[t.fieldName]?.values().next().value;o[t.fieldName]?.delete(e),t.granularity=e}}return{...t,columns:i,rows:a}}getUnusedGranularities(e,t){let{columns:n,rows:r,measures:i}=t,a=n.concat(r).concat(i).filter(t=>{let n=e[t.fieldName]?.type;return n===`date`||n===`datetime`}),o={};for(let t of a)o[t.fieldName]=new Set(e[t.fieldName]?.type===`date`?this.dateGranularities:this.datetimeGranularities);for(let e of a)o[e.fieldName].delete(e.granularity);return o}shouldKeepSortedColumn(e){let{sortedColumn:t}=e;if(!t)return!0;let n=this.getters.getPivotCoreDefinition(this.pivotId);return e.measures.find(e=>e.id===t.measure)&&w(n.columns,e.columns)}},Tz=class extends t.Component{static template=`o-spreadsheet-PivotSpreadsheetSidePanel`;static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:QR,Section:Q,SelectionInput:qI,Checkbox:Yj,PivotDeferUpdate:VR,PivotTitleSection:$R};store;state;pivotSidePanelRef=(0,t.useRef)(`pivotSidePanel`);setup(){this.store=Jd(wz,this.props.pivotId),this.state=(0,t.useState)({range:void 0,rangeHasChanged:!1})}get shouldDisplayInvalidRangeError(){return this.store.isDirty&&this.state.rangeHasChanged?!1:this.pivot.isInvalidRange}get ranges(){return this.state.range?[this.state.range]:this.definition.range?[this.env.model.getters.getRangeString(this.definition.range,`forceSheetReference`)]:[]}get pivot(){return this.store.pivot}get definition(){return this.store.definition}getScrollableContainerEl(){return this.pivotSidePanelRef.el}onSelectionChanged(e){this.state.rangeHasChanged=!0,this.state.range=e[0]}onSelectionConfirmed(){if(this.state.range){let e=this.env.model.getters.getRangeFromSheetXC(this.env.model.getters.getActiveSheetId(),this.state.range);if(e.invalidSheetName||e.invalidXc)return;let t={sheetId:e.sheetId,zone:e.zone};this.store.update({dataSet:t}),this.store.applyUpdate()}}flipAxis(){let{rows:e,columns:t}=this.definition;this.onDimensionsUpdated({rows:t,columns:e})}onDimensionsUpdated(e){this.store.update(e)}};let Ez=new h;Ez.add(`SPREADSHEET`,{editor:Tz});var Dz=class extends t.Component{static template=`o-spreadsheet-PivotSidePanel`;static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:QR,Section:Q};setup(){cR(this)}get sidePanelEditor(){let e=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);if(!e)throw Error(`pivotId does not correspond to a pivot.`);return Ez.get(e.type).editor}get highlights(){return MI(this.env.model.getters,this.props.pivotId)}};H`
|
|
1395
|
+
`;var QR=class extends t.Component{static template=`o-spreadsheet-PivotLayoutConfigurator`;static components={AddDimensionButton:UR,PivotDimension:KR,PivotDimensionOrder:JR,PivotDimensionGranularity:qR,PivotMeasureEditor:XR,PivotSortSection:ZR};static props={definition:Object,onDimensionsUpdated:Function,unusedGroupableFields:Array,measureFields:Array,unusedGranularities:Object,dateGranularities:Array,datetimeGranularities:Array,getScrollableContainerEl:{type:Function,optional:!0},pivotId:String};dimensionsRef=(0,t.useRef)(`pivot-dimensions`);dragAndDrop=RI();AGGREGATORS=ud;composerFocus;isDateOrDatetimeField=gd;setup(){this.composerFocus=V(nf)}startDragAndDrop(e,t){if(t.button!==0||t.target.tagName===`SELECT`)return;let n=this.getDimensionElementsRects(),{columns:r,rows:i}=this.props.definition,a=[...r.map(e=>e.nameWithGranularity),`__rows_title__`,...i.map(e=>e.nameWithGranularity)],o=r.concat(i),s=a.map((e,t)=>({id:e,size:n[t+1].height,position:n[t+1].y}));this.dragAndDrop.start(`vertical`,{draggedItemId:e.nameWithGranularity,initialMousePosition:t.clientY,items:s,scrollableContainerEl:this.props.getScrollableContainerEl?.()||this.dimensionsRef.el,onDragEnd:(e,t)=>{let n=a.findIndex(t=>t===e);if(n===t)return;let r=[...a];r.splice(n,1),r.splice(t,0,e);let i=r.slice(0,r.indexOf(`__rows_title__`)),s=r.slice(r.indexOf(`__rows_title__`)+1);this.props.onDimensionsUpdated({columns:i.map(e=>o.find(t=>t.nameWithGranularity===e)).filter(C),rows:s.map(e=>o.find(t=>t.nameWithGranularity===e)).filter(C)})}})}getGranularitiesFor(e){return gd(e)?e.type===`date`?this.props.dateGranularities:this.props.datetimeGranularities:[]}startDragAndDropMeasures(e,t){if(t.button!==0||t.target.tagName===`SELECT`||t.target.tagName===`INPUT`||this.composerFocus.focusMode!==`inactive`)return;let n=this.getDimensionElementsRects(),{measures:r,columns:i,rows:a}=this.props.definition,o=r.map(e=>e.id),s=3+i.length+a.length,c=o.map((e,t)=>({id:e,size:n[t+s].height,position:n[t+s].y}));this.dragAndDrop.start(`vertical`,{draggedItemId:e.id,initialMousePosition:t.clientY,items:c,scrollableContainerEl:this.props.getScrollableContainerEl?.()||this.dimensionsRef.el,onDragEnd:(e,t)=>{let n=o.findIndex(t=>t===e);if(n===t)return;let i=[...o];i.splice(n,1),i.splice(t,0,e),this.props.onDimensionsUpdated({measures:i.map(e=>r.find(t=>t.id===e)).filter(C)})}})}getDimensionElementsRects(){return Array.from(this.dimensionsRef.el.children).map(e=>{let t=getComputedStyle(e),n=e.getBoundingClientRect();return{x:n.x,y:n.y,width:n.width+parseInt(t.marginLeft||`0`)+parseInt(t.marginRight||`0`),height:n.height+parseInt(t.marginTop||`0`)+parseInt(t.marginBottom||`0`)}})}removeDimension(e){let{columns:t,rows:n}=this.props.definition;this.props.onDimensionsUpdated({columns:t.filter(t=>t.nameWithGranularity!==e.nameWithGranularity),rows:n.filter(t=>t.nameWithGranularity!==e.nameWithGranularity)})}removeMeasureDimension(e){let{measures:t}=this.props.definition;this.props.onDimensionsUpdated({measures:t.filter(t=>t.id!==e.id)})}addColumnDimension(e){let{columns:t}=this.props.definition;this.props.onDimensionsUpdated({columns:t.concat([{fieldName:e,order:`asc`}])})}addRowDimension(e){let{rows:t}=this.props.definition;this.props.onDimensionsUpdated({rows:t.concat([{fieldName:e,order:`asc`}])})}addMeasureDimension(e){let{measures:t}=this.props.definition,n=this.getDefaultMeasureAggregator(e);this.props.onDimensionsUpdated({measures:t.concat([{id:this.getMeasureId(e,n),fieldName:e,aggregator:n}])})}updateMeasure(e,t){let{measures:n}=this.props.definition,r={measures:n.map(n=>n.id===e.id?t:n)};this.props.definition.sortedColumn?.measure===e.id&&(r.sortedColumn={...this.props.definition.sortedColumn,measure:t.id}),this.props.onDimensionsUpdated(r)}getMeasureId(e,t){let n=e.replaceAll(`'`,``)+(t?`:${t}`:``),r=n,i=2;for(;this.props.definition.measures.some(e=>e.id===r);)r=`${n}:${i}`,i++;return r}getDefaultMeasureAggregator(e){let t=this.props.measureFields.find(t=>t.name===e);return t?.aggregator?t.aggregator:`count`}addCalculatedMeasure(){let{measures:e}=this.props.definition,t=this.env.model.getters.generateNewCalculatedMeasureName(e);this.props.onDimensionsUpdated({measures:e.concat([{id:this.getMeasureId(t,`sum`),fieldName:t,aggregator:`sum`,computedBy:{sheetId:this.env.model.getters.getActiveSheetId(),formula:`=0`}}])})}updateOrder(e,t){let{rows:n,columns:r}=this.props.definition;this.props.onDimensionsUpdated({rows:n.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,order:t||void 0}:n),columns:r.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,order:t||void 0}:n)})}updateGranularity(e,t){let{rows:n,columns:r}=this.props.definition;this.props.onDimensionsUpdated({rows:n.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,granularity:t}:n),columns:r.map(n=>n.nameWithGranularity===e.nameWithGranularity?{...n,granularity:t}:n)})}getMeasureDescription(e){let t=e.display;if(!t||t.type===`no_calculations`)return``;let n=this.env.model.getters.getPivot(this.props.pivotId),r=[...n.definition.columns,...n.definition.rows].find(e=>e.nameWithGranularity===t.fieldNameWithGranularity),i=r?Ed(r):``;return _w.descriptions[t.type](i)}},$R=class extends t.Component{static template=`o-spreadsheet-PivotTitleSection`;static components={CogWheelMenu:GR,Section:Q,TextInput:WR};static props={pivotId:String,flipAxis:Function};get cogWheelMenuItems(){return[{name:O(`Flip axes`),icon:`o-spreadsheet-Icon.EXCHANGE`,execute:this.props.flipAxis},{name:O(`Duplicate`),icon:`o-spreadsheet-Icon.COPY`,execute:()=>this.duplicatePivot()},{name:O(`Delete`),icon:`o-spreadsheet-Icon.TRASH`,execute:()=>this.delete()}]}get name(){return this.env.model.getters.getPivotName(this.props.pivotId)}get displayName(){return this.env.model.getters.getPivotDisplayName(this.props.pivotId)}duplicatePivot(){let e=this.env.model.uuidGenerator.smallUuid(),t=this.env.model.uuidGenerator.smallUuid(),n=this.env.model.dispatch(`DUPLICATE_PIVOT_IN_NEW_SHEET`,{pivotId:this.props.pivotId,newPivotId:e,newSheetId:t}),r;r=n.isSuccessful?O(`Pivot duplicated.`):n.isCancelledBecause(`PivotInError`)?O(`Cannot duplicate a pivot in error.`):O(`Pivot duplication failed.`);let i=n.isSuccessful?`success`:`danger`;this.env.notifyUser({text:r,sticky:!1,type:i}),n.isSuccessful&&this.env.openSidePanel(`PivotSidePanel`,{pivotId:e})}delete(){this.env.askConfirmation(O(`Are you sure you want to delete this pivot?`),()=>{this.env.model.dispatch(`REMOVE_PIVOT`,{pivotId:this.props.pivotId})})}onNameChanged(e){let t=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);this.env.model.dispatch(`UPDATE_PIVOT`,{pivotId:this.props.pivotId,pivot:{...t,name:e}})}},ez=class{measures;columns;rows;sortedColumn;constructor(e,t){this.measures=e.measures.map(e=>tz(t,e)),this.columns=e.columns.map(e=>nz(t,e)),this.rows=e.rows.map(e=>nz(t,e)),this.sortedColumn=e.sortedColumn}getDimension(e){let t=this.columns.find(t=>t.nameWithGranularity===e)||this.rows.find(t=>t.nameWithGranularity===e);if(!t)throw new M(O(`Dimension %s does not exist`,e));return t}getMeasure(e){let t=this.measures.find(t=>t.id===e);if(!t)throw new M(O(`Field %s is not a measure`,e));return t}};function tz(e,t){let n=t.fieldName,r=n===`__count`?{name:`__count`,string:O(`Count`),type:`integer`,aggregator:`sum`}:e[n],i=t.aggregator;return{id:t.id,get displayName(){return t.userDefinedName??r?.string??t.fieldName},userDefinedName:t.userDefinedName,fieldName:n,aggregator:i,type:n===`__count`?`integer`:r?.type??`integer`,isValid:!!(r||t.computedBy),isHidden:t.isHidden,format:t.format,computedBy:t.computedBy,display:t.display}}function nz(e,t){let n=e[t.fieldName],r=n?.type??`integer`,i=n&&gd(n)?t.granularity:void 0;return{displayName:n?.string??t.fieldName,nameWithGranularity:t.fieldName+(i?`:${i}`:``),fieldName:t.fieldName,granularity:i,type:r,order:t.order,isValid:!!n}}var rz=class extends ez{range;constructor(e,t,n){if(super(e,t),e.dataSet){let{sheetId:t,zone:r}=e.dataSet;this.range=n.getRangeFromZone(t,r)}}},iz=class{columns;rows;measures;fieldsType;maxIndent;pivotCells={};rowTree;colTree;isSorted=!1;constructor(e,t,n,r){this.columns=e.map(e=>{let t=1;return e.map(e=>(e={...e,offset:t},t+=e.width,e))}),this.rows=t,this.measures=n,this.fieldsType=r,this.maxIndent=Math.max(...this.rows.map(e=>e.indent)),this.rowTree=kt(()=>this.buildRowsTree()),this.colTree=kt(()=>this.buildColumnsTree())}getNumberOfDataColumns(){return this.columns.at(-1)?.length||0}getPivotCells(e=!0,t=!0){let n=JSON.stringify({includeTotal:e,includeColumnHeaders:t});if(!this.pivotCells[n]){let r=this.rows.length,i=this.getNumberOfDataColumns(),a=this.columns.length+r,o=1+i;!e&&r!==1&&--a,!e&&i!==this.measures.length&&(o-=this.measures.length);let s=[],c=t?0:this.columns.length;for(let t=0;t<o;t++){s.push([]);for(let n=c;n<a;n++)!e&&n===a||s[t].push(this.getPivotCell(t,n,e))}this.pivotCells[n]=s}return this.pivotCells[n]}getRowTree(){return this.rowTree()}getColTree(){return this.colTree()}isTotalRow(e){return this.rows[e].indent!==this.maxIndent}getPivotCell(e,t,n=!0){let r=this.columns.length;if(e>0&&t===r-1){let n=this.getColHeaderDomain(e,t);if(!n)return az;let r=n.at(-1)?.value?.toString()||``;return{type:`MEASURE_HEADER`,domain:n.slice(0,-1),measure:r}}else if(t<=r-1){let n=this.getColHeaderDomain(e,t);return n?{type:`HEADER`,domain:n}:az}else if(e===0){let e=t-r;return{type:`HEADER`,domain:this.getRowDomain(e)}}else{let i=t-r;return!n&&this.isTotalRow(i)?az:{type:`VALUE`,domain:[...this.getRowDomain(i),...this.getColDomain(e)],measure:this.getColMeasure(e)}}}getColHeaderDomain(e,t){if(e===0)return;let n=[],r=this.columns[t].find(t=>t.offset===e);if(r){for(let e=0;e<r.fields.length;e++){let t=r.fields[e];if(t===`measure`)n.push({type:`char`,field:t,value:bd({displayName:`measure`,type:`char`},r.values[e])});else{let{fieldName:i,granularity:a}=hd(t),o=this.fieldsType[i]||`char`;n.push({type:o,field:t,value:bd({displayName:i,type:o,granularity:a},r.values[e])})}}return n}}getColDomain(e){let t=this.getColHeaderDomain(e,this.columns.length-1);return t?t.slice(0,-1):[]}getColMeasure(e){let t=this.getColHeaderDomain(e,this.columns.length-1)?.at(-1)?.value;if(t==null)throw Error(`Measure is missing`);return t.toString()}getRowDomain(e){let t=[];for(let n=0;n<this.rows[e].fields.length;n++){let r=this.rows[e].fields[n],{fieldName:i,granularity:a}=hd(r),o=this.fieldsType[i]||`char`;t.push({type:o,field:r,value:bd({displayName:i,type:o,granularity:a},this.rows[e].values[n])})}return t}buildRowsTree(){let e=[],t=0,n={};n[0]=e;for(let r of this.rows){if(r.fields.length===0||r.values.length===0)return e;let i=r.fields.length-1,a=r.fields[i],{fieldName:o,granularity:s}=hd(a),c=bd({displayName:o,type:this.fieldsType[o]??`char`,granularity:s},r.values[i]);if(i>t){t=i,n[t]=[];let e=n[t-1].at(-1);e&&(e.children=n[t])}t=i;let l={value:c,field:r.fields[i],children:[],type:this.fieldsType[o]||`char`,width:0};n[t].push(l)}return e}buildColumnsTree(){let e=[],t=this.columns.at(-2)||[],n={};n[0]=e;for(let e of t)for(let t=0;t<e.fields.length;t++){let r=e.fields[t],{fieldName:i,granularity:a}=hd(r),o=bd({displayName:i,type:this.fieldsType[i]??`char`,granularity:a},e.values[t]),s={value:o,field:e.fields[t],children:[],width:e.width,type:this.fieldsType[i]||`char`};n[t]?.at(-1)?.value!==o&&(n[t+1]=[],s.children=n[t+1],n[t].push(s))}return e}export(){return{cols:this.columns,rows:this.rows,measures:this.measures,fieldsType:this.fieldsType}}sort(e,t,n){if(this.isSorted)return;let r=(e,t)=>{let r=n(e,t).value;return typeof r==`number`?r:-1/0},i=t.domain,a=Ku(this.rowTree(),[],(n,a)=>{let o=r(e,[...n,...i]),s=r(e,[...a,...i]);return t.order===`asc`?o-s:s-o});this.rowTree=kt(a),this.rows=[...this.rowTreeToRows(a),this.rows[this.rows.length-1]],this.isSorted=!0}rowTreeToRows(e,t){return e.flatMap(e=>{let n={indent:t?t.indent+1:1,fields:[...t?.fields||[],e.field],values:[...t?.values||[],e.value]};return[n,...this.rowTreeToRows(e.children,n)]})}};let az={type:`EMPTY`};function oz(e,t){let n=t.measures.filter(e=>!e.isHidden).map(e=>e.id),r=cz(e,t.columns,0);lz(r,n.length);let i=uz(r,t),a=sz(e,0,t.rows,[],[]);a.push({fields:[],values:[],indent:0});let o={};for(let e of t.columns)o[e.fieldName]=e.type;for(let e of t.rows)o[e.fieldName]=e.type;return new iz(i,a,n,o)}function sz(e,t,n,r,i){if(t>=n.length)return[];let a=n[t],o=a.nameWithGranularity,s=dz(e,a),c=pz(s,a),l=[],u=r.concat(o);for(let e of c){let r=i.concat(e);l.push({fields:u,values:r,indent:t+1});let a=s[e];a&&l.push(...sz(a,t+1,n,u,r))}return l}function cz(e,t,n){if(n>=t.length)return[];let r=t[n],i=t[n].nameWithGranularity,a=dz(e,r);return pz(a,t[n]).map(e=>({value:a[e]?.[0]?.[r.nameWithGranularity]?.value??null,field:i,children:cz(a[e]||[],t,n+1),type:r.type,width:0}))}function lz(e,t){for(let n in e){let r=e[n];r.children.length===0?r.width=t:(lz(r.children,t),r.width=r.children.reduce((e,t)=>e+t.width,0))}}function uz(e,t){let n=t.columns.map(e=>e.nameWithGranularity),r=n.length,i=t.measures.filter(e=>!e.isHidden),a=i.length,o=Array(r).fill(0).map(()=>[]);function s(e,t,i){let a=o[t];for(let o of e){let e=i.concat([o.value]),c={fields:n.slice(0,t+1),values:e,width:o.width,offset:0};a.push(c),t<=r-1&&s(o.children,t+1,e)}}s(e,0,[]);let c=n.length>0,l=[];return c&&o[o.length-1].forEach(e=>{i.forEach(t=>{let n={fields:[...e.fields,`measure`],values:[...e.values,t.id],width:1,offset:0};l.push(n)})}),i.forEach(e=>{let t={fields:[`measure`],values:[e.id],width:1,offset:0};l.push(t)}),o.push(l),o.length===1&&o.unshift([]),o[o.length-2].push({fields:[],values:[],width:a,offset:0}),o}function dz(e,t){return Object.groupBy(e,fz(t))}function fz(e){let t=e.nameWithGranularity;return e=>`${e[t]?.value??null}`}function pz(e,t){return t.order?Object.keys(e).sort((e,n)=>mz(t,e,n)):Object.keys(e)}function mz(e,t,n){return t===`null`?e.order===`asc`?1:-1:n===`null`?e.order===`asc`?-1:1:e.type===`integer`||e.type===`datetime`?e.order===`asc`?F(t,k)-F(n,k):F(n,k)-F(t,k):e.order===`asc`?t.localeCompare(n):n.localeCompare(t)}let hz=Symbol(`NULL`);function gz(e,t,n){let r=e.granularity||`month`;if(!(r in _z))throw Error(`Unknown date granularity: ${r}`);let i=typeof t==`number`||typeof t==`string`?t:hz;if(!_z[r].set.has(t)){_z[r].set.add(t);let a=null;if(typeof t==`number`||typeof t==`string`){let e=R(t,n);switch(r){case`year`:a=e.getFullYear();break;case`quarter_number`:a=Math.floor(e.getMonth()/3)+1;break;case`month_number`:a=e.getMonth()+1;break;case`month`:a=Math.floor(F(t,n));break;case`iso_week_number`:a=e.getIsoWeek();break;case`day_of_month`:a=e.getDate();break;case`day`:a=Math.floor(F(t,n));break;case`day_of_week`:a=(e.getDay()+7-n.weekStart)%7+1;break;case`hour_number`:a=e.getHours();break;case`minute_number`:a=e.getMinutes();break;case`second_number`:a=e.getSeconds();break}}_z[r].values[i]=bd(e,a)}return _z[r].values[i]}let _z={year:{set:new Set,values:{}},quarter_number:{set:new Set,values:{}},month_number:{set:new Set,values:{}},month:{set:new Set,values:{}},iso_week_number:{set:new Set,values:{}},day_of_month:{set:new Set,values:{}},day:{set:new Set,values:{}},day_of_week:{set:new Set,values:{}},hour_number:{set:new Set,values:{}},minute_number:{set:new Set,values:{}},second_number:{set:new Set,values:{}}};function vz(){for(let e in _z)_z[e].set.clear(),_z[e].values={}}var yz=class{type=`SPREADSHEET`;getters;_definition;coreDefinition;metaData={fields:{},fieldKeys:[]};dataEntries=[];table;invalidRangeError;needsReevaluation=!0;constructor(e,t){this.getters=t.getters,this.coreDefinition=t.definition}init(e={}){(!this._definition||e.reload)&&(this.reload(4),this.needsReevaluation=!1)}reload(e){e===4&&(this.metaData=this.loadMetaData()),e>=3&&(this._definition=this.loadRuntimeDefinition()),e>=2&&(this.dataEntries=this.loadData()),e>=1&&(this.table=void 0)}onDefinitionChange(e){let t=this.coreDefinition;if(this.coreDefinition=e,this._definition){let n=Math.max(this.computeShouldReload(t,e),0);this.reload(n)}}computeShouldReload(e,t){return w(e.dataSet,t.dataSet)?3:4}get isInvalidRange(){return!!this.invalidRangeError}get invalidRangeMessage(){return this.invalidRangeError?.message}get definition(){if(this._definition||this.init(),!this._definition)throw Error(`Pivot definition should be defined at this point.`);return this._definition}isValid(){if(this.invalidRangeError||!this.definition)return!1;for(let e of this.definition.measures)if(!e.isValid)return!1;for(let e of this.definition.columns)if(!e.isValid)return!1;for(let e of this.definition.rows)if(!e.isValid)return!1;return!0}assertIsValid({throwOnError:e}){if(!this.isValid()){if(e)throw this.invalidRangeError?this.invalidRangeError:new M(O(`At least one measure and/or dimension is not correct.`));return{value:j.GenericError,message:this.invalidRangeError?.message??O(`At least one measure and/or dimension is not correct.`)}}}areDomainArgsFieldsValid(e){let t=e.filter((e,t)=>t%2==0).map(I);return t.length&&t.at(-1)===`measure`&&(t=t.slice(0,-1)),vd(t,this.definition)}parseArgsToPivotDomain(e){let t=[];for(let n=0;n<e.length-1;n+=2){let r=I(e[n]),i=this.getTypeOfDimension(r),a=r===`measure`?I(e[n+1]):bd(this.getDimension(r),e[n+1]);t.push({field:r,value:a,type:i})}return t}markAsDirtyForEvaluation(){this.needsReevaluation=!0}getMeasure(e){return this.definition.getMeasure(e)}getPivotMeasureValue(e){return{value:this.getMeasure(e).displayName}}getPivotHeaderValueAndFormat(e){let t=e.at(-1);if(!t)return{value:O(`Total`)};let n=this.getDimension(t.field),r=this.filterDataEntriesFromDomain(this.dataEntries,e)[0]?.[n.nameWithGranularity];return n.type===`datetime`?Ju(n.granularity||`month`).toValueAndFormat(t.value,this.getters.getLocale()):r?r.value===null?{value:O(`(Undefined)`)}:r:{value:``}}getPivotCellValueAndFormat(e,t){let n=this.filterDataEntriesFromDomain(this.dataEntries,t);if(n.length===0)return{value:``};let r=this.getMeasure(e),i=n.map(e=>e[r.fieldName]).filter(C),a=i.filter(e=>e.type!==`empty`),o=r.aggregator,s=dd[o];if(!s)throw Error(`Aggregator ${o} does not exist`);try{let e=s([i],this.getters.getLocale());return a.length===0?{...e,value:``}:e}catch(e){return ox(e,o.toUpperCase())}}getPossibleFieldValues(e){let t=[],n=dz(this.dataEntries,e),r=pz(n,e);for(let i of r)t.push({value:n[i]?.[0]?.[e.nameWithGranularity]?.value??``,label:n[i]?.[0]?.[e.nameWithGranularity]?.formattedValue||``});return t}getTableStructure(){if(!this.isValid())throw Error(`Pivot is not valid !`);return this.table||=oz(this.dataEntries,this.definition),this.table}getFields(){return this.metaData.fields}get fields(){return this.getFields()}loadMetaData(){if(this.invalidRangeError=void 0,this.coreDefinition.dataSet){let{zone:e,sheetId:t}=this.coreDefinition.dataSet,n=this.getters.getRangeFromZone(t,e);try{return this.extractFieldsFromRange(n)}catch(e){return this.invalidRangeError=e,{fields:{},fieldKeys:[]}}}else return this.invalidRangeError=new M(O(`The pivot cannot be created because the dataset is missing.`)),{fields:{},fieldKeys:[]}}loadRuntimeDefinition(){return new rz(this.coreDefinition,this.fields,this.getters)}loadData(){let e=this._definition?.range;return this.isValid()&&e?this.extractDataEntriesFromRange(e):[]}getTypeOfDimension(e){if(e===`measure`)return`char`;let{fieldName:t}=hd(e),n=this.fields[t]?.type;if(!n)throw Error(`Field ${t} does not exist`);return n}filterDataEntriesFromDomain(e,t){return t.reduce((e,t)=>this.filterDataEntriesFromDomainNode(e,t),e)}filterDataEntriesFromDomainNode(e,t){let{field:n,value:r,type:i}=t,{nameWithGranularity:a}=this.getDimension(n);return e.filter(e=>{let t=e[a]?.value;return i===`char`?String(t)===String(r):t===r})}getDimension(e){return this.definition.getDimension(e)}getTypeFromZone(e,t){let n=this.getters.getEvaluatedCellsInZone(e,t).filter(e=>!(e.type===`empty`||e.value===``));return n.length===0?`integer`:n.every(e=>e.type===`number`&&e.format&&ls(e.format))?`datetime`:n.every(e=>e.type===`boolean`)?`boolean`:n.every(e=>e.type===`number`)?`integer`:`char`}assertCellIsValidField(e,t,n){if(n.type===`error`)throw new M(O(`The pivot cannot be created because cell %s contains an error`,T(e,t)));if(n.type===`empty`||n.value===``)throw new M(O(`The pivot cannot be created because cell %s is empty`,T(e,t)));if(n.value===`__count`)throw new M(O(`The pivot cannot be created because cell %s contains a reserved value`,T(e,t)))}extractFieldsFromRange(e){let t={},n=[],r=e.sheetId,i=e.zone.top;for(let a=e.zone.left;a<=e.zone.right;a++){let o=this.getters.getEvaluatedCell({sheetId:r,col:a,row:i});this.assertCellIsValidField(a,i,o);let s=o.value?.toString();if(s){let i=this.getTypeFromZone(r,{top:e.zone.top+1,left:a,bottom:e.zone.bottom,right:a}),o=this.findName(s,t);t[o]={name:o,type:i,string:o,aggregator:i===`integer`?`sum`:`count`},n.push(o)}}return{fields:t,fieldKeys:n}}findName(e,t){return $t(e,Object.keys(t),{compute:(e,t)=>`${e}${t}`,start:2})}extractDataEntriesFromRange(e){let t=[];for(let n=e.zone.top+1;n<=e.zone.bottom;n++){let r={top:n,bottom:n,left:e.zone.left,right:e.zone.right},i=this.getters.getEvaluatedCellsInZone(e.sheetId,r),a={};for(let e in i){let t=i[e],n=this.fields[this.metaData.fieldKeys[e]];if(!n)throw Error(`Field ${this.metaData.fieldKeys[e]} does not exist`);t.value===``?a[n.name]={value:null,type:`empty`,formattedValue:``}:a[n.name]=t}a.__count={value:1,type:`number`,formattedValue:`1`},t.push(a)}let n=this.definition.columns.concat(this.definition.rows).filter(e=>e.type===`datetime`);if(n.length){let e=this.getters.getLocale();for(let r of t)for(let t of n){let n=gz(t,r[t.fieldName]?.value||null,this.getters.getLocale()),{format:i,value:a}=Ju(t.granularity||`month`).toValueAndFormat(n,e);r[t.nameWithGranularity]={value:n,type:r[t.fieldName]?.type||`empty`,format:r[t.fieldName]?.format,formattedValue:B(a,{locale:e,format:i})}}}return t}};let bz=new h,xz=[`year`,`quarter_number`,`month_number`,`month`,`iso_week_number`,`day_of_month`,`day`,`day_of_week`],Sz=[...xz,`hour_number`,`minute_number`,`second_number`];bz.add(`SPREADSHEET`,{ui:yz,definition:rz,dateGranularities:[...xz],isMeasureCandidate:e=>e.type!==`boolean`,datetimeGranularities:[...Sz],isGroupable:()=>!0,adaptRanges:(e,t,n)=>{if(t.type!==`SPREADSHEET`||!t.dataSet)return t;let{sheetId:r,zone:i}=t.dataSet,a=e.getRangeFromZone(r,i),o=Cz(a,n);if(o===a)return t;let s=o&&{sheetId:o.sheetId,zone:o.zone};return{...t,dataSet:s}}});function Cz(e,t){if(!e)return;let n=t(e);switch(n.changeType){case`REMOVE`:return;default:return n.range}}var wz=class extends ef{pivotId;mutators=[`reset`,`deferUpdates`,`applyUpdate`,`discardPendingUpdate`,`update`];updatesAreDeferred;draft=null;notification=this.get(dC);alreadyNotified=!1;constructor(e,t){super(e),this.pivotId=t,this.updatesAreDeferred=this.getters.getPivotCoreDefinition(this.pivotId).deferUpdates??!1}handle(e){switch(e.type){case`UPDATE_PIVOT`:e.pivotId===this.pivotId&&this.getters.getPivot(this.pivotId).init()}}get fields(){return this.pivot.getFields()}get pivot(){return this.getters.getPivot(this.pivotId)}get definition(){let e=bz.get(this.pivot.type).definition;return this.draft?new e(this.draft,this.fields,this.getters):this.pivot.definition}get isDirty(){return!!this.draft}get measureFields(){let e=[{name:`__count`,string:O(`Count`),type:`integer`,aggregator:`sum`}],t=this.fields;for(let n in t){let r=t[n];r&&bz.get(this.pivot.type).isMeasureCandidate(r)&&e.push(r)}return e.sort((e,t)=>e.string.localeCompare(t.string))}get unusedGroupableFields(){let e=[],t=this.fields;for(let n in t){let r=t[n];r&&bz.get(this.pivot.type).isGroupable(r)&&e.push(r)}let{columns:n,rows:r,measures:i}=this.definition,a=i.concat(r).concat(n).map(e=>e.fieldName),o=this.unusedGranularities;return e.filter(e=>gd(e)?!a.includes(e.name)||o[e.name].size>0:!a.includes(e.name)).sort((e,t)=>e.string.localeCompare(t.string))}get datetimeGranularities(){return bz.get(this.pivot.type).datetimeGranularities}get dateGranularities(){return bz.get(this.pivot.type).dateGranularities}get unusedGranularities(){return this.getUnusedGranularities(this.fields,this.draft??this.getters.getPivotCoreDefinition(this.pivotId))}reset(e){this.pivotId=e,this.updatesAreDeferred=!0,this.draft=null}deferUpdates(e){e===!1&&this.draft?(this.draft.deferUpdates=!1,this.applyUpdate()):this.update({deferUpdates:e}),this.updatesAreDeferred=e}applyUpdate(){if(this.draft&&(this.model.dispatch(`UPDATE_PIVOT`,{pivotId:this.pivotId,pivot:this.draft}),this.draft=null,!this.alreadyNotified&&this.isUpdatedPivotVisibleInViewportOnlyAsStaticPivot())){let e=`=PIVOT(${this.getters.getPivotFormulaId(this.pivotId)})`;this.alreadyNotified=!0,this.notification.notifyUser({type:`info`,text:O(`Pivot updates only work with dynamic pivot tables. Use the formula '%s' or re-insert the static pivot from the Data menu.`,e),sticky:!0})}}discardPendingUpdate(){this.draft=null}update(e){let t=this.getters.getPivotCoreDefinition(this.pivotId),n={...t,...this.draft,...e},r={...n,columns:n.columns.map(e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity})),rows:n.rows.map(e=>({fieldName:e.fieldName,order:e.order,granularity:e.granularity})),measures:n.measures.map(e=>({id:e.id,fieldName:e.fieldName,aggregator:e.aggregator,userDefinedName:e.userDefinedName,computedBy:e.computedBy,isHidden:e.isHidden,format:e.format,display:e.display})),sortedColumn:this.shouldKeepSortedColumn(n)?n.sortedColumn:void 0};if(!this.draft&&w(t,r))return;let i=this.addDefaultDateTimeGranularity(this.fields,r);this.draft=i,this.updatesAreDeferred||this.applyUpdate()}isUpdatedPivotVisibleInViewportOnlyAsStaticPivot(){let e=0,t=this.getters.getPivotFormulaId(this.pivotId);for(let n of this.getters.getVisibleCellPositions()){let r=this.getters.getCell(n);if(r?.isFormula){let n=SC(r.compiledFormula.tokens),i=n?.args[0]?.value;if(n&&t===i.toString()){if(n.functionName===`PIVOT`)return!1;e++}}}return e>0}addDefaultDateTimeGranularity(e,t){let{columns:n,rows:r}=t,i=b(n),a=b(r),o=this.getUnusedGranularities(e,t);for(let t of i.concat(a)){let n=e[t.fieldName]?.type;if((n===`date`||n===`datetime`)&&!t.granularity){let e=o[t.fieldName]?.values().next().value;o[t.fieldName]?.delete(e),t.granularity=e}}return{...t,columns:i,rows:a}}getUnusedGranularities(e,t){let{columns:n,rows:r,measures:i}=t,a=n.concat(r).concat(i).filter(t=>{let n=e[t.fieldName]?.type;return n===`date`||n===`datetime`}),o={};for(let t of a)o[t.fieldName]=new Set(e[t.fieldName]?.type===`date`?this.dateGranularities:this.datetimeGranularities);for(let e of a)o[e.fieldName].delete(e.granularity);return o}shouldKeepSortedColumn(e){let{sortedColumn:t}=e;if(!t)return!0;let n=this.getters.getPivotCoreDefinition(this.pivotId);return e.measures.find(e=>e.id===t.measure)&&w(n.columns,e.columns)}},Tz=class extends t.Component{static template=`o-spreadsheet-PivotSpreadsheetSidePanel`;static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:QR,Section:Q,SelectionInput:qI,Checkbox:Yj,PivotDeferUpdate:VR,PivotTitleSection:$R};store;state;pivotSidePanelRef=(0,t.useRef)(`pivotSidePanel`);setup(){this.store=Jd(wz,this.props.pivotId),this.state=(0,t.useState)({range:void 0,rangeHasChanged:!1})}get shouldDisplayInvalidRangeError(){return this.store.isDirty&&this.state.rangeHasChanged?!1:this.pivot.isInvalidRange}get ranges(){return this.state.range?[this.state.range]:this.definition.range?[this.env.model.getters.getRangeString(this.definition.range,`forceSheetReference`)]:[]}get pivot(){return this.store.pivot}get definition(){return this.store.definition}getScrollableContainerEl(){return this.pivotSidePanelRef.el}onSelectionChanged(e){this.state.rangeHasChanged=!0,this.state.range=e[0]}onSelectionConfirmed(){if(this.state.range){let e=this.env.model.getters.getRangeFromSheetXC(this.env.model.getters.getActiveSheetId(),this.state.range);if(e.invalidSheetName||e.invalidXc)return;let t={sheetId:e.sheetId,zone:e.zone};this.store.update({dataSet:t}),this.store.applyUpdate()}}flipAxis(){let{rows:e,columns:t}=this.definition;this.onDimensionsUpdated({rows:t,columns:e})}onDimensionsUpdated(e){this.store.update(e)}};let Ez=new h;Ez.add(`SPREADSHEET`,{editor:Tz});var Dz=class extends t.Component{static template=`o-spreadsheet-PivotSidePanel`;static props={pivotId:String,onCloseSidePanel:Function};static components={PivotLayoutConfigurator:QR,Section:Q};setup(){cR(this)}get sidePanelEditor(){let e=this.env.model.getters.getPivotCoreDefinition(this.props.pivotId);if(!e)throw Error(`pivotId does not correspond to a pivot.`);return Ez.get(e.type).editor}get highlights(){return MI(this.env.model.getters,this.props.pivotId)}};H`
|
|
1396
1396
|
.o-checkbox-selection {
|
|
1397
1397
|
max-height: 300px;
|
|
1398
1398
|
}
|
|
@@ -1974,13 +1974,13 @@ stores.inject(MyMetaStore, storeInstance);
|
|
|
1974
1974
|
background: #e7f2f6;
|
|
1975
1975
|
}
|
|
1976
1976
|
}
|
|
1977
|
-
`;var fV=class extends t.Component{static template=`o_spreadsheet.PivotHTMLRenderer`;static components={Checkbox:Yj};static props={pivotId:String,onCellClicked:Function};pivot=this.env.model.getters.getPivot(this.props.pivotId);data={columns:[],rows:[],values:[]};state=(0,t.useState)({showMissingValuesOnly:!1});setup(){let e=this.pivot.getTableStructure(),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;let e=this.getColumnsIndexes(),t=this.getRowsIndexes();return{columns:this.buildColumnsMissing(e),rows:this.buildRowsMissing(t),values:this.buildValuesMissing(e,t)}}addRecursiveRow(e){let t=this.pivot.getTableStructure().rows,n=[...t[e].values];if(n.length<=1)return[e];n.pop();let r=t.findIndex(e=>JSON.stringify(e.values)===JSON.stringify(n));return[e].concat(this.addRecursiveRow(r))}buildColumnsMissing(e){let t=[];for(let e of this.data.columns){let n=[];for(let t in e)for(let r=0;r<e[t].span;r++)n.push(parseInt(t,10));t.push(n)}for(let n=t[t.length-1].length;n>=0;n--)if(!e.includes(n))for(let e of t)e.splice(n,1);let n=[];for(let e in t){let r=[],i,a=1;for(let n=0;n<t[e].length;n++)i===t[e][n]?a++:(i!==void 0&&r.push(Object.assign({},this.data.columns[e][i],{span:a})),i=t[e][n],a=1);i!==void 0&&r.push(Object.assign({},this.data.columns[e][i],{span:a})),n.push(r)}return n}buildRowsMissing(e){return e.map(e=>this.data.rows[e])}buildValuesMissing(e,t){let n=e.map(()=>[]);for(let r of t)for(let t in e)n[t].push(this.data.values[e[t]][r]);return n}getColumnsIndexes(){let e=new Set;for(let t=0;t<this.data.columns.length;t++){let n=[];for(let e=0;e<this.data.columns[t].length;e++)for(let r=0;r<this.data.columns[t][e].span;r++)n.push(this.data.columns[t][e]);for(let t=0;t<n.length;t++)n[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(){let e=new Set;for(let t=0;t<this.data.rows.length;t++){this.data.rows[t].isMissing&&e.add(t);for(let n of this.data.values)n[t].isMissing&&this.addRecursiveRow(t).forEach(t=>e.add(t))}return Array.from(e).sort((e,t)=>e-t)}_buildColHeaders(e,t){let n=[];for(let r of t.columns){let t=[];for(let n of r){let r=[];for(let e=0;e<n.fields.length;e++)r.push({value:n.fields[e]},{value:n.values[e]});let i=this.pivot.parseArgsToPivotDomain(r),a=this.env.model.getters.getLocale();if(i.at(-1)?.field===`measure`){let{value:r,format:o}=this.pivot.getPivotMeasureValue(I(i.at(-1).value),i);t.push({formula:`=PIVOT.HEADER(${_d(e,i).join(`,`)})`,value:B(r,{format:o,locale:a}),span:n.width,isMissing:!this.tracker?.isHeaderPresent(i)})}else{let{value:r,format:o}=this.pivot.getPivotHeaderValueAndFormat(i);t.push({formula:`=PIVOT.HEADER(${_d(e,i).join(`,`)})`,value:B(r,{format:o,locale:a}),span:n.width,isMissing:!this.tracker?.isHeaderPresent(i)})}}n.push(t)}let r=n[n.length-1];return n[n.length-1]=r.map(e=>(e.isMissing||(e.style=`color: #756f6f;`),e)),n}_buildRowHeaders(e,t){let n=[];for(let r of t.rows){let t=[];for(let e=0;e<r.fields.length;e++)t.push({value:r.fields[e]},{value:r.values[e]});let i=this.pivot.parseArgsToPivotDomain(t),{value:a,format:o}=this.pivot.getPivotHeaderValueAndFormat(i),s=this.env.model.getters.getLocale(),c={formula:`=PIVOT.HEADER(${_d(e,i).join(`,`)})`,value:B(a,{format:o,locale:s}),isMissing:!this.tracker?.isHeaderPresent(i)};r.indent>1&&(c.style=`padding-left: ${r.indent-10}px`),n.push(c)}return n}_buildValues(e,t){let n=[];for(let r of t.columns.at(-1)||[]){let i=[],a=I(r.values[r.values.length-1]);for(let n of t.rows){let t=[];for(let e=0;e<n.fields.length;e++)t.push({value:n.fields[e]},{value:n.values[e]});for(let e=0;e<r.fields.length-1;e++)t.push({value:r.fields[e]},{value:r.values[e]});let o=this.pivot.parseArgsToPivotDomain(t),{value:s,format:c}=this.pivot.getPivotCellValueAndFormat(a,o),l=this.env.model.getters.getLocale();i.push({formula:`=PIVOT.VALUE(${_d(e,o,a).join(`,`)})`,value:B(s,{format:c,locale:l}),isMissing:!this.tracker?.isValuePresent(a,o)})}n.push(i)}return n}},pV=class{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(let n of e){let e=n.call(this,t);Array.isArray(e)||(e=[e]);let r=e.filter(e=>e!==`Success`);if(r.length)return r}return`Success`}}checkValidations(e,...t){return this.batchValidations(...t)(e)}},mV=class extends pV{getters;dispatch;canDispatch;constructor({getters:e,stateObserver:t,range:n,dispatch:r,canDispatch:i}){super(t),n.addRangeProvider(this.adaptRanges.bind(this)),this.getters=e,this.dispatch=r,this.canDispatch=i}import(e){}export(e){}adaptRanges(e,t,n){}garbageCollectExternalResources(){}},hV=class extends mV{static getters=[`getCellBorder`,`getBordersColors`];borders={};allowDispatch(e){switch(e.type){case`SET_BORDER`:return this.checkBordersUnchanged(e);default:return`Success`}}handle(e){switch(e.type){case`ADD_MERGE`:for(let t of e.target)this.addBordersToMerge(e.sheetId,t);break;case`DUPLICATE_SHEET`:let t=this.borders[e.sheetId];if(t){let n=t.slice().map(e=>e?.slice().map(e=>b(e)));this.history.update(`borders`,e.sheetIdTo,n)}break;case`DELETE_SHEET`:let n={...this.borders};delete n[e.sheetId],this.history.update(`borders`,n);break;case`SET_BORDER`:this.setBorder(e.sheetId,e.col,e.row,e.border);break;case`SET_BORDERS_ON_TARGET`:for(let t of e.target)for(let n=t.top;n<=t.bottom;n++)for(let r=t.left;r<=t.right;r++)this.setBorder(e.sheetId,r,n,e.border);break;case`SET_ZONE_BORDERS`:if(e.border){let 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||He.style,color:e.border.color||He.color})}break;case`CLEAR_FORMATTING`:this.clearBorders(e.sheetId,e.target);break;case`REMOVE_COLUMNS_ROWS`:let r=[...e.elements].sort((e,t)=>t-e);for(let t of dt(r))if(e.dimension===`COL`){let n=this.getters.getColsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[n]),this.shiftBordersHorizontally(e.sheetId,t[0]+1,-t.length)}else{let n=this.getters.getRowsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[n]),this.shiftBordersVertically(e.sheetId,t[0]+1,-t.length)}break;case`ADD_COLUMNS_ROWS`:e.dimension===`COL`?this.handleAddColumns(e):this.handleAddRows(e);break}}handleAddColumns(e){let t,n;e.position===`before`?(this.shiftBordersHorizontally(e.sheetId,e.base,e.quantity),t=e.base-1,n=e.base+e.quantity):(this.shiftBordersHorizontally(e.sheetId,e.base+1,e.quantity),t=e.base,n=e.base+e.quantity+1),this.ensureColumnBorderContinuity(e.sheetId,t,n)}handleAddRows(e){let t,n;e.position===`before`?(this.shiftBordersVertically(e.sheetId,e.base,e.quantity),t=e.base-1,n=e.base+e.quantity):(this.shiftBordersVertically(e.sheetId,e.base+1,e.quantity),t=e.base,n=e.base+e.quantity+1),this.ensureRowBorderContinuity(e.sheetId,t,n)}getCellBorder({sheetId:e,col:t,row:n}){let r=this.borders[e]?.[t]?.[n];return r?.top||r?.bottom||r?.left||r?.right?b(r):null}getBordersColors(e){let t=[],n=this.borders[e];if(n){for(let e of n.filter(C))for(let n of e)if(n)for(let e of[`top`,`bottom`,`left`,`right`]){let r=n[e]?.color;r&&t.push(r)}}return t}ensureColumnBorderContinuity(e,t,n){let r=S(t+1,n);for(let i=0;i<this.getters.getNumberRows(e);i++){let a=this.getCellBorder({sheetId:e,col:t,row:i}),o=this.getCellBorder({sheetId:e,col:n,row:i});if(a&&o){let t=this.getCommonSides(a,o);for(let n of r)this.addBorder(e,n,i,t)}}}ensureRowBorderContinuity(e,t,n){let r=S(t+1,n);for(let i=0;i<this.getters.getNumberCols(e);i++){let a=this.getCellBorder({sheetId:e,col:i,row:t}),o=this.getCellBorder({sheetId:e,col:i,row:n});if(a&&o){let t=this.getCommonSides(a,o);for(let n of r)this.addBorder(e,i,n,t)}}}getCommonSides(e,t){let n={};for(let r of[`top`,`bottom`,`left`,`right`])e[r]&&w(e[r],t[r])&&(n[r]=e[r]);return n}getColumnsWithBorders(e){let t=this.borders[e];return t?Object.keys(t).map(e=>parseInt(e,10)):[]}getRowsWithBorders(e){let t=this.borders[e]?.filter(C);if(!t)return[];let n=new Set;for(let e of t)for(let t in e)n.add(parseInt(t,10));return Array.from(n)}getRowsRange(e){return this.borders[e]?S(0,this.getters.getNumberRows(e)+1):[]}shiftBordersHorizontally(e,t,n){this.borders[e]&&this.getColumnsWithBorders(e).filter(e=>e>=t).sort((e,t)=>n<0?e-t:t-e).forEach(t=>{this.moveBordersOfColumn(e,t,n)})}shiftBordersVertically(e,t,n){this.borders[e]&&(n<0&&this.moveBordersOfRow(e,t,n,{destructive:!1}),this.getRowsWithBorders(e).filter(e=>e>=t).sort((e,t)=>n<0?e-t:t-e).forEach(t=>{this.moveBordersOfRow(e,t,n)}))}moveBordersOfRow(e,t,n,{destructive:r}={destructive:!0}){let i=this.borders[e];i&&this.getColumnsWithBorders(e).forEach(a=>{let o=i[a]?.[t+n],s=i[a]?.[t];this.history.update(`borders`,e,a,t+n,r?s:s||o),this.history.update(`borders`,e,a,t,void 0)})}moveBordersOfColumn(e,t,n,{destructive:r}={destructive:!0}){let i=this.borders[e];i&&this.getRowsRange(e).forEach(a=>{let o=i[t+n]?.[a],s=i[t]?.[a];this.history.update(`borders`,e,t+n,a,r?s:s||o),r&&this.history.update(`borders`,e,t,a,void 0)})}setBorder(e,t,n,r,i=!0){let a=this.getters.getNumberCols(e)-1,o=this.getters.getNumberRows(e)-1;(i||!this.borders[e]?.[t]?.[n]?.left)&&(this.history.update(`borders`,e,t,n,`left`,r?.left),r?.left&&t>0&&!w(this.borders[e]?.[t-1]?.[n]?.right,r?.left)&&this.history.update(`borders`,e,t-1,n,`right`,void 0)),(i||!this.borders[e]?.[t]?.[n]?.top)&&(this.history.update(`borders`,e,t,n,`top`,r?.top),r?.top&&n>0&&!w(this.borders[e]?.[t]?.[n-1]?.bottom,r?.top)&&this.history.update(`borders`,e,t,n-1,`bottom`,void 0)),(i||!this.borders[e]?.[t]?.[n]?.right)&&(this.history.update(`borders`,e,t,n,`right`,r?.right),r?.right&&t<a&&!w(this.borders[e]?.[t+1]?.[n]?.left,r?.right)&&this.history.update(`borders`,e,t+1,n,`left`,void 0)),(i||!this.borders[e]?.[t]?.[n]?.bottom)&&(this.history.update(`borders`,e,t,n,`bottom`,r?.bottom),r?.bottom&&n<o&&!w(this.borders[e]?.[t]?.[n+1]?.top,r?.bottom)&&this.history.update(`borders`,e,t,n+1,`top`,void 0))}clearBorders(e,t,n=!1){let r=this.getters.getNumberCols(e)-1,i=this.getters.getNumberRows(e)-1;for(let a of Yn(t))for(let t=a.top;t<=a.bottom;t++){n&&(a.left>0&&this.history.update(`borders`,e,a.left-1,t,`right`,void 0),a.right<r&&this.history.update(`borders`,e,a.right+1,t,`left`,void 0));for(let r=a.left;r<=a.right;r++)this.history.update(`borders`,e,r,t,void 0),n&&(a.top>0&&this.history.update(`borders`,e,r,a.top-1,`bottom`,void 0),a.bottom<i&&this.history.update(`borders`,e,r,a.bottom+1,`top`,void 0))}}clearInsideBorders(e,t){for(let n of t)for(let t=n.top;t<=n.bottom;t++)for(let r=n.left;r<=n.right;r++)this.history.update(`borders`,e,r,t,void 0)}addBorder(e,t,n,r){this.setBorder(e,t,n,{...this.getCellBorder({sheetId:e,col:t,row:n}),...r})}setBorders(e,t,n,r){if(n===`clear`)return this.clearBorders(e,t,!0);for(let i of Yn(t)){if(n===`all`)for(let t=i.top;t<=i.bottom;t++)for(let n=i.left;n<=i.right;n++)this.addBorder(e,n,t,{top:r,right:r,bottom:r,left:r});if(n===`h`||n===`hv`){if(i.top===i.bottom)continue;for(let t=i.left;t<=i.right;t++){this.addBorder(e,t,i.top,{bottom:r});for(let n=i.top+1;n<i.bottom;n++)this.addBorder(e,t,n,{top:r,bottom:r});this.addBorder(e,t,i.bottom,{top:r})}}if(n===`v`||n===`hv`){if(i.left===i.right)continue;for(let t=i.top;t<=i.bottom;t++){this.addBorder(e,i.left,t,{right:r});for(let n=i.left+1;n<i.right;n++)this.addBorder(e,n,t,{left:r,right:r});this.addBorder(e,i.right,t,{left:r})}}if(n===`left`||n===`external`)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.left,t,{left:r});if(n===`right`||n===`external`)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.right,t,{right:r});if(n===`top`||n===`external`)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.top,{top:r});if(n===`bottom`||n===`external`)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.bottom,{bottom:r})}}addBordersToMerge(e,t){let{left:n,right:r,top:i,bottom:a}=t,o=this.getCellBorder({sheetId:e,col:n,row:i}),s=this.getCellBorder({sheetId:e,col:r,row:a});this.clearBorders(e,[t]),o?.top&&this.setBorders(e,[{...t,bottom:i}],`top`,o.top),o?.left&&this.setBorders(e,[{...t,right:n}],`left`,o.left),s?.bottom?this.setBorders(e,[{...t,top:a}],`bottom`,s.bottom):o?.bottom&&this.setBorders(e,[{...t,top:a}],`bottom`,o.bottom),s?.right?this.setBorders(e,[{...t,left:r}],`right`,s.right):o?.right&&this.setBorders(e,[{...t,left:r}],`right`,o.right)}checkBordersUnchanged(e){let t=this.getCellBorder(e),n=!e.border?.bottom&&!e.border?.left&&!e.border?.right&&!e.border?.top;return!t&&n||w(t,e.border)?`NoChanges`:`Success`}import(e){if(Object.keys(e.borders||{}).length)for(let t of e.sheets)for(let[n,r]of Wr(t.id,t.borders)){let{sheetId:t,col:i,row:a}=n,o=e.borders[r];this.setBorder(t,i,a,o,!1)}for(let t of e.sheets)if(t.merges)for(let e of t.merges)this.addBordersToMerge(t.id,ar(e))}export(e){let t={};for(let n of e.sheets){let e={};for(let r=0;r<n.colNumber;r++)for(let i=0;i<n.rowNumber;i++){let a=this.getCellBorder({sheetId:n.id,col:r,row:i});if(a){let o=Hr(a,t),s={sheetId:n.id,col:r,row:i};e[o]??=[],e[o].push(s)}}n.borders=Ur(e)}e.borders=t}exportForExcel(e){this.export(e)}},gV=class extends mV{static getters=[`zoneToXC`,`getCells`,`getTranslatedCellFormula`,`getCellStyle`,`getCellById`,`getFormulaString`,`getFormulaMovedInSheet`];nextId=1;cells={};adaptRanges({applyChange:e},t,n){for(let r of Object.keys(this.cells))for(let i of Object.values(this.cells[r]||{}))if(i.isFormula){for(let a of i.compiledFormula.dependencies)if(a.sheetId===t||a.invalidSheetName===n.old){let t=e(a);t.changeType!==`NONE`&&this.history.update(`cells`,r,i.id,`compiledFormula`,`dependencies`,i.compiledFormula.dependencies.indexOf(a),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&&e.format!==void 0&&this.setFormatter(e.sheetId,e.target,e.format);break;case`CLEAR_FORMATTING`:this.clearFormatting(e.sheetId,e.target);break;case`ADD_COLUMNS_ROWS`:e.dimension===`COL`?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(let n of Yn(t))for(let t=n.left;t<=n.right;t++)for(let r=n.top;r<=n.bottom;r++){let n=this.getters.getCell({sheetId:e,col:t,row:r});(n?.isFormula||n?.content)&&this.dispatch(`UPDATE_CELL`,{sheetId:e,content:``,col:t,row:r})}}setFormatter(e,t,n){for(let r of Yn(t))for(let t=r.top;t<=r.bottom;t++)for(let i=r.left;i<=r.right;i++)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:i,row:t,format:n})}clearFormatting(e,t){for(let n of Yn(t))for(let t=n.left;t<=n.right;t++)for(let r=n.top;r<=n.bottom;r++)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,style:null,format:``})}clearCells(e,t){for(let n of t)for(let t=n.left;t<=n.right;t++)for(let r=n.top;r<=n.bottom;r++)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,content:``,style:null,format:``})}handleAddColumnsRows(e,t){let n,r;e.position===`before`?(n=S(e.base,e.base+e.quantity),r=e.base+e.quantity):(n=S(e.base+1,e.base+e.quantity+1),r=e.base),t(e.sheetId,r,n)}import(e){for(let t of e.sheets){let n=t.id,r=new YF;for(let e in t.cells)if(t.cells[e]){let{col:n,row:i}=Jn(e),a={sheetId:t.id,col:n,row:i};r.set(a,{content:t.cells[e]})}for(let[e,n]of[[`style`,t.styles],[`format`,t.formats]])for(let[i,a]of Wr(t.id,n)){let t=r.get(i);t?t[e]=a:r.set(i,{[e]:a})}for(let i of r.keysForSheet(n)){let n=r.get(i);if(n?.content||n?.format||n?.style){let r=this.importCell(t.id,n?.content,n?.style?e.styles[n?.style]:void 0,n?.format?e.formats[n?.format]:void 0);this.history.update(`cells`,t.id,r.id,r),this.dispatch(`UPDATE_CELL_POSITION`,{cellId:r.id,...i})}}}}export(e){let t={},n={};for(let r of e.sheets){let e=[],i=[],a={},o=Object.keys(this.cells[r.id]||{}).map(e=>this.getters.getCellPosition(e)).sort((e,t)=>e.col===t.col?e.row-t.row:e.col-t.col);for(let r of o){let o=this.getters.getCell(r),s=T(r.col,r.row),c=this.extractCustomStyle(o);if(Object.keys(c).length){let n=Hr(c,t);e[n]??=[],e[n].push(r)}if(o.format){let e=Hr(o.format,n);i[e]??=[],i[e].push(r)}o.content&&(a[s]=o.content)}r.styles=Ur(e),r.formats=Ur(i),r.cells=a}e.styles=t,e.formats=n}importCell(e,t,n,r){let i=this.getNextUid();return this.createCell(i,t||``,r,n,e)}exportForExcel(e){this.export(e);let t=[];for(let n in e.formats||[])As(e.formats[n])||(t.push(Number(n)),delete e.formats[n]);if(t.length)for(let n of e.sheets)for(let e in n.formats){let r=n.formats[e];r&&t.includes(r)&&delete n.formats[e]}}extractCustomStyle(e){let t={...e.style},n=Li(e.content,k)?Le:Ie;for(let r in t)(r!==`align`||!e.isFormula)&&t[r]===n[r]&&delete t[r];return t}getCells(e){return this.cells[e]||{}}getCellById(e){let t=this.getters.getCellPosition(e);return this.cells[t.sheetId][e]}getFormulaString(e,t,n,r=!1){if(!n.length)return Ot(t.map(e=>e.value));let i=0;return Ot(t.map(t=>{if(t.type===`REFERENCE`){let t=n[i++];return this.getters.getRangeString(t,e,{useBoundedReference:r})}return t.value}))}getTranslatedCellFormula(e,t,n,r){let i=this.getters.createAdaptedRanges(xx(r).dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t)),t,n,e);return this.getFormulaString(e,r,i)}getFormulaMovedInSheet(e,t,n){let r=xx(n).dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t)),i=this.getters.removeRangesSheetPrefix(t,r);return this.getFormulaString(t,n,i)}getCellStyle(e){return this.getters.getCell(e)?.style||{}}zoneToXC(e,t,n=[{colFixed:!1,rowFixed:!1}]){t=this.getters.expandZone(e,t);let r=T(t.left,t.top,n[0]),i=T(t.right,t.bottom,n.length>1?n[1]:n[0]),a=this.getters.getMainCellPosition({sheetId:e,col:t.left,row:t.top}),o=this.getters.getMainCellPosition({sheetId:e,col:t.right,row:t.bottom}),s=a.col===o.col&&a.row===o.row;return r!==i&&!s?r+`:`+i:r}setStyle(e,t,n){for(let r of Yn(t))for(let t=r.left;t<=r.right;t++)for(let i=r.top;i<=r.bottom;i++){let r=this.getters.getCell({sheetId:e,col:t,row:i});this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:i,style:n?{...r?.style,...n}:void 0})}}copyColumnStyle(e,t,n){for(let r=0;r<this.getters.getNumberRows(e);r++){let i=this.getFormat(e,t,r);if(i.style||i.format)for(let t of n)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,...i})}}copyRowStyle(e,t,n){for(let r=0;r<this.getters.getNumberCols(e);r++){let i=this.getFormat(e,r,t);if(i.style||i.format)for(let t of n)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:r,row:t,...i})}}getFormat(e,t,n){let r={},i=this.getters.getMainCellPosition({sheetId:e,col:t,row:n}),a=this.getters.getCell(i);return a&&(a.style&&(r.style=a.style),a.format&&(r.format=a.format)),r}getNextUid(){let e=this.nextId.toString();return this.history.update(`nextId`,this.nextId+1),e}updateCell(e,t,n,r){let i=this.getters.getCell({sheetId:e,col:t,row:n}),a=r.content!==void 0||`formula`in r,o=a?zt(r?.content||void 0):i?.content||``,s;s=r.style===void 0?i?i.style:void 0:r.style||void 0;let c=r.format===void 0?i&&i.format:r.format;if((a&&!o&&!r.formula||!a&&(!i||i.content===``))&&!s&&!c){i&&(this.history.update(`cells`,e,i.id,void 0),this.dispatch(`UPDATE_CELL_POSITION`,{cellId:void 0,col:t,row:n,sheetId:e}));return}let l=i?.id||this.getNextUid(),u=this.createCell(l,o,c,s,e);this.history.update(`cells`,e,u.id,u),this.dispatch(`UPDATE_CELL_POSITION`,{cellId:u.id,col:t,row:n,sheetId:e})}createCell(e,t,n,r,i){return t.startsWith(`=`)?this.createFormulaCell(e,t,n,r,i):this.createLiteralCell(e,t,n,r)}createLiteralCell(e,t,n,r){let i=this.getters.getLocale(),a=Ns(t,i);return n||=typeof a==`number`?ms(t,i)||hs(t):void 0,!js(n)&&!P(t)&&(t=I(a)),{id:e,content:t,style:r,format:n,isFormula:!1,parsedValue:a}}createFormulaCell(e,t,n,r,i){let a=bx(t);return a.dependencies.length?this.createFormulaCellWithDependencies(e,a,n,r,i):{id:e,content:t,style:r,format:n,isFormula:!0,compiledFormula:{...a,dependencies:[]}}}createFormulaCellWithDependencies(e,t,n,r,i){let a=[];for(let e of t.dependencies)a.push(this.getters.getRangeFromSheetXC(i,e));return new _V(e,t,n,r,a,i,this.getters.getRangeString)}checkCellOutOfSheet(e){let{sheetId:t,col:n,row:r}=e;return this.getters.tryGetSheet(t)?vr(n,r,this.getters.getSheetZone(t))?`Success`:`TargetOutOfSheet`:`InvalidSheetId`}checkUselessClearCell(e){let t=this.getters.getCell(e);return!t||!t.content&&!t.style&&!t.format?`NoChanges`:`Success`}checkUselessUpdateCell(e){let t=this.getters.getCell(e),n=`content`in e||`formula`in e,r=`style`in e,i=`format`in e;return(!n||t?.content===e.content)&&(!r||w(t?.style,e.style))&&(!i||t?.format===e.format)?`NoChanges`:`Success`}},_V=class{isFormula=!0;compiledFormula;constructor(e,t,n,r,i,a,o){this.id=e,this.format=n,this.style=r,this.sheetId=a,this.getRangeString=o;let s=0,c=t.tokens.map(e=>e.type===`REFERENCE`?new vV(i,s++,this.sheetId,this.getRangeString):e);this.compiledFormula={...t,dependencies:i,tokens:c}}get content(){return Ot(this.compiledFormula.tokens.map(e=>e.value))}get contentWithFixedReferences(){let e=0;return Ot(this.compiledFormula.tokens.map(t=>{if(t.type===`REFERENCE`){let t=e++;return this.getRangeString(this.compiledFormula.dependencies[t],this.sheetId,{useBoundedReference:!0})}return t.value}))}},vV=class{type=`REFERENCE`;constructor(e,t,n,r){this.ranges=e,this.rangeIndex=t,this.sheetId=n,this.getRangeString=r}get value(){let e=this.ranges[this.rangeIndex];return this.getRangeString(e,this.sheetId)}},yV=class extends mV{static getters=[`isChartDefined`,`getChartDefinition`,`getChartType`,`getChartIds`,`getChart`,`getContextCreationChart`];charts={};createChart=cD(this.getters);validateChartDefinition=e=>uD(this,e.definition);adaptRanges(e){for(let[t,n]of Object.entries(this.charts))this.history.update(`charts`,t,n?.updateRanges(e))}allowDispatch(e){switch(e.type){case`CREATE_CHART`:return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartDuplicate));case`UPDATE_CHART`:return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartExists,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`:{let t=this.getters.getFigures(e.sheetId);for(let n of t)if(n.tag===`chart`){let t=n.id.split(`??`).pop(),r=`${e.sheetIdTo}??${t}`,i=this.charts[n.id]?.duplicateInDuplicatedSheet(e.sheetIdTo);i&&this.dispatch(`CREATE_CHART`,{figureId:r,col:n.col,row:n.row,offset:n.offset,size:{width:n.width,height:n.height},definition:i.getDefinition(),sheetId:e.sheetIdTo})}break}case`DELETE_FIGURE`:this.history.update(`charts`,e.figureId,void 0);break;case`DELETE_SHEET`:for(let t of this.getChartIds(e.sheetId))this.history.update(`charts`,t,void 0);break}}getContextCreationChart(e){return this.charts[e]?.getContextCreation()}getChart(e){return this.charts[e]}getChartType(e){let t=this.charts[e]?.type;if(!t)throw Error(`Chart not defined.`);return t}isChartDefined(e){return e in this.charts&&this.charts!==void 0}getChartIds(e){return Object.entries(this.charts).filter(([,t])=>t?.sheetId===e).map(([e])=>e)}getChartDefinition(e){let t=this.charts[e]?.getDefinition();if(!t)throw Error(`There is no chart with the given figureId: ${e}`);return t}import(e){for(let t of e.sheets)if(t.figures)for(let e of t.figures)e.tag===`chart`&&(this.charts[e.id]=this.createChart(e.id,e.data,t.id))}export(e){if(e.sheets)for(let t of e.sheets){let e=this.getters.getFigures(t.id),n=[];for(let t of e){let e=t;if(e&&e.tag===`chart`){let t=this.charts[e.id]?.getDefinition();t&&(e.data=t,n.push(e))}else n.push(e)}t.figures=n}}addFigure(e,t,n,r,i,a={width:536,height:335}){this.dispatch(`CREATE_FIGURE`,{sheetId:t,figureId:e,col:n,row:r,offset:i,size:a,tag:`chart`})}addChart(e,t){let n=this.getters.getFigureSheetId(e);n&&this.history.update(`charts`,e,this.createChart(e,t,n))}checkChartDuplicate(e){return this.getters.getFigureSheetId(e.figureId)?`DuplicatedChartId`:`Success`}checkChartExists(e){return this.isChartDefined(e.figureId)?`Success`:`ChartDoesNotExist`}checkChartChanged(e){return w(this.getChartDefinition(e.figureId),e.definition)?`NoChanges`:`Success`}};function bV(e){return e===``?NaN:Number(e)}var xV=class extends mV{static getters=[`getConditionalFormats`,`getRulesSelection`,`getRulesByCell`,`getAdaptedCfRanges`];cfRules={};adaptCFFormulas({applyChange:e,adaptFormulaString:t}){for(let n in this.cfRules)for(let r of this.cfRules[n])if(r.rule.type===`DataBarRule`&&r.rule.rangeValues){let t=e(r.rule.rangeValues);switch(t.changeType){case`REMOVE`:this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,`rangeValues`,void 0);break;case`RESIZE`:case`MOVE`:case`CHANGE`:this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,`rangeValues`,t.range);break}}else if(r.rule.type===`CellIsRule`)for(let e=0;e<r.rule.values.length;e++)this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,`values`,e,t(n,r.rule.values[e]));else if(r.rule.type===`IconSetRule`)for(let e of[`lowerInflectionPoint`,`upperInflectionPoint`])r.rule[e].type===`formula`&&this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,e,`value`,t(n,r.rule[e].value));else if(r.rule.type===`ColorScaleRule`)for(let e of[`minimum`,`maximum`,`midpoint`]){let i=r.rule[e];i?.type===`formula`&&i?.value&&this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,e,`value`,t(n,i.value))}}adaptCFRanges(e,{applyChange:t}){for(let n of this.cfRules[e])for(let r of n.ranges){let i=t(r);switch(i.changeType){case`REMOVE`:let t=n.ranges.slice();t.splice(n.ranges.indexOf(r),1),t.length>=1?this.history.update(`cfRules`,e,this.cfRules[e].indexOf(n),`ranges`,t):this.removeConditionalFormatting(n.id,e);break;case`RESIZE`:case`MOVE`:case`CHANGE`:this.history.update(`cfRules`,e,this.cfRules[e].indexOf(n),`ranges`,n.ranges.indexOf(r),i.range);break}}}adaptRanges(e,t){let n=t?[t]:Object.keys(this.cfRules);for(let t of n)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(let t of this.getConditionalFormats(e.sheetId))this.addConditionalFormatting(t,e.sheetIdTo);break;case`DELETE_SHEET`:let t=Object.assign({},this.cfRules);delete t[e.sheetId],this.history.update(`cfRules`,t);break;case`ADD_CONDITIONAL_FORMAT`:let n={...e.cf,ranges:e.ranges.map(t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId))};this.addConditionalFormatting(n,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);break}}import(e){for(let t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map(e=>this.mapToConditionalFormatInternal(t.id,e))}export(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map(e=>this.mapToConditionalFormat(t.id,e)))}exportForExcel(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map(e=>this.mapToConditionalFormat(t.id,e,{useBoundedReference:!0})))}getConditionalFormats(e){return this.cfRules[e]?.map(t=>this.mapToConditionalFormat(e,t))||[]}getRulesSelection(e,t){let n=new Set;return t.forEach(t=>{this.getRulesByZone(e,t).forEach(e=>{n.add(e)})}),Array.from(n)}getRulesByZone(e,t){let n=new Set;for(let r=t.top;r<=t.bottom;r++)for(let i=t.left;i<=t.right;i++)this.getRulesByCell(e,i,r).forEach(e=>{n.add(e.id)});return n}getRulesByCell(e,t,n){let r=[];for(let i of this.cfRules[e])for(let e of i.ranges)vr(t,n,e.zone)&&r.push(i);return new Set(r.map(t=>this.mapToConditionalFormat(e,t)))}getAdaptedCfRanges(e,t,n,r){if(n.length===0&&r.length===0)return;let i=this.getters.getConditionalFormats(e),a=i.findIndex(e=>e.id===t.id),o=[];a>-1&&(o=i[a].ranges.map(ir));let s=Yn(o,r);return Yn([...n,...s],[]).map(t=>this.getters.getRangeDataFromZone(e,t))}mapToConditionalFormat(e,t,{useBoundedReference:n}={useBoundedReference:!1}){let r=t.ranges.map(t=>this.getters.getRangeString(t,e,{useBoundedReference:n}));return t.rule.type===`DataBarRule`?{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues&&this.getters.getRangeString(t.rule.rangeValues,e,{useBoundedReference:n})},ranges:r}:{...t,rule:{...t.rule},ranges:r}}mapToConditionalFormatInternal(e,t){let n=t.ranges.map(t=>this.getters.getRangeFromSheetXC(e,t));return t.rule.type===`DataBarRule`?{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues?this.getters.getRangeFromSheetXC(e,t.rule.rangeValues):void 0},ranges:n}:{...t,rule:{...t.rule},ranges:n}}addConditionalFormatting(e,t){let n=this.cfRules[t].slice(),r=n.findIndex(t=>t.id===e.id),i=this.mapToConditionalFormatInternal(t,e);r>-1?n.splice(r,1,i):n.push(i),this.history.update(`cfRules`,t,n)}checkValidPriorityChange(e,t,n){if(!this.cfRules[n])return`InvalidSheetId`;let r=this.cfRules[n].findIndex(t=>t.id===e);if(r===-1)return`InvalidConditionalFormatId`;let i=r-t;return i<0||i>=this.cfRules[n].length?`InvalidConditionalFormatId`:`Success`}checkEmptyRange(e){return e.ranges.length?`Success`:`EmptyRange`}checkCFRule(e){let t=e.cf.rule;switch(t.type){case`CellIsRule`:return lw[t.operator]?this.checkValidations(t,this.checkOperatorArgsNumber(2,[`Between`,`NotBetween`]),this.checkOperatorArgsNumber(1,[`BeginsWith`,`ContainsText`,`EndsWith`,`GreaterThan`,`GreaterThanOrEqual`,`LessThan`,`LessThanOrEqual`,`NotContains`,`Equal`,`NotEqual`]),this.checkOperatorArgsNumber(0,[`IsEmpty`,`IsNotEmpty`]),this.checkCFValues):`InvalidConditionalFormatType`;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)));case`DataBarRule`:return`Success`}return`InvalidConditionalFormatType`}checkCFHasChanged(e){let t=this.mapToConditionalFormatInternal(e.sheetId,{...e.cf,ranges:e.ranges.map(t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId))}),n=this.cfRules[e.sheetId]?.find(t=>t.id===e.cf.id);return n&&w(t,n)?`NoChanges`:`Success`}checkOperatorArgsNumber(e,t){if(e>2)throw Error(`Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.`);return n=>{if(t.includes(n.operator)){let t=[],r=e=>e===void 0||e===``;return e>=1&&r(n.values[0])&&t.push(`FirstArgMissing`),e>=2&&r(n.values[1])&&t.push(`SecondArgMissing`),t.length?t:`Success`}return`Success`}}checkNaN(e,t){if([`number`,`percentage`,`percentile`].includes(e.type)&&(e.value===``||isNaN(e.value)))switch(t){case`min`:return`MinNaN`;case`max`:return`MaxNaN`;case`mid`:return`MidNaN`;case`upperInflectionPoint`:return`ValueUpperInflectionNaN`;case`lowerInflectionPoint`:return`ValueLowerInflectionNaN`}return`Success`}checkFormulaCompilation(e,t){if(e.type!==`formula`)return`Success`;if(bx(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){let t=e.lowerInflectionPoint.value,n=e.upperInflectionPoint.value;return[`number`,`percentage`,`percentile`].includes(e.lowerInflectionPoint.type)&&e.lowerInflectionPoint.type===e.upperInflectionPoint.type&&Number(t)>Number(n)?`LowerBiggerThanUpper`:`Success`}checkMinBiggerThanMax(e){let t=e.minimum.value,n=e.maximum.value;return[`number`,`percentage`,`percentile`].includes(e.minimum.type)&&e.minimum.type===e.maximum.type&&bV(t)>=bV(n)?`MinBiggerThanMax`:`Success`}checkMidBiggerThanMax(e){let t=e.midpoint?.value,n=e.maximum.value;return e.midpoint&&[`number`,`percentage`,`percentile`].includes(e.midpoint.type)&&e.midpoint.type===e.maximum.type&&bV(t)>=bV(n)?`MidBiggerThanMax`:`Success`}checkMinBiggerThanMid(e){let t=e.minimum.value,n=e.midpoint?.value;return e.midpoint&&[`number`,`percentage`,`percentile`].includes(e.midpoint.type)&&e.minimum.type===e.midpoint.type&&bV(t)>=bV(n)?`MinBiggerThanMid`:`Success`}checkCFValues(e){for(let t of e.values)if(t.startsWith(`=`)&&bx(t||``).isBadExpression)return`ValueCellIsInvalidFormula`;return`Success`}removeConditionalFormatting(e,t){let n=this.cfRules[t].findIndex(t=>t.id===e);if(n!==-1){let e=this.cfRules[t].slice();e.splice(n,1),this.history.update(`cfRules`,t,e)}}changeCFPriority(e,t,n){let r=this.cfRules[n].findIndex(t=>t.id===e),i=this.cfRules[n][r],a=r-t,o=[...this.cfRules[n]];o.splice(r,1),o.splice(a,0,i),this.history.update(`cfRules`,n,o)}},SV=class extends mV{static getters=[`cellHasListDataValidationIcon`,`getDataValidationRule`,`getDataValidationRules`,`getValidationRuleForCell`];rules={};adaptRanges(e,t){this.adaptDVRanges(t,e),this.adaptDVFormulas(e)}adaptDVFormulas({adaptFormulaString:e}){for(let t in this.rules){let n=this.rules[t];for(let r=n.length-1;r>=0;r--){let n=this.rules[t][r];for(let i=0;i<n.criterion.values.length;i++){let a=e(t,n.criterion.values[i]);this.history.update(`rules`,t,r,`criterion`,`values`,i,a)}}}}adaptDVRanges(e,{applyChange:t}){let n=this.rules[e];for(let r=n.length-1;r>=0;r--){let n=this.rules[e][r];for(let i=n.ranges.length-1;i>=0;i--){let a=n.ranges[i],o=t(a);switch(o.changeType){case`REMOVE`:if(n.ranges.length===1)this.removeDataValidationRule(e,n.id);else{let t=n.ranges.slice();t.splice(i,1),this.history.update(`rules`,e,r,`ranges`,t)}break;case`RESIZE`:case`MOVE`:case`CHANGE`:this.history.update(`rules`,e,r,`ranges`,i,o.range);break}}}}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));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`;break}return`Success`}handle(e){switch(e.type){case`CREATE_SHEET`:this.history.update(`rules`,e.sheetId,[]);break;case`DUPLICATE_SHEET`:{let t=b(this.rules[e.sheetId]).map(t=>({...t,ranges:t.ranges.map(t=>pc(e.sheetId,e.sheetIdTo,t))}));this.history.update(`rules`,e.sheetIdTo,t);break}case`DELETE_SHEET`:{let 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`:{let t=e.ranges.map(e=>this.getters.getRangeFromRangeData(e));this.addDataValidationRule(e.sheetId,{...e.rule,ranges:t});break}case`DELETE_CONTENT`:{let t=Yn(e.target),n=e.sheetId;for(let e of t)for(let t=e.top;t<=e.bottom;t++)for(let r=e.left;r<=e.right;r++){let e=this.getValidationRuleForCell({sheetId:n,col:r,row:t});if(e&&(e.criterion.type===`isBoolean`||e.criterion.type===`isValueInList`&&!this.getters.getCell({sheetId:n,col:r,row:t})?.content)){let e=this.rules[n],i=[this.getters.getRangeFromSheetXC(n,T(r,t))],a=this.removeRangesFromRules(n,i,e);this.history.update(`rules`,n,a)}}}}}getDataValidationRules(e){return this.rules[e]}getDataValidationRule(e,t){return this.rules[e].find(e=>e.id===t)}getValidationRuleForCell({sheetId:e,col:t,row:n}){if(this.rules[e]){for(let r of this.rules[e])for(let e of r.ranges)if(vr(t,n,e.zone))return r}}cellHasListDataValidationIcon(e){let t=this.getValidationRuleForCell(e);return t?(t.criterion.type===`isValueInList`||t.criterion.type===`isValueInRange`)&&t.criterion.displayStyle===`arrow`:!1}addDataValidationRule(e,t){let n=this.rules[e];t.criterion.type===`isBoolean`?this.setCenterStyleToBooleanCells(t):t.criterion.type===`isValueInList`&&(t.criterion.values=Array.from(new Set(t.criterion.values)));let r=this.removeRangesFromRules(e,t.ranges,n,t.id),i=r.findIndex(e=>e.id===t.id);i===-1?this.history.update(`rules`,e,[...r,t]):(r[i]=t,this.history.update(`rules`,e,r))}removeRangesFromRules(e,t,n,r){n=b(n);for(let e of n)e.id!==r&&(e.ranges=this.getters.recomputeRanges(e.ranges,t));return n.filter(e=>e.ranges.length>0)}removeDataValidationRule(e,t){let n=this.rules[e].filter(e=>e.id!==t);this.history.update(`rules`,e,n)}setCenterStyleToBooleanCells(e){for(let t of gc(e.ranges)){let e=this.getters.getCell(t),n={...e?.style,align:e?.style?.align??`center`,verticalAlign:e?.style?.verticalAlign??`middle`};this.dispatch(`UPDATE_CELL`,{...t,style:n})}}checkEmptyRange(e){return e.ranges.length?`Success`:`EmptyRange`}import(e){for(let t of e.sheets)if(this.rules[t.id]=[],t.dataValidationRules)for(let 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(let t of e.sheets){t.dataValidationRules=[];for(let 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(let t of e.sheets){t.dataValidationRules=[];for(let e of this.rules[t.id]){let n={...b(e),ranges:e.ranges.map(e=>this.getters.getRangeString(e,t.id,{useBoundedReference:!0}))};e.criterion.type===`isValueInRange`&&(n.criterion.values=e.criterion.values.map(e=>{let n=this.getters.getRangeFromSheetXC(t.id,e);return this.getters.getRangeString(n,t.id,{useBoundedReference:!0,useFixedReference:!0})})),t.dataValidationRules.push(n)}}}checkCriterionTypeIsValid(e){return $.contains(e.rule.criterion.type)?`Success`:`UnknownDataValidationCriterionType`}checkCriterionHasValidNumberOfValues(e){let t=e.rule.criterion,n=$.get(t.type).numberOfValues(t);return n!==void 0&&t.values.length!==n?`InvalidNumberOfCriterionValues`:`Success`}checkCriterionValuesAreValid(e){let t=e.rule.criterion,n=$.get(t.type);return t.values.some(e=>n.allowedValues===`onlyFormulas`&&!e.startsWith(`=`)?!0:e.startsWith(`=`)?n.allowedValues===`onlyLiterals`||bx(e).isBadExpression:!n.isCriterionValueValid(e))?`InvalidDataValidationCriterionValue`:`Success`}checkValidRange(e){return e.ranges.map(e=>this.getters.getRangeFromRangeData(e)).map(t=>this.getters.getRangeString(t,e.sheetId)).some(e=>!this.getters.isRangeValid(e))?`InvalidRange`:`Success`}},CV=class extends mV{static getters=[`getFigures`,`getFigure`,`getFigureSheetId`];figures={};insertionOrders=[];adaptRanges({applyChange:e},t){for(let n of this.getFigures(t)){let r=e(this.getters.getRangeFromZone(t,{left:n.col,right:n.col,top:n.row,bottom:n.row}));if(r.changeType===`MOVE`)this.history.update(`figures`,t,n.id,`col`,r.range.zone.right),this.history.update(`figures`,t,n.id,`row`,r.range.zone.bottom);else if(r.changeType===`REMOVE`){let r=e(this.getters.getRangeFromZone(t,{left:0,right:n.col-1,top:0,bottom:n.row-1})),{offset:i,col:a,row:o}=n;r.changeType!==`NONE`&&(a=r.range.zone.right+1,o=r.range.zone.bottom+1),{offset:i,col:a,row:o}=this.getPositionInSheet(t,{...n,col:a,row:o}),this.history.update(`figures`,t,n.id,`offset`,i),this.history.update(`figures`,t,n.id,`col`,a),this.history.update(`figures`,t,n.id,`row`,o)}}}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){switch(e.type){case`DELETE_SHEET`:this.getters.getFigures(e.sheetId).forEach(t=>{this.dispatch(`DELETE_FIGURE`,{figureId:t.id,sheetId:e.sheetId})});break}}handle(e){switch(e.type){case`CREATE_SHEET`:this.figures[e.sheetId]={};break;case`DELETE_SHEET`:this.deleteSheet(e.sheetId);break;case`CREATE_FIGURE`:let 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`:e.dimension===`COL`?this.onColRemove(e.sheetId):this.onRowRemove(e.sheetId);break}}onColRemove(e){let t=this.getters.getNumberCols(e),n=Array(t+1);n[t]=0;for(let r=t-1;r>=0;r--)n[r]=n[r+1]+this.getters.getColSize(e,r);for(let t of this.getFigures(e))if(t.offset.x+t.width>n[t.col]){let r=t.offset.x,i=t.col;for(r=Math.min(r,n[i]-t.width);r<0&&i>0;)i--,r=n[i]-t.width;r!==t.offset.x&&this.history.update(`figures`,e,t.id,`offset`,{x:Math.max(r,0),y:t.offset.y}),i!==t.col&&this.history.update(`figures`,e,t.id,`col`,i)}}onRowRemove(e){let t=this.getters.getNumberRows(e),n=Array(t+1);n[t]=0;for(let r=t-1;r>=0;r--)n[r]=n[r+1]+(this.getters.getUserRowSize(e,r)??23);for(let t of this.getFigures(e))if(t.offset.y+t.height>n[t.row]){let r=t.offset.y,i=t.row;for(let t=this.getters.getUserRowSize(e,i)??23;t<r;t=this.getters.getUserRowSize(e,i)??23)i+=1,r-=t;for(r=Math.min(r,n[i]-t.height);r<0&&i>0;)i--,r=n[i]-t.height;r!==t.offset.y&&this.history.update(`figures`,e,t.id,`offset`,{x:t.offset.x,y:Math.max(0,r)}),i!==t.row&&this.history.update(`figures`,e,t.id,`row`,i)}else t.offset.y+t.height>n[0]&&this.history.update(`figures`,e,t.id,`offset`,{x:t.offset.x,y:Math.max(n[0]-t.height,0)})}getPositionInSheet(e,t){let{numberOfRows:n,numberOfCols:r}=this.getters.getSheetSize(e),i=0,a=0,o,s,{col:c,row:l}=t,u={...t.offset};for(o=n;i<t.height&&o>0;o--)i+=this.getters.getUserRowSize(e,o-1)??23;for(l>o?(l=o,u.y=Math.max(i-t.height,0)):l===o&&(u.y=x(u.y,0,Math.max(i-t.height,0))),s=r;a<t.width&&s>0;s--)a+=this.getters.getColSize(e,s-1);return c>s?(c=s,u.x=Math.max(a-t.width,0)):s===c&&(u.x=x(u.x,0,Math.max(a-t.width,0))),{col:c,row:l,offset:u}}updateFigure(e){if(!(`figureId`in e)||!(`sheetId`in e))return;let{figureId:t,sheetId:n,...r}=e,i={...this.getFigure(n,t),...r};for(let[e,t]of Object.entries(r))switch(e){case`offset`:this.history.update(`figures`,n,i.id,e,t);break;case`col`:case`row`:case`width`:case`height`:t!==void 0&&this.history.update(`figures`,n,i.id,e,t);break}}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 this.figures[e.sheetId]?.[e.figureId]===void 0?`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){let t=[];for(let n of this.insertionOrders){let r=this.figures[e]?.[n];r&&t.push(r)}return t}getFigure(e,t){return this.figures[e]?.[t]}getFigureSheetId(e){return Object.keys(this.figures).find(t=>this.figures[t]?.[e]!==void 0)}import(e){for(let t of e.sheets)for(let e of t.figures)this.addFigure(e,t.id)}export(e){for(let t of e.sheets)for(let e of this.getFigures(t.id))t.figures.push({...e,data:void 0})}exportForExcel(e){return this.export(e)}},wV=class extends mV{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,b(this.sizes[e.sheetId]));break;case`DELETE_SHEET`:let t={...this.sizes};delete t[e.sheetId],this.history.update(`sizes`,t);break;case`REMOVE_COLUMNS_ROWS`:{let t=this.sizes[e.sheetId][e.dimension],n=Ht(t,e.elements);this.history.update(`sizes`,e.sheetId,e.dimension,n);break}case`ADD_COLUMNS_ROWS`:{let t=[...this.sizes[e.sheetId][e.dimension]],n=jt(e.position,e.base),r=t[e.base];t=Ut(t,Array(e.quantity).fill(r),n),this.history.update(`sizes`,e.sheetId,e.dimension,t);break}case`RESIZE_COLUMNS_ROWS`:if(e.dimension===`ROW`)for(let t of e.elements)this.history.update(`sizes`,e.sheetId,e.dimension,t,e.size||void 0);else for(let t of e.elements)this.history.update(`sizes`,e.sheetId,e.dimension,t,e.size||void 0);break}}getColSize(e,t){return Math.round(this.sizes[e]?.COL[t]||96)}getUserRowSize(e,t){let n=this.sizes[e]?.ROW[t];return n?Math.round(n):void 0}import(e){for(let t of e.sheets){let e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(let[n,r]of Object.entries(t.rows))r.size&&(e.ROW[n]=r.size);for(let[n,r]of Object.entries(t.cols))r.size&&(e.COL[n]=r.size);this.sizes[t.id]=e}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let n of e.sheets){n.rows===void 0&&(n.rows={});for(let e of S(0,this.getters.getNumberRows(n.id)))(t||this.sizes[n.id].ROW[e])&&(n.rows[e]={...n.rows[e],size:this.getUserRowSize(n.id,e)??23});n.cols===void 0&&(n.cols={});for(let e of S(0,this.getters.getNumberCols(n.id)))(t||this.sizes[n.id].COL[e])&&(n.cols[e]={...n.cols[e],size:this.getColSize(n.id,e)})}}},TV=class extends mV{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`;let t=e.dimension===`COL`?this.getHiddenColsGroups(e.sheetId):this.getHiddenRowsGroups(e.sheetId),n=e.dimension===`COL`?this.getters.getNumberCols(e.sheetId):this.getters.getNumberRows(e.sheetId);return new Set((t||[]).flat().concat(e.elements)).size>=n?`TooManyHiddenElements`:Yt(e.elements)<0||Jt(e.elements)>n?`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`:let 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,b(this.hiddenHeaders[e.sheetId]));break;case`DELETE_SHEET`:this.history.update(`hiddenHeaders`,e.sheetId,void 0);break;case`REMOVE_COLUMNS_ROWS`:{let t=[...this.hiddenHeaders[e.sheetId][e.dimension]];for(let n of[...e.elements].sort((e,t)=>t-e))t.splice(n,1);this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,t);break}case`ADD_COLUMNS_ROWS`:{let t=jt(e.position,e.base),n=Ut([...this.hiddenHeaders[e.sheetId][e.dimension]],Array(e.quantity).fill(!1),t);this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,n);break}case`HIDE_COLUMNS_ROWS`:for(let t of e.elements)this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,t,!0);break;case`UNHIDE_COLUMNS_ROWS`:for(let t of e.elements)this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,t,!1);break}}checkElementsIncludeAllVisibleHeaders(e,t,n){return Nt(n,this.getAllVisibleHeaders(e,t))}isHeaderHiddenByUser(e,t,n){return t===`COL`?this.isColHiddenByUser(e,n):this.isRowHiddenByUser(e,n)}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){let t=[[]],n=this.hiddenHeaders[e].COL;for(let e=0;e<n.length;e++)n[e]?t[t.length-1].push(e):t[t.length-1].length!==0&&t.push([]);return t[t.length-1].length===0&&t.pop(),t}getHiddenRowsGroups(e){let t=[[]],n=this.hiddenHeaders[e].ROW;for(let e=0;e<n.length;e++)n[e]?t[t.length-1].push(e):t[t.length-1].length!==0&&t.push([]);return t[t.length-1].length===0&&t.pop(),t}getAllVisibleHeaders(e,t){let n=S(0,this.getters.getNumberHeaders(e,t)),r=[];return this.getters.getHeaderGroups(e,t).forEach(e=>{e.isFolded&&r.push(...S(e.start,e.end+1))}),n.filter(n=>!this.hiddenHeaders[e][t][n]&&!r.includes(n))}import(e){for(let t of e.sheets){this.hiddenHeaders[t.id]={COL:[],ROW:[]};for(let e=0;e<t.rowNumber;e++)this.hiddenHeaders[t.id].ROW[e]=!!t.rows[e]?.isHidden;for(let e=0;e<t.colNumber;e++)this.hiddenHeaders[t.id].COL[e]=!!t.cols[e]?.isHidden}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let n of e.sheets){n.rows===void 0&&(n.rows={});for(let e=0;e<this.getters.getNumberRows(n.id);e++)(t||this.hiddenHeaders[n.id].ROW[e])&&(n.rows[e]===void 0&&(n.rows[e]={}),n.rows[e].isHidden||=this.hiddenHeaders[n.id].ROW[e]);n.cols===void 0&&(n.cols={});for(let e=0;e<this.getters.getNumberCols(n.id);e++)(t||this.hiddenHeaders[n.id].COL[e])&&(n.cols[e]===void 0&&(n.cols[e]={}),n.cols[e].isHidden||=this.hiddenHeaders[n.id].COL[e])}}},EV=class extends mV{static getters=[`getImage`,`getImagePath`,`getImageSize`];fileStore;images={};syncedImages=new Set;constructor(e){super(e),this.fileStore=e.external.fileStore}allowDispatch(e){switch(e.type){case`CREATE_IMAGE`:return this.getters.getFigure(e.sheetId,e.figureId)?`InvalidFigureId`:`Success`;default:return`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`:{let t=this.getters.getFigures(e.sheetId);for(let n of t)if(n.tag===`image`){let t=n.id.split(`??`).pop(),r=`${e.sheetIdTo}??${t}`,i=this.getImage(n.id);if(i){let t={width:n.width,height:n.height};this.dispatch(`CREATE_IMAGE`,{sheetId:e.sheetIdTo,figureId:r,offset:n.offset,col:n.col,row:n.row,size:t,definition:b(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);break}}garbageCollectExternalResources(){let e=new Set(this.getAllImages().map(e=>e.path));for(let t of this.syncedImages)e.has(t)||this.fileStore?.delete(t)}getImage(e){for(let t of Object.values(this.images))if(t&&t[e])return t[e];throw 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,n,r,i,a){this.dispatch(`CREATE_FIGURE`,{sheetId:t,figureId:e,col:n,row:r,offset:i,size:a,tag:`image`})}import(e){for(let t of e.sheets){let e=(t.figures||[]).filter(e=>e.tag===`image`);for(let n of e)this.history.update(`images`,t.id,n.id,n.data),this.syncedImages.add(n.data.path)}}export(e){for(let t of e.sheets){let e=t.figures.filter(e=>e.tag===`image`);for(let n of e)n.data=this.images[t.id]?.[n.id]}}exportForExcel(e){for(let t of e.sheets){t.images||=[];let e=this.getters.getFigures(t.id),n=[];for(let t of e)if(t?.tag===`image`){let e=this.getImage(t.id);e&&n.push({...t,data:b(e)})}t.images=[...t.images,...n]}}getAllImages(){let e=[];for(let t in this.images)e.push(...Object.values(this.images[t]||{}).filter(C));return e}},DV=class extends mV{static getters=[`isInMerge`,`isInSameMerge`,`isMergeHidden`,`getMainCellPosition`,`expandZone`,`doesIntersectMerge`,`doesColumnsHaveCommonMerges`,`doesRowsHaveCommonMerges`,`getMerges`,`getMerge`,`getMergesInZone`,`isSingleCellOrMerge`,`getSelectionRangeString`,`isMainCellPosition`];nextId=1;merges={};mergeCellMap={};allowDispatch(e){let t=`force`in e?!!e.force:!1;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`:this.history.update(`merges`,e.sheetId,{}),this.history.update(`mergeCellMap`,e.sheetId,{});break;case`DELETE_SHEET`:this.history.update(`merges`,e.sheetId,{}),this.history.update(`mergeCellMap`,e.sheetId,{});break;case`DUPLICATE_SHEET`:let t=this.merges[e.sheetId];if(!t)break;for(let n of Object.values(t).filter(C))this.addMerge(e.sheetIdTo,n.zone);break;case`ADD_MERGE`:for(let t of e.target)this.addMerge(e.sheetId,t);break;case`REMOVE_MERGE`:for(let t of e.target)this.removeMerge(e.sheetId,t);break}}adaptRanges(e,t){this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map(t=>this.getMergeById(e,parseInt(t,10))).filter(C)}getMerge({sheetId:e,col:t,row:n}){let r=this.mergeCellMap[e],i=r?t in r&&r[t]?.[n]:void 0;return i?this.getMergeById(e,i):void 0}getMergesInZone(e,t){let n=this.mergeCellMap[e];if(!n)return[];let r=new Set;for(let e=t.left;e<=t.right;e++)for(let i=t.top;i<=t.bottom;i++){let t=n[e]?.[i];t&&r.add(t)}return Array.from(r).map(t=>this.getMergeById(e,t)).filter(C)}getSelectionRangeString(e,t){let n=this.getters.expandZone(e.sheetId,e.zone),r=sc({...e,zone:{...n,bottom:uc(e)?void 0:n.bottom,right:dc(e)?void 0:n.right}},this.getters.getSheetSize),i=this.getters.getRangeString(r,t);if(this.isSingleCellOrMerge(e.sheetId,e.zone)){let{sheetName:e,xc:t}=ac(i);return oc(e,t.split(`:`)[0])}return i}doesIntersectMerge(e,t){for(let n of this.getMerges(e))if(_r(t,n))return!0;return!1}doesColumnsHaveCommonMerges(e,t,n){let r=this.getters.getSheet(e);for(let i=0;i<this.getters.getNumberRows(e);i++)if(this.isInSameMerge(r.id,t,i,n,i))return!0;return!1}doesRowsHaveCommonMerges(e,t,n){let r=this.getters.getSheet(e);for(let i=0;i<=this.getters.getNumberCols(e);i++)if(this.isInSameMerge(r.id,i,t,i,n))return!0;return!1}expandZone(e,t){let{left:n,right:r,top:i,bottom:a}=t,o={left:n,right:r,top:i,bottom:a};for(let t in this.merges[e]){let n=this.getMergeById(e,parseInt(t));n&&_r(n,o)&&(o=pr(n,o))}return gr(o,t)?o:this.expandZone(e,o)}isInSameMerge(e,t,n,r,i){let a=this.getMerge({sheetId:e,col:t,row:n}),o=this.getMerge({sheetId:e,col:r,row:i});return!a||!o?!1:gr(a,o)}isInMerge({sheetId:e,col:t,row:n}){let r=this.mergeCellMap[e];return r?t in r&&!!r[t]?.[n]:!1}getMainCellPosition(e){let t=this.getMerge(e);return t?{sheetId:e.sheetId,col:t.left,row:t.top}:e}isMergeHidden(e,t){let n=this.getters.getHiddenColsGroups(e),r=this.getters.getHiddenRowsGroups(e);for(let e of n)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(let e of r)if(t.top>=e[0]&&t.bottom<=e[e.length-1])return!0;return!1}isSingleCellOrMerge(e,t){let n=this.getMerge({sheetId:e,col:t.left,row:t.top});if(n)return gr(t,n);let{numberOfCols:r,numberOfRows:i}=br(t);return r===1&&i===1}isMainCellPosition(e){return w(this.getMainCellPosition(e),e)}isMergeDestructive(e,t){let{left:n,right:r,top:i,bottom:a}=t;r=x(r,0,this.getters.getNumberCols(e)-1),a=x(a,0,this.getters.getNumberRows(e)-1);for(let t=i;t<=a;t++)for(let a=n;a<=r;a++)if(a!==n||t!==i){let n=this.getters.getCell({sheetId:e,col:a,row:t});if(n&&n.content!==``)return!0}return!1}getMergeById(e,t){let n=this.merges[e]?.[t];return n===void 0?void 0:kV(t,n)}checkDestructiveMerge({sheetId:e,target:t}){return this.getters.tryGetSheet(e)&&t.some(t=>this.isMergeDestructive(e,t))?`MergeIsDestructive`:`Success`}checkOverlap({target:e}){for(let t of e)for(let n of e)if(t!==n&&_r(t,n))return`MergeOverlap`;return`Success`}checkFrozenPanes({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return`Success`;let{xSplit:n,ySplit:r}=this.getters.getPaneDivisions(e);for(let e of t)if(e.left<n&&e.right>=n||e.top<r&&e.bottom>=r)return`FrozenPaneOverlap`;return`Success`}checkMergedContentUpdate(e){let{col:t,row:n,content:r}=e;if(r===void 0)return`Success`;let{col:i,row:a}=this.getMainCellPosition(e);return i===t&&a===n?`Success`:`CellIsMerged`}checkMergeExists(e){let{sheetId:t,target:n}=e;for(let e of n){let{left:n,top:r}=e,i=this.getMerge({sheetId:t,col:n,row:r});if(i===void 0||!gr(e,i))return`InvalidTarget`}return`Success`}addMerge(e,t){let{left:n,right:r,top:i,bottom:a}=t;if(r=x(r,0,this.getters.getNumberCols(e)-1),a=x(a,0,this.getters.getNumberRows(e)-1),T(n,i)===T(r,a))return;let o=this.getters.getCell({sheetId:e,col:n,row:i}),s=this.nextId++;this.history.update(`merges`,e,s,this.getters.getRangeFromSheetXC(e,cr({left:n,top:i,right:r,bottom:a})));let c=new Set;for(let t=i;t<=a;t++)for(let a=n;a<=r;a++){(a!==n||t!==i)&&this.dispatch(`UPDATE_CELL`,{sheetId:e,col:a,row:t,style:o?o.style:null,content:``});let r=this.getMerge({sheetId:e,col:a,row:t});r&&c.add(r.id),this.history.update(`mergeCellMap`,e,a,t,s)}for(let t of c){let{top:n,bottom:r,left:i,right:a}=this.getMergeById(e,t);for(let t=n;t<=r;t++)for(let n=i;n<=a;n++){let r={sheetId:e,col:n,row:t},i=this.getMerge(r);(!i||i.id!==s)&&(this.history.update(`mergeCellMap`,e,n,t,void 0),this.dispatch(`CLEAR_CELL`,r))}this.history.update(`merges`,e,t,void 0)}}removeMerge(e,t){let{left:n,top:r,bottom:i,right:a}=t,o=this.getMerge({sheetId:e,col:n,row:r});if(!(o===void 0||!gr(t,o))){this.history.update(`merges`,e,o.id,void 0);for(let t=r;t<=i;t++)for(let r=n;r<=a;r++)this.history.update(`mergeCellMap`,e,r,t,void 0)}}applyRangeChangeOnSheet(e,{applyChange:t}){let n=Object.entries(this.merges[e]||{});for(let[r,i]of n)if(i){let n=i.zone,a=t(i);switch(a.changeType){case`NONE`:break;case`REMOVE`:this.removeMerge(e,n);break;default:let{numberOfCols:t,numberOfRows:i}=br(a.range.zone);t===1&&i===1?this.removeMerge(e,n):this.history.update(`merges`,e,parseInt(r,10),a.range);break}}this.history.update(`mergeCellMap`,e,{});for(let t of this.getMerges(e))for(let{col:n,row:r}of wr(t))this.history.update(`mergeCellMap`,e,n,r,t.id)}import(e){let t=e.sheets||[];for(let e of t)this.history.update(`merges`,e.id,{}),this.history.update(`mergeCellMap`,e.id,{}),e.merges&&this.importMerges(e.id,e.merges)}importMerges(e,t){for(let n of t)this.addMerge(e,ar(n))}export(e){for(let t of e.sheets){let e=this.merges[t.id];e&&t.merges.push(...OV(e))}}exportForExcel(e){this.export(e)}};function OV(e){return Object.entries(e).map(([e,t])=>t?kV(parseInt(e,10),t):void 0).filter(C).map(e=>T(e.left,e.top)+`:`+T(e.right,e.bottom))}function kV(e,t){return{...t.zone,id:e}}var AV=class{getters;providers=[];isAdaptingRanges=!1;constructor(e){this.getters=e}static getters=[`copyFormulaStringForSheet`,`extendRange`,`getRangeString`,`getRangeFromSheetXC`,`createAdaptedRanges`,`getRangeData`,`getRangeDataFromXc`,`getRangeDataFromZone`,`getRangeFromRangeData`,`getRangeFromZone`,`getRangesUnion`,`recomputeRanges`,`isRangeValid`,`removeRangesSheetPrefix`];allowDispatch(e){return e.type===`MOVE_RANGES`?e.target.length===1?`Success`:`InvalidZones`:`Success`}beforeHandle(e){}handle(e){if(this.isAdaptingRanges)throw Error(`Plugins cannot dispatch commands during adaptRanges phase`);let t=yc(e);t&&this.executeOnAllRanges(t)}finalize(){}verifyRangeRemoved(e){return t=>{let n=e(t);return n.changeType!==`NONE`&&!or(n.range.zone)?{range:n.range,changeType:`REMOVE`}:n}}executeOnAllRanges(e){this.isAdaptingRanges=!0;let t={applyChange:this.verifyRangeRemoved(e.applyChange),adaptRangeString:(t,n)=>Mx(t,n,e),adaptFormulaString:(t,n)=>jx(t,n,e)};for(let n of this.providers)n(t,e.sheetId,e.sheetName);this.isAdaptingRanges=!1}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,n,r){return e.map(e=>{if(!or(e.zone))return e;let i=e.prefixSheet?e.sheetId:r,a=dc(e),o=uc(e),s={...e.unboundedZone,left:a&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:a?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:o&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:n),bottom:o?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:n)};return vc(sc({...e,sheetId:i,zone:s},this.getters.getSheetSize))})}removeRangesSheetPrefix(e,t){return t.map(t=>t.prefixSheet&&t.sheetId===e?{...t,prefixSheet:!1}:t)}extendRange(e,t,n){let r=t===`COL`?e.zone.right+n:e.zone.right,i=t===`ROW`?e.zone.bottom+n:e.zone.bottom,a={left:e.zone.left,top:e.zone.top,right:dc(e)?void 0:r,bottom:uc(e)?void 0:i};return sc({...e,zone:a},this.getters.getSheetSize)}getRangeFromSheetXC(e,t){if(!$s.test(t)||!this.getters.tryGetSheet(e))return lc(t);let{sheetName:n}=ac(t);return cc({xc:t,sheetId:this.getters.getSheetIdByName(n)||e,invalidSheetName:n&&!this.getters.getSheetIdByName(n)?n:void 0},this.getters.getSheetSize)}getRangeString(e,t,n={useBoundedReference:!1,useFixedReference:!1}){return e?e.invalidXc?e.invalidXc:this.getters.tryGetSheet(e.sheetId)?fc(e,t,this.getters.getSheetName,n):j.InvalidReference:j.InvalidReference}getRangeDataFromXc(e,t){let n=this.getters.getRangeFromSheetXC(e,t);return this.getRangeDataFromZone(n.sheetId,n.unboundedZone)}getRangeDataFromZone(e,t){return t=this.getters.getUnboundedZone(e,t),{_sheetId:e,_zone:t}}getRangeData(e){return this.getRangeDataFromZone(e.sheetId,e.unboundedZone)}getRangeFromZone(e,t){return sc({sheetId:e,zone:t,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}],prefixSheet:!1},this.getters.getSheetSize)}recomputeRanges(e,t){return Yn(e.map(e=>e.unboundedZone),t.map(e=>e.unboundedZone)).map(t=>this.getRangeFromZone(e[0].sheetId,t))}getRangeFromRangeData(e){return this.getters.tryGetSheet(e._sheetId)?sc({prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]},this.getters.getSheetSize):lc(j.InvalidReference)}isRangeValid(e){if(!e)return!1;let{xc:t,sheetName:n}=ac(e);return t.match($s)!==null&&(!n||this.getters.getSheetIdByName(n)!==void 0)}getRangesUnion(e){let t=mr(...e.map(e=>e.unboundedZone));return this.getRangeFromZone(e[0].sheetId,t)}copyFormulaStringForSheet(e,t,n,r){if(!n.startsWith(`=`))return n;let i=bx(n),a=i.dependencies.map(n=>{let i=this.getters.getRangeFromSheetXC(e,n);return r===`keepSameReference`?i:pc(e,t,i)});return this.getters.getFormulaString(t,i.tokens,a)}},jV=class extends mV{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`.split(`.`);sheetIdsMapName={};orderedSheetIds=[];sheets={};cellPosition={};allowDispatch(e){let t=this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e);if(t!==`Success`)return t;switch(e.type){case`HIDE_SHEET`:return this.getVisibleSheetIds().length===1?`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{let t=this.orderedSheetIds.findIndex(t=>t===e.sheetId);return this.findIndexOfTargetSheet(t,e.delta),`Success`}catch{return`WrongSheetMove`}case`RENAME_SHEET`:return this.isRenameAllowed(e);case`COLOR_SHEET`:return!e.color||cn(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`:{let t=Yt(e.elements),n=Jt(e.elements);return t<0||!this.doesHeaderExist(e.sheetId,e.dimension,n)?`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`:let 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`:e.dimension===`COL`?this.removeColumns(this.sheets[e.sheetId],[...e.elements]):this.removeRows(this.sheets[e.sheetId],[...e.elements]);break;case`ADD_COLUMNS_ROWS`:e.dimension===`COL`?this.addColumns(this.sheets[e.sheetId],e.base,e.position,e.quantity):this.addRows(this.sheets[e.sheetId],e.base,e.position,e.quantity);break;case`UPDATE_CELL_POSITION`:this.updateCellPosition(e);break;case`FREEZE_COLUMNS`:this.setPaneDivisions(e.sheetId,e.quantity,`COL`);break;case`FREEZE_ROWS`:this.setPaneDivisions(e.sheetId,e.quantity,`ROW`);break;case`UNFREEZE_ROWS`:this.setPaneDivisions(e.sheetId,0,`ROW`);break;case`UNFREEZE_COLUMNS`:this.setPaneDivisions(e.sheetId,0,`COL`);break;case`UNFREEZE_COLUMNS_ROWS`:this.setPaneDivisions(e.sheetId,0,`COL`),this.setPaneDivisions(e.sheetId,0,`ROW`)}}import(e){for(let t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(let t of e.sheets){let e=t.name||`Sheet`+(Object.keys(this.sheets).length+1),{colNumber:n,rowNumber:r}=this.getImportedSheetSize(t),i={id:t.id,name:e,numberOfCols:n,rows:Ac(r),areGridLinesVisible:t.areGridLinesVisible===void 0?!0: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(C).map(e=>{let t=this.sheets[e],n={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:t.areGridLinesVisible===void 0?!0:t.areGridLinesVisible,isVisible:t.isVisible,color:t.color};return(t.panes.xSplit||t.panes.ySplit)&&(n.panes=t.panes),n})}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){let t=this.sheets[e];if(!t)throw 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){let t=st(e);for(let e in this.sheetIdsMapName)if(Fc(e,t))return this.sheetIdsMapName[e]}}getSheetIds(){return this.orderedSheetIds}getVisibleSheetIds(){return this.orderedSheetIds.filter(this.isSheetVisible.bind(this))}doesHeaderExist(e,t,n){return t===`COL`?n>=0&&n<this.getNumberCols(e):n>=0&&n<this.getNumberRows(e)}doesHeadersExist(e,t,n){return n.every(n=>this.doesHeaderExist(e,t,n))}getCell({sheetId:e,col:t,row:n}){let r=this.tryGetSheet(e)?.rows[n]?.cells[t];if(r!==void 0)return this.getters.getCellById(r)}getColsZone(e,t,n){return{top:0,bottom:this.getNumberRows(e)-1,left:t,right:n}}getRowCells(e,t){return Object.values(this.getSheet(e).rows[t]?.cells).filter(C)}getRowsZone(e,t,n){return{top:t,bottom:n,left:0,right:this.getSheet(e).numberOfCols-1}}getCellPosition(e){let t=this.cellPosition[e];if(!t)throw 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 t===`COL`?this.getNumberCols(e):this.getNumberRows(e)}getNextSheetName(e=`Sheet`){return Nc(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(t.bottom===void 0||t.right===void 0)return t;let n=t.left===0&&t.right===this.getNumberCols(e)-1,r=t.top===0&&t.bottom===this.getNumberRows(e)-1;return{...t,bottom:r?void 0:t.bottom,right:n&&!r?void 0:t.right}}getPaneDivisions(e){return this.getSheet(e).panes}setPaneDivisions(e,t,n){let r={...this.getPaneDivisions(e)};n===`COL`?r.xSplit=t:n===`ROW`&&(r.ySplit=t),this.history.update(`sheets`,e,`panes`,r)}checkElementsIncludeAllNonFrozenHeaders(e,t,n){let r=this.getters.getPaneDivisions(e),i=t===`ROW`?r.ySplit:r.xSplit,a=this.getters.getNumberHeaders(e,t);return i?Nt(n,S(i,a)):!1}getCommandZones(e){let 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&&e.col!==void 0&&`row`in e&&e.row!==void 0&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(or))return`InvalidRange`;if(t.length){let n=this.getSheetZone(e);return t.every(e=>yr(e,n))?`Success`:`TargetOutOfSheet`}return`Success`}updateCellPosition(e){let{sheetId:t,cellId:n,col:r,row:i}=e;n?this.setNewPosition(n,t,r,i):this.clearPosition(t,r,i)}setNewPosition(e,t,n,r){let i=this.cellPosition[e];i&&this.clearPosition(t,i.col,i.row),this.history.update(`cellPosition`,e,{row:r,col:n,sheetId:t}),this.history.update(`sheets`,t,`rows`,r,`cells`,n,e)}clearPosition(e,t,n){let r=this.sheets[e]?.rows[n].cells[t];r&&(this.history.update(`cellPosition`,r,void 0),this.history.update(`sheets`,e,`rows`,n,`cells`,t,void 0))}setGridLinesVisibility(e,t){this.history.update(`sheets`,e,`areGridLinesVisible`,t)}createSheet(e,t,n,r,i){let a={id:e,name:t,numberOfCols:n,rows:Ac(r),areGridLinesVisible:!0,isVisible:!0,panes:{xSplit:0,ySplit:0}},o=this.orderedSheetIds.slice();o.splice(i,0,a.id);let s=this.sheets;return this.history.update(`orderedSheetIds`,o),this.history.update(`sheets`,Object.assign({},s,{[a.id]:a})),a}moveSheet(e,t){let n=this.orderedSheetIds.slice(),r=n.findIndex(t=>t===e),i=n.splice(r,1),a=this.findIndexOfTargetSheet(r,t);n.splice(a,0,i[0]),this.history.update(`orderedSheetIds`,n)}findIndexOfTargetSheet(e,t){for(;t!==0&&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(t===0)return e;throw Error(`There is not enough visible sheets`)}checkSheetName(e){let t=this.getters.tryGetSheetName(e.sheetId),n=e.type===`RENAME_SHEET`?e.newName:e.name;if(t!==void 0&&n===t)return`UnchangedSheetName`;let{orderedSheetIds:r,sheets:i}=this,a=n&&n.trim().toLowerCase();return r.find(t=>Fc(i[t]?.name,a)&&t!==e.sheetId)?`DuplicatedSheetName`:Ye.test(a)?`ForbiddenCharactersInSheetName`:`Success`}checkSheetPosition(e){let{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){let t=this.getters.getMerges(e.sheetId);for(let n of t)if(n.top<e.quantity&&e.quantity<=n.bottom)return`MergeOverlap`;return`Success`}checkColFreezeOverlapMerge(e){let t=this.getters.getMerges(e.sheetId);for(let n of t)if(n.left<e.quantity&&e.quantity<=n.right)return`MergeOverlap`;return`Success`}isRenameAllowed(e){return e.newName&&e.newName.trim().toLowerCase()?this.checkSheetName(e):`MissingSheetName`}renameSheet(e,t){let n=e.name;this.history.update(`sheets`,e.id,`name`,t.trim());let r=Object.assign({},this.sheetIdsMapName);delete r[n],r[t]=e.id,this.history.update(`sheetIdsMapName`,r)}hideSheet(e){this.history.update(`sheets`,e,`isVisible`,!1)}showSheet(e){this.history.update(`sheets`,e,`isVisible`,!0)}duplicateSheet(e,t,n){let r=b(this.getSheet(e));r.id=t,r.name=n;for(let e=0;e<=r.numberOfCols;e++)for(let t=0;t<=r.rows.length;t++)r.rows[t]&&(r.rows[t].cells[e]=void 0);let i=this.orderedSheetIds.slice(),a=i.indexOf(e);i.splice(a+1,0,r.id),this.history.update(`orderedSheetIds`,i),this.history.update(`sheets`,Object.assign({},this.sheets,{[r.id]:r}));for(let t of Object.values(this.getters.getCells(e))){let{col:e,row:n}=this.getCellPosition(t.id);this.dispatch(`UPDATE_CELL`,{sheetId:r.id,col:e,row:n,content:t.content,format:t.format,style:t.style})}let o=Object.assign({},this.sheetIdsMapName);o[r.name]=r.id,this.history.update(`sheetIdsMapName`,o)}getDuplicateSheetName(e){return Pc(e,this.orderedSheetIds.map(this.getSheetName.bind(this)))}deleteSheet(e){let t=e.name,n=Object.assign({},this.sheets);delete n[e.id],this.history.update(`sheets`,n);let r=this.orderedSheetIds.slice(),i=r.indexOf(e.id);r.splice(i,1),this.history.update(`orderedSheetIds`,r);let a=Object.assign({},this.sheetIdsMapName);delete a[t],this.history.update(`sheetIdsMapName`,a)}removeColumns(e,t){t.sort((e,t)=>t-e);for(let n of t)this.moveCellOnColumnsDeletion(e,n);let n=this.sheets[e.id].numberOfCols;this.history.update(`sheets`,e.id,`numberOfCols`,n-t.length);let r=t.filter(t=>t<e.panes.xSplit).length;r&&this.setPaneDivisions(e.id,e.panes.xSplit-r,`COL`)}removeRows(e,t){t.sort((e,t)=>t-e);for(let n of dt(t)){let t=n[n.length-1],r=n[0];this.moveCellOnRowsDeletion(e,t,r),this.updateRowsStructureOnDeletion(e,t,r)}let n=t.filter(t=>t<e.panes.ySplit).length;n&&this.setPaneDivisions(e.id,e.panes.ySplit-n,`ROW`)}addColumns(e,t,n,r){let i=n===`before`?t:t+1;this.moveCellsOnAddition(e,i,r,`columns`);let a=this.sheets[e.id].numberOfCols;this.history.update(`sheets`,e.id,`numberOfCols`,a+r),i<e.panes.xSplit&&this.setPaneDivisions(e.id,e.panes.xSplit+r,`COL`)}addRows(e,t,n,r){let i=n===`before`?t:t+1;this.addEmptyRows(e,r),this.moveCellsOnAddition(e,i,r,`rows`),i<e.panes.ySplit&&this.setPaneDivisions(e.id,e.panes.ySplit+r,`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 n=0;n<e.rows.length;n++){let r=e.rows[n];for(let i in r.cells){let a=Number(i),o=r.cells[i];o&&a>t&&this.setNewPosition(o,e.id,a-1,n)}}}moveCellsOnAddition(e,t,n,r){let i=[];for(let a=0;a<e.rows.length;a++){let o=e.rows[a];if(r!==`rows`||a>=t)for(let s in o.cells){let c=Number(s),l=o.cells[s];l&&(r===`rows`||c>=t)&&i.push({sheetId:e.id,cellId:l,col:c+(r===`columns`?n:0),row:a+(r===`rows`?n:0),type:`UPDATE_CELL_POSITION`})}}for(let e of i.reverse())this.updateCellPosition(e)}moveCellOnRowsDeletion(e,t,n){this.dispatch(`CLEAR_CELLS`,{sheetId:e.id,target:[{left:0,top:t,right:this.getters.getNumberCols(e.id),bottom:n}]});let r=n-t+1;for(let t=0;t<e.rows.length;t++){let i=e.rows[t];if(t>n)for(let n in i.cells){let a=Number(n),o=i.cells[n];o&&this.setNewPosition(o,e.id,a,t-r)}}}updateRowsStructureOnDeletion(e,t,n){let r=[],i=e.rows.map(e=>e.cells).reverse();for(let a in e.rows){let e=Number(a);e>=t&&e<=n||r.push({cells:i.pop()})}this.history.update(`sheets`,e.id,`rows`,r)}addEmptyRows(e,t){let n=e.rows.slice();for(let e=0;e<t;e++)n.push({cells:{}});this.history.update(`sheets`,e.id,`rows`,n)}getImportedSheetSize(e){let t=Object.keys(e.cells).map(Jn),n=e.rowNumber,r=e.colNumber;for(let{col:e,row:i}of t)n=Math.max(n,i+1),r=Math.max(r,e+1);return{rowNumber:n,colNumber:r}}checkSheetExists(e){return e.type!==`CREATE_SHEET`&&`sheetId`in e&&this.sheets[e.sheetId]===void 0?`InvalidSheetId`:e.type===`CREATE_SHEET`&&this.sheets[e.sheetId]!==void 0?`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`}},MV=class extends mV{static getters=[`getCoreTable`,`getCoreTables`,`getCoreTableMatchingTopLeft`];tables={};nextTableId=1;adaptRanges({applyChange:e},t){for(let n of this.getCoreTables(t))this.applyRangeChangeOnTable(t,n,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`;let t=e.ranges.map(e=>this.getters.getRangeFromRangeData(e).zone);return Fr(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(let t of this.getCoreTables(e.sheetId)){let n=t.range.zone;for(let t of e.target)if(_r(n,t))return`MergeInTable`}break}return`Success`}handle(e){switch(e.type){case`CREATE_SHEET`:this.history.update(`tables`,e.sheetId,{});break;case`DELETE_SHEET`:{let t={...this.tables};delete t[e.sheetId],this.history.update(`tables`,t);break}case`DUPLICATE_SHEET`:{let t={};for(let n of this.getCoreTables(e.sheetId))t[n.id]=n.type===`dynamic`?this.copyDynamicTableForSheet(e.sheetIdTo,n):this.copyStaticTableForSheet(e.sheetIdTo,n);this.history.update(`tables`,e.sheetIdTo,t);break}case`CREATE_TABLE`:{let t=e.ranges.map(e=>this.getters.getRangeFromRangeData(e)),n=this.getters.getRangesUnion(t),r=this.getters.getMergesInZone(e.sheetId,n.zone);r.length&&this.dispatch(`REMOVE_MERGE`,{sheetId:e.sheetId,target:r});let i=this.consumeNextId(),a=e.config||OA,o=e.tableType===`dynamic`?this.createDynamicTable(i,n,a):this.createStaticTable(i,e.tableType,n,a);this.history.update(`tables`,e.sheetId,o.id,o);break}case`REMOVE_TABLE`:{let t={};for(let n of this.getCoreTables(e.sheetId))e.target.every(e=>!hr(n.range.zone,e))&&(t[n.id]=n);this.history.update(`tables`,e.sheetId,t);break}case`UPDATE_TABLE`:this.updateTable(e);break;case`UPDATE_CELL`:{let t=e.sheetId;for(let n of this.getCoreTables(t)){if(n.type===`dynamic`)continue;let r=this.canUpdateCellCmdExtendTable(e,n);r===`down`?this.extendTableDown(t,n):r===`right`&&this.extendTableRight(t,n)}break}case`DELETE_CONTENT`:{let t={...this.tables[e.sheetId]};for(let n in t){let r=t[n];r&&e.target.some(e=>yr(r.range.zone,e))&&this.dispatch(`REMOVE_TABLE`,{sheetId:e.sheetId,target:[r.range.zone]})}break}}}getCoreTables(e){return this.tables[e]?Object.values(this.tables[e]).filter(C):[]}getCoreTable({sheetId:e,col:t,row:n}){return this.getCoreTables(e).find(e=>vr(t,n,e.range.zone))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter(e=>t.some(t=>_r(e.range.zone,t)))}extendTableDown(e,t){let n=this.getters.extendRange(t.range,`ROW`,1);this.history.update(`tables`,e,t.id,this.updateStaticTable(t,n))}extendTableRight(e,t){let n=this.getters.extendRange(t.range,`COL`,1);this.history.update(`tables`,e,t.id,this.updateStaticTable(t,n))}canUpdateCellCmdExtendTable({content:e,sheetId:t,col:n,row:r},i){if(!e)return`none`;let a=i.range.zone,o=`none`;if(a.bottom+1===r&&n>=a.left&&n<=a.right?o=`down`:a.right+1===n&&r>=a.top&&r<=a.bottom&&(o=`right`),o===`none`)return`none`;let s=o===`down`?{...a,bottom:a.bottom+1,top:a.bottom+1}:{...a,right:a.right+1,left:a.right+1};for(let e=s.top;e<=s.bottom;e++)for(let n=s.left;n<=s.right;n++){let r={sheetId:t,col:n,row:e};if(this.getters.getCell(r)?.content||this.getters.isInMerge(r)||this.getTablesOverlappingZones(t,[E(r)]).length)return`none`}return o}getCoreTableMatchingTopLeft(e,t){for(let n of this.getCoreTables(e)){let e=n.range.zone;if(e.left===t.left&&e.top===t.top)return n}}checkUpdatedTableZoneIsValid(e){if(!e.newTableRange)return`Success`;let t=this.getters.getRangeFromRangeData(e.newTableRange).zone,n=this.getters.checkZonesExistInSheet(e.sheetId,[t]);if(n!==`Success`)return n;let r=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);return r?this.getTablesOverlappingZones(e.sheetId,[t]).filter(e=>e.id!==r.id).length?`TableOverlap`:`Success`:`TableNotFound`}checkTableConfigUpdateIsValid(e){return e&&(e.numberOfHeaders!==void 0&&e.numberOfHeaders<0||e.hasFilters&&e.numberOfHeaders===0)?`InvalidTableConfig`:`Success`}createStaticTable(e,t,n,r,i){let a=n.zone;if(!i){i=[];for(let e of S(a.left,a.right+1)){let t={...a,left:e,right:e},o=this.consumeNextId();i.push(this.createFilterFromZone(o,n.sheetId,t,r))}}return{id:e,range:n,filters:i,config:r,type:t}}createDynamicTable(e,t,n){let r=Ar(t.zone);return{id:e,range:this.getters.getRangeFromZone(t.sheetId,r),config:n,type:`dynamic`}}updateTable(e){let t=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return;let n=e.newTableRange?this.getters.getRangeFromRangeData(e.newTableRange):void 0;if(n){let t=this.getters.getMergesInZone(e.sheetId,n.zone);this.dispatch(`REMOVE_MERGE`,{sheetId:e.sheetId,target:t})}let r=n||t.range,i=this.updateTableConfig(e.config,t.config),a=e.tableType??t.type;if(a===`dynamic`&&t.type!==`dynamic`||a!==`dynamic`&&t.type===`dynamic`){let n=a===`dynamic`?this.createDynamicTable(t.id,r,i):this.createStaticTable(t.id,a,r,i);this.history.update(`tables`,e.sheetId,t.id,n)}else{let n=t.type===`dynamic`?this.updateDynamicTable(t,r,i):this.updateStaticTable(t,r,i,a);this.history.update(`tables`,e.sheetId,t.id,n)}}updateStaticTable(e,t,n,r=e.type){if(r===`dynamic`)throw Error(`Cannot use updateStaticTable to update a dynamic table`);let i=t||e.range,a=i.zone,o=this.updateTableConfig(n,e.config),s=o||e.config,c=[];if(t||o&&`numberOfHeaders`in o)for(let t of S(a.left,a.right+1)){let n=a.top===e.range.zone.top?e.filters.find(e=>e.col===t):void 0,r={...a,left:t,right:t},o=n?.id||this.consumeNextId();c.push(this.createFilterFromZone(o,i.sheetId,r,s))}return{...e,range:i,config:s,filters:c.length?c:e.filters,type:r}}updateDynamicTable(e,t,n){let r=t?this.getters.getRangeFromZone(t.sheetId,Ar(t.zone)):e.range,i=n||e.config;return{...e,range:r,config:i}}updateTableConfig(e,t){if(!e)return t;let n={...t,...e};return e.numberOfHeaders===0?n.hasFilters=!1:e.hasFilters===!0&&(n.numberOfHeaders||=1),n}createFilterFromZone(e,t,n,r){return Lz(e,this.getters.getRangeFromZone(t,n),r,this.getters.getRangeFromZone)}copyStaticTableForSheet(e,t){let n=this.getters.getRangeFromZone(e,t.range.zone),r=t.filters.map(n=>{let r=this.getters.getRangeFromZone(e,n.rangeWithHeaders.zone);return Lz(n.id,r,t.config,this.getters.getRangeFromZone)});return{id:t.id,range:n,filters:r,config:b(t.config),type:t.type}}copyDynamicTableForSheet(e,t){let n=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:n,config:b(t.config),type:`dynamic`}}applyRangeChangeOnTable(e,t,n){let r=n(t.range),i;switch(r.changeType){case`REMOVE`:this.history.update(`tables`,e,t.id,void 0);return;case`NONE`:return;default:i=r.range}if(t.type===`dynamic`){let n=this.updateDynamicTable(t,i);this.history.update(`tables`,e,t.id,n);return}let a=[];for(let e of t.filters){let r=n(e.rangeWithHeaders);switch(r.changeType){case`REMOVE`:continue;case`NONE`:a.push(e);break;default:let n=r.range,i=Lz(e.id,n,t.config,this.getters.getRangeFromZone);a.push(i)}}let o=i.zone;if(a.length<br(o).numberOfCols){for(let n=o.left;n<=o.right;n++)if(!a.find(e=>e.col===n)){let r=this.consumeNextId(),i={...o,left:n,right:n};a.push(this.createFilterFromZone(r,e,i,t.config))}a.sort((e,t)=>e.col-t.col)}let s=this.createStaticTable(t.id,t.type,i,t.config,a);this.history.update(`tables`,e,t.id,s)}consumeNextId(){let e=`${this.nextTableId}`;return this.history.update(`nextTableId`,this.nextTableId+1),e}import(e){for(let t of e.sheets)for(let e of t.tables||[]){let n=this.consumeNextId(),r=e.config||OA,i=this.getters.getRangeFromSheetXC(t.id,e.range),a=e.type||`static`,o=a===`dynamic`?this.createDynamicTable(n,i,r):this.createStaticTable(n,a,i,r);this.history.update(`tables`,t.id,o.id,o)}}export(e){for(let t of e.sheets)for(let e of this.getCoreTables(t.id)){let n={range:cr(e.range.zone),type:e.type};w(e.config,OA)||(n.config=e.config),t.tables.push(n)}}exportForExcel(e){for(let t of e.sheets)for(let e of this.getCoreTables(t.id)){let n=cr(e.range.zone);t.tables.push({range:n,filters:[],config:e.config})}}},NV=class extends mV{static getters=[`getHeaderGroups`,`getGroupsLayers`,`getVisibleGroupLayers`,`getHeaderGroup`,`getHeaderGroupsInZone`,`isGroupFolded`,`isRowFolded`,`isColFolded`];groups={};allowDispatch(e){switch(e.type){case`GROUP_HEADERS`:{let{start:t,end:n,sheetId:r}=e;if(!this.getters.tryGetSheet(r))return`InvalidSheetId`;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,n])||t>n)return`InvalidHeaderGroupStartEnd`;if(this.findGroupWithStartEnd(e.sheetId,e.dimension,t,n))return`HeaderGroupAlreadyExists`;break}case`UNGROUP_HEADERS`:{let{start:t,end:n,sheetId:r}=e;if(!this.getters.tryGetSheet(r))return`InvalidSheetId`;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,n])||t>n)return`InvalidHeaderGroupStartEnd`;break}case`UNFOLD_HEADER_GROUP`:case`FOLD_HEADER_GROUP`:if(!this.getters.tryGetSheet(e.sheetId))return`InvalidSheetId`;let t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return`UnknownHeaderGroup`;if(S(0,this.getters.getNumberHeaders(e.sheetId,e.dimension)).every(n=>n>=t.start&&n<=t.end||this.getters.isHeaderHiddenByUser(e.sheetId,e.dimension,n)))return`NotEnoughElements`;break}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`:{let t=b(this.groups[e.sheetId]);this.history.update(`groups`,e.sheetIdTo,t);break}case`DELETE_SHEET`:{let t={...this.groups};delete t[e.sheetId],this.history.update(`groups`,t);break}case`ADD_COLUMNS_ROWS`:let t=jt(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`:{let t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.unfoldHeaderGroup(e.sheetId,e.dimension,t);break}case`FOLD_HEADER_GROUP`:{let 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`:{let t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(let n of t)this.unfoldHeaderGroup(e.sheetId,e.dimension,n);break}case`FOLD_ALL_HEADER_GROUPS`:{let t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(let n of t)this.foldHeaderGroup(e.sheetId,e.dimension,n);break}case`FOLD_HEADER_GROUPS_IN_ZONE`:case`UNFOLD_HEADER_GROUPS_IN_ZONE`:{let t=e.type===`UNFOLD_HEADER_GROUPS_IN_ZONE`?`unfold`:`fold`,n=this.getGroupsLayers(e.sheetId,e.dimension);t===`fold`&&n.reverse();let r=n.flat(),i=e.dimension===`ROW`?e.zone.top:e.zone.left,a=e.dimension===`ROW`?e.zone.bottom:e.zone.right,o=new Set;for(let e=i;e<=a;e++){let n=r.filter(t=>t.start-1<=e&&e<=t.end);for(let e of n)if(!(t===`fold`&&e.isFolded||t===`unfold`&&!e.isFolded)){o.add(e);break}}for(let n of o)t===`unfold`?this.unfoldHeaderGroup(e.sheetId,e.dimension,n):this.foldHeaderGroup(e.sheetId,e.dimension,n);break}}}getHeaderGroups(e,t){return this.groups[e][t]}getHeaderGroup(e,t,n,r){return this.getHeaderGroups(e,t).find(e=>e.start===n&&e.end===r)}getHeaderGroupsInZone(e,t,n){return this.getHeaderGroups(e,t).filter(e=>{let r=t===`ROW`?n.top:n.left,i=t===`ROW`?n.bottom:n.right;return this.doGroupOverlap(e,r,i)})}getGroupsLayers(e,t){let n=this.getHeaderGroups(e,t);return this.bricksFallingAlgorithm(n,0,0)}getVisibleGroupLayers(e,t){let n=this.getGroupsLayers(e,t);for(let r of n)for(let n=r.length-1;n>=0;n--){let i=r[n];i.start!==0&&S(i.start-1,i.end+1).every(n=>this.getters.isHeaderHiddenByUser(e,t,n))&&r.splice(n,1)}return n.filter(e=>e.length>0)}isGroupFolded(e,t,n,r){return this.getHeaderGroup(e,t,n,r)?.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,n,r=0){let i={};for(let t of e)i[this.getGroupId(t)]=t.isFolded;let a={};for(let t of e)for(let e=t.start;e<=t.end;e++)a[e]=a[e]?a[e]+1:1;for(let e=t;e<=n;e++)a[e]=a[e]?a[e]+r:r;let o=Math.max(...Object.values(a),0),s=Array.from({length:o},()=>[]),c=Math.max(n,...e.map(e=>e.end)),l=Math.min(t,...e.map(e=>e.start));for(let e=l;e<=c;e++){let t=a[e]||0;for(let n=0;n<t;n++){let t=s[n].at(-1);if(t&&Bt([t.end,e]))t.end++;else{let t={start:e,end:e};s[n].push(t)}}}for(let e of s)for(let t of e)t.isFolded=i[this.getGroupId(t)];return s}groupHeaders(e,t,n,r){let i=this.getHeaderGroups(e,t),a=this.bricksFallingAlgorithm(i,n,r,1).flat();this.history.update(`groups`,e,t,this.removeDuplicateGroups(a))}unGroupHeaders(e,t,n,r){let i=this.getHeaderGroups(e,t),a=this.bricksFallingAlgorithm(i,n,r,-1).flat();this.history.update(`groups`,e,t,this.removeDuplicateGroups(a))}moveGroupsOnHeaderInsertion(e,t,n,r){let i=this.groups[e][t];for(let a=0;a<i.length;a++){let o=i[a],[s,c]=jc(n,r,[o.start,o.end]);(s!==o.start||c!==o.end)&&this.history.update(`groups`,e,t,a,{...o,start:s,end:c})}}moveGroupsOnHeaderDeletion(e,t,n){let r=this.getHeaderGroups(e,t),i=[];for(let e of r){let t=Mc(n,S(e.start,e.end+1));t.length!==0&&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,n){return e.start<=n&&e.end>=t}removeDuplicateGroups(e){let t={};for(let n of e)t[this.getGroupId(n)]=n;return Object.values(t)}findGroupWithStartEnd(e,t,n,r){return this.getHeaderGroups(e,t).find(e=>e.start===n&&e.end===r)}foldHeaderGroup(e,t,n){let r=this.getGroupIndex(e,t,n.start,n.end);if(r===void 0)return;this.history.update(`groups`,e,t,r,`isFolded`,!0);let i=this.getters.getHeaderGroups(e,t);for(let r=0;r<i.length;r++){let a=i[r];a.start===n.start&&a.end<=n.end&&this.history.update(`groups`,e,t,r,`isFolded`,!0)}}unfoldHeaderGroup(e,t,n){let r=this.getGroupIndex(e,t,n.start,n.end);if(r===void 0)return;this.history.update(`groups`,e,t,r,`isFolded`,!1);let i=this.getters.getHeaderGroups(e,t);for(let r=0;r<i.length;r++){let a=i[r];a.start===n.start&&a.end>=n.end&&this.history.update(`groups`,e,t,r,`isFolded`,!1)}}getGroupIndex(e,t,n,r){let i=this.groups[e][t].findIndex(e=>e.start===n&&e.end===r);return i===-1?void 0:i}import(e){for(let t of e.sheets)if(this.groups[t.id]={ROW:[],COL:[]},t.headerGroups)for(let e of[`ROW`,`COL`])for(let n of t.headerGroups[e]||[])this.groups[t.id][e].push({...n})}export(e){for(let t of e.sheets)t.headerGroups=this.groups[t.id]}exportForExcel(e){for(let t of e.sheets)for(let e of[`ROW`,`COL`]){let n=this.getGroupsLayers(t.id,e);for(let r=0;r<n.length;r++){let i=n[r];for(let n of i){for(let i=n.start;i<=n.end;i++){let a=OO(t,e,i);a.outlineLevel=r+1,n.isFolded&&(a.isHidden=!0)}if(n.isFolded){let r=OO(t,e,n.end+1);r.collapsed=!0}}}}}},PV=class extends mV{static getters=[`getPivotCoreDefinition`,`getPivotDisplayName`,`getPivotId`,`getPivotFormulaId`,`getPivotIds`,`getMeasureCompiledFormula`,`getPivotName`,`isExistingPivot`,`getMeasureFullDependencies`];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?w(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`:if(!(e.pivotId in this.pivots))return`PivotIdNotFound`;break;case`DUPLICATE_PIVOT`:if(!(e.pivotId in this.pivots))return`PivotIdNotFound`}return`Success`}handle(e){switch(e.type){case`ADD_PIVOT`:{let{pivotId:t,pivot:n}=e;this.addPivot(t,n);break}case`INSERT_PIVOT`:{let{sheetId:t,col:n,row:r,pivotId:i,table:a}=e,o={sheetId:t,col:n,row:r},{cols:s,rows:c,measures:l,fieldsType:u}=a,d=new iz(s,c,l,u||{}),f=this.getPivotFormulaId(i);this.insertPivot(o,f,d);break}case`RENAME_PIVOT`:this.history.update(`pivots`,e.pivotId,`definition`,`name`,e.name);break;case`REMOVE_PIVOT`:{let t={...this.pivots};delete t[e.pivotId];let n=this.getPivotFormulaId(e.pivotId);this.history.update(`formulaIds`,n,void 0),this.history.update(`pivots`,t);break}case`DUPLICATE_PIVOT`:{let{pivotId:t,newPivotId:n}=e,r=b(this.getPivotCore(t).definition);r.name=e.duplicatedPivotName??r.name+` (copy)`,this.addPivot(n,r);break}case`UPDATE_PIVOT`:this.history.update(`pivots`,e.pivotId,`definition`,this.repairSortedColumn(b(e.pivot))),this.compileCalculatedMeasures(e.pivotId,e.pivot.measures);break}}adaptRanges({applyChange:e,adaptFormulaString:t}){for(let t in this.pivots){let n=b(this.pivots[t]?.definition);if(!n)continue;let r=bz.get(n.type)?.adaptRanges?.(this.getters,n,e);r&&!w(n,r)&&this.history.update(`pivots`,t,`definition`,r)}for(let n in this.compiledMeasureFormulas)for(let r in this.compiledMeasureFormulas[n]){let i=this.pivots[n]?.definition.measures.find(e=>e.id===r);if(!i||!i.computedBy)continue;let a=i.computedBy.sheetId,{formula:o,dependencies:s}=this.compiledMeasureFormulas[n][r];this.history.update(`compiledMeasureFormulas`,n,r,`formula`,`dependencies`,o.dependencies.map(t=>e(t).range)),this.history.update(`compiledMeasureFormulas`,n,i.id,`dependencies`,s.map(t=>e(t).range));let c=i.computedBy.formula,l=t(a,c);l!==c&&this.replaceMeasureFormula(n,i,l)}}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,t){if(!t.computedBy)throw Error(`Measure ${t.fieldName} is not computed by formula`);return this.compiledMeasureFormulas[e][t.id].formula}getMeasureFullDependencies(e,t){if(!t.computedBy)throw Error(`Measure ${t.fieldName} is not computed by formula`);return this.compiledMeasureFormulas[e][t.id].dependencies}addPivot(e,t,n=this.nextFormulaId.toString()){this.history.update(`pivots`,e,{definition:this.repairSortedColumn(b(t)),formulaId:n}),this.compileCalculatedMeasures(e,t.measures),this.history.update(`formulaIds`,n,e),this.history.update(`nextFormulaId`,this.nextFormulaId+1)}compileCalculatedMeasures(e,t){for(let n of t)if(n.computedBy){let t=this.compileMeasureFormula(n.computedBy.sheetId,n.computedBy.formula);this.history.update(`compiledMeasureFormulas`,e,n.id,`formula`,t)}for(let n of t)if(n.computedBy){let t=this.computeMeasureFullDependencies(e,n);this.history.update(`compiledMeasureFormulas`,e,n.id,`dependencies`,t)}}computeMeasureFullDependencies(e,t,n=new Set){let r=[],i=this.getPivotCoreDefinition(e),a=this.getMeasureCompiledFormula(e,t);n.add(t.id);for(let o of a.tokens){if(o.type!==`SYMBOL`)continue;let a=i.measures.find(e=>lt(e.id)===o.value&&t.id!==e.id);!a||n.has(a.id)||!a.computedBy||r.push(...this.computeMeasureFullDependencies(e,a,n))}return r.push(...a.dependencies.filter(e=>!e.invalidXc)),r}insertPivot(e,t,n){this.resizeSheet(e.sheetId,e,n);let r=n.getPivotCells();for(let n=0;n<r.length;n++)for(let i=0;i<r[n].length;i++){let a=r[n][i];this.dispatch(`UPDATE_CELL`,{sheetId:e.sheetId,col:e.col+n,row:e.row+i,content:yd(t,a)})}}resizeSheet(e,{col:t,row:n},r){let i=r.getNumberOfDataColumns()+1,a=this.getters.getNumberCols(e),o=a-t;o<i&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`COL`,base:a-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:i-o,position:`after`});let s=r.columns.length+r.rows.length,c=this.getters.getNumberRows(e),l=c-n;l<s&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`ROW`,base:c-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:s-l,position:`after`})}getPivotCore(e){let t=this.pivots[e];if(!t)throw Error(`Pivot with id ${e} not found`);return t}compileMeasureFormula(e,t){let n=bx(t),r=n.dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t));return{...n,dependencies:r}}replaceMeasureFormula(e,t,n){let r=this.pivots[e];if(!r)return;let i=r.definition.measures.indexOf(t);this.history.update(`pivots`,e,`definition`,`measures`,i,`computedBy`,{formula:n,sheetId:t.computedBy.sheetId})}checkSortedColumnInMeasures(e){e=this.repairSortedColumn(e);let t=e.measures.map(e=>e.id);return e.sortedColumn&&!t.includes(e.sortedColumn.measure)?`InvalidDefinition`:`Success`}checkDuplicatedMeasureIds(e){let t=new Set(e.measures.map(e=>e.id));return e.measures.length===t.size?`Success`:`InvalidDefinition`}repairSortedColumn(e){if(e.sortedColumn){let t=e.measures.find(t=>t.fieldName===e.sortedColumn?.measure);if(t)return{...e,sortedColumn:{...e.sortedColumn,measure:t.id}}}return e}import(e){if(e.pivots)for(let[t,n]of Object.entries(e.pivots))this.addPivot(t,n,n.formulaId);this.history.update(`nextFormulaId`,e.pivotNextId||fd(this.pivots)+1)}export(e){e.pivots={};for(let t in this.pivots)e.pivots[t]={...this.getPivotCoreDefinition(t),formulaId:this.getPivotFormulaId(t)};e.pivotNextId=this.nextFormulaId}},FV=class extends mV{static getters=[`getLocale`];locale=k;allowDispatch(e){switch(e.type){case`UPDATE_LOCALE`:return Il(e.locale)?`Success`:`InvalidLocale`}return`Success`}handle(e){switch(e.type){case`UPDATE_LOCALE`:let t=this.locale,n=e.locale;this.history.update(`locale`,n),this.changeCellsDateFormatWithLocale(t,n);break}}getLocale(){return this.locale}changeCellsDateFormatWithLocale(e,t){for(let n of this.getters.getSheetIds())for(let[r,i]of Object.entries(this.getters.getCells(n))){let n;if(i.format===e.dateFormat&&(n=t.dateFormat),i.format===e.timeFormat&&(n=t.timeFormat),i.format===$l(e)&&(n=$l(t)),n){let{col:e,row:t,sheetId:i}=this.getters.getCellPosition(r);this.dispatch(`UPDATE_CELL`,{col:e,row:t,sheetId:i,format:n})}}}import(e){this.locale=e.settings?.locale??k}export(e){e.settings={locale:this.locale}}},IV=class extends mV{allowDispatch(e){switch(e.type){case`ADD_PIVOT`:case`UPDATE_PIVOT`:let t=e.pivot;return this.checkDataSetValidity(t)}return`Success`}checkDataSetValidity(e){if(e.type===`SPREADSHEET`&&e.dataSet){let{zone:t,sheetId:n}=e.dataSet;return!n||!this.getters.tryGetSheet(n)||!t||!or(t)?`InvalidDataSet`:this.getters.checkZonesExistInSheet(n,[t])}return`Success`}},LV=class extends mV{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(!UA[e.templateName])return`InvalidTableStyle`;try{sn(e.primaryColor)}catch{return`InvalidTableStyle`}break}return`Success`}handle(e){switch(e.type){case`CREATE_TABLE_STYLE`:let t=WA(e.tableStyleName,e.templateName,e.primaryColor);this.history.update(`styles`,e.tableStyleId,t);break;case`REMOVE_TABLE_STYLE`:let n={...this.styles};delete n[e.tableStyleId],this.history.update(`styles`,n);for(let t of this.getters.getSheetIds())for(let n of this.getters.getCoreTables(t))n.config.styleId===e.tableStyleId&&this.dispatch(`UPDATE_TABLE`,{sheetId:t,zone:n.range.zone,config:{styleId:OA.styleId}});break}}getTableStyle(e){if(!this.styles[e])throw Error(`Table style ${e} does not exist`);return this.styles[e]}getTableStyles(){return this.styles}getNewCustomTableStyleName(){return $t(O(`Custom Table Style`),Object.values(this.styles).map(e=>e.displayName),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!HA[e]}import(e){for(let e in HA)this.styles[e]=HA[e];for(let t in e.customTableStyles){let n=e.customTableStyles[t];this.styles[t]=WA(n.displayName,n.templateName,n.primaryColor)}}export(e){let t={};for(let e in this.styles)HA[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}},RV=class extends pV{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}};let zV=new h;zV.add(`pivots`,e=>{for(let t of e.getPivotIds())e.getPivot(t).markAsDirtyForEvaluation?.()});let BV=ix.mapping;function VV(e,t,n){return new HV(e,t,n).getParameters()}var HV=class{evalContext;rangeCache={};constructor(e,t,n){this.getters=t,this.computeCell=n,this.evalContext=Object.assign(Object.create(BV),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){let n=this.getRangeError(e);if(n)return n;if(t)return{value:oc(this.getters.getSheetName(e.sheetId),cr(e.zone))};let r={sheetId:e.sheetId,col:e.zone.left,row:e.zone.top};return this.computeCell(r)}range(e){let t=this.getRangeError(e);if(t)return[[t]];let n=e.sheetId,r=e.zone,i=hr(r,this.getters.getSheetZone(n));if(!i)return[[]];let{top:a,left:o,bottom:s,right:c}=r,l=`${n}-${a}-${o}-${s}-${c}`;if(l in this.rangeCache)return this.rangeCache[l];let u=i.bottom-i.top+1,d=i.right-i.left+1,f=Array(d);for(let e=i.left;e<=i.right;e++){let t=e-i.left;f[t]=Array(u);for(let r=i.top;r<=i.bottom;r++){let a=r-i.top;f[t][a]=this.computeCell({sheetId:n,col:e,row:r})}}return this.rangeCache[l]=f,f}getRangeError(e){if(!or(e.zone))return new xa;if(e.invalidSheetName)return new M(O(`Invalid sheet name: %s`,e.invalidSheetName))}},UV=d(c(((e,t)=>{(function(n,r){typeof e==`object`&&t!==void 0?t.exports=r():typeof define==`function`&&define.amd?define(r):(n||=self).RBush=r()})(e,function(){"use strict";function e(e,r,i,a,o){(function e(n,r,i,a,o){for(;a>i;){if(a-i>600){var s=a-i+1,c=r-i+1,l=Math.log(s),u=.5*Math.exp(2*l/3),d=.5*Math.sqrt(l*u*(s-u)/s)*(c-s/2<0?-1:1);e(n,r,Math.max(i,Math.floor(r-c*u/s+d)),Math.min(a,Math.floor(r+(s-c)*u/s+d)),o)}var f=n[r],p=i,m=a;for(t(n,i,r),o(n[a],f)>0&&t(n,i,a);p<m;){for(t(n,p,m),p++,m--;o(n[p],f)<0;)p++;for(;o(n[m],f)>0;)m--}o(n[i],f)===0?t(n,i,m):t(n,++m,a),m<=r&&(i=m+1),r<=m&&(a=m-1)}})(e,r,i||0,a||e.length-1,o||n)}function t(e,t,n){var r=e[t];e[t]=e[n],e[n]=r}function n(e,t){return e<t?-1:+(e>t)}var r=function(e){e===void 0&&(e=9),this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()};function i(e,t,n){if(!n)return t.indexOf(e);for(var r=0;r<t.length;r++)if(n(e,t[r]))return r;return-1}function a(e,t){o(e,0,e.children.length,t,e)}function o(e,t,n,r,i){i||=m(null),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(var a=t;a<n;a++){var o=e.children[a];s(i,e.leaf?r(o):o)}return i}function s(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 c(e,t){return e.minX-t.minX}function l(e,t){return e.minY-t.minY}function u(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function d(e){return e.maxX-e.minX+(e.maxY-e.minY)}function f(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function p(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function m(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function h(t,n,r,i,a){for(var o=[n,r];o.length;)if(!((r=o.pop())-(n=o.pop())<=i)){var s=n+Math.ceil((r-n)/i/2)*i;e(t,s,n,r,a),o.push(n,s,s,r)}}return r.prototype.all=function(){return this._all(this.data,[])},r.prototype.search=function(e){var t=this.data,n=[];if(!p(e,t))return n;for(var r=this.toBBox,i=[];t;){for(var a=0;a<t.children.length;a++){var o=t.children[a],s=t.leaf?r(o):o;p(e,s)&&(t.leaf?n.push(o):f(e,s)?this._all(o,n):i.push(o))}t=i.pop()}return n},r.prototype.collides=function(e){var t=this.data;if(!p(e,t))return!1;for(var n=[];t;){for(var r=0;r<t.children.length;r++){var i=t.children[r],a=t.leaf?this.toBBox(i):i;if(p(e,a)){if(t.leaf||f(e,a))return!0;n.push(i)}}t=n.pop()}return!1},r.prototype.load=function(e){if(!e||!e.length)return this;if(e.length<this._minEntries){for(var t=0;t<e.length;t++)this.insert(e[t]);return this}var n=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===n.height)this._splitRoot(this.data,n);else{if(this.data.height<n.height){var r=this.data;this.data=n,n=r}this._insert(n,this.data.height-n.height-1,!0)}else this.data=n;return this},r.prototype.insert=function(e){return e&&this._insert(e,this.data.height-1),this},r.prototype.clear=function(){return this.data=m([]),this},r.prototype.remove=function(e,t){if(!e)return this;for(var n,r,a,o=this.data,s=this.toBBox(e),c=[],l=[];o||c.length;){if(o||(o=c.pop(),r=c[c.length-1],n=l.pop(),a=!0),o.leaf){var u=i(e,o.children,t);if(u!==-1)return o.children.splice(u,1),c.push(o),this._condense(c),this}a||o.leaf||!f(o,s)?r?(n++,o=r.children[n],a=!1):o=null:(c.push(o),l.push(n),n=0,r=o,o=o.children[0])}return this},r.prototype.toBBox=function(e){return e},r.prototype.compareMinX=function(e,t){return e.minX-t.minX},r.prototype.compareMinY=function(e,t){return e.minY-t.minY},r.prototype.toJSON=function(){return this.data},r.prototype.fromJSON=function(e){return this.data=e,this},r.prototype._all=function(e,t){for(var n=[];e;)e.leaf?t.push.apply(t,e.children):n.push.apply(n,e.children),e=n.pop();return t},r.prototype._build=function(e,t,n,r){var i,o=n-t+1,s=this._maxEntries;if(o<=s)return a(i=m(e.slice(t,n+1)),this.toBBox),i;r||(r=Math.ceil(Math.log(o)/Math.log(s)),s=Math.ceil(o/s**(r-1))),(i=m([])).leaf=!1,i.height=r;var c=Math.ceil(o/s),l=c*Math.ceil(Math.sqrt(s));h(e,t,n,l,this.compareMinX);for(var u=t;u<=n;u+=l){var d=Math.min(u+l-1,n);h(e,u,d,c,this.compareMinY);for(var f=u;f<=d;f+=c){var p=Math.min(f+c-1,d);i.children.push(this._build(e,f,p,r-1))}}return a(i,this.toBBox),i},r.prototype._chooseSubtree=function(e,t,n,r){for(;r.push(t),!t.leaf&&r.length-1!==n;){for(var i=1/0,a=1/0,o=void 0,s=0;s<t.children.length;s++){var c=t.children[s],l=u(c),d=(f=e,p=c,(Math.max(p.maxX,f.maxX)-Math.min(p.minX,f.minX))*(Math.max(p.maxY,f.maxY)-Math.min(p.minY,f.minY))-l);d<a?(a=d,i=l<i?l:i,o=c):d===a&&l<i&&(i=l,o=c)}t=o||t.children[0]}var f,p;return t},r.prototype._insert=function(e,t,n){var r=n?e:this.toBBox(e),i=[],a=this._chooseSubtree(r,this.data,t,i);for(a.children.push(e),s(a,r);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(r,i,t)},r.prototype._split=function(e,t){var n=e[t],r=n.children.length,i=this._minEntries;this._chooseSplitAxis(n,i,r);var o=this._chooseSplitIndex(n,i,r),s=m(n.children.splice(o,n.children.length-o));s.height=n.height,s.leaf=n.leaf,a(n,this.toBBox),a(s,this.toBBox),t?e[t-1].children.push(s):this._splitRoot(n,s)},r.prototype._splitRoot=function(e,t){this.data=m([e,t]),this.data.height=e.height+1,this.data.leaf=!1,a(this.data,this.toBBox)},r.prototype._chooseSplitIndex=function(e,t,n){for(var r,i,a,s,c,l,d,f=1/0,p=1/0,m=t;m<=n-t;m++){var h=o(e,0,m,this.toBBox),g=o(e,m,n,this.toBBox),_=(i=h,a=g,s=void 0,c=void 0,l=void 0,d=void 0,s=Math.max(i.minX,a.minX),c=Math.max(i.minY,a.minY),l=Math.min(i.maxX,a.maxX),d=Math.min(i.maxY,a.maxY),Math.max(0,l-s)*Math.max(0,d-c)),v=u(h)+u(g);_<f?(f=_,r=m,p=v<p?v:p):_===f&&v<p&&(p=v,r=m)}return r||n-t},r.prototype._chooseSplitAxis=function(e,t,n){var r=e.leaf?this.compareMinX:c,i=e.leaf?this.compareMinY:l;this._allDistMargin(e,t,n,r)<this._allDistMargin(e,t,n,i)&&e.children.sort(r)},r.prototype._allDistMargin=function(e,t,n,r){e.children.sort(r);for(var i=this.toBBox,a=o(e,0,t,i),c=o(e,n-t,n,i),l=d(a)+d(c),u=t;u<n-t;u++){var f=e.children[u];s(a,e.leaf?i(f):f),l+=d(a)}for(var p=n-t-1;p>=t;p--){var m=e.children[p];s(c,e.leaf?i(m):m),l+=d(c)}return l},r.prototype._adjustParentBBoxes=function(e,t,n){for(var r=n;r>=0;r--)s(t[r],e)},r.prototype._condense=function(e){for(var t=e.length-1,n=void 0;t>=0;t--)e[t].children.length===0?t>0?(n=e[t-1].children).splice(n.indexOf(e[t]),1):this.clear():a(e[t],this.toBBox)},r})}))(),1),WV=class{rTrees={};constructor(e=[]){let t={};for(let n of e){let e=n.boundingBox.sheetId;t[e]||(t[e]=[]),t[e].push(n)}for(let e in t)this.rTrees[e]=new GV,this.rTrees[e].load(t[e])}insert(e){let 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){let 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&&w(e.data,t.data)}},GV=class extends UV.default{toBBox({boundingBox:e}){let 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}},KV=class{dependencies=new YF;rTree;constructor(e,t=[]){this.createEmptyPositionSet=e,this.rTree=new WV(t)}removeAllDependencies(e){let t=this.dependencies.get(e);if(t){for(let e of t)this.rTree.remove(e);this.dependencies.delete(e)}}addDependencies(e,t){let n=t.map(({sheetId:t,zone:n})=>({data:e,boundingBox:{zone:n,sheetId:t}}));for(let e of n)this.rTree.insert(e);let r=this.dependencies.get(e);r?r.push(...n):this.dependencies.set(e,n)}getCellsDependingOn(e,t){let n=this.createEmptyPositionSet(),r=Array.from(e).reverse();for(;r.length>0;){let e=r.pop(),i=e.zone,a=e.sheetId;for(let e=i.left;e<=i.right;e++)for(let t=i.top;t<=i.bottom;t++)n.add({sheetId:a,col:e,row:t});let o=this.rTree.search(e).map(e=>e.data),s={};for(let e of o)!n.has(e)&&!t.has(e)&&(s[e.sheetId]||(s[e.sheetId]=[]),s[e.sheetId].push(E(e)));for(let e in s){let t=Yn(s[e],[]);r.push(...t.map(t=>({sheetId:e,zone:t})))}}for(let t of e){let e=t.zone,r=t.sheetId;for(let t=e.left;t<=e.right;t++)for(let i=e.top;i<=e.bottom;i++)n.delete({sheetId:r,col:t,row:i})}return n}},qV=class extends Uint32Array{columnOffset=0;cols=0;rows=0;static create(e,t){let n=JV(t),r=e<<n>>5,i=new this(r+1);return i.columnOffset=n,i.cols=t,i.rows=e,i}getValue(e){let[t,n]=this.getCoordinates(e);return this[t]>>n&1}setValue(e,t){let[n,r]=this.getCoordinates(e),i=(this[n]>>r&1)==0&&t===1;return this[n]=this[n]&~(1<<r)|t<<r,i}isEmpty(){return!this.some(e=>e!==0)}fillAllPositions(){this.fill(-1>>>0)}clear(){this.fill(0)}getCoordinates(e){let{row:t,col:n}=e,r=(t<<this.columnOffset)+n,i=r>>5;return[i,r-(i<<5)]}};function JV(e){return e===0?-1/0:e<0?NaN:32-Math.clz32(--e)}var YV=class{sheets={};insertions=[];maxSize=0;constructor(e){for(let t in e){let n=e[t].cols,r=e[t].rows;this.maxSize+=n*r,this.sheets[t]=qV.create(r,n)}}add(e){this.sheets[e.sheetId].setValue(e,1)&&this.insertions.push(e)}addMany(e){for(let t of e)this.add(t)}delete(e){this.sheets[e.sheetId].setValue(e,0)}deleteMany(e){for(let t of e)this.delete(t)}has(e){return this.sheets[e.sheetId].getValue(e)===1}clear(){let e=[...this];this.insertions=[];for(let e in this.sheets)this.sheets[e].clear();return e}isEmpty(){if(this.insertions.length===0)return!0;for(let e in this.sheets)if(!this.sheets[e].isEmpty())return!1;return!0}fillAllPositions(){this.insertions=Array(this.maxSize);let e=0;for(let t in this.sheets){let n=this.sheets[t];n.fillAllPositions();for(let r=0;r<n.rows;r++)for(let i=0;i<n.cols;i++)this.insertions[e++]={sheetId:t,row:r,col:i}}}*[Symbol.iterator](){for(let e of this.insertions)this.sheets[e.sheetId].getValue(e)===1&&(yield e)}},XV=class{resultsToArrayFormulas=new WV;arrayFormulasToResults=new YF;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map(e=>e.data)||ZV}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){let t=this.arrayFormulasToResults.get(e);t&&(this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:t},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)}};let ZV=[],QV=Object.freeze(Ps(new ba)),$V=Object.freeze(Ps({value:null}));var eH=class{getters;compilationParams;evaluatedCells=new YF;formulaDependencies=kt(new KV(this.createEmptyPositionSet.bind(this)));blockedArrayFormulas=new YV({});spreadingRelations=new XV;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=VV(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||$V}getSpreadZone(e,t={ignoreSpillError:!1}){let n=this.spreadingRelations.getArrayResultZone(e);if(!n)return;let r=this.evaluatedCells.get(e);return r?.type===`error`&&!(t.ignoreSpillError&&r?.value===j.SpilledBlocked)?E(e):pr(E(e),n)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(this.getEvaluatedCell(e).type===`empty`)return;let t=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,E(e));return Array.from(t).find(e=>!this.blockedArrayFormulas.has(e))}isArrayFormulaSpillBlocked(e){return this.blockedArrayFormulas.has(e)}updateDependencies(e){this.formulaDependencies().removeAllDependencies(e);let t=this.getDirectDependencies(e);this.formulaDependencies().addDependencies(e,t)}addDependencies(e,t){this.formulaDependencies().addDependencies(e,t);for(let e of t)this.compilationParams.ensureRange(e)}updateCompilationParametersForIsolatedFormula(e){this.compilationParams=VV(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.__originCellPosition=e,this.compilationParams.evalContext.updateDependencies=void 0,this.compilationParams.evalContext.addDependencies=void 0,this.compilationParams.evalContext.lookupCaches=this.compilationParams.evalContext.lookupCaches||{forwardSearch:new Map,reverseSearch:new Map}}updateCompilationParameters(){this.compilationParams=VV(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(){let e={};for(let t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new YV(e)}evaluateCells(e){let t=performance.now(),n=this.createEmptyPositionSet();n.addMany(e);let r=this.getArrayFormulasImpactedByChangesOf(e);n.addMany(this.getCellsDependingOn(e)),n.addMany(r),n.addMany(this.getCellsDependingOn(r)),this.evaluate(n),console.debug(`evaluate Cells`,performance.now()-t,`ms`)}getArrayFormulasImpactedByChangesOf(e){let t=this.createEmptyPositionSet();for(let n of e){let e=this.getters.getCell(n)?.content,r=this.getArrayFormulaSpreadingOn(n);r!==void 0&&t.add(r),e||t.add(n)}let n=Cr(t);for(let e in n)for(let r of n[e])t.addMany(this.getArrayFormulasBlockedBy(e,r));return t}buildDependencyGraph(){this.blockedArrayFormulas=this.createEmptyPositionSet(),this.spreadingRelations=new XV,this.formulaDependencies=kt(()=>{let 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 KV(this.createEmptyPositionSet.bind(this),e)})}evaluateAllCells(){let e=performance.now();this.evaluatedCells=new YF,this.evaluate(this.getAllCells()),console.debug(`evaluate all cells`,performance.now()-e,`ms`)}evaluateFormulaResult(e,t,n){let r=bx(t),i=r.dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t));return this.updateCompilationParametersForIsolatedFormula(n),this.evaluateCompiledFormula(e,{...r,dependencies:i})}evaluateCompiledFormula(e,t,n){try{let r=rH(t,this.compilationParams,e,this.buildSafeGetSymbolValue(n),this.compilationParams.evalContext.__originCellPosition);return A(r)?Xa(r,nH):nH(r)}catch(e){return ox(e,``)}}getAllCells(){let e=this.createEmptyPositionSet();return e.fillAllPositions(),e}getArrayFormulasBlockedBy(e,t){let n=this.createEmptyPositionSet(),r=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e,t);n.addMany(r);let i=[...r].filter(e=>!this.blockedArrayFormulas.has(e));return i.length&&n.deleteMany(i),n.addMany(this.getCellsDependingOn(n)),n}nextPositionsToUpdate=new YV({});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();let 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){let n=e[t];if(this.nextPositionsToUpdate.has(n))continue;let r=this.computeCell(n);r!==$V&&this.evaluatedCells.set(n,r)}zV.getAll().forEach(e=>e(this.getters))}t>=30&&console.warn(`Maximum iteration reached while evaluating cells`)}computeCell(e){let t=this.evaluatedCells.get(e);if(t)return t;this.blockedArrayFormulas.has(e)||this.invalidateSpreading(e),this.spreadingRelations.isArrayFormula(e)&&this.spreadingRelations.removeNode(e);let n=this.getters.getCell(e);if(n===void 0)return $V;let r=n.id,i={format:n.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(r)?QV:(this.cellsBeingComputed.add(r),n.isFormula?this.computeFormulaCell(e,n):Ms(n,i))}catch(e){return e.value=e?.value||j.GenericError,e.message=e?.message||lx,e.errorOriginPosition=e?.errorOriginPosition,Ps(e)}finally{this.cellsBeingComputed.delete(r)}}computeAndSave(e){let t=this.computeCell(e);return this.evaluatedCells.has(e)||this.evaluatedCells.set(e,t),t}computeFormulaCell(e,t){let n=rH(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!A(n)){let r=Ps(nH(n),this.getters.getLocale(),t);return r.type===`error`&&(r.errorOriginPosition=n.errorOriginPosition??e),r}this.assertSheetHasEnoughSpaceToSpreadFormulaResult(e,n);let r=n.length,i=n[0].length;if(i===0)return Ps({value:0},this.getters.getLocale(),t);if(i===1&&r===1)return Ps(nH(n[0][0]),this.getters.getLocale(),t);let a={top:e.row,bottom:e.row+i-1,left:e.col,right:e.col+r-1};return this.spreadingRelations.addRelation({resultZone:a,arrayFormulaPosition:e}),this.assertNoMergedCellsInSpreadZone(e,n),tH(r,i,this.checkCollision(e)),tH(r,i,this.spreadValues(e,n)),this.invalidatePositionsDependingOnSpread(e.sheetId,a),Ps(nH(n[0][0]),this.getters.getLocale(),t)}invalidatePositionsDependingOnSpread(e,t){let n=this.formulaDependencies().getCellsDependingOn(Sr(t).map(t=>({sheetId:e,zone:t})),this.nextPositionsToUpdate);n.delete({sheetId:e,col:t.left,row:t.top}),this.nextPositionsToUpdate.addMany(n)}assertSheetHasEnoughSpaceToSpreadFormulaResult({sheetId:e,col:t,row:n},r){let i=this.getters.getNumberCols(e),a=this.getters.getNumberRows(e),o=t+r.length<=i,s=n+r[0].length<=a;if(!(o&&s))throw o?new wa(O(`Result couldn't be automatically expanded. Please insert more rows.`)):s?new wa(O(`Result couldn't be automatically expanded. Please insert more columns.`)):new wa(O(`Result couldn't be automatically expanded. Please insert more columns and rows.`))}assertNoMergedCellsInSpreadZone({sheetId:e,col:t,row:n},r){if(this.getters.getMergesInZone(e,{top:n,bottom:n+r[0].length-1,left:t,right:t+r.length-1}).length!==0)throw new wa(O(`Merged cells found in the spill zone. Please unmerge cells before using array formulas.`))}checkCollision(e){let{sheetId:t,col:n,row:r}=e;return(i,a)=>{let o={sheetId:t,col:i+n,row:a+r};if(this.getters.getCell(o)?.content||this.getters.getEvaluatedCell(o).type!==`empty`)throw this.blockedArrayFormulas.add(e),new wa(O(`Array result was not expanded because it would overwrite data.`),o);this.blockedArrayFormulas.delete(e)}}spreadValues({sheetId:e,col:t,row:n},r){return(i,a)=>{let o={sheetId:e,col:i+t,row:a+n},s=this.getters.getCell(o),c=Ps(nH(r[i][a]),this.getters.getLocale(),s);c.type===`error`&&(c.errorOriginPosition=r[i][a].errorOriginPosition??o),this.evaluatedCells.set(o,c)}}invalidateSpreading(e){let t=this.spreadingRelations.getArrayResultZone(e);if(!t)return;for(let n=t.left;n<=t.right;n++)for(let r=t.top;r<=t.bottom;r++){let t={sheetId:e.sheetId,col:n,row:r};this.getters.getCell(t)?.content||this.evaluatedCells.delete(t)}let n=e.sheetId;this.invalidatePositionsDependingOnSpread(n,t),this.nextPositionsToUpdate.addMany(this.getArrayFormulasBlockedBy(n,t))}buildSafeGetSymbolValue(e){return t=>{if(this.symbolsBeingComputed.has(t))return QV;this.symbolsBeingComputed.add(t);try{return e?.(t)||new ya(O(`Invalid formula`))}finally{this.symbolsBeingComputed.delete(t)}}}getDirectDependencies(e){let t=this.getters.getCell(e);return t?.isFormula?t.compiledFormula.dependencies:[]}getCellsDependingOn(e){let t=[],n=Cr(e);for(let e in n)t.push(...n[e].map(t=>({sheetId:e,zone:t})));return this.formulaDependencies().getCellsDependingOn(t,this.nextPositionsToUpdate)}};function tH(e,t,n){for(let r=0;r<e;++r)for(let e=0;e<t;++e)r===0&&e===0||n(r,e)}function nH(e){return e.value===null||e.value===void 0?{...e,value:0}:e}function rH(e,t,n,r,i){let a=t.evalContext,o=a.__originCellPosition,s=a.__originSheetId;a.__originCellPosition=i,a.__originSheetId=n;let c=e.execute(e.dependencies,t.referenceDenormalizer,t.ensureRange,r,a);return a.__originCellPosition=o,a.__originSheetId=s,c}var iH=class extends RV{static getters=[`evaluateFormula`,`evaluateFormulaResult`,`evaluateCompiledFormula`,`getCorrespondingFormulaCell`,`getRangeFormattedValues`,`getRangeValues`,`getRangeFormats`,`getEvaluatedCell`,`getEvaluatedCells`,`getEvaluatedCellsInZone`,`getEvaluatedCellsPositions`,`getSpreadZone`,`getArrayFormulaSpreadingOn`,`isArrayFormulaSpillBlocked`,`isEmpty`];shouldRebuildDependenciesGraph=!0;evaluator;positionsToUpdate=[];constructor(e){super(e),this.evaluator=new eH(e.custom,this.getters)}beforeHandle(e){(ta.has(e.type)||ra.has(e.type))&&(this.shouldRebuildDependenciesGraph=!0)}handle(e){switch(e.type){case`UPDATE_CELL`:if(!(`content`in e||`format`in e)||this.shouldRebuildDependenciesGraph)return;let 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();break}}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,n){let r=this.evaluateFormulaResult(e,t,n);return A(r)?Xa(r,e=>e.value):r.value}evaluateFormulaResult(e,t,n){return this.evaluator.evaluateFormulaResult(e,t,n)}evaluateCompiledFormula(e,t,n){return this.evaluator.evaluateCompiledFormula(e,t,n)}getRangeFormattedValues(e){return this.getters.tryGetSheet(e.sheetId)===void 0?[]:this.mapVisiblePositions(e,e=>this.getters.getEvaluatedCell(e).formattedValue)}getRangeValues(e){return this.getters.tryGetSheet(e.sheetId)===void 0?[]:this.mapVisiblePositions(e,e=>this.getters.getEvaluatedCell(e).value)}getRangeFormats(e){let t=this.getters.tryGetSheet(e.sheetId);return t===void 0?[]: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 wr(t).map(({col:t,row:n})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}))}getSpreadZone(e,t={ignoreSpillError:!1}){return this.evaluator.getSpreadZone(e,t)}getArrayFormulaSpreadingOn(e){return this.evaluator.getArrayFormulaSpreadingOn(e)}isArrayFormulaSpillBlocked(e){return this.evaluator.isArrayFormulaSpillBlocked(e)}isEmpty(e,t){return wr(t).map(({col:t,row:n})=>this.getEvaluatedCell({sheetId:e,col:t,row:n})).every(e=>e.type===`empty`)}mapVisiblePositions(e,t){let{sheetId:n,zone:r}=e;return wr(r).reduce((e,r)=>{let{col:i,row:a}=r;return!this.getters.isColHidden(n,i)&&!this.getters.isRowHidden(n,a)&&e.push(t({sheetId:n,...r})),e},[])}exportForExcel(e){for(let t of e.sheets)t.cellValues={},t.formulaSpillRanges={};for(let t of this.evaluator.getEvaluatedPositions()){let n=this.evaluator.getEvaluatedCell(t),r=T(t.col,t.row),i=n.value,a=!1,o,s=!0,c=e.sheets.find(e=>e.id===t.sheetId),l=this.getCorrespondingFormulaCell(t);if(l){let u=this.getters.getCell(t);if(s=Ox(l.compiledFormula.tokens),a=s&&u?.content===l.content,!s&&i!==``){o=(i??``).toString();let t=n.format;if(t){let n=Hr(t,e.formats);c.formats[r]=n}}}let u=c.cells[r],d;d=s&&a&&l instanceof _V?l.contentWithFixedReferences:s?u:o,c.cells[r]=d,c.cellValues[r]=i===j.BadExpression?void 0:i;let f=this.getSpreadZone(t);f&&(c.formulaSpillRanges[r]=this.getters.getRangeString(this.getters.getRangeFromZone(t.sheetId,f),t.sheetId))}}getCorrespondingFormulaCell(e){let t=this.getters.getCell(e);if(t&&t.isFormula)return t.compiledFormula.isBadExpression?void 0:t;if(t&&t.content)return;let n=this.getArrayFormulaSpreadingOn(e);if(n===void 0)return;let r=this.getters.getCell(n);if(r?.isFormula)return r}};let aH=/"(#[0-9a-fA-F]{6})"/g;function oH(e){let t=[{leadColor:dn(255,0,0),colors:[]},{leadColor:dn(255,128,0),colors:[]},{leadColor:dn(128,128,0),colors:[]},{leadColor:dn(128,255,0),colors:[]},{leadColor:dn(0,255,0),colors:[]},{leadColor:dn(0,255,128),colors:[]},{leadColor:dn(0,255,255),colors:[]},{leadColor:dn(0,127,255),colors:[]},{leadColor:dn(0,0,255),colors:[]},{leadColor:dn(127,0,255),colors:[]},{leadColor:dn(128,0,128),colors:[]},{leadColor:dn(255,0,128),colors:[]}];for(let n of e.map(hn)){let e=500,r=0;t.forEach((t,i)=>{let a=sH(n,t.leadColor);e>a&&(e=a,r=i)}),t[r].colors.push(n)}return t.map(e=>e.colors.sort((e,t)=>_n(e).s-_n(t).s)).flat().map(mn)}function sH(e,t){return Math.sqrt((e.r-t.r)**2+(e.g-t.g)**2+(e.b-t.b)**2)}var cH=class extends RV{customColors={};shouldUpdateColors=!0;static getters=[`getCustomColors`];constructor(e){super(e),this.tryToAddColors(e.customColors??[])}handle(e){switch(e.type){case`START`:for(let e of this.getters.getSheetIds())for(let 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);break}}finalize(){this.shouldUpdateColors&&(this.history.update(`shouldUpdateColors`,!1),this.tryToAddColors(this.computeCustomColors()))}getCustomColors(){return oH(Object.keys(this.customColors))}computeCustomColors(){let e=[];for(let t of this.getters.getSheetIds())e=e.concat(this.getColorsFromCells(t),this.getFormattingColors(t),this.getTableColors(t));return[...new Set([...e])]}getColorsFromCells(e){let t=Object.values(this.getters.getCells(e)),n=new Set;for(let e of t)e.style?.textColor&&n.add(e.style.textColor),e.style?.fillColor&&n.add(e.style.fillColor);for(let t of this.getters.getBordersColors(e))n.add(t);return[...n]}getFormattingColors(e){let t=this.getters.getConditionalFormats(e),n=[];for(let e of t){let t=e.rule;t.type===`CellIsRule`?(n.push(t.style.textColor),n.push(t.style.fillColor)):t.type===`ColorScaleRule`&&(n.push(an(t.minimum.color)),n.push(t.midpoint?an(t.midpoint.color):void 0),n.push(an(t.maximum.color)))}return n.filter(C)}getChartColors(e){let t=this.getters.getChart(e);return t===void 0?[]:[...JSON.stringify(t.getDefinition()).matchAll(aH)].map(e=>e[1])}getTableColors(e){return this.getters.getTables(e).flatMap(e=>{let t=e.config,n=this.getters.getTableStyle(t.styleId);return[this.getTableStyleElementColors(n.wholeTable),t.numberOfHeaders>0?this.getTableStyleElementColors(n.headerRow):[],t.totalRow?this.getTableStyleElementColors(n.totalRow):[],t.bandedColumns?this.getTableStyleElementColors(n.firstColumnStripe):[],t.bandedColumns?this.getTableStyleElementColors(n.secondColumnStripe):[],t.bandedRows?this.getTableStyleElementColors(n.firstRowStripe):[],t.bandedRows?this.getTableStyleElementColors(n.secondRowStripe):[],t.firstColumn?this.getTableStyleElementColors(n.firstColumn):[],t.lastColumn?this.getTableStyleElementColors(n.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(C):[]}tryToAddColors(e){for(let t of e){if(!cn(t))continue;let e=sn(t);t&&!Fe.includes(e)&&this.history.update(`customColors`,e,!0)}}},lH=class extends RV{static getters=[`getChartRuntime`,`getStyleOfSingleCellChart`];charts={};createRuntimeChart=lD(this.getters);handle(e){if(ta.has(e.type)||ia.has(e.type)||na.has(e.type))for(let 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(let e in this.charts)this.getters.isChartDefined(e)||(this.charts[e]=void 0);break}}getChartRuntime(e){if(!this.charts[e]){let t=this.getters.getChart(e);if(!t)throw 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:Kx(e)};if(!t)return{background:ae,fontColor:Kx(ae)};let n=t.zone.left,r=t.zone.top,i=t.sheetId,a=this.getters.getCellComputedStyle({sheetId:i,col:n,row:r}),o=a.fillColor||`#FFFFFF`;return{background:o,fontColor:a.textColor||Kx(o)}}exportForExcel(e){for(let t of e.sheets){t.images||=[];let e=this.getters.getFigures(t.id),n=[];for(let r of e){if(!r||r.tag!==`chart`)continue;let e=r.id,i=this.getters.getChart(e)?.getDefinitionForExcel();if(i)n.push({...r,data:i});else{if(!this.getters.getChart(e))continue;let n=this.getters.getChartType(e),i=aw(this.getters.getChartRuntime(e),r,n);i&&t.images.push({...r,tag:`image`,data:{mimetype:`image/png`,path:i,size:{width:r.width,height:r.height}}})}}t.charts=n}}},uH=class extends RV{static getters=[`getConditionalIcon`,`getCellConditionalFormatStyle`,`getConditionalDataBar`];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(ta.has(e.type)||ia.has(e.type)||e.type===`UPDATE_CELL`&&(`content`in e||`format`in e))&&(this.isStale=!0)}finalize(){if(this.isStale){for(let e of this.getters.getSheetIds())this.computedStyles[e]=kt(()=>this.getComputedStyles(e)),this.computedIcons[e]=kt(()=>this.getComputedIcons(e)),this.computedDataBars[e]=kt(()=>this.getComputedDataBars(e));this.isStale=!1}}getCellConditionalFormatStyle(e){let{sheetId:t,col:n,row:r}=e,i=this.computedStyles[t]();return i&&i[n]?.[r]}getConditionalIcon({sheetId:e,col:t,row:n}){let r=this.computedIcons[e]();return r&&r[t]?.[n]}getConditionalDataBar({sheetId:e,col:t,row:n}){let r=this.computedDataBars[e]();return r&&r[t]?.[n]}getComputedStyles(e){let t={};for(let n of this.getters.getConditionalFormats(e).reverse())switch(n.rule.type){case`ColorScaleRule`:for(let r of n.ranges)this.applyColorScale(e,r,n.rule,t);break;case`CellIsRule`:let r=n.rule.values.map(e=>e.startsWith(`=`)?bx(e):void 0);for(let i of n.ranges){let a=this.getters.getRangeFromSheetXC(e,i).zone;for(let i=a.top;i<=a.bottom;i++)for(let o=a.left;o<=a.right;o++){let s=this.rulePredicate[n.rule.type],c={sheetId:e,col:o,row:i},l=n.rule.values.map((t,n)=>{let s=r[n];return s?this.getters.getTranslatedCellFormula(e,o-a.left,i-a.top,s.tokens):t});s&&s(c,{...n.rule,values:l})&&(t[o]||(t[o]=[]),t[o][i]=Object.assign(t[o]?.[i]||{},n.rule.style))}}break}return t}getComputedIcons(e){let t={};for(let n of this.getters.getConditionalFormats(e).reverse())if(n.rule.type===`IconSetRule`)for(let r of n.ranges)this.applyIcon(e,r,n.rule,t);return t}getComputedDataBars(e){let t={};for(let n of this.getters.getConditionalFormats(e).reverse())if(n.rule.type===`DataBarRule`)for(let r of n.ranges)this.applyDataBar(e,r,n.rule,t);return t}parsePoint(e,t,n,r){let i=this.getters.getEvaluatedCellsInZone(e,this.getters.getRangeFromSheetXC(e,t).zone).filter(e=>e.type===`number`).map(e=>e.value);switch(n.type){case`value`:return r===`max`?Jt(i):Yt(i);case`number`:return Number(n.value);case`percentage`:let t=Yt(i);return t+(Jt(i)-t)*Number(n.value)/100;case`percentile`:return Bi(i,Number(n.value)/100,!0);case`formula`:let a=n.value&&this.getters.evaluateFormula(e,n.value);return typeof a==`number`?a:null;default:return null}}applyIcon(e,t,n,r){let i=this.parsePoint(e,t,n.lowerInflectionPoint),a=this.parsePoint(e,t,n.upperInflectionPoint);if(i===null||a===null||i>a)return;let o=this.getters.getRangeFromSheetXC(e,t).zone,s=[n.icons.upper,n.icons.middle,n.icons.lower];for(let t=o.top;t<=o.bottom;t++)for(let c=o.left;c<=o.right;c++){let o=this.getters.getEvaluatedCell({sheetId:e,col:c,row:t});if(o.type!==`number`)continue;let l=this.computeIcon(o.value,a,n.upperInflectionPoint.operator,i,n.lowerInflectionPoint.operator,s);r[c]||(r[c]=[]),r[c][t]=l}}computeIcon(e,t,n,r,i,a){return n===`ge`&&e>=t||n===`gt`&&e>t?a[0]:i===`ge`&&e>=r||i===`gt`&&e>r?a[1]:a[2]}applyDataBar(e,t,n,r){let i=this.getters.getRangeFromSheetXC(e,n.rangeValues||t),a=Jt(this.getters.getEvaluatedCellsInZone(e,i.zone).filter(e=>e.type===`number`).map(e=>e.value));if(a<=0)return;let o=n.color,s=this.getters.getRangeFromSheetXC(e,t).zone,c=i.zone;for(let t=s.top;t<=s.bottom;t++)for(let n=s.left;n<=s.right;n++){let i=n-s.left+c.left,l=t-s.top+c.top,u=this.getters.getEvaluatedCell({sheetId:e,col:i,row:l});!vr(i,l,c)||u.type!==`number`||u.value<=0||(r[n]||(r[n]=[]),r[n][t]={color:an(o),percentage:u.value*100/a})}}applyColorScale(e,t,n,r){let i=this.parsePoint(e,t,n.minimum,`min`),a=n.midpoint?this.parsePoint(e,t,n.midpoint):null,o=this.parsePoint(e,t,n.maximum,`max`);if(i===null||o===null||i>=o||a&&(i>=a||a>=o))return;let s=this.getters.getRangeFromSheetXC(e,t).zone,c=[{value:i,color:n.minimum.color}];n.midpoint&&a&&c.push({value:a,color:n.midpoint.color}),c.push({value:o,color:n.maximum.color});let l=In(c);for(let t=s.top;t<=s.bottom;t++)for(let n=s.left;n<=s.right;n++){let a=this.getters.getEvaluatedCell({sheetId:e,col:n,row:t});if(a.type===`number`){let e=x(a.value,i,o);r[n]||(r[n]=[]),r[n][t]=r[n]?.[t]||{},r[n][t].fillColor=l(e)}}}rulePredicate={CellIsRule:(e,t)=>{let n=this.getters.getEvaluatedCell(e);if(n.type===`error`)return!1;let[r,i]=t.values.map(t=>t.startsWith(`=`)?this.getters.evaluateFormula(e.sheetId,t)??``:Ns(t,k));if(A(r)||A(i))return!1;let a=n.value??``;switch(r??=``,i??=``,t.operator){case`IsEmpty`:return a.toString().trim()===``;case`IsNotEmpty`:return a.toString().trim()!==``;case`BeginsWith`:return r===``?!1:a.toString().startsWith(r.toString());case`EndsWith`:return r===``?!1:a.toString().endsWith(r.toString());case`Between`:return a>=r&&a<=i;case`NotBetween`:return!(a>=r&&a<=i);case`ContainsText`:return a.toString().indexOf(r.toString())>-1;case`NotContains`:return!a||a.toString().indexOf(r.toString())===-1;case`GreaterThan`:return a>r;case`GreaterThanOrEqual`:return a>=r;case`LessThan`:return a<r;case`LessThanOrEqual`:return a<=r;case`NotEqual`:return r===``?!1:a!==r;case`Equal`:return r===``?!0:a===r;default:console.warn(O(`Not implemented operator %s for kind of conditional formatting: %s`,t.operator,t.type))}return!1}}};let dH={isValid:!0};var fH=class extends RV{static getters=[`getDataValidationInvalidCriterionValueMessage`,`getInvalidDataValidationMessage`,`getValidationResultForCellValue`,`isCellValidCheckbox`,`isDataValidationInvalid`];validationResults={};handle(e){if(ta.has(e.type)||e.type===`EVALUATE_CELLS`||e.type===`UPDATE_CELL`&&(`content`in e||`format`in e)){this.validationResults={};return}switch(e.type){case`ADD_DATA_VALIDATION_RULE`:case`REMOVE_DATA_VALIDATION_RULE`:delete this.validationResults[e.sheetId];break}}isDataValidationInvalid(e){return!this.getValidationResultForCell(e).isValid}getInvalidDataValidationMessage(e){let t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){let n=$.get(e);return t.startsWith(`=`)?n.allowedValues===`onlyLiterals`?O(`The value must not be a formula`):this.isValidFormula(t)?void 0:K.CriterionError.validFormula:n.allowedValues===`onlyFormulas`?O(`The value must be a formula`):n.isCriterionValueValid(t)?void 0:n.criterionValueErrorString}isCellValidCheckbox(e){if(!this.getters.isMainCellPosition(e))return!1;let t=this.getters.getValidationRuleForCell(e);return!t||t.criterion.type!==`isBoolean`?!1:this.getValidationResultForCell(e).isValid}getValidationResultForCellValue(e,t){let n=this.getters.getValidationRuleForCell(t);if(!n)return dH;let r=this.getRuleErrorForCellValue(e,t,n);return r?{error:r,rule:n,isValid:!1}:dH}isValidFormula(e){return!bx(e).isBadExpression}getValidationResultForCell(e){let{col:t,row:n,sheetId:r}=e;return this.validationResults[r]||(this.validationResults[r]=this.computeSheetValidationResults(r)),this.validationResults[r][t]?.[n]?.()||dH}computeSheetValidationResults(e){let t={},n=this.getters.getDataValidationRules(e).map(e=>e.ranges);for(let e of gc(n.flat())){let{col:n,row:r}=e;t[n]||(t[n]=[]),t[n][r]=kt(()=>{let t=this.getters.getEvaluatedCell(e);return t.type===`empty`?dH:this.getValidationResultForCellValue(t.value,e)})}return t}getRuleErrorForCellValue(e,t,n){let{sheetId:r}=t,i=n.criterion,a=$.get(i.type),o=this.getCellOffsetInRule(t,n),s=this.getEvaluatedCriterionValues(r,o,i),c={...i,values:s};if(!a.isValueValid(e,c,this.getters,r))return a.getErrorString(c,this.getters,r)}getCellOffsetInRule(e,t){let n=t.ranges.find(t=>vr(e.col,e.row,t.zone));if(!n)throw Error(`The cell is not in any range of the rule`);return{col:e.col-n.zone.left,row:e.row-n.zone.top}}getEvaluatedCriterionValues(e,t,n){return n.values.map(n=>{if(!n.startsWith(`=`))return n;let r=bx(n),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,r.tokens),a=this.getters.evaluateFormula(e,i);return a&&!A(a)?a.toString():``})}},pH=class extends RV{static getters=[`canCreateDynamicTableOnZones`,`doesZonesContainFilter`,`getFilter`,`getFilters`,`getTable`,`getTables`,`getTablesOverlappingZones`,`getFilterId`,`getFilterHeaders`,`isFilterHeader`];tables={};handle(e){if(ta.has(e.type)||e.type===`UPDATE_CELL`&&(`content`in e||`format`in e)||e.type===`EVALUATE_CELLS`){this.tables={};return}switch(e.type){case`CREATE_TABLE`:case`REMOVE_TABLE`:case`UPDATE_TABLE`:case`DELETE_CONTENT`:this.tables={};break}}finalize(){for(let e of this.getters.getSheetIds())this.tables[e]||(this.tables[e]=this.computeTables(e))}computeTables(e){let t=[],n=this.getters.getCoreTables(e);for(let e of n)e.type!==`dynamic`&&t.push(e);let r=[...t];for(let i of n){if(i.type!==`dynamic`)continue;let n=this.coreTableToTable(e,i),a=n.range.zone;for(let e of r){let t=e.range.zone;_r(a,t)&&(a=t.left>a.left?{...a,right:Math.min(a.right,t.left-1)}:{...a,bottom:Math.min(a.bottom,t.top-1)})}t.push({...n,range:this.getters.getRangeFromZone(e,a)})}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){let 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:n}){return this.getTables(e).find(e=>vr(t,n,e.range.zone))}getTablesOverlappingZones(e,t){return this.getTables(e).filter(e=>t.some(t=>_r(e.range.zone,t)))}doesZonesContainFilter(e,t){return this.getTablesOverlappingZones(e,t).some(e=>e.config.hasFilters)}getFilterHeaders(e){let t=[];for(let n of this.getTables(e)){if(!n.config.hasFilters)continue;let r=n.range.zone,i=r.top;for(let n=r.left;n<=r.right;n++)t.push({sheetId:e,col:n,row:i})}return t}isFilterHeader({sheetId:e,col:t,row:n}){return this.getFilterHeaders(e).some(e=>e.col===t&&e.row===n)}canCreateDynamicTableOnZones(e,t){if(!Fr(t))return!1;let n=pr(...t),r={col:n.left,row:n.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(r);if(!i){let e=this.getters.getEvaluatedCell(r);return e.value===j.SpilledBlocked&&!e.errorOriginPosition}else if(w(i,r)&&Nr(n)===1)return!0;return w(n,this.getters.getSpreadZone(i))}coreTableToTable(e,t){if(t.type!==`dynamic`)return t;let n=t.range.zone,r={sheetId:e,col:n.left,row:n.top},i=this.getters.getSpreadZone(r)??t.range.zone,a=this.getters.getRangeFromZone(e,i),o=this.getDynamicTableFilters(e,t,i);return{id:t.id,range:a,filters:o,config:t.config}}getDynamicTableFilters(e,t,n){let r=[],{top:i,bottom:a,left:o,right:s}=n;for(let n=o;n<=s;n++){let s=n-o,c={left:n,right:n,top:i,bottom:a},l=Lz(this.getDynamicTableFilterId(t.id,s),this.getters.getRangeFromZone(e,c),t.config,this.getters.getRangeFromZone);r.push(l)}return r}getDynamicTableFilterId(e,t){return e+`_`+t}isTableExcelExportable(e,t){return t.type===`dynamic`?!1:!wr(t.range.zone).some(t=>this.getters.getArrayFormulaSpreadingOn({sheetId:e,...t}))}exportForExcel(e){for(let t of e.sheets){let n=[];for(let r of t.tables){let i=ar(r.range),a={sheetId:t.id,col:i.left,row:i.top},o=this.getters.getCoreTable(a),s=this.getTable(a);if(!o||!s||this.isTableExcelExportable(t.id,o)){n.push(r);continue}t.styles=t.styles||{},t.borders=t.borders||{};for(let n of wr(s.range.zone)){let r={sheetId:t.id,...n},i=this.getters.getCellComputedStyle(r),a=this.getters.getCellComputedBorder(r),o=T(n.col,n.row);if(!Tt(i)){let n=Hr(i,e.styles);t.styles[o]=n}if(a){let n=Hr(a,e.borders);t.borders[o]=n}}}t.tables=n}}},mH=class extends RV{static getters=[`getRowSize`,`getHeaderSize`,`getMaxAnchorOffset`];tallestCellInRow={};ctx=document.createElement(`canvas`).getContext(`2d`);beforeHandle(e){switch(e.type){case`ADD_COLUMNS_ROWS`:if(e.dimension===`COL`)return;let t=jt(e.position,e.base),n=Array(e.quantity).fill(void 0),r=Ut(this.tallestCellInRow[e.sheetId],n,t);this.history.update(`tallestCellInRow`,e.sheetId,r);break}}handle(e){switch(e.type){case`START`:case`UPDATE_LOCALE`:for(let e of this.getters.getSheetIds())this.initializeSheet(e);break;case`CREATE_SHEET`:this.initializeSheet(e.sheetId);break;case`DUPLICATE_SHEET`:{let t=b(this.tallestCellInRow[e.sheetId]);this.history.update(`tallestCellInRow`,e.sheetIdTo,t);break}case`DELETE_SHEET`:let t={...this.tallestCellInRow};delete t[e.sheetId],this.history.update(`tallestCellInRow`,t);break;case`REMOVE_COLUMNS_ROWS`:{if(e.dimension===`COL`)return;let t=Ht(this.tallestCellInRow[e.sheetId],e.elements);this.history.update(`tallestCellInRow`,e.sheetId,t);break}case`RESIZE_COLUMNS_ROWS`:{let t=e.sheetId;if(e.dimension===`ROW`)for(let n of e.elements){let e=this.getRowTallestCell(t,n);this.history.update(`tallestCellInRow`,t,n,e)}else for(let n of S(0,this.getters.getNumberRows(t)))for(let r of e.elements)this.updateRowSizeForCellChange(t,n,r)}break;case`UPDATE_CELL`:this.updateRowSizeForCellChange(e.sheetId,e.row,e.col);break;case`ADD_MERGE`:case`REMOVE_MERGE`:for(let t of e.target)for(let n of wr(t))this.updateRowSizeForCellChange(e.sheetId,n.row,n.col)}}getRowSize(e,t){return Math.round(this.getters.getUserRowSize(e,t)??this.tallestCellInRow[e][t]?.size??23)}getMaxAnchorOffset(e,t,n){let{numberOfRows:r,numberOfCols:i}=this.getters.getSheetSize(e),a=0;for(;a<t&&r>0;r--)a+=this.getRowSize(e,r-1);let o=0;for(;o<n&&i>0;i--)o+=this.getters.getColSize(e,i-1);return{col:i,row:r,offset:{x:o-n,y:a-t}}}getHeaderSize(e,t,n){return this.getters.isHeaderHidden(e,t,n)?0:t===`ROW`?this.getRowSize(e,n):this.getters.getColSize(e,n)}updateRowSizeForCellChange(e,t,n){let r=this.tallestCellInRow[e]?.[t];if(r?.cell.col===n){let n=this.getRowTallestCell(e,t);this.history.update(`tallestCellInRow`,e,t,n)}let i=this.getCellHeight({sheetId:e,col:n,row:t});if(!(i<=23)&&(!r&&i>23||r&&i>r.size)){let r={cell:{sheetId:e,col:n,row:t},size:i};this.history.update(`tallestCellInRow`,e,t,r)}}initializeSheet(e){let t=[];for(let n=0;n<this.getters.getNumberRows(e);n++){let r=this.getRowTallestCell(e,n);t.push(r)}this.history.update(`tallestCellInRow`,e,t)}getCellHeight(e){if(this.isInMultiRowMerge(e))return 23;let t=this.getters.getCell(e),n=this.getters.getColSize(e.sheetId,e.col);return Lc(this.ctx,t,this.getters.getLocale(),n)}isInMultiRowMerge(e){let t=this.getters.getMerge(e);return!!t&&t.bottom!==t.top}getRowTallestCell(e,t){if(this.getters.getUserRowSize(e,t)!==void 0)return;let n=this.getters.getRowCells(e,t),r=0,i;for(let e=0;e<n.length;e++){let t=this.getters.getCellById(n[e]);if(!t)continue;let a=this.getters.getCellPosition(t.id),o=this.getCellHeight(a);o>r&&o>23&&(r=o,i={cell:a,size:o})}if(i&&i.size>23)return i}};let hH=`0.00%`;function gH(e){class t extends e{getters;pivotId;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t,n){super(t,n),this.getters=n.getters,this.pivotId=e}markAsDirtyForEvaluation(){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.markAsDirtyForEvaluation?.()}getPivotCellValueAndFormat(e,t){return this.getMeasureDisplayValue(e,t)}_getPivotCellValueAndFormat(e,t){let n=`${e}-${t.map(e=>e.field+`=`+e.value).join(`,`)}`;if(this.cache[n])return this.cache[n];let r=this.getMeasure(e),i=r.computedBy?this.computeMeasure(r,t):super.getPivotCellValueAndFormat(e,t);return r.format?this.cache[n]={...i,format:r.format}:this.cache[n]=i,this.cache[n]}computeMeasure(e,t){if(!e.computedBy)return{value:0};let{columns:n,rows:r}=super.definition;if(e.aggregator&&n.length+r.length!==t.length){let n=this.getValuesToAggregate(e,t),r=dd[e.aggregator];if(!r)return{value:0};try{return r([n],this.getters.getLocale())}catch(t){return ox(t,e.aggregator.toUpperCase())}}let i=this.getters.getMeasureCompiledFormula(this.pivotId,e),a=this.getters.evaluateCompiledFormula(e.computedBy.sheetId,i,e=>{let{columns:n,rows:r}=this.definition;if(n.find(t=>t.nameWithGranularity===e)){let{colDomain:n}=ju(this,t),r=n.findIndex(t=>t.field===e);return r===-1?new Sa:this.getPivotHeaderValueAndFormat(n.slice(0,r+1))}if(r.find(t=>t.nameWithGranularity===e)){let{rowDomain:n}=ju(this,t),r=n.findIndex(t=>t.field===e);return r===-1?new Sa:this.getPivotHeaderValueAndFormat(n.slice(0,r+1))}return this.getPivotCellValueAndFormat(e,t)});return A(a)?a[0][0]:a}getValuesToAggregate(e,t){let{rowDomain:n,colDomain:r}=ju(this,t),i=super.getTableStructure(),a=[];if(r.length===0&&n.length<this.definition.rows.length&&this.definition.rows.length&&this.definition.columns.length){let t=this.treeToLeafDomains(i.getColTree()),r=this.getSubTreeMatchingDomain(i.getRowTree(),n),o=this.treeToLeafDomains(r);for(let r of t)for(let t of o)a.push(this._getPivotCellValueAndFormat(e.id,n.concat(t).concat(r)));return a}else if(n.length===this.definition.rows.length&&r.length===0){let t=i.getColTree(),o=this.getSubTreeMatchingDomain(t,r),s=this.treeToLeafDomains(o,r);for(let t of s)a.push(this._getPivotCellValueAndFormat(e.id,n.concat(t)));return a}else if(n.length===this.definition.rows.length&&r.length&&r.length<this.definition.columns.length){let t=this.getSubTreeMatchingDomain(i.getColTree(),r),o=this.treeToLeafDomains(t,r);for(let t of o)a.push(this._getPivotCellValueAndFormat(e.id,n.concat(t)));return a}else{let t=i.getRowTree(),o=this.getSubTreeMatchingDomain(t,n),s=this.treeToLeafDomains(o,n);for(let t of s)a.push(this._getPivotCellValueAndFormat(e.id,t.concat(r)));return a}}getSubTreeMatchingDomain(e,t,n=0){if(n>t.length)return[];if(t.length===n)return e;for(let r of e){let e=bd(this.definition.getDimension(r.field),t[n]?.value);if(r.field===t[n]?.field&&r.value===e)return this.getSubTreeMatchingDomain(r.children,t,n+1)}return[]}treeToLeafDomains(e,t=[]){let n=[];for(let r of e){let e=this.definition.getDimension(r.field),i=[...t,{field:r.field,value:r.value,type:e.type}];r.children.length===0?n.push(i):n.push(...this.treeToLeafDomains(r.children,i))}return n}getMeasureDisplayValue(e,t){let n=this.getMeasure(e),r=this._getPivotCellValueAndFormat(e,t);if(!n.display||n.display.type===`no_calculations`||r.message)return r;let i=n.display.fieldNameWithGranularity;if(i&&!this.isFieldInPivot(i))return{value:j.NotAvailable,message:O(`Field "%s" not found in pivot for measure display calculation`,i)};try{let e=n.display;switch(e.type){case`%_of_grand_total`:return this.asPercentOfGrandTotal(r,n);case`%_of_col_total`:return this.asPercentOfColumnTotal(r,n,t);case`%_of_row_total`:return this.asPercentOfRowTotal(r,n,t);case`%_of_parent_row_total`:return this.asPercentOfParentRowTotal(r,n,t);case`%_of_parent_col_total`:return this.asPercentOfParentColumnTotal(r,n,t);case`index`:return this.asIndex(r,n,t);case`%_of_parent_total`:return this.asPercentOfParentTotal(r,n,t,e);case`running_total`:return this.asRunningTotal(r,n,t,e,`running_total`);case`%_running_total`:return this.asRunningTotal(r,n,t,e,`%_running_total`);case`rank_asc`:return this.asRank(r,n,t,e,`asc`);case`rank_desc`:return this.asRank(r,n,t,e,`desc`);case`%_of`:return this.asPercentOf(r,n,t,e);case`difference_from`:return this.asDifferenceFrom(r,n,t,e);case`%_difference_from`:return this.asDifferenceFromInPercent(r,n,t,e)}return r}catch(e){return ox(e,`COMPUTE_MEASURE_DISPLAY_VALUE`)}}asPercentOfGrandTotal(e,t){let n=this.getGrandTotal(t.id);return n===0?{value:j.DivisionByZero}:{value:this.measureValueToNumber(e)/n,format:hH}}asPercentOfRowTotal(e,t,n){let r=this.getRowTotal(t.id,n);return r===0?{value:j.DivisionByZero}:{value:this.measureValueToNumber(e)/r,format:hH}}asPercentOfColumnTotal(e,t,n){let r=this.getColumnTotal(t.id,n);return r===0?{value:j.DivisionByZero}:{value:this.measureValueToNumber(e)/r,format:hH}}asPercentOfParentRowTotal(e,t,n){let r=ku(this,n),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,r));return i===0?{value:``}:{value:this.measureValueToNumber(e)/i,format:hH}}asPercentOfParentColumnTotal(e,t,n){let r=Au(this,n),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,r));return i===0?{value:``}:{value:this.measureValueToNumber(e)/i,format:hH}}asPercentOfParentTotal(e,t,n,r){let{fieldNameWithGranularity:i}=r;if(!i)return e;if(!zu(i,n))return{value:``};let a=Lu(this,i,n),o=this._getPivotCellValueAndFormat(t.id,a),s=this.measureValueToNumber(o);return s===0?{value:``}:{value:this.measureValueToNumber(e)/s,format:hH}}asIndex(e,t,n){let r=this.measureValueToNumber(e),i=this.getRowTotal(t.id,n),a=this.getColumnTotal(t.id,n),o=this.getGrandTotal(t.id);return i===0||a===0?{value:j.DivisionByZero}:{value:r*o/(a*i),format:void 0}}asRunningTotal(e,t,n,r,i){let{fieldNameWithGranularity:a}=r;if(!a)return e;let o=i===`running_total`?this.runningTotal:this.runningTotalInPercent,s=o[t.id]?.[a];s||(s=this.computeRunningTotal(t,a,i),o[t.id]||(o[t.id]={}),o[t.id][a]=s);let{rowDomain:c,colDomain:l}=ju(this,n),u=Hu(l),d=Hu(c);return{value:s[u]?.[d]??``,format:i===`running_total`?e.format:hH}}asPercentOf(e,t,n,r){let{fieldNameWithGranularity:i,value:a}=r;if(a===void 0||!i)return e;if(!zu(i,n))return{value:``};let o=this.getComparisonValue(t,n,i,a),s=this.strictMeasureValueToNumber(e);return o===0||o===`sameValue`&&s===0?{value:j.DivisionByZero}:!o||o===`sameValue`&&!s?{value:``}:o===`sameValue`?{value:1,format:hH}:s===void 0?{value:j.NullError}:{value:s/o,format:hH}}asDifferenceFrom(e,t,n,r){let{fieldNameWithGranularity:i,value:a}=r;if(a===void 0||!i)return e;if(!zu(i,n))return{value:``};let o=this.getComparisonValue(t,n,i,a)||0;return o===`sameValue`?{value:``}:{value:this.measureValueToNumber(e)-o,format:e.format}}asDifferenceFromInPercent(e,t,n,r){let{fieldNameWithGranularity:i,value:a}=r;if(a===void 0||!i)return e;if(!zu(i,n))return{value:``};let o=this.getComparisonValue(t,n,i,a),s=this.strictMeasureValueToNumber(e);return o===0?{value:j.DivisionByZero}:!o||o===`sameValue`?{value:``}:s===void 0?{value:j.NullError}:{value:(s-o)/o,format:hH}}asRank(e,t,n,r,i){let{fieldNameWithGranularity:a}=r;if(!a)return e;if(!zu(a,n))return{value:``};let o=i===`asc`?this.rankAsc:this.rankDesc,s=o[t.id]?.[a];s||(s=this.computeRank(t,a,i),o[t.id]||(o[t.id]={}),o[t.id][a]=s);let{rowDomain:c,colDomain:l}=ju(this,n),u=Hu(l),d=Hu(c);return{value:s[u]?.[d]??``}}computeRank(e,t,n){let r={},i=Bu(this,t),a=i===`row`?`column`:`row`,o=this.getPivotValueCells(e.id);i===`column`&&(o=Qa(o));for(let s of o){let o=Hu(Mu(this,a,s[0].domain)),c=s.map(t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:Mu(this,i,t.domain)})).filter(e=>zu(t,e.rowDomain)),l=Object.groupBy(c,e=>Wu(e.rowDomain,t));for(let e in l)l[e]=Zt(l[e]||[],e=>e.value).filter(e=>e.value!==void 0).sort((e,t)=>n===`asc`?e.value-t.value:t.value-e.value);r[o]={};for(let e of c){let n=Hu(Mu(this,i,e.domain)),a=l[Wu(e.rowDomain,t)];if(!a)continue;let s=a.findIndex(t=>t.value===e.value);s!==-1&&(r[o][n]=s+1)}}return i===`row`?r:Qt(r)}computeRunningTotal(e,t,n){let r={},i=Bu(this,t),a=i===`row`?`column`:`row`,o=this.getPivotValueCells(e.id);i===`column`&&(o=Qa(o));for(let s of o){let o=Hu(Mu(this,a,s[0].domain));r[o]={};let c={},l=s.map(t=>({...t,rowDomain:Mu(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))})).filter(e=>zu(t,e.rowDomain));for(let e of l){let n=Hu(e.rowDomain),i=Gu(e.rowDomain,t),a=(c[i]||0)+e.value;c[i]=a,r[o][n]=a}if(n===`%_running_total`)for(let e of l){let n=e.rowDomain,i=Hu(n),a=Gu(n,t),s=r[o][i]||0,l=c[a];r[o][i]=l?s/l:void 0}}return i===`row`?r:Qt(r)}getGrandTotal(e){let t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){let n=ju(this,t).rowDomain,r=this._getPivotCellValueAndFormat(e,n);return this.measureValueToNumber(r)}getColumnTotal(e,t){let n=ju(this,t).colDomain,r=this._getPivotCellValueAndFormat(e,n);return this.measureValueToNumber(r)}isFieldInPivot(e){return this.definition.columns.some(t=>t.nameWithGranularity===e)||this.definition.rows.some(t=>t.nameWithGranularity===e)}getComparisonValue(e,t,n,r){let i=r===`(previous)`||r===`(next)`?Vu(this,t,n,r):Ru(t,n,r);if(w(i,t))return`sameValue`;if(!i||!Pu(this,i))throw new Sa;let a=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(a)}getPivotValueCells(e){return this.getTableStructure().getPivotCells().map(t=>t.filter(t=>t.type===`VALUE`&&t.measure===e)).filter(e=>e.length>0)}measureValueToNumber(e){if(typeof e.value==`number`)return e.value;if(!e.value)return 0;throw Error(`Value ${e.value} is not a number`)}strictMeasureValueToNumber(e){if(typeof e.value==`number`)return e.value;if(e.value)throw Error(`Value ${e.value} is not a number`)}getTableStructure(){let e=super.getTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;let t=this.definition.sortedColumn.measure;Od(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,(e,t)=>this._getPivotCellValueAndFormat(e,t))}}return t}let _H=[`ADD_PIVOT`,`UPDATE_PIVOT`,`REMOVE_PIVOT`];function vH(e){return _H.includes(e.type)}var yH=class extends RV{static getters=[`getPivot`,`getFirstPivotFunction`,`getPivotIdFromPosition`,`getPivotCellFromPosition`,`generateNewCalculatedMeasureName`,`isPivotUnused`,`isSpillPivotFormula`];pivots={};unusedPivots;custom;constructor(e){super(e),this.custom=e.custom}beforeHandle(e){switch(e.type){case`START`:for(let e of this.getters.getPivotIds())this.setupPivot(e)}}handle(e){if(ta.has(e.type))for(let e of this.getters.getPivotIds())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;let t=e.commands.filter(vH);for(let e of t){let t=e.pivotId;this.getters.isExistingPivot(t)&&this.setupPivot(t,{recreate:!0})}break}case`UPDATE_LOCALE`:vz();break}}getPivotIdFromPosition(e){let t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){let n=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(n){let e=n.args[0]?.toString();return e&&this.getters.getPivotId(e)}}}isSpillPivotFormula(e){let t=this.getters.getCorrespondingFormulaCell(e);return t&&t.isFormula?this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens)?.functionName===`PIVOT`:!1}getFirstPivotFunction(e,t){let n=SC(t);if(!n)return;let{functionName:r,args:i}=n;return{functionName:r,args:i.map(t=>{if(t.type===`EMPTY`)return;if(t.type===`STRING`||t.type===`BOOLEAN`||t.type===`NUMBER`)return t.value;let n=zv(t);return this.getters.evaluateFormula(e,n)})}}getPivotCellFromPosition(e){let t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||CC(t.compiledFormula.tokens)===0)return az;let n=this.getters.getCellPosition(t.id),r=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!r)return az;let{functionName:i,args:a}=r,o=a[0];if(!o)return az;let s=this.getters.getPivotId(o.toString());if(!s)return az;let c=this.getPivot(s);if(!c.isValid()||i===`PIVOT`&&!t.content.replaceAll(` `,``).toUpperCase().startsWith(`=PIVOT`))return az;try{if(i===`PIVOT`){let t=cu(a[2]),r=t===void 0?!0:L(t),i=cu(a[3]),o=i===void 0?!0:L(i),s=c.getTableStructure().getPivotCells(r,o),l=e.col-n.col,u=e.row-n.row;return s[l][u]}let t=e.row-n.row,r=e.col-n.col;if(a=a.map(e=>A(e)?e[r][t]:e),i===`PIVOT.HEADER`&&a.at(-2)===`measure`)return{type:`MEASURE_HEADER`,domain:c.parseArgsToPivotDomain(a.slice(1,-2).map(e=>({value:e}))),measure:a.at(-1)?.toString()||``};if(i===`PIVOT.HEADER`)return{type:`HEADER`,domain:c.parseArgsToPivotDomain(a.slice(1).map(e=>({value:e})))};let[o,...s]=a.slice(1);return{type:`VALUE`,domain:c.parseArgsToPivotDomain(s.map(e=>({value:e}))),measure:o?.toString()||``}}catch{return az}}generateNewCalculatedMeasureName(e){let t=e.map(e=>e.fieldName);return $t(O(`Calculated measure 1`),t,{compute:(e,t)=>O(`Calculated measure %s`,t)})}getPivot(e){if(!this.getters.isExistingPivot(e))throw 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}){let n=b(this.getters.getPivotCoreDefinition(e));if(e in this.pivots)t&&this.pivots[e].onDefinitionChange(n);else{let t=gH(bz.get(n.type).ui);this.pivots[e]=new t(e,this.custom,{definition:n,getters:this.getters})}}_getUnusedPivots(){if(this.unusedPivots!==void 0)return this.unusedPivots;let e=new Set(this.getters.getPivotIds());for(let t of this.getters.getSheetIds())for(let n in this.getters.getCells(t)){let t=this.getters.getCellPosition(n),r=this.getPivotIdFromPosition(t);if(r&&(e.delete(r),!e.size))return this.unusedPivots=[],[]}return this.unusedPivots=[...e],this.unusedPivots}},bH=class extends pV{static layers=[];getters;ui;selection;dispatch;canDispatch;constructor({getters:e,stateObserver:t,dispatch:n,canDispatch:r,uiActions:i,selection:a}){super(t),this.getters=e,this.ui=i,this.selection=a,this.dispatch=n,this.canDispatch=r}drawLayer(e,t){}},xH=class{cells;getters;index=0;direction;constructor(e,t,n){this.cells=e,this.getters=t,this.direction=n}next(){let e=this.cells[this.index++%this.cells.length],t=e.rule,{cellData:n,tooltip:r}=kC.get(t.type).apply(t,e.data,this.getters,this.direction);return{cellData:n,tooltip:r,origin:{col:e.data.col,row:e.data.row}}}},SH=class extends bH{static layers=[`Autofill`];static getters=[`getAutofillTooltip`];autofillZone;steps;lastCellSelected={};direction;tooltip;allowDispatch(e){switch(e.type){case`AUTOFILL_SELECT`:let t=this.getters.getActiveSheetId();return this.lastCellSelected.col=e.col===-1?this.lastCellSelected.col:x(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=e.row===-1?this.lastCellSelected.row:x(e.row,0,this.getters.getNumberRows(t)),this.lastCellSelected.col!==void 0&&this.lastCellSelected.row!==void 0?`Success`:`InvalidAutofillSelection`}return`Success`}handle(e){switch(e.type){case`AUTOFILL`:this.autofill(!0);break;case`AUTOFILL_SELECT`:this.select(e.col,e.row);break;case`AUTOFILL_AUTO`:this.autofillAuto();break}}getAutofillTooltip(){return this.tooltip}autofill(e){if(!this.autofillZone||!this.steps||this.direction===void 0){this.tooltip=void 0;return}let t=this.getters.getSelectedZone(),n=this.autofillZone,r=[];switch(this.direction){case`down`:for(let e=t.left;e<=t.right;e++){let i=[];for(let n=t.top;n<=t.bottom;n++)i.push(T(e,n));let a=this.createGenerator(i);for(let t=n.top;t<=n.bottom;t++)r.push(this.computeNewCell(a,e,t))}break;case`up`:for(let e=t.left;e<=t.right;e++){let i=[];for(let n=t.bottom;n>=t.top;n--)i.push(T(e,n));let a=this.createGenerator(i);for(let t=n.bottom;t>=n.top;t--)r.push(this.computeNewCell(a,e,t))}break;case`left`:for(let e=t.top;e<=t.bottom;e++){let i=[];for(let n=t.right;n>=t.left;n--)i.push(T(n,e));let a=this.createGenerator(i);for(let t=n.right;t>=n.left;t--)r.push(this.computeNewCell(a,t,e))}break;case`right`:for(let e=t.top;e<=t.bottom;e++){let i=[];for(let n=t.left;n<=t.right;n++)i.push(T(n,e));let a=this.createGenerator(i);for(let t=n.left;t<=n.right;t++)r.push(this.computeNewCell(a,t,e))}break}if(e){let e={},t={},n={},i=this.getters.getActiveSheetId();for(let a of r)this.collectBordersData(a,e),this.autofillMerge(i,a),this.autofillCell(i,a),this.collectConditionalFormatsData(i,a,t),this.collectDataValidationsData(i,a,n);this.autofillBorders(i,e),this.autofillConditionalFormats(i,t),this.autofillDataValidations(i,n),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){let n=JSON.stringify(e.border);n in t||(t[n]=[]),t[n].push(E({col:e.col,row:e.row}))}collectConditionalFormatsData(e,t,n){let{originCol:r,originRow:i,col:a,row:o}=t,s=this.getters.getRulesByCell(e,r,i),c=T(a,o);for(let e of s)e.id in n||(n[e.id]=[]),n[e.id].push(c)}collectDataValidationsData(e,t,n){let{originCol:r,originRow:i,col:a,row:o}=t,s={sheetId:e,col:r,row:i},c=this.getters.getValidationRuleForCell(s);c&&(c.id in n||(n[c.id]=[]),n[c.id].push(E({col:a,row:o})))}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(let n in t){let r=n===`undefined`?void 0:JSON.parse(n);this.dispatch(`SET_BORDERS_ON_TARGET`,{sheetId:e,border:r,target:Yn(t[n])})}}autofillConditionalFormats(e,t){for(let n in t){let r=t[n],i=this.getters.getConditionalFormats(e).find(e=>e.id===n);if(!i)continue;let a=this.getters.getAdaptedCfRanges(e,i,r.map(ar),[]);a&&this.dispatch(`ADD_CONDITIONAL_FORMAT`,{cf:{id:i.id,rule:i.rule,stopIfTrue:i.stopIfTrue},ranges:a,sheetId:e})}}autofillDataValidations(e,t){for(let n in t){let r=t[n],i=this.getters.getDataValidationRule(e,n);if(!i)continue;let a=Yn(i.ranges.map(e=>e.zone).concat(r),[]);this.dispatch(`ADD_DATA_VALIDATION_RULE`,{rule:i,ranges:a.map(t=>this.getters.getRangeDataFromZone(e,t)),sheetId:e})}}select(e,t){let n=this.getters.getSelectedZone();if(vr(e,t,n)){this.autofillZone=void 0;return}switch(this.direction=this.getDirection(e,t),this.direction){case`up`:this.saveZone(t,n.top-1,n.left,n.right),this.steps=n.top-t;break;case`down`:this.saveZone(n.bottom+1,t,n.left,n.right),this.steps=t-n.bottom;break;case`left`:this.saveZone(n.top,n.bottom,e,n.left-1),this.steps=n.left-e;break;case`right`:this.saveZone(n.top,n.bottom,n.right+1,e),this.steps=e-n.right;break}this.autofill(!1)}autofillAuto(){let e=this.getters.getActivePosition(),t=this.getters.getTable(e),n=t?t.range.zone.bottom:this.getAutofillAutoLastRow(),r=this.getters.getSelectedZone();for(let t=r.bottom+1;t<=n;t++)if(this.getters.getEvaluatedCell({...e,row:t}).type!==`empty`){n=t-1;break}n>r.bottom&&(this.select(e.col,n),this.autofill(!0))}getAutofillAutoLastRow(){let e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId(),n=e.left,r=e.bottom;if(n>0){let e={sheetId:t,col:n-1,row:r};for(;this.getters.getEvaluatedCell(e).type!==`empty`;)r+=1,e={sheetId:t,col:n-1,row:r}}if(r===e.bottom&&(n=e.right,n<=this.getters.getNumberCols(t))){let e={sheetId:t,col:n+1,row:r};for(;this.getters.getEvaluatedCell(e).type!==`empty`;)r+=1,e={sheetId:t,col:n+1,row:r}}return r-1}computeNewCell(e,t,n){let{cellData:r,tooltip:i,origin:a}=e.next(),{content:o,style:s,border:c,format:l}=r;return this.tooltip=i,{originCol:a.col,originRow:a.row,col:t,row:n,content:o,style:s,border:c,format:l}}getRule(e,t){let n=AC.getAll().sort((e,t)=>e.sequence-t.sequence).find(n=>n.condition(e,t));return n&&this.direction&&n.generateRule(e,t,this.direction)}createGenerator(e){let t=[],n=[],r=this.getters.getActiveSheetId();for(let t of e){let{col:e,row:i}=Jn(t),a=this.getters.getCell({sheetId:r,col:e,row:i});n.push({col:e,row:i,cell:a,sheetId:r})}let i=n.map(e=>e.cell);for(let e of n){let n={type:`COPY_MODIFIER`};e&&e.cell&&(n=this.getRule(e.cell,i)||n);let r=this.getters.getCellBorder(e)||void 0;t.push({data:{...e,border:r},rule:n})}return new xH(t,this.getters,this.direction)}saveZone(e,t,n,r){this.autofillZone={top:e,bottom:t,left:n,right:r}}getDirection(e,t){let n=this.getters.getSelectedZone(),r={up:{number:n.top-t,value:`up`},down:{number:t-n.bottom,value:`down`},left:{number:n.left-e,value:`left`},right:{number:e-n.right,value:`right`}};if(Object.values(r).map(e=>+(e.number>0)).reduce((e,t)=>e+t)===1)return Object.values(r).find(e=>+(e.number>0)).value;let i=r.up.number>0?`up`:`down`,a=r.left.number>0?`left`:`right`;return Math.abs(r[i].number)>=Math.abs(r[a].number)?r[i].value:r[a].value}autofillMerge(e,t){let{originCol:n,originRow:r,col:i,row:a}=t,o={sheetId:e,col:i,row:a},s={sheetId:e,col:n,row:r};if(this.getters.isInMerge(o)&&!this.getters.isInMerge(s)){let t=this.getters.getMerge(o);t&&this.dispatch(`REMOVE_MERGE`,{sheetId:e,target:[t]})}let c=this.getters.getMerge(s);c?.left===n&&c?.top===r&&this.dispatch(`ADD_MERGE`,{sheetId:e,target:[{top:a,bottom:a+c.bottom-c.top,left:i,right:i+c.right-c.left}]})}drawLayer(e){if(!this.autofillZone)return;let{ctx:t,thinLineWidth:n}=e,{x:r,y:i,width:a,height:o}=this.getters.getVisibleRect(this.autofillZone);a>0&&o>0&&(t.strokeStyle=`black`,t.lineWidth=n,t.setLineDash([3]),t.strokeRect(r,i,a,o),t.setLineDash([]))}},CH=class extends bH{static getters=[`getAutomaticSums`];handle(e){switch(e.type){case`SUM_SELECTION`:let e=this.getters.getActiveSheetId(),{zones:t,anchor:n}=this.getters.getSelection();for(let r of t){let t=this.getAutomaticSums(e,r,n.cell);this.dispatchCellUpdates(e,t)}break}}getAutomaticSums(e,t,n){return this.shouldFindData(e,t)?this.sumAdjacentData(e,t,n):this.sumData(e,t)}sumData(e,t){let n=this.dimensionsToSum(e,t),r=this.sumDimensions(e,t,n).filter(({zone:t})=>!this.getters.isEmpty(e,t));return n.has(`ROW`)&&n.has(`COL`)&&r.push(this.sumTotal(t)),r}sumAdjacentData(e,t,n){let{col:r,row:i}=vr(n.col,n.row,t)?n:{col:t.left,row:t.top},a=this.findAdjacentData(e,r,i);return a?this.getters.isSingleCellOrMerge(e,t)||xr(pr(a,t))?[{position:{col:r,row:i},zone:a}]:this.sumDimensions(e,pr(a,t),this.transpose(this.dimensionsToSum(e,t))):[]}findAdjacentData(e,t,n){let r=this.getters.getSheet(e),i=this.getters.getMainCellPosition({sheetId:e,col:t,row:n}),a=this.findSuitableZoneToSum(r,i.col,i.row);if(a)return this.getters.expandZone(e,a)}findSuitableZoneToSum(e,t,n){let r=this.getters.getEvaluatedCell({sheetId:e.id,col:t,row:n-1}),i=this.getters.getEvaluatedCell({sheetId:e.id,col:t-1,row:n});if(this.isNumber(i)&&!this.isNumber(r))return this.findHorizontalZone(e,t,n);let a=this.findVerticalZone(e,t,n);if(this.isZoneValid(a))return a;let o=this.findHorizontalZone(e,t,n);if(this.isZoneValid(o))return o}findVerticalZone(e,t,n){let r={top:0,bottom:n-1,left:t,right:t},i=this.reduceZoneStart(e,r,r.bottom);return{...r,top:i}}findHorizontalZone(e,t,n){let r={top:n,bottom:n,left:0,right:t-1},i=this.reduceZoneStart(e,r,r.right);return{...r,left:i}}reduceZoneStart(e,t,n){let r=this.getters.getEvaluatedCellsInZone(e.id,t),i=S(n,-1,-1),a=Jt(i.filter(e=>r[e]&&!r[e].isAutoSummable)),o=dt(i.filter(e=>this.isNumber(r[e])))[0]||[];return Jt(o)<a?1/0:Yt(o)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===`number`&&!(e.format&&ls(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){let n=new Set;return xr(t)?(n.add(br(t).numberOfCols===1?`COL`:`ROW`),n):(this.lastColIsEmpty(e,t)&&n.add(`ROW`),this.lastRowIsEmpty(e,t)&&n.add(`COL`),n.size===0&&n.add(`COL`),n)}sumDimensions(e,t,n){return[...n.has(`COL`)?this.sumColumns(t,e):[],...n.has(`ROW`)?this.sumRows(t,e):[]]}sumTotal(e){let{bottom:t,right:n}=e;return{position:{col:n,row:t},zone:{...e,top:t,right:n-1}}}sumColumns(e,t){let n=this.nextEmptyRow(t,{...e,bottom:e.bottom-1});return e={...e,bottom:Math.min(e.bottom,n.bottom-1)},wr(n).map(t=>({position:t,zone:{...e,right:t.col,left:t.col}}))}sumRows(e,t){let n=this.nextEmptyCol(t,{...e,right:e.right-1});return e={...e,right:Math.min(e.right,n.right-1)},wr(n).map(t=>({position:t,zone:{...e,top:t.row,bottom:t.row}}))}dispatchCellUpdates(e,t){for(let n of t){let{col:t,row:r}=n.position;this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,content:`=SUM(${this.getters.zoneToXC(e,n.zone)})`})}}nextEmptyRow(e,t){let n=t.bottom+1,{left:r,right:i}=t;for(;!this.getters.isEmpty(e,{bottom:n,top:n,left:r,right:i});)n++;return{...t,top:n,bottom:n}}nextEmptyCol(e,t){let n=t.right+1,{top:r,bottom:i}=t;for(;!this.getters.isEmpty(e,{left:n,right:n,top:r,bottom:i});)n++;return{...t,left:n,right:n}}transpose(e){return new Set([...e.values()].map(e=>e===`COL`?`ROW`:`COL`))}};let wH=new class extends h{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};FI.addTransformation(`ADD_COLUMNS_ROWS`,[`ADD_COLUMNS_ROWS`],FH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`ADD_COLUMNS_ROWS`],FH),FI.addTransformation(`DELETE_SHEET`,[`MOVE_RANGES`],OH),FI.addTransformation(`DELETE_FIGURE`,[`UPDATE_FIGURE`,`UPDATE_CHART`],kH),FI.addTransformation(`CREATE_SHEET`,[`CREATE_SHEET`],AH),FI.addTransformation(`ADD_MERGE`,[`ADD_MERGE`,`REMOVE_MERGE`],jH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`FREEZE_COLUMNS`,`FREEZE_ROWS`],MH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`FREEZE_COLUMNS`,`FREEZE_ROWS`],MH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`UPDATE_TABLE`],NH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`UPDATE_TABLE`],NH),FI.addTransformation(`REMOVE_TABLE_STYLE`,[`CREATE_TABLE`,`UPDATE_TABLE`],PH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`GROUP_HEADERS`,`UNGROUP_HEADERS`,`FOLD_HEADER_GROUP`,`UNFOLD_HEADER_GROUP`],IH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`GROUP_HEADERS`,`UNGROUP_HEADERS`,`FOLD_HEADER_GROUP`,`UNFOLD_HEADER_GROUP`],IH),FI.addTransformation(`REMOVE_PIVOT`,[`RENAME_PIVOT`,`DUPLICATE_PIVOT`,`INSERT_PIVOT`,`UPDATE_PIVOT`],DH),FI.addTransformation(`DELETE_SHEET`,[`ADD_PIVOT`,`UPDATE_PIVOT`],EH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`ADD_PIVOT`,`UPDATE_PIVOT`],TH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`ADD_PIVOT`,`UPDATE_PIVOT`],TH);function TH(e,t){if(e.pivot.type!==`SPREADSHEET`||e.pivot.dataSet?.sheetId!==t.sheetId)return e;let n=Bd(e.pivot.dataSet.zone,t),r=n?{...e.pivot.dataSet,zone:n}:void 0;return{...e,pivot:{...e.pivot,dataSet:r}}}function EH(e,t){return e.pivot.type===`SPREADSHEET`&&e.pivot.dataSet?.sheetId===t.sheetId?{...e,pivot:{...e.pivot,dataSet:void 0}}:e}function DH(e,t){if(e.pivotId!==t.pivotId)return e}function OH(e,t){let n=t.sheetId;if(!(e.targetSheetId===n||e.sheetId===n))return e}function kH(e,t){if(e.figureId!==t.figureId)return e}function AH(e,t){return e.sheetId===t.sheetId&&(e={...e,sheetId:`${e.sheetId}~`}),e.name===t.name?{...e,name:e.name?.match(/\d+/)?e.name.replace(/\d+/,e=>(parseInt(e)+1).toString()):`${e.name}~`,position:e.position+1}:e}function jH(e,t){if(e.sheetId!==t.sheetId)return e;let n=[];for(let r of e.target)t.target.every(e=>!_r(r,e))&&n.push(r);if(n.length)return{...e,target:n}}function MH(e,t){if(e.sheetId!==t.sheetId||(e.type===`FREEZE_COLUMNS`?`COL`:`ROW`)!==t.dimension)return e;let n=e.quantity;if(t.type===`REMOVE_COLUMNS_ROWS`){let e=[...t.elements].sort((e,t)=>t-e);for(let t of e)n>t&&n--}if(t.type===`ADD_COLUMNS_ROWS`){let e=t.position===`before`?t.base-1:t.base;n=n>e?n+t.quantity:n}return n>0?{...e,quantity:n}:void 0}function NH(e,t){if(e.sheetId!==t.sheetId)return e;let n=Bd(e.zone,t);if(!n)return;let r=e.newTableRange?Vd(e.newTableRange,t):void 0;return{...e,newTableRange:r,zone:n}}function PH(e,t){return e.config?.styleId===t.tableStyleId?{...e,config:{...e.config,styleId:OA.styleId}}:e}function FH(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let n;if(t.type===`REMOVE_COLUMNS_ROWS`?n=Mc(t.elements,[e.base])[0]:t.type===`ADD_COLUMNS_ROWS`&&(n=jc(jt(t.position,t.base),t.quantity,[e.base])[0]),n!==void 0)return{...e,base:n}}function IH(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let n=S(e.start,e.end+1),r=[];if(t.type===`REMOVE_COLUMNS_ROWS`?r=Mc(t.elements,n):t.type===`ADD_COLUMNS_ROWS`&&(r=jc(jt(t.position,t.base),t.quantity,n)),r.length!==0)return{...e,start:Math.min(...r),end:Math.max(...r)}}function LH(e,t){let n=e.content&&jx(e.sheetId,e.content,t);return{...e,content:n}}wH.add(`UPDATE_CELL`,LH);function RH(e,t){let n=e.cf.rule;if(e={...e,cf:{...e.cf}},n.type===`CellIsRule`)e.cf.rule={...n,values:n.values.map(n=>jx(e.sheetId,n,t))};else if(n.type===`ColorScaleRule`){let{minimum:r,maximum:i,midpoint:a}=n;e.cf.rule={...n,minimum:{...r,value:r.value&&jx(e.sheetId,r.value,t)},maximum:{...i,value:i.value&&jx(e.sheetId,i.value,t)},midpoint:a?{...a,value:jx(e.sheetId,a.value,t)}:void 0}}else if(n.type===`IconSetRule`){let{upperInflectionPoint:r,lowerInflectionPoint:i}=n;e.cf.rule={...n,upperInflectionPoint:{...r,value:jx(e.sheetId,r.value,t)},lowerInflectionPoint:{...i,value:jx(e.sheetId,i.value,t)}}}else n.type===`DataBarRule`&&(e.cf.rule={...n,rangeValues:n.rangeValues?Mx(e.sheetId,n.rangeValues,t).range:void 0});return e}wH.add(`ADD_CONDITIONAL_FORMAT`,RH);function zH(e,t){return e={...e,rule:{...e.rule,criterion:{...e.rule.criterion}}},e.rule.criterion.values=e.rule.criterion.values.map(n=>jx(e.sheetId,n,t)),e}wH.add(`ADD_DATA_VALIDATION_RULE`,zH);function BH(e,t){return e=b(e),e.pivot.measures.map(e=>{e.computedBy&&(e.computedBy.formula=jx(e.computedBy.sheetId,e.computedBy.formula,t))}),e}wH.add(`ADD_PIVOT`,BH),wH.add(`UPDATE_PIVOT`,BH),wH.add(`CREATE_CHART`,VH),wH.add(`UPDATE_CHART`,VH);function VH(e,t){return{...e,definition:dD(e.sheetId,e.definition,t)}}let HH=[{match:Yi,fn:qH},{match:Zi,fn:JH},{match:ea,fn:YH},{match:$i,fn:QH},{match:Xi,fn:ZH},{match:Qi,fn:XH}];function UH(e,t){let n=FI.getTransformation(e.type,t.type),r=n?n(e,t):KH(e,t);return r&&WH(r,t)}function WH(e,t){let n=wH.get(e.type);if(!n)return e;let r=yc(t);return r?n(e,r):e}function GH(e,t){let n=[...e],r=new Set(FI.getKeys());for(let e of t)(r.has(e.type)||bc.contains(e.type))&&(n=n.reduce((t,n)=>{let r=UH(n,e);return r&&t.push(r),t},[]));return n}function KH(e,t){for(let{match:n,fn:r}of HH)if(n(e)){let n=r(e,t);if(n===`SKIP_TRANSFORMATION`)continue;if(n===`IGNORE_COMMAND`)return;e=n}return e}function qH(e,t){if(!(`sheetId`in t))return e;let n=t.type===`DELETE_SHEET`&&t.sheetId;return e.sheetId===n?`IGNORE_COMMAND`:e.type===`CREATE_SHEET`||t.type===`CREATE_SHEET`||e.sheetId!==t.sheetId?e:`SKIP_TRANSFORMATION`}function JH(e,t){let n=qH(e,t);if(n!==`SKIP_TRANSFORMATION`)return n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e;let r=[];for(let n of e.target){let e=Bd(n,t);e&&r.push(e)}return r.length?{...e,target:r}:`IGNORE_COMMAND`}function YH(e,t){let n=qH(e,t);if(n!==`SKIP_TRANSFORMATION`)return n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e;let r=Bd(e.zone,t);return r?{...e,zone:r}:`IGNORE_COMMAND`}function XH(e,t){if(!(`sheetId`in t))return e;let n=e.ranges.map(e=>Vd(e,t)).filter(C);return n.length?{...e,ranges:n}:`IGNORE_COMMAND`}function ZH(e,t){let n=qH(e,t);if(n!==`SKIP_TRANSFORMATION`)return n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e;if(t.type!==`ADD_COLUMNS_ROWS`&&t.type!==`REMOVE_COLUMNS_ROWS`)return`SKIP_TRANSFORMATION`;if(t.dimension!==e.dimension)return e;let r=[];return t.type===`REMOVE_COLUMNS_ROWS`?r=Mc(t.elements,e.elements):t.type===`ADD_COLUMNS_ROWS`&&(r=jc(jt(t.position,t.base),t.quantity,e.elements)),r.length===0?`IGNORE_COMMAND`:{...e,elements:r}}function QH(e,t){let n=qH(e,t);return n===`SKIP_TRANSFORMATION`?t.type===`ADD_COLUMNS_ROWS`||t.type===`REMOVE_COLUMNS_ROWS`?$H(e,t):t.type===`ADD_MERGE`?eU(e,t):`SKIP_TRANSFORMATION`:n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e}function $H(e,t){let n=t.dimension===`COL`?`col`:`row`,r=e[n];if(t.type===`REMOVE_COLUMNS_ROWS`){let e=[...t.elements].sort((e,t)=>t-e);if(e.includes(r))return`IGNORE_COMMAND`;for(let t of e)r>=t&&r--}return t.type===`ADD_COLUMNS_ROWS`&&(r>t.base||r===t.base&&t.position===`before`)&&(r+=t.quantity),{...e,[n]:r}}function eU(e,t){for(let n of t.target)if(!(e.col===n.left&&e.row===n.top)&&vr(e.col,e.row,n))return`IGNORE_COMMAND`;return e}var tU=class{id;clientId;_commands=[];_changes=[];constructor(e,t,n,r,i,a){this.rootCommand=r,this.timestamp=a,this.id=e,this.clientId=t,this._commands=[...n],this._changes=i?[...i]:[]}setChanges(e){this._changes=e}get commands(){return this._commands}get changes(){return this._changes}},nU=class extends Error{},rU=class extends Hd{clients={};clientId=`local`;debouncedMove;pendingMessages=[];waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new al;lastLocalOperation;constructor(e,t,n=Ue){super(),this.revisions=e,this.transportService=t,this.serverRevisionId=n,this.debouncedMove=Et(this._move.bind(this),200)}canApplyOptimisticUpdate(){return!this.waitingUndoRedoAck}save(e,t,n){if(!t.length||!n.length||!this.canApplyOptimisticUpdate())return;let r=new tU(this.uuidGenerator.uuidv4(),this.clientId,t,e,n,Date.now());this.revisions.append(r.id,r),e.type!==`REQUEST_REDO`&&(this.lastLocalOperation=r),this.trigger(`new-local-state-update`,{id:r.id}),this.sendUpdateMessage({type:`REMOTE_REVISION`,version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:r.id,clientId:r.clientId,commands:r.commands})}undo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:`REVISION_UNDONE`,version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),undoneRevisionId:e})}redo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:`REVISION_REDONE`,version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),redoneRevisionId:e})}move(e){this.debouncedMove(e)}join(e){e?(this.clients[e.id]=e,this.clientId=e.id):(this.clients.local={id:`local`,name:`local`},this.clientId=`local`),this.transportService.onNewMessage(this.clientId,this.onMessageReceived.bind(this))}loadInitialMessages(e){let t=performance.now(),n=e.reduce((e,t)=>e+(t.type===`REMOTE_REVISION`?t.commands.length:1),0);this.isReplayingInitialRevisions=!0;for(let t of e)this.onMessageReceived(t);this.isReplayingInitialRevisions=!1,console.debug(`Replayed`,n,`commands in`,performance.now()-t,`ms`)}async leave(e){e&&Object.keys(this.clients).length===1&&this.lastRevisionMessage&&this.lastRevisionMessage?.type!==`SNAPSHOT_CREATED`&&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(this.pendingMessages.length!==0)return;let t=this.uuidGenerator.uuidv4();await this.transportService.sendMessage({type:`SNAPSHOT`,nextRevisionId:t,serverRevisionId:this.serverRevisionId,data:{...e,revisionId:t},version:1})}getClient(){let e=this.clients[this.clientId];if(!e)throw new nU(`The client left the session`);return e}getConnectedClients(){return new Set(Object.values(this.clients).filter(C))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return this.pendingMessages.length===0}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return;let t=this.clients[this.clientId]?.position;if(t?.col===e.col&&t.row===e.row&&t.sheetId===e.sheetId)return;let n=t?`CLIENT_MOVED`:`CLIENT_JOINED`,r=this.getClient();this.clients[this.clientId]={...r,position:e},this.transportService.sendMessage({type:n,version:1,client:{...r,position:e}})}onMessageReceived(e){if(!this.isAlreadyProcessed(e)){if(this.isWrongServerRevisionId(e)){this.trigger(`unexpected-revision-id`);return}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`:let{clientId:t,commands:n,timestamp:r}=e,i=new tU(e.nextRevisionId,t,n,void 0,void 0,r);if(i.clientId!==this.clientId){this.revisions.insert(i.id,i,e.serverRevisionId);let t=this.pendingMessages.filter(e=>e.type===`REMOTE_REVISION`).map(e=>e.commands).flat();this.trigger(`remote-revision-received`,{commands:GH(n,t)})}break;case`SNAPSHOT_CREATED`:{let t=new tU(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;let t=this.clients[this.clientId];if(t){let{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(e.type===`REMOTE_REVISION`){let t=this.revisions.get(e.nextRevisionId);t.commands.length===0&&(this.revisions.rebase(t.id),t=this.revisions.get(e.nextRevisionId)),e={...e,clientId:t.clientId,commands:t.commands}}if(this.isReplayingInitialRevisions)throw Error(`Trying to send a new revision while replaying initial revision. This can lead to endless dispatches every time the spreadsheet is open.
|
|
1977
|
+
`;var fV=class extends t.Component{static template=`o_spreadsheet.PivotHTMLRenderer`;static components={Checkbox:Yj};static props={pivotId:String,onCellClicked:Function};pivot=this.env.model.getters.getPivot(this.props.pivotId);data={columns:[],rows:[],values:[]};state=(0,t.useState)({showMissingValuesOnly:!1});setup(){let e=this.pivot.getTableStructure(),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;let e=this.getColumnsIndexes(),t=this.getRowsIndexes();return{columns:this.buildColumnsMissing(e),rows:this.buildRowsMissing(t),values:this.buildValuesMissing(e,t)}}addRecursiveRow(e){let t=this.pivot.getTableStructure().rows,n=[...t[e].values];if(n.length<=1)return[e];n.pop();let r=t.findIndex(e=>JSON.stringify(e.values)===JSON.stringify(n));return[e].concat(this.addRecursiveRow(r))}buildColumnsMissing(e){let t=[];for(let e of this.data.columns){let n=[];for(let t in e)for(let r=0;r<e[t].span;r++)n.push(parseInt(t,10));t.push(n)}for(let n=t[t.length-1].length;n>=0;n--)if(!e.includes(n))for(let e of t)e.splice(n,1);let n=[];for(let e in t){let r=[],i,a=1;for(let n=0;n<t[e].length;n++)i===t[e][n]?a++:(i!==void 0&&r.push(Object.assign({},this.data.columns[e][i],{span:a})),i=t[e][n],a=1);i!==void 0&&r.push(Object.assign({},this.data.columns[e][i],{span:a})),n.push(r)}return n}buildRowsMissing(e){return e.map(e=>this.data.rows[e])}buildValuesMissing(e,t){let n=e.map(()=>[]);for(let r of t)for(let t in e)n[t].push(this.data.values[e[t]][r]);return n}getColumnsIndexes(){let e=new Set;for(let t=0;t<this.data.columns.length;t++){let n=[];for(let e=0;e<this.data.columns[t].length;e++)for(let r=0;r<this.data.columns[t][e].span;r++)n.push(this.data.columns[t][e]);for(let t=0;t<n.length;t++)n[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(){let e=new Set;for(let t=0;t<this.data.rows.length;t++){this.data.rows[t].isMissing&&e.add(t);for(let n of this.data.values)n[t].isMissing&&this.addRecursiveRow(t).forEach(t=>e.add(t))}return Array.from(e).sort((e,t)=>e-t)}_buildColHeaders(e,t){let n=[];for(let r of t.columns){let t=[];for(let n of r){let r=[];for(let e=0;e<n.fields.length;e++)r.push({value:n.fields[e]},{value:n.values[e]});let i=this.pivot.parseArgsToPivotDomain(r),a=this.env.model.getters.getLocale();if(i.at(-1)?.field===`measure`){let{value:r,format:o}=this.pivot.getPivotMeasureValue(I(i.at(-1).value),i);t.push({formula:`=PIVOT.HEADER(${_d(e,i).join(`,`)})`,value:B(r,{format:o,locale:a}),span:n.width,isMissing:!this.tracker?.isHeaderPresent(i)})}else{let{value:r,format:o}=this.pivot.getPivotHeaderValueAndFormat(i);t.push({formula:`=PIVOT.HEADER(${_d(e,i).join(`,`)})`,value:B(r,{format:o,locale:a}),span:n.width,isMissing:!this.tracker?.isHeaderPresent(i)})}}n.push(t)}let r=n[n.length-1];return n[n.length-1]=r.map(e=>(e.isMissing||(e.style=`color: #756f6f;`),e)),n}_buildRowHeaders(e,t){let n=[];for(let r of t.rows){let t=[];for(let e=0;e<r.fields.length;e++)t.push({value:r.fields[e]},{value:r.values[e]});let i=this.pivot.parseArgsToPivotDomain(t),{value:a,format:o}=this.pivot.getPivotHeaderValueAndFormat(i),s=this.env.model.getters.getLocale(),c={formula:`=PIVOT.HEADER(${_d(e,i).join(`,`)})`,value:B(a,{format:o,locale:s}),isMissing:!this.tracker?.isHeaderPresent(i)};r.indent>1&&(c.style=`padding-left: ${r.indent-10}px`),n.push(c)}return n}_buildValues(e,t){let n=[];for(let r of t.columns.at(-1)||[]){let i=[],a=I(r.values[r.values.length-1]);for(let n of t.rows){let t=[];for(let e=0;e<n.fields.length;e++)t.push({value:n.fields[e]},{value:n.values[e]});for(let e=0;e<r.fields.length-1;e++)t.push({value:r.fields[e]},{value:r.values[e]});let o=this.pivot.parseArgsToPivotDomain(t),{value:s,format:c}=this.pivot.getPivotCellValueAndFormat(a,o),l=this.env.model.getters.getLocale();i.push({formula:`=PIVOT.VALUE(${_d(e,o,a).join(`,`)})`,value:B(s,{format:c,locale:l}),isMissing:!this.tracker?.isValuePresent(a,o)})}n.push(i)}return n}},pV=class{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(let n of e){let e=n.call(this,t);Array.isArray(e)||(e=[e]);let r=e.filter(e=>e!==`Success`);if(r.length)return r}return`Success`}}checkValidations(e,...t){return this.batchValidations(...t)(e)}},mV=class extends pV{getters;dispatch;canDispatch;constructor({getters:e,stateObserver:t,range:n,dispatch:r,canDispatch:i}){super(t),n.addRangeProvider(this.adaptRanges.bind(this)),this.getters=e,this.dispatch=r,this.canDispatch=i}import(e){}export(e){}adaptRanges(e,t,n){}garbageCollectExternalResources(){}},hV=class extends mV{static getters=[`getCellBorder`,`getBordersColors`];borders={};allowDispatch(e){switch(e.type){case`SET_BORDER`:return this.checkBordersUnchanged(e);default:return`Success`}}handle(e){switch(e.type){case`ADD_MERGE`:for(let t of e.target)this.addBordersToMerge(e.sheetId,t);break;case`DUPLICATE_SHEET`:let t=this.borders[e.sheetId];if(t){let n=t.slice().map(e=>e?.slice().map(e=>b(e)));this.history.update(`borders`,e.sheetIdTo,n)}break;case`DELETE_SHEET`:let n={...this.borders};delete n[e.sheetId],this.history.update(`borders`,n);break;case`SET_BORDER`:this.setBorder(e.sheetId,e.col,e.row,e.border);break;case`SET_BORDERS_ON_TARGET`:for(let t of e.target)for(let n=t.top;n<=t.bottom;n++)for(let r=t.left;r<=t.right;r++)this.setBorder(e.sheetId,r,n,e.border);break;case`SET_ZONE_BORDERS`:if(e.border){let 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||He.style,color:e.border.color||He.color})}break;case`CLEAR_FORMATTING`:this.clearBorders(e.sheetId,e.target);break;case`REMOVE_COLUMNS_ROWS`:let r=[...e.elements].sort((e,t)=>t-e);for(let t of dt(r))if(e.dimension===`COL`){let n=this.getters.getColsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[n]),this.shiftBordersHorizontally(e.sheetId,t[0]+1,-t.length)}else{let n=this.getters.getRowsZone(e.sheetId,t[t.length-1],t[0]);this.clearInsideBorders(e.sheetId,[n]),this.shiftBordersVertically(e.sheetId,t[0]+1,-t.length)}break;case`ADD_COLUMNS_ROWS`:e.dimension===`COL`?this.handleAddColumns(e):this.handleAddRows(e);break}}handleAddColumns(e){let t,n;e.position===`before`?(this.shiftBordersHorizontally(e.sheetId,e.base,e.quantity),t=e.base-1,n=e.base+e.quantity):(this.shiftBordersHorizontally(e.sheetId,e.base+1,e.quantity),t=e.base,n=e.base+e.quantity+1),this.ensureColumnBorderContinuity(e.sheetId,t,n)}handleAddRows(e){let t,n;e.position===`before`?(this.shiftBordersVertically(e.sheetId,e.base,e.quantity),t=e.base-1,n=e.base+e.quantity):(this.shiftBordersVertically(e.sheetId,e.base+1,e.quantity),t=e.base,n=e.base+e.quantity+1),this.ensureRowBorderContinuity(e.sheetId,t,n)}getCellBorder({sheetId:e,col:t,row:n}){let r=this.borders[e]?.[t]?.[n];return r?.top||r?.bottom||r?.left||r?.right?b(r):null}getBordersColors(e){let t=[],n=this.borders[e];if(n){for(let e of n.filter(C))for(let n of e)if(n)for(let e of[`top`,`bottom`,`left`,`right`]){let r=n[e]?.color;r&&t.push(r)}}return t}ensureColumnBorderContinuity(e,t,n){let r=S(t+1,n);for(let i=0;i<this.getters.getNumberRows(e);i++){let a=this.getCellBorder({sheetId:e,col:t,row:i}),o=this.getCellBorder({sheetId:e,col:n,row:i});if(a&&o){let t=this.getCommonSides(a,o);for(let n of r)this.addBorder(e,n,i,t)}}}ensureRowBorderContinuity(e,t,n){let r=S(t+1,n);for(let i=0;i<this.getters.getNumberCols(e);i++){let a=this.getCellBorder({sheetId:e,col:i,row:t}),o=this.getCellBorder({sheetId:e,col:i,row:n});if(a&&o){let t=this.getCommonSides(a,o);for(let n of r)this.addBorder(e,i,n,t)}}}getCommonSides(e,t){let n={};for(let r of[`top`,`bottom`,`left`,`right`])e[r]&&w(e[r],t[r])&&(n[r]=e[r]);return n}getColumnsWithBorders(e){let t=this.borders[e];return t?Object.keys(t).map(e=>parseInt(e,10)):[]}getRowsWithBorders(e){let t=this.borders[e]?.filter(C);if(!t)return[];let n=new Set;for(let e of t)for(let t in e)n.add(parseInt(t,10));return Array.from(n)}getRowsRange(e){return this.borders[e]?S(0,this.getters.getNumberRows(e)+1):[]}shiftBordersHorizontally(e,t,n){this.borders[e]&&this.getColumnsWithBorders(e).filter(e=>e>=t).sort((e,t)=>n<0?e-t:t-e).forEach(t=>{this.moveBordersOfColumn(e,t,n)})}shiftBordersVertically(e,t,n){this.borders[e]&&(n<0&&this.moveBordersOfRow(e,t,n,{destructive:!1}),this.getRowsWithBorders(e).filter(e=>e>=t).sort((e,t)=>n<0?e-t:t-e).forEach(t=>{this.moveBordersOfRow(e,t,n)}))}moveBordersOfRow(e,t,n,{destructive:r}={destructive:!0}){let i=this.borders[e];i&&this.getColumnsWithBorders(e).forEach(a=>{let o=i[a]?.[t+n],s=i[a]?.[t];this.history.update(`borders`,e,a,t+n,r?s:s||o),this.history.update(`borders`,e,a,t,void 0)})}moveBordersOfColumn(e,t,n,{destructive:r}={destructive:!0}){let i=this.borders[e];i&&this.getRowsRange(e).forEach(a=>{let o=i[t+n]?.[a],s=i[t]?.[a];this.history.update(`borders`,e,t+n,a,r?s:s||o),r&&this.history.update(`borders`,e,t,a,void 0)})}setBorder(e,t,n,r,i=!0){let a=this.getters.getNumberCols(e)-1,o=this.getters.getNumberRows(e)-1;(i||!this.borders[e]?.[t]?.[n]?.left)&&(this.history.update(`borders`,e,t,n,`left`,r?.left),r?.left&&t>0&&!w(this.borders[e]?.[t-1]?.[n]?.right,r?.left)&&this.history.update(`borders`,e,t-1,n,`right`,void 0)),(i||!this.borders[e]?.[t]?.[n]?.top)&&(this.history.update(`borders`,e,t,n,`top`,r?.top),r?.top&&n>0&&!w(this.borders[e]?.[t]?.[n-1]?.bottom,r?.top)&&this.history.update(`borders`,e,t,n-1,`bottom`,void 0)),(i||!this.borders[e]?.[t]?.[n]?.right)&&(this.history.update(`borders`,e,t,n,`right`,r?.right),r?.right&&t<a&&!w(this.borders[e]?.[t+1]?.[n]?.left,r?.right)&&this.history.update(`borders`,e,t+1,n,`left`,void 0)),(i||!this.borders[e]?.[t]?.[n]?.bottom)&&(this.history.update(`borders`,e,t,n,`bottom`,r?.bottom),r?.bottom&&n<o&&!w(this.borders[e]?.[t]?.[n+1]?.top,r?.bottom)&&this.history.update(`borders`,e,t,n+1,`top`,void 0))}clearBorders(e,t,n=!1){let r=this.getters.getNumberCols(e)-1,i=this.getters.getNumberRows(e)-1;for(let a of Yn(t))for(let t=a.top;t<=a.bottom;t++){n&&(a.left>0&&this.history.update(`borders`,e,a.left-1,t,`right`,void 0),a.right<r&&this.history.update(`borders`,e,a.right+1,t,`left`,void 0));for(let r=a.left;r<=a.right;r++)this.history.update(`borders`,e,r,t,void 0),n&&(a.top>0&&this.history.update(`borders`,e,r,a.top-1,`bottom`,void 0),a.bottom<i&&this.history.update(`borders`,e,r,a.bottom+1,`top`,void 0))}}clearInsideBorders(e,t){for(let n of t)for(let t=n.top;t<=n.bottom;t++)for(let r=n.left;r<=n.right;r++)this.history.update(`borders`,e,r,t,void 0)}addBorder(e,t,n,r){this.setBorder(e,t,n,{...this.getCellBorder({sheetId:e,col:t,row:n}),...r})}setBorders(e,t,n,r){if(n===`clear`)return this.clearBorders(e,t,!0);for(let i of Yn(t)){if(n===`all`)for(let t=i.top;t<=i.bottom;t++)for(let n=i.left;n<=i.right;n++)this.addBorder(e,n,t,{top:r,right:r,bottom:r,left:r});if(n===`h`||n===`hv`){if(i.top===i.bottom)continue;for(let t=i.left;t<=i.right;t++){this.addBorder(e,t,i.top,{bottom:r});for(let n=i.top+1;n<i.bottom;n++)this.addBorder(e,t,n,{top:r,bottom:r});this.addBorder(e,t,i.bottom,{top:r})}}if(n===`v`||n===`hv`){if(i.left===i.right)continue;for(let t=i.top;t<=i.bottom;t++){this.addBorder(e,i.left,t,{right:r});for(let n=i.left+1;n<i.right;n++)this.addBorder(e,n,t,{left:r,right:r});this.addBorder(e,i.right,t,{left:r})}}if(n===`left`||n===`external`)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.left,t,{left:r});if(n===`right`||n===`external`)for(let t=i.top;t<=i.bottom;t++)this.addBorder(e,i.right,t,{right:r});if(n===`top`||n===`external`)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.top,{top:r});if(n===`bottom`||n===`external`)for(let t=i.left;t<=i.right;t++)this.addBorder(e,t,i.bottom,{bottom:r})}}addBordersToMerge(e,t){let{left:n,right:r,top:i,bottom:a}=t,o=this.getCellBorder({sheetId:e,col:n,row:i}),s=this.getCellBorder({sheetId:e,col:r,row:a});this.clearBorders(e,[t]),o?.top&&this.setBorders(e,[{...t,bottom:i}],`top`,o.top),o?.left&&this.setBorders(e,[{...t,right:n}],`left`,o.left),s?.bottom?this.setBorders(e,[{...t,top:a}],`bottom`,s.bottom):o?.bottom&&this.setBorders(e,[{...t,top:a}],`bottom`,o.bottom),s?.right?this.setBorders(e,[{...t,left:r}],`right`,s.right):o?.right&&this.setBorders(e,[{...t,left:r}],`right`,o.right)}checkBordersUnchanged(e){let t=this.getCellBorder(e),n=!e.border?.bottom&&!e.border?.left&&!e.border?.right&&!e.border?.top;return!t&&n||w(t,e.border)?`NoChanges`:`Success`}import(e){if(Object.keys(e.borders||{}).length)for(let t of e.sheets)for(let[n,r]of Wr(t.id,t.borders)){let{sheetId:t,col:i,row:a}=n,o=e.borders[r];this.setBorder(t,i,a,o,!1)}for(let t of e.sheets)if(t.merges)for(let e of t.merges)this.addBordersToMerge(t.id,ar(e))}export(e){let t={};for(let n of e.sheets){let e={};for(let r=0;r<n.colNumber;r++)for(let i=0;i<n.rowNumber;i++){let a=this.getCellBorder({sheetId:n.id,col:r,row:i});if(a){let o=Hr(a,t),s={sheetId:n.id,col:r,row:i};e[o]??=[],e[o].push(s)}}n.borders=Ur(e)}e.borders=t}exportForExcel(e){this.export(e)}},gV=class extends mV{static getters=[`zoneToXC`,`getCells`,`getTranslatedCellFormula`,`getCellStyle`,`getCellById`,`getFormulaString`,`getFormulaMovedInSheet`];nextId=1;cells={};adaptRanges({applyChange:e},t,n){for(let r of Object.keys(this.cells))for(let i of Object.values(this.cells[r]||{}))if(i.isFormula){for(let a of i.compiledFormula.dependencies)if(a.sheetId===t||a.invalidSheetName===n.old){let t=e(a);t.changeType!==`NONE`&&this.history.update(`cells`,r,i.id,`compiledFormula`,`dependencies`,i.compiledFormula.dependencies.indexOf(a),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&&e.format!==void 0&&this.setFormatter(e.sheetId,e.target,e.format);break;case`CLEAR_FORMATTING`:this.clearFormatting(e.sheetId,e.target);break;case`ADD_COLUMNS_ROWS`:e.dimension===`COL`?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(let n of Yn(t))for(let t=n.left;t<=n.right;t++)for(let r=n.top;r<=n.bottom;r++){let n=this.getters.getCell({sheetId:e,col:t,row:r});(n?.isFormula||n?.content)&&this.dispatch(`UPDATE_CELL`,{sheetId:e,content:``,col:t,row:r})}}setFormatter(e,t,n){for(let r of Yn(t))for(let t=r.top;t<=r.bottom;t++)for(let i=r.left;i<=r.right;i++)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:i,row:t,format:n})}clearFormatting(e,t){for(let n of Yn(t))for(let t=n.left;t<=n.right;t++)for(let r=n.top;r<=n.bottom;r++)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,style:null,format:``})}clearCells(e,t){for(let n of t)for(let t=n.left;t<=n.right;t++)for(let r=n.top;r<=n.bottom;r++)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,content:``,style:null,format:``})}handleAddColumnsRows(e,t){let n,r;e.position===`before`?(n=S(e.base,e.base+e.quantity),r=e.base+e.quantity):(n=S(e.base+1,e.base+e.quantity+1),r=e.base),t(e.sheetId,r,n)}import(e){for(let t of e.sheets){let n=t.id,r=new YF;for(let e in t.cells)if(t.cells[e]){let{col:n,row:i}=Jn(e),a={sheetId:t.id,col:n,row:i};r.set(a,{content:t.cells[e]})}for(let[e,n]of[[`style`,t.styles],[`format`,t.formats]])for(let[i,a]of Wr(t.id,n)){let t=r.get(i);t?t[e]=a:r.set(i,{[e]:a})}for(let i of r.keysForSheet(n)){let n=r.get(i);if(n?.content||n?.format||n?.style){let r=this.importCell(t.id,n?.content,n?.style?e.styles[n?.style]:void 0,n?.format?e.formats[n?.format]:void 0);this.history.update(`cells`,t.id,r.id,r),this.dispatch(`UPDATE_CELL_POSITION`,{cellId:r.id,...i})}}}}export(e){let t={},n={};for(let r of e.sheets){let e=[],i=[],a={},o=Object.keys(this.cells[r.id]||{}).map(e=>this.getters.getCellPosition(e)).sort((e,t)=>e.col===t.col?e.row-t.row:e.col-t.col);for(let r of o){let o=this.getters.getCell(r),s=T(r.col,r.row),c=this.extractCustomStyle(o);if(Object.keys(c).length){let n=Hr(c,t);e[n]??=[],e[n].push(r)}if(o.format){let e=Hr(o.format,n);i[e]??=[],i[e].push(r)}o.content&&(a[s]=o.content)}r.styles=Ur(e),r.formats=Ur(i),r.cells=a}e.styles=t,e.formats=n}importCell(e,t,n,r){let i=this.getNextUid();return this.createCell(i,t||``,r,n,e)}exportForExcel(e){this.export(e);let t=[];for(let n in e.formats||[])As(e.formats[n])||(t.push(Number(n)),delete e.formats[n]);if(t.length)for(let n of e.sheets)for(let e in n.formats){let r=n.formats[e];r&&t.includes(r)&&delete n.formats[e]}}extractCustomStyle(e){let t={...e.style},n=Li(e.content,k)?Le:Ie;for(let r in t)(r!==`align`||!e.isFormula)&&t[r]===n[r]&&delete t[r];return t}getCells(e){return this.cells[e]||{}}getCellById(e){let t=this.getters.getCellPosition(e);return this.cells[t.sheetId][e]}getFormulaString(e,t,n,r=!1){if(!n.length)return Ot(t.map(e=>e.value));let i=0;return Ot(t.map(t=>{if(t.type===`REFERENCE`){let t=n[i++];return this.getters.getRangeString(t,e,{useBoundedReference:r})}return t.value}))}getTranslatedCellFormula(e,t,n,r){let i=this.getters.createAdaptedRanges(xx(r).dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t)),t,n,e);return this.getFormulaString(e,r,i)}getFormulaMovedInSheet(e,t,n){let r=xx(n).dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t)),i=this.getters.removeRangesSheetPrefix(t,r);return this.getFormulaString(t,n,i)}getCellStyle(e){return this.getters.getCell(e)?.style||{}}zoneToXC(e,t,n=[{colFixed:!1,rowFixed:!1}]){t=this.getters.expandZone(e,t);let r=T(t.left,t.top,n[0]),i=T(t.right,t.bottom,n.length>1?n[1]:n[0]),a=this.getters.getMainCellPosition({sheetId:e,col:t.left,row:t.top}),o=this.getters.getMainCellPosition({sheetId:e,col:t.right,row:t.bottom}),s=a.col===o.col&&a.row===o.row;return r!==i&&!s?r+`:`+i:r}setStyle(e,t,n){for(let r of Yn(t))for(let t=r.left;t<=r.right;t++)for(let i=r.top;i<=r.bottom;i++){let r=this.getters.getCell({sheetId:e,col:t,row:i});this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:i,style:n?{...r?.style,...n}:void 0})}}copyColumnStyle(e,t,n){for(let r=0;r<this.getters.getNumberRows(e);r++){let i=this.getFormat(e,t,r);if(i.style||i.format)for(let t of n)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,...i})}}copyRowStyle(e,t,n){for(let r=0;r<this.getters.getNumberCols(e);r++){let i=this.getFormat(e,r,t);if(i.style||i.format)for(let t of n)this.dispatch(`UPDATE_CELL`,{sheetId:e,col:r,row:t,...i})}}getFormat(e,t,n){let r={},i=this.getters.getMainCellPosition({sheetId:e,col:t,row:n}),a=this.getters.getCell(i);return a&&(a.style&&(r.style=a.style),a.format&&(r.format=a.format)),r}getNextUid(){let e=this.nextId.toString();return this.history.update(`nextId`,this.nextId+1),e}updateCell(e,t,n,r){let i=this.getters.getCell({sheetId:e,col:t,row:n}),a=r.content!==void 0||`formula`in r,o=a?zt(r?.content||void 0):i?.content||``,s;s=r.style===void 0?i?i.style:void 0:r.style||void 0;let c=r.format===void 0?i&&i.format:r.format;if((a&&!o&&!r.formula||!a&&(!i||i.content===``))&&!s&&!c){i&&(this.history.update(`cells`,e,i.id,void 0),this.dispatch(`UPDATE_CELL_POSITION`,{cellId:void 0,col:t,row:n,sheetId:e}));return}let l=i?.id||this.getNextUid(),u=this.createCell(l,o,c,s,e);this.history.update(`cells`,e,u.id,u),this.dispatch(`UPDATE_CELL_POSITION`,{cellId:u.id,col:t,row:n,sheetId:e})}createCell(e,t,n,r,i){return t.startsWith(`=`)?this.createFormulaCell(e,t,n,r,i):this.createLiteralCell(e,t,n,r)}createLiteralCell(e,t,n,r){let i=this.getters.getLocale(),a=Ns(t,i);return n||=typeof a==`number`?ms(t,i)||hs(t):void 0,!js(n)&&!P(t)&&(t=I(a)),{id:e,content:t,style:r,format:n,isFormula:!1,parsedValue:a}}createFormulaCell(e,t,n,r,i){let a=bx(t);return a.dependencies.length?this.createFormulaCellWithDependencies(e,a,n,r,i):{id:e,content:t,style:r,format:n,isFormula:!0,compiledFormula:{...a,dependencies:[]}}}createFormulaCellWithDependencies(e,t,n,r,i){let a=[];for(let e of t.dependencies)a.push(this.getters.getRangeFromSheetXC(i,e));return new _V(e,t,n,r,a,i,this.getters.getRangeString)}checkCellOutOfSheet(e){let{sheetId:t,col:n,row:r}=e;return this.getters.tryGetSheet(t)?vr(n,r,this.getters.getSheetZone(t))?`Success`:`TargetOutOfSheet`:`InvalidSheetId`}checkUselessClearCell(e){let t=this.getters.getCell(e);return!t||!t.content&&!t.style&&!t.format?`NoChanges`:`Success`}checkUselessUpdateCell(e){let t=this.getters.getCell(e),n=`content`in e||`formula`in e,r=`style`in e,i=`format`in e;return(!n||t?.content===e.content)&&(!r||w(t?.style,e.style))&&(!i||t?.format===e.format)?`NoChanges`:`Success`}},_V=class{id;format;style;sheetId;getRangeString;isFormula=!0;compiledFormula;constructor(e,t,n,r,i,a,o){this.id=e,this.format=n,this.style=r,this.sheetId=a,this.getRangeString=o;let s=0,c=t.tokens.map(e=>e.type===`REFERENCE`?new vV(i,s++,this.sheetId,this.getRangeString):e);this.compiledFormula={...t,dependencies:i,tokens:c}}get content(){return Ot(this.compiledFormula.tokens.map(e=>e.value))}get contentWithFixedReferences(){let e=0;return Ot(this.compiledFormula.tokens.map(t=>{if(t.type===`REFERENCE`){let t=e++;return this.getRangeString(this.compiledFormula.dependencies[t],this.sheetId,{useBoundedReference:!0})}return t.value}))}},vV=class{ranges;rangeIndex;sheetId;getRangeString;type=`REFERENCE`;constructor(e,t,n,r){this.ranges=e,this.rangeIndex=t,this.sheetId=n,this.getRangeString=r}get value(){let e=this.ranges[this.rangeIndex];return this.getRangeString(e,this.sheetId)}},yV=class extends mV{static getters=[`isChartDefined`,`getChartDefinition`,`getChartType`,`getChartIds`,`getChart`,`getContextCreationChart`];charts={};createChart=cD(this.getters);validateChartDefinition=e=>uD(this,e.definition);adaptRanges(e){for(let[t,n]of Object.entries(this.charts))this.history.update(`charts`,t,n?.updateRanges(e))}allowDispatch(e){switch(e.type){case`CREATE_CHART`:return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartDuplicate));case`UPDATE_CHART`:return this.checkValidations(e,this.chainValidations(this.validateChartDefinition,this.checkChartExists,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`:{let t=this.getters.getFigures(e.sheetId);for(let n of t)if(n.tag===`chart`){let t=n.id.split(`??`).pop(),r=`${e.sheetIdTo}??${t}`,i=this.charts[n.id]?.duplicateInDuplicatedSheet(e.sheetIdTo);i&&this.dispatch(`CREATE_CHART`,{figureId:r,col:n.col,row:n.row,offset:n.offset,size:{width:n.width,height:n.height},definition:i.getDefinition(),sheetId:e.sheetIdTo})}break}case`DELETE_FIGURE`:this.history.update(`charts`,e.figureId,void 0);break;case`DELETE_SHEET`:for(let t of this.getChartIds(e.sheetId))this.history.update(`charts`,t,void 0);break}}getContextCreationChart(e){return this.charts[e]?.getContextCreation()}getChart(e){return this.charts[e]}getChartType(e){let t=this.charts[e]?.type;if(!t)throw Error(`Chart not defined.`);return t}isChartDefined(e){return e in this.charts&&this.charts!==void 0}getChartIds(e){return Object.entries(this.charts).filter(([,t])=>t?.sheetId===e).map(([e])=>e)}getChartDefinition(e){let t=this.charts[e]?.getDefinition();if(!t)throw Error(`There is no chart with the given figureId: ${e}`);return t}import(e){for(let t of e.sheets)if(t.figures)for(let e of t.figures)e.tag===`chart`&&(this.charts[e.id]=this.createChart(e.id,e.data,t.id))}export(e){if(e.sheets)for(let t of e.sheets){let e=this.getters.getFigures(t.id),n=[];for(let t of e){let e=t;if(e&&e.tag===`chart`){let t=this.charts[e.id]?.getDefinition();t&&(e.data=t,n.push(e))}else n.push(e)}t.figures=n}}addFigure(e,t,n,r,i,a={width:536,height:335}){this.dispatch(`CREATE_FIGURE`,{sheetId:t,figureId:e,col:n,row:r,offset:i,size:a,tag:`chart`})}addChart(e,t){let n=this.getters.getFigureSheetId(e);n&&this.history.update(`charts`,e,this.createChart(e,t,n))}checkChartDuplicate(e){return this.getters.getFigureSheetId(e.figureId)?`DuplicatedChartId`:`Success`}checkChartExists(e){return this.isChartDefined(e.figureId)?`Success`:`ChartDoesNotExist`}checkChartChanged(e){return w(this.getChartDefinition(e.figureId),e.definition)?`NoChanges`:`Success`}};function bV(e){return e===``?NaN:Number(e)}var xV=class extends mV{static getters=[`getConditionalFormats`,`getRulesSelection`,`getRulesByCell`,`getAdaptedCfRanges`];cfRules={};adaptCFFormulas({applyChange:e,adaptFormulaString:t}){for(let n in this.cfRules)for(let r of this.cfRules[n])if(r.rule.type===`DataBarRule`&&r.rule.rangeValues){let t=e(r.rule.rangeValues);switch(t.changeType){case`REMOVE`:this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,`rangeValues`,void 0);break;case`RESIZE`:case`MOVE`:case`CHANGE`:this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,`rangeValues`,t.range);break}}else if(r.rule.type===`CellIsRule`)for(let e=0;e<r.rule.values.length;e++)this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,`values`,e,t(n,r.rule.values[e]));else if(r.rule.type===`IconSetRule`)for(let e of[`lowerInflectionPoint`,`upperInflectionPoint`])r.rule[e].type===`formula`&&this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,e,`value`,t(n,r.rule[e].value));else if(r.rule.type===`ColorScaleRule`)for(let e of[`minimum`,`maximum`,`midpoint`]){let i=r.rule[e];i?.type===`formula`&&i?.value&&this.history.update(`cfRules`,n,this.cfRules[n].indexOf(r),`rule`,e,`value`,t(n,i.value))}}adaptCFRanges(e,{applyChange:t}){for(let n of this.cfRules[e])for(let r of n.ranges){let i=t(r);switch(i.changeType){case`REMOVE`:let t=n.ranges.slice();t.splice(n.ranges.indexOf(r),1),t.length>=1?this.history.update(`cfRules`,e,this.cfRules[e].indexOf(n),`ranges`,t):this.removeConditionalFormatting(n.id,e);break;case`RESIZE`:case`MOVE`:case`CHANGE`:this.history.update(`cfRules`,e,this.cfRules[e].indexOf(n),`ranges`,n.ranges.indexOf(r),i.range);break}}}adaptRanges(e,t){let n=t?[t]:Object.keys(this.cfRules);for(let t of n)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(let t of this.getConditionalFormats(e.sheetId))this.addConditionalFormatting(t,e.sheetIdTo);break;case`DELETE_SHEET`:let t=Object.assign({},this.cfRules);delete t[e.sheetId],this.history.update(`cfRules`,t);break;case`ADD_CONDITIONAL_FORMAT`:let n={...e.cf,ranges:e.ranges.map(t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId))};this.addConditionalFormatting(n,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);break}}import(e){for(let t of e.sheets)this.cfRules[t.id]=t.conditionalFormats.map(e=>this.mapToConditionalFormatInternal(t.id,e))}export(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map(e=>this.mapToConditionalFormat(t.id,e)))}exportForExcel(e){if(e.sheets)for(let t of e.sheets)this.cfRules[t.id]&&(t.conditionalFormats=this.cfRules[t.id].map(e=>this.mapToConditionalFormat(t.id,e,{useBoundedReference:!0})))}getConditionalFormats(e){return this.cfRules[e]?.map(t=>this.mapToConditionalFormat(e,t))||[]}getRulesSelection(e,t){let n=new Set;return t.forEach(t=>{this.getRulesByZone(e,t).forEach(e=>{n.add(e)})}),Array.from(n)}getRulesByZone(e,t){let n=new Set;for(let r=t.top;r<=t.bottom;r++)for(let i=t.left;i<=t.right;i++)this.getRulesByCell(e,i,r).forEach(e=>{n.add(e.id)});return n}getRulesByCell(e,t,n){let r=[];for(let i of this.cfRules[e])for(let e of i.ranges)vr(t,n,e.zone)&&r.push(i);return new Set(r.map(t=>this.mapToConditionalFormat(e,t)))}getAdaptedCfRanges(e,t,n,r){if(n.length===0&&r.length===0)return;let i=this.getters.getConditionalFormats(e),a=i.findIndex(e=>e.id===t.id),o=[];a>-1&&(o=i[a].ranges.map(ir));let s=Yn(o,r);return Yn([...n,...s],[]).map(t=>this.getters.getRangeDataFromZone(e,t))}mapToConditionalFormat(e,t,{useBoundedReference:n}={useBoundedReference:!1}){let r=t.ranges.map(t=>this.getters.getRangeString(t,e,{useBoundedReference:n}));return t.rule.type===`DataBarRule`?{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues&&this.getters.getRangeString(t.rule.rangeValues,e,{useBoundedReference:n})},ranges:r}:{...t,rule:{...t.rule},ranges:r}}mapToConditionalFormatInternal(e,t){let n=t.ranges.map(t=>this.getters.getRangeFromSheetXC(e,t));return t.rule.type===`DataBarRule`?{...t,rule:{...t.rule,rangeValues:t.rule.rangeValues?this.getters.getRangeFromSheetXC(e,t.rule.rangeValues):void 0},ranges:n}:{...t,rule:{...t.rule},ranges:n}}addConditionalFormatting(e,t){let n=this.cfRules[t].slice(),r=n.findIndex(t=>t.id===e.id),i=this.mapToConditionalFormatInternal(t,e);r>-1?n.splice(r,1,i):n.push(i),this.history.update(`cfRules`,t,n)}checkValidPriorityChange(e,t,n){if(!this.cfRules[n])return`InvalidSheetId`;let r=this.cfRules[n].findIndex(t=>t.id===e);if(r===-1)return`InvalidConditionalFormatId`;let i=r-t;return i<0||i>=this.cfRules[n].length?`InvalidConditionalFormatId`:`Success`}checkEmptyRange(e){return e.ranges.length?`Success`:`EmptyRange`}checkCFRule(e){let t=e.cf.rule;switch(t.type){case`CellIsRule`:return lw[t.operator]?this.checkValidations(t,this.checkOperatorArgsNumber(2,[`Between`,`NotBetween`]),this.checkOperatorArgsNumber(1,[`BeginsWith`,`ContainsText`,`EndsWith`,`GreaterThan`,`GreaterThanOrEqual`,`LessThan`,`LessThanOrEqual`,`NotContains`,`Equal`,`NotEqual`]),this.checkOperatorArgsNumber(0,[`IsEmpty`,`IsNotEmpty`]),this.checkCFValues):`InvalidConditionalFormatType`;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)));case`DataBarRule`:return`Success`}return`InvalidConditionalFormatType`}checkCFHasChanged(e){let t=this.mapToConditionalFormatInternal(e.sheetId,{...e.cf,ranges:e.ranges.map(t=>this.getters.getRangeString(this.getters.getRangeFromRangeData(t),e.sheetId))}),n=this.cfRules[e.sheetId]?.find(t=>t.id===e.cf.id);return n&&w(t,n)?`NoChanges`:`Success`}checkOperatorArgsNumber(e,t){if(e>2)throw Error(`Checking more than 2 arguments is currently not supported. Add the appropriate CommandResult if you want to.`);return n=>{if(t.includes(n.operator)){let t=[],r=e=>e===void 0||e===``;return e>=1&&r(n.values[0])&&t.push(`FirstArgMissing`),e>=2&&r(n.values[1])&&t.push(`SecondArgMissing`),t.length?t:`Success`}return`Success`}}checkNaN(e,t){if([`number`,`percentage`,`percentile`].includes(e.type)&&(e.value===``||isNaN(e.value)))switch(t){case`min`:return`MinNaN`;case`max`:return`MaxNaN`;case`mid`:return`MidNaN`;case`upperInflectionPoint`:return`ValueUpperInflectionNaN`;case`lowerInflectionPoint`:return`ValueLowerInflectionNaN`}return`Success`}checkFormulaCompilation(e,t){if(e.type!==`formula`)return`Success`;if(bx(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){let t=e.lowerInflectionPoint.value,n=e.upperInflectionPoint.value;return[`number`,`percentage`,`percentile`].includes(e.lowerInflectionPoint.type)&&e.lowerInflectionPoint.type===e.upperInflectionPoint.type&&Number(t)>Number(n)?`LowerBiggerThanUpper`:`Success`}checkMinBiggerThanMax(e){let t=e.minimum.value,n=e.maximum.value;return[`number`,`percentage`,`percentile`].includes(e.minimum.type)&&e.minimum.type===e.maximum.type&&bV(t)>=bV(n)?`MinBiggerThanMax`:`Success`}checkMidBiggerThanMax(e){let t=e.midpoint?.value,n=e.maximum.value;return e.midpoint&&[`number`,`percentage`,`percentile`].includes(e.midpoint.type)&&e.midpoint.type===e.maximum.type&&bV(t)>=bV(n)?`MidBiggerThanMax`:`Success`}checkMinBiggerThanMid(e){let t=e.minimum.value,n=e.midpoint?.value;return e.midpoint&&[`number`,`percentage`,`percentile`].includes(e.midpoint.type)&&e.minimum.type===e.midpoint.type&&bV(t)>=bV(n)?`MinBiggerThanMid`:`Success`}checkCFValues(e){for(let t of e.values)if(t.startsWith(`=`)&&bx(t||``).isBadExpression)return`ValueCellIsInvalidFormula`;return`Success`}removeConditionalFormatting(e,t){let n=this.cfRules[t].findIndex(t=>t.id===e);if(n!==-1){let e=this.cfRules[t].slice();e.splice(n,1),this.history.update(`cfRules`,t,e)}}changeCFPriority(e,t,n){let r=this.cfRules[n].findIndex(t=>t.id===e),i=this.cfRules[n][r],a=r-t,o=[...this.cfRules[n]];o.splice(r,1),o.splice(a,0,i),this.history.update(`cfRules`,n,o)}},SV=class extends mV{static getters=[`cellHasListDataValidationIcon`,`getDataValidationRule`,`getDataValidationRules`,`getValidationRuleForCell`];rules={};adaptRanges(e,t){this.adaptDVRanges(t,e),this.adaptDVFormulas(e)}adaptDVFormulas({adaptFormulaString:e}){for(let t in this.rules){let n=this.rules[t];for(let r=n.length-1;r>=0;r--){let n=this.rules[t][r];for(let i=0;i<n.criterion.values.length;i++){let a=e(t,n.criterion.values[i]);this.history.update(`rules`,t,r,`criterion`,`values`,i,a)}}}}adaptDVRanges(e,{applyChange:t}){let n=this.rules[e];for(let r=n.length-1;r>=0;r--){let n=this.rules[e][r];for(let i=n.ranges.length-1;i>=0;i--){let a=n.ranges[i],o=t(a);switch(o.changeType){case`REMOVE`:if(n.ranges.length===1)this.removeDataValidationRule(e,n.id);else{let t=n.ranges.slice();t.splice(i,1),this.history.update(`rules`,e,r,`ranges`,t)}break;case`RESIZE`:case`MOVE`:case`CHANGE`:this.history.update(`rules`,e,r,`ranges`,i,o.range);break}}}}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));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`;break}return`Success`}handle(e){switch(e.type){case`CREATE_SHEET`:this.history.update(`rules`,e.sheetId,[]);break;case`DUPLICATE_SHEET`:{let t=b(this.rules[e.sheetId]).map(t=>({...t,ranges:t.ranges.map(t=>pc(e.sheetId,e.sheetIdTo,t))}));this.history.update(`rules`,e.sheetIdTo,t);break}case`DELETE_SHEET`:{let 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`:{let t=e.ranges.map(e=>this.getters.getRangeFromRangeData(e));this.addDataValidationRule(e.sheetId,{...e.rule,ranges:t});break}case`DELETE_CONTENT`:{let t=Yn(e.target),n=e.sheetId;for(let e of t)for(let t=e.top;t<=e.bottom;t++)for(let r=e.left;r<=e.right;r++){let e=this.getValidationRuleForCell({sheetId:n,col:r,row:t});if(e&&(e.criterion.type===`isBoolean`||e.criterion.type===`isValueInList`&&!this.getters.getCell({sheetId:n,col:r,row:t})?.content)){let e=this.rules[n],i=[this.getters.getRangeFromSheetXC(n,T(r,t))],a=this.removeRangesFromRules(n,i,e);this.history.update(`rules`,n,a)}}}}}getDataValidationRules(e){return this.rules[e]}getDataValidationRule(e,t){return this.rules[e].find(e=>e.id===t)}getValidationRuleForCell({sheetId:e,col:t,row:n}){if(this.rules[e]){for(let r of this.rules[e])for(let e of r.ranges)if(vr(t,n,e.zone))return r}}cellHasListDataValidationIcon(e){let t=this.getValidationRuleForCell(e);return t?(t.criterion.type===`isValueInList`||t.criterion.type===`isValueInRange`)&&t.criterion.displayStyle===`arrow`:!1}addDataValidationRule(e,t){let n=this.rules[e];t.criterion.type===`isBoolean`?this.setCenterStyleToBooleanCells(t):t.criterion.type===`isValueInList`&&(t.criterion.values=Array.from(new Set(t.criterion.values)));let r=this.removeRangesFromRules(e,t.ranges,n,t.id),i=r.findIndex(e=>e.id===t.id);i===-1?this.history.update(`rules`,e,[...r,t]):(r[i]=t,this.history.update(`rules`,e,r))}removeRangesFromRules(e,t,n,r){n=b(n);for(let e of n)e.id!==r&&(e.ranges=this.getters.recomputeRanges(e.ranges,t));return n.filter(e=>e.ranges.length>0)}removeDataValidationRule(e,t){let n=this.rules[e].filter(e=>e.id!==t);this.history.update(`rules`,e,n)}setCenterStyleToBooleanCells(e){for(let t of gc(e.ranges)){let e=this.getters.getCell(t),n={...e?.style,align:e?.style?.align??`center`,verticalAlign:e?.style?.verticalAlign??`middle`};this.dispatch(`UPDATE_CELL`,{...t,style:n})}}checkEmptyRange(e){return e.ranges.length?`Success`:`EmptyRange`}import(e){for(let t of e.sheets)if(this.rules[t.id]=[],t.dataValidationRules)for(let 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(let t of e.sheets){t.dataValidationRules=[];for(let 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(let t of e.sheets){t.dataValidationRules=[];for(let e of this.rules[t.id]){let n={...b(e),ranges:e.ranges.map(e=>this.getters.getRangeString(e,t.id,{useBoundedReference:!0}))};e.criterion.type===`isValueInRange`&&(n.criterion.values=e.criterion.values.map(e=>{let n=this.getters.getRangeFromSheetXC(t.id,e);return this.getters.getRangeString(n,t.id,{useBoundedReference:!0,useFixedReference:!0})})),t.dataValidationRules.push(n)}}}checkCriterionTypeIsValid(e){return $.contains(e.rule.criterion.type)?`Success`:`UnknownDataValidationCriterionType`}checkCriterionHasValidNumberOfValues(e){let t=e.rule.criterion,n=$.get(t.type).numberOfValues(t);return n!==void 0&&t.values.length!==n?`InvalidNumberOfCriterionValues`:`Success`}checkCriterionValuesAreValid(e){let t=e.rule.criterion,n=$.get(t.type);return t.values.some(e=>n.allowedValues===`onlyFormulas`&&!e.startsWith(`=`)?!0:e.startsWith(`=`)?n.allowedValues===`onlyLiterals`||bx(e).isBadExpression:!n.isCriterionValueValid(e))?`InvalidDataValidationCriterionValue`:`Success`}checkValidRange(e){return e.ranges.map(e=>this.getters.getRangeFromRangeData(e)).map(t=>this.getters.getRangeString(t,e.sheetId)).some(e=>!this.getters.isRangeValid(e))?`InvalidRange`:`Success`}},CV=class extends mV{static getters=[`getFigures`,`getFigure`,`getFigureSheetId`];figures={};insertionOrders=[];adaptRanges({applyChange:e},t){for(let n of this.getFigures(t)){let r=e(this.getters.getRangeFromZone(t,{left:n.col,right:n.col,top:n.row,bottom:n.row}));if(r.changeType===`MOVE`)this.history.update(`figures`,t,n.id,`col`,r.range.zone.right),this.history.update(`figures`,t,n.id,`row`,r.range.zone.bottom);else if(r.changeType===`REMOVE`){let r=e(this.getters.getRangeFromZone(t,{left:0,right:n.col-1,top:0,bottom:n.row-1})),{offset:i,col:a,row:o}=n;r.changeType!==`NONE`&&(a=r.range.zone.right+1,o=r.range.zone.bottom+1),{offset:i,col:a,row:o}=this.getPositionInSheet(t,{...n,col:a,row:o}),this.history.update(`figures`,t,n.id,`offset`,i),this.history.update(`figures`,t,n.id,`col`,a),this.history.update(`figures`,t,n.id,`row`,o)}}}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){switch(e.type){case`DELETE_SHEET`:this.getters.getFigures(e.sheetId).forEach(t=>{this.dispatch(`DELETE_FIGURE`,{figureId:t.id,sheetId:e.sheetId})});break}}handle(e){switch(e.type){case`CREATE_SHEET`:this.figures[e.sheetId]={};break;case`DELETE_SHEET`:this.deleteSheet(e.sheetId);break;case`CREATE_FIGURE`:let 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`:e.dimension===`COL`?this.onColRemove(e.sheetId):this.onRowRemove(e.sheetId);break}}onColRemove(e){let t=this.getters.getNumberCols(e),n=Array(t+1);n[t]=0;for(let r=t-1;r>=0;r--)n[r]=n[r+1]+this.getters.getColSize(e,r);for(let t of this.getFigures(e))if(t.offset.x+t.width>n[t.col]){let r=t.offset.x,i=t.col;for(r=Math.min(r,n[i]-t.width);r<0&&i>0;)i--,r=n[i]-t.width;r!==t.offset.x&&this.history.update(`figures`,e,t.id,`offset`,{x:Math.max(r,0),y:t.offset.y}),i!==t.col&&this.history.update(`figures`,e,t.id,`col`,i)}}onRowRemove(e){let t=this.getters.getNumberRows(e),n=Array(t+1);n[t]=0;for(let r=t-1;r>=0;r--)n[r]=n[r+1]+(this.getters.getUserRowSize(e,r)??23);for(let t of this.getFigures(e))if(t.offset.y+t.height>n[t.row]){let r=t.offset.y,i=t.row;for(let t=this.getters.getUserRowSize(e,i)??23;t<r;t=this.getters.getUserRowSize(e,i)??23)i+=1,r-=t;for(r=Math.min(r,n[i]-t.height);r<0&&i>0;)i--,r=n[i]-t.height;r!==t.offset.y&&this.history.update(`figures`,e,t.id,`offset`,{x:t.offset.x,y:Math.max(0,r)}),i!==t.row&&this.history.update(`figures`,e,t.id,`row`,i)}else t.offset.y+t.height>n[0]&&this.history.update(`figures`,e,t.id,`offset`,{x:t.offset.x,y:Math.max(n[0]-t.height,0)})}getPositionInSheet(e,t){let{numberOfRows:n,numberOfCols:r}=this.getters.getSheetSize(e),i=0,a=0,o,s,{col:c,row:l}=t,u={...t.offset};for(o=n;i<t.height&&o>0;o--)i+=this.getters.getUserRowSize(e,o-1)??23;for(l>o?(l=o,u.y=Math.max(i-t.height,0)):l===o&&(u.y=x(u.y,0,Math.max(i-t.height,0))),s=r;a<t.width&&s>0;s--)a+=this.getters.getColSize(e,s-1);return c>s?(c=s,u.x=Math.max(a-t.width,0)):s===c&&(u.x=x(u.x,0,Math.max(a-t.width,0))),{col:c,row:l,offset:u}}updateFigure(e){if(!(`figureId`in e)||!(`sheetId`in e))return;let{figureId:t,sheetId:n,...r}=e,i={...this.getFigure(n,t),...r};for(let[e,t]of Object.entries(r))switch(e){case`offset`:this.history.update(`figures`,n,i.id,e,t);break;case`col`:case`row`:case`width`:case`height`:t!==void 0&&this.history.update(`figures`,n,i.id,e,t);break}}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 this.figures[e.sheetId]?.[e.figureId]===void 0?`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){let t=[];for(let n of this.insertionOrders){let r=this.figures[e]?.[n];r&&t.push(r)}return t}getFigure(e,t){return this.figures[e]?.[t]}getFigureSheetId(e){return Object.keys(this.figures).find(t=>this.figures[t]?.[e]!==void 0)}import(e){for(let t of e.sheets)for(let e of t.figures)this.addFigure(e,t.id)}export(e){for(let t of e.sheets)for(let e of this.getFigures(t.id))t.figures.push({...e,data:void 0})}exportForExcel(e){return this.export(e)}},wV=class extends mV{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,b(this.sizes[e.sheetId]));break;case`DELETE_SHEET`:let t={...this.sizes};delete t[e.sheetId],this.history.update(`sizes`,t);break;case`REMOVE_COLUMNS_ROWS`:{let t=this.sizes[e.sheetId][e.dimension],n=Ht(t,e.elements);this.history.update(`sizes`,e.sheetId,e.dimension,n);break}case`ADD_COLUMNS_ROWS`:{let t=[...this.sizes[e.sheetId][e.dimension]],n=jt(e.position,e.base),r=t[e.base];t=Ut(t,Array(e.quantity).fill(r),n),this.history.update(`sizes`,e.sheetId,e.dimension,t);break}case`RESIZE_COLUMNS_ROWS`:if(e.dimension===`ROW`)for(let t of e.elements)this.history.update(`sizes`,e.sheetId,e.dimension,t,e.size||void 0);else for(let t of e.elements)this.history.update(`sizes`,e.sheetId,e.dimension,t,e.size||void 0);break}}getColSize(e,t){return Math.round(this.sizes[e]?.COL[t]||96)}getUserRowSize(e,t){let n=this.sizes[e]?.ROW[t];return n?Math.round(n):void 0}import(e){for(let t of e.sheets){let e={COL:Array(t.colNumber).fill(void 0),ROW:Array(t.rowNumber).fill(void 0)};for(let[n,r]of Object.entries(t.rows))r.size&&(e.ROW[n]=r.size);for(let[n,r]of Object.entries(t.cols))r.size&&(e.COL[n]=r.size);this.sizes[t.id]=e}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let n of e.sheets){n.rows===void 0&&(n.rows={});for(let e of S(0,this.getters.getNumberRows(n.id)))(t||this.sizes[n.id].ROW[e])&&(n.rows[e]={...n.rows[e],size:this.getUserRowSize(n.id,e)??23});n.cols===void 0&&(n.cols={});for(let e of S(0,this.getters.getNumberCols(n.id)))(t||this.sizes[n.id].COL[e])&&(n.cols[e]={...n.cols[e],size:this.getColSize(n.id,e)})}}},TV=class extends mV{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`;let t=e.dimension===`COL`?this.getHiddenColsGroups(e.sheetId):this.getHiddenRowsGroups(e.sheetId),n=e.dimension===`COL`?this.getters.getNumberCols(e.sheetId):this.getters.getNumberRows(e.sheetId);return new Set((t||[]).flat().concat(e.elements)).size>=n?`TooManyHiddenElements`:Yt(e.elements)<0||Jt(e.elements)>n?`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`:let 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,b(this.hiddenHeaders[e.sheetId]));break;case`DELETE_SHEET`:this.history.update(`hiddenHeaders`,e.sheetId,void 0);break;case`REMOVE_COLUMNS_ROWS`:{let t=[...this.hiddenHeaders[e.sheetId][e.dimension]];for(let n of[...e.elements].sort((e,t)=>t-e))t.splice(n,1);this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,t);break}case`ADD_COLUMNS_ROWS`:{let t=jt(e.position,e.base),n=Ut([...this.hiddenHeaders[e.sheetId][e.dimension]],Array(e.quantity).fill(!1),t);this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,n);break}case`HIDE_COLUMNS_ROWS`:for(let t of e.elements)this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,t,!0);break;case`UNHIDE_COLUMNS_ROWS`:for(let t of e.elements)this.history.update(`hiddenHeaders`,e.sheetId,e.dimension,t,!1);break}}checkElementsIncludeAllVisibleHeaders(e,t,n){return Nt(n,this.getAllVisibleHeaders(e,t))}isHeaderHiddenByUser(e,t,n){return t===`COL`?this.isColHiddenByUser(e,n):this.isRowHiddenByUser(e,n)}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){let t=[[]],n=this.hiddenHeaders[e].COL;for(let e=0;e<n.length;e++)n[e]?t[t.length-1].push(e):t[t.length-1].length!==0&&t.push([]);return t[t.length-1].length===0&&t.pop(),t}getHiddenRowsGroups(e){let t=[[]],n=this.hiddenHeaders[e].ROW;for(let e=0;e<n.length;e++)n[e]?t[t.length-1].push(e):t[t.length-1].length!==0&&t.push([]);return t[t.length-1].length===0&&t.pop(),t}getAllVisibleHeaders(e,t){let n=S(0,this.getters.getNumberHeaders(e,t)),r=[];return this.getters.getHeaderGroups(e,t).forEach(e=>{e.isFolded&&r.push(...S(e.start,e.end+1))}),n.filter(n=>!this.hiddenHeaders[e][t][n]&&!r.includes(n))}import(e){for(let t of e.sheets){this.hiddenHeaders[t.id]={COL:[],ROW:[]};for(let e=0;e<t.rowNumber;e++)this.hiddenHeaders[t.id].ROW[e]=!!t.rows[e]?.isHidden;for(let e=0;e<t.colNumber;e++)this.hiddenHeaders[t.id].COL[e]=!!t.cols[e]?.isHidden}}exportForExcel(e){this.exportData(e,!0)}export(e){this.exportData(e)}exportData(e,t=!1){for(let n of e.sheets){n.rows===void 0&&(n.rows={});for(let e=0;e<this.getters.getNumberRows(n.id);e++)(t||this.hiddenHeaders[n.id].ROW[e])&&(n.rows[e]===void 0&&(n.rows[e]={}),n.rows[e].isHidden||=this.hiddenHeaders[n.id].ROW[e]);n.cols===void 0&&(n.cols={});for(let e=0;e<this.getters.getNumberCols(n.id);e++)(t||this.hiddenHeaders[n.id].COL[e])&&(n.cols[e]===void 0&&(n.cols[e]={}),n.cols[e].isHidden||=this.hiddenHeaders[n.id].COL[e])}}},EV=class extends mV{static getters=[`getImage`,`getImagePath`,`getImageSize`];fileStore;images={};syncedImages=new Set;constructor(e){super(e),this.fileStore=e.external.fileStore}allowDispatch(e){switch(e.type){case`CREATE_IMAGE`:return this.getters.getFigure(e.sheetId,e.figureId)?`InvalidFigureId`:`Success`;default:return`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`:{let t=this.getters.getFigures(e.sheetId);for(let n of t)if(n.tag===`image`){let t=n.id.split(`??`).pop(),r=`${e.sheetIdTo}??${t}`,i=this.getImage(n.id);if(i){let t={width:n.width,height:n.height};this.dispatch(`CREATE_IMAGE`,{sheetId:e.sheetIdTo,figureId:r,offset:n.offset,col:n.col,row:n.row,size:t,definition:b(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);break}}garbageCollectExternalResources(){let e=new Set(this.getAllImages().map(e=>e.path));for(let t of this.syncedImages)e.has(t)||this.fileStore?.delete(t)}getImage(e){for(let t of Object.values(this.images))if(t&&t[e])return t[e];throw 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,n,r,i,a){this.dispatch(`CREATE_FIGURE`,{sheetId:t,figureId:e,col:n,row:r,offset:i,size:a,tag:`image`})}import(e){for(let t of e.sheets){let e=(t.figures||[]).filter(e=>e.tag===`image`);for(let n of e)this.history.update(`images`,t.id,n.id,n.data),this.syncedImages.add(n.data.path)}}export(e){for(let t of e.sheets){let e=t.figures.filter(e=>e.tag===`image`);for(let n of e)n.data=this.images[t.id]?.[n.id]}}exportForExcel(e){for(let t of e.sheets){t.images||=[];let e=this.getters.getFigures(t.id),n=[];for(let t of e)if(t?.tag===`image`){let e=this.getImage(t.id);e&&n.push({...t,data:b(e)})}t.images=[...t.images,...n]}}getAllImages(){let e=[];for(let t in this.images)e.push(...Object.values(this.images[t]||{}).filter(C));return e}},DV=class extends mV{static getters=[`isInMerge`,`isInSameMerge`,`isMergeHidden`,`getMainCellPosition`,`expandZone`,`doesIntersectMerge`,`doesColumnsHaveCommonMerges`,`doesRowsHaveCommonMerges`,`getMerges`,`getMerge`,`getMergesInZone`,`isSingleCellOrMerge`,`getSelectionRangeString`,`isMainCellPosition`];nextId=1;merges={};mergeCellMap={};allowDispatch(e){let t=`force`in e?!!e.force:!1;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`:this.history.update(`merges`,e.sheetId,{}),this.history.update(`mergeCellMap`,e.sheetId,{});break;case`DELETE_SHEET`:this.history.update(`merges`,e.sheetId,{}),this.history.update(`mergeCellMap`,e.sheetId,{});break;case`DUPLICATE_SHEET`:let t=this.merges[e.sheetId];if(!t)break;for(let n of Object.values(t).filter(C))this.addMerge(e.sheetIdTo,n.zone);break;case`ADD_MERGE`:for(let t of e.target)this.addMerge(e.sheetId,t);break;case`REMOVE_MERGE`:for(let t of e.target)this.removeMerge(e.sheetId,t);break}}adaptRanges(e,t){this.applyRangeChangeOnSheet(t,e)}getMerges(e){return Object.keys(this.merges[e]||{}).map(t=>this.getMergeById(e,parseInt(t,10))).filter(C)}getMerge({sheetId:e,col:t,row:n}){let r=this.mergeCellMap[e],i=r?t in r&&r[t]?.[n]:void 0;return i?this.getMergeById(e,i):void 0}getMergesInZone(e,t){let n=this.mergeCellMap[e];if(!n)return[];let r=new Set;for(let e=t.left;e<=t.right;e++)for(let i=t.top;i<=t.bottom;i++){let t=n[e]?.[i];t&&r.add(t)}return Array.from(r).map(t=>this.getMergeById(e,t)).filter(C)}getSelectionRangeString(e,t){let n=this.getters.expandZone(e.sheetId,e.zone),r=sc({...e,zone:{...n,bottom:uc(e)?void 0:n.bottom,right:dc(e)?void 0:n.right}},this.getters.getSheetSize),i=this.getters.getRangeString(r,t);if(this.isSingleCellOrMerge(e.sheetId,e.zone)){let{sheetName:e,xc:t}=ac(i);return oc(e,t.split(`:`)[0])}return i}doesIntersectMerge(e,t){for(let n of this.getMerges(e))if(_r(t,n))return!0;return!1}doesColumnsHaveCommonMerges(e,t,n){let r=this.getters.getSheet(e);for(let i=0;i<this.getters.getNumberRows(e);i++)if(this.isInSameMerge(r.id,t,i,n,i))return!0;return!1}doesRowsHaveCommonMerges(e,t,n){let r=this.getters.getSheet(e);for(let i=0;i<=this.getters.getNumberCols(e);i++)if(this.isInSameMerge(r.id,i,t,i,n))return!0;return!1}expandZone(e,t){let{left:n,right:r,top:i,bottom:a}=t,o={left:n,right:r,top:i,bottom:a};for(let t in this.merges[e]){let n=this.getMergeById(e,parseInt(t));n&&_r(n,o)&&(o=pr(n,o))}return gr(o,t)?o:this.expandZone(e,o)}isInSameMerge(e,t,n,r,i){let a=this.getMerge({sheetId:e,col:t,row:n}),o=this.getMerge({sheetId:e,col:r,row:i});return!a||!o?!1:gr(a,o)}isInMerge({sheetId:e,col:t,row:n}){let r=this.mergeCellMap[e];return r?t in r&&!!r[t]?.[n]:!1}getMainCellPosition(e){let t=this.getMerge(e);return t?{sheetId:e.sheetId,col:t.left,row:t.top}:e}isMergeHidden(e,t){let n=this.getters.getHiddenColsGroups(e),r=this.getters.getHiddenRowsGroups(e);for(let e of n)if(t.left>=e[0]&&t.right<=e[e.length-1])return!0;for(let e of r)if(t.top>=e[0]&&t.bottom<=e[e.length-1])return!0;return!1}isSingleCellOrMerge(e,t){let n=this.getMerge({sheetId:e,col:t.left,row:t.top});if(n)return gr(t,n);let{numberOfCols:r,numberOfRows:i}=br(t);return r===1&&i===1}isMainCellPosition(e){return w(this.getMainCellPosition(e),e)}isMergeDestructive(e,t){let{left:n,right:r,top:i,bottom:a}=t;r=x(r,0,this.getters.getNumberCols(e)-1),a=x(a,0,this.getters.getNumberRows(e)-1);for(let t=i;t<=a;t++)for(let a=n;a<=r;a++)if(a!==n||t!==i){let n=this.getters.getCell({sheetId:e,col:a,row:t});if(n&&n.content!==``)return!0}return!1}getMergeById(e,t){let n=this.merges[e]?.[t];return n===void 0?void 0:kV(t,n)}checkDestructiveMerge({sheetId:e,target:t}){return this.getters.tryGetSheet(e)&&t.some(t=>this.isMergeDestructive(e,t))?`MergeIsDestructive`:`Success`}checkOverlap({target:e}){for(let t of e)for(let n of e)if(t!==n&&_r(t,n))return`MergeOverlap`;return`Success`}checkFrozenPanes({sheetId:e,target:t}){if(!this.getters.tryGetSheet(e))return`Success`;let{xSplit:n,ySplit:r}=this.getters.getPaneDivisions(e);for(let e of t)if(e.left<n&&e.right>=n||e.top<r&&e.bottom>=r)return`FrozenPaneOverlap`;return`Success`}checkMergedContentUpdate(e){let{col:t,row:n,content:r}=e;if(r===void 0)return`Success`;let{col:i,row:a}=this.getMainCellPosition(e);return i===t&&a===n?`Success`:`CellIsMerged`}checkMergeExists(e){let{sheetId:t,target:n}=e;for(let e of n){let{left:n,top:r}=e,i=this.getMerge({sheetId:t,col:n,row:r});if(i===void 0||!gr(e,i))return`InvalidTarget`}return`Success`}addMerge(e,t){let{left:n,right:r,top:i,bottom:a}=t;if(r=x(r,0,this.getters.getNumberCols(e)-1),a=x(a,0,this.getters.getNumberRows(e)-1),T(n,i)===T(r,a))return;let o=this.getters.getCell({sheetId:e,col:n,row:i}),s=this.nextId++;this.history.update(`merges`,e,s,this.getters.getRangeFromSheetXC(e,cr({left:n,top:i,right:r,bottom:a})));let c=new Set;for(let t=i;t<=a;t++)for(let a=n;a<=r;a++){(a!==n||t!==i)&&this.dispatch(`UPDATE_CELL`,{sheetId:e,col:a,row:t,style:o?o.style:null,content:``});let r=this.getMerge({sheetId:e,col:a,row:t});r&&c.add(r.id),this.history.update(`mergeCellMap`,e,a,t,s)}for(let t of c){let{top:n,bottom:r,left:i,right:a}=this.getMergeById(e,t);for(let t=n;t<=r;t++)for(let n=i;n<=a;n++){let r={sheetId:e,col:n,row:t},i=this.getMerge(r);(!i||i.id!==s)&&(this.history.update(`mergeCellMap`,e,n,t,void 0),this.dispatch(`CLEAR_CELL`,r))}this.history.update(`merges`,e,t,void 0)}}removeMerge(e,t){let{left:n,top:r,bottom:i,right:a}=t,o=this.getMerge({sheetId:e,col:n,row:r});if(!(o===void 0||!gr(t,o))){this.history.update(`merges`,e,o.id,void 0);for(let t=r;t<=i;t++)for(let r=n;r<=a;r++)this.history.update(`mergeCellMap`,e,r,t,void 0)}}applyRangeChangeOnSheet(e,{applyChange:t}){let n=Object.entries(this.merges[e]||{});for(let[r,i]of n)if(i){let n=i.zone,a=t(i);switch(a.changeType){case`NONE`:break;case`REMOVE`:this.removeMerge(e,n);break;default:let{numberOfCols:t,numberOfRows:i}=br(a.range.zone);t===1&&i===1?this.removeMerge(e,n):this.history.update(`merges`,e,parseInt(r,10),a.range);break}}this.history.update(`mergeCellMap`,e,{});for(let t of this.getMerges(e))for(let{col:n,row:r}of wr(t))this.history.update(`mergeCellMap`,e,n,r,t.id)}import(e){let t=e.sheets||[];for(let e of t)this.history.update(`merges`,e.id,{}),this.history.update(`mergeCellMap`,e.id,{}),e.merges&&this.importMerges(e.id,e.merges)}importMerges(e,t){for(let n of t)this.addMerge(e,ar(n))}export(e){for(let t of e.sheets){let e=this.merges[t.id];e&&t.merges.push(...OV(e))}}exportForExcel(e){this.export(e)}};function OV(e){return Object.entries(e).map(([e,t])=>t?kV(parseInt(e,10),t):void 0).filter(C).map(e=>T(e.left,e.top)+`:`+T(e.right,e.bottom))}function kV(e,t){return{...t.zone,id:e}}var AV=class{getters;providers=[];isAdaptingRanges=!1;constructor(e){this.getters=e}static getters=[`copyFormulaStringForSheet`,`extendRange`,`getRangeString`,`getRangeFromSheetXC`,`createAdaptedRanges`,`getRangeData`,`getRangeDataFromXc`,`getRangeDataFromZone`,`getRangeFromRangeData`,`getRangeFromZone`,`getRangesUnion`,`recomputeRanges`,`isRangeValid`,`removeRangesSheetPrefix`];allowDispatch(e){return e.type===`MOVE_RANGES`?e.target.length===1?`Success`:`InvalidZones`:`Success`}beforeHandle(e){}handle(e){if(this.isAdaptingRanges)throw Error(`Plugins cannot dispatch commands during adaptRanges phase`);let t=yc(e);t&&this.executeOnAllRanges(t)}finalize(){}verifyRangeRemoved(e){return t=>{let n=e(t);return n.changeType!==`NONE`&&!or(n.range.zone)?{range:n.range,changeType:`REMOVE`}:n}}executeOnAllRanges(e){this.isAdaptingRanges=!0;let t={applyChange:this.verifyRangeRemoved(e.applyChange),adaptRangeString:(t,n)=>Mx(t,n,e),adaptFormulaString:(t,n)=>jx(t,n,e)};for(let n of this.providers)n(t,e.sheetId,e.sheetName);this.isAdaptingRanges=!1}addRangeProvider(e){this.providers.push(e)}createAdaptedRanges(e,t,n,r){return e.map(e=>{if(!or(e.zone))return e;let i=e.prefixSheet?e.sheetId:r,a=dc(e),o=uc(e),s={...e.unboundedZone,left:a&&!e.unboundedZone.hasHeader?e.unboundedZone.left:e.unboundedZone.left+(e.parts[0].colFixed?0:t),right:a?e.unboundedZone.right:e.unboundedZone.right+((e.parts[1]||e.parts[0]).colFixed?0:t),top:o&&!e.unboundedZone.hasHeader?e.unboundedZone.top:e.unboundedZone.top+(e.parts[0].rowFixed?0:n),bottom:o?e.unboundedZone.bottom:e.unboundedZone.bottom+((e.parts[1]||e.parts[0]).rowFixed?0:n)};return vc(sc({...e,sheetId:i,zone:s},this.getters.getSheetSize))})}removeRangesSheetPrefix(e,t){return t.map(t=>t.prefixSheet&&t.sheetId===e?{...t,prefixSheet:!1}:t)}extendRange(e,t,n){let r=t===`COL`?e.zone.right+n:e.zone.right,i=t===`ROW`?e.zone.bottom+n:e.zone.bottom,a={left:e.zone.left,top:e.zone.top,right:dc(e)?void 0:r,bottom:uc(e)?void 0:i};return sc({...e,zone:a},this.getters.getSheetSize)}getRangeFromSheetXC(e,t){if(!$s.test(t)||!this.getters.tryGetSheet(e))return lc(t);let{sheetName:n}=ac(t);return cc({xc:t,sheetId:this.getters.getSheetIdByName(n)||e,invalidSheetName:n&&!this.getters.getSheetIdByName(n)?n:void 0},this.getters.getSheetSize)}getRangeString(e,t,n={useBoundedReference:!1,useFixedReference:!1}){return e?e.invalidXc?e.invalidXc:this.getters.tryGetSheet(e.sheetId)?fc(e,t,this.getters.getSheetName,n):j.InvalidReference:j.InvalidReference}getRangeDataFromXc(e,t){let n=this.getters.getRangeFromSheetXC(e,t);return this.getRangeDataFromZone(n.sheetId,n.unboundedZone)}getRangeDataFromZone(e,t){return t=this.getters.getUnboundedZone(e,t),{_sheetId:e,_zone:t}}getRangeData(e){return this.getRangeDataFromZone(e.sheetId,e.unboundedZone)}getRangeFromZone(e,t){return sc({sheetId:e,zone:t,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}],prefixSheet:!1},this.getters.getSheetSize)}recomputeRanges(e,t){return Yn(e.map(e=>e.unboundedZone),t.map(e=>e.unboundedZone)).map(t=>this.getRangeFromZone(e[0].sheetId,t))}getRangeFromRangeData(e){return this.getters.tryGetSheet(e._sheetId)?sc({prefixSheet:!1,zone:e._zone,sheetId:e._sheetId,invalidSheetName:void 0,parts:[{colFixed:!1,rowFixed:!1},{colFixed:!1,rowFixed:!1}]},this.getters.getSheetSize):lc(j.InvalidReference)}isRangeValid(e){if(!e)return!1;let{xc:t,sheetName:n}=ac(e);return t.match($s)!==null&&(!n||this.getters.getSheetIdByName(n)!==void 0)}getRangesUnion(e){let t=mr(...e.map(e=>e.unboundedZone));return this.getRangeFromZone(e[0].sheetId,t)}copyFormulaStringForSheet(e,t,n,r){if(!n.startsWith(`=`))return n;let i=bx(n),a=i.dependencies.map(n=>{let i=this.getters.getRangeFromSheetXC(e,n);return r===`keepSameReference`?i:pc(e,t,i)});return this.getters.getFormulaString(t,i.tokens,a)}},jV=class extends mV{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`.split(`.`);sheetIdsMapName={};orderedSheetIds=[];sheets={};cellPosition={};allowDispatch(e){let t=this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e);if(t!==`Success`)return t;switch(e.type){case`HIDE_SHEET`:return this.getVisibleSheetIds().length===1?`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{let t=this.orderedSheetIds.findIndex(t=>t===e.sheetId);return this.findIndexOfTargetSheet(t,e.delta),`Success`}catch{return`WrongSheetMove`}case`RENAME_SHEET`:return this.isRenameAllowed(e);case`COLOR_SHEET`:return!e.color||cn(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`:{let t=Yt(e.elements),n=Jt(e.elements);return t<0||!this.doesHeaderExist(e.sheetId,e.dimension,n)?`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`:let 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`:e.dimension===`COL`?this.removeColumns(this.sheets[e.sheetId],[...e.elements]):this.removeRows(this.sheets[e.sheetId],[...e.elements]);break;case`ADD_COLUMNS_ROWS`:e.dimension===`COL`?this.addColumns(this.sheets[e.sheetId],e.base,e.position,e.quantity):this.addRows(this.sheets[e.sheetId],e.base,e.position,e.quantity);break;case`UPDATE_CELL_POSITION`:this.updateCellPosition(e);break;case`FREEZE_COLUMNS`:this.setPaneDivisions(e.sheetId,e.quantity,`COL`);break;case`FREEZE_ROWS`:this.setPaneDivisions(e.sheetId,e.quantity,`ROW`);break;case`UNFREEZE_ROWS`:this.setPaneDivisions(e.sheetId,0,`ROW`);break;case`UNFREEZE_COLUMNS`:this.setPaneDivisions(e.sheetId,0,`COL`);break;case`UNFREEZE_COLUMNS_ROWS`:this.setPaneDivisions(e.sheetId,0,`COL`),this.setPaneDivisions(e.sheetId,0,`ROW`)}}import(e){for(let t of e.sheets)this.sheetIdsMapName[t.name]=t.id;for(let t of e.sheets){let e=t.name||`Sheet`+(Object.keys(this.sheets).length+1),{colNumber:n,rowNumber:r}=this.getImportedSheetSize(t),i={id:t.id,name:e,numberOfCols:n,rows:Ac(r),areGridLinesVisible:t.areGridLinesVisible===void 0?!0: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(C).map(e=>{let t=this.sheets[e],n={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:t.areGridLinesVisible===void 0?!0:t.areGridLinesVisible,isVisible:t.isVisible,color:t.color};return(t.panes.xSplit||t.panes.ySplit)&&(n.panes=t.panes),n})}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){let t=this.sheets[e];if(!t)throw 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){let t=st(e);for(let e in this.sheetIdsMapName)if(Fc(e,t))return this.sheetIdsMapName[e]}}getSheetIds(){return this.orderedSheetIds}getVisibleSheetIds(){return this.orderedSheetIds.filter(this.isSheetVisible.bind(this))}doesHeaderExist(e,t,n){return t===`COL`?n>=0&&n<this.getNumberCols(e):n>=0&&n<this.getNumberRows(e)}doesHeadersExist(e,t,n){return n.every(n=>this.doesHeaderExist(e,t,n))}getCell({sheetId:e,col:t,row:n}){let r=this.tryGetSheet(e)?.rows[n]?.cells[t];if(r!==void 0)return this.getters.getCellById(r)}getColsZone(e,t,n){return{top:0,bottom:this.getNumberRows(e)-1,left:t,right:n}}getRowCells(e,t){return Object.values(this.getSheet(e).rows[t]?.cells).filter(C)}getRowsZone(e,t,n){return{top:t,bottom:n,left:0,right:this.getSheet(e).numberOfCols-1}}getCellPosition(e){let t=this.cellPosition[e];if(!t)throw 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 t===`COL`?this.getNumberCols(e):this.getNumberRows(e)}getNextSheetName(e=`Sheet`){return Nc(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(t.bottom===void 0||t.right===void 0)return t;let n=t.left===0&&t.right===this.getNumberCols(e)-1,r=t.top===0&&t.bottom===this.getNumberRows(e)-1;return{...t,bottom:r?void 0:t.bottom,right:n&&!r?void 0:t.right}}getPaneDivisions(e){return this.getSheet(e).panes}setPaneDivisions(e,t,n){let r={...this.getPaneDivisions(e)};n===`COL`?r.xSplit=t:n===`ROW`&&(r.ySplit=t),this.history.update(`sheets`,e,`panes`,r)}checkElementsIncludeAllNonFrozenHeaders(e,t,n){let r=this.getters.getPaneDivisions(e),i=t===`ROW`?r.ySplit:r.xSplit,a=this.getters.getNumberHeaders(e,t);return i?Nt(n,S(i,a)):!1}getCommandZones(e){let 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&&e.col!==void 0&&`row`in e&&e.row!==void 0&&t.push({top:e.row,left:e.col,bottom:e.row,right:e.col}),t}checkZonesExistInSheet(e,t){if(!t.every(or))return`InvalidRange`;if(t.length){let n=this.getSheetZone(e);return t.every(e=>yr(e,n))?`Success`:`TargetOutOfSheet`}return`Success`}updateCellPosition(e){let{sheetId:t,cellId:n,col:r,row:i}=e;n?this.setNewPosition(n,t,r,i):this.clearPosition(t,r,i)}setNewPosition(e,t,n,r){let i=this.cellPosition[e];i&&this.clearPosition(t,i.col,i.row),this.history.update(`cellPosition`,e,{row:r,col:n,sheetId:t}),this.history.update(`sheets`,t,`rows`,r,`cells`,n,e)}clearPosition(e,t,n){let r=this.sheets[e]?.rows[n].cells[t];r&&(this.history.update(`cellPosition`,r,void 0),this.history.update(`sheets`,e,`rows`,n,`cells`,t,void 0))}setGridLinesVisibility(e,t){this.history.update(`sheets`,e,`areGridLinesVisible`,t)}createSheet(e,t,n,r,i){let a={id:e,name:t,numberOfCols:n,rows:Ac(r),areGridLinesVisible:!0,isVisible:!0,panes:{xSplit:0,ySplit:0}},o=this.orderedSheetIds.slice();o.splice(i,0,a.id);let s=this.sheets;return this.history.update(`orderedSheetIds`,o),this.history.update(`sheets`,Object.assign({},s,{[a.id]:a})),a}moveSheet(e,t){let n=this.orderedSheetIds.slice(),r=n.findIndex(t=>t===e),i=n.splice(r,1),a=this.findIndexOfTargetSheet(r,t);n.splice(a,0,i[0]),this.history.update(`orderedSheetIds`,n)}findIndexOfTargetSheet(e,t){for(;t!==0&&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(t===0)return e;throw Error(`There is not enough visible sheets`)}checkSheetName(e){let t=this.getters.tryGetSheetName(e.sheetId),n=e.type===`RENAME_SHEET`?e.newName:e.name;if(t!==void 0&&n===t)return`UnchangedSheetName`;let{orderedSheetIds:r,sheets:i}=this,a=n&&n.trim().toLowerCase();return r.find(t=>Fc(i[t]?.name,a)&&t!==e.sheetId)?`DuplicatedSheetName`:Ye.test(a)?`ForbiddenCharactersInSheetName`:`Success`}checkSheetPosition(e){let{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){let t=this.getters.getMerges(e.sheetId);for(let n of t)if(n.top<e.quantity&&e.quantity<=n.bottom)return`MergeOverlap`;return`Success`}checkColFreezeOverlapMerge(e){let t=this.getters.getMerges(e.sheetId);for(let n of t)if(n.left<e.quantity&&e.quantity<=n.right)return`MergeOverlap`;return`Success`}isRenameAllowed(e){return e.newName&&e.newName.trim().toLowerCase()?this.checkSheetName(e):`MissingSheetName`}renameSheet(e,t){let n=e.name;this.history.update(`sheets`,e.id,`name`,t.trim());let r=Object.assign({},this.sheetIdsMapName);delete r[n],r[t]=e.id,this.history.update(`sheetIdsMapName`,r)}hideSheet(e){this.history.update(`sheets`,e,`isVisible`,!1)}showSheet(e){this.history.update(`sheets`,e,`isVisible`,!0)}duplicateSheet(e,t,n){let r=b(this.getSheet(e));r.id=t,r.name=n;for(let e=0;e<=r.numberOfCols;e++)for(let t=0;t<=r.rows.length;t++)r.rows[t]&&(r.rows[t].cells[e]=void 0);let i=this.orderedSheetIds.slice(),a=i.indexOf(e);i.splice(a+1,0,r.id),this.history.update(`orderedSheetIds`,i),this.history.update(`sheets`,Object.assign({},this.sheets,{[r.id]:r}));for(let t of Object.values(this.getters.getCells(e))){let{col:e,row:n}=this.getCellPosition(t.id);this.dispatch(`UPDATE_CELL`,{sheetId:r.id,col:e,row:n,content:t.content,format:t.format,style:t.style})}let o=Object.assign({},this.sheetIdsMapName);o[r.name]=r.id,this.history.update(`sheetIdsMapName`,o)}getDuplicateSheetName(e){return Pc(e,this.orderedSheetIds.map(this.getSheetName.bind(this)))}deleteSheet(e){let t=e.name,n=Object.assign({},this.sheets);delete n[e.id],this.history.update(`sheets`,n);let r=this.orderedSheetIds.slice(),i=r.indexOf(e.id);r.splice(i,1),this.history.update(`orderedSheetIds`,r);let a=Object.assign({},this.sheetIdsMapName);delete a[t],this.history.update(`sheetIdsMapName`,a)}removeColumns(e,t){t.sort((e,t)=>t-e);for(let n of t)this.moveCellOnColumnsDeletion(e,n);let n=this.sheets[e.id].numberOfCols;this.history.update(`sheets`,e.id,`numberOfCols`,n-t.length);let r=t.filter(t=>t<e.panes.xSplit).length;r&&this.setPaneDivisions(e.id,e.panes.xSplit-r,`COL`)}removeRows(e,t){t.sort((e,t)=>t-e);for(let n of dt(t)){let t=n[n.length-1],r=n[0];this.moveCellOnRowsDeletion(e,t,r),this.updateRowsStructureOnDeletion(e,t,r)}let n=t.filter(t=>t<e.panes.ySplit).length;n&&this.setPaneDivisions(e.id,e.panes.ySplit-n,`ROW`)}addColumns(e,t,n,r){let i=n===`before`?t:t+1;this.moveCellsOnAddition(e,i,r,`columns`);let a=this.sheets[e.id].numberOfCols;this.history.update(`sheets`,e.id,`numberOfCols`,a+r),i<e.panes.xSplit&&this.setPaneDivisions(e.id,e.panes.xSplit+r,`COL`)}addRows(e,t,n,r){let i=n===`before`?t:t+1;this.addEmptyRows(e,r),this.moveCellsOnAddition(e,i,r,`rows`),i<e.panes.ySplit&&this.setPaneDivisions(e.id,e.panes.ySplit+r,`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 n=0;n<e.rows.length;n++){let r=e.rows[n];for(let i in r.cells){let a=Number(i),o=r.cells[i];o&&a>t&&this.setNewPosition(o,e.id,a-1,n)}}}moveCellsOnAddition(e,t,n,r){let i=[];for(let a=0;a<e.rows.length;a++){let o=e.rows[a];if(r!==`rows`||a>=t)for(let s in o.cells){let c=Number(s),l=o.cells[s];l&&(r===`rows`||c>=t)&&i.push({sheetId:e.id,cellId:l,col:c+(r===`columns`?n:0),row:a+(r===`rows`?n:0),type:`UPDATE_CELL_POSITION`})}}for(let e of i.reverse())this.updateCellPosition(e)}moveCellOnRowsDeletion(e,t,n){this.dispatch(`CLEAR_CELLS`,{sheetId:e.id,target:[{left:0,top:t,right:this.getters.getNumberCols(e.id),bottom:n}]});let r=n-t+1;for(let t=0;t<e.rows.length;t++){let i=e.rows[t];if(t>n)for(let n in i.cells){let a=Number(n),o=i.cells[n];o&&this.setNewPosition(o,e.id,a,t-r)}}}updateRowsStructureOnDeletion(e,t,n){let r=[],i=e.rows.map(e=>e.cells).reverse();for(let a in e.rows){let e=Number(a);e>=t&&e<=n||r.push({cells:i.pop()})}this.history.update(`sheets`,e.id,`rows`,r)}addEmptyRows(e,t){let n=e.rows.slice();for(let e=0;e<t;e++)n.push({cells:{}});this.history.update(`sheets`,e.id,`rows`,n)}getImportedSheetSize(e){let t=Object.keys(e.cells).map(Jn),n=e.rowNumber,r=e.colNumber;for(let{col:e,row:i}of t)n=Math.max(n,i+1),r=Math.max(r,e+1);return{rowNumber:n,colNumber:r}}checkSheetExists(e){return e.type!==`CREATE_SHEET`&&`sheetId`in e&&this.sheets[e.sheetId]===void 0?`InvalidSheetId`:e.type===`CREATE_SHEET`&&this.sheets[e.sheetId]!==void 0?`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`}},MV=class extends mV{static getters=[`getCoreTable`,`getCoreTables`,`getCoreTableMatchingTopLeft`];tables={};nextTableId=1;adaptRanges({applyChange:e},t){for(let n of this.getCoreTables(t))this.applyRangeChangeOnTable(t,n,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`;let t=e.ranges.map(e=>this.getters.getRangeFromRangeData(e).zone);return Fr(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(let t of this.getCoreTables(e.sheetId)){let n=t.range.zone;for(let t of e.target)if(_r(n,t))return`MergeInTable`}break}return`Success`}handle(e){switch(e.type){case`CREATE_SHEET`:this.history.update(`tables`,e.sheetId,{});break;case`DELETE_SHEET`:{let t={...this.tables};delete t[e.sheetId],this.history.update(`tables`,t);break}case`DUPLICATE_SHEET`:{let t={};for(let n of this.getCoreTables(e.sheetId))t[n.id]=n.type===`dynamic`?this.copyDynamicTableForSheet(e.sheetIdTo,n):this.copyStaticTableForSheet(e.sheetIdTo,n);this.history.update(`tables`,e.sheetIdTo,t);break}case`CREATE_TABLE`:{let t=e.ranges.map(e=>this.getters.getRangeFromRangeData(e)),n=this.getters.getRangesUnion(t),r=this.getters.getMergesInZone(e.sheetId,n.zone);r.length&&this.dispatch(`REMOVE_MERGE`,{sheetId:e.sheetId,target:r});let i=this.consumeNextId(),a=e.config||OA,o=e.tableType===`dynamic`?this.createDynamicTable(i,n,a):this.createStaticTable(i,e.tableType,n,a);this.history.update(`tables`,e.sheetId,o.id,o);break}case`REMOVE_TABLE`:{let t={};for(let n of this.getCoreTables(e.sheetId))e.target.every(e=>!hr(n.range.zone,e))&&(t[n.id]=n);this.history.update(`tables`,e.sheetId,t);break}case`UPDATE_TABLE`:this.updateTable(e);break;case`UPDATE_CELL`:{let t=e.sheetId;for(let n of this.getCoreTables(t)){if(n.type===`dynamic`)continue;let r=this.canUpdateCellCmdExtendTable(e,n);r===`down`?this.extendTableDown(t,n):r===`right`&&this.extendTableRight(t,n)}break}case`DELETE_CONTENT`:{let t={...this.tables[e.sheetId]};for(let n in t){let r=t[n];r&&e.target.some(e=>yr(r.range.zone,e))&&this.dispatch(`REMOVE_TABLE`,{sheetId:e.sheetId,target:[r.range.zone]})}break}}}getCoreTables(e){return this.tables[e]?Object.values(this.tables[e]).filter(C):[]}getCoreTable({sheetId:e,col:t,row:n}){return this.getCoreTables(e).find(e=>vr(t,n,e.range.zone))}getTablesOverlappingZones(e,t){return this.getCoreTables(e).filter(e=>t.some(t=>_r(e.range.zone,t)))}extendTableDown(e,t){let n=this.getters.extendRange(t.range,`ROW`,1);this.history.update(`tables`,e,t.id,this.updateStaticTable(t,n))}extendTableRight(e,t){let n=this.getters.extendRange(t.range,`COL`,1);this.history.update(`tables`,e,t.id,this.updateStaticTable(t,n))}canUpdateCellCmdExtendTable({content:e,sheetId:t,col:n,row:r},i){if(!e)return`none`;let a=i.range.zone,o=`none`;if(a.bottom+1===r&&n>=a.left&&n<=a.right?o=`down`:a.right+1===n&&r>=a.top&&r<=a.bottom&&(o=`right`),o===`none`)return`none`;let s=o===`down`?{...a,bottom:a.bottom+1,top:a.bottom+1}:{...a,right:a.right+1,left:a.right+1};for(let e=s.top;e<=s.bottom;e++)for(let n=s.left;n<=s.right;n++){let r={sheetId:t,col:n,row:e};if(this.getters.getCell(r)?.content||this.getters.isInMerge(r)||this.getTablesOverlappingZones(t,[E(r)]).length)return`none`}return o}getCoreTableMatchingTopLeft(e,t){for(let n of this.getCoreTables(e)){let e=n.range.zone;if(e.left===t.left&&e.top===t.top)return n}}checkUpdatedTableZoneIsValid(e){if(!e.newTableRange)return`Success`;let t=this.getters.getRangeFromRangeData(e.newTableRange).zone,n=this.getters.checkZonesExistInSheet(e.sheetId,[t]);if(n!==`Success`)return n;let r=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);return r?this.getTablesOverlappingZones(e.sheetId,[t]).filter(e=>e.id!==r.id).length?`TableOverlap`:`Success`:`TableNotFound`}checkTableConfigUpdateIsValid(e){return e&&(e.numberOfHeaders!==void 0&&e.numberOfHeaders<0||e.hasFilters&&e.numberOfHeaders===0)?`InvalidTableConfig`:`Success`}createStaticTable(e,t,n,r,i){let a=n.zone;if(!i){i=[];for(let e of S(a.left,a.right+1)){let t={...a,left:e,right:e},o=this.consumeNextId();i.push(this.createFilterFromZone(o,n.sheetId,t,r))}}return{id:e,range:n,filters:i,config:r,type:t}}createDynamicTable(e,t,n){let r=Ar(t.zone);return{id:e,range:this.getters.getRangeFromZone(t.sheetId,r),config:n,type:`dynamic`}}updateTable(e){let t=this.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return;let n=e.newTableRange?this.getters.getRangeFromRangeData(e.newTableRange):void 0;if(n){let t=this.getters.getMergesInZone(e.sheetId,n.zone);this.dispatch(`REMOVE_MERGE`,{sheetId:e.sheetId,target:t})}let r=n||t.range,i=this.updateTableConfig(e.config,t.config),a=e.tableType??t.type;if(a===`dynamic`&&t.type!==`dynamic`||a!==`dynamic`&&t.type===`dynamic`){let n=a===`dynamic`?this.createDynamicTable(t.id,r,i):this.createStaticTable(t.id,a,r,i);this.history.update(`tables`,e.sheetId,t.id,n)}else{let n=t.type===`dynamic`?this.updateDynamicTable(t,r,i):this.updateStaticTable(t,r,i,a);this.history.update(`tables`,e.sheetId,t.id,n)}}updateStaticTable(e,t,n,r=e.type){if(r===`dynamic`)throw Error(`Cannot use updateStaticTable to update a dynamic table`);let i=t||e.range,a=i.zone,o=this.updateTableConfig(n,e.config),s=o||e.config,c=[];if(t||o&&`numberOfHeaders`in o)for(let t of S(a.left,a.right+1)){let n=a.top===e.range.zone.top?e.filters.find(e=>e.col===t):void 0,r={...a,left:t,right:t},o=n?.id||this.consumeNextId();c.push(this.createFilterFromZone(o,i.sheetId,r,s))}return{...e,range:i,config:s,filters:c.length?c:e.filters,type:r}}updateDynamicTable(e,t,n){let r=t?this.getters.getRangeFromZone(t.sheetId,Ar(t.zone)):e.range,i=n||e.config;return{...e,range:r,config:i}}updateTableConfig(e,t){if(!e)return t;let n={...t,...e};return e.numberOfHeaders===0?n.hasFilters=!1:e.hasFilters===!0&&(n.numberOfHeaders||=1),n}createFilterFromZone(e,t,n,r){return Lz(e,this.getters.getRangeFromZone(t,n),r,this.getters.getRangeFromZone)}copyStaticTableForSheet(e,t){let n=this.getters.getRangeFromZone(e,t.range.zone),r=t.filters.map(n=>{let r=this.getters.getRangeFromZone(e,n.rangeWithHeaders.zone);return Lz(n.id,r,t.config,this.getters.getRangeFromZone)});return{id:t.id,range:n,filters:r,config:b(t.config),type:t.type}}copyDynamicTableForSheet(e,t){let n=this.getters.getRangeFromZone(e,t.range.zone);return{id:t.id,range:n,config:b(t.config),type:`dynamic`}}applyRangeChangeOnTable(e,t,n){let r=n(t.range),i;switch(r.changeType){case`REMOVE`:this.history.update(`tables`,e,t.id,void 0);return;case`NONE`:return;default:i=r.range}if(t.type===`dynamic`){let n=this.updateDynamicTable(t,i);this.history.update(`tables`,e,t.id,n);return}let a=[];for(let e of t.filters){let r=n(e.rangeWithHeaders);switch(r.changeType){case`REMOVE`:continue;case`NONE`:a.push(e);break;default:let n=r.range,i=Lz(e.id,n,t.config,this.getters.getRangeFromZone);a.push(i)}}let o=i.zone;if(a.length<br(o).numberOfCols){for(let n=o.left;n<=o.right;n++)if(!a.find(e=>e.col===n)){let r=this.consumeNextId(),i={...o,left:n,right:n};a.push(this.createFilterFromZone(r,e,i,t.config))}a.sort((e,t)=>e.col-t.col)}let s=this.createStaticTable(t.id,t.type,i,t.config,a);this.history.update(`tables`,e,t.id,s)}consumeNextId(){let e=`${this.nextTableId}`;return this.history.update(`nextTableId`,this.nextTableId+1),e}import(e){for(let t of e.sheets)for(let e of t.tables||[]){let n=this.consumeNextId(),r=e.config||OA,i=this.getters.getRangeFromSheetXC(t.id,e.range),a=e.type||`static`,o=a===`dynamic`?this.createDynamicTable(n,i,r):this.createStaticTable(n,a,i,r);this.history.update(`tables`,t.id,o.id,o)}}export(e){for(let t of e.sheets)for(let e of this.getCoreTables(t.id)){let n={range:cr(e.range.zone),type:e.type};w(e.config,OA)||(n.config=e.config),t.tables.push(n)}}exportForExcel(e){for(let t of e.sheets)for(let e of this.getCoreTables(t.id)){let n=cr(e.range.zone);t.tables.push({range:n,filters:[],config:e.config})}}},NV=class extends mV{static getters=[`getHeaderGroups`,`getGroupsLayers`,`getVisibleGroupLayers`,`getHeaderGroup`,`getHeaderGroupsInZone`,`isGroupFolded`,`isRowFolded`,`isColFolded`];groups={};allowDispatch(e){switch(e.type){case`GROUP_HEADERS`:{let{start:t,end:n,sheetId:r}=e;if(!this.getters.tryGetSheet(r))return`InvalidSheetId`;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,n])||t>n)return`InvalidHeaderGroupStartEnd`;if(this.findGroupWithStartEnd(e.sheetId,e.dimension,t,n))return`HeaderGroupAlreadyExists`;break}case`UNGROUP_HEADERS`:{let{start:t,end:n,sheetId:r}=e;if(!this.getters.tryGetSheet(r))return`InvalidSheetId`;if(!this.getters.doesHeadersExist(e.sheetId,e.dimension,[t,n])||t>n)return`InvalidHeaderGroupStartEnd`;break}case`UNFOLD_HEADER_GROUP`:case`FOLD_HEADER_GROUP`:if(!this.getters.tryGetSheet(e.sheetId))return`InvalidSheetId`;let t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);if(!t)return`UnknownHeaderGroup`;if(S(0,this.getters.getNumberHeaders(e.sheetId,e.dimension)).every(n=>n>=t.start&&n<=t.end||this.getters.isHeaderHiddenByUser(e.sheetId,e.dimension,n)))return`NotEnoughElements`;break}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`:{let t=b(this.groups[e.sheetId]);this.history.update(`groups`,e.sheetIdTo,t);break}case`DELETE_SHEET`:{let t={...this.groups};delete t[e.sheetId],this.history.update(`groups`,t);break}case`ADD_COLUMNS_ROWS`:let t=jt(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`:{let t=this.findGroupWithStartEnd(e.sheetId,e.dimension,e.start,e.end);t&&this.unfoldHeaderGroup(e.sheetId,e.dimension,t);break}case`FOLD_HEADER_GROUP`:{let 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`:{let t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(let n of t)this.unfoldHeaderGroup(e.sheetId,e.dimension,n);break}case`FOLD_ALL_HEADER_GROUPS`:{let t=this.getters.getHeaderGroups(e.sheetId,e.dimension);for(let n of t)this.foldHeaderGroup(e.sheetId,e.dimension,n);break}case`FOLD_HEADER_GROUPS_IN_ZONE`:case`UNFOLD_HEADER_GROUPS_IN_ZONE`:{let t=e.type===`UNFOLD_HEADER_GROUPS_IN_ZONE`?`unfold`:`fold`,n=this.getGroupsLayers(e.sheetId,e.dimension);t===`fold`&&n.reverse();let r=n.flat(),i=e.dimension===`ROW`?e.zone.top:e.zone.left,a=e.dimension===`ROW`?e.zone.bottom:e.zone.right,o=new Set;for(let e=i;e<=a;e++){let n=r.filter(t=>t.start-1<=e&&e<=t.end);for(let e of n)if(!(t===`fold`&&e.isFolded||t===`unfold`&&!e.isFolded)){o.add(e);break}}for(let n of o)t===`unfold`?this.unfoldHeaderGroup(e.sheetId,e.dimension,n):this.foldHeaderGroup(e.sheetId,e.dimension,n);break}}}getHeaderGroups(e,t){return this.groups[e][t]}getHeaderGroup(e,t,n,r){return this.getHeaderGroups(e,t).find(e=>e.start===n&&e.end===r)}getHeaderGroupsInZone(e,t,n){return this.getHeaderGroups(e,t).filter(e=>{let r=t===`ROW`?n.top:n.left,i=t===`ROW`?n.bottom:n.right;return this.doGroupOverlap(e,r,i)})}getGroupsLayers(e,t){let n=this.getHeaderGroups(e,t);return this.bricksFallingAlgorithm(n,0,0)}getVisibleGroupLayers(e,t){let n=this.getGroupsLayers(e,t);for(let r of n)for(let n=r.length-1;n>=0;n--){let i=r[n];i.start!==0&&S(i.start-1,i.end+1).every(n=>this.getters.isHeaderHiddenByUser(e,t,n))&&r.splice(n,1)}return n.filter(e=>e.length>0)}isGroupFolded(e,t,n,r){return this.getHeaderGroup(e,t,n,r)?.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,n,r=0){let i={};for(let t of e)i[this.getGroupId(t)]=t.isFolded;let a={};for(let t of e)for(let e=t.start;e<=t.end;e++)a[e]=a[e]?a[e]+1:1;for(let e=t;e<=n;e++)a[e]=a[e]?a[e]+r:r;let o=Math.max(...Object.values(a),0),s=Array.from({length:o},()=>[]),c=Math.max(n,...e.map(e=>e.end)),l=Math.min(t,...e.map(e=>e.start));for(let e=l;e<=c;e++){let t=a[e]||0;for(let n=0;n<t;n++){let t=s[n].at(-1);if(t&&Bt([t.end,e]))t.end++;else{let t={start:e,end:e};s[n].push(t)}}}for(let e of s)for(let t of e)t.isFolded=i[this.getGroupId(t)];return s}groupHeaders(e,t,n,r){let i=this.getHeaderGroups(e,t),a=this.bricksFallingAlgorithm(i,n,r,1).flat();this.history.update(`groups`,e,t,this.removeDuplicateGroups(a))}unGroupHeaders(e,t,n,r){let i=this.getHeaderGroups(e,t),a=this.bricksFallingAlgorithm(i,n,r,-1).flat();this.history.update(`groups`,e,t,this.removeDuplicateGroups(a))}moveGroupsOnHeaderInsertion(e,t,n,r){let i=this.groups[e][t];for(let a=0;a<i.length;a++){let o=i[a],[s,c]=jc(n,r,[o.start,o.end]);(s!==o.start||c!==o.end)&&this.history.update(`groups`,e,t,a,{...o,start:s,end:c})}}moveGroupsOnHeaderDeletion(e,t,n){let r=this.getHeaderGroups(e,t),i=[];for(let e of r){let t=Mc(n,S(e.start,e.end+1));t.length!==0&&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,n){return e.start<=n&&e.end>=t}removeDuplicateGroups(e){let t={};for(let n of e)t[this.getGroupId(n)]=n;return Object.values(t)}findGroupWithStartEnd(e,t,n,r){return this.getHeaderGroups(e,t).find(e=>e.start===n&&e.end===r)}foldHeaderGroup(e,t,n){let r=this.getGroupIndex(e,t,n.start,n.end);if(r===void 0)return;this.history.update(`groups`,e,t,r,`isFolded`,!0);let i=this.getters.getHeaderGroups(e,t);for(let r=0;r<i.length;r++){let a=i[r];a.start===n.start&&a.end<=n.end&&this.history.update(`groups`,e,t,r,`isFolded`,!0)}}unfoldHeaderGroup(e,t,n){let r=this.getGroupIndex(e,t,n.start,n.end);if(r===void 0)return;this.history.update(`groups`,e,t,r,`isFolded`,!1);let i=this.getters.getHeaderGroups(e,t);for(let r=0;r<i.length;r++){let a=i[r];a.start===n.start&&a.end>=n.end&&this.history.update(`groups`,e,t,r,`isFolded`,!1)}}getGroupIndex(e,t,n,r){let i=this.groups[e][t].findIndex(e=>e.start===n&&e.end===r);return i===-1?void 0:i}import(e){for(let t of e.sheets)if(this.groups[t.id]={ROW:[],COL:[]},t.headerGroups)for(let e of[`ROW`,`COL`])for(let n of t.headerGroups[e]||[])this.groups[t.id][e].push({...n})}export(e){for(let t of e.sheets)t.headerGroups=this.groups[t.id]}exportForExcel(e){for(let t of e.sheets)for(let e of[`ROW`,`COL`]){let n=this.getGroupsLayers(t.id,e);for(let r=0;r<n.length;r++){let i=n[r];for(let n of i){for(let i=n.start;i<=n.end;i++){let a=OO(t,e,i);a.outlineLevel=r+1,n.isFolded&&(a.isHidden=!0)}if(n.isFolded){let r=OO(t,e,n.end+1);r.collapsed=!0}}}}}},PV=class extends mV{static getters=[`getPivotCoreDefinition`,`getPivotDisplayName`,`getPivotId`,`getPivotFormulaId`,`getPivotIds`,`getMeasureCompiledFormula`,`getPivotName`,`isExistingPivot`,`getMeasureFullDependencies`];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?w(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`:if(!(e.pivotId in this.pivots))return`PivotIdNotFound`;break;case`DUPLICATE_PIVOT`:if(!(e.pivotId in this.pivots))return`PivotIdNotFound`}return`Success`}handle(e){switch(e.type){case`ADD_PIVOT`:{let{pivotId:t,pivot:n}=e;this.addPivot(t,n);break}case`INSERT_PIVOT`:{let{sheetId:t,col:n,row:r,pivotId:i,table:a}=e,o={sheetId:t,col:n,row:r},{cols:s,rows:c,measures:l,fieldsType:u}=a,d=new iz(s,c,l,u||{}),f=this.getPivotFormulaId(i);this.insertPivot(o,f,d);break}case`RENAME_PIVOT`:this.history.update(`pivots`,e.pivotId,`definition`,`name`,e.name);break;case`REMOVE_PIVOT`:{let t={...this.pivots};delete t[e.pivotId];let n=this.getPivotFormulaId(e.pivotId);this.history.update(`formulaIds`,n,void 0),this.history.update(`pivots`,t);break}case`DUPLICATE_PIVOT`:{let{pivotId:t,newPivotId:n}=e,r=b(this.getPivotCore(t).definition);r.name=e.duplicatedPivotName??r.name+` (copy)`,this.addPivot(n,r);break}case`UPDATE_PIVOT`:this.history.update(`pivots`,e.pivotId,`definition`,this.repairSortedColumn(b(e.pivot))),this.compileCalculatedMeasures(e.pivotId,e.pivot.measures);break}}adaptRanges({applyChange:e,adaptFormulaString:t}){for(let t in this.pivots){let n=b(this.pivots[t]?.definition);if(!n)continue;let r=bz.get(n.type)?.adaptRanges?.(this.getters,n,e);r&&!w(n,r)&&this.history.update(`pivots`,t,`definition`,r)}for(let n in this.compiledMeasureFormulas)for(let r in this.compiledMeasureFormulas[n]){let i=this.pivots[n]?.definition.measures.find(e=>e.id===r);if(!i||!i.computedBy)continue;let a=i.computedBy.sheetId,{formula:o,dependencies:s}=this.compiledMeasureFormulas[n][r];this.history.update(`compiledMeasureFormulas`,n,r,`formula`,`dependencies`,o.dependencies.map(t=>e(t).range)),this.history.update(`compiledMeasureFormulas`,n,i.id,`dependencies`,s.map(t=>e(t).range));let c=i.computedBy.formula,l=t(a,c);l!==c&&this.replaceMeasureFormula(n,i,l)}}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,t){if(!t.computedBy)throw Error(`Measure ${t.fieldName} is not computed by formula`);return this.compiledMeasureFormulas[e][t.id].formula}getMeasureFullDependencies(e,t){if(!t.computedBy)throw Error(`Measure ${t.fieldName} is not computed by formula`);return this.compiledMeasureFormulas[e][t.id].dependencies}addPivot(e,t,n=this.nextFormulaId.toString()){this.history.update(`pivots`,e,{definition:this.repairSortedColumn(b(t)),formulaId:n}),this.compileCalculatedMeasures(e,t.measures),this.history.update(`formulaIds`,n,e),this.history.update(`nextFormulaId`,this.nextFormulaId+1)}compileCalculatedMeasures(e,t){for(let n of t)if(n.computedBy){let t=this.compileMeasureFormula(n.computedBy.sheetId,n.computedBy.formula);this.history.update(`compiledMeasureFormulas`,e,n.id,`formula`,t)}for(let n of t)if(n.computedBy){let t=this.computeMeasureFullDependencies(e,n);this.history.update(`compiledMeasureFormulas`,e,n.id,`dependencies`,t)}}computeMeasureFullDependencies(e,t,n=new Set){let r=[],i=this.getPivotCoreDefinition(e),a=this.getMeasureCompiledFormula(e,t);n.add(t.id);for(let o of a.tokens){if(o.type!==`SYMBOL`)continue;let a=i.measures.find(e=>lt(e.id)===o.value&&t.id!==e.id);!a||n.has(a.id)||!a.computedBy||r.push(...this.computeMeasureFullDependencies(e,a,n))}return r.push(...a.dependencies.filter(e=>!e.invalidXc)),r}insertPivot(e,t,n){this.resizeSheet(e.sheetId,e,n);let r=n.getPivotCells();for(let n=0;n<r.length;n++)for(let i=0;i<r[n].length;i++){let a=r[n][i];this.dispatch(`UPDATE_CELL`,{sheetId:e.sheetId,col:e.col+n,row:e.row+i,content:yd(t,a)})}}resizeSheet(e,{col:t,row:n},r){let i=r.getNumberOfDataColumns()+1,a=this.getters.getNumberCols(e),o=a-t;o<i&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`COL`,base:a-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:i-o,position:`after`});let s=r.columns.length+r.rows.length,c=this.getters.getNumberRows(e),l=c-n;l<s&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`ROW`,base:c-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:s-l,position:`after`})}getPivotCore(e){let t=this.pivots[e];if(!t)throw Error(`Pivot with id ${e} not found`);return t}compileMeasureFormula(e,t){let n=bx(t),r=n.dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t));return{...n,dependencies:r}}replaceMeasureFormula(e,t,n){let r=this.pivots[e];if(!r)return;let i=r.definition.measures.indexOf(t);this.history.update(`pivots`,e,`definition`,`measures`,i,`computedBy`,{formula:n,sheetId:t.computedBy.sheetId})}checkSortedColumnInMeasures(e){e=this.repairSortedColumn(e);let t=e.measures.map(e=>e.id);return e.sortedColumn&&!t.includes(e.sortedColumn.measure)?`InvalidDefinition`:`Success`}checkDuplicatedMeasureIds(e){let t=new Set(e.measures.map(e=>e.id));return e.measures.length===t.size?`Success`:`InvalidDefinition`}repairSortedColumn(e){if(e.sortedColumn){let t=e.measures.find(t=>t.fieldName===e.sortedColumn?.measure);if(t)return{...e,sortedColumn:{...e.sortedColumn,measure:t.id}}}return e}import(e){if(e.pivots)for(let[t,n]of Object.entries(e.pivots))this.addPivot(t,n,n.formulaId);this.history.update(`nextFormulaId`,e.pivotNextId||fd(this.pivots)+1)}export(e){e.pivots={};for(let t in this.pivots)e.pivots[t]={...this.getPivotCoreDefinition(t),formulaId:this.getPivotFormulaId(t)};e.pivotNextId=this.nextFormulaId}},FV=class extends mV{static getters=[`getLocale`];locale=k;allowDispatch(e){switch(e.type){case`UPDATE_LOCALE`:return Il(e.locale)?`Success`:`InvalidLocale`}return`Success`}handle(e){switch(e.type){case`UPDATE_LOCALE`:let t=this.locale,n=e.locale;this.history.update(`locale`,n),this.changeCellsDateFormatWithLocale(t,n);break}}getLocale(){return this.locale}changeCellsDateFormatWithLocale(e,t){for(let n of this.getters.getSheetIds())for(let[r,i]of Object.entries(this.getters.getCells(n))){let n;if(i.format===e.dateFormat&&(n=t.dateFormat),i.format===e.timeFormat&&(n=t.timeFormat),i.format===$l(e)&&(n=$l(t)),n){let{col:e,row:t,sheetId:i}=this.getters.getCellPosition(r);this.dispatch(`UPDATE_CELL`,{col:e,row:t,sheetId:i,format:n})}}}import(e){this.locale=e.settings?.locale??k}export(e){e.settings={locale:this.locale}}},IV=class extends mV{allowDispatch(e){switch(e.type){case`ADD_PIVOT`:case`UPDATE_PIVOT`:let t=e.pivot;return this.checkDataSetValidity(t)}return`Success`}checkDataSetValidity(e){if(e.type===`SPREADSHEET`&&e.dataSet){let{zone:t,sheetId:n}=e.dataSet;return!n||!this.getters.tryGetSheet(n)||!t||!or(t)?`InvalidDataSet`:this.getters.checkZonesExistInSheet(n,[t])}return`Success`}},LV=class extends mV{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(!UA[e.templateName])return`InvalidTableStyle`;try{sn(e.primaryColor)}catch{return`InvalidTableStyle`}break}return`Success`}handle(e){switch(e.type){case`CREATE_TABLE_STYLE`:let t=WA(e.tableStyleName,e.templateName,e.primaryColor);this.history.update(`styles`,e.tableStyleId,t);break;case`REMOVE_TABLE_STYLE`:let n={...this.styles};delete n[e.tableStyleId],this.history.update(`styles`,n);for(let t of this.getters.getSheetIds())for(let n of this.getters.getCoreTables(t))n.config.styleId===e.tableStyleId&&this.dispatch(`UPDATE_TABLE`,{sheetId:t,zone:n.range.zone,config:{styleId:OA.styleId}});break}}getTableStyle(e){if(!this.styles[e])throw Error(`Table style ${e} does not exist`);return this.styles[e]}getTableStyles(){return this.styles}getNewCustomTableStyleName(){return $t(O(`Custom Table Style`),Object.values(this.styles).map(e=>e.displayName),{compute:(e,t)=>`${e} ${t}`,start:2})}isTableStyleEditable(e){return!HA[e]}import(e){for(let e in HA)this.styles[e]=HA[e];for(let t in e.customTableStyles){let n=e.customTableStyles[t];this.styles[t]=WA(n.displayName,n.templateName,n.primaryColor)}}export(e){let t={};for(let e in this.styles)HA[e]||(t[e]={displayName:this.styles[e].displayName,templateName:this.styles[e].templateName,primaryColor:this.styles[e].primaryColor});e.customTableStyles=t}},RV=class extends pV{getters;constructor({getters:e,stateObserver:t}){super(t),this.getters=e}};let zV=new h;zV.add(`pivots`,e=>{for(let t of e.getPivotIds())e.getPivot(t).markAsDirtyForEvaluation?.()});let BV=ix.mapping;function VV(e,t,n){return new HV(e,t,n).getParameters()}var HV=class{getters;computeCell;evalContext;rangeCache={};constructor(e,t,n){this.getters=t,this.computeCell=n,this.evalContext=Object.assign(Object.create(BV),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){let n=this.getRangeError(e);if(n)return n;if(t)return{value:oc(this.getters.getSheetName(e.sheetId),cr(e.zone))};let r={sheetId:e.sheetId,col:e.zone.left,row:e.zone.top};return this.computeCell(r)}range(e){let t=this.getRangeError(e);if(t)return[[t]];let n=e.sheetId,r=e.zone,i=hr(r,this.getters.getSheetZone(n));if(!i)return[[]];let{top:a,left:o,bottom:s,right:c}=r,l=`${n}-${a}-${o}-${s}-${c}`;if(l in this.rangeCache)return this.rangeCache[l];let u=i.bottom-i.top+1,d=i.right-i.left+1,f=Array(d);for(let e=i.left;e<=i.right;e++){let t=e-i.left;f[t]=Array(u);for(let r=i.top;r<=i.bottom;r++){let a=r-i.top;f[t][a]=this.computeCell({sheetId:n,col:e,row:r})}}return this.rangeCache[l]=f,f}getRangeError(e){if(!or(e.zone))return new xa;if(e.invalidSheetName)return new M(O(`Invalid sheet name: %s`,e.invalidSheetName))}},UV=d(c(((e,t)=>{(function(n,r){typeof e==`object`&&t!==void 0?t.exports=r():typeof define==`function`&&define.amd?define(r):(n||=self).RBush=r()})(e,function(){"use strict";function e(e,r,i,a,o){(function e(n,r,i,a,o){for(;a>i;){if(a-i>600){var s=a-i+1,c=r-i+1,l=Math.log(s),u=.5*Math.exp(2*l/3),d=.5*Math.sqrt(l*u*(s-u)/s)*(c-s/2<0?-1:1);e(n,r,Math.max(i,Math.floor(r-c*u/s+d)),Math.min(a,Math.floor(r+(s-c)*u/s+d)),o)}var f=n[r],p=i,m=a;for(t(n,i,r),o(n[a],f)>0&&t(n,i,a);p<m;){for(t(n,p,m),p++,m--;o(n[p],f)<0;)p++;for(;o(n[m],f)>0;)m--}o(n[i],f)===0?t(n,i,m):t(n,++m,a),m<=r&&(i=m+1),r<=m&&(a=m-1)}})(e,r,i||0,a||e.length-1,o||n)}function t(e,t,n){var r=e[t];e[t]=e[n],e[n]=r}function n(e,t){return e<t?-1:+(e>t)}var r=function(e){e===void 0&&(e=9),this._maxEntries=Math.max(4,e),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()};function i(e,t,n){if(!n)return t.indexOf(e);for(var r=0;r<t.length;r++)if(n(e,t[r]))return r;return-1}function a(e,t){o(e,0,e.children.length,t,e)}function o(e,t,n,r,i){i||=m(null),i.minX=1/0,i.minY=1/0,i.maxX=-1/0,i.maxY=-1/0;for(var a=t;a<n;a++){var o=e.children[a];s(i,e.leaf?r(o):o)}return i}function s(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 c(e,t){return e.minX-t.minX}function l(e,t){return e.minY-t.minY}function u(e){return(e.maxX-e.minX)*(e.maxY-e.minY)}function d(e){return e.maxX-e.minX+(e.maxY-e.minY)}function f(e,t){return e.minX<=t.minX&&e.minY<=t.minY&&t.maxX<=e.maxX&&t.maxY<=e.maxY}function p(e,t){return t.minX<=e.maxX&&t.minY<=e.maxY&&t.maxX>=e.minX&&t.maxY>=e.minY}function m(e){return{children:e,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function h(t,n,r,i,a){for(var o=[n,r];o.length;)if(!((r=o.pop())-(n=o.pop())<=i)){var s=n+Math.ceil((r-n)/i/2)*i;e(t,s,n,r,a),o.push(n,s,s,r)}}return r.prototype.all=function(){return this._all(this.data,[])},r.prototype.search=function(e){var t=this.data,n=[];if(!p(e,t))return n;for(var r=this.toBBox,i=[];t;){for(var a=0;a<t.children.length;a++){var o=t.children[a],s=t.leaf?r(o):o;p(e,s)&&(t.leaf?n.push(o):f(e,s)?this._all(o,n):i.push(o))}t=i.pop()}return n},r.prototype.collides=function(e){var t=this.data;if(!p(e,t))return!1;for(var n=[];t;){for(var r=0;r<t.children.length;r++){var i=t.children[r],a=t.leaf?this.toBBox(i):i;if(p(e,a)){if(t.leaf||f(e,a))return!0;n.push(i)}}t=n.pop()}return!1},r.prototype.load=function(e){if(!e||!e.length)return this;if(e.length<this._minEntries){for(var t=0;t<e.length;t++)this.insert(e[t]);return this}var n=this._build(e.slice(),0,e.length-1,0);if(this.data.children.length)if(this.data.height===n.height)this._splitRoot(this.data,n);else{if(this.data.height<n.height){var r=this.data;this.data=n,n=r}this._insert(n,this.data.height-n.height-1,!0)}else this.data=n;return this},r.prototype.insert=function(e){return e&&this._insert(e,this.data.height-1),this},r.prototype.clear=function(){return this.data=m([]),this},r.prototype.remove=function(e,t){if(!e)return this;for(var n,r,a,o=this.data,s=this.toBBox(e),c=[],l=[];o||c.length;){if(o||(o=c.pop(),r=c[c.length-1],n=l.pop(),a=!0),o.leaf){var u=i(e,o.children,t);if(u!==-1)return o.children.splice(u,1),c.push(o),this._condense(c),this}a||o.leaf||!f(o,s)?r?(n++,o=r.children[n],a=!1):o=null:(c.push(o),l.push(n),n=0,r=o,o=o.children[0])}return this},r.prototype.toBBox=function(e){return e},r.prototype.compareMinX=function(e,t){return e.minX-t.minX},r.prototype.compareMinY=function(e,t){return e.minY-t.minY},r.prototype.toJSON=function(){return this.data},r.prototype.fromJSON=function(e){return this.data=e,this},r.prototype._all=function(e,t){for(var n=[];e;)e.leaf?t.push.apply(t,e.children):n.push.apply(n,e.children),e=n.pop();return t},r.prototype._build=function(e,t,n,r){var i,o=n-t+1,s=this._maxEntries;if(o<=s)return a(i=m(e.slice(t,n+1)),this.toBBox),i;r||(r=Math.ceil(Math.log(o)/Math.log(s)),s=Math.ceil(o/s**(r-1))),(i=m([])).leaf=!1,i.height=r;var c=Math.ceil(o/s),l=c*Math.ceil(Math.sqrt(s));h(e,t,n,l,this.compareMinX);for(var u=t;u<=n;u+=l){var d=Math.min(u+l-1,n);h(e,u,d,c,this.compareMinY);for(var f=u;f<=d;f+=c){var p=Math.min(f+c-1,d);i.children.push(this._build(e,f,p,r-1))}}return a(i,this.toBBox),i},r.prototype._chooseSubtree=function(e,t,n,r){for(;r.push(t),!t.leaf&&r.length-1!==n;){for(var i=1/0,a=1/0,o=void 0,s=0;s<t.children.length;s++){var c=t.children[s],l=u(c),d=(f=e,p=c,(Math.max(p.maxX,f.maxX)-Math.min(p.minX,f.minX))*(Math.max(p.maxY,f.maxY)-Math.min(p.minY,f.minY))-l);d<a?(a=d,i=l<i?l:i,o=c):d===a&&l<i&&(i=l,o=c)}t=o||t.children[0]}var f,p;return t},r.prototype._insert=function(e,t,n){var r=n?e:this.toBBox(e),i=[],a=this._chooseSubtree(r,this.data,t,i);for(a.children.push(e),s(a,r);t>=0&&i[t].children.length>this._maxEntries;)this._split(i,t),t--;this._adjustParentBBoxes(r,i,t)},r.prototype._split=function(e,t){var n=e[t],r=n.children.length,i=this._minEntries;this._chooseSplitAxis(n,i,r);var o=this._chooseSplitIndex(n,i,r),s=m(n.children.splice(o,n.children.length-o));s.height=n.height,s.leaf=n.leaf,a(n,this.toBBox),a(s,this.toBBox),t?e[t-1].children.push(s):this._splitRoot(n,s)},r.prototype._splitRoot=function(e,t){this.data=m([e,t]),this.data.height=e.height+1,this.data.leaf=!1,a(this.data,this.toBBox)},r.prototype._chooseSplitIndex=function(e,t,n){for(var r,i,a,s,c,l,d,f=1/0,p=1/0,m=t;m<=n-t;m++){var h=o(e,0,m,this.toBBox),g=o(e,m,n,this.toBBox),_=(i=h,a=g,s=void 0,c=void 0,l=void 0,d=void 0,s=Math.max(i.minX,a.minX),c=Math.max(i.minY,a.minY),l=Math.min(i.maxX,a.maxX),d=Math.min(i.maxY,a.maxY),Math.max(0,l-s)*Math.max(0,d-c)),v=u(h)+u(g);_<f?(f=_,r=m,p=v<p?v:p):_===f&&v<p&&(p=v,r=m)}return r||n-t},r.prototype._chooseSplitAxis=function(e,t,n){var r=e.leaf?this.compareMinX:c,i=e.leaf?this.compareMinY:l;this._allDistMargin(e,t,n,r)<this._allDistMargin(e,t,n,i)&&e.children.sort(r)},r.prototype._allDistMargin=function(e,t,n,r){e.children.sort(r);for(var i=this.toBBox,a=o(e,0,t,i),c=o(e,n-t,n,i),l=d(a)+d(c),u=t;u<n-t;u++){var f=e.children[u];s(a,e.leaf?i(f):f),l+=d(a)}for(var p=n-t-1;p>=t;p--){var m=e.children[p];s(c,e.leaf?i(m):m),l+=d(c)}return l},r.prototype._adjustParentBBoxes=function(e,t,n){for(var r=n;r>=0;r--)s(t[r],e)},r.prototype._condense=function(e){for(var t=e.length-1,n=void 0;t>=0;t--)e[t].children.length===0?t>0?(n=e[t-1].children).splice(n.indexOf(e[t]),1):this.clear():a(e[t],this.toBBox)},r})}))(),1),WV=class{rTrees={};constructor(e=[]){let t={};for(let n of e){let e=n.boundingBox.sheetId;t[e]||(t[e]=[]),t[e].push(n)}for(let e in t)this.rTrees[e]=new GV,this.rTrees[e].load(t[e])}insert(e){let 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){let 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&&w(e.data,t.data)}},GV=class extends UV.default{toBBox({boundingBox:e}){let 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}},KV=class{createEmptyPositionSet;dependencies=new YF;rTree;constructor(e,t=[]){this.createEmptyPositionSet=e,this.rTree=new WV(t)}removeAllDependencies(e){let t=this.dependencies.get(e);if(t){for(let e of t)this.rTree.remove(e);this.dependencies.delete(e)}}addDependencies(e,t){let n=t.map(({sheetId:t,zone:n})=>({data:e,boundingBox:{zone:n,sheetId:t}}));for(let e of n)this.rTree.insert(e);let r=this.dependencies.get(e);r?r.push(...n):this.dependencies.set(e,n)}getCellsDependingOn(e,t){let n=this.createEmptyPositionSet(),r=Array.from(e).reverse();for(;r.length>0;){let e=r.pop(),i=e.zone,a=e.sheetId;for(let e=i.left;e<=i.right;e++)for(let t=i.top;t<=i.bottom;t++)n.add({sheetId:a,col:e,row:t});let o=this.rTree.search(e).map(e=>e.data),s={};for(let e of o)!n.has(e)&&!t.has(e)&&(s[e.sheetId]||(s[e.sheetId]=[]),s[e.sheetId].push(E(e)));for(let e in s){let t=Yn(s[e],[]);r.push(...t.map(t=>({sheetId:e,zone:t})))}}for(let t of e){let e=t.zone,r=t.sheetId;for(let t=e.left;t<=e.right;t++)for(let i=e.top;i<=e.bottom;i++)n.delete({sheetId:r,col:t,row:i})}return n}},qV=class extends Uint32Array{columnOffset=0;cols=0;rows=0;static create(e,t){let n=JV(t),r=e<<n>>5,i=new this(r+1);return i.columnOffset=n,i.cols=t,i.rows=e,i}getValue(e){let[t,n]=this.getCoordinates(e);return this[t]>>n&1}setValue(e,t){let[n,r]=this.getCoordinates(e),i=(this[n]>>r&1)==0&&t===1;return this[n]=this[n]&~(1<<r)|t<<r,i}isEmpty(){return!this.some(e=>e!==0)}fillAllPositions(){this.fill(-1>>>0)}clear(){this.fill(0)}getCoordinates(e){let{row:t,col:n}=e,r=(t<<this.columnOffset)+n,i=r>>5;return[i,r-(i<<5)]}};function JV(e){return e===0?-1/0:e<0?NaN:32-Math.clz32(--e)}var YV=class{sheets={};insertions=[];maxSize=0;constructor(e){for(let t in e){let n=e[t].cols,r=e[t].rows;this.maxSize+=n*r,this.sheets[t]=qV.create(r,n)}}add(e){this.sheets[e.sheetId].setValue(e,1)&&this.insertions.push(e)}addMany(e){for(let t of e)this.add(t)}delete(e){this.sheets[e.sheetId].setValue(e,0)}deleteMany(e){for(let t of e)this.delete(t)}has(e){return this.sheets[e.sheetId].getValue(e)===1}clear(){let e=[...this];this.insertions=[];for(let e in this.sheets)this.sheets[e].clear();return e}isEmpty(){if(this.insertions.length===0)return!0;for(let e in this.sheets)if(!this.sheets[e].isEmpty())return!1;return!0}fillAllPositions(){this.insertions=Array(this.maxSize);let e=0;for(let t in this.sheets){let n=this.sheets[t];n.fillAllPositions();for(let r=0;r<n.rows;r++)for(let i=0;i<n.cols;i++)this.insertions[e++]={sheetId:t,row:r,col:i}}}*[Symbol.iterator](){for(let e of this.insertions)this.sheets[e.sheetId].getValue(e)===1&&(yield e)}},XV=class{resultsToArrayFormulas=new WV;arrayFormulasToResults=new YF;searchFormulaPositionsSpreadingOn(e,t){return this.resultsToArrayFormulas.search({sheetId:e,zone:t}).map(e=>e.data)||ZV}getArrayResultZone(e){return this.arrayFormulasToResults.get(e)}removeNode(e){let t=this.arrayFormulasToResults.get(e);t&&(this.resultsToArrayFormulas.remove({boundingBox:{sheetId:e.sheetId,zone:t},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)}};let ZV=[],QV=Object.freeze(Ps(new ba)),$V=Object.freeze(Ps({value:null}));var eH=class{context;getters;compilationParams;evaluatedCells=new YF;formulaDependencies=kt(new KV(this.createEmptyPositionSet.bind(this)));blockedArrayFormulas=new YV({});spreadingRelations=new XV;constructor(e,t){this.context=e,this.getters=t,this.compilationParams=VV(this.context,this.getters,this.computeAndSave.bind(this))}getEvaluatedCell(e){return this.evaluatedCells.get(e)||$V}getSpreadZone(e,t={ignoreSpillError:!1}){let n=this.spreadingRelations.getArrayResultZone(e);if(!n)return;let r=this.evaluatedCells.get(e);return r?.type===`error`&&!(t.ignoreSpillError&&r?.value===j.SpilledBlocked)?E(e):pr(E(e),n)}getEvaluatedPositions(){return this.evaluatedCells.keys()}getEvaluatedPositionsInSheet(e){return this.evaluatedCells.keysForSheet(e)}getArrayFormulaSpreadingOn(e){if(this.getEvaluatedCell(e).type===`empty`)return;let t=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e.sheetId,E(e));return Array.from(t).find(e=>!this.blockedArrayFormulas.has(e))}isArrayFormulaSpillBlocked(e){return this.blockedArrayFormulas.has(e)}updateDependencies(e){this.formulaDependencies().removeAllDependencies(e);let t=this.getDirectDependencies(e);this.formulaDependencies().addDependencies(e,t)}addDependencies(e,t){this.formulaDependencies().addDependencies(e,t);for(let e of t)this.compilationParams.ensureRange(e)}updateCompilationParametersForIsolatedFormula(e){this.compilationParams=VV(this.context,this.getters,this.computeAndSave.bind(this)),this.compilationParams.evalContext.__originCellPosition=e,this.compilationParams.evalContext.updateDependencies=void 0,this.compilationParams.evalContext.addDependencies=void 0,this.compilationParams.evalContext.lookupCaches=this.compilationParams.evalContext.lookupCaches||{forwardSearch:new Map,reverseSearch:new Map}}updateCompilationParameters(){this.compilationParams=VV(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(){let e={};for(let t of this.getters.getSheetIds())e[t]={rows:this.getters.getNumberRows(t),cols:this.getters.getNumberCols(t)};return new YV(e)}evaluateCells(e){let t=performance.now(),n=this.createEmptyPositionSet();n.addMany(e);let r=this.getArrayFormulasImpactedByChangesOf(e);n.addMany(this.getCellsDependingOn(e)),n.addMany(r),n.addMany(this.getCellsDependingOn(r)),this.evaluate(n),console.debug(`evaluate Cells`,performance.now()-t,`ms`)}getArrayFormulasImpactedByChangesOf(e){let t=this.createEmptyPositionSet();for(let n of e){let e=this.getters.getCell(n)?.content,r=this.getArrayFormulaSpreadingOn(n);r!==void 0&&t.add(r),e||t.add(n)}let n=Cr(t);for(let e in n)for(let r of n[e])t.addMany(this.getArrayFormulasBlockedBy(e,r));return t}buildDependencyGraph(){this.blockedArrayFormulas=this.createEmptyPositionSet(),this.spreadingRelations=new XV,this.formulaDependencies=kt(()=>{let 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 KV(this.createEmptyPositionSet.bind(this),e)})}evaluateAllCells(){let e=performance.now();this.evaluatedCells=new YF,this.evaluate(this.getAllCells()),console.debug(`evaluate all cells`,performance.now()-e,`ms`)}evaluateFormulaResult(e,t,n){let r=bx(t),i=r.dependencies.map(t=>this.getters.getRangeFromSheetXC(e,t));return this.updateCompilationParametersForIsolatedFormula(n),this.evaluateCompiledFormula(e,{...r,dependencies:i})}evaluateCompiledFormula(e,t,n){try{let r=rH(t,this.compilationParams,e,this.buildSafeGetSymbolValue(n),this.compilationParams.evalContext.__originCellPosition);return A(r)?Xa(r,nH):nH(r)}catch(e){return ox(e,``)}}getAllCells(){let e=this.createEmptyPositionSet();return e.fillAllPositions(),e}getArrayFormulasBlockedBy(e,t){let n=this.createEmptyPositionSet(),r=this.spreadingRelations.searchFormulaPositionsSpreadingOn(e,t);n.addMany(r);let i=[...r].filter(e=>!this.blockedArrayFormulas.has(e));return i.length&&n.deleteMany(i),n.addMany(this.getCellsDependingOn(n)),n}nextPositionsToUpdate=new YV({});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();let 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){let n=e[t];if(this.nextPositionsToUpdate.has(n))continue;let r=this.computeCell(n);r!==$V&&this.evaluatedCells.set(n,r)}zV.getAll().forEach(e=>e(this.getters))}t>=30&&console.warn(`Maximum iteration reached while evaluating cells`)}computeCell(e){let t=this.evaluatedCells.get(e);if(t)return t;this.blockedArrayFormulas.has(e)||this.invalidateSpreading(e),this.spreadingRelations.isArrayFormula(e)&&this.spreadingRelations.removeNode(e);let n=this.getters.getCell(e);if(n===void 0)return $V;let r=n.id,i={format:n.format,locale:this.getters.getLocale()};try{return this.cellsBeingComputed.has(r)?QV:(this.cellsBeingComputed.add(r),n.isFormula?this.computeFormulaCell(e,n):Ms(n,i))}catch(e){return e.value=e?.value||j.GenericError,e.message=e?.message||lx,e.errorOriginPosition=e?.errorOriginPosition,Ps(e)}finally{this.cellsBeingComputed.delete(r)}}computeAndSave(e){let t=this.computeCell(e);return this.evaluatedCells.has(e)||this.evaluatedCells.set(e,t),t}computeFormulaCell(e,t){let n=rH(t.compiledFormula,this.compilationParams,e.sheetId,this.buildSafeGetSymbolValue(),e);if(!A(n)){let r=Ps(nH(n),this.getters.getLocale(),t);return r.type===`error`&&(r.errorOriginPosition=n.errorOriginPosition??e),r}this.assertSheetHasEnoughSpaceToSpreadFormulaResult(e,n);let r=n.length,i=n[0].length;if(i===0)return Ps({value:0},this.getters.getLocale(),t);if(i===1&&r===1)return Ps(nH(n[0][0]),this.getters.getLocale(),t);let a={top:e.row,bottom:e.row+i-1,left:e.col,right:e.col+r-1};return this.spreadingRelations.addRelation({resultZone:a,arrayFormulaPosition:e}),this.assertNoMergedCellsInSpreadZone(e,n),tH(r,i,this.checkCollision(e)),tH(r,i,this.spreadValues(e,n)),this.invalidatePositionsDependingOnSpread(e.sheetId,a),Ps(nH(n[0][0]),this.getters.getLocale(),t)}invalidatePositionsDependingOnSpread(e,t){let n=this.formulaDependencies().getCellsDependingOn(Sr(t).map(t=>({sheetId:e,zone:t})),this.nextPositionsToUpdate);n.delete({sheetId:e,col:t.left,row:t.top}),this.nextPositionsToUpdate.addMany(n)}assertSheetHasEnoughSpaceToSpreadFormulaResult({sheetId:e,col:t,row:n},r){let i=this.getters.getNumberCols(e),a=this.getters.getNumberRows(e),o=t+r.length<=i,s=n+r[0].length<=a;if(!(o&&s))throw o?new wa(O(`Result couldn't be automatically expanded. Please insert more rows.`)):s?new wa(O(`Result couldn't be automatically expanded. Please insert more columns.`)):new wa(O(`Result couldn't be automatically expanded. Please insert more columns and rows.`))}assertNoMergedCellsInSpreadZone({sheetId:e,col:t,row:n},r){if(this.getters.getMergesInZone(e,{top:n,bottom:n+r[0].length-1,left:t,right:t+r.length-1}).length!==0)throw new wa(O(`Merged cells found in the spill zone. Please unmerge cells before using array formulas.`))}checkCollision(e){let{sheetId:t,col:n,row:r}=e;return(i,a)=>{let o={sheetId:t,col:i+n,row:a+r};if(this.getters.getCell(o)?.content||this.getters.getEvaluatedCell(o).type!==`empty`)throw this.blockedArrayFormulas.add(e),new wa(O(`Array result was not expanded because it would overwrite data.`),o);this.blockedArrayFormulas.delete(e)}}spreadValues({sheetId:e,col:t,row:n},r){return(i,a)=>{let o={sheetId:e,col:i+t,row:a+n},s=this.getters.getCell(o),c=Ps(nH(r[i][a]),this.getters.getLocale(),s);c.type===`error`&&(c.errorOriginPosition=r[i][a].errorOriginPosition??o),this.evaluatedCells.set(o,c)}}invalidateSpreading(e){let t=this.spreadingRelations.getArrayResultZone(e);if(!t)return;for(let n=t.left;n<=t.right;n++)for(let r=t.top;r<=t.bottom;r++){let t={sheetId:e.sheetId,col:n,row:r};this.getters.getCell(t)?.content||this.evaluatedCells.delete(t)}let n=e.sheetId;this.invalidatePositionsDependingOnSpread(n,t),this.nextPositionsToUpdate.addMany(this.getArrayFormulasBlockedBy(n,t))}buildSafeGetSymbolValue(e){return t=>{if(this.symbolsBeingComputed.has(t))return QV;this.symbolsBeingComputed.add(t);try{return e?.(t)||new ya(O(`Invalid formula`))}finally{this.symbolsBeingComputed.delete(t)}}}getDirectDependencies(e){let t=this.getters.getCell(e);return t?.isFormula?t.compiledFormula.dependencies:[]}getCellsDependingOn(e){let t=[],n=Cr(e);for(let e in n)t.push(...n[e].map(t=>({sheetId:e,zone:t})));return this.formulaDependencies().getCellsDependingOn(t,this.nextPositionsToUpdate)}};function tH(e,t,n){for(let r=0;r<e;++r)for(let e=0;e<t;++e)r===0&&e===0||n(r,e)}function nH(e){return e.value===null||e.value===void 0?{...e,value:0}:e}function rH(e,t,n,r,i){let a=t.evalContext,o=a.__originCellPosition,s=a.__originSheetId;a.__originCellPosition=i,a.__originSheetId=n;let c=e.execute(e.dependencies,t.referenceDenormalizer,t.ensureRange,r,a);return a.__originCellPosition=o,a.__originSheetId=s,c}var iH=class extends RV{static getters=[`evaluateFormula`,`evaluateFormulaResult`,`evaluateCompiledFormula`,`getCorrespondingFormulaCell`,`getRangeFormattedValues`,`getRangeValues`,`getRangeFormats`,`getEvaluatedCell`,`getEvaluatedCells`,`getEvaluatedCellsInZone`,`getEvaluatedCellsPositions`,`getSpreadZone`,`getArrayFormulaSpreadingOn`,`isArrayFormulaSpillBlocked`,`isEmpty`];shouldRebuildDependenciesGraph=!0;evaluator;positionsToUpdate=[];constructor(e){super(e),this.evaluator=new eH(e.custom,this.getters)}beforeHandle(e){(ta.has(e.type)||ra.has(e.type))&&(this.shouldRebuildDependenciesGraph=!0)}handle(e){switch(e.type){case`UPDATE_CELL`:if(!(`content`in e||`format`in e)||this.shouldRebuildDependenciesGraph)return;let 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();break}}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,n){let r=this.evaluateFormulaResult(e,t,n);return A(r)?Xa(r,e=>e.value):r.value}evaluateFormulaResult(e,t,n){return this.evaluator.evaluateFormulaResult(e,t,n)}evaluateCompiledFormula(e,t,n){return this.evaluator.evaluateCompiledFormula(e,t,n)}getRangeFormattedValues(e){return this.getters.tryGetSheet(e.sheetId)===void 0?[]:this.mapVisiblePositions(e,e=>this.getters.getEvaluatedCell(e).formattedValue)}getRangeValues(e){return this.getters.tryGetSheet(e.sheetId)===void 0?[]:this.mapVisiblePositions(e,e=>this.getters.getEvaluatedCell(e).value)}getRangeFormats(e){let t=this.getters.tryGetSheet(e.sheetId);return t===void 0?[]: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 wr(t).map(({col:t,row:n})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}))}getSpreadZone(e,t={ignoreSpillError:!1}){return this.evaluator.getSpreadZone(e,t)}getArrayFormulaSpreadingOn(e){return this.evaluator.getArrayFormulaSpreadingOn(e)}isArrayFormulaSpillBlocked(e){return this.evaluator.isArrayFormulaSpillBlocked(e)}isEmpty(e,t){return wr(t).map(({col:t,row:n})=>this.getEvaluatedCell({sheetId:e,col:t,row:n})).every(e=>e.type===`empty`)}mapVisiblePositions(e,t){let{sheetId:n,zone:r}=e;return wr(r).reduce((e,r)=>{let{col:i,row:a}=r;return!this.getters.isColHidden(n,i)&&!this.getters.isRowHidden(n,a)&&e.push(t({sheetId:n,...r})),e},[])}exportForExcel(e){for(let t of e.sheets)t.cellValues={},t.formulaSpillRanges={};for(let t of this.evaluator.getEvaluatedPositions()){let n=this.evaluator.getEvaluatedCell(t),r=T(t.col,t.row),i=n.value,a=!1,o,s=!0,c=e.sheets.find(e=>e.id===t.sheetId),l=this.getCorrespondingFormulaCell(t);if(l){let u=this.getters.getCell(t);if(s=Ox(l.compiledFormula.tokens),a=s&&u?.content===l.content,!s&&i!==``){o=(i??``).toString();let t=n.format;if(t){let n=Hr(t,e.formats);c.formats[r]=n}}}let u=c.cells[r],d;d=s&&a&&l instanceof _V?l.contentWithFixedReferences:s?u:o,c.cells[r]=d,c.cellValues[r]=i===j.BadExpression?void 0:i;let f=this.getSpreadZone(t);f&&(c.formulaSpillRanges[r]=this.getters.getRangeString(this.getters.getRangeFromZone(t.sheetId,f),t.sheetId))}}getCorrespondingFormulaCell(e){let t=this.getters.getCell(e);if(t&&t.isFormula)return t.compiledFormula.isBadExpression?void 0:t;if(t&&t.content)return;let n=this.getArrayFormulaSpreadingOn(e);if(n===void 0)return;let r=this.getters.getCell(n);if(r?.isFormula)return r}};let aH=/"(#[0-9a-fA-F]{6})"/g;function oH(e){let t=[{leadColor:dn(255,0,0),colors:[]},{leadColor:dn(255,128,0),colors:[]},{leadColor:dn(128,128,0),colors:[]},{leadColor:dn(128,255,0),colors:[]},{leadColor:dn(0,255,0),colors:[]},{leadColor:dn(0,255,128),colors:[]},{leadColor:dn(0,255,255),colors:[]},{leadColor:dn(0,127,255),colors:[]},{leadColor:dn(0,0,255),colors:[]},{leadColor:dn(127,0,255),colors:[]},{leadColor:dn(128,0,128),colors:[]},{leadColor:dn(255,0,128),colors:[]}];for(let n of e.map(hn)){let e=500,r=0;t.forEach((t,i)=>{let a=sH(n,t.leadColor);e>a&&(e=a,r=i)}),t[r].colors.push(n)}return t.map(e=>e.colors.sort((e,t)=>_n(e).s-_n(t).s)).flat().map(mn)}function sH(e,t){return Math.sqrt((e.r-t.r)**2+(e.g-t.g)**2+(e.b-t.b)**2)}var cH=class extends RV{customColors={};shouldUpdateColors=!0;static getters=[`getCustomColors`];constructor(e){super(e),this.tryToAddColors(e.customColors??[])}handle(e){switch(e.type){case`START`:for(let e of this.getters.getSheetIds())for(let 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);break}}finalize(){this.shouldUpdateColors&&(this.history.update(`shouldUpdateColors`,!1),this.tryToAddColors(this.computeCustomColors()))}getCustomColors(){return oH(Object.keys(this.customColors))}computeCustomColors(){let e=[];for(let t of this.getters.getSheetIds())e=e.concat(this.getColorsFromCells(t),this.getFormattingColors(t),this.getTableColors(t));return[...new Set([...e])]}getColorsFromCells(e){let t=Object.values(this.getters.getCells(e)),n=new Set;for(let e of t)e.style?.textColor&&n.add(e.style.textColor),e.style?.fillColor&&n.add(e.style.fillColor);for(let t of this.getters.getBordersColors(e))n.add(t);return[...n]}getFormattingColors(e){let t=this.getters.getConditionalFormats(e),n=[];for(let e of t){let t=e.rule;t.type===`CellIsRule`?(n.push(t.style.textColor),n.push(t.style.fillColor)):t.type===`ColorScaleRule`&&(n.push(an(t.minimum.color)),n.push(t.midpoint?an(t.midpoint.color):void 0),n.push(an(t.maximum.color)))}return n.filter(C)}getChartColors(e){let t=this.getters.getChart(e);return t===void 0?[]:[...JSON.stringify(t.getDefinition()).matchAll(aH)].map(e=>e[1])}getTableColors(e){return this.getters.getTables(e).flatMap(e=>{let t=e.config,n=this.getters.getTableStyle(t.styleId);return[this.getTableStyleElementColors(n.wholeTable),t.numberOfHeaders>0?this.getTableStyleElementColors(n.headerRow):[],t.totalRow?this.getTableStyleElementColors(n.totalRow):[],t.bandedColumns?this.getTableStyleElementColors(n.firstColumnStripe):[],t.bandedColumns?this.getTableStyleElementColors(n.secondColumnStripe):[],t.bandedRows?this.getTableStyleElementColors(n.firstRowStripe):[],t.bandedRows?this.getTableStyleElementColors(n.secondRowStripe):[],t.firstColumn?this.getTableStyleElementColors(n.firstColumn):[],t.lastColumn?this.getTableStyleElementColors(n.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(C):[]}tryToAddColors(e){for(let t of e){if(!cn(t))continue;let e=sn(t);t&&!Fe.includes(e)&&this.history.update(`customColors`,e,!0)}}},lH=class extends RV{static getters=[`getChartRuntime`,`getStyleOfSingleCellChart`];charts={};createRuntimeChart=lD(this.getters);handle(e){if(ta.has(e.type)||ia.has(e.type)||na.has(e.type))for(let 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(let e in this.charts)this.getters.isChartDefined(e)||(this.charts[e]=void 0);break}}getChartRuntime(e){if(!this.charts[e]){let t=this.getters.getChart(e);if(!t)throw 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:Kx(e)};if(!t)return{background:ae,fontColor:Kx(ae)};let n=t.zone.left,r=t.zone.top,i=t.sheetId,a=this.getters.getCellComputedStyle({sheetId:i,col:n,row:r}),o=a.fillColor||`#FFFFFF`;return{background:o,fontColor:a.textColor||Kx(o)}}exportForExcel(e){for(let t of e.sheets){t.images||=[];let e=this.getters.getFigures(t.id),n=[];for(let r of e){if(!r||r.tag!==`chart`)continue;let e=r.id,i=this.getters.getChart(e)?.getDefinitionForExcel();if(i)n.push({...r,data:i});else{if(!this.getters.getChart(e))continue;let n=this.getters.getChartType(e),i=aw(this.getters.getChartRuntime(e),r,n);i&&t.images.push({...r,tag:`image`,data:{mimetype:`image/png`,path:i,size:{width:r.width,height:r.height}}})}}t.charts=n}}},uH=class extends RV{static getters=[`getConditionalIcon`,`getCellConditionalFormatStyle`,`getConditionalDataBar`];isStale=!0;computedStyles={};computedIcons={};computedDataBars={};handle(e){(ta.has(e.type)||ia.has(e.type)||e.type===`UPDATE_CELL`&&(`content`in e||`format`in e))&&(this.isStale=!0)}finalize(){if(this.isStale){for(let e of this.getters.getSheetIds())this.computedStyles[e]=kt(()=>this.getComputedStyles(e)),this.computedIcons[e]=kt(()=>this.getComputedIcons(e)),this.computedDataBars[e]=kt(()=>this.getComputedDataBars(e));this.isStale=!1}}getCellConditionalFormatStyle(e){let{sheetId:t,col:n,row:r}=e,i=this.computedStyles[t]();return i&&i[n]?.[r]}getConditionalIcon({sheetId:e,col:t,row:n}){let r=this.computedIcons[e]();return r&&r[t]?.[n]}getConditionalDataBar({sheetId:e,col:t,row:n}){let r=this.computedDataBars[e]();return r&&r[t]?.[n]}getComputedStyles(e){let t={};for(let n of this.getters.getConditionalFormats(e).reverse())switch(n.rule.type){case`ColorScaleRule`:for(let r of n.ranges)this.applyColorScale(e,r,n.rule,t);break;case`CellIsRule`:let r=n.rule.values.map(e=>e.startsWith(`=`)?bx(e):void 0);for(let i of n.ranges){let a=this.getters.getRangeFromSheetXC(e,i).zone;for(let i=a.top;i<=a.bottom;i++)for(let o=a.left;o<=a.right;o++){let s=this.rulePredicate[n.rule.type],c={sheetId:e,col:o,row:i},l=n.rule.values.map((t,n)=>{let s=r[n];return s?this.getters.getTranslatedCellFormula(e,o-a.left,i-a.top,s.tokens):t});s&&s(c,{...n.rule,values:l})&&(t[o]||(t[o]=[]),t[o][i]=Object.assign(t[o]?.[i]||{},n.rule.style))}}break}return t}getComputedIcons(e){let t={};for(let n of this.getters.getConditionalFormats(e).reverse())if(n.rule.type===`IconSetRule`)for(let r of n.ranges)this.applyIcon(e,r,n.rule,t);return t}getComputedDataBars(e){let t={};for(let n of this.getters.getConditionalFormats(e).reverse())if(n.rule.type===`DataBarRule`)for(let r of n.ranges)this.applyDataBar(e,r,n.rule,t);return t}parsePoint(e,t,n,r){let i=this.getters.getEvaluatedCellsInZone(e,this.getters.getRangeFromSheetXC(e,t).zone).filter(e=>e.type===`number`).map(e=>e.value);switch(n.type){case`value`:return r===`max`?Jt(i):Yt(i);case`number`:return Number(n.value);case`percentage`:let t=Yt(i);return t+(Jt(i)-t)*Number(n.value)/100;case`percentile`:return Bi(i,Number(n.value)/100,!0);case`formula`:let a=n.value&&this.getters.evaluateFormula(e,n.value);return typeof a==`number`?a:null;default:return null}}applyIcon(e,t,n,r){let i=this.parsePoint(e,t,n.lowerInflectionPoint),a=this.parsePoint(e,t,n.upperInflectionPoint);if(i===null||a===null||i>a)return;let o=this.getters.getRangeFromSheetXC(e,t).zone,s=[n.icons.upper,n.icons.middle,n.icons.lower];for(let t=o.top;t<=o.bottom;t++)for(let c=o.left;c<=o.right;c++){let o=this.getters.getEvaluatedCell({sheetId:e,col:c,row:t});if(o.type!==`number`)continue;let l=this.computeIcon(o.value,a,n.upperInflectionPoint.operator,i,n.lowerInflectionPoint.operator,s);r[c]||(r[c]=[]),r[c][t]=l}}computeIcon(e,t,n,r,i,a){return n===`ge`&&e>=t||n===`gt`&&e>t?a[0]:i===`ge`&&e>=r||i===`gt`&&e>r?a[1]:a[2]}applyDataBar(e,t,n,r){let i=this.getters.getRangeFromSheetXC(e,n.rangeValues||t),a=Jt(this.getters.getEvaluatedCellsInZone(e,i.zone).filter(e=>e.type===`number`).map(e=>e.value));if(a<=0)return;let o=n.color,s=this.getters.getRangeFromSheetXC(e,t).zone,c=i.zone;for(let t=s.top;t<=s.bottom;t++)for(let n=s.left;n<=s.right;n++){let i=n-s.left+c.left,l=t-s.top+c.top,u=this.getters.getEvaluatedCell({sheetId:e,col:i,row:l});!vr(i,l,c)||u.type!==`number`||u.value<=0||(r[n]||(r[n]=[]),r[n][t]={color:an(o),percentage:u.value*100/a})}}applyColorScale(e,t,n,r){let i=this.parsePoint(e,t,n.minimum,`min`),a=n.midpoint?this.parsePoint(e,t,n.midpoint):null,o=this.parsePoint(e,t,n.maximum,`max`);if(i===null||o===null||i>=o||a&&(i>=a||a>=o))return;let s=this.getters.getRangeFromSheetXC(e,t).zone,c=[{value:i,color:n.minimum.color}];n.midpoint&&a&&c.push({value:a,color:n.midpoint.color}),c.push({value:o,color:n.maximum.color});let l=In(c);for(let t=s.top;t<=s.bottom;t++)for(let n=s.left;n<=s.right;n++){let a=this.getters.getEvaluatedCell({sheetId:e,col:n,row:t});if(a.type===`number`){let e=x(a.value,i,o);r[n]||(r[n]=[]),r[n][t]=r[n]?.[t]||{},r[n][t].fillColor=l(e)}}}rulePredicate={CellIsRule:(e,t)=>{let n=this.getters.getEvaluatedCell(e);if(n.type===`error`)return!1;let[r,i]=t.values.map(t=>t.startsWith(`=`)?this.getters.evaluateFormula(e.sheetId,t)??``:Ns(t,k));if(A(r)||A(i))return!1;let a=n.value??``;switch(r??=``,i??=``,t.operator){case`IsEmpty`:return a.toString().trim()===``;case`IsNotEmpty`:return a.toString().trim()!==``;case`BeginsWith`:return r===``?!1:a.toString().startsWith(r.toString());case`EndsWith`:return r===``?!1:a.toString().endsWith(r.toString());case`Between`:return a>=r&&a<=i;case`NotBetween`:return!(a>=r&&a<=i);case`ContainsText`:return a.toString().indexOf(r.toString())>-1;case`NotContains`:return!a||a.toString().indexOf(r.toString())===-1;case`GreaterThan`:return a>r;case`GreaterThanOrEqual`:return a>=r;case`LessThan`:return a<r;case`LessThanOrEqual`:return a<=r;case`NotEqual`:return r===``?!1:a!==r;case`Equal`:return r===``?!0:a===r;default:console.warn(O(`Not implemented operator %s for kind of conditional formatting: %s`,t.operator,t.type))}return!1}}};let dH={isValid:!0};var fH=class extends RV{static getters=[`getDataValidationInvalidCriterionValueMessage`,`getInvalidDataValidationMessage`,`getValidationResultForCellValue`,`isCellValidCheckbox`,`isDataValidationInvalid`];validationResults={};handle(e){if(ta.has(e.type)||e.type===`EVALUATE_CELLS`||e.type===`UPDATE_CELL`&&(`content`in e||`format`in e)){this.validationResults={};return}switch(e.type){case`ADD_DATA_VALIDATION_RULE`:case`REMOVE_DATA_VALIDATION_RULE`:delete this.validationResults[e.sheetId];break}}isDataValidationInvalid(e){return!this.getValidationResultForCell(e).isValid}getInvalidDataValidationMessage(e){let t=this.getValidationResultForCell(e);return t.isValid?void 0:t.error}getDataValidationInvalidCriterionValueMessage(e,t){let n=$.get(e);return t.startsWith(`=`)?n.allowedValues===`onlyLiterals`?O(`The value must not be a formula`):this.isValidFormula(t)?void 0:K.CriterionError.validFormula:n.allowedValues===`onlyFormulas`?O(`The value must be a formula`):n.isCriterionValueValid(t)?void 0:n.criterionValueErrorString}isCellValidCheckbox(e){if(!this.getters.isMainCellPosition(e))return!1;let t=this.getters.getValidationRuleForCell(e);return!t||t.criterion.type!==`isBoolean`?!1:this.getValidationResultForCell(e).isValid}getValidationResultForCellValue(e,t){let n=this.getters.getValidationRuleForCell(t);if(!n)return dH;let r=this.getRuleErrorForCellValue(e,t,n);return r?{error:r,rule:n,isValid:!1}:dH}isValidFormula(e){return!bx(e).isBadExpression}getValidationResultForCell(e){let{col:t,row:n,sheetId:r}=e;return this.validationResults[r]||(this.validationResults[r]=this.computeSheetValidationResults(r)),this.validationResults[r][t]?.[n]?.()||dH}computeSheetValidationResults(e){let t={},n=this.getters.getDataValidationRules(e).map(e=>e.ranges);for(let e of gc(n.flat())){let{col:n,row:r}=e;t[n]||(t[n]=[]),t[n][r]=kt(()=>{let t=this.getters.getEvaluatedCell(e);return t.type===`empty`?dH:this.getValidationResultForCellValue(t.value,e)})}return t}getRuleErrorForCellValue(e,t,n){let{sheetId:r}=t,i=n.criterion,a=$.get(i.type),o=this.getCellOffsetInRule(t,n),s=this.getEvaluatedCriterionValues(r,o,i),c={...i,values:s};if(!a.isValueValid(e,c,this.getters,r))return a.getErrorString(c,this.getters,r)}getCellOffsetInRule(e,t){let n=t.ranges.find(t=>vr(e.col,e.row,t.zone));if(!n)throw Error(`The cell is not in any range of the rule`);return{col:e.col-n.zone.left,row:e.row-n.zone.top}}getEvaluatedCriterionValues(e,t,n){return n.values.map(n=>{if(!n.startsWith(`=`))return n;let r=bx(n),i=this.getters.getTranslatedCellFormula(e,t.col,t.row,r.tokens),a=this.getters.evaluateFormula(e,i);return a&&!A(a)?a.toString():``})}},pH=class extends RV{static getters=[`canCreateDynamicTableOnZones`,`doesZonesContainFilter`,`getFilter`,`getFilters`,`getTable`,`getTables`,`getTablesOverlappingZones`,`getFilterId`,`getFilterHeaders`,`isFilterHeader`];tables={};handle(e){if(ta.has(e.type)||e.type===`UPDATE_CELL`&&(`content`in e||`format`in e)||e.type===`EVALUATE_CELLS`){this.tables={};return}switch(e.type){case`CREATE_TABLE`:case`REMOVE_TABLE`:case`UPDATE_TABLE`:case`DELETE_CONTENT`:this.tables={};break}}finalize(){for(let e of this.getters.getSheetIds())this.tables[e]||(this.tables[e]=this.computeTables(e))}computeTables(e){let t=[],n=this.getters.getCoreTables(e);for(let e of n)e.type!==`dynamic`&&t.push(e);let r=[...t];for(let i of n){if(i.type!==`dynamic`)continue;let n=this.coreTableToTable(e,i),a=n.range.zone;for(let e of r){let t=e.range.zone;_r(a,t)&&(a=t.left>a.left?{...a,right:Math.min(a.right,t.left-1)}:{...a,bottom:Math.min(a.bottom,t.top-1)})}t.push({...n,range:this.getters.getRangeFromZone(e,a)})}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){let 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:n}){return this.getTables(e).find(e=>vr(t,n,e.range.zone))}getTablesOverlappingZones(e,t){return this.getTables(e).filter(e=>t.some(t=>_r(e.range.zone,t)))}doesZonesContainFilter(e,t){return this.getTablesOverlappingZones(e,t).some(e=>e.config.hasFilters)}getFilterHeaders(e){let t=[];for(let n of this.getTables(e)){if(!n.config.hasFilters)continue;let r=n.range.zone,i=r.top;for(let n=r.left;n<=r.right;n++)t.push({sheetId:e,col:n,row:i})}return t}isFilterHeader({sheetId:e,col:t,row:n}){return this.getFilterHeaders(e).some(e=>e.col===t&&e.row===n)}canCreateDynamicTableOnZones(e,t){if(!Fr(t))return!1;let n=pr(...t),r={col:n.left,row:n.top,sheetId:e},i=this.getters.getArrayFormulaSpreadingOn(r);if(!i){let e=this.getters.getEvaluatedCell(r);return e.value===j.SpilledBlocked&&!e.errorOriginPosition}else if(w(i,r)&&Nr(n)===1)return!0;return w(n,this.getters.getSpreadZone(i))}coreTableToTable(e,t){if(t.type!==`dynamic`)return t;let n=t.range.zone,r={sheetId:e,col:n.left,row:n.top},i=this.getters.getSpreadZone(r)??t.range.zone,a=this.getters.getRangeFromZone(e,i),o=this.getDynamicTableFilters(e,t,i);return{id:t.id,range:a,filters:o,config:t.config}}getDynamicTableFilters(e,t,n){let r=[],{top:i,bottom:a,left:o,right:s}=n;for(let n=o;n<=s;n++){let s=n-o,c={left:n,right:n,top:i,bottom:a},l=Lz(this.getDynamicTableFilterId(t.id,s),this.getters.getRangeFromZone(e,c),t.config,this.getters.getRangeFromZone);r.push(l)}return r}getDynamicTableFilterId(e,t){return e+`_`+t}isTableExcelExportable(e,t){return t.type===`dynamic`?!1:!wr(t.range.zone).some(t=>this.getters.getArrayFormulaSpreadingOn({sheetId:e,...t}))}exportForExcel(e){for(let t of e.sheets){let n=[];for(let r of t.tables){let i=ar(r.range),a={sheetId:t.id,col:i.left,row:i.top},o=this.getters.getCoreTable(a),s=this.getTable(a);if(!o||!s||this.isTableExcelExportable(t.id,o)){n.push(r);continue}t.styles=t.styles||{},t.borders=t.borders||{};for(let n of wr(s.range.zone)){let r={sheetId:t.id,...n},i=this.getters.getCellComputedStyle(r),a=this.getters.getCellComputedBorder(r),o=T(n.col,n.row);if(!Tt(i)){let n=Hr(i,e.styles);t.styles[o]=n}if(a){let n=Hr(a,e.borders);t.borders[o]=n}}}t.tables=n}}},mH=class extends RV{static getters=[`getRowSize`,`getHeaderSize`,`getMaxAnchorOffset`];tallestCellInRow={};ctx=document.createElement(`canvas`).getContext(`2d`);beforeHandle(e){switch(e.type){case`ADD_COLUMNS_ROWS`:if(e.dimension===`COL`)return;let t=jt(e.position,e.base),n=Array(e.quantity).fill(void 0),r=Ut(this.tallestCellInRow[e.sheetId],n,t);this.history.update(`tallestCellInRow`,e.sheetId,r);break}}handle(e){switch(e.type){case`START`:case`UPDATE_LOCALE`:for(let e of this.getters.getSheetIds())this.initializeSheet(e);break;case`CREATE_SHEET`:this.initializeSheet(e.sheetId);break;case`DUPLICATE_SHEET`:{let t=b(this.tallestCellInRow[e.sheetId]);this.history.update(`tallestCellInRow`,e.sheetIdTo,t);break}case`DELETE_SHEET`:let t={...this.tallestCellInRow};delete t[e.sheetId],this.history.update(`tallestCellInRow`,t);break;case`REMOVE_COLUMNS_ROWS`:{if(e.dimension===`COL`)return;let t=Ht(this.tallestCellInRow[e.sheetId],e.elements);this.history.update(`tallestCellInRow`,e.sheetId,t);break}case`RESIZE_COLUMNS_ROWS`:{let t=e.sheetId;if(e.dimension===`ROW`)for(let n of e.elements){let e=this.getRowTallestCell(t,n);this.history.update(`tallestCellInRow`,t,n,e)}else for(let n of S(0,this.getters.getNumberRows(t)))for(let r of e.elements)this.updateRowSizeForCellChange(t,n,r)}break;case`UPDATE_CELL`:this.updateRowSizeForCellChange(e.sheetId,e.row,e.col);break;case`ADD_MERGE`:case`REMOVE_MERGE`:for(let t of e.target)for(let n of wr(t))this.updateRowSizeForCellChange(e.sheetId,n.row,n.col)}}getRowSize(e,t){return Math.round(this.getters.getUserRowSize(e,t)??this.tallestCellInRow[e][t]?.size??23)}getMaxAnchorOffset(e,t,n){let{numberOfRows:r,numberOfCols:i}=this.getters.getSheetSize(e),a=0;for(;a<t&&r>0;r--)a+=this.getRowSize(e,r-1);let o=0;for(;o<n&&i>0;i--)o+=this.getters.getColSize(e,i-1);return{col:i,row:r,offset:{x:o-n,y:a-t}}}getHeaderSize(e,t,n){return this.getters.isHeaderHidden(e,t,n)?0:t===`ROW`?this.getRowSize(e,n):this.getters.getColSize(e,n)}updateRowSizeForCellChange(e,t,n){let r=this.tallestCellInRow[e]?.[t];if(r?.cell.col===n){let n=this.getRowTallestCell(e,t);this.history.update(`tallestCellInRow`,e,t,n)}let i=this.getCellHeight({sheetId:e,col:n,row:t});if(!(i<=23)&&(!r&&i>23||r&&i>r.size)){let r={cell:{sheetId:e,col:n,row:t},size:i};this.history.update(`tallestCellInRow`,e,t,r)}}initializeSheet(e){let t=[];for(let n=0;n<this.getters.getNumberRows(e);n++){let r=this.getRowTallestCell(e,n);t.push(r)}this.history.update(`tallestCellInRow`,e,t)}getCellHeight(e){if(this.isInMultiRowMerge(e))return 23;let t=this.getters.getCell(e),n=this.getters.getColSize(e.sheetId,e.col);return Lc(this.ctx,t,this.getters.getLocale(),n)}isInMultiRowMerge(e){let t=this.getters.getMerge(e);return!!t&&t.bottom!==t.top}getRowTallestCell(e,t){if(this.getters.getUserRowSize(e,t)!==void 0)return;let n=this.getters.getRowCells(e,t),r=0,i;for(let e=0;e<n.length;e++){let t=this.getters.getCellById(n[e]);if(!t)continue;let a=this.getters.getCellPosition(t.id),o=this.getCellHeight(a);o>r&&o>23&&(r=o,i={cell:a,size:o})}if(i&&i.size>23)return i}};let hH=`0.00%`;function gH(e){class t extends e{getters;pivotId;cache={};rankAsc={};rankDesc={};runningTotal={};runningTotalInPercent={};constructor(e,t,n){super(t,n),this.getters=n.getters,this.pivotId=e}markAsDirtyForEvaluation(){this.cache={},this.rankAsc={},this.rankDesc={},this.runningTotal={},this.runningTotalInPercent={},super.markAsDirtyForEvaluation?.()}getPivotCellValueAndFormat(e,t){return this.getMeasureDisplayValue(e,t)}_getPivotCellValueAndFormat(e,t){let n=`${e}-${t.map(e=>e.field+`=`+e.value).join(`,`)}`;if(this.cache[n])return this.cache[n];let r=this.getMeasure(e),i=r.computedBy?this.computeMeasure(r,t):super.getPivotCellValueAndFormat(e,t);return r.format?this.cache[n]={...i,format:r.format}:this.cache[n]=i,this.cache[n]}computeMeasure(e,t){if(!e.computedBy)return{value:0};let{columns:n,rows:r}=super.definition;if(e.aggregator&&n.length+r.length!==t.length){let n=this.getValuesToAggregate(e,t),r=dd[e.aggregator];if(!r)return{value:0};try{return r([n],this.getters.getLocale())}catch(t){return ox(t,e.aggregator.toUpperCase())}}let i=this.getters.getMeasureCompiledFormula(this.pivotId,e),a=this.getters.evaluateCompiledFormula(e.computedBy.sheetId,i,e=>{let{columns:n,rows:r}=this.definition;if(n.find(t=>t.nameWithGranularity===e)){let{colDomain:n}=ju(this,t),r=n.findIndex(t=>t.field===e);return r===-1?new Sa:this.getPivotHeaderValueAndFormat(n.slice(0,r+1))}if(r.find(t=>t.nameWithGranularity===e)){let{rowDomain:n}=ju(this,t),r=n.findIndex(t=>t.field===e);return r===-1?new Sa:this.getPivotHeaderValueAndFormat(n.slice(0,r+1))}return this.getPivotCellValueAndFormat(e,t)});return A(a)?a[0][0]:a}getValuesToAggregate(e,t){let{rowDomain:n,colDomain:r}=ju(this,t),i=super.getTableStructure(),a=[];if(r.length===0&&n.length<this.definition.rows.length&&this.definition.rows.length&&this.definition.columns.length){let t=this.treeToLeafDomains(i.getColTree()),r=this.getSubTreeMatchingDomain(i.getRowTree(),n),o=this.treeToLeafDomains(r);for(let r of t)for(let t of o)a.push(this._getPivotCellValueAndFormat(e.id,n.concat(t).concat(r)));return a}else if(n.length===this.definition.rows.length&&r.length===0){let t=i.getColTree(),o=this.getSubTreeMatchingDomain(t,r),s=this.treeToLeafDomains(o,r);for(let t of s)a.push(this._getPivotCellValueAndFormat(e.id,n.concat(t)));return a}else if(n.length===this.definition.rows.length&&r.length&&r.length<this.definition.columns.length){let t=this.getSubTreeMatchingDomain(i.getColTree(),r),o=this.treeToLeafDomains(t,r);for(let t of o)a.push(this._getPivotCellValueAndFormat(e.id,n.concat(t)));return a}else{let t=i.getRowTree(),o=this.getSubTreeMatchingDomain(t,n),s=this.treeToLeafDomains(o,n);for(let t of s)a.push(this._getPivotCellValueAndFormat(e.id,t.concat(r)));return a}}getSubTreeMatchingDomain(e,t,n=0){if(n>t.length)return[];if(t.length===n)return e;for(let r of e){let e=bd(this.definition.getDimension(r.field),t[n]?.value);if(r.field===t[n]?.field&&r.value===e)return this.getSubTreeMatchingDomain(r.children,t,n+1)}return[]}treeToLeafDomains(e,t=[]){let n=[];for(let r of e){let e=this.definition.getDimension(r.field),i=[...t,{field:r.field,value:r.value,type:e.type}];r.children.length===0?n.push(i):n.push(...this.treeToLeafDomains(r.children,i))}return n}getMeasureDisplayValue(e,t){let n=this.getMeasure(e),r=this._getPivotCellValueAndFormat(e,t);if(!n.display||n.display.type===`no_calculations`||r.message)return r;let i=n.display.fieldNameWithGranularity;if(i&&!this.isFieldInPivot(i))return{value:j.NotAvailable,message:O(`Field "%s" not found in pivot for measure display calculation`,i)};try{let e=n.display;switch(e.type){case`%_of_grand_total`:return this.asPercentOfGrandTotal(r,n);case`%_of_col_total`:return this.asPercentOfColumnTotal(r,n,t);case`%_of_row_total`:return this.asPercentOfRowTotal(r,n,t);case`%_of_parent_row_total`:return this.asPercentOfParentRowTotal(r,n,t);case`%_of_parent_col_total`:return this.asPercentOfParentColumnTotal(r,n,t);case`index`:return this.asIndex(r,n,t);case`%_of_parent_total`:return this.asPercentOfParentTotal(r,n,t,e);case`running_total`:return this.asRunningTotal(r,n,t,e,`running_total`);case`%_running_total`:return this.asRunningTotal(r,n,t,e,`%_running_total`);case`rank_asc`:return this.asRank(r,n,t,e,`asc`);case`rank_desc`:return this.asRank(r,n,t,e,`desc`);case`%_of`:return this.asPercentOf(r,n,t,e);case`difference_from`:return this.asDifferenceFrom(r,n,t,e);case`%_difference_from`:return this.asDifferenceFromInPercent(r,n,t,e)}return r}catch(e){return ox(e,`COMPUTE_MEASURE_DISPLAY_VALUE`)}}asPercentOfGrandTotal(e,t){let n=this.getGrandTotal(t.id);return n===0?{value:j.DivisionByZero}:{value:this.measureValueToNumber(e)/n,format:hH}}asPercentOfRowTotal(e,t,n){let r=this.getRowTotal(t.id,n);return r===0?{value:j.DivisionByZero}:{value:this.measureValueToNumber(e)/r,format:hH}}asPercentOfColumnTotal(e,t,n){let r=this.getColumnTotal(t.id,n);return r===0?{value:j.DivisionByZero}:{value:this.measureValueToNumber(e)/r,format:hH}}asPercentOfParentRowTotal(e,t,n){let r=ku(this,n),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,r));return i===0?{value:``}:{value:this.measureValueToNumber(e)/i,format:hH}}asPercentOfParentColumnTotal(e,t,n){let r=Au(this,n),i=this.measureValueToNumber(this._getPivotCellValueAndFormat(t.id,r));return i===0?{value:``}:{value:this.measureValueToNumber(e)/i,format:hH}}asPercentOfParentTotal(e,t,n,r){let{fieldNameWithGranularity:i}=r;if(!i)return e;if(!zu(i,n))return{value:``};let a=Lu(this,i,n),o=this._getPivotCellValueAndFormat(t.id,a),s=this.measureValueToNumber(o);return s===0?{value:``}:{value:this.measureValueToNumber(e)/s,format:hH}}asIndex(e,t,n){let r=this.measureValueToNumber(e),i=this.getRowTotal(t.id,n),a=this.getColumnTotal(t.id,n),o=this.getGrandTotal(t.id);return i===0||a===0?{value:j.DivisionByZero}:{value:r*o/(a*i),format:void 0}}asRunningTotal(e,t,n,r,i){let{fieldNameWithGranularity:a}=r;if(!a)return e;let o=i===`running_total`?this.runningTotal:this.runningTotalInPercent,s=o[t.id]?.[a];s||(s=this.computeRunningTotal(t,a,i),o[t.id]||(o[t.id]={}),o[t.id][a]=s);let{rowDomain:c,colDomain:l}=ju(this,n),u=Hu(l),d=Hu(c);return{value:s[u]?.[d]??``,format:i===`running_total`?e.format:hH}}asPercentOf(e,t,n,r){let{fieldNameWithGranularity:i,value:a}=r;if(a===void 0||!i)return e;if(!zu(i,n))return{value:``};let o=this.getComparisonValue(t,n,i,a),s=this.strictMeasureValueToNumber(e);return o===0||o===`sameValue`&&s===0?{value:j.DivisionByZero}:!o||o===`sameValue`&&!s?{value:``}:o===`sameValue`?{value:1,format:hH}:s===void 0?{value:j.NullError}:{value:s/o,format:hH}}asDifferenceFrom(e,t,n,r){let{fieldNameWithGranularity:i,value:a}=r;if(a===void 0||!i)return e;if(!zu(i,n))return{value:``};let o=this.getComparisonValue(t,n,i,a)||0;return o===`sameValue`?{value:``}:{value:this.measureValueToNumber(e)-o,format:e.format}}asDifferenceFromInPercent(e,t,n,r){let{fieldNameWithGranularity:i,value:a}=r;if(a===void 0||!i)return e;if(!zu(i,n))return{value:``};let o=this.getComparisonValue(t,n,i,a),s=this.strictMeasureValueToNumber(e);return o===0?{value:j.DivisionByZero}:!o||o===`sameValue`?{value:``}:s===void 0?{value:j.NullError}:{value:(s-o)/o,format:hH}}asRank(e,t,n,r,i){let{fieldNameWithGranularity:a}=r;if(!a)return e;if(!zu(a,n))return{value:``};let o=i===`asc`?this.rankAsc:this.rankDesc,s=o[t.id]?.[a];s||(s=this.computeRank(t,a,i),o[t.id]||(o[t.id]={}),o[t.id][a]=s);let{rowDomain:c,colDomain:l}=ju(this,n),u=Hu(l),d=Hu(c);return{value:s[u]?.[d]??``}}computeRank(e,t,n){let r={},i=Bu(this,t),a=i===`row`?`column`:`row`,o=this.getPivotValueCells(e.id);i===`column`&&(o=Qa(o));for(let s of o){let o=Hu(Mu(this,a,s[0].domain)),c=s.map(t=>({...t,value:this.strictMeasureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain)),rowDomain:Mu(this,i,t.domain)})).filter(e=>zu(t,e.rowDomain)),l=Object.groupBy(c,e=>Wu(e.rowDomain,t));for(let e in l)l[e]=Zt(l[e]||[],e=>e.value).filter(e=>e.value!==void 0).sort((e,t)=>n===`asc`?e.value-t.value:t.value-e.value);r[o]={};for(let e of c){let n=Hu(Mu(this,i,e.domain)),a=l[Wu(e.rowDomain,t)];if(!a)continue;let s=a.findIndex(t=>t.value===e.value);s!==-1&&(r[o][n]=s+1)}}return i===`row`?r:Qt(r)}computeRunningTotal(e,t,n){let r={},i=Bu(this,t),a=i===`row`?`column`:`row`,o=this.getPivotValueCells(e.id);i===`column`&&(o=Qa(o));for(let s of o){let o=Hu(Mu(this,a,s[0].domain));r[o]={};let c={},l=s.map(t=>({...t,rowDomain:Mu(this,i,t.domain),value:this.measureValueToNumber(this._getPivotCellValueAndFormat(e.id,t.domain))})).filter(e=>zu(t,e.rowDomain));for(let e of l){let n=Hu(e.rowDomain),i=Gu(e.rowDomain,t),a=(c[i]||0)+e.value;c[i]=a,r[o][n]=a}if(n===`%_running_total`)for(let e of l){let n=e.rowDomain,i=Hu(n),a=Gu(n,t),s=r[o][i]||0,l=c[a];r[o][i]=l?s/l:void 0}}return i===`row`?r:Qt(r)}getGrandTotal(e){let t=this._getPivotCellValueAndFormat(e,[]);return this.measureValueToNumber(t)}getRowTotal(e,t){let n=ju(this,t).rowDomain,r=this._getPivotCellValueAndFormat(e,n);return this.measureValueToNumber(r)}getColumnTotal(e,t){let n=ju(this,t).colDomain,r=this._getPivotCellValueAndFormat(e,n);return this.measureValueToNumber(r)}isFieldInPivot(e){return this.definition.columns.some(t=>t.nameWithGranularity===e)||this.definition.rows.some(t=>t.nameWithGranularity===e)}getComparisonValue(e,t,n,r){let i=r===`(previous)`||r===`(next)`?Vu(this,t,n,r):Ru(t,n,r);if(w(i,t))return`sameValue`;if(!i||!Pu(this,i))throw new Sa;let a=this._getPivotCellValueAndFormat(e.id,i);return this.strictMeasureValueToNumber(a)}getPivotValueCells(e){return this.getTableStructure().getPivotCells().map(t=>t.filter(t=>t.type===`VALUE`&&t.measure===e)).filter(e=>e.length>0)}measureValueToNumber(e){if(typeof e.value==`number`)return e.value;if(!e.value)return 0;throw Error(`Value ${e.value} is not a number`)}strictMeasureValueToNumber(e){if(typeof e.value==`number`)return e.value;if(e.value)throw Error(`Value ${e.value} is not a number`)}getTableStructure(){let e=super.getTableStructure();return this.sortTableStructure(e),e}sortTableStructure(e){if(!this.definition.sortedColumn||e.isSorted)return;let t=this.definition.sortedColumn.measure;Od(this.definition.sortedColumn,this)&&e.sort(t,this.definition.sortedColumn,(e,t)=>this._getPivotCellValueAndFormat(e,t))}}return t}let _H=[`ADD_PIVOT`,`UPDATE_PIVOT`,`REMOVE_PIVOT`];function vH(e){return _H.includes(e.type)}var yH=class extends RV{static getters=[`getPivot`,`getFirstPivotFunction`,`getPivotIdFromPosition`,`getPivotCellFromPosition`,`generateNewCalculatedMeasureName`,`isPivotUnused`,`isSpillPivotFormula`];pivots={};unusedPivots;custom;constructor(e){super(e),this.custom=e.custom}beforeHandle(e){switch(e.type){case`START`:for(let e of this.getters.getPivotIds())this.setupPivot(e)}}handle(e){if(ta.has(e.type))for(let e of this.getters.getPivotIds())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;let t=e.commands.filter(vH);for(let e of t){let t=e.pivotId;this.getters.isExistingPivot(t)&&this.setupPivot(t,{recreate:!0})}break}case`UPDATE_LOCALE`:vz();break}}getPivotIdFromPosition(e){let t=this.getters.getCorrespondingFormulaCell(e);if(t&&t.isFormula){let n=this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(n){let e=n.args[0]?.toString();return e&&this.getters.getPivotId(e)}}}isSpillPivotFormula(e){let t=this.getters.getCorrespondingFormulaCell(e);return t&&t.isFormula?this.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens)?.functionName===`PIVOT`:!1}getFirstPivotFunction(e,t){let n=SC(t);if(!n)return;let{functionName:r,args:i}=n;return{functionName:r,args:i.map(t=>{if(t.type===`EMPTY`)return;if(t.type===`STRING`||t.type===`BOOLEAN`||t.type===`NUMBER`)return t.value;let n=zv(t);return this.getters.evaluateFormula(e,n)})}}getPivotCellFromPosition(e){let t=this.getters.getCorrespondingFormulaCell(e);if(!t||!t.isFormula||CC(t.compiledFormula.tokens)===0)return az;let n=this.getters.getCellPosition(t.id),r=this.getters.getFirstPivotFunction(e.sheetId,t.compiledFormula.tokens);if(!r)return az;let{functionName:i,args:a}=r,o=a[0];if(!o)return az;let s=this.getters.getPivotId(o.toString());if(!s)return az;let c=this.getPivot(s);if(!c.isValid()||i===`PIVOT`&&!t.content.replaceAll(` `,``).toUpperCase().startsWith(`=PIVOT`))return az;try{if(i===`PIVOT`){let t=cu(a[2]),r=t===void 0?!0:L(t),i=cu(a[3]),o=i===void 0?!0:L(i),s=c.getTableStructure().getPivotCells(r,o),l=e.col-n.col,u=e.row-n.row;return s[l][u]}let t=e.row-n.row,r=e.col-n.col;if(a=a.map(e=>A(e)?e[r][t]:e),i===`PIVOT.HEADER`&&a.at(-2)===`measure`)return{type:`MEASURE_HEADER`,domain:c.parseArgsToPivotDomain(a.slice(1,-2).map(e=>({value:e}))),measure:a.at(-1)?.toString()||``};if(i===`PIVOT.HEADER`)return{type:`HEADER`,domain:c.parseArgsToPivotDomain(a.slice(1).map(e=>({value:e})))};let[o,...s]=a.slice(1);return{type:`VALUE`,domain:c.parseArgsToPivotDomain(s.map(e=>({value:e}))),measure:o?.toString()||``}}catch{return az}}generateNewCalculatedMeasureName(e){let t=e.map(e=>e.fieldName);return $t(O(`Calculated measure 1`),t,{compute:(e,t)=>O(`Calculated measure %s`,t)})}getPivot(e){if(!this.getters.isExistingPivot(e))throw 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}){let n=b(this.getters.getPivotCoreDefinition(e));if(e in this.pivots)t&&this.pivots[e].onDefinitionChange(n);else{let t=gH(bz.get(n.type).ui);this.pivots[e]=new t(e,this.custom,{definition:n,getters:this.getters})}}_getUnusedPivots(){if(this.unusedPivots!==void 0)return this.unusedPivots;let e=new Set(this.getters.getPivotIds());for(let t of this.getters.getSheetIds())for(let n in this.getters.getCells(t)){let t=this.getters.getCellPosition(n),r=this.getPivotIdFromPosition(t);if(r&&(e.delete(r),!e.size))return this.unusedPivots=[],[]}return this.unusedPivots=[...e],this.unusedPivots}},bH=class extends pV{static layers=[];getters;ui;selection;dispatch;canDispatch;constructor({getters:e,stateObserver:t,dispatch:n,canDispatch:r,uiActions:i,selection:a}){super(t),this.getters=e,this.ui=i,this.selection=a,this.dispatch=n,this.canDispatch=r}drawLayer(e,t){}},xH=class{cells;getters;index=0;direction;constructor(e,t,n){this.cells=e,this.getters=t,this.direction=n}next(){let e=this.cells[this.index++%this.cells.length],t=e.rule,{cellData:n,tooltip:r}=kC.get(t.type).apply(t,e.data,this.getters,this.direction);return{cellData:n,tooltip:r,origin:{col:e.data.col,row:e.data.row}}}},SH=class extends bH{static layers=[`Autofill`];static getters=[`getAutofillTooltip`];autofillZone;steps;lastCellSelected={};direction;tooltip;allowDispatch(e){switch(e.type){case`AUTOFILL_SELECT`:let t=this.getters.getActiveSheetId();return this.lastCellSelected.col=e.col===-1?this.lastCellSelected.col:x(e.col,0,this.getters.getNumberCols(t)),this.lastCellSelected.row=e.row===-1?this.lastCellSelected.row:x(e.row,0,this.getters.getNumberRows(t)),this.lastCellSelected.col!==void 0&&this.lastCellSelected.row!==void 0?`Success`:`InvalidAutofillSelection`}return`Success`}handle(e){switch(e.type){case`AUTOFILL`:this.autofill(!0);break;case`AUTOFILL_SELECT`:this.select(e.col,e.row);break;case`AUTOFILL_AUTO`:this.autofillAuto();break}}getAutofillTooltip(){return this.tooltip}autofill(e){if(!this.autofillZone||!this.steps||this.direction===void 0){this.tooltip=void 0;return}let t=this.getters.getSelectedZone(),n=this.autofillZone,r=[];switch(this.direction){case`down`:for(let e=t.left;e<=t.right;e++){let i=[];for(let n=t.top;n<=t.bottom;n++)i.push(T(e,n));let a=this.createGenerator(i);for(let t=n.top;t<=n.bottom;t++)r.push(this.computeNewCell(a,e,t))}break;case`up`:for(let e=t.left;e<=t.right;e++){let i=[];for(let n=t.bottom;n>=t.top;n--)i.push(T(e,n));let a=this.createGenerator(i);for(let t=n.bottom;t>=n.top;t--)r.push(this.computeNewCell(a,e,t))}break;case`left`:for(let e=t.top;e<=t.bottom;e++){let i=[];for(let n=t.right;n>=t.left;n--)i.push(T(n,e));let a=this.createGenerator(i);for(let t=n.right;t>=n.left;t--)r.push(this.computeNewCell(a,t,e))}break;case`right`:for(let e=t.top;e<=t.bottom;e++){let i=[];for(let n=t.left;n<=t.right;n++)i.push(T(n,e));let a=this.createGenerator(i);for(let t=n.left;t<=n.right;t++)r.push(this.computeNewCell(a,t,e))}break}if(e){let e={},t={},n={},i=this.getters.getActiveSheetId();for(let a of r)this.collectBordersData(a,e),this.autofillMerge(i,a),this.autofillCell(i,a),this.collectConditionalFormatsData(i,a,t),this.collectDataValidationsData(i,a,n);this.autofillBorders(i,e),this.autofillConditionalFormats(i,t),this.autofillDataValidations(i,n),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){let n=JSON.stringify(e.border);n in t||(t[n]=[]),t[n].push(E({col:e.col,row:e.row}))}collectConditionalFormatsData(e,t,n){let{originCol:r,originRow:i,col:a,row:o}=t,s=this.getters.getRulesByCell(e,r,i),c=T(a,o);for(let e of s)e.id in n||(n[e.id]=[]),n[e.id].push(c)}collectDataValidationsData(e,t,n){let{originCol:r,originRow:i,col:a,row:o}=t,s={sheetId:e,col:r,row:i},c=this.getters.getValidationRuleForCell(s);c&&(c.id in n||(n[c.id]=[]),n[c.id].push(E({col:a,row:o})))}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(let n in t){let r=n===`undefined`?void 0:JSON.parse(n);this.dispatch(`SET_BORDERS_ON_TARGET`,{sheetId:e,border:r,target:Yn(t[n])})}}autofillConditionalFormats(e,t){for(let n in t){let r=t[n],i=this.getters.getConditionalFormats(e).find(e=>e.id===n);if(!i)continue;let a=this.getters.getAdaptedCfRanges(e,i,r.map(ar),[]);a&&this.dispatch(`ADD_CONDITIONAL_FORMAT`,{cf:{id:i.id,rule:i.rule,stopIfTrue:i.stopIfTrue},ranges:a,sheetId:e})}}autofillDataValidations(e,t){for(let n in t){let r=t[n],i=this.getters.getDataValidationRule(e,n);if(!i)continue;let a=Yn(i.ranges.map(e=>e.zone).concat(r),[]);this.dispatch(`ADD_DATA_VALIDATION_RULE`,{rule:i,ranges:a.map(t=>this.getters.getRangeDataFromZone(e,t)),sheetId:e})}}select(e,t){let n=this.getters.getSelectedZone();if(vr(e,t,n)){this.autofillZone=void 0;return}switch(this.direction=this.getDirection(e,t),this.direction){case`up`:this.saveZone(t,n.top-1,n.left,n.right),this.steps=n.top-t;break;case`down`:this.saveZone(n.bottom+1,t,n.left,n.right),this.steps=t-n.bottom;break;case`left`:this.saveZone(n.top,n.bottom,e,n.left-1),this.steps=n.left-e;break;case`right`:this.saveZone(n.top,n.bottom,n.right+1,e),this.steps=e-n.right;break}this.autofill(!1)}autofillAuto(){let e=this.getters.getActivePosition(),t=this.getters.getTable(e),n=t?t.range.zone.bottom:this.getAutofillAutoLastRow(),r=this.getters.getSelectedZone();for(let t=r.bottom+1;t<=n;t++)if(this.getters.getEvaluatedCell({...e,row:t}).type!==`empty`){n=t-1;break}n>r.bottom&&(this.select(e.col,n),this.autofill(!0))}getAutofillAutoLastRow(){let e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId(),n=e.left,r=e.bottom;if(n>0){let e={sheetId:t,col:n-1,row:r};for(;this.getters.getEvaluatedCell(e).type!==`empty`;)r+=1,e={sheetId:t,col:n-1,row:r}}if(r===e.bottom&&(n=e.right,n<=this.getters.getNumberCols(t))){let e={sheetId:t,col:n+1,row:r};for(;this.getters.getEvaluatedCell(e).type!==`empty`;)r+=1,e={sheetId:t,col:n+1,row:r}}return r-1}computeNewCell(e,t,n){let{cellData:r,tooltip:i,origin:a}=e.next(),{content:o,style:s,border:c,format:l}=r;return this.tooltip=i,{originCol:a.col,originRow:a.row,col:t,row:n,content:o,style:s,border:c,format:l}}getRule(e,t){let n=AC.getAll().sort((e,t)=>e.sequence-t.sequence).find(n=>n.condition(e,t));return n&&this.direction&&n.generateRule(e,t,this.direction)}createGenerator(e){let t=[],n=[],r=this.getters.getActiveSheetId();for(let t of e){let{col:e,row:i}=Jn(t),a=this.getters.getCell({sheetId:r,col:e,row:i});n.push({col:e,row:i,cell:a,sheetId:r})}let i=n.map(e=>e.cell);for(let e of n){let n={type:`COPY_MODIFIER`};e&&e.cell&&(n=this.getRule(e.cell,i)||n);let r=this.getters.getCellBorder(e)||void 0;t.push({data:{...e,border:r},rule:n})}return new xH(t,this.getters,this.direction)}saveZone(e,t,n,r){this.autofillZone={top:e,bottom:t,left:n,right:r}}getDirection(e,t){let n=this.getters.getSelectedZone(),r={up:{number:n.top-t,value:`up`},down:{number:t-n.bottom,value:`down`},left:{number:n.left-e,value:`left`},right:{number:e-n.right,value:`right`}};if(Object.values(r).map(e=>+(e.number>0)).reduce((e,t)=>e+t)===1)return Object.values(r).find(e=>+(e.number>0)).value;let i=r.up.number>0?`up`:`down`,a=r.left.number>0?`left`:`right`;return Math.abs(r[i].number)>=Math.abs(r[a].number)?r[i].value:r[a].value}autofillMerge(e,t){let{originCol:n,originRow:r,col:i,row:a}=t,o={sheetId:e,col:i,row:a},s={sheetId:e,col:n,row:r};if(this.getters.isInMerge(o)&&!this.getters.isInMerge(s)){let t=this.getters.getMerge(o);t&&this.dispatch(`REMOVE_MERGE`,{sheetId:e,target:[t]})}let c=this.getters.getMerge(s);c?.left===n&&c?.top===r&&this.dispatch(`ADD_MERGE`,{sheetId:e,target:[{top:a,bottom:a+c.bottom-c.top,left:i,right:i+c.right-c.left}]})}drawLayer(e){if(!this.autofillZone)return;let{ctx:t,thinLineWidth:n}=e,{x:r,y:i,width:a,height:o}=this.getters.getVisibleRect(this.autofillZone);a>0&&o>0&&(t.strokeStyle=`black`,t.lineWidth=n,t.setLineDash([3]),t.strokeRect(r,i,a,o),t.setLineDash([]))}},CH=class extends bH{static getters=[`getAutomaticSums`];handle(e){switch(e.type){case`SUM_SELECTION`:let e=this.getters.getActiveSheetId(),{zones:t,anchor:n}=this.getters.getSelection();for(let r of t){let t=this.getAutomaticSums(e,r,n.cell);this.dispatchCellUpdates(e,t)}break}}getAutomaticSums(e,t,n){return this.shouldFindData(e,t)?this.sumAdjacentData(e,t,n):this.sumData(e,t)}sumData(e,t){let n=this.dimensionsToSum(e,t),r=this.sumDimensions(e,t,n).filter(({zone:t})=>!this.getters.isEmpty(e,t));return n.has(`ROW`)&&n.has(`COL`)&&r.push(this.sumTotal(t)),r}sumAdjacentData(e,t,n){let{col:r,row:i}=vr(n.col,n.row,t)?n:{col:t.left,row:t.top},a=this.findAdjacentData(e,r,i);return a?this.getters.isSingleCellOrMerge(e,t)||xr(pr(a,t))?[{position:{col:r,row:i},zone:a}]:this.sumDimensions(e,pr(a,t),this.transpose(this.dimensionsToSum(e,t))):[]}findAdjacentData(e,t,n){let r=this.getters.getSheet(e),i=this.getters.getMainCellPosition({sheetId:e,col:t,row:n}),a=this.findSuitableZoneToSum(r,i.col,i.row);if(a)return this.getters.expandZone(e,a)}findSuitableZoneToSum(e,t,n){let r=this.getters.getEvaluatedCell({sheetId:e.id,col:t,row:n-1}),i=this.getters.getEvaluatedCell({sheetId:e.id,col:t-1,row:n});if(this.isNumber(i)&&!this.isNumber(r))return this.findHorizontalZone(e,t,n);let a=this.findVerticalZone(e,t,n);if(this.isZoneValid(a))return a;let o=this.findHorizontalZone(e,t,n);if(this.isZoneValid(o))return o}findVerticalZone(e,t,n){let r={top:0,bottom:n-1,left:t,right:t},i=this.reduceZoneStart(e,r,r.bottom);return{...r,top:i}}findHorizontalZone(e,t,n){let r={top:n,bottom:n,left:0,right:t-1},i=this.reduceZoneStart(e,r,r.right);return{...r,left:i}}reduceZoneStart(e,t,n){let r=this.getters.getEvaluatedCellsInZone(e.id,t),i=S(n,-1,-1),a=Jt(i.filter(e=>r[e]&&!r[e].isAutoSummable)),o=dt(i.filter(e=>this.isNumber(r[e])))[0]||[];return Jt(o)<a?1/0:Yt(o)}shouldFindData(e,t){return this.getters.isEmpty(e,t)||this.getters.isSingleCellOrMerge(e,t)}isNumber(e){return e.type===`number`&&!(e.format&&ls(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){let n=new Set;return xr(t)?(n.add(br(t).numberOfCols===1?`COL`:`ROW`),n):(this.lastColIsEmpty(e,t)&&n.add(`ROW`),this.lastRowIsEmpty(e,t)&&n.add(`COL`),n.size===0&&n.add(`COL`),n)}sumDimensions(e,t,n){return[...n.has(`COL`)?this.sumColumns(t,e):[],...n.has(`ROW`)?this.sumRows(t,e):[]]}sumTotal(e){let{bottom:t,right:n}=e;return{position:{col:n,row:t},zone:{...e,top:t,right:n-1}}}sumColumns(e,t){let n=this.nextEmptyRow(t,{...e,bottom:e.bottom-1});return e={...e,bottom:Math.min(e.bottom,n.bottom-1)},wr(n).map(t=>({position:t,zone:{...e,right:t.col,left:t.col}}))}sumRows(e,t){let n=this.nextEmptyCol(t,{...e,right:e.right-1});return e={...e,right:Math.min(e.right,n.right-1)},wr(n).map(t=>({position:t,zone:{...e,top:t.row,bottom:t.row}}))}dispatchCellUpdates(e,t){for(let n of t){let{col:t,row:r}=n.position;this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:r,content:`=SUM(${this.getters.zoneToXC(e,n.zone)})`})}}nextEmptyRow(e,t){let n=t.bottom+1,{left:r,right:i}=t;for(;!this.getters.isEmpty(e,{bottom:n,top:n,left:r,right:i});)n++;return{...t,top:n,bottom:n}}nextEmptyCol(e,t){let n=t.right+1,{top:r,bottom:i}=t;for(;!this.getters.isEmpty(e,{left:n,right:n,top:r,bottom:i});)n++;return{...t,left:n,right:n}}transpose(e){return new Set([...e.values()].map(e=>e===`COL`?`ROW`:`COL`))}};let wH=new class extends h{add(e,t){return super.add(e,t),this}get(e){return this.content[e]}};FI.addTransformation(`ADD_COLUMNS_ROWS`,[`ADD_COLUMNS_ROWS`],FH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`ADD_COLUMNS_ROWS`],FH),FI.addTransformation(`DELETE_SHEET`,[`MOVE_RANGES`],OH),FI.addTransformation(`DELETE_FIGURE`,[`UPDATE_FIGURE`,`UPDATE_CHART`],kH),FI.addTransformation(`CREATE_SHEET`,[`CREATE_SHEET`],AH),FI.addTransformation(`ADD_MERGE`,[`ADD_MERGE`,`REMOVE_MERGE`],jH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`FREEZE_COLUMNS`,`FREEZE_ROWS`],MH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`FREEZE_COLUMNS`,`FREEZE_ROWS`],MH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`UPDATE_TABLE`],NH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`UPDATE_TABLE`],NH),FI.addTransformation(`REMOVE_TABLE_STYLE`,[`CREATE_TABLE`,`UPDATE_TABLE`],PH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`GROUP_HEADERS`,`UNGROUP_HEADERS`,`FOLD_HEADER_GROUP`,`UNFOLD_HEADER_GROUP`],IH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`GROUP_HEADERS`,`UNGROUP_HEADERS`,`FOLD_HEADER_GROUP`,`UNFOLD_HEADER_GROUP`],IH),FI.addTransformation(`REMOVE_PIVOT`,[`RENAME_PIVOT`,`DUPLICATE_PIVOT`,`INSERT_PIVOT`,`UPDATE_PIVOT`],DH),FI.addTransformation(`DELETE_SHEET`,[`ADD_PIVOT`,`UPDATE_PIVOT`],EH),FI.addTransformation(`ADD_COLUMNS_ROWS`,[`ADD_PIVOT`,`UPDATE_PIVOT`],TH),FI.addTransformation(`REMOVE_COLUMNS_ROWS`,[`ADD_PIVOT`,`UPDATE_PIVOT`],TH);function TH(e,t){if(e.pivot.type!==`SPREADSHEET`||e.pivot.dataSet?.sheetId!==t.sheetId)return e;let n=Bd(e.pivot.dataSet.zone,t),r=n?{...e.pivot.dataSet,zone:n}:void 0;return{...e,pivot:{...e.pivot,dataSet:r}}}function EH(e,t){return e.pivot.type===`SPREADSHEET`&&e.pivot.dataSet?.sheetId===t.sheetId?{...e,pivot:{...e.pivot,dataSet:void 0}}:e}function DH(e,t){if(e.pivotId!==t.pivotId)return e}function OH(e,t){let n=t.sheetId;if(!(e.targetSheetId===n||e.sheetId===n))return e}function kH(e,t){if(e.figureId!==t.figureId)return e}function AH(e,t){return e.sheetId===t.sheetId&&(e={...e,sheetId:`${e.sheetId}~`}),e.name===t.name?{...e,name:e.name?.match(/\d+/)?e.name.replace(/\d+/,e=>(parseInt(e)+1).toString()):`${e.name}~`,position:e.position+1}:e}function jH(e,t){if(e.sheetId!==t.sheetId)return e;let n=[];for(let r of e.target)t.target.every(e=>!_r(r,e))&&n.push(r);if(n.length)return{...e,target:n}}function MH(e,t){if(e.sheetId!==t.sheetId||(e.type===`FREEZE_COLUMNS`?`COL`:`ROW`)!==t.dimension)return e;let n=e.quantity;if(t.type===`REMOVE_COLUMNS_ROWS`){let e=[...t.elements].sort((e,t)=>t-e);for(let t of e)n>t&&n--}if(t.type===`ADD_COLUMNS_ROWS`){let e=t.position===`before`?t.base-1:t.base;n=n>e?n+t.quantity:n}return n>0?{...e,quantity:n}:void 0}function NH(e,t){if(e.sheetId!==t.sheetId)return e;let n=Bd(e.zone,t);if(!n)return;let r=e.newTableRange?Vd(e.newTableRange,t):void 0;return{...e,newTableRange:r,zone:n}}function PH(e,t){return e.config?.styleId===t.tableStyleId?{...e,config:{...e.config,styleId:OA.styleId}}:e}function FH(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let n;if(t.type===`REMOVE_COLUMNS_ROWS`?n=Mc(t.elements,[e.base])[0]:t.type===`ADD_COLUMNS_ROWS`&&(n=jc(jt(t.position,t.base),t.quantity,[e.base])[0]),n!==void 0)return{...e,base:n}}function IH(e,t){if(e.sheetId!==t.sheetId||e.dimension!==t.dimension)return e;let n=S(e.start,e.end+1),r=[];if(t.type===`REMOVE_COLUMNS_ROWS`?r=Mc(t.elements,n):t.type===`ADD_COLUMNS_ROWS`&&(r=jc(jt(t.position,t.base),t.quantity,n)),r.length!==0)return{...e,start:Math.min(...r),end:Math.max(...r)}}function LH(e,t){let n=e.content&&jx(e.sheetId,e.content,t);return{...e,content:n}}wH.add(`UPDATE_CELL`,LH);function RH(e,t){let n=e.cf.rule;if(e={...e,cf:{...e.cf}},n.type===`CellIsRule`)e.cf.rule={...n,values:n.values.map(n=>jx(e.sheetId,n,t))};else if(n.type===`ColorScaleRule`){let{minimum:r,maximum:i,midpoint:a}=n;e.cf.rule={...n,minimum:{...r,value:r.value&&jx(e.sheetId,r.value,t)},maximum:{...i,value:i.value&&jx(e.sheetId,i.value,t)},midpoint:a?{...a,value:jx(e.sheetId,a.value,t)}:void 0}}else if(n.type===`IconSetRule`){let{upperInflectionPoint:r,lowerInflectionPoint:i}=n;e.cf.rule={...n,upperInflectionPoint:{...r,value:jx(e.sheetId,r.value,t)},lowerInflectionPoint:{...i,value:jx(e.sheetId,i.value,t)}}}else n.type===`DataBarRule`&&(e.cf.rule={...n,rangeValues:n.rangeValues?Mx(e.sheetId,n.rangeValues,t).range:void 0});return e}wH.add(`ADD_CONDITIONAL_FORMAT`,RH);function zH(e,t){return e={...e,rule:{...e.rule,criterion:{...e.rule.criterion}}},e.rule.criterion.values=e.rule.criterion.values.map(n=>jx(e.sheetId,n,t)),e}wH.add(`ADD_DATA_VALIDATION_RULE`,zH);function BH(e,t){return e=b(e),e.pivot.measures.map(e=>{e.computedBy&&(e.computedBy.formula=jx(e.computedBy.sheetId,e.computedBy.formula,t))}),e}wH.add(`ADD_PIVOT`,BH),wH.add(`UPDATE_PIVOT`,BH),wH.add(`CREATE_CHART`,VH),wH.add(`UPDATE_CHART`,VH);function VH(e,t){return{...e,definition:dD(e.sheetId,e.definition,t)}}let HH=[{match:Yi,fn:qH},{match:Zi,fn:JH},{match:ea,fn:YH},{match:$i,fn:QH},{match:Xi,fn:ZH},{match:Qi,fn:XH}];function UH(e,t){let n=FI.getTransformation(e.type,t.type),r=n?n(e,t):KH(e,t);return r&&WH(r,t)}function WH(e,t){let n=wH.get(e.type);if(!n)return e;let r=yc(t);return r?n(e,r):e}function GH(e,t){let n=[...e],r=new Set(FI.getKeys());for(let e of t)(r.has(e.type)||bc.contains(e.type))&&(n=n.reduce((t,n)=>{let r=UH(n,e);return r&&t.push(r),t},[]));return n}function KH(e,t){for(let{match:n,fn:r}of HH)if(n(e)){let n=r(e,t);if(n===`SKIP_TRANSFORMATION`)continue;if(n===`IGNORE_COMMAND`)return;e=n}return e}function qH(e,t){if(!(`sheetId`in t))return e;let n=t.type===`DELETE_SHEET`&&t.sheetId;return e.sheetId===n?`IGNORE_COMMAND`:e.type===`CREATE_SHEET`||t.type===`CREATE_SHEET`||e.sheetId!==t.sheetId?e:`SKIP_TRANSFORMATION`}function JH(e,t){let n=qH(e,t);if(n!==`SKIP_TRANSFORMATION`)return n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e;let r=[];for(let n of e.target){let e=Bd(n,t);e&&r.push(e)}return r.length?{...e,target:r}:`IGNORE_COMMAND`}function YH(e,t){let n=qH(e,t);if(n!==`SKIP_TRANSFORMATION`)return n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e;let r=Bd(e.zone,t);return r?{...e,zone:r}:`IGNORE_COMMAND`}function XH(e,t){if(!(`sheetId`in t))return e;let n=e.ranges.map(e=>Vd(e,t)).filter(C);return n.length?{...e,ranges:n}:`IGNORE_COMMAND`}function ZH(e,t){let n=qH(e,t);if(n!==`SKIP_TRANSFORMATION`)return n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e;if(t.type!==`ADD_COLUMNS_ROWS`&&t.type!==`REMOVE_COLUMNS_ROWS`)return`SKIP_TRANSFORMATION`;if(t.dimension!==e.dimension)return e;let r=[];return t.type===`REMOVE_COLUMNS_ROWS`?r=Mc(t.elements,e.elements):t.type===`ADD_COLUMNS_ROWS`&&(r=jc(jt(t.position,t.base),t.quantity,e.elements)),r.length===0?`IGNORE_COMMAND`:{...e,elements:r}}function QH(e,t){let n=qH(e,t);return n===`SKIP_TRANSFORMATION`?t.type===`ADD_COLUMNS_ROWS`||t.type===`REMOVE_COLUMNS_ROWS`?$H(e,t):t.type===`ADD_MERGE`?eU(e,t):`SKIP_TRANSFORMATION`:n===`IGNORE_COMMAND`?`IGNORE_COMMAND`:e}function $H(e,t){let n=t.dimension===`COL`?`col`:`row`,r=e[n];if(t.type===`REMOVE_COLUMNS_ROWS`){let e=[...t.elements].sort((e,t)=>t-e);if(e.includes(r))return`IGNORE_COMMAND`;for(let t of e)r>=t&&r--}return t.type===`ADD_COLUMNS_ROWS`&&(r>t.base||r===t.base&&t.position===`before`)&&(r+=t.quantity),{...e,[n]:r}}function eU(e,t){for(let n of t.target)if(!(e.col===n.left&&e.row===n.top)&&vr(e.col,e.row,n))return`IGNORE_COMMAND`;return e}var tU=class{rootCommand;timestamp;id;clientId;_commands=[];_changes=[];constructor(e,t,n,r,i,a){this.rootCommand=r,this.timestamp=a,this.id=e,this.clientId=t,this._commands=[...n],this._changes=i?[...i]:[]}setChanges(e){this._changes=e}get commands(){return this._commands}get changes(){return this._changes}},nU=class extends Error{},rU=class extends Hd{revisions;transportService;serverRevisionId;clients={};clientId=`local`;debouncedMove;pendingMessages=[];waitingAck=!1;waitingUndoRedoAck=!1;isReplayingInitialRevisions=!1;processedRevisions=new Set;lastRevisionMessage=void 0;uuidGenerator=new al;lastLocalOperation;constructor(e,t,n=Ue){super(),this.revisions=e,this.transportService=t,this.serverRevisionId=n,this.debouncedMove=Et(this._move.bind(this),200)}canApplyOptimisticUpdate(){return!this.waitingUndoRedoAck}save(e,t,n){if(!t.length||!n.length||!this.canApplyOptimisticUpdate())return;let r=new tU(this.uuidGenerator.uuidv4(),this.clientId,t,e,n,Date.now());this.revisions.append(r.id,r),e.type!==`REQUEST_REDO`&&(this.lastLocalOperation=r),this.trigger(`new-local-state-update`,{id:r.id}),this.sendUpdateMessage({type:`REMOTE_REVISION`,version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:r.id,clientId:r.clientId,commands:r.commands})}undo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:`REVISION_UNDONE`,version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),undoneRevisionId:e})}redo(e){this.waitingUndoRedoAck=!0,this.sendUpdateMessage({type:`REVISION_REDONE`,version:1,serverRevisionId:this.serverRevisionId,nextRevisionId:this.uuidGenerator.uuidv4(),redoneRevisionId:e})}move(e){this.debouncedMove(e)}join(e){e?(this.clients[e.id]=e,this.clientId=e.id):(this.clients.local={id:`local`,name:`local`},this.clientId=`local`),this.transportService.onNewMessage(this.clientId,this.onMessageReceived.bind(this))}loadInitialMessages(e){let t=performance.now(),n=e.reduce((e,t)=>e+(t.type===`REMOTE_REVISION`?t.commands.length:1),0);this.isReplayingInitialRevisions=!0;for(let t of e)this.onMessageReceived(t);this.isReplayingInitialRevisions=!1,console.debug(`Replayed`,n,`commands in`,performance.now()-t,`ms`)}async leave(e){e&&Object.keys(this.clients).length===1&&this.lastRevisionMessage&&this.lastRevisionMessage?.type!==`SNAPSHOT_CREATED`&&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(this.pendingMessages.length!==0)return;let t=this.uuidGenerator.uuidv4();await this.transportService.sendMessage({type:`SNAPSHOT`,nextRevisionId:t,serverRevisionId:this.serverRevisionId,data:{...e,revisionId:t},version:1})}getClient(){let e=this.clients[this.clientId];if(!e)throw new nU(`The client left the session`);return e}getConnectedClients(){return new Set(Object.values(this.clients).filter(C))}getRevisionId(){return this.serverRevisionId}isFullySynchronized(){return this.pendingMessages.length===0}getLastLocalNonEmptyRevision(){return this.lastLocalOperation}_move(e){if(!this.clients[this.clientId])return;let t=this.clients[this.clientId]?.position;if(t?.col===e.col&&t.row===e.row&&t.sheetId===e.sheetId)return;let n=t?`CLIENT_MOVED`:`CLIENT_JOINED`,r=this.getClient();this.clients[this.clientId]={...r,position:e},this.transportService.sendMessage({type:n,version:1,client:{...r,position:e}})}onMessageReceived(e){if(!this.isAlreadyProcessed(e)){if(this.isWrongServerRevisionId(e)){this.trigger(`unexpected-revision-id`);return}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`:let{clientId:t,commands:n,timestamp:r}=e,i=new tU(e.nextRevisionId,t,n,void 0,void 0,r);if(i.clientId!==this.clientId){this.revisions.insert(i.id,i,e.serverRevisionId);let t=this.pendingMessages.filter(e=>e.type===`REMOTE_REVISION`).map(e=>e.commands).flat();this.trigger(`remote-revision-received`,{commands:GH(n,t)})}break;case`SNAPSHOT_CREATED`:{let t=new tU(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;let t=this.clients[this.clientId];if(t){let{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(e.type===`REMOTE_REVISION`){let t=this.revisions.get(e.nextRevisionId);t.commands.length===0&&(this.revisions.rebase(t.id),t=this.revisions.get(e.nextRevisionId)),e={...e,clientId:t.clientId,commands:t.commands}}if(this.isReplayingInitialRevisions)throw Error(`Trying to send a new revision while replaying initial revision. This can lead to endless dispatches every time the spreadsheet is open.
|
|
1978
1978
|
${JSON.stringify(e)}`);this.waitingAck=!0,this.transportService.sendMessage({...e,serverRevisionId:this.serverRevisionId})}}acknowledge(e){switch((e.type===`REVISION_UNDONE`||e.type===`REVISION_REDONE`)&&(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);let t=this.pendingMessages.findIndex(e=>e.type===`REMOTE_REVISION`);t!==-1&&this.revisions.rebase(this.pendingMessages[t].nextRevisionId),this.serverRevisionId=e.nextRevisionId,this.processedRevisions.add(e.nextRevisionId),this.sendPendingMessage();break}}}isAlreadyProcessed(e){if(e.type===`CLIENT_MOVED`&&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})=>e!==`REVISION_REDONE`&&e!==`REVISION_UNDONE`)}},iU=class extends bH{static getters=[`getClientsToDisplay`,`getClient`,`getConnectedClients`,`isFullySynchronized`];static layers=[`Selection`];availableColors=new Fn(12);colors={};session;constructor(e){super(e),this.session=e.session}isPositionValid(e){return e.row<this.getters.getNumberRows(e.sheetId)&&e.col<this.getters.getNumberCols(e.sheetId)}getClient(){return this.session.getClient()}getConnectedClients(){return this.session.getConnectedClients()}isFullySynchronized(){return this.session.isFullySynchronized()}getClientsToDisplay(){try{this.getters.getClient()}catch(e){if(e instanceof nU)return[];throw e}let e=this.getters.getActiveSheetId(),t=[];for(let n of this.getters.getConnectedClients())if(n.id!==this.getters.getClient().id&&n.position&&n.position.sheetId===e&&this.isPositionValid(n.position)){let e=n.position;this.colors[n.id]||(this.colors[n.id]=this.availableColors.next());let r=this.colors[n.id];t.push({...n,position:e,color:r})}return t}drawLayer(e){if(this.getters.isDashboard())return;let{ctx:t,thinLineWidth:n}=e,r=this.getters.getActiveSheetId();for(let e of this.getClientsToDisplay()){let{row:i,col:a}=e.position,o=this.getters.expandZone(r,{top:i,bottom:i,left:a,right:a}),{x:s,y:c,width:l,height:u}=this.getters.getVisibleRect(o);if(l<=0||u<=0)continue;let d=e.color;t.fillStyle=`${d}10`,t.lineWidth=4*n,t.strokeStyle=d,t.globalCompositeOperation=`multiply`,t.fillRect(s,c,l,u),t.globalCompositeOperation=`source-over`,t.strokeRect(s,c,l,u),t.font=`bold ${Be+1}px ${Ve}`}}},aU=class extends bH{allowDispatch(e){switch(e.type){case`REMOVE_DUPLICATES`:return this.checkValidations(e,this.chainValidations(this.checkSingleRangeSelected,this.checkNoMergeInZone,this.checkRangeContainsValues,this.checkColumnsIncludedInZone),this.chainValidations(this.checkNoColumnProvided,this.checkColumnsAreUnique))}return`Success`}handle(e){switch(e.type){case`REMOVE_DUPLICATES`:this.removeDuplicates(e.columns,e.hasHeader);break;case`TRIM_WHITESPACE`:this.trimWhitespace();break}}removeDuplicates(e,t){let n=this.getters.getActiveSheetId(),r=this.getters.getSelectedZone();t&&(r.top+=1);let i=this.getUniqueRowsIndexes(n,r.top,r.bottom,e),a=i.length;if(a===br(r).numberOfRows){this.notifyRowsRemovedAndRemaining(0,a);return}let o=i.map(e=>({left:r.left,top:e,right:r.right,bottom:e})),s=new kd(this.getters,this.dispatch),c=s.copy(sl(n,o),!1);if(!c)return;this.dispatch(`CLEAR_CELLS`,{target:[r],sheetId:n});let l={left:r.left,top:r.top,right:r.left,bottom:r.top};s.paste({zones:[l],sheetId:n},c,{isCutOperation:!1});let u={left:r.left,top:r.top-+!!t,right:r.right,bottom:r.top+a-1};this.selection.selectZone({cell:{col:u.left,row:u.top},zone:u});let d=r.bottom-r.top+1-a;this.notifyRowsRemovedAndRemaining(d,a)}getUniqueRowsIndexes(e,t,n,r){let i=new Map;for(let a of S(t,n+1)){let t=r.map(t=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:a}).value);Object.values(i).some(e=>w(e,t))||(i[a]=t)}return Object.keys(i).map(e=>parseInt(e))}notifyRowsRemovedAndRemaining(e,t){this.ui.notifyUI({type:`info`,text:O(`%s duplicate rows found and removed.
|
|
1979
1979
|
%s unique rows remain.`,e.toString(),t.toString()),sticky:!1})}checkSingleRangeSelected(){return this.getters.getSelectedZones().length===1?`Success`:`MoreThanOneRangeSelected`}checkNoMergeInZone(){let e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZone();return this.getters.getMergesInZone(e,t).length>0?`WillRemoveExistingMerge`:`Success`}checkRangeContainsValues(e){let t=this.getters.getActiveSheetId(),n=this.getters.getSelectedZone();return e.hasHeader&&(n.top+=1),this.getters.getEvaluatedCellsInZone(t,n).every(e=>e.type===`empty`)?`EmptyTarget`:`Success`}checkNoColumnProvided(e){return e.columns.length===0?`NoColumnsProvided`:`Success`}checkColumnsIncludedInZone(e){let 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?`Success`:`DuplicatesColumnsSelected`}trimWhitespace(){let e=Yn(this.getters.getSelectedZones()),t=this.getters.getActiveSheetId(),n=0;for(let{col:r,row:i}of e.map(wr).flat()){let e=this.getters.getCell({col:r,row:i,sheetId:t});if(!e)continue;let a=Gt(e.content);a!==e.content&&(n+=1,this.dispatch(`UPDATE_CELL`,{sheetId:t,col:r,row:i,content:a}))}let r=n?O(`Trimmed whitespace from %s cells.`,n):O(`No selected cells had whitespace trimmed.`);this.ui.notifyUI({type:`info`,text:r,sticky:!1})}},oU=class extends bH{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);break}}setContextualFormat(e,t,n){let r=[],i={};for(let n of Yn(t))for(let t=n.left;t<=n.right;t++)for(let a=n.top;a<=n.bottom;a++){let n={sheetId:e,col:t,row:a},o=this.getters.getPivotCellFromPosition(n);if(this.isSpilledPivotValueFormula(n,o)){r.push(n);let e=this.getters.getPivotIdFromPosition(n)||``;i[e]??=new Set,i[e].add(o.measure)}}let a=Yn(r.map(E));for(let e in i){let t=i[e],r=this.getters.getPivotCoreDefinition(e);this.dispatch(`UPDATE_PIVOT`,{pivotId:e,pivot:{...r,measures:r.measures.map(e=>t.has(e.id)?{...e,format:n}:e)}})}this.dispatch(`SET_FORMATTING`,{sheetId:e,target:a,format:``}),this.dispatch(`SET_FORMATTING`,{sheetId:e,target:Yn(t,a),format:n})}isSpilledPivotValueFormula(e,t){let n=this.getters.getCell(e);return t.type===`VALUE`&&!n?.isFormula}setDecimal(e,t,n){let r={};for(let i of Yn(t))for(let t of wr(i)){let i=this.getCellNumberFormat({sheetId:e,...t});if(i!==void 0){let e=Es(i,n);r[e]=r[e]||[],r[e].push(t)}}for(let t in r){let n=Yn(r[t].map(e=>E(e)));this.setContextualFormat(e,n,t)}}getCellNumberFormat(e){for(let t of[e]){let e=this.getters.getEvaluatedCell(t);if(e.type===`number`&&!(e.format&&ls(e.format)))return e.format||ps(e.value)}}},sU=class extends bH{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){console.error(`No geoJsonService provided to the model`);return}let t=this.geoJsonCache[e];if(!(t instanceof Promise)){if(t!==void 0)return t??void 0;this.geoJsonCache[e]=new Promise(async t=>{let n=await this.geoJsonService?.getTopoJson(e);this.geoJsonCache[e]=this.convertToGeoJson(n),this.dispatch(`EVALUATE_CHARTS`),t()})}}geoFeatureNameToId(e,t){if(!this.geoJsonService){console.error(`No geoJsonService provided to the model`);return}return this.geoJsonService.geoFeatureNameToId(e,t)}convertToGeoJson(e){if(!e)return null;if(e.type===`Topology`){let t=window.ChartGeo.topojson.feature(e,Object.values(e.objects)[0]);return t.type===`FeatureCollection`?t.features:[t]}else if(e.type===`FeatureCollection`)return e.features;throw Error(`Invalid TopoJSON`)}},cU=class extends bH{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,n){return t===`COL`?this.isColHidden(e,n):this.isRowHidden(e,n)}getNextVisibleCellPosition({sheetId:e,col:t,row:n}){return{sheetId:e,col:this.findVisibleHeader(e,`COL`,t,this.getters.getNumberCols(e)-1),row:this.findVisibleHeader(e,`ROW`,n,this.getters.getNumberRows(e)-1)}}findVisibleHeader(e,t,n,r){if(n<=r){for(let i=n;i<=r;i++)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i}if(n>r){for(let i=n;i>=r;i--)if(this.getters.doesHeaderExist(e,t,i)&&!this.isHeaderHidden(e,t,i))return i}}findLastVisibleColRowIndex(e,t,{last:n,first:r}){return S(n,r,-1).find(n=>!this.isHeaderHidden(e,t,n))||r}findFirstVisibleColRowIndex(e,t){let n=this.getters.getNumberHeaders(e,t);for(let r=0;r<n;r++)if(t===`COL`&&!this.isColHidden(e,r)||t===`ROW`&&!this.isRowHidden(e,r))return r}exportForExcel(e){for(let t of e.sheets)for(let[e,n]of Object.entries(t.rows))n.isHidden=this.isRowHidden(t.id,Number(e))}},lU=class extends bH{static getters=[];allowDispatch(e){switch(e.type){case`DUPLICATE_PIVOT_IN_NEW_SHEET`:if(!this.getters.isExistingPivot(e.pivotId))return`PivotIdNotFound`;if(!this.getters.getPivot(e.pivotId).isValid())return`PivotInError`;break}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){Nr(this.getters.getSelectedZone())===1&&this.selection.selectTableAroundSelection();let n=this.getters.getActiveSheetId();this.dispatch(`ADD_PIVOT`,{pivotId:e,pivot:{dataSet:{zone:this.getters.getSelectedZone(),sheetId:n},columns:[],rows:[],measures:[],name:O(`New pivot`),type:`SPREADSHEET`}});let r=this.getters.getSheetIds().findIndex(e=>e===n)+1,i=this.getters.getPivotFormulaId(e);this.dispatch(`CREATE_SHEET`,{sheetId:t,name:O(`Pivot #%(formulaId)s`,{formulaId:i}),position:r}),this.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:n,sheetIdTo:t});let a=this.getters.getPivot(e);this.insertPivotWithTable(t,0,0,e,a.getTableStructure().export(),`dynamic`)}duplicatePivotInNewSheet(e,t,n){this.dispatch(`DUPLICATE_PIVOT`,{pivotId:e,newPivotId:t,duplicatedPivotName:O(`%s (copy)`,this.getters.getPivotCoreDefinition(e).name)});let r=this.getters.getActiveSheetId(),i=this.getters.getSheetIds().indexOf(r)+1,a=this.getters.getPivotFormulaId(t),o=this.getters.getPivotName(t);if(this.dispatch(`CREATE_SHEET`,{sheetId:n,name:this.getPivotDuplicateSheetName(O(`%(newPivotName)s (Pivot #%(formulaId)s)`,{newPivotName:o,formulaId:a})),position:i}).isSuccessful){this.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:r,sheetIdTo:n});let i=this.getters.getPivot(e);this.insertPivotWithTable(n,0,0,t,i.getTableStructure().export(),`dynamic`)}}getPivotDuplicateSheetName(e){let t=this.getters.getSheetIds().map(e=>this.getters.getSheetName(e));return $t(ut(e),t)}insertPivotWithTable(e,t,n,r,i,a){let{cols:o,rows:s,measures:c,fieldsType:l}=i,u=new iz(o,s,c,l||{}),d=u.columns.length-1;this.resizeSheet(e,t,n,u);let f=this.getters.getPivotFormulaId(r),p;a===`dynamic`?(this.dispatch(`UPDATE_CELL`,{sheetId:e,col:t,row:n,content:`=PIVOT(${f})`}),p={left:t,right:t,top:n,bottom:n}):(this.dispatch(`INSERT_PIVOT`,{sheetId:e,col:t,row:n,pivotId:r,table:u.export()}),p={left:t,right:t+u.getNumberOfDataColumns(),top:n,bottom:n+d+u.rows.length}),this.dispatch(`CREATE_TABLE`,{tableType:a,sheetId:e,ranges:[this.getters.getRangeDataFromZone(e,p)],config:{...et,numberOfHeaders:d}})}resizeSheet(e,t,n,r){let i=r.getNumberOfDataColumns()+1,a=this.getters.getNumberCols(e),o=a-t;o<i&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`COL`,base:a-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:i-o,position:`after`});let s=r.columns.length+r.rows.length,c=this.getters.getNumberRows(e),l=c-n;l<s&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`ROW`,base:c-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:s-l,position:`after`})}splitPivotFormula(e,t,n,r){let i=this.getters.getSpreadZone({sheetId:e,col:t,row:n});if(!i)return;let a=this.getters.getPivotFormulaId(r),o=new Map;for(let t=i.left;t<=i.right;t++)for(let n=i.top;n<=i.bottom;n++){let r={sheetId:e,col:t,row:n};o.set(r,this.getters.getPivotCellFromPosition(r))}for(let[e,t]of o)this.dispatch(`UPDATE_CELL`,{...e,content:yd(a,t)});if(this.getters.getCoreTable({sheetId:e,col:t,row:n})?.type===`dynamic`){let r=E({col:t,row:n}),a=this.getters.getRangeDataFromZone(e,i);this.dispatch(`UPDATE_TABLE`,{sheetId:e,zone:r,newTableRange:a,tableType:`static`})}}},uU=class extends bH{allowDispatch(e){switch(e.type){case`SORT_CELLS`:return vr(e.col,e.row,e.zone)?this.checkValidations(e,this.checkMerge,this.checkMergeSizes,this.checkArrayFormulaInSortZone):`InvalidSortAnchor`}return`Success`}handle(e){switch(e.type){case`SORT_CELLS`:this.sortZone(e.sheetId,e,e.zone,e.sortDirection,e.sortOptions||{});break}}checkMerge({sheetId:e,zone:t}){return this.getters.doesIntersectMerge(e,t)&&wr(t).some(({col:t,row:n})=>!this.getters.isInMerge({sheetId:e,col:t,row:n}))?`InvalidSortZone`:`Success`}checkMergeSizes({sheetId:e,zone:t}){if(!this.getters.doesIntersectMerge(e,t))return`Success`;let n=this.getters.getMerges(e).filter(e=>_r(e,t)),r=br(n[0]),[i,a]=[r.numberOfCols,r.numberOfRows];return n.every(e=>{let[t,n]=[e.right-e.left+1,e.bottom-e.top+1];return t===i&&n===a})?`Success`:`InvalidSortZone`}checkArrayFormulaInSortZone({sheetId:e,zone:t}){return wr(t).some(({col:t,row:n})=>{let r=this.getters.getArrayFormulaSpreadingOn({sheetId:e,col:t,row:n});return r&&!w(r,{sheetId:e,col:t,row:n})})?`SortZoneWithArrayFormulas`:`Success`}hasHeader(e,t){if(t[0].length===1)return!1;let n=t.map(t=>t.map(({col:t,row:n})=>this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}).type));return n[0][0]===`empty`&&(n=n.slice(1)),n.some(e=>e[0]===`empty`)?!1:!!n.some(e=>e[1]!==`empty`&&e[0]!==e[1])}sortZone(e,t,n,r,i){let[a,o]=this.mainCellsSteps(e,n),s=this.getters.getMainCellPosition({sheetId:e,col:t.col,row:t.row}).col,c=Object.assign({},n),l=this.mainCells(e,n);!i.sortHeaders&&this.hasHeader(e,l)&&(c.top+=o),l=this.mainCells(e,c);let u=l[s-c.left],d=Tg(u.map(e=>this.getters.getEvaluatedCell(e)),r,!!i.emptyCellAsZero).map(e=>e.index),[f,p]=[l.length,l[0].length],m=[];for(let e=0;e<f;e++)for(let t=0;t<p;t++){let{col:n,row:r,sheetId:i}=l[e][d[t]],s=this.getters.getCell({sheetId:i,col:n,row:r}),u=c.left+e*a,f=c.top+t*o,p={sheetId:i,col:u,row:f,content:``};if(s){let e=s.content;if(s.isFormula){let t=this.getters.getCellPosition(s.id);e=this.getters.getTranslatedCellFormula(i,0,f-t.row,s.compiledFormula.tokens)}p.style=s.style,p.content=e,p.format=s.format}m.push(p)}m.forEach(e=>this.dispatch(`UPDATE_CELL`,e))}mainCellsSteps(e,t){let n=this.getters.getMerge({sheetId:e,col:t.left,row:t.top});return[n?n.right-n.left+1:1,n?n.bottom-n.top+1:1]}mainCells(e,t){let[n,r]=this.mainCellsSteps(e,t),i=[],a=S(t.left,t.right+1,n),o=S(t.top,t.bottom+1,r);for(let t of a){let n=[];i.push(n);for(let r of o)n.push({sheetId:e,col:t,row:r})}return i}},dU=class extends bH{static getters=[`shouldShowFormulas`];showFormulas=!1;handle(e){switch(e.type){case`SET_FORMULA_VISIBILITY`:this.showFormulas=e.show;break}}shouldShowFormulas(){return this.showFormulas}},fU=class extends bH{static getters=[`doesCellHaveGridIcon`,`getCellWidth`,`getCellIconSvg`,`getTextWidth`,`getCellText`,`getCellMultiLineText`,`getContiguousZone`];ctx=document.createElement(`canvas`).getContext(`2d`);allowDispatch(e){return this.chainValidations(this.checkSheetExists,this.checkZonesAreInSheet)(e)}handle(e){switch(e.type){case`AUTORESIZE_COLUMNS`:for(let t of e.cols){let n=this.getColMaxWidth(e.sheetId,t);n!==0&&this.dispatch(`RESIZE_COLUMNS_ROWS`,{elements:[t],dimension:`COL`,size:n,sheetId:e.sheetId})}break;case`AUTORESIZE_ROWS`:this.autoResizeRows(e.sheetId,e.rows);break;case`DELETE_UNFILTERED_CONTENT`:let t=[];for(let n of e.target){let r=dt(S(n.top,n.bottom+1).filter(t=>!this.getters.isRowFiltered(e.sheetId,t)));for(let e of r)t.push({...n,top:e[0],bottom:e[e.length-1]})}this.dispatch(`DELETE_CONTENT`,{sheetId:e.sheetId,target:t});break}}getCellWidth(e){let t=this.getters.getCellComputedStyle(e),n=0,r=this.getters.getEvaluatedCell(e).formattedValue;if(r){let e=Xc(this.ctx,r,t,void 0);n+=Math.max(...e.map(e=>Vc(this.ctx,e,t)))}if(this.getters.getCellIconSvg(e)&&(n+=Qc(t)),this.getters.doesCellHaveGridIcon(e)&&(n+=20),n===0)return 0;if(n+=8,t.wrapping===`wrap`){let t=this.getters.getColSize(this.getters.getActiveSheetId(),e.col);return Math.min(t,n)}return n}getCellIconSvg(e){let t=hO.getAll();for(let n of t){let t=n(this.getters,e);if(t)return t}}getTextWidth(e,t){return Vc(this.ctx,e,t)}getCellText(e,t){let n=this.getters.getCell(e),r=this.getters.getLocale();if(t?.showFormula&&n?.isFormula)return Hl(n.content,r);if(t?.showFormula&&!n?.content)return``;{let i=this.getters.getEvaluatedCell(e),a=t?.availableWidth?{availableWidth:t.availableWidth,measureText:e=>Vc(this.ctx,e,n?.style||{})}:void 0;return B(i.value,{format:i.format,locale:r,formatWidth:a})}}getCellMultiLineText(e,t){let n=this.getters.getCellStyle(e),r=this.getters.getCellText(e,{showFormula:this.getters.shouldShowFormulas(),availableWidth:t.formatWidth});return Xc(this.ctx,r,n,t.wrapText?t.maxWidth:void 0)}doesCellHaveGridIcon(e){let t=this.getters.isFilterHeader(e),n=!this.getters.isReadonly()&&this.getters.cellHasListDataValidationIcon(e);return t||n}getContiguousZone(e,t){let n=t=>{for(let n of S(t.left,t.right+1)){if(!this.isCellEmpty({sheetId:e,col:n,row:t.top-1}))return{...t,top:t.top-1};if(!this.isCellEmpty({sheetId:e,col:n,row:t.bottom+1}))return{...t,bottom:t.bottom+1}}for(let n of S(t.top,t.bottom+1)){if(!this.isCellEmpty({sheetId:e,col:t.left-1,row:n}))return{...t,left:t.left-1};if(!this.isCellEmpty({sheetId:e,col:t.right+1,row:n}))return{...t,right:t.right+1}}return t},r=!1,i=t;do{r=!1;let e=n(i);gr(i,e)||(r=!0,i=e)}while(r);return i}isCellEmpty(e){let t=this.getters.getMainCellPosition(e);return this.getters.getEvaluatedCell(t).type===`empty`}getColMaxWidth(e,t){let n=wr(this.getters.getColsZone(e,t,t)).map(t=>this.getCellWidth({sheetId:e,...t}));return Math.max(0,Jt(n))}checkSheetExists(e){return`sheetId`in e&&this.getters.tryGetSheet(e.sheetId)===void 0?`InvalidSheetId`:`Success`}checkZonesAreInSheet(e){let t=`sheetId`in e?e.sheetId:this.getters.tryGetActiveSheetId();if(`ranges`in e&&e.ranges.some(e=>!this.getters.tryGetSheet(e._sheetId)))return`InvalidSheetId`;let n=this.getters.getCommandZones(e);return!t&&n.length>0?`NoActiveSheet`:t&&n.length>0?this.getters.checkZonesExistInSheet(t,n):`Success`}autoResizeRows(e,t){let n=[];for(let r of t){let t=0;for(let n of this.getters.getRowCells(e,r)){let r=this.getters.getCellById(n);if(!r)continue;let i=this.getters.getCellPosition(r.id),a=this.getters.getColSize(e,i.col);if(r.isFormula||this.getters.getArrayFormulaSpreadingOn(i)){let e=this.getters.getEvaluatedCell(i).formattedValue,n=Rc(this.ctx,e,r?.style,a);n>t&&n>23&&(t=n)}else{let e=r.content,n=Rc(this.ctx,e,r?.style,a);n>=t&&n>23&&(t=0)}}n.push(t||null)}let r=new Map(n.map(e=>[e,[]]));for(let e=0;e<n.length;e++)r.get(n[e])?.push(t[e]);for(let[t,n]of r)this.dispatch(`RESIZE_COLUMNS_ROWS`,{elements:n,dimension:`ROW`,size:t,sheetId:e})}},pU=class extends bH{static getters=[`getCellTableStyle`,`getCellTableBorder`];tableStyles={};handle(e){if(ta.has(e.type)||e.type===`UPDATE_CELL`&&(`content`in e||`format`in e)||e.type===`EVALUATE_CELLS`){this.tableStyles={};return}if(hU(e)){`sheetId`in e?delete this.tableStyles[e.sheetId]:this.tableStyles={};return}}finalize(){for(let e of this.getters.getSheetIds()){this.tableStyles[e]||(this.tableStyles[e]={});for(let t of this.getters.getTables(e))this.tableStyles[e][t.id]||(this.tableStyles[e][t.id]=this.computeTableStyle(e,t))}}getCellTableStyle(e){let t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().styles[e.col]?.[e.row]}getCellTableBorder(e){let t=this.getters.getTable(e);if(t)return this.tableStyles[e.sheetId][t.id]().borders[e.col]?.[e.row]}computeTableStyle(e,t){return kt(()=>{let{config:n,numberOfCols:r,numberOfRows:i}=this.getTableRuntimeConfig(e,t),a=zz(n,this.getters.getTableStyle(t.config.styleId),r,i),o=this.getTableMapping(e,t),s={borders:{},styles:{}};for(let e=0;e<r;e++){let t=o.colMapping[e];s.borders[t]={},s.styles[t]={};for(let n=0;n<i;n++){let r=o.rowMapping[n];s.borders[t][r]=a.borders[e][n],s.styles[t][r]=a.styles[e][n]}}return s})}getTableRuntimeConfig(e,t){let n=t.range.zone,r={...t.config},i=n.right-n.left+1,a=n.bottom-n.top+1;for(let i=n.top;i<=n.bottom;i++)this.getters.isRowHidden(e,i)&&(a--,i-n.top<t.config.numberOfHeaders&&(r.numberOfHeaders--,r.numberOfHeaders<0&&(r.numberOfHeaders=0)),i===n.bottom&&(r.totalRow=!1));for(let t=n.left;t<=n.right;t++)this.getters.isColHidden(e,t)&&(i--,t===n.left&&(r.firstColumn=!1),t===n.right&&(r.lastColumn=!1));return{config:r,numberOfCols:i,numberOfRows:a}}getTableMapping(e,t){let n={},r={},i=0,a=0,o=t.range.zone;for(let t=o.left;t<=o.right;t++)if(!this.getters.isColHidden(e,t)){n[i]=t,i++;for(let t=o.top;t<=o.bottom;t++)this.getters.isRowHidden(e,t)||(r[a]=t,a++)}return{colMapping:n,rowMapping:r}}};let mU=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 hU(e){return mU.has(e.type)}var gU=class extends bH{static getters=[`getCellComputedBorder`,`getCellComputedStyle`];styles={};borders={};handle(e){if(ta.has(e.type)||e.type===`UPDATE_CELL`||e.type===`SET_FORMATTING`||e.type===`CLEAR_FORMATTING`||e.type===`EVALUATE_CELLS`){this.styles={},this.borders={};return}if(hU(e)){`sheetId`in e?(delete this.styles[e.sheetId],delete this.borders[e.sheetId]):(this.styles={},this.borders={});return}if(ia.has(e.type)){this.styles={};return}if(aa.has(e.type)){this.borders={};return}}getCellComputedBorder(e){let{sheetId:t,row:n,col:r}=e;return this.borders[t]?.[n]?.[r]===void 0?(this.borders[t]||(this.borders[t]={}),this.borders[t][n]||(this.borders[t][n]={}),this.borders[t][n][r]||(this.borders[t][n][r]=this.computeCellBorder(e)),this.borders[t][n][r]):this.borders[t][n][r]}getCellComputedStyle(e){let{sheetId:t,row:n,col:r}=e;return this.styles[t]?.[n]?.[r]===void 0?(this.styles[t]||(this.styles[t]={}),this.styles[t][n]||(this.styles[t][n]={}),this.styles[t][n][r]||(this.styles[t][n][r]=this.computeCellStyle(e)),this.styles[t][n][r]):this.styles[t][n][r]}computeCellBorder(e){let t=this.getters.getCellBorder(e)||{},n={...Pt(this.getters.getCellTableBorder(e)||{}),...Pt(t)};return Tt(n)?null:n}computeCellStyle(e){let t=this.getters.getCell(e),n=this.getters.getCellConditionalFormatStyle(e),r={...Pt(this.getters.getCellTableStyle(e)),...Pt(t?.style),...Pt(n)};return this.getters.getEvaluatedCell(e).link&&!r.textColor&&(r.textColor=ce),r}},_U=class extends bH{handle(e){switch(e.type){case`ADD_DATA_VALIDATION_RULE`:if(e.rule.criterion.type===`isBoolean`){let t=e.ranges.map(e=>this.getters.getRangeFromRangeData(e));for(let e of gc(t)){let t=this.getters.getCell(e),n=this.getters.getEvaluatedCell(e);if(!t?.content)this.dispatch(`UPDATE_CELL`,{...e,content:`FALSE`});else if(t?.content&&n.type===`empty`){let n;if(t.content.startsWith(`=`)){let r=this.getters.evaluateFormula(e.sheetId,t.content);n=(A(r)?r[0][0]:r)?.toString()}else n=t.content;(!n||!pt(n))&&this.dispatch(`UPDATE_CELL`,{...e,content:`FALSE`})}else n.type!==`boolean`&&this.dispatch(`UPDATE_CELL`,{...e,content:`FALSE`})}}}}};let vU=[yU,bU,SU,CU];function yU(e,t){return`sheetId`in t?{...b(t),sheetId:e.getActiveSheetId()}:t}function bU(e,t){return!(`target`in t)||!Array.isArray(t.target)?t:{...b(t),target:e.getSelectedZones()}}function xU(e,t){return`zone`in t?{...b(t),zone:e.getSelectedZone()}:t}function SU(e,t){if(!(`row`in t)||!(`col`in t))return t;let{col:n,row:r}=e.getActivePosition();return{...b(t),col:n,row:r}}function CU(e,t){return`ranges`in t?{...b(t),ranges:e.getSelectedZones().map(t=>e.getRangeDataFromZone(e.getActiveSheetId(),t))}:t}let wU=new al;function TU(e,t){return{...yU(e,t),figureId:wU.smallUuid()}}function EU(e,t){return{...yU(e,t),figureId:wU.smallUuid()}}function DU(e,t){let n=SU(e,yU(e,t));return n.figureId=wU.smallUuid(),n}function OU(e,t){let n=b(t);n.sheetId=wU.smallUuid();let r=t.name||e.getSheet(e.getActiveSheetId()).name,i=r.match(/(.+?)\d*$/)?.[1]||r;return n.name=e.getNextSheetName(i),n}function kU(e,t){let n=e.getActivePosition();return{...yU(e,t),base:t.dimension===`COL`?n.col:n.row}}function AU(e,t){let n=e.getSelectedZone();return{...yU(e,t),elements:t.dimension===`COL`?S(n.left,n.right+1):S(n.top,n.bottom+1)}}function jU(e,t){let n=e.getSelectedZone();return{...b(t),zone:n}}function MU(e,t){let n=b(t),{top:r,bottom:i,left:a,right:o}=e.getSelectedZone();return`cols`in n?n.cols=S(a,o+1):`rows`in n&&(n.rows=S(r,i+1)),n}function NU(e,t){let n=e.getSelectedZone();return{...yU(e,t),col:n.left,row:n.top,zone:n}}function PU(e,t){return{type:`REPEAT_PASTE`,pasteOption:b(t.pasteOption),target:e.getSelectedZones()}}function FU(e,t){let n=e.getSelectedZone();return{...yU(e,t),start:t.dimension===`COL`?n.left:n.top,end:t.dimension===`COL`?n.right:n.bottom}}let IU=new h;IU.add(`UPDATE_CELL`,RU),IU.add(`CLEAR_CELL`,RU),IU.add(`CLEAR_CELLS`,RU),IU.add(`DELETE_CONTENT`,RU),IU.add(`ADD_MERGE`,RU),IU.add(`REMOVE_MERGE`,RU),IU.add(`SET_FORMATTING`,RU),IU.add(`CLEAR_FORMATTING`,RU),IU.add(`SET_BORDER`,RU),IU.add(`CREATE_TABLE`,RU),IU.add(`REMOVE_TABLE`,RU),IU.add(`HIDE_SHEET`,RU),IU.add(`ADD_COLUMNS_ROWS`,kU),IU.add(`REMOVE_COLUMNS_ROWS`,AU),IU.add(`HIDE_COLUMNS_ROWS`,AU),IU.add(`RESIZE_COLUMNS_ROWS`,AU),IU.add(`CREATE_SHEET`,OU),IU.add(`CREATE_FIGURE`,DU),IU.add(`CREATE_CHART`,TU),IU.add(`CREATE_IMAGE`,EU),IU.add(`GROUP_HEADERS`,FU),IU.add(`UNGROUP_HEADERS`,FU),IU.add(`UNGROUP_HEADERS`,FU),IU.add(`UNFOLD_HEADER_GROUPS_IN_ZONE`,xU),IU.add(`FOLD_HEADER_GROUPS_IN_ZONE`,xU);let LU=new h;LU.add(`PASTE`,PU),LU.add(`INSERT_CELL`,jU),LU.add(`DELETE_CELL`,jU),LU.add(`AUTORESIZE_COLUMNS`,MU),LU.add(`AUTORESIZE_ROWS`,MU),LU.add(`SORT_CELLS`,NU),LU.add(`SUM_SELECTION`,RU),LU.add(`SET_DECIMAL`,RU),LU.add(`DELETE_UNFILTERED_CONTENT`,RU);function RU(e,t){let n=b(t);for(let t of vU)n=t(e,n);return n}function zU(e,t){if(t&&IU.contains(t.type))return IU.get(t.type)(e,t)}function BU(e,t,n){if(LU.contains(t.type))return LU.get(t.type)(e,t,n)}function VU(e){return!e||!e.rootCommand||typeof e.rootCommand!=`object`?!1:ca(e.rootCommand)?IU.contains(e.rootCommand.type):LU.contains(e.rootCommand.type)}function HU(e,t){if(!(!e.rootCommand||typeof e.rootCommand!=`object`))return ca(e.rootCommand)?zU(t,e.rootCommand):BU(t,e.rootCommand,e.commands)}var UU=class extends bH{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`;break}return`Success`}handle(e){switch(e.type){case`REQUEST_UNDO`:case`REQUEST_REDO`:this.requestHistoryChange(e.type===`REQUEST_UNDO`?`UNDO`:`REDO`)}}finalize(){}requestHistoryChange(e){let t=e===`UNDO`?this.undoStack.pop():this.redoStack.pop();if(!t){let e=this.getPossibleRevisionToRepeat();if(!e)return;let t=HU(e,this.getters);if(!t)return;if(!Array.isArray(t)){this.dispatch(t.type,t);return}for(let e of t)this.dispatch(e.type,e);return}e===`UNDO`?(this.session.undo(t),this.redoStack.push(t)):(this.session.redo(t),this.undoStack.push(t))}canUndo(){return this.undoStack.length>0}canRedo(){return this.redoStack.length>0?!0:VU(this.getPossibleRevisionToRepeat())}onNewLocalStateUpdate({id:e}){this.undoStack.push(e),this.redoStack=[],this.undoStack.length>99&&this.undoStack.shift()}getPossibleRevisionToRepeat(){return this.session.getLastLocalNonEmptyRevision()}},WU=class{trackedValues=new Set;domainToArray(e){return e.flatMap(e=>[e.field,I(e.value)])}isValuePresent(e,t){let n=JSON.stringify({measure:e,domain:this.domainToArray(t)});return this.trackedValues.has(n)}isHeaderPresent(e){let t=JSON.stringify({domain:this.domainToArray(e)});return this.trackedValues.has(t)}trackValue(e,t){let n=JSON.stringify({measure:e,domain:this.domainToArray(t)});this.trackedValues.add(n)}trackHeader(e){let t=JSON.stringify({domain:this.domainToArray(e)});this.trackedValues.add(t)}},GU=class extends bH{static getters=[`getPivotPresenceTracker`];trackPresencePivotId;tracker;handle(e){switch(e.type){case`PIVOT_START_PRESENCE_TRACKING`:this.tracker=new WU,this.trackPresencePivotId=e.pivotId;break;case`PIVOT_STOP_PRESENCE_TRACKING`:this.trackPresencePivotId=void 0;break}}getPivotPresenceTracker(e){if(this.trackPresencePivotId===e){if(!this.tracker)throw Error(`Tracker not initialized`);return this.tracker}}},KU=class extends bH{static getters=[`getAutomaticSeparator`];allowDispatch(e){switch(e.type){case`SPLIT_TEXT_INTO_COLUMNS`:return this.chainValidations(this.batchValidations(this.checkSingleColSelected,this.checkNonEmptySelector),this.batchValidations(this.checkNotOverwritingContent,this.checkSeparatorInSelection))(e)}return`Success`}handle(e){switch(e.type){case`SPLIT_TEXT_INTO_COLUMNS`:this.splitIntoColumns(e);break}}getAutomaticSeparator(){let e=this.getters.getSelectedCells();for(let t of e)if(t.value&&t.type===`text`){let e=this.getAutoSeparatorForString(t.value);if(e)return e}return` `}getAutoSeparatorForString(e){for(let t of[`
|
|
1980
1980
|
`,`;`,`,`,` `,`.`])if(e.includes(t))return t}splitIntoColumns({separator:e,addNewColumns:t}){let n=this.getters.getSelectedZone(),r=this.getters.getActiveSheetId(),i=this.getSplittedCols(n,e);t&&this.addColsToAvoidCollisions(n,i),this.removeMergesInSplitZone(n,i),this.addColumnsToNotOverflowSheet(n,i);for(let e=0;e<i.length;e++){let t=n.top+e,a=i[e],o=n.left,s=this.getters.getCell({sheetId:r,col:o,row:t});if(!(a.length===1&&a[0]===s?.content))for(let[e,n]of a.entries())this.dispatch(`UPDATE_CELL`,{sheetId:r,col:o+e,row:t,content:Ll(n,this.getters.getLocale()),format:``,style:s?.style||null})}}getSplittedCols(e,t){if(!t)throw Error(`Separator cannot be empty`);let n=this.getters.getActiveSheetId(),r=[];for(let i of S(e.top,e.bottom+1)){let a=this.getters.getEvaluatedCell({sheetId:n,col:e.left,row:i}).formattedValue;r.push(this.splitAndRemoveTrailingEmpty(a,t))}return r}splitAndRemoveTrailingEmpty(e,t){let n=e.split(t);for(;n.length>1&&n[n.length-1]===``;)n.pop();return n}willSplittedColsOverwriteContent(e,t){let n=this.getters.getActiveSheetId();for(let r of S(e.top,e.bottom+1)){let i=t[r-e.top];for(let t=1;t<i.length;t++){let i=this.getters.getCell({sheetId:n,col:e.left+t,row:r});if(i&&i.content)return!0}}return!1}removeMergesInSplitZone(e,t){let n=this.getters.getActiveSheetId(),r=Math.max(...t.map(e=>e.length)),i={...e,right:e.left+r-1},a=this.getters.getMergesInZone(n,i);this.dispatch(`REMOVE_MERGE`,{sheetId:n,target:a})}addColsToAvoidCollisions(e,t){let n=this.getters.getActiveSheetId(),r=0;for(let i of S(e.top,e.bottom+1)){let a={sheetId:n,col:e.left,row:i},o=t[i-e.top],s=this.getColsToAddToAvoidCollision(a,o);r=Math.max(r,s)}r&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`COL`,base:e.left,sheetId:n,sheetName:this.getters.getSheetName(n),quantity:r,position:`after`})}getColsToAddToAvoidCollision(e,t){let n=t.length;for(let t=1;t<n;t++){let r=e.col+t,i=this.getters.getCell({...e,col:r});if(i&&i.content)return n-t}return 0}addColumnsToNotOverflowSheet(e,t){let n=this.getters.getActiveSheetId(),r=Math.max(...t.map(e=>e.length-1)),i=this.getters.getNumberCols(n)-1;e.left+r>i&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`COL`,base:i,sheetId:n,sheetName:this.getters.getSheetName(n),quantity:e.left+r-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`;let t=this.getters.getSelectedZones()[0],n=this.getSplittedCols(t,e.separator);return this.willSplittedColsOverwriteContent(t,n)?`SplitWillOverwriteContent`:`Success`}checkSeparatorInSelection({separator:e}){let t=this.getters.getSelectedCells();for(let n of t)if(n.formattedValue.includes(e))return`Success`;return`NoSplitSeparatorInSelection`}},qU=class extends bH{handle(e){switch(e.type){case`AUTOFILL_TABLE_COLUMN`:let t=this.getters.getCoreTable(e),n=this.getters.getCell(e);if(!t?.config.automaticAutofill||t.type===`dynamic`||!n?.isFormula)return;let{col:r,row:i}=e,a=Fz(t.range.zone,t.config);if(a&&vr(r,i,a)){let t=e.autofillRowStart??a.top,n=e.autofillRowEnd??a.bottom,r={...a,top:t,bottom:n};this.autofillTableZone(e,r)}break}}autofillTableZone(e,t){if(t.top===t.bottom)return;let{col:n,row:r,sheetId:i}=e;for(let e=t.top;e<=t.bottom;e++)if(e!==r&&this.getters.getEvaluatedCell({col:n,row:e,sheetId:i}).type!==`empty`)return;let a={zone:this.getters.getSelectedZone(),cell:this.getters.getActivePosition()};this.selection.selectCell(n,r),this.dispatch(`AUTOFILL_SELECT`,{col:n,row:t.bottom}),this.dispatch(`AUTOFILL`),this.selection.selectCell(n,r),this.dispatch(`AUTOFILL_SELECT`,{col:n,row:t.top}),this.dispatch(`AUTOFILL`),this.selection.selectZone(a)}},JU=class extends bH{allowDispatch(e){switch(e.type){case`RESIZE_TABLE`:let t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(!t)return`TableNotFound`;let n=t.range.zone,r=this.getters.getRangeFromRangeData(e.newTableRange).zone;return r.top!==n.top||r.left!==n.left?`InvalidTableResize`:this.canDispatch(`UPDATE_TABLE`,{...e}).reasons}return`Success`}handle(e){switch(e.type){case`RESIZE_TABLE`:{let t=this.getters.getCoreTableMatchingTopLeft(e.sheetId,e.zone);if(this.dispatch(`UPDATE_TABLE`,{...e}),!t)return;let n=this.getters.getRangeFromRangeData(e.newTableRange).zone;if(this.selection.selectCell(n.right,n.bottom),!t.config.automaticAutofill)return;let r=t.range.zone;if(n.bottom>=r.bottom){for(let t=n.left;t<=n.right;t++){let i={col:t,row:r.bottom,sheetId:e.sheetId};this.getters.getCell(i)?.content.startsWith(`=`)&&this.dispatch(`AUTOFILL_TABLE_COLUMN`,{...i,autofillRowStart:r.bottom,autofillRowEnd:n.bottom})}break}}}}},YU=class extends bH{static layers=[`Clipboard`];static getters=[`getClipboardTextAndImageContent`,`getClipboardId`,`getClipboardTextContent`,`isCutOperation`];status=`invisible`;originSheetId;copiedData;_isCutOperation=!1;clipboardId=new al().uuidv4();fileStore;uuidGenerator;constructor(e){super(e),this.fileStore=e.external.fileStore,this.uuidGenerator=new al}allowDispatch(e){switch(e.type){case`CUT`:let t=this.getters.getSelectedZones();return this.isCutAllowedOn(t);case`PASTE_FROM_OS_CLIPBOARD`:{let t=this.convertTextToClipboardData(e.clipboardContent.text??``),n=e.pasteOption;return this.isPasteAllowed(e.target,t,{pasteOption:n,isCutOperation:!1})}case`PASTE`:{if(!this.copiedData)return`EmptyClipboard`;let t=e.pasteOption;return this.isPasteAllowed(e.target,this.copiedData,{pasteOption:t,isCutOperation:this._isCutOperation})}case`COPY_PASTE_CELLS_ABOVE`:{let e=this.getters.getSelectedZones();if(e.length>1||e[0].top===0&&e[0].bottom===0)return`InvalidCopyPasteSelection`;break}case`COPY_PASTE_CELLS_ON_LEFT`:{let e=this.getters.getSelectedZones();if(e.length>1||e[0].left===0&&e[0].right===0)return`InvalidCopyPasteSelection`;break}case`INSERT_CELL`:{let{cut:t,paste:n}=this.getInsertCellsTargets(e.zone,e.shiftDimension),r=this.copy(t,`shiftCells`);return this.isPasteAllowed(n,r,{isCutOperation:!0})}case`DELETE_CELL`:{let{cut:t,paste:n}=this.getDeleteCellsTargets(e.zone,e.shiftDimension),r=this.copy(t,`shiftCells`);return this.isPasteAllowed(n,r,{isCutOperation:!0})}}return`Success`}handle(e){switch(e.type){case`COPY`:case`CUT`:let t=this.getters.getSelectedZones();this.status=`visible`,this.originSheetId=this.getters.getActiveSheetId(),this._isCutOperation=e.type===`CUT`,this.copiedData=this.copy(t);break;case`PASTE_FROM_OS_CLIPBOARD`:{this._isCutOperation=!1;let t=e.clipboardContent;if(t.data?.version!==Sj()&&(t={...t},delete t.data),t.imageData){let n=this.getters.getActiveSheetId(),r=this.uuidGenerator.uuidv4(),i=t.imageData,a=gD(this.getters,i.size);this.dispatch(`CREATE_IMAGE`,{definition:i,size:a,col:e.target[0].left,row:e.target[0].top,offset:{x:0,y:0},sheetId:n,figureId:r})}t.data?this.copiedData=t.data:this.copiedData=this.convertTextToClipboardData(t.text??``);let n=e.pasteOption;this.paste(e.target,this.copiedData,{pasteOption:n,selectTarget:!0,isCutOperation:!1}),this.status=`invisible`,this.copiedData=void 0;break}case`PASTE`:{let 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,!1);break}case`COPY_PASTE_CELLS_ABOVE`:{let e=this.getters.getSelectedZone(),t=e.top!==e.bottom,n={...e,bottom:t?e.top:e.top-1,top:t?e.top:e.top-1};this.originSheetId=this.getters.getActiveSheetId();let r=this.copy([n]);this.paste([e],r,{isCutOperation:!1,selectTarget:!0})}break;case`COPY_PASTE_CELLS_ON_LEFT`:{let e=this.getters.getSelectedZone(),t=e.left!==e.right,n={...e,right:t?e.left:e.left-1,left:t?e.left:e.left-1};this.originSheetId=this.getters.getActiveSheetId();let r=this.copy([n]);this.paste([e],r,{isCutOperation:!1,selectTarget:!0})}break;case`CLEAN_CLIPBOARD_HIGHLIGHT`:this.status=`invisible`;break;case`DELETE_CELL`:{let{cut:t,paste:n}=this.getDeleteCellsTargets(e.zone,e.shiftDimension);if(!or(t[0])){this.dispatch(`CLEAR_CELLS`,{target:[e.zone],sheetId:this.getters.getActiveSheetId()});break}let r=this.copy(t,`shiftCells`);this.paste(n,r,{isCutOperation:!0});break}case`INSERT_CELL`:{let{cut:t,paste:n}=this.getInsertCellsTargets(e.zone,e.shiftDimension),r=this.copy(t,`shiftCells`);this.paste(n,r,{isCutOperation:!0});break}case`ADD_COLUMNS_ROWS`:if(this.status=`invisible`,!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;this.isColRowDirtyingClipboard(e.position===`before`?e.base:e.base+1,e.dimension)&&(this.copiedData=void 0);break;case`REMOVE_COLUMNS_ROWS`:if(this.status=`invisible`,!this._isCutOperation||e.sheetId!==this.copiedData?.sheetId)return;for(let t of e.elements)if(this.isColRowDirtyingClipboard(t,e.dimension)){this.copiedData=void 0;break}this.status=`invisible`;break;case`REPEAT_PASTE`:this.paste(e.target,this.copiedData,{isCutOperation:!1,pasteOption:e.pasteOption,selectTarget:!0});break;case`DELETE_SHEET`:if(!this._isCutOperation)return;this.originSheetId===e.sheetId&&(this.copiedData=void 0,this.status=`invisible`);break;default:ca(e)&&(this.status=`invisible`)}}convertTextToClipboardData(e){let t=this.selectClipboardHandlers({figureId:!0}).concat(this.selectClipboardHandlers({})),n={};for(let{handlerName:r,handler:i}of t){let t=i.convertTextToClipboardData(e);n[r]=t;for(let e of[`sheetId`,`cells`,`zones`,`figureId`])t&&e in t&&(n[e]=t[e])}return n}selectClipboardHandlers(e){let t=`figureId`in e?zd.figureHandlers:zd.cellHandlers;return t.getKeys().map(e=>({handlerName:e,handler:new(t.get(e))(this.getters,this.dispatch)}))}isCutAllowedOn(e){let t=this.getClipboardData(e);for(let{handler:e}of this.selectClipboardHandlers(t)){let n=e.isCutAllowed(t);if(n!==`Success`)return n}return`Success`}isPasteAllowed(e,t,n){for(let{handler:r}of this.selectClipboardHandlers(t)){let i=r.isPasteAllowed(this.getters.getActiveSheetId(),e,t,{...n});if(i!==`Success`)return i}return`Success`}isColRowDirtyingClipboard(e,t){if(!this.copiedData||!this.copiedData.zones)return!1;let{zones:n}=this.copiedData;for(let r of n)if(t===`COL`&&e<=r.right||t===`ROW`&&e<=r.bottom)return!0;return!1}copy(e,t=`copyPaste`){let n={},r=this.getClipboardData(e);for(let{handlerName:e,handler:i}of this.selectClipboardHandlers(r)){let a=i.copy(r,this._isCutOperation,t);n[e]=a;for(let e of[`sheetId`,`cells`,`zones`,`figureId`])a&&e in a&&(n[e]=a[e])}return n}paste(e,t,n){if(!t)return;let r=this.getters.getActiveSheetId(),i=this.selectClipboardHandlers(t),{target:a,zone:o,selectedZones:s}=pl(r,e,t,i,n);o!==void 0&&this.addMissingDimensions(r,o.right-o.left+1,o.bottom-o.top+1,o.left,o.top),fl(i,t,a,n),n?.selectTarget&&ml(this.selection,e,s)}addMissingDimensions(e,t,n,r,i){let a=n+i-this.getters.getNumberRows(e);a>0&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`ROW`,base:this.getters.getNumberRows(e)-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:a,position:`after`});let o=t+r-this.getters.getNumberCols(e);o>0&&this.dispatch(`ADD_COLUMNS_ROWS`,{dimension:`COL`,base:this.getters.getNumberCols(e)-1,sheetId:e,sheetName:this.getters.getSheetName(e),quantity:o,position:`after`})}getClipboardTextContent(){return this.getPlainTextContent()}getClipboardId(){return this.clipboardId}async getClipboardTextAndImageContent(){let e=await this.getImageContent(),t=e?.type,n={"text/plain":this.getPlainTextContent(),"text/html":await this.getHTMLContent()};return t&&e&&(n[t]=e),n}getSheetData(){let e={version:Sj(),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(` `)).join(`
|
|
1981
1981
|
`)||` `}async getHTMLContent(){let e=``,t=this.copiedData?.cells;if(!t)if(this.copiedData?.figureId){let t=this.copiedData.figureId,n=this.getters.getFigureSheetId(t);e=this.getters.getFigure(n,t).tag===`image`?await this.craftImageHTML(t):` `}else e=` `;else if(t.length===1&&t[0].length===1)e=`${this.getters.getCellText(t[0][0].position)}`;else if(t[0][0]){let n=`<table border="1" style="border-collapse:collapse">`;for(let e of t){n+=`<tr>`;for(let t of e){if(!t)continue;let e=U(uf(this.getters.getCellComputedStyle(t.position))),r=this.getters.getCellText(t.position);n+=`<td style="${e}">`+bD(r)+`</td>`}n+=`</tr>`}n+=`</table>`,e=n}else return``;return`<div data-osheet-clipboard='${bD(JSON.stringify(this.getSheetData()))}'>${e}</div>`}readFileAsDataURL(e){return new Promise(t=>{let n=new FileReader;n.onload=()=>t(n.result),n.readAsDataURL(e)})}async craftImageHTML(e){if(!this.fileStore)return` `;let t=this.getters.getImage(e).path,n=await this.fileStore?.getFile(t)||null;return n?`<img src="${bD(await this.readFileAsDataURL(n))}" />`:` `}async getImageContent(){let e=this.copiedData?.figureId;if(!e)return;let t=this.getters.getFigureSheetId(e),n=this.getters.getFigure(t,e),r;if(n.tag===`image`){if(!this.fileStore)return;let t=this.getters.getImage(e).path;if(r=await this.fileStore?.getFile(t),r.type!==`image/png`){if(r.size>5242880){this.ui.notifyUI({text:O(`The file you are trying to copy is too large (>%sMB).
|
|
1982
1982
|
It will not be added to your OS clipboard.
|
|
1983
|
-
You can download it directly instead.`,5),sticky:!1,type:`warning`});return}r=await aD(t)}}if(r)return r instanceof File?r:new File([r],`image.png`,{type:`image/png`})}isCutOperation(){return this._isCutOperation??!1}getDeleteCellsTargets(e,t){let n=this.getters.getActiveSheetId(),r;return r=t===`COL`?{...e,left:e.right+1,right:this.getters.getNumberCols(n)-1}:{...e,top:e.bottom+1,bottom:this.getters.getNumberRows(n)-1},{cut:[r],paste:[e]}}getInsertCellsTargets(e,t){let n=this.getters.getActiveSheetId(),r,i;return t===`COL`?(r={...e,right:this.getters.getNumberCols(n)-1},i={...e,left:e.right+1,right:e.right+1}):(r={...e,bottom:this.getters.getNumberRows(n)-1},i={...e,top:e.bottom+1,bottom:this.getters.getNumberRows(n)-1}),{cut:[r],paste:[i]}}getClipboardData(e){let t=this.getters.getActiveSheetId(),n=this.getters.getSelectedFigureId();if(n)return{figureId:n,sheetId:t};let r=sl(t,e);return this._isCutOperation||(r.rowsIndexes=r.rowsIndexes.filter(e=>!this.getters.isRowFiltered(t,e))),r}drawLayer(e){if(this.status!==`visible`||!this.copiedData)return;let{sheetId:t,zones:n}=this.copiedData;if(t!==this.getters.getActiveSheetId()||!n||!n.length)return;let{ctx:r,thinLineWidth:i}=e;r.setLineDash([8,5]),r.strokeStyle=ie,r.lineWidth=3.3*i;for(let e of n){let{x:t,y:n,width:i,height:a}=this.getters.getVisibleRect(e);i>0&&a>0&&r.strokeRect(t,n,i,a)}}},XU=class extends bH{static getters=[`getFilterHiddenValues`,`getFirstTableInSelection`,`isRowFiltered`,`isFilterActive`];filterValues={};hiddenRows={};isEvaluationDirty=!1;allowDispatch(e){switch(e.type){case`UPDATE_FILTER`:if(!this.getters.getFilterId(e))return`FilterNotFound`;break}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(let 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]=b(this.filterValues[e.sheetId]);break}}finalize(){if(this.isEvaluationDirty){for(let e of this.getters.getSheetIds())this.updateHiddenRows(e);this.isEvaluationDirty=!1}}isRowFiltered(e,t){return!!this.hiddenRows[e]?.has(t)}getFilterHiddenValues(e){let t=this.getters.getFilterId(e),n=e.sheetId;return!t||!this.filterValues[n]?[]:this.filterValues[n][t]||[]}isFilterActive(e){let t=this.getters.getFilterId(e),n=e.sheetId;return!!(t&&this.filterValues[n]?.[t]?.length)}getFirstTableInSelection(){let e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,hiddenValues:n,sheetId:r}){let i=this.getters.getFilterId({sheetId:r,col:e,row:t});i&&(this.filterValues[r]||(this.filterValues[r]={}),this.filterValues[r][i]=n)}updateHiddenRows(e){let t=this.getters.getFilters(e).sort((e,t)=>e.rangeWithHeaders.zone.top-t.rangeWithHeaders.zone.top),n=new Set;for(let r of t){if(n.has(r.rangeWithHeaders.zone.top)||this.getters.isRowHiddenByUser(e,r.rangeWithHeaders.zone.top))continue;let t=this.filterValues[e]?.[r.id]?.map($c),i=r.filteredRange?.zone;if(!t||!i)continue;let a=new Set(t);for(let t=i.top;t<=i.bottom;t++){let i=this.getCellValueAsString(e,r.col,t);a.has(i)&&n.add(t)}}this.hiddenRows[e]=n}getCellValueAsString(e,t,n){return this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}).formattedValue.toLowerCase()}exportForExcel(e){for(let t of e.sheets){let e=t.id;for(let n of t.tables){let r=ar(n.range),i=[],a=[];for(let n of S(0,br(r).numberOfCols)){let o={sheetId:t.id,col:r.left+n,row:r.top},s=this.getFilterHiddenValues(o),c=this.getters.getFilter(o),l=c?.filteredRange?wr(c.filteredRange.zone).map(t=>this.getters.getEvaluatedCell({sheetId:e,...t}).formattedValue):[];if(s.length){let e=l.filter(e=>e).filter(e=>!s.includes(e));i.push({colId:n,displayedValues:[...new Set(e)],displayBlanks:!s.includes(``)&&l.some(e=>!e)})}let u=this.getters.getEvaluatedCell(o).formattedValue,d=this.getUniqueColNameForExcel(n,u,a);a.push(d);let f=T(o.col,o.row);t.cells[f]=d,t.cellValues[f]=d}n.filters=i}}}getUniqueColNameForExcel(e,t,n){return t||=`Column${e}`,$t(t,n,{compute:(e,n)=>t+String(n),start:2})}},ZU=class extends bH{static layers=[`Selection`];static getters=[`getActiveSheet`,`getActiveSheetId`,`getActiveSheetName`,`getActiveCell`,`getActiveCols`,`getActiveRows`,`getCurrentStyle`,`getSelectedZones`,`getSelectedZone`,`getSelectedCells`,`getSelectedFigureId`,`getSelection`,`getActivePosition`,`getSheetPosition`,`isSingleColSelected`,`getElementsFromSelection`,`tryGetActiveSheetId`,`isGridSelectionActive`];gridSelection={anchor:{cell:{col:0,row:0},zone:{top:0,left:0,bottom:0,right:0}},zones:[{top:0,left:0,bottom:0,right:0}]};selectedFigureId=null;sheetsData={};moveClient;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient}allowDispatch(e){switch(e.type){case`ACTIVATE_SHEET`:try{if(!this.getters.getSheet(e.sheetIdTo).isVisible)return`SheetIsHidden`;break}catch{return`InvalidSheetId`}case`MOVE_COLUMNS_ROWS`:return this.isMoveElementAllowed(e)}return`Success`}handleEvent(e){let t=e.anchor,n=[];switch(e.mode){case`overrideSelection`:n=[t.zone];break;case`updateAnchor`:n=[...this.gridSelection.zones];let r=n.findIndex(t=>gr(t,e.previousAnchor.zone));r>=0&&(n[r]=t.zone);break;case`newAnchor`:n=[...this.gridSelection.zones,t.zone];break}this.setSelectionMixin(e.anchor,n),this.selection.resetDefaultAnchor(this,b(this.gridSelection.anchor));let{col:r,row:i}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:r,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);break}switch(e.type){case`START`:let t=this.getters.getVisibleSheetIds()[0];this.activateSheet(t,t);let{col:n,row:r}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(n,r),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`:{let t=this.getters.getActiveSheetId();if(e.sheetId===t){e.dimension===`COL`?this.onColumnsRemoved(e):this.onRowsRemoved(e);let{col:n,row:r}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:n,row:r})}break}case`ADD_COLUMNS_ROWS`:{let t=this.getters.getActiveSheetId();if(e.sheetId===t){this.onAddElements(e);let{col:n,row:r}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:n,row:r})}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`:let i=Object.keys(this.sheetsData).filter(e=>!this.getters.tryGetSheet(e));for(let e of i)delete this.sheetsData[e];for(let e in this.sheetsData){let t=this.clipSelection(e,this.sheetsData[e].gridSelection);this.sheetsData[e]={gridSelection:b(t)}}this.fallbackToVisibleSheet();let a=this.getters.getActiveSheetId();this.gridSelection.zones=this.gridSelection.zones.map(e=>this.getters.expandZone(a,e)),this.gridSelection.anchor.zone=this.getters.expandZone(a,this.gridSelection.anchor.zone),this.setSelectionMixin(this.gridSelection.anchor,this.gridSelection.zones),this.selectedFigureId=null;break}}finalize(){this.fallbackToVisibleSheet(),this.selection.resetDefaultAnchor(this,b(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(){let e=new Set;for(let t of this.gridSelection.zones)if(t.top===0&&t.bottom===this.getters.getNumberRows(this.getters.getActiveSheetId())-1)for(let n=t.left;n<=t.right;n++)e.add(n);return e}getActiveRows(){let e=new Set,t=this.getters.getActiveSheetId();for(let n of this.gridSelection.zones)if(n.left===0&&n.right===this.getters.getNumberCols(t)-1)for(let t=n.top;t<=n.bottom;t++)e.add(t);return e}getCurrentStyle(){let e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();return this.getters.getCellStyle({sheetId:t,col:e.left,row:e.top})}getSelectedZones(){return b(this.gridSelection.zones)}getSelectedZone(){return b(this.gridSelection.anchor.zone)}getSelection(){return b(this.gridSelection)}getSelectedCells(){let e=this.getters.getActiveSheetId(),t=[];for(let n of this.gridSelection.zones)t.push(...this.getters.getEvaluatedCellsInZone(e,n));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();{let 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(){let e=this.getters.getSelectedZones();return!(e.length!==1||e[0].left!==e[0].right)}getElementsFromSelection(e){if(e===`COL`&&this.getters.getActiveCols().size===0||e===`ROW`&&this.getters.getActiveRows().size===0)return[];let t=this.getters.getSelectedZones(),n=[],r=e===`COL`?`left`:`top`,i=e===`COL`?`right`:`bottom`;for(let e of t){let t=Array.from({length:e[i]-e[r]+1},(t,n)=>e[r]+n);n=n.concat(t)}return[...new Set(n)].sort()}activateSheet(e,t){if(this.setActiveSheet(t),this.sheetsData[e]={gridSelection:b(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,b(this.gridSelection.anchor));else{let{col:e,row:n}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,n)}let{col:n,row:r}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.activeSheet.id,col:n,row:r})}setSelectionMixin(e,t){let{anchor:n,zones:r}=this.clipSelection(this.getters.getActiveSheetId(),{anchor:e,zones:t});this.gridSelection.anchor=n,this.gridSelection.zones=Dr(r)}selectCell(e,t){let n=this.getters.getActiveSheetId(),r=this.getters.expandZone(n,{left:e,right:e,top:t,bottom:t});this.setSelectionMixin({zone:r,cell:{col:e,row:t}},[r])}setActiveSheet(e){this.activeSheet=this.getters.getSheet(e)}activateNextSheet(e){let t=this.getters.getSheetIds(),n=(t.findIndex(e=>e===this.activeSheet.id)+(e===`left`?t.length-1:1))%t.length;this.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:this.getActiveSheetId(),sheetIdTo:t[n]})}onColumnsRemoved(e){let{cell:t,zone:n}=this.gridSelection.anchor,r=dr(n,`left`,[...e.elements]),i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=dr(i,`left`,[...e.elements]);let a={cell:{col:i.left,row:i.top},zone:r},o=this.gridSelection.zones.map(t=>dr(t,`left`,[...e.elements]));this.setSelectionMixin(a,o)}onRowsRemoved(e){let{cell:t,zone:n}=this.gridSelection.anchor,r=dr(n,`top`,[...e.elements]),i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=dr(i,`top`,[...e.elements]);let a={cell:{col:i.left,row:i.top},zone:r},o=this.gridSelection.zones.map(t=>dr(t,`top`,[...e.elements]));this.setSelectionMixin(a,o)}onAddElements(e){let t=e.dimension===`COL`?`left`:`top`,n=ur(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),r=this.gridSelection.zones.map(n=>ur(n,t,e.base,e.position,e.quantity)),i={cell:{col:n.left,row:n.top},zone:n};this.setSelectionMixin(i,r)}onMoveElements(e){let t=e.elements.length,n=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});let r=e.dimension===`COL`,i=e.elements[0],a=e.elements[t-1],o=e.base<i,s=o&&r?t:0,c=o&&!r?t:0,l=o?e.elements.map(e=>e+t):e.elements,u={};for(let t of l)u[t]=this.getters.getHeaderSize(e.sheetId,e.dimension,t);let d=[{left:r?i+s:0,right:r?a+s:this.getters.getNumberCols(e.sheetId)-1,top:r?0:i+c,bottom:r?this.getters.getNumberRows(e.sheetId)-1:a+c}],f=this.getActiveSheetId(),p=o?e.base:e.base+1,m=[{left:r?p:0,right:r?p+t-1:this.getters.getNumberCols(e.sheetId)-1,top:r?0:p,bottom:r?this.getters.getNumberRows(e.sheetId)-1:p+t-1}];for(let e of zd.cellHandlers.getAll()){let t=new e(this.getters,this.dispatch),n=t.copy(sl(f,d),!1,`shiftCells`);n&&t.paste({zones:m,sheetId:f},n,{isCutOperation:!0})}let h=m[0],g=h.left,_=h.top;this.setSelectionMixin({zone:h,cell:{col:g,row:_}},[h]);let v=o?e.base:e.base+1,y={};for(let t of l){let n=u[t];n!==this.getters.getHeaderSize(e.sheetId,e.dimension,v)&&(y[n]??=[],y[n].push(v)),v+=1}for(let t in y)this.dispatch(`RESIZE_COLUMNS_ROWS`,{dimension:e.dimension,sheetId:e.sheetId,size:parseInt(t,10),elements:y[t]});this.dispatch(`REMOVE_COLUMNS_ROWS`,{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,elements:l}),this.applyFigureUpdates(n)}getFiguresUpdates(e){let t=[],n={},r=e.elements[0]<e.base?e.base-e.elements.length+1:e.base;for(let t=0;t<e.elements.length;t++)n[e.elements[t]]=r+t;for(let r of this.getters.getFigures(e.sheetId))e.dimension===`COL`&&r.col in n&&t.push({type:`UPDATE_FIGURE`,sheetId:e.sheetId,figureId:r.id,col:n[r.col],row:r.row}),e.dimension===`ROW`&&r.row in n&&t.push({type:`UPDATE_FIGURE`,sheetId:e.sheetId,figureId:r.id,row:n[r.row],col:r.col});return t}applyFigureUpdates(e){for(let t of e)this.dispatch(t.type,{...t})}isMoveElementAllowed(e){let t=e.dimension===`COL`,n=e.elements[0],r=e.elements[e.elements.length-1],i=e.sheetId,a=t?this.getters.doesColumnsHaveCommonMerges:this.getters.doesRowsHaveCommonMerges;if(a(i,n-1,n)||a(i,r,r+1)||a(i,e.base-1,e.base))return`WillRemoveExistingMerge`;let o=[e.base,...e.elements],s=t?this.getters.getNumberCols(i):this.getters.getNumberRows(i);return o.some(e=>e<0||e>=s)?`InvalidHeaderIndex`:!t&&!this.isTableRowMoveAllowed(i,e.elements)?`CannotMoveTableHeader`:`Success`}isTableRowMoveAllowed(e,t){let n=this.getters.getCoreTables(e);if(n.length===0)return!0;let r=new Set(t);return n.every(({range:{zone:e},config:n})=>{let{top:i,bottom:a}=e;if(n.numberOfHeaders===0)return!0;let o=i+n.numberOfHeaders-1;return t.some(e=>e>=i&&e<=o)?S(i,a+1).every(e=>r.has(e)):!0})}fallbackToVisibleSheet(){if(!this.getters.tryGetSheet(this.getters.getActiveSheetId())){let e=this.getters.getVisibleSheetIds();if(this.activeSheet=this.getters.getSheet(e[0]),this.activeSheet.id in this.sheetsData){let{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);let{col:t,row:n}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:t,row:n})}}clipSelection(e,t){let n=this.getters.getNumberCols(e)-1,r=this.getters.getNumberRows(e)-1,i=t.zones.map(e=>({left:x(e.left,0,n),right:x(e.right,0,n),top:x(e.top,0,r),bottom:x(e.bottom,0,r)})),a=x(t.anchor.cell.col,0,n),o=x(t.anchor.cell.row,0,r),s={left:x(t.anchor.zone.left,0,n),right:x(t.anchor.zone.right,0,n),top:x(t.anchor.zone.top,0,r),bottom:x(t.anchor.zone.bottom,0,r)};return{zones:i,anchor:{cell:{col:a,row:o},zone:s}}}drawLayer(e){if(this.getters.isDashboard())return;let{ctx:t,thinLineWidth:n}=e,r=this.getSelectedZones();t.fillStyle=`#f3f7fe`,t.fillStyle=r.length===1&&r[0].left===r[0].right&&r[0].top===r[0].bottom?`#f3f7fe`:`#e9f0ff`,t.strokeStyle=ie,t.lineWidth=1.5*n;for(let e of r){let{x:n,y:r,width:i,height:a}=this.getters.getVisibleRect(e);t.globalCompositeOperation=`multiply`,t.fillRect(n,r,i,a),t.globalCompositeOperation=`source-over`,t.strokeRect(n,r,i,a)}t.globalCompositeOperation=`source-over`;let i=this.getActivePosition();t.strokeStyle=ie,t.lineWidth=3*n;let a;a=this.getters.isInMerge(i)?this.getters.getMerge(i):E(i);let{x:o,y:s,width:c,height:l}=this.getters.getVisibleRect(a);c>0&&l>0&&t.strokeRect(o,s,c,l)}},QU=class{top;bottom;left;right;offsetX;offsetY;canScrollVertically;canScrollHorizontally;viewportWidth;viewportHeight;offsetCorrectionX;offsetCorrectionY;constructor(e,t,n,r,i,a){if(this.getters=e,this.sheetId=t,this.boundaries=n,r.width<0||r.height<0)throw Error(`Viewport size cannot be negative`);this.viewportWidth=r.height&&r.width,this.viewportHeight=r.width&&r.height,this.top=n.top,this.bottom=n.bottom,this.left=n.left,this.right=n.right,this.offsetX=a.x,this.offsetY=a.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(){let 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:n}=this.getters.getColDimensions(this.sheetId,e),{end:r}=this.getters.getRowDimensions(this.sheetId,t),i=n-this.offsetCorrectionX;this.canScrollHorizontally&&(i=Math.max(i,this.viewportWidth));let a=r-this.offsetCorrectionY;return this.canScrollVertically&&(a=Math.max(a,this.viewportHeight),r+46>a&&!this.getters.isReadonly()&&(a+=46)),{width:i,height:a}}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){let t=this.sheetId,n=this.getters.getMainCellPosition({sheetId:t,...e}),{col:r,row:i}=this.getters.getNextVisibleCellPosition(n);vr(r,this.boundaries.top,this.boundaries)&&this.adjustPositionX(r),vr(this.boundaries.left,i,this.boundaries)&&this.adjustPositionY(i)}adjustPositionX(e){let t=this.sheetId,{start:n,end:r}=this.getters.getColDimensions(t,e);this.offsetX+this.viewportWidth+this.offsetCorrectionX<r?this.offsetX=r-this.viewportWidth:this.offsetX+this.offsetCorrectionX>n&&(this.offsetX=n-this.offsetCorrectionX),this.adjustViewportZoneX()}adjustPositionY(e){let t=this.sheetId,{start:n,end:r}=this.getters.getRowDimensions(t,e);this.offsetY+this.viewportHeight+this.offsetCorrectionY<r?this.offsetY=r-this.viewportHeight:this.offsetY+this.offsetCorrectionY>n&&(this.offsetY=n-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){let t=hr(e,this),n=this.snapCorrection.x,r=this.snapCorrection.y;if(t)return{x:this.getters.getColRowOffset(`COL`,this.left,t.left)+this.offsetCorrectionX-(this.left===t.left?0:n),y:this.getters.getColRowOffset(`ROW`,this.top,t.top)+this.offsetCorrectionY-(this.top===t.top?0:r),width:Math.min(this.getters.getColRowOffset(`COL`,t.left,t.right+1)-(this.left===t.left?n:0),this.viewportWidth),height:Math.min(this.getters.getColRowOffset(`ROW`,t.top,t.bottom+1)-(this.top===t.top?r:0),this.viewportHeight)}}getFullRect(e){let t=hr(e,this.boundaries),n=this.snapCorrection.x,r=this.snapCorrection.y;if(t){let t=this.getters.getColRowOffset(`COL`,this.left,e.left)+this.offsetCorrectionX,i=this.getters.getColRowOffset(`ROW`,this.top,e.top)+this.offsetCorrectionY,a=this.getters.getColRowOffset(`COL`,e.left,e.right+1),o=this.getters.getColRowOffset(`ROW`,e.top,e.bottom+1);return{x:t-n,y:i-r,width:a,height:o}}}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,n=0){if(this.viewportWidth<=0||this.viewportHeight<=0)return-1;let r=this.sheetId,i=this.getters.getNumberHeaders(r,e),a=n,o=i;for(;a<=o&&a!==i&&o!==-1;){let i=Math.floor((a+o)/2),s=this.getters.getColRowOffset(e,n,i),c=this.getters.getHeaderSize(r,e,i);if(t>=s&&t<s+c)return i;t>=s+c?a=i+1:o=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){let{width:e}=this.getMaxSize();this.viewportWidth+this.offsetX>e&&(this.offsetX=Math.max(0,e-this.viewportWidth))}this.adjustViewportZoneX()}adjustViewportOffsetY(){if(this.canScrollVertically){let{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&&(this.left===-1&&(this.left=this.boundaries.left),this.right===-1&&(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&&(this.top===-1&&(this.top=this.boundaries.top),this.bottom===-1&&(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)))}}},$U=class extends bH{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`.split(`.`);viewports={};sheetViewWidth=Ze();sheetViewHeight=Ze();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){let t=this.getters.getActiveSheetId();if(e.options.scrollIntoView){let{col:n,row:r}=kr(e.previousAnchor.zone,e.anchor.zone);if(e.mode===`updateAnchor`){let i=e.previousAnchor.zone,a=e.anchor.zone,{top:o,bottom:s,left:c,right:l}=this.getMainInternalViewport(t);i.left===a.left&&i.right===a.right&&(n=c>n||n>l?c:n),i.top===a.top&&i.bottom===a.bottom&&(r=o>r||r>s?o:r)}n=Math.min(n,this.getters.getNumberCols(t)-1),r=Math.min(r,this.getters.getNumberRows(t)-1),this.sheetsWithDirtyViewports.has(t)||this.refreshViewport(this.getters.getActiveSheetId(),{col:n,row:r})}}handle(e){if(ta.has(e.type))for(let 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(let 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`:let t=this.getters.getActiveSheetId(),{top:n,viewportHeight:r,offsetCorrectionY:i}=this.getMainInternalViewport(t),a=this.getters.getRowDimensions(t,n);this.shiftVertically(a.start+r-i);break;case`SHIFT_VIEWPORT_UP`:{let e=this.getters.getActiveSheetId(),{top:t,viewportHeight:n,offsetCorrectionY:r}=this.getMainInternalViewport(e),i=this.getters.getRowDimensions(e,t);this.shiftVertically(i.end-r-n);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`:for(let 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});break}}finalize(){for(let e of this.sheetsWithDirtyViewports)if(this.resetViewports(e),this.shouldAdjustViewports){let t=this.getters.getSheetPosition(e);this.getSubViewports(e).forEach(e=>{e.adjustPosition(t)})}this.sheetsWithDirtyViewports=new Set,this.shouldAdjustViewports=!1,this.setViewports()}setViewports(){let e=this.getters.getSheetIds();for(let t of e)this.viewports[t]?.bottomRight||this.resetViewports(t)}getColIndex(e){let t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map(t=>t.getColIndex(e)))}getRowIndex(e){let t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map(t=>t.getRowIndex(e)))}getSheetViewDimensionWithHeaders(){return{width:this.sheetViewWidth+this.gridOffsetX,height:this.sheetViewHeight+this.gridOffsetY}}getSheetViewDimension(){return{width:this.sheetViewWidth,height:this.sheetViewHeight}}getActiveMainViewport(){let e=this.getters.getActiveSheetId();return this.getMainViewport(e)}getActiveSheetScrollInfo(){let e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e);return{scrollX:t.offsetX,scrollY:t.offsetY}}getSheetViewVisibleCols(){let e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map(e=>S(e.left,e.right+1)).flat())].filter(t=>t>=0&&!this.getters.isHeaderHidden(e,`COL`,t))}getSheetViewVisibleRows(){let e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map(e=>S(e.top,e.bottom+1)).flat())].filter(t=>t>=0&&!this.getters.isHeaderHidden(e,`ROW`,t))}getVisibleCellPositions(){let e=this.getSheetViewVisibleCols(),t=this.getSheetViewVisibleRows(),n=this.getters.getActiveSheetId(),r=[];for(let i of e)for(let e of t){let t={sheetId:n,col:i,row:e},a=this.getters.getMainCellPosition(t);a.row!==e||a.col!==i||r.push(t)}return r}getMainViewportRect(){let e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e),{xSplit:n,ySplit:r}=this.getters.getPaneDivisions(e),{width:i,height:a}=t.getMaxSize();return{x:this.getters.getColDimensions(e,n).start,y:this.getters.getRowDimensions(e,r).start,width:i,height:a}}getMaximumSheetOffset(){let e=this.getters.getActiveSheetId(),{width:t,height:n}=this.getMainViewportRect(),r=this.getMainInternalViewport(e);return{maxOffsetX:Math.max(0,t-r.viewportWidth),maxOffsetY:Math.max(0,n-r.viewportHeight)}}getColRowOffsetInViewport(e,t,n){if(n<t)return-this.getColRowOffsetInViewport(e,n,t);let r=this.getters.getActiveSheetId(),i=e===`COL`?this.getters.getSheetViewVisibleCols():this.getters.getSheetViewVisibleRows(),a=i.findIndex(e=>t>=e),o=i.findIndex(e=>n<=e);o=o===-1?i.length:o;let s=i.slice(a,o),c=0;for(let t of s)c+=this.getters.getHeaderSize(r,e,t);return c}isVisibleInViewport({sheetId:e,col:t,row:n}){return this.getSubViewports(e).some(e=>e.isVisible(t,n))}getEdgeScrollCol(e,t,n){let r=!1,i=0,a=0,{xSplit:o}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{width:s}=this.getSheetViewDimension(),{x:c}=this.getMainViewportCoordinates(),l=this.getActiveSheetScrollInfo().scrollX;return e>s?(r=!0,a=Ks(e-s),i=1):e<c&&n>=c&&l>0?(r=!0,a=Ks(c-e),i=-1):o&&t<c&&e>c&&(r=!0,a=Ks(e),i=`reset`),{canEdgeScroll:r,direction:i,delay:a}}getEdgeScrollRow(e,t,n){let r=!1,i=0,a=0,{ySplit:o}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{height:s}=this.getSheetViewDimension(),{y:c}=this.getMainViewportCoordinates(),l=this.getActiveSheetScrollInfo().scrollY;return e>s?(r=!0,a=Ks(e-s),i=1):e<c&&n>=c&&l>0?(r=!0,a=Ks(c-e),i=-1):o&&t<c&&e>c&&(r=!0,a=Ks(e),i=`reset`),{canEdgeScroll:r,direction:i,delay:a}}getVisibleRect(e){let t=this.getVisibleRectWithoutHeaders(e);return{...t,x:t.x+this.gridOffsetX,y:t.y+this.gridOffsetY}}getVisibleRectWithoutHeaders(e){let t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,t=>t.getVisibleRect(e))}getRect(e){let t=this.getters.getActiveSheetId(),n=this.mapViewportsToRect(t,t=>t.getFullRect(e));return{...n,x:n.x+this.gridOffsetX,y:n.y+this.gridOffsetY}}getRectWithoutHeaders(e){let t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,t=>t.getFullRect(e))}getMainViewportCoordinates(){let e=this.getters.getActiveSheetId(),{xSplit:t,ySplit:n}=this.getters.getPaneDivisions(e);return{x:this.getters.getColDimensions(e,t).start,y:this.getters.getRowDimensions(e,n).start}}getColDimensionsInViewport(e,t){let{top:n}=this.getMainInternalViewport(e),r={left:t,right:t,top:n,bottom:n},{x:i,width:a}=this.getVisibleRect(r),o=i-this.gridOffsetX;return{start:o,size:a,end:o+a}}getRowDimensionsInViewport(e,t){let{left:n}=this.getMainInternalViewport(e),r={left:0,right:n,top:t,bottom:t},{y:i,height:a}=this.getVisibleRect(r),o=i-this.gridOffsetY;return{start:o,size:a,end:o+a}}getAllActiveViewportsZonesAndRect(){let 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(C)}checkPositiveDimension(e){return e.width<0||e.height<0?`InvalidViewportSize`:`Success`}checkValuesAreDifferent(e){let{height:t,width:n}=this.getSheetViewDimension();return e.gridOffsetX===this.gridOffsetX&&e.gridOffsetY===this.gridOffsetY&&e.width===n&&e.height===t?`ValuesNotChanged`:`Success`}checkScrollingDirection({offsetX:e,offsetY:t}){let n=this.getMainInternalViewport(this.getters.getActiveSheetId());return!n.canScrollHorizontally&&e>0||!n.canScrollVertically&&t>0?`InvalidScrollingDirection`:`Success`}checkIfViewportsWillChange({offsetX:e,offsetY:t}){let n=this.getters.getActiveSheetId(),{maxOffsetX:r,maxOffsetY:i}=this.getMaximumSheetOffset();return this.getSubViewports(n).some(n=>n.willNewOffsetScrollViewport(x(e,0,r),x(t,0,i)))?`Success`:`ViewportScrollLimitsReached`}getMainViewport(e){let 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(){let e={};for(let t of this.getters.getSheetIds())e[t]=this.viewports[t];this.viewports=e}resizeSheetView(e,t,n=0,r=0){this.sheetViewHeight=e,this.sheetViewWidth=t,this.gridOffsetX=n,this.gridOffsetY=r,this.recomputeViewports()}recomputeViewports(){for(let e of this.getters.getSheetIds())this.resetViewports(e)}setSheetViewOffset(e,t){let n=this.getters.getActiveSheetId(),{maxOffsetX:r,maxOffsetY:i}=this.getMaximumSheetOffset();this.getSubViewports(n).forEach(n=>n.setViewportOffset(x(e,0,r),x(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;let{xSplit:t,ySplit:n}=this.getters.getPaneDivisions(e),r=this.getters.getNumberCols(e),i=this.getters.getNumberRows(e),a=Math.min(this.getters.getColRowOffset(`COL`,0,t,e),this.sheetViewWidth),o=Math.min(this.getters.getColRowOffset(`ROW`,0,n,e),this.sheetViewHeight),s=Math.max(this.sheetViewWidth-a,0),c=Math.max(this.sheetViewHeight-o,0),{xRatio:l,yRatio:u}=this.getFrozenSheetViewRatio(e),d=l<1,f=u<1,p=this.getViewportOffset(e),m={topLeft:n&&t&&new QU(this.getters,e,{left:0,right:t-1,top:0,bottom:n-1},{width:a,height:o},{canScrollHorizontally:!1,canScrollVertically:!1},{x:0,y:0})||void 0,topRight:n&&new QU(this.getters,e,{left:t,right:r-1,top:0,bottom:n-1},{width:s,height:o},{canScrollHorizontally:d,canScrollVertically:!1},{x:d?p.x:0,y:0})||void 0,bottomLeft:t&&new QU(this.getters,e,{left:0,right:t-1,top:n,bottom:i-1},{width:a,height:c},{canScrollHorizontally:!1,canScrollVertically:f},{x:0,y:f?p.y:0})||void 0,bottomRight:new QU(this.getters,e,{left:t,right:r-1,top:n,bottom:i-1},{width:s,height:c},{canScrollHorizontally:d,canScrollVertically:f},{x:d?p.x:0,y:f?p.y:0})};this.viewports[e]=m}refreshViewport(e,t){this.getSubViewports(e).forEach(e=>{e.adjustViewportZone(),e.adjustPosition(t)})}shiftVertically(e){let t=this.getters.getActiveSheetId(),{top:n}=this.getMainInternalViewport(t),{scrollX:r}=this.getActiveSheetScrollInfo();this.setSheetViewOffset(r,e);let{anchor:i}=this.getters.getSelection();if(i.cell.row>=this.getters.getPaneDivisions(t).ySplit){let e=this.getMainInternalViewport(t).top-n;this.selection.selectCell(i.cell.col,i.cell.row+e)}}getColIndexLeftOfMainViewport(e){if(e>=0)return-1;let t=this.getters.getActiveSheetId(),n=this.getActiveMainViewport().left,r=-this.getActiveSheetScrollInfo().scrollX-this.getters.getColRowOffset(`COL`,n,0);for(;e<r;n--)r-=this.getters.getColSize(t,n-1);return Math.max(n,0)}getRowIndexTopOfMainViewport(e){if(e>=0)return-1;let t=this.getters.getActiveSheetId(),n=this.getActiveMainViewport().top,r=-this.getActiveSheetScrollInfo().scrollY-this.getters.getColRowOffset(`ROW`,n,0);for(;e<r;n--)r-=this.getters.getRowSize(t,n-1);return Math.max(n,0)}getVisibleFigures(){let e=this.getters.getActiveSheetId(),t=[],n=this.getters.getFigures(e),{scrollX:r,scrollY:i}=this.getters.getActiveSheetScrollInfo(),{x:a,y:o}=this.getMainViewportCoordinates(),{width:s,height:c}=this.getters.getSheetViewDimensionWithHeaders();for(let l of n){let n=this.getFigureUI(e,l),{x:u,y:d}=n;u>=a&&(u+l.width<r+a||u>s+r+a)||d>=o&&(d+l.height<i+o||d>c+i+o)||t.push(n)}return t}getFigureUI(e,t){let n=t.offset.x+this.getters.getColDimensions(e,t.col).start,r=t.offset.y+this.getters.getRowDimensions(e,t.row).start;return{...t,x:n,y:r}}getPositionAnchorOffset(e){let{scrollX:t,scrollY:n}=this.getters.getActiveSheetScrollInfo(),r=e.x-t,i=e.y-n,a=r>=0?this.getColIndex(r):this.getColIndexLeftOfMainViewport(r),o=i>=0?this.getRowIndex(i):this.getRowIndexTopOfMainViewport(i),{x:s,y:c}=this.getRect(E({col:a,row:o}));return{col:a,row:o,offset:{x:Math.max(r-s+this.gridOffsetX,0),y:Math.max(i-c+this.gridOffsetY,0)}}}isPixelPositionVisible(e){let{scrollX:t,scrollY:n}=this.getters.getActiveSheetScrollInfo(),{x:r,y:i}=this.getters.getMainViewportCoordinates(),{width:a,height:o}=this.getters.getSheetViewDimension();return!(e.x>=r&&(e.x<r+t||e.x>a+t+r)||e.y>=i&&(e.y<i+n||e.y>o+n+i))}getFrozenSheetViewRatio(e){let{xSplit:t,ySplit:n}=this.getters.getPaneDivisions(e),r=this.getters.getColDimensions(e,t).start,i=this.getters.getRowDimensions(e,n).start,a=this.sheetViewWidth+this.gridOffsetX,o=this.sheetViewHeight+this.gridOffsetY;return{xRatio:r/a,yRatio:i/o}}mapViewportsToRect(e,t){let n=1/0,r=1/0,i=0,a=0,o=!1;for(let s of this.getSubViewports(e)){let e=t(s);e&&(o=!0,n=Math.min(n,e.x),r=Math.min(r,e.y),i=Math.max(i,e.x+e.width),a=Math.max(a,e.y+e.height))}return o?{x:n,y:r,width:i-n,height:a-r}:{x:0,y:0,width:0,height:0}}},eW=class extends bH{static getters=[`getColDimensions`,`getRowDimensions`,`getColRowOffset`];headerPositions={};isDirty=!0;handle(e){switch(ta.has(e.type)&&(this.headerPositions={},this.isDirty=!0),e.type){case`START`:for(let e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);break;case`UPDATE_CELL`:this.headerPositions={},this.isDirty=!0;break;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]=b(this.headerPositions[e.sheetId]);break}}finalize(){for(let e of this.getters.getSheetIds())(this.isDirty||!this.headerPositions[e])&&(this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e));this.isDirty=!1}getColDimensions(e,t){let n=this.headerPositions[e].COL[t],r=this.getters.getColSize(e,t);return{start:n,size:r,end:n+(this.getters.isColHidden(e,t)?0:r)}}getRowDimensions(e,t){let n=this.headerPositions[e].ROW[t],r=this.getters.getRowSize(e,t);return{start:n,size:r,end:n+(this.getters.isRowHidden(e,t)?0:r)}}getColRowOffset(e,t,n,r=this.getters.getActiveSheetId()){let i=this.headerPositions[r][e][t];return this.headerPositions[r][e][n]-i}computeHeaderPositionsOfSheet(e){return{COL:this.computePositions(e,`COL`),ROW:this.computePositions(e,`ROW`)}}computePositions(e,t){let n={},r=0;for(let i=0;i<this.getters.getNumberHeaders(e,t)+1;i++)n[i]=r,!this.getters.isHeaderHidden(e,t,i)&&(r+=this.getters.getHeaderSize(e,t,i));return n}};let tW=new h().add(`settings`,FV).add(`sheet`,jV).add(`header grouping`,NV).add(`header visibility`,TV).add(`tables`,MV).add(`dataValidation`,SV).add(`cell`,gV).add(`merge`,DV).add(`headerSize`,wV).add(`borders`,hV).add(`conditional formatting`,xV).add(`figures`,CV).add(`chart`,yV).add(`image`,EV).add(`pivot_core`,PV).add(`spreadsheet_pivot_core`,IV).add(`tableStyle`,LV),nW=new h().add(`ui_sheet`,fU).add(`ui_options`,dU).add(`autofill`,SH).add(`sort`,uU).add(`automatic_sum`,CH).add(`format`,oU).add(`insert_pivot`,lU).add(`pivot_presence`,GU).add(`split_to_columns`,KU).add(`collaborative`,iU).add(`history`,UU).add(`data_cleanup`,aU).add(`table_autofill`,qU).add(`table_ui_resize`,JU).add(`datavalidation_insert`,_U).add(`geo_features`,sU),rW=new h().add(`selection`,ZU).add(`evaluation_filter`,XU).add(`header_visibility_ui`,cU).add(`cell_computed_style`,gU).add(`table_computed_style`,pU).add(`header_positions`,eW).add(`viewport`,$U).add(`clipboard`,YU),iW=new h().add(`evaluation`,iH).add(`evaluation_chart`,lH).add(`evaluation_cf`,uH).add(`row_size`,mH).add(`data_validation_ui`,fH).add(`dynamic_tables`,pH).add(`custom_colors`,cH).add(`pivot_ui`,yH),aW=new h;aW.add(`link`,{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t,n)=>bo(t.model.getters.getEvaluatedCell(e).link,t,n),sequence:5});var oW=class{fileStore;constructor(e){this.fileStore=e}async requestImage(){let e=await this.userImageUpload(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}async uploadFile(e){let t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}userImageUpload(){return new Promise((e,t)=>{let n=document.createElement(`input`);n.setAttribute(`type`,`file`),n.setAttribute(`accept`,`image/*`),n.addEventListener(`change`,async()=>{n.files===null||n.files.length!==1?t():e(n.files[0])}),n.click()})}getImageOriginalSize(e){return new Promise((t,n)=>{let r=new Image;r.addEventListener(`load`,()=>{t({width:r.width,height:r.height})}),r.addEventListener(`error`,n),r.src=e})}};let sW=[{transform:`scale(0)`},{transform:`scale(0.8)`,offset:.33},{opacity:`0`,transform:`scale(1)`,offset:1}];H`
|
|
1983
|
+
You can download it directly instead.`,5),sticky:!1,type:`warning`});return}r=await aD(t)}}if(r)return r instanceof File?r:new File([r],`image.png`,{type:`image/png`})}isCutOperation(){return this._isCutOperation??!1}getDeleteCellsTargets(e,t){let n=this.getters.getActiveSheetId(),r;return r=t===`COL`?{...e,left:e.right+1,right:this.getters.getNumberCols(n)-1}:{...e,top:e.bottom+1,bottom:this.getters.getNumberRows(n)-1},{cut:[r],paste:[e]}}getInsertCellsTargets(e,t){let n=this.getters.getActiveSheetId(),r,i;return t===`COL`?(r={...e,right:this.getters.getNumberCols(n)-1},i={...e,left:e.right+1,right:e.right+1}):(r={...e,bottom:this.getters.getNumberRows(n)-1},i={...e,top:e.bottom+1,bottom:this.getters.getNumberRows(n)-1}),{cut:[r],paste:[i]}}getClipboardData(e){let t=this.getters.getActiveSheetId(),n=this.getters.getSelectedFigureId();if(n)return{figureId:n,sheetId:t};let r=sl(t,e);return this._isCutOperation||(r.rowsIndexes=r.rowsIndexes.filter(e=>!this.getters.isRowFiltered(t,e))),r}drawLayer(e){if(this.status!==`visible`||!this.copiedData)return;let{sheetId:t,zones:n}=this.copiedData;if(t!==this.getters.getActiveSheetId()||!n||!n.length)return;let{ctx:r,thinLineWidth:i}=e;r.setLineDash([8,5]),r.strokeStyle=ie,r.lineWidth=3.3*i;for(let e of n){let{x:t,y:n,width:i,height:a}=this.getters.getVisibleRect(e);i>0&&a>0&&r.strokeRect(t,n,i,a)}}},XU=class extends bH{static getters=[`getFilterHiddenValues`,`getFirstTableInSelection`,`isRowFiltered`,`isFilterActive`];filterValues={};hiddenRows={};isEvaluationDirty=!1;allowDispatch(e){switch(e.type){case`UPDATE_FILTER`:if(!this.getters.getFilterId(e))return`FilterNotFound`;break}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(let 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]=b(this.filterValues[e.sheetId]);break}}finalize(){if(this.isEvaluationDirty){for(let e of this.getters.getSheetIds())this.updateHiddenRows(e);this.isEvaluationDirty=!1}}isRowFiltered(e,t){return!!this.hiddenRows[e]?.has(t)}getFilterHiddenValues(e){let t=this.getters.getFilterId(e),n=e.sheetId;return!t||!this.filterValues[n]?[]:this.filterValues[n][t]||[]}isFilterActive(e){let t=this.getters.getFilterId(e),n=e.sheetId;return!!(t&&this.filterValues[n]?.[t]?.length)}getFirstTableInSelection(){let e=this.getters.getActiveSheetId(),t=this.getters.getSelectedZones();return this.getters.getTablesOverlappingZones(e,t)[0]}updateFilter({col:e,row:t,hiddenValues:n,sheetId:r}){let i=this.getters.getFilterId({sheetId:r,col:e,row:t});i&&(this.filterValues[r]||(this.filterValues[r]={}),this.filterValues[r][i]=n)}updateHiddenRows(e){let t=this.getters.getFilters(e).sort((e,t)=>e.rangeWithHeaders.zone.top-t.rangeWithHeaders.zone.top),n=new Set;for(let r of t){if(n.has(r.rangeWithHeaders.zone.top)||this.getters.isRowHiddenByUser(e,r.rangeWithHeaders.zone.top))continue;let t=this.filterValues[e]?.[r.id]?.map($c),i=r.filteredRange?.zone;if(!t||!i)continue;let a=new Set(t);for(let t=i.top;t<=i.bottom;t++){let i=this.getCellValueAsString(e,r.col,t);a.has(i)&&n.add(t)}}this.hiddenRows[e]=n}getCellValueAsString(e,t,n){return this.getters.getEvaluatedCell({sheetId:e,col:t,row:n}).formattedValue.toLowerCase()}exportForExcel(e){for(let t of e.sheets){let e=t.id;for(let n of t.tables){let r=ar(n.range),i=[],a=[];for(let n of S(0,br(r).numberOfCols)){let o={sheetId:t.id,col:r.left+n,row:r.top},s=this.getFilterHiddenValues(o),c=this.getters.getFilter(o),l=c?.filteredRange?wr(c.filteredRange.zone).map(t=>this.getters.getEvaluatedCell({sheetId:e,...t}).formattedValue):[];if(s.length){let e=l.filter(e=>e).filter(e=>!s.includes(e));i.push({colId:n,displayedValues:[...new Set(e)],displayBlanks:!s.includes(``)&&l.some(e=>!e)})}let u=this.getters.getEvaluatedCell(o).formattedValue,d=this.getUniqueColNameForExcel(n,u,a);a.push(d);let f=T(o.col,o.row);t.cells[f]=d,t.cellValues[f]=d}n.filters=i}}}getUniqueColNameForExcel(e,t,n){return t||=`Column${e}`,$t(t,n,{compute:(e,n)=>t+String(n),start:2})}},ZU=class extends bH{static layers=[`Selection`];static getters=[`getActiveSheet`,`getActiveSheetId`,`getActiveSheetName`,`getActiveCell`,`getActiveCols`,`getActiveRows`,`getCurrentStyle`,`getSelectedZones`,`getSelectedZone`,`getSelectedCells`,`getSelectedFigureId`,`getSelection`,`getActivePosition`,`getSheetPosition`,`isSingleColSelected`,`getElementsFromSelection`,`tryGetActiveSheetId`,`isGridSelectionActive`];gridSelection={anchor:{cell:{col:0,row:0},zone:{top:0,left:0,bottom:0,right:0}},zones:[{top:0,left:0,bottom:0,right:0}]};selectedFigureId=null;sheetsData={};moveClient;activeSheet=null;constructor(e){super(e),this.moveClient=e.moveClient}allowDispatch(e){switch(e.type){case`ACTIVATE_SHEET`:try{if(!this.getters.getSheet(e.sheetIdTo).isVisible)return`SheetIsHidden`;break}catch{return`InvalidSheetId`}case`MOVE_COLUMNS_ROWS`:return this.isMoveElementAllowed(e)}return`Success`}handleEvent(e){let t=e.anchor,n=[];switch(e.mode){case`overrideSelection`:n=[t.zone];break;case`updateAnchor`:n=[...this.gridSelection.zones];let r=n.findIndex(t=>gr(t,e.previousAnchor.zone));r>=0&&(n[r]=t.zone);break;case`newAnchor`:n=[...this.gridSelection.zones,t.zone];break}this.setSelectionMixin(e.anchor,n),this.selection.resetDefaultAnchor(this,b(this.gridSelection.anchor));let{col:r,row:i}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:r,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);break}switch(e.type){case`START`:let t=this.getters.getVisibleSheetIds()[0];this.activateSheet(t,t);let{col:n,row:r}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(n,r),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`:{let t=this.getters.getActiveSheetId();if(e.sheetId===t){e.dimension===`COL`?this.onColumnsRemoved(e):this.onRowsRemoved(e);let{col:n,row:r}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:n,row:r})}break}case`ADD_COLUMNS_ROWS`:{let t=this.getters.getActiveSheetId();if(e.sheetId===t){this.onAddElements(e);let{col:n,row:r}=this.gridSelection.anchor.cell;this.moveClient({sheetId:t,col:n,row:r})}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`:let i=Object.keys(this.sheetsData).filter(e=>!this.getters.tryGetSheet(e));for(let e of i)delete this.sheetsData[e];for(let e in this.sheetsData){let t=this.clipSelection(e,this.sheetsData[e].gridSelection);this.sheetsData[e]={gridSelection:b(t)}}this.fallbackToVisibleSheet();let a=this.getters.getActiveSheetId();this.gridSelection.zones=this.gridSelection.zones.map(e=>this.getters.expandZone(a,e)),this.gridSelection.anchor.zone=this.getters.expandZone(a,this.gridSelection.anchor.zone),this.setSelectionMixin(this.gridSelection.anchor,this.gridSelection.zones),this.selectedFigureId=null;break}}finalize(){this.fallbackToVisibleSheet(),this.selection.resetDefaultAnchor(this,b(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(){let e=new Set;for(let t of this.gridSelection.zones)if(t.top===0&&t.bottom===this.getters.getNumberRows(this.getters.getActiveSheetId())-1)for(let n=t.left;n<=t.right;n++)e.add(n);return e}getActiveRows(){let e=new Set,t=this.getters.getActiveSheetId();for(let n of this.gridSelection.zones)if(n.left===0&&n.right===this.getters.getNumberCols(t)-1)for(let t=n.top;t<=n.bottom;t++)e.add(t);return e}getCurrentStyle(){let e=this.getters.getSelectedZone(),t=this.getters.getActiveSheetId();return this.getters.getCellStyle({sheetId:t,col:e.left,row:e.top})}getSelectedZones(){return b(this.gridSelection.zones)}getSelectedZone(){return b(this.gridSelection.anchor.zone)}getSelection(){return b(this.gridSelection)}getSelectedCells(){let e=this.getters.getActiveSheetId(),t=[];for(let n of this.gridSelection.zones)t.push(...this.getters.getEvaluatedCellsInZone(e,n));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();{let 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(){let e=this.getters.getSelectedZones();return!(e.length!==1||e[0].left!==e[0].right)}getElementsFromSelection(e){if(e===`COL`&&this.getters.getActiveCols().size===0||e===`ROW`&&this.getters.getActiveRows().size===0)return[];let t=this.getters.getSelectedZones(),n=[],r=e===`COL`?`left`:`top`,i=e===`COL`?`right`:`bottom`;for(let e of t){let t=Array.from({length:e[i]-e[r]+1},(t,n)=>e[r]+n);n=n.concat(t)}return[...new Set(n)].sort()}activateSheet(e,t){if(this.setActiveSheet(t),this.sheetsData[e]={gridSelection:b(this.gridSelection)},t in this.sheetsData)Object.assign(this,this.sheetsData[t]),this.selection.resetDefaultAnchor(this,b(this.gridSelection.anchor));else{let{col:e,row:n}=this.getters.getNextVisibleCellPosition({sheetId:t,col:0,row:0});this.selectCell(e,n)}let{col:n,row:r}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.activeSheet.id,col:n,row:r})}setSelectionMixin(e,t){let{anchor:n,zones:r}=this.clipSelection(this.getters.getActiveSheetId(),{anchor:e,zones:t});this.gridSelection.anchor=n,this.gridSelection.zones=Dr(r)}selectCell(e,t){let n=this.getters.getActiveSheetId(),r=this.getters.expandZone(n,{left:e,right:e,top:t,bottom:t});this.setSelectionMixin({zone:r,cell:{col:e,row:t}},[r])}setActiveSheet(e){this.activeSheet=this.getters.getSheet(e)}activateNextSheet(e){let t=this.getters.getSheetIds(),n=(t.findIndex(e=>e===this.activeSheet.id)+(e===`left`?t.length-1:1))%t.length;this.dispatch(`ACTIVATE_SHEET`,{sheetIdFrom:this.getActiveSheetId(),sheetIdTo:t[n]})}onColumnsRemoved(e){let{cell:t,zone:n}=this.gridSelection.anchor,r=dr(n,`left`,[...e.elements]),i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=dr(i,`left`,[...e.elements]);let a={cell:{col:i.left,row:i.top},zone:r},o=this.gridSelection.zones.map(t=>dr(t,`left`,[...e.elements]));this.setSelectionMixin(a,o)}onRowsRemoved(e){let{cell:t,zone:n}=this.gridSelection.anchor,r=dr(n,`top`,[...e.elements]),i={left:t.col,right:t.col,top:t.row,bottom:t.row};i=dr(i,`top`,[...e.elements]);let a={cell:{col:i.left,row:i.top},zone:r},o=this.gridSelection.zones.map(t=>dr(t,`top`,[...e.elements]));this.setSelectionMixin(a,o)}onAddElements(e){let t=e.dimension===`COL`?`left`:`top`,n=ur(this.gridSelection.anchor.zone,t,e.base,e.position,e.quantity),r=this.gridSelection.zones.map(n=>ur(n,t,e.base,e.position,e.quantity)),i={cell:{col:n.left,row:n.top},zone:n};this.setSelectionMixin(i,r)}onMoveElements(e){let t=e.elements.length,n=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});let r=e.dimension===`COL`,i=e.elements[0],a=e.elements[t-1],o=e.base<i,s=o&&r?t:0,c=o&&!r?t:0,l=o?e.elements.map(e=>e+t):e.elements,u={};for(let t of l)u[t]=this.getters.getHeaderSize(e.sheetId,e.dimension,t);let d=[{left:r?i+s:0,right:r?a+s:this.getters.getNumberCols(e.sheetId)-1,top:r?0:i+c,bottom:r?this.getters.getNumberRows(e.sheetId)-1:a+c}],f=this.getActiveSheetId(),p=o?e.base:e.base+1,m=[{left:r?p:0,right:r?p+t-1:this.getters.getNumberCols(e.sheetId)-1,top:r?0:p,bottom:r?this.getters.getNumberRows(e.sheetId)-1:p+t-1}];for(let e of zd.cellHandlers.getAll()){let t=new e(this.getters,this.dispatch),n=t.copy(sl(f,d),!1,`shiftCells`);n&&t.paste({zones:m,sheetId:f},n,{isCutOperation:!0})}let h=m[0],g=h.left,_=h.top;this.setSelectionMixin({zone:h,cell:{col:g,row:_}},[h]);let v=o?e.base:e.base+1,y={};for(let t of l){let n=u[t];n!==this.getters.getHeaderSize(e.sheetId,e.dimension,v)&&(y[n]??=[],y[n].push(v)),v+=1}for(let t in y)this.dispatch(`RESIZE_COLUMNS_ROWS`,{dimension:e.dimension,sheetId:e.sheetId,size:parseInt(t,10),elements:y[t]});this.dispatch(`REMOVE_COLUMNS_ROWS`,{dimension:e.dimension,sheetId:e.sheetId,sheetName:e.sheetName,elements:l}),this.applyFigureUpdates(n)}getFiguresUpdates(e){let t=[],n={},r=e.elements[0]<e.base?e.base-e.elements.length+1:e.base;for(let t=0;t<e.elements.length;t++)n[e.elements[t]]=r+t;for(let r of this.getters.getFigures(e.sheetId))e.dimension===`COL`&&r.col in n&&t.push({type:`UPDATE_FIGURE`,sheetId:e.sheetId,figureId:r.id,col:n[r.col],row:r.row}),e.dimension===`ROW`&&r.row in n&&t.push({type:`UPDATE_FIGURE`,sheetId:e.sheetId,figureId:r.id,row:n[r.row],col:r.col});return t}applyFigureUpdates(e){for(let t of e)this.dispatch(t.type,{...t})}isMoveElementAllowed(e){let t=e.dimension===`COL`,n=e.elements[0],r=e.elements[e.elements.length-1],i=e.sheetId,a=t?this.getters.doesColumnsHaveCommonMerges:this.getters.doesRowsHaveCommonMerges;if(a(i,n-1,n)||a(i,r,r+1)||a(i,e.base-1,e.base))return`WillRemoveExistingMerge`;let o=[e.base,...e.elements],s=t?this.getters.getNumberCols(i):this.getters.getNumberRows(i);return o.some(e=>e<0||e>=s)?`InvalidHeaderIndex`:!t&&!this.isTableRowMoveAllowed(i,e.elements)?`CannotMoveTableHeader`:`Success`}isTableRowMoveAllowed(e,t){let n=this.getters.getCoreTables(e);if(n.length===0)return!0;let r=new Set(t);return n.every(({range:{zone:e},config:n})=>{let{top:i,bottom:a}=e;if(n.numberOfHeaders===0)return!0;let o=i+n.numberOfHeaders-1;return t.some(e=>e>=i&&e<=o)?S(i,a+1).every(e=>r.has(e)):!0})}fallbackToVisibleSheet(){if(!this.getters.tryGetSheet(this.getters.getActiveSheetId())){let e=this.getters.getVisibleSheetIds();if(this.activeSheet=this.getters.getSheet(e[0]),this.activeSheet.id in this.sheetsData){let{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);let{col:t,row:n}=this.gridSelection.anchor.cell;this.moveClient({sheetId:this.getters.getActiveSheetId(),col:t,row:n})}}clipSelection(e,t){let n=this.getters.getNumberCols(e)-1,r=this.getters.getNumberRows(e)-1,i=t.zones.map(e=>({left:x(e.left,0,n),right:x(e.right,0,n),top:x(e.top,0,r),bottom:x(e.bottom,0,r)})),a=x(t.anchor.cell.col,0,n),o=x(t.anchor.cell.row,0,r),s={left:x(t.anchor.zone.left,0,n),right:x(t.anchor.zone.right,0,n),top:x(t.anchor.zone.top,0,r),bottom:x(t.anchor.zone.bottom,0,r)};return{zones:i,anchor:{cell:{col:a,row:o},zone:s}}}drawLayer(e){if(this.getters.isDashboard())return;let{ctx:t,thinLineWidth:n}=e,r=this.getSelectedZones();t.fillStyle=`#f3f7fe`,t.fillStyle=r.length===1&&r[0].left===r[0].right&&r[0].top===r[0].bottom?`#f3f7fe`:`#e9f0ff`,t.strokeStyle=ie,t.lineWidth=1.5*n;for(let e of r){let{x:n,y:r,width:i,height:a}=this.getters.getVisibleRect(e);t.globalCompositeOperation=`multiply`,t.fillRect(n,r,i,a),t.globalCompositeOperation=`source-over`,t.strokeRect(n,r,i,a)}t.globalCompositeOperation=`source-over`;let i=this.getActivePosition();t.strokeStyle=ie,t.lineWidth=3*n;let a;a=this.getters.isInMerge(i)?this.getters.getMerge(i):E(i);let{x:o,y:s,width:c,height:l}=this.getters.getVisibleRect(a);c>0&&l>0&&t.strokeRect(o,s,c,l)}},QU=class{getters;sheetId;boundaries;top;bottom;left;right;offsetX;offsetY;canScrollVertically;canScrollHorizontally;viewportWidth;viewportHeight;offsetCorrectionX;offsetCorrectionY;constructor(e,t,n,r,i,a){if(this.getters=e,this.sheetId=t,this.boundaries=n,r.width<0||r.height<0)throw Error(`Viewport size cannot be negative`);this.viewportWidth=r.height&&r.width,this.viewportHeight=r.width&&r.height,this.top=n.top,this.bottom=n.bottom,this.left=n.left,this.right=n.right,this.offsetX=a.x,this.offsetY=a.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(){let 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:n}=this.getters.getColDimensions(this.sheetId,e),{end:r}=this.getters.getRowDimensions(this.sheetId,t),i=n-this.offsetCorrectionX;this.canScrollHorizontally&&(i=Math.max(i,this.viewportWidth));let a=r-this.offsetCorrectionY;return this.canScrollVertically&&(a=Math.max(a,this.viewportHeight),r+46>a&&!this.getters.isReadonly()&&(a+=46)),{width:i,height:a}}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){let t=this.sheetId,n=this.getters.getMainCellPosition({sheetId:t,...e}),{col:r,row:i}=this.getters.getNextVisibleCellPosition(n);vr(r,this.boundaries.top,this.boundaries)&&this.adjustPositionX(r),vr(this.boundaries.left,i,this.boundaries)&&this.adjustPositionY(i)}adjustPositionX(e){let t=this.sheetId,{start:n,end:r}=this.getters.getColDimensions(t,e);this.offsetX+this.viewportWidth+this.offsetCorrectionX<r?this.offsetX=r-this.viewportWidth:this.offsetX+this.offsetCorrectionX>n&&(this.offsetX=n-this.offsetCorrectionX),this.adjustViewportZoneX()}adjustPositionY(e){let t=this.sheetId,{start:n,end:r}=this.getters.getRowDimensions(t,e);this.offsetY+this.viewportHeight+this.offsetCorrectionY<r?this.offsetY=r-this.viewportHeight:this.offsetY+this.offsetCorrectionY>n&&(this.offsetY=n-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){let t=hr(e,this),n=this.snapCorrection.x,r=this.snapCorrection.y;if(t)return{x:this.getters.getColRowOffset(`COL`,this.left,t.left)+this.offsetCorrectionX-(this.left===t.left?0:n),y:this.getters.getColRowOffset(`ROW`,this.top,t.top)+this.offsetCorrectionY-(this.top===t.top?0:r),width:Math.min(this.getters.getColRowOffset(`COL`,t.left,t.right+1)-(this.left===t.left?n:0),this.viewportWidth),height:Math.min(this.getters.getColRowOffset(`ROW`,t.top,t.bottom+1)-(this.top===t.top?r:0),this.viewportHeight)}}getFullRect(e){let t=hr(e,this.boundaries),n=this.snapCorrection.x,r=this.snapCorrection.y;if(t){let t=this.getters.getColRowOffset(`COL`,this.left,e.left)+this.offsetCorrectionX,i=this.getters.getColRowOffset(`ROW`,this.top,e.top)+this.offsetCorrectionY,a=this.getters.getColRowOffset(`COL`,e.left,e.right+1),o=this.getters.getColRowOffset(`ROW`,e.top,e.bottom+1);return{x:t-n,y:i-r,width:a,height:o}}}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,n=0){if(this.viewportWidth<=0||this.viewportHeight<=0)return-1;let r=this.sheetId,i=this.getters.getNumberHeaders(r,e),a=n,o=i;for(;a<=o&&a!==i&&o!==-1;){let i=Math.floor((a+o)/2),s=this.getters.getColRowOffset(e,n,i),c=this.getters.getHeaderSize(r,e,i);if(t>=s&&t<s+c)return i;t>=s+c?a=i+1:o=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){let{width:e}=this.getMaxSize();this.viewportWidth+this.offsetX>e&&(this.offsetX=Math.max(0,e-this.viewportWidth))}this.adjustViewportZoneX()}adjustViewportOffsetY(){if(this.canScrollVertically){let{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&&(this.left===-1&&(this.left=this.boundaries.left),this.right===-1&&(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&&(this.top===-1&&(this.top=this.boundaries.top),this.bottom===-1&&(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)))}}},$U=class extends bH{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`.split(`.`);viewports={};sheetViewWidth=Ze();sheetViewHeight=Ze();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){let t=this.getters.getActiveSheetId();if(e.options.scrollIntoView){let{col:n,row:r}=kr(e.previousAnchor.zone,e.anchor.zone);if(e.mode===`updateAnchor`){let i=e.previousAnchor.zone,a=e.anchor.zone,{top:o,bottom:s,left:c,right:l}=this.getMainInternalViewport(t);i.left===a.left&&i.right===a.right&&(n=c>n||n>l?c:n),i.top===a.top&&i.bottom===a.bottom&&(r=o>r||r>s?o:r)}n=Math.min(n,this.getters.getNumberCols(t)-1),r=Math.min(r,this.getters.getNumberRows(t)-1),this.sheetsWithDirtyViewports.has(t)||this.refreshViewport(this.getters.getActiveSheetId(),{col:n,row:r})}}handle(e){if(ta.has(e.type))for(let 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(let 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`:let t=this.getters.getActiveSheetId(),{top:n,viewportHeight:r,offsetCorrectionY:i}=this.getMainInternalViewport(t),a=this.getters.getRowDimensions(t,n);this.shiftVertically(a.start+r-i);break;case`SHIFT_VIEWPORT_UP`:{let e=this.getters.getActiveSheetId(),{top:t,viewportHeight:n,offsetCorrectionY:r}=this.getMainInternalViewport(e),i=this.getters.getRowDimensions(e,t);this.shiftVertically(i.end-r-n);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`:for(let 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});break}}finalize(){for(let e of this.sheetsWithDirtyViewports)if(this.resetViewports(e),this.shouldAdjustViewports){let t=this.getters.getSheetPosition(e);this.getSubViewports(e).forEach(e=>{e.adjustPosition(t)})}this.sheetsWithDirtyViewports=new Set,this.shouldAdjustViewports=!1,this.setViewports()}setViewports(){let e=this.getters.getSheetIds();for(let t of e)this.viewports[t]?.bottomRight||this.resetViewports(t)}getColIndex(e){let t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map(t=>t.getColIndex(e)))}getRowIndex(e){let t=this.getters.getActiveSheetId();return Math.max(...this.getSubViewports(t).map(t=>t.getRowIndex(e)))}getSheetViewDimensionWithHeaders(){return{width:this.sheetViewWidth+this.gridOffsetX,height:this.sheetViewHeight+this.gridOffsetY}}getSheetViewDimension(){return{width:this.sheetViewWidth,height:this.sheetViewHeight}}getActiveMainViewport(){let e=this.getters.getActiveSheetId();return this.getMainViewport(e)}getActiveSheetScrollInfo(){let e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e);return{scrollX:t.offsetX,scrollY:t.offsetY}}getSheetViewVisibleCols(){let e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map(e=>S(e.left,e.right+1)).flat())].filter(t=>t>=0&&!this.getters.isHeaderHidden(e,`COL`,t))}getSheetViewVisibleRows(){let e=this.getters.getActiveSheetId(),t=this.getSubViewports(e);return[...new Set(t.map(e=>S(e.top,e.bottom+1)).flat())].filter(t=>t>=0&&!this.getters.isHeaderHidden(e,`ROW`,t))}getVisibleCellPositions(){let e=this.getSheetViewVisibleCols(),t=this.getSheetViewVisibleRows(),n=this.getters.getActiveSheetId(),r=[];for(let i of e)for(let e of t){let t={sheetId:n,col:i,row:e},a=this.getters.getMainCellPosition(t);a.row!==e||a.col!==i||r.push(t)}return r}getMainViewportRect(){let e=this.getters.getActiveSheetId(),t=this.getMainInternalViewport(e),{xSplit:n,ySplit:r}=this.getters.getPaneDivisions(e),{width:i,height:a}=t.getMaxSize();return{x:this.getters.getColDimensions(e,n).start,y:this.getters.getRowDimensions(e,r).start,width:i,height:a}}getMaximumSheetOffset(){let e=this.getters.getActiveSheetId(),{width:t,height:n}=this.getMainViewportRect(),r=this.getMainInternalViewport(e);return{maxOffsetX:Math.max(0,t-r.viewportWidth),maxOffsetY:Math.max(0,n-r.viewportHeight)}}getColRowOffsetInViewport(e,t,n){if(n<t)return-this.getColRowOffsetInViewport(e,n,t);let r=this.getters.getActiveSheetId(),i=e===`COL`?this.getters.getSheetViewVisibleCols():this.getters.getSheetViewVisibleRows(),a=i.findIndex(e=>t>=e),o=i.findIndex(e=>n<=e);o=o===-1?i.length:o;let s=i.slice(a,o),c=0;for(let t of s)c+=this.getters.getHeaderSize(r,e,t);return c}isVisibleInViewport({sheetId:e,col:t,row:n}){return this.getSubViewports(e).some(e=>e.isVisible(t,n))}getEdgeScrollCol(e,t,n){let r=!1,i=0,a=0,{xSplit:o}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{width:s}=this.getSheetViewDimension(),{x:c}=this.getMainViewportCoordinates(),l=this.getActiveSheetScrollInfo().scrollX;return e>s?(r=!0,a=Ks(e-s),i=1):e<c&&n>=c&&l>0?(r=!0,a=Ks(c-e),i=-1):o&&t<c&&e>c&&(r=!0,a=Ks(e),i=`reset`),{canEdgeScroll:r,direction:i,delay:a}}getEdgeScrollRow(e,t,n){let r=!1,i=0,a=0,{ySplit:o}=this.getters.getPaneDivisions(this.getters.getActiveSheetId()),{height:s}=this.getSheetViewDimension(),{y:c}=this.getMainViewportCoordinates(),l=this.getActiveSheetScrollInfo().scrollY;return e>s?(r=!0,a=Ks(e-s),i=1):e<c&&n>=c&&l>0?(r=!0,a=Ks(c-e),i=-1):o&&t<c&&e>c&&(r=!0,a=Ks(e),i=`reset`),{canEdgeScroll:r,direction:i,delay:a}}getVisibleRect(e){let t=this.getVisibleRectWithoutHeaders(e);return{...t,x:t.x+this.gridOffsetX,y:t.y+this.gridOffsetY}}getVisibleRectWithoutHeaders(e){let t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,t=>t.getVisibleRect(e))}getRect(e){let t=this.getters.getActiveSheetId(),n=this.mapViewportsToRect(t,t=>t.getFullRect(e));return{...n,x:n.x+this.gridOffsetX,y:n.y+this.gridOffsetY}}getRectWithoutHeaders(e){let t=this.getters.getActiveSheetId();return this.mapViewportsToRect(t,t=>t.getFullRect(e))}getMainViewportCoordinates(){let e=this.getters.getActiveSheetId(),{xSplit:t,ySplit:n}=this.getters.getPaneDivisions(e);return{x:this.getters.getColDimensions(e,t).start,y:this.getters.getRowDimensions(e,n).start}}getColDimensionsInViewport(e,t){let{top:n}=this.getMainInternalViewport(e),r={left:t,right:t,top:n,bottom:n},{x:i,width:a}=this.getVisibleRect(r),o=i-this.gridOffsetX;return{start:o,size:a,end:o+a}}getRowDimensionsInViewport(e,t){let{left:n}=this.getMainInternalViewport(e),r={left:0,right:n,top:t,bottom:t},{y:i,height:a}=this.getVisibleRect(r),o=i-this.gridOffsetY;return{start:o,size:a,end:o+a}}getAllActiveViewportsZonesAndRect(){let 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(C)}checkPositiveDimension(e){return e.width<0||e.height<0?`InvalidViewportSize`:`Success`}checkValuesAreDifferent(e){let{height:t,width:n}=this.getSheetViewDimension();return e.gridOffsetX===this.gridOffsetX&&e.gridOffsetY===this.gridOffsetY&&e.width===n&&e.height===t?`ValuesNotChanged`:`Success`}checkScrollingDirection({offsetX:e,offsetY:t}){let n=this.getMainInternalViewport(this.getters.getActiveSheetId());return!n.canScrollHorizontally&&e>0||!n.canScrollVertically&&t>0?`InvalidScrollingDirection`:`Success`}checkIfViewportsWillChange({offsetX:e,offsetY:t}){let n=this.getters.getActiveSheetId(),{maxOffsetX:r,maxOffsetY:i}=this.getMaximumSheetOffset();return this.getSubViewports(n).some(n=>n.willNewOffsetScrollViewport(x(e,0,r),x(t,0,i)))?`Success`:`ViewportScrollLimitsReached`}getMainViewport(e){let 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(){let e={};for(let t of this.getters.getSheetIds())e[t]=this.viewports[t];this.viewports=e}resizeSheetView(e,t,n=0,r=0){this.sheetViewHeight=e,this.sheetViewWidth=t,this.gridOffsetX=n,this.gridOffsetY=r,this.recomputeViewports()}recomputeViewports(){for(let e of this.getters.getSheetIds())this.resetViewports(e)}setSheetViewOffset(e,t){let n=this.getters.getActiveSheetId(),{maxOffsetX:r,maxOffsetY:i}=this.getMaximumSheetOffset();this.getSubViewports(n).forEach(n=>n.setViewportOffset(x(e,0,r),x(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;let{xSplit:t,ySplit:n}=this.getters.getPaneDivisions(e),r=this.getters.getNumberCols(e),i=this.getters.getNumberRows(e),a=Math.min(this.getters.getColRowOffset(`COL`,0,t,e),this.sheetViewWidth),o=Math.min(this.getters.getColRowOffset(`ROW`,0,n,e),this.sheetViewHeight),s=Math.max(this.sheetViewWidth-a,0),c=Math.max(this.sheetViewHeight-o,0),{xRatio:l,yRatio:u}=this.getFrozenSheetViewRatio(e),d=l<1,f=u<1,p=this.getViewportOffset(e),m={topLeft:n&&t&&new QU(this.getters,e,{left:0,right:t-1,top:0,bottom:n-1},{width:a,height:o},{canScrollHorizontally:!1,canScrollVertically:!1},{x:0,y:0})||void 0,topRight:n&&new QU(this.getters,e,{left:t,right:r-1,top:0,bottom:n-1},{width:s,height:o},{canScrollHorizontally:d,canScrollVertically:!1},{x:d?p.x:0,y:0})||void 0,bottomLeft:t&&new QU(this.getters,e,{left:0,right:t-1,top:n,bottom:i-1},{width:a,height:c},{canScrollHorizontally:!1,canScrollVertically:f},{x:0,y:f?p.y:0})||void 0,bottomRight:new QU(this.getters,e,{left:t,right:r-1,top:n,bottom:i-1},{width:s,height:c},{canScrollHorizontally:d,canScrollVertically:f},{x:d?p.x:0,y:f?p.y:0})};this.viewports[e]=m}refreshViewport(e,t){this.getSubViewports(e).forEach(e=>{e.adjustViewportZone(),e.adjustPosition(t)})}shiftVertically(e){let t=this.getters.getActiveSheetId(),{top:n}=this.getMainInternalViewport(t),{scrollX:r}=this.getActiveSheetScrollInfo();this.setSheetViewOffset(r,e);let{anchor:i}=this.getters.getSelection();if(i.cell.row>=this.getters.getPaneDivisions(t).ySplit){let e=this.getMainInternalViewport(t).top-n;this.selection.selectCell(i.cell.col,i.cell.row+e)}}getColIndexLeftOfMainViewport(e){if(e>=0)return-1;let t=this.getters.getActiveSheetId(),n=this.getActiveMainViewport().left,r=-this.getActiveSheetScrollInfo().scrollX-this.getters.getColRowOffset(`COL`,n,0);for(;e<r;n--)r-=this.getters.getColSize(t,n-1);return Math.max(n,0)}getRowIndexTopOfMainViewport(e){if(e>=0)return-1;let t=this.getters.getActiveSheetId(),n=this.getActiveMainViewport().top,r=-this.getActiveSheetScrollInfo().scrollY-this.getters.getColRowOffset(`ROW`,n,0);for(;e<r;n--)r-=this.getters.getRowSize(t,n-1);return Math.max(n,0)}getVisibleFigures(){let e=this.getters.getActiveSheetId(),t=[],n=this.getters.getFigures(e),{scrollX:r,scrollY:i}=this.getters.getActiveSheetScrollInfo(),{x:a,y:o}=this.getMainViewportCoordinates(),{width:s,height:c}=this.getters.getSheetViewDimensionWithHeaders();for(let l of n){let n=this.getFigureUI(e,l),{x:u,y:d}=n;u>=a&&(u+l.width<r+a||u>s+r+a)||d>=o&&(d+l.height<i+o||d>c+i+o)||t.push(n)}return t}getFigureUI(e,t){let n=t.offset.x+this.getters.getColDimensions(e,t.col).start,r=t.offset.y+this.getters.getRowDimensions(e,t.row).start;return{...t,x:n,y:r}}getPositionAnchorOffset(e){let{scrollX:t,scrollY:n}=this.getters.getActiveSheetScrollInfo(),r=e.x-t,i=e.y-n,a=r>=0?this.getColIndex(r):this.getColIndexLeftOfMainViewport(r),o=i>=0?this.getRowIndex(i):this.getRowIndexTopOfMainViewport(i),{x:s,y:c}=this.getRect(E({col:a,row:o}));return{col:a,row:o,offset:{x:Math.max(r-s+this.gridOffsetX,0),y:Math.max(i-c+this.gridOffsetY,0)}}}isPixelPositionVisible(e){let{scrollX:t,scrollY:n}=this.getters.getActiveSheetScrollInfo(),{x:r,y:i}=this.getters.getMainViewportCoordinates(),{width:a,height:o}=this.getters.getSheetViewDimension();return!(e.x>=r&&(e.x<r+t||e.x>a+t+r)||e.y>=i&&(e.y<i+n||e.y>o+n+i))}getFrozenSheetViewRatio(e){let{xSplit:t,ySplit:n}=this.getters.getPaneDivisions(e),r=this.getters.getColDimensions(e,t).start,i=this.getters.getRowDimensions(e,n).start,a=this.sheetViewWidth+this.gridOffsetX,o=this.sheetViewHeight+this.gridOffsetY;return{xRatio:r/a,yRatio:i/o}}mapViewportsToRect(e,t){let n=1/0,r=1/0,i=0,a=0,o=!1;for(let s of this.getSubViewports(e)){let e=t(s);e&&(o=!0,n=Math.min(n,e.x),r=Math.min(r,e.y),i=Math.max(i,e.x+e.width),a=Math.max(a,e.y+e.height))}return o?{x:n,y:r,width:i-n,height:a-r}:{x:0,y:0,width:0,height:0}}},eW=class extends bH{static getters=[`getColDimensions`,`getRowDimensions`,`getColRowOffset`];headerPositions={};isDirty=!0;handle(e){switch(ta.has(e.type)&&(this.headerPositions={},this.isDirty=!0),e.type){case`START`:for(let e of this.getters.getSheetIds())this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e);break;case`UPDATE_CELL`:this.headerPositions={},this.isDirty=!0;break;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]=b(this.headerPositions[e.sheetId]);break}}finalize(){for(let e of this.getters.getSheetIds())(this.isDirty||!this.headerPositions[e])&&(this.headerPositions[e]=this.computeHeaderPositionsOfSheet(e));this.isDirty=!1}getColDimensions(e,t){let n=this.headerPositions[e].COL[t],r=this.getters.getColSize(e,t);return{start:n,size:r,end:n+(this.getters.isColHidden(e,t)?0:r)}}getRowDimensions(e,t){let n=this.headerPositions[e].ROW[t],r=this.getters.getRowSize(e,t);return{start:n,size:r,end:n+(this.getters.isRowHidden(e,t)?0:r)}}getColRowOffset(e,t,n,r=this.getters.getActiveSheetId()){let i=this.headerPositions[r][e][t];return this.headerPositions[r][e][n]-i}computeHeaderPositionsOfSheet(e){return{COL:this.computePositions(e,`COL`),ROW:this.computePositions(e,`ROW`)}}computePositions(e,t){let n={},r=0;for(let i=0;i<this.getters.getNumberHeaders(e,t)+1;i++)n[i]=r,!this.getters.isHeaderHidden(e,t,i)&&(r+=this.getters.getHeaderSize(e,t,i));return n}};let tW=new h().add(`settings`,FV).add(`sheet`,jV).add(`header grouping`,NV).add(`header visibility`,TV).add(`tables`,MV).add(`dataValidation`,SV).add(`cell`,gV).add(`merge`,DV).add(`headerSize`,wV).add(`borders`,hV).add(`conditional formatting`,xV).add(`figures`,CV).add(`chart`,yV).add(`image`,EV).add(`pivot_core`,PV).add(`spreadsheet_pivot_core`,IV).add(`tableStyle`,LV),nW=new h().add(`ui_sheet`,fU).add(`ui_options`,dU).add(`autofill`,SH).add(`sort`,uU).add(`automatic_sum`,CH).add(`format`,oU).add(`insert_pivot`,lU).add(`pivot_presence`,GU).add(`split_to_columns`,KU).add(`collaborative`,iU).add(`history`,UU).add(`data_cleanup`,aU).add(`table_autofill`,qU).add(`table_ui_resize`,JU).add(`datavalidation_insert`,_U).add(`geo_features`,sU),rW=new h().add(`selection`,ZU).add(`evaluation_filter`,XU).add(`header_visibility_ui`,cU).add(`cell_computed_style`,gU).add(`table_computed_style`,pU).add(`header_positions`,eW).add(`viewport`,$U).add(`clipboard`,YU),iW=new h().add(`evaluation`,iH).add(`evaluation_chart`,lH).add(`evaluation_cf`,uH).add(`row_size`,mH).add(`data_validation_ui`,fH).add(`dynamic_tables`,pH).add(`custom_colors`,cH).add(`pivot_ui`,yH),aW=new h;aW.add(`link`,{condition:(e,t)=>!!t.getEvaluatedCell(e).link,execute:(e,t,n)=>bo(t.model.getters.getEvaluatedCell(e).link,t,n),sequence:5});var oW=class{fileStore;constructor(e){this.fileStore=e}async requestImage(){let e=await this.userImageUpload(),t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}async uploadFile(e){let t=await this.fileStore.upload(e);return{path:t,size:await this.getImageOriginalSize(t),mimetype:e.type}}userImageUpload(){return new Promise((e,t)=>{let n=document.createElement(`input`);n.setAttribute(`type`,`file`),n.setAttribute(`accept`,`image/*`),n.addEventListener(`change`,async()=>{n.files===null||n.files.length!==1?t():e(n.files[0])}),n.click()})}getImageOriginalSize(e){return new Promise((t,n)=>{let r=new Image;r.addEventListener(`load`,()=>{t({width:r.width,height:r.height})}),r.addEventListener(`error`,n),r.src=e})}};let sW=[{transform:`scale(0)`},{transform:`scale(0.8)`,offset:.33},{opacity:`0`,transform:`scale(1)`,offset:1}];H`
|
|
1984
1984
|
.o-ripple {
|
|
1985
1985
|
z-index: 1;
|
|
1986
1986
|
}
|
|
@@ -2419,7 +2419,7 @@ You can download it directly instead.`,5),sticky:!1,type:`warning`});return}r=aw
|
|
|
2419
2419
|
}
|
|
2420
2420
|
}
|
|
2421
2421
|
}
|
|
2422
|
-
`;var RW=class extends t.Component{static template=`o-spreadsheet-TopBar`;static props={onClick:Function,dropdownMaxHeight:Number};static components={Menu:EM,TopBarComposer:wW,Popover:SM};toolsCategories=LW.getCategories();state=(0,t.useState)({menuState:{isOpen:!1,anchorRect:null,menuItems:[]},invisibleToolsCategories:[],toolsPopoverState:{isOpen:!1}});isSelectingMenu=!1;openedEl=null;menus=[];toolbarMenuRegistry=LW;formatNumberMenuItemSpec=kI;isntToolbarMenu=!1;composerFocusStore;fingerprints;topBarToolStore;toolBarContainerRef=(0,t.useRef)(`toolBarContainer`);toolbarRef=(0,t.useRef)(`toolBar`);moreToolsContainerRef=(0,t.useRef)(`moreToolsContainer`);moreToolsButtonRef=(0,t.useRef)(`moreToolsButton`);spreadsheetRect=pM();setup(){this.composerFocusStore=V(nf),this.fingerprints=V(XF),this.topBarToolStore=V(TW),(0,t.useExternalListener)(window,`click`,this.onExternalClick),(0,t.onWillStart)(()=>this.updateCellState()),(0,t.onWillUpdateProps)(()=>this.updateCellState()),(0,t.useEffect)(()=>{this.state.toolsPopoverState.isOpen=!1,this.setVisibilityToolsGroups()},()=>[this.spreadsheetRect.width])}setVisibilityToolsGroups(){if(this.env.model.getters.isReadonly())return;let e=[],{x:t}=this.toolbarRef.el.getBoundingClientRect(),{x:n}=this.toolBarContainerRef.el.getBoundingClientRect();this.moreToolsContainerRef.el?.classList.remove(`d-none`);let r=this.moreToolsButtonRef.el?.getBoundingClientRect().width||0,i=Math.round(this.spreadsheetRect.width)-r-(t-n)-16,a=document.querySelectorAll(`.tool-container`),o=0;for(let t=0;t<a.length;t++){let n=a[t];n.classList.remove(`d-none`);let{width:r}=n.getBoundingClientRect();o+=r,o>i&&(n.classList.add(`d-none`),e.push(this.toolsCategories[t]))}this.state.invisibleToolsCategories=e,e.length||this.moreToolsContainerRef.el?.classList.add(`d-none`)}get topbarComponents(){return II.getAllOrdered().filter(e=>!e.isVisible||e.isVisible(this.env))}get currentFontSize(){return this.env.model.getters.getCurrentStyle().fontSize||Be}onExternalClick(e){this.openedEl!==e.target&&this.closeMenus()}onClick(){this.props.onClick(),this.closeMenus()}onMenuMouseOver(e,t){this.isSelectingMenu&&this.isntToolbarMenu&&this.openMenu(e,t)}toggleContextMenu(e,t){this.state.menuState.isOpen&&this.isntToolbarMenu?this.closeMenus():(this.openMenu(e,t),this.isntToolbarMenu=!0)}openMenu(e,t){this.topBarToolStore.currentDropdown&&this.topBarToolStore.closeDropdowns(),this.state.toolsPopoverState.isOpen=!1,this.state.menuState.isOpen=!0,this.state.menuState.anchorRect=JE(t.currentTarget),this.state.menuState.menuItems=e.children(this.env).sort((e,t)=>e.sequence-t.sequence),this.state.menuState.parentMenu=e,this.isSelectingMenu=!0,this.openedEl=t.target,this.composerFocusStore.activeComposer.stopEdition()}closeMenus(){this.topBarToolStore.currentDropdown&&this.topBarToolStore.closeDropdowns(),this.state.toolsPopoverState.isOpen=!1,this.state.menuState.isOpen=!1,this.state.menuState.parentMenu=void 0,this.isSelectingMenu=!1,this.openedEl=null}updateCellState(){this.menus=PI.getMenuItems()}getMenuName(e){return e.name(this.env)}setColor(e,t){AM(this.env,{[e]:t}),this.onClick()}setFontSize(e){AM(this.env,{fontSize:e})}toggleMoreTools(){this.topBarToolStore.currentDropdown&&this.topBarToolStore.closeDropdowns(),this.state.toolsPopoverState.isOpen=!this.state.toolsPopoverState.isOpen}get toolsPopoverProps(){return{anchorRect:this.moreToolsButtonRef.el?JE(this.moreToolsButtonRef.el):{x:0,y:0,width:0,height:0},positioning:`bottom-left`,verticalOffset:0,class:`rounded`,maxWidth:300}}showDivider(e){return e<this.toolsCategories.length-1||this.state.invisibleToolsCategories.length>0}};function zW(){return new BW(navigator.clipboard)}var BW=class{constructor(e){this.clipboard=e}async write(e){if(this.clipboard?.write)try{await this.clipboard?.write(this.getClipboardItems(e))}catch(t){console.log(`Failed to write on the clipboard, falling back to plain/html text. Error %s`,t);try{await this.clipboard?.write([new ClipboardItem({"text/plain":this.getBlob(e,`text/plain`),"text/html":this.getBlob(e,`text/html`)})])}catch{}}else await this.writeText(e[`text/plain`]??``)}async writeText(e){try{this.clipboard?.writeText(e)}catch{}}async read(){let e;try{e=await navigator.permissions.query({name:`clipboard-read`})}catch{}if(this.clipboard?.read)try{let e=await this.clipboard.read(),t={};for(let n of e)for(let e of n.types){let r=await n.getType(e);ol.includes(e)?t[e]=r:t[e]=await r.text()}return{status:`ok`,content:t}}catch{return{status:e?.state===`denied`?`permissionDenied`:`notImplemented`}}else return{status:`ok`,content:{"text/plain":await this.clipboard?.readText()}}}getClipboardItems(e){let t={};for(let n of Object.keys(e))t[n]=this.getBlob(e,n);return[new ClipboardItem(t)]}getBlob(e,t){let n=e[t];return n instanceof Blob||n instanceof File?n:new Blob([e[t]||``],{type:t})}};H`
|
|
2422
|
+
`;var RW=class extends t.Component{static template=`o-spreadsheet-TopBar`;static props={onClick:Function,dropdownMaxHeight:Number};static components={Menu:EM,TopBarComposer:wW,Popover:SM};toolsCategories=LW.getCategories();state=(0,t.useState)({menuState:{isOpen:!1,anchorRect:null,menuItems:[]},invisibleToolsCategories:[],toolsPopoverState:{isOpen:!1}});isSelectingMenu=!1;openedEl=null;menus=[];toolbarMenuRegistry=LW;formatNumberMenuItemSpec=kI;isntToolbarMenu=!1;composerFocusStore;fingerprints;topBarToolStore;toolBarContainerRef=(0,t.useRef)(`toolBarContainer`);toolbarRef=(0,t.useRef)(`toolBar`);moreToolsContainerRef=(0,t.useRef)(`moreToolsContainer`);moreToolsButtonRef=(0,t.useRef)(`moreToolsButton`);spreadsheetRect=pM();setup(){this.composerFocusStore=V(nf),this.fingerprints=V(XF),this.topBarToolStore=V(TW),(0,t.useExternalListener)(window,`click`,this.onExternalClick),(0,t.onWillStart)(()=>this.updateCellState()),(0,t.onWillUpdateProps)(()=>this.updateCellState()),(0,t.useEffect)(()=>{this.state.toolsPopoverState.isOpen=!1,this.setVisibilityToolsGroups()},()=>[this.spreadsheetRect.width])}setVisibilityToolsGroups(){if(this.env.model.getters.isReadonly())return;let e=[],{x:t}=this.toolbarRef.el.getBoundingClientRect(),{x:n}=this.toolBarContainerRef.el.getBoundingClientRect();this.moreToolsContainerRef.el?.classList.remove(`d-none`);let r=this.moreToolsButtonRef.el?.getBoundingClientRect().width||0,i=Math.round(this.spreadsheetRect.width)-r-(t-n)-16,a=document.querySelectorAll(`.tool-container`),o=0;for(let t=0;t<a.length;t++){let n=a[t];n.classList.remove(`d-none`);let{width:r}=n.getBoundingClientRect();o+=r,o>i&&(n.classList.add(`d-none`),e.push(this.toolsCategories[t]))}this.state.invisibleToolsCategories=e,e.length||this.moreToolsContainerRef.el?.classList.add(`d-none`)}get topbarComponents(){return II.getAllOrdered().filter(e=>!e.isVisible||e.isVisible(this.env))}get currentFontSize(){return this.env.model.getters.getCurrentStyle().fontSize||Be}onExternalClick(e){this.openedEl!==e.target&&this.closeMenus()}onClick(){this.props.onClick(),this.closeMenus()}onMenuMouseOver(e,t){this.isSelectingMenu&&this.isntToolbarMenu&&this.openMenu(e,t)}toggleContextMenu(e,t){this.state.menuState.isOpen&&this.isntToolbarMenu?this.closeMenus():(this.openMenu(e,t),this.isntToolbarMenu=!0)}openMenu(e,t){this.topBarToolStore.currentDropdown&&this.topBarToolStore.closeDropdowns(),this.state.toolsPopoverState.isOpen=!1,this.state.menuState.isOpen=!0,this.state.menuState.anchorRect=JE(t.currentTarget),this.state.menuState.menuItems=e.children(this.env).sort((e,t)=>e.sequence-t.sequence),this.state.menuState.parentMenu=e,this.isSelectingMenu=!0,this.openedEl=t.target,this.composerFocusStore.activeComposer.stopEdition()}closeMenus(){this.topBarToolStore.currentDropdown&&this.topBarToolStore.closeDropdowns(),this.state.toolsPopoverState.isOpen=!1,this.state.menuState.isOpen=!1,this.state.menuState.parentMenu=void 0,this.isSelectingMenu=!1,this.openedEl=null}updateCellState(){this.menus=PI.getMenuItems()}getMenuName(e){return e.name(this.env)}setColor(e,t){AM(this.env,{[e]:t}),this.onClick()}setFontSize(e){AM(this.env,{fontSize:e})}toggleMoreTools(){this.topBarToolStore.currentDropdown&&this.topBarToolStore.closeDropdowns(),this.state.toolsPopoverState.isOpen=!this.state.toolsPopoverState.isOpen}get toolsPopoverProps(){return{anchorRect:this.moreToolsButtonRef.el?JE(this.moreToolsButtonRef.el):{x:0,y:0,width:0,height:0},positioning:`bottom-left`,verticalOffset:0,class:`rounded`,maxWidth:300}}showDivider(e){return e<this.toolsCategories.length-1||this.state.invisibleToolsCategories.length>0}};function zW(){return new BW(navigator.clipboard)}var BW=class{clipboard;constructor(e){this.clipboard=e}async write(e){if(this.clipboard?.write)try{await this.clipboard?.write(this.getClipboardItems(e))}catch(t){console.log(`Failed to write on the clipboard, falling back to plain/html text. Error %s`,t);try{await this.clipboard?.write([new ClipboardItem({"text/plain":this.getBlob(e,`text/plain`),"text/html":this.getBlob(e,`text/html`)})])}catch{}}else await this.writeText(e[`text/plain`]??``)}async writeText(e){try{this.clipboard?.writeText(e)}catch{}}async read(){let e;try{e=await navigator.permissions.query({name:`clipboard-read`})}catch{}if(this.clipboard?.read)try{let e=await this.clipboard.read(),t={};for(let n of e)for(let e of n.types){let r=await n.getType(e);ol.includes(e)?t[e]=r:t[e]=await r.text()}return{status:`ok`,content:t}}catch{return{status:e?.state===`denied`?`permissionDenied`:`notImplemented`}}else return{status:`ok`,content:{"text/plain":await this.clipboard?.readText()}}}getClipboardItems(e){let t={};for(let n of Object.keys(e))t[n]=this.getBlob(e,n);return[new ClipboardItem(t)]}getBlob(e,t){let n=e[t];return n instanceof Blob||n instanceof File?n:new Blob([e[t]||``],{type:t})}};H`
|
|
2423
2423
|
.o-spreadsheet {
|
|
2424
2424
|
position: relative;
|
|
2425
2425
|
display: grid;
|
|
@@ -2647,7 +2647,7 @@ You can download it directly instead.`,5),sticky:!1,type:`warning`});return}r=aw
|
|
|
2647
2647
|
color: ${xe};
|
|
2648
2648
|
}
|
|
2649
2649
|
}
|
|
2650
|
-
`;var VW=class extends t.Component{static template=`o-spreadsheet-Spreadsheet`;static props={model:Object,notifyUser:{type:Function,optional:!0},raiseError:{type:Function,optional:!0},askConfirmation:{type:Function,optional:!0}};static components={TopBar:RW,Grid:dV,BottomBar:hW,SidePanel:CW,SpreadsheetDashboard:_W,HeaderGroupContainer:xW};sidePanel;spreadsheetRef=(0,t.useRef)(`spreadsheet`);spreadsheetRect=pM();_focusGrid;isViewportTooSmall=!1;notificationStore;composerFocusStore;get model(){return this.props.model}getStyle(){let e={};return this.env.isDashboard()?e[`grid-template-rows`]=`auto`:e[`grid-template-rows`]=`min-content auto min-content`,e[`grid-template-columns`]=`auto ${this.sidePanel.panelSize}px`,U(e)}setup(){let e=qd();e.inject(Qd,this.model),this.notificationStore=V(dC),this.composerFocusStore=V(nf),this.sidePanel=V(sV);let n=this.model.config.external.fileStore;if((0,t.useSubEnv)({model:this.model,imageProvider:n?new oW(n):void 0,loadCurrencies:this.model.config.external.loadCurrencies,loadLocales:this.model.config.external.loadLocales,isDashboard:()=>this.model.getters.isDashboard(),openSidePanel:this.sidePanel.open.bind(this.sidePanel),toggleSidePanel:this.sidePanel.toggle.bind(this.sidePanel),clipboard:this.env.clipboard||zW(),startCellEdition:e=>this.composerFocusStore.focusActiveComposer({content:e}),notifyUser:e=>this.notificationStore.notifyUser(e),askConfirmation:(e,t,n)=>this.notificationStore.askConfirmation(e,t,n),raiseError:(e,t)=>this.notificationStore.raiseError(e,t)}),!(`isSmall`in this.env)){let e=SW();(0,t.useSubEnv)({get isSmall(){return e.isSmall}})}this.notificationStore.updateNotificationCallbacks({...this.props}),(0,t.useEffect)(()=>{!this.spreadsheetRef.el.contains(document.activeElement)&&document.activeElement?.contains(this.spreadsheetRef.el)&&this.focusGrid()}),(0,t.useExternalListener)(window,`resize`,()=>this.render(!0)),(0,t.useExternalListener)(document.body,`wheel`,()=>{}),this.bindModelEvents(),(0,t.onWillUpdateProps)(e=>{if(e.model!==this.props.model)throw Error(`Changing the props model is not supported at the moment.`);(e.notifyUser!==this.props.notifyUser||e.askConfirmation!==this.props.askConfirmation||e.raiseError!==this.props.raiseError)&&this.notificationStore.updateNotificationCallbacks({...e})});let r=Dt(this.render.bind(this,!0));(0,t.onMounted)(()=>{this.checkViewportSize(),e.on(`store-updated`,this,r),i.observe(this.spreadsheetRef.el)}),(0,t.onWillUnmount)(()=>{this.unbindModelEvents(),e.off(`store-updated`,this),i.disconnect(),gf()}),(0,t.onPatched)(()=>{this.checkViewportSize()});let i=new ResizeObserver(()=>{this.sidePanel.changePanelSize(this.sidePanel.panelSize,this.spreadsheetRect.width)})}bindModelEvents(){this.model.on(`update`,this,()=>this.render(!0)),this.model.on(`notify-ui`,this,e=>this.notificationStore.notifyUser(e)),this.model.on(`raise-error-ui`,this,({text:e})=>this.notificationStore.raiseError(e))}unbindModelEvents(){this.model.off(`update`,this),this.model.off(`notify-ui`,this),this.model.off(`raise-error-ui`,this)}checkViewportSize(){let{xRatio:e,yRatio:t}=this.env.model.getters.getFrozenSheetViewRatio(this.env.model.getters.getActiveSheetId());if(!(!isFinite(e)||!isFinite(t)))if(t>.85||e>.85){if(this.isViewportTooSmall)return;this.notificationStore.notifyUser({text:O(`The current window is too small to display this sheet properly. Consider resizing your browser window or adjusting frozen rows and columns.`),type:`warning`,sticky:!1}),this.isViewportTooSmall=!0}else this.isViewportTooSmall=!1}focusGrid(){this._focusGrid&&this._focusGrid()}get gridHeight(){return this.env.model.getters.getSheetViewDimension().height}get gridContainerStyle(){let e=21*this.rowLayers.length,t=21*this.colLayers.length;return U({"grid-template-columns":`${e?e+2:0}px auto`,"grid-template-rows":`${t?t+2:0}px auto`})}get rowLayers(){let e=this.env.model.getters.getActiveSheetId();return this.env.model.getters.getVisibleGroupLayers(e,`ROW`)}get colLayers(){let e=this.env.model.getters.getActiveSheetId();return this.env.model.getters.getVisibleGroupLayers(e,`COL`)}},HW=class{listeners=[];async sendMessage(e){for(let{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)}};function UW(e){return FD.get(e.type)(e)}var WW=class e{constructor(e,t=[]){this.buildTransformation=e,this.operations=t}getOperations(){return this.operations}getOperation(e){let t=this.operations.find(t=>t.id===e);if(!t)throw Error(`Operation ${e} not found`);return t}getLastOperationId(){return this.operations[this.operations.length-1]?.id}getFirstOperationAmong(e,t){for(let n of this.operations){if(n.id===e)return e;if(n.id===t)return t}throw Error(`Operation ${e} and ${t} not found`)}contains(e){return!!this.operations.find(t=>t.id===e)}prepend(e){let t=this.buildTransformation.with(e.data);this.operations=[e,...this.operations.map(e=>e.transformed(t))]}insert(e,t){let n=this.buildTransformation.with(e.data),{before:r,operation:i,after:a}=this.locateOperation(t);this.operations=[...r,i,e,...a.map(e=>e.transformed(n))]}append(e){this.operations.push(e)}appendBranch(e){this.operations=this.operations.concat(e.operations)}fork(t){let{after:n}=this.locateOperation(t);return new e(this.buildTransformation,n)}transform(e){this.operations=this.operations.map(t=>t.transformed(e))}cutBefore(e){this.operations=this.locateOperation(e).before}cutAfter(e){let{before:t,operation:n}=this.locateOperation(e);this.operations=t.concat([n])}locateOperation(e){let t=this.operations.findIndex(t=>t.id===e);if(t===-1)throw Error(`Operation ${e} not found`);return{before:this.operations.slice(0,t),operation:this.operations[t],after:this.operations.slice(t+1)}}},GW=class{constructor(e,t){this.id=e,this.data=t}transformed(e){return new KW(this.id,kt(()=>e(this.data)))}},KW=class e{constructor(e,t){this.id=e,this.lazyData=t}get data(){return this.lazyData()}transformed(t){return new e(this.id,this.lazyData.map(t))}},qW=class e{constructor(e){this.operations=e}[Symbol.iterator](){return this.operations[Symbol.iterator]()}stopWith(t){function*n(e,t){for(let n of e)if(yield n,n.operation.id===t)return}return new e(n(this.operations,t))}stopBefore(t){function*n(e,t){for(let n of e){if(n.operation.id===t)return;yield n}}return new e(n(this.operations,t))}startAfter(t){function*n(e,t){let n=!0;for(let r of e)n||(yield r),r.operation.id===t&&(n=!1)}return new e(n(this.operations,t))}},JW=class{branches;branchingOperationIds=new Map;constructor(e,t){this.buildTransformation=e,this.branches=[t]}getLastBranch(){return this.branches[this.branches.length-1]}execution(e){return new qW(ft(this._execution(e),this._execution(e)))}revertedExecution(e){return new qW(ft(this._revertedExecution(e),this._revertedExecution(e)))}insertOperationLast(e,t){let n=e.getLastOperationId()||this.previousBranch(e)?.getLastOperationId();e.append(t),n&&this.insertPrevious(e,t,n)}insertOperationAfter(e,t,n){e.insert(t,n),this.updateNextWith(e,t,n),this.insertPrevious(e,t,n)}undo(e,t){let n=this.buildTransformation.without(t.data),r=this.branchingOperationIds.get(e);this.branchingOperationIds.set(e,t.id);let i=e.fork(t.id);r&&this.branchingOperationIds.set(i,r),this.insertBranchAfter(e,i),this.transform(i,n)}redo(e){let t=this.nextBranch(e);if(!t)return;let n=this.nextBranch(t);this.removeBranchFromTree(t);let r=this.branchingOperationIds.get(t);r?this.branchingOperationIds.set(e,r):this.branchingOperationIds.delete(e),n&&this.rebaseUp(n)}drop(e){for(let t of this.branches)t.contains(e)&&t.cutBefore(e)}findOperation(e,t){for(let n of this.revertedExecution(e))if(n.operation.id===t)return n;throw Error(`Operation ${t} not found`)}rebaseUp(e){let{previousBranch:t,branchingOperation:n}=this.findPreviousBranchingOperation(e);if(!t||!n)return;let r=this.buildTransformation.without(n.data),i=t.fork(n.id);this.branchingOperationIds.set(i,this.branchingOperationIds.get(e)),this.removeBranchFromTree(e),this.insertBranchAfter(t,i),i.transform(r);let a=this.nextBranch(i);a&&this.rebaseUp(a)}removeBranchFromTree(e){let t=this.branches.findIndex(t=>t===e);this.branches.splice(t,1)}insertBranchAfter(e,t){let n=this.branches.findIndex(t=>t===e);this.branches.splice(n+1,0,t)}updateNextWith(e,t,n){let r=this.branchingOperationIds.get(e),i=this.nextBranch(e);if(!(!r||!i))if(e.getFirstOperationAmong(n,r)===r){let a=this.addToNextBranch(e,i,r,t,n);this.updateNextWith(i,a,n)}else{let e=this.buildTransformation.with(t.data);this.transform(i,e)}}addToNextBranch(e,t,n,r,i){let a=r;return i===n?(a=this.getTransformedOperation(e,n,r),t.prepend(a)):t.contains(i)?(a=this.getTransformedOperation(e,n,r),t.insert(a,i)):t.append(r),a}getTransformedOperation(e,t,n){let r=e.getOperation(t),i=this.buildTransformation.without(r.data);return n.transformed(i)}shouldExecute(e,t){return t.id!==this.branchingOperationIds.get(e)}transform(e,t){e.transform(t);let n=this.nextBranch(e);n&&this.transform(n,t)}insertPrevious(e,t,n){let{previousBranch:r,branchingOperation:i}=this.findPreviousBranchingOperation(e);if(!r||!i)return;let a=this.buildTransformation.with(i.data),o=e.fork(n);o.transform(a),r.cutAfter(n),r.appendBranch(o);let s=t.transformed(a);this.insertPrevious(r,s,n)}findPreviousBranchingOperation(e){let t=this.previousBranch(e);if(!t)return{previousBranch:void 0,branchingOperation:void 0};let n=this.branchingOperationIds.get(t);return n?{previousBranch:t,branchingOperation:t.getOperation(n)}:{previousBranch:void 0,branchingOperation:void 0}}nextBranch(e){let t=this.branches.findIndex(t=>t===e);if(t!==-1)return this.branches[t+1]}previousBranch(e){let t=this.branches.findIndex(t=>t===e);if(t!==-1)return this.branches[t-1]}*_revertedExecution(e){let t=this.branchingOperationIds.get(e),n=!!t,r=e.getOperations();for(let i=r.length-1;i>=0;i--){let a=r[i];a.id===t&&(n=!1),n||(yield{operation:a,branch:e,isCancelled:!this.shouldExecute(e,a)})}let i=this.previousBranch(e);yield*i?this._revertedExecution(i):[]}*_execution(e){for(let t of e.getOperations())if(yield{operation:t,branch:e,isCancelled:!this.shouldExecute(e,t)},t.id===this.branchingOperationIds.get(e)){let t=this.nextBranch(e);yield*t?this._execution(t):[];return}if(!this.branchingOperationIds.get(e)){let t=this.nextBranch(e);yield*t?this._execution(t):[]}}},YW=class{HEAD_BRANCH;HEAD_OPERATION;tree;applyOperation;revertOperation;buildEmpty;buildTransformation;constructor(e){this.applyOperation=e.applyOperation,this.revertOperation=e.revertOperation,this.buildEmpty=e.buildEmpty,this.buildTransformation=e.buildTransformation,this.HEAD_BRANCH=new WW(this.buildTransformation),this.tree=new JW(this.buildTransformation,this.HEAD_BRANCH);let t=e.initialOperationId,n=new GW(t,this.buildEmpty(t));this.tree.insertOperationLast(this.HEAD_BRANCH,n),this.HEAD_OPERATION=n}get(e){return this.tree.findOperation(this.HEAD_BRANCH,e).operation.data}append(e,t){let n=new GW(e,t),r=this.tree.getLastBranch();this.tree.insertOperationLast(r,n),this.HEAD_BRANCH=r,this.HEAD_OPERATION=n}insert(e,t,n){let r=new GW(e,t);this.revertTo(n),this.tree.insertOperationAfter(this.HEAD_BRANCH,r,n),this.fastForward()}undo(e,t,n){let{branch:r,operation:i}=this.tree.findOperation(this.HEAD_BRANCH,e);this.revertBefore(e),this.tree.undo(r,i),this.fastForward(),this.insert(t,this.buildEmpty(t),n)}redo(e,t,n){let{branch:r}=this.tree.findOperation(this.HEAD_BRANCH,e);this.revertBefore(e),this.tree.redo(r),this.fastForward(),this.insert(t,this.buildEmpty(t),n)}rebase(e){let t=this.get(e),n=[...this.tree.execution(this.HEAD_BRANCH).startAfter(e)];this.revertBefore(e);let r=this.HEAD_OPERATION.id;this.tree.drop(e),this.insert(e,t,r);for(let{operation:e}of n)this.insert(e.id,e.data,this.HEAD_OPERATION.id)}revertBefore(e){let t=this.tree.revertedExecution(this.HEAD_BRANCH).stopWith(e);this.revert(t)}revertTo(e){let t=e?this.tree.revertedExecution(this.HEAD_BRANCH).stopBefore(e):this.tree.revertedExecution(this.HEAD_BRANCH);this.revert(t)}revert(e){for(let{next:t,operation:n,isCancelled:r}of e)r||this.revertOperation(n.data),t&&(this.HEAD_BRANCH=t.branch,this.HEAD_OPERATION=t.operation)}fastForward(){let e=this.HEAD_OPERATION?this.tree.execution(this.HEAD_BRANCH).startAfter(this.HEAD_OPERATION.id):this.tree.execution(this.HEAD_BRANCH);for(let{operation:t,branch:n,isCancelled:r}of e)r||this.applyOperation(t.data),this.HEAD_OPERATION=t,this.HEAD_BRANCH=n}};function XW(e){return new YW({initialOperationId:e.initialRevisionId,applyOperation:t=>{let n=t.commands.slice(),{changes:r}=e.recordChanges(()=>{for(let t of n)e.dispatch(t)});t.setChanges(r)},revertOperation:e=>ZW([e]),buildEmpty:e=>new tU(e,`empty`,[]),buildTransformation:{with:e=>t=>new tU(t.id,t.clientId,GH(t.commands,e.commands),t.rootCommand,void 0,t.timestamp),without:e=>t=>new tU(t.id,t.clientId,GH(t.commands,e.commands.map(UW).flat()),t.rootCommand,void 0,t.timestamp)}})}function ZW(e){for(let t of e.slice().reverse())for(let e=t.changes.length-1;e>=0;e--){let n=t.changes[e];QW(n)}}function QW(e){let t=e.target,n=e.key,r=e.before;r===void 0?delete t[n]:t[n]=r}var $W=class{observers=new Map;defaultSubscription;mainSubscription;registerAsDefault(e,t){this.defaultSubscription={owner:e,callbacks:t},this.mainSubscription||=this.defaultSubscription}observe(e,t){this.observers.set(e,{owner:e,callbacks:t})}detachObserver(e){this.observers.delete(e)}capture(e,t){if(this.observers.get(e))throw Error(`You are already subscribed forever`);this.mainSubscription?.owner&&this.mainSubscription.owner!==e&&this.mainSubscription.callbacks.release?.(),this.mainSubscription={owner:e,callbacks:t}}release(e){this.mainSubscription?.owner!==e||this.observers.get(e)||(this.mainSubscription=this.defaultSubscription)}getBackToDefault(){this.mainSubscription!==this.defaultSubscription&&(this.mainSubscription?.callbacks.release?.(),this.mainSubscription=this.defaultSubscription)}isListening(e){return this.mainSubscription?.owner===e}send(e){this.mainSubscription?.callbacks.handleEvent(e),this.observers.forEach(t=>t.callbacks.handleEvent(e))}},eG=class{stream;anchor;defaultAnchor;constructor(e){this.getters=e,this.stream=new $W,this.anchor={cell:{col:0,row:0},zone:E({col:0,row:0})},this.defaultAnchor=this.anchor}capture(e,t,n){this.stream.capture(e,n),this.anchor=t}registerAsDefault(e,t,n){this.checkAnchorZoneOrThrow(t),this.stream.registerAsDefault(e,n),this.defaultAnchor=t,this.capture(e,t,n)}resetDefaultAnchor(e,t){this.checkAnchorZoneOrThrow(t),this.stream.isListening(e)&&(this.anchor=t),this.defaultAnchor=t}resetAnchor(e,t){this.checkAnchorZoneOrThrow(t),this.stream.isListening(e)&&(this.anchor=t)}observe(e,t){this.stream.observe(e,t)}detachObserver(e){this.stream.detachObserver(e)}release(e){this.stream.isListening(e)&&(this.stream.release(e),this.anchor=this.defaultAnchor)}getBackToDefault(){this.stream.getBackToDefault()}modifyAnchor(e,t,n){let r=this.getters.getActiveSheetId();return e={...e,zone:this.getters.expandZone(r,e.zone)},this.processEvent({options:n,anchor:e,mode:t})}selectZone(e,t={scrollIntoView:!0}){return this.modifyAnchor(e,`overrideSelection`,t)}selectCell(e,t){let n=E({col:e,row:t});return this.selectZone({zone:n,cell:{col:e,row:t}},{scrollIntoView:!0})}moveAnchorCell(e,t=1){if(t!==`end`&&t<=0)return new ua(`InvalidSelectionStep`);let{col:n,row:r}=this.getNextAvailablePosition(e,t);return this.selectCell(n,r)}setAnchorCorner(e,t){let n=this.getters.getActiveSheetId(),{col:r,row:i}=this.anchor.cell,a={left:Math.min(r,e),top:Math.min(i,t),right:Math.max(r,e),bottom:Math.max(i,t)},o={zone:this.getters.expandZone(n,a),cell:{col:r,row:i}};return this.processEvent({mode:`updateAnchor`,anchor:o,options:{scrollIntoView:!1}})}addCellToSelection(e,t){let n=this.getters.getActiveSheetId();({col:e,row:t}=this.getters.getMainCellPosition({sheetId:n,col:e,row:t}));let r=this.getters.expandZone(n,E({col:e,row:t}));return this.processEvent({options:{scrollIntoView:!0},anchor:{zone:r,cell:{col:e,row:t}},mode:`newAnchor`})}resizeAnchorZone(e,t=1){if(t!==`end`&&t<=0)return new ua(`InvalidSelectionStep`);let n=this.getters.getActiveSheetId(),r=this.anchor,{col:i,row:a}=r.cell,{left:o,right:s,top:c,bottom:l}=r.zone,u=this.getStartingPosition(e),[d,f]=this.deltaToTarget(u,e,t);if(d===0&&f===0)return ua.Success;let p=r.zone,m=e=>{e=Tr(e);let{left:t,right:r,top:i,bottom:a}=this.getters.expandZone(n,e);return{left:Math.max(0,t),right:Math.min(this.getters.getNumberCols(n)-1,r),top:Math.max(0,i),bottom:Math.min(this.getters.getNumberRows(n)-1,a)}},{cell:h,zone:g}=this.getReferenceAnchor(),{col:_,row:v}=h,y=0;for(;p!==null;){if(y++,d<0){let e=this.getNextAvailableCol(d,s-(y-1),v);p=g.right<=s-y?m({top:c,left:o,bottom:l,right:e}):null}if(d>0){let e=this.getNextAvailableCol(d,o+(y-1),v);p=o+y<=g.left?m({top:c,left:e,bottom:l,right:s}):null}if(f<0){let e=this.getNextAvailableRow(f,_,l-(y-1));p=g.bottom<=l-y?m({top:c,left:o,bottom:e,right:s}):null}if(f>0){let e=this.getNextAvailableRow(f,_,c+(y-1));p=c+y<=g.top?m({top:e,left:o,bottom:l,right:s}):null}if(p&&=Tr(p),p&&!gr(p,r.zone))return this.processEvent({options:{scrollIntoView:!0},mode:`updateAnchor`,anchor:{zone:p,cell:{col:i,row:a}}})}p=m(pr({top:a,bottom:a,left:i,right:i},Tr({top:this.getNextAvailableRow(f,_,c),left:this.getNextAvailableCol(d,o,v),bottom:this.getNextAvailableRow(f,_,l),right:this.getNextAvailableCol(d,s,v)})));let ee={zone:p,cell:{col:i,row:a}};return this.processEvent({anchor:ee,mode:`updateAnchor`,options:{scrollIntoView:!0}})}selectColumn(e,t){let n=this.getters.getActiveSheetId(),r=this.getters.getNumberRows(n)-1,i={left:e,right:e,top:0,bottom:r},a=this.getters.findFirstVisibleColRowIndex(n,`ROW`),o,s;switch(t){case`overrideSelection`:case`newAnchor`:o=e,s=a;break;case`updateAnchor`:({col:o,row:s}=this.anchor.cell),i=pr(i,{left:o,right:o,top:a,bottom:r});break}return this.processEvent({options:{scrollIntoView:!1,unbounded:!0},anchor:{zone:i,cell:{col:o,row:s}},mode:t})}selectRow(e,t){let n=this.getters.getActiveSheetId(),r=this.getters.getNumberCols(n)-1,i={top:e,bottom:e,left:0,right:r},a=this.getters.findFirstVisibleColRowIndex(n,`COL`),o,s;switch(t){case`overrideSelection`:case`newAnchor`:o=a,s=e;break;case`updateAnchor`:({col:o,row:s}=this.anchor.cell),i=pr(i,{left:a,right:r,top:s,bottom:s});break}return this.processEvent({options:{scrollIntoView:!1,unbounded:!0},anchor:{zone:i,cell:{col:o,row:s}},mode:t})}loopSelection(){let e=this.getters.getActiveSheetId(),t=this.anchor;if(gr(this.anchor.zone,this.getters.getSheetZone(e)))return this.modifyAnchor({...t,zone:E(t.cell)},`updateAnchor`,{scrollIntoView:!1});let n=this.getters.getContiguousZone(e,t.zone);return w(n,t.zone)?this.selectAll():this.modifyAnchor({...t,zone:n},`updateAnchor`,{scrollIntoView:!1})}selectTableAroundSelection(){let e=this.getters.getActiveSheetId(),t=this.getters.getContiguousZone(e,this.anchor.zone);return this.modifyAnchor({...this.anchor,zone:t},`updateAnchor`,{scrollIntoView:!1})}selectAll(){let e=this.getters.getActiveSheetId(),t={left:0,top:0,bottom:this.getters.getNumberRows(e)-1,right:this.getters.getNumberCols(e)-1};return this.processEvent({mode:`overrideSelection`,anchor:{zone:t,cell:this.anchor.cell},options:{scrollIntoView:!1}})}isListening(e){return this.stream.isListening(e)}processEvent(e){let t={...e,previousAnchor:b(this.anchor)},n=this.checkEventAnchorZone(t);return n===`Success`?(this.anchor=t.anchor,this.stream.send(t),ua.Success):new ua(n)}checkEventAnchorZone(e){return this.checkAnchorZone(e.anchor)}checkAnchorZone(e){let{cell:t,zone:n}=e;if(!vr(t.col,t.row,n))return`InvalidAnchorZone`;let{left:r,right:i,top:a,bottom:o}=n,s=this.getters.getActiveSheetId(),c=this.getters.findVisibleHeader(s,`COL`,r,i);return this.getters.findVisibleHeader(s,`ROW`,a,o)===void 0||c===void 0?`SelectionOutOfBound`:`Success`}checkAnchorZoneOrThrow(e){if(this.checkAnchorZone(e)===`InvalidAnchorZone`)throw Error(`The provided anchor is invalid. The cell must be part of the zone.`)}getNextAvailablePosition(e,t=1){let{col:n,row:r}=this.anchor.cell,i=this.deltaToTarget({col:n,row:r},e,t);return{col:this.getNextAvailableCol(i[0],n,r),row:this.getNextAvailableRow(i[1],n,r)}}getNextAvailableCol(e,t,n){let r=this.getters.getActiveSheetId(),i={col:t,row:n};return this.getNextAvailableHeader(e,`COL`,t,i,e=>this.getters.isInSameMerge(r,t,n,e,n))}getNextAvailableRow(e,t,n){let r=this.getters.getActiveSheetId(),i={col:t,row:n};return this.getNextAvailableHeader(e,`ROW`,n,i,e=>this.getters.isInSameMerge(r,t,n,t,e))}getNextAvailableHeader(e,t,n,r,i){let a=this.getters.getActiveSheetId();if(e===0)return n;let o=Math.sign(e),s=n+e;for(;i(s);)s+=o;for(;this.getters.isHeaderHidden(a,t,s);)s+=o;return s<0||s>this.getters.getNumberHeaders(a,t)-1?this.getters.isHeaderHidden(a,t,n)?this.getNextAvailableHeader(-o,t,n,r,i):n:s}getReferenceAnchor(){let e=this.getters.getActiveSheetId(),t=this.anchor,{left:n,right:r,top:i,bottom:a}=t.zone,{col:o,row:s}=t.cell,c=this.getters.isColHidden(e,o)&&this.getters.findVisibleHeader(e,`COL`,n,r)||o,l=this.getters.isRowHidden(e,s)&&this.getters.findVisibleHeader(e,`ROW`,i,a)||s,u=this.getters.expandZone(e,{left:c,right:c,top:l,bottom:l});return{cell:{col:c,row:l},zone:u}}deltaToTarget(e,t,n){switch(t){case`up`:return n===`end`?[0,this.getEndOfCluster(e,`rows`,-1)-e.row]:[0,-n];case`down`:return n===`end`?[0,this.getEndOfCluster(e,`rows`,1)-e.row]:[0,n];case`left`:return n===`end`?[this.getEndOfCluster(e,`cols`,-1)-e.col,0]:[-n,0];case`right`:return n===`end`?[this.getEndOfCluster(e,`cols`,1)-e.col,0]:[n,0]}}getStartingPosition(e){let{col:t,row:n}=this.getPosition(),r=this.anchor.zone;switch(e){case`down`:case`up`:n=n===r.top?r.bottom:r.top;break;case`left`:case`right`:t=t===r.right?r.left:r.right;break}return{col:t,row:n}}getEndOfCluster(e,t,n){let r=this.getters.getActiveSheetId(),i=e,a=this.getNextCellPosition(e,t,n),o=!this.isCellSkippableInCluster({...i,sheetId:r})&&!this.isCellSkippableInCluster({...a,sheetId:r})?`endOfCluster`:`nextCluster`;for(;;){let e=this.getNextCellPosition(i,t,n);if(i.col===e.col&&i.row===e.row)break;let a=this.isCellSkippableInCluster({...e,sheetId:r});if(o===`endOfCluster`&&a)break;if(o===`nextCluster`&&!a){i=e;break}i=e}return t===`cols`?i.col:i.row}getNextCellPosition(e,t,n){let r=t===`cols`?`col`:`row`,i={...e};return i[r]=t===`cols`?this.getNextAvailableCol(n,i.col,i.row):this.getNextAvailableRow(n,i.col,i.row),{col:i.col,row:i.row}}getPosition(){return{...this.anchor.cell}}isCellSkippableInCluster(e){let t=this.getters.getMainCellPosition(e),n=this.getters.getEvaluatedCell(t);return n.type===`empty`||n.type===`text`&&n.value===``}};function tG(e){if(typeof e==`string`)return{};if(typeof e==`number`)return[];throw Error(`Cannot create new node`)}var nG=class{changes;commands=[];recordChanges(e){return this.changes=[],this.commands=[],e(),{changes:this.changes,commands:this.commands}}addCommand(e){this.commands.push(e)}addChange(...e){let t=e.pop(),n=e[0],r=e.at(-1),i=e.length-2;for(let t=1;t<=i;t++){let r=e[t];if(n[r]===void 0){let i=e[t+1];n[r]=tG(i)}n=n[r]}n[r]!==t&&(this.changes?.push({key:r,target:n,before:n[r]}),t===void 0?delete n[r]:n[r]=t)}};let rG=17781237,iG=17781238,aG=88853993,oG=88853994;function sG(e,t,n){let r=[[`xmlns:r`,cO],[`xmlns:a`,iO],[`xmlns:c`,aO]],i=cG({backgroundColor:e.data.backgroundColor,line:{color:`000000`}}),a=Y``;if(e.data.title?.text){let t=rw(qx(e.data.backgroundColor)),n=e.data.title.fontSize??16;a=Y`
|
|
2650
|
+
`;var VW=class extends t.Component{static template=`o-spreadsheet-Spreadsheet`;static props={model:Object,notifyUser:{type:Function,optional:!0},raiseError:{type:Function,optional:!0},askConfirmation:{type:Function,optional:!0}};static components={TopBar:RW,Grid:dV,BottomBar:hW,SidePanel:CW,SpreadsheetDashboard:_W,HeaderGroupContainer:xW};sidePanel;spreadsheetRef=(0,t.useRef)(`spreadsheet`);spreadsheetRect=pM();_focusGrid;isViewportTooSmall=!1;notificationStore;composerFocusStore;get model(){return this.props.model}getStyle(){let e={};return this.env.isDashboard()?e[`grid-template-rows`]=`auto`:e[`grid-template-rows`]=`min-content auto min-content`,e[`grid-template-columns`]=`auto ${this.sidePanel.panelSize}px`,U(e)}setup(){let e=qd();e.inject(Qd,this.model),this.notificationStore=V(dC),this.composerFocusStore=V(nf),this.sidePanel=V(sV);let n=this.model.config.external.fileStore;if((0,t.useSubEnv)({model:this.model,imageProvider:n?new oW(n):void 0,loadCurrencies:this.model.config.external.loadCurrencies,loadLocales:this.model.config.external.loadLocales,isDashboard:()=>this.model.getters.isDashboard(),openSidePanel:this.sidePanel.open.bind(this.sidePanel),toggleSidePanel:this.sidePanel.toggle.bind(this.sidePanel),clipboard:this.env.clipboard||zW(),startCellEdition:e=>this.composerFocusStore.focusActiveComposer({content:e}),notifyUser:e=>this.notificationStore.notifyUser(e),askConfirmation:(e,t,n)=>this.notificationStore.askConfirmation(e,t,n),raiseError:(e,t)=>this.notificationStore.raiseError(e,t)}),!(`isSmall`in this.env)){let e=SW();(0,t.useSubEnv)({get isSmall(){return e.isSmall}})}this.notificationStore.updateNotificationCallbacks({...this.props}),(0,t.useEffect)(()=>{!this.spreadsheetRef.el.contains(document.activeElement)&&document.activeElement?.contains(this.spreadsheetRef.el)&&this.focusGrid()}),(0,t.useExternalListener)(window,`resize`,()=>this.render(!0)),(0,t.useExternalListener)(document.body,`wheel`,()=>{}),this.bindModelEvents(),(0,t.onWillUpdateProps)(e=>{if(e.model!==this.props.model)throw Error(`Changing the props model is not supported at the moment.`);(e.notifyUser!==this.props.notifyUser||e.askConfirmation!==this.props.askConfirmation||e.raiseError!==this.props.raiseError)&&this.notificationStore.updateNotificationCallbacks({...e})});let r=Dt(this.render.bind(this,!0));(0,t.onMounted)(()=>{this.checkViewportSize(),e.on(`store-updated`,this,r),i.observe(this.spreadsheetRef.el)}),(0,t.onWillUnmount)(()=>{this.unbindModelEvents(),e.off(`store-updated`,this),i.disconnect(),gf()}),(0,t.onPatched)(()=>{this.checkViewportSize()});let i=new ResizeObserver(()=>{this.sidePanel.changePanelSize(this.sidePanel.panelSize,this.spreadsheetRect.width)})}bindModelEvents(){this.model.on(`update`,this,()=>this.render(!0)),this.model.on(`notify-ui`,this,e=>this.notificationStore.notifyUser(e)),this.model.on(`raise-error-ui`,this,({text:e})=>this.notificationStore.raiseError(e))}unbindModelEvents(){this.model.off(`update`,this),this.model.off(`notify-ui`,this),this.model.off(`raise-error-ui`,this)}checkViewportSize(){let{xRatio:e,yRatio:t}=this.env.model.getters.getFrozenSheetViewRatio(this.env.model.getters.getActiveSheetId());if(!(!isFinite(e)||!isFinite(t)))if(t>.85||e>.85){if(this.isViewportTooSmall)return;this.notificationStore.notifyUser({text:O(`The current window is too small to display this sheet properly. Consider resizing your browser window or adjusting frozen rows and columns.`),type:`warning`,sticky:!1}),this.isViewportTooSmall=!0}else this.isViewportTooSmall=!1}focusGrid(){this._focusGrid&&this._focusGrid()}get gridHeight(){return this.env.model.getters.getSheetViewDimension().height}get gridContainerStyle(){let e=21*this.rowLayers.length,t=21*this.colLayers.length;return U({"grid-template-columns":`${e?e+2:0}px auto`,"grid-template-rows":`${t?t+2:0}px auto`})}get rowLayers(){let e=this.env.model.getters.getActiveSheetId();return this.env.model.getters.getVisibleGroupLayers(e,`ROW`)}get colLayers(){let e=this.env.model.getters.getActiveSheetId();return this.env.model.getters.getVisibleGroupLayers(e,`COL`)}},HW=class{listeners=[];async sendMessage(e){for(let{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)}};function UW(e){return FD.get(e.type)(e)}var WW=class e{buildTransformation;operations;constructor(e,t=[]){this.buildTransformation=e,this.operations=t}getOperations(){return this.operations}getOperation(e){let t=this.operations.find(t=>t.id===e);if(!t)throw Error(`Operation ${e} not found`);return t}getLastOperationId(){return this.operations[this.operations.length-1]?.id}getFirstOperationAmong(e,t){for(let n of this.operations){if(n.id===e)return e;if(n.id===t)return t}throw Error(`Operation ${e} and ${t} not found`)}contains(e){return!!this.operations.find(t=>t.id===e)}prepend(e){let t=this.buildTransformation.with(e.data);this.operations=[e,...this.operations.map(e=>e.transformed(t))]}insert(e,t){let n=this.buildTransformation.with(e.data),{before:r,operation:i,after:a}=this.locateOperation(t);this.operations=[...r,i,e,...a.map(e=>e.transformed(n))]}append(e){this.operations.push(e)}appendBranch(e){this.operations=this.operations.concat(e.operations)}fork(t){let{after:n}=this.locateOperation(t);return new e(this.buildTransformation,n)}transform(e){this.operations=this.operations.map(t=>t.transformed(e))}cutBefore(e){this.operations=this.locateOperation(e).before}cutAfter(e){let{before:t,operation:n}=this.locateOperation(e);this.operations=t.concat([n])}locateOperation(e){let t=this.operations.findIndex(t=>t.id===e);if(t===-1)throw Error(`Operation ${e} not found`);return{before:this.operations.slice(0,t),operation:this.operations[t],after:this.operations.slice(t+1)}}},GW=class{id;data;constructor(e,t){this.id=e,this.data=t}transformed(e){return new KW(this.id,kt(()=>e(this.data)))}},KW=class e{id;lazyData;constructor(e,t){this.id=e,this.lazyData=t}get data(){return this.lazyData()}transformed(t){return new e(this.id,this.lazyData.map(t))}},qW=class e{operations;constructor(e){this.operations=e}[Symbol.iterator](){return this.operations[Symbol.iterator]()}stopWith(t){function*n(e,t){for(let n of e)if(yield n,n.operation.id===t)return}return new e(n(this.operations,t))}stopBefore(t){function*n(e,t){for(let n of e){if(n.operation.id===t)return;yield n}}return new e(n(this.operations,t))}startAfter(t){function*n(e,t){let n=!0;for(let r of e)n||(yield r),r.operation.id===t&&(n=!1)}return new e(n(this.operations,t))}},JW=class{buildTransformation;branches;branchingOperationIds=new Map;constructor(e,t){this.buildTransformation=e,this.branches=[t]}getLastBranch(){return this.branches[this.branches.length-1]}execution(e){return new qW(ft(this._execution(e),this._execution(e)))}revertedExecution(e){return new qW(ft(this._revertedExecution(e),this._revertedExecution(e)))}insertOperationLast(e,t){let n=e.getLastOperationId()||this.previousBranch(e)?.getLastOperationId();e.append(t),n&&this.insertPrevious(e,t,n)}insertOperationAfter(e,t,n){e.insert(t,n),this.updateNextWith(e,t,n),this.insertPrevious(e,t,n)}undo(e,t){let n=this.buildTransformation.without(t.data),r=this.branchingOperationIds.get(e);this.branchingOperationIds.set(e,t.id);let i=e.fork(t.id);r&&this.branchingOperationIds.set(i,r),this.insertBranchAfter(e,i),this.transform(i,n)}redo(e){let t=this.nextBranch(e);if(!t)return;let n=this.nextBranch(t);this.removeBranchFromTree(t);let r=this.branchingOperationIds.get(t);r?this.branchingOperationIds.set(e,r):this.branchingOperationIds.delete(e),n&&this.rebaseUp(n)}drop(e){for(let t of this.branches)t.contains(e)&&t.cutBefore(e)}findOperation(e,t){for(let n of this.revertedExecution(e))if(n.operation.id===t)return n;throw Error(`Operation ${t} not found`)}rebaseUp(e){let{previousBranch:t,branchingOperation:n}=this.findPreviousBranchingOperation(e);if(!t||!n)return;let r=this.buildTransformation.without(n.data),i=t.fork(n.id);this.branchingOperationIds.set(i,this.branchingOperationIds.get(e)),this.removeBranchFromTree(e),this.insertBranchAfter(t,i),i.transform(r);let a=this.nextBranch(i);a&&this.rebaseUp(a)}removeBranchFromTree(e){let t=this.branches.findIndex(t=>t===e);this.branches.splice(t,1)}insertBranchAfter(e,t){let n=this.branches.findIndex(t=>t===e);this.branches.splice(n+1,0,t)}updateNextWith(e,t,n){let r=this.branchingOperationIds.get(e),i=this.nextBranch(e);if(!(!r||!i))if(e.getFirstOperationAmong(n,r)===r){let a=this.addToNextBranch(e,i,r,t,n);this.updateNextWith(i,a,n)}else{let e=this.buildTransformation.with(t.data);this.transform(i,e)}}addToNextBranch(e,t,n,r,i){let a=r;return i===n?(a=this.getTransformedOperation(e,n,r),t.prepend(a)):t.contains(i)?(a=this.getTransformedOperation(e,n,r),t.insert(a,i)):t.append(r),a}getTransformedOperation(e,t,n){let r=e.getOperation(t),i=this.buildTransformation.without(r.data);return n.transformed(i)}shouldExecute(e,t){return t.id!==this.branchingOperationIds.get(e)}transform(e,t){e.transform(t);let n=this.nextBranch(e);n&&this.transform(n,t)}insertPrevious(e,t,n){let{previousBranch:r,branchingOperation:i}=this.findPreviousBranchingOperation(e);if(!r||!i)return;let a=this.buildTransformation.with(i.data),o=e.fork(n);o.transform(a),r.cutAfter(n),r.appendBranch(o);let s=t.transformed(a);this.insertPrevious(r,s,n)}findPreviousBranchingOperation(e){let t=this.previousBranch(e);if(!t)return{previousBranch:void 0,branchingOperation:void 0};let n=this.branchingOperationIds.get(t);return n?{previousBranch:t,branchingOperation:t.getOperation(n)}:{previousBranch:void 0,branchingOperation:void 0}}nextBranch(e){let t=this.branches.findIndex(t=>t===e);if(t!==-1)return this.branches[t+1]}previousBranch(e){let t=this.branches.findIndex(t=>t===e);if(t!==-1)return this.branches[t-1]}*_revertedExecution(e){let t=this.branchingOperationIds.get(e),n=!!t,r=e.getOperations();for(let i=r.length-1;i>=0;i--){let a=r[i];a.id===t&&(n=!1),n||(yield{operation:a,branch:e,isCancelled:!this.shouldExecute(e,a)})}let i=this.previousBranch(e);yield*i?this._revertedExecution(i):[]}*_execution(e){for(let t of e.getOperations())if(yield{operation:t,branch:e,isCancelled:!this.shouldExecute(e,t)},t.id===this.branchingOperationIds.get(e)){let t=this.nextBranch(e);yield*t?this._execution(t):[];return}if(!this.branchingOperationIds.get(e)){let t=this.nextBranch(e);yield*t?this._execution(t):[]}}},YW=class{HEAD_BRANCH;HEAD_OPERATION;tree;applyOperation;revertOperation;buildEmpty;buildTransformation;constructor(e){this.applyOperation=e.applyOperation,this.revertOperation=e.revertOperation,this.buildEmpty=e.buildEmpty,this.buildTransformation=e.buildTransformation,this.HEAD_BRANCH=new WW(this.buildTransformation),this.tree=new JW(this.buildTransformation,this.HEAD_BRANCH);let t=e.initialOperationId,n=new GW(t,this.buildEmpty(t));this.tree.insertOperationLast(this.HEAD_BRANCH,n),this.HEAD_OPERATION=n}get(e){return this.tree.findOperation(this.HEAD_BRANCH,e).operation.data}append(e,t){let n=new GW(e,t),r=this.tree.getLastBranch();this.tree.insertOperationLast(r,n),this.HEAD_BRANCH=r,this.HEAD_OPERATION=n}insert(e,t,n){let r=new GW(e,t);this.revertTo(n),this.tree.insertOperationAfter(this.HEAD_BRANCH,r,n),this.fastForward()}undo(e,t,n){let{branch:r,operation:i}=this.tree.findOperation(this.HEAD_BRANCH,e);this.revertBefore(e),this.tree.undo(r,i),this.fastForward(),this.insert(t,this.buildEmpty(t),n)}redo(e,t,n){let{branch:r}=this.tree.findOperation(this.HEAD_BRANCH,e);this.revertBefore(e),this.tree.redo(r),this.fastForward(),this.insert(t,this.buildEmpty(t),n)}rebase(e){let t=this.get(e),n=[...this.tree.execution(this.HEAD_BRANCH).startAfter(e)];this.revertBefore(e);let r=this.HEAD_OPERATION.id;this.tree.drop(e),this.insert(e,t,r);for(let{operation:e}of n)this.insert(e.id,e.data,this.HEAD_OPERATION.id)}revertBefore(e){let t=this.tree.revertedExecution(this.HEAD_BRANCH).stopWith(e);this.revert(t)}revertTo(e){let t=e?this.tree.revertedExecution(this.HEAD_BRANCH).stopBefore(e):this.tree.revertedExecution(this.HEAD_BRANCH);this.revert(t)}revert(e){for(let{next:t,operation:n,isCancelled:r}of e)r||this.revertOperation(n.data),t&&(this.HEAD_BRANCH=t.branch,this.HEAD_OPERATION=t.operation)}fastForward(){let e=this.HEAD_OPERATION?this.tree.execution(this.HEAD_BRANCH).startAfter(this.HEAD_OPERATION.id):this.tree.execution(this.HEAD_BRANCH);for(let{operation:t,branch:n,isCancelled:r}of e)r||this.applyOperation(t.data),this.HEAD_OPERATION=t,this.HEAD_BRANCH=n}};function XW(e){return new YW({initialOperationId:e.initialRevisionId,applyOperation:t=>{let n=t.commands.slice(),{changes:r}=e.recordChanges(()=>{for(let t of n)e.dispatch(t)});t.setChanges(r)},revertOperation:e=>ZW([e]),buildEmpty:e=>new tU(e,`empty`,[]),buildTransformation:{with:e=>t=>new tU(t.id,t.clientId,GH(t.commands,e.commands),t.rootCommand,void 0,t.timestamp),without:e=>t=>new tU(t.id,t.clientId,GH(t.commands,e.commands.map(UW).flat()),t.rootCommand,void 0,t.timestamp)}})}function ZW(e){for(let t of e.slice().reverse())for(let e=t.changes.length-1;e>=0;e--){let n=t.changes[e];QW(n)}}function QW(e){let t=e.target,n=e.key,r=e.before;r===void 0?delete t[n]:t[n]=r}var $W=class{observers=new Map;defaultSubscription;mainSubscription;registerAsDefault(e,t){this.defaultSubscription={owner:e,callbacks:t},this.mainSubscription||=this.defaultSubscription}observe(e,t){this.observers.set(e,{owner:e,callbacks:t})}detachObserver(e){this.observers.delete(e)}capture(e,t){if(this.observers.get(e))throw Error(`You are already subscribed forever`);this.mainSubscription?.owner&&this.mainSubscription.owner!==e&&this.mainSubscription.callbacks.release?.(),this.mainSubscription={owner:e,callbacks:t}}release(e){this.mainSubscription?.owner!==e||this.observers.get(e)||(this.mainSubscription=this.defaultSubscription)}getBackToDefault(){this.mainSubscription!==this.defaultSubscription&&(this.mainSubscription?.callbacks.release?.(),this.mainSubscription=this.defaultSubscription)}isListening(e){return this.mainSubscription?.owner===e}send(e){this.mainSubscription?.callbacks.handleEvent(e),this.observers.forEach(t=>t.callbacks.handleEvent(e))}},eG=class{getters;stream;anchor;defaultAnchor;constructor(e){this.getters=e,this.stream=new $W,this.anchor={cell:{col:0,row:0},zone:E({col:0,row:0})},this.defaultAnchor=this.anchor}capture(e,t,n){this.stream.capture(e,n),this.anchor=t}registerAsDefault(e,t,n){this.checkAnchorZoneOrThrow(t),this.stream.registerAsDefault(e,n),this.defaultAnchor=t,this.capture(e,t,n)}resetDefaultAnchor(e,t){this.checkAnchorZoneOrThrow(t),this.stream.isListening(e)&&(this.anchor=t),this.defaultAnchor=t}resetAnchor(e,t){this.checkAnchorZoneOrThrow(t),this.stream.isListening(e)&&(this.anchor=t)}observe(e,t){this.stream.observe(e,t)}detachObserver(e){this.stream.detachObserver(e)}release(e){this.stream.isListening(e)&&(this.stream.release(e),this.anchor=this.defaultAnchor)}getBackToDefault(){this.stream.getBackToDefault()}modifyAnchor(e,t,n){let r=this.getters.getActiveSheetId();return e={...e,zone:this.getters.expandZone(r,e.zone)},this.processEvent({options:n,anchor:e,mode:t})}selectZone(e,t={scrollIntoView:!0}){return this.modifyAnchor(e,`overrideSelection`,t)}selectCell(e,t){let n=E({col:e,row:t});return this.selectZone({zone:n,cell:{col:e,row:t}},{scrollIntoView:!0})}moveAnchorCell(e,t=1){if(t!==`end`&&t<=0)return new ua(`InvalidSelectionStep`);let{col:n,row:r}=this.getNextAvailablePosition(e,t);return this.selectCell(n,r)}setAnchorCorner(e,t){let n=this.getters.getActiveSheetId(),{col:r,row:i}=this.anchor.cell,a={left:Math.min(r,e),top:Math.min(i,t),right:Math.max(r,e),bottom:Math.max(i,t)},o={zone:this.getters.expandZone(n,a),cell:{col:r,row:i}};return this.processEvent({mode:`updateAnchor`,anchor:o,options:{scrollIntoView:!1}})}addCellToSelection(e,t){let n=this.getters.getActiveSheetId();({col:e,row:t}=this.getters.getMainCellPosition({sheetId:n,col:e,row:t}));let r=this.getters.expandZone(n,E({col:e,row:t}));return this.processEvent({options:{scrollIntoView:!0},anchor:{zone:r,cell:{col:e,row:t}},mode:`newAnchor`})}resizeAnchorZone(e,t=1){if(t!==`end`&&t<=0)return new ua(`InvalidSelectionStep`);let n=this.getters.getActiveSheetId(),r=this.anchor,{col:i,row:a}=r.cell,{left:o,right:s,top:c,bottom:l}=r.zone,u=this.getStartingPosition(e),[d,f]=this.deltaToTarget(u,e,t);if(d===0&&f===0)return ua.Success;let p=r.zone,m=e=>{e=Tr(e);let{left:t,right:r,top:i,bottom:a}=this.getters.expandZone(n,e);return{left:Math.max(0,t),right:Math.min(this.getters.getNumberCols(n)-1,r),top:Math.max(0,i),bottom:Math.min(this.getters.getNumberRows(n)-1,a)}},{cell:h,zone:g}=this.getReferenceAnchor(),{col:_,row:v}=h,y=0;for(;p!==null;){if(y++,d<0){let e=this.getNextAvailableCol(d,s-(y-1),v);p=g.right<=s-y?m({top:c,left:o,bottom:l,right:e}):null}if(d>0){let e=this.getNextAvailableCol(d,o+(y-1),v);p=o+y<=g.left?m({top:c,left:e,bottom:l,right:s}):null}if(f<0){let e=this.getNextAvailableRow(f,_,l-(y-1));p=g.bottom<=l-y?m({top:c,left:o,bottom:e,right:s}):null}if(f>0){let e=this.getNextAvailableRow(f,_,c+(y-1));p=c+y<=g.top?m({top:e,left:o,bottom:l,right:s}):null}if(p&&=Tr(p),p&&!gr(p,r.zone))return this.processEvent({options:{scrollIntoView:!0},mode:`updateAnchor`,anchor:{zone:p,cell:{col:i,row:a}}})}p=m(pr({top:a,bottom:a,left:i,right:i},Tr({top:this.getNextAvailableRow(f,_,c),left:this.getNextAvailableCol(d,o,v),bottom:this.getNextAvailableRow(f,_,l),right:this.getNextAvailableCol(d,s,v)})));let ee={zone:p,cell:{col:i,row:a}};return this.processEvent({anchor:ee,mode:`updateAnchor`,options:{scrollIntoView:!0}})}selectColumn(e,t){let n=this.getters.getActiveSheetId(),r=this.getters.getNumberRows(n)-1,i={left:e,right:e,top:0,bottom:r},a=this.getters.findFirstVisibleColRowIndex(n,`ROW`),o,s;switch(t){case`overrideSelection`:case`newAnchor`:o=e,s=a;break;case`updateAnchor`:({col:o,row:s}=this.anchor.cell),i=pr(i,{left:o,right:o,top:a,bottom:r});break}return this.processEvent({options:{scrollIntoView:!1,unbounded:!0},anchor:{zone:i,cell:{col:o,row:s}},mode:t})}selectRow(e,t){let n=this.getters.getActiveSheetId(),r=this.getters.getNumberCols(n)-1,i={top:e,bottom:e,left:0,right:r},a=this.getters.findFirstVisibleColRowIndex(n,`COL`),o,s;switch(t){case`overrideSelection`:case`newAnchor`:o=a,s=e;break;case`updateAnchor`:({col:o,row:s}=this.anchor.cell),i=pr(i,{left:a,right:r,top:s,bottom:s});break}return this.processEvent({options:{scrollIntoView:!1,unbounded:!0},anchor:{zone:i,cell:{col:o,row:s}},mode:t})}loopSelection(){let e=this.getters.getActiveSheetId(),t=this.anchor;if(gr(this.anchor.zone,this.getters.getSheetZone(e)))return this.modifyAnchor({...t,zone:E(t.cell)},`updateAnchor`,{scrollIntoView:!1});let n=this.getters.getContiguousZone(e,t.zone);return w(n,t.zone)?this.selectAll():this.modifyAnchor({...t,zone:n},`updateAnchor`,{scrollIntoView:!1})}selectTableAroundSelection(){let e=this.getters.getActiveSheetId(),t=this.getters.getContiguousZone(e,this.anchor.zone);return this.modifyAnchor({...this.anchor,zone:t},`updateAnchor`,{scrollIntoView:!1})}selectAll(){let e=this.getters.getActiveSheetId(),t={left:0,top:0,bottom:this.getters.getNumberRows(e)-1,right:this.getters.getNumberCols(e)-1};return this.processEvent({mode:`overrideSelection`,anchor:{zone:t,cell:this.anchor.cell},options:{scrollIntoView:!1}})}isListening(e){return this.stream.isListening(e)}processEvent(e){let t={...e,previousAnchor:b(this.anchor)},n=this.checkEventAnchorZone(t);return n===`Success`?(this.anchor=t.anchor,this.stream.send(t),ua.Success):new ua(n)}checkEventAnchorZone(e){return this.checkAnchorZone(e.anchor)}checkAnchorZone(e){let{cell:t,zone:n}=e;if(!vr(t.col,t.row,n))return`InvalidAnchorZone`;let{left:r,right:i,top:a,bottom:o}=n,s=this.getters.getActiveSheetId(),c=this.getters.findVisibleHeader(s,`COL`,r,i);return this.getters.findVisibleHeader(s,`ROW`,a,o)===void 0||c===void 0?`SelectionOutOfBound`:`Success`}checkAnchorZoneOrThrow(e){if(this.checkAnchorZone(e)===`InvalidAnchorZone`)throw Error(`The provided anchor is invalid. The cell must be part of the zone.`)}getNextAvailablePosition(e,t=1){let{col:n,row:r}=this.anchor.cell,i=this.deltaToTarget({col:n,row:r},e,t);return{col:this.getNextAvailableCol(i[0],n,r),row:this.getNextAvailableRow(i[1],n,r)}}getNextAvailableCol(e,t,n){let r=this.getters.getActiveSheetId(),i={col:t,row:n};return this.getNextAvailableHeader(e,`COL`,t,i,e=>this.getters.isInSameMerge(r,t,n,e,n))}getNextAvailableRow(e,t,n){let r=this.getters.getActiveSheetId(),i={col:t,row:n};return this.getNextAvailableHeader(e,`ROW`,n,i,e=>this.getters.isInSameMerge(r,t,n,t,e))}getNextAvailableHeader(e,t,n,r,i){let a=this.getters.getActiveSheetId();if(e===0)return n;let o=Math.sign(e),s=n+e;for(;i(s);)s+=o;for(;this.getters.isHeaderHidden(a,t,s);)s+=o;return s<0||s>this.getters.getNumberHeaders(a,t)-1?this.getters.isHeaderHidden(a,t,n)?this.getNextAvailableHeader(-o,t,n,r,i):n:s}getReferenceAnchor(){let e=this.getters.getActiveSheetId(),t=this.anchor,{left:n,right:r,top:i,bottom:a}=t.zone,{col:o,row:s}=t.cell,c=this.getters.isColHidden(e,o)&&this.getters.findVisibleHeader(e,`COL`,n,r)||o,l=this.getters.isRowHidden(e,s)&&this.getters.findVisibleHeader(e,`ROW`,i,a)||s,u=this.getters.expandZone(e,{left:c,right:c,top:l,bottom:l});return{cell:{col:c,row:l},zone:u}}deltaToTarget(e,t,n){switch(t){case`up`:return n===`end`?[0,this.getEndOfCluster(e,`rows`,-1)-e.row]:[0,-n];case`down`:return n===`end`?[0,this.getEndOfCluster(e,`rows`,1)-e.row]:[0,n];case`left`:return n===`end`?[this.getEndOfCluster(e,`cols`,-1)-e.col,0]:[-n,0];case`right`:return n===`end`?[this.getEndOfCluster(e,`cols`,1)-e.col,0]:[n,0]}}getStartingPosition(e){let{col:t,row:n}=this.getPosition(),r=this.anchor.zone;switch(e){case`down`:case`up`:n=n===r.top?r.bottom:r.top;break;case`left`:case`right`:t=t===r.right?r.left:r.right;break}return{col:t,row:n}}getEndOfCluster(e,t,n){let r=this.getters.getActiveSheetId(),i=e,a=this.getNextCellPosition(e,t,n),o=!this.isCellSkippableInCluster({...i,sheetId:r})&&!this.isCellSkippableInCluster({...a,sheetId:r})?`endOfCluster`:`nextCluster`;for(;;){let e=this.getNextCellPosition(i,t,n);if(i.col===e.col&&i.row===e.row)break;let a=this.isCellSkippableInCluster({...e,sheetId:r});if(o===`endOfCluster`&&a)break;if(o===`nextCluster`&&!a){i=e;break}i=e}return t===`cols`?i.col:i.row}getNextCellPosition(e,t,n){let r=t===`cols`?`col`:`row`,i={...e};return i[r]=t===`cols`?this.getNextAvailableCol(n,i.col,i.row):this.getNextAvailableRow(n,i.col,i.row),{col:i.col,row:i.row}}getPosition(){return{...this.anchor.cell}}isCellSkippableInCluster(e){let t=this.getters.getMainCellPosition(e),n=this.getters.getEvaluatedCell(t);return n.type===`empty`||n.type===`text`&&n.value===``}};function tG(e){if(typeof e==`string`)return{};if(typeof e==`number`)return[];throw Error(`Cannot create new node`)}var nG=class{changes;commands=[];recordChanges(e){return this.changes=[],this.commands=[],e(),{changes:this.changes,commands:this.commands}}addCommand(e){this.commands.push(e)}addChange(...e){let t=e.pop(),n=e[0],r=e.at(-1),i=e.length-2;for(let t=1;t<=i;t++){let r=e[t];if(n[r]===void 0){let i=e[t+1];n[r]=tG(i)}n=n[r]}n[r]!==t&&(this.changes?.push({key:r,target:n,before:n[r]}),t===void 0?delete n[r]:n[r]=t)}};let rG=17781237,iG=17781238,aG=88853993,oG=88853994;function sG(e,t,n){let r=[[`xmlns:r`,cO],[`xmlns:a`,iO],[`xmlns:c`,aO]],i=cG({backgroundColor:e.data.backgroundColor,line:{color:`000000`}}),a=Y``;if(e.data.title?.text){let t=rw(qx(e.data.backgroundColor)),n=e.data.title.fontSize??16;a=Y`
|
|
2651
2651
|
<c:title>
|
|
2652
2652
|
${dG(e.data.title.text,t,n,e.data.title)}
|
|
2653
2653
|
<c:overlay val="0" />
|
|
@@ -3382,4 +3382,4 @@ You can download it directly instead.`,5),sticky:!1,type:`warning`});return}r=aw
|
|
|
3382
3382
|
<Relationships xmlns="${rO.Relationships}">
|
|
3383
3383
|
<Relationship ${q(e)} />
|
|
3384
3384
|
</Relationships>
|
|
3385
|
-
`),`_rels/.rels`)}function FK(e){let t={},n=[];for(let r of e.sheets){let e=r.name.slice(0,31);e=$t(e,n,{compute:(e,t)=>e.slice(0,31-String(t).length)+t}),n.push(e),e!==r.name&&(t[r.name]=e,r.name=e)}if(!Object.keys(t).length)return e;let r=Object.keys(t).sort((e,t)=>t.length-e.length),i=JSON.stringify(e);for(let e of r){let n=RegExp(`'?${at(e)}'?!`,`g`);i=i.replaceAll(n,n=>{let r=t[e];return n.replace(e,r)})}return JSON.parse(i)}function IK(e){for(let t of e.sheets)t.tables=t.tables.filter(e=>br(ar(e.range)).numberOfRows>1);return e}var LK=class extends Hd{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;coreViewPluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},n={},r=[],i=new al,a=!1){let o=performance.now();console.debug(`##### Model creation #####`),super(),qi(),r=Nj(e,r);let s=Tj(e,a);this.state=new nG,this.uuidGenerator=i,this.config=this.setupConfig(n),this.session=this.setupSession(s.revisionId),this.coreGetters={},this.range=new AV(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.copyFormulaStringForSheet=this.range.copyFormulaStringForSheet.bind(this.range),this.getters={isReadonly:()=>this.config.mode===`readonly`||this.config.mode===`dashboard`,isDashboard:()=>this.config.mode===`dashboard`},this.selection=new eG(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.coreViewPluginConfig=this.setupCoreViewPluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(let e of tW.getAll())this.setupCorePlugin(e,s);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(r);for(let e of iW.getAll()){let t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(let e of rW.getAll()){let t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(let e of nW.getAll()){let 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(),n.snapshotRequested||e[`[Content_Types].xml`]&&!this.getters.isReadonly()){let e=performance.now();console.debug(`Snapshot requested`),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug(`Snapshot taken in`,performance.now()-e,`ms`)}(0,t.markRaw)(this),console.debug(`Model created in`,performance.now()-o,`ms`),console.debug(`######`)}joinSession(){this.session.join(this.config.client)}async leaveSession(){let e=this.getters.isReadonly()?void 0:kt(()=>this.exportData());await this.session.leave(e)}setupUiPlugin(e){let t=new e(this.uiPluginConfig);for(let n of e.getters){if(!(n in t))throw Error(`Invalid getter name: ${n} for plugin ${t.constructor}`);if(n in this.getters)throw Error(`Getter "${n}" is already defined.`);this.getters[n]=t[n].bind(t)}for(let n of e.layers)this.renderers[n]||(this.renderers[n]=[]),this.renderers[n].push(t);return t}setupCoreViewPlugin(e){let t=new e(this.coreViewPluginConfig);for(let n of e.getters){if(!(n in t))throw Error(`Invalid getter name: ${n} for plugin ${t.constructor}`);if(n in this.getters)throw Error(`Getter "${n}" is already defined.`);this.getters[n]=t[n].bind(t)}return t}setupCorePlugin(e,t){let n=new e(this.corePluginConfig);for(let t of e.getters){if(!(t in n))throw Error(`Invalid getter name: ${t} for plugin ${n.constructor}`);if(t in this.coreGetters)throw Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=n[t].bind(n)}n.import(t),this.corePlugins.push(n),this.coreHandlers.push(n),this.handlers.push(n)}onRemoteRevisionReceived({commands:e}){for(let t of e){let e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new rU(XW({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{if(!this.checkDispatchAllowed(e).isSuccessful){this.dispatchToHandlers(this.coreHandlers,{type:`UNDO`,commands:[e]});return}this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1}}),this.config.transportService,e)}setupSessionEvents(){this.session.on(`remote-revision-received`,this,this.onRemoteRevisionReceived),this.session.on(`revision-undone`,this,({commands:e})=>{this.dispatchFromCorePlugin(`UNDO`,{commands:e}),this.finalize()}),this.session.on(`revision-redone`,this,({commands:e})=>{this.dispatchFromCorePlugin(`REDO`,{commands:e}),this.finalize()}),this.session.on(`unexpected-revision-id`,this,()=>this.trigger(`unexpected-revision-id`)),this.session.on(`collaborative-event-received`,this,()=>{this.trigger(`update`)})}setupConfig(e){let t=e.client||{id:this.uuidGenerator.smallUuid(),name:O(`Anonymous`).toString()},n=e.transportService||new HW;return{...e,mode:e.mode||`normal`,custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:n,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){let t=e.loadLocales||(()=>Promise.resolve(pa));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){let t=ca(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some(e=>e!==`Success`)?new ua(t.flat()):ua.Success}checkDispatchAllowedCoreCommand(e){let 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(let e of this.handlers)e.finalize();this.status=0,this.trigger(`command-finalized`)}canDispatch=(e,t)=>this.checkDispatchAllowed(RK(e,t));dispatch=(e,t)=>{let n=RK(e,t),r=this.status;if(this.getters.isReadonly()&&!la(n))return new ua(`Readonly`);if(!this.session.canApplyOptimisticUpdate())return new ua(`WaitingSessionConfirmation`);switch(r){case 0:let t=this.checkDispatchAllowed(n);if(!t.isSuccessful)return this.trigger(`update`),t;this.status=1;let{changes:r,commands:i}=this.state.recordChanges(()=>{let t=performance.now();ca(n)&&this.state.addCommand(n),this.dispatchToHandlers(this.handlers,n),this.finalize();let r=performance.now()-t;r>5&&console.debug(e,r,`ms`)});this.session.save(n,i,r),this.status=0,this.trigger(`update`);break;case 1:if(ca(n)){let e=this.checkDispatchAllowed(n);if(!e.isSuccessful)return e;this.state.addCommand(n)}this.dispatchToHandlers(this.handlers,n);break;case 3:throw Error(`Cannot dispatch commands in the finalize state`);case 2:if(ca(n))throw Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,n)}return ua.Success};dispatchFromCorePlugin=(e,t)=>{let n=RK(e,t),r=this.status;this.status=2;let i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,n),this.status=r,ua.Success};dispatchToHandlers(e,t){let n=ca(t);for(let r of e)!n&&r instanceof mV||r.beforeHandle(t);for(let r of e)!n&&r instanceof mV||r.handle(t);this.trigger(`command-dispatched`,t)}drawLayer(e,t){let n=this.renderers[t];if(n)for(let r of n)e.ctx.save(),r.drawLayer(e,t),e.ctx.restore()}exportData(){let e=Bj();for(let t of this.handlers)t instanceof mV&&t.export(e);return e.revisionId=this.session.getRevisionId()||`START_REVISION`,e=b(e),e}updateMode(e){this.config.mode=e,this.trigger(`update`)}exportXLSX(){this.dispatch(`EVALUATE_CELLS`);let e=Hj();for(let t of this.handlers)t instanceof pV&&t.exportForExcel(e);return e=b(e),EK(e)}garbageCollectExternalResources(){for(let e of this.corePlugins)e.garbageCollectExternalResources()}};function RK(e,t={}){let n=b(t);return n.type=e,n}let zK={},BK={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:26,HEADER_WIDTH:48,BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:96,DEFAULT_CELL_HEIGHT:23,SCROLLBAR_WIDTH:15},VK={autoCompleteProviders:oC,autofillModifiersRegistry:kC,autofillRulesRegistry:AC,cellMenuRegistry:MP,colMenuRegistry:TI,errorTypes:va,linkMenuRegistry:fM,functionRegistry:ix,featurePluginRegistry:nW,iconsOnCellRegistry:hO,statefulUIPluginRegistry:rW,coreViewsPluginRegistry:iW,corePluginRegistry:tW,rowMenuRegistry:AI,sidePanelRegistry:nB,figureRegistry:kD,chartSidePanelComponentRegistry:eR,chartComponentRegistry:RE,chartRegistry:LE,chartSubtypeRegistry:BE,topbarMenuRegistry:PI,topbarComponentRegistry:II,clickableCellRegistry:aW,otRegistry:FI,inverseCommandRegistry:FD,urlRegistry:ho,cellPopoverRegistry:BC,numberFormatMenuRegistry:EI,repeatLocalCommandTransformRegistry:LU,repeatCommandTransformRegistry:IU,clipboardHandlersRegistries:zd,pivotRegistry:bz,pivotTimeAdapterRegistry:qu,pivotSidePanelRegistry:Ez,pivotNormalizationValueRegistry:wd,supportedPivotPositionalFormulaRegistry:wC,pivotToFunctionValueRegistry:Td,migrationStepRegistry:bj,chartJsExtensionRegistry:pf},HK={arg:W,isEvaluationError:P,toBoolean:L,toJsDate:R,toNumber:F,toString:I,toNormalizedPivotValue:bd,toFunctionPivotValue:Sd,toXC:T,toZone:ar,toUnboundedZone:ir,toCartesian:Jn,numberToLetters:zn,lettersToNumber:Bn,UuidGenerator:al,formatValue:B,createCurrencyFormat:gs,ColorGenerator:Pn,computeTextWidth:Vc,createEmptyWorkbookData:Bj,createEmptySheet:zj,createEmptyExcelSheet:Vj,rgbaToHex:mn,colorToRGBA:hn,positionToZone:E,isDefined:C,isMatrix:A,lazy:kt,genericRepeat:RU,createAction:m,createActions:f,transformRangeData:Vd,deepEquals:w,overlap:_r,union:pr,isInside:vr,deepCopy:b,expandZoneOnInsertion:lr,reduceZoneOnDeletion:fr,unquote:ct,getMaxObjectId:fd,getFunctionsFromTokens:kx,getFirstPivotFunction:SC,getNumberOfPivotFunctions:CC,parseDimension:hd,isDateOrDatetimeField:gd,makeFieldProposal:_C,insertTokenAfterArgSeparator:yC,insertTokenAfterLeftParenthesis:bC,mergeContiguousZones:zr,getPivotHighlights:MI,pivotTimeAdapter:Ju,UNDO_REDO_PIVOT_COMMANDS:_H,createPivotFormula:yd,areDomainArgsFieldsValid:vd,splitReference:ac,sanitizeSheetName:ut,getUniqueText:$t,isNumber:Li,isDateTime:ai},UK={isMarkdownLink:gt,parseMarkdownLink:yt,markdownLink:vt,openLink:bo,urlRepresentation:yo},WK={Checkbox:Yj,Section:Q,RoundColorPicker:dL,ChartDataSeries:JI,ChartErrorSection:XI,ChartLabelRange:ZI,ChartTitle:cL,ChartPanel:rR,ChartFigure:HE,ChartJsComponent:HS,Grid:dV,GridOverlay:VB,ScorecardChart:aC,LineConfigPanel:VL,BarConfigPanel:$I,PieChartDesignPanel:HL,GenericChartConfigPanel:QI,ChartWithAxisDesignPanel:gL,GaugeChartConfigPanel:bL,GaugeChartDesignPanel:FL,ScorecardChartConfigPanel:GL,ScorecardChartDesignPanel:KL,GeoChartDesignPanel:zL,RadarChartDesignPanel:UL,WaterfallChartDesignPanel:$L,ComboChartDesignPanel:_L,FunnelChartDesignPanel:yL,ChartTypePicker:tR,FigureComponent:rB,Menu:EM,Popover:SM,SelectionInput:qI,ValidationMessages:YI,AddDimensionButton:UR,PivotDimensionGranularity:qR,PivotDimensionOrder:JR,PivotDimension:KR,PivotLayoutConfigurator:QR,PivotHTMLRenderer:fV,PivotDeferUpdate:VR,PivotTitleSection:$R,CogWheelMenu:GR,TextInput:WR,SidePanelCollapsible:tL,RadioSelection:uL,GeoChartRegionSelectSection:IL},GK={useDragAndDropListItems:RI,useHighlights:cR,useHighlightsOnHover:sR},KK={useStoreProvider:qd,DependencyContainer:Ud,CellPopoverStore:tM,ComposerFocusStore:nf,CellComposerStore:_B,FindAndReplaceStore:FR,HighlightStore:uC,DelayedHoveredCellStore:eM,HoveredTableStore:zB,ModelStore:Qd,NotificationStore:dC,RendererStore:$d,SelectionInputStore:KI,SpreadsheetStore:ef,useStore:V,useLocalStore:Jd,SidePanelStore:sV,PivotSidePanelStore:wz,PivotMeasureDisplayPanelStore:zR};function qK(e,t){return ix.add(e,t),{addFunction:(e,t)=>qK(e,t)}}let JK={DEFAULT_LOCALE:k,HIGHLIGHT_COLOR:_,PIVOT_TABLE_CONFIG:et,ChartTerms:uw},YK={...mD,...tE};e.AbstractCellClipboardHandler=gl,e.AbstractChart=US,e.AbstractFigureClipboardHandler=Ad,e.CellErrorType=j,e.CommandResult=fa,e.CorePlugin=mV,e.CoreViewPlugin=RV,e.DispatchResult=ua,e.EvaluationError=M,e.Model=LK,e.PivotRuntimeDefinition=ez,e.Registry=h,e.Revision=tU,e.SPREADSHEET_DIMENSIONS=BK,e.Spreadsheet=VW,e.SpreadsheetPivotTable=iz,e.UIPlugin=bH,e.__info__=zK,e.addFunction=qK,e.addRenderingLayer=_a,e.astToFormula=zv,e.chartHelpers=YK,e.compile=bx,e.compileTokens=xx,e.components=WK,e.constants=JK,e.convertAstNodes=Fv,e.coreTypes=sa,e.findCellInNewZone=kr,e.functionCache=yx,e.helpers=HK,e.hooks=GK,e.invalidateCFEvaluationCommands=ia,e.invalidateChartEvaluationCommands=na,e.invalidateDependenciesCommands=ra,e.invalidateEvaluationCommands=ta,e.iterateAstNodes=Iv,e.links=UK,e.load=Tj,e.parse=Nv,e.parseTokens=Pv,e.readonlyAllowedCommands=oa,e.registries=VK,e.setDefaultSheetViewSize=Qe,e.setTranslationMethod=Ki,e.stores=KK,e.tokenColors=mC,e.tokenize=bl,zK.version=`18.3.47`,zK.date=`2026-05-12T12:18:07.038Z`,zK.hash=`8b8bc44`})(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|
|
3385
|
+
`),`_rels/.rels`)}function FK(e){let t={},n=[];for(let r of e.sheets){let e=r.name.slice(0,31);e=$t(e,n,{compute:(e,t)=>e.slice(0,31-String(t).length)+t}),n.push(e),e!==r.name&&(t[r.name]=e,r.name=e)}if(!Object.keys(t).length)return e;let r=Object.keys(t).sort((e,t)=>t.length-e.length),i=JSON.stringify(e);for(let e of r){let n=RegExp(`'?${at(e)}'?!`,`g`);i=i.replaceAll(n,n=>{let r=t[e];return n.replace(e,r)})}return JSON.parse(i)}function IK(e){for(let t of e.sheets)t.tables=t.tables.filter(e=>br(ar(e.range)).numberOfRows>1);return e}var LK=class extends Hd{corePlugins=[];statefulUIPlugins=[];range;session;isReplayingCommand=!1;renderers={};status=0;config;corePluginConfig;coreViewPluginConfig;uiPluginConfig;state;selection;getters;coreGetters;uuidGenerator;handlers=[];uiHandlers=[];coreHandlers=[];constructor(e={},n={},r=[],i=new al,a=!1){let o=performance.now();console.debug(`##### Model creation #####`),super(),qi(),r=Nj(e,r);let s=Tj(e,a);this.state=new nG,this.uuidGenerator=i,this.config=this.setupConfig(n),this.session=this.setupSession(s.revisionId),this.coreGetters={},this.range=new AV(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.copyFormulaStringForSheet=this.range.copyFormulaStringForSheet.bind(this.range),this.getters={isReadonly:()=>this.config.mode===`readonly`||this.config.mode===`dashboard`,isDashboard:()=>this.config.mode===`dashboard`},this.selection=new eG(this.getters),this.coreHandlers.push(this.range),this.handlers.push(this.range),this.corePluginConfig=this.setupCorePluginConfig(),this.coreViewPluginConfig=this.setupCoreViewPluginConfig(),this.uiPluginConfig=this.setupUiPluginConfig();for(let e of tW.getAll())this.setupCorePlugin(e,s);Object.assign(this.getters,this.coreGetters),this.session.loadInitialMessages(r);for(let e of iW.getAll()){let t=this.setupCoreViewPlugin(e);this.handlers.push(t),this.uiHandlers.push(t),this.coreHandlers.push(t)}for(let e of rW.getAll()){let t=this.setupUiPlugin(e);this.statefulUIPlugins.push(t),this.handlers.push(t),this.uiHandlers.push(t)}for(let e of nW.getAll()){let 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(),n.snapshotRequested||e[`[Content_Types].xml`]&&!this.getters.isReadonly()){let e=performance.now();console.debug(`Snapshot requested`),this.session.snapshot(this.exportData()),this.garbageCollectExternalResources(),console.debug(`Snapshot taken in`,performance.now()-e,`ms`)}(0,t.markRaw)(this),console.debug(`Model created in`,performance.now()-o,`ms`),console.debug(`######`)}joinSession(){this.session.join(this.config.client)}async leaveSession(){let e=this.getters.isReadonly()?void 0:kt(()=>this.exportData());await this.session.leave(e)}setupUiPlugin(e){let t=new e(this.uiPluginConfig);for(let n of e.getters){if(!(n in t))throw Error(`Invalid getter name: ${n} for plugin ${t.constructor}`);if(n in this.getters)throw Error(`Getter "${n}" is already defined.`);this.getters[n]=t[n].bind(t)}for(let n of e.layers)this.renderers[n]||(this.renderers[n]=[]),this.renderers[n].push(t);return t}setupCoreViewPlugin(e){let t=new e(this.coreViewPluginConfig);for(let n of e.getters){if(!(n in t))throw Error(`Invalid getter name: ${n} for plugin ${t.constructor}`);if(n in this.getters)throw Error(`Getter "${n}" is already defined.`);this.getters[n]=t[n].bind(t)}return t}setupCorePlugin(e,t){let n=new e(this.corePluginConfig);for(let t of e.getters){if(!(t in n))throw Error(`Invalid getter name: ${t} for plugin ${n.constructor}`);if(t in this.coreGetters)throw Error(`Getter "${t}" is already defined.`);this.coreGetters[t]=n[t].bind(n)}n.import(t),this.corePlugins.push(n),this.coreHandlers.push(n),this.handlers.push(n)}onRemoteRevisionReceived({commands:e}){for(let t of e){let e=this.status;this.status=2,this.dispatchToHandlers(this.statefulUIPlugins,t),this.status=e}this.finalize()}setupSession(e){return new rU(XW({initialRevisionId:e,recordChanges:this.state.recordChanges.bind(this.state),dispatch:e=>{if(!this.checkDispatchAllowed(e).isSuccessful){this.dispatchToHandlers(this.coreHandlers,{type:`UNDO`,commands:[e]});return}this.isReplayingCommand=!0,this.dispatchToHandlers(this.coreHandlers,e),this.isReplayingCommand=!1}}),this.config.transportService,e)}setupSessionEvents(){this.session.on(`remote-revision-received`,this,this.onRemoteRevisionReceived),this.session.on(`revision-undone`,this,({commands:e})=>{this.dispatchFromCorePlugin(`UNDO`,{commands:e}),this.finalize()}),this.session.on(`revision-redone`,this,({commands:e})=>{this.dispatchFromCorePlugin(`REDO`,{commands:e}),this.finalize()}),this.session.on(`unexpected-revision-id`,this,()=>this.trigger(`unexpected-revision-id`)),this.session.on(`collaborative-event-received`,this,()=>{this.trigger(`update`)})}setupConfig(e){let t=e.client||{id:this.uuidGenerator.smallUuid(),name:O(`Anonymous`).toString()},n=e.transportService||new HW;return{...e,mode:e.mode||`normal`,custom:e.custom||{},external:this.setupExternalConfig(e.external||{}),transportService:n,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){let t=e.loadLocales||(()=>Promise.resolve(pa));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){let t=ca(e)?this.checkDispatchAllowedCoreCommand(e):this.checkDispatchAllowedLocalCommand(e);return t.some(e=>e!==`Success`)?new ua(t.flat()):ua.Success}checkDispatchAllowedCoreCommand(e){let 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(let e of this.handlers)e.finalize();this.status=0,this.trigger(`command-finalized`)}canDispatch=(e,t)=>this.checkDispatchAllowed(RK(e,t));dispatch=(e,t)=>{let n=RK(e,t),r=this.status;if(this.getters.isReadonly()&&!la(n))return new ua(`Readonly`);if(!this.session.canApplyOptimisticUpdate())return new ua(`WaitingSessionConfirmation`);switch(r){case 0:let t=this.checkDispatchAllowed(n);if(!t.isSuccessful)return this.trigger(`update`),t;this.status=1;let{changes:r,commands:i}=this.state.recordChanges(()=>{let t=performance.now();ca(n)&&this.state.addCommand(n),this.dispatchToHandlers(this.handlers,n),this.finalize();let r=performance.now()-t;r>5&&console.debug(e,r,`ms`)});this.session.save(n,i,r),this.status=0,this.trigger(`update`);break;case 1:if(ca(n)){let e=this.checkDispatchAllowed(n);if(!e.isSuccessful)return e;this.state.addCommand(n)}this.dispatchToHandlers(this.handlers,n);break;case 3:throw Error(`Cannot dispatch commands in the finalize state`);case 2:if(ca(n))throw Error(`A UI plugin cannot dispatch ${e} while handling a core command`);this.dispatchToHandlers(this.handlers,n)}return ua.Success};dispatchFromCorePlugin=(e,t)=>{let n=RK(e,t),r=this.status;this.status=2;let i=this.isReplayingCommand?this.coreHandlers:this.handlers;return this.dispatchToHandlers(i,n),this.status=r,ua.Success};dispatchToHandlers(e,t){let n=ca(t);for(let r of e)!n&&r instanceof mV||r.beforeHandle(t);for(let r of e)!n&&r instanceof mV||r.handle(t);this.trigger(`command-dispatched`,t)}drawLayer(e,t){let n=this.renderers[t];if(n)for(let r of n)e.ctx.save(),r.drawLayer(e,t),e.ctx.restore()}exportData(){let e=Bj();for(let t of this.handlers)t instanceof mV&&t.export(e);return e.revisionId=this.session.getRevisionId()||`START_REVISION`,e=b(e),e}updateMode(e){this.config.mode=e,this.trigger(`update`)}exportXLSX(){this.dispatch(`EVALUATE_CELLS`);let e=Hj();for(let t of this.handlers)t instanceof pV&&t.exportForExcel(e);return e=b(e),EK(e)}garbageCollectExternalResources(){for(let e of this.corePlugins)e.garbageCollectExternalResources()}};function RK(e,t={}){let n=b(t);return n.type=e,n}let zK={},BK={MIN_ROW_HEIGHT:10,MIN_COL_WIDTH:5,HEADER_HEIGHT:26,HEADER_WIDTH:48,BOTTOMBAR_HEIGHT:36,DEFAULT_CELL_WIDTH:96,DEFAULT_CELL_HEIGHT:23,SCROLLBAR_WIDTH:15},VK={autoCompleteProviders:oC,autofillModifiersRegistry:kC,autofillRulesRegistry:AC,cellMenuRegistry:MP,colMenuRegistry:TI,errorTypes:va,linkMenuRegistry:fM,functionRegistry:ix,featurePluginRegistry:nW,iconsOnCellRegistry:hO,statefulUIPluginRegistry:rW,coreViewsPluginRegistry:iW,corePluginRegistry:tW,rowMenuRegistry:AI,sidePanelRegistry:nB,figureRegistry:kD,chartSidePanelComponentRegistry:eR,chartComponentRegistry:RE,chartRegistry:LE,chartSubtypeRegistry:BE,topbarMenuRegistry:PI,topbarComponentRegistry:II,clickableCellRegistry:aW,otRegistry:FI,inverseCommandRegistry:FD,urlRegistry:ho,cellPopoverRegistry:BC,numberFormatMenuRegistry:EI,repeatLocalCommandTransformRegistry:LU,repeatCommandTransformRegistry:IU,clipboardHandlersRegistries:zd,pivotRegistry:bz,pivotTimeAdapterRegistry:qu,pivotSidePanelRegistry:Ez,pivotNormalizationValueRegistry:wd,supportedPivotPositionalFormulaRegistry:wC,pivotToFunctionValueRegistry:Td,migrationStepRegistry:bj,chartJsExtensionRegistry:pf},HK={arg:W,isEvaluationError:P,toBoolean:L,toJsDate:R,toNumber:F,toString:I,toNormalizedPivotValue:bd,toFunctionPivotValue:Sd,toXC:T,toZone:ar,toUnboundedZone:ir,toCartesian:Jn,numberToLetters:zn,lettersToNumber:Bn,UuidGenerator:al,formatValue:B,createCurrencyFormat:gs,ColorGenerator:Pn,computeTextWidth:Vc,createEmptyWorkbookData:Bj,createEmptySheet:zj,createEmptyExcelSheet:Vj,rgbaToHex:mn,colorToRGBA:hn,positionToZone:E,isDefined:C,isMatrix:A,lazy:kt,genericRepeat:RU,createAction:m,createActions:f,transformRangeData:Vd,deepEquals:w,overlap:_r,union:pr,isInside:vr,deepCopy:b,expandZoneOnInsertion:lr,reduceZoneOnDeletion:fr,unquote:ct,getMaxObjectId:fd,getFunctionsFromTokens:kx,getFirstPivotFunction:SC,getNumberOfPivotFunctions:CC,parseDimension:hd,isDateOrDatetimeField:gd,makeFieldProposal:_C,insertTokenAfterArgSeparator:yC,insertTokenAfterLeftParenthesis:bC,mergeContiguousZones:zr,getPivotHighlights:MI,pivotTimeAdapter:Ju,UNDO_REDO_PIVOT_COMMANDS:_H,createPivotFormula:yd,areDomainArgsFieldsValid:vd,splitReference:ac,sanitizeSheetName:ut,getUniqueText:$t,isNumber:Li,isDateTime:ai},UK={isMarkdownLink:gt,parseMarkdownLink:yt,markdownLink:vt,openLink:bo,urlRepresentation:yo},WK={Checkbox:Yj,Section:Q,RoundColorPicker:dL,ChartDataSeries:JI,ChartErrorSection:XI,ChartLabelRange:ZI,ChartTitle:cL,ChartPanel:rR,ChartFigure:HE,ChartJsComponent:HS,Grid:dV,GridOverlay:VB,ScorecardChart:aC,LineConfigPanel:VL,BarConfigPanel:$I,PieChartDesignPanel:HL,GenericChartConfigPanel:QI,ChartWithAxisDesignPanel:gL,GaugeChartConfigPanel:bL,GaugeChartDesignPanel:FL,ScorecardChartConfigPanel:GL,ScorecardChartDesignPanel:KL,GeoChartDesignPanel:zL,RadarChartDesignPanel:UL,WaterfallChartDesignPanel:$L,ComboChartDesignPanel:_L,FunnelChartDesignPanel:yL,ChartTypePicker:tR,FigureComponent:rB,Menu:EM,Popover:SM,SelectionInput:qI,ValidationMessages:YI,AddDimensionButton:UR,PivotDimensionGranularity:qR,PivotDimensionOrder:JR,PivotDimension:KR,PivotLayoutConfigurator:QR,PivotHTMLRenderer:fV,PivotDeferUpdate:VR,PivotTitleSection:$R,CogWheelMenu:GR,TextInput:WR,SidePanelCollapsible:tL,RadioSelection:uL,GeoChartRegionSelectSection:IL},GK={useDragAndDropListItems:RI,useHighlights:cR,useHighlightsOnHover:sR},KK={useStoreProvider:qd,DependencyContainer:Ud,CellPopoverStore:tM,ComposerFocusStore:nf,CellComposerStore:_B,FindAndReplaceStore:FR,HighlightStore:uC,DelayedHoveredCellStore:eM,HoveredTableStore:zB,ModelStore:Qd,NotificationStore:dC,RendererStore:$d,SelectionInputStore:KI,SpreadsheetStore:ef,useStore:V,useLocalStore:Jd,SidePanelStore:sV,PivotSidePanelStore:wz,PivotMeasureDisplayPanelStore:zR};function qK(e,t){return ix.add(e,t),{addFunction:(e,t)=>qK(e,t)}}let JK={DEFAULT_LOCALE:k,HIGHLIGHT_COLOR:_,PIVOT_TABLE_CONFIG:et,ChartTerms:uw},YK={...mD,...tE};e.AbstractCellClipboardHandler=gl,e.AbstractChart=US,e.AbstractFigureClipboardHandler=Ad,e.CellErrorType=j,e.CommandResult=fa,e.CorePlugin=mV,e.CoreViewPlugin=RV,e.DispatchResult=ua,e.EvaluationError=M,e.Model=LK,e.PivotRuntimeDefinition=ez,e.Registry=h,e.Revision=tU,e.SPREADSHEET_DIMENSIONS=BK,e.Spreadsheet=VW,e.SpreadsheetPivotTable=iz,e.UIPlugin=bH,e.__info__=zK,e.addFunction=qK,e.addRenderingLayer=_a,e.astToFormula=zv,e.chartHelpers=YK,e.compile=bx,e.compileTokens=xx,e.components=WK,e.constants=JK,e.convertAstNodes=Fv,e.coreTypes=sa,e.findCellInNewZone=kr,e.functionCache=yx,e.helpers=HK,e.hooks=GK,e.invalidateCFEvaluationCommands=ia,e.invalidateChartEvaluationCommands=na,e.invalidateDependenciesCommands=ra,e.invalidateEvaluationCommands=ta,e.iterateAstNodes=Iv,e.links=UK,e.load=Tj,e.parse=Nv,e.parseTokens=Pv,e.readonlyAllowedCommands=oa,e.registries=VK,e.setDefaultSheetViewSize=Qe,e.setTranslationMethod=Ki,e.stores=KK,e.tokenColors=mC,e.tokenize=bl,zK.version=`18.3.48`,zK.date=`2026-05-15T07:05:43.612Z`,zK.hash=`76bed65`})(this.o_spreadsheet=this.o_spreadsheet||{},owl);
|